aboutsummaryrefslogtreecommitdiffstats
path: root/includes/parser/CoreMagicVariables.php
diff options
context:
space:
mode:
authorC. Scott Ananian <cscott@cscott.net>2022-03-11 11:21:33 -0500
committerC. Scott Ananian <cscott@cscott.net>2022-03-14 17:30:15 -0400
commitb72fa830d60290ceffb679a20bb8f450721cb4b9 (patch)
tree12cdfc3038adb99a2c76b7cafb5ac95fa3b1f52d /includes/parser/CoreMagicVariables.php
parenta6d443f352aa6ee3e2f37177f9e6ed6c041dc37e (diff)
downloadmediawikicore-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.php74
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