diff options
author | Puck Meerburg <puck@puckipedia.com> | 2023-09-21 09:14:44 +0000 |
---|---|---|
committer | Puck Meerburg <puck@puckipedia.com> | 2023-09-21 09:14:44 +0000 |
commit | 5742d5a8fdee5dd31035b9b497458f1eea931a5b (patch) | |
tree | 5711311e6cd91861a3dd1c8d5313a47095da4bd8 /pkgs/development/perl-modules | |
parent | 73afddd2a5f4d15067a4aa08dbf755530763d62b (diff) | |
download | nixpkgs-5742d5a8fdee5dd31035b9b497458f1eea931a5b.tar nixpkgs-5742d5a8fdee5dd31035b9b497458f1eea931a5b.tar.gz nixpkgs-5742d5a8fdee5dd31035b9b497458f1eea931a5b.tar.bz2 nixpkgs-5742d5a8fdee5dd31035b9b497458f1eea931a5b.tar.lz nixpkgs-5742d5a8fdee5dd31035b9b497458f1eea931a5b.tar.xz nixpkgs-5742d5a8fdee5dd31035b9b497458f1eea931a5b.tar.zst nixpkgs-5742d5a8fdee5dd31035b9b497458f1eea931a5b.zip |
perlPackages.SDL: import patch
Diffstat (limited to 'pkgs/development/perl-modules')
-rw-r--r-- | pkgs/development/perl-modules/sdl-modern-perl.patch | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/pkgs/development/perl-modules/sdl-modern-perl.patch b/pkgs/development/perl-modules/sdl-modern-perl.patch new file mode 100644 index 00000000000..c97eeb03448 --- /dev/null +++ b/pkgs/development/perl-modules/sdl-modern-perl.patch @@ -0,0 +1,64 @@ +From d734d03862d7dcc776bd2fa3ba662cdd5879b32e Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Petr=20P=C3=ADsa=C5=99?= <ppisar@redhat.com> +Date: Wed, 12 Jul 2023 17:55:27 +0200 +Subject: [PATCH] Adapt to perl 5.37.1 + +Perl 5.37.1 removed a deprecated sv_nv() macro and SDL fails to build +with Perl 5.38.0: + +lib/SDLx/Controller/Interface.xs:60:26: error: implicit declaration of function 'sv_nv' + 60 | out->dv_x = sv_nv(temp); + | ^~~~~ + +Users are advised to use SvNVx() macro instead. SvNVx() seems to have been +available all the time (it predates a commit from 1993-10-07). + +This patch does that. + +https://github.com/PerlGameDev/SDL/issues/303 +--- + src/SDLx/Controller/Interface.xs | 12 ++++++------ + 1 file changed, 6 insertions(+), 6 deletions(-) + +diff --git a/src/SDLx/Controller/Interface.xs b/src/SDLx/Controller/Interface.xs +index 3dc202b7..d326c885 100644 +--- a/src/SDLx/Controller/Interface.xs ++++ b/src/SDLx/Controller/Interface.xs +@@ -57,15 +57,15 @@ void evaluate(SDLx_Interface *obj, SDLx_Derivative *out, SDLx_State *initial, fl + + SV *temp; + temp = av_pop(accel); +- out->dv_x = sv_nv(temp); ++ out->dv_x = SvNVx(temp); + SvREFCNT_dec(temp); + + temp = av_pop(accel); +- out->dv_y = sv_nv(temp); ++ out->dv_y = SvNVx(temp); + SvREFCNT_dec(temp); + + temp = av_pop(accel); +- out->dang_v = sv_nv(temp); ++ out->dang_v = SvNVx(temp); + SvREFCNT_dec(temp); + + SvREFCNT_dec((SV *)accel); +@@ -90,15 +90,15 @@ void evaluate_dt(SDLx_Interface *obj, SDLx_Derivative *out, SDLx_State *initial, + + SV *temp; + temp = av_pop(accel); +- out->dv_x = sv_nv(temp); ++ out->dv_x = SvNVx(temp); + SvREFCNT_dec(temp); + + temp = av_pop(accel); +- out->dv_y = sv_nv(temp); ++ out->dv_y = SvNVx(temp); + SvREFCNT_dec(temp); + + temp = av_pop(accel); +- out->dang_v = sv_nv(temp); ++ out->dang_v = SvNVx(temp); + SvREFCNT_dec(temp); + + SvREFCNT_dec((SV *)accel); |