0.38 bump
This commit is contained in:
		
							parent
							
								
									b052e10401
								
							
						
					
					
						commit
						fc069b61d0
					
				
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -31,3 +31,4 @@ | |||||||
| /XS-Parse-Keyword-0.34.tar.gz | /XS-Parse-Keyword-0.34.tar.gz | ||||||
| /XS-Parse-Keyword-0.36.tar.gz | /XS-Parse-Keyword-0.36.tar.gz | ||||||
| /XS-Parse-Keyword-0.37.tar.gz | /XS-Parse-Keyword-0.37.tar.gz | ||||||
|  | /XS-Parse-Keyword-0.38.tar.gz | ||||||
|  | |||||||
| @ -1,78 +0,0 @@ | |||||||
| From 2e2114556330296d7451b7dd11f9ead7d0b40b4f Mon Sep 17 00:00:00 2001 |  | ||||||
| From: =?UTF-8?q?Petr=20P=C3=ADsa=C5=99?= <ppisar@redhat.com> |  | ||||||
| Date: Wed, 26 Jul 2023 13:21:20 +0200 |  | ||||||
| Subject: [PATCH] No special linker flags for checking for PL_infix_plugin |  | ||||||
| MIME-Version: 1.0 |  | ||||||
| Content-Type: text/plain; charset=UTF-8 |  | ||||||
| Content-Transfer-Encoding: 8bit |  | ||||||
| 
 |  | ||||||
| $Config{libs} lists all discovered libraries for optional perl |  | ||||||
| extensions. If perl is built dynamically, there is no need to link an |  | ||||||
| executable to all the libraries. For this purpose there is |  | ||||||
| $Config{perllibs}. |  | ||||||
| 
 |  | ||||||
| Actually the extensions can be uninstalled when building |  | ||||||
| XS-Parse-Keyword and the check would fail like this: |  | ||||||
| 
 |  | ||||||
| Checking for PL_infix_plugin... |  | ||||||
| test-56-1.c: In function 'main': |  | ||||||
| test-56-1.c:6:29: warning: variable 'def' set but not used [-Wunused-but-set-variable] |  | ||||||
|     6 |    struct Perl_custom_infix def; |  | ||||||
|       |                             ^~~ |  | ||||||
| /usr/bin/ld: cannot find -lgdbm: No such file or directory |  | ||||||
| /usr/bin/ld: cannot find -ldb: No such file or directory |  | ||||||
| 
 |  | ||||||
| $Config{perllibs} should be used instead. |  | ||||||
| 
 |  | ||||||
| In reality both $Config{libs} and $Config{perllibs} are wrong because |  | ||||||
| they list libraries used for building perl. The only library needed for |  | ||||||
| building perl extensions is -lperl itself. Unfortunately %Config does |  | ||||||
| not make the distinction and does not provide any variable which would |  | ||||||
| contain only required flags (i.e. -lperl and additional libraries |  | ||||||
| necessary for a statically linked perl). |  | ||||||
| 
 |  | ||||||
| At the end, the Keyword.so is also not linked to all the libraries. |  | ||||||
| 
 |  | ||||||
| In the actual reallity, the check program does use any perl function |  | ||||||
| or variable, hence strictely speaking the program does not have to |  | ||||||
| link to libper.so at all and @linker_flags should be empty. |  | ||||||
| 
 |  | ||||||
| That's what this patch does. |  | ||||||
| 
 |  | ||||||
| It might breaks what upstream fixed in 0.24, but for dynamic ELF |  | ||||||
| systems it's the best solution. |  | ||||||
| 
 |  | ||||||
| Signed-off-by: Petr Písař <ppisar@redhat.com> |  | ||||||
| ---
 |  | ||||||
|  Build.PL | 10 ---------- |  | ||||||
|  1 file changed, 10 deletions(-) |  | ||||||
| 
 |  | ||||||
| diff --git a/Build.PL b/Build.PL
 |  | ||||||
| index 27aa208..560dc75 100644
 |  | ||||||
| --- a/Build.PL
 |  | ||||||
| +++ b/Build.PL
 |  | ||||||
| @@ -40,21 +40,11 @@ EOF
 |  | ||||||
|  { |  | ||||||
|     print "Checking for PL_infix_plugin...\n"; |  | ||||||
|   |  | ||||||
| -   # Teach $cc how to find and link to libperl
 |  | ||||||
| -   require Config;
 |  | ||||||
| -   require Text::ParseWords;
 |  | ||||||
| -
 |  | ||||||
| -   my @linker_flags = (
 |  | ||||||
| -      "-L" . File::Spec->catdir($Config::Config{archlibexp}, "CORE"),
 |  | ||||||
| -      "-lperl", Text::ParseWords::shellwords( $Config::Config{libs} ),
 |  | ||||||
| -   );
 |  | ||||||
| -
 |  | ||||||
|     my $have_pl_infix_plugin = 0; |  | ||||||
|   |  | ||||||
|     $have_pl_infix_plugin = 1 if grep { $_ eq "--have-pl_infix_plugin" } @ARGV; |  | ||||||
|   |  | ||||||
|     $have_pl_infix_plugin ||= $cc->try_compile_run( |  | ||||||
| -      extra_linker_flags => \@linker_flags,
 |  | ||||||
|        source => <<'EOF' |  | ||||||
|  #include "EXTERN.h" |  | ||||||
|  #include "perl.h" |  | ||||||
| -- 
 |  | ||||||
| 2.41.0 |  | ||||||
| 
 |  | ||||||
| @ -1,47 +0,0 @@ | |||||||
| From 2f53d01f14661f7a663090582ac4f2a5414328b5 Mon Sep 17 00:00:00 2001 |  | ||||||
| From: =?UTF-8?q?Petr=20P=C3=ADsa=C5=99?= <ppisar@redhat.com> |  | ||||||
| Date: Wed, 9 Aug 2023 12:19:21 +0200 |  | ||||||
| Subject: [PATCH] Pass a format string to warn() |  | ||||||
| MIME-Version: 1.0 |  | ||||||
| Content-Type: text/plain; charset=UTF-8 |  | ||||||
| Content-Transfer-Encoding: 8bit |  | ||||||
| 
 |  | ||||||
| Building with -Werror=format-security compiler flag raised an error: |  | ||||||
| 
 |  | ||||||
|     gcc -Isrc/ -I/usr/lib64/perl5/CORE -fPIC -DHAVE_PL_INFIX_PLUGIN -I. -Ihax -c -D_REENTRANT -D_GNU_SOURCE -O2 '-flto=auto' -ffat-lto-objects -fexceptions -g -grecord-gcc-switches -pipe -Wall -Wno-complain-wrong-lang '-Werror=format-security' '-Wp,-U_FORTIFY_SOURCE,-D_FORTIFY_SOURCE=3' -Wp,-D_GLIBCXX_ASSERTIONS '-specs=/usr/lib/rpm/redhat/redhat-hardened-cc1' -fstack-protector-strong '-specs=/usr/lib/rpm/redhat/redhat-annobin-cc1' -m64 '-mtune=generic' -fasynchronous-unwind-tables -fstack-clash-protection -fcf-protection -fno-omit-frame-pointer -mno-omit-leaf-frame-pointer -fwrapv -fno-strict-aliasing -I/usr/local/include -D_LARGEFILE_SOURCE '-D_FILE_OFFSET_BITS=64' -O2 '-flto=auto' -ffat-lto-objects -fexceptions -g -grecord-gcc-switches -pipe -Wall '-Werror=format-security' '-Wp,-U_FORTIFY_SOURCE,-D_FORTIFY_SOURCE=3' -Wp,-D_GLIBCXX_ASSERTIONS '-specs=/usr/lib/rpm/redhat/redhat-hardened-cc1' -fstack-protector-strong '-specs=/usr/lib/rpm/redhat/redhat-annobin-cc1' -m64 '-mtune=generic' -fasynchronous-unwind-tables -fstack-clash-protection -fcf-protection -fno-omit-frame-pointer -mno-omit-leaf-frame-pointer -g -o src/keyword.o src/keyword.c |  | ||||||
|     [...] |  | ||||||
|     src/keyword.c: In function 'parse_piece': |  | ||||||
|     src/keyword.c:422:7: error: format not a string literal and no format arguments [-Werror=format-security] |  | ||||||
|       422 |       warn(piece->u.str); |  | ||||||
| 	  |       ^~~~ |  | ||||||
| 
 |  | ||||||
| This is becaue warn() expects a format string as a first argument, see proto.h: |  | ||||||
| 
 |  | ||||||
|     Perl_warn(pTHX_ const char *pat, ...) |  | ||||||
| 	    __attribute__format__(__printf__,pTHX_1,pTHX_2); |  | ||||||
| 
 |  | ||||||
| This patch fixes it by formatting the unknown string with "%s". |  | ||||||
| 
 |  | ||||||
| CPAN RT#149346 |  | ||||||
| 
 |  | ||||||
| Signed-off-by: Petr Písař <ppisar@redhat.com> |  | ||||||
| ---
 |  | ||||||
|  src/keyword.c | 2 +- |  | ||||||
|  1 file changed, 1 insertion(+), 1 deletion(-) |  | ||||||
| 
 |  | ||||||
| diff --git a/src/keyword.c b/src/keyword.c
 |  | ||||||
| index 30d0900..07aae26 100644
 |  | ||||||
| --- a/src/keyword.c
 |  | ||||||
| +++ b/src/keyword.c
 |  | ||||||
| @@ -419,7 +419,7 @@ static void parse_piece(pTHX_ SV *argsv, size_t *argidx, const struct XSParseKey
 |  | ||||||
|        int warnbit = piece->type >> 24; |  | ||||||
|        if(warnbit && !ckWARN(warnbit)) |  | ||||||
|          return; |  | ||||||
| -      warn(piece->u.str);
 |  | ||||||
| +      warn("%s", piece->u.str);
 |  | ||||||
|        return; |  | ||||||
|      } |  | ||||||
|   |  | ||||||
| -- 
 |  | ||||||
| 2.41.0 |  | ||||||
| 
 |  | ||||||
| @ -2,18 +2,13 @@ | |||||||
| %bcond_without perl_XS_Parse_Keyword_enables_optional_test | %bcond_without perl_XS_Parse_Keyword_enables_optional_test | ||||||
| 
 | 
 | ||||||
| Name:           perl-XS-Parse-Keyword | Name:           perl-XS-Parse-Keyword | ||||||
| Version:        0.37 | Version:        0.38 | ||||||
| Release:        1%{?dist} | Release:        1%{?dist} | ||||||
| Summary:        XS functions to assist in parsing keyword syntax | Summary:        XS functions to assist in parsing keyword syntax | ||||||
| License:        GPL-1.0-or-later OR Artistic-1.0-Perl | License:        GPL-1.0-or-later OR Artistic-1.0-Perl | ||||||
| URL:            https://metacpan.org/release/XS-Parse-Keyword | URL:            https://metacpan.org/release/XS-Parse-Keyword | ||||||
| Source0:        https://cpan.metacpan.org/authors/id/P/PE/PEVANS/XS-Parse-Keyword-%{version}.tar.gz | Source0:        https://cpan.metacpan.org/authors/id/P/PE/PEVANS/XS-Parse-Keyword-%{version}.tar.gz | ||||||
| Source1:        macros.perl-XS-Parse-Keyword | Source1:        macros.perl-XS-Parse-Keyword | ||||||
| # Fix a check for PL_infix_plugin, not suitable for upstream, bug #2226738, |  | ||||||
| # CPAN RT#149179. |  | ||||||
| Patch0:         XS-Parse-Keyword-0.36-No-special-linker-flags-for-checking-for-PL_infix_pl.patch |  | ||||||
| # Fix calling warn(), CPAN RT#149346, proposed to the upstream. |  | ||||||
| Patch1:         XS-Parse-Keyword-0.37-Pass-a-format-string-to-warn.patch |  | ||||||
| BuildRequires:  coreutils | BuildRequires:  coreutils | ||||||
| BuildRequires:  perl-devel | BuildRequires:  perl-devel | ||||||
| BuildRequires:  perl-generators | BuildRequires:  perl-generators | ||||||
| @ -149,6 +144,9 @@ export HARNESS_OPTIONS=j$(perl -e 'if ($ARGV[0] =~ /.*-j([0-9][0-9]*).*/) {print | |||||||
| %{_libexecdir}/%{name} | %{_libexecdir}/%{name} | ||||||
| 
 | 
 | ||||||
| %changelog | %changelog | ||||||
|  | * Wed Aug 09 2023 Petr Pisar <ppisar@redhat.com> - 0.38-1 | ||||||
|  | - 0.38 bump | ||||||
|  | 
 | ||||||
| * Wed Aug 09 2023 Petr Pisar <ppisar@redhat.com> - 0.37-1 | * Wed Aug 09 2023 Petr Pisar <ppisar@redhat.com> - 0.37-1 | ||||||
| - 0.37 bump | - 0.37 bump | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								sources
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								sources
									
									
									
									
									
								
							| @ -1 +1 @@ | |||||||
| SHA512 (XS-Parse-Keyword-0.37.tar.gz) = 6a0c125e8f4afb6c33260e1bb07e64b168f1e7e1776739b6f09cc47232cb41ae65cee9ea5bbcafcc67eefa91b7cb3cd7a916581649b4b2da3049f306987ca5a9 | SHA512 (XS-Parse-Keyword-0.38.tar.gz) = 2b7dfade590c00095681a55ff937e3d9de1f939e0ea9fec6ae5cd06e618c2dacdc226f94047d41e6d95725dbf722feb3f2c8794a9a6950bfe12fc53bdbb823fa | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user