Skip to content

Commit ad95a63

Browse files
committed
plperl: windows: Use Perl_setlocale on 5.28+, fixing compile failure.
For older versions we need our own copy of perl's setlocale(), because it was not exposed (why we need the setlocale in the first place is explained in plperl_init_interp) . The copy stopped working in 5.28, as some of the used macros are not public anymore. But Perl_setlocale is available in 5.28, so use that. Author: Victor Wagner <vitus@wagner.pp.ru> Reviewed-By: Dagfinn Ilmari Mannsåker <ilmari@ilmari.org> Discussion: https://postgr.es/m/20200501134711.08750c5f@antares.wagner.home Backpatch: all versions
1 parent 5cb8864 commit ad95a63

File tree

1 file changed

+8
-5
lines changed

1 file changed

+8
-5
lines changed

src/pl/plperl/plperl.c

Lines changed: 8 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -302,9 +302,11 @@ static char *strip_trailing_ws(const char *msg);
302302
static OP *pp_require_safe(pTHX);
303303
static void activate_interpreter(plperl_interp_desc *interp_desc);
304304

305-
#ifdef WIN32
305+
#if defined(WIN32) && PERL_VERSION_LT(5, 28, 0)
306306
static char *setlocale_perl(int category, char *locale);
307-
#endif
307+
#else
308+
#define setlocale_perl(a,b) Perl_setlocale(a,b)
309+
#endif /* defined(WIN32) && PERL_VERSION_LT(5, 28, 0) */
308310

309311
/*
310312
* Decrement the refcount of the given SV within the active Perl interpreter
@@ -4138,8 +4140,10 @@ plperl_inline_callback(void *arg)
41384140
/*
41394141
* Perl's own setlocale(), copied from POSIX.xs
41404142
* (needed because of the calls to new_*())
4143+
*
4144+
* Starting in 5.28, perl exposes Perl_setlocale to do so.
41414145
*/
4142-
#ifdef WIN32
4146+
#if defined(WIN32) && PERL_VERSION_LT(5, 28, 0)
41434147
static char *
41444148
setlocale_perl(int category, char *locale)
41454149
{
@@ -4207,5 +4211,4 @@ setlocale_perl(int category, char *locale)
42074211

42084212
return RETVAL;
42094213
}
4210-
4211-
#endif /* WIN32 */
4214+
#endif /* defined(WIN32) && PERL_VERSION_LT(5, 28, 0) */

0 commit comments

Comments
 (0)