diff options
author | C. Scott Ananian <cscott@cscott.net> | 2022-03-11 11:21:33 -0500 |
---|---|---|
committer | C. Scott Ananian <cscott@cscott.net> | 2022-03-14 17:30:15 -0400 |
commit | b72fa830d60290ceffb679a20bb8f450721cb4b9 (patch) | |
tree | 12cdfc3038adb99a2c76b7cafb5ac95fa3b1f52d /includes/parser/CoreMagicVariables.php | |
parent | a6d443f352aa6ee3e2f37177f9e6ed6c041dc37e (diff) | |
download | mediawikicore-b72fa830d60290ceffb679a20bb8f450721cb4b9.tar.gz mediawikicore-b72fa830d60290ceffb679a20bb8f450721cb4b9.zip |
Pass a ConvertibleTimestamp to CoreMagicVariables
This avoids a type mismatch found by phan strict checks
(Ifc7fc64ac26a756f181b7d0155f13a6500114f5e) -- the passed timestamp
from Parser was a string in unix format (ie, an integer as a string)
but was declared as an integer. It was then passed to
MWTimestamp::getInstance() which expected a string.
However, the 'simple' fix for this issue still caused unnecessary
conversions to/from timestamp format. We took the string (nominally
in TS_MW format), ran a regexp against it to convert it to an
MWTimestamp instance, then converted that MWTimestamp to UNIX format
and exported that as a string, just to take that string and run four
different regexps against it *again* to convert it back to an
MWTimestamp instance so we can format it.
Better to just pass the MWTimestamp directly. Only two wrinkles:
1. the ParserGetVariableValueTs hook expects to be passed a string
in TS_UNIX format and then to be able to mutate it. Nothing in production
uses that hook, so only do this conversion if the hook is registered.
2. Parsoid would like to use the definitions in CoreMagicVariables
in the future as well. So pass the timestamp as the not-MW-@internal
ConvertibleTimestamp class instead of directly as a MWTimestamp.
Change-Id: Ib2c5fa45630c54c2716897370a0580ed48d27242
Diffstat (limited to 'includes/parser/CoreMagicVariables.php')
-rw-r--r-- | includes/parser/CoreMagicVariables.php | 74 |
1 files changed, 44 insertions, 30 deletions
diff --git a/includes/parser/CoreMagicVariables.php b/includes/parser/CoreMagicVariables.php index 3a2571071f97..85ace21eb674 100644 --- a/includes/parser/CoreMagicVariables.php +++ b/includes/parser/CoreMagicVariables.php @@ -23,6 +23,7 @@ use MediaWiki\Config\ServiceOptions; use MediaWiki\Parser\ParserOutputFlags; use Psr\Log\LoggerInterface; +use Wikimedia\Timestamp\ConvertibleTimestamp; /** * Expansions of core magic variables, used by the parser. @@ -39,7 +40,7 @@ class CoreMagicVariables { * @param Parser $parser * @param string $id The name of the variable, and equivalently, the magic * word ID which was used to match the variable - * @param int $ts Timestamp to use when expanding magic variable + * @param ConvertibleTimestamp $ts Timestamp to use when expanding magic variable * @param NamespaceInfo $nsInfo The NamespaceInfo to use when expanding * @param ServiceOptions $svcOptions Service options for the parser * @param LoggerInterface $logger @@ -51,7 +52,7 @@ class CoreMagicVariables { Parser $parser, string $id, // Context passed over from the parser - int $ts, + ConvertibleTimestamp $ts, NamespaceInfo $nsInfo, ServiceOptions $svcOptions, LoggerInterface $logger @@ -63,33 +64,33 @@ class CoreMagicVariables { case '!': return '|'; case 'currentmonth': - return $pageLang->formatNumNoSeparators( MWTimestamp::getInstance( $ts )->format( 'm' ) ); + return $pageLang->formatNumNoSeparators( $ts->format( 'm' ) ); case 'currentmonth1': - return $pageLang->formatNumNoSeparators( MWTimestamp::getInstance( $ts )->format( 'n' ) ); + return $pageLang->formatNumNoSeparators( $ts->format( 'n' ) ); case 'currentmonthname': - return $pageLang->getMonthName( MWTimestamp::getInstance( $ts )->format( 'n' ) ); + return $pageLang->getMonthName( $ts->format( 'n' ) ); case 'currentmonthnamegen': - return $pageLang->getMonthNameGen( MWTimestamp::getInstance( $ts )->format( 'n' ) ); + return $pageLang->getMonthNameGen( $ts->format( 'n' ) ); case 'currentmonthabbrev': - return $pageLang->getMonthAbbreviation( MWTimestamp::getInstance( $ts )->format( 'n' ) ); + return $pageLang->getMonthAbbreviation( $ts->format( 'n' ) ); case 'currentday': - return $pageLang->formatNumNoSeparators( MWTimestamp::getInstance( $ts )->format( 'j' ) ); + return $pageLang->formatNumNoSeparators( $ts->format( 'j' ) ); case 'currentday2': - return $pageLang->formatNumNoSeparators( MWTimestamp::getInstance( $ts )->format( 'd' ) ); + return $pageLang->formatNumNoSeparators( $ts->format( 'd' ) ); case 'localmonth': - return $pageLang->formatNumNoSeparators( MWTimestamp::getLocalInstance( $ts )->format( 'm' ) ); + return $pageLang->formatNumNoSeparators( self::makeTsLocal( $svcOptions, $ts )->format( 'm' ) ); case 'localmonth1': - return $pageLang->formatNumNoSeparators( MWTimestamp::getLocalInstance( $ts )->format( 'n' ) ); + return $pageLang->formatNumNoSeparators( self::makeTsLocal( $svcOptions, $ts )->format( 'n' ) ); case 'localmonthname': - return $pageLang->getMonthName( MWTimestamp::getLocalInstance( $ts )->format( 'n' ) ); + return $pageLang->getMonthName( self::makeTsLocal( $svcOptions, $ts )->format( 'n' ) ); case 'localmonthnamegen': - return $pageLang->getMonthNameGen( MWTimestamp::getLocalInstance( $ts )->format( 'n' ) ); + return $pageLang->getMonthNameGen( self::makeTsLocal( $svcOptions, $ts )->format( 'n' ) ); case 'localmonthabbrev': - return $pageLang->getMonthAbbreviation( MWTimestamp::getLocalInstance( $ts )->format( 'n' ) ); + return $pageLang->getMonthAbbreviation( self::makeTsLocal( $svcOptions, $ts )->format( 'n' ) ); case 'localday': - return $pageLang->formatNumNoSeparators( MWTimestamp::getLocalInstance( $ts )->format( 'j' ) ); + return $pageLang->formatNumNoSeparators( self::makeTsLocal( $svcOptions, $ts )->format( 'j' ) ); case 'localday2': - return $pageLang->formatNumNoSeparators( MWTimestamp::getLocalInstance( $ts )->format( 'd' ) ); + return $pageLang->formatNumNoSeparators( self::makeTsLocal( $svcOptions, $ts )->format( 'd' ) ); case 'pagename': return wfEscapeWikiText( $title->getText() ); case 'pagenamee': @@ -240,39 +241,39 @@ class CoreMagicVariables { case 'subjectspacee': return ( wfUrlencode( $title->getSubjectNsText() ) ); case 'currentdayname': - return $pageLang->getWeekdayName( (int)MWTimestamp::getInstance( $ts )->format( 'w' ) + 1 ); + return $pageLang->getWeekdayName( (int)$ts->format( 'w' ) + 1 ); case 'currentyear': - return $pageLang->formatNumNoSeparators( MWTimestamp::getInstance( $ts )->format( 'Y' ) ); + return $pageLang->formatNumNoSeparators( $ts->format( 'Y' ) ); case 'currenttime': - return $pageLang->time( wfTimestamp( TS_MW, $ts ), false, false ); + return $pageLang->time( $ts->getTimestamp( TS_MW ), false, false ); case 'currenthour': - return $pageLang->formatNumNoSeparators( MWTimestamp::getInstance( $ts )->format( 'H' ) ); + return $pageLang->formatNumNoSeparators( $ts->format( 'H' ) ); case 'currentweek': // @bug T6594 PHP5 has it zero padded, PHP4 does not, cast to // int to remove the padding - return $pageLang->formatNum( (int)MWTimestamp::getInstance( $ts )->format( 'W' ) ); + return $pageLang->formatNum( (int)$ts->format( 'W' ) ); case 'currentdow': - return $pageLang->formatNum( MWTimestamp::getInstance( $ts )->format( 'w' ) ); + return $pageLang->formatNum( $ts->format( 'w' ) ); case 'localdayname': return $pageLang->getWeekdayName( - (int)MWTimestamp::getLocalInstance( $ts )->format( 'w' ) + 1 + (int)self::makeTsLocal( $svcOptions, $ts )->format( 'w' ) + 1 ); case 'localyear': - return $pageLang->formatNumNoSeparators( MWTimestamp::getLocalInstance( $ts )->format( 'Y' ) ); + return $pageLang->formatNumNoSeparators( self::makeTsLocal( $svcOptions, $ts )->format( 'Y' ) ); case 'localtime': return $pageLang->time( - MWTimestamp::getLocalInstance( $ts )->format( 'YmdHis' ), + self::makeTsLocal( $svcOptions, $ts )->format( 'YmdHis' ), false, false ); case 'localhour': - return $pageLang->formatNumNoSeparators( MWTimestamp::getLocalInstance( $ts )->format( 'H' ) ); + return $pageLang->formatNumNoSeparators( self::makeTsLocal( $svcOptions, $ts )->format( 'H' ) ); case 'localweek': // @bug T6594 PHP5 has it zero padded, PHP4 does not, cast to // int to remove the padding - return $pageLang->formatNum( (int)MWTimestamp::getLocalInstance( $ts )->format( 'W' ) ); + return $pageLang->formatNum( (int)self::makeTsLocal( $svcOptions, $ts )->format( 'W' ) ); case 'localdow': - return $pageLang->formatNum( MWTimestamp::getLocalInstance( $ts )->format( 'w' ) ); + return $pageLang->formatNum( self::makeTsLocal( $svcOptions, $ts )->format( 'w' ) ); case 'numberofarticles': return $pageLang->formatNum( SiteStats::articles() ); case 'numberoffiles': @@ -288,9 +289,9 @@ class CoreMagicVariables { case 'numberofedits': return $pageLang->formatNum( SiteStats::edits() ); case 'currenttimestamp': - return wfTimestamp( TS_MW, $ts ); + return $ts->getTimestamp( TS_MW ); case 'localtimestamp': - return MWTimestamp::getLocalInstance( $ts )->format( 'YmdHis' ); + return self::makeTsLocal( $svcOptions, $ts )->format( 'YmdHis' ); case 'currentversion': return SpecialVersion::getVersion(); case 'articlepath': @@ -320,6 +321,19 @@ class CoreMagicVariables { } /** + * Helper to convert a timestamp instance to local time + * @see MWTimestamp::getLocalInstance() + * @param ServiceOptions $svcOptions Service options for the parser + * @param ConvertibleTimestamp $ts Timestamp to convert + * @return ConvertibleTimestamp + */ + private static function makeTsLocal( $svcOptions, $ts ) { + $localtimezone = $svcOptions->get( 'Localtimezone' ); + $ts->setTimezone( $localtimezone ); + return $ts; + } + + /** * @param Parser $parser * @param LoggerInterface $logger * @param int $start |