__UNDEFINED__ Perl_setlocale LOCK_NUMERIC_STANDARD UNLOCK_NUMERIC_STANDARD
#if PERL_VERSION_LT(5,27,9) __UNDEFINED__ LC_NUMERIC_LOCK __UNDEFINED__ LC_NUMERIC_UNLOCK # if PERL_VERSION_LT(5,19,0) # undef STORE_LC_NUMERIC_SET_STANDARD # undef RESTORE_LC_NUMERIC # undef DECLARATION_FOR_LC_NUMERIC_MANIPULATION # ifdef USE_LOCALE __UNDEFINED__ DECLARATION_FOR_LC_NUMERIC_MANIPULATION char *LoC_ __UNDEFINED__ STORE_NUMERIC_SET_STANDARD() \ LoC_ = savepv(setlocale(LC_NUMERIC, NULL)); \ SAVEFREEPV(LoC_); \ setlocale(LC_NUMERIC, "C"); __UNDEFINED__ RESTORE_LC_NUMERIC() \ setlocale(LC_NUMERIC, LoC_); # else __UNDEFINED__ DECLARATION_FOR_LC_NUMERIC_MANIPULATION __UNDEFINED__ STORE_LC_NUMERIC_SET_STANDARD() __UNDEFINED__ RESTORE_LC_NUMERIC() # endif # endif #endif
#ifndef LOCK_NUMERIC_STANDARD # define LOCK_NUMERIC_STANDARD() #endif
#ifndef UNLOCK_NUMERIC_STANDARD # define UNLOCK_NUMERIC_STANDARD() #endif
/* The names of these changed in 5.28 */ __UNDEFINED__ LOCK_LC_NUMERIC_STANDARD LOCK_NUMERIC_STANDARD __UNDEFINED__ UNLOCK_LC_NUMERIC_STANDARD UNLOCK_NUMERIC_STANDARD
/* If this doesn't exist, it's not needed, so is void noop */ __UNDEFINED__ switch_to_global_locale()
/* Originally, this didn't return a value, but in perls like that, the value * should always be TRUE. Add a return to Perl_sync_locale() when it's * available. And actually do a sync when its not, if locales are available on * this system. */ #ifdef sync_locale # if { VERSION < 5.27.9 } # if { VERSION >= 5.21.3 } # undef sync_locale # define sync_locale() (Perl_sync_locale(aTHX), 1) # elif defined(sync_locale) /* These should only be the 5.20 maints*/ # undef sync_locale /* Just copy their defn and return 1 */ # define sync_locale() (new_ctype(setlocale(LC_CTYPE, NULL)), \ new_collate(setlocale(LC_COLLATE, NULL)), \ set_numeric_local(), \ new_numeric(setlocale(LC_NUMERIC, NULL)), \ 1) # elif defined(new_ctype) && defined(LC_CTYPE) # define sync_locale() (new_ctype(setlocale(LC_CTYPE, NULL)), 1) # endif # endif #endif
__UNDEFINED__ sync_locale() 1
/* Warning: Perl_setlocale * This function will compile and run in even the earliest perls supported by * PPPort, but there were significant locale-related bugs that may prevent its * proper operation until v5.22. The final bugs to be fixed in the releases * leading up to that one involved setting and querying the locale for * LC_NUMERIC. */
#if { VERSION < 5.27.2 } # if { NEED Perl_setlocale }
const char * Perl_setlocale(const int category, const char * locale) { CV * setlocale; dTHX;
# ifdef D_PPP_usechar
char * locale_afterwards;
dSP;
# else
SV * locale_afterwards;
dXSARGS;
# endif
load_module(PERL_LOADMOD_NOIMPORT, newSVpvs("POSIX"), NULL);
setlocale = get_cv("POSIX::setlocale", 0);
assert(setlocale);
# if defined(PUSHSTACKi) && defined(PERLSI_REQUIRE) && defined(POPSTACK)
PUSHSTACKi(PERLSI_REQUIRE);
# endif
ENTER ;
SAVETMPS;
PUSHMARK(SP) ;
mXPUSHi(category);
mXPUSHp(locale, strlen(locale));
PUTBACK;
call_sv(MUTABLE_SV(setlocale), G_SCALAR);
SPAGAIN ;
# ifdef D_PPP_usechar
locale_afterwards = POPp;
# else
locale_afterwards = POPs;
SvREFCNT_inc_simple_void_NN(locale_afterwards);
# endif
PUTBACK ;
FREETMPS ;
LEAVE ;
# if defined(PUSHSTACKi) && defined(PERLSI_REQUIRE) && defined(POPSTACK)
POPSTACK;
# endif # ifdef D_PPP_usechar
return(locale_afterwards);
# else
if (! SvPOK(locale_afterwards)) {
XSRETURN_UNDEF;
}
return(savepv(SvPVX_const(locale_afterwards)));
# endif
}
# endif #endif
#define NEED_Perl_setlocale
bool sync_locale() CODE: RETVAL = sync_locale(); OUTPUT: RETVAL
char * Perl_setlocale(locale = 0) char * locale PREINIT: char * retval; CODE: /*const in input not valid in 5.7.0 */ retval = (char *) Perl_setlocale(LC_ALL, locale); if (! retval) { XSRETURN_UNDEF; } RETVAL = retval; OUTPUT: RETVAL
use Config;
# We don't know for sure that we are in the global locale for testing. But # if this is unthreaded, it almost certainly is. But Configure can be called # to force POSIX locales on unthreaded systems. If this becomes a problem # this check could be beefed up. if ($Config{usethreads}) { ok(1, "ironically we have to skip testing sync_locale under threads"); } else { ok(&Devel::PPPort::sync_locale(), "sync_locale returns TRUE"); }
is(&Devel::PPPort::Perl_setlocale("C"), "C", "setlocale returns 'C' when setting to 'C'");
5 POD Errors
The following errors were encountered while parsing the POD:
- Around line 1:
Unknown directive: =provides
- Around line 8:
Unknown directive: =implementation
- Around line 160:
Unknown directive: =xsinit
- Around line 164:
Unknown directive: =xsubs
- Around line 188:
Unknown directive: =tests