perl: update to 5.28
Refresh patches 900 and 910.
Add fix (920) for improperly gated variable.
Add workaround (020) for Storable's run-time check for stacksize.
Signed-off-by: Philip Prindeville <philipp@redfish-solutions.com>
(cherry picked from commit b94744496f
)
This commit is contained in:
parent
53597cf64e
commit
c875de62b3
8 changed files with 520 additions and 68 deletions
|
@ -8,7 +8,7 @@
|
||||||
include $(TOPDIR)/rules.mk
|
include $(TOPDIR)/rules.mk
|
||||||
|
|
||||||
PKG_NAME:=perl
|
PKG_NAME:=perl
|
||||||
PKG_VERSION:=5.26.2
|
PKG_VERSION:=5.28.0
|
||||||
PKG_RELEASE:=1
|
PKG_RELEASE:=1
|
||||||
|
|
||||||
PKG_SOURCE_URL:=\
|
PKG_SOURCE_URL:=\
|
||||||
|
@ -19,7 +19,7 @@ PKG_SOURCE_URL:=\
|
||||||
https://mirrors.sonic.net/cpan/src/5.0 \
|
https://mirrors.sonic.net/cpan/src/5.0 \
|
||||||
https://www.cpan.org/src/5.0
|
https://www.cpan.org/src/5.0
|
||||||
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.xz
|
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.xz
|
||||||
PKG_HASH:=0f8c0fb1b0db4681adb75c3ba0dd77a0472b1b359b9e80efd79fc27b4352132c
|
PKG_HASH:=059b3cb69970d8c8c5964caced0335b4af34ac990c8e61f7e3f90cd1c2d11e49
|
||||||
|
|
||||||
PKG_LICENSE:=GPL-1.0+ Artistic-1.0-Perl
|
PKG_LICENSE:=GPL-1.0+ Artistic-1.0-Perl
|
||||||
PKG_LICENSE_FILES:=Copying Artistic README
|
PKG_LICENSE_FILES:=Copying Artistic README
|
||||||
|
|
|
@ -69,6 +69,7 @@ d_PRIu64='define'
|
||||||
d_PRIx64='define'
|
d_PRIx64='define'
|
||||||
d_SCNfldbl='define'
|
d_SCNfldbl='define'
|
||||||
d__fwalk='undef'
|
d__fwalk='undef'
|
||||||
|
d_accept4='define'
|
||||||
d_access='define'
|
d_access='define'
|
||||||
d_accessx='undef'
|
d_accessx='undef'
|
||||||
d_acosh='define'
|
d_acosh='define'
|
||||||
|
@ -94,8 +95,11 @@ d_bcopy='define'
|
||||||
d_bsd='undef'
|
d_bsd='undef'
|
||||||
d_bsdgetpgrp='undef'
|
d_bsdgetpgrp='undef'
|
||||||
d_bsdsetpgrp='undef'
|
d_bsdsetpgrp='undef'
|
||||||
|
d_builtin_add_overflow='define'
|
||||||
d_builtin_choose_expr='define'
|
d_builtin_choose_expr='define'
|
||||||
d_builtin_expect='undef'
|
d_builtin_expect='undef'
|
||||||
|
d_builtin_mul_overflow='define'
|
||||||
|
d_builtin_sub_overflow='define'
|
||||||
d_bzero='define'
|
d_bzero='define'
|
||||||
d_c99_variadic_macros='define'
|
d_c99_variadic_macros='define'
|
||||||
d_castneg='define'
|
d_castneg='define'
|
||||||
|
@ -143,6 +147,7 @@ d_double_style_ieee='define'
|
||||||
d_double_style_vax='undef'
|
d_double_style_vax='undef'
|
||||||
d_drand48proto='define'
|
d_drand48proto='define'
|
||||||
d_dup2='define'
|
d_dup2='define'
|
||||||
|
d_dup3='define'
|
||||||
d_duplocale='define'
|
d_duplocale='define'
|
||||||
d_eaccess='undef'
|
d_eaccess='undef'
|
||||||
d_endgrent='define'
|
d_endgrent='define'
|
||||||
|
@ -166,6 +171,7 @@ d_expm1='define'
|
||||||
d_faststdio='undef'
|
d_faststdio='undef'
|
||||||
d_fchdir='define'
|
d_fchdir='define'
|
||||||
d_fchmod='define'
|
d_fchmod='define'
|
||||||
|
d_fchmodat='define'
|
||||||
d_fchown='define'
|
d_fchown='define'
|
||||||
d_fcntl='define'
|
d_fcntl='define'
|
||||||
d_fcntl_can_lock='define'
|
d_fcntl_can_lock='define'
|
||||||
|
@ -282,10 +288,12 @@ d_lgamma_r='define'
|
||||||
d_libm_lib_version='define'
|
d_libm_lib_version='define'
|
||||||
d_libname_unique='undef'
|
d_libname_unique='undef'
|
||||||
d_link='define'
|
d_link='define'
|
||||||
|
d_linkat='define'
|
||||||
d_llrint='define'
|
d_llrint='define'
|
||||||
d_llrintl='define'
|
d_llrintl='define'
|
||||||
d_llround='define'
|
d_llround='define'
|
||||||
d_llroundl='define'
|
d_llroundl='define'
|
||||||
|
d_localeconv_l='undef'
|
||||||
d_localtime64='undef'
|
d_localtime64='undef'
|
||||||
d_locconv='define'
|
d_locconv='define'
|
||||||
d_lockf='define'
|
d_lockf='define'
|
||||||
|
@ -309,6 +317,8 @@ d_madvise='define'
|
||||||
d_malloc_good_size='undef'
|
d_malloc_good_size='undef'
|
||||||
d_malloc_size='undef'
|
d_malloc_size='undef'
|
||||||
d_mblen='define'
|
d_mblen='define'
|
||||||
|
d_mbrlen='define'
|
||||||
|
d_mbrtowc='define'
|
||||||
d_mbstowcs='define'
|
d_mbstowcs='define'
|
||||||
d_mbtowc='define'
|
d_mbtowc='define'
|
||||||
d_memchr='define'
|
d_memchr='define'
|
||||||
|
@ -316,10 +326,12 @@ d_memcmp='define'
|
||||||
d_memcpy='define'
|
d_memcpy='define'
|
||||||
d_memmem='define'
|
d_memmem='define'
|
||||||
d_memmove='define'
|
d_memmove='define'
|
||||||
|
d_memrchr='undef'
|
||||||
d_memset='define'
|
d_memset='define'
|
||||||
d_mkdir='define'
|
d_mkdir='define'
|
||||||
d_mkdtemp='define'
|
d_mkdtemp='define'
|
||||||
d_mkfifo='define'
|
d_mkfifo='define'
|
||||||
|
d_mkostemp='define'
|
||||||
d_mkstemp='define'
|
d_mkstemp='define'
|
||||||
d_mkstemps='undef'
|
d_mkstemps='undef'
|
||||||
d_mktime='define'
|
d_mktime='define'
|
||||||
|
@ -356,11 +368,13 @@ d_old_pthread_create_joinable='undef'
|
||||||
d_oldpthreads='undef'
|
d_oldpthreads='undef'
|
||||||
d_oldsock='undef'
|
d_oldsock='undef'
|
||||||
d_open3='define'
|
d_open3='define'
|
||||||
|
d_openat='define'
|
||||||
d_pathconf='define'
|
d_pathconf='define'
|
||||||
d_pause='define'
|
d_pause='define'
|
||||||
d_perl_otherlibdirs='undef'
|
d_perl_otherlibdirs='undef'
|
||||||
d_phostname='undef'
|
d_phostname='undef'
|
||||||
d_pipe='define'
|
d_pipe='define'
|
||||||
|
d_pipe2='define'
|
||||||
d_poll='define'
|
d_poll='define'
|
||||||
d_portable='define'
|
d_portable='define'
|
||||||
d_prctl='define'
|
d_prctl='define'
|
||||||
|
@ -389,6 +403,7 @@ d_regcmp='undef'
|
||||||
d_regcomp='define'
|
d_regcomp='define'
|
||||||
d_remainder='define'
|
d_remainder='define'
|
||||||
d_remquo='define'
|
d_remquo='define'
|
||||||
|
d_renameat='define'
|
||||||
d_rename='define'
|
d_rename='define'
|
||||||
d_rewinddir='define'
|
d_rewinddir='define'
|
||||||
d_rint='define'
|
d_rint='define'
|
||||||
|
@ -497,9 +512,12 @@ d_strerror_l='define'
|
||||||
d_strftime='define'
|
d_strftime='define'
|
||||||
d_strlcat='define'
|
d_strlcat='define'
|
||||||
d_strlcpy='define'
|
d_strlcpy='define'
|
||||||
|
d_strnlen='define'
|
||||||
d_strtod='define'
|
d_strtod='define'
|
||||||
|
d_strtod_l='define'
|
||||||
d_strtol='define'
|
d_strtol='define'
|
||||||
d_strtold='define'
|
d_strtold='define'
|
||||||
|
d_strtold_l='define'
|
||||||
d_strtoll='define'
|
d_strtoll='define'
|
||||||
d_strtoq='define'
|
d_strtoq='define'
|
||||||
d_strtoul='define'
|
d_strtoul='define'
|
||||||
|
@ -519,6 +537,7 @@ d_tcsetpgrp='define'
|
||||||
d_telldir='define'
|
d_telldir='define'
|
||||||
d_telldirproto='define'
|
d_telldirproto='define'
|
||||||
d_tgamma='define'
|
d_tgamma='define'
|
||||||
|
d_thread_safe_nl_langinfo_l='define'
|
||||||
d_time='define'
|
d_time='define'
|
||||||
d_timegm='define'
|
d_timegm='define'
|
||||||
d_times='define'
|
d_times='define'
|
||||||
|
@ -532,6 +551,7 @@ d_ualarm='define'
|
||||||
d_umask='define'
|
d_umask='define'
|
||||||
d_uname='define'
|
d_uname='define'
|
||||||
d_union_semun='undef'
|
d_union_semun='undef'
|
||||||
|
d_unlinkat='define'
|
||||||
d_unordered='undef'
|
d_unordered='undef'
|
||||||
d_unsetenv='define'
|
d_unsetenv='define'
|
||||||
d_uselocale='define'
|
d_uselocale='define'
|
||||||
|
@ -716,6 +736,7 @@ i_values='define'
|
||||||
i_varargs='undef'
|
i_varargs='undef'
|
||||||
i_varhdr='stdarg.h'
|
i_varhdr='stdarg.h'
|
||||||
i_vfork='undef'
|
i_vfork='undef'
|
||||||
|
i_wchar='define'
|
||||||
i_xlocale='undef'
|
i_xlocale='undef'
|
||||||
ignore_versioned_solibs='y'
|
ignore_versioned_solibs='y'
|
||||||
inc_version_list=' '
|
inc_version_list=' '
|
||||||
|
|
|
@ -1,11 +1,11 @@
|
||||||
# Set the version here
|
# Set the version here
|
||||||
PERL_REVISION=5
|
PERL_REVISION=5
|
||||||
PERL_VERSION=26
|
PERL_VERSION=28
|
||||||
PERL_SUBVERSION=2
|
PERL_SUBVERSION=0
|
||||||
|
|
||||||
# (api_revison, api_version, api_subversion) = (revision, version, 0) usually
|
# (api_revison, api_version, api_subversion) = (revision, version, 0) usually
|
||||||
PERL_API_REVISION=5
|
PERL_API_REVISION=5
|
||||||
PERL_API_VERSION=26
|
PERL_API_VERSION=28
|
||||||
PERL_API_SUBVERSION=0
|
PERL_API_SUBVERSION=0
|
||||||
|
|
||||||
known_extensions='B Compress/Raw/Zlib Cwd DB_File Data/Dumper Devel/DProf Devel/PPPort Devel/Peek Digest/MD5 Digest/SHA Encode Fcntl File/Glob Filter/Util/Call GDBM_File Hash/Util I18N/Langinfo IO IPC/SysV List/Util MIME/Base64 Math/BigInt/FastCalc NDBM_File ODBM_File Opcode POSIX PerlIO/encoding PerlIO/scalar PerlIO/via SDBM_File Socket Storable Sys/Hostname Sys/Syslog Text/Soundex Time/HiRes Time/Piece Unicode/Normalize Win32 Win32API/File Win32CORE XS/APItest XS/Typemap attrs re threads threads/shared Hash/Util/FieldHash'
|
known_extensions='B Compress/Raw/Zlib Cwd DB_File Data/Dumper Devel/DProf Devel/PPPort Devel/Peek Digest/MD5 Digest/SHA Encode Fcntl File/Glob Filter/Util/Call GDBM_File Hash/Util I18N/Langinfo IO IPC/SysV List/Util MIME/Base64 Math/BigInt/FastCalc NDBM_File ODBM_File Opcode POSIX PerlIO/encoding PerlIO/scalar PerlIO/via SDBM_File Socket Storable Sys/Hostname Sys/Syslog Text/Soundex Time/HiRes Time/Piece Unicode/Normalize Win32 Win32API/File Win32CORE XS/APItest XS/Typemap attrs re threads threads/shared Hash/Util/FieldHash'
|
||||||
|
|
73
lang/perl/patches/020-storables-stacksize.patch
Normal file
73
lang/perl/patches/020-storables-stacksize.patch
Normal file
|
@ -0,0 +1,73 @@
|
||||||
|
From 682a4acb98783a7f9b5c286b308f12863599fec3 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Tony Cook <tony@develop-help.com>
|
||||||
|
Date: Mon, 30 Jul 2018 21:00:52 +1000
|
||||||
|
Subject: (perl #133411) don't try to load Storable with -Dusecrosscompile
|
||||||
|
|
||||||
|
---
|
||||||
|
dist/Storable/Makefile.PL | 9 ++++++++-
|
||||||
|
dist/Storable/stacksize | 10 +++++++---
|
||||||
|
2 files changed, 15 insertions(+), 4 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/dist/Storable/Makefile.PL b/dist/Storable/Makefile.PL
|
||||||
|
index a5d9e66891..db420ab30b 100644
|
||||||
|
--- a/dist/Storable/Makefile.PL
|
||||||
|
+++ b/dist/Storable/Makefile.PL
|
||||||
|
@@ -90,12 +90,19 @@ sub depend {
|
||||||
|
# blib.pm needs arch/lib
|
||||||
|
$extra_deps = ' Storable.pm';
|
||||||
|
}
|
||||||
|
+ my $whichperl;
|
||||||
|
+ if ($Config::Config{usecrosscompile}) {
|
||||||
|
+ $whichperl = '$(PERLRUN)';
|
||||||
|
+ }
|
||||||
|
+ else {
|
||||||
|
+ $whichperl = '$(FULLPERLRUNINST)';
|
||||||
|
+ }
|
||||||
|
my $linktype = uc($_[0]->{LINKTYPE});
|
||||||
|
my $limit_pm = File::Spec->catfile('lib', 'Storable', 'Limit.pm');
|
||||||
|
"
|
||||||
|
$limit_pm : stacksize \$(INST_$linktype)$extra_deps
|
||||||
|
\$(MKPATH) \$(INST_LIB)
|
||||||
|
- \$(FULLPERLRUNINST) stacksize $options
|
||||||
|
+ $whichperl stacksize $options
|
||||||
|
|
||||||
|
release : dist
|
||||||
|
git tag \$(VERSION)
|
||||||
|
diff --git a/dist/Storable/stacksize b/dist/Storable/stacksize
|
||||||
|
index 7abd3a84cc..14e0739734 100644
|
||||||
|
--- a/dist/Storable/stacksize
|
||||||
|
+++ b/dist/Storable/stacksize
|
||||||
|
@@ -7,6 +7,9 @@ use Cwd;
|
||||||
|
use File::Spec;
|
||||||
|
use strict;
|
||||||
|
|
||||||
|
+-d "lib" or mkdir "lib";
|
||||||
|
+-d "lib/Storable" or mkdir "lib/Storable";
|
||||||
|
+
|
||||||
|
my $fn = "lib/Storable/Limit.pm";
|
||||||
|
my $ptrsize = $Config{ptrsize};
|
||||||
|
my ($bad1, $bad2) = (65001, 25000);
|
||||||
|
@@ -29,6 +32,10 @@ sub is_miniperl {
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_miniperl()) {
|
||||||
|
+ if ($Config{usecrosscompile}) {
|
||||||
|
+ write_limits(500, 265);
|
||||||
|
+ exit;
|
||||||
|
+ }
|
||||||
|
die "Should not run during miniperl\n";
|
||||||
|
}
|
||||||
|
my $prefix = "";
|
||||||
|
@@ -68,9 +75,6 @@ if ($ENV{PERL_CORE}) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
--d "lib" or mkdir "lib";
|
||||||
|
--d "lib/Storable" or mkdir "lib/Storable";
|
||||||
|
-
|
||||||
|
if ($^O eq "MSWin32") {
|
||||||
|
require Win32;
|
||||||
|
my ($str, $major, $minor) = Win32::GetOSVersion();
|
||||||
|
--
|
||||||
|
2.11.0
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
--- a/Makefile.SH 2017-10-17 11:59:52.938763142 -0600
|
--- a/Makefile.SH 2017-10-17 11:59:52.938763142 -0600
|
||||||
+++ b/Makefile.SH 2017-10-17 12:13:46.202555604 -0600
|
+++ b/Makefile.SH 2017-10-17 12:13:46.202555604 -0600
|
||||||
@@ -270,6 +270,7 @@ LNS = $lns
|
@@ -275,6 +275,7 @@ LNS = $lns
|
||||||
# NOTE: some systems don't grok "cp -f". XXX Configure test needed?
|
# NOTE: some systems don't grok "cp -f". XXX Configure test needed?
|
||||||
CPS = $cp
|
CPS = $cp
|
||||||
RMS = rm -f
|
RMS = rm -f
|
||||||
|
@ -8,7 +8,7 @@
|
||||||
ranlib = $ranlib
|
ranlib = $ranlib
|
||||||
|
|
||||||
# The following are mentioned only to make metaconfig include the
|
# The following are mentioned only to make metaconfig include the
|
||||||
@@ -731,7 +731,7 @@ bitcount.h: generate_uudmap$(HOST_EXE_EX
|
@@ -736,7 +737,7 @@ bitcount.h: generate_uudmap$(HOST_EXE_EX
|
||||||
./generate_uudmap$(HOST_EXE_EXT) $(generated_headers)
|
./generate_uudmap$(HOST_EXE_EXT) $(generated_headers)
|
||||||
|
|
||||||
generate_uudmap$(HOST_EXE_EXT): generate_uudmap$(OBJ_EXT)
|
generate_uudmap$(HOST_EXE_EXT): generate_uudmap$(OBJ_EXT)
|
||||||
|
@ -17,7 +17,7 @@
|
||||||
$(LNS) $(HOST_GENERATE) generate_uudmap$(HOST_EXE_EXT)
|
$(LNS) $(HOST_GENERATE) generate_uudmap$(HOST_EXE_EXT)
|
||||||
|
|
||||||
!NO!SUBS!
|
!NO!SUBS!
|
||||||
@@ -871,26 +872,26 @@ mydtrace.h: $(DTRACE_H)
|
@@ -876,26 +877,26 @@ mydtrace.h: $(DTRACE_H)
|
||||||
define)
|
define)
|
||||||
$spitshell >>$Makefile <<'!NO!SUBS!'
|
$spitshell >>$Makefile <<'!NO!SUBS!'
|
||||||
$(DTRACE_MINI_O): perldtrace.d $(miniperl_objs_nodt)
|
$(DTRACE_MINI_O): perldtrace.d $(miniperl_objs_nodt)
|
||||||
|
@ -48,7 +48,7 @@
|
||||||
|
|
||||||
!NO!SUBS!
|
!NO!SUBS!
|
||||||
;;
|
;;
|
||||||
@@ -901,13 +902,13 @@ $(LIBPERL): $& $(perllib_dep) $(DYNALOAD
|
@@ -906,13 +907,13 @@ $(LIBPERL): $& $(perllib_dep) $(DYNALOAD
|
||||||
case "$useshrplib" in
|
case "$useshrplib" in
|
||||||
true)
|
true)
|
||||||
$spitshell >>$Makefile <<'!NO!SUBS!'
|
$spitshell >>$Makefile <<'!NO!SUBS!'
|
||||||
|
@ -64,7 +64,7 @@
|
||||||
mv $@ libperl$(OBJ_EXT)
|
mv $@ libperl$(OBJ_EXT)
|
||||||
$(AR) qv $(LIBPERL) libperl$(OBJ_EXT)
|
$(AR) qv $(LIBPERL) libperl$(OBJ_EXT)
|
||||||
!NO!SUBS!
|
!NO!SUBS!
|
||||||
@@ -916,7 +917,7 @@ $(LIBPERL): $& $(perllib_dep) $(DYNALOAD
|
@@ -921,7 +922,7 @@ $(LIBPERL): $& $(perllib_dep) $(DYNALOAD
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
$spitshell >>$Makefile <<'!NO!SUBS!'
|
$spitshell >>$Makefile <<'!NO!SUBS!'
|
||||||
|
@ -73,7 +73,7 @@
|
||||||
$(AR) rc $(LIBPERL) $(perllib_objs) $(DYNALOADER)
|
$(AR) rc $(LIBPERL) $(perllib_objs) $(DYNALOADER)
|
||||||
@$(ranlib) $(LIBPERL)
|
@$(ranlib) $(LIBPERL)
|
||||||
!NO!SUBS!
|
!NO!SUBS!
|
||||||
@@ -949,7 +950,7 @@ $(MINIPERL_EXE): lib/buildcustomize.pl
|
@@ -954,7 +955,7 @@ $(MINIPERL_EXE): lib/buildcustomize.pl
|
||||||
amigaos*)
|
amigaos*)
|
||||||
$spitshell >>$Makefile <<'!NO!SUBS!'
|
$spitshell >>$Makefile <<'!NO!SUBS!'
|
||||||
lib/buildcustomize.pl: $& $(miniperl_objs) write_buildcustomize.pl
|
lib/buildcustomize.pl: $& $(miniperl_objs) write_buildcustomize.pl
|
||||||
|
@ -82,7 +82,7 @@
|
||||||
$(CC) $(CLDFLAGS) -o $(MINIPERL_EXE) \
|
$(CC) $(CLDFLAGS) -o $(MINIPERL_EXE) \
|
||||||
$(miniperl_objs) $(libs)
|
$(miniperl_objs) $(libs)
|
||||||
# $(LDLIBPTH) ./miniperl$(HOST_EXE_EXT) -w -Ilib -Idist/Exporter/lib -MExporter -e '<?>' || sh -c 'echo >&2 Failed to build miniperl. Please run make minitest; exit 1'
|
# $(LDLIBPTH) ./miniperl$(HOST_EXE_EXT) -w -Ilib -Idist/Exporter/lib -MExporter -e '<?>' || sh -c 'echo >&2 Failed to build miniperl. Please run make minitest; exit 1'
|
||||||
@@ -987,7 +988,7 @@ NAMESPACEFLAGS = -force_flat_namespace
|
@@ -992,7 +993,7 @@ NAMESPACEFLAGS = -force_flat_namespace
|
||||||
esac
|
esac
|
||||||
$spitshell >>$Makefile <<'!NO!SUBS!'
|
$spitshell >>$Makefile <<'!NO!SUBS!'
|
||||||
lib/buildcustomize.pl: $& $(miniperl_objs) write_buildcustomize.pl
|
lib/buildcustomize.pl: $& $(miniperl_objs) write_buildcustomize.pl
|
||||||
|
@ -91,7 +91,7 @@
|
||||||
$(CC) $(CLDFLAGS) $(NAMESPACEFLAGS) -o $(MINIPERL_EXE) \
|
$(CC) $(CLDFLAGS) $(NAMESPACEFLAGS) -o $(MINIPERL_EXE) \
|
||||||
$(miniperl_objs) $(libs)
|
$(miniperl_objs) $(libs)
|
||||||
$(LDLIBPTH) ./miniperl$(HOST_EXE_EXT) -w -Ilib -Idist/Exporter/lib -MExporter -e '<?>' || sh -c 'echo >&2 Failed to build miniperl. Please run make minitest; exit 1'
|
$(LDLIBPTH) ./miniperl$(HOST_EXE_EXT) -w -Ilib -Idist/Exporter/lib -MExporter -e '<?>' || sh -c 'echo >&2 Failed to build miniperl. Please run make minitest; exit 1'
|
||||||
@@ -998,8 +999,8 @@ lib/buildcustomize.pl: $& $(miniperl_obj
|
@@ -1003,8 +1004,8 @@ lib/buildcustomize.pl: $& $(miniperl_obj
|
||||||
if test "X$hostperl" != X; then
|
if test "X$hostperl" != X; then
|
||||||
$spitshell >>$Makefile <<!GROK!THIS!
|
$spitshell >>$Makefile <<!GROK!THIS!
|
||||||
lib/buildcustomize.pl: \$& \$(miniperl_dep) write_buildcustomize.pl
|
lib/buildcustomize.pl: \$& \$(miniperl_dep) write_buildcustomize.pl
|
||||||
|
@ -102,7 +102,7 @@
|
||||||
\$(LNS) \$(HOST_PERL) \$(MINIPERL_EXE)
|
\$(LNS) \$(HOST_PERL) \$(MINIPERL_EXE)
|
||||||
\$(LDLIBPTH) ./miniperl\$(HOST_EXE_EXT) -w -Ilib -Idist/Exporter/lib -MExporter -e '<?>' || sh -c 'echo >&2 Failed to build miniperl. Please run make minitest; exit 1'
|
\$(LDLIBPTH) ./miniperl\$(HOST_EXE_EXT) -w -Ilib -Idist/Exporter/lib -MExporter -e '<?>' || sh -c 'echo >&2 Failed to build miniperl. Please run make minitest; exit 1'
|
||||||
\$(MINIPERL) -f write_buildcustomize.pl 'osname' "$osname"
|
\$(MINIPERL) -f write_buildcustomize.pl 'osname' "$osname"
|
||||||
@@ -1007,7 +1008,7 @@ lib/buildcustomize.pl: \$& \$(miniperl_d
|
@@ -1012,7 +1013,7 @@ lib/buildcustomize.pl: \$& \$(miniperl_d
|
||||||
else
|
else
|
||||||
$spitshell >>$Makefile <<'!NO!SUBS!'
|
$spitshell >>$Makefile <<'!NO!SUBS!'
|
||||||
lib/buildcustomize.pl: $& $(miniperl_dep) write_buildcustomize.pl
|
lib/buildcustomize.pl: $& $(miniperl_dep) write_buildcustomize.pl
|
||||||
|
@ -111,7 +111,7 @@
|
||||||
$(CC) $(CLDFLAGS) -o $(MINIPERL_EXE) \
|
$(CC) $(CLDFLAGS) -o $(MINIPERL_EXE) \
|
||||||
$(miniperl_objs) $(libs)
|
$(miniperl_objs) $(libs)
|
||||||
$(LDLIBPTH) ./miniperl$(HOST_EXE_EXT) -w -Ilib -Idist/Exporter/lib -MExporter -e '<?>' || sh -c 'echo >&2 Failed to build miniperl. Please run make minitest; exit 1'
|
$(LDLIBPTH) ./miniperl$(HOST_EXE_EXT) -w -Ilib -Idist/Exporter/lib -MExporter -e '<?>' || sh -c 'echo >&2 Failed to build miniperl. Please run make minitest; exit 1'
|
||||||
@@ -1020,7 +1021,7 @@ lib/buildcustomize.pl: $& $(miniperl_dep
|
@@ -1025,7 +1026,7 @@ lib/buildcustomize.pl: $& $(miniperl_dep
|
||||||
$spitshell >>$Makefile <<'!NO!SUBS!'
|
$spitshell >>$Makefile <<'!NO!SUBS!'
|
||||||
|
|
||||||
$(PERL_EXE): $& $(perlmain_dep) $(LIBPERL) $(static_ext) ext.libs $(PERLEXPORT) write_buildcustomize.pl
|
$(PERL_EXE): $& $(perlmain_dep) $(LIBPERL) $(static_ext) ext.libs $(PERLEXPORT) write_buildcustomize.pl
|
||||||
|
@ -120,8 +120,8 @@
|
||||||
!NO!SUBS!
|
!NO!SUBS!
|
||||||
|
|
||||||
case $osname in
|
case $osname in
|
||||||
@@ -1114,8 +1115,8 @@ pod/perl5261delta.pod: pod/perldelta.pod
|
@@ -1119,8 +1120,8 @@ pod/perl5280delta.pod: pod/perldelta.pod
|
||||||
$(LNS) perldelta.pod pod/perl5261delta.pod
|
$(LNS) perldelta.pod pod/perl5280delta.pod
|
||||||
|
|
||||||
extra.pods: $(MINIPERL_EXE)
|
extra.pods: $(MINIPERL_EXE)
|
||||||
- -@test ! -f extra.pods || rm -f `cat extra.pods`
|
- -@test ! -f extra.pods || rm -f `cat extra.pods`
|
||||||
|
@ -131,7 +131,7 @@
|
||||||
-@for x in `grep -l '^=[a-z]' README.* | grep -v README.vms` ; do \
|
-@for x in `grep -l '^=[a-z]' README.* | grep -v README.vms` ; do \
|
||||||
nx=`echo $$x | sed -e "s/README\.//"`; \
|
nx=`echo $$x | sed -e "s/README\.//"`; \
|
||||||
$(LNS) ../$$x "pod/perl"$$nx".pod" ; \
|
$(LNS) ../$$x "pod/perl"$$nx".pod" ; \
|
||||||
@@ -1332,11 +1333,11 @@ realclean: _realcleaner _mopup
|
@@ -1340,11 +1341,11 @@ realclean: _realcleaner _mopup
|
||||||
@echo "Note that '$(MAKE) realclean' does not delete config.sh or Policy.sh"
|
@echo "Note that '$(MAKE) realclean' does not delete config.sh or Policy.sh"
|
||||||
|
|
||||||
_clobber:
|
_clobber:
|
||||||
|
@ -148,7 +148,7 @@
|
||||||
|
|
||||||
clobber: _realcleaner _mopup _clobber
|
clobber: _realcleaner _mopup _clobber
|
||||||
|
|
||||||
@@ -1344,23 +1345,23 @@ distclean: clobber
|
@@ -1352,23 +1353,23 @@ distclean: clobber
|
||||||
|
|
||||||
# Like distclean but also removes emacs backups and *.orig.
|
# Like distclean but also removes emacs backups and *.orig.
|
||||||
veryclean: _verycleaner _mopup _clobber
|
veryclean: _verycleaner _mopup _clobber
|
||||||
|
@ -183,7 +183,7 @@
|
||||||
-cd pod; $(LDLIBPTH) $(MAKE) $(CLEAN)
|
-cd pod; $(LDLIBPTH) $(MAKE) $(CLEAN)
|
||||||
-cd utils; $(LDLIBPTH) $(MAKE) $(CLEAN)
|
-cd utils; $(LDLIBPTH) $(MAKE) $(CLEAN)
|
||||||
-@if test -f $(MINIPERL_EXE) ; then \
|
-@if test -f $(MINIPERL_EXE) ; then \
|
||||||
@@ -1370,31 +1371,31 @@ _cleaner1:
|
@@ -1378,31 +1379,31 @@ _cleaner1:
|
||||||
else \
|
else \
|
||||||
sh $(CLEAN).sh ; \
|
sh $(CLEAN).sh ; \
|
||||||
fi
|
fi
|
||||||
|
@ -233,7 +233,7 @@
|
||||||
-rmdir lib/version lib/threads lib/inc/ExtUtils lib/inc lib/encoding
|
-rmdir lib/version lib/threads lib/inc/ExtUtils lib/inc lib/encoding
|
||||||
-rmdir lib/autodie/exception lib/autodie/Scope lib/autodie lib/XS
|
-rmdir lib/autodie/exception lib/autodie/Scope lib/autodie lib/XS
|
||||||
-rmdir lib/Win32API lib/VMS lib/Unicode/Collate/Locale
|
-rmdir lib/Win32API lib/VMS lib/Unicode/Collate/Locale
|
||||||
@@ -1443,11 +1444,11 @@ _realcleaner:
|
@@ -1452,11 +1453,11 @@ _realcleaner:
|
||||||
_verycleaner:
|
_verycleaner:
|
||||||
@$(LDLIBPTH) $(MAKE) _cleaner1 CLEAN=veryclean
|
@$(LDLIBPTH) $(MAKE) _cleaner1 CLEAN=veryclean
|
||||||
@$(LDLIBPTH) $(MAKE) _cleaner2
|
@$(LDLIBPTH) $(MAKE) _cleaner2
|
||||||
|
@ -247,16 +247,16 @@
|
||||||
lint $(lintflags) -DPERL_CORE -D_REENTRANT -DDEBUGGING -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64 $(c)
|
lint $(lintflags) -DPERL_CORE -D_REENTRANT -DDEBUGGING -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64 $(c)
|
||||||
|
|
||||||
cscopeflags = -Rb # Recursive, build-only.
|
cscopeflags = -Rb # Recursive, build-only.
|
||||||
@@ -1505,7 +1506,7 @@ case "$targethost" in
|
@@ -1514,7 +1515,7 @@ case "$targethost" in
|
||||||
'') $spitshell >>$Makefile <<'!NO!SUBS!'
|
'') $spitshell >>$Makefile <<'!NO!SUBS!'
|
||||||
test_prep test-prep: test_prep_pre $(MINIPERL_EXE) $(unidatafiles) $(PERL_EXE) \
|
test_prep test-prep: test_prep_pre $(MINIPERL_EXE) $(unidatafiles) $(PERL_EXE) \
|
||||||
$(dynamic_ext) $(TEST_PERL_DLL) runtests $(generated_pods)
|
$(dynamic_ext) $(TEST_PERL_DLL) runtests $(generated_pods) common_build
|
||||||
- cd t && (rm -f $(PERL_EXE); $(LNS) ../$(PERL_EXE) $(PERL_EXE))
|
- cd t && (rm -f $(PERL_EXE); $(LNS) ../$(PERL_EXE) $(PERL_EXE))
|
||||||
+ cd t && ($(RMS) $(PERL_EXE); $(LNS) ../$(PERL_EXE) $(PERL_EXE))
|
+ cd t && ($(RMS) $(PERL_EXE); $(LNS) ../$(PERL_EXE) $(PERL_EXE))
|
||||||
|
|
||||||
!NO!SUBS!
|
!NO!SUBS!
|
||||||
;;
|
;;
|
||||||
@@ -1555,7 +1556,7 @@ test_prep test-prep: test_prep_pre \$(MI
|
@@ -1564,7 +1565,7 @@ test_prep test-prep: test_prep_pre \$(MI
|
||||||
$to config.sh
|
$to config.sh
|
||||||
# --- For lib/diagnostics.t with -Duseshrplib
|
# --- For lib/diagnostics.t with -Duseshrplib
|
||||||
$to \$(PERL_EXE)
|
$to \$(PERL_EXE)
|
||||||
|
@ -265,7 +265,7 @@
|
||||||
$to t/\$(PERL_EXE)
|
$to t/\$(PERL_EXE)
|
||||||
|
|
||||||
!GROK!THIS!
|
!GROK!THIS!
|
||||||
@@ -1565,7 +1566,7 @@ esac
|
@@ -1574,7 +1575,7 @@ esac
|
||||||
$spitshell >>$Makefile <<'!NO!SUBS!'
|
$spitshell >>$Makefile <<'!NO!SUBS!'
|
||||||
test_prep_reonly: $(MINIPERL_EXE) $(PERL_EXE) $(dynamic_ext_re) $(TEST_PERL_DLL)
|
test_prep_reonly: $(MINIPERL_EXE) $(PERL_EXE) $(dynamic_ext_re) $(TEST_PERL_DLL)
|
||||||
$(MINIPERL) make_ext.pl $(dynamic_ext_re) MAKE="$(MAKE)" LIBPERL_A=$(LIBPERL) LINKTYPE=dynamic
|
$(MINIPERL) make_ext.pl $(dynamic_ext_re) MAKE="$(MAKE)" LIBPERL_A=$(LIBPERL) LINKTYPE=dynamic
|
||||||
|
@ -274,7 +274,7 @@
|
||||||
!NO!SUBS!
|
!NO!SUBS!
|
||||||
|
|
||||||
case "$targethost" in
|
case "$targethost" in
|
||||||
@@ -1620,7 +1621,7 @@ minitest_prep:
|
@@ -1629,7 +1630,7 @@ minitest_prep:
|
||||||
@echo "You may see some irrelevant test failures if you have been unable"
|
@echo "You may see some irrelevant test failures if you have been unable"
|
||||||
@echo "to build lib/Config.pm, or the Unicode data files."
|
@echo "to build lib/Config.pm, or the Unicode data files."
|
||||||
@echo " "
|
@echo " "
|
||||||
|
|
|
@ -37,44 +37,3 @@
|
||||||
$(MINIPERL) -f write_buildcustomize.pl
|
$(MINIPERL) -f write_buildcustomize.pl
|
||||||
!NO!SUBS!
|
!NO!SUBS!
|
||||||
fi
|
fi
|
||||||
--- a/cpan/Devel-PPPort/PPPort_pm.PL 2017-07-18 16:59:59.000000000 -0600
|
|
||||||
+++ b/cpan/Devel-PPPort/PPPort_pm.PL 2017-10-15 19:19:27.341543182 -0600
|
|
||||||
@@ -15,6 +15,7 @@
|
|
||||||
|
|
||||||
use strict;
|
|
||||||
$^W = 1;
|
|
||||||
+push(@INC, '.');
|
|
||||||
require "parts/ppptools.pl";
|
|
||||||
|
|
||||||
my $INCLUDE = 'parts/inc';
|
|
||||||
--- a/cpan/Devel-PPPort/ppport_h.PL 2017-07-18 16:59:59.000000000 -0600
|
|
||||||
+++ b/cpan/Devel-PPPort/ppport_h.PL 2017-10-15 19:27:16.594178623 -0600
|
|
||||||
@@ -14,6 +14,7 @@
|
|
||||||
################################################################################
|
|
||||||
|
|
||||||
package Devel::PPPort;
|
|
||||||
+push(@INC, '.');
|
|
||||||
require "PPPort.pm";
|
|
||||||
rename 'ppport.h', 'ppport.old' if -f 'ppport.h';
|
|
||||||
unlink "ppport.old" if WriteFile("ppport.h") && -f 'ppport.h';
|
|
||||||
--- a/cpan/Devel-PPPort/PPPort_xs.PL 2017-07-18 16:59:59.000000000 -0600
|
|
||||||
+++ b/cpan/Devel-PPPort/PPPort_xs.PL 2017-10-15 19:38:09.296679968 -0600
|
|
||||||
@@ -15,6 +15,7 @@
|
|
||||||
|
|
||||||
use strict;
|
|
||||||
$^W = 1;
|
|
||||||
+push(@INC, '.');
|
|
||||||
require "parts/ppptools.pl";
|
|
||||||
|
|
||||||
my %SECTION = (
|
|
||||||
--- a/cpan/Unicode-Collate/Makefile.PL 2017-07-18 16:49:51.000000000 -0600
|
|
||||||
+++ b/cpan/Unicode-Collate/Makefile.PL 2017-10-15 20:19:31.890439791 -0600
|
|
||||||
@@ -6,7 +6,7 @@ my $clean = {};
|
|
||||||
if (-f "Collate.xs") {
|
|
||||||
print "Making header files for XS...\n";
|
|
||||||
|
|
||||||
- do 'mkheader' or die $@ || "mkheader: $!";
|
|
||||||
+ do './mkheader' or die $@ || "mkheader: $!";
|
|
||||||
|
|
||||||
$clean = { FILES => 'ucatbl.h' };
|
|
||||||
}
|
|
||||||
|
|
399
lang/perl/patches/920-fix-no-locale.patch
Normal file
399
lang/perl/patches/920-fix-no-locale.patch
Normal file
|
@ -0,0 +1,399 @@
|
||||||
|
commit d36adde059ed1c4f7af210b4f9fc3a7bd2d7d343
|
||||||
|
Author: Karl Williamson <khw@cpan.org>
|
||||||
|
Date: Wed May 23 15:32:47 2018 -0600
|
||||||
|
|
||||||
|
Fix to compile under -DNO_LOCALE
|
||||||
|
|
||||||
|
Several problems with this compile option were not caught before 5.28
|
||||||
|
was frozen.
|
||||||
|
|
||||||
|
diff --git a/embed.fnc b/embed.fnc
|
||||||
|
index 0f06e38..36f9f97 100644
|
||||||
|
--- a/embed.fnc
|
||||||
|
+++ b/embed.fnc
|
||||||
|
@@ -2765,9 +2765,11 @@ s |bool |isa_lookup |NN HV *stash|NN const char * const name \
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(PERL_IN_LOCALE_C)
|
||||||
|
+# ifdef USE_LOCALE
|
||||||
|
sn |const char*|category_name |const int category
|
||||||
|
s |const char*|switch_category_locale_to_template|const int switch_category|const int template_category|NULLOK const char * template_locale
|
||||||
|
s |void |restore_switched_locale|const int category|NULLOK const char * const original_locale
|
||||||
|
+# endif
|
||||||
|
# ifdef HAS_NL_LANGINFO
|
||||||
|
sn |const char*|my_nl_langinfo|const nl_item item|bool toggle
|
||||||
|
# else
|
||||||
|
diff --git a/embed.h b/embed.h
|
||||||
|
index cf3ad9e..fb66c26 100644
|
||||||
|
--- a/embed.h
|
||||||
|
+++ b/embed.h
|
||||||
|
@@ -1724,16 +1724,16 @@
|
||||||
|
#define unshare_hek_or_pvn(a,b,c,d) S_unshare_hek_or_pvn(aTHX_ a,b,c,d)
|
||||||
|
# endif
|
||||||
|
# if defined(PERL_IN_LOCALE_C)
|
||||||
|
-#define category_name S_category_name
|
||||||
|
-#define restore_switched_locale(a,b) S_restore_switched_locale(aTHX_ a,b)
|
||||||
|
#define save_to_buffer S_save_to_buffer
|
||||||
|
-#define switch_category_locale_to_template(a,b,c) S_switch_category_locale_to_template(aTHX_ a,b,c)
|
||||||
|
# if defined(USE_LOCALE)
|
||||||
|
+#define category_name S_category_name
|
||||||
|
#define new_collate(a) S_new_collate(aTHX_ a)
|
||||||
|
#define new_ctype(a) S_new_ctype(aTHX_ a)
|
||||||
|
#define new_numeric(a) S_new_numeric(aTHX_ a)
|
||||||
|
+#define restore_switched_locale(a,b) S_restore_switched_locale(aTHX_ a,b)
|
||||||
|
#define set_numeric_radix(a) S_set_numeric_radix(aTHX_ a)
|
||||||
|
#define stdize_locale(a) S_stdize_locale(aTHX_ a)
|
||||||
|
+#define switch_category_locale_to_template(a,b,c) S_switch_category_locale_to_template(aTHX_ a,b,c)
|
||||||
|
# if defined(USE_POSIX_2008_LOCALE)
|
||||||
|
#define emulate_setlocale S_emulate_setlocale
|
||||||
|
# endif
|
||||||
|
diff --git a/locale.c b/locale.c
|
||||||
|
index 7653340..f8f77fb 100644
|
||||||
|
--- a/locale.c
|
||||||
|
+++ b/locale.c
|
||||||
|
@@ -1264,6 +1264,7 @@ S_locking_setlocale(pTHX_
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
+#ifdef USE_LOCALE
|
||||||
|
|
||||||
|
STATIC void
|
||||||
|
S_set_numeric_radix(pTHX_ const bool use_locale)
|
||||||
|
@@ -1299,6 +1300,10 @@ S_set_numeric_radix(pTHX_ const bool use_locale)
|
||||||
|
}
|
||||||
|
|
||||||
|
# endif
|
||||||
|
+#else
|
||||||
|
+
|
||||||
|
+ PERL_UNUSED_ARG(use_locale);
|
||||||
|
+
|
||||||
|
#endif /* USE_LOCALE_NUMERIC and can find the radix char */
|
||||||
|
|
||||||
|
}
|
||||||
|
@@ -1481,7 +1486,6 @@ S_new_ctype(pTHX_ const char *newctype)
|
||||||
|
|
||||||
|
#ifndef USE_LOCALE_CTYPE
|
||||||
|
|
||||||
|
- PERL_ARGS_ASSERT_NEW_CTYPE;
|
||||||
|
PERL_UNUSED_ARG(newctype);
|
||||||
|
PERL_UNUSED_CONTEXT;
|
||||||
|
|
||||||
|
@@ -1994,6 +1998,8 @@ S_new_collate(pTHX_ const char *newcoll)
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
#ifdef WIN32
|
||||||
|
|
||||||
|
STATIC char *
|
||||||
|
@@ -2139,11 +2145,20 @@ Perl_setlocale(const int category, const char * locale)
|
||||||
|
{
|
||||||
|
/* This wraps POSIX::setlocale() */
|
||||||
|
|
||||||
|
+#ifdef NO_LOCALE
|
||||||
|
+
|
||||||
|
+ PERL_UNUSED_ARG(category);
|
||||||
|
+ PERL_UNUSED_ARG(locale);
|
||||||
|
+
|
||||||
|
+ return "C";
|
||||||
|
+
|
||||||
|
+#else
|
||||||
|
+
|
||||||
|
const char * retval;
|
||||||
|
const char * newlocale;
|
||||||
|
dSAVEDERRNO;
|
||||||
|
- DECLARATION_FOR_LC_NUMERIC_MANIPULATION;
|
||||||
|
dTHX;
|
||||||
|
+ DECLARATION_FOR_LC_NUMERIC_MANIPULATION;
|
||||||
|
|
||||||
|
#ifdef USE_LOCALE_NUMERIC
|
||||||
|
|
||||||
|
@@ -2262,6 +2277,8 @@ Perl_setlocale(const int category, const char * locale)
|
||||||
|
|
||||||
|
return retval;
|
||||||
|
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
}
|
||||||
|
|
||||||
|
PERL_STATIC_INLINE const char *
|
||||||
|
@@ -2414,13 +2431,16 @@ S_my_nl_langinfo(const int item, bool toggle)
|
||||||
|
dTHX;
|
||||||
|
const char * retval;
|
||||||
|
|
||||||
|
+#ifdef USE_LOCALE_NUMERIC
|
||||||
|
+
|
||||||
|
/* We only need to toggle into the underlying LC_NUMERIC locale for these
|
||||||
|
* two items, and only if not already there */
|
||||||
|
if (toggle && (( item != RADIXCHAR && item != THOUSEP)
|
||||||
|
|| PL_numeric_underlying))
|
||||||
|
- {
|
||||||
|
+
|
||||||
|
+#endif /* No toggling needed if not using LC_NUMERIC */
|
||||||
|
+
|
||||||
|
toggle = FALSE;
|
||||||
|
- }
|
||||||
|
|
||||||
|
#if defined(HAS_NL_LANGINFO) /* nl_langinfo() is available. */
|
||||||
|
# if ! defined(HAS_THREAD_SAFE_NL_LANGINFO_L) \
|
||||||
|
@@ -2468,6 +2488,8 @@ S_my_nl_langinfo(const int item, bool toggle)
|
||||||
|
do_free = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
+# ifdef USE_LOCALE_NUMERIC
|
||||||
|
+
|
||||||
|
if (toggle) {
|
||||||
|
if (PL_underlying_numeric_obj) {
|
||||||
|
cur = PL_underlying_numeric_obj;
|
||||||
|
@@ -2478,6 +2500,8 @@ S_my_nl_langinfo(const int item, bool toggle)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
+# endif
|
||||||
|
+
|
||||||
|
/* We have to save it to a buffer, because the freelocale() just below
|
||||||
|
* can invalidate the internal one */
|
||||||
|
retval = save_to_buffer(nl_langinfo_l(item, cur),
|
||||||
|
@@ -5169,9 +5193,7 @@ Perl_my_strerror(pTHX_ const int errnum)
|
||||||
|
LOCALE_UNLOCK;
|
||||||
|
|
||||||
|
# endif /* End of doesn't have strerror_l */
|
||||||
|
-#endif /* End of does have locale messages */
|
||||||
|
-
|
||||||
|
-#ifdef DEBUGGING
|
||||||
|
+# ifdef DEBUGGING
|
||||||
|
|
||||||
|
if (DEBUG_Lv_TEST) {
|
||||||
|
PerlIO_printf(Perl_debug_log, "Strerror returned; saving a copy: '");
|
||||||
|
@@ -5179,7 +5201,8 @@ Perl_my_strerror(pTHX_ const int errnum)
|
||||||
|
PerlIO_printf(Perl_debug_log, "'\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
-#endif
|
||||||
|
+# endif
|
||||||
|
+#endif /* End of does have locale messages */
|
||||||
|
|
||||||
|
SAVEFREEPV(errstr);
|
||||||
|
return errstr;
|
||||||
|
@@ -5301,10 +5324,17 @@ L<C<Perl_switch_to_global_locale>|perlapi/switch_to_global_locale>.
|
||||||
|
bool
|
||||||
|
Perl_sync_locale()
|
||||||
|
{
|
||||||
|
+
|
||||||
|
+#ifndef USE_LOCALE
|
||||||
|
+
|
||||||
|
+ return TRUE;
|
||||||
|
+
|
||||||
|
+#else
|
||||||
|
+
|
||||||
|
const char * newlocale;
|
||||||
|
dTHX;
|
||||||
|
|
||||||
|
-#ifdef USE_POSIX_2008_LOCALE
|
||||||
|
+# ifdef USE_POSIX_2008_LOCALE
|
||||||
|
|
||||||
|
bool was_in_global_locale = FALSE;
|
||||||
|
locale_t cur_obj = uselocale((locale_t) 0);
|
||||||
|
@@ -5316,11 +5346,11 @@ Perl_sync_locale()
|
||||||
|
* will affect the */
|
||||||
|
if (cur_obj == LC_GLOBAL_LOCALE) {
|
||||||
|
|
||||||
|
-# ifdef HAS_QUERY_LOCALE
|
||||||
|
+# ifdef HAS_QUERY_LOCALE
|
||||||
|
|
||||||
|
do_setlocale_c(LC_ALL, setlocale(LC_ALL, NULL));
|
||||||
|
|
||||||
|
-# else
|
||||||
|
+# else
|
||||||
|
|
||||||
|
unsigned int i;
|
||||||
|
|
||||||
|
@@ -5330,17 +5360,17 @@ Perl_sync_locale()
|
||||||
|
do_setlocale_r(categories[i], setlocale(categories[i], NULL));
|
||||||
|
}
|
||||||
|
|
||||||
|
-# endif
|
||||||
|
+# endif
|
||||||
|
|
||||||
|
was_in_global_locale = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
-#else
|
||||||
|
+# else
|
||||||
|
|
||||||
|
bool was_in_global_locale = TRUE;
|
||||||
|
|
||||||
|
-#endif
|
||||||
|
-#ifdef USE_LOCALE_CTYPE
|
||||||
|
+# endif
|
||||||
|
+# ifdef USE_LOCALE_CTYPE
|
||||||
|
|
||||||
|
newlocale = savepv(do_setlocale_c(LC_CTYPE, NULL));
|
||||||
|
DEBUG_Lv(PerlIO_printf(Perl_debug_log,
|
||||||
|
@@ -5349,8 +5379,8 @@ Perl_sync_locale()
|
||||||
|
new_ctype(newlocale);
|
||||||
|
Safefree(newlocale);
|
||||||
|
|
||||||
|
-#endif /* USE_LOCALE_CTYPE */
|
||||||
|
-#ifdef USE_LOCALE_COLLATE
|
||||||
|
+# endif /* USE_LOCALE_CTYPE */
|
||||||
|
+# ifdef USE_LOCALE_COLLATE
|
||||||
|
|
||||||
|
newlocale = savepv(do_setlocale_c(LC_COLLATE, NULL));
|
||||||
|
DEBUG_Lv(PerlIO_printf(Perl_debug_log,
|
||||||
|
@@ -5359,8 +5389,8 @@ Perl_sync_locale()
|
||||||
|
new_collate(newlocale);
|
||||||
|
Safefree(newlocale);
|
||||||
|
|
||||||
|
-#endif
|
||||||
|
-#ifdef USE_LOCALE_NUMERIC
|
||||||
|
+# endif
|
||||||
|
+# ifdef USE_LOCALE_NUMERIC
|
||||||
|
|
||||||
|
newlocale = savepv(do_setlocale_c(LC_NUMERIC, NULL));
|
||||||
|
DEBUG_Lv(PerlIO_printf(Perl_debug_log,
|
||||||
|
@@ -5369,9 +5399,12 @@ Perl_sync_locale()
|
||||||
|
new_numeric(newlocale);
|
||||||
|
Safefree(newlocale);
|
||||||
|
|
||||||
|
-#endif /* USE_LOCALE_NUMERIC */
|
||||||
|
+# endif /* USE_LOCALE_NUMERIC */
|
||||||
|
|
||||||
|
return was_in_global_locale;
|
||||||
|
+
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
}
|
||||||
|
|
||||||
|
#if defined(DEBUGGING) && defined(USE_LOCALE)
|
||||||
|
diff --git a/makedef.pl b/makedef.pl
|
||||||
|
index dbd756d..661b71d 100644
|
||||||
|
--- a/makedef.pl
|
||||||
|
+++ b/makedef.pl
|
||||||
|
@@ -574,6 +574,9 @@ unless ($define{USE_LOCALE_COLLATE}) {
|
||||||
|
PL_collxfrm_mult
|
||||||
|
Perl_sv_collxfrm
|
||||||
|
Perl_sv_collxfrm_flags
|
||||||
|
+ PL_strxfrm_NUL_replacement
|
||||||
|
+ PL_strxfrm_is_behaved
|
||||||
|
+ PL_strxfrm_max_cp
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -583,6 +586,9 @@ unless ($define{USE_LOCALE_NUMERIC}) {
|
||||||
|
PL_numeric_name
|
||||||
|
PL_numeric_radix_sv
|
||||||
|
PL_numeric_standard
|
||||||
|
+ PL_numeric_underlying
|
||||||
|
+ PL_numeric_underlying_is_standard
|
||||||
|
+ PL_underlying_numeric_obj
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
diff --git a/perl.h b/perl.h
|
||||||
|
index 3e1f6cd..d457776 100644
|
||||||
|
--- a/perl.h
|
||||||
|
+++ b/perl.h
|
||||||
|
@@ -5657,6 +5657,9 @@ typedef struct am_table_short AMTS;
|
||||||
|
# define IN_LC_COMPILETIME(category) 0
|
||||||
|
# define IN_LC_RUNTIME(category) 0
|
||||||
|
# define IN_LC(category) 0
|
||||||
|
+# define _CHECK_AND_WARN_PROBLEMATIC_LOCALE
|
||||||
|
+# define _CHECK_AND_OUTPUT_WIDE_LOCALE_UTF8_MSG(s, send)
|
||||||
|
+# define _CHECK_AND_OUTPUT_WIDE_LOCALE_CP_MSG(c)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/proto.h b/proto.h
|
||||||
|
index 3e027ab..558c33a 100644
|
||||||
|
--- a/proto.h
|
||||||
|
+++ b/proto.h
|
||||||
|
@@ -4669,8 +4669,6 @@ PERL_CALLCONV SV* Perl_hfree_next_entry(pTHX_ HV *hv, STRLEN *indexp);
|
||||||
|
assert(hv); assert(indexp)
|
||||||
|
#endif
|
||||||
|
#if defined(PERL_IN_LOCALE_C)
|
||||||
|
-STATIC const char* S_category_name(const int category);
|
||||||
|
-STATIC void S_restore_switched_locale(pTHX_ const int category, const char * const original_locale);
|
||||||
|
#ifndef PERL_NO_INLINE_FUNCTIONS
|
||||||
|
PERL_STATIC_INLINE const char * S_save_to_buffer(const char * string, char **buf, Size_t *buf_size, const Size_t offset)
|
||||||
|
__attribute__warn_unused_result__;
|
||||||
|
@@ -4678,17 +4676,19 @@ PERL_STATIC_INLINE const char * S_save_to_buffer(const char * string, char **buf
|
||||||
|
assert(buf_size)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
-STATIC const char* S_switch_category_locale_to_template(pTHX_ const int switch_category, const int template_category, const char * template_locale);
|
||||||
|
# if defined(USE_LOCALE)
|
||||||
|
+STATIC const char* S_category_name(const int category);
|
||||||
|
STATIC void S_new_collate(pTHX_ const char* newcoll);
|
||||||
|
STATIC void S_new_ctype(pTHX_ const char* newctype);
|
||||||
|
#define PERL_ARGS_ASSERT_NEW_CTYPE \
|
||||||
|
assert(newctype)
|
||||||
|
STATIC void S_new_numeric(pTHX_ const char* newnum);
|
||||||
|
+STATIC void S_restore_switched_locale(pTHX_ const int category, const char * const original_locale);
|
||||||
|
STATIC void S_set_numeric_radix(pTHX_ const bool use_locale);
|
||||||
|
STATIC char* S_stdize_locale(pTHX_ char* locs);
|
||||||
|
#define PERL_ARGS_ASSERT_STDIZE_LOCALE \
|
||||||
|
assert(locs)
|
||||||
|
+STATIC const char* S_switch_category_locale_to_template(pTHX_ const int switch_category, const int template_category, const char * template_locale);
|
||||||
|
# if defined(USE_POSIX_2008_LOCALE)
|
||||||
|
STATIC const char* S_emulate_setlocale(const int category, const char* locale, unsigned int index, const bool is_index_valid);
|
||||||
|
# endif
|
||||||
|
diff --git a/sv.c b/sv.c
|
||||||
|
index 07865bb..81223ca 100644
|
||||||
|
--- a/sv.c
|
||||||
|
+++ b/sv.c
|
||||||
|
@@ -13330,10 +13330,15 @@ Perl_sv_vcatpvfn_flags(pTHX_ SV *const sv, const char *const pat, const STRLEN p
|
||||||
|
|
||||||
|
SvTAINT(sv);
|
||||||
|
|
||||||
|
+#ifdef USE_LOCALE_NUMERIC
|
||||||
|
+
|
||||||
|
if (lc_numeric_set) {
|
||||||
|
RESTORE_LC_NUMERIC(); /* Done outside loop, so don't have to
|
||||||
|
save/restore each iteration. */
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
}
|
||||||
|
|
||||||
|
/* =========================================================================
|
||||||
|
diff --git a/t/lib/warnings/regexec b/t/lib/warnings/regexec
|
||||||
|
index 900dd6e..b9e53c9 100644
|
||||||
|
--- a/t/lib/warnings/regexec
|
||||||
|
+++ b/t/lib/warnings/regexec
|
||||||
|
@@ -215,6 +215,10 @@ Use of \b{} or \B{} for non-UTF-8 locale is wrong. Assuming a UTF-8 locale at -
|
||||||
|
Use of \b{} or \B{} for non-UTF-8 locale is wrong. Assuming a UTF-8 locale at - line 17.
|
||||||
|
########
|
||||||
|
# NAME (?[ ]) in non-UTF-8 locale
|
||||||
|
+require '../loc_tools.pl';
|
||||||
|
+unless (locales_enabled()) {
|
||||||
|
+ print("SKIPPED\n# locales not available\n"),exit;
|
||||||
|
+}
|
||||||
|
eval { require POSIX; POSIX->import("locale_h") };
|
||||||
|
if ($@) {
|
||||||
|
print("SKIPPED\n# no POSIX\n"),exit;
|
||||||
|
@@ -229,14 +233,14 @@ setlocale(&POSIX::LC_CTYPE, "C");
|
||||||
|
":" =~ /(?[ \: ])/;
|
||||||
|
no warnings 'locale';
|
||||||
|
EXPECT
|
||||||
|
-Use of (?[ ]) for non-UTF-8 locale is wrong. Assuming a UTF-8 locale at - line 9.
|
||||||
|
-Use of (?[ ]) for non-UTF-8 locale is wrong. Assuming a UTF-8 locale at - line 9.
|
||||||
|
-Use of (?[ ]) for non-UTF-8 locale is wrong. Assuming a UTF-8 locale at - line 10.
|
||||||
|
-Use of (?[ ]) for non-UTF-8 locale is wrong. Assuming a UTF-8 locale at - line 10.
|
||||||
|
-Use of (?[ ]) for non-UTF-8 locale is wrong. Assuming a UTF-8 locale at - line 11.
|
||||||
|
-Use of (?[ ]) for non-UTF-8 locale is wrong. Assuming a UTF-8 locale at - line 11.
|
||||||
|
-Use of (?[ ]) for non-UTF-8 locale is wrong. Assuming a UTF-8 locale at - line 12.
|
||||||
|
-Use of (?[ ]) for non-UTF-8 locale is wrong. Assuming a UTF-8 locale at - line 12.
|
||||||
|
+Use of (?[ ]) for non-UTF-8 locale is wrong. Assuming a UTF-8 locale at - line 13.
|
||||||
|
+Use of (?[ ]) for non-UTF-8 locale is wrong. Assuming a UTF-8 locale at - line 13.
|
||||||
|
+Use of (?[ ]) for non-UTF-8 locale is wrong. Assuming a UTF-8 locale at - line 14.
|
||||||
|
+Use of (?[ ]) for non-UTF-8 locale is wrong. Assuming a UTF-8 locale at - line 14.
|
||||||
|
+Use of (?[ ]) for non-UTF-8 locale is wrong. Assuming a UTF-8 locale at - line 15.
|
||||||
|
+Use of (?[ ]) for non-UTF-8 locale is wrong. Assuming a UTF-8 locale at - line 15.
|
||||||
|
+Use of (?[ ]) for non-UTF-8 locale is wrong. Assuming a UTF-8 locale at - line 16.
|
||||||
|
+Use of (?[ ]) for non-UTF-8 locale is wrong. Assuming a UTF-8 locale at - line 16.
|
||||||
|
########
|
||||||
|
# NAME (?[ ]) in UTF-8 locale
|
||||||
|
require '../loc_tools.pl';
|
|
@ -1,7 +1,7 @@
|
||||||
# This makefile simplifies perl module builds.
|
# This makefile simplifies perl module builds.
|
||||||
#
|
#
|
||||||
|
|
||||||
PERL_VERSION:=5.26
|
PERL_VERSION:=5.28
|
||||||
|
|
||||||
# Build environment
|
# Build environment
|
||||||
HOST_PERL_PREFIX:=$(STAGING_DIR_HOSTPKG)/usr
|
HOST_PERL_PREFIX:=$(STAGING_DIR_HOSTPKG)/usr
|
||||||
|
|
Loading…
Reference in a new issue