From 9e254b0b5b145c9bfc3053e778e9f7fbb3760b45 Mon Sep 17 00:00:00 2001 From: Karl Williamson Date: Wed, 5 Apr 2023 12:26:26 -0600 Subject: [PATCH] PERL_SET_LOCALE_CONTEXT: Actually do something This is a macro that does a quick check before calling a function to actually do the work. The sense of that check was reversed. The check is repeated in the function, but this time correctly. The bottom line was if the function should be called, the macro failed to call it. If it shouldn't be called the macro would call it, but the check in the function caused it to return without doing anything. Hence this whole thing was a no-op. However, I cant get things to fail without this patch. ISTR this was the result of a BBC, with another one likely affected, but I can't find them now. --- perl.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/perl.h b/perl.h index 4ef161db95b4..1257a5595144 100644 --- a/perl.h +++ b/perl.h @@ -6365,7 +6365,7 @@ EXTCONST U8 PL_deBruijn_bitpos_tab64[]; #ifdef USE_PERL_SWITCH_LOCALE_CONTEXT # define PERL_SET_LOCALE_CONTEXT(i) \ STMT_START { \ - if (UNLIKELY(PL_veto_switch_non_tTHX_context)) \ + if (LIKELY(! PL_veto_switch_non_tTHX_context)) \ Perl_switch_locale_context(); \ } STMT_END #else