From: jenkins-bot Date: Wed, 25 Jul 2018 22:49:39 +0000 (+0000) Subject: Merge "Add helper trait for deprecating properties" X-Git-Tag: 1.34.0-rc.0~4659 X-Git-Url: http://git.cyclocoop.org/%7B%24www_url%7Dadmin/compta/operations/recherche.php?a=commitdiff_plain;h=9f32a4dc89ec5788987e1378b05f156b7d666db3;hp=4aedefdbfd193f323097354bf581de1c93f02715;p=lhc%2Fweb%2Fwiklou.git Merge "Add helper trait for deprecating properties" --- diff --git a/RELEASE-NOTES-1.32 b/RELEASE-NOTES-1.32 index c2dbd9d9c1..486645a867 100644 --- a/RELEASE-NOTES-1.32 +++ b/RELEASE-NOTES-1.32 @@ -95,6 +95,9 @@ production. * (T198935) User list preferences such as `email-blacklist` and similar extension preferences are no longer represented as arrays when returned by action=query&meta=userinfo&uiprop=options. +* 'missingparam' errors will now use the prefixed parameter name in the code + and error text, e.g. "noxxfoo" and "The 'xxfoo' parameter must be set" rather + than "nofoo" and "The 'foo' parameter must be set". === Action API internal changes in 1.32 === * Added 'ApiParseMakeOutputPage' hook. @@ -192,9 +195,6 @@ because of Phabricator reports. CapsuleMultiselectWidget. The following methods may no longer be used: * setItemsFromData: Use setValue instead * getItemsData: Use getItems instead and get the data property -* LanguageCode::bcp47() now always returns a valid BCP 47 code. This means - that some MediaWiki-specific language codes, such as `simple`, are mapped - into valid BCP 47 codes (eg `en-simple`). === Deprecations in 1.32 === * Use of a StartProfiler.php file is deprecated in favour of placing @@ -275,6 +275,14 @@ because of Phabricator reports. override this methods. * SearchEngine::replacePrefixes( $query ) should no longer be called prior to running searchText/searchTitle. +* (T199657) Messages for $wgFilterLogTypes labels should be no longer be in the + 'log-show-hide-[type]' format. Instead use 'logeventslist-[type]-log'. +* Global functions wfArrayFilter() and wfArrayFilterByKey() are deprecated. + use array_filter() directly. +* The $wgShowSQLErrors global is deprecated and nonfunctional. + Set $wgShowExceptionDetails and/or $wgShowHostnames instead. +* The $wgShowDBErrorBacktrace global is deprecated and nonfunctional. + Set $wgShowExceptionDetails instead. === Other changes in 1.32 === * (T198811) The following tables have had their UNIQUE indexes turned into diff --git a/autoload.php b/autoload.php index ac34efbaf1..4018b3cf10 100644 --- a/autoload.php +++ b/autoload.php @@ -704,7 +704,6 @@ $wgAutoloadLocalClasses = [ 'JobQueueMemory' => __DIR__ . '/includes/jobqueue/JobQueueMemory.php', 'JobQueueReadOnlyError' => __DIR__ . '/includes/jobqueue/JobQueue.php', 'JobQueueRedis' => __DIR__ . '/includes/jobqueue/JobQueueRedis.php', - 'JobQueueSecondTestQueue' => __DIR__ . '/includes/jobqueue/JobQueueSecondTestQueue.php', 'JobRunner' => __DIR__ . '/includes/jobqueue/JobRunner.php', 'JobSpecification' => __DIR__ . '/includes/jobqueue/JobSpecification.php', 'JpegHandler' => __DIR__ . '/includes/media/JpegHandler.php', @@ -890,6 +889,7 @@ $wgAutoloadLocalClasses = [ 'MediaWiki\\Auth\\Throttler' => __DIR__ . '/includes/auth/Throttler.php', 'MediaWiki\\Auth\\UserDataAuthenticationRequest' => __DIR__ . '/includes/auth/UserDataAuthenticationRequest.php', 'MediaWiki\\Auth\\UsernameAuthenticationRequest' => __DIR__ . '/includes/auth/UsernameAuthenticationRequest.php', + 'MediaWiki\\Config\\ConfigRepository' => __DIR__ . '/includes/config/ConfigRepository.php', 'MediaWiki\\DB\\PatchFileLocation' => __DIR__ . '/includes/db/PatchFileLocation.php', 'MediaWiki\\Diff\\ComplexityException' => __DIR__ . '/includes/diff/ComplexityException.php', 'MediaWiki\\Diff\\WordAccumulator' => __DIR__ . '/includes/diff/WordAccumulator.php', @@ -1212,6 +1212,7 @@ $wgAutoloadLocalClasses = [ 'ReplicatedBagOStuff' => __DIR__ . '/includes/libs/objectcache/ReplicatedBagOStuff.php', 'RepoGroup' => __DIR__ . '/includes/filerepo/RepoGroup.php', 'RequestContext' => __DIR__ . '/includes/context/RequestContext.php', + 'ResetAuthenticationThrottle' => __DIR__ . '/maintenance/resetAuthenticationThrottle.php', 'ResetUserEmail' => __DIR__ . '/maintenance/resetUserEmail.php', 'ResetUserTokens' => __DIR__ . '/maintenance/resetUserTokens.php', 'ResourceFileCache' => __DIR__ . '/includes/cache/ResourceFileCache.php', diff --git a/composer.json b/composer.json index f8de4c3022..b16983f957 100644 --- a/composer.json +++ b/composer.json @@ -55,6 +55,7 @@ "zordius/lightncandy": "0.23" }, "require-dev": { + "cache/integration-tests": "0.16.0", "composer/spdx-licenses": "1.3.0", "hamcrest/hamcrest-php": "^2.0", "jakub-onderka/php-parallel-lint": "0.9.2", @@ -63,6 +64,7 @@ "mediawiki/mediawiki-codesniffer": "20.0.0", "monolog/monolog": "~1.22.1", "nikic/php-parser": "3.1.3", + "seld/jsonlint": "1.7.1", "nmred/kafka-php": "0.1.5", "phpunit/phpunit": "4.8.36 || ^6.5", "psy/psysh": "0.9.6", diff --git a/docs/uidesign/table-layout.html b/docs/uidesign/table-layout.html deleted file mode 100644 index 2c268199b0..0000000000 --- a/docs/uidesign/table-layout.html +++ /dev/null @@ -1,59 +0,0 @@ - - - - - - - -

-This play with table-layout:fixed; and applying the width to colgroup or col element. Firefox only recongize the width if it is applied on col element!

-

-On a perfect browser, both tables should look the same

- -
-
colgroup
-
300 px width is applied to the first colgroup element
-
-
- - - - - - - - - -
Very long?#$
-
- -
-
col
-
Each colgroup has an additional col element. The first col element is applied the 300 px width
-
- -
- - - - - - - - - -
Very long?#$
-
diff --git a/includes/Category.php b/includes/Category.php index f8ac8aeb59..3352c2c2b0 100644 --- a/includes/Category.php +++ b/includes/Category.php @@ -420,4 +420,45 @@ class Category { return true; } + + /** + * Call refreshCounts() if there are no entries in the categorylinks table + * or if the category table has a row that states that there are no entries + * + * Due to lock errors or other failures, the precomputed counts can get out of sync, + * making it hard to know when to delete the category row without checking the + * categorylinks table. + * + * @return bool Whether links were refreshed + * @since 1.32 + */ + public function refreshCountsIfEmpty() { + $dbw = wfGetDB( DB_MASTER ); + + $hasLink = $dbw->selectField( + 'categorylinks', + '1', + [ 'cl_to' => $this->getName() ], + __METHOD__ + ); + if ( !$hasLink ) { + $this->refreshCounts(); // delete any category table entry + + return true; + } + + $hasBadRow = $dbw->selectField( + 'category', + '1', + [ 'cat_title' => $this->getName(), 'cat_pages <= 0' ], + __METHOD__ + ); + if ( $hasBadRow ) { + $this->refreshCounts(); // clean up this row + + return true; + } + + return false; + } } diff --git a/includes/DefaultSettings.php b/includes/DefaultSettings.php index 9a08c8c8aa..13d5368fac 100644 --- a/includes/DefaultSettings.php +++ b/includes/DefaultSettings.php @@ -6296,14 +6296,17 @@ $wgSpecialVersionShowHooks = false; * Whether to show "we're sorry, but there has been a database error" pages. * Displaying errors aids in debugging, but may display information useful * to an attacker. + * + * @deprecated and nonfunctional since 1.32: set $wgShowExceptionDetails and/or + * $wgShowHostnames instead. */ $wgShowSQLErrors = false; /** - * If set to true, uncaught exceptions will print a complete stack trace - * to output. This should only be used for debugging, as it may reveal - * private information in function parameters due to PHP's backtrace - * formatting. + * If set to true, uncaught exceptions will print the exception message and a + * complete stack trace to output. This should only be used for debugging, as it + * may reveal private information in function parameters due to PHP's backtrace + * formatting. If set to false, only the exception's class will be shown. */ $wgShowExceptionDetails = false; @@ -6314,6 +6317,8 @@ $wgShowExceptionDetails = false; * reported in the normal manner. $wgShowExceptionDetails applies in other cases, * including those in which an uncaught exception is thrown from within the * exception handler. + * + * @deprecated and nonfunctional since 1.32: set $wgShowExceptionDetails instead. */ $wgShowDBErrorBacktrace = false; @@ -8669,9 +8674,14 @@ $wgSiteTypes = [ $wgPagePropsHaveSortkey = true; /** - * Port where you have HTTPS running - * Supports HTTPS on non-standard ports - * @see T67184 + * For installations where the canonical server is HTTP but HTTPS is optionally + * supported, you can specify a non-standard HTTPS port here. $wgServer should + * be a protocol-relative URL. + * + * If HTTPS is always used, just specify the port number in $wgServer. + * + * @see https://phabricator.wikimedia.org/T67184 + * * @since 1.24 */ $wgHttpsPort = 443; @@ -8975,7 +8985,7 @@ $wgCommentTableSchemaMigrationStage = MIGRATION_OLD; * @since 1.32 * @var int An appropriate combination of SCHEMA_COMPAT_XXX flags. */ -$wgMultiContentRevisionSchemaMigrationStage = MIGRATION_OLD; +$wgMultiContentRevisionSchemaMigrationStage = SCHEMA_COMPAT_WRITE_BOTH | SCHEMA_COMPAT_READ_OLD; /** * Actor table schema migration stage. diff --git a/includes/DevelopmentSettings.php b/includes/DevelopmentSettings.php index 96ed56b94d..8b32de4f64 100644 --- a/includes/DevelopmentSettings.php +++ b/includes/DevelopmentSettings.php @@ -24,18 +24,16 @@ ini_set( 'display_errors', 1 ); /** * Debugging: MediaWiki */ -global $wgDevelopmentWarnings, $wgShowDBErrorBacktrace, $wgShowExceptionDetails, - $wgShowSQLErrors, $wgDebugRawPage, - $wgDebugComments, $wgDebugDumpSql, $wgDebugTimestamps, +global $wgDevelopmentWarnings, $wgShowExceptionDetails, $wgShowHostnames, + $wgDebugRawPage, $wgDebugComments, $wgDebugDumpSql, $wgDebugTimestamps, $wgCommandLineMode, $wgDebugLogFile, $wgDBerrorLog, $wgDebugLogGroups; // Use of wfWarn() should cause tests to fail $wgDevelopmentWarnings = true; // Enable showing of errors -$wgShowDBErrorBacktrace = true; $wgShowExceptionDetails = true; -$wgShowSQLErrors = true; +$wgShowHostnames = true; $wgDebugRawPage = true; // T49960 // Enable log files diff --git a/includes/GlobalFunctions.php b/includes/GlobalFunctions.php index 3ea020fd3c..aa8aee5ea7 100644 --- a/includes/GlobalFunctions.php +++ b/includes/GlobalFunctions.php @@ -141,7 +141,7 @@ function wfArrayDiff2_cmp( $a, $b ) { } /** - * Like array_filter with ARRAY_FILTER_USE_BOTH, but works pre-5.6. + * @deprecated since 1.32, use array_filter() with ARRAY_FILTER_USE_BOTH directly * * @param array $arr * @param callable $callback Will be called with the array value and key (in that order) and @@ -149,17 +149,11 @@ function wfArrayDiff2_cmp( $a, $b ) { * @return array */ function wfArrayFilter( array $arr, callable $callback ) { - if ( defined( 'ARRAY_FILTER_USE_BOTH' ) ) { - return array_filter( $arr, $callback, ARRAY_FILTER_USE_BOTH ); - } - $filteredKeys = array_filter( array_keys( $arr ), function ( $key ) use ( $arr, $callback ) { - return call_user_func( $callback, $arr[$key], $key ); - } ); - return array_intersect_key( $arr, array_fill_keys( $filteredKeys, true ) ); + return array_filter( $arr, $callback, ARRAY_FILTER_USE_BOTH ); } /** - * Like array_filter with ARRAY_FILTER_USE_KEY, but works pre-5.6. + * @deprecated since 1.32, use array_filter() with ARRAY_FILTER_USE_KEY directly * * @param array $arr * @param callable $callback Will be called with the array key and should return a bool which @@ -167,9 +161,7 @@ function wfArrayFilter( array $arr, callable $callback ) { * @return array */ function wfArrayFilterByKey( array $arr, callable $callback ) { - return wfArrayFilter( $arr, function ( $val, $key ) use ( $callback ) { - return call_user_func( $callback, $key ); - } ); + return array_filter( $arr, $callback, ARRAY_FILTER_USE_KEY ); } /** @@ -556,17 +548,24 @@ function wfExpandUrl( $url, $defaultProto = PROTO_CURRENT ) { } elseif ( substr( $url, 0, 1 ) == '/' ) { // If $serverUrl is protocol-relative, prepend $defaultProtoWithoutSlashes, // otherwise leave it alone. - $url = ( $serverHasProto ? '' : $defaultProtoWithoutSlashes ) . $serverUrl . $url; + if ( $serverHasProto ) { + $url = $serverUrl . $url; + } else { + // If an HTTPS URL is synthesized from a protocol-relative $wgServer, allow the + // user to override the port number (T67184) + if ( $defaultProto === PROTO_HTTPS && $wgHttpsPort != 443 ) { + if ( isset( $bits['port'] ) ) { + throw new Exception( 'A protocol-relative $wgServer may not contain a port number' ); + } + $url = $defaultProtoWithoutSlashes . $serverUrl . ':' . $wgHttpsPort . $url; + } else { + $url = $defaultProtoWithoutSlashes . $serverUrl . $url; + } + } } $bits = wfParseUrl( $url ); - // ensure proper port for HTTPS arrives in URL - // https://phabricator.wikimedia.org/T67184 - if ( $defaultProto === PROTO_HTTPS && $wgHttpsPort != 443 ) { - $bits['port'] = $wgHttpsPort; - } - if ( $bits && isset( $bits['path'] ) ) { $bits['path'] = wfRemoveDotSegments( $bits['path'] ); return wfAssembleUrl( $bits ); @@ -582,6 +581,19 @@ function wfExpandUrl( $url, $defaultProto = PROTO_CURRENT ) { return false; } +/** + * Get the wiki's "server", i.e. the protocol and host part of the URL, with a + * protocol specified using a PROTO_* constant as in wfExpandUrl() + * + * @since 1.32 + * @param string|int|null $proto One of the PROTO_* constants. + * @return string The URL + */ +function wfGetServerUrl( $proto ) { + $url = wfExpandUrl( '/', $proto ); + return substr( $url, 0, -1 ); +} + /** * This function will reassemble a URL parsed with wfParseURL. This is useful * if you need to edit part of a URL and put it back together. @@ -874,20 +886,13 @@ function wfParseUrl( $url ) { function wfExpandIRI( $url ) { return preg_replace_callback( '/((?:%[89A-F][0-9A-F])+)/i', - 'wfExpandIRI_callback', + function ( array $matches ) { + return urldecode( $matches[1] ); + }, wfExpandUrl( $url ) ); } -/** - * Private callback for wfExpandIRI - * @param array $matches - * @return string - */ -function wfExpandIRI_callback( $matches ) { - return urldecode( $matches[1] ); -} - /** * Make URL indexes, appropriate for the el_index field of externallinks. * diff --git a/includes/MediaWikiServices.php b/includes/MediaWikiServices.php index a756d50982..7a4c2df861 100644 --- a/includes/MediaWikiServices.php +++ b/includes/MediaWikiServices.php @@ -27,6 +27,7 @@ use Wikimedia\Rdbms\LBFactory; use LinkCache; use Wikimedia\Rdbms\LoadBalancer; use MediaHandlerFactory; +use MediaWiki\Config\ConfigRepository; use MediaWiki\Linker\LinkRenderer; use MediaWiki\Linker\LinkRendererFactory; use MediaWiki\Services\SalvageableService; @@ -855,6 +856,13 @@ class MediaWikiServices extends ServiceContainer { return $this->getService( 'OldRevisionImporter' ); } + /** + * @return ConfigRepository + */ + public function getConfigRepository() { + return $this->getService( 'ConfigRepository' ); + } + /////////////////////////////////////////////////////////////////////////// // NOTE: When adding a service getter here, don't forget to add a test // case for it in MediaWikiServicesTest::provideGetters() and in diff --git a/includes/OutputPage.php b/includes/OutputPage.php index 5965cbe7c2..4e7c0bbe83 100644 --- a/includes/OutputPage.php +++ b/includes/OutputPage.php @@ -55,9 +55,8 @@ class OutputPage extends ContextSource { protected $mCanonicalUrl = false; /** - * @var string Should be private - has getter and setter. Contains - * the HTML title */ - public $mPagetitle = ''; + * @var string The contents of

*/ + private $mPageTitle = ''; /** * @var string Contains all of the "" content. Should be private we @@ -992,7 +991,7 @@ class OutputPage extends ContextSource { # change "" to "<script>foo&bar</script>" # but leave "foobar" alone $nameWithTags = Sanitizer::normalizeCharReferences( Sanitizer::removeHTMLtags( $name ) ); - $this->mPagetitle = $nameWithTags; + $this->mPageTitle = $nameWithTags; # change "foo&bar" to "foo&bar" $this->setHTMLTitle( @@ -1007,7 +1006,7 @@ class OutputPage extends ContextSource { * @return string */ public function getPageTitle() { - return $this->mPagetitle; + return $this->mPageTitle; } /** diff --git a/includes/PathRouter.php b/includes/PathRouter.php index f24e298a0d..faf4db4f62 100644 --- a/includes/PathRouter.php +++ b/includes/PathRouter.php @@ -240,6 +240,28 @@ class PathRouter { // matches are tested first $this->sortByWeight(); + $matches = $this->internalParse( $path ); + if ( is_null( $matches ) ) { + // Try with the normalized path (T100782) + $path = wfRemoveDotSegments( $path ); + $path = preg_replace( '#/+#', '/', $path ); + $matches = $this->internalParse( $path ); + } + + // We know the difference between null (no matches) and + // array() (a match with no data) but our WebRequest caller + // expects array() even when we have no matches so return + // a array() when we have null + return is_null( $matches ) ? [] : $matches; + } + + /** + * Match a path against each defined pattern + * + * @param string $path + * @return array|null + */ + protected function internalParse( $path ) { $matches = null; foreach ( $this->patterns as $pattern ) { @@ -248,12 +270,7 @@ class PathRouter { break; } } - - // We know the difference between null (no matches) and - // array() (a match with no data) but our WebRequest caller - // expects array() even when we have no matches so return - // a array() when we have null - return is_null( $matches ) ? [] : $matches; + return $matches; } /** diff --git a/includes/ServiceWiring.php b/includes/ServiceWiring.php index 6da537d4e1..7d49080902 100644 --- a/includes/ServiceWiring.php +++ b/includes/ServiceWiring.php @@ -38,6 +38,7 @@ */ use MediaWiki\Auth\AuthManager; +use MediaWiki\Config\ConfigRepository; use MediaWiki\Interwiki\ClassicInterwikiLookup; use MediaWiki\Linker\LinkRendererFactory; use MediaWiki\Logger\LoggerFactory; @@ -104,6 +105,10 @@ return [ return $factory; }, + 'ConfigRepository' => function ( MediaWikiServices $services ) { + return new ConfigRepository( $services->getConfigFactory() ); + }, + 'MainConfig' => function ( MediaWikiServices $services ) { // Use the 'main' config from the ConfigFactory service. return $services->getConfigFactory()->makeConfig( 'main' ); diff --git a/includes/Title.php b/includes/Title.php index 8586ad762d..b583554ab4 100644 --- a/includes/Title.php +++ b/includes/Title.php @@ -37,7 +37,7 @@ use MediaWiki\MediaWikiServices; * and does not rely on global state or the database. */ class Title implements LinkTarget { - /** @var HashBagOStuff */ + /** @var MapCacheLRU */ static private $titleCache = null; /** @@ -371,11 +371,11 @@ class Title implements LinkTarget { } /** - * @return HashBagOStuff + * @return MapCacheLRU */ private static function getTitleCache() { if ( self::$titleCache == null ) { - self::$titleCache = new HashBagOStuff( [ 'maxKeys' => self::CACHE_MAX ] ); + self::$titleCache = new MapCacheLRU( self::CACHE_MAX ); } return self::$titleCache; } diff --git a/includes/WebRequest.php b/includes/WebRequest.php index f3edebc6b6..e31d3f9c77 100644 --- a/includes/WebRequest.php +++ b/includes/WebRequest.php @@ -856,7 +856,7 @@ class WebRequest { * @return string */ public function getFullRequestURL() { - return wfExpandUrl( $this->getRequestURL(), PROTO_CURRENT ); + return wfGetServerUrl( PROTO_CURRENT ) . $this->getRequestURL(); } /** diff --git a/includes/actions/HistoryAction.php b/includes/actions/HistoryAction.php index bd64a41479..20637fcdf7 100644 --- a/includes/actions/HistoryAction.php +++ b/includes/actions/HistoryAction.php @@ -788,7 +788,10 @@ class HistoryPager extends ReverseChronologicalPager { $attribs = [ 'data-mw-revid' => $rev->getId() ]; Hooks::run( 'PageHistoryLineEnding', [ $this, &$row, &$s, &$classes, &$attribs ] ); - $attribs = wfArrayFilterByKey( $attribs, [ Sanitizer::class, 'isReservedDataAttribute' ] ); + $attribs = array_filter( $attribs, + [ Sanitizer::class, 'isReservedDataAttribute' ], + ARRAY_FILTER_USE_KEY + ); if ( $classes ) { $attribs['class'] = implode( ' ', $classes ); diff --git a/includes/api/ApiBase.php b/includes/api/ApiBase.php index be4eeef7c4..e546c4aca5 100644 --- a/includes/api/ApiBase.php +++ b/includes/api/ApiBase.php @@ -1289,7 +1289,7 @@ abstract class ApiBase extends ContextSource { case 'text': case 'password': if ( $required && $value === '' ) { - $this->dieWithError( [ 'apierror-missingparam', $paramName ] ); + $this->dieWithError( [ 'apierror-missingparam', $encParamName ] ); } break; case 'integer': // Force everything using intval() and optionally validate limits @@ -1443,7 +1443,7 @@ abstract class ApiBase extends ContextSource { } } } elseif ( $required ) { - $this->dieWithError( [ 'apierror-missingparam', $paramName ] ); + $this->dieWithError( [ 'apierror-missingparam', $encParamName ] ); } return $value; diff --git a/includes/api/ApiMain.php b/includes/api/ApiMain.php index 610ecf5145..e5e384c0f1 100644 --- a/includes/api/ApiMain.php +++ b/includes/api/ApiMain.php @@ -24,8 +24,6 @@ use MediaWiki\Logger\LoggerFactory; use MediaWiki\MediaWikiServices; use Wikimedia\Timestamp\TimestampException; -use Wikimedia\Rdbms\DBQueryError; -use Wikimedia\Rdbms\DBError; /** * This is the main API class, used for both external and internal processing. @@ -486,7 +484,7 @@ class ApiMain extends ApiBase { * @return ApiFormatBase */ public function createPrinterByName( $format ) { - $printer = $this->mModuleMgr->getModule( $format, 'format' ); + $printer = $this->mModuleMgr->getModule( $format, 'format', /* $ignoreCache */ true ); if ( $printer === null ) { $this->dieWithError( [ 'apierror-unknownformat', wfEscapeWikiText( $format ) ], 'unknown_format' @@ -535,11 +533,9 @@ class ApiMain extends ApiBase { $this->executeAction(); $runTime = microtime( true ) - $t; $this->logRequest( $runTime ); - if ( $this->mModule->isWriteMode() && $this->getRequest()->wasPosted() ) { - MediaWikiServices::getInstance()->getStatsdDataFactory()->timing( - 'api.' . $this->mModule->getModuleName() . '.executeTiming', 1000 * $runTime - ); - } + MediaWikiServices::getInstance()->getStatsdDataFactory()->timing( + 'api.' . $this->mModule->getModuleName() . '.executeTiming', 1000 * $runTime + ); } catch ( Exception $e ) { $this->handleException( $e ); $this->logRequest( microtime( true ) - $t, $e ); @@ -1040,9 +1036,7 @@ class ApiMain extends ApiBase { $config = $this->getConfig(); $class = preg_replace( '#^Wikimedia\\\Rdbms\\\#', '', get_class( $e ) ); $code = 'internal_api_error_' . $class; - if ( ( $e instanceof DBQueryError ) && !$config->get( 'ShowSQLErrors' ) ) { - $params = [ 'apierror-databaseerror', WebRequest::getRequestId() ]; - } else { + if ( $config->get( 'ShowExceptionDetails' ) ) { if ( $e instanceof ILocalizedException ) { $msg = $e->getMessageObject(); } elseif ( $e instanceof MessageSpecifier ) { @@ -1051,7 +1045,10 @@ class ApiMain extends ApiBase { $msg = wfEscapeWikiText( $e->getMessage() ); } $params = [ 'apierror-exceptioncaught', WebRequest::getRequestId(), $msg ]; + } else { + $params = [ 'apierror-exceptioncaughttype', WebRequest::getRequestId(), get_class( $e ) ]; } + $messages[] = ApiMessage::create( $params, $code ); } return $messages; @@ -1115,9 +1112,7 @@ class ApiMain extends ApiBase { ) ); } else { - if ( $config->get( 'ShowExceptionDetails' ) && - ( !$e instanceof DBError || $config->get( 'ShowDBErrorBacktrace' ) ) - ) { + if ( $config->get( 'ShowExceptionDetails' ) ) { $result->addContentValue( $path, 'trace', diff --git a/includes/api/ApiQuerySiteinfo.php b/includes/api/ApiQuerySiteinfo.php index f23c6a6323..4b408fc481 100644 --- a/includes/api/ApiQuerySiteinfo.php +++ b/includes/api/ApiQuerySiteinfo.php @@ -705,10 +705,7 @@ class ApiQuerySiteinfo extends ApiQueryBase { $data = []; foreach ( $langNames as $code => $name ) { - $lang = [ - 'code' => $code, - 'bcp47' => LanguageCode::bcp47( $code ), - ]; + $lang = [ 'code' => $code ]; ApiResult::setContentValue( $lang, 'name', $name ); $data[] = $lang; } diff --git a/includes/api/i18n/ar.json b/includes/api/i18n/ar.json index 4b4177f585..313cb02926 100644 --- a/includes/api/i18n/ar.json +++ b/includes/api/i18n/ar.json @@ -1586,7 +1586,6 @@ "apierror-copyuploadbadurl": "لا يُسمَح بالرفع من هذا المسار.", "apierror-create-titleexists": "لا يمكن حماية العناوين الموجودة باستخدام create.", "apierror-csp-report": "خطأ في معالجة تقرير CSP: $1.", - "apierror-databaseerror": "[$1] خطأ في استعلام قاعدة البيانات.", "apierror-deletedrevs-param-not-1-2": "لا يمكن استخدام الوسيط $1 في الأوضاع 1 أو 2.", "apierror-deletedrevs-param-not-3": "لا يمكن استخدام الوسيط $1 في الوضع 3.", "apierror-emptynewsection": "إنشاء أقسام جديدة فارغة غير ممكن.", diff --git a/includes/api/i18n/en.json b/includes/api/i18n/en.json index 74efd820ca..d7cdc6cfa7 100644 --- a/includes/api/i18n/en.json +++ b/includes/api/i18n/en.json @@ -1712,12 +1712,12 @@ "apierror-copyuploadbadurl": "Upload not allowed from this URL.", "apierror-create-titleexists": "Existing titles can't be protected with create.", "apierror-csp-report": "Error processing CSP report: $1.", - "apierror-databaseerror": "[$1] Database query error.", "apierror-deletedrevs-param-not-1-2": "The $1 parameter cannot be used in modes 1 or 2.", "apierror-deletedrevs-param-not-3": "The $1 parameter cannot be used in mode 3.", "apierror-emptynewsection": "Creating empty new sections is not possible.", "apierror-emptypage": "Creating new, empty pages is not allowed.", "apierror-exceptioncaught": "[$1] Exception caught: $2", + "apierror-exceptioncaughttype": "[$1] Caught exception of type $2", "apierror-filedoesnotexist": "File does not exist.", "apierror-fileexists-sharedrepo-perm": "The target file exists on a shared repository. Use the ignorewarnings parameter to override it.", "apierror-filenopath": "Cannot get local file path.", diff --git a/includes/api/i18n/es.json b/includes/api/i18n/es.json index 8328006dd2..00759e8b84 100644 --- a/includes/api/i18n/es.json +++ b/includes/api/i18n/es.json @@ -1499,7 +1499,6 @@ "apierror-copyuploadbadurl": "No se permite realizar cargas a partir de este URL.", "apierror-create-titleexists": "Los títulos existentes no se pueden proteger con create.", "apierror-csp-report": "Error de procesamiento del informe CSP: $1.", - "apierror-databaseerror": "[$1] Error en la consulta de la base de datos.", "apierror-deletedrevs-param-not-1-2": "El parámetro $1 no se puede utilizar en los modos 1 o 2.", "apierror-deletedrevs-param-not-3": "El parámetro $1 no se puede usar en modo 3.", "apierror-emptynewsection": "Crear secciones vacías no es posible.", diff --git a/includes/api/i18n/fr.json b/includes/api/i18n/fr.json index 0759e35dae..9f2a06fb01 100644 --- a/includes/api/i18n/fr.json +++ b/includes/api/i18n/fr.json @@ -1610,7 +1610,6 @@ "apierror-copyuploadbadurl": "Les téléversements ne sont pas autorisés depuis cette URL.", "apierror-create-titleexists": "Les titres existants ne peuvent pas être protégés avec create.", "apierror-csp-report": "Erreur lors du traitement du rapport CSP: $1.", - "apierror-databaseerror": "[$1] erreur de requête de base de données.", "apierror-deletedrevs-param-not-1-2": "Le paramètre $1 ne peut pas être utilisé dans les modes 1 ou 2.", "apierror-deletedrevs-param-not-3": "Le paramètre $1 ne peut pas être utilisé dans le mode 3.", "apierror-emptynewsection": "Il n'est pas possible de créer de nouvelles sections vides.", diff --git a/includes/api/i18n/gl.json b/includes/api/i18n/gl.json index 173132384d..da839f43c6 100644 --- a/includes/api/i18n/gl.json +++ b/includes/api/i18n/gl.json @@ -1536,7 +1536,6 @@ "apierror-copyuploadbadurl": "As subas non están permitidas para esta URL.", "apierror-create-titleexists": "Os títulos existentes non poden ser protexidos con create.", "apierror-csp-report": "Erro procesando o informe CSPː $1.", - "apierror-databaseerror": "[$1] erro de consulta da base de datos.", "apierror-deletedrevs-param-not-1-2": "O parámetro $1 non pode usarse nos modos 1 e 2.", "apierror-deletedrevs-param-not-3": "O parámetro $1 non pode usarse no modo 3.", "apierror-emptynewsection": "Non é posible crear novas seccións baleiras.", diff --git a/includes/api/i18n/he.json b/includes/api/i18n/he.json index 44910c82fc..5cc579544a 100644 --- a/includes/api/i18n/he.json +++ b/includes/api/i18n/he.json @@ -1594,7 +1594,6 @@ "apierror-copyuploadbadurl": "העלאה אינה מותרת מה־URL הזה.", "apierror-create-titleexists": "כותרות קיימות אינם יכולות מוגנות עם create.", "apierror-csp-report": "בעיבוד דו\"ח CSP אירעה שגיאה: $1", - "apierror-databaseerror": "[$1] שגיאת שאילתת מסד נתונים.", "apierror-deletedrevs-param-not-1-2": "הפרמטר $1 אינו יכול לשמש במצבים 1 או 2.", "apierror-deletedrevs-param-not-3": "הפרמטר $1 אינו יכול במצב 3.", "apierror-emptynewsection": "יצירת פסקאות חדשות ריקות בלתי־אפשרי.", diff --git a/includes/api/i18n/ja.json b/includes/api/i18n/ja.json index 97309ff77d..399fc1fd17 100644 --- a/includes/api/i18n/ja.json +++ b/includes/api/i18n/ja.json @@ -948,6 +948,9 @@ "apihelp-undelete-param-timestamps": "復元する版のタイムスタンプ。$1timestamps と $1fileids の両方が空の場合、すべての版が復元されます。", "apihelp-undelete-example-page": "Main Page を復元する。", "apihelp-undelete-example-revisions": "Main Page の2つの版を復元する。", + "apihelp-upload-param-filename": "対象のファイル名。", + "apihelp-upload-param-comment": "アップロードのコメント。新規ファイルのアップロードで $1text が指定されていない場合、初期ページテキストとしても使用されます。", + "apihelp-upload-param-text": "新しいファイルの初期ページテキスト。", "apihelp-upload-param-watch": "このページをウォッチする。", "apihelp-upload-param-ignorewarnings": "あらゆる警告を無視する。", "apihelp-upload-param-url": "ファイル取得元のURL.", diff --git a/includes/api/i18n/ko.json b/includes/api/i18n/ko.json index e2b6bb4427..56a6507a57 100644 --- a/includes/api/i18n/ko.json +++ b/includes/api/i18n/ko.json @@ -835,7 +835,6 @@ "apierror-cantimport-upload": "업로드된 페이지를 가져올 권한이 없습니다.", "apierror-cantimport": "페이지를 가져올 권한이 없습니다.", "apierror-cantsend": "로그인하지 않았거나 인증된 이메일 주소가 없거나 다른 사용자로 이메일을 보낼 권한이 없기 때문에 이메일을 보낼 수 없습니다.", - "apierror-databaseerror": "[$1] 데이터베이스 쿼리 오류.", "apierror-emptynewsection": "비어있는 새 문단을 만들 수 없습니다.", "apierror-emptypage": "새 문서로 빈 문서를 만들 수 없습니다.", "apierror-exceptioncaught": "[$1] 예외가 발생했습니다: $2", diff --git a/includes/api/i18n/lt.json b/includes/api/i18n/lt.json index f470a72228..09b6671dd5 100644 --- a/includes/api/i18n/lt.json +++ b/includes/api/i18n/lt.json @@ -370,7 +370,6 @@ "apierror-cantimport-upload": "Neturite teisės importuoti įkeltų puslapių.", "apierror-cantimport": "Neturite teisės importuoti puslapių.", "apierror-copyuploadbadurl": "Įkėlimas neleidžiamas iš šio URL.", - "apierror-databaseerror": "[$1] Duomenų bazės užklausos klaida.", "apierror-emptynewsection": "Neįmanoma kurti naujų tuščių skyrių.", "apierror-filedoesnotexist": "Failas neegzistuoja.", "apierror-filetypecannotberotated": "Failo tipas negali būti pasuktas.", diff --git a/includes/api/i18n/nb.json b/includes/api/i18n/nb.json index a1c92389d4..c43960b447 100644 --- a/includes/api/i18n/nb.json +++ b/includes/api/i18n/nb.json @@ -610,7 +610,6 @@ "apierror-copyuploadbadurl": "Opplasting tillates ikke fra denne URL-en.", "apierror-create-titleexists": "Eksisterende titler kan ikke beskyttes med create.", "apierror-csp-report": "Feil under prosessering av CSP-rapport: $1.", - "apierror-databaseerror": "[$1] Databasespørringsfeil.", "apierror-deletedrevs-param-not-1-2": "Parameteren $1 kan ikke brukes i modus 1 eller 2.", "apierror-deletedrevs-param-not-3": "Parameteren $1 kan ikke brukes i modus 3.", "apierror-emptynewsection": "Oppretting av tomme nye seksjoner er ikke mulig.", diff --git a/includes/api/i18n/pl.json b/includes/api/i18n/pl.json index 9b4ac5f81f..1ded789288 100644 --- a/includes/api/i18n/pl.json +++ b/includes/api/i18n/pl.json @@ -661,7 +661,6 @@ "apierror-cantimport": "Nie masz uprawnień do importowania stron.", "apierror-cantsend": "Nie jesteś zalogowany, nie masz potwierdzonego adresu e-mail, albo nie masz prawa wysyłać e-maili do innych użytkowników, więc nie możesz wysłać wiadomości e-mail.", "apierror-cantundelete": "Nie można przywrócić: dana wersja nie istnieje albo została już przywrócona.", - "apierror-databaseerror": "[$1] Błąd zapytania do bazy danych.", "apierror-exceptioncaught": "[$1] Stwierdzono wyjątek: $2", "apierror-filedoesnotexist": "Plik nie istnieje.", "apierror-import-unknownerror": "Nieznany błąd podczas importowania: $1.", diff --git a/includes/api/i18n/pt-br.json b/includes/api/i18n/pt-br.json index 439f811d59..e6724d440a 100644 --- a/includes/api/i18n/pt-br.json +++ b/includes/api/i18n/pt-br.json @@ -1593,7 +1593,6 @@ "apierror-copyuploadbadurl": "Envio não permitido a partir deste URL.", "apierror-create-titleexists": "Os títulos existentes não podem ser protegidos com create.", "apierror-csp-report": "Erro ao processar o relatório CSP: $1.", - "apierror-databaseerror": "[$1] Houve um erro na consulta ao banco de dados.", "apierror-deletedrevs-param-not-1-2": "O parâmetro $1 não pode ser usado nos modos 1 ou 2.", "apierror-deletedrevs-param-not-3": "O parâmetro $1 não pode ser usado no modo 3.", "apierror-emptynewsection": "A criação de novas seções vazias não é possível.", diff --git a/includes/api/i18n/pt.json b/includes/api/i18n/pt.json index ca43981e96..a58dec1e01 100644 --- a/includes/api/i18n/pt.json +++ b/includes/api/i18n/pt.json @@ -1509,7 +1509,7 @@ "api-help-param-default": "Valor por omissão: $1", "api-help-param-default-empty": "Padrão: (vazio)", "api-help-param-token": "Uma chave \"$1\" obtida de [[Special:ApiHelp/query+tokens|action=query&meta=tokens]]", - "api-help-param-token-webui": "Para efeitos de compatibilidade, a chave usada na interface ''web'' também é aceite.", + "api-help-param-token-webui": "Para efeitos de compatibilidade, a chave usada na interface da Internet também é aceite.", "api-help-param-disabled-in-miser-mode": "Desativado devido ao [[mw:Special:MyLanguage/Manual:$wgMiserMode|modo avarento]] (''miser mode'').", "api-help-param-limited-in-miser-mode": "Nota: devido ao [[mw:Special:MyLanguage/Manual:$wgMiserMode|modo avarento]] (''miser mode''), usar isto pode resultar na devolução de menos de $1limit resultados antes de continuar; em casos extremos pode não ser devolvido qualquer resultado.", "api-help-param-direction": "A direção da enumeração:\n;newer:Listar o mais antigo primeiro. Nota: $1start tem de estar antes de $1end.\n;older:Listar o mais recente primeiro (padrão). Nota: $1start tem de estar depois de $1end.", @@ -1528,7 +1528,7 @@ "api-help-authmanagerhelper-messageformat": "Formato a usar nas mensagens de saída.", "api-help-authmanagerhelper-mergerequestfields": "Combinar a informação de todos os pedidos de autenticação numa única matriz.", "api-help-authmanagerhelper-preservestate": "Preservar o estado de uma tentativa de autenticação anterior falhada, se possível.", - "api-help-authmanagerhelper-returnurl": "O URL de retorno para processos de autenticação por terceiros tem de ser absoluto. É obrigatório fornecer este URL ou $1continue.\n\nTipicamente, após receber uma resposta REDIRECT, abrirá um ''browser'' ou uma ''web view'' para o URL redirecttarget especificado, para dar lugar ao processo de autenticação por terceiros. Quando esse processo terminar, a terceira entidade encaminhará o ''browser'' ou a ''web view'' para este URL. Deve extrair do URL quaisquer parâmetros de consulta ou de POST, e passá-los como um pedido $1continue a este módulo da API.", + "api-help-authmanagerhelper-returnurl": "O URL de retorno para processos de autenticação por terceiros tem de ser absoluto. É obrigatório fornecer este URL ou $1continue.\n\nTipicamente, após receber uma resposta REDIRECT, abrirá um ''browser'' ou uma vista da Internet para o URL redirecttarget especificado, para dar lugar ao processo de autenticação por terceiros. Quando esse processo terminar, a terceira entidade encaminhará o ''browser'' ou a vista da Internet para este URL. Deve extrair do URL quaisquer parâmetros de consulta ou de POST, e passá-los como um pedido $1continue a este módulo da API.", "api-help-authmanagerhelper-continue": "Este pedido é uma continuação após uma resposta anterior com o valor UI ou REDIRECT. É obrigatório fornecer este parâmetro ou o parâmetro $1returnurl.", "api-help-authmanagerhelper-additional-params": "Este módulo aceita parâmetros adicionais, dependendo dos pedidos de autenticação disponíveis. Use [[Special:ApiHelp/query+authmanagerinfo|action=query&meta=authmanagerinfo]] com amirequestsfor=$1 (ou uma resposta anterior deste módulo, se aplicável) para determinar os pedidos disponíveis e os campos que estes utilizam.", "apierror-allimages-redirect": "Usar gaifilterredir=nonredirects em vez de redirects ao utilizar allimages como gerador.", @@ -1588,7 +1588,6 @@ "apierror-copyuploadbadurl": "Não são permitidos carregamentos a partir deste URL.", "apierror-create-titleexists": "Os títulos existentes não podem ser protegidos com create.", "apierror-csp-report": "Ocorreu um erro no processamento do relatório CSP: $1.", - "apierror-databaseerror": "[$1] Erro na consulta da base de dados.", "apierror-deletedrevs-param-not-1-2": "O parâmetro $1 não pode ser usado nos modos 1 e 2.", "apierror-deletedrevs-param-not-3": "O parâmetro $1 não pode ser usado no modo 3.", "apierror-emptynewsection": "Não é possível criar secções novas vazias.", diff --git a/includes/api/i18n/qqq.json b/includes/api/i18n/qqq.json index 2b4a587a0b..dd8e529db1 100644 --- a/includes/api/i18n/qqq.json +++ b/includes/api/i18n/qqq.json @@ -1600,12 +1600,12 @@ "apierror-copyuploadbadurl": "{{doc-apierror}}", "apierror-create-titleexists": "{{doc-apierror}}", "apierror-csp-report": "{{doc-apierror}}\n\nParameters:\n* $1 - Error code, e.g. \"toobig\".", - "apierror-databaseerror": "{{doc-apierror}}\n\nParameters:\n* $1 - Exception log ID code. This is meaningless to the end user, but can be used by people with access to the logs to easily find the logged error.", "apierror-deletedrevs-param-not-1-2": "{{doc-apierror}}\n\nParameters:\n* $1 - Parameter name.\n\nSee also:\n* {{msg-mw|apihelp-query+deletedrevs-extended-description}}", "apierror-deletedrevs-param-not-3": "{{doc-apierror}}\n\nParameters:\n* $1 - Parameter name.\n\nSee also:\n* {{msg-mw|apihelp-query+deletedrevs-extended-description}}", "apierror-emptynewsection": "{{doc-apierror}}", "apierror-emptypage": "{{doc-apierror}}", "apierror-exceptioncaught": "{{doc-apierror}}\n\nParameters:\n* $1 - Exception log ID code. This is meaningless to the end user, but can be used by people with access to the logs to easily find the logged error.\n* $2 - Exception message, which may end with punctuation. Probably in English.", + "apierror-exceptioncaughttype": "{{doc-apierror}}\n\nParameters:\n* $1 - Exception log ID code. This is meaningless to the end user, but can be used by people with access to the logs to easily find the logged error.\n* $2 - Exception type (for example, DBError).", "apierror-filedoesnotexist": "{{doc-apierror}}", "apierror-fileexists-sharedrepo-perm": "{{doc-apierror}}", "apierror-filenopath": "{{doc-apierror}}", diff --git a/includes/api/i18n/ru.json b/includes/api/i18n/ru.json index 4df71badc2..6bfe0598b3 100644 --- a/includes/api/i18n/ru.json +++ b/includes/api/i18n/ru.json @@ -34,7 +34,8 @@ "AttemptToCallNil", "Movses", "Stjn", - "Edward Chernenko" + "Edward Chernenko", + "Vlad5250" ] }, "apihelp-main-extended-description": "
\n* [[mw:Special:MyLanguage/API:Main_page|Документация]]\n* [[mw:Special:MyLanguage/API:FAQ|ЧаВО]]\n* [https://lists.wikimedia.org/mailman/listinfo/mediawiki-api Почтовая рассылка]\n* [https://lists.wikimedia.org/mailman/listinfo/mediawiki-api-announce Новости API]\n* [https://phabricator.wikimedia.org/maniphest/query/GebfyV4uCaLd/#R Ошибки и запросы]\n
\nСтатус: MediaWiki API — зрелый и стабильный интерфейс, активно поддерживаемый и улучшаемый. Мы стараемся избегать ломающих изменений, однако изредка они могут быть необходимы. Подпишитесь на [https://lists.wikimedia.org/pipermail/mediawiki-api-announce/ почтовую рассылку mediawiki-api-announce], чтобы быть в курсе обновлений.\n\nОшибочные запросы: Если API получает запрос с ошибкой, вернётся заголовок HTTP с ключом «MediaWiki-API-Error», после чего значение заголовка и код ошибки будут отправлены обратно и установлены в то же значение. Более подробную информацию см. [[mw:Special:MyLanguage/API:Errors_and_warnings|API: Ошибки и предупреждения]].\n\n

Тестирование: для удобства тестирования API-запросов, см. [[Special:ApiSandbox]].

", @@ -784,6 +785,8 @@ "apihelp-query+filearchive-example-simple": "Список всех удалённых файлов.", "apihelp-query+filerepoinfo-summary": "Возвращает мета-информацию о файловых репозиториях, настроенных в вики.", "apihelp-query+filerepoinfo-param-prop": "Какие свойства хранилища получить (доступность свойств может отличаться в разных вики).", + "apihelp-query+filerepoinfo-paramvalue-prop-rootUrl": "Корневой URL для изображений.", + "apihelp-query+filerepoinfo-paramvalue-prop-url": "URL путь публичной зоны.", "apihelp-query+filerepoinfo-example-simple": "Получить информацию о файловых репозиториях.", "apihelp-query+fileusage-summary": "Поиск всех страниц, использующих данный файл.", "apihelp-query+fileusage-param-prop": "Какие свойства получить:", @@ -1599,7 +1602,6 @@ "apierror-copyuploadbadurl": "Загрузка по этой ссылке недоступна.", "apierror-create-titleexists": "Существующие названия не могут быть защищены с помощью create.", "apierror-csp-report": "Ошибка при обработке отчёта CSP: $1.", - "apierror-databaseerror": "[$1] Ошибка запроса к базе данных.", "apierror-deletedrevs-param-not-1-2": "Параметр $1 не может быть использован в режимах 1 и 2.", "apierror-deletedrevs-param-not-3": "Параметр $1 не может быть использован в третьем режиме.", "apierror-emptynewsection": "Создание пустых секций невозможно.", diff --git a/includes/api/i18n/uk.json b/includes/api/i18n/uk.json index 3039ef4f74..95cd7093ba 100644 --- a/includes/api/i18n/uk.json +++ b/includes/api/i18n/uk.json @@ -1565,7 +1565,6 @@ "apierror-copyuploadbadurl": "Завантаження з цієї URL-адреси недозволені.", "apierror-create-titleexists": "Наявні назви не можна захистити за допомогою create.", "apierror-csp-report": "Помилка при опрацюванні CSP-звіту: $1.", - "apierror-databaseerror": "[$1] Помилка запиту до бази даних.", "apierror-deletedrevs-param-not-1-2": "Параметр $1 не може використовуватись у режимах 1 або 2.", "apierror-deletedrevs-param-not-3": "Параметр $1 не може використовуватись у режимі 3.", "apierror-emptynewsection": "Створення нових порожніх розділів неможливе.", diff --git a/includes/api/i18n/zh-hans.json b/includes/api/i18n/zh-hans.json index 1cc7c5c1a0..5b9c2e467f 100644 --- a/includes/api/i18n/zh-hans.json +++ b/includes/api/i18n/zh-hans.json @@ -416,7 +416,7 @@ "apihelp-purge-example-simple": "刷新Main Page和API页面。", "apihelp-purge-example-generator": "刷新主名字空间的前10个页面。", "apihelp-query-summary": "取得来自并有关MediaWiki的数据。", - "apihelp-query-extended-description": "所有数据修改将首先不得不使用查询来获得令牌,以阻止来自恶意网站的滥用行为。", + "apihelp-query-extended-description": "所有数据修改须首先使用查询来获得令牌,以阻止来自恶意网站的滥用行为。", "apihelp-query-param-prop": "要为已查询页面获取的属性。", "apihelp-query-param-list": "要获取的列表。", "apihelp-query-param-meta": "要获取的元数据。", @@ -1603,7 +1603,6 @@ "apierror-copyuploadbadurl": "不允许从此URL上传。", "apierror-create-titleexists": "现有标题不能通过create保护。", "apierror-csp-report": "处理CSP报告时出错:$1。", - "apierror-databaseerror": "[$1]数据库查询错误。", "apierror-deletedrevs-param-not-1-2": "$1参数不能用于模式1或2。", "apierror-deletedrevs-param-not-3": "$1参数不能用于模式3。", "apierror-emptynewsection": "无法创建空白新章节。", diff --git a/includes/auth/AuthManager.php b/includes/auth/AuthManager.php index ca59ec7ac1..d3fd5fcb0f 100644 --- a/includes/auth/AuthManager.php +++ b/includes/auth/AuthManager.php @@ -886,8 +886,11 @@ class AuthManager implements LoggerAwareInterface { * returned success. * * @param AuthenticationRequest $req + * @param bool $isAddition Set true if this represents an addition of + * credentials rather than a change. The main difference is that additions + * should not invalidate BotPasswords. If you're not sure, leave it false. */ - public function changeAuthenticationData( AuthenticationRequest $req ) { + public function changeAuthenticationData( AuthenticationRequest $req, $isAddition = false ) { $this->logger->info( 'Changing authentication data for {user} class {what}', [ 'user' => is_string( $req->username ) ? $req->username : '', 'what' => get_class( $req ), @@ -897,7 +900,9 @@ class AuthManager implements LoggerAwareInterface { // When the main account's authentication data is changed, invalidate // all BotPasswords too. - \BotPassword::invalidateAllPasswordsForUser( $req->username ); + if ( !$isAddition ) { + \BotPassword::invalidateAllPasswordsForUser( $req->username ); + } } /**@}*/ diff --git a/includes/auth/ConfirmLinkSecondaryAuthenticationProvider.php b/includes/auth/ConfirmLinkSecondaryAuthenticationProvider.php index 7f121cdef1..c2d730cbbd 100644 --- a/includes/auth/ConfirmLinkSecondaryAuthenticationProvider.php +++ b/includes/auth/ConfirmLinkSecondaryAuthenticationProvider.php @@ -119,7 +119,9 @@ class ConfirmLinkSecondaryAuthenticationProvider extends AbstractSecondaryAuthen $status = $this->manager->allowsAuthenticationDataChange( $req ); $statuses[] = [ $req, $status ]; if ( $status->isGood() ) { - $this->manager->changeAuthenticationData( $req ); + // We're not changing credentials, just adding a new link + // to an already-known user. + $this->manager->changeAuthenticationData( $req, /* $isAddition */ true ); } else { $anyFailed = true; } diff --git a/includes/cache/MessageCache.php b/includes/cache/MessageCache.php index 78fb24a39e..7a172bead8 100644 --- a/includes/cache/MessageCache.php +++ b/includes/cache/MessageCache.php @@ -55,7 +55,7 @@ class MessageCache { /** * @var bool[] Map of (language code => boolean) */ - protected $mCacheVolatile = []; + protected $cacheVolatile = []; /** * Should mean that database cannot be used, but check @@ -272,7 +272,7 @@ class MessageCache { # Hash of the contents is stored in memcache, to detect if data-center cache # or local cache goes out of date (e.g. due to replace() on some other server) list( $hash, $hashVolatile ) = $this->getValidationHash( $code ); - $this->mCacheVolatile[$code] = $hashVolatile; + $this->cacheVolatile[$code] = $hashVolatile; # Try the local cache and check against the cluster hash key... $cache = $this->getLocalCache( $code ); @@ -592,13 +592,15 @@ class MessageCache { [ 'title' => $title, 'code' => $code ] ); return; } - // Load the messages from the master DB to avoid race conditions + // Reload messages from the database and pre-populate dc-local caches + // as optimisation. Use the master DB to avoid race conditions. $cache = $this->loadFromDB( $code, self::FOR_UPDATE ); // Check if an individual cache key should exist and update cache accordingly $page = WikiPage::factory( Title::makeTitle( NS_MEDIAWIKI, $title ) ); $page->loadPageData( $page::READ_LATEST ); $text = $this->getMessageTextFromContent( $page->getContent() ); if ( is_string( $text ) && strlen( $text ) > $wgMaxMsgCacheEntrySize ) { + // Match logic of loadCachedMessagePageEntry() $this->wanCache->set( $this->bigMessageCacheKey( $cache['HASH'], $title ), ' ' . $text, @@ -966,10 +968,13 @@ class MessageCache { * @return string|bool The message, or false if it does not exist or on error */ public function getMsgFromNamespace( $title, $code ) { + // Load all MediaWiki page definitions into cache. Note that individual keys + // already loaded into cache during this request remain in the cache, which + // includes the value of hook-defined messages. $this->load( $code ); - if ( $this->cache->hasField( $code, $title ) ) { - $entry = $this->cache->getField( $code, $title ); + $entry = $this->cache->getField( $code, $title ); + if ( $entry !== null ) { if ( substr( $entry, 0, 1 ) === ' ' ) { // The message exists and is not '!TOO BIG' return (string)substr( $entry, 1 ); @@ -978,6 +983,7 @@ class MessageCache { } // Fall through and try invididual message cache below } else { + // Message does not have a MediaWiki page definition $message = false; Hooks::run( 'MessagesPreLoad', [ $title, &$message, $code ] ); if ( $message !== false ) { @@ -989,75 +995,82 @@ class MessageCache { return $message; } - // Individual message cache key - $bigKey = $this->bigMessageCacheKey( $this->cache->getField( $code, 'HASH' ), $title ); - - if ( $this->mCacheVolatile[$code] ) { + if ( $this->cacheVolatile[$code] ) { $entry = false; // Make sure that individual keys respect the WAN cache holdoff period too LoggerFactory::getInstance( 'MessageCache' )->debug( __METHOD__ . ': loading volatile key \'{titleKey}\'', - [ 'titleKey' => $bigKey, 'code' => $code ] ); + [ 'titleKey' => $title, 'code' => $code ] ); } else { // Try the individual message cache - $entry = $this->wanCache->get( $bigKey ); - } - - if ( $entry !== false ) { - if ( substr( $entry, 0, 1 ) === ' ' ) { - $this->cache->setField( $code, $title, $entry ); - // The message exists, so make sure a string is returned - return (string)substr( $entry, 1 ); - } elseif ( $entry === '!NONEXISTENT' ) { - $this->cache->setField( $code, $title, '!NONEXISTENT' ); - - return false; - } else { - // Corrupt/obsolete entry, delete it - $this->wanCache->delete( $bigKey ); - } - } - - // Try loading the message from the database - $dbr = wfGetDB( DB_REPLICA ); - $cacheOpts = Database::getCacheSetOptions( $dbr ); - // Use newKnownCurrent() to avoid querying revision/user tables - $titleObj = Title::makeTitle( NS_MEDIAWIKI, $title ); - if ( $titleObj->getLatestRevID() ) { - $revision = Revision::newKnownCurrent( - $dbr, - $titleObj + $entry = $this->loadCachedMessagePageEntry( + $title, + $code, + $this->cache->getField( $code, 'HASH' ) ); - } else { - $revision = false; } - if ( $revision ) { - $content = $revision->getContent(); - if ( $content ) { - $message = $this->getMessageTextFromContent( $content ); - if ( is_string( $message ) ) { - $this->cache->setField( $code, $title, ' ' . $message ); - $this->wanCache->set( $bigKey, ' ' . $message, $this->mExpiry, $cacheOpts ); - } - } else { - // A possibly temporary loading failure - LoggerFactory::getInstance( 'MessageCache' )->warning( - __METHOD__ . ': failed to load message page text for \'{titleKey}\'', - [ 'titleKey' => $bigKey, 'code' => $code ] ); - $message = null; // no negative caching - } - } else { - $message = false; // negative caching + if ( $entry !== false && substr( $entry, 0, 1 ) === ' ' ) { + $this->cache->setField( $code, $title, $entry ); + // The message exists, so make sure a string is returned + return (string)substr( $entry, 1 ); } - if ( $message === false ) { - // Negative caching in case a "too big" message is no longer available (deleted) - $this->cache->setField( $code, $title, '!NONEXISTENT' ); - $this->wanCache->set( $bigKey, '!NONEXISTENT', $this->mExpiry, $cacheOpts ); - } + $this->cache->setField( $code, $title, '!NONEXISTENT' ); - return $message; + return false; + } + + /** + * @param string $dbKey + * @param string $code + * @param string $hash + * @return string Either " " or "!NONEXISTANT" + */ + private function loadCachedMessagePageEntry( $dbKey, $code, $hash ) { + return $this->srvCache->getWithSetCallback( + $this->srvCache->makeKey( 'messages-big', $hash, $dbKey ), + IExpiringStore::TTL_MINUTE, + function () use ( $code, $dbKey, $hash ) { + return $this->wanCache->getWithSetCallback( + $this->bigMessageCacheKey( $hash, $dbKey ), + $this->mExpiry, + function ( $oldValue, &$ttl, &$setOpts ) use ( $dbKey, $code ) { + // Try loading the message from the database + $dbr = wfGetDB( DB_REPLICA ); + $setOpts += Database::getCacheSetOptions( $dbr ); + // Use newKnownCurrent() to avoid querying revision/user tables + $title = Title::makeTitle( NS_MEDIAWIKI, $dbKey ); + $revision = Revision::newKnownCurrent( $dbr, $title ); + if ( !$revision ) { + // The wiki doesn't have a local override page. Cache absence with normal TTL. + // When overrides are created, self::replace() takes care of the cache. + return '!NONEXISTENT'; + } + $content = $revision->getContent(); + if ( $content ) { + $message = $this->getMessageTextFromContent( $content ); + } else { + LoggerFactory::getInstance( 'MessageCache' )->warning( + __METHOD__ . ': failed to load page text for \'{titleKey}\'', + [ 'titleKey' => $dbKey, 'code' => $code ] + ); + $message = null; + } + + if ( !is_string( $message ) ) { + // Revision failed to load Content, or Content is incompatible with wikitext. + // Possibly a temporary loading failure. + $ttl = 5; + + return '!NONEXISTENT'; + } + + return ' ' . $message; + } + ); + } + ); } /** diff --git a/includes/changes/EnhancedChangesList.php b/includes/changes/EnhancedChangesList.php index cdfbf56576..28b30d8ba4 100644 --- a/includes/changes/EnhancedChangesList.php +++ b/includes/changes/EnhancedChangesList.php @@ -472,7 +472,10 @@ class EnhancedChangesList extends ChangesList { // skip entry if hook aborted it return []; } - $attribs = wfArrayFilterByKey( $attribs, [ Sanitizer::class, 'isReservedDataAttribute' ] ); + $attribs = array_filter( $attribs, + [ Sanitizer::class, 'isReservedDataAttribute' ], + ARRAY_FILTER_USE_KEY + ); $lineParams['recentChangesFlagsRaw'] = []; if ( isset( $data['recentChangesFlags'] ) ) { @@ -704,9 +707,9 @@ class EnhancedChangesList extends ChangesList { } $attribs = $data['attribs']; unset( $data['attribs'] ); - $attribs = wfArrayFilterByKey( $attribs, function ( $key ) { + $attribs = array_filter( $attribs, function ( $key ) { return $key === 'class' || Sanitizer::isReservedDataAttribute( $key ); - } ); + }, ARRAY_FILTER_USE_KEY ); $prefix = ''; if ( is_callable( $this->changeLinePrefixer ) ) { diff --git a/includes/config/ConfigRepository.php b/includes/config/ConfigRepository.php new file mode 100644 index 0000000000..c87a3440b6 --- /dev/null +++ b/includes/config/ConfigRepository.php @@ -0,0 +1,224 @@ + [], + 'public' => [], + ]; + + /** + * @param \ConfigFactory $configFactory + */ + public function __construct( \ConfigFactory $configFactory ) { + $this->configFactory = $configFactory; + } + + /** + * Returns true, if this repository contains a configuration with a specific name. + * + * @param string $name The name of the config to check the existence of + * @param bool $alsoPrivate If set to true, will check the private config options, too + * @return bool + */ + public function has( $name, $alsoPrivate = false ) { + return isset( $this->configItems['public'][$name] ) || + ( $alsoPrivate && isset( $this->configItems['private'][$name] ) ); + } + + /** + * Returns the ConfigItem with the given name, if there's one. Throws a ConfigException + * otherwise. + * + * @param string $name The name of the configuration option to get + * @return array + * @throws \ConfigException + */ + public function get( $name ) { + if ( !$this->has( $name, true ) ) { + throw new \ConfigException( 'The configuration option ' . $name . ' does not exist.' ); + } + if ( isset( $this->configItems['public'][$name] ) ) { + return $this->configItems['public'][$name]; + } + return $this->configItems['private'][$name]; + } + + /** + * Returns an array of all configuration items saved in this ConfigRepository. This includes + * all configuration options, including the ones marked as private and public. + * + * Note: This function does not do any permission checks or something similar. You should not + * use this function, if the output will be available to the public audience! Use + * ConfigRepository::getPublic() instead. + * + * @return array + */ + public function getAll() { + return array_merge( $this->configItems['private'], $this->configItems['public'] ); + } + + /** + * Returns an array of all public configuration options saved in this ConfigRepository. + * + * @return array + */ + public function getPublic() { + return $this->configItems['public']; + } + + /** + * Returns the current value of the configuration option. If no ConfigRegistry was provided + * when the config was added to the repository, the default value will be returned. + * + * @param string $name The name of the configuration option to get the value of + * @return mixed + * @throws \ConfigException + */ + public function getValueOf( $name ) { + $config = $this->get( $name ); + if ( !isset( $config['configregistry'] ) ) { + return $config['value']; + } + + return $this->configFactory->makeConfig( $config['configregistry'] )->get( $name ); + } + + /** + * Returns the description of the given config option, This can be either a localized + * description, if one such, or the (maybe english only) description provided in the + * definition of the configuration. If both is not provided an empty string is returned. + * + * @param string $name The name of the configuration option to get the description of + * @return string HTML-escaped string + */ + public function getDescriptionOf( $name ) { + $config = $this->get( $name ); + if ( isset( $config['descriptionmsg'] ) ) { + return wfMessage( $config['descriptionmsg'] )->escaped(); + } + if ( isset( $config['description'] ) ) { + return htmlspecialchars( $config['description'] ); + } + return ''; + } + + /** + * Adds the definition of a configuration to this repository. + * + * @param string $name the name of the config + * @param array $config Options of this config. Values are: + * - value: The default value of this configuration, required + * - providedby: The name of the provider of this config (an extension, core, ...), required + * - configregistry: The name of the config to retrieve the value with, required + * - public: whether this option is public or not, if not set, the option is considered as + * "private", optional + * - description: the not localized description of this config option, optional + * - descriptionmsg: The message key of the localized description of this configuration + * option, optional + * @throws \ConfigException + */ + public function add( $name, array $config ) { + if ( $this->has( $name ) ) { + throw new \ConfigException( 'A configuration with the name ' . $name . + 'does already exist. It is provided by: ' . + $this->get( $name )['providedby'] ); + } + if ( isset( $config['public'] ) && $config['public'] ) { + $this->configItems['public'][$name] = $config; + } else { + $this->configItems['private'][$name] = $config; + } + } + + /** + * Returns true, if there're no elements in this instance, otherwise false. + * + * @param bool $includePrivate Whether configuration options, that are marked as private + * should be included in this check. + * @return bool + */ + public function isEmpty( $includePrivate = false ) { + if ( $includePrivate ) { + return empty( $this->configItems['private'] ) && + empty( $this->configItems[ 'public'] ); + } + return empty( $this->configItems['public'] ); + } + + /** + * Re-uses existing Cache objects from $other. Cache objects are only re-used if the + * registered factory function for both is the same. + * + * @see SalvageableService::salvage() + * + * @param SalvageableService $other The object to salvage state from. $other must have the + * exact same type as $this. + */ + public function salvage( SalvageableService $other ) { + Assert::parameterType( self::class, $other, '$other' ); + + /** @var ConfigRepository $other */ + $otherCurrentObj = $other->current(); + foreach ( $other->configItems['public'] as $name => $otherConfig ) { + if ( isset( $this->configItems['public'][$name] ) ) { + continue; + } + + $this->add( $name, $otherConfig ); + + // recover the pointer of the other config repository + if ( $otherCurrentObj === $otherConfig ) { + end( $this->configItems['public'] ); + } + } + foreach ( $other->configItems['private'] as $name => $otherConfig ) { + if ( isset( $this->configItems['private'][$name] ) ) { + continue; + } + + $this->add( $name, $otherConfig ); + + // recover the pointer of the other config repository + if ( $otherCurrentObj === $otherConfig ) { + end( $this->configItems['private'] ); + } + } + + // disable $other + $other->configItems = []; + } +} diff --git a/includes/deferred/LinksDeletionUpdate.php b/includes/deferred/LinksDeletionUpdate.php index 9f6257c810..f370e43ffd 100644 --- a/includes/deferred/LinksDeletionUpdate.php +++ b/includes/deferred/LinksDeletionUpdate.php @@ -101,7 +101,8 @@ class LinksDeletionUpdate extends DataUpdate implements EnqueueableDataUpdate { if ( $title->getNamespace() === NS_CATEGORY ) { // T166757: do the update after the main job DB commit DeferredUpdates::addCallableUpdate( function () use ( $title ) { - $this->refreshCategoryIfEmpty( $title ); + $cat = Category::newFromName( $title->getDBkey() ); + $cat->refreshCountsIfEmpty(); } ); } @@ -187,35 +188,6 @@ class LinksDeletionUpdate extends DataUpdate implements EnqueueableDataUpdate { ScopedCallback::consume( $scopedLock ); } - /** - * @param Title $title - */ - private function refreshCategoryIfEmpty( Title $title ) { - $dbw = $this->getDB(); - - $row = $dbw->selectRow( - 'category', - [ 'cat_id', 'cat_title', 'cat_pages', 'cat_subcats', 'cat_files' ], - [ 'cat_title' => $title->getDBkey(), 'cat_pages <= 100' ], - __METHOD__ - ); - - if ( !$row ) { - return; // nothing to delete - } - - $cat = Category::newFromRow( $row, $title ); - $hasLink = $dbw->selectField( - 'categorylinks', - '1', - [ 'cl_to' => $title->getDBkey() ], - __METHOD__ - ); - if ( !$hasLink ) { - $cat->refreshCounts(); // delete the category table entry - } - } - private function batchDeleteByPK( $table, array $conds, array $pk, $bSize ) { $services = MediaWikiServices::getInstance(); $lbFactory = $services->getDBLoadBalancerFactory(); diff --git a/includes/exception/MWExceptionRenderer.php b/includes/exception/MWExceptionRenderer.php index 88b28df385..49cf71e624 100644 --- a/includes/exception/MWExceptionRenderer.php +++ b/includes/exception/MWExceptionRenderer.php @@ -19,7 +19,6 @@ */ use Wikimedia\Rdbms\DBConnectionError; -use Wikimedia\Rdbms\DBError; use Wikimedia\Rdbms\DBReadOnlyError; use Wikimedia\Rdbms\DBExpectedError; @@ -37,7 +36,7 @@ class MWExceptionRenderer { * @param Exception|Throwable|null $eNew New exception from attempting to show the first */ public static function output( $e, $mode, $eNew = null ) { - global $wgMimeType; + global $wgMimeType, $wgShowExceptionDetails; if ( defined( 'MW_API' ) ) { // Unhandled API exception, we can't be sure that format printer is alive @@ -58,7 +57,7 @@ class MWExceptionRenderer { self::header( "Content-Type: $wgMimeType; charset=utf-8" ); if ( $eNew ) { $message = "MediaWiki internal error.\n\n"; - if ( self::showBackTrace( $e ) ) { + if ( $wgShowExceptionDetails ) { $message .= 'Original exception: ' . MWExceptionHandler::getLogMessage( $e ) . "\nBacktrace:\n" . MWExceptionHandler::getRedactedTraceAsString( $e ) . @@ -73,7 +72,7 @@ class MWExceptionRenderer { } $message .= "\n"; } else { - if ( self::showBackTrace( $e ) ) { + if ( $wgShowExceptionDetails ) { $message = MWExceptionHandler::getLogMessage( $e ) . "\nBacktrace:\n" . MWExceptionHandler::getRedactedTraceAsString( $e ) . "\n"; @@ -162,7 +161,9 @@ class MWExceptionRenderer { * @return string Html to output */ public static function getHTML( $e ) { - if ( self::showBackTrace( $e ) ) { + global $wgShowExceptionDetails; + + if ( $wgShowExceptionDetails ) { $html = "

" . nl2br( htmlspecialchars( MWExceptionHandler::getLogMessage( $e ) ) ) . '

Backtrace:

' . @@ -209,7 +210,9 @@ class MWExceptionRenderer { * @return string */ private static function getText( $e ) { - if ( self::showBackTrace( $e ) ) { + global $wgShowExceptionDetails; + + if ( $wgShowExceptionDetails ) { return MWExceptionHandler::getLogMessage( $e ) . "\nBacktrace:\n" . MWExceptionHandler::getRedactedTraceAsString( $e ) . "\n"; @@ -218,34 +221,13 @@ class MWExceptionRenderer { } } - /** - * @param Exception|Throwable $e - * @return bool - */ - private static function showBackTrace( $e ) { - global $wgShowExceptionDetails, $wgShowDBErrorBacktrace; - - return ( - $wgShowExceptionDetails && - ( !( $e instanceof DBError ) || $wgShowDBErrorBacktrace ) - ); - } - /** * @param Exception|Throwable $e * @return string */ private static function getShowBacktraceError( $e ) { - global $wgShowExceptionDetails, $wgShowDBErrorBacktrace; - $vars = []; - if ( !$wgShowExceptionDetails ) { - $vars[] = '$wgShowExceptionDetails = true;'; - } - if ( $e instanceof DBError && !$wgShowDBErrorBacktrace ) { - $vars[] = '$wgShowDBErrorBacktrace = true;'; - } - $vars = implode( ' and ', $vars ); - return "Set $vars at the bottom of LocalSettings.php to show detailed debugging information."; + $var = '$wgShowExceptionDetails = true;'; + return "Set $var at the bottom of LocalSettings.php to show detailed debugging information."; } /** @@ -294,7 +276,7 @@ class MWExceptionRenderer { * @param Exception|Throwable $e */ private static function reportOutageHTML( $e ) { - global $wgShowDBErrorBacktrace, $wgShowHostnames, $wgShowSQLErrors, $wgSitename; + global $wgShowExceptionDetails, $wgShowHostnames, $wgSitename; $sorry = htmlspecialchars( self::msg( 'dberr-problems', @@ -305,7 +287,7 @@ class MWExceptionRenderer { 'Try waiting a few minutes and reloading.' ) ); - if ( $wgShowHostnames || $wgShowSQLErrors ) { + if ( $wgShowHostnames ) { $info = str_replace( '$1', Html::element( 'span', [ 'dir' => 'ltr' ], $e->getMessage() ), @@ -327,7 +309,7 @@ class MWExceptionRenderer { '' . "

$sorry

$again

$info

"; - if ( $wgShowDBErrorBacktrace ) { + if ( $wgShowExceptionDetails ) { $html .= '

Backtrace:

' .
 				htmlspecialchars( $e->getTraceAsString() ) . '
'; } diff --git a/includes/filebackend/FileBackendGroup.php b/includes/filebackend/FileBackendGroup.php index dc6dbe8f53..503acdcf42 100644 --- a/includes/filebackend/FileBackendGroup.php +++ b/includes/filebackend/FileBackendGroup.php @@ -123,9 +123,7 @@ class FileBackendGroup { } $class = $config['class']; - $config['readOnly'] = !empty( $config['readOnly'] ) - ? $config['readOnly'] - : $readOnlyReason; + $config['readOnly'] = $config['readOnly'] ?? $readOnlyReason; unset( $config['class'] ); // backend won't need this $this->backends[$name] = [ diff --git a/includes/filerepo/RepoGroup.php b/includes/filerepo/RepoGroup.php index 90c8707f8d..f3fed5772d 100644 --- a/includes/filerepo/RepoGroup.php +++ b/includes/filerepo/RepoGroup.php @@ -125,10 +125,12 @@ class RepoGroup { if ( isset( $options['bypassCache'] ) ) { $options['latest'] = $options['bypassCache']; // b/c } + $options += [ 'time' => false ]; if ( !$this->reposInitialised ) { $this->initialiseRepos(); } + $title = File::normalizeTitle( $title ); if ( !$title ) { return false; @@ -136,17 +138,16 @@ class RepoGroup { # Check the cache $dbkey = $title->getDBkey(); + $timeKey = is_string( $options['time'] ) ? $options['time'] : ''; if ( empty( $options['ignoreRedirect'] ) && empty( $options['private'] ) && empty( $options['latest'] ) ) { - $time = $options['time'] ?? ''; - if ( $this->cache->hasField( $dbkey, $time, 60 ) ) { - return $this->cache->getField( $dbkey, $time ); + if ( $this->cache->hasField( $dbkey, $timeKey, 60 ) ) { + return $this->cache->getField( $dbkey, $timeKey ); } $useCache = true; } else { - $time = false; $useCache = false; } @@ -166,7 +167,7 @@ class RepoGroup { $image = $image ?: false; // type sanity # Cache file existence or non-existence if ( $useCache && ( !$image || $image->isCacheable() ) ) { - $this->cache->setField( $dbkey, $time, $image ); + $this->cache->setField( $dbkey, $timeKey, $image ); } return $image; diff --git a/includes/htmlform/fields/HTMLCheckField.php b/includes/htmlform/fields/HTMLCheckField.php index 7523b5fe84..aad9f6e9d2 100644 --- a/includes/htmlform/fields/HTMLCheckField.php +++ b/includes/htmlform/fields/HTMLCheckField.php @@ -116,10 +116,9 @@ class HTMLCheckField extends HTMLFormField { public function loadDataFromRequest( $request ) { $invert = isset( $this->mParams['invert'] ) && $this->mParams['invert']; - // GetCheck won't work like we want for checks. // Fetch the value in either one of the two following case: - // - we have a valid submit attempt (form was just submitted, or a GET URL forged by the user) - // - checkbox name has a value (false or true), ie is not null + // - we have a valid submit attempt (form was just submitted) + // - we have a value (an URL manually built by the user, or GET form with no wpFormIdentifier) if ( $this->isSubmitAttempt( $request ) || $request->getVal( $this->mName ) !== null ) { return $invert ? !$request->getBool( $this->mName ) diff --git a/includes/htmlform/fields/HTMLMultiSelectField.php b/includes/htmlform/fields/HTMLMultiSelectField.php index 4b1bc552bb..2038606597 100644 --- a/includes/htmlform/fields/HTMLMultiSelectField.php +++ b/includes/htmlform/fields/HTMLMultiSelectField.php @@ -214,10 +214,14 @@ class HTMLMultiSelectField extends HTMLFormField implements HTMLNestedFilterable * @return string|array */ public function loadDataFromRequest( $request ) { - if ( $this->isSubmitAttempt( $request ) ) { + $fromRequest = $request->getArray( $this->mName, [] ); + // Fetch the value in either one of the two following case: + // - we have a valid submit attempt (form was just submitted) + // - we have a value (an URL manually built by the user, or GET form with no wpFormIdentifier) + if ( $this->isSubmitAttempt( $request ) || $fromRequest ) { // Checkboxes are just not added to the request arrays if they're not checked, // so it's perfectly possible for there not to be an entry at all - return $request->getArray( $this->mName, [] ); + return $fromRequest; } else { // That's ok, the user has not yet submitted the form, so show the defaults return $this->getDefault(); diff --git a/includes/htmlform/fields/HTMLTitleTextField.php b/includes/htmlform/fields/HTMLTitleTextField.php index 602ddee486..0ad41d43bd 100644 --- a/includes/htmlform/fields/HTMLTitleTextField.php +++ b/includes/htmlform/fields/HTMLTitleTextField.php @@ -41,6 +41,11 @@ class HTMLTitleTextField extends HTMLTextField { return parent::validate( $value, $alldata ); } + // Default value (from getDefault()) is null, which breaks Title::newFromTextThrow() below + if ( $value === null ) { + $value = ''; + } + if ( !$this->mParams['required'] && $value === '' ) { // If this field is not required and the value is empty, that's okay, skip validation return parent::validate( $value, $alldata ); diff --git a/includes/htmlform/fields/HTMLUserTextField.php b/includes/htmlform/fields/HTMLUserTextField.php index e1939705ab..d6723144f5 100644 --- a/includes/htmlform/fields/HTMLUserTextField.php +++ b/includes/htmlform/fields/HTMLUserTextField.php @@ -34,6 +34,11 @@ class HTMLUserTextField extends HTMLTextField { } public function validate( $value, $alldata ) { + // Default value (from getDefault()) is null, User::newFromName() expects a string + if ( $value === null ) { + $value = ''; + } + // check, if a user exists with the given username $user = User::newFromName( $value, false ); $rangeError = null; @@ -43,7 +48,7 @@ class HTMLUserTextField extends HTMLTextField { } elseif ( // check, if the user exists, if requested ( $this->mParams['exists'] && $user->getId() === 0 ) && - // check, if the username is a valid IP address, otherweise save the error message + // check, if the username is a valid IP address, otherwise save the error message !( $this->mParams['ipallowed'] && IP::isValid( $value ) ) && // check, if the username is a valid IP range, otherwise save the error message !( $this->mParams['iprange'] && ( $rangeError = $this->isValidIPRange( $value ) ) === true ) diff --git a/includes/http/CurlHttpRequest.php b/includes/http/CurlHttpRequest.php index f457b2192c..bab85216c0 100644 --- a/includes/http/CurlHttpRequest.php +++ b/includes/http/CurlHttpRequest.php @@ -98,6 +98,7 @@ class CurlHttpRequest extends MWHttpRequest { $curlHandle = curl_init( $this->url ); if ( !curl_setopt_array( $curlHandle, $this->curlOptions ) ) { + $this->status->fatal( 'http-internal-error' ); throw new InvalidArgumentException( "Error setting curl options." ); } diff --git a/includes/http/MWHttpRequest.php b/includes/http/MWHttpRequest.php index 71e08a815f..257955c13d 100644 --- a/includes/http/MWHttpRequest.php +++ b/includes/http/MWHttpRequest.php @@ -332,6 +332,7 @@ abstract class MWHttpRequest implements LoggerAwareInterface { if ( is_null( $callback ) ) { $callback = [ $this, 'read' ]; } elseif ( !is_callable( $callback ) ) { + $this->status->fatal( 'http-internal-error' ); throw new InvalidArgumentException( __METHOD__ . ': invalid callback' ); } $this->callback = $callback; @@ -387,6 +388,11 @@ abstract class MWHttpRequest implements LoggerAwareInterface { protected function parseHeader() { $lastname = ""; + // Failure without (valid) headers gets a response status of zero + if ( !$this->status->isOK() ) { + $this->respStatus = '0'; + } + foreach ( $this->headerList as $header ) { if ( preg_match( "#^HTTP/([0-9.]+) (.*)#", $header, $match ) ) { $this->respVersion = $match[1]; diff --git a/includes/installer/Installer.php b/includes/installer/Installer.php index 3905ba02ee..e7ee95c78a 100644 --- a/includes/installer/Installer.php +++ b/includes/installer/Installer.php @@ -1725,13 +1725,10 @@ abstract class Installer { $GLOBALS['wgLanguageConverterCacheType'] = CACHE_NONE; // Debug-friendly $GLOBALS['wgShowExceptionDetails'] = true; + $GLOBALS['wgShowHostnames'] = true; // Don't break forms $GLOBALS['wgExternalLinkTarget'] = '_blank'; - // Extended debugging - $GLOBALS['wgShowSQLErrors'] = true; - $GLOBALS['wgShowDBErrorBacktrace'] = true; - // Allow multiple ob_flush() calls $GLOBALS['wgDisableOutputCompression'] = true; diff --git a/includes/installer/i18n/ar.json b/includes/installer/i18n/ar.json index 856b44baa6..dcccd228f2 100644 --- a/includes/installer/i18n/ar.json +++ b/includes/installer/i18n/ar.json @@ -117,7 +117,7 @@ "config-sqlite-dir-help": "يخزن SQLite جميع البيانات في ملف واحد. \n\nيجب أن يكون الدليل الذي توفره قابلا للكتابة بواسطة خادم الويب أثناء التثبيت. \n\nيجب أن يكون غير متاحا عبر الويب؛ هذا هو سبب عدم وضعه في مكان ملفات PHP الخاصة بك. \n\nسيقوم المثبت بكتابة ملف .htaccess معه، ولكن إذا فشل ذلك، يمكن لشخص ما الوصول إلى قاعدة بياناتك الأولية، \nيتضمن ذلك بيانات المستخدم الأولية (عناوين البريد الإلكتروني وكلمات المرور المجزأة) بالإضافة إلى المراجعات المحذوفة والبيانات المحظورة الأخرى على الويكي. \n\nفكر في وضع قاعدة البيانات في مكان آخر تماما، على سبيل المثال في /var/lib/mediawiki/yourwikiتحذير: لقد اخترت MyISAM كمحرك تخزين لـMySQL، والذي لا يُنصَح باستخدامه مع ميدياويكي; لأنه:\n* بالكاد يدعم التزامن بسبب قفل الجدول \n* أكثر عرضة للفساد من المحركات الأخرى\n* لا يقوم الكود الأساسي لميدياويكي بمعالجة MyISAM دائما كما يجب\n\nإذا كان تثبيت MySQL يدعم InnoDB، فمن المستحسن جدا أن تختاره بدلا منه، \nإذا كان تثبيت MySQL لا يدعم InnoDB، فربما حان الوقت للترقية.", "config-mysql-only-myisam-dep": "تحذير: MyISAMهو محرك التخزين الوحيد المتاح لـMySQL على هذا الجهاز، ولا يُنصَح باستخدامه مع ميدياويكي; لأنه:\n* بالكاد يدعم التزامن بسبب قفل الجدول \n* أكثر عرضة للفساد من المحركات الأخرى\n* لا يقوم الكود الأساسي لميدياويكي بمعالجة MyISAM دائما كما يجب\n\nتثبيت MySQL لا يدعم InnoDB; ربما حان الوقت للترقية.", diff --git a/includes/installer/i18n/es.json b/includes/installer/i18n/es.json index ee89d1f20f..9c24b34eee 100644 --- a/includes/installer/i18n/es.json +++ b/includes/installer/i18n/es.json @@ -142,7 +142,7 @@ "config-sqlite-dir-help": "SQLite almacena todos los datos en un único archivo.\n\nEl directorio que proporciones debe poder escribirse por el servidor web durante la instalación.\n\n'''No''' debería ser accesible a través de Internet. Por eso no vamos a ponerlo en el sitio donde están los archivos PHP.\n\nEl instalador escribirá un archivo .htaccess junto con él, pero si falla alguien podría tener acceso a la base de datos en bloque.\nEso incluye los datos de usuario en bloque (direcciones de correo electrónico, las contraseñas con hash) así como revisiones eliminadas y otros datos restringidos del wiki.\n\nConsidera poner la base de datos en algún otro sitio, por ejemplo en /var/lib/mediawiki/tuwiki .", "config-oracle-def-ts": "Espacio de tablas predeterminado:", "config-oracle-temp-ts": "Espacio de tablas temporal:", - "config-type-mysql": "MySQL (o compatible)", + "config-type-mysql": "MariaDB, MySQL o un sistema compatible", "config-type-postgres": "PostgreSQL", "config-type-sqlite": "SQLite", "config-type-oracle": "Oracle", diff --git a/includes/installer/i18n/he.json b/includes/installer/i18n/he.json index a680353406..6d1b89483f 100644 --- a/includes/installer/i18n/he.json +++ b/includes/installer/i18n/he.json @@ -59,7 +59,7 @@ "config-unicode-using-intl": "משתמש ב[https://pecl.php.net/intl הרחבת intl PECL] לנרמול יוניקוד.", "config-unicode-pure-php-warning": "אזהרה: [https://pecl.php.net/intl הרחבת intl PECL] אינה זמינה לטיפול בנרמול יוניקוד. משתמש ביישום PHP טהור ואטי יותר.\nאם זהו אתר בעל תעבורה גבוהה, כדאי לקרוא את המסמך הבא: [https://www.mediawiki.org/wiki/Special:MyLanguage/Unicode_normalization_considerations Unicode normalization].", "config-unicode-update-warning": "'''אזהרה''': הגרסה המותקנת של מעטפת נרמול יוניקוד משתמשת בגרסה ישנה של הספרייה של [http://site.icu-project.org/ פרויקט ICU].\nכדאי [https://www.mediawiki.org/wiki/Special:MyLanguage/Unicode_normalization_considerations לעדכן] אם הטיפול ביוניקוד חשוב לך.", - "config-no-db": "לא נמצא דרייבר מסד נתונים מתאים. יש להתקין דרייבר מסד נתונים ל־PHP.\n{{PLURAL:$2|נתמך הסוג הבא של מסד נתונים|נתמכים הסוגים הבאים של מסדי נתונים}}: $1.\n\nאם קִמפלת את PHP בעצמך, יש להגדיר אותו מחדש ולהפעיל את לקוח מסד נתונים, למשל באמצעות ./configure --with-mysqli.\nאם התקנת את PHP מחבילה של דביאן או של אובונטו, יש להתקין, למשל, גם את המודול php5-mysql.", + "config-no-db": "לא נמצא דרייבר מסד נתונים מתאים. יש להתקין דרייבר מסד נתונים ל־PHP.\n{{PLURAL:$2|נתמך הסוג הבא של מסד נתונים|נתמכים הסוגים הבאים של מסדי נתונים}}: $1.\n\nאם קִמפלת את PHP בעצמך, יש להגדיר אותו מחדש ולהפעיל את לקוח מסד נתונים, למשל באמצעות ./configure --with-mysqli.\nאם התקנת את PHP מחבילה של דביאן או של אובונטו, יש להתקין, למשל, גם את המודול php-mysql.", "config-outdated-sqlite": "'''אזהרה''': במערכת מתוקן SQLite $1. גרסה זו לא נתמכת ולשימוש ב־SQLite נדרשת גרסה $2 לפחות. SQLlite לא יהיה זמין.", "config-no-fts3": "'''אזהרה''': SQLite מהודר ללא [//sqlite.org/fts3.html מודול FTS]. יכולות חיפוש לא יהיו זמינות בהתקנה הזאת.", "config-pcre-old": "שגיאה סופנית: חובה להתקין PCRE מגרסה $1 או גרסה חדשה יותר.\nקובץ הרצת ה־PHP שלך מקושר עם PCRE מגרסה $2.\n[https://www.mediawiki.org/wiki/Manual:Errors_and_symptoms/PCRE מידע נוסף].", diff --git a/includes/installer/i18n/it.json b/includes/installer/i18n/it.json index bea4607138..b8db48900c 100644 --- a/includes/installer/i18n/it.json +++ b/includes/installer/i18n/it.json @@ -126,10 +126,10 @@ "config-sqlite-dir-help": "SQLite memorizza tutti i dati in un unico file.\n\nLa directory che indicherai deve essere scrivibile dal server web durante l'installazione.\n\nDovrebbe essere non accessibile via web, è per questo che non la stiamo mettendo dove ci sono i file PHP.\n\nL'installatore scriverà insieme ad essa un file .htaccess, ma se il tentativo fallisse qualcuno potrebbe avere accesso al database grezzo.\nQuesto include dati utente grezzi (indirizzi, password cifrate) così come versioni eliminate e altri dati ad accesso limitato del wiki.\n\nConsidera l'opportunità di sistemare allo stesso tempo il database da qualche altra parte, per esempio in /var/lib/mediawiki/tuowiki.", "config-oracle-def-ts": "Tablespace di default:", "config-oracle-temp-ts": "Tablespace temporaneo:", - "config-type-mysql": "MySQL (o compatibile)", + "config-type-mysql": "MariaDB, MySQL o compatibile", "config-type-mssql": "Microsoft SQL Server", "config-support-info": "MediaWiki supporta i seguenti sistemi di database:\n\n$1\n\nSe fra quelli elencati qui sotto non vedi il sistema di database che vorresti utilizzare, seguire le istruzioni linkate sopra per abilitare il supporto.", - "config-dbsupport-mysql": "* [{{int:version-db-mysql-url}} MySQL] è la configurazione preferibile per MediaWiki ed è quella meglio supportata. MediaWiki funziona anche con [{{int:version-db-mariadb-url}} MariaDB] e [{{int:version-db-percona-url}} Percona Server], che sono compatibili con MySQL.([https://secure.php.net/manual/en/mysqli.installation.php Come compilare PHP con supporto MySQL])", + "config-dbsupport-mysql": "* [{{int:version-db-mariadb-url}} MariaDB] è la configurazione preferibile per MediaWiki ed è quella meglio supportata. MediaWiki funziona anche con [{{int:version-db-mysql-url}} MySQL] e [{{int:version-db-percona-url}} Percona Server], che sono compatibili con MariaDB.([https://secure.php.net/manual/en/mysqli.installation.php Come compilare PHP con supporto MySQL])", "config-dbsupport-postgres": "* [{{int:version-db-postgres-url}} PostgreSQL] è un popolare sistema di database open source come alternativa a MySQL. ([https://secure.php.net/manual/en/pgsql.installation.php Come compilare PHP con supporto PostgreSQL])", "config-dbsupport-sqlite": "* [{{int:version-db-sqlite-url}} SQLite] è un sistema di database leggero, che è supportato molto bene. ([https://secure.php.net/manual/en/pdo.installation.php Come compilare PHP con supporto SQLite], utilizza PDO)", "config-dbsupport-oracle": "* [{{int:version-db-oracle-url}} Oracle] è un database di un'impresa commerciale. ([https://secure.php.net/manual/en/oci8.installation.php Come compilare PHP con supporto OCI8])", diff --git a/includes/installer/i18n/nb.json b/includes/installer/i18n/nb.json index 671127ee21..1e88f7b299 100644 --- a/includes/installer/i18n/nb.json +++ b/includes/installer/i18n/nb.json @@ -115,18 +115,18 @@ "config-sqlite-dir-help": "SQLite lagrer alle data i en enkelt fil.\n\nMappen du oppgir må være skrivbar for nettjeneren under installasjonen.\n\nDen bør '''ikke''' være tilgjengelig fra nettet, dette er grunnen til at vi ikke legger det der PHP-filene dine er.\n\nInstallasjonsprogrammet vil skrive en .htaccess-fil sammen med det, men om det mislykkes kan noen få tilgang til din råe database. Dette inkluderer rå brukerdata (e-postadresser, hashede passord) samt slettede revisjoner og andre begrensede data på wikien.\n\nVurder å plassere databasen et helt annet sted, for eksempel i /var/lib/mediawiki/yourwiki.", "config-oracle-def-ts": "Standard tabellrom:", "config-oracle-temp-ts": "Midlertidig tabellrom:", - "config-type-mysql": "MySQL (eller kompatibelt)", + "config-type-mysql": "MariaDB, MySQL eller kompatibel", "config-type-postgres": "PostgreSQL", "config-type-sqlite": "SQLite", "config-type-oracle": "Oracle", "config-type-mssql": "Microsoft SQLServer", "config-support-info": "MediaWiki støtter følgende databasesystem:\n\n$1\n\nHvis du ikke ser databasesystemet du prøver å bruke i listen nedenfor, følg instruksjonene det er lenket til over for å aktivere støtte.", - "config-dbsupport-mysql": "* [{{int:version-db-mysql-url}} MySQL] er den foretrukne databasetypen for MediaWiki og har best støtte. MediaWiki fungerer også med [{{int:version-db-mariadb-url}} MariaDB] og [{{int:version-db-percona-url}} Percona Server], som begge er MySQL-kompatible. ([https://secure.php.net/manual/en/mysqli.installation.php Hvordan kompilere PHP med MySQL-støtte])", + "config-dbsupport-mysql": "* [{{int:version-db-mariadb-url}} MariaDB] er den foretrukne databasetypen for MediaWiki og har best støtte. MediaWiki fungerer også med [{{int:version-db-mysql-url}} MySQL] og [{{int:version-db-percona-url}} Percona Server], som begge er MariaDB-kompatible. ([https://secure.php.net/manual/en/mysqli.installation.php Hvordan kompilere PHP med MySQL-støtte])", "config-dbsupport-postgres": "* [{{int:version-db-postgres-url}} PostgreSQL] er et populært åpen kildekode-databasesystem og et alternativ til MySQL. ([https://secure.php.net/manual/en/pgsql.installation.php Hvordan kompilere PHP med PostgreSQL-støtte])", "config-dbsupport-sqlite": "* [{{int:version-db-sqlite-url}} SQLite] er et lettvekts-databasesystem som har veldig god støtte. ([http://www.php.net/manual/en/pdo.installation.php Hvordan kompilere PHP med SQLite-støtte], bruker PDO)", "config-dbsupport-oracle": "* [{{int:version-db-oracle-url}} Oracle] er en kommersiell database for bedrifter. ([https://secure.php.net/manual/en/oci8.installation.php Hvordan kompilere PHP med OCI8-støtte])", "config-dbsupport-mssql": "* [{{int:version-db-mssql-url}} Microsoft SQL Server] er et kommersielt databasesystem under Windows for bedrifter. ([https://secure.php.net/manual/en/sqlsrv.installation.php Hvordan kompilere PHP med SQLSRV-støtte])", - "config-header-mysql": "MySQL-innstillinger", + "config-header-mysql": "MariadB/MySQL-innstillinger", "config-header-postgres": "PostgreSQL-innstillinger", "config-header-sqlite": "SQLite-innstillinger", "config-header-oracle": "Oracle-innstillinger", @@ -165,7 +165,7 @@ "config-db-web-create": "Opprett kontoen om den ikke finnes allerede", "config-db-web-no-create-privs": "Kontoen du oppga for installasjonen har ikke nok privilegier til å opprette en konto.\nKontoen du oppgir her må finnes allerede.", "config-mysql-engine": "Lagringsmotor:", - "config-mysql-innodb": "InnoDB", + "config-mysql-innodb": "InnoDB (anbefalt)", "config-mysql-myisam": "MyISAM", "config-mysql-myisam-dep": "'''Advarsel:''' Du har valgt MyISAM som lagringsmotor for MySQL, noe som ikke er anbefalt for bruk med MediaWiki, fordi:\n* den knapt støtter samtidighet pga. tabell-låsing\n* den har større tilbøyelighet for å bli korrupt enn andre motorer\n* MediaWiki-koden håndterer ikke alltid MyISAM som den burde\n\nHvis din MySQL-installasjon støtter InnoDB, er det sterkt å anbefale at du i stedet velger den.\nHvis din MySQL-installasjon ikke støtter InnoDB, kan det være på tide med en oppgradering.", "config-mysql-only-myisam-dep": "'''Advarsel:''' MyISAM er den eneste tilgjengelig lagringsmotoren for MySQL på denne maskinen, og det er ikke anbefalt brukt for MediaWiki, fordi:\n* den knapt støtter samtidighet pga. tabell-låsing\n* den har større tilbøyelighet for å bli korrupt enn andre motorer\n* MediaWiki-koden håndterer ikke alltid MyISAM som den burde\n\nHvis din MySQL-installasjon ikke støtter InnoDB, kan det være på tide med en oppgradering.", @@ -226,7 +226,7 @@ "config-license-help": "Mange åpne wikier legger alle bidrag under en [https://freedomdefined.org/Definition gratislisens].\nDette gir en følelse av felleseie og stimulerer til langvarige bidrag.\nDette er normalt unødvendig for en privat eller virksomhetsbegrenset wiki.\n\nHvis du ønsker å kunne bruke tekst fra Wikipedia, og at Wikipedia skal kunne ta i mot tekst kopiert fra din wiki, bør du velge {{int:config-license-cc-by-sa}}.\n\nWikipedia brukte tidligere GNU Free Documentation License.\nGFDL er en grei lisens, med vanskelig å forstå.\nDet er også vanskelig å gjenbruke innhold lisensiert under GFDL.", "config-email-settings": "E-postinnstillinger", "config-enable-email": "Aktiver utgående e-post", - "config-enable-email-help": "Hvis du vil at e-post skal virke, må [https://secure.php.net/manual/en/mail.configuration.php PHPs e-post-innstillinger] konfigureres riktig.\nHvis du ikke ønsker noen e-postfunksjoner, kan du deaktivere dem her.", + "config-enable-email-help": "Hvis du vil at e-post skal virke, må [https://secure.php.net/manual/en/mail.configuration.php PHPs epostinnstillinger] konfigureres riktig.\nHvis du ikke ønsker noen epostfunksjoner, kan du deaktivere dem her.", "config-email-user": "Aktiver e-post mellom brukere", "config-email-user-help": "Tillat alle brukere å sende hverandre e-post hvis de har aktivert det i deres innstillinger.", "config-email-usertalk": "Aktiver brukerdiskusjonssidevarsler", diff --git a/includes/installer/i18n/nl.json b/includes/installer/i18n/nl.json index 807a627729..ca4bcc2e10 100644 --- a/includes/installer/i18n/nl.json +++ b/includes/installer/i18n/nl.json @@ -127,7 +127,7 @@ "config-sqlite-dir-help": "SQLite slaat alle gegevens op in een enkel bestand.\n\nDe map die u opgeeft moet beschrijfbaar zijn voor de webserver tijdens de installatie.\n\nDeze mag '''niet toegankelijk''' zijn via het web en het bestand mag dus niet tussen de PHP-bestanden staan.\n\nHet installatieprogramma schrijft het bestand .htaccess weg met het databasebestand, maar als dat niet werkt kan iemand zich toegang tot het ruwe databasebestand verschaffen.\nOok de gebruikersgegevens (e-mailadressen, wachtwoordhashes) en verwijderde versies en overige gegevens met beperkte toegang via MediaWiki zijn dan onbeschermd.\n\nOverweeg om de database op een totaal andere plaats neer te zetten, bijvoorbeeld in /var/lib/mediawiki/yourwiki.", "config-oracle-def-ts": "Standaard tablespace:", "config-oracle-temp-ts": "Tijdelijke tablespace:", - "config-type-mysql": "MySQL (of compatibel)", + "config-type-mysql": "MariaDB, MySQL of compatibele systemen", "config-type-postgres": "PostgreSQL", "config-type-sqlite": "SQLite", "config-type-oracle": "Oracle", @@ -138,7 +138,7 @@ "config-dbsupport-sqlite": "* [{{int:version-db-sqlite-url}} SQLite] is een zeer goed ondersteund lichtgewicht databasesysteem ([https://secure.php.net/manual/en/pdo.installation.php hoe PHP gecompileerd moet zijn met ondersteuning voor SQLite]; gebruikt PDO).", "config-dbsupport-oracle": "* [{{int:version-db-oracle-url}} Oracle] is een commerciële database voor grote bedrijven ([https://secure.php.net/manual/en/oci8.installation.php PHP compileren met ondersteuning voor OCI8]).", "config-dbsupport-mssql": "* [{{int:version-db-mssql-url}} Microsoft SQL Server] is een commerciële enterprisedatabase voor Windows ([https://secure.php.net/manual/en/sqlsrv.installation.php PHP compileren met ondersteuning voor SQLSRV]).", - "config-header-mysql": "MySQL-instellingen", + "config-header-mysql": "MariaDB/MySQL-instellingen", "config-header-postgres": "PostgreSQL-instellingen", "config-header-sqlite": "SQLite-instellingen", "config-header-oracle": "Oracle-instellingen", @@ -177,7 +177,7 @@ "config-db-web-create": "Maak de gebruiker aan als deze nog niet bestaat", "config-db-web-no-create-privs": "Het account dat u voor de installatie hebt opgegeven, heeft niet voldoende rechten om een account aan te maken.\nHet account dat u hier opgeeft, moet al bestaan.", "config-mysql-engine": "Opslagmethode:", - "config-mysql-innodb": "InnoDB", + "config-mysql-innodb": "InnoDB (aanbevolen)", "config-mysql-myisam": "MyISAM", "config-mysql-myisam-dep": "'''Waarschuwing''': u hebt MyISAM geselecteerd als opslagengine voor MySQL. Dit is niet aan te raden voor MediaWiki omdat:\n* het nauwelijks ondersteuning biedt voor gebruik door meerdere gebruikers tegelijkertijd door het locken van tabellen;\n* het meer vatbaar is voor corruptie dan andere engines;\n* de code van MediaWiki niet alstijd omgaat met MyISAM zoals dat zou moeten.\n\nAls uw installatie van MySQL InnoDB ondersteunt, gebruik dat dan vooral.\nAls uw installatie van MySQL geen ondersteuning heeft voor InnoDB, denk dan na over upgraden.", "config-mysql-only-myisam-dep": "'''Waarschuwing:''' MyISAM is enige beschikbare opslagmethode voor MySQL in deze omgeving, en deze wordt niet aangeraden voor gebruik met MediaWiki, omdat:\n* er nauwelijks ondersteuning is voor meerdere gelijktijdige transacties omdat tabellen op slot gezet worden;\n* tabellen makkelijker stuk kunnen gaan;\n* de code van MediaWiki niet altijd op de juiste wijze omgaat met MyISAM.\n\nUw installatie van MySQL heeft geen ondersteuning voor InnoDB. We raden u aan om een meer recente versie te gebruiken.", diff --git a/includes/installer/i18n/sl.json b/includes/installer/i18n/sl.json index 7e83f5634c..ce43339721 100644 --- a/includes/installer/i18n/sl.json +++ b/includes/installer/i18n/sl.json @@ -4,7 +4,8 @@ "Dbc334", "Eleassar", "Yerpo", - "HairyFotr" + "HairyFotr", + "Janezdrilc" ] }, "config-desc": "Namestitveni program za MediaWiki", @@ -76,9 +77,9 @@ "config-db-schema-help": "Ta shema je po navadi v redu.\nSpremenite jo samo, če veste, da jo morate.", "config-pg-test-error": "Ne morem se povezati z zbirko podatkov $1: $2", "config-sqlite-dir": "Mapa podatkov SQLite:", - "config-type-mysql": "MySQL (ali združljiv)", + "config-type-mysql": "MySQL, MySQL ali združljiv", "config-support-info": "MediaWiki podpira naslednje sisteme zbirk podatkov:\n\n$1\n\nČe zgoraj ne vidite navedenega sistema zbirk podatkov, ki ga poskušate uporabiti, sledite navodilom na spodnji povezavi, da omogočite podporo.", - "config-header-mysql": "Nastavitve MySQL", + "config-header-mysql": "Nastavitve MariaDB/MySQL", "config-header-postgres": "Nastavitve PostgreSQL", "config-header-sqlite": "Nastavitve SQLite", "config-header-oracle": "Nastavitve Oracle", @@ -103,7 +104,7 @@ "config-db-web-account-same": "Uporabi enak račun kot za namestitev", "config-db-web-create": "Ustvari račun, če že ne obstaja", "config-mysql-engine": "Pogon skladiščenja:", - "config-mysql-innodb": "InnoDB", + "config-mysql-innodb": "InnoDB (priporočeno)", "config-mysql-myisam": "MyISAM", "config-mssql-auth": "Tip avtentikacije:", "config-site-name": "Ime wikija:", diff --git a/includes/installer/i18n/tr.json b/includes/installer/i18n/tr.json index 633d8cb6d7..93d44e4c60 100644 --- a/includes/installer/i18n/tr.json +++ b/includes/installer/i18n/tr.json @@ -75,9 +75,9 @@ "config-pcre-no-utf8": "Önemli hata: PHP'nin PCRE modülü PCRE_UTF8 desteği olmadan derlenmiş gözüküyor.\nMediaWiki'nin doğru çalışabilmesi için UTF-8 desteği gereklidir.", "config-memory-raised": "PHP'nin memory_limit (hafıza sınırı) değeri $1, $2'ye yükseltildi.", "config-memory-bad": "Uyarı: PHP'nin memory_limit (hafıza sınırı) değeri $1.\nBu büyük ihtimalle çok düşük.\nKurulum başarısız olabilir!", - "config-apc": "[https://secure.php.net/apc APC] kurulu", - "config-apcu": "[https://secure.php.net/apcu APCu] yüklendi", - "config-wincache": "[https://www.iis.net/downloads/microsoft/wincache-extension WinCache] kurulu", + "config-apc": "[https://secure.php.net/apc APC] kuruldu", + "config-apcu": "[https://secure.php.net/apcu APCu] kuruldu", + "config-wincache": "[https://www.iis.net/downloads/microsoft/wincache-extension WinCache] kuruldu", "config-no-cache-apcu": "Uyarı: [https://secure.php.net/apcu APCu] ya da [https://www.iis.net/downloads/microsoft/wincache-extension WinCache] kurulumu bulunamadı.\nNesne önbellekleme etkin değil.", "config-mod-security": "'''Uyarı:''' Web sunucunuz [https://modsecurity.org/mod_security2 mod_security] etkin. Bunun birçok yaygın yapılandırması bulunur ve eğer yanlış yapılandırılmış ise, bu MediaWiki ve kullanıcılara isteğe bağlı içerik göndermesine izin veren diğer yazılımlar için sorun oluşturabilir.\nMümkünse bu devre dışı bırakılmalıdır. Aksi takdirde rastgele hatalar alırsanız [https://modsecurity.org/documentation/ mod_security belgelemesine] bakın ya da sunucunuzun desteğine başvurun.", "config-diff3-bad": "GNU diff3 bulunamadı.", @@ -90,6 +90,8 @@ "config-no-cli-uri": "Uyarı: Herhangi bir --scriptpath belirlenmemiş, varsayılan kullanılıyor: $1.", "config-using-server": "Sunucu adı olarak \"$1\" kullanılıyor.", "config-using-uri": "Sunucu URLsi olarak \"$1$2\" kullanılıyor.", + "config-uploads-not-safe": "Uyarı: Yüklemeler için varsayılan dizininiz $1, rastgele komut dosyalarının yürütülmesine karşı savunmasızdır.\nMediaWiki, karşıya yüklenen tüm dosyaları güvenlik tehditlerine karşı denetlese de, yüklemeleri etkinleştirmeden önce [https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:Security#Upload_security bu güvenlik açığını kapatmanız] önemle tavsiye edilir.", + "config-no-cli-uploads-check": "Uyarı: Yüklemeler için varsayılan dizininiz ($1), CLI yüklemesi sırasında rastgele kod yürütme güvenlik açığı açısından denetlenmez.", "config-db-type": "Veritabanı tipi:", "config-db-host": "Veritabanı sunucusu:", "config-db-host-help": "Veritabanı sunucunuz farklı bir sunucu üzerinde ise, ana bilgisayar adını veya IP adresini buraya girin.\n\nPaylaşılan ağ barındırma hizmeti kullanıyorsanız, barındırma sağlayıcınız size doğru bir ana bilgisayar adını kendi belgelerinde vermiştir.\n\nEğer MySQL kullanan bir Windows sunucusuna yükleme yapıyorsanız, sunucu adı olarak \"localhost\" kullanırsanız çalışmayabilir. Çalışmazsa, yerel IP adresi için \"127.0.0.1\" deneyin.\n\nPostgreSQL kullanıyorsanız, bu alanı bir Unix soketi ile bağlanmak için boş bırakın.", diff --git a/includes/installer/i18n/vi.json b/includes/installer/i18n/vi.json index 7b3462d618..ca87d6084e 100644 --- a/includes/installer/i18n/vi.json +++ b/includes/installer/i18n/vi.json @@ -113,15 +113,15 @@ "config-sqlite-dir-help": "SQLite lưu tất cả các dữ liệu trong một tập tin duy nhất.\n\nThư mục mà bạn cung cấp phải cho phép máy chủ Web ghi vào khi cài đặt.\n\nKhông nên làm cho nó truy cập được qua Web; đây là lý do chúng tôi không đặt nó vào cùng thư mục với các tập tin PHP của bạn.\n\nTrình cài đặt sẽ ghi một tập tin .htaccess đi kèm, nhưng nếu thất bại người nào đó có thể truy cập vào cơ sở dữ liệu thô của bạn.\nĐiều đó bao gồm dữ liệu người dùng thô (địa chỉ thư điện tử, mật khẩu được băm) cũng như các phiên bản bị xóa và dữ liệu bị hạn chế khác trên wiki.\n\nXem xét đặt cơ sở dữ liệu tại nơi nào khác hẳn, ví dụ trong /var/lib/mediawiki/wiki_cua_ban.", "config-oracle-def-ts": "Không gian bảng mặc định:", "config-oracle-temp-ts": "Không gian bảng tạm:", - "config-type-mysql": "MySQL (hoặc tương hợp)", + "config-type-mysql": "MariaDB, MySQL, hoặc tương hợp", "config-type-mssql": "Microsoft SQL Server", "config-support-info": "MediaWiki hỗ trợ các hệ thống cơ sở dữ liệu sau đây:\n\n$1\n\nNếu bạn không thấy hệ thống cơ sở dữ liệu mà bạn đang muốn sử dụng được liệt kê dưới đây, thì hãy theo chỉ dẫn được liên kết ở trên để kích hoạt tính năng hỗ trợ.", - "config-dbsupport-mysql": "* [{{int:version-db-mysql-url}} MySQL] là mục tiêu chính cho MediaWiki và được hỗ trợ tốt nhất. MediaWiki cũng làm việc với [{{int:version-db-mariadb-url}} MariaDB] và [{{int:version-db-percona-url}} Percona Server], là những cơ sở dữ liệu tương thích với MySQL. ([https://secure.php.net/manual/en/mysqli.installation.php Làm thế nào để biên dịch PHP với sự hỗ trợ của MySQL])", + "config-dbsupport-mysql": "* [{{int:version-db-mariadb-url}} MariaDB] là mục tiêu chính cho MediaWiki và được hỗ trợ tốt nhất. MediaWiki cũng làm việc với [{{int:version-db-mysql-url}} MySQL] và [{{int:version-db-percona-url}} Percona Server], là những cơ sở dữ liệu tương thích với MariaDB. ([https://secure.php.net/manual/en/mysqli.installation.php Làm thế nào để biên dịch PHP với sự hỗ trợ của MySQL])", "config-dbsupport-postgres": "* [{{int:version-db-postgres-url}} PostgreSQL] là một hệ thống cơ sở dữ liệu mã nguồn mở phổ biến như là một thay thế cho MySQL. ([https://secure.php.net/manual/en/pgsql.installation.php Làm thế nào để biên dịch PHP với sự hỗ trợ của PostgreSQL])", "config-dbsupport-sqlite": "* [{{int:version-db-sqlite-url}} SQLite] là một hệ thống cơ sở dữ liệu dung lượng nhẹ được hỗ trợ rất tốt. ([https://secure.php.net/manual/en/pdo.installation.php Làm thế nào để biên dịch PHP với sự hỗ trợ của SQLite], sử dụng PDO)", "config-dbsupport-oracle": "* [{{int:version-db-oracle-url}} Oracle] là một cơ sở dữ liệu doanh nghiệp thương mại. ([https://secure.php.net/manual/en/oci8.installation.php Làm thế nào để biên dịch PHP với sự hỗ trợ của OCI8])", "config-dbsupport-mssql": "* [{{int:version-db-mssql-url}} Microsoft SQL Server] là một cơ sở dữ liệu doanh nghiệp thương mại cho Windows. ([https://secure.php.net/manual/en/sqlsrv.installation.php Làm thế nào để biên dịch PHP với sự hỗ trợ của SQLSRV])", - "config-header-mysql": "Thiết lập MySQL", + "config-header-mysql": "Thiết lập MariaDB/MySQL", "config-header-postgres": "Thiết lập PostgreSQL", "config-header-sqlite": "Thiết lập SQLite", "config-header-oracle": "Thiết lập Oracle", @@ -160,7 +160,7 @@ "config-db-web-create": "Mở tài khoản nếu chưa tồn tại", "config-db-web-no-create-privs": "Tài khoản mà bạn xác định để cài đặt không có đủ quyền để tạo một tài khoản. Tài khoản mà bạn chỉ ra ở đây phải thực sự tồn tại trước đó.", "config-mysql-engine": "Máy lưu trữ:", - "config-mysql-innodb": "InnoDB", + "config-mysql-innodb": "InnoDB (khuyến khích)", "config-mysql-myisam": "MyISAM", "config-mysql-myisam-dep": "Cảnh báo: Bạn đã chọn MyISAM làm động cơ lưu trữ cho MySQL, điều này không được khuyến khích sử dụng với MediaWiki, bởi vì:\n* Nó ít hỗ trợ đồng thời do việc khóa bảng\n* Nó dễ bị lỗi hơn so với các động cơ khác\n* Kho mã nguồn của MediaWiki không phải khi nào cũng xử lý MyISAM như mong muốn\n\nNếu cài đặt MySQL của bạn hỗ trợ InnoDB, đặc biệt khuyến cáo bạn nên chọn để thay thế.\nNếu cài đặt MySQL của bạn không hỗ trợ InnoDB, có lẽ đã đến lúc để nâng cấp.", "config-mysql-only-myisam-dep": "Cảnh báo: MyISAM chỉ là công cụ lưu trữ có sẵn cho MySQL trên máy tính này, và điều này không được khuyến khích sử dụng với MediaWiki, bởi vì:\n* Nó ít hỗ trợ đồng thời do việc khóa khóa\n* Nó là dễ bị hư hỏng hơn các engine khác\n* Codebase MediaWiki không phải khi nào cũng xử lý MyISAM như mong muốn\n\nCài đặt MySQL của bạn không hỗ trợ InnoDB, có lẽ đã đến lúc để nâng cấp.", diff --git a/includes/jobqueue/JobQueueGroup.php b/includes/jobqueue/JobQueueGroup.php index 37c8890cc9..820c492e85 100644 --- a/includes/jobqueue/JobQueueGroup.php +++ b/includes/jobqueue/JobQueueGroup.php @@ -111,7 +111,7 @@ class JobQueueGroup { $conf = $conf + $wgJobTypeConf['default']; } $conf['aggregator'] = JobQueueAggregator::singleton(); - if ( $this->readOnlyReason !== false ) { + if ( !isset( $conf['readOnlyReason'] ) ) { $conf['readOnlyReason'] = $this->readOnlyReason; } diff --git a/includes/jobqueue/JobQueueSecondTestQueue.php b/includes/jobqueue/JobQueueSecondTestQueue.php deleted file mode 100644 index e63f01fc2c..0000000000 --- a/includes/jobqueue/JobQueueSecondTestQueue.php +++ /dev/null @@ -1,290 +0,0 @@ - $params['wiki'], 'type' => $params['type'] ]; - $this->mainQueue = JobQueue::factory( $params['mainqueue'] + $conf ); - $this->debugQueue = JobQueue::factory( $params['debugqueue'] + $conf ); - $this->onlyWriteToDebugQueue = $params['readonly'] ?? false; - - // We need to construct parent after creating the main and debug queue - // because super constructor calls some methods we delegate to the main queue. - parent::__construct( $params ); - } - - /** - * Get the allowed queue orders for configuration validation - * - * @return array Subset of (random, timestamp, fifo, undefined) - */ - protected function supportedOrders() { - return $this->mainQueue->supportedOrders(); - } - - /** - * Get the default queue order to use if configuration does not specify one - * - * @return string One of (random, timestamp, fifo, undefined) - */ - protected function optimalOrder() { - return $this->mainQueue->optimalOrder(); - } - - /** - * Find out if delayed jobs are supported for configuration validation - * - * @return bool Whether delayed jobs are supported - */ - protected function supportsDelayedJobs() { - return $this->mainQueue->supportsDelayedJobs(); - } - - /** - * @see JobQueue::isEmpty() - * @return bool - */ - protected function doIsEmpty() { - return $this->mainQueue->doIsEmpty(); - } - - /** - * @see JobQueue::getSize() - * @return int - */ - protected function doGetSize() { - return $this->mainQueue->doGetSize(); - } - - /** - * @see JobQueue::getAcquiredCount() - * @return int - */ - protected function doGetAcquiredCount() { - return $this->mainQueue->doGetAcquiredCount(); - } - - /** - * @see JobQueue::getDelayedCount() - * @return int - */ - protected function doGetDelayedCount() { - return $this->mainQueue->doGetDelayedCount(); - } - - /** - * @see JobQueue::getAbandonedCount() - * @return int - */ - protected function doGetAbandonedCount() { - return $this->mainQueue->doGetAbandonedCount(); - } - - /** - * @see JobQueue::batchPush() - * @param IJobSpecification[] $jobs - * @param int $flags - */ - protected function doBatchPush( array $jobs, $flags ) { - if ( !$this->onlyWriteToDebugQueue ) { - $this->mainQueue->doBatchPush( $jobs, $flags ); - } - - try { - $this->debugQueue->doBatchPush( $jobs, $flags ); - } catch ( Exception $exception ) { - MWExceptionHandler::logException( $exception ); - } - } - - /** - * @see JobQueue::pop() - * @return Job|bool - */ - protected function doPop() { - return $this->mainQueue->doPop(); - } - - /** - * @see JobQueue::ack() - * @param Job $job - * @return Job|bool - */ - protected function doAck( Job $job ) { - return $this->mainQueue->doAck( $job ); - } - - /** - * @see JobQueue::deduplicateRootJob() - * @param IJobSpecification $job - * @throws MWException - * @return bool - */ - protected function doDeduplicateRootJob( IJobSpecification $job ) { - return $this->mainQueue->doDeduplicateRootJob( $job ); - } - - /** - * @see JobQueue::isRootJobOldDuplicate() - * @param Job $job - * @return bool - */ - protected function doIsRootJobOldDuplicate( Job $job ) { - return $this->mainQueue->doIsRootJobOldDuplicate( $job ); - } - - /** - * @param string $signature Hash identifier of the root job - * @return string - */ - protected function getRootJobCacheKey( $signature ) { - return $this->mainQueue->getRootJobCacheKey( $signature ); - } - - /** - * @see JobQueue::delete() - * @return bool - * @throws MWException - */ - protected function doDelete() { - return $this->mainQueue->doDelete(); - } - - /** - * @see JobQueue::waitForBackups() - * @return void - */ - protected function doWaitForBackups() { - $this->mainQueue->doWaitForBackups(); - } - - /** - * @see JobQueue::flushCaches() - * @return void - */ - protected function doFlushCaches() { - $this->mainQueue->doFlushCaches(); - } - - /** - * Get an iterator to traverse over all available jobs in this queue. - * This does not include jobs that are currently acquired or delayed. - * Note: results may be stale if the queue is concurrently modified. - * - * @return Iterator - * @throws JobQueueError - */ - public function getAllQueuedJobs() { - return $this->mainQueue->getAllQueuedJobs(); - } - - /** - * Get an iterator to traverse over all delayed jobs in this queue. - * Note: results may be stale if the queue is concurrently modified. - * - * @return Iterator - * @throws JobQueueError - * @since 1.22 - */ - public function getAllDelayedJobs() { - return $this->mainQueue->getAllDelayedJobs(); - } - - /** - * Get an iterator to traverse over all claimed jobs in this queue - * - * Callers should be quick to iterator over it or few results - * will be returned due to jobs being acknowledged and deleted - * - * @return Iterator - * @throws JobQueueError - * @since 1.26 - */ - public function getAllAcquiredJobs() { - return $this->mainQueue->getAllAcquiredJobs(); - } - - /** - * Get an iterator to traverse over all abandoned jobs in this queue - * - * @return Iterator - * @throws JobQueueError - * @since 1.25 - */ - public function getAllAbandonedJobs() { - return $this->mainQueue->getAllAbandonedJobs(); - } - - /** - * Do not use this function outside of JobQueue/JobQueueGroup - * - * @return string - * @since 1.22 - */ - public function getCoalesceLocationInternal() { - return $this->mainQueue->getCoalesceLocationInternal(); - } - - /** - * @see JobQueue::getSiblingQueuesWithJobs() - * @param array $types List of queues types - * @return array|null (list of queue types) or null if unsupported - */ - protected function doGetSiblingQueuesWithJobs( array $types ) { - return $this->mainQueue->doGetSiblingQueuesWithJobs( $types ); - } - - /** - * @see JobQueue::getSiblingQueuesSize() - * @param array $types List of queues types - * @return array|null (list of queue types) or null if unsupported - */ - protected function doGetSiblingQueueSizes( array $types ) { - return $this->mainQueue->doGetSiblingQueueSizes( $types ); - } - - /** - * @throws JobQueueReadOnlyError - */ - protected function assertNotReadOnly() { - $this->mainQueue->assertNotReadOnly(); - } -} diff --git a/includes/libs/CSSMin.php b/includes/libs/CSSMin.php index 74e8b54e2a..92a4f9e6f4 100644 --- a/includes/libs/CSSMin.php +++ b/includes/libs/CSSMin.php @@ -72,15 +72,24 @@ class CSSMin { $url = $match['file'][0]; // Skip fully-qualified and protocol-relative URLs and data URIs - // Also skips the rare `behavior` property specifying application's default behavior if ( substr( $url, 0, 2 ) === '//' || - parse_url( $url, PHP_URL_SCHEME ) || - substr( $url, 0, 9 ) === '#default#' + parse_url( $url, PHP_URL_SCHEME ) ) { break; } + // Strip trailing anchors - T115436 + $anchor = strpos( $url, '#' ); + if ( $anchor !== false ) { + $url = substr( $url, 0, $anchor ); + + // '#some-anchors' is not a file + if ( $url === '' ) { + break; + } + } + $files[] = $path . $url; } } @@ -485,11 +494,11 @@ class CSSMin { // Pass thru fully-qualified and protocol-relative URLs and data URIs, as well as local URLs if // we can't expand them. - // Also skips the rare `behavior` property specifying application's default behavior + // Also skips anchors or the rare `behavior` property specifying application's default behavior if ( self::isRemoteUrl( $url ) || self::isLocalUrl( $url ) || - substr( $url, 0, 9 ) === '#default#' + substr( $url, 0, 1 ) === '#' ) { return $url; } diff --git a/includes/libs/MapCacheLRU.php b/includes/libs/MapCacheLRU.php index e891c9ed13..ad5e58d808 100644 --- a/includes/libs/MapCacheLRU.php +++ b/includes/libs/MapCacheLRU.php @@ -135,7 +135,7 @@ class MapCacheLRU implements IExpiringStore, Serializable { * Check if a key exists * * @param string $key - * @param float $maxAge Ignore items older than this many seconds (since 1.32) + * @param float $maxAge Ignore items older than this many seconds [optional] (since 1.32) * @return bool */ public function has( $key, $maxAge = 0.0 ) { @@ -157,10 +157,11 @@ class MapCacheLRU implements IExpiringStore, Serializable { * If the item is already set, it will be pushed to the top of the cache. * * @param string $key - * @return mixed Returns null if the key was not found + * @param float $maxAge Ignore items older than this many seconds [optional] (since 1.32) + * @return mixed Returns null if the key was not found or is older than $maxAge */ - public function get( $key ) { - if ( !$this->has( $key ) ) { + public function get( $key, $maxAge = 0.0 ) { + if ( !$this->has( $key, $maxAge ) ) { return null; } @@ -193,7 +194,7 @@ class MapCacheLRU implements IExpiringStore, Serializable { /** * @param string|int $key * @param string|int $field - * @param float $maxAge + * @param float $maxAge Ignore items older than this many seconds [optional] (since 1.32) * @return bool */ public function hasField( $key, $field, $maxAge = 0.0 ) { @@ -205,8 +206,18 @@ class MapCacheLRU implements IExpiringStore, Serializable { return ( $maxAge <= 0 || $this->getAge( $key, $field ) <= $maxAge ); } - public function getField( $key, $field ) { - return $this->get( $key )[$field] ?? null; + /** + * @param string|int $key + * @param string|int $field + * @param float $maxAge Ignore items older than this many seconds [optional] (since 1.32) + * @return mixed Returns null if the key was not found or is older than $maxAge + */ + public function getField( $key, $field, $maxAge = 0.0 ) { + if ( !$this->hasField( $key, $field, $maxAge ) ) { + return null; + } + + return $this->cache[$key][$field]; } /** diff --git a/includes/libs/MultiHttpClient.php b/includes/libs/MultiHttpClient.php index 20ddf723f9..36f49e0e6b 100644 --- a/includes/libs/MultiHttpClient.php +++ b/includes/libs/MultiHttpClient.php @@ -23,9 +23,13 @@ use Psr\Log\LoggerAwareInterface; use Psr\Log\LoggerInterface; use Psr\Log\NullLogger; +use MediaWiki\MediaWikiServices; /** - * Class to handle concurrent HTTP requests + * Class to handle multiple HTTP requests + * + * If curl is available, requests will be made concurrently. + * Otherwise, they will be made serially. * * HTTP request maps are arrays that use the following format: * - method : GET/HEAD/PUT/POST/DELETE @@ -78,6 +82,8 @@ class MultiHttpClient implements LoggerAwareInterface { * - usePipelining : whether to use HTTP pipelining if possible (for all hosts) * - maxConnsPerHost : maximum number of concurrent connections (per host) * - userAgent : The User-Agent header value to send + * - logger : a \Psr\Log\LoggerInterface instance for debug logging + * - caBundlePath : path to specific Certificate Authority bundle (if any) * @throws Exception */ public function __construct( array $options ) { @@ -105,11 +111,11 @@ class MultiHttpClient implements LoggerAwareInterface { * Execute an HTTP(S) request * * This method returns a response map of: - * - code : HTTP response code or 0 if there was a serious cURL error - * - reason : HTTP response reason (empty if there was a serious cURL error) + * - code : HTTP response code or 0 if there was a serious error + * - reason : HTTP response reason (empty if there was a serious error) * - headers :
* - body : HTTP response body or resource (if "stream" was set) - * - error : Any cURL error string + * - error : Any error string * The map also stores integer-indexed copies of these values. This lets callers do: * @code * list( $rcode, $rdesc, $rhdrs, $rbody, $rerr ) = $http->run( $req ); @@ -125,14 +131,17 @@ class MultiHttpClient implements LoggerAwareInterface { } /** - * Execute a set of HTTP(S) requests concurrently + * Execute a set of HTTP(S) requests. + * + * If curl is available, requests will be made concurrently. + * Otherwise, they will be made serially. * * The maps are returned by this method with the 'response' field set to a map of: - * - code : HTTP response code or 0 if there was a serious cURL error - * - reason : HTTP response reason (empty if there was a serious cURL error) + * - code : HTTP response code or 0 if there was a serious error + * - reason : HTTP response reason (empty if there was a serious error) * - headers :
* - body : HTTP response body or resource (if "stream" was set) - * - error : Any cURL error string + * - error : Any error string * The map also stores integer-indexed copies of these values. This lets callers do: * @code * list( $rcode, $rdesc, $rhdrs, $rbody, $rerr ) = $req['response']; @@ -151,47 +160,45 @@ class MultiHttpClient implements LoggerAwareInterface { * @throws Exception */ public function runMulti( array $reqs, array $opts = [] ) { + $this->normalizeRequests( $reqs ); + if ( $this->isCurlEnabled() ) { + return $this->runMultiCurl( $reqs, $opts ); + } else { + return $this->runMultiHttp( $reqs, $opts ); + } + } + + /** + * Determines if the curl extension is available + * + * @return bool true if curl is available, false otherwise. + */ + protected function isCurlEnabled() { + return extension_loaded( 'curl' ); + } + + /** + * Execute a set of HTTP(S) requests concurrently + * + * @see MultiHttpClient::runMulti() + * + * @param array $reqs Map of HTTP request arrays + * @param array $opts + * - connTimeout : connection timeout per request (seconds) + * - reqTimeout : post-connection timeout per request (seconds) + * - usePipelining : whether to use HTTP pipelining if possible + * - maxConnsPerHost : maximum number of concurrent connections (per host) + * @return array $reqs With response array populated for each + * @throws Exception + */ + private function runMultiCurl( array $reqs, array $opts = [] ) { $chm = $this->getCurlMulti(); $selectTimeout = $this->getSelectTimeout( $opts ); - // Normalize $reqs and add all of the required cURL handles... + // Add all of the required cURL handles... $handles = []; foreach ( $reqs as $index => &$req ) { - $req['response'] = [ - 'code' => 0, - 'reason' => '', - 'headers' => [], - 'body' => '', - 'error' => '' - ]; - if ( isset( $req[0] ) ) { - $req['method'] = $req[0]; // short-form - unset( $req[0] ); - } - if ( isset( $req[1] ) ) { - $req['url'] = $req[1]; // short-form - unset( $req[1] ); - } - if ( !isset( $req['method'] ) ) { - throw new Exception( "Request has no 'method' field set." ); - } elseif ( !isset( $req['url'] ) ) { - throw new Exception( "Request has no 'url' field set." ); - } - $this->logger->debug( "{$req['method']}: {$req['url']}" ); - $req['query'] = $req['query'] ?? []; - $headers = []; // normalized headers - if ( isset( $req['headers'] ) ) { - foreach ( $req['headers'] as $name => $value ) { - $headers[strtolower( $name )] = $value; - } - } - $req['headers'] = $headers; - if ( !isset( $req['body'] ) ) { - $req['body'] = ''; - $req['headers']['content-length'] = 0; - } - $req['flags'] = $req['flags'] ?? []; $handles[$index] = $this->getCurlHandle( $req, $opts ); if ( count( $reqs ) > 1 ) { // https://github.com/guzzle/guzzle/issues/349 @@ -391,7 +398,13 @@ class MultiHttpClient implements LoggerAwareInterface { return $length; } list( $name, $value ) = explode( ":", $header, 2 ); - $req['response']['headers'][strtolower( $name )] = trim( $value ); + $name = strtolower( $name ); + $value = trim( $value ); + if ( isset( $req['response']['headers'][$name] ) ) { + $req['response']['headers'][$name] .= ', ' . $value; + } else { + $req['response']['headers'][$name] = $value; + } return $length; } ); @@ -417,6 +430,148 @@ class MultiHttpClient implements LoggerAwareInterface { return $ch; } + /** + * @return resource + * @throws Exception + */ + protected function getCurlMulti() { + if ( !$this->multiHandle ) { + if ( !function_exists( 'curl_multi_init' ) ) { + throw new Exception( "PHP cURL function curl_multi_init missing. " . + "Check https://www.mediawiki.org/wiki/Manual:CURL" ); + } + $cmh = curl_multi_init(); + curl_multi_setopt( $cmh, CURLMOPT_PIPELINING, (int)$this->usePipelining ); + curl_multi_setopt( $cmh, CURLMOPT_MAXCONNECTS, (int)$this->maxConnsPerHost ); + $this->multiHandle = $cmh; + } + return $this->multiHandle; + } + + /** + * Execute a set of HTTP(S) requests sequentially. + * + * @see MultiHttpClient::runMulti() + * @todo Remove dependency on MediaWikiServices: use a separate HTTP client + * library or copy code from PhpHttpRequest + * @param array $reqs Map of HTTP request arrays + * @param array $opts + * - connTimeout : connection timeout per request (seconds) + * - reqTimeout : post-connection timeout per request (seconds) + * @return array $reqs With response array populated for each + * @throws Exception + */ + private function runMultiHttp( array $reqs, array $opts = [] ) { + $httpOptions = [ + 'timeout' => $opts['reqTimeout'] ?? $this->reqTimeout, + 'connectTimeout' => $opts['connTimeout'] ?? $this->connTimeout, + 'logger' => $this->logger, + 'caInfo' => $this->caBundlePath, + ]; + foreach ( $reqs as &$req ) { + $reqOptions = $httpOptions + [ + 'method' => $req['method'], + 'proxy' => $req['proxy'] ?? $this->proxy, + 'userAgent' => $req['headers']['user-agent'] ?? $this->userAgent, + 'postData' => $req['body'], + ]; + + $url = $req['url']; + $query = http_build_query( $req['query'], '', '&', PHP_QUERY_RFC3986 ); + if ( $query != '' ) { + $url .= strpos( $req['url'], '?' ) === false ? "?$query" : "&$query"; + } + + $httpRequest = MediaWikiServices::getInstance()->getHttpRequestFactory()->create( + $url, $reqOptions ); + $sv = $httpRequest->execute()->getStatusValue(); + + $respHeaders = array_map( + function ( $v ) { + return implode( ', ', $v ); + }, + $httpRequest->getResponseHeaders() ); + + $req['response'] = [ + 'code' => $httpRequest->getStatus(), + 'reason' => '', + 'headers' => $respHeaders, + 'body' => $httpRequest->getContent(), + 'error' => '', + ]; + + if ( !$sv->isOk() ) { + $svErrors = $sv->getErrors(); + if ( isset( $svErrors[0] ) ) { + $req['response']['error'] = $svErrors[0]['message']; + + // param values vary per failure type (ex. unknown host vs unknown page) + if ( isset( $svErrors[0]['params'][0] ) ) { + if ( is_numeric( $svErrors[0]['params'][0] ) ) { + if ( isset( $svErrors[0]['params'][1] ) ) { + $req['response']['reason'] = $svErrors[0]['params'][1]; + } + } else { + $req['response']['reason'] = $svErrors[0]['params'][0]; + } + } + } + } + + $req['response'][0] = $req['response']['code']; + $req['response'][1] = $req['response']['reason']; + $req['response'][2] = $req['response']['headers']; + $req['response'][3] = $req['response']['body']; + $req['response'][4] = $req['response']['error']; + } + + return $reqs; + } + + /** + * Normalize request information + * + * @param array $reqs the requests to normalize + */ + private function normalizeRequests( array &$reqs ) { + foreach ( $reqs as &$req ) { + $req['response'] = [ + 'code' => 0, + 'reason' => '', + 'headers' => [], + 'body' => '', + 'error' => '' + ]; + if ( isset( $req[0] ) ) { + $req['method'] = $req[0]; // short-form + unset( $req[0] ); + } + if ( isset( $req[1] ) ) { + $req['url'] = $req[1]; // short-form + unset( $req[1] ); + } + if ( !isset( $req['method'] ) ) { + throw new Exception( "Request has no 'method' field set." ); + } elseif ( !isset( $req['url'] ) ) { + throw new Exception( "Request has no 'url' field set." ); + } + $this->logger->debug( "{$req['method']}: {$req['url']}" ); + $req['query'] = $req['query'] ?? []; + $headers = []; // normalized headers + if ( isset( $req['headers'] ) ) { + foreach ( $req['headers'] as $name => $value ) { + $headers[strtolower( $name )] = $value; + } + } + $req['headers'] = $headers; + if ( !isset( $req['body'] ) ) { + $req['body'] = ''; + $req['headers']['content-length'] = 0; + } + $req['flags'] = $req['flags'] ?? []; + } + } + /** * Get a suitable select timeout for the given options. * @@ -439,24 +594,6 @@ class MultiHttpClient implements LoggerAwareInterface { return $selectTimeout; } - /** - * @return resource - * @throws Exception - */ - protected function getCurlMulti() { - if ( !$this->multiHandle ) { - if ( !function_exists( 'curl_multi_init' ) ) { - throw new Exception( "PHP cURL extension missing. " . - "Check https://www.mediawiki.org/wiki/Manual:CURL" ); - } - $cmh = curl_multi_init(); - curl_multi_setopt( $cmh, CURLMOPT_PIPELINING, (int)$this->usePipelining ); - curl_multi_setopt( $cmh, CURLMOPT_MAXCONNECTS, (int)$this->maxConnsPerHost ); - $this->multiHandle = $cmh; - } - return $this->multiHandle; - } - /** * Register a logger * diff --git a/includes/libs/lockmanager/MemcLockManager.php b/includes/libs/lockmanager/MemcLockManager.php index f1f749faa0..7f5f003df9 100644 --- a/includes/libs/lockmanager/MemcLockManager.php +++ b/includes/libs/lockmanager/MemcLockManager.php @@ -46,7 +46,7 @@ class MemcLockManager extends QuorumLockManager { /** @var MemcachedBagOStuff[] Map of (server name => MemcachedBagOStuff) */ protected $cacheServers = []; - /** @var HashBagOStuff Server status cache */ + /** @var MapCacheLRU Server status cache */ protected $statusCache; /** @@ -81,7 +81,7 @@ class MemcLockManager extends QuorumLockManager { $this->cacheServers[$name] = new $class( $params ); } - $this->statusCache = new HashBagOStuff(); + $this->statusCache = new MapCacheLRU( 100 ); } protected function getLocksOnServer( $lockSrv, array $pathsByType ) { @@ -252,13 +252,13 @@ class MemcLockManager extends QuorumLockManager { throw new InvalidArgumentException( "Invalid cache server '$lockSrv'." ); } - $online = $this->statusCache->get( "online:$lockSrv" ); - if ( $online === false ) { + $online = $this->statusCache->get( "online:$lockSrv", 30 ); + if ( $online === null ) { $online = $this->cacheServers[$lockSrv]->set( __CLASS__ . ':ping', 1, 1 ); if ( !$online ) { // server down? $this->logger->warning( __METHOD__ . ": Could not contact $lockSrv." ); } - $this->statusCache->set( "online:$lockSrv", (int)$online, 30 ); + $this->statusCache->set( "online:$lockSrv", (int)$online ); } return $online ? $this->cacheServers[$lockSrv] : null; diff --git a/includes/libs/objectcache/BagOStuff.php b/includes/libs/objectcache/BagOStuff.php index 782f4c618e..e03645f02b 100644 --- a/includes/libs/objectcache/BagOStuff.php +++ b/includes/libs/objectcache/BagOStuff.php @@ -133,7 +133,7 @@ abstract class BagOStuff implements IExpiringStore, LoggerAwareInterface { /** * @param LoggerInterface $logger - * @return null + * @return void */ public function setLogger( LoggerInterface $logger ) { $this->logger = $logger; @@ -308,6 +308,11 @@ abstract class BagOStuff implements IExpiringStore, LoggerAwareInterface { $this->reportDupes = $reportDupes; if ( $this->getLastError() ) { + $this->logger->warning( + __METHOD__ . ' failed due to I/O error on get() for {key}.', + [ 'key' => $key ] + ); + return false; // don't spam retries (retry only on races) } @@ -325,6 +330,11 @@ abstract class BagOStuff implements IExpiringStore, LoggerAwareInterface { $success = $this->cas( $casToken, $key, $value, $exptime ); } if ( $this->getLastError() ) { + $this->logger->warning( + __METHOD__ . ' failed due to I/O error for {key}.', + [ 'key' => $key ] + ); + return false; // IO error; don't spam retries } } while ( !$success && --$attempts ); @@ -352,6 +362,11 @@ abstract class BagOStuff implements IExpiringStore, LoggerAwareInterface { if ( $casToken === $curCasToken ) { $success = $this->set( $key, $value, $exptime ); } else { + $this->logger->info( + __METHOD__ . ' failed due to race condition for {key}.', + [ 'key' => $key ] + ); + $success = false; // mismatched or failed } @@ -388,6 +403,11 @@ abstract class BagOStuff implements IExpiringStore, LoggerAwareInterface { $this->reportDupes = $reportDupes; if ( $this->getLastError() ) { + $this->logger->warning( + __METHOD__ . ' failed due to I/O error on get() for {key}.', + [ 'key' => $key ] + ); + $success = false; } else { // Derive the new value from the old value @@ -443,13 +463,19 @@ abstract class BagOStuff implements IExpiringStore, LoggerAwareInterface { } } + $fname = __METHOD__; $expiry = min( $expiry ?: INF, self::TTL_DAY ); $loop = new WaitConditionLoop( - function () use ( $key, $timeout, $expiry ) { + function () use ( $key, $timeout, $expiry, $fname ) { $this->clearLastError(); if ( $this->add( "{$key}:lock", 1, $expiry ) ) { return true; // locked! } elseif ( $this->getLastError() ) { + $this->logger->warning( + $fname . ' failed due to I/O error for {key}.', + [ 'key' => $key ] + ); + return WaitConditionLoop::CONDITION_ABORTED; // network partition? } @@ -458,9 +484,15 @@ abstract class BagOStuff implements IExpiringStore, LoggerAwareInterface { $timeout ); - $locked = ( $loop->invoke() === $loop::CONDITION_REACHED ); + $code = $loop->invoke(); + $locked = ( $code === $loop::CONDITION_REACHED ); if ( $locked ) { $this->locks[$key] = [ 'class' => $rclass, 'depth' => 1 ]; + } elseif ( $code === $loop::CONDITION_TIMED_OUT ) { + $this->logger->warning( + "$fname failed due to timeout for {key}.", + [ 'key' => $key, 'timeout' => $timeout ] + ); } return $locked; @@ -476,7 +508,15 @@ abstract class BagOStuff implements IExpiringStore, LoggerAwareInterface { if ( isset( $this->locks[$key] ) && --$this->locks[$key]['depth'] <= 0 ) { unset( $this->locks[$key] ); - return $this->delete( "{$key}:lock" ); + $ok = $this->delete( "{$key}:lock" ); + if ( !$ok ) { + $this->logger->warning( + __METHOD__ . ' failed to release lock for {key}.', + [ 'key' => $key ] + ); + } + + return $ok; } return true; @@ -511,7 +551,10 @@ abstract class BagOStuff implements IExpiringStore, LoggerAwareInterface { $latency = 0.050; // latency skew (err towards keeping lock present) $age = ( $this->getCurrentTime() - $lSince + $latency ); if ( ( $age + $latency ) >= $expiry ) { - $this->logger->warning( "Lock for $key held too long ($age sec)." ); + $this->logger->warning( + "Lock for {key} held too long ({age} sec).", + [ 'key' => $key, 'age' => $age ] + ); return; // expired; it's not "safe" to delete the key } $this->unlock( $key ); @@ -573,6 +616,7 @@ abstract class BagOStuff implements IExpiringStore, LoggerAwareInterface { * @return bool Success */ public function add( $key, $value, $exptime = 0 ) { + // @note: avoid lock() here since that method uses *this* method by default if ( $this->get( $key ) === false ) { return $this->set( $key, $value, $exptime ); } @@ -586,7 +630,7 @@ abstract class BagOStuff implements IExpiringStore, LoggerAwareInterface { * @return int|bool New value or false on failure */ public function incr( $key, $value = 1 ) { - if ( !$this->lock( $key ) ) { + if ( !$this->lock( $key, 1 ) ) { return false; } $n = $this->get( $key ); @@ -624,14 +668,15 @@ abstract class BagOStuff implements IExpiringStore, LoggerAwareInterface { * @since 1.24 */ public function incrWithInit( $key, $ttl, $value = 1, $init = 1 ) { + $this->clearLastError(); $newValue = $this->incr( $key, $value ); - if ( $newValue === false ) { + if ( $newValue === false && !$this->getLastError() ) { // No key set; initialize $newValue = $this->add( $key, (int)$init, $ttl ) ? $init : false; - } - if ( $newValue === false ) { - // Raced out initializing; increment - $newValue = $this->incr( $key, $value ); + if ( $newValue === false && !$this->getLastError() ) { + // Raced out initializing; increment + $newValue = $this->incr( $key, $value ); + } } return $newValue; diff --git a/includes/libs/objectcache/MultiWriteBagOStuff.php b/includes/libs/objectcache/MultiWriteBagOStuff.php index 91f4167e32..043f8cbbe2 100644 --- a/includes/libs/objectcache/MultiWriteBagOStuff.php +++ b/includes/libs/objectcache/MultiWriteBagOStuff.php @@ -122,7 +122,7 @@ class MultiWriteBagOStuff extends BagOStuff { && $missIndexes && ( $flags & self::READ_VERIFIED ) == self::READ_VERIFIED ) { - // Backfill the value to the lower (and often larger) cache tiers + // Backfill the value to the higher (and often faster/smaller) cache tiers $this->doWrite( $missIndexes, $this->asyncWrites, 'set', $key, $value, self::UPGRADE_TTL ); @@ -171,6 +171,23 @@ class MultiWriteBagOStuff extends BagOStuff { return $this->doWrite( $this->cacheIndexes, $this->asyncWrites, 'decr', $key, $value ); } + public function merge( $key, callable $callback, $exptime = 0, $attempts = 10, $flags = 0 ) { + $asyncWrites = ( ( $flags & self::WRITE_SYNC ) == self::WRITE_SYNC ) + ? false + : $this->asyncWrites; + + return $this->doWrite( + $this->cacheIndexes, + $asyncWrites, + 'merge', + $key, + $callback, + $exptime, + $attempts, + $flags + ); + } + public function lock( $key, $timeout = 6, $expiry = 6, $rclass = '' ) { // Only need to lock the first cache; also avoids deadlocks return $this->caches[0]->lock( $key, $timeout, $expiry, $rclass ); @@ -202,7 +219,7 @@ class MultiWriteBagOStuff extends BagOStuff { $ret = true; $args = array_slice( func_get_args(), 3 ); - if ( array_diff( $indexes, [ 0 ] ) && $asyncWrites ) { + if ( array_diff( $indexes, [ 0 ] ) && $asyncWrites && $method !== 'merge' ) { // Deep-clone $args to prevent misbehavior when something writes an // object to the BagOStuff then modifies it afterwards, e.g. T168040. $args = unserialize( serialize( $args ) ); diff --git a/includes/libs/objectcache/WANObjectCache.php b/includes/libs/objectcache/WANObjectCache.php index e30e061815..2989c81c04 100644 --- a/includes/libs/objectcache/WANObjectCache.php +++ b/includes/libs/objectcache/WANObjectCache.php @@ -87,7 +87,7 @@ use Psr\Log\NullLogger; class WANObjectCache implements IExpiringStore, LoggerAwareInterface { /** @var BagOStuff The local datacenter cache */ protected $cache; - /** @var HashBagOStuff[] Map of group PHP instance caches */ + /** @var MapCacheLRU[] Map of group PHP instance caches */ protected $processCaches = []; /** @var string Purge channel name */ protected $purgeChannel; @@ -1061,7 +1061,7 @@ class WANObjectCache implements IExpiringStore, LoggerAwareInterface { if ( $pcTTL >= 0 && $this->callbackDepth == 0 ) { $group = $opts['pcGroup'] ?? self::PC_PRIMARY; $procCache = $this->getProcessCache( $group ); - $value = $procCache->get( $key ); + $value = $procCache->has( $key, $pcTTL ) ? $procCache->get( $key ) : false; } else { $procCache = false; $value = false; @@ -1117,7 +1117,7 @@ class WANObjectCache implements IExpiringStore, LoggerAwareInterface { // Update the process cache if enabled if ( $procCache && $value !== false ) { - $procCache->set( $key, $value, $pcTTL ); + $procCache->set( $key, $value ); } } @@ -1385,10 +1385,11 @@ class WANObjectCache implements IExpiringStore, LoggerAwareInterface { ) { $valueKeys = array_keys( $keyedIds->getArrayCopy() ); $checkKeys = $opts['checkKeys'] ?? []; + $pcTTL = $opts['pcTTL'] ?? self::TTL_UNCACHEABLE; // Load required keys into process cache in one go $this->warmupCache = $this->getRawKeysForWarmup( - $this->getNonProcessCachedKeys( $valueKeys, $opts ), + $this->getNonProcessCachedKeys( $valueKeys, $opts, $pcTTL ), $checkKeys ); $this->warmupKeyMisses = 0; @@ -1480,11 +1481,12 @@ class WANObjectCache implements IExpiringStore, LoggerAwareInterface { $idsByValueKey = $keyedIds->getArrayCopy(); $valueKeys = array_keys( $idsByValueKey ); $checkKeys = $opts['checkKeys'] ?? []; + $pcTTL = $opts['pcTTL'] ?? self::TTL_UNCACHEABLE; unset( $opts['lockTSE'] ); // incompatible unset( $opts['busyValue'] ); // incompatible // Load required keys into process cache in one go - $keysGet = $this->getNonProcessCachedKeys( $valueKeys, $opts ); + $keysGet = $this->getNonProcessCachedKeys( $valueKeys, $opts, $pcTTL ); $this->warmupCache = $this->getRawKeysForWarmup( $keysGet, $checkKeys ); $this->warmupKeyMisses = 0; @@ -2103,12 +2105,12 @@ class WANObjectCache implements IExpiringStore, LoggerAwareInterface { /** * @param string $group - * @return HashBagOStuff + * @return MapCacheLRU */ protected function getProcessCache( $group ) { if ( !isset( $this->processCaches[$group] ) ) { list( , $n ) = explode( ':', $group ); - $this->processCaches[$group] = new HashBagOStuff( [ 'maxKeys' => (int)$n ] ); + $this->processCaches[$group] = new MapCacheLRU( (int)$n ); } return $this->processCaches[$group]; @@ -2117,15 +2119,16 @@ class WANObjectCache implements IExpiringStore, LoggerAwareInterface { /** * @param array $keys * @param array $opts + * @param int $pcTTL * @return array List of keys */ - private function getNonProcessCachedKeys( array $keys, array $opts ) { + private function getNonProcessCachedKeys( array $keys, array $opts, $pcTTL ) { $keysFound = []; if ( isset( $opts['pcTTL'] ) && $opts['pcTTL'] > 0 && $this->callbackDepth == 0 ) { $pcGroup = $opts['pcGroup'] ?? self::PC_PRIMARY; $procCache = $this->getProcessCache( $pcGroup ); foreach ( $keys as $key ) { - if ( $procCache->get( $key ) !== false ) { + if ( $procCache->has( $key, $pcTTL ) ) { $keysFound[] = $key; } } diff --git a/includes/libs/rdbms/database/Database.php b/includes/libs/rdbms/database/Database.php index d11b51b0fd..dc3260d4d4 100644 --- a/includes/libs/rdbms/database/Database.php +++ b/includes/libs/rdbms/database/Database.php @@ -3844,9 +3844,11 @@ abstract class Database implements IDatabase, IMaintainableDatabase, LoggerAware $this->assertOpen(); $this->runOnTransactionPreCommitCallbacks(); + $writeTime = $this->pendingWriteQueryDuration( self::ESTIMATE_DB_APPLY ); $this->doCommit( $fname ); $this->trxStatus = self::STATUS_TRX_NONE; + if ( $this->trxDoneWrites ) { $this->lastWriteTime = microtime( true ); $this->trxProfiler->transactionWritingOut( @@ -3894,14 +3896,18 @@ abstract class Database implements IDatabase, IMaintainableDatabase, LoggerAware // Avoid fatals if close() was called $this->assertOpen(); + $writeTime = $this->pendingWriteQueryDuration( self::ESTIMATE_DB_APPLY ); $this->doRollback( $fname ); $this->trxStatus = self::STATUS_TRX_NONE; $this->trxAtomicLevels = []; + if ( $this->trxDoneWrites ) { $this->trxProfiler->transactionWritingOut( $this->server, $this->dbName, - $this->trxShortId + $this->trxShortId, + $writeTime, + $this->trxWriteAffectedRows ); } } diff --git a/includes/logging/LogEventsList.php b/includes/logging/LogEventsList.php index a7620fedd6..db973640b1 100644 --- a/includes/logging/LogEventsList.php +++ b/includes/logging/LogEventsList.php @@ -110,8 +110,6 @@ class LogEventsList extends ContextSource { public function showOptions( $types = [], $user = '', $page = '', $pattern = false, $year = 0, $month = 0, $day = 0, $filter = null, $tagFilter = '', $action = null ) { - $title = SpecialPage::getTitleFor( 'Log' ); - // For B/C, we take strings, but make sure they are converted... $types = ( $types === '' ) ? [] : (array)$types; @@ -120,7 +118,7 @@ class LogEventsList extends ContextSource { // Basic selectors $formDescriptor['type'] = $this->getTypeMenuDesc( $types ); $formDescriptor['user'] = $this->getUserInputDesc( $user ); - $formDescriptor['page'] = $this->getTitleInputDesc( $title ); + $formDescriptor['page'] = $this->getTitleInputDesc( $page ); // Add extra inputs if any // This could either be a form descriptor array or a string with raw HTML. @@ -170,9 +168,12 @@ class LogEventsList extends ContextSource { $formDescriptor['subtype'] = $this->getActionSelectorDesc( $types, $action ); } - $htmlForm = new HTMLForm( $formDescriptor, $this->getContext() ); + $context = new DerivativeContext( $this->getContext() ); + $context->setTitle( SpecialPage::getTitleFor( 'Log' ) ); // Remove subpage + $htmlForm = new HTMLForm( $formDescriptor, $context ); $htmlForm ->setSubmitText( $this->msg( 'logeventslist-submit' )->text() ) + ->setMethod( 'get' ) ->setWrapperLegendMsg( 'log' ); // TODO This will should be removed at some point. See T199495. @@ -195,9 +196,14 @@ class LogEventsList extends ContextSource { $options = []; $default = []; foreach ( $filter as $type => $val ) { - $options[ $this->msg( "logeventslist-{$type}-log" )->text() ] = $type; + $message = $this->msg( "logeventslist-{$type}-log" ); + // FIXME: Remove this check once T199657 is fully resolved. + if ( !$message->exists() ) { + $message = $this->msg( "log-show-hide-{$type}" )->params( $this->msg( 'show' )->text() ); + } + $options[ $message->text() ] = $type; - if ( $val === 0 ) { + if ( $val === false ) { $default[] = $type; } } @@ -279,7 +285,6 @@ class LogEventsList extends ContextSource { 'class' => 'HTMLTitleTextField', 'label-message' => 'speciallogtitlelabel', 'name' => 'page', - 'value' => $title, 'required' => false ]; } @@ -303,16 +308,10 @@ class LogEventsList extends ContextSource { private function getExtraInputsDesc( $types ) { if ( count( $types ) == 1 ) { if ( $types[0] == 'suppress' ) { - $offender = $this->getRequest()->getVal( 'offender' ); - $user = User::newFromName( $offender, false ); - if ( !$user || ( $user->getId() == 0 && !IP::isIPAddress( $offender ) ) ) { - $offender = ''; // Blank field if invalid - } return [ 'type' => 'text', 'label-message' => 'revdelete-offender', 'name' => 'offender', - 'value' => $offender, ]; } else { // Allow extensions to add their own extra inputs @@ -424,7 +423,10 @@ class LogEventsList extends ContextSource { // Let extensions add data Hooks::run( 'LogEventsListLineEnding', [ $this, &$ret, $entry, &$classes, &$attribs ] ); - $attribs = wfArrayFilterByKey( $attribs, [ Sanitizer::class, 'isReservedDataAttribute' ] ); + $attribs = array_filter( $attribs, + [ Sanitizer::class, 'isReservedDataAttribute' ], + ARRAY_FILTER_USE_KEY + ); $attribs['class'] = implode( ' ', $classes ); return Html::rawElement( 'li', $attribs, $ret ) . "\n"; diff --git a/includes/logging/LogPager.php b/includes/logging/LogPager.php index 2efb462b90..e7096c460a 100644 --- a/includes/logging/LogPager.php +++ b/includes/logging/LogPager.php @@ -107,12 +107,17 @@ class LogPager extends ReverseChronologicalPager { return $filters; } - $request_filters = $this->getRequest()->getArray( "wpfilters" ); - $request_filters = $request_filters === null ? [] : $request_filters; + $wpfilters = $this->getRequest()->getArray( "wpfilters" ); + $request_filters = $wpfilters === null ? [] : $wpfilters; foreach ( $wgFilterLogTypes as $type => $default ) { $hide = !in_array( $type, $request_filters ); + // Back-compat: Check old URL params if the new param wasn't passed + if ( $wpfilters === null ) { + $hide = $this->getRequest()->getBool( "hide_{$type}_log", $default ); + } + $filters[$type] = $hide; if ( $hide ) { $this->mConds[] = 'log_type != ' . $this->mDb->addQuotes( $type ); diff --git a/includes/page/PageArchive.php b/includes/page/PageArchive.php index aa34dd24c2..dfc7c02f05 100644 --- a/includes/page/PageArchive.php +++ b/includes/page/PageArchive.php @@ -767,7 +767,7 @@ class PageArchive { 0, $this->title, [ - 'page' => $pageId, + 'page_id' => $pageId, 'deleted' => $unsuppress ? 0 : $row->ar_deleted ] ); diff --git a/includes/page/WikiPage.php b/includes/page/WikiPage.php index 7cc25bd3fc..a1b2e574d1 100644 --- a/includes/page/WikiPage.php +++ b/includes/page/WikiPage.php @@ -1470,7 +1470,7 @@ class WikiPage implements Page, IDBAccessObject { $bSlots = $b->getRevisionRecord()->getSlots(); $changedRoles = $aSlots->getRolesWithDifferentContent( $bSlots ); - return ( $changedRoles !== [ 'main' ] ); + return ( $changedRoles !== [ 'main' ] && $changedRoles !== [] ); } /** @@ -3343,23 +3343,10 @@ class WikiPage implements Page, IDBAccessObject { foreach ( $deleted as $catName ) { $cat = Category::newFromName( $catName ); Hooks::run( 'CategoryAfterPageRemoved', [ $cat, $this, $id ] ); - } - - // Refresh counts on categories that should be empty now - if ( count( $deleted ) ) { - $rows = $dbw->select( - 'category', - [ 'cat_id', 'cat_title', 'cat_pages', 'cat_subcats', 'cat_files' ], - [ 'cat_title' => $deleted, 'cat_pages <= 100' ], - __METHOD__ - ); - foreach ( $rows as $row ) { - $cat = Category::newFromRow( $row ); - // T166757: do the update after this DB commit - DeferredUpdates::addCallableUpdate( function () use ( $cat ) { - $cat->refreshCounts(); - } ); - } + // Refresh counts on categories that should be empty now (after commit, T166757) + DeferredUpdates::addCallableUpdate( function () use ( $cat ) { + $cat->refreshCountsIfEmpty(); + } ); } } diff --git a/includes/pager/TablePager.php b/includes/pager/TablePager.php index 4f5cb672f8..f38ed27563 100644 --- a/includes/pager/TablePager.php +++ b/includes/pager/TablePager.php @@ -298,7 +298,6 @@ abstract class TablePager extends IndexPager { $types = [ 'first', 'prev', 'next', 'last' ]; $queries = $this->getPagingQueries(); - $links = []; $buttons = []; diff --git a/includes/registration/ExtensionJsonValidator.php b/includes/registration/ExtensionJsonValidator.php index 564ea6be0c..9d6c1a5b33 100644 --- a/includes/registration/ExtensionJsonValidator.php +++ b/includes/registration/ExtensionJsonValidator.php @@ -21,8 +21,19 @@ use Composer\Spdx\SpdxLicenses; use JsonSchema\Validator; +use Seld\JsonLint\JsonParser; +use Seld\JsonLint\ParsingException; /** + * Validate extension.json files against their JSON schema. + * + * This is used for static validation from the command-line via + * validateRegistrationFile.php, and the PHPUnit structure test suite + * (ExtensionJsonValidationTest). + * + * The files are normally read by the ExtensionRegistry + * and ExtensionProcessor classes. + * * @since 1.29 */ class ExtensionJsonValidator { @@ -54,6 +65,10 @@ class ExtensionJsonValidator { 'The spdx-licenses library cannot be found, please install it through composer.' ); return false; + } elseif ( !class_exists( JsonParser::class ) ) { + call_user_func( $this->missingDepCallback, + 'The JSON lint library cannot be found, please install it through composer.' + ); } return true; @@ -65,8 +80,14 @@ class ExtensionJsonValidator { * @throws ExtensionJsonValidationError on any failure */ public function validate( $path ) { - $data = json_decode( file_get_contents( $path ) ); - if ( !is_object( $data ) ) { + $contents = file_get_contents( $path ); + $jsonParser = new JsonParser(); + try { + $data = $jsonParser->parse( $contents, JsonParser::DETECT_KEY_CONFLICTS ); + } catch ( ParsingException $e ) { + if ( $e instanceof \Seld\JsonLint\DuplicateKeyException ) { + throw new ExtensionJsonValidationError( $e->getMessage() ); + } throw new ExtensionJsonValidationError( "$path is not valid JSON" ); } diff --git a/includes/registration/ExtensionProcessor.php b/includes/registration/ExtensionProcessor.php index a803e3a80d..d0a987116d 100644 --- a/includes/registration/ExtensionProcessor.php +++ b/includes/registration/ExtensionProcessor.php @@ -162,6 +162,11 @@ class ExtensionProcessor implements Processor { */ protected $credits = []; + /** + * @var array + */ + protected $config = []; + /** * Any thing else in the $info that hasn't * already been processed @@ -290,6 +295,7 @@ class ExtensionProcessor implements Processor { return [ 'globals' => $this->globals, + 'config' => $this->config, 'defines' => $this->defines, 'callbacks' => $this->callbacks, 'credits' => $this->credits, @@ -493,6 +499,11 @@ class ExtensionProcessor implements Processor { $value = "$dir/$value"; } $this->addConfigGlobal( "$prefix$key", $value, $info['name'] ); + $data['providedby'] = $info['name']; + if ( isset( $info['ConfigRegistry'][0] ) ) { + $data['configregistry'] = array_keys( $info['ConfigRegistry'] )[0]; + } + $this->config[$key] = $data; } } } diff --git a/includes/registration/ExtensionRegistry.php b/includes/registration/ExtensionRegistry.php index c58b55ebfd..d21ae412f1 100644 --- a/includes/registration/ExtensionRegistry.php +++ b/includes/registration/ExtensionRegistry.php @@ -36,7 +36,7 @@ class ExtensionRegistry { /** * Bump whenever the registration cache needs resetting */ - const CACHE_VERSION = 6; + const CACHE_VERSION = 7; /** * Special key that defines the merge strategy diff --git a/includes/registration/Processor.php b/includes/registration/Processor.php index 210deb1bde..636d3b3768 100644 --- a/includes/registration/Processor.php +++ b/includes/registration/Processor.php @@ -25,6 +25,7 @@ interface Processor { * @return array With following keys: * 'globals' - variables to be set to $GLOBALS * 'defines' - constants to define + * 'config' - configuration information * 'callbacks' - functions to be executed by the registry * 'credits' - metadata to be stored by registry * 'attributes' - registration info which isn't a global variable diff --git a/includes/registration/VersionChecker.php b/includes/registration/VersionChecker.php index 9c673bc5db..59853b42ba 100644 --- a/includes/registration/VersionChecker.php +++ b/includes/registration/VersionChecker.php @@ -117,7 +117,7 @@ class VersionChecker { } break; case 'extensions': - case 'skin': + case 'skins': foreach ( $values as $dependency => $constraint ) { $extError = $this->handleExtensionDependency( $dependency, $constraint, $extension, $dependencyType @@ -169,7 +169,7 @@ class VersionChecker { * @param string $dependencyName The name of the dependency * @param string $constraint The required version constraint for this dependency * @param string $checkedExt The Extension, which depends on this dependency - * @param string $type Either 'extension' or 'skin' + * @param string $type Either 'extensions' or 'skins' * @return bool|array false for no errors, or an array of info */ private function handleExtensionDependency( $dependencyName, $constraint, $checkedExt, diff --git a/includes/resourceloader/ResourceLoaderLanguageDataModule.php b/includes/resourceloader/ResourceLoaderLanguageDataModule.php index f718e5feb3..4b24081109 100644 --- a/includes/resourceloader/ResourceLoaderLanguageDataModule.php +++ b/includes/resourceloader/ResourceLoaderLanguageDataModule.php @@ -46,7 +46,6 @@ class ResourceLoaderLanguageDataModule extends ResourceLoaderFileModule { 'pluralRules' => $language->getPluralRules(), 'digitGroupingPattern' => $language->digitGroupingPattern(), 'fallbackLanguages' => $language->getFallbackLanguages(), - 'bcp47Map' => LanguageCode::getNonstandardLanguageCodeMapping(), ]; } diff --git a/includes/shell/Command.php b/includes/shell/Command.php index 8ae517eed4..1154e05886 100644 --- a/includes/shell/Command.php +++ b/includes/shell/Command.php @@ -437,12 +437,12 @@ class Command { @trigger_error( '' ); restore_error_handler(); - $readPipes = wfArrayFilterByKey( $pipes, function ( $fd ) use ( $desc ) { + $readPipes = array_filter( $pipes, function ( $fd ) use ( $desc ) { return $desc[$fd][0] === 'pipe' && $desc[$fd][1] === 'r'; - } ); - $writePipes = wfArrayFilterByKey( $pipes, function ( $fd ) use ( $desc ) { + }, ARRAY_FILTER_USE_KEY ); + $writePipes = array_filter( $pipes, function ( $fd ) use ( $desc ) { return $desc[$fd][0] === 'pipe' && $desc[$fd][1] === 'w'; - } ); + }, ARRAY_FILTER_USE_KEY ); // stream_select parameter names are from the POV of us being able to do the operation; // proc_open desriptor types are from the POV of the process doing it. // So $writePipes is passed as the $read parameter and $readPipes as $write. diff --git a/includes/skins/Skin.php b/includes/skins/Skin.php index b6de5108ac..ff2a9eafe9 100644 --- a/includes/skins/Skin.php +++ b/includes/skins/Skin.php @@ -401,15 +401,14 @@ abstract class Skin extends ContextSource { * @param string|null $nonce OutputPage::getCSPNonce() * @return string|WrappedString HTML */ - static function makeVariablesScript( $data, $nonce = null ) { + public static function makeVariablesScript( $data, $nonce = null ) { if ( $data ) { return ResourceLoader::makeInlineScript( ResourceLoader::makeConfigSetScript( $data ), $nonce ); - } else { - return ''; } + return ''; } /** diff --git a/includes/specialpage/LoginSignupSpecialPage.php b/includes/specialpage/LoginSignupSpecialPage.php index d5c889aef0..e94f3db72c 100644 --- a/includes/specialpage/LoginSignupSpecialPage.php +++ b/includes/specialpage/LoginSignupSpecialPage.php @@ -265,6 +265,7 @@ abstract class LoginSignupSpecialPage extends AuthManagerSpecialPage { $this->getUser()->isLoggedIn() ) { $this->successfulAction(); + return; } // If logging in and not on HTTPS, either redirect to it or offer a link. diff --git a/includes/specials/SpecialBlock.php b/includes/specials/SpecialBlock.php index 92c6f504dd..3b25c6c2af 100644 --- a/includes/specials/SpecialBlock.php +++ b/includes/specials/SpecialBlock.php @@ -854,9 +854,11 @@ class SpecialBlock extends FormSpecialPage { * to the standard "**|" format? * @param Language|null $lang The language to get the durations in, or null to use * the wiki's content language + * @param bool $includeOther Whether to include the 'other' option in the list of + * suggestions * @return array */ - public static function getSuggestedDurations( $lang = null ) { + public static function getSuggestedDurations( $lang = null, $includeOther = true ) { $a = []; $msg = $lang === null ? wfMessage( 'ipboptions' )->inContentLanguage()->text() @@ -875,7 +877,7 @@ class SpecialBlock extends FormSpecialPage { $a[$show] = $value; } - if ( $a ) { + if ( $a && $includeOther ) { // if options exist, add other to the end instead of the begining (which // is what happens by default). $a[ wfMessage( 'ipbother' )->text() ] = 'other'; diff --git a/includes/specials/SpecialEditTags.php b/includes/specials/SpecialEditTags.php index 3db7edaf8e..b657335e31 100644 --- a/includes/specials/SpecialEditTags.php +++ b/includes/specials/SpecialEditTags.php @@ -166,7 +166,7 @@ class SpecialEditTags extends UnlistedSpecialPage { [], [ 'page' => $this->targetObj->getPrefixedText(), - 'hide_tag_log' => '0', + 'wpfilters' => [ 'tag' ], ] ); if ( !$this->targetObj->isSpecialPage() ) { diff --git a/includes/specials/SpecialNewpages.php b/includes/specials/SpecialNewpages.php index a93b5222c0..da2b688144 100644 --- a/includes/specials/SpecialNewpages.php +++ b/includes/specials/SpecialNewpages.php @@ -398,7 +398,10 @@ class SpecialNewpages extends IncludableSpecialPage { // Let extensions add data Hooks::run( 'NewPagesLineEnding', [ $this, &$ret, $result, &$classes, &$attribs ] ); - $attribs = wfArrayFilterByKey( $attribs, [ Sanitizer::class, 'isReservedDataAttribute' ] ); + $attribs = array_filter( $attribs, + [ Sanitizer::class, 'isReservedDataAttribute' ], + ARRAY_FILTER_USE_KEY + ); if ( count( $classes ) ) { $attribs['class'] = implode( ' ', $classes ); diff --git a/includes/specials/pagers/ContribsPager.php b/includes/specials/pagers/ContribsPager.php index 205364f81b..59fa948ac6 100644 --- a/includes/specials/pagers/ContribsPager.php +++ b/includes/specials/pagers/ContribsPager.php @@ -593,7 +593,10 @@ class ContribsPager extends RangeChronologicalPager { // Let extensions add data Hooks::run( 'ContributionsLineEnding', [ $this, &$ret, $row, &$classes, &$attribs ] ); - $attribs = wfArrayFilterByKey( $attribs, [ Sanitizer::class, 'isReservedDataAttribute' ] ); + $attribs = array_filter( $attribs, + [ Sanitizer::class, 'isReservedDataAttribute' ], + ARRAY_FILTER_USE_KEY + ); // TODO: Handle exceptions in the catch block above. Do any extensions rely on // receiving empty rows? diff --git a/includes/specials/pagers/DeletedContribsPager.php b/includes/specials/pagers/DeletedContribsPager.php index f261b72d8d..ee7eb3e4d8 100644 --- a/includes/specials/pagers/DeletedContribsPager.php +++ b/includes/specials/pagers/DeletedContribsPager.php @@ -221,7 +221,10 @@ class DeletedContribsPager extends IndexPager { // Let extensions add data Hooks::run( 'DeletedContributionsLineEnding', [ $this, &$ret, $row, &$classes, &$attribs ] ); - $attribs = wfArrayFilterByKey( $attribs, [ Sanitizer::class, 'isReservedDataAttribute' ] ); + $attribs = array_filter( $attribs, + [ Sanitizer::class, 'isReservedDataAttribute' ], + ARRAY_FILTER_USE_KEY + ); if ( $classes === [] && $attribs === [] && $ret === '' ) { wfDebug( "Dropping Special:DeletedContribution row that could not be formatted\n" ); diff --git a/includes/user/PasswordReset.php b/includes/user/PasswordReset.php index 39c0c1baf4..f65bae5aa7 100644 --- a/includes/user/PasswordReset.php +++ b/includes/user/PasswordReset.php @@ -240,7 +240,9 @@ class PasswordReset implements LoggerAwareInterface { $passwords = []; foreach ( $reqs as $req ) { - $this->authManager->changeAuthenticationData( $req ); + // This is adding a new temporary password, not intentionally changing anything + // (even though it might technically invalidate an old temporary password). + $this->authManager->changeAuthenticationData( $req, /* $isAddition */ true ); } $this->logger->info( diff --git a/languages/FakeConverter.php b/languages/FakeConverter.php index 6d9892000e..22377c28be 100644 --- a/languages/FakeConverter.php +++ b/languages/FakeConverter.php @@ -116,10 +116,6 @@ class FakeConverter { } function validateVariant( $variant = null ) { - if ( $variant === null ) { - return null; - } - $variant = strtolower( $variant ); return $variant === $this->mLang->getCode() ? $variant : null; } diff --git a/languages/Language.php b/languages/Language.php index 97920950e0..7f04a6874e 100644 --- a/languages/Language.php +++ b/languages/Language.php @@ -3413,32 +3413,26 @@ class Language { * Take a list of strings and build a locale-friendly comma-separated * list, using the local comma-separator message. * The last two strings are chained with an "and". - * NOTE: This function will only work with standard numeric array keys (0, 1, 2…) * - * @param string[] $l + * @param string[] $list * @return string */ - function listToText( array $l ) { - $m = count( $l ) - 1; - if ( $m < 0 ) { + public function listToText( array $list ) { + $itemCount = count( $list ); + if ( $itemCount < 1 ) { return ''; } - if ( $m > 0 ) { + $text = array_pop( $list ); + if ( $itemCount > 1 ) { $and = $this->msg( 'and' )->escaped(); $space = $this->msg( 'word-separator' )->escaped(); - if ( $m > 1 ) { + $comma = ''; + if ( $itemCount > 2 ) { $comma = $this->msg( 'comma-separator' )->escaped(); } + $text = implode( $comma, $list ) . $and . $space . $text; } - $s = $l[$m]; - for ( $i = $m - 1; $i >= 0; $i-- ) { - if ( $i == $m - 1 ) { - $s = $l[$i] . $and . $space . $s; - } else { - $s = $l[$i] . $comma . $s; - } - } - return $s; + return $text; } /** diff --git a/languages/LanguageCode.php b/languages/LanguageCode.php index 54d7fbe275..f50c55fe76 100644 --- a/languages/LanguageCode.php +++ b/languages/LanguageCode.php @@ -30,85 +30,22 @@ class LanguageCode { /** * Mapping of deprecated language codes that were used in previous * versions of MediaWiki to up-to-date, current language codes. - * These may or may not be valid BCP 47 codes; they are included here - * because MediaWiki remapped these particular codes at some point. * * @var array Mapping from language code to language code * * @since 1.30 - * @see https://meta.wikimedia.org/wiki/Special_language_codes */ private static $deprecatedLanguageCodeMapping = [ // Note that als is actually a valid ISO 639 code (Tosk Albanian), but it // was previously used in MediaWiki for Alsatian, which comes under gsw - 'als' => 'gsw', // T25215 - 'bat-smg' => 'sgs', // T27522 - 'be-x-old' => 'be-tarask', // T11823 - 'fiu-vro' => 'vro', // T31186 - 'roa-rup' => 'rup', // T17988 - 'zh-classical' => 'lzh', // T30443 - 'zh-min-nan' => 'nan', // T30442 - 'zh-yue' => 'yue', // T30441 - ]; - - /** - * Mapping of non-standard language codes used in MediaWiki to - * standardized BCP 47 codes. These are not deprecated (yet?): - * IANA may eventually recognize the subtag, in which case the `-x-` - * infix could be removed, or else we could rename the code in - * MediaWiki, in which case they'd move up to the above mapping - * of deprecated codes. - * - * As a rule, we preserve all distinctions made by MediaWiki - * internally. For example, `de-formal` becomes `de-x-formal` - * instead of just `de` because MediaWiki distinguishes `de-formal` - * from `de` (for example, for interface translations). Similarly, - * BCP 47 indicates that `kk-Cyrl` SHOULD not be used because it - * "typically does not add information", but in our case MediaWiki - * LanguageConverter distinguishes `kk` (render content in a mix of - * Kurdish variants) from `kk-Cyrl` (convert content to be uniformly - * Cyrillic). As the BCP 47 requirement is a SHOULD not a MUST, - * `kk-Cyrl` is a valid code, although some validators may emit - * a warning note. - * - * @var array Mapping from nonstandard codes to BCP 47 codes - * - * @since 1.32 - * @see https://meta.wikimedia.org/wiki/Special_language_codes - * @see https://phabricator.wikimedia.org/T125073 - */ - private static $nonstandardLanguageCodeMapping = [ - // All codes returned by Language::fetchLanguageNames() validated - // against IANA registry at - // https://www.iana.org/assignments/language-subtag-registry/language-subtag-registry - // with help of validator at - // http://schneegans.de/lv/ - 'cbk-zam' => 'cbk', // T124657 - 'de-formal' => 'de-x-formal', - 'eml' => 'egl', // T36217 - 'en-rtl' => 'en-x-rtl', - 'es-formal' => 'es-x-formal', - 'hu-formal' => 'hu-x-formal', - 'map-bms' => 'jv-x-bms', // [[en:Banyumasan_dialect]] T125073 - 'mo' => 'ro-MD', // T125073 - 'nrm' => 'nrf', // [[en:Norman_language]] T25216 - 'nl-informal' => 'nl-x-informal', - 'roa-tara' => 'nap-x-tara', // [[en:Tarantino_dialect]] - 'simple' => 'en-simple', - 'sr-ec' => 'sr-Cyrl', // T117845 - 'sr-el' => 'sr-Latn', // T117845 - - // Although these next codes aren't *wrong* per se, including - // both the script and the country code helps compatibility with - // other BCP 47 users. Note that MW also uses `zh-Hans`/`zh-Hant`, - // without a country code, and those should be left alone. - // (See $variantfallbacks in LanguageZh.php for Hans/Hant id.) - 'zh-cn' => 'zh-Hans-CN', - 'zh-sg' => 'zh-Hans-SG', - 'zh-my' => 'zh-Hans-MY', - 'zh-tw' => 'zh-Hant-TW', - 'zh-hk' => 'zh-Hant-HK', - 'zh-mo' => 'zh-Hant-MO', + 'als' => 'gsw', + 'bat-smg' => 'sgs', + 'be-x-old' => 'be-tarask', + 'fiu-vro' => 'vro', + 'roa-rup' => 'rup', + 'zh-classical' => 'lzh', + 'zh-min-nan' => 'nan', + 'zh-yue' => 'yue', ]; /** @@ -127,29 +64,6 @@ class LanguageCode { return self::$deprecatedLanguageCodeMapping; } - /** - * Returns a mapping of non-standard language codes used by - * (current and previous version of) MediaWiki, mapped to standard - * BCP 47 names. - * - * This array is exported to JavaScript to ensure - * mediawiki.language.bcp47 stays in sync with LanguageCode::bcp47(). - * - * @return string[] - * - * @since 1.32 - */ - public static function getNonstandardLanguageCodeMapping() { - $result = []; - foreach ( self::$deprecatedLanguageCodeMapping as $code => $ignore ) { - $result[$code] = self::bcp47( $code ); - } - foreach ( self::$nonstandardLanguageCodeMapping as $code => $ignore ) { - $result[$code] = self::bcp47( $code ); - } - return $result; - } - /** * Replace deprecated language codes that were used in previous * versions of MediaWiki to up-to-date, current language codes. @@ -173,15 +87,11 @@ class LanguageCode { * See mediawiki.language.bcp47 for the JavaScript implementation. * * @param string $code The language code. - * @return string A language code complying with BCP 47 standards. + * @return string The language code which complying with BCP 47 standards. * * @since 1.31 */ public static function bcp47( $code ) { - $code = self::replaceDeprecatedCodes( strtolower( $code ) ); - if ( isset( self::$nonstandardLanguageCodeMapping[$code] ) ) { - $code = self::$nonstandardLanguageCodeMapping[$code]; - } $codeSegment = explode( '-', $code ); $codeBCP = []; foreach ( $codeSegment as $segNo => $seg ) { diff --git a/languages/LanguageConverter.php b/languages/LanguageConverter.php index 494280cc41..dcc2cf335f 100644 --- a/languages/LanguageConverter.php +++ b/languages/LanguageConverter.php @@ -175,13 +175,11 @@ class LanguageConverter { $req = $this->validateVariant( $wgDefaultLanguageVariant ); } - $req = $this->validateVariant( $req ); - // This function, unlike the other get*Variant functions, is // not memoized (i.e. there return value is not cached) since // new information might appear during processing after this // is first called. - if ( $req ) { + if ( $this->validateVariant( $req ) ) { return $req; } return $this->mMainLanguageCode; @@ -217,25 +215,9 @@ class LanguageConverter { * @return mixed Returns the variant if it is valid, null otherwise */ public function validateVariant( $variant = null ) { - if ( $variant === null ) { - return null; - } - // Our internal variants are always lower-case; the variant we - // are validating may have mixed case. - $variant = LanguageCode::replaceDeprecatedCodes( strtolower( $variant ) ); - if ( in_array( $variant, $this->mVariants ) ) { + if ( $variant !== null && in_array( $variant, $this->mVariants ) ) { return $variant; } - // Browsers are supposed to use BCP 47 standard in the - // Accept-Language header, but not all of our internal - // mediawiki variant codes are BCP 47. Map BCP 47 code - // to our internal code. - foreach ( $this->mVariants as $v ) { - // Case-insensitive match (BCP 47 is mixed case) - if ( strtolower( LanguageCode::bcp47( $v ) ) === $variant ) { - return $v; - } - } return null; } @@ -311,7 +293,7 @@ class LanguageConverter { return $this->mHeaderVariant; } - // See if some supported language variant is set in the + // see if some supported language variant is set in the // HTTP header. $languages = array_keys( $wgRequest->getAcceptLang() ); if ( empty( $languages ) ) { @@ -563,18 +545,17 @@ class LanguageConverter { $convTable = $convRule->getConvTable(); $action = $convRule->getRulesAction(); foreach ( $convTable as $variant => $pair ) { - $v = $this->validateVariant( $variant ); - if ( !$v ) { + if ( !$this->validateVariant( $variant ) ) { continue; } if ( $action == 'add' ) { // More efficient than array_merge(), about 2.5 times. foreach ( $pair as $from => $to ) { - $this->mTables[$v]->setPair( $from, $to ); + $this->mTables[$variant]->setPair( $from, $to ); } } elseif ( $action == 'remove' ) { - $this->mTables[$v]->removeArray( $pair ); + $this->mTables[$variant]->removeArray( $pair ); } } } diff --git a/languages/data/Names.php b/languages/data/Names.php index 67da06b96a..277bd021fe 100644 --- a/languages/data/Names.php +++ b/languages/data/Names.php @@ -82,7 +82,7 @@ class Names { 'ba' => 'башҡортса', # Bashkir 'ban' => 'Basa Bali', # Balinese 'bar' => 'Boarisch', # Bavarian (Austro-Bavarian and South Tyrolean) - 'bat-smg' => 'žemaitėška', # Samogitian (deprecated code, 'sgs' in ISO 639-3 since 2010-06-30 ) + 'bat-smg' => 'žemaitėška', # Samogitian (deprecated code, 'sgs' in ISO 693-3 since 2010-06-30 ) 'bbc' => 'Batak Toba', # Batak Toba (falls back to bbc-latn) 'bbc-latn' => 'Batak Toba', # Batak Toba 'bcc' => 'جهلسری بلوچی', # Southern Balochi @@ -287,7 +287,7 @@ class Names { 'lzh' => '文言', # Literary Chinese, T10217 'lzz' => 'Lazuri', # Laz 'mai' => 'मैथिली', # Maithili - 'map-bms' => 'Basa Banyumasan', # Banyumasan ('jv-x-bms') + 'map-bms' => 'Basa Banyumasan', # Banyumasan 'mdf' => 'мокшень', # Moksha 'mg' => 'Malagasy', # Malagasy 'mh' => 'Ebon', # Marshallese @@ -298,7 +298,7 @@ class Names { 'ml' => 'മലയാളം', # Malayalam 'mn' => 'монгол', # Halh Mongolian (Cyrillic) (ISO 639-3: khk) 'mni' => 'মেইতেই লোন্', # Manipuri/Meitei - 'mo' => 'молдовеняскэ', # Moldovan, deprecated (ISO 639-2: ro-MD) + 'mo' => 'молдовеняскэ', # Moldovan, deprecated 'mr' => 'मराठी', # Marathi 'mrj' => 'кырык мары', # Hill Mari 'ms' => 'Bahasa Melayu', # Malay @@ -309,7 +309,7 @@ class Names { 'myv' => 'эрзянь', # Erzya 'mzn' => 'مازِرونی', # Mazanderani 'na' => 'Dorerin Naoero', # Nauruan - 'nah' => 'Nāhuatl', # Nahuatl (added to ISO 639-3 on 2006-10-31) + 'nah' => 'Nāhuatl', # Nahuatl (not in ISO 639-3) 'nan' => 'Bân-lâm-gú', # Min-nan, T10217 'nap' => 'Napulitano', # Neapolitan, T45793 'nb' => 'norsk bokmÃ¥l', # Norwegian (Bokmal) @@ -324,7 +324,7 @@ class Names { 'nn' => 'norsk nynorsk', # Norwegian (Nynorsk) 'no' => 'norsk', # Norwegian macro language (falls back to nb). 'nov' => 'Novial', # Novial - 'nrm' => 'Nouormand', # Norman (invalid code; 'nrf' in ISO 639 since 2014) + 'nrm' => 'Nouormand', # Norman 'nso' => 'Sesotho sa Leboa', # Northern Sotho 'nv' => 'Diné bizaad', # Navajo 'ny' => 'Chi-Chewa', # Chichewa @@ -360,8 +360,8 @@ class Names { 'rmy' => 'Romani', # Vlax Romany 'rn' => 'Kirundi', # Rundi/Kirundi/Urundi 'ro' => 'română', # Romanian - 'roa-rup' => 'armãneashti', # Aromanian (deprecated code, 'rup' exists in ISO 639-3) - 'roa-tara' => 'tarandíne', # Tarantino ('nap-x-tara') + 'roa-rup' => 'armãneashti', # Aromanian (deprecated code, 'rup' exists in ISO 693-3) + 'roa-tara' => 'tarandíne', # Tarantino 'ru' => 'русский', # Russian 'rue' => 'русиньскый', # Rusyn 'rup' => 'armãneashti', # Aromanian @@ -437,7 +437,7 @@ class Names { 'tt-cyrl' => 'татарча', # Tatar (Cyrillic script) (default) 'tt-latn' => 'tatarça', # Tatar (Latin script) 'tum' => 'chiTumbuka', # Tumbuka - 'tw' => 'Twi', # Twi + 'tw' => 'Twi', # Twi, (FIXME!) 'ty' => 'reo tahiti', # Tahitian 'tyv' => 'тыва дыл', # Tyvan 'tzm' => 'ⵜⴰⵎⴰⵣⵉⵖⵜ', # Tamazight diff --git a/languages/data/README.md b/languages/data/README.md new file mode 100644 index 0000000000..8a13fdcd0d --- /dev/null +++ b/languages/data/README.md @@ -0,0 +1,7 @@ +## normalize-ar.phpc + +Generated by `maintenance/language/generateNormalizerDataAr.php`. + +## normalize-ml.php + +Generated by `maintenance/language/generateNormalizerDataMl.php`. diff --git a/languages/data/normalize-ar.php b/languages/data/normalize-ar.php index c1daf20ca1..f54b23179d 100644 --- a/languages/data/normalize-ar.php +++ b/languages/data/normalize-ar.php @@ -1,5 +1,5 @@ 'Ù±', 'ﭑ' => 'Ù±', diff --git a/languages/data/normalize-ml.php b/languages/data/normalize-ml.php index ca89a5aef3..1cf854862d 100644 --- a/languages/data/normalize-ml.php +++ b/languages/data/normalize-ml.php @@ -1,5 +1,5 @@ 'ൺ', 'ന്‍' => 'ൻ', diff --git a/languages/i18n/af.json b/languages/i18n/af.json index c6e0c38313..dc6ed48844 100644 --- a/languages/i18n/af.json +++ b/languages/i18n/af.json @@ -897,6 +897,7 @@ "timezoneregion-indian": "Indiese Oseaan", "timezoneregion-pacific": "Stille Oseaan", "allowemail": "Laat e-pos van ander toe", + "email-blacklist-label": "Verbied hierdie gebruikers om my te e-pos:", "prefs-searchoptions": "Soek", "prefs-namespaces": "Naamruimtes", "default": "verstek", @@ -1213,7 +1214,8 @@ "rcfilters-view-tags-tooltip": "Filter resultate volgens wysigingsetikette", "rcfilters-liveupdates-button": "Monitor bywerkings", "rcfilters-liveupdates-button-title-off": "Wys nuwe wysigings soos hulle inrol.", - "rcfilters-preference-label": "Versteek die verbeter weergawe van 'Onlangse wysigings'", + "rcfilters-preference-label": "Versteek die verbeterde weergawe van 'Onlangse wysigings'", + "rcfilters-watchlist-preference-label": "Versteek die verbeterde weergawe van die dophoulys.", "rcnotefrom": "{{PLURAL:$5|Wysiging|Wysigings}} sedert $3 om $4 (maksimum van $1 word gewys).", "rclistfrom": "Vertoon wysigings vanaf $3 $2", "rcshowhideminor": "$1 klein wysigings", @@ -2403,7 +2405,6 @@ "markedaspatrollederrornotify": "Merk as gekontroleerd het misluk.", "patrol-log-page": "Kontroleringslogboek", "patrol-log-header": "Die logboek wys weergawes wat as gekontroleer gemerk is.", - "log-show-hide-patrol": "Nasienlogboek $1", "confirm-markpatrolled-button": "OK", "deletedrevision": "Ou weergawe $1 geskrap", "filedeleteerror-short": "Fout met verwydering van lêer: $1", diff --git a/languages/i18n/ais.json b/languages/i18n/ais.json index be9ce9835a..b00e768695 100644 --- a/languages/i18n/ais.json +++ b/languages/i18n/ais.json @@ -2604,8 +2604,6 @@ "markedaspatrollederrornotify": "silusi tayza-mikibi mungangaw.", "patrol-log-page": "tayza mikibi nasulitan nazipa’an", "patrol-log-header": "uyniyan sa u tayza-mikibi masumaday baziyong a nasulitan-nazipa’an.", - "log-show-hide-patrol": "$1 tayza mikibi nasulitan nazipa’an", - "log-show-hide-tag": "$1 tazihan-paya nasulitan nazipa’an", "confirm-markpatrolled-button": "malucekay", "confirm-markpatrolled-top": "silusi $2 a sumad $3 ku tayza-mikibi?", "deletedrevision": "masipu malumanay misumad nu ayaway $1", diff --git a/languages/i18n/am.json b/languages/i18n/am.json index b1740217cf..0612ee9f61 100644 --- a/languages/i18n/am.json +++ b/languages/i18n/am.json @@ -1559,7 +1559,6 @@ "markedaspatrollederrortext": "የተመለከተ ሆኖ ለማሳለፍ አንድን ዕትም መወሰን አለብዎት።", "markedaspatrollederror-noautopatrol": "የራስዎን ለውጥ የተመለከተ ሆኖ ለማሳለፍ አይችሉም።", "patrol-log-page": "የማሳለፊያ መዝገብ", - "log-show-hide-patrol": "ማሳለፊያ መዝገቦች", "deletedrevision": "የቆየው ዕትም $1 አጠፋ", "filedeleteerror-short": "የፋይል ማጥፋት ስኅተት፦ $1", "filedeleteerror-long": "ፋይሉን በማጥፋት ስህተቶች ተነስተዋል፦\n\n$1", diff --git a/languages/i18n/an.json b/languages/i18n/an.json index 0c3da7e561..6e2147d3a9 100644 --- a/languages/i18n/an.json +++ b/languages/i18n/an.json @@ -1951,7 +1951,6 @@ "markedaspatrollederror-noautopatrol": "No tiene premisos ta sinyalar os suyos propios cambios como controlatos.", "patrol-log-page": "Rechistro de control de revisions", "patrol-log-header": "Iste ye un rechistro de revisions patrullatas.", - "log-show-hide-patrol": "$1 o rechistro de patrullache", "deletedrevision": "S'ha borrato a versión antiga $1", "filedeleteerror-short": "Error borrando o fichero: $1", "filedeleteerror-long": "Se troboron errors borrando o fichero:\n\n$1", diff --git a/languages/i18n/ar.json b/languages/i18n/ar.json index 8d12ba0efe..5f04e02781 100644 --- a/languages/i18n/ar.json +++ b/languages/i18n/ar.json @@ -977,6 +977,8 @@ "diff-paragraph-moved-toold": "الفقرة تم نقلها. اضغط للذهاب للموقع القديم.", "difference-missing-revision": "{{PLURAL:$2|مراجعة واحدة|$2 مراجعات}} لهذا الفرق ($1) {{PLURAL:$2|لم|لم}} يتم إيجادها.\n\nهذا يحدث عادة عن طريق اتباع وصلة فرق قديمة لصفحة تم حذفها.\nالتفاصيل يمكن إيجادها في [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} سجل الحذف].", "searchresults": "نتائج البحث", + "search-filter-title-prefix": "البحث فقط في الصفحات التي يبدأ عنوانها بـ \"$1\"", + "search-filter-title-prefix-reset": "البحث في جميع الصفحات", "searchresults-title": "نتائج البحث عن \"$1\"", "titlematches": "عنوان الصفحة يطابق", "textmatches": "نص الصفحة يطابق", @@ -2076,7 +2078,9 @@ "speciallogtitlelabel": "الهدف (عنوان أو {{ns:user}}:اسم المستخدم للمستخدم):", "log": "سجلات", "logeventslist-submit": "أظهر", - "logeventslist-more-filters": "المزيد من المرشحات:", + "logeventslist-more-filters": "إظهار السجلات الإضافية:", + "logeventslist-patrol-log": "سجل الخفر", + "logeventslist-tag-log": "سجل الوسم", "all-logs-page": "كل السجلات العامة", "alllogstext": "عرض شامل لكل السجلات المتوفرة في {{SITENAME}}.\nباستطاعتك جعل القائمة أكثر تحديداً، وذلك باختيار نوع السجل واسم المستخدم (حساس لحالة الحروف)، أو الصفحة المتأثرة (أيضاً حساس لحالة الحروف).", "logempty": "لا توجد مدخلات مطابقة في السجل.", @@ -2430,6 +2434,7 @@ "uctop": "(حالية)", "month": "من شهر (وأقدم):", "year": "من سنة (وأقدم):", + "date": "من تاريخ (وأقدم).", "sp-contributions-newbies": "اعرض مساهمات الحسابات الجديدة فقط", "sp-contributions-newbies-sub": "للحسابات الجديدة", "sp-contributions-newbies-title": "مساهمات المستخدم للحسابات الجديدة", @@ -2931,8 +2936,6 @@ "markedaspatrollederrornotify": "لم ينجح وسم هذه النسخة بأنها مراجعة", "patrol-log-page": "سجل الخفر", "patrol-log-header": "هذا سجل بالمراجعات المراجعة.", - "log-show-hide-patrol": "$1 سجل الخفر", - "log-show-hide-tag": "$1 سجل الوسوم", "confirm-markpatrolled-button": "موافق", "confirm-markpatrolled-top": "علم على المراجعة $3 من $2 كمراجعة؟", "deletedrevision": "حذف المراجعة القديمة $1", diff --git a/languages/i18n/arc.json b/languages/i18n/arc.json index 5e2e307901..9c910c2914 100644 --- a/languages/i18n/arc.json +++ b/languages/i18n/arc.json @@ -1170,7 +1170,6 @@ "markedaspatrollednotify": "ܫܘܚܠܦܐ ܗܢܐ ܥܠ $1 ܐܫܬܘܕܥ ܐܝܟ ܟܪܝܟܐ.", "markedaspatrollederrornotify": "ܠܐ ܐܬܢܨܚ ܫܘܘܕܥܐ ܐܝܟ ܟܪܝܟܬܐ", "patrol-log-page": "ܣܓܠܐ ܕܟܪܟܐ", - "log-show-hide-patrol": "$1 ܣܓܠܐ ܕܟܪܟܐ", "filedeleteerror-short": "ܦܘܕܐ ܒܫܝܦܐ ܕܠܦܦܐ: $1", "filedeleteerror-long": "ܦܘܕ̈ܐ ܐܫܟܚܬ ܟܕ ܫܝܦܐ ܠܦܦܐ:\n\n$1", "previousdiff": "← ܫܘܚܠܦܐ ܕܩܕܡ", diff --git a/languages/i18n/ary.json b/languages/i18n/ary.json index fb7eec7f62..135dca587c 100644 --- a/languages/i18n/ary.json +++ b/languages/i18n/ary.json @@ -1521,7 +1521,6 @@ "pageinfo-authors": "ĝadad l-mo'llifin l-mĥṫalfin", "pageinfo-toolboxlink": "معلومات على الصفحة", "markaspatrolleddiff": "marki kamorajaaa", - "log-show-hide-patrol": "$1 sijjil lkhafr", "previousdiff": "Ṫ-Ṫeĝdil li mbeĝd", "nextdiff": "Ṫ-Ṫeĝdila li mbeĝd", "thumbsize": "ḫajm l-miniatur:", diff --git a/languages/i18n/arz.json b/languages/i18n/arz.json index 9152090f0e..b1f5f843a3 100644 --- a/languages/i18n/arz.json +++ b/languages/i18n/arz.json @@ -1801,7 +1801,6 @@ "markedaspatrollederror-noautopatrol": "مش مسموح ليك تعلم على تغييراتك الشخصية كأنها متراجعة.", "patrol-log-page": "سجل المراجعة", "patrol-log-header": "دا سجل بالنسخ المتراجعة", - "log-show-hide-patrol": "$1 سجل المراجعة", "deletedrevision": "مسح النسخة القديمة $1", "filedeleteerror-short": "غلط مسح الملف: $1", "filedeleteerror-long": "حصلت غلطات و الملف دا بيتمسح :\n\n$1", diff --git a/languages/i18n/as.json b/languages/i18n/as.json index 7158a626a6..fead6f8c57 100644 --- a/languages/i18n/as.json +++ b/languages/i18n/as.json @@ -2333,7 +2333,6 @@ "markedaspatrollederrornotify": "নিৰীক্ষণবিহীন ৰূপে চিহ্নিত কৰা হ’ল", "patrol-log-page": "নিৰীক্ষণ অভিলেখ", "patrol-log-header": "এইখন নিৰীক্ষিত সংশোধনসমূহৰ অভিলেখ ।", - "log-show-hide-patrol": "নিৰীক্ষণ অভিলেখ $1", "deletedrevision": "পুৰণি সংশোধনী $1 বিলোপ কৰা হ’ল", "filedeleteerror-short": "নথি বিলোপ কৰাত ত্ৰুটি: $1", "filedeleteerror-long": "এই নথিখন বিলোপ কৰাত সমস্যা হৈছে :\n\n$1", diff --git a/languages/i18n/ase.json b/languages/i18n/ase.json index 1017e864e2..b3783e9bbb 100644 --- a/languages/i18n/ase.json +++ b/languages/i18n/ase.json @@ -410,6 +410,7 @@ "rcshowhideminor": "$1 M515x512S1f010486x488S2f900502x507 M521x532S10609498x496S10621487x512S21100500x483S2df20479x468", "rcshowhideminor-hide": "M546x533S15a56519x474S2ff00482x483S2c601516x507S1f740521x487S1f711484x508", "rcshowhidebots-show": "M521x531S10012491x516S15a18479x503S26620486x469", + "rcshowhidebots-hide": "M546x533S15a56519x474S2ff00482x483S2c601516x507S1f740521x487S1f711484x508", "rcshowhideliu": "$1 M538x521S2a200497x480S20b00462x508S11530523x482S15a37462x483S11551470x493 M526x522S15a56499x510S11520503x479S20e00489x496S26a02474x489", "rcshowhideliu-hide": "M546x533S15a56519x474S2ff00482x483S2c601516x507S1f740521x487S1f711484x508", "rcshowhideanons-hide": "M546x533S15a56519x474S2ff00482x483S2c601516x507S1f740521x487S1f711484x508", @@ -551,7 +552,6 @@ "tooltip-summary": "M535x523S14c50508x492S14c58469x492S22520503x477S22520465x477 M529x528S11541487x496S11549471x501S20e00503x488S26507516x473 M554x523S14c40530x476S14c48446x492S26502515x489S26516468x507S20340495x489S20348487x506", "patrol-log-page": "M518x560S2035a492x545S10e50501x522S31500482x483 M518x536S15a37483x465S18550493x476S15a37483x509S15a51486x513", "patrol-log-header": "M508x525S10004493x475S22a04494x510 M518x560S2035a492x545S10e50501x522S31500482x483 M521x532S10609498x496S10621487x512S21100500x483S2df20479x468 M518x536S15a37483x465S18550493x476S15a37483x509S15a51486x513", - "log-show-hide-tag": "$1 M519x514S15a28482x487S11502489x498 M518x536S15a37483x465S18550493x476S15a37483x509S15a51486x513", "filedeleteerror-short": "M527x532S1ea40473x511S1f540512x478S22a07497x504S2f700512x468 M520x523S14c19480x496S15a01497x497S20710483x477 M518x526S2ff00482x483S19a00487x506 S38700463x496 $1", "ilsubmit": "M546x525S2ff00482x483S16d10492x505S2e502519x502", "metadata": "M520x523S14c19480x496S15a01497x497S20710483x477 M538x522S18517516x486S1851f461x495S2ff00482x483S14c00513x436S14c08461x445S26a00511x469S26a10459x478", @@ -572,7 +572,7 @@ "logentry-newusers-autocreate": "M526x522S15a56499x510S11520503x479S20e00489x496S26a02474x489 M518x517S15a30482x489S1f750484x484S20500496x506S22a04505x495 $1 M531x531S14c30506x469S2a204508x503S2a21c470x503S14c38470x469 {{GENDER:$2|M532x519S20302493x485S2030a489x502S21100509x504S26900516x482S26910468x501}} M520x525S15a18480x490S10a02483x476S23100494x508S20e00500x494", "log-name-managetags": "M519x514S15a28482x487S11502489x498 M530x529S10640507x503S10648479x489S26c08503x484S26c18470x471 M518x536S15a37483x465S18550493x476S15a37483x509S15a51486x513", "log-name-tag": "M519x514S15a28482x487S11502489x498 M518x536S15a37483x465S18550493x476S15a37483x509S15a51486x513", - "searchsuggest-search": "M546x525S2ff00482x483S16d10492x505S2e502519x502", + "searchsuggest-search": "M546x525S2ff00482x483S16d10492x505S2e502519x502 {{SITENAME}}", "api-error-unknownerror": "M536x518S2ff00482x483S15a11513x486S28108513x453 M518x526S2ff00482x483S19a00487x506 S38700463x496 $1", "expandtemplates": "M554x524S14c40530x477S14c48446x493S26506515x490S26512468x508S20340495x490S20348487x507 M510x522S15c10490x513S16d12490x495S22a04494x478", "expand_templates_ok": "M515x525S17620499x475S14020485x495", diff --git a/languages/i18n/ast.json b/languages/i18n/ast.json index 9ee88c88db..d49e1c5f7d 100644 --- a/languages/i18n/ast.json +++ b/languages/i18n/ast.json @@ -2865,8 +2865,6 @@ "markedaspatrollederrornotify": "Falló l'aición de marcar como revisáu.", "patrol-log-page": "Rexistru de supervisión", "patrol-log-header": "Esti ye un rexistru de les revisiones supervisaes.", - "log-show-hide-patrol": "$1 rexistru de supervisión", - "log-show-hide-tag": "$1 rexistru d'etiquetes", "confirm-markpatrolled-button": "Aceutar", "confirm-markpatrolled-top": "¿Marcar la revisión $3 de $2 como patrullada?", "deletedrevision": "Desaniciada la revisión antigua $1", diff --git a/languages/i18n/awa.json b/languages/i18n/awa.json index 48d79d2ed3..dde8033fa9 100644 --- a/languages/i18n/awa.json +++ b/languages/i18n/awa.json @@ -2253,8 +2253,6 @@ "markedaspatrollederrornotify": "जाँचा हुआ चिन्हित करना असफल रहा।", "patrol-log-page": "परीक्षण लॉग", "patrol-log-header": "यह परीक्षित अवतरणों की लॉग है।", - "log-show-hide-patrol": "परीक्षण लॉग $1", - "log-show-hide-tag": "$1 चिप्पी लग", "deletedrevision": "पुरान अवतरण $1 हटाय दिहा गा है", "filedeleteerror-short": "फ़ाईल हटावै मा समस्या: $1", "filedeleteerror-long": "फ़ाइल हटावै में आवा गल्ती:\n\n$1", diff --git a/languages/i18n/az.json b/languages/i18n/az.json index 6cef2fbb29..fa2b983c82 100644 --- a/languages/i18n/az.json +++ b/languages/i18n/az.json @@ -225,7 +225,7 @@ "redirectedfrom": "($1 səhifəsindən yönləndirilmişdir)", "redirectpagesub": "Yönləndirmə səhifəsi", "redirectto": "Ä°stiqamətləndirilir:", - "lastmodifiedat": "Bu səhifə sonuncu dəfə $1 tarixində saat $2-də redaktə edilib.", + "lastmodifiedat": "Bu səhifə sonuncu dəfə $1 tarixində, saat $2-də redaktə edilib.", "viewcount": "Bu səhifəyə $1 {{PLURAL:$1|dəfə}} müraciət olunub.", "protectedpage": "Mühafizəli səhifə", "jumpto": "Keçid et:", @@ -416,9 +416,9 @@ "createacct-submit": "Ä°stifadəçi hesabı yarat", "createacct-another-submit": "Ä°stifadəçi hesabı yarat", "createacct-benefit-heading": "{{SITENAME}} sizin kimi insanlar tərəfindən yaradılır.", - "createacct-benefit-body1": "$1 {{PLURAL:$1|redaktə}}", + "createacct-benefit-body1": "{{PLURAL:$1|redaktə}}", "createacct-benefit-body2": "{{PLURAL:$1|səhifə|səhifə}}", - "createacct-benefit-body3": "ən son {{PLURAL:$1|iştirakçılar|iştirakçılar}}", + "createacct-benefit-body3": "nəfər yenicə {{PLURAL:$1|redaktə edən}}", "badretype": "Daxil etdiyiniz parol uyğun gəlmir.", "userexists": "Daxil edilmiş ad artıq istifadədədir.\nLütfən başqa ad seçin.", "loginerror": "Daxil olma xətası", @@ -1132,15 +1132,15 @@ "recentchanges-page-added-to-category": "[[:$1]] kateqoriyaya əlavə edildi", "upload": "Fayl yüklə", "uploadbtn": "Sənəd yüklə", - "reuploaddesc": "Return to the upload form.", - "upload-tryagain": "Dəyşdirilmiş fayl izahını göndər", + "reuploaddesc": "Yükləmə formasına geri qayıt", + "upload-tryagain": "Dəyişdirilmiş fayl izahını göndər", "uploadnologin": "Daxil olmamısınız", "uploadnologintext": "Fayl yükləmək üçün siz sistemə $1.", "upload_directory_missing": "($1) yükləmə qaydası axtarılır və vebserverdə yaradılması qeyri-mümkündür.", "upload_directory_read_only": "\"$1\" kataloqunun arxivi veb-server yazıları üçün qapalıdır.", "uploaderror": "Yükləmə xətası", "upload-recreate-warning": "'''Diqqət: Bu adda fayl silinib, yaxud adı dəyişdirilib.'''\n\nBu səhifənin silinmə və addəyişmə jurnalı aşağıda göstərilmişdir:", - "uploadtext": "Fayl yükləmək üçün aşağıdakı formadan istifadə edin.\nƏvvəllər yüklənmiş fayllara baxmaq üçün [[Special:FileList|yüklənmiş fayllar siyahısına]] keçin, həmçinin (təkrar) yüklənmiş fayllara [[Special:Log/upload|yükləmə jurnalında]], silinmiş fayllara [[Special:Log/delete|silinmə jurnalında]] baxa bilərsiniz.\n\nMəqaləyə fayl yerləşdirmək üçün aşağıdaki formalardan birini istifadə edin:\n* Faylın tam versiyasını yerləşdirmək üçün: '''[[{{ns:file}}:File.jpg]]''';\n* Faylın 200 pikselədək kiçildilmiş versiyasını mətndən solda, altında izahla yerləşdirmək üçün: '''[[{{ns:file}}:File.png|200px|thumb|left|təsvir]]''';\n* Səhifədə faylın özünü göstərmədən ona birbaşa keçid yerləşdirmək üçün: '''[[{{ns:media}}:File.ogg]]'''.", + "uploadtext": "Fayl yükləmək üçün aşağıdakı formadan istifadə edin.\nƏvvəllər yüklənmiş fayllara baxmaq üçün [[Special:FileList|yüklənmiş fayllar siyahısına]] keçin, həmçinin (təkrar) yüklənmiş fayllara [[Special:Log/upload|yükləmə jurnalında]], silinmiş fayllara [[Special:Log/delete|silinmə jurnalında]] baxa bilərsiniz.\n\nMəqaləyə fayl yerləşdirmək üçün aşağıdakı formalardan birini istifadə edin:\n* Faylın tam versiyasını yerləşdirmək üçün: '''[[{{ns:file}}:File.jpg]]''';\n* Faylın 200 pikselədək kiçildilmiş versiyasını mətndən solda və altında izahla yerləşdirmək üçün: '''[[{{ns:file}}:File.png|200px|thumb|left|təsvir]]''';\n* Səhifədə faylın özünü göstərmədən ona birbaşa keçid yerləşdirmək üçün: '''[[{{ns:media}}:File.ogg]]'''.", "upload-permitted": "Ä°cazə verilən fayl {{PLURAL:$2|tipi|tipləri}}: $1.", "upload-preferred": "Üstünlük verilən fayl {{PLURAL:$2|tipi|tipləri}}: $1.", "upload-prohibited": "Qadağan olunan fayl {{PLURAL:$2|tipi|tipləri}}: $1.", @@ -1959,6 +1959,7 @@ "anonymous": "{{SITENAME}} saytının anonim {{PLURAL:$1|istifadəçisi|istifadəçiləri}}", "siteuser": "{{SITENAME}} istifadəçisi $1", "anonuser": "{{SITENAME}} anonim istifadəçisi $1", + "lastmodifiedatby": "Bu səhifə sonuncu dəfə $3 tərəfindən $1 tarixində, saat $2-də redaktə edilib.", "othercontribs": "$1-in işinə əsaslanıb.", "others": "digərləri", "siteusers": "{{SITENAME}} {{PLURAL:$2|user|istifadəçi}} $1", @@ -2019,7 +2020,6 @@ "markedaspatrollednotify": "\"$1\" səhifəsindəki bu redaktə patrullanmış kimi işarələndi.", "patrol-log-page": "Patrul gündəliyi", "patrol-log-header": "Bu yoxlanmış dəyişikliklərin gündəliyidir.", - "log-show-hide-patrol": "$1 patrul gündəliyi", "deletedrevision": "Köhnə versiyaları silindi $1.", "filedeleteerror-short": "Fayl silinərkən xəta: $1", "filedeleteerror-long": "Fayl silinərkən üzə çıxan xətalar:\n\n$1", diff --git a/languages/i18n/azb.json b/languages/i18n/azb.json index d3aeeb5d1c..f3b60a1b25 100644 --- a/languages/i18n/azb.json +++ b/languages/i18n/azb.json @@ -2368,8 +2368,6 @@ "markedaspatrollederrornotify": "دولانماق برچسبی مووفقیت سیز اولدو", "patrol-log-page": "دولانما ژورنالی", "patrol-log-header": "بو یوخلانمیش دییشیک‌لیک‌لرین ژورنالی‌دیر.", - "log-show-hide-patrol": "$1 دولانما ژورنالی", - "log-show-hide-tag": "اِتیکت ژورنالی $1", "deletedrevision": "کؤهنه نوسخه لری سیلیندی $1.", "filedeleteerror-short": "فایل سیلینرکن ختا: $1", "filedeleteerror-long": "فایل سیلینرکن اوزه چیخان ختا‌لار:\n\n$1", diff --git a/languages/i18n/ba.json b/languages/i18n/ba.json index 8a24243ea3..79b9215534 100644 --- a/languages/i18n/ba.json +++ b/languages/i18n/ba.json @@ -2770,8 +2770,6 @@ "markedaspatrollederrornotify": "Патрулләнгән тип билдәләү уңышһыҙ тамамланды.", "patrol-log-page": "Тикшереү яҙмалары журналы", "patrol-log-header": "Был — тикшерелгән өлгөләр яҙмалары журналы.", - "log-show-hide-patrol": "тикшереү яҙмалары журналын $1", - "log-show-hide-tag": "$1 билдәләр журналы", "confirm-markpatrolled-button": "Яҡшы", "confirm-markpatrolled-top": "$2 битенең $3 версияһын тикшерелгән тип һанарғамы?", "deletedrevision": "Иҫке $1 өлгөһө юйылды", diff --git a/languages/i18n/bcc.json b/languages/i18n/bcc.json index bd8bac4d7a..e0e4805a96 100644 --- a/languages/i18n/bcc.json +++ b/languages/i18n/bcc.json @@ -2041,7 +2041,6 @@ "markedaspatrollederror-noautopatrol": "شما را اجازت نیست وتی تغییراتء په عنوان نظارت بیتگین نشان کنیت.", "patrol-log-page": "آمار نظارت", "patrol-log-header": "شی آماری چه بازبینی آن گشتی انت.", - "log-show-hide-patrol": "$1 آمار گشت", "deletedrevision": "قدیمی بازبینی $1 حذف بوت", "filedeleteerror-short": "حطا حذف فایل: $1", "filedeleteerror-long": "حطای پیش آتک وهدی که فایل حذف بیگت:\n\n$1", diff --git a/languages/i18n/bcl.json b/languages/i18n/bcl.json index ca68364e46..2913aa20c7 100644 --- a/languages/i18n/bcl.json +++ b/languages/i18n/bcl.json @@ -2181,7 +2181,6 @@ "markedaspatrollederrornotify": "Pagmamarka bilang patrolyado na nagpalya.", "patrol-log-page": "Laóg kan Pigpapatrolya", "patrol-log-header": "Ini an sarong talaan kan patrolyadong mga rebisyon.", - "log-show-hide-patrol": "$1 talaan sa patrolya", "deletedrevision": "Pigparâ an lumang pagribay na $1.", "filedeleteerror-short": "Salâ sa pagparà kan dokumento: $1", "filedeleteerror-long": "May mga nasabat na salâ mientras na pigpaparâ an ''file'':\n\n$1", diff --git a/languages/i18n/be-tarask.json b/languages/i18n/be-tarask.json index 9f6cbda6f2..dbbffdc901 100644 --- a/languages/i18n/be-tarask.json +++ b/languages/i18n/be-tarask.json @@ -919,6 +919,8 @@ "diff-paragraph-moved-toold": "Параграф быў перанесены. Націсьніце, каб перайсьці ў першапачатковае месца.", "difference-missing-revision": "{{PLURAL:$2|$2 вэрсія|$2 вэрсіі|$2 вэрсіяў}} з гэтымі адрозьненьнямі ($1) {{PLURAL:$2|не была|не былі}} знойдзеныя.\n\nЗвычайна гэта здараецца з-за пераходу па састарэлай спасылцы на старонку, якая была выдаленая.\nПадрабязнасьці можна знайсьці ў [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} журнале выдаленьняў].", "searchresults": "Вынікі пошуку", + "search-filter-title-prefix": "Шукаем толькі на старонках, назвы якіх пачынаюцца з «$1»", + "search-filter-title-prefix-reset": "Шукаць сярод усіх старонак", "searchresults-title": "Вынікі пошуку для «$1»", "titlematches": "Супадзеньні ў назвах старонак", "textmatches": "Супадзеньні ў тэкстах старонак", @@ -1592,11 +1594,11 @@ "uploadvirus": "Файл утрымлівае вірус! Падрабязнасьці: $1", "uploadjava": "Файл зьяўляецца ZIP-архівам, які зьмяшчае .class-файл Java.\nЗагрузка Java-файлаў забароненая, бо яны могуць быць прычынай абыходу абмежаваньняў бясьпекі.", "upload-source": "Крынічны файл", - "sourcefilename": "Пачатковая назва файла:", + "sourcefilename": "Пачатковая назва файлу:", "sourceurl": "URL-адрас крыніцы:", - "destfilename": "Канчатковая назва файла:", - "upload-maxfilesize": "Максымальны памер файла: $1", - "upload-description": "Апісаньне файла", + "destfilename": "Канчатковая назва файлу:", + "upload-maxfilesize": "Максымальны памер файлу: $1", + "upload-description": "Апісаньне файлу", "upload-options": "Налады загрузкі", "watchthisupload": "Назіраць за гэтым файлам", "filewasdeleted": "Файл з такой назвай загружаўся, але быў выдалены.\nВам трэба праверыць $1 перад новай загрузкай.", @@ -1723,6 +1725,7 @@ "http-timed-out": "Скончыўся час чаканьня HTTP-запыту.", "http-curl-error": "Памылка выбаркі URL-адрасу: $1", "http-bad-status": "Адбылася памылка пад час выкананьня HTTP-запыту: $1 $2", + "http-internal-error": "Унутраная памылка HTTP.", "upload-curl-error6": "Немагчыма дасягнуць URL-адрас", "upload-curl-error6-text": "Немагчыма адкрыць пазначаны URL-адрас.\nКалі ласка, упэўніцеся, што адрас слушны і сайт працуе.", "upload-curl-error28": "Ліміт часу загрузкі скончыўся", @@ -2016,7 +2019,7 @@ "speciallogtitlelabel": "Мэта (назва ці {{ns:user}}:імя_ўдзельніка для ўдзельніка):", "log": "Журналы падзеяў", "logeventslist-submit": "Паказаць", - "logeventslist-more-filters": "Болей фільтраў:", + "logeventslist-more-filters": "Паказаць дадатковыя журналы:", "logeventslist-patrol-log": "Журнал патруляваньня", "logeventslist-tag-log": "Журнал метак", "all-logs-page": "Усе публічныя журналы падзеяў", @@ -2860,8 +2863,6 @@ "markedaspatrollederrornotify": "Не атрымалася адпатруляваць старонку.", "patrol-log-page": "Журнал патруляваньняў", "patrol-log-header": "Гэта журнал патруляваных вэрсіяў.", - "log-show-hide-patrol": "$1 журнал патруляваньняў", - "log-show-hide-tag": "$1 журнал метак", "confirm-markpatrolled-button": "Добра", "confirm-markpatrolled-top": "Пазначыць вэрсію $3 старонкі $2 як патруляваную?", "deletedrevision": "Выдаленая старая вэрсія $1", diff --git a/languages/i18n/be.json b/languages/i18n/be.json index 2277444b36..bd5ac50b0d 100644 --- a/languages/i18n/be.json +++ b/languages/i18n/be.json @@ -33,7 +33,8 @@ "Artsiom91", "Andrus", "Da voli", - "OlegCinema" + "OlegCinema", + "Gorgich" ] }, "tog-underline": "Падкрэсліваць спасылкі:", @@ -932,6 +933,7 @@ "diff-paragraph-moved-toold": "Параграф быў перамешчаны. Клікніце, каб перайсці да старога месцазнаходжання.", "difference-missing-revision": "{{PLURAL:$2|$2 версія|$2 версіі|$2 версій}} гэтай розніцы ($1) {{PLURAL:$2|не знойдзена|не знойдзены}}.\n\nЗвычайна такое здараецца з-за пераходу па састарэлай спасылцы на розніцу ў старонцы, якая была выдалена.\nПадрабязнасці могуць быць у [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} журнале выдаленняў].", "searchresults": "Вынікі пошуку", + "search-filter-title-prefix": "Шукаць толькі на старонках, назва якіх пачынаецца з «$1»", "searchresults-title": "Вынікі пошуку «$1»", "titlematches": "Знойдзена ў назвах", "textmatches": "Знойдзена ў тэкстах", @@ -1333,6 +1335,7 @@ "rcfilters-other-review-tools": "Іншыя інструменты праверкі", "rcfilters-group-results-by-page": "Групіраваць вынікі паводле старонкі", "rcfilters-activefilters": "Актыўныя фільтры", + "rcfilters-activefilters-show": "Паказаць", "rcfilters-advancedfilters": "Пашыраныя фільтры", "rcfilters-limit-title": "Вынікі для паказу", "rcfilters-limit-and-date-label": "$1 {{PLURAL:$1|змена|змены|змен}}, $2", @@ -1941,6 +1944,7 @@ "apisandbox-dynamic-error-exists": "Параметр з назвай \"$1\" ужо існуе.", "apisandbox-deprecated-parameters": "Састарэлыя параметры", "apisandbox-fetch-token": "Аўтазапаўненне токена", + "apisandbox-add-multi": "Дадаць", "apisandbox-submit-invalid-fields-title": "Некаторыя палі недапушчальныя", "apisandbox-submit-invalid-fields-message": "Калі ласка, выпраўце адзначаныя палі і паспрабуйце ізноў.", "apisandbox-results": "Вынікі", @@ -2795,8 +2799,6 @@ "markedaspatrollederrornotify": "Не ўдалося пазначыць як ухваленую.", "patrol-log-page": "Журнал ухваленых", "patrol-log-header": "Журнал ухваленых версій", - "log-show-hide-patrol": "$1 журнал ухваленняў", - "log-show-hide-tag": "$1 журнал бірак", "confirm-markpatrolled-button": "Добра", "confirm-markpatrolled-top": "Пазначыць версію $3 старонкі $2 як патруляваную?", "deletedrevision": "Сцёрта старая версія $1", diff --git a/languages/i18n/bg.json b/languages/i18n/bg.json index 480f28c5dc..af77e3218a 100644 --- a/languages/i18n/bg.json +++ b/languages/i18n/bg.json @@ -1308,6 +1308,7 @@ "rcfilters-other-review-tools": "Други инструменти за проверка", "rcfilters-group-results-by-page": "Групиране на резултатите по страница", "rcfilters-activefilters": "Активни филтри", + "rcfilters-activefilters-hide": "Скриване", "rcfilters-advancedfilters": "Разширени филтри", "rcfilters-limit-title": "Резултати за показване", "rcfilters-limit-and-date-label": "$1 {{PLURAL:$1|промяна|промени}}, $2", @@ -1369,7 +1370,7 @@ "rcfilters-filter-humans-label": "Човек (не бот)", "rcfilters-filter-humans-description": "Редакции, направени от редактори.", "rcfilters-filtergroup-reviewstatus": "Проверка на статуса", - "rcfilters-filter-reviewstatus-unpatrolled-label": "Непатрулирано", + "rcfilters-filter-reviewstatus-unpatrolled-label": "Непатрулирани", "rcfilters-filter-reviewstatus-manual-label": "Ръчно патрулирани", "rcfilters-filter-reviewstatus-auto-label": "Автоматично патрулирани", "rcfilters-filtergroup-significance": "Значимост", @@ -1385,9 +1386,9 @@ "rcfilters-filter-watchlist-notwatched-label": "Извън списъка за наблюдение", "rcfilters-filter-watchlist-notwatched-description": "Всички, освен промените в страници от списъка за наблюдение.", "rcfilters-filtergroup-watchlistactivity": "Активност по списъка за наблюдение", - "rcfilters-filter-watchlistactivity-unseen-label": "Невидяни промени", + "rcfilters-filter-watchlistactivity-unseen-label": "Непрегледани промени", "rcfilters-filter-watchlistactivity-unseen-description": "Промени по страници, които не сте посетили откакто са настъпили промените.", - "rcfilters-filter-watchlistactivity-seen-label": "Видени промени", + "rcfilters-filter-watchlistactivity-seen-label": "Прегледани промени", "rcfilters-filter-watchlistactivity-seen-description": "Промени по страници, които сте посетили откакто са настъпили промените.", "rcfilters-filtergroup-changetype": "Вид на промяната", "rcfilters-filter-pageedits-label": "Редакции на страници", @@ -1416,7 +1417,7 @@ "rcfilters-liveupdates-button": "Обновяване на живо", "rcfilters-liveupdates-button-title-on": "Изключване на обновяването в реално време", "rcfilters-liveupdates-button-title-off": "Показване на новите промени в реално време", - "rcfilters-watchlist-markseen-button": "Отбелязване на всички промени като видени", + "rcfilters-watchlist-markseen-button": "Отбелязване на всички промени като прегледани", "rcfilters-watchlist-edit-watchlist-button": "Редактиране на списъка за наблюдение", "rcfilters-watchlist-showupdated": "Промени по страници, които не сте посетили откакто са внесени промените, са в получер, с удебелени маркери.", "rcfilters-preference-label": "Скриване на подобрената версия на Последни промени", @@ -2087,6 +2088,8 @@ "dellogpage": "Дневник на изтриванията", "dellogpagetext": "Списък на последните изтривания.", "deletionlog": "дневник на изтриванията", + "log-name-create": "Дневник на създадените страници", + "log-description-create": "По-долу е показан списък на последно създадените страници.", "logentry-create-create": "$1 {{GENDER:$2|създаде}} страница $3", "reverted": "Възвръщане към предишна версия", "deletecomment": "Причина:", @@ -2711,8 +2714,6 @@ "markedaspatrollederrornotify": "Неуспешно отбелязване на редакция като патрулирана.", "patrol-log-page": "Дневник на патрула", "patrol-log-header": "Тази страница съдържа дневник на проверените версии.", - "log-show-hide-patrol": "$1 на дневника на патрула", - "log-show-hide-tag": "$1 на дневника на отбелязванията", "confirm-markpatrolled-button": "Добре", "confirm-markpatrolled-top": "Маркиране на редакция $3 на $2 като патрулирана?", "deletedrevision": "Изтрита стара версия $1", @@ -3302,6 +3303,10 @@ "tag-filter-submit": "Филтриране", "tag-list-wrapper": "([[Special:Tags|{{PLURAL:$1|Етикет|Етикети}}]]: $2)", "tag-mw-contentmodelchange": "промяна на модела на съдържание", + "tag-mw-new-redirect": "Ново пренасочване", + "tag-mw-removed-redirect": "Премахнато пренасочване", + "tag-mw-blank": "Изтриване на съдържанието", + "tag-mw-replace": "Заменено", "tag-mw-rollback": "Отмяна", "tag-mw-undo": "Отмяна", "tags-title": "Етикети", diff --git a/languages/i18n/bgn.json b/languages/i18n/bgn.json index b9500aba51..4d9537cfb8 100644 --- a/languages/i18n/bgn.json +++ b/languages/i18n/bgn.json @@ -2065,8 +2065,6 @@ "markedaspatrollederrornotify": "گشت وارته ئی برچسپ جتین ناکام ات.", "patrol-log-page": "گشتئ سیاه چال", "patrol-log-header": "ای سیاهه شه گشت وارته ئین ایڈیٹ ئان است.", - "log-show-hide-patrol": "$1 گشت جنوکین سیاهه", - "log-show-hide-tag": "$1 خالیجای ٹاپه", "deletedrevision": "$1 قدیمی پاک بوته ئین نخسه ئی است", "filedeleteerror-short": "خطا بئ فایلی پاک کورتین: $1", "filedeleteerror-long": "بی پدا پاک کورتین ئی وختا خطا رخ دات:\n\n$1", diff --git a/languages/i18n/bjn.json b/languages/i18n/bjn.json index f6da61e059..d677a0b1c9 100644 --- a/languages/i18n/bjn.json +++ b/languages/i18n/bjn.json @@ -1965,7 +1965,6 @@ "markedaspatrollederrornotify": "Manandai sabagai paitihan nang gagal.", "patrol-log-page": "Log pa-awasan", "patrol-log-header": "Ngini adalah sabuah log matan raralatan nang ta-awasi.", - "log-show-hide-patrol": "$1 log pa-awasan", "deletedrevision": "Raralatan lawas tahapus: $1", "filedeleteerror-short": "Kasalahan mahapus barakas: $1", "filedeleteerror-long": "Kasalahan tarikin parhatan mahapus barakas:\n\n$1", diff --git a/languages/i18n/bn.json b/languages/i18n/bn.json index 07f18f3a8c..f8b988192f 100644 --- a/languages/i18n/bn.json +++ b/languages/i18n/bn.json @@ -941,6 +941,7 @@ "diff-paragraph-moved-toold": "অনুচ্ছেদ স্থানান্তর করা হয়েছে। পুরনো অবস্থানে যাওয়ার জন্য ক্লিক করুন।", "difference-missing-revision": "এই পার্থক্যের ($1) অন্তর্গত {{PLURAL:$2|একটি সংশোধিত সংস্করণ|$2টি সংশোধিত সংস্করণ}} খুঁজে পাওয়া যাচ্ছে না।\n\nসাধারণত মুছে ফেলা হয়েছে এমন পাতার মেয়াদ উত্তীর্ণ ইতিহাস পাতার লিংক খোলার কারণে এটি হতে পারে। \n[{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} পাতা অবলুপ্তি লগে] বিস্তারিত তথ্য জানা যাবে।", "searchresults": "অনুসন্ধানের ফলাফল", + "search-filter-title-prefix-reset": "সব পাতা অনুসন্ধান করুন", "searchresults-title": "\"$1\" অনুসন্ধানের ফলাফল", "titlematches": "নিবন্ধের শিরোনাম মিলেছে", "textmatches": "পাতার লেখার সাথে মিলেছে", @@ -1737,6 +1738,7 @@ "http-timed-out": "HTTP অনুরোধের সময় পার হয়েছে।", "http-curl-error": "ইউআরএল নিয়ে আসার ক্ষেত্রে ত্রুটি: $1", "http-bad-status": "HTTP অনুরোধের সময় কোন সমস্যা হয়েছে: $1 $2", + "http-internal-error": "HTTP অভ্যন্তরীণ ত্রুটি।", "upload-curl-error6": "URL-এ পৌঁছানো যায়নি", "upload-curl-error6-text": "প্রদত্ত URLটিতে পৌঁছানো যায়নি। অনুগ্রহ করে আবার পরীক্ষা করে দেখুন URLটি সঠিক কি না এবং সাইটটি চালু আছে কি না।", "upload-curl-error28": "আপলোড সময়োত্তীর্ণ", @@ -2029,7 +2031,7 @@ "speciallogtitlelabel": "লক্ষ্য (ব্যবহারকারীর জন্য শিরোনাম বা {{ns:user}}:ব্যবহারকারী নাম):", "log": "লগগুলি", "logeventslist-submit": "দেখাও", - "logeventslist-more-filters": "আরো ছাঁকনি:", + "logeventslist-more-filters": "অতিরিক্ত লগ দেখান:", "logeventslist-patrol-log": "পরীক্ষণ লগ", "logeventslist-tag-log": "ট্যাগ লগ", "all-logs-page": "সব প্রকাশ্য লগ", @@ -2888,8 +2890,6 @@ "markedaspatrollederrornotify": "পরীক্ষিত হিসাবে চিহ্নিত করতে ব্যর্থ।", "patrol-log-page": "পরীক্ষণ লগ", "patrol-log-header": "এটি যাচাইকৃত রিভিশনের তালিকা।", - "log-show-hide-patrol": "পরীক্ষণ লগ $1", - "log-show-hide-tag": "ট্যাগ লগ $1", "confirm-markpatrolled-button": "ঠিক আছে", "confirm-markpatrolled-top": "$2-এর $3 নং সংস্করণটি পরীক্ষিত হিসেবে চিহ্নিত করবেন?", "deletedrevision": "মুছে ফেলা পুরাতন সংশোধন $1", diff --git a/languages/i18n/br.json b/languages/i18n/br.json index a552b16e01..48526f557d 100644 --- a/languages/i18n/br.json +++ b/languages/i18n/br.json @@ -2775,8 +2775,6 @@ "markedaspatrollederrornotify": "N'eus ket bet gallet merkañ evel gwiriet.", "patrol-log-page": "Log gwiriañ", "patrol-log-header": "Setu ur marilh eus ar stummoù patrouilhet.", - "log-show-hide-patrol": "$1 istor ar stummoù gwiriet", - "log-show-hide-tag": "$1 marilh an dikedenn", "confirm-markpatrolled-button": "Mat eo", "confirm-markpatrolled-top": "Merkañ adweladenn $3 eus $2 evel gwiriet ?", "deletedrevision": "Diverket stumm kozh $1.", diff --git a/languages/i18n/bs.json b/languages/i18n/bs.json index 0f18d91767..8249df5911 100644 --- a/languages/i18n/bs.json +++ b/languages/i18n/bs.json @@ -1954,6 +1954,7 @@ "speciallogtitlelabel": "Cilj (naslov ili {{ns:user}}:korisničko ime):", "log": "Zapisnici", "logeventslist-submit": "Prikaži", + "logeventslist-more-filters": "Prikaži dodatne zapisnike:", "all-logs-page": "Svi javni zapisnici", "alllogstext": "Skupni prikaz svih dostupnih zapisnika sa {{GRAMMAR:genitiv|{{SITENAME}}}}.\nMožete suziti prikaz izabiranjem specifičnog zapisnika, korisničkog imena (razlikovati velika i mala slova) ili izmijenjenog članka (također treba razlikovati velika i mala slova).", "logempty": "Nema zatraženih stavki u zapisniku.", @@ -2791,8 +2792,6 @@ "markedaspatrollederrornotify": "Označavanje stranice pregledanom nije uspjelo.", "patrol-log-page": "Zapisnik patroliranja", "patrol-log-header": "Ovo je zapisnik patroliranih izmjena.", - "log-show-hide-patrol": "$1 zapisnik patroliranja", - "log-show-hide-tag": "$1 zapisnik oznaka", "confirm-markpatrolled-button": "U redu", "confirm-markpatrolled-top": "Označiti izmjenu $3 stranice $2 patroliranom?", "deletedrevision": "Obrisana stara izmjena $1", diff --git a/languages/i18n/ca.json b/languages/i18n/ca.json index 3579d72a46..3cd1b13278 100644 --- a/languages/i18n/ca.json +++ b/languages/i18n/ca.json @@ -966,6 +966,7 @@ "diff-paragraph-moved-toold": "S'ha mogut el paràgraf. Feu clic per a saltar la ubicació antiga.", "difference-missing-revision": "{{PLURAL:$2|Una revisió|$2 revisions}} d'aquesta diferència ($1) no {{PLURAL:$2|s'ha|s'han}} trobat.\n\nAixò passa generalment en seguir un enllaç obsolet de diferències a una pàgina que s'ha suprimit.\nEs pot trobar més informació en el [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} registre de supressions].", "searchresults": "Resultats de la cerca", + "search-filter-title-prefix-reset": "Cerca a totes les pàgines", "searchresults-title": "Resultats de la cerca de «$1»", "titlematches": "Coincidències de títol de la pàgina", "textmatches": "Coincidències de text de pàgina", @@ -1430,6 +1431,7 @@ "rcfilters-filter-humans-description": "Modificacions fetes per editors humans.", "rcfilters-filtergroup-reviewstatus": "Estat de revisió", "rcfilters-filter-reviewstatus-unpatrolled-label": "No patrullat", + "rcfilters-filter-reviewstatus-manual-description": "Modificacions marcades manualment com a patrullades.", "rcfilters-filter-reviewstatus-manual-label": "Patrullat manualment", "rcfilters-filter-reviewstatus-auto-label": "Autopatrullat", "rcfilters-filtergroup-significance": "Significació", @@ -1479,6 +1481,7 @@ "rcfilters-watchlist-edit-watchlist-button": "Editeu la vostra llista de pàgines seguides", "rcfilters-watchlist-showupdated": "Els canvis fets en pàgines que no heu visitat des que s'efectuaren apareixen en negreta amb un punt sòlid al costat.", "rcfilters-preference-label": "Amaga la versió millorada de Canvis recents", + "rcfilters-watchlist-preference-label": "Amaga la versió millorada de la llista de seguiment", "rcfilters-filter-showlinkedfrom-label": "Mostra els canvis en les pàgines enllaçades des de", "rcfilters-filter-showlinkedfrom-option-label": "Pàgines enllaçades des de la pàgina seleccionada", "rcfilters-filter-showlinkedto-label": "Mostra els canvis a les pàgines que enllacin a", @@ -1716,6 +1719,8 @@ "uploadstash-bad-path-invalid": "El camí no és vàlid.", "uploadstash-bad-path-unknown-type": "El tipus «$1» és desconegut.", "uploadstash-bad-path-unrecognized-thumb-name": "Nom de miniatura no reconegut.", + "uploadstash-file-not-found-not-exists": "No es pot trobar el camí, o bé no és un fitxer pla.", + "uploadstash-file-too-large": "No es pot servir un fitxer més gran de $1 bytes.", "uploadstash-no-extension": "L’extensió és nul·la.", "uploadstash-zero-length": "El fitxer té mida zero.", "invalid-chunk-offset": "El desplaçament del fragment no és vàlid", @@ -2024,6 +2029,7 @@ "log": "Registres", "logeventslist-submit": "Mostra", "logeventslist-more-filters": "Més filtres:", + "logeventslist-tag-log": "Registre d'etiquetes", "all-logs-page": "Tots els registres públics", "alllogstext": "Presentació combinada de tots els registres disponibles de {{SITENAME}}.\nPodeu reduir l'extensió seleccionant el tipus de registre, el nom d'usuari realitzador (distingeix entre majúscules i minúscules), o la pàgina objectiu (també en distingeix).", "logempty": "No hi ha cap coincidència en el registre.", @@ -2218,6 +2224,8 @@ "dellogpagetext": "Davall hi ha una llista dels esborraments més recents.", "deletionlog": "registre de supressions", "log-name-create": "Registre de creació de pàgines", + "log-description-create": "A continuació hi ha una llista de les pàgines creades més recentment.", + "logentry-create-create": "$1 {{GENDER:$2|va crear}} la pàgina $3", "reverted": "Invertit amb una revisió anterior", "deletecomment": "Motiu:", "deleteotherreason": "Motiu diferent o addicional:", @@ -2867,8 +2875,6 @@ "markedaspatrollederrornotify": "Ha fallat la marca com a patrullat.", "patrol-log-page": "Registre de supervisió", "patrol-log-header": "Això és un registre de les revisions patrullades.", - "log-show-hide-patrol": "$1 el registre de patrulla", - "log-show-hide-tag": "$1 el registre d’etiquetes", "confirm-markpatrolled-button": "D'acord", "confirm-markpatrolled-top": "Voleu marcar la revisió $3 de $2 com a patrullada?", "deletedrevision": "S'ha eliminat la revisió antiga $1.", @@ -3642,6 +3648,7 @@ "logentry-delete-delete": "$1 {{GENDER:$2|ha suprimit}} la pàgina $3", "logentry-delete-delete_redir": "$1 {{GENDER:$2|ha esborrat}} la redirecció $3 sobreescrivint-la", "logentry-delete-restore": "$1 {{GENDER:$2|ha restaurat}} la pàgina $3 ($4)", + "logentry-delete-restore-nocount": "$1 {{GENDER:$2|va restaurar}} la pàgina $3", "restore-count-revisions": "{{PLURAL:$1|Una revisió|$1 revisions}}", "restore-count-files": "{{PLURAL:$1|Un fitxer|$1 fitxers}}", "logentry-delete-event": "$1 {{GENDER:$2|ha canviat}} la visibilitat {{PLURAL:$5|d'un esdeveniment al registre|de $5 esdeveniments al registre}} de $3: $4", diff --git a/languages/i18n/cdo.json b/languages/i18n/cdo.json index 9d04fa59c4..251688906b 100644 --- a/languages/i18n/cdo.json +++ b/languages/i18n/cdo.json @@ -566,6 +566,7 @@ "nextn": "âu $1 bÄ­k", "shown-title": "MÅ«i hiĕk hiēng-sê $1{{PLURAL:$1|bÄ­k giék-guō}}", "viewprevnext": "Káng ($1 {{int:pipe-separator}} $2) ($3)", + "searchmenu-exists": "cÄ« siŏh bÄ­h wiki Ä«-gÄ­ng ô „$1“ mìng-chÄ­ng gì dèu-mÅ­k", "searchprofile-articles": "Nô̤i-ṳ̀ng hiĕk", "searchprofile-images": "Dŏ̤-mùi-tā̤", "searchprofile-everything": "SÅ«-iÅ«-nó̤h", diff --git a/languages/i18n/ce.json b/languages/i18n/ce.json index 32cb94b889..21e3132dda 100644 --- a/languages/i18n/ce.json +++ b/languages/i18n/ce.json @@ -2385,8 +2385,6 @@ "markedaspatrollederrornotify": "Хийцамаш хьаьжжина сана билгал бан цабелира.", "patrol-log-page": "ТӀехьажаран тептар", "patrol-log-header": "Хьажжина версеш йолу тептар.", - "log-show-hide-patrol": "$1 тӀехьажаран тептар", - "log-show-hide-tag": "$1 билгалонийн тептар", "confirm-markpatrolled-button": "ХӀаъ", "deletedrevision": "ДӀаяьккхина шира верси $1", "filedeleteerror-short": "Файл дӀаяккхаран гӀалат: $1", diff --git a/languages/i18n/ckb.json b/languages/i18n/ckb.json index f64a03f121..4d64e063c1 100644 --- a/languages/i18n/ckb.json +++ b/languages/i18n/ckb.json @@ -1804,6 +1804,8 @@ "dellogpage": "لۆگی سڕینەوە", "dellogpagetext": "ئەوەی خوارەوە لیستێكە لە دوایین سڕینەوەکان", "deletionlog": "لۆگی سڕینەوە", + "log-name-create": "لۆگی دروستکردنی پەڕە", + "logentry-create-create": "$1 پەڕەی $3ی دروست کرد", "reverted": "گەڕێندراوە بۆ پێداچوونەوەی پێشووتر", "deletecomment": "ھۆکار:", "deleteotherreason": "ھۆکاری تر/زیاتر:", @@ -2373,7 +2375,6 @@ "markedaspatrollederrornotify": "نیشانکردن وەک پاس دراو سەرکەوتوو نەبوو.", "patrol-log-page": "لۆگی پاسدان", "patrol-log-header": "ئەمە لۆگێکی پێداچوونەوە پاس دراوەکانە.", - "log-show-hide-patrol": "لۆگی پاسدان $1", "confirm-markpatrolled-button": "باشە", "deletedrevision": "پێداچوونەوەی کۆنی سڕاوە $1", "filedeleteerror-short": "هەڵە لە سڕینەوەی پەڕگە: $1", diff --git a/languages/i18n/crh-cyrl.json b/languages/i18n/crh-cyrl.json index c06c758a60..2241458ed7 100644 --- a/languages/i18n/crh-cyrl.json +++ b/languages/i18n/crh-cyrl.json @@ -1318,7 +1318,6 @@ "spam_blanking": "Бар олгъан версияларда $1 сайтына багълантылар бар, темизлев", "pageinfo-language": "Саифе ичиндекисининъ тили", "patrol-log-page": "Тешкерюв журналы", - "log-show-hide-patrol": "Тешкерюв журналыны $1", "deletedrevision": "$1 сайылы эски версия ёкъ этильди.", "filedeleteerror-short": "Файл ёкъ эткенде хата чыкъты: $1", "filedelete-missing": "\"$1\" адлы файл ёкъ этилип оламай, чюнки ойле бир файл ёкъ.", diff --git a/languages/i18n/crh-latn.json b/languages/i18n/crh-latn.json index 8728109b91..02405daf5f 100644 --- a/languages/i18n/crh-latn.json +++ b/languages/i18n/crh-latn.json @@ -1315,7 +1315,6 @@ "spam_blanking": "Bar olğan versiyalarda $1 saytına bağlantılar bar, temizlev", "pageinfo-language": "Saife içindekisiniñ tili", "patrol-log-page": "Teşkerüv jurnalı", - "log-show-hide-patrol": "Teşkerüv jurnalını $1", "deletedrevision": "$1 sayılı eski versiya yoq etildi.", "filedeleteerror-short": "Fayl yoq etkende hata çıqtı: $1", "filedelete-missing": "\"$1\" adlı fayl yoq etilip olamay, çünki öyle bir fayl yoq.", diff --git a/languages/i18n/cs.json b/languages/i18n/cs.json index d8e96408ce..e3cf41105b 100644 --- a/languages/i18n/cs.json +++ b/languages/i18n/cs.json @@ -945,6 +945,8 @@ "diff-paragraph-moved-toold": "Odstavec byl přesunut. Kliknutím skočíte na původní umístění.", "difference-missing-revision": "{{PLURAL:$2|Jedna z revizí|$2 revize|$2 revizí}} k požadovanému porovnání ($1) {{PLURAL:$2|neexistuje|neexistují|neexistuje}}.\n\nToto je obvykle způsobeno tím, že jste následovali zastaralý odkaz na historickou verzi stránky, jež byla smazána.\nPodrobnosti mohou být uvedeny v [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} knize smazaných stránek].", "searchresults": "Výsledky hledání", + "search-filter-title-prefix": "Hledání pouze ve stránkách, jejichž název začíná na „$1“", + "search-filter-title-prefix-reset": "Hledat ve vÅ¡ech stránkách", "searchresults-title": "Výsledky hledání „$1“", "titlematches": "Stránky s odpovídajícím názvem", "textmatches": "Stránky s odpovídajícím textem", @@ -2039,7 +2041,7 @@ "speciallogtitlelabel": "Cíl (název nebo {{ns:user}}:Jméno pro uživatele):", "log": "Protokolovací záznamy", "logeventslist-submit": "Zobrazit", - "logeventslist-more-filters": "Další filtry:", + "logeventslist-more-filters": "Zobrazit další záznamy:", "logeventslist-patrol-log": "Kniha prověřených editací", "logeventslist-tag-log": "Kniha značek", "all-logs-page": "VÅ¡echny veřejné záznamy", @@ -2896,8 +2898,6 @@ "markedaspatrollederrornotify": "Nepodařilo se označit jako prověřené.", "patrol-log-page": "Kniha prověřených editací", "patrol-log-header": "Toto je kniha prověřených verzí.", - "log-show-hide-patrol": "$1 knihu záznamů patroly", - "log-show-hide-tag": "$1 knihu značek", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Označit revizi $3 stránky $2 jako prověřenou?", "deletedrevision": "Smazána stará revize $1", diff --git a/languages/i18n/cy.json b/languages/i18n/cy.json index 5b2c82df7a..6e5cfb8c33 100644 --- a/languages/i18n/cy.json +++ b/languages/i18n/cy.json @@ -20,7 +20,8 @@ "Dafyddt", "Jdforrester", "Irus", - "Fitoschido" + "Fitoschido", + "Nrowe" ] }, "tog-underline": "Tanlinellu cysylltiadau:", @@ -1333,7 +1334,7 @@ "rcfilters-filter-newpages-description": "Golygiadau creu dalennau", "rcfilters-filter-categorization-label": "Newidiadau i'r Categoriau", "rcfilters-filter-categorization-description": "Cofnodion y dalennau a ychwanegwyd neu a symudwyd o'r categoriau.", - "rcfilters-filter-logactions-label": "Gweithredoedd a logiwyd", + "rcfilters-filter-logactions-label": "Gwriansow kovskrifys", "rcfilters-filtergroup-lastRevision": "Yr adolygiadau diweddaraf", "rcfilters-filter-lastrevision-label": "Yr adolygiad diweddaraf", "rcfilters-filter-lastrevision-description": "Dim ond yn newidiadau diweddaraf i'r ddalen.", @@ -2600,7 +2601,6 @@ "markedaspatrollederrornotify": "Methwyd rhoi marc ymweliad patrôl arni.", "patrol-log-page": "Lòg patrolio", "patrol-log-header": "Mae'r lòg hwn yn dangos y golygiadau sydd wedi derbyn ymweliad patrôl.", - "log-show-hide-patrol": "$1 lòg patrolio", "confirm-markpatrolled-button": "Iawn", "confirm-markpatrolled-top": "Nodi fod diwygiad $3 o $2 wedi cael sêl-bendith golygydd?", "deletedrevision": "Wedi dileu hen ddiwygiad $1.", diff --git a/languages/i18n/da.json b/languages/i18n/da.json index 875e4476f3..a7dd8c01dc 100644 --- a/languages/i18n/da.json +++ b/languages/i18n/da.json @@ -2140,6 +2140,9 @@ "dellogpage": "Sletningslog", "dellogpagetext": "Herunder vises de nyeste sletninger. Alle tider er serverens tid.", "deletionlog": "sletningslog", + "log-name-create": "Sideoprettelseslog", + "log-description-create": "Nedenfor er en liste over de senest oprettede sider.", + "logentry-create-create": "$1 {{GENDER:$2|oprettede}} siden $3", "reverted": "Gendannet en tidligere version", "deletecomment": "Begrundelse:", "deleteotherreason": "Anden/uddybende begrundelse:", @@ -2755,8 +2758,6 @@ "markedaspatrollederrornotify": "Markering som patruljeret mislykkedes.", "patrol-log-page": "Kontrollog", "patrol-log-header": "Patruljerede versioner.", - "log-show-hide-patrol": "$1 patruljeringslog", - "log-show-hide-tag": "$1 taglog", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Marker version $3 af $2 som patruljeret?", "deletedrevision": "Slettede gammel version $1", diff --git a/languages/i18n/de.json b/languages/i18n/de.json index 143f26c4e3..7fb78b247b 100644 --- a/languages/i18n/de.json +++ b/languages/i18n/de.json @@ -997,6 +997,8 @@ "diff-paragraph-moved-toold": "Der Absatz wurde verschoben. Klicken, um zur alten Stelle zu springen.", "difference-missing-revision": "{{PLURAL:$2|Eine Version|$2 Versionen}} dieser Unterschiedsanzeige ($1) {{PLURAL:$2|wurde|wurden}} nicht gefunden.\n\nDieser Fehler wird normalerweise von einem veralteten Link zur Versionsgeschichte einer Seite verursacht, die zwischenzeitlich gelöscht wurde.\nEinzelheiten sind im [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} Lösch-Logbuch] vorhanden.", "searchresults": "Suchergebnisse", + "search-filter-title-prefix": "Nur in Seiten suchen, deren Titel mit „$1“ beginnt.", + "search-filter-title-prefix-reset": "Alle Seiten durchsuchen", "searchresults-title": "Suchergebnisse für „$1“", "titlematches": "Übereinstimmungen mit Seitentiteln", "textmatches": "Übereinstimmungen mit Inhalten", @@ -1807,6 +1809,7 @@ "http-timed-out": "Zeitüberschreitung bei der HTTP-Anfrage.", "http-curl-error": "Fehler beim Abruf der URL: $1", "http-bad-status": "Während der HTTP-Anfrage ist ein Fehler aufgetreten: $1 $2", + "http-internal-error": "Interner HTTP-Fehler.", "upload-curl-error6": "URL ist nicht erreichbar", "upload-curl-error6-text": "Die angegebene URL ist nicht erreichbar. Prüfe sowohl die URL auf Fehler als auch den Online-Status der Seite.", "upload-curl-error28": "Zeitüberschreitung beim Hochladen", @@ -2099,7 +2102,7 @@ "speciallogtitlelabel": "Ziel (Titel oder {{ns:user}}:Benutzername für einen Benutzer):", "log": "Logbücher", "logeventslist-submit": "Anzeigen", - "logeventslist-more-filters": "Weitere Filter:", + "logeventslist-more-filters": "Zusätzliche Logbücher anzeigen:", "logeventslist-patrol-log": "Kontroll-Logbuch", "logeventslist-tag-log": "Markierungs-Logbuch", "all-logs-page": "Alle öffentlichen Logbücher", @@ -2960,8 +2963,6 @@ "markedaspatrollederrornotify": "Der Versuch, die Version als kontrolliert zu markieren, ist fehlgeschlagen.", "patrol-log-page": "Kontroll-Logbuch", "patrol-log-header": "Dies ist das Kontroll-Logbuch.", - "log-show-hide-patrol": "Kontroll-Logbuch $1", - "log-show-hide-tag": "Markierungs-Logbuch $1", "confirm-markpatrolled-button": "Okay", "confirm-markpatrolled-top": "Version $3 von $2 als kontrolliert markieren?", "deletedrevision": "alte Version $1 gelöscht", diff --git a/languages/i18n/diq.json b/languages/i18n/diq.json index ba91d02657..1ba6eec287 100644 --- a/languages/i18n/diq.json +++ b/languages/i18n/diq.json @@ -2455,8 +2455,6 @@ "markedaspatrollederrornotify": "Nışan kerdışê dewriyey nêbı", "patrol-log-page": "Qeydé çımsernayoğan", "patrol-log-header": "Ena listeyê logi revizyonê devriyeyi mocneno.", - "log-show-hide-patrol": "Qeydé Çımsernayoğan $1", - "log-show-hide-tag": "$1 qeydê etiketi", "confirm-markpatrolled-button": "TEMAM", "deletedrevision": "Veriyono kihan $1 wederna", "filedeleteerror-short": "Wedarnayişê dosya de ğelati esto: $1", diff --git a/languages/i18n/dsb.json b/languages/i18n/dsb.json index 1bd76b6d28..0cff6d9aea 100644 --- a/languages/i18n/dsb.json +++ b/languages/i18n/dsb.json @@ -2233,7 +2233,6 @@ "markedaspatrollederrornotify": "Markěrowanje ako doglědowane njejo se raźiło.", "patrol-log-page": "Protokol kontrolow", "patrol-log-header": "To jo protokol pśekontrolowanych wersijow.", - "log-show-hide-patrol": "Protokol doglědowanja $1", "deletedrevision": "wulaÅ¡owana stara wersija: $1", "filedeleteerror-short": "Zmólka pśi wulaÅ¡owanju dataje: $1", "filedeleteerror-long": "Pśi wulaÅ¡owanju dataje su se zwěsćili zmólki:\n\n$1", diff --git a/languages/i18n/el.json b/languages/i18n/el.json index 6b223f8aa0..a0e9bca1d2 100644 --- a/languages/i18n/el.json +++ b/languages/i18n/el.json @@ -955,6 +955,7 @@ "diff-paragraph-moved-toold": "Η παράγραφος αφαιρέθηκε. Πατήστε στο κουμπί για να πάτε σε προηγούμενη τοποθεσία.", "difference-missing-revision": "{{PLURAL:$2|Μία αναθεώρηση|$2 αναθεωρήσεις}} αυτής της διαφοράς ($1) δεν {{PLURAL:$2|μπόρεσε να βρεθεί|μπόρεσαν να βρεθούν}}.\n\nΑυτό συνήθως προκαλείται από παλιό σύνδεσμο διαφοράς προς σελίδα που έχει διαγραφεί.\nΛεπτομέρειες θα βρείτε στο [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} ημερολόγιο καταγραφής διαγραφών].", "searchresults": "Αποτελέσματα αναζήτησης", + "search-filter-title-prefix-reset": "Αναζήτηση όλων των σελίδων", "searchresults-title": "Αποτελέσματα αναζήτησης για \"$1\"", "titlematches": "Τίτλοι άρθρων που ανταποκρίνονται", "textmatches": "Κείμενα σελίδων που ανταποκρίνονται:", @@ -2822,8 +2823,6 @@ "markedaspatrollederrornotify": "Σήμανση ως ελεγμένη απέτυχε.", "patrol-log-page": "Αρχείο καταγραφής περιπολιών", "patrol-log-header": "Αυτό είναι μητρώο ελεγμένων αναθεωρήσεων.", - "log-show-hide-patrol": "$1 μητρώου ελέγχου επεξεργασιών", - "log-show-hide-tag": "$1 ετικέττα καταγραφής", "confirm-markpatrolled-button": "Εντάξει", "deletedrevision": "Η παλιά έκδοση της $1 διαγράφτηκε", "filedeleteerror-short": "Σφάλμα κατά τη διαγραφή του αρχείου: $1", diff --git a/languages/i18n/en.json b/languages/i18n/en.json index bc35c9e02c..d350e3fdd0 100644 --- a/languages/i18n/en.json +++ b/languages/i18n/en.json @@ -1799,6 +1799,7 @@ "http-timed-out": "HTTP request timed out.", "http-curl-error": "Error fetching URL: $1", "http-bad-status": "There was a problem during the HTTP request: $1 $2", + "http-internal-error": "HTTP internal error.", "upload-curl-error6": "Could not reach URL", "upload-curl-error6-text": "The URL provided could not be reached.\nPlease double-check that the URL is correct and the site is up.", "upload-curl-error28": "Upload timeout", diff --git a/languages/i18n/eo.json b/languages/i18n/eo.json index bf4dc22ad3..8348065782 100644 --- a/languages/i18n/eo.json +++ b/languages/i18n/eo.json @@ -2750,8 +2750,6 @@ "markedaspatrollederrornotify": "Malsukcesis marki la dosieron kiel patrolatan.", "patrol-log-page": "Protokolo pri patrolado", "patrol-log-header": "Jen protokolo de patrolitaj versioj.", - "log-show-hide-patrol": "$1 protokolo pri patrolado", - "log-show-hide-tag": "$1 etikedan protokolon", "confirm-markpatrolled-button": "Ek!", "confirm-markpatrolled-top": "Marki version $3 el $2 kiel patrolita?", "deletedrevision": "Forigita malnova versio $1", diff --git a/languages/i18n/es.json b/languages/i18n/es.json index 39598261e1..82eb62aa7a 100644 --- a/languages/i18n/es.json +++ b/languages/i18n/es.json @@ -169,7 +169,9 @@ "Athena in Wonderland", "Truebamateo", "La Mantis", - "Amaia" + "Amaia", + "Tiberius1701", + "Astroemi" ] }, "tog-underline": "Subrayar los enlaces:", @@ -495,7 +497,7 @@ "title-invalid-interwiki": "El título de página solicitado contiene un enlace interwiki que no se puede usar en los títulos.", "title-invalid-talk-namespace": "El título de la página solicitada apunta a una página de discusión imposible.", "title-invalid-characters": "El título de la página solicitada contiene caracteres no válidos: \"$1\".", - "title-invalid-relative": "El título contiene una ruta relativa. Los títulos relativos (./, ../) no son válidos porque a menudo no los pueden manejar los navegadores web.", + "title-invalid-relative": "El título contiene una ruta relativa. Los títulos relativos (./, ../) no son válidos porque a menudo no los pueden manipular los navegadores web.", "title-invalid-magic-tilde": "El título de la página solicitada contiene una secuencia de virgulillas no válida (~~~).", "title-invalid-too-long": "El título de la página solicitada es muy largo. No debe exceder $1 {{PLURAL:$1|byte|bytes}} en codificación UTF-8.", "title-invalid-leading-colon": "El título de la página solicitada contiene un caracater (:) no válido en el comienzo.", @@ -1073,6 +1075,8 @@ "diff-paragraph-moved-toold": "Se trasladó el párrafo. Pulsa para saltar a la ubicación anterior.", "difference-missing-revision": "No se {{PLURAL:$2|ha encontrado una revisión|han encontrado $2 revisiones}} de la comparación solicitada ($1).\n\nLa causa de esto suele ser un enlace obsoleto hacia una edición de una página que ha sido borrada.\nPara más información, consulta el [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} registro de borrados].", "searchresults": "Resultados de la búsqueda", + "search-filter-title-prefix": "Buscar solo en las páginas cuyos títulos comiencen por «$1»", + "search-filter-title-prefix-reset": "Buscar en todas las páginas", "searchresults-title": "Resultados de la búsqueda de «$1»", "titlematches": "Resultados por título de página", "textmatches": "Resultados por texto de página", @@ -1598,7 +1602,7 @@ "rcfilters-watchlist-edit-watchlist-button": "Edita tu lista de seguimiento", "rcfilters-watchlist-showupdated": "Los cambios hechos a páginas que no has visitado desde que se efectuaron aparecen en negrita, acompañados de marcadores sólidos.", "rcfilters-preference-label": "Ocultar la versión mejorada de Cambios recientes", - "rcfilters-preference-help": "Revierte el rediseño de interfaz de 2017 y desactiva todas las herramientas añadidas desde entonces.", + "rcfilters-preference-help": "Revierte el rediseño de interfaz de 2017 e indisponibiliza todas las herramientas añadidas desde entonces.", "rcfilters-watchlist-preference-label": "Ocultar la versión mejorada de la lista de seguimiento", "rcfilters-watchlist-preference-help": "Revierte el rediseño de la interfaz de 2017 e indisponibiliza todas las herramientas añadidas desde entonces.", "rcfilters-filter-showlinkedfrom-label": "Mostrar cambios en páginas enlazadas desde", @@ -1845,7 +1849,7 @@ "uploadstash-bad-path-invalid": "La ruta no es válida.", "uploadstash-bad-path-unknown-type": "El tipo «$1» es desconocido.", "uploadstash-bad-path-unrecognized-thumb-name": "No se reconoce el nombre de la miniatura.", - "uploadstash-bad-path-no-handler": "No se encontró ningún manejador para el MIME $1 del archivo $2.", + "uploadstash-bad-path-no-handler": "No se encontró ningún manipulador para el MIME $1 del archivo $2.", "uploadstash-bad-path-bad-format": "El formato de la clave «$1» es incorrecto.", "uploadstash-file-not-found": "No se encuentra la clave «$1» en el almacén provisional.", "uploadstash-file-not-found-no-thumb": "No se pudo obtener la miniatura.", @@ -1878,6 +1882,7 @@ "http-timed-out": "La solicitud HTTP ha expirado.", "http-curl-error": "Error al recuperar el URL: $1", "http-bad-status": "Ha habido un problema durante la solicitud HTTP: $1 $2", + "http-internal-error": "Error interno de HTTP.", "upload-curl-error6": "No se pudo alcanzar la URL", "upload-curl-error6-text": "La URL no pudo ser alcanzada. Por favor comprueba que la URL es correcta y el sitio web está funcionando.", "upload-curl-error28": "Tiempo de espera excedido", @@ -2169,7 +2174,7 @@ "speciallogtitlelabel": "Objetivo (título o {{ns:user}}:nombre de usuario):", "log": "Registros", "logeventslist-submit": "Mostrar", - "logeventslist-more-filters": "Más filtros:", + "logeventslist-more-filters": "Mostrar registros adicionales:", "logeventslist-patrol-log": "Registro de revisiones", "logeventslist-tag-log": "Registro de etiquetas", "all-logs-page": "Todos los registros públicos", @@ -3027,8 +3032,6 @@ "markedaspatrollederrornotify": "Error al marcar como verificado.", "patrol-log-page": "Registro de revisiones", "patrol-log-header": "Este es un registro de revisiones verificadas.", - "log-show-hide-patrol": "$1 registro de verificación", - "log-show-hide-tag": "$1 registro de etiquetas", "confirm-markpatrolled-button": "Aceptar", "confirm-markpatrolled-top": "¿Marcar la revisión $3 de $2 como verificada?", "deletedrevision": "Borrada revisión antigua $1", @@ -3541,7 +3544,7 @@ "watchlistedit-raw-removed": "{{PLURAL:$1|Una página ha sido borrada|$1 páginas han sido borradas}}:", "watchlistedit-clear-title": "Vaciar la lista de seguimiento", "watchlistedit-clear-legend": "Vaciar la lista de seguimiento", - "watchlistedit-clear-explain": "Todos los títulos serán eliminados de tu lista de seguimiento", + "watchlistedit-clear-explain": "Se quitarán todos los títulos de la lista de seguimiento", "watchlistedit-clear-titles": "Títulos:", "watchlistedit-clear-submit": "Vaciar la lista de seguimiento (¡permanente!)", "watchlistedit-clear-done": "Se ha vaciado tu lista de seguimiento.", @@ -3567,7 +3570,7 @@ "version-editors": "Editores", "version-antispam": "Prevención de spam", "version-other": "Otro", - "version-mediahandlers": "Manejadores multimedia", + "version-mediahandlers": "Manipuladores multimedia", "version-hooks": "Extensiones", "version-parser-extensiontags": "Etiquetas de extensiones sintácticas", "version-parser-function-hooks": "Extensiones de funciones sintácticas", diff --git a/languages/i18n/et.json b/languages/i18n/et.json index 74c4d97a25..a4ff0fb47a 100644 --- a/languages/i18n/et.json +++ b/languages/i18n/et.json @@ -2878,8 +2878,6 @@ "markedaspatrollederrornotify": "Kontrollituks märkimine ebaõnnestus.", "patrol-log-page": "Kontrollimislogi", "patrol-log-header": "See on kontrollitud redaktsioonide logi.", - "log-show-hide-patrol": "$1 kontrollimislogi", - "log-show-hide-tag": "$1 märgiste logi", "confirm-markpatrolled-button": "Sobib", "confirm-markpatrolled-top": "Kas märgid lehekülje $2 redaktsiooni $3 kontrollituks?", "deletedrevision": "Kustutatud vanem versioon $1", diff --git a/languages/i18n/eu.json b/languages/i18n/eu.json index c54705617b..97ce51e964 100644 --- a/languages/i18n/eu.json +++ b/languages/i18n/eu.json @@ -936,6 +936,8 @@ "diff-paragraph-moved-toold": "Paragrafoa mugitu egin da. Egin klik aurretiko kokalekura salto egiteko.", "difference-missing-revision": " ($1) ezberdinatasunaren {{PLURAL:$2|Berrikusketa bat|$2 berrikusketa}} ez {{PLURAL:$2|da|dira}} aurkitu.\n\nHau, orokorrean ezabatu egin den orri batera deskonektatua dagoen esteka desegonkor baten ondorioz gertatzen da.\n\nHemen xehetasunak aurki daitezke: [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} deletion log].", "searchresults": "Bilaketaren emaitzak", + "search-filter-title-prefix": "\"$1\" hasiera duten orriak bakarrik bilatzen", + "search-filter-title-prefix-reset": "Orri guztiak bilatu", "searchresults-title": "«$1» bilaketaren emaitzak", "titlematches": "Emaitzak artikuluen izenburuetan", "textmatches": "Emaitza orrialde testuetan", @@ -2031,7 +2033,8 @@ "speciallogtitlelabel": "Helburua (izenburua edo {{ns:user}}: lankidea):", "log": "Erregistroak", "logeventslist-submit": "Erakutsi", - "logeventslist-more-filters": "Iragazki gehiago:", + "logeventslist-more-filters": "Erakutsi erregistro gehiago:", + "logeventslist-tag-log": "Etiketen erregistroa", "all-logs-page": "Erregistro publiko guztiak", "alllogstext": "{{SITENAME}} orrialdearen erregistro guztien erakusketa konbinatua.\nErregistro mota, erabiltzailearen izena edota orrialdearen izena iragaziz bistaratu daiteke. Letra larriak eta xeheak bereizten dira.", "logempty": "Ez dago emaitzarik erregistroan.", @@ -2874,8 +2877,6 @@ "markedaspatrollederrornotify": "Patruilatu gisa markatzean akatsa egon da.", "patrol-log-page": "Patrullatze loga", "patrol-log-header": "Hau patruliatutako aldaketen log bat da.", - "log-show-hide-patrol": "$1 patruilatze loga", - "log-show-hide-tag": "$1 etiketa erregistroa", "confirm-markpatrolled-button": "Ados", "confirm-markpatrolled-top": "$2ren $3 berrikusketa patruilatu bezala markatu?", "deletedrevision": "$1 berrikuspen zaharra ezabatu da", diff --git a/languages/i18n/fa.json b/languages/i18n/fa.json index 3eb42f9905..329a19c0f8 100644 --- a/languages/i18n/fa.json +++ b/languages/i18n/fa.json @@ -2882,8 +2882,6 @@ "markedaspatrollederrornotify": "زدن برچسب گشت، ناموفق بود.", "patrol-log-page": "سیاههٔ گشت", "patrol-log-header": "این سیاهه‌ای از ویرایش‌های گشت‌خورده است.", - "log-show-hide-patrol": "$1 سیاههٔ گشت‌زنی", - "log-show-hide-tag": "$1 سیاهه برچسب", "confirm-markpatrolled-button": "تأیید", "confirm-markpatrolled-top": "نسخهٔ $3 از $2 علامت گشت بخورد؟", "deletedrevision": "$1 نسخهٔ حذف شدهٔ قدیمی", diff --git a/languages/i18n/fi.json b/languages/i18n/fi.json index 5ae033967b..57a0bd03de 100644 --- a/languages/i18n/fi.json +++ b/languages/i18n/fi.json @@ -962,6 +962,8 @@ "diff-paragraph-moved-toold": "Kappale siirrettiin. Klikkaa hypätäksesi vanhaan sijaintiin.", "difference-missing-revision": "{{PLURAL:$2|Yhtä versiota|$2 versiota}} tästä vertailusta ($1) {{PLURAL:$2|ei}} löytynyt.\n\nUseimmiten tämä johtuu vanhentuneesta vertailulinkistä poistettuun sivuun.\nLisätietoja löytyy [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} poistolokista].", "searchresults": "Hakutulokset", + "search-filter-title-prefix": "Haetaan vain sivuista, joiden otsikko alkaa \"$1\"", + "search-filter-title-prefix-reset": "Hae kaikista sivuista", "searchresults-title": "Haun tulokset hakusanalle ”$1”", "titlematches": "Osumat sivujen otsikoissa", "textmatches": "Osumat sivujen teksteissä", @@ -1050,9 +1052,9 @@ "stub-threshold": "Tynkälinkkien muotoilun kynnysarvo ($1):", "stub-threshold-sample-link": "näyte", "stub-threshold-disabled": "Ei käytössä", - "recentchangesdays": "Näytettävien päivien määrä tuoreissa muutoksissa", + "recentchangesdays": "Näytettävien päivien määrä tuoreissa muutoksissa:", "recentchangesdays-max": "Enintään $1 {{PLURAL:$1|päivä|päivää}}", - "recentchangescount": "Näytettävien muutoksien määrä tuoreissa muutoksissa, sivujen historioissa ja logeissa oletuksena", + "recentchangescount": "Näytettävien muutoksien määrä tuoreissa muutoksissa, sivuhistorioissa ja lokeissa oletusarvoisesti:", "prefs-help-recentchangescount": "Maksimiluku 1000", "prefs-help-watchlist-token2": "Tämä on salainen avain tarkkailulistasi verkkosyötteeseen.\nKuka tahansa, joka tietää sen voi lukea tarkkailulistaasi, joten älä paljasta sitä.\nJos sinun täytyy, [[Special:ResetTokens|voit uudistaa sen]].", "prefs-help-tokenmanagement": "Voit nähdä ja nollata tilisi salaisen avaimen, jota käyttämällä pääset katsomaan tarkastuslistasi verkkosyötettä. Kuka tahansa sen tietävä voi lukea tarkkailulistaasi, joten älä paljasta sitä.", @@ -2061,7 +2063,7 @@ "speciallogtitlelabel": "Kohde (sivu tai {{ns:user}}:käyttäjänimi):", "log": "Lokit", "logeventslist-submit": "Näytä", - "logeventslist-more-filters": "Lisää suodattimia:", + "logeventslist-more-filters": "Näytä lisää lokeja:", "logeventslist-patrol-log": "Partiointiloki", "logeventslist-tag-log": "Merkkausloki", "all-logs-page": "Kaikki julkiset lokit", @@ -2417,7 +2419,7 @@ "uctop": "(uusin)", "month": "Alkaen kuukaudesta (ja aiemmin):", "year": "Vuosi", - "date": "Alkaen päiväydestä (ja aiemmin):", + "date": "Alkaen päivämäärästä (tai sitä aikaisemmasta):", "sp-contributions-newbies": "Näytä uusien tulokkaiden muutokset", "sp-contributions-newbies-sub": "Uusien käyttäjien muokkaukset", "sp-contributions-newbies-title": "Uusien käyttäjien muokkaukset", @@ -2920,8 +2922,6 @@ "markedaspatrollederrornotify": "Tarkastetuksi merkitseminen epäonnistui.", "patrol-log-page": "Muutostentarkastusloki", "patrol-log-header": "Tämä on loki tarkastetuista muutoksista.", - "log-show-hide-patrol": "$1 muutostentarkastusloki", - "log-show-hide-tag": "$1 merkkausloki", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Merkitäänkö versio $3 kohdesivusta $2 partioiduksi?", "deletedrevision": "Poistettiin vanha versio $1", diff --git a/languages/i18n/fo.json b/languages/i18n/fo.json index 86e2160462..af388a4fc5 100644 --- a/languages/i18n/fo.json +++ b/languages/i18n/fo.json @@ -2085,7 +2085,6 @@ "markedaspatrollederrornotify": "Tað miseydnaðist at merkja sum eftirkannað.", "patrol-log-page": "Eftirlitsloggur", "patrol-log-header": "Hetta er ein loggur yvir patruljeraðum síðuversjónum.", - "log-show-hide-patrol": "$1 patrulleringsloggur", "deletedrevision": "Slettaði gamla síðuversjón $1", "filedeleteerror-short": "Feilur hendi við sletting av fílu: $1", "previousdiff": "← Eldri broytingar", diff --git a/languages/i18n/fr.json b/languages/i18n/fr.json index ab015faa86..f7baf0729b 100644 --- a/languages/i18n/fr.json +++ b/languages/i18n/fr.json @@ -1078,6 +1078,8 @@ "diff-paragraph-moved-toold": "Le paragraphe a été déplacé. Cliquez pour accéder à l'ancien emplacement.", "difference-missing-revision": "{{PLURAL:$2|Une révision|$2 révisions}} de cette différence ($1) {{PLURAL:$2|n’a pas été trouvée|n’ont pas été trouvées}}.\n\nCela survient en général en suivant un lien de différence désuet vers une page qui a été supprimée.\nVous pouvez trouver des détails dans le [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} journal des suppressions].", "searchresults": "Résultats de la recherche", + "search-filter-title-prefix": "Recherche seulement les pages dont le titre commence par « $1 »", + "search-filter-title-prefix-reset": "Rechercher toutes les pages", "searchresults-title": "Résultats de recherche pour « $1 »", "titlematches": "Correspondances dans les titres des pages", "textmatches": "Correspondances dans le texte des pages", @@ -1089,7 +1091,7 @@ "prevn-title": "$1 {{PLURAL:$1|résultat précédent|résultats précédents}}", "nextn-title": "$1 {{PLURAL:$1|résultat suivant|résultats suivants}}", "shown-title": "Afficher $1 résultat{{PLURAL:$1||s}} par page", - "viewprevnext": "Voir ($1 {{int:pipe-separator}} $2) ($3).", + "viewprevnext": "Voir ($1 {{int:pipe-separator}} $2) ($3)", "searchmenu-exists": "Il existe une page nommée « [[:$1]] » sur ce wiki. {{PLURAL:$2|0=|Voyez également les autres résultats de votre recherche.}}", "searchmenu-new": "Créer la page « [[:$1|$1]] » sur ce wiki ! {{PLURAL:$2|0=Voyez également la page trouvée avec votre recherche.|Voyez également les résultats de votre recherche.}}", "searchprofile-articles": "Pages de contenu", @@ -1482,7 +1484,7 @@ "recentchanges-legend-plusminus": "(''±123'')", "recentchanges-submit": "Lister", "rcfilters-tag-remove": "Supprimer « $1 »", - "rcfilters-legend-heading": "Liste des abréviations :", + "rcfilters-legend-heading": "Liste des abréviations : ", "rcfilters-other-review-tools": "Autres outils de relecture", "rcfilters-group-results-by-page": "Grouper les résultats par page", "rcfilters-activefilters": "Filtres actifs", @@ -1890,6 +1892,7 @@ "http-timed-out": "La requête HTTP a expiré.", "http-curl-error": "Erreur lors de la récupération de l'URL : $1", "http-bad-status": "Il y a eu un problème lors de la requête HTTP : $1 $2", + "http-internal-error": "Erreur interne HTTP.", "upload-curl-error6": "URL injoignable", "upload-curl-error6-text": "L’URL fournie ne peut pas être atteinte. \nVeuillez vérifier que l’URL est correcte et que le site est en ligne.", "upload-curl-error28": "Dépassement du délai lors de l'import", @@ -2185,7 +2188,7 @@ "speciallogtitlelabel": "Cible (titre ou {{ns:user}}:nom d'utilisateur) :", "log": "Journaux d’opérations", "logeventslist-submit": "Lister", - "logeventslist-more-filters": "Davantage de filtres:", + "logeventslist-more-filters": "Afficher des journaux supplémentaires :", "logeventslist-patrol-log": "Journal des relectures", "logeventslist-tag-log": "Journal des balises", "all-logs-page": "Tous les journaux publics", @@ -3045,8 +3048,6 @@ "markedaspatrollederrornotify": "Échec du marquage de la modification comme relue.", "patrol-log-page": "Journal des relectures", "patrol-log-header": "Voici l’historique des versions relues.", - "log-show-hide-patrol": "$1 l’historique des relectures", - "log-show-hide-tag": "$1 le journal des balises", "confirm-markpatrolled-button": "Valider", "confirm-markpatrolled-top": "Marquer la révision $3 de $2 comme relue ?", "deletedrevision": "Ancienne version $1 supprimée", diff --git a/languages/i18n/frp.json b/languages/i18n/frp.json index 0057921fda..b10a3f6ff4 100644 --- a/languages/i18n/frp.json +++ b/languages/i18n/frp.json @@ -2539,8 +2539,6 @@ "markedaspatrollederrornotify": "Falyita du marcâjo du changement coment gouardâ.", "patrol-log-page": "Jornâl de gouârda", "patrol-log-header": "Vê-que un jornâl de les vèrsions gouardâyes.", - "log-show-hide-patrol": "$1 lo jornâl de gouârda", - "log-show-hide-tag": "$1 lo jornâl de les balises", "deletedrevision": "Vielye vèrsion $1 suprimâye", "filedeleteerror-short": "Fôta pendent la suprèssion du fichiér : $1", "filedeleteerror-long": "Des fôtes sont étâyes rencontrâyes pendent la suprèssion du fichiér :\n\n$1", diff --git a/languages/i18n/frr.json b/languages/i18n/frr.json index b69d49c7ce..dffd28bafa 100644 --- a/languages/i18n/frr.json +++ b/languages/i18n/frr.json @@ -2470,8 +2470,6 @@ "markedaspatrollederrornotify": "Det werjuun küd ei üs kontroliaret kääntiakent wurd.", "patrol-log-page": "Kontrol-logbuk", "patrol-log-header": "Det as det kontrol-logbuk.", - "log-show-hide-patrol": "Kontrol-logbuk $1", - "log-show-hide-tag": "Markiarang-logbuk $1", "deletedrevision": "Ual werjuun $1 stregen", "filedeleteerror-short": "Bi't striken faan det datei $1 as wat skiaf gingen.", "filedeleteerror-long": "Bi't striken faan det datei as wat skiaf gingen:\n\n$1", diff --git a/languages/i18n/ga.json b/languages/i18n/ga.json index 07479072bb..703d080e8a 100644 --- a/languages/i18n/ga.json +++ b/languages/i18n/ga.json @@ -1347,7 +1347,6 @@ "rcpatroldisabled": "Mhíchumasaíodh Patról na n-Athruithe is Déanaí", "rcpatroldisabledtext": "Tá an tréith Patról na n-Athruithe is Déanaí míchumasaithe faoi láthair.", "patrol-log-page": "Log phatról", - "log-show-hide-patrol": "$1 log phatról", "deletedrevision": "Scriosadh an seanleagan $1", "filedeleteerror-short": "Earráid comhad a scriosadh: $1", "previousdiff": "← Gabh chuig an difear roimhe seo", diff --git a/languages/i18n/gd.json b/languages/i18n/gd.json index 57cc99641b..9bdd762089 100644 --- a/languages/i18n/gd.json +++ b/languages/i18n/gd.json @@ -531,6 +531,7 @@ "botpasswords-created-body": "Chaidh am facal-faire bot airson a’ bhot air a bheil “$1” aig a’ chleachdaiche “$2” a chruthachadh.", "botpasswords-updated-title": "Chaidh am facal-faire bot ùrachadh", "resetpass_forbidden": "Cha ghabh na faclan-faire atharrachadh", + "resetpass_forbidden-reason": "Cha ghabh na faclan-faire atharrachadh: $1", "resetpass-no-info": "Feumaidh tu logadh a-steach mus dèan thu inntrigeadh dìreach dhan duilleag seo.", "resetpass-submit-loggedin": "Atharraich am facal-faire", "resetpass-submit-cancel": "Sguir dheth", @@ -540,8 +541,8 @@ "resetpass-temp-password": "Facal-faire sealach:", "resetpass-abort-generic": "Chuir leudachan crìoch air atharrachadh an fhacail-fhaire.", "resetpass-expired": "Dh'fhalbh an ùine air an fhacal-fhaire agad. Suidhich facal-faire ùr airson logadh a-steach.", - "resetpass-expired-soft": "Dh'fhalbh an ùine air an fhacal-fhaire agad is feumaidh tu ath-shuidheachadh. Tagh fear ùr no briog air \"{{int:authprovider-resetpass-skip-label}}\" gus ath-shuidheachadh às a dhèidh seo.", - "resetpass-validity-soft": "Chan eil am facal-faire seo dligheach: $1\n\nTagh facal-faire ùr an-dràsta no briog air \"{{int:authprovider-resetpass-skip-label}}\" gus ath-shuidheachadh às a dhèidh seo.", + "resetpass-expired-soft": "Dh'fhalbh an ùine air an fhacal-fhaire agad is feumaidh tu atharrachadh. Tagh fear ùr no briog air “{{int:authprovider-resetpass-skip-label}}” gus atharrachadh às a dhèidh seo.", + "resetpass-validity-soft": "Chan eil am facal-faire seo dligheach: $1\n\nTagh facal-faire ùr an-dràsta no briog air “{{int:authprovider-resetpass-skip-label}}” gus atharrachadh às a dhèidh seo.", "passwordreset": "Ath-shuidhich am facal-faire", "passwordreset-text-one": "Lìon am foirm seo gus am facal-faire agad ath-shuidheachadh.", "passwordreset-text-many": "Lìon {{PLURAL:$1|an raon|aon dhe na raointean}} gus facal-faire sealach fhaighinn air a' phost-d.", @@ -555,6 +556,12 @@ "passwordreset-emailtext-user": "Dh'iarr an cleachdaiche $1 air {{SITENAME}} ath-shuidheachadh an fhacail-fhaire air {{SITENAME}} ($4). Tha {{PLURAL:$3|an cunntas-cleachdaiche|na cunntasan-cleachdaiche}} a leanas co-cheangailte ris an t-seòladh puist-d seo:\n\n$2\n\nFalbhaidh an ùine air {{PLURAL:$3|an fhacal-fhaire shealach|na faclan-faire sealach}} seo an ceann $5 {{PLURAL:$5|latha|latha|làithean|latha}}.\nBu chòir dhut logadh a-steach agus facal-faire ùr a thaghadh an-dràsta. Ma dh'iarr cuideigin eile seo no ma chuimhnich thu air an fhacal-fhaire agad 's mur eil thu airson atharrachadh tuilleadh, leig seachad an teachdaireachd seo 's lean ort leis an t-seann fhacal-fhaire.", "passwordreset-emailelement": "Ainm-cleachdaiche: \n$1\n\nFacal-faire sealach: \n$2", "passwordreset-emailsentemail": "Ma tha am post-d seo co-cheangailte ris a’ chunntas agad, thèid post-d airson ath-shuidheachadh an fhacail-fhaire a chur.", + "passwordreset-emailsentusername": "Ma tha post-d co-cheangailte ris an ainm-chleachdaiche seo, thèid post-d airson ath-shuidheachadh an fhacail-fhaire a chur.", + "passwordreset-nocaller": "Feumaidh tu gairmear a chur ann", + "passwordreset-nosuchcaller": "Chan eil an gairmear seo ann: $1", + "passwordreset-ignored": "Cha b’ urrainn dhuinn ath-shuidheachadh an fhacail-fhaire a làimhseachadh. Dh’fhaoidte nach deach solaraiche a rèiteachadh.", + "passwordreset-invalidemail": "Seòladh puist-d mì-dhligheach", + "passwordreset-nodata": "Cha deach ainm-cleachdaiche no seòladh puist-d a thoirt seachad", "changeemail": "Atharraich no thoir air falbh an seòladh puist-d", "changeemail-header": "Lìon am foirm seo a dh’atharrachadh an t-seòlaidh phuist-d agad. Ma tha thu airson an co-cheangal eadar post-d sam bith is an cunntas agad a thoirt air falbh, fàg an seòladh ùr bàn nuair a chuireas tu am foirm.", "changeemail-no-info": "Feumaidh tu logadh a-steach mus dèan thu inntrigeadh dìreach dhan duilleag seo.", @@ -564,6 +571,7 @@ "changeemail-password": "Am facal-faire agad air {{SITENAME}}:", "changeemail-submit": "Atharraich am post-d", "changeemail-throttled": "Dh'fheuch thu ri logadh a-steach ro thric.\nFuirich ort $1 mus feuch thu ris a-rithist.", + "changeemail-nochange": "Cuir a-steach post-d ùr eile.", "resettokens": "Ath-shuidhich na tòcanan", "resettokens-text": "'S urrainn dhut tòcanan ath-shuidheachadh a bheir cothrom dhut air cuid a dhàta prìobhaideach a tha co-cheangailte ris a' chunntas agad.\n\nBu chòir dhut seo a dhèanamh ma thug thu do chuideigin e air mhearachd no ma bhris cuideigin a-steach air a' chunntas agad.", "resettokens-no-tokens": "Chan eil tòcan ann a ghabhas ath-shuidheachadh.", @@ -598,6 +606,10 @@ "savechanges": "Sàbhail na dh’atharraich thu", "publishpage": "Foillsich an duilleag", "publishchanges": "Foillsich na mùthaidhean", + "savearticle-start": "Sàbhail an duilleag...", + "savechanges-start": "Sàbhail na h-atharraichean...", + "publishpage-start": "Foillsich an duilleag...", + "publishchanges-start": "Foillsich na mùthaidhean...", "preview": "Ro-shealladh", "showpreview": "Seall an ro-shealladh", "showdiff": "Seall na mùthaidhean", @@ -606,12 +618,13 @@ "anonpreviewwarning": "Chan eil thu air logadh a-steach. Ma nì thu sàbhaladh, thèid an seòladh IP agad a chlàradh ann an eachdraidh deasachadh na duilleige seo.", "missingsummary": "Cuimhnich: Cha dug thu seachad gearr-chunntas air na dh'atharraich thu.\nMa bhriogas tu air \"$1\" a-rithist, thèid na dheasaich thu a shàbhaladh as aonais gearr-chunntais.", "selfredirect": "Rabhadh: Tha thu ag ath-stiùireadh duilleag dha fhèin.\nDh'fhaoidte gun do shònraich thu an t-amas cearr airson an ath-stiùiridh no gu bheil thu a' deasachadh an duilleag cearr.\nMa nì thu briogadh air \"$1\" a-rithist,m thèid an ath-stiùireadh a chruthachadh co-dhiù.", - "missingcommenttext": "Cuir a-steach beachd gu h-ìosal.", + "missingcommenttext": "Cuir a-steach beachd.", "missingcommentheader": "Cuimhnich: Cha dug thu seachad cuspair airson a’ bheachd seo.\nMa bhriogas tu air “$1” a-rithist, thèid na dheasaich thu a shàbhaladh as aonais.", - "summary-preview": "Ro-shealladh a' ghearr-chunntais:", + "summary-preview": "Ro-shealladh gearr-chunntas an deasachaidh:", "subject-preview": "Ro-shealladh a’ chuspair:", + "previewerrortext": "Thachair mearachd fhad ’s a bha sinn airson ro-shealladh nan atharraichean a shealltainn dhut.", "blockedtitle": "Tha an cleachdair air a bhacadh", - "blockedtext": "Chaidh an t-ainm-cleachdaiche no an seòladh IP agad a bhacadh.\n\n'S e $1 a chur am bacadh seo ort.\n{{GENDER:$1|Thug e|Thug i|Thugadh}} an cèill gun do {{GENDER:$1|rinn e|rinn i|rinneadh}} sin air sgàth an adhbhair seo: $2.\n\n* Toiseach a' bhacaidh: $8\n* Deireadh a' bhacaidh: $6\n* An neach air a bheil am bacadh: $7\n\n'S urrainn dhut fios a chur gu $1 no [[{{MediaWiki:Grouppage-sysop}}|rianair]] eile gus am bacadh seo a dheasbad.\nChan urrainn dhut am feart \"Cuir post-d dhan chleachdaiche seo\" a chleachdadh ach ma tha seòladh puist-d dligheach ann an [[Special:Preferences|roghainnean a' chunntais agad]] agus mura deach bacadh a chur air a chleachdadh.\n'S e $3 an seòladh IP làithreach agus agus 's e #$5 ID a' bhacaidh.\nThoir iomradh air a' mhion-fhiosrachadh gu h-àrd ma chuireas tu ceist sam bith mu dhèidhinn.", + "blockedtext": "Chaidh an t-ainm-cleachdaiche no an seòladh IP agad a bhacadh.\n\n’S e $1 a chur am bacadh seo ort.\n’S e “$2” an t-adbhar a thug iad.\n\n* Toiseach a’ bhacaidh: $8\n* Deireadh a’ bhacaidh: $6\n* An neach air a bheil am bacadh: $7\n\n’S urrainn dhut fios a chur gu $1 no [[{{MediaWiki:Grouppage-sysop}}|rianaire]] eile gus am bacadh seo a dheasbad.\nChan urrainn dhut an gleus “Cuir post-d dhan chleachdaiche seo” a chleachdadh ach ma tha seòladh puist-d dligheach ann an [[Special:Preferences|roghainnean a’ chunntais agad]] agus mura deach bacadh a chur air a chleachdadh.\n’S e $3 an seòladh IP làithreach agus agus ’s e #$5 ID a’ bhacaidh.\nThoir iomradh air a’ mhion-fhiosrachadh gu h-àrd ma chuireas tu ceist sam bith mu dhèidhinn.", "autoblockedtext": "Chaidh an seòladh IP agad a bhacadh gu fèin-obrachail a chionn 's gun deach a chleachdadh le cuideigin eile a chaidh a bhacadh le $1.\n{{GENDER:$1|Thug e|Thug i|Thugadh}} an cèill gun do {{GENDER:$1|rinn e|rinn i|rinneadh}} sin air sgàth an adhbhair seo: \n\n:$2.\n\n* Toiseach a' bhacaidh: $8\n* Deireadh a' bhacaidh: $6\n* An neach air a bheil am bacadh: $7\n\n'S urrainn dhut fios a chur gu $1 no [[{{MediaWiki:Grouppage-sysop}}|rianair]] eile gus am bacadh seo a dheasbad.\n\nDh'fhaoidte nach urrainn dhut am feart \"Cuir post-d dhan chleachdaiche seo\" a chleachdadh ach ma tha seòladh puist-d dligheach ann an [[Special:Preferences|roghainnean a' chunntais agad]] agus mura deach bacadh a chur air a chleachdadh.\n\n'S e $3 an seòladh IP làithreach agus agus 's e #$5 ID a' bhacaidh.\nThoir iomradh air a' mhion-fhiosrachadh gu h-àrd ma chuireas tu ceist sam bith mu dhèidhinn.", "blockednoreason": "cha deach adhbhar a shònrachadh", "whitelistedittext": "Feumaidh tu $1 mus urrainn dhut duilleagan a dheasachadh.", @@ -1192,6 +1205,7 @@ "recentchanges-legend-heading": "Treòir:", "recentchanges-legend-newpage": "{{int:recentchanges-label-newpage}} (faic [[Special:NewPages|liosta nan duilleagan ùra]] cuideachd)", "recentchanges-legend-plusminus": "(±123)", + "rcfilters-legend-heading": "Liosta nan giorrachaidhean:", "rcfilters-activefilters": "Criathragan gnìomhach", "rcfilters-activefilters-hide": "Falaich", "rcfilters-limit-and-date-label": "$1 {{PLURAL:$1|mhùthadh|mhùthadh|mùthaidhean|mùthadh}}, $2", @@ -1204,6 +1218,29 @@ "rcfilters-filterlist-whatsthis": "Ciamar a dh’obraicheas iad seo?", "rcfilters-highlightbutton-title": "Soillsich toraidhean", "rcfilters-filterlist-noresults": "Cha do lorg sinn criathrag", + "rcfilters-filter-editsbyself-label": "Mùthaidhean a rinn thusa", + "rcfilters-filter-editsbyself-description": "Na mùthaidhean a rinn thu fhèin.", + "rcfilters-filter-editsbyother-label": "Mùthaidhean a rinn daoine eile", + "rcfilters-filter-editsbyother-description": "Gach mùthadh ach an fheadhainn agad fhèin.", + "rcfilters-filtergroup-userExpLevel": "Clàradh is eòlas a’ chleachdaiche", + "rcfilters-filter-user-experience-level-registered-label": "Air clàradh a-steach", + "rcfilters-filter-user-experience-level-registered-description": "Deasaichean a rinn clàradh a-steach.", + "rcfilters-filter-user-experience-level-unregistered-label": "Gun chlàradh a-steach", + "rcfilters-filter-user-experience-level-unregistered-description": "Deasaichean nach do rinn clàradh a-steach.", + "rcfilters-filter-user-experience-level-newcomer-label": "Ùranaich", + "rcfilters-filter-user-experience-level-newcomer-description": "Deasaichean a chlàraich a-steach ach a rinn nas lugha na 10 deasachaidhean no aig a bheil nas lugha na 4 làithean de ghnìomhachd.", + "rcfilters-filter-user-experience-level-learner-label": "Luchd-ionnsachaidh", + "rcfilters-filter-user-experience-level-learner-description": "Deasaichean a rinn clàradh a-steach is aig a bheil eòlas eadar feadhainn air ùr-thighinn is feadhainn shàr-eòlach.", + "rcfilters-filter-user-experience-level-experienced-label": "Seann-eòlaich", + "rcfilters-filter-user-experience-level-experienced-description": "Deasaichean a chlàraich a-steach ach a rinn barrachd air 500 deasachadh is aig a bheil barrachd air 30 latha de ghnìomhachd.", + "rcfilters-filtergroup-automated": "Mùthaidhean fèin-obrachail", + "rcfilters-filter-bots-description": "Mùthaidhean a rinn innealan fèin-obrachail.", + "rcfilters-filter-humans-label": "Duine (chan e bot)", + "rcfilters-filter-humans-description": "Deasachaidhean a rinn deasaichean daonna.", + "rcfilters-filtergroup-significance": "Cudromachd", + "rcfilters-filter-minor-label": "Mùthaidhean beaga", + "rcfilters-filter-major-label": "Mùthaichean nach eil beag", + "rcfilters-filter-major-description": "Deasachaidhean ris nach eil comharra gur e deasachadh beag a tha ann.", "rcfilters-filtergroup-watchlistactivity": "Gnìomhachd a’ chlàir-fhaire", "rcfilters-filter-watchlistactivity-unseen-label": "Atharraichean gun choimhead", "rcfilters-filter-watchlistactivity-unseen-description": "Atharraichean air duilleagan air nach do thadhail thu on a chaidh an atharrachadh.", @@ -1214,10 +1251,13 @@ "rcfilters-filter-newpages-description": "Deasachadh a chruthaich duilleag ùr.", "rcfilters-filter-logactions-label": "Gnìomhan logaichte", "rcfilters-filtergroup-lastRevision": "Na mùthaidhean as ùire", + "rcfilters-filter-lastrevision-label": "Am mùthadh mu dheireadh", "rcfilters-filter-lastrevision-description": "Dìreach an t-àtharrachadh as ùire air duilleag.", "rcfilters-liveupdates-button": "Ùrachadh beò", "rcfilters-liveupdates-button-title-off": "Seall atharraichean ùra fhad ’s a thathar gan dèanamh", "rcfilters-watchlist-markseen-button": "Comharraich gun dug thu sùil air gach atharrachadh", + "rcfilters-watchlist-edit-watchlist-button": "Deasaich liosta nan duilleagan air a’ chlàr-fhaire agad", + "rcfilters-watchlist-showupdated": "Tha atharraichean air duilleagan nach do thadhail thu orra on a chaidh an atharrachadh ann an clò trom le comharran soladach.", "rcnotefrom": "Chì thu {{PLURAL:$5|am mùthadh|na mùthaidhean|na mùthaidhean|na mùthaidhean}} o $3 $4 (gu ruige $1 dhiubh) gu h-ìosal.", "rclistfrom": "Seall na mùthaidhean ùra a-mach o $3 $2", "rcshowhideminor": "$1 mùthaidhean beaga", @@ -1259,7 +1299,7 @@ "recentchangeslinked-feed": "Mùthaidhean buntainneach", "recentchangeslinked-toolbox": "Mùthaidhean buntainneach", "recentchangeslinked-title": "Mùthaidhean co-cheangailte ri \"$1\"", - "recentchangeslinked-summary": "Seo liosta nam mùthaidhean a chaidh a chur air duilleagan a tha a' ceangal o dhuilleag shònraichte (no ri buill ann an roinn-seòrsa sònraichte).\nTha duilleagan air a' [[Special:Watchlist|chlàr-fhaire]] agad ann an litrichean troma.", + "recentchangeslinked-summary": "Cuir a-steach ainm duilleige airson atharraichean fhaicinn air duilleagan a tha a’ ceangal ris an duilleag ud no uaipe. (Airson buill de roinn-seòrsa fhaicinn, cuir a-steach {{ns:category}}:Ainm roinn-seòrsa). Tha atharraichean air duilleagan a tha air a’ [[Special:Watchlist|chlàr-fhaire]] agad ann an clò trom.", "recentchangeslinked-page": "Ainm na duilleige:", "recentchangeslinked-to": "Seall mùthaidhean nan duilleagan a tha a' ceangal ris an duilleag sin 'na àite", "upload": "Luchdaich suas faidhle", @@ -1774,7 +1814,7 @@ "unwatchthispage": "Na cum sùil tuilleadh", "notanarticle": "Chan e duilleag susbaint a tha ann", "notvisiblerev": "Chaidh am mùthadh mu dheireadh le cleachdaiche eile a sguabadh às", - "watchlist-details": "Tha {{PLURAL:$1|$1 duilleag|$1 dhuilleag|$1 duilleagan|$1 duilleag}} air a' chlàr-fhaire agad, gun luaidh air na duilleagan deasbaireachd.", + "watchlist-details": "Tha {{PLURAL:$1|$1 duilleag|$1 dhuilleag|$1 duilleagan|$1 duilleag}} air a’ chlàr-fhaire agad (agus duilleagan deasbaireachd a bharrachd air sin).", "wlheader-enotif": "Tha brathan-naidheachd air a' phost-d an comas.", "wlheader-showupdated": "Tha clò trom air duilleagan a chaidh atharrachadh on turas mu dheireadh a thadhail thu orra.", "wlnote": "Chì thu gu h-ìosal {{PLURAL:$1|a' $1 mhùthadh|an $1 mhùthadh|na $1 mùthaidhean|am $1 mùthadh}} mu dheireadh san {{PLURAL:$2|$2 uair a thìde|$2 uair a thìde|$2 uairean a thìde|$2 uair a thìde}} mu dheireadh, mar a bha e $3, $4.", @@ -2415,7 +2455,6 @@ "markedaspatrollederrornotify": "Cha b' urrainn dhuinn comharra freiceadain a chur ris.", "patrol-log-page": "Loga nam freiceadan", "patrol-log-header": "Seo loga nam mùthaidhean le comharra freiceadain riutha.", - "log-show-hide-patrol": "$1 loga nam freiceadan", "deletedrevision": "Chaidh an seann mhùthadh $1 a sguabadh às", "filedeleteerror-short": "Mearachd a' sguabadh às an fhaidhle: $1", "filedeleteerror-long": "Thachair mearachd le sguabadh às an fhaidhle:\n\n$1", diff --git a/languages/i18n/gl.json b/languages/i18n/gl.json index 3e21a17bb7..13e7581299 100644 --- a/languages/i18n/gl.json +++ b/languages/i18n/gl.json @@ -2908,8 +2908,6 @@ "markedaspatrollederrornotify": "Erro ao marcar como revisada.", "patrol-log-page": "Rexistro de revisións patrulladas", "patrol-log-header": "Este é un rexistro das revisións patrulladas.", - "log-show-hide-patrol": "$1 o rexistro de patrullas", - "log-show-hide-tag": "$1 o rexistro de etiquetas", "confirm-markpatrolled-button": "Aceptar", "confirm-markpatrolled-top": "Quere marcar a revisión $3 de \"$2\" como patrullada?", "deletedrevision": "Revisión vella e borrada de \"$1\"", diff --git a/languages/i18n/grc.json b/languages/i18n/grc.json index 494289f814..4b224c26a0 100644 --- a/languages/i18n/grc.json +++ b/languages/i18n/grc.json @@ -1611,7 +1611,6 @@ "markedaspatrollederrortext": "Δεῖ σε ὁρίσειν ἀναθεώρησιν τινὰ ἵνα σεσημασμένη αὕτη ᾖ ὡς περιπολουμένη.", "patrol-log-page": "Κατάλογος περιπόλων", "patrol-log-header": "Ὅδε ἐστὶ κατάλογος περιπολουμένων ἀναθεωρήσεων.", - "log-show-hide-patrol": "$1 κατάλογος περιπόλου", "deletedrevision": "Προτέρα ἔκδοσις διαγραφεῖσα $1", "filedeleteerror-short": "Ἀρχεῖον διαγράφον σφάλματα: $1", "filedeleteerror-long": "Σφάλματα ἀπαντἠθησαν ἐν τῷ διαγράφειν τὸ ἀρχεῖον:\n\n$1", diff --git a/languages/i18n/gsw.json b/languages/i18n/gsw.json index b90745426c..7554e128d6 100644 --- a/languages/i18n/gsw.json +++ b/languages/i18n/gsw.json @@ -2426,8 +2426,6 @@ "markedaspatrollederrornotify": "D Markierig als kontrolliert isch nid glunge.", "patrol-log-page": "Kontroll-Logbuech", "patrol-log-header": "Des isch s Kontroll-Logbuech.", - "log-show-hide-patrol": "Kontroll-Logbuech $1", - "log-show-hide-tag": "Markierigs-Logbuech $1", "deletedrevision": "alti Version: $1", "filedeleteerror-short": "Fähler bi dr Datei-Leschig: $1", "filedeleteerror-long": "Bi dr Datei-Leschig sin Fähler feschtgstellt wore:\n\n$1", diff --git a/languages/i18n/gu.json b/languages/i18n/gu.json index eaa92e2d40..d5d9435bb8 100644 --- a/languages/i18n/gu.json +++ b/languages/i18n/gu.json @@ -2244,7 +2244,6 @@ "markedaspatrollederror-noautopatrol": "તમે તમારા પોતાના ફેરફારોને નીરીક્ષિત અંકિત ન કરી શકો", "patrol-log-page": "ચકાસણી લોગ", "patrol-log-header": "આ નીરીક્ષિત ફેરફાઓનો લોગ છે", - "log-show-hide-patrol": "$1 ચકાસણી લોગ", "deletedrevision": "જુના સુધારા ભૂસો $1", "filedeleteerror-short": "ફાઇલ : $1 ભૂંસવામાં તૃટિ", "filedeleteerror-long": "$1 આ ફાઈલ ભૂંસતી વખતે ચૂક થઈ", diff --git a/languages/i18n/he.json b/languages/i18n/he.json index d617622596..0dd4a4981b 100644 --- a/languages/i18n/he.json +++ b/languages/i18n/he.json @@ -940,6 +940,8 @@ "diff-paragraph-moved-toold": "הפסקה הועברה. ניתן ללחוץ כאן כדי לעבור למיקומה הישן.", "difference-missing-revision": "{{PLURAL:$2|גרסה אחת|$2 גרסאות}} מתוך הגרסאות שביקשת להשוות ($1) {{PLURAL:$2|לא נמצאה|לא נמצאו}}.\n\nזה נגרם בדרך־כלל עקב לחיצה על קישור ישן להבדלים בין גרסאות של דף שנמחק.\nאפשר למצוא פרטים ב[{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} יומן המחיקות].", "searchresults": "תוצאות החיפוש", + "search-filter-title-prefix": "חיפוש רק בדפים ששמם מתחיל ב\"$1\"", + "search-filter-title-prefix-reset": "חיפוש בכל הדפים", "searchresults-title": "תוצאות החיפוש \"$1\"", "titlematches": "כותרות דפים תואמות", "textmatches": "דפים עם תוכן תואם", @@ -2040,7 +2042,7 @@ "speciallogtitlelabel": "יעד (שם הדף, או \"{{ns:user}}:שם\" עבור משתמש):", "log": "יומנים", "logeventslist-submit": "הצגה", - "logeventslist-more-filters": "מסננים נוספים:", + "logeventslist-more-filters": "הצגת יומנים נוספים:", "logeventslist-patrol-log": "יומן שינויים בדוקים", "logeventslist-tag-log": "יומן תגיות", "all-logs-page": "כל היומנים הציבוריים", @@ -2899,8 +2901,6 @@ "markedaspatrollederrornotify": "סימון השינוי כבדוק נכשל.", "patrol-log-page": "יומן שינויים בדוקים", "patrol-log-header": "יומן זה מציג גרסאות שנבדקו.", - "log-show-hide-patrol": "$1 יומן שינויים בדוקים", - "log-show-hide-tag": "$1 יומן תגיות", "confirm-markpatrolled-button": "אישור", "confirm-markpatrolled-top": "לסמן את גרסה $3 בדף $2 כבדוקה?", "deletedrevision": "מחיקת גרסה ישנה ($1)", diff --git a/languages/i18n/hi.json b/languages/i18n/hi.json index 62b8ba6416..d290292794 100644 --- a/languages/i18n/hi.json +++ b/languages/i18n/hi.json @@ -2921,8 +2921,6 @@ "markedaspatrollederrornotify": "जाँचा हुआ चिन्हित करना असफल रहा।", "patrol-log-page": "परीक्षण लॉग", "patrol-log-header": "यह परीक्षित अवतरणों की लॉग है।", - "log-show-hide-patrol": "परीक्षण लॉग $1", - "log-show-hide-tag": "$1 टैग लॉग", "confirm-markpatrolled-button": "ठीक है", "confirm-markpatrolled-top": "$2 के $3 संशोधन को परीक्षित चिन्ह्नत करे?", "deletedrevision": "पुराना अवतरण $1 हटा दिया", diff --git a/languages/i18n/hif-latn.json b/languages/i18n/hif-latn.json index abd9720df9..bce4509b44 100644 --- a/languages/i18n/hif-latn.json +++ b/languages/i18n/hif-latn.json @@ -2747,8 +2747,6 @@ "markedaspatrollederrornotify": "Patrolled mark kare ke kosis fail hoe gais hae.", "patrol-log-page": "Pahraa de waala suchi", "patrol-log-header": "Ii pahraa dewa gais badlao ke suchi hai.", - "log-show-hide-patrol": "$1 pahraa de waala suchi", - "log-show-hide-tag": "$1 tag log", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Mark karo ki ii revision $3 of $2 patrolled hai?", "deletedrevision": "Purana badlao ke mitae dia hai $1", diff --git a/languages/i18n/hr.json b/languages/i18n/hr.json index 013c0b1217..dc678af6c7 100644 --- a/languages/i18n/hr.json +++ b/languages/i18n/hr.json @@ -1874,10 +1874,13 @@ "magiclink-tracking-pmid-desc": "Ova stranica rabi čarobne PMID poveznice. Za njihovu migraciju vidi [https://www.mediawiki.org/wiki/Special:MyLanguage/Help:Magic_links mediawiki.org].", "magiclink-tracking-isbn": "Stranice s čarobnim ISBN poveznicama", "magiclink-tracking-isbn-desc": "Ova stranica rabi čarobne ISBN poveznice. Za njihovu migraciju vidi [https://www.mediawiki.org/wiki/Special:MyLanguage/Help:Magic_links mediawiki.org].", - "specialloguserlabel": "Suradnik:", - "speciallogtitlelabel": "Cilj (naslov ili {{ns:user}}:suradničko ime):", + "specialloguserlabel": "IzvrÅ¡itelj:", + "speciallogtitlelabel": "Cilj (naslov ili {{ns:user}}:suradničko ime za suradnika):", "log": "Evidencije", "logeventslist-submit": "Prikaži", + "logeventslist-more-filters": "Prikaži dodatne evidencije:", + "logeventslist-patrol-log": "Evidencija ophodnje", + "logeventslist-tag-log": "Evidencija oznaka", "all-logs-page": "Sve javne evidencije", "alllogstext": "Skupni prikaz svih dostupnih evidencija projekta {{SITENAME}}.\nMožete suziti prikaz odabirući tip evidencije, suradničko ime ili stranicu u upitu.", "logempty": "Nema pronađenih stavki u evidenciji.", @@ -2062,6 +2065,7 @@ "dellogpage": "Evidencija brisanja", "dellogpagetext": "Dolje je popis nedavnih brisanja.\nSva vremena su prema poslužiteljevom vremenu.", "deletionlog": "evidencija brisanja", + "log-name-create": "Evidencija stvaranja stranica", "logentry-create-create": "$1 {{GENDER:$2|stvorio|stvorila}} je stranicu $3", "reverted": "Vraćeno na prijaÅ¡nju inačicu", "deletecomment": "Razlog:", @@ -2217,6 +2221,7 @@ "uctop": "(vrh)", "month": "Od mjeseca (i ranije):", "year": "Od godine (i ranije):", + "date": "Do nadnevka (i prije):", "sp-contributions-newbies": "Prikaži samo doprinose novih suradnika", "sp-contributions-newbies-sub": "Za nove suradnike", "sp-contributions-newbies-title": "Doprinosi novih suradnika", @@ -2676,8 +2681,6 @@ "markedaspatrollederrornotify": "Označavanje stranice pregledanom nije uspjelo.", "patrol-log-page": "Evidencija ophodnji i samoophodnji", "patrol-log-header": "Ovo su evidencije ophođenih izmjena.", - "log-show-hide-patrol": "$1 evidenciju ophodnji", - "log-show-hide-tag": "$1 evidenciju oznaka", "confirm-markpatrolled-button": "U redu", "confirm-markpatrolled-top": "Označiti izmjenu $3 stranice $2 pregledanom?", "deletedrevision": "izbrisana stara inačica $1", diff --git a/languages/i18n/hrx.json b/languages/i18n/hrx.json index 4290382f04..8b28e9f2f2 100644 --- a/languages/i18n/hrx.json +++ b/languages/i18n/hrx.json @@ -2219,7 +2219,6 @@ "markedaspatrollederrornotify": "Der Versuch, die Version als wie kontrolliert se markiere, ist fehlgeschlooht.", "patrol-log-page": "Kontroll-Logbuch", "patrol-log-header": "Das ist das Kontroll-Logbuch.", - "log-show-hide-patrol": "Kontroll-Logbuch $1", "deletedrevision": "alte Version $1 abgewischt", "filedeleteerror-short": "Fehler bei Datei-Abwäsch: $1", "filedeleteerror-long": "Bei der Datei-Abwischung woorre Fehler festgestellt:\n\n$1", diff --git a/languages/i18n/hsb.json b/languages/i18n/hsb.json index 814ac0dc4f..f9797613c6 100644 --- a/languages/i18n/hsb.json +++ b/languages/i18n/hsb.json @@ -2415,8 +2415,6 @@ "markedaspatrollederrornotify": "Markěrowanje jako dohladowane je so njeporadźiło.", "patrol-log-page": "Protokol přepruwowanjow", "patrol-log-header": "To je protokol dohladowanych wersijow.", - "log-show-hide-patrol": "Protokol dohladowanja $1", - "log-show-hide-tag": "Protokol markěrowanjow $1", "confirm-markpatrolled-button": "W porjadku", "confirm-markpatrolled-top": "Wersiju $3 strony $2 jako přehladowanu markěrować?", "deletedrevision": "Stara wersija $1 wuÅ¡mórnjena", diff --git a/languages/i18n/hu.json b/languages/i18n/hu.json index 97848de1f0..8552dfc117 100644 --- a/languages/i18n/hu.json +++ b/languages/i18n/hu.json @@ -950,6 +950,8 @@ "diff-paragraph-moved-toold": "A szakaszt áthelyezték. Kattints ide a régi helyére való ugráshoz.", "difference-missing-revision": "Az összehasonlítandó változatok {{PLURAL:$2|egyike ($1) nem található|($1) nem találhatóak}}.\n\nEzt általában egy elavult, törölt oldalra mutató laptörténeti hivatkozás használata okozza. Részletek a [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} törlési naplóban] találhatóak.", "searchresults": "A keresés eredménye", + "search-filter-title-prefix": "Keresés csak olyan lapokban, amelyek címe a következőképp kezdődik: „$1”", + "search-filter-title-prefix-reset": "Keresés az összes lapban", "searchresults-title": "Keresési eredmények: „$1”", "titlematches": "Címbeli egyezések", "textmatches": "Szövegbeli egyezések", @@ -2898,8 +2900,6 @@ "markedaspatrollederrornotify": "Nem sikerült ellenőrzöttnek jelölni.", "patrol-log-page": "Ellenőrzési napló (patrol)", "patrol-log-header": "Ez az ellenőrzött változatok naplója.", - "log-show-hide-patrol": "járőrnapló $1", - "log-show-hide-tag": "címkenapló $1", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Ellenőrzöttnek jelölöd a(z) $2 lap $3 változatát?", "deletedrevision": "Régebbi változat törölve: $1", diff --git a/languages/i18n/ia.json b/languages/i18n/ia.json index 9eed78c2af..48828ae6e6 100644 --- a/languages/i18n/ia.json +++ b/languages/i18n/ia.json @@ -2864,8 +2864,6 @@ "markedaspatrollederrornotify": "Le marcar como patruliate ha fallite.", "patrol-log-page": "Registro de patrulia", "patrol-log-header": "Isto es un registro de versiones patruliate.", - "log-show-hide-patrol": "$1 le registro de versiones patruliate", - "log-show-hide-tag": "$1 registro de etiquettas", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Marcar le version $3 de $2 como patruliate?", "deletedrevision": "Deleva le ancian version $1", diff --git a/languages/i18n/id.json b/languages/i18n/id.json index 0ffc1dd77b..fc966d7917 100644 --- a/languages/i18n/id.json +++ b/languages/i18n/id.json @@ -2884,8 +2884,6 @@ "markedaspatrollederrornotify": "Menandai sebagai terpatroli gagal.", "patrol-log-page": "Log patroli", "patrol-log-header": "Ini adalah log revisi terpatroli.", - "log-show-hide-patrol": "$1 log patroli", - "log-show-hide-tag": "log tag $1", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Tandai revisi $3 dari $2 sebagai terperiksa?", "deletedrevision": "Revisi lama yang dihapus $1", diff --git a/languages/i18n/ilo.json b/languages/i18n/ilo.json index 269e7a0738..e174f147e6 100644 --- a/languages/i18n/ilo.json +++ b/languages/i18n/ilo.json @@ -2793,8 +2793,6 @@ "markedaspatrollederrornotify": "Ti panagmarka a kas napatruliaan ket napaay.", "patrol-log-page": "Listaan ti napatruliaan", "patrol-log-header": "Daytoy ket listaan dagiti napatruliaan a rebision.", - "log-show-hide-patrol": "$1 listaan ti napatruliaan", - "log-show-hide-tag": "$1 ti listaan ti etiketa", "confirm-markpatrolled-button": "Sige", "confirm-markpatrolled-top": "Markaan ti rebision $3 iti $2 a kas napatruliaan?", "deletedrevision": "Naikkat a daan a rebision ti $1", diff --git a/languages/i18n/inh.json b/languages/i18n/inh.json index 01fc2fd982..9b87ad7ae0 100644 --- a/languages/i18n/inh.json +++ b/languages/i18n/inh.json @@ -1181,8 +1181,6 @@ "pageinfo-contentpage": "Счётчико чулацаме оагIув санна лоархI", "pageinfo-contentpage-yes": "XIаа", "patrol-log-page": "ТӀахьожама тептар", - "log-show-hide-patrol": "$1 патрул яра тептар", - "log-show-hide-tag": "$1 фостий тептар", "previousdiff": "← КъаьнагIа дола нийсдаьр", "nextdiff": "КердагӀа дола нийсдаьр →", "imagemaxsize": "Сурта боарамá доазув тохар:
''(Файлах лаьца дувцача оагӀона)''", diff --git a/languages/i18n/is.json b/languages/i18n/is.json index 6d5ce82835..f14b8457ce 100644 --- a/languages/i18n/is.json +++ b/languages/i18n/is.json @@ -2705,8 +2705,6 @@ "markedaspatrollederrornotify": "Mistókst að merkja síðuna sem yfirfarna.", "patrol-log-page": "Yfirferðarskrá", "patrol-log-header": "Þetta er skrá yfir yfirfarnar breytingar.", - "log-show-hide-patrol": "$1 listi yfir yfirfarnar síður", - "log-show-hide-tag": "$1 merkjaannáll", "confirm-markpatrolled-button": "Í lagi", "deletedrevision": "Eyddi gamla útgáfu $1", "filedeleteerror-short": "Villa við eyðingu: $1", diff --git a/languages/i18n/it.json b/languages/i18n/it.json index d0ffa8ec5f..153d249cbe 100644 --- a/languages/i18n/it.json +++ b/languages/i18n/it.json @@ -1806,6 +1806,7 @@ "http-timed-out": "Richiesta HTTP scaduta.", "http-curl-error": "Errore durante il recupero dell'URL: $1", "http-bad-status": "Si è verificato un problema durante la richiesta HTTP: $1 $2", + "http-internal-error": "Errore interno HTTP.", "upload-curl-error6": "URL non raggiungibile", "upload-curl-error6-text": "Impossibile raggiungere la URL specificata. Verificare che la URL sia scritta correttamente e che il sito in questione sia attivo.", "upload-curl-error28": "Tempo scaduto per l'upload", @@ -2094,7 +2095,7 @@ "speciallogtitlelabel": "Azione effettuata su (titolo della pagina o {{ns:user}}:Nome utente):", "log": "Registri", "logeventslist-submit": "Mostra", - "logeventslist-more-filters": "Altri filtri:", + "logeventslist-more-filters": "Mostra registri aggiuntivi:", "logeventslist-patrol-log": "Modifiche verificate", "logeventslist-tag-log": "Etichette", "all-logs-page": "Tutti i registri pubblici", @@ -2951,8 +2952,6 @@ "markedaspatrollederrornotify": "Errore durante la verifica.", "patrol-log-page": "Modifiche verificate", "patrol-log-header": "Di seguito sono elencate le verifiche delle modifiche.", - "log-show-hide-patrol": "$1 registro delle modifiche verificate", - "log-show-hide-tag": "$1 registro delle etichette", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Segna versione $3 di $2 come verificata?", "deletedrevision": "Cancellata la vecchia versione di $1.", diff --git a/languages/i18n/ja.json b/languages/i18n/ja.json index 2d3757264d..ca6445d8d4 100644 --- a/languages/i18n/ja.json +++ b/languages/i18n/ja.json @@ -2965,8 +2965,6 @@ "markedaspatrollederrornotify": "巡回済みにするのに失敗しました。", "patrol-log-page": "巡回記録", "patrol-log-header": "以下は巡回された版の記録です。", - "log-show-hide-patrol": "巡回記録を$1", - "log-show-hide-tag": "タグ記録を$1", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "ページ$2の$3の版を巡回済みにマークしますか?", "deletedrevision": "古い版 $1 を削除しました", diff --git a/languages/i18n/jv.json b/languages/i18n/jv.json index 336b741696..66df3aa0a9 100644 --- a/languages/i18n/jv.json +++ b/languages/i18n/jv.json @@ -243,8 +243,8 @@ "policy-url": "Project:Kabijakan", "portal": "Gapura paguyuban", "portal-url": "Project:Garupa paguyuban", - "privacy": "Pranatan bab privasi", - "privacypage": "Project:Pranatan bab privasi", + "privacy": "Niti privasi", + "privacypage": "Project:Niti privasi", "badaccess": "Aksès ora olèh", "badaccess-group0": "Panjenengan ora pareng nglakokaké tindhakan sing panjenengan gayuh.", "badaccess-groups": "Tumindak sing panjenengan péngini winates marang panganggo ing {{PLURAL:$2|golongan|golongan}}: $1.", @@ -336,7 +336,7 @@ "title-invalid-empty": "Sesirah kaca sing dikarepaké kosong utawa mung ngemu jenengé mandala-aran.", "title-invalid-utf8": "Sesirah kaca sing dikarepaké ngemu reroncèn UTF-8 sing ora sah.", "title-invalid-interwiki": "Sesirah kaca sing dikarepaké ngemu pranala interwiki sing ora bisa dicakaké dadi sesirah", - "title-invalid-talk-namespace": "Sesirah kaca sing dikarepaké nggayut kaca parembugan sing ora ana.", + "title-invalid-talk-namespace": "Sesirah kaca kang dikarepaké ngener ing kaca parembugan kang ora ana.", "title-invalid-characters": "Sesirah kaca sing dikarepaké ngemu karakter sing ora sah: \"$1\".", "title-invalid-relative": "Sesirah ngemu alamat rélatif. Sesirah kaca relatif (./, ../) iku ora sah amarga ora bisa ditekani lumantar pangluru.", "title-invalid-magic-tilde": "Sesirah kaca sing dikarepaké ngemu reroncèn tilda (~~~) sing ora sah.", @@ -1330,7 +1330,7 @@ "newpageletter": "A", "boteditletter": "b", "number_of_watching_users_pageview": "[$1 {{PLURAL:$1|cacahé sing ngawasi|cacahé sing ngawasi}}]", - "rc-change-size-new": "$1 {{PLURAL:$1|bét|bét}} sawisé diowahi", + "rc-change-size-new": "$1 {{PLURAL:$1|bèt|bèt}} sawisé kaowahan", "newsectionsummary": "/* $1 */ pérangan anyar", "rc-enhanced-expand": "Tuduhaké princèn", "rc-enhanced-hide": "Dhelikaké princèn", @@ -2113,7 +2113,7 @@ "sp-contributions-newonly": "Tuduhaké besutan mligi kaca gawéan", "sp-contributions-hideminor": "Dhelikaké besutan cilik", "sp-contributions-submit": "Golèk", - "whatlinkshere": "Sing nggayut mréné", + "whatlinkshere": "Kang nggayut mréné", "whatlinkshere-title": "Kaca mawa pranala nggayut \"$1\"", "whatlinkshere-page": "Kaca:", "linkshere": "Kaca-kaca ing ngisor iki nggayut menyang $2:", @@ -2432,8 +2432,8 @@ "tooltip-ca-watch": "Tambahaké kaca iki menyang pawawangané panjenengan", "tooltip-ca-unwatch": "Busak kaca iki saka pawawanganing panjenengan", "tooltip-search": "Golèk ing {{SITENAME}}", - "tooltip-search-go": "Jujug kaca asesirah persis mangkéné yèn ana", - "tooltip-search-fulltext": "Golèk kaca isi tèks kaya mangkéné", + "tooltip-search-go": "Jujug kaca kang sesirah persis mangkéné yèn ana", + "tooltip-search-fulltext": "Golèk kaca kang isi tèks mangkéné", "tooltip-p-logo": "Menyang tepas", "tooltip-n-mainpage": "Menyang tepas", "tooltip-n-mainpage-description": "Menyang tepas", @@ -2442,7 +2442,7 @@ "tooltip-n-recentchanges": "Pratélaning owah-owahan anyar sajeroning wiki.", "tooltip-n-randompage": "Mot sembarang kaca", "tooltip-n-help": "Papan kanggo golèk pitulung", - "tooltip-t-whatlinkshere": "Pratélané kabèh kaca wiki sing nggayut mréné", + "tooltip-t-whatlinkshere": "Pratélan kabèh kaca wiki kang nggayut mréné", "tooltip-t-recentchangeslinked": "Owah-owahan anyar saka kaca-kaca sing nggayut kaca iki", "tooltip-feed-rss": "''RSS feed'' kanggo kaca iki", "tooltip-feed-atom": "Pakan atom tumrap kaca iki", @@ -2453,7 +2453,7 @@ "tooltip-t-specialpages": "Pratélaning kabèh kaca mirunggan", "tooltip-t-print": "Vèrsi céthak kaca iki", "tooltip-t-permalink": "Pranala permanèn saka owahan iki", - "tooltip-ca-nstab-main": "Deleng kaca isi", + "tooltip-ca-nstab-main": "Deleng kaca kontèn", "tooltip-ca-nstab-user": "Deleng kaca panganggo", "tooltip-ca-nstab-media": "Deleng kaca médhia", "tooltip-ca-nstab-special": "Iki kaca mirunggan lan ora bisa dibesut", @@ -2556,7 +2556,6 @@ "markedaspatrollederrornotify": "Penanda patroli gagal dibuat.", "patrol-log-page": "Log patroli", "patrol-log-header": "Iki log revisi sing wis dipatroli.", - "log-show-hide-patrol": "$1 log patroli", "confirm-markpatrolled-button": "YA", "deletedrevision": "Revisi lawas sing dibusak $1.", "filedeleteerror-short": "Kaluputan nalika mbusak berkas: $1", diff --git a/languages/i18n/ka.json b/languages/i18n/ka.json index 951289fa7a..2982e73e88 100644 --- a/languages/i18n/ka.json +++ b/languages/i18n/ka.json @@ -2830,8 +2830,6 @@ "markedaspatrollederrornotify": "პატრულირებულად მონიშვნა ვერ მოხერხდა.", "patrol-log-page": "პატრულირების ჟურნალი", "patrol-log-header": "ეს არის პატრულირებულ ვერსიათა ჟურნალი.", - "log-show-hide-patrol": "$1 პატრულირების ჟურნალი", - "log-show-hide-tag": "$1 დასათაურების ჟურნალი", "confirm-markpatrolled-button": "კარგი", "confirm-markpatrolled-top": "მოინიშნოს $2-ის $3 ცვლილება შემოწმებულად?", "deletedrevision": "წაშლილია ძველი ვერსია $1.", diff --git a/languages/i18n/kab.json b/languages/i18n/kab.json index 89b564bb1a..631949d859 100644 --- a/languages/i18n/kab.json +++ b/languages/i18n/kab.json @@ -2442,7 +2442,6 @@ "markedaspatrollederrornotify": "Axṣar n ucṛaḍ am aken yetsenqed.", "patrol-log-page": "Aɣmis n usenqad", "patrol-log-header": "Atan amezruy n ileqman yetwalsɣren.", - "log-show-hide-patrol": "$1 amezruy n alstiɣuryin", "deletedrevision": "Tasiwelt taqdimt $1 tettumḥa.", "filedeleteerror-short": "Tuccḍ deg tukksa n ufaylu : $1", "filedeleteerror-long": "Llant tuccḍiwin deg tukksa n ufaylu :\n\n$1", diff --git a/languages/i18n/khw.json b/languages/i18n/khw.json index 1752c1cefa..d9b0a87c88 100644 --- a/languages/i18n/khw.json +++ b/languages/i18n/khw.json @@ -901,7 +901,7 @@ "sp-contributions-logs": "لاگز", "sp-contributions-talk": "تبادلہ خیال", "sp-contributions-search": "تان نیویشیرو مضمونن تلاش کورے", - "sp-contributions-username": "آئی.پی پتہ یا اسمِ صارف:", + "sp-contributions-username": "آئی پی پتہ یا صارف نام:", "sp-contributions-toponly": "صرف حالیہ ترین نظرثانی ترمیماتن پشاؤے", "sp-contributions-submit": "Search/تلاش", "whatlinkshere": "ھیارا کیہ کیہ لنک شینی", diff --git a/languages/i18n/kk-cyrl.json b/languages/i18n/kk-cyrl.json index 86a0d7f2fb..93f7982e50 100644 --- a/languages/i18n/kk-cyrl.json +++ b/languages/i18n/kk-cyrl.json @@ -2414,8 +2414,6 @@ "markedaspatrollederrornotify": "Тексерілді деп белгіленбеді.", "patrol-log-page": "Тексеру журналы", "patrol-log-header": "Бұл тексерілген нұсқалар журналы", - "log-show-hide-patrol": "$1 тексеру журналы", - "log-show-hide-tag": "$1 белгі журналы", "deletedrevision": "Ескі түзетуін жойды: $1", "filedeleteerror-short": "Файл жою қатесі: $1", "filedeleteerror-long": "Файлды жойғанда қателер кездесті:\n\n$1", diff --git a/languages/i18n/km.json b/languages/i18n/km.json index 6c059032b2..e13058951e 100644 --- a/languages/i18n/km.json +++ b/languages/i18n/km.json @@ -2336,7 +2336,6 @@ "markedaspatrollederror": "មិនអាចគូសចំណាំថាបានល្បាត", "patrol-log-page": "កំណត់ហេតុនៃការតាមដាន", "patrol-log-header": "នេះជាកំណត់ហេតុនៃកំណែ​ប្រែ​ដែល​បាន​តាមដាន", - "log-show-hide-patrol": "កំណត់ហេតុនៃការតាមដាន $1", "confirm-markpatrolled-button": "យល់ព្រម", "deletedrevision": "កំណែចាស់ដែលត្រូវបានលុបចេញ $1", "filedeleteerror-short": "កំហុសនៃការលុបឯកសារ៖ $1", @@ -2770,6 +2769,7 @@ "tag-filter": "[[Special:Tags|ស្លាក​]] តម្រង​:", "tag-filter-submit": "តម្រង", "tag-list-wrapper": "([[Special:Tags|{{PLURAL:$1|ស្លាក|ស្លាក}}]]: $2)", + "tag-mw-undo": "មិនធ្វើវិញ", "tags-title": "ស្លាក​", "tags-intro": "ទំព័រ​រាយ​នាម​ស្លាក​ទាំង​ឡាយ​ដែល​កម្មវិធី​ software អាចកត់​សម្គាល់កំណែ​ជាមួយ​ និង​អត្ថ​ន័យ​របស់​វា។​", "tags-tag": "ឈ្មោះ​ស្លាក", diff --git a/languages/i18n/ko.json b/languages/i18n/ko.json index 01081145a5..e87831cf39 100644 --- a/languages/i18n/ko.json +++ b/languages/i18n/ko.json @@ -972,6 +972,7 @@ "diff-paragraph-moved-toold": "문단이 이동되었습니다. 오래된 위치로 이동하려면 클릭하십시오.", "difference-missing-revision": "문서 비교에서 {{PLURAL:$2|하나|$2개}}의 판($1)을 찾을 수 {{PLURAL:$2|없습니다}}.\n\n이 문제는 주로 삭제된 문서를 가리키는 오래된 문서 비교 링크로 인해 발생합니다.\n자세한 내용은 [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} 삭제 기록]에서 확인할 수 있습니다.", "searchresults": "검색 결과", + "search-filter-title-prefix-reset": "모든 문서 검색", "searchresults-title": "\"$1\"에 대한 검색 결과", "titlematches": "문서 제목 일치", "textmatches": "문서 내용 일치", @@ -1778,6 +1779,7 @@ "http-timed-out": "HTTP 요청 시간 초과입니다.", "http-curl-error": "URL 열기 오류: $1", "http-bad-status": "HTTP 요청 중 오류 발생: $1 $2", + "http-internal-error": "HTTP 내부 오류.", "upload-curl-error6": "URL 접근 불가", "upload-curl-error6-text": "URL에 접근할 수 없습니다.\nURL이 맞고 해당 웹사이트가 작동하는지 확인해주세요.", "upload-curl-error28": "올리기 시간 초과", @@ -2072,7 +2074,7 @@ "speciallogtitlelabel": "대상 (문서 제목 또는 {{ns:user}}:사용자 이름으로 사용자 검색):", "log": "기록 목록", "logeventslist-submit": "보기", - "logeventslist-more-filters": "더 많은 필터:", + "logeventslist-more-filters": "추가 기록 표시:", "logeventslist-patrol-log": "점검 기록", "logeventslist-tag-log": "태그 기록", "all-logs-page": "모든 공개 기록", @@ -2932,8 +2934,6 @@ "markedaspatrollederrornotify": "점검한 것으로 표시를 실패했습니다.", "patrol-log-page": "점검 기록", "patrol-log-header": "문서 점검에 대한 기록입니다.", - "log-show-hide-patrol": "점검 기록을 $1", - "log-show-hide-tag": "태그 기록을 $1", "confirm-markpatrolled-button": "확인", "confirm-markpatrolled-top": "$2의 $3 판을 점검한 것으로 표시하시겠습니까?", "deletedrevision": "예전 $1 판이 삭제되었습니다.", diff --git a/languages/i18n/krc.json b/languages/i18n/krc.json index f8b077ab89..89e4ac19f4 100644 --- a/languages/i18n/krc.json +++ b/languages/i18n/krc.json @@ -2072,7 +2072,6 @@ "markedaspatrollednotify": "«$1» бетдеги бу тюрлениу тинтиб къаралгъанча белгиленди.", "patrol-log-page": "Патруль этиуню журналы", "patrol-log-header": "Бу осмакъланнган версияланы журналыды.", - "log-show-hide-patrol": "Осмакълауну журналы $1", "deletedrevision": "$1 эски версия кетерилгенди.", "filedeleteerror-short": "Файл кетериуню халаты: $1", "filedeleteerror-long": "Файлны кетериуде халатлагъа тюбелди:\n\n$1", diff --git a/languages/i18n/ksh.json b/languages/i18n/ksh.json index 970fd3d98e..d3f6dbd39c 100644 --- a/languages/i18n/ksh.json +++ b/languages/i18n/ksh.json @@ -2578,8 +2578,6 @@ "markedaspatrollederrornotify": "Dat di Sigg nohjekik es, kunnte mer nit faßhalde.", "patrol-log-page": "Logbohch vun de nohjelohrte Änderonge", "patrol-log-header": "", - "log-show-hide-patrol": "$1 et Logbuch vum Sigge nohlooere", - "log-show-hide-tag": "Donn et Logbohch vun de Makkehronge $1", "deletedrevision": "De ahle Väsjohn „$1“ es fottjeschmeße", "filedeleteerror-short": "Fähler bem Dattei-Fottschmiiße: $1", "filedeleteerror-long": "Bem Fosooch, de Dattei fottzeschmihße, hatte mer Fähler:\n\n$1", diff --git a/languages/i18n/kw.json b/languages/i18n/kw.json index 6c41f42dc8..466d339245 100644 --- a/languages/i18n/kw.json +++ b/languages/i18n/kw.json @@ -174,10 +174,10 @@ "viewhelppage": "Gweles an folen weres", "categorypage": "Gweles folen an klass", "viewtalkpage": "Gweles an dadhlow", - "otherlanguages": "Yn yethow erel", - "redirectedfrom": "(Daskedyes dhyworth $1)", + "otherlanguages": "Yn tavosow erel", + "redirectedfrom": "(Daskevarwodhys dhyworth $1)", "redirectpagesub": "Folen dhaskedya", - "lastmodifiedat": "Gwrys veu diwettha chanj an folen ma an $1, dhe $2.", + "lastmodifiedat": "Diwettha chanj an folen ma a veu an $1, dhe $2.", "protectedpage": "Folen dhifresys", "jumpto": "Lamma dhe:", "jumptonavigation": "kevrennow lewya", @@ -193,8 +193,8 @@ "disclaimers": "Avisyansow", "disclaimerpage": "Project:Avisyans ollgemmyn", "edithelp": "Gweres ow chanjya", - "mainpage": "Dynnargh", - "mainpage-description": "Dynnargh", + "mainpage": "Folen dre", + "mainpage-description": "Folen dre", "policy-url": "Project:Polici", "portal": "Porth an gemeneth", "portal-url": "Project:Porth an gemeneth", @@ -218,6 +218,7 @@ "toc": "Rol an folen", "showtoc": "diskwedhes", "hidetoc": "kudha", + "collapsible-collapse": "Diskara", "collapsible-expand": "Efani", "thisisdeleted": "Gweles po daskor $1?", "viewdeleted": "Gweles $1?", @@ -227,7 +228,7 @@ "site-atom-feed": "Feed Atom $1", "page-rss-feed": "Feed RSS \"$1\"", "page-atom-feed": "Feed Atom \"$1\"", - "red-link-title": "$1 (nyns eus folen henwys yndelma)", + "red-link-title": "$1 (nyns eus an folen ma)", "nstab-main": "Folen", "nstab-user": "Folen dhevnydhyer", "nstab-media": "Folen media", @@ -238,6 +239,7 @@ "nstab-template": "Skantlyn", "nstab-help": "Gweres", "nstab-category": "Klass", + "mainpage-nstab": "Folen dre", "error": "Gwall", "databaseerror": "Gwall database", "readonly": "Alhwedhys yw an database", @@ -253,8 +255,8 @@ "badtitle": "Titel drog", "viewsource": "Gweles an bennfenten", "viewsource-title": "Gweles an bennfenten rag $1", - "protectedpagetext": "Difresys re beu an folen-ma rag gwitha rag chanjya po gwriansow erel.", - "viewsourcetext": "Hwi a yll gweles ha kopia pennfenten an folen-ma:", + "protectedpagetext": "Difresys yw an folen ma dhe witha rag chanjya po gwriansow erel.", + "viewsourcetext": "Hwi a yll gweles ha kopia pennfenten an folen ma.", "mycustomcssprotected": "Ny'gas beus kummyes dhe janjya an folen CSS-ma.", "mycustomjsprotected": "Ny'gas beus kummyes dhe janjya an folen JavaScript-ma.", "ns-specialprotected": "Ny yllir chanjya folennow arbennek.", @@ -279,8 +281,8 @@ "password-change-forbidden": "Ny yllir chanjya geryow tremena war an wiki-ma.", "login": "Omgelmi", "nav-login-createaccount": "Omgelmi / Gwruthyl akont nowyth", - "logout": "Digelmi", - "userlogout": "Digelmi", + "logout": "Omdenna", + "userlogout": "Omdenna", "notloggedin": "Digelmys", "userlogin-noaccount": "A nyns eus akont dhywgh?", "userlogin-joinproject": "Junya {{SITENAME}}", @@ -332,7 +334,7 @@ "pt-login": "Omgelmi", "pt-login-button": "Omgelmi", "pt-createaccount": "Gwruthyl akont", - "pt-userlogout": "Digelmi", + "pt-userlogout": "Omdenna", "changepassword": "Chanjya an ger-tremena", "resetpass_announce": "Hwi a omgelmis dre goden ebostyes anbarthus.\nRag gorfenna omgelmi, res yw dhywgh settya ger tremena nowyth omma:", "resetpass_header": "Chanjya ger tremena an akont", @@ -377,22 +379,31 @@ "media_tip": "Kevren restren", "sig_tip": "Agas sinans ha stampa-termyn", "summary": "Berrskrif:", - "subject": "Testen/Pennlinen:", + "subject": "Testen:", "minoredit": "Chanj byghan yw hemma", "watchthis": "Golya an folen ma", "savearticle": "Gwitha an folen", + "savechanges": "Gwitha an chanjyow", + "publishpage": "Dyllo an folen", + "publishchanges": "Dyllo an chanjyow", + "savearticle-start": "Gwitha an folen…", + "savechanges-start": "Gwitha an chanjyow…", + "publishpage-start": "Dyllo an folen…", + "publishchanges-start": "Dyllo an chanjyow…", "preview": "Ragwel", "showpreview": "Diskwedhes ragwel", "showdiff": "Diskwedhes an chanjyow", + "blankarticle": "Bedhowgh war: Gwag yw an folen esowgh ow kul.\nMar klyckyowgh \"$1\" arta, an folen a vydh gwrys heb dalgh.", "anoneditwarning": "Gwarnyans: Nyns owgh hwi omgelmys. Gweladow yn foblek vydh agas trigva IP mar kwrewgh chanjyow. Mars [$1 omgelmowgh] po [$2 gwruthyl akont], agas chanjyow a vydh askrifys dhe'gas hanow devnydher, keffrys ha lesow erel.", "anonpreviewwarning": "''Nyns owgh omgelmys. Dre witha, agas trigva IP a vydh rekordyes istori chanjya an folen-ma.''", + "missingsummary": "Bedhowgh war: Nyns eus berrskrif skrifys genowgh.\nMar klyckyowgh \"$1\" arta, agas chanj a vydh gwithys heb berrskrif.", "summary-preview": "Ragwel a'n berrskrif:", "loginreqtitle": "Res yw omgelmi", "loginreqlink": "omgelmi", "accmailtitle": "Ger-tremena danvenys.", "newarticle": "(Nowyth)", "newarticletext": "Hwi re holyas kevren dhe folen nag yw gwruthys hwath.\nRag gwruthyl an folen, dallethewgh jynnskrifa y'n gist a-woles (gwelewgh an [$1 folen weres] rag moy kedhlow).\nMar teuthowgh omma yn kamm, klyckyewgh boton '''war-dhelergh''' agas peurell.", - "noarticletext": "Nyns eus tekst y'n folen ma a-lemmyn.\nHwi a yll [[Special:Search/{{PAGENAME}}|hwilas titel an folen ma]] yn folennow erel,\n[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} hwilas y'n kovnotennow kelmys],\npo [{{fullurl:{{FULLPAGENAME}}|action=edit}} chanjya an folen ma].", + "noarticletext": "Nyns eus tekst y'n folen ma a-lemmyn.\nHwi a yll [[Special:Search/{{PAGENAME}}|hwilas titel an folen ma]] yn folennow erel,\n[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} hwilas y'n kovnotennow kelmys],\npo [{{fullurl:{{FULLPAGENAME}}|action=edit}} gwruthyl an folen ma].", "noarticletext-nopermission": "Nyns eus tekst y'n folen ma a-lemmyn.\nHwi a yll [[Special:Search/{{PAGENAME}}|hwilas titel an folen ma]] yn folennow erel, po [{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} hwilas y'n kovnotennow kelmys], mes ny'gas beus kummyas dhe wruthyl an folen ma.", "userpage-userdoesnotexist": "Nyns yw kovskrifys an akont devnydhyer \"$1\".\nCheckyewgh mar pleg mara'gas beus hwans dhe wruthyl/dhe janjya an folen-ma.", "userpage-userdoesnotexist-view": "Nyns yw kovskrifys an akont devnydhyer \"$1\".", @@ -421,7 +432,7 @@ "viewpagelogs": "Gweles kovnotennow an folen ma", "currentrev": "Amendyans diwettha", "currentrev-asof": "An amendyans diwettha a-dhia $1", - "revisionasof": "Versyon an folen a-dhia $1", + "revisionasof": "Versyon a-dhia $1", "revision-info": "Amendyans a-dhia $1 gans {{GENDER:$6|$2}}$7", "previousrevision": "← Amendyans kottha", "nextrevision": "Amendyans nowyttha →", @@ -454,14 +465,14 @@ "compareselectedversions": "Keheveli an amendyansow dewisyes", "showhideselectedversions": "Diskwedhes/kudha amendyansow dewisyes", "editundo": "diswul", - "searchresults": "Sewyansow an hwilans", - "searchresults-title": "Sewyansow an hwilans rag \"$1\"", + "searchresults": "Sewyansow hwilas", + "searchresults-title": "Sewyansow hwilas rag \"$1\"", "notextmatches": "Nyns eus tekst folen vyth owth omdhesedha", "prevn": "{{PLURAL:$1|$1}} kyns", "nextn": "nessa {{PLURAL:$1|$1}}", "prevn-title": "$1 {{PLURAL:$1|sewyans}} kyns", "nextn-title": "$1 {{PLURAL:$1|sewyans}} nessa", - "shown-title": "Diskwedhes $1 {{PLURAL:$1|sewyans}} yn folen", + "shown-title": "Diskwedhes $1 {{PLURAL:$1|sewyans}} war pub folen", "viewprevnext": "Gweles ($1 {{int:pipe-separator}} $2) ($3)", "searchmenu-exists": "''Yma folen henwys \"[[:$1]]\" war an wiki-ma'''", "searchmenu-new": "Gwrewgh an folen \"[[:$1]]\" war an wiki ma! {{PLURAL:$2|0=|Gweler ynwegh an folen a veu kevys yn unn hwilas.|Gweler ynwedh an sewyans hwilas kevys.}}", @@ -475,7 +486,7 @@ "searchprofile-advanced-tooltip": "Hwilas yn spasys hanow personelhes", "search-result-size": "$1 ({{PLURAL:$2|1 ger|$2 ger}})", "search-result-category-size": "{{PLURAL:$1|1 esel|$1 esel}} ({{PLURAL:$2|1 isglass|$2 isglass}}, {{PLURAL:$3|1 restren|$3 restren}})", - "search-redirect": "(daskedyans $1)", + "search-redirect": "(daskevarwodhyans a $1)", "search-section": "(tregh $1)", "search-suggest": "Esewgh hwi ow menya: $1", "search-interwiki-caption": "Ragdresow hwor", @@ -485,7 +496,7 @@ "searchrelated": "kelmys", "searchall": "oll", "search-showingresults": "{{PLURAL:$4|Sewyans $1 a $3|Sewyansow $1 - $2 a $3}}", - "search-nonefound": "Nyns esa sewyans vyth owth omdhesedha orth an govyn.", + "search-nonefound": "Ny veu sewyans vyth par dhe'n govyn.", "powersearch-legend": "Hwilans avonsys", "powersearch-ns": "Hwilas yn spasys-hanow:", "powersearch-togglelabel": "Dewis:", @@ -579,43 +590,55 @@ "newuserlogpage": "Kovnoten gwruthyl akontow devnydhyer", "rightslog": "Kovnoten wiryow an devnydhyer", "action-edit": "chanjya an folen-ma", - "action-move": "gwaya an folen-ma", + "action-move": "gwaya an folen ma", "action-movefile": "gwaya an restren-ma", "action-upload": "ughkarga an restren-ma", - "action-delete": "dilea an folen-ma", + "action-delete": "dilea an folen ma", "nchanges": "$1 {{PLURAL:$1|chanj|chanj}}", "enhancedrc-history": "istori", "recentchanges": "Chanjyow a-dhiwedhes", - "recentchanges-legend": "Etholyow an chanjyow a-dhiwedhes", - "recentchanges-summary": "War an folen-ma y hyllir helerghi an chanjyow diwettha eus gwrys dhe'n wiki.", + "recentchanges-legend": "Dewisyow an chanjyow a-dhiwedhes", + "recentchanges-summary": "Homm yw rol a janjyow a-dhiwedhes dhe'n wiki ma.", "recentchanges-noresult": "Nyns eus chanj vyth dres an termyn res a omdhesedh orth an etholyow-ma.", "recentchanges-feed-description": "Y hyllir helerhi an chanjyow diwettha gwrys dhe'n wiki y'n feed-ma.", - "recentchanges-label-newpage": "Gans an chanj ma y feu gwruthys folen nowydh", - "recentchanges-label-minor": "Chanj byghan yw hemma", - "recentchanges-label-bot": "Gwrys veu an chanj ma gans bott", - "recentchanges-label-unpatrolled": "Ny veu an chanj ma patrolyes hwath", + "recentchanges-label-newpage": "Folen nowydh", + "recentchanges-label-minor": "Chanj byghan", + "recentchanges-label-bot": "Chanj gans bott", + "recentchanges-label-unpatrolled": "Ny veu patrolyes hwath", + "recentchanges-label-plusminus": "Chanj dhe vyns an folen (baytys)", "recentchanges-legend-heading": "Alhwedh:", - "recentchanges-legend-newpage": "{{int:recentchanges-label-newpage}} (gweler ynwedh an [[Special:NewPages|rol a folennow nowydh]])", - "rclistfrom": "Diskwedhes chanjyow nowydh yn unn dhalleth dhyworth $3 $2", + "recentchanges-legend-newpage": "{{int:recentchanges-label-newpage}} ([[Special:NewPages|rol leun]])", + "rcfilters-legend-heading": "Berrheansow:", + "rcfilters-activefilters": "Sidhlow byw", + "rcfilters-days-show-days": "$1 {{PLURAL:$1|jydh|dydh}}", + "rcfilters-search-placeholder": "Sidhla an chanjyow (usyowgh an rol po hwilas hanow an sidhel)", + "rcfilters-filter-humans-label": "Den (nyns yw bott)", + "rcfilters-filter-pageedits-label": "Chanjyow dhe folennow", + "rcfilters-filter-newpages-label": "Folennow gwrys", + "rcfilters-liveupdates-button": "Nowedhansow byw", + "rclistfrom": "Diskwedhes chanjyow nowydh a-dhia $3 $2", "rcshowhideminor": "$1 chanjyow byghan", "rcshowhideminor-hide": "Kudha", "rcshowhidebots": "$1 bottow", "rcshowhidebots-show": "Diskwedhes", + "rcshowhidebots-hide": "Kudha", "rcshowhideliu": "$1 devnydhoryon govskrifys", "rcshowhideliu-hide": "Kudha", "rcshowhideanons": "$1 devnydhyoryon dhihanow", "rcshowhideanons-show": "Diskwedhes", "rcshowhideanons-hide": "Kudha", + "rcshowhidepatr-hide": "Kudha", "rcshowhidemine": "$1 ow chanjyow", "rcshowhidemine-hide": "Kudha", + "rcshowhidecategorization-hide": "Kudha", "rclinks": "Diskwedhes an $1 chanj diwettha gwrys y'n $2 dydh diwettha", - "diff": "dyffrans", + "diff": "dihevelepter", "hist": "istori", "hide": "Kudha", "show": "Diskwedhes", "minoreditletter": "B", "newpageletter": "N", - "boteditletter": "bott", + "boteditletter": "b", "rc-change-size-new": "$1 {{PLURAL:$1|byte|bytes}} wosa an chanj", "newsectionsummary": "/* $1 */ tregh nowyth", "rc-enhanced-expand": "Diskwedhes an manylyon (res yw JavaScript)", @@ -649,26 +672,26 @@ "listfiles_count": "Versyons", "file-anchor-link": "Restren", "filehist": "Istori an restren", - "filehist-help": "Klyckyewgh war dhedhyans/eur rag gweles an folen dell omdhiskwedhas nena.", + "filehist-help": "Klyckyewgh war dhedhyans/eur rag gweles an folen dell o an termyn na.", "filehist-deleteall": "dilea oll", "filehist-deleteone": "dilea", "filehist-revert": "gorthtreylya", "filehist-current": "a-lemmyn", "filehist-datetime": "Dedhyans/Eur", "filehist-thumb": "Skeusennik", - "filehist-thumbtext": "Skeusennik rag an versyon a-dhia $1", + "filehist-thumbtext": "Skeusennik an versyon a-dhia $1", "filehist-nothumb": "Nyns eus skeusennik", "filehist-user": "Devnydhyer", "filehist-dimensions": "Mynsow", "filehist-filesize": "Mens an restren", - "filehist-comment": "Kampoll", + "filehist-comment": "Kampol", "imagelinks": "Devnydh an restren", "linkstoimage": "Yma an {{PLURAL:$1|folen|$1 folen}} a syw ow kevrenna dhe'n restren ma:", "linkstoimage-more": "Yma moy es $1 {{PLURAL:$1|folen}} ow kevrenna dhe'n restren-ma.\nNy dhiskwa an rol a syw marnas an {{PLURAL:$1|kynsa kevren folen|kynsa $1 kevren folen}} dhe'n restren-ma.\nYma [[Special:WhatLinksHere/$2|rol leun]] kavadow.", "nolinkstoimage": "Nyns eus folen vyth ow kevrenna dhe'n restren-ma.", "morelinkstoimage": "Gweles [[Special:WhatLinksHere/$1|moy kevrennow]] dhe'n restren-ma.", - "sharedupload": "Yma an folen-ma ow tos dhyworth $1 ha hy a alsa bos yn-dann devnydh gans ragdresow erel.", - "sharedupload-desc-here": "Yma an restren ma dhe $1 ha ragdresow erel a allsa bos orth hy devnydhya.\nDiskwedhys a-woles yw an deskrifans war hy [$2 folen dheskrifans] ena.", + "sharedupload": "An folen ma a dheu a $1 hag a allsa bos usys gans ragdresow erel.", + "sharedupload-desc-here": "Yma an restren ma dhe $1 ha ragdresow erel a allsa bos orth hy devnydhya.\nDiskwedhys a-woles yma an deskrifans war hy [$2 folen dheskrifans] ena.", "uploadnewversion-linktext": "Ughkarga versyon nowyth a'n restren-ma", "filedelete": "Dilea $1", "filedelete-legend": "Dilea an restren", @@ -678,7 +701,7 @@ "listredirects": "Rol an daswedyansow", "unusedtemplates": "Skantlyns heb devnydh", "unusedtemplateswlh": "kevrennow erel", - "randompage": "Folen dre happ", + "randompage": "Folen jonsus", "statistics": "Statystygyon", "statistics-pages": "Folennow", "brokenredirects-edit": "chanjya", @@ -703,7 +726,7 @@ "newpages-username": "Hanow-usyer:", "ancientpages": "An kottha folennow", "move": "Gwaya", - "movethispage": "Gwaya an folen-ma", + "movethispage": "Gwaya an folen ma", "pager-newer-n": "{{PLURAL:$1|1 nowyttha|$1 nowyttha}}", "pager-older-n": "{{PLURAL:$1|1 kottha|$1 kottha}}", "booksources": "Pennfentynyow lyver", @@ -740,12 +763,13 @@ "mywatchlist": "Rol wolya", "watchlistfor2": "Rag $1 ($2)", "watch": "Golya", - "watchthispage": "Golya an folen-ma", + "watchthispage": "Golya an folen ma", "unwatch": "Diswolya", "watchlist-details": "Yma {{PLURAL:$1|$1 folen}} war agas rol wolya, marnas folennow keskows.", "wlheader-showupdated": "Yn '''tew''' y tiskwedhir folennow re beu chanjyes a-dhia agas vysytyans diwettha.", "wlnote": "A-woles yma an {{PLURAL:$1|chanj diwettha|'''$1''' chanj diwettha}} y'n {{PLURAL:$2|our|'''$2''' our}} diwettha, a-dhia $3, $4.", "wlshowlast": "Diskwedhes an $1 our diwettha, an $2 dydh diwettha, po", + "watchlist-hide": "Kudha", "watchlist-options": "Etholyow an rol wolya", "watching": "Ow kolya...", "unwatching": "Ow tisgolya...", @@ -763,7 +787,7 @@ "deletecomment": "Acheson:", "deleteotherreason": "Acheson aral/keworansel:", "deletereasonotherlist": "Acheson aral", - "rollbacklink": "revya war-dhelergh", + "rollbacklink": "rolya war-dhelergh", "protectlogpage": "Kovnoten dhifres", "protectedarticle": "\"[[$1]]\" difresys", "prot_1movedto2": "[[$1]] gwayys dhe [[$2]]", @@ -804,7 +828,7 @@ "sp-contributions-username": "Trigva IP po hanow devnydhyer:", "sp-contributions-toponly": "Diskwedhes yn unnik chanjyow yw amendyansow diwettha", "sp-contributions-submit": "Hwilas", - "whatlinkshere": "Pyth a gevren dhe omma", + "whatlinkshere": "Folennow kevrennys", "whatlinkshere-title": "Folennow ow kevrenna dhe \"$1\"", "whatlinkshere-page": "Folen:", "linkshere": "Yma an folennow a syw ow kevrenna dhe '''$2''':", @@ -842,7 +866,7 @@ "movepagetext": "Devnydhya an furvlen a-woles a dhashenow folen, yn unn waya oll y istori dhe'n hanow nowyth.\nAn titel koth a vydh folen dhaskedyans dhe'n titel nowyth.\nHwi a yll nowedhi daskedyansow a boynt dhe'n titel derowel yn awtomatek.\nMar ny wrewgh, surhewgh hwi dhe jeckya rag [[Special:DoubleRedirects|daskedyansow dobyl]] po [[Special:BrokenRedirects|terrys]].\nOmgemeryansek owgh rag surhe y pes kevrennow poyntya dhe'n tyller ewn.\n\nNotyewgh '''na wayir''' an folen mars eus folen orth an titel nowyth seulabrys, marnas bos an pyth kampollys diwettha daskedyans ha ny'n jeves istori chanjya kyns vyth.\nHemm a styr y hyllowgh diswul dashenwel folen mar kwrewgh kammwrians, ha ny yllowgh gorskrifa folen eus ena seulabrys.\n\n'''Gwarnyans!'''\nHemm a yll bos chanj tromm ha bras dres ehen rag folen gerys-da;\nSurhewgh mar pleg hwi dhe gonvedhes sewyansow an gwrians-ma kyns mos yn-rag.", "moveuserpage-warning": "'''Gwarnyans''': Yth esowgh ow mos dhe waya folen dhevnydhyer. Notyewgh mar pleg ny vydh marnas an folen gwayys ha ''ny vydh'' an devnydhyer dashenwys.", "newtitle": "Dhe ditel nowyth:", - "move-watch": "Golya an folen-ma", + "move-watch": "Golya an folen ma", "movepagebtn": "Gwaya an folen", "pagemovedsub": "Gwaya a sewenis", "movepage-moved": "'''Gwayys re beu \"$1\" dhe \"$2\"'''", @@ -867,9 +891,9 @@ "tooltip-pt-preferences": "Agas dewisyow", "tooltip-pt-watchlist": "Rol a folennow esowgh ow kolya rag chanjyow", "tooltip-pt-mycontris": "Rol a'gas kevrohow", - "tooltip-pt-login": "Ni a gomend hwi dhe omgelmi, mes nyns yw besi", - "tooltip-pt-logout": "Digelmi", - "tooltip-pt-createaccount": "Ni a gomend hwi dhe wruthyl akont hag omgelmi; byttegyns nyns yw besi", + "tooltip-pt-login": "Ni a gomend hwi dhe omgelmi, mes nyns yw bysi", + "tooltip-pt-logout": "Omdenna", + "tooltip-pt-createaccount": "Ni a gomend hwi dhe wruthyl akont hag omgelmi; byttegyns nyns yw bysi", "tooltip-ca-talk": "Dadhlow a-dro dhe'n folen", "tooltip-ca-edit": "Chanjya an folen ma", "tooltip-ca-addsection": "Dalleth tregh nowydh", @@ -878,21 +902,21 @@ "tooltip-ca-protect": "Difres an folen-ma", "tooltip-ca-delete": "Dilea an folen-ma", "tooltip-ca-move": "Gwaya an folen ma", - "tooltip-ca-watch": "Keworra an folen ma dhe'gas rol wolya", + "tooltip-ca-watch": "Keworra an folen ma dh'agas rol wolya", "tooltip-ca-unwatch": "Dilea an folen-ma dhyworth agas rol wolya", "tooltip-search": "Hwilas yn {{SITENAME}}", "tooltip-search-go": "Mos dhe folen dhedhi an keth hanow ma, mars eus", "tooltip-search-fulltext": "Hwilas an tekst ma y'n folennow", - "tooltip-p-logo": "Mos dhe'n folen dynnargh", - "tooltip-n-mainpage": "Mos dhe'n folen dynnargh", - "tooltip-n-mainpage-description": "Mos dhe'n folen dynnargh", - "tooltip-n-portal": "A-dro dhe'n ragdres, an pyth a yllowgh gul, ple hyllir kavos taklow", + "tooltip-p-logo": "Mos dhe'n folen dre", + "tooltip-n-mainpage": "Mos dhe'n folen dre", + "tooltip-n-mainpage-description": "Mos dhe'n folen dre", + "tooltip-n-portal": "A-dro dhe'n ragdres, pyth a yllowgh gul, ple hyllir kavos taklow", "tooltip-n-currentevents": "Kavos kedhlow a-dro dhe hwarvosow a-lemmyn", "tooltip-n-recentchanges": "Rol a janjyow a-dhiwedhes y'n wiki", "tooltip-n-randompage": "Karga folen dre happ", "tooltip-n-help": "Gweres", - "tooltip-t-whatlinkshere": "Rol a bub folen wiki a gevren dhe omma", - "tooltip-t-recentchangeslinked": "Chanjyow a-dhiwedhes yn folennow a gevren an folen ma dhedha", + "tooltip-t-whatlinkshere": "Rol a bub folen wiki kevrennys dhe'n folen ma", + "tooltip-t-recentchangeslinked": "Chanjyow a-dhiwedhes yn folennow kevrennys dhyworth an folen ma", "tooltip-feed-rss": "Feed RSS rag an folen-ma", "tooltip-feed-atom": "Feed Atom rag an folen ma", "tooltip-t-contributions": "Gweles rol a gevrohow an devnydhyer ma", @@ -903,7 +927,7 @@ "tooltip-t-permalink": "Kevren fast dhe'n amendyans ma a'n folen", "tooltip-ca-nstab-main": "Gweles an folen", "tooltip-ca-nstab-user": "Gweles an folen dhevnydhyer", - "tooltip-ca-nstab-special": "Folen arbennek yw homma; ny yllowgh chanjya an folen hy honan.", + "tooltip-ca-nstab-special": "Folen arbennek yw homma; ny yllir hy chanjya", "tooltip-ca-nstab-project": "Gweles folen an wiki", "tooltip-ca-nstab-image": "Gweles folen an restren", "tooltip-ca-nstab-template": "Gweles an skantlyn", @@ -914,11 +938,11 @@ "tooltip-diff": "Diskwedhes an chanjyow a wrussowgh dhe'n tekst", "tooltip-compareselectedversions": "Gweles an dyffransow ynter dew amendyansow dewisyes an folen-ma", "tooltip-watch": "Keworra an folen-ma dhe'gas rol wolya", - "tooltip-rollback": "\"Revya war-dhelergh\" a worthtreyl chanjyow an diwettha devnydhyer der unn glyck", + "tooltip-rollback": "\"Rolya war-dhelergh\" a worthtreyl chanj(yow) an diwettha devnydhyer der unn glyck", "tooltip-undo": "\"Diswul\" a worthtreyl an chanj ma hag ygeri an furvlen janjya y'n modh ragweles. Y hyllir keworra acheson y'n berrskrif.", - "tooltip-summary": "Entrewgh berrskrif", + "tooltip-summary": "Keworrewgh berrskrif", "siteuser": "devnydhyer {{SITENAME}} $1", - "lastmodifiedatby": "Chanj diwettha an folen-ma o dhe $2, $1 gans $3.", + "lastmodifiedatby": "Chanj diwettha an folen ma a veu dhe $2 an $1 gans $3.", "siteusers": "{{PLURAL:$2|devnydhyer|devnydhyoryon}} {{SITENAME}} $1", "pageinfo-toolboxlink": "Kedhlow an folen", "previousdiff": "← Chanj kottha", @@ -985,6 +1009,7 @@ "blankpage": "Folen wag", "tag-filter": "Sidhel [[Special:Tags|tagyow]]:", "tag-list-wrapper": "([[Special:Tags|{{PLURAL:$1|Tagg|Taggys}}]]: $2)", + "tags-title": "Taggys", "tags-edit": "chanjya", "dberr-problems": "Drog yw genen! An wiasva-ma a's teves kaletter teknogel.", "dberr-again": "Assayewgh gortos pols ha daskarga.", diff --git a/languages/i18n/la.json b/languages/i18n/la.json index 5833a574df..edb658633b 100644 --- a/languages/i18n/la.json +++ b/languages/i18n/la.json @@ -1524,7 +1524,6 @@ "markaspatrolledtext": "Indicare hanc paginam qua circumita", "markedaspatrolled": "Indicare hanc paginam qua circumita", "patrol-log-page": "Acta emendationum circumitarum", - "log-show-hide-patrol": "$1 acta emendationum circumitarum", "deletedrevision": "Abolita redactio imaginis $1", "previousdiff": "← Differentia superior", "nextdiff": "Differentia proxima →", diff --git a/languages/i18n/lb.json b/languages/i18n/lb.json index 60da736559..7d5ea83251 100644 --- a/languages/i18n/lb.json +++ b/languages/i18n/lb.json @@ -888,6 +888,7 @@ "diff-paragraph-moved-toold": "Den Abschnitt gouf geréckelt. Klickt fir op déi al Plaz ze sprangen.", "difference-missing-revision": "{{PLURAL:$2|Eng Versioun|$2 Versioune}} vun dëser Differenz ($1) {{PLURAL:$2|gouf|goufen}} net fonnt.\n\nDat geschitt normalerweis wann Dir op e vereelste Link vun enger Versioun vun enger Säit klickt déi geläscht ginn ass.\nDetailer fannt Dir am [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} Logbuch vum Läschen].", "searchresults": "Resultat vum Sichen", + "search-filter-title-prefix-reset": "Op all de Säite sichen", "searchresults-title": "Resultater vum Sichen no \"$1\"", "titlematches": "Iwwereneestëmmungen am Säitentitel", "textmatches": "Iwwereneestëmmungen am Säitentext", @@ -2715,7 +2716,6 @@ "markedaspatrollederrornotify": "Markéieren als kontrolléiert huet net funktionéiert.", "patrol-log-page": "Logbuch vun den iwwerkuckte Versiounen", "patrol-log-header": "Dëst ass d'Logbuch vun den nogekuckte Versiounen.", - "log-show-hide-patrol": "Kontroll-Logbuch $1", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Versioun $3 vu(n) $2 als kontrolléiert markéieren?", "deletedrevision": "Al, geläscht Versioun vu(n) $1", diff --git a/languages/i18n/lfn.json b/languages/i18n/lfn.json index 4821c8323e..f279596f50 100644 --- a/languages/i18n/lfn.json +++ b/languages/i18n/lfn.json @@ -2824,8 +2824,6 @@ "markedaspatrollederrornotify": "La marca como patruliada ia fali.", "patrol-log-page": "Arcivo de patrulias", "patrol-log-header": "Esta es un rejistra de revisas patruliada.", - "log-show-hide-patrol": "$1 rejistra de patrulias", - "log-show-hide-tag": "$1 rejistra de eticetas", "confirm-markpatrolled-button": "Oce", "confirm-markpatrolled-top": "Marca revisa $3 de $2 como patruliada?", "deletedrevision": "Sutrae revisa vea $1", diff --git a/languages/i18n/lg.json b/languages/i18n/lg.json index b1e6101219..fe1221f583 100644 --- a/languages/i18n/lg.json +++ b/languages/i18n/lg.json @@ -3,7 +3,8 @@ "authors": [ "Kizito", "아라", - "Macofe" + "Macofe", + "Erinamukuta" ] }, "tog-underline": "Enyunzi ebengako olukoloboze?", @@ -235,6 +236,7 @@ "nstab-template": "Lutiba", "nstab-help": "Buyambi", "nstab-category": "Ttuluba lya", + "mainpage-nstab": "Olupapula Olusinga Omugaso", "nosuchaction": "Ekikolwa ekyo tekisoboka", "nosuchactiontext": "Ekikolwa ekikongojedwa mu URL tekisoboka.
\nOyinza okuba nga URL wagiwandise bubi, oba yo URL y'eyinza okuba nga ya nsobi.
\nKiyinza ate okuba nti sofutiweya {{SITENAME}} gy'ekozesa erimu ebitali bituufu.", "nosuchspecialpage": "Olwo olupapula olwawule teruliwo", diff --git a/languages/i18n/li.json b/languages/i18n/li.json index 23ea9cb923..f7db609f54 100644 --- a/languages/i18n/li.json +++ b/languages/i18n/li.json @@ -2834,8 +2834,6 @@ "markedaspatrollederrornotify": "Markere es gecontroleerd mislök.", "patrol-log-page": "Markeerlogbook", "patrol-log-header": "Dit logbook bevat versies die gemarkeerd zeen es gecontroleerd.", - "log-show-hide-patrol": "Markeerlogbook $1", - "log-show-hide-tag": "$1 labellogbook", "confirm-markpatrolled-button": "Ok", "confirm-markpatrolled-top": "Markeer bewirking $3 van $2 es gecontroleerd?", "deletedrevision": "Aw versie $1 gewis", diff --git a/languages/i18n/lij.json b/languages/i18n/lij.json index a47b186be9..3849fa21a4 100644 --- a/languages/i18n/lij.json +++ b/languages/i18n/lij.json @@ -2723,8 +2723,6 @@ "markedaspatrollederrornotify": "Errô durante a veifica.", "patrol-log-page": "Modiffiche controlæ", "patrol-log-header": "Questo o l'è 'n registro de revixoin controlæ.", - "log-show-hide-patrol": "$1 registro di controlli", - "log-show-hide-tag": "$1 registro di etichette", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Marca verscion $3 de $2 comme veificâ?", "deletedrevision": "Scassou a vegia verscion de $1.", diff --git a/languages/i18n/lki.json b/languages/i18n/lki.json index e474285aa2..2e98cb9d49 100644 --- a/languages/i18n/lki.json +++ b/languages/i18n/lki.json @@ -2486,8 +2486,6 @@ "markedaspatrollederrornotify": "زدن برچسب گشت، ناموفق بود.", "patrol-log-page": "سیاههٔ گشت", "patrol-log-header": "این سیاهه‌ای از ویرایش‌های گشت‌خورده است.", - "log-show-hide-patrol": "$1 سیاههٔ گشت‌زنی", - "log-show-hide-tag": "$1 سیاهه برچسب", "deletedrevision": "$1 نسخهٔ حذف شدهٔ قدیمی", "filedeleteerror-short": "خطا در حذف پرونده: $1", "filedeleteerror-long": "در زمان حذف پرونده خطا رخ داد:\n\n$1", diff --git a/languages/i18n/lrc.json b/languages/i18n/lrc.json index fb7a5ee405..ab62a89bee 100644 --- a/languages/i18n/lrc.json +++ b/languages/i18n/lrc.json @@ -2372,8 +2372,6 @@ "markedaspatrollederrornotify": "نشودار کردن چی نشودار بیه شکست حرده", "patrol-log-page": "پهرستنومه گشتن", "patrol-log-header": "یه پهرستنومه وانئریا سردیاری کرده هئ.", - "log-show-hide-patrol": "$1 پهرستنومه سردیاری کردن", - "log-show-hide-tag": "سردیس پهرستنومه $1", "deletedrevision": "وانئری دماتری پاکسابیه د $1", "filedeleteerror-short": "خطا پاک نبیئن جانیا:$1", "filedeleteerror-long": "د گات پاکسا کردن جانیا یه گل خطا پیش اوما:\n\n\n$1", diff --git a/languages/i18n/lt.json b/languages/i18n/lt.json index 27d7605f26..78a274814b 100644 --- a/languages/i18n/lt.json +++ b/languages/i18n/lt.json @@ -2778,8 +2778,6 @@ "markedaspatrollederrornotify": "Nepavyko pažymėti kaip patikrinto.", "patrol-log-page": "Patikrinimų sąrašas", "patrol-log-header": "Tai patvirtintų versijų sąrašas.", - "log-show-hide-patrol": "$1 patvirtinimų sąrašą", - "log-show-hide-tag": "$1 žymės žurnalas", "confirm-markpatrolled-button": "GERAI", "deletedrevision": "Ištrinta sena versija $1", "filedeleteerror-short": "Klaida trinant rinkmeną: $1", diff --git a/languages/i18n/lus.json b/languages/i18n/lus.json index 800bcef29d..d7c7e263ea 100644 --- a/languages/i18n/lus.json +++ b/languages/i18n/lus.json @@ -1308,7 +1308,6 @@ "markedaspatrolledtext": "[[:$1]] ennawnna thlansa hi vil anga chhinchhiah a ni.", "markedaspatrollederror": "Vil anga chhinchhiah theih a ni lo", "patrol-log-page": "Vil chhinchhiahna", - "log-show-hide-patrol": "Vil chhinchhiahna $1", "filedeleteerror-long": "Taksa paih tum laiin buaina a lo thleng\n\n$1", "previousdiff": "←Siamţhatna hlui zâwk", "nextdiff": "Siamţhatna thar zâwk→", diff --git a/languages/i18n/lv.json b/languages/i18n/lv.json index 5176eaf4ff..e3a3066440 100644 --- a/languages/i18n/lv.json +++ b/languages/i18n/lv.json @@ -2353,7 +2353,6 @@ "markedaspatrollednotify": "Šī izmaiņa lapā \"$1\" ir atzīmēta kā patrulēta.", "patrol-log-page": "Pārbaudes reģistrs", "patrol-log-header": "Šis ir pārbaudīto versiju reģistrs.", - "log-show-hide-patrol": "$1 pārbaudes reģistrs", "confirm-markpatrolled-button": "Labi", "confirm-markpatrolled-top": "Atzīmēt lapas \"$2\" versiju $3 kā pārbaudītu?", "deletedrevision": "Izdzēstā vecā versija $1", diff --git a/languages/i18n/lzh.json b/languages/i18n/lzh.json index 8d86a73ba1..43496d7852 100644 --- a/languages/i18n/lzh.json +++ b/languages/i18n/lzh.json @@ -1932,7 +1932,6 @@ "markedaspatrollederror-noautopatrol": "己易不可自審。", "patrol-log-page": "誌哨", "patrol-log-header": "此乃誌哨也。", - "log-show-hide-patrol": "$1誌巡", "deletedrevision": "刪舊審$1", "filedeleteerror-short": "刪檔有誤:$1", "filedeleteerror-long": "刪檔有誤:\n\n$1", diff --git a/languages/i18n/mai.json b/languages/i18n/mai.json index 8e2a16b159..d4c3e75800 100644 --- a/languages/i18n/mai.json +++ b/languages/i18n/mai.json @@ -2475,8 +2475,6 @@ "markedaspatrollederrornotify": "जाँचल चिन्हासी असफल भेल।", "patrol-log-page": "परीक्षण लौग", "patrol-log-header": "ई परीक्षित अवतरणसभक लौग छी।", - "log-show-hide-patrol": "$1 निरीक्षण लौग", - "log-show-hide-tag": "$1 ट्याग लग", "deletedrevision": "पुरान संशोधन $1 हटा देलौं", "filedeleteerror-short": "संचिका मेटेबामे भ्रम : $1", "filedeleteerror-long": "संचिका मेटेबा काल भ्रम संकेत भेटल:\n$1", diff --git a/languages/i18n/mdf.json b/languages/i18n/mdf.json index 4c8257a4d9..8f4fd3c04d 100644 --- a/languages/i18n/mdf.json +++ b/languages/i18n/mdf.json @@ -1605,7 +1605,6 @@ "markedaspatrollederror-noautopatrol": "Тондейть аф мярьгови тяштемс эсь полфнемацень кода патрулень варжафт.", "patrol-log-page": "Патрулень лувомась", "patrol-log-header": "Патруль ала верзиетнень лувомась.", - "log-show-hide-patrol": "$1 патрулень лувомась", "deletedrevision": "Нардаф сире илякстоптома $1", "filedeleteerror-short": "Лиссь эльбятькс нардамста файл: $1", "filedeleteerror-long": "Лиссть эльбятькст нардамста файл:\n\n$1", diff --git a/languages/i18n/mg.json b/languages/i18n/mg.json index aea1f0e399..8d0cf62a7b 100644 --- a/languages/i18n/mg.json +++ b/languages/i18n/mg.json @@ -1252,15 +1252,20 @@ "recentchanges-legend-newpage": "{{int:recentchanges-label-newpage}} (jereo koa ny [[Special:NewPage|lisitry ny pejy vaovao]])", "recentchanges-submit": "Aseho", "rcfilters-activefilters": "Sivana miasa", + "rcfilters-activefilters-hide-tooltip": "Hanafina ny faritry ny sivana miasa", "rcfilters-advancedfilters": "Sivana havanana kokoa", "rcfilters-quickfilters": "Sivana notehirizina", "rcfilters-quickfilters-placeholder-title": "Tsy mbola misy sivana notehirizina", "rcfilters-savedqueries-defaultlabel": "Sivana voatahiry", "rcfilters-savedqueries-rename": "Hanova ny anarana", + "rcfilters-savedqueries-setdefault": "Ampiasaina ho solon'ny tsy misy", "rcfilters-savedqueries-remove": "Esorina", "rcfilters-savedqueries-new-name-label": "Anarana", + "rcfilters-savedqueries-new-name-placeholder": "Visavisao eto ny tanjon'ilay sivana", "rcfilters-savedqueries-apply-label": "Hamorona rohy haingana", + "rcfilters-savedqueries-apply-and-setdefault-label": "Hamorona sivana solon'ny tsy misy", "rcfilters-savedqueries-cancel-label": "Avela", + "rcfilters-savedqueries-already-saved": "Efa voatahiry ireo sivana ireo. Ovay ny parametatra hamoronana sivana voatahiry vaovao.", "rcfilters-restore-default-filters": "Hamerina sivana ampiasaina raha tsy misy", "rcfilters-clear-all-filters": "Hamafa ny sivana rehetra", "rcfilters-search-placeholder": "Hanivana ny fiovana farany (tetezo na manomboha manoratra)", @@ -1321,6 +1326,8 @@ "rcfilters-filter-excluded": "Foanana", "rcfilters-tag-prefix-namespace-inverted": ":not $1", "rcfilters-view-tags": "Fiovam-pejy voamarika", + "rcfilters-view-namespaces-tooltip": "Hanasivana ny valiny araka ny anaran-tsehatra", + "rcfilters-view-return-to-default-tooltip": "Hiverina amin'ny menion'ny sivana", "rcfilters-liveupdates-button": "Fihavaozana mivantana", "rcnotefrom": "Eo ambany dia ahitana ireo fiovana{{PLURAL:$5}} hatry ny $3, $4 (naseho hatramin'ny $1).", "rclistfrom": "Asehoy izay vao niova manomboka ny $3 $2", @@ -2540,8 +2547,6 @@ "markedaspatrollederrornotify": "Tsy nahamarika azy ho voaara-maso.", "patrol-log-page": "Laogin'ny fanovana voamarina", "patrol-log-header": "Ity dia laogy mikasikan'ny fanovana voamarina.", - "log-show-hide-patrol": "$1 ny laogy mikasikan'ny versiona voamarina", - "log-show-hide-tag": "$1 laogim-balizy", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Hanamarika ny reviziôna $3 an'i $2 ho voamarina?", "deletedrevision": "Fanovana an'i $1 taloha voafafa.", diff --git a/languages/i18n/min.json b/languages/i18n/min.json index 4a7c7e127a..642e01eba3 100644 --- a/languages/i18n/min.json +++ b/languages/i18n/min.json @@ -1604,7 +1604,6 @@ "rcpatroldisabled": "Patroli parubahan baru dimatian", "patrol-log-page": "Log patroli", "patrol-log-header": "Iko daftar log revisi nan alah dipatroli.", - "log-show-hide-patrol": "$1 log patroli", "previousdiff": "← Revisi sabalunnyo", "nextdiff": "Revisi salanjuiknyo →", "imagemaxsize": "Bateh ukuran gambar:
''(untuak laman katarangan berkas)''", diff --git a/languages/i18n/mk.json b/languages/i18n/mk.json index b4b35ff187..4580593ada 100644 --- a/languages/i18n/mk.json +++ b/languages/i18n/mk.json @@ -931,6 +931,8 @@ "diff-paragraph-moved-toold": "Пасусот е преместен. Стиснете за да прејдете на старото место.", "difference-missing-revision": "Не пронајдов {{PLURAL:$2|една преработка|$2 преработки}} од оваа разлика ($1).\n\nОва обично се должи на застарена врска за разлики што води кон избришана страница.\nПовеќе подробности ќе најдете во [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} дневникот на бришења].", "searchresults": "Исход од пребарувањето", + "search-filter-title-prefix": "Пребарување по страници чиј наслов почнува со „$1“", + "search-filter-title-prefix-reset": "Пребарај по сите страници", "searchresults-title": "Исход од пребарувањето на „$1“", "titlematches": "Совпаднати наслови", "textmatches": "Совпаднат текст во страниците", @@ -1739,6 +1741,7 @@ "http-timed-out": "HTTP-барањето истече.", "http-curl-error": "Грешка при добивањето на URL: $1", "http-bad-status": "Се појави проблем во текот на обработката на HTTP-барањето: $1 $2", + "http-internal-error": "Внатрешна грешка со HTTP.", "upload-curl-error6": "Не може да се пристапи до URL-то", "upload-curl-error6-text": "Наведеното URL не е достапно.\nПроверете дали URL-то е исправно и достапно.", "upload-curl-error28": "Истече времето за подигање", @@ -2033,7 +2036,7 @@ "speciallogtitlelabel": "Цел (наслов или {{ns:user}}:корисничко име на корисникот):", "log": "Дневници", "logeventslist-submit": "Прикажи", - "logeventslist-more-filters": "Повеќе филтри:", + "logeventslist-more-filters": "Прикажи повеќе дневници:", "logeventslist-patrol-log": "Дневник на патролирања", "logeventslist-tag-log": "Дневник на ознаки", "all-logs-page": "Сите јавни дневници", @@ -2895,8 +2898,6 @@ "markedaspatrollederrornotify": "Означувањето како испатролирано не успеа.", "patrol-log-page": "Дневник на патролирања", "patrol-log-header": "Ова е дневник на патролирани преработки.", - "log-show-hide-patrol": "$1 дневник на патролирање", - "log-show-hide-tag": "$1 дневник на ознаки", "confirm-markpatrolled-button": "ОК", "confirm-markpatrolled-top": "Да ја означан преработката $3 на $2 како испатролирана?", "deletedrevision": "Избришана стара преработка $1.", diff --git a/languages/i18n/ml.json b/languages/i18n/ml.json index b4d51b8a06..de580c92a1 100644 --- a/languages/i18n/ml.json +++ b/languages/i18n/ml.json @@ -2733,8 +2733,6 @@ "markedaspatrollederrornotify": "റോന്തുചുറ്റിയതെന്ന് അടയാളപ്പെടുത്തൽ പരാജയപ്പെട്ടു.", "patrol-log-page": "റോന്തുചുറ്റൽ പ്രവർത്തനരേഖ", "patrol-log-header": "റോന്തുചുറ്റപ്പെട്ട നാൾപ്പതിപ്പുകളുടെ രേഖയാണിത്", - "log-show-hide-patrol": "റോന്തുചുറ്റൽ രേഖ $1", - "log-show-hide-tag": "ടാഗ് രേഖ $1", "confirm-markpatrolled-button": "ശരി", "confirm-markpatrolled-top": "$2 താളിലെ $3 നാൾപ്പതിപ്പ് റോന്തുചുറ്റിയതായി അടയാളപ്പെടുത്തണോ?", "deletedrevision": "$1 എന്ന പഴയ പതിപ്പ് മായ്ച്ചിരിക്കുന്നു", diff --git a/languages/i18n/mn.json b/languages/i18n/mn.json index d7d3dc5ae9..84528b97b1 100644 --- a/languages/i18n/mn.json +++ b/languages/i18n/mn.json @@ -2128,7 +2128,6 @@ "markedaspatrollederror-noautopatrol": "Та өөрийн өөрчлөлтүүдээ эргүүлээр хянагдсан гэж тэмдэглэж болохгүй.", "patrol-log-page": "Эргүүлийн лог", "patrol-log-header": "Энэ нь манагдсан засваруудын лог юм.", - "log-show-hide-patrol": "мануулын логийг $1", "deletedrevision": "Хуучин засвар $1 нь устгагдлаа", "filedeleteerror-short": "Файлыг устгахад алдаа гарлаа: $1", "filedeleteerror-long": "Дараах файлыг устгахад алдаа гарлаа:\n\n$1", diff --git a/languages/i18n/mr.json b/languages/i18n/mr.json index 4f0d86b1e7..57e3609ba3 100644 --- a/languages/i18n/mr.json +++ b/languages/i18n/mr.json @@ -1072,6 +1072,7 @@ "prefs-dateformat": "दिनांक प्रारुपण", "prefs-timeoffset": "वेळ बरोबरी", "prefs-advancedediting": "सर्वसामान्य पर्याय", + "prefs-developertools": "विकसक उपकरण", "prefs-editor": "संपादक", "prefs-preview": "झलक", "prefs-advancedrc": "प्रगत पर्याय", @@ -2688,7 +2689,6 @@ "markedaspatrollederrornotify": "'पहारा दिला' म्हणून अंकित करणे विफल झाले.", "patrol-log-page": "टेहळणीतील नोंदी", "patrol-log-header": "ही पाहणीनंतरच्या निरीक्षणाची नोंद आहे.", - "log-show-hide-patrol": "$1 गस्तीची नोंद", "confirm-markpatrolled-button": "ठीक आहे", "confirm-markpatrolled-top": "$2च्या $3 आवृत्तीवर पहारा दिला म्हणून खूण करायची?", "deletedrevision": "जुनी आवृत्ती ($1) वगळली.", @@ -3454,7 +3454,7 @@ "logentry-protect-protect-cascade": "$1 ने $3 $4 [निपतन]ला {{GENDER:$2|सुरक्षित केले}}", "logentry-protect-modify": "$1 ने $3 $4 ची सुरक्षा पातळी {{GENDER:$2|बदलली}}", "logentry-protect-modify-cascade": "$1 ने $3 $4 [निपतन]ची सुरक्षा पातळी {{GENDER:$2|बदलली}}", - "logentry-rights-rights": "$1 ने {{GENDER:$6|$3}} साठी $4 वरुन $5 ला गट सदस्यता{{GENDER:$2|बदलली}}", + "logentry-rights-rights": "$1 ने {{GENDER:$6|$3}} साठी $4 वरुन $5 ला गट सदस्यता {{GENDER:$2|बदलली}}", "logentry-rights-rights-legacy": "$1 ने $3 साठी गट सदस्यता {{GENDER:$2|बदलली}}", "logentry-rights-autopromote": "$1 ला स्वयंचलितरित्या $4 वरुन $5 ला {{GENDER:$2|बढती दिल्या गेली}}", "logentry-upload-upload": "$1 {{GENDER:$2|अपभारीत केली}} $3", diff --git a/languages/i18n/ms.json b/languages/i18n/ms.json index dc340160dd..50f6e19111 100644 --- a/languages/i18n/ms.json +++ b/languages/i18n/ms.json @@ -2524,8 +2524,6 @@ "markedaspatrollederrornotify": "Penandaan sebagai dironda gagal.", "patrol-log-page": "Log pemeriksaan", "patrol-log-header": "Yang berikut ialah log rondaan bagi semakan.", - "log-show-hide-patrol": "$1 log rondaan", - "log-show-hide-tag": "$1 log teg", "deletedrevision": "Menghapuskan semakan lama $1.", "filedeleteerror-short": "Ralat ketika menghapuskan fail: $1", "filedeleteerror-long": "Berlaku ralat ketika menghapuskan fail tersebut:\n\n$1", diff --git a/languages/i18n/mt.json b/languages/i18n/mt.json index 25a622a489..5ab6b4cf5d 100644 --- a/languages/i18n/mt.json +++ b/languages/i18n/mt.json @@ -2230,8 +2230,6 @@ "markedaspatrollederrornotify": "L-ivverifikar tal-modifika falla.", "patrol-log-page": "Modifiki verifikati", "patrol-log-header": "Dan huwa reġistru ta' reviżjonijiet verifikati.", - "log-show-hide-patrol": "$1 r-reġistru tal-modifiki verifikati", - "log-show-hide-tag": "$1 r-reġistru tat-tikketti", "deletedrevision": "Reviżjoni preċedenti, mħassra: $1", "filedeleteerror-short": "Problema waqt li kont qiegħed tħassar il-fajl: $1", "filedeleteerror-long": "Ġew verifikati xi problemi waqt li kont qiegħed tħassar il-fajl:\n\n$1", diff --git a/languages/i18n/my.json b/languages/i18n/my.json index da5d40da7b..cf3cc7f5fc 100644 --- a/languages/i18n/my.json +++ b/languages/i18n/my.json @@ -1705,7 +1705,6 @@ "markedaspatrolledtext": "[[:$1]] ၏ ရွေးချယ်ထားသော တည်းဖြတ်မူကို စောင့်ကြပ်စစ်ဆေးပြီးကြောင်း မှတ်သားပြီးပါပြီ။", "markedaspatrollednotify": "$1 သို့ ဤပြောင်းလဲမှုအား စောင့်ကြပ်စစ်ဆေးပြီးကြောင်း မှတ်သားပြီးပါပြီ။", "patrol-log-page": "စောင့်ကြပ်စစ်ဆေးမှု မှတ်တမ်း", - "log-show-hide-patrol": "စောင့်ကြပ်စစ်ဆေးမှု မှတ်တမ်း $1", "filedeleteerror-short": "ဖိုင်ဖျက်ရာတွင် အမှားအယွင်း - $1", "previousdiff": "← တည်းဖြတ်မူ အဟောင်း", "nextdiff": "ပိုသစ်သော တည်းဖြတ်မှု", diff --git a/languages/i18n/myv.json b/languages/i18n/myv.json index df0f72b43b..20ebd82e6a 100644 --- a/languages/i18n/myv.json +++ b/languages/i18n/myv.json @@ -1388,7 +1388,6 @@ "markaspatrolledtext": "Тешкстамс те лопанть ванстнемань ютазекс", "markedaspatrolled": "Тешкстазь ванстнемань ютазекс", "patrol-log-page": "Ванстнемадо конёв", - "log-show-hide-patrol": "$1 патрулонь журналонть", "deletedrevision": "Нардань ташто лиякстомтома $1", "filedeleteerror-short": "\"$1\" керьмазонть нардамсто лиссь ильведевкс", "previousdiff": "← Седе икелень верзиязо", diff --git a/languages/i18n/nan.json b/languages/i18n/nan.json index 3a93f60496..38beb03fef 100644 --- a/languages/i18n/nan.json +++ b/languages/i18n/nan.json @@ -987,6 +987,7 @@ "movelogpagetext": "Ē-kha lia̍t-chhut hông soá-ūi ê ia̍h.", "movereason": "Lí-iû:", "revertmove": "hôe-tńg", + "delete_and_move_reason": "Thâi-ia̍h hō͘ \"[[$1]]\" thang sóa-ia̍h kòe--lâi", "selfmove": "Goân piau-tê kap sin piau-tê sio-siâng; bô hoat-tō· sóa.", "protectedpagemovewarning": "'''KÉNG-KÒ: Pún ia̍h só tiâu leh. Kan-taⁿ ū hêng-chèng te̍k-koân ê iōng-chiá (sysop) ē-sái soá tín-tāng.'''\nĒ-kha ū choè-kīn ê kì-lio̍k thang chham-khó:", "export": "Su-chhut ia̍h", @@ -1120,6 +1121,7 @@ "tag-list-wrapper": "([[Special:Tags|{{PLURAL:$1|piau-chhiam}}]]: $2)", "tag-mw-new-redirect": "Sin choán-ia̍h", "tag-mw-changed-redirect-target": "Choán-ia̍h bo̍k-phiau kái-piàn", + "logentry-delete-delete_redir": "$1 ēng têng-siá lâi kā choán-ia̍h $3 {{GENDER:$2|thâi-tiāu}}", "logentry-move-move": "$1 {{GENDER:$2|sóa}} $3 chit ia̍h khì $4", "logentry-move-move_redir": "$1 iōng choán-ia̍h {{GENDER:$2|sóa}} ia̍h-bīn $3 kòe $4", "logentry-newusers-create": "已經{{GENDER:$2|開好}}用者口座 $1", diff --git a/languages/i18n/nap.json b/languages/i18n/nap.json index 83ef7bf5a6..6b18e7184b 100644 --- a/languages/i18n/nap.json +++ b/languages/i18n/nap.json @@ -2609,8 +2609,6 @@ "markedaspatrollederrornotify": "Errore pe' tramente ca se nzegnava comme cuntrullata.", "patrol-log-page": "Riggistro 'e cuntrolle", "patrol-log-header": "Chest'è nu riggistro ch' 'e verziune cuntrullate.", - "log-show-hide-patrol": "$1 riggistro 'e cuntrolle", - "log-show-hide-tag": "$1 tag log", "deletedrevision": "Viecchia verziona scancellata $1", "filedeleteerror-short": "Errore pe' tramente ca se scancellava nu file: $1", "filedeleteerror-long": "N'errore s'è apprisentato pe' tramente ca se scancellava 'o file:\n\n$1", diff --git a/languages/i18n/nb.json b/languages/i18n/nb.json index 266ba6406b..857f8b05f0 100644 --- a/languages/i18n/nb.json +++ b/languages/i18n/nb.json @@ -51,7 +51,8 @@ "Nemo bis", "Telaneo", "Jon Harald Søby", - "Fitoschido" + "Fitoschido", + "Orf3us" ] }, "tog-underline": "Strek under lenker:", @@ -671,7 +672,7 @@ "subject-preview": "Forhåndsvisning av overskrift:", "previewerrortext": "En feil oppsto mens dine endringer skulle forhåndsvises.", "blockedtitle": "Brukeren er blokkert", - "blockedtext": "Ditt brukernavn eller din IP-adresse har blitt blokkert.\n\nBlokkeringen ble utført av $1. Grunnen som ble oppgitt var $2.\n\n* Blokkeringen begynte: $8\n* Blokkeringen opphører: $6\n* Blokkeringen ment for: $7\n\nDu kan kontakte $1 eller en annen [[{{MediaWiki:Grouppage-sysop}}|administrator]] for å diskutere blokkeringen.\nDu kan ikke bruke \"{{int:emailuser}}\"-funksjonen med mindre du har oppgitt en gyldig e-postadresse i [[Special:Preferences|innstillingene dine]] og du ikke har blitt blokkert fra å sende e-post.\nDin nåværende IP-adresse er $3, og blokkerings-ID-en er #$5.\nVennligst ta med all denne informasjonen ved henvendelser.", + "blockedtext": "Ditt brukernavn eller din IP-adresse har blitt blokkert.\n\nBlokkeringen ble utført av $1. Grunnen som ble oppgitt var $2.\n\n* Blokkeringen begynte: $8\n* Blokkeringen opphører: $6\n* Blokkeringen ment for: $7\n\nDu kan kontakte $1 eller en annen [[{{MediaWiki:Grouppage-sysop}}|administrator]] for å diskutere blokkeringen.\nDu kan ikke bruke «{{int:emailuser}}»-funksjonen med mindre du har oppgitt en gyldig e-postadresse i [[Special:Preferences|innstillingene dine]] og du ikke har blitt blokkert fra å sende e-post.\nDin nåværende IP-adresse er $3, og blokkerings-ID-en er #$5.\nVennligst ta med all denne informasjonen ved henvendelser.", "autoblockedtext": "Din IP-adresse har blitt automatisk blokkert fordi den ble brukt av en annen bruker som ble blokkert av $1.\nDen oppgitte grunnen var:\n\n:'''$2'''\n\n* Blokkeringen begynte: $8\n* Blokkeringen utgår: $6\n* Blokkeringen er ment for: $7\n\nDu kan kontakte $1 eller en av de andre [[{{MediaWiki:Grouppage-sysop}}|administratorene]] for å diskutere blokkeringen.\n\nMerk at du ikke kan bruke «{{int:emailuser}}»-funksjonen med mindre du har registrert en gyldig e-postadresse i [[Special:Preferences|innstillingene dine]].\n\nDin IP-adresse er $3, og blokkerings-ID-en er #$5.\nVennligst ta med all denne informasjonen ved henvendelser.", "systemblockedtext": "Ditt brukernavn eller IP-adresse har blitt blokkert automatisk av MediaWiki.\n\nBlokkeringen grunnes:\n\n:$2\n\n* Blokkeringen startet: $8\n* Blokkeringen gjelder til: $6\n* Blokkeringen er ment for: $7\n\nDin nåværende IP-adresse er $3.\nVennligst inkluder informasjonen over i alle spørsmål du spør angående dette.", "blockednoreason": "ingen grunn gitt", @@ -955,6 +956,8 @@ "diff-paragraph-moved-toold": "Avsnittet ble flyttet. Klikk for å hoppe til den gamle plasseringen.", "difference-missing-revision": "{{PLURAL:$2|En revisjon|$2 revisjoner}} av denne forskjellen ($1) {{PLURAL:$2|ble|ble}} ikke funnet.\n\nDette skyldes som regel at en gammel forskjell-lenke er fulgt til en side som er slettet.\nDetaljer kan finnes i [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} sletteloggen].", "searchresults": "Søkeresultater", + "search-filter-title-prefix": "Søker bare i sider der tittelen begynner med «$1»", + "search-filter-title-prefix-reset": "Søk i alle sider", "searchresults-title": "Søkeresultater for «$1»", "titlematches": "Artikkeltitler med treff på forespørselen", "textmatches": "Artikkeltekster med treff på forespørselen", @@ -1483,7 +1486,7 @@ "rcfilters-watchlist-showupdated": "Endringer til sider du ikke har besøkt siden endringene ble gjort vises med fet skrift.", "rcfilters-preference-label": "Skjul den forbedrede versjonen av siste endringer", "rcfilters-preference-help": "Fjerner grensesnittendringen fra 2017 og alle verktøyene som ble lagt fra og med da.", - "rcfilters-watchlist-preference-label": "Skjul den forbedrede versjonen av bevåkningslisten", + "rcfilters-watchlist-preference-label": "Skjul den forbedrede versjonen av overvåkningslisten", "rcfilters-watchlist-preference-help": "Ruller tilbake det omarbeidede grensesnittet fra 2017 og alle verktøy som ble lagt til da og etterpå.", "rcfilters-filter-showlinkedfrom-label": "Vis endringer på sider som lenkes fra", "rcfilters-filter-showlinkedfrom-option-label": "Sider som lenkes fra den valgte siden", @@ -2013,7 +2016,7 @@ "apisandbox-dynamic-parameters-add-label": "Legg til parameter:", "apisandbox-dynamic-parameters-add-placeholder": "Parameternavn", "apisandbox-dynamic-error-exists": "En parameter med navn «$1» finnes fra før.", - "apisandbox-templated-parameter-reason": "Denne [[Special:ApiHelp/main#main/templatedparams|templated parameteren]] tilbys basert på {{PLURAL:$1|verdi|verdier}} av $2.", + "apisandbox-templated-parameter-reason": "Denne [[Special:ApiHelp/main#main/templatedparams|malparameteren]] tilbys basert på {{PLURAL:$1|verdien|verdiene}} til $2.", "apisandbox-deprecated-parameters": "Utgåtte parametre", "apisandbox-fetch-token": "Fyll inn nøkkelen automatisk", "apisandbox-add-multi": "Legg til", @@ -2054,7 +2057,7 @@ "speciallogtitlelabel": "Mål (tittel eller {{ns:user}}:brukernavn for brukeren):", "log": "Logger", "logeventslist-submit": "Vis", - "logeventslist-more-filters": "Flere filtre:", + "logeventslist-more-filters": "Vis flere logger:", "logeventslist-patrol-log": "Patruljeringslogg", "logeventslist-tag-log": "Merkelogg", "all-logs-page": "Alle offentlige logger", @@ -2251,7 +2254,7 @@ "deletionlog": "slettelogg", "log-name-create": "Logg over nye sider", "log-description-create": "Under er ei liste over nylige sideopprettelser.", - "logentry-create-create": "$1 {{GENDER:$2|opprettet}} side $3", + "logentry-create-create": "$1 {{GENDER:$2|opprettet}} siden $3", "reverted": "Gjenopprettet en tidligere versjon", "deletecomment": "Årsak:", "deleteotherreason": "Annen/utdypende grunn:", @@ -2912,8 +2915,6 @@ "markedaspatrollederrornotify": "Patruljering feilet.", "patrol-log-page": "Patruljeringslogg", "patrol-log-header": "Dette er en logg over patruljerte sideversjoner.", - "log-show-hide-patrol": "$1 patruljeringslogg", - "log-show-hide-tag": "$1 merkelogg", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Merk revisjon $3 av $2 som patruljert?", "deletedrevision": "Slettet gammel revisjon $1.", @@ -4097,7 +4098,7 @@ "pagedata-text": "Denne siden gir et datagrensesnitt til sidene. Oppgi en sidetittel i URL-en, med undersidesyntaks.\n* Innholdsforhandlingen er basert på din klients Accept-header. Dette betyr at data for siden blir angitt på formatet som foretrekkes av din klient.", "pagedata-not-acceptable": "Ingen passende format funnet. Støttede MIME-typer: $1", "pagedata-bad-title": "Ugyldig tittel: $1.", - "unregistered-user-config": "For å ivareta sikkerhet kan JavaScript, CSS and JSON ikks brukes i underliggende sider for uregistrerte brukere.", + "unregistered-user-config": "For å ivareta sikkerhet kan ikke JavaScript-, CSS- og JSON-undersider lastes for uregistrerte brukere.", "passwordpolicies": "Passord-regler", "passwordpolicies-summary": "Det finnes en liste over gode passord-regler for brukergrupper definert i denne wikien.", "passwordpolicies-group": "Gruppe", diff --git a/languages/i18n/nds-nl.json b/languages/i18n/nds-nl.json index 663fec189f..a03d10486b 100644 --- a/languages/i18n/nds-nl.json +++ b/languages/i18n/nds-nl.json @@ -2285,7 +2285,6 @@ "markedaspatrollederrornotify": "Markeren as nao-ekeken is mislokt.", "patrol-log-page": "Markeerlogboek", "patrol-log-header": "In dit logboek staon de versies die op nao-ekeken ezet bin.", - "log-show-hide-patrol": "Markeerlogboek $1", "deletedrevision": "Vortedaone ouwe versie $1.", "filedeleteerror-short": "Fout bie t vortdoon van bestaand: $1", "filedeleteerror-long": "Der waren fouten bie t vortdoon van t bestaand:\n\n$1", diff --git a/languages/i18n/nds.json b/languages/i18n/nds.json index 3ae3f9c330..c5b1a289a9 100644 --- a/languages/i18n/nds.json +++ b/languages/i18n/nds.json @@ -1739,7 +1739,6 @@ "markedaspatrollederror-noautopatrol": "Du kannst de Saken, de du sülvst ännert hest, nich as nakeken marken.", "patrol-log-page": "Nakiek-Logbook", "patrol-log-header": "Dit is dat Patrolleer-Logbook.", - "log-show-hide-patrol": "Nakiek-Logbook $1", "deletedrevision": "Löschte ole Version $1", "filedeleteerror-short": "Fehler bi dat Wegsmieten vun de Datei: $1", "filedeleteerror-long": "Dat geev Fehlers bi dat Wegsmieten vun de Datei:\n\n$1", diff --git a/languages/i18n/ne.json b/languages/i18n/ne.json index fcd4a289e5..5002cfa696 100644 --- a/languages/i18n/ne.json +++ b/languages/i18n/ne.json @@ -27,7 +27,8 @@ "रमेश सिंह बोहरा", "Nirajan pant", "Drjpoudel", - "Fitoschido" + "Fitoschido", + "Nabin Sapkota" ] }, "tog-underline": "रेखाङ्कित लिङ्क:", @@ -614,7 +615,7 @@ "subject-preview": "विषयको पूर्वावलोकन:", "previewerrortext": "तपाईंको परिवर्तनको पूर्वावलोकन बनाउन खोज्दा समस्या आएको छ ।", "blockedtitle": "प्रयोककर्तालाई रोक लगाइएको छ", - "blockedtext": "'''तपाईंको प्रयोगकर्ता नाम या आइ पी ठेगानालाई रोक लगाइएको छ ।'''\n\nरोक लगाउने $1.\nरोक लगाउनाको कारण ''$2''.\n\n* रोक सुरू हुने : $8\n* रोक सकिने: $6\n* रोकबाट लक्षित: $7\n\nतपाईंले $1 वा अरु कुनै [[{{MediaWiki:Grouppage-sysop}}|प्रवन्धक]] सँग रोकको बारेमा छलफल गर्न सम्पर्क गर्न सक्नुहुन्छ ।\nतपाईँले 'प्रयोगकर्तालाई इ-मेल गर्ने ' सुविधा मान्य इमेल ठेगाना [[Special:Preferences|अभिरुचीहरू]]मा नखुलाए सम्म प्रयोगगर्न पाउनुहुने छैन र यसको प्रयोग गर्नबाट रोक लगाइएको छैन ।\nतपाईंको IP ठेगाना $3 को, र रोक्का संख्या #$5.\nकृपया तपाईँको प्रश्नमा सबै जानकारी खुलाउनुहोला ।", + "blockedtext": "'''तपाईंको प्रयोगकर्ता नाम वा आइपी ठेगानालाई रोक लगाइएको छ ।'''\n\nरोक लगाउने $1.\nरोक लगाउनाको कारण ''$2''.\n\n* रोक सुरू हुने : $8\n* रोक सकिने: $6\n* रोकबाट लक्षित: $7\n\nतपाईंले $1 वा अरु कुनै [[{{MediaWiki:Grouppage-sysop}}|प्रवन्धक]] सँग रोकको बारेमा छलफल गर्न सम्पर्क गर्न सकिन्छ ।\nतपाईँले ''{{int:emailuser}}'' सुविधा मान्य इमेल ठेगाना [[Special:Preferences|अभिरुचीहरू]]मा नखुलाए सम्म प्रयोगगर्न पाउनुहुने छैन र यसको प्रयोग गर्नबाट रोक लगाइएको छैन ।\nतपाईंको IP ठेगाना $3 को, र रोक्का संख्या #$5.\nकृपया तपाईँको प्रश्नमा सबै जानकारी खुलाउनुहोला ।", "autoblockedtext": "तपाईंको IP ठेगानामाथि रोक लगाइएकोछ किन भनें यो अर्को प्रयोगकर्ताले प्रयोग गरेको थियो, जसलाई $1ले रोक लगाएका थिए। \nरोक लगाउनुको कारण:\n:''$2'' \n\n* रोकावट सुरु: $8\n* रोकावट सकिने: $6\n* रोकावटको प्रयोजन: $7\n\nतपाईं $1 सित सम्पर्क गर्न सक्नुहुन्छ अथवा कुनै [[{{MediaWiki:Grouppage-sysop}}|प्रबन्धक]]सँग रोकबारे चर्चा गर्न सक्नुहुन्छ ।\n\nध्यान दिनुहोस् कि तपाईंले यस प्रयोगकर्ताका लागि ई-मेलको प्रयोग तबसम्म गर्नसक्नुहुन्न जबसम्म तपाईंको [[Special:Preferences|अभिरुचि]] पंजिकृत गर्नु हुन्न वा यस ई-मेलको प्रयोगमाथि रोक लगाइएको हुँदैन । \n\nतपाईंको वर्तमान IP ठेगाना हो- $3, अनि रोक लगाइएको ID हो- #$5.\nकृपया कुनै बेला सोधनी गर्नु परे उपर्युक्त विवरण दर्शाउनु होला ।", "blockednoreason": "कारण दिइएको छैन", "whitelistedittext": "पाना सम्पादन गर्न तपाँईले $1 गर्नु पर्दछ।", @@ -628,7 +629,7 @@ "accmailtext": "जथाभावीरूपमा सृजना गरिएको प्रवेशशब्द प्रयोगकर्ता [[User talk:$1|$1]] को $2 मा पठाइएको छ।\n\nयो नयाँ खाताको प्रवेशशब्द ''[[Special:ChangePassword|change password]]'' मा प्रवेश गरेर परिवर्तन गर्न सकिन्छ ।", "newarticle": "(नयाँ)", "newarticletext": "तपाईंले अहिले सम्म नभएको पृष्ठको लिङ्क पहिल्याउनु भएको छ।\nयो पृष्ठ निर्माण गर्न तलको कोष्ठमा टाइप गर्नुहोस् ।(थप जानकारीको लागि [$1 help page] हेर्नुहोस् )।\nयहाँ त्यत्तिकै आइपुग्नु भएको हो भने , ब्राउजरको '''back''' बटन थिच्नुहोस् ।", - "anontalkpagetext": "----''यो वार्तालाप पृष्ठ अज्ञात प्रयोगकर्ताको हो जसले अहिलेसम्म खाता बनाएकै छैन, अथवा जसले यस पृष्ठको उपयोग गर्दैन।\nयस कारण हामीले उसलाई उसको आइ पी (IP) ठेगानाले चिन्न सक्छौं। \nयस्तो आइ पी (IP) ठेगाना धेरै प्रयोगकर्ताहरूको साझा हुनसक्छ।\nयदि तपाईं अज्ञात प्रयोगकर्ता हुनुहुन्छ र तपाईंमाथि अचाहिँदो टिप्पणी भएको अनुभव गर्नुहुन्छ भने भविष्यमा अन्य अज्ञात प्रयोगकर्तासितको भ्रमबाट बाँच्न कृपया [[Special:CreateAccount|खाता खोल्नुहोस्]] अथवा [[Special:UserLogin|प्रवेश गर्नुहोस्]] ''", + "anontalkpagetext": "----''यो वार्तालाप पृष्ठ अज्ञात प्रयोगकर्ताको हो जसले अहिलेसम्म खाता बनाएकै छैन, अथवा जसले यस पृष्ठको उपयोग गर्दैन।\nयस कारण हामीले उसलाई उसको आइपी ठेगानाले चिन्न सक्छौं। \nयस्तो आइपी ठेगाना धेरै प्रयोगकर्ताहरूको साझा हुनसक्छ।\nयदि तपाईं अज्ञात प्रयोगकर्ता हुनुहुन्छ र तपाईंमाथि अचाहिँदो टिप्पणी भएको अनुभव गर्नुहुन्छ भने भविष्यमा अन्य अज्ञात प्रयोगकर्तासित अलमलिनबाट बच्न कृपया [[Special:CreateAccount|खाता खोल्नुहोस्]] अथवा [[Special:UserLogin|प्रवेश गर्नुहोस्]] ''", "noarticletext": "यस लेखमा अहिले केहि पनि पाठ छैन ।\nतपाईंले अन्य पृष्ठमा [[Special:Search/{{PAGENAME}}|यस पृष्ठको शीर्षकको लागि खोज]] गर्न सक्नुहुन्छ ।\n[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} पृष्ठ सम्बन्धित ढड्डामा खोज],\nवा [{{fullurl:{{FULLPAGENAME}}|action=edit}} यसै पृष्ठलाई सम्पादन गर्ने].", "noarticletext-nopermission": "यस लेखमा अहिले कुनै पनि पाठ छैन ।\nतपाईंले अन्य पृष्ठमा [[Special:Search/{{PAGENAME}}|यस पृष्ठको शीर्षकको लागि खोज]] गर्न सक्नुहुन्छ,\nअथवा [{{fullurl:{{#Special:Log}}|पृष्ठ={{FULLPAGENAMEE}}}} सम्बन्धित लगहरू खोज्न सक्नुहुनेछ ] तर तपाईंलाई नयाँ पृष्ठ बनाउने अधिकार छैन।", "missing-revision": "\"{{FULLPAGENAME}}\" पृष्ठको अवतरण #$1 रहेको छैन।\n\nसामान्य रूपमा यसो एउटा हटाइएको पृष्ठको पुरानो लिङ्कमा क्लिक गर्दा हुन्छ।\nअधिक जानकारीको लागि तपाईं [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} हटाएको लग] हेर्न सक्नुहुन्छ।", @@ -1278,7 +1279,7 @@ "recentchangeslinked-feed": "सम्बन्धित परिवर्तनहरू", "recentchangeslinked-toolbox": "सम्बन्धित परिवर्तनहरू", "recentchangeslinked-title": "\"$1\" सँग सम्बन्धित परिवर्तन", - "recentchangeslinked-summary": "यो सूची निर्दिष्ट पृष्ठ (वा निर्दिष्ट श्रेणी)सित जोडिएका भर्खरै परिवर्तन भएका पृष्ठको हो । [[Special:Watchlist|तपाईंको निगरानी सूची]]का पृष्ठहरू गाढा अक्षरमा छन् ।", + "recentchangeslinked-summary": "कुनै पृष्ठको वा यससँग सम्बन्धित परिवर्तन हेर्नको लागि उक्त पृष्ठको नाम हाल्नुहोस। (कुनै श्रेणीको सामाग्रीहरुको लागि {{ns:category}}: श्रेणीको नाम हल्नुहोस । [[Special:Watchlist|तपाईंको अवलोकन सूची]]का पृष्ठहरू गाढा अक्षरमा छन् ।", "recentchangeslinked-page": "पृष्ठ नाम:", "recentchangeslinked-to": "यसको सट्टा यो पृष्ठसँग जोडिएका पृष्ठहरूको परिवर्तन देखाउने", "upload": "फाइल उर्ध्वभरण", @@ -1827,7 +1828,7 @@ "unwatchthispage": "निगरानीबाट हटाउने", "notanarticle": "सामाग्री सहितको पेज हैन", "notvisiblerev": "पूर्वावलोकन हटाइयो", - "watchlist-details": "तपाईंको निगरानी सूचीमा रहेका {{PLURAL:$1|$1 पृष्ठ|$1 पृष्ठहरू}} वार्तालाप पृष्ठ गनिएका छैनन्।", + "watchlist-details": "तपाईंको अवलोकन सूचीमा रहेका {{PLURAL:$1|$1 पृष्ठ|$1 पृष्ठहरू}} (तथा वार्तालाप पृष्ठहरू)।", "wlheader-enotif": "ईमेल जानकारी सक्रिय गरियो ।", "wlheader-showupdated": "तपाईंले पछिल्लो पल्ट भ्रमण गरेपछि परिवर्तन भएका पृष्ठहरूलाई गाढा गरेर देखाइएको छ ।", "wlnote": "$3 र $4 अनुसार विगत {{PLURAL:$2|घण्टामा|'''$2''' घण्टाहरूमा}} {{PLURAL:$1|गरिएको अन्तिम परिवर्तन तल दिइएकोछ|गरिएका अन्तिम '''$1''' परिवर्तनहरू तल दिइएका छन्}}।", @@ -2478,8 +2479,6 @@ "markedaspatrollederrornotify": "गस्ती अङ्कित गर्न विफल।", "patrol-log-page": "निगरानीको लग", "patrol-log-header": "गस्ती गरिएका संस्करणहरूको लग यस प्रकार रहेका छन् ।", - "log-show-hide-patrol": "$1 निगरानी लग", - "log-show-hide-tag": "$1 ट्याग लग", "confirm-markpatrolled-button": "ठीक छ", "deletedrevision": "पुराना पुनरावलोकनहरू $1 मेटिए", "filedeleteerror-short": "$1 फाइल मेटाइमा भूल", @@ -3111,7 +3110,7 @@ "version-libraries-description": "वर्णन", "version-libraries-authors": "लेखकहरू", "redirect": "फाइल, प्रयोगकर्ता, वा संशोधन आइडीको आधारमा अनुप्रेषित गर्ने", - "redirect-summary": "यस विशेष पृष्ठ (प्रदान गरिएको फाइलनाम), पृष्ठको (पृष्ठ आइडी अथवा अवतरण आइडी), वा (प्रयोगकर्ता आइडी) राख्दा प्रयोगकर्तापृष्ठमा मा सारिनेछ। उदाहरण: [[{{#Special:Redirect}}/file/Example.jpg]], [[{{#Special:Redirect}}/page/64308]], [[{{#Special:Redirect}}/revision/328429]], वा [[{{#Special:Redirect}}/user/101]]।", + "redirect-summary": "यस विशेष पृष्ठ (प्रदान गरिएको फाइलनाम), पृष्ठको (पृष्ठ आइडी अथवा अवतरण आइडी), प्रयोगकर्ता पृष्ठ (प्रयोगकर्ता आइडी) वा लग इन्ट्री (दिईएको लग आइडी) राख्दा प्रयोगकर्ता पृष्ठमा अनुप्रेषण हुनेछ । उदाहरण: [[{{#Special:Redirect}}/file/Example.jpg]], [[{{#Special:Redirect}}/page/64308]], [[{{#Special:Redirect}}/revision/328429]], [[{{#Special:Redirect}}/user/101]] वा [[{{#Special:Redirect}}/logid/186]]।", "redirect-submit": "जाने", "redirect-lookup": "खोजी:", "redirect-value": "मानः", diff --git a/languages/i18n/nl.json b/languages/i18n/nl.json index 5e9df7c4ce..297b2bbd6e 100644 --- a/languages/i18n/nl.json +++ b/languages/i18n/nl.json @@ -992,6 +992,8 @@ "diff-paragraph-moved-toold": "Deze paragraaf is verplaatst. Klik om naar de oude locatie te springen.", "difference-missing-revision": "{{PLURAL:$2|Eén versie|$2 versies}} van deze verschillen ($1) {{PLURAL:$2|is|zijn}} niet aangetroffen.\n\nDit wordt meestal veroorzaakt door het volgen van een verouderde koppeling verschillen voor een pagina die is verwijderd.\nMeer gegevens zijn mogelijk te vinden in het [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} verwijderingslogboek].", "searchresults": "Zoekresultaten", + "search-filter-title-prefix": "Alleen zoeken naar pagina's waarvan de titel begint met \"$1\"", + "search-filter-title-prefix-reset": "Alle zoeken naar alle pagina's", "searchresults-title": "Zoekresultaten voor \"$1\"", "titlematches": "Overeenkomst met onderwerp", "textmatches": "Overeenkomst met inhoud", @@ -1797,6 +1799,7 @@ "http-timed-out": "Timeout bij het HTTP-verzoek.", "http-curl-error": "Fout bij het ophalen van URL: $1", "http-bad-status": "Er is een probleem opgetreden bij het HTTP-verzoek: $1 $2", + "http-internal-error": "HTTP interne fout.", "upload-curl-error6": "Kon de URL niet bereiken", "upload-curl-error6-text": "De opgegeven URL is niet bereikbaar.\nControleer of de URL juist is, en of de website beschikbaar is.", "upload-curl-error28": "Uploadtime-out", @@ -2089,7 +2092,7 @@ "speciallogtitlelabel": "Doel (paginanaam of {{ns:user}}:gebruikersnaam voor gebruiker):", "log": "Logboeken", "logeventslist-submit": "Weergeven", - "logeventslist-more-filters": "Meer filters:", + "logeventslist-more-filters": "Toon extra logboeken:", "logeventslist-patrol-log": "Markeerlogboek", "logeventslist-tag-log": "Labellogboek", "all-logs-page": "Alle openbare logboeken", @@ -2947,8 +2950,6 @@ "markedaspatrollederrornotify": "Markeren als gecontroleerd mislukt.", "patrol-log-page": "Markeerlogboek", "patrol-log-header": "Dit logboek bevat versies die gemarkeerd zijn als gecontroleerd.", - "log-show-hide-patrol": "markeerlogboek $1", - "log-show-hide-tag": "labellogboek $1", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Wilt u bewerking $3 van $2 als gecontroleerd markeren?", "deletedrevision": "De oude versie $1 is verwijderd", diff --git a/languages/i18n/nn.json b/languages/i18n/nn.json index ec31855ea2..4b5d69fd03 100644 --- a/languages/i18n/nn.json +++ b/languages/i18n/nn.json @@ -368,7 +368,7 @@ "cascadeprotected": "Denne sida er verna mot endring fordi ho er inkludert i fylgjande {{PLURAL:$1|side|sider}} som har djupvern slått på:\n$2", "namespaceprotected": "Du har ikkje tilgang til å endre sidene i '''$1'''-namnerommet.", "customcssprotected": "↓Du har ikkje tilgang til å endre denne sida, fordi ho inneheld ein annan brukar sine personlege innstillingar.", - "customjsprotected": "↓Du har ikkje tilgang til å endra denne JavaScript-sida fordi ho inneheld ein annen brukar sine personlege innstillingar.", + "customjsprotected": "↓Du har ikkje løyve til å endra denne JavaScript-sida fordi ho inneheld dei personlege innstillingane til ein annan brukar.", "mycustomcssprotected": "Du har ikkje løyve til å endra denne CSS-sida.", "mycustomjsprotected": "Du har ikkje løyve til å endra denne JavaScript-sida.", "myprivateinfoprotected": "Du har ikkje løyve til endra den private informasjonen din.", @@ -2476,8 +2476,6 @@ "markedaspatrollederrornotify": "Det gjekk ikkje å merkja endringa som patruljert.", "patrol-log-page": "Patruljeringslogg", "patrol-log-header": "Dette er ein logg over patruljerte sideversjonar.", - "log-show-hide-patrol": "$1 patruljeringslogg", - "log-show-hide-tag": "$1 merkelogg", "deletedrevision": "Slett gammal versjon $1", "filedeleteerror-short": "Feil ved sletting av fila: $1", "filedeleteerror-long": "Det vart ein feil under filslettinga av:\n\n$1", diff --git a/languages/i18n/oc.json b/languages/i18n/oc.json index 0810158155..69133688b6 100644 --- a/languages/i18n/oc.json +++ b/languages/i18n/oc.json @@ -2695,8 +2695,6 @@ "markedaspatrollederrornotify": "Fracàs del marcatge coma contrarotlat.", "patrol-log-page": "Istoric de las versions patrolhadas", "patrol-log-header": "Vaquí un jornal de las versions patrolhadas.", - "log-show-hide-patrol": "$1 l'istoric de las relecturas", - "log-show-hide-tag": "$1 lo jornal de las balisas", "confirm-markpatrolled-button": "D'acòrdi", "deletedrevision": "La version anciana $1 es estada suprimida.", "filedeleteerror-short": "Error al moment de la supression del fichièr : $1", diff --git a/languages/i18n/or.json b/languages/i18n/or.json index b5f891357b..602eaa418a 100644 --- a/languages/i18n/or.json +++ b/languages/i18n/or.json @@ -2353,7 +2353,6 @@ "markedaspatrollederrornotify": "ଶ୍ରେଣୀବିଭାଗ କରିହେଲାନି ।", "patrol-log-page": "ଜଗିବା ଇତିହାସ", "patrol-log-header": "ଏହା ଏକ ଜଗାଯାଇଥିବା ସଂସ୍କରଣର ଇତିହାସ ।", - "log-show-hide-patrol": "$1 ଜଗିବା ଇତିହାସ", "deletedrevision": "ଲିଭାଯାଇଥିବା ପୁରୁଣା $1", "filedeleteerror-short": "ଫାଇଲ ଲିଭାଇବାରେ ଅସୁବିଧା: $1", "filedeleteerror-long": "ତଳଲିଖିତ ଫାଇଲକୁ ଲିଭାଇବାରେ ଅସୁବିଧା:\n\n$1", diff --git a/languages/i18n/pl.json b/languages/i18n/pl.json index 2d0ff9bc89..ecfb2e5fc5 100644 --- a/languages/i18n/pl.json +++ b/languages/i18n/pl.json @@ -1004,6 +1004,7 @@ "diff-paragraph-moved-toold": "Akapit został przeniesiony. Kliknij aby przeskoczyć do jego poprzedniego położenia.", "difference-missing-revision": "{{PLURAL:$2|Wersja|$2 wersje|$2 wersji}} #$1 strony \"{{PAGENAME}}\" nie {{PLURAL:$2|została znaleziona|zostały znalezione|zostało znalezionych}}.\n\nZazwyczaj jest to spowodowane przestarzałym linkiem do usuniętej strony. Powód usunięcia znajduje się w [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} rejestrze].", "searchresults": "Wyniki wyszukiwania", + "search-filter-title-prefix": "Wyszukiwanie tylko na stronach, których tytuł zaczyna się od „$1”", "searchresults-title": "Wyniki wyszukiwania „$1”", "titlematches": "Znaleziono w tytułach", "textmatches": "Znaleziono w treści stron", @@ -1810,6 +1811,7 @@ "http-timed-out": "Przekroczony czas żądania HTTP.", "http-curl-error": "Błąd pobierania z adresu $1", "http-bad-status": "Wystąpił problem z realizacją żądania HTTP $1 $2", + "http-internal-error": "Błąd wewnętrzny HTTP.", "upload-curl-error6": "Adres URL jest nieosiągalny", "upload-curl-error6-text": "Podany adres URL jest nieosiągalny. Upewnij się, czy podany adres URL jest prawidłowy i czy dana strona jest dostępna.", "upload-curl-error28": "Upłynął limit czasu odpowiedzi", @@ -2101,7 +2103,7 @@ "speciallogtitlelabel": "Co (tytuł lub {{ns:user}}:nick użytkownika):", "log": "Rejestr operacji", "logeventslist-submit": "Pokaż", - "logeventslist-more-filters": "Więcej filtrów:", + "logeventslist-more-filters": "Pokaż dodatkowe rejestry:", "logeventslist-patrol-log": "Rejestr patrolowania", "logeventslist-tag-log": "Rejestr znaczników", "all-logs-page": "Wszystkie publiczne operacje", @@ -2952,8 +2954,6 @@ "markedaspatrollederrornotify": "Oznaczenie strony jako sprawdzonej nie powiodło się.", "patrol-log-page": "Rejestr patrolowania", "patrol-log-header": "Poniżej znajduje się rejestr patrolowania stron.", - "log-show-hide-patrol": "$1 rejestr sprawdzania", - "log-show-hide-tag": "$1 rejestr znaczników", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Oznaczyć wersję $3 strony $2 jako sprawdzoną?", "deletedrevision": "Usunięto poprzednie wersje $1", diff --git a/languages/i18n/pms.json b/languages/i18n/pms.json index 726c303c79..f837484afa 100644 --- a/languages/i18n/pms.json +++ b/languages/i18n/pms.json @@ -2344,8 +2344,6 @@ "markedaspatrollederrornotify": "Marcadura com verificà falìa.", "patrol-log-page": "Registr dij contròj", "patrol-log-header": "Cost-sì a l'é un registr ëd le revision controlà.", - "log-show-hide-patrol": "$1 registr verificà", - "log-show-hide-tag": "tichëtta d'argistr $1", "deletedrevision": "Veja version scancelà $1", "filedeleteerror-short": "Eror ën scanceland l'archivi: $1", "filedeleteerror-long": "A-i son ësta-ie dj'eror ën scanceland l'archivi:\n\n$1", diff --git a/languages/i18n/pnb.json b/languages/i18n/pnb.json index aa9f6b90c1..449de37cc1 100644 --- a/languages/i18n/pnb.json +++ b/languages/i18n/pnb.json @@ -1996,7 +1996,6 @@ "markedaspatrollederror-noautopatrol": "تھوانوں اے اجازت نئیں جے تسی اپنی تبدیلیاں تے گشت دا نشان لاؤ۔", "patrol-log-page": "گشت لاگ", "patrol-log-header": "اے گست لائیآں ہوئیآن ریوین دی لاگ اے۔", - "log-show-hide-patrol": "$1 گشت لاگ", "deletedrevision": "پرانیاں مٹائیاں ریوین $1", "filedeleteerror-short": "فاغل مٹان چ غلطی: $1", "filedeleteerror-long": "فائل مٹان لگیاں غلطیاں ہوئیاں:\n$1", diff --git a/languages/i18n/prg.json b/languages/i18n/prg.json index d4923fe02f..27f1641aa9 100644 --- a/languages/i18n/prg.json +++ b/languages/i18n/prg.json @@ -1559,7 +1559,6 @@ "markedaspatrollederror-noautopatrol": "Ni assei enwarīntan, kāi pazentlitun swajjans kitawīdinsnans kāigi \"izbandātans\".", "patrol-log-page": "Izbandāsnas registerin", "patrol-log-header": "Sta ast izbandātan wersiōnin regīsterin.", - "log-show-hide-patrol": "$1 izbandāsnas registerin", "deletedrevision": "Āupausinā di panzdaumans wersiōnins stesse $1", "filedeleteerror-short": "Blānda prei zūrbrukes $1 āupausinsnan", "filedeleteerror-long": "Blāndas tikka prei zūrbrukes āupausinsnan:\n\n$1", diff --git a/languages/i18n/ps.json b/languages/i18n/ps.json index ad46b4db88..210aebe9d7 100644 --- a/languages/i18n/ps.json +++ b/languages/i18n/ps.json @@ -2340,8 +2340,6 @@ "markedaspatrollederrornotify": "د څارل شوي په توگه په نښه کول نابريال شو.", "patrol-log-page": "د څارنې يادښت", "patrol-log-header": "دا د څارل شويو مخکتنو يو يادښت دی.", - "log-show-hide-patrol": "د څارنې يادښت $1", - "log-show-hide-tag": "نښلن يادښت $1", "confirm-markpatrolled-button": "ښه", "deletedrevision": "د $1 زړه ړنگه شوې بڼه", "filedeleteerror-short": "د دوتنې د ړنگولو ستونزه: $1", diff --git a/languages/i18n/pt-br.json b/languages/i18n/pt-br.json index a947f6bdad..07604da8e9 100644 --- a/languages/i18n/pt-br.json +++ b/languages/i18n/pt-br.json @@ -1022,6 +1022,8 @@ "diff-paragraph-moved-toold": "O parágrafo foi movido. Clique para saltar para a posição anterior.", "difference-missing-revision": "{{PLURAL:$2|Uma revisão|$2 revisões}} desta diferença ($1) não {{PLURAL:$2|foi encontrada|foram encontradas}}.\n\nIsto é geralmente causado por seguir um link de histórico desatualizado para uma página que foi eliminada.\nOs detalhes podem ser encontrados no [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} registro de eliminação].", "searchresults": "Resultados da pesquisa", + "search-filter-title-prefix": "A pesquisar só nas páginas cujo título começa por \"$1\"", + "search-filter-title-prefix-reset": "Pesquisar em todas as páginas", "searchresults-title": "Resultados da pesquisa por \"$1\"", "titlematches": "Resultados nos títulos das páginas", "textmatches": "Resultados nos textos das páginas", @@ -1828,6 +1830,7 @@ "http-timed-out": "Esgotado o tempo de espera da requisição HTTP.", "http-curl-error": "Erro ao requisitar a URL: $1", "http-bad-status": "Ocorreu um problema durante a requisição HTTP: $1 $2", + "http-internal-error": "Erro interno do HTTP.", "upload-curl-error6": "Não foi possível acessar a URL", "upload-curl-error6-text": "Não foi possível acessar o endereço (URL) fornecido. Por gentileza, se certifique que o endereço foi fornecido corretamente e de que o site esteja acessível.", "upload-curl-error28": "Tempo limite para o envio do arquivo excedido", @@ -2120,7 +2123,7 @@ "speciallogtitlelabel": "Alvo (título da página ou {{ns:user}}:'nomedeusuário' para usuários):", "log": "Registros", "logeventslist-submit": "Exibir", - "logeventslist-more-filters": "Mais filtros:", + "logeventslist-more-filters": "Mostrar registos adicionais:", "logeventslist-patrol-log": "Registro de edições patrulhadas", "logeventslist-tag-log": "Registro de etiquetas", "all-logs-page": "Todos os registros públicos", @@ -2965,8 +2968,6 @@ "markedaspatrollederrornotify": "Falha ao marcar como patrulhada.", "patrol-log-page": "Registro de edições patrulhadas", "patrol-log-header": "Este é um registro de edições patrulhadas.", - "log-show-hide-patrol": "$1 registro de edições patrulhadas", - "log-show-hide-tag": "$1 etiqueta de log", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Marque a revisão $3 de $2 como patrulhado?", "deletedrevision": "Apagou a versão antiga $1", diff --git a/languages/i18n/pt.json b/languages/i18n/pt.json index e04b6ae1ea..87f4f61902 100644 --- a/languages/i18n/pt.json +++ b/languages/i18n/pt.json @@ -992,6 +992,8 @@ "diff-paragraph-moved-toold": "O parágrafo foi movido. Clique para saltar para a posição anterior.", "difference-missing-revision": "{{PLURAL:$2|Uma revisão|$2 revisões}} desta diferença ($1) não {{PLURAL:$2|foi encontrada|foram encontradas}}.\n\nIsto é geralmente causado por seguir uma hiperligação de diferenças desatualizada para uma página que foi eliminada.\nOs detalhes podem ser encontrados no [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} registo de eliminação].", "searchresults": "Resultados da pesquisa", + "search-filter-title-prefix": "A pesquisar só nas páginas cujo título começa por \"$1\"", + "search-filter-title-prefix-reset": "Pesquisar em todas as páginas", "searchresults-title": "Resultados da pesquisa de \"$1\"", "titlematches": "Resultados no título das páginas", "textmatches": "Resultados no conteúdo das páginas", @@ -1802,6 +1804,7 @@ "http-timed-out": "O pedido HTTP expirou.", "http-curl-error": "Ocorreu um erro ao aceder ao URL: $1", "http-bad-status": "Ocorreu um problema durante o pedido HTTP: $1 $2", + "http-internal-error": "Erro interno do HTTP.", "upload-curl-error6": "Não foi possível aceder ao URL", "upload-curl-error6-text": "Não foi possível aceder ao URL.\nVerifique se o endereço está correto e o sítio disponível, por favor.", "upload-curl-error28": "Tempo limite para o envio do ficheiro excedido", @@ -2094,7 +2097,7 @@ "speciallogtitlelabel": "Alvo (título ou página ou {{ns:user}}:nome de utilizador):", "log": "Registos", "logeventslist-submit": "Mostrar", - "logeventslist-more-filters": "Mais filtros:", + "logeventslist-more-filters": "Mostrar registos adicionais:", "logeventslist-patrol-log": "Registo de edições patrulhadas", "logeventslist-tag-log": "Registo de etiquetas", "all-logs-page": "Todos os registos públicos", @@ -2167,7 +2170,7 @@ "listgrouprights-namespaceprotection-namespace": "Domínio", "listgrouprights-namespaceprotection-restrictedto": "Direito(s) do utilizador para editar", "listgrants": "Concessões de permissões a aplicações ligadas", - "listgrants-summary": "Esta é uma lista das possíveis concessões de permissões e das respetivas permissões dos utilizadores que são atribuídas por cada concessão. Os utilizadores podem autorizar aplicações a utilizar a sua conta, agindo assim em seu nome mas com as permissões limitadas com base nestas concessões. Uma aplicação que age em nome de um utilizador não pode utilizar permissões que o utilizador não possui.\nPoderá existir [[{{MediaWiki:Listgrouprights-helppage}}|informação adicional]] sobre as permissões individuais.", + "listgrants-summary": "Esta é uma lista das possíveis concessões de permissões e das respetivas permissões dos utilizadores que são atribuídas por cada concessão. Os utilizadores podem autorizar aplicações a utilizar a sua conta, agindo assim em seu nome mas com as permissões limitadas com base nestas concessões. Uma aplicação que age em nome de um utilizador não pode utilizar permissões que o utilizador não tem.\nPoderá existir [[{{MediaWiki:Listgrouprights-helppage}}|informação adicional]] sobre as permissões individuais.", "listgrants-grant": "Concessão de permissões", "listgrants-rights": "Permissões", "trackingcategories": "Categorias de monitorização", @@ -2953,8 +2956,6 @@ "markedaspatrollederrornotify": "A marcação como patrulhada falhou.", "patrol-log-page": "Registo de edições patrulhadas", "patrol-log-header": "Este é um registo de edições patrulhadas.", - "log-show-hide-patrol": "$1 registo de edições patrulhadas", - "log-show-hide-tag": "$1 registo de etiquetas", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Marcar a revisão $3 de $2 como patrulhada?", "deletedrevision": "Apagou a versão antiga $1", @@ -3418,7 +3419,7 @@ "confirm-purge-title": "Purgar esta página", "confirm_purge_button": "OK", "confirm-purge-top": "Limpar esta página da memória cache?", - "confirm-purge-bottom": "Recarregar uma página limpa a cache e força a sua versão mais recente a aparecer.", + "confirm-purge-bottom": "Purgar uma página limpa-a da ''cache'' e força a sua versão mais recente a aparecer.", "confirm-watch-button": "OK", "confirm-watch-top": "Adicionar esta página à lista de páginas vigiadas?", "confirm-unwatch-button": "OK", diff --git a/languages/i18n/qqq.json b/languages/i18n/qqq.json index 573c0290fd..02d8b27cbc 100644 --- a/languages/i18n/qqq.json +++ b/languages/i18n/qqq.json @@ -1999,6 +1999,7 @@ "http-timed-out": "Used as error message when executing HTTP request.\n\nSee also:\n* {{msg-mw|Http-request-error}}\n* {{msg-mw|Http-read-error}}\n* {{msg-mw|Http-host-unreachable|6}}", "http-curl-error": "Used as curl error message when the error is other than known messages.\n* $1 - error code; not URL\nKnown messages are:\n* {{msg-mw|http-host-unreachable}}\n* {{msg-mw|http-timed-out}}", "http-bad-status": "Parameters:\n* $1 - an HTTP error code (e.g. 404)\n* $2 - the HTTP error message (e.g. File Not Found)", + "http-internal-error": "Used as generic error message when executing HTTP request and no more specific message is available.", "upload-curl-error6": "See also:\n* {{msg-mw|Upload-curl-error6|title}}\n* {{msg-mw|Upload-curl-error6-text|body}}", "upload-curl-error6-text": "See also:\n* {{msg-mw|Upload-curl-error6|title}}\n* {{msg-mw|Upload-curl-error6-text|body}}", "upload-curl-error28": "See also:\n* {{msg-mw|Upload-curl-error28|title}}\n* {{msg-mw|Upload-curl-error28-text|body}}", @@ -3399,8 +3400,8 @@ "variantname-gan-hans": "{{Optional}}\n\nVariant option for wikis with variants conversion enabled.", "variantname-gan-hant": "{{Optional}}\n\nVariant option for wikis with variants conversion enabled.", "variantname-gan": "{{Optional}}\n\nVariant option for wikis with variants conversion enabled.", - "variantname-sr-ec": "{{optional}}\nVariant Option for wikis with variants conversion enabled.\n\nNote that sr-ec is not a conforming BCP 47 language tag. Wikis should be migrated by:\n* allowing it only as a legacy alias of the preferred tag sr-cyrl (possibly insert a tracking category in templates as long as they must support the legacy tag),\n* making the new tag the default to look first, before looking for the old tag,\n* moving the translations to the new code by renaming them,\n* checking links in source pages still using the legacy tag to change it to the new tag,\n* possibly cleanup the redirect pages.", - "variantname-sr-el": "{{optional}}\nVariant Option for wikis with variants conversion enabled.\n\nNote that sr-el is not a conforming BCP 47 language tag. Wikis should be migrated by:\n* allowing it only as a legacy alias of the preferred tag sr-latn (possibly insert a tracking category in templates as long as they must support the legacy tag),\n* making the new tag the default to look first, before looking for the old tag,\n* moving the translations to the new code by renaming them,\n* checking links in source pages still using the legacy tag to change it to the new tag,\n* possibly cleanup the redirect pages.", + "variantname-sr-ec": "{{optional}}\nVariant Option for wikis with variants conversion enabled.\n\nNote that sr-ec is not a conforming BCP47 language tag. Wikis should be migrated by:\n* allowing it only as a legacy alias of the preferred tag sr-cyrl (possibly insert a tracking category in templates as long as they must support the legacy tag),\n* making the new tag the default to look first, before looking for the old tag,\n* moving the translations to the new code by renaming them,\n* checking links in source pages still using the legacy tag to change it to the new tag,\n* possibly cleanup the redirect pages.", + "variantname-sr-el": "{{optional}}\nVariant Option for wikis with variants conversion enabled.\n\nNote that sr-el is not a conforming BCP47 language tag. Wikis should be migrated by:\n* allowing it only as a legacy alias of the preferred tag sr-latn (possibly insert a tracking category in templates as long as they must support the legacy tag),\n* making the new tag the default to look first, before looking for the old tag,\n* moving the translations to the new code by renaming them,\n* checking links in source pages still using the legacy tag to change it to the new tag,\n* possibly cleanup the redirect pages.", "variantname-sr": "{{optional}}\nVariant Option for wikis with variants conversion enabled.", "variantname-kk-kz": "{{optional}}\nVariant Option for wikis with variants conversion enabled.", "variantname-kk-tr": "{{optional}}\nVariant Option for wikis with variants conversion enabled.", diff --git a/languages/i18n/qu.json b/languages/i18n/qu.json index 3275e0ba66..c734d041bd 100644 --- a/languages/i18n/qu.json +++ b/languages/i18n/qu.json @@ -2228,7 +2228,6 @@ "markedaspatrollederrornotify": "Qhawakipasqa niyqa manam aypanchu.", "patrol-log-page": "Qhawakipay hallch'a", "patrol-log-header": "Kayqa patrullasqa musuqchasqakunamanta hallch'asqam.", - "log-show-hide-patrol": "$1 patrullay hallch'a", "deletedrevision": "Qullusqam mawk'a qhawakipasqa $1", "filedeleteerror-short": "Manam atinichu kay willañiqita qulluyta: $1", "filedeleteerror-long": "Pantasqakunam rikch'akurqan kay willañiqita qulluypi:\n\n$1", diff --git a/languages/i18n/rm.json b/languages/i18n/rm.json index 7bed1585cb..c67397946b 100644 --- a/languages/i18n/rm.json +++ b/languages/i18n/rm.json @@ -2060,7 +2060,6 @@ "markedaspatrollederrornotify": "Sbagl durant marcar sco controllà.", "patrol-log-page": "Protocol da controllas", "patrol-log-header": "Quai è il protocol da las versiuns controlladas.", - "log-show-hide-patrol": "$1 il protocol da controllas", "deletedrevision": "Stizzà la versiun veglia $1.", "filedeleteerror-short": "Errur cun stizzar la datoteca: $1", "filedeleteerror-long": "Cun stizzar la datoteca èn errurs vegnidas constatadas:\n\n$1", diff --git a/languages/i18n/ro.json b/languages/i18n/ro.json index 7259340947..e0c49abfbe 100644 --- a/languages/i18n/ro.json +++ b/languages/i18n/ro.json @@ -72,7 +72,7 @@ "tog-watchlisthideminor": "Ascunde modificările minore din lista de pagini urmărite", "tog-watchlisthideliu": "Ascunde modificările efectuate de utilizatori autentificați din lista de pagini urmărite", "tog-watchlistreloadautomatically": "Reîncarcă automat lista paginilor urmărite de fiecare dată când un filtru este modificat (necesită JavaScript)", - "tog-watchlistunwatchlinks": "Adaugă legături directe pentru urmărire/neurmărire inrărilor din lista de pagini urmărite (este nevoie de JavaScript pentru a activa funcționalitatea)", + "tog-watchlistunwatchlinks": "Adaugă legături directe pentru urmărirea/neurmărirea ({{int:Watchlist-unwatch}}/{{int:Watchlist-unwatch-undo}}) intrărilor din lista de pagini urmărite (este nevoie de JavaScript pentru a activa funcționalitatea)", "tog-watchlisthideanons": "Ascunde modificările făcute de utilizatori anonimi din lista de pagini urmărite", "tog-watchlisthidepatrolled": "Ascunde paginile patrulate din lista de pagini urmărite", "tog-watchlisthidecategorization": "Ascunde categorisirea paginilor", @@ -380,8 +380,10 @@ "cascadeprotected": "Această pagină a fost protejată la modificare, deoarece este inclusă în {{PLURAL:$1|următoarea pagină|următoarele pagini}} {{PLURAL:$1|protejată|protejate}} cu opțiunea „în cascadă”:\n$2", "namespaceprotected": "Nu aveți permisiunea de a modifica pagini din spațiul de nume '''$1'''.", "customcssprotected": "Nu aveți permisiunea de a modifica această pagină CSS, deoarece conține setările personale ale altui utilizator.", + "customjsonprotected": "Nu aveți permisiunea de a modifica această pagină JSON, deoarece conține setările personale ale altui utilizator.", "customjsprotected": "Nu aveți permisiunea de a modifica această pagină JavaScript, deoarece conține setările personale ale altui utilizator.", "mycustomcssprotected": "Nu aveți permisiunea să modificați această pagină CSS.", + "mycustomjsonprotected": "Nu aveți permisiunea să modificați această pagină JSON.", "mycustomjsprotected": "Nu aveți permisiunea să modificați această pagină JavaScript.", "myprivateinfoprotected": "Nu aveți permisiunea să vă modificați informațiile personale.", "mypreferencesprotected": "Nu aveți permisiunea să vă modificați preferințele.", @@ -476,12 +478,12 @@ "wrongpasswordempty": "Spațiul pentru introducerea parolei nu a fost completat. Vă rugăm să încercați din nou.", "passwordtooshort": "Parola trebuie să aibă cel puțin {{PLURAL:$1|1 caracter|$1 caractere|$1 de caractere}}.", "passwordtoolong": "Parolele nu pot fi mai lungi de {{PLURAL:$1|un caracter|$1 caractere|$1 de caractere}}.", - "passwordtoopopular": "Parolele comune nu pot fi utilizate. Alegeți o parolă mai puțin obișnuită.", + "passwordtoopopular": "Parolele comune nu pot fi utilizate. Alegeți o parolă mai greu de ghicit.", "password-name-match": "Parola dumneavoastră trebuie să fie diferită de numele de utilizator.", "password-login-forbidden": "Utilizarea acestui nume de utilizator și a acestei parole este interzisă.", "mailmypassword": "Resetează parola", "passwordremindertitle": "Noua parolă temporară la {{SITENAME}}", - "passwordremindertext": "Cineva (probabil dumneavoastră, de la adresa $1)\na cerut să vi se trimită o nouă parolă pentru {{SITENAME}} ($4).\nO parolă temporară pentru utilizatorul „$2” a fost generată și este acum „$3”.\nParola temporară va expira {{PLURAL:$5|într-o zi|în $5 zile|în $5 de zile}}.\n\nDacă această cerere a fost efectuată de altcineva sau dacă v-ați amintit\nparola și nu doriți să o schimbați, ignorați acest mesaj și continuați\nsă folosiți vechea parolă.", + "passwordremindertext": "Cineva (de la adresa IP $1)\na cerut să vi se trimită o nouă parolă pentru {{SITENAME}} ($4).\nO parolă temporară pentru utilizatorul „$2” a fost generată și este acum „$3”.\nParola temporară va expira {{PLURAL:$5|într-o zi|în $5 zile|în $5 de zile}}.\n\nDacă această cerere a fost efectuată de altcineva sau dacă v-ați amintit\nparola și nu doriți să o schimbați, ignorați acest mesaj și continuați\nsă folosiți vechea parolă.", "noemail": "Nu este nici o adresă de e-mail înregistrată pentru utilizatorul „$1”.", "noemailcreate": "Trebuie oferită o adresă e e-mail validă.", "passwordsent": "O nouă parolă a fost trimisă la adresa de e-mail a utilizatorului \"$1\". Te rugăm să te autentifici pe {{SITENAME}} după ce o primești.", @@ -682,8 +684,9 @@ "userjsonpreview": "Rețineți că vedeți doar o previzualizare a JSON-ului dumneavoastră de utilizator.\nAcesta nu a fost încă salvat!", "userjspreview": "'''Rețineți că vizualizați doar o previzualizare/versiune de testare a JavaScript-ului dumneavoastră de utilizator.'''\n'''Acesta nu a fost încă salvat!'''", "sitecsspreview": "'''Rețineți că doar previzualizați această foaie de stil.'''\n'''Ea nu a fost salvată încă!'''", + "sitejsonpreview": "Rețineți că doar previzualizați această configurație JSON.\nEl nu a fost salvat încă!", "sitejspreview": "'''Rețineți că doar previzualizați acest cod JavaScript.'''\n'''El nu a fost salvat încă!'''", - "userinvalidconfigtitle": "'''Avertizare:''' Nu există aspectul „$1”.\nPaginile .css și .js specifice utilizatorilor au titluri care încep cu literă mică; de exemplu {{ns:user}}:Foo/vector.css în comparație cu {{ns:user}}:Foo/Vector.css.", + "userinvalidconfigtitle": "Avertizare: Nu există skinul „$1”.\nPaginile .css, .json și .js specifice utilizatorilor au titluri care încep cu literă mică; de exemplu {{ns:user}}:Foo/vector.css în loc de {{ns:user}}:Foo/Vector.css.", "updated": "(Actualizat)", "note": "'''Notă:'''", "previewnote": "'''Țineți cont că aceasta este doar o previzualizare.'''\nModificările dumneavoastră nu au fost încă salvate!", @@ -710,7 +713,7 @@ "longpageerror": "'''Eroare: Textul pe care l-ați trimis are o lungime de {{PLURAL:$1|un kilooctet|$1 kiloocteți|$1 de kiloocteți}}, ceea ce înseamnă mai mult decât maximul de {{PLURAL:$2|un kilooctet|$2 kiloocteți|$2 de kiloocteți}}.'''\nSalvarea nu este posibilă.", "readonlywarning": "Atenție: Baza de date a fost blocată pentru întreținere, deci nu veți putea salva modificările în acest moment.\nPuteți copia textul într-un fișier text, păstrându-l pentru mai târziu.\n\nAdministratorul de sistem care a efectuat blocarea a oferit următoarea explicație: $1", "protectedpagewarning": "'''Atenție: această pagină a fost protejată astfel încât poate fi modificată doar de către administratori.'''\nUltima intrare în jurnal este afișată mai jos pentru referință:", - "semiprotectedpagewarning": "'''Observație: această pagină a fost protejată și poate fi modificată doar de către utilizatorii înregistrați.'''\nUltima intrare în jurnal este afișată mai jos pentru referință:", + "semiprotectedpagewarning": "Observație: această pagină a fost protejată și poate fi modificată doar de către utilizatorii autoconfirmați.\nUltima intrare în jurnal este afișată mai jos pentru referință:", "cascadeprotectedwarning": "Atenție: Această pagină a fost protejată, astfel încât numai [[Special:ListGroupRights|utilizatori cu drepturi specifice]] o pot modifica, fiind inclusă în {{PLURAL:$1|următoarea pagină protejată|următoarele pagini protejate}} în cascadă:", "titleprotectedwarning": "'''Atenție: această pagină a fost protejată astfel încât doar anumiți [[Special:ListGroupRights|utilizatori]] o pot crea.'''\nUltima intrare în jurnal este afișată mai jos pentru referință:", "templatesused": "{{PLURAL:$1|Format folosit|Formate folosite}} în această pagină:", @@ -931,6 +934,7 @@ "diff-paragraph-moved-toold": "Paragraful a fost mutat. Clic pentru a ajunge la vechea locație.", "difference-missing-revision": "{{PLURAL:$2|O versiune a|$2 versiuni ale|$2 de versiuni ale}} acestei diferențe ($1) nu {{PLURAL:$2|a fost găsită|au fost găsite}}.\n\nAcest lucru se întâmplă de obicei atunci când se accesează o legătură expirată către istoricul unei pagini șterse.\nDetalii se pot găsi în [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} jurnalul ștergerilor].", "searchresults": "Rezultatele căutării", + "search-filter-title-prefix-reset": "Caută toate paginile", "searchresults-title": "Rezultatele căutării pentru „$1”", "titlematches": "Rezultate din titlurile paginilor", "textmatches": "Rezultate din conținutul paginilor", @@ -1406,6 +1410,7 @@ "rcfilters-filter-humans-description": "Modificări făcute de oameni.", "rcfilters-filtergroup-reviewstatus": "Statutul reviziei", "rcfilters-filter-reviewstatus-unpatrolled-label": "Nepatrulate", + "rcfilters-filter-reviewstatus-manual-description": "Modificări marcate manual ca patrulate.", "rcfilters-filter-reviewstatus-manual-label": "Patrulate manual", "rcfilters-filter-reviewstatus-auto-label": "Patrulate automat", "rcfilters-filtergroup-significance": "Semnificație", @@ -1928,6 +1933,7 @@ "deadendpages": "Pagini fără legături", "deadendpagestext": "Următoarele pagini nu se leagă de alte pagini din acestă wiki.", "protectedpages": "Pagini protejate", + "protectedpages-filters": "Filtre:", "protectedpages-indef": "Doar protejări pe termen nelimitat", "protectedpages-summary": "Această pagină enumeră paginile protejate în acest moment. Pentru o listă a titlurilor protejate la creare, vedeți [[{{#special:ProtectedTitles}}|{{int:protectedtitles}}]].", "protectedpages-cascade": "Doar protejări în cascadă", @@ -1988,6 +1994,7 @@ "apisandbox-dynamic-error-exists": "Un parametru cu numele „$1” există deja.", "apisandbox-deprecated-parameters": "Parametri învechiți", "apisandbox-fetch-token": "Completează automat jetonul", + "apisandbox-add-multi": "Adaugă", "apisandbox-submit-invalid-fields-title": "Anumite câmpuri nu sunt valide", "apisandbox-submit-invalid-fields-message": "Corectați câmpurile marcate și încercați din nou.", "apisandbox-results": "Rezultate", @@ -2026,6 +2033,9 @@ "speciallogtitlelabel": "Destinație (titlu sau {{ns:user}}:numeutilizator pentru utilizator):", "log": "Jurnale", "logeventslist-submit": "Afișează", + "logeventslist-more-filters": "Arată jurnale adiționale:", + "logeventslist-patrol-log": "Jurnal de patrulare", + "logeventslist-tag-log": "Jurnal etichete", "all-logs-page": "Toate jurnalele publice", "alllogstext": "Afișare combinată a tuturor jurnalelor {{SITENAME}}.\nPuteți limita vizualizarea selectând tipul jurnalului, numele de utilizator sau pagina afectată.", "logempty": "Nici o înregistrare în jurnal.", @@ -2220,6 +2230,9 @@ "dellogpage": "Jurnal ștergeri", "dellogpagetext": "Mai jos se află lista celor mai recente elemente șterse.", "deletionlog": "jurnal pagini șterse", + "log-name-create": "Jurnal creare pagini", + "log-description-create": "Mai jos se află lista celor mai recente pagini create.", + "logentry-create-create": "$1 {{GENDER:$2|a creat|a creat}} pagina $3", "reverted": "Revenire la o versiune mai veche", "deletecomment": "Motiv:", "deleteotherreason": "Motiv diferit/suplimentar:", @@ -2378,6 +2391,7 @@ "uctop": "(actuală)", "month": "Din luna (și dinainte):", "year": "Din anul (și dinainte):", + "date": "Din data (și dinainte):", "sp-contributions-newbies": "Arată doar contribuțiile conturilor noi", "sp-contributions-newbies-sub": "Pentru începători", "sp-contributions-newbies-title": "Contribuțiile utilizatorului pentru conturile noi", @@ -2867,8 +2881,6 @@ "markedaspatrollederrornotify": "Marcarea ca patrulată a eșuat.", "patrol-log-page": "Jurnal verificări", "patrol-log-header": "Aceasta este o listă a tuturor versiunilor marcate ca verificate.", - "log-show-hide-patrol": "$1 jurnalul versiunilor verificate", - "log-show-hide-tag": "$1 jurnal etichete", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Marcați revizia $3 a $2 ca patrulată?", "deletedrevision": "A fost ștearsă vechea versiune $1.", @@ -3396,6 +3408,7 @@ "version-specialpages": "Pagini speciale", "version-parserhooks": "Hook-uri parser", "version-variables": "Variabile", + "version-editors": "Editori", "version-antispam": "Prevenirea spamului", "version-other": "Altele", "version-mediahandlers": "Suport media", @@ -3591,6 +3604,7 @@ "diff-form": "Diferențe", "diff-form-submit": "Arată diferențele", "permanentlink": "Legătură permanentă", + "permanentlink-submit": "Mergi la versiunea", "dberr-problems": "Ne cerem scuze! Acest site întâmpină dificultăți tehnice.", "dberr-again": "Așteptați câteva minute și încercați din nou.", "dberr-info": "(Nu se poate accesa baza de date: $1)", @@ -3752,6 +3766,7 @@ "limitreport-templateargumentsize-value": "$1/$2 {{PLURAL:$2|octet|octeți|de octeți}}", "limitreport-expansiondepth": "Cea mai mare profunzime a expansiunii", "limitreport-expensivefunctioncount": "Număr de funcții de analiză costisitoare", + "limitreport-unstrip-size-value": "$1/$2 {{PLURAL:$2|octet|octeți|de octeți}}", "expandtemplates": "Expandare formate", "expand_templates_intro": "Această pagină specială servește la expandarea recursivă a tuturor formatelor dintr-un wikitext. Ea acționează și asupra funcțiilor de analiză (''parser'') de tipul {{#if:...}}, a variabilelor precum {{CURRENTDAY}} și în general asupra oricăror coduri cuprinse între acolade duble.", "expand_templates_title": "Titlul contextului (de exemplu pentru {{PAGENAME}}):", @@ -3776,6 +3791,7 @@ "pagelang-reason": "Motiv", "pagelang-submit": "Trimite", "pagelang-nonexistent-page": "Pagina $1 nu există.", + "pagelang-unchanged-language": "Pagina $1 e deja în limba $2.", "right-pagelang": "Modifică limba paginii", "action-pagelang": "modificați limba paginii", "log-name-pagelang": "Jurnal modificare limbă", @@ -3836,12 +3852,14 @@ "special-characters-group-thai": "Thailandeză", "special-characters-group-lao": "Laoțiană", "special-characters-group-khmer": "Khmeră", + "special-characters-group-canadianaboriginal": "Aborigen Canadian", "special-characters-title-endash": "linie de pauză (en dash)", "special-characters-title-emdash": "linie de pauză (em dash)", "special-characters-title-minus": "semnul minus", "mw-widgets-dateinput-no-date": "Nicio dată selectată", "mw-widgets-dateinput-placeholder-day": "AAAA-LL-ZZ", "mw-widgets-dateinput-placeholder-month": "AAAA-LL", + "mw-widgets-mediasearch-input-placeholder": "Căutare de multimedia", "mw-widgets-mediasearch-noresults": "Niciun rezultat găsit.", "mw-widgets-titleinput-description-new-page": "pagina nu există încă", "mw-widgets-titleinput-description-redirect": "redirecționare către $1", @@ -3879,6 +3897,8 @@ "log-action-filter-managetags-delete": "Ștergere tag", "log-action-filter-managetags-activate": "Activare tag", "log-action-filter-managetags-deactivate": "Dezactivare tag", + "log-action-filter-newusers-create": "Creare de utilizator anonim", + "log-action-filter-newusers-create2": "Creare de un utilizator înregistrat", "log-action-filter-newusers-autocreate": "Creare automată", "log-action-filter-patrol-patrol": "Patrulă manuală", "log-action-filter-patrol-autopatrol": "Patrulă automată", @@ -3938,5 +3958,14 @@ "gotointerwiki-invalid": "Titlul specificat nu este valid.", "pagedata-title": "Datele paginii", "pagedata-not-acceptable": "Niciun format corespunzător găsit. Tipuri MIME acceptate: $1", - "pagedata-bad-title": "Titlu invalid: $1." + "pagedata-bad-title": "Titlu invalid: $1.", + "passwordpolicies": "Politică parole", + "passwordpolicies-group": "Grup", + "passwordpolicies-policies": "Politici", + "passwordpolicies-policy-minimalpasswordlength": "Parola trebuie să aibă cel puțin $1 {{PLURAL:$1|caracter|caractere|de caractere}}.", + "passwordpolicies-policy-minimumpasswordlengthtologin": "Parola trebuie să aibă cel puțin $1 {{PLURAL:$1|caracter|caractere|de caractere}} pentru a vă putea autentifica.", + "passwordpolicies-policy-passwordcannotmatchusername": "Parola nu poate fi identică cu numele de utilizator", + "passwordpolicies-policy-passwordcannotmatchblacklist": "Parolele nu pot fi cele de pe lista neagră", + "passwordpolicies-policy-maximalpasswordlength": "Parola trebuie să aibă cel puțin $1 {{PLURAL:$1|caracter|caractere|de caractere}}.", + "passwordpolicies-policy-passwordcannotbepopular": "Parola nu poate fi {{PLURAL:$1|o parolă populară|în lista celor $1 parole populare|în lista celor $1 de parole populare}}." } diff --git a/languages/i18n/roa-tara.json b/languages/i18n/roa-tara.json index 4bc493c15d..e32a7c2b93 100644 --- a/languages/i18n/roa-tara.json +++ b/languages/i18n/roa-tara.json @@ -2649,8 +2649,6 @@ "markedaspatrollederrornotify": "Signate cumme condrollate fallite.", "patrol-log-page": "Archivije de le condrolle", "patrol-log-header": "Quiste è l'archivije de le revisiune condrollate.", - "log-show-hide-patrol": "$1 archivije de le condrolle", - "log-show-hide-tag": "$1 archivije de le tag", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Signe 'a revisione $3 de $2 cumme condrollate?", "deletedrevision": "Vecchia revisione scangellete $1", diff --git a/languages/i18n/ru.json b/languages/i18n/ru.json index c688b3f355..bd66ad8c2a 100644 --- a/languages/i18n/ru.json +++ b/languages/i18n/ru.json @@ -1043,6 +1043,8 @@ "diff-paragraph-moved-toold": "Пункт был перемещен. Нажмите, чтобы перейти к старому местоположению.", "difference-missing-revision": "Не {{PLURAL:$2|1=найдена|найдены}} {{PLURAL:$2|$2 версия|$2 версий|$2 версии|1=одна из версий}} для этого сравнения ($1).\n\nТакое обычно случается при переходе по устаревшей ссылке сравнения версий для страницы, которая была удалена.\nПодробности могут быть в [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} журнале удалений].", "searchresults": "Результаты поиска", + "search-filter-title-prefix": "Искать только на страницах, название которых начинается с «$1»", + "search-filter-title-prefix-reset": "Искать все страницы", "searchresults-title": "Поиск «$1»", "titlematches": "Совпадения в названиях страниц", "textmatches": "Совпадения в текстах страниц", @@ -1532,7 +1534,7 @@ "rcfilters-filter-major-description": "Правки, не помеченные как малые.", "rcfilters-filtergroup-watchlist": "Страницы в списке наблюдения", "rcfilters-filter-watchlist-watched-label": "В списке наблюдения", - "rcfilters-filter-watchlist-watched-description": "Изменения страниц в вашем Списке наблюдения.", + "rcfilters-filter-watchlist-watched-description": "Изменения страниц в вашем списке наблюдения.", "rcfilters-filter-watchlist-watchednew-label": "Новые изменения в списке наблюдения", "rcfilters-filter-watchlist-watchednew-description": "Правки на страницах из вашего списка наблюдения, которые вы не просмотрели с их совершения.", "rcfilters-filter-watchlist-notwatched-label": "Нет в списке наблюдения", @@ -1576,7 +1578,7 @@ "rcfilters-watchlist-showupdated": "Изменения страниц, которые вы не посещали с того момента, как они изменились, выделены жирным и отмечены полным маркером.", "rcfilters-preference-label": "Скрыть улучшенную версию «Свежих правок»", "rcfilters-preference-help": "Откатывает редизайн интерфейса 2017 года и все инструменты, добавленные с тех пор.", - "rcfilters-watchlist-preference-label": "Скрыть улучшенную версию Списка наблюдения", + "rcfilters-watchlist-preference-label": "Скрыть улучшенную версию cписка наблюдения", "rcfilters-watchlist-preference-help": "Отменяет редизайн интерфейса 2017 года и все инструменты, добавленные тогда и позднее.", "rcfilters-filter-showlinkedfrom-label": "Показать правки на ссылаемых страницах", "rcfilters-filter-showlinkedfrom-option-label": "Страницы, на которые ссылается выбранная", @@ -1857,6 +1859,7 @@ "http-timed-out": "Истекло время ожидания HTTP-запроса.", "http-curl-error": "Ошибка обращения к URL: $1", "http-bad-status": "Во время обработки HTTP-запроса обнаружена проблема: $1 $2", + "http-internal-error": "Внутренняя ошибка HTTP.", "upload-curl-error6": "Невозможно обратить по указанному адресу.", "upload-curl-error6-text": "Невозможно обратить по указанному адресу. Пожалуйста, проверьте, что адрес верен, а сайт доступен.", "upload-curl-error28": "Время, отведённое на загрузку, истекло", @@ -2152,7 +2155,7 @@ "speciallogtitlelabel": "Цель (название или {{ns:user}}:имя участника):", "log": "Журналы", "logeventslist-submit": "Показать", - "logeventslist-more-filters": "Больше фильтров:", + "logeventslist-more-filters": "Показать дополнительные журналы:", "logeventslist-patrol-log": "Журнал патрулирования", "logeventslist-tag-log": "Журнал меток", "all-logs-page": "Все доступные журналы", @@ -2862,7 +2865,7 @@ "tooltip-ca-talk": "Обсуждение основной страницы", "tooltip-ca-edit": "Редактировать данную страницу", "tooltip-ca-addsection": "Создать новый раздел", - "tooltip-ca-viewsource": "Эта страница защищена от изменений. Вы можете посмотреть и скопировать её исходный текст.", + "tooltip-ca-viewsource": "Эта страница защищена от изменений. Вы можете посмотреть её исходный текст.", "tooltip-ca-history": "Журнал изменений страницы", "tooltip-ca-protect": "Защитить страницу от изменений", "tooltip-ca-unprotect": "Изменить защиту этой страницы", @@ -3019,8 +3022,6 @@ "markedaspatrollederrornotify": "Отметить изменение как проверенное не удалось.", "patrol-log-page": "Журнал патрулирования", "patrol-log-header": "Это журнал патрулированных версий.", - "log-show-hide-patrol": "$1 журнал патрулирования", - "log-show-hide-tag": "$1 журнал меток", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Пометить версию $3 страницы $2 как отпатрулированную?", "deletedrevision": "Удалена старая версия $1", diff --git a/languages/i18n/rue.json b/languages/i18n/rue.json index 070f6205ae..591f26266a 100644 --- a/languages/i18n/rue.json +++ b/languages/i18n/rue.json @@ -2154,7 +2154,6 @@ "markedaspatrollederrornotify": "Не вдало ся поставити позначку про патролёваня", "patrol-log-page": "Книга перевіреных едітовань", "patrol-log-header": "Тото є книга перевіреных верзій.", - "log-show-hide-patrol": "$1 книгу записів патролованя", "deletedrevision": "Змазана стара ревізія $1", "filedeleteerror-short": "Хыба мазаня файлу: $1", "filedeleteerror-long": "Выникла хыба під час мазаня файлу:\n\n$1", diff --git a/languages/i18n/sa.json b/languages/i18n/sa.json index 513e64df22..6ce15127a3 100644 --- a/languages/i18n/sa.json +++ b/languages/i18n/sa.json @@ -2331,8 +2331,6 @@ "markedaspatrollederrornotify": "समीक्षितम् इति चिह्नीकरणं विफलम्।", "patrol-log-page": "निरीक्षिता संरक्षितावलिः", "patrol-log-header": "इयम् आरक्षितपुनरावृत्तीनां सूचिका अस्ति ।", - "log-show-hide-patrol": "$1 इत्यनेन निरीक्षिता संरक्षितावलिः", - "log-show-hide-tag": "$1 चिह्नाऽऽवलिः", "deletedrevision": "अपमर्जितप्राचीनपुनरावृत्तिः $1", "filedeleteerror-short": "सञ्चिकानपमर्जने दोषः : $1", "filedeleteerror-long": " सञ्चिकानामपमर्जने आगता समस्या $1", diff --git a/languages/i18n/sah.json b/languages/i18n/sah.json index 2214defe23..0bad36edeb 100644 --- a/languages/i18n/sah.json +++ b/languages/i18n/sah.json @@ -2814,8 +2814,6 @@ "markedaspatrollederrornotify": "Бэлиэтэммит курдук бэлиэтиир сатаммата.", "patrol-log-page": "Бэрэбиэркэ сурунаала", "patrol-log-header": "Ботуруулламмыт торумнар сурунааллара.", - "log-show-hide-patrol": "$1 ботурууллааһын сурунаала", - "log-show-hide-tag": "$1 тиэк сурунаала", "confirm-markpatrolled-button": "Сөп", "confirm-markpatrolled-top": "$2 сирэй $3 торумун ботуруулламмыт курдук бэлиэтиигин дуо?", "deletedrevision": "$1 урукку торума сотулунна", diff --git a/languages/i18n/sat.json b/languages/i18n/sat.json index 76e4181102..3f62e10178 100644 --- a/languages/i18n/sat.json +++ b/languages/i18n/sat.json @@ -329,8 +329,8 @@ "protectedpagetext": "ᱱᱚᱣᱟ ᱥᱟᱦᱴᱟ ᱫᱚ ᱚᱞ ᱥᱟᱯᱲᱟᱣ ᱞᱟᱹᱜᱤᱛᱛᱮ ᱫᱚ ᱵᱟᱸᱪᱟᱣ ᱜᱮᱭᱟ᱾", "viewsourcetext": "ᱱᱚᱭᱟ ᱥᱟᱦᱴᱟᱢ ᱧᱮᱞ ᱫᱟᱲᱮᱭᱟᱜ-ᱟ ᱟᱨᱮᱢ ᱠᱚᱯᱤ ᱫᱟᱲᱮᱭᱟᱜ-ᱟ᱾", "viewyourtext": "ᱟᱢ ᱫᱚ '''ᱟᱢᱟᱜ ᱥᱟᱯᱲᱟᱣ''' ᱥᱟᱦᱴᱟ ᱧᱮᱞ ᱟᱨ ᱮᱢ ᱠᱚᱯᱤ ᱦᱟᱛᱟᱣ ᱫᱟᱲᱮᱭᱟᱜ-ᱟ:", - "protectedinterface": "Noa sakam reaḱ babotko do wiki sofṭoyer reaḱ mit́ṭen inṭarfes khobore ema, onate noa do rukhiyạ doho hoeakana.", - "cascadeprotected": "Noa sakam do sompadon khon rukhiyạre menaḱa, karon sakam do latar reaḱ {{PLURAL:$1 gan sakam reaḱ gan sakam reaḱ}} bhitrire, oka sakam do (cascading) te rukhiyạ menaḱa:\n$2", + "protectedinterface": "ᱱᱚᱣᱟ ᱥᱟᱦᱴᱟ ᱨᱮᱭᱟᱜ ᱵᱟᱵᱚᱛᱠᱚ ᱫᱚ ᱣᱤᱠᱤ ᱥᱚᱯᱷᱴᱚᱭᱟᱨ ᱨᱮᱭᱟᱜ ᱢᱤᱫᱴᱮᱱ ᱤᱱᱴᱟᱨᱯᱷᱮᱥ ᱠᱷᱚᱵᱚᱨᱮ ᱮᱢᱟ, ᱚᱱᱟᱛᱮ ᱱᱚᱣᱟ ᱫᱟ ᱨᱩᱠᱷᱤᱭᱟᱹ ᱫᱚᱦᱚ ᱦᱩᱭᱠᱟᱱᱟ᱾", + "cascadeprotected": "ᱱᱚᱣᱟ ᱥᱟᱦᱴᱟ ᱫᱚ ᱥᱟᱯᱲᱟᱣ ᱠᱷᱚᱱ ᱨᱩᱠᱷᱤᱭᱟᱹᱨᱮ ᱢᱮᱱᱟᱜ-ᱟ, ᱠᱟᱨᱚᱱ ᱱᱚᱣᱟ ᱥᱟᱦᱴᱟ ᱫᱚ ᱞᱟᱛᱟᱨ ᱨᱮᱭᱟᱜ {{PLURAL:$1 ᱜᱟᱱ ᱥᱟᱦᱴᱟ ᱨᱮᱭᱟᱜ ᱜᱟᱱ ᱥᱟᱦᱴᱟ ᱨᱮᱭᱟᱜ}} ᱵᱷᱤᱛᱨᱤᱨᱮ, ᱚᱠᱟ ᱥᱟᱦᱴᱟ ᱫᱚ (cascading) ᱛᱮ ᱨᱩᱠᱷᱤᱭᱟᱹ ᱢᱮᱱᱟᱜ-ᱟ:\n$2", "namespaceprotected": "Amaḱ do sakamko joṛao lạgit́te ạidạri banuḱ tama '''$1''' ńutumjayga.", "ns-specialprotected": "Asokay teaḱ sakamkodo baṅ oltoṅgea.", "exception-nologin": "ᱵᱟᱢ ᱵᱚᱞᱚ ᱟᱠᱟᱱᱟ", @@ -377,7 +377,7 @@ "createacct-emailoptional": "ᱤᱢᱮᱞ ᱴᱷᱤᱠᱱᱟ (ᱟᱢᱠᱩᱥᱤ)", "createacct-email-ph": "ᱟᱢᱟᱜ ᱤᱢᱮᱞ ᱵᱩᱴᱟᱹ ᱟᱫᱮᱨᱢᱮ", "createacct-another-email-ph": "ᱤᱢᱮᱞ ᱵᱩᱴᱟᱹ ᱟᱫᱮᱨᱢᱮ", - "createaccountmail": "E-mail hotete", + "createaccountmail": "E-mail ᱦᱚᱛᱮᱛᱮ", "createacct-realname": "ᱥᱚᱛ ᱧᱩᱛᱩᱢ (ᱚᱯᱥᱱᱟᱞ)", "createacct-reason": "ᱚᱡᱮ", "createacct-reason-ph": "ᱪᱮᱫᱟᱜ ᱟᱢ ᱮᱴᱟᱜ ᱦᱤᱥᱟᱹᱵᱮᱢ ᱛᱮᱭᱟᱨᱫᱟ", @@ -398,13 +398,13 @@ "nocookieslogin": "{{SITENAME}} re kuki hotete beoharićaḱ bhitri boloḱ do hoyoḱa. Amaḱ sendrare kuki bondo menaḱa. Kuki cạlu kate arhõ kurumuṭuimẽ.", "nocookiesfornew": "Beoharićaḱ ekaunṭ do baṅ tear akana, Cedaḱ je noa ńamoḱ jaega babote ale do bale uruma.\nAle do baḍae ocolem amaḱ kuki doe kạmikana, sakam do arhõ rakaṕ lạgit́te kurumuṭuemẽ.", "noname": "Am do asol beoharićaḱ ńutum ṭhikte bam emakada.", - "loginsuccesstitle": "Bhitri boloḱ do moctege puraoena", + "loginsuccesstitle": "ᱵᱷᱤᱛᱨᱤ ᱵᱚᱠᱟᱜ ᱫᱚ ᱢᱚᱡᱽᱛᱮᱜᱮ ᱯᱩᱨᱟᱹᱣᱱᱟ", "loginsuccess": "'''Am do nitge \"$1\" ńutumte {{SITENAME}} rem bolo akana.'''", - "nosuchuser": "\"$1\" ńutuman jahan beoharić bạnuea.\nBeoharićaḱ ńutum do bukṛogea.\nAmaḱ bananko ńelmẽ, se [[Special:Userlogin/signup nãwã mit́ṭen ekaunṭ tearmẽ]].", + "nosuchuser": "\"$1\" ᱧᱩᱛᱩᱢᱟᱱ ᱡᱟᱸᱦᱟᱱ ᱵᱮᱵᱷᱟᱨᱤᱡ ᱵᱟᱹᱱᱩᱭᱟ᱾ ᱵᱮᱵᱷᱟᱨᱤᱡ ᱧᱩᱛᱩᱢ ᱫᱚ ᱵᱩᱠᱨᱩᱜᱮᱭᱟ᱾ ᱟᱢᱟᱜ ᱵᱟᱱᱟᱱᱠᱩ ᱧᱮᱞᱢᱮ, ᱥᱮ [[Special:CreateAccount|ᱱᱟᱣᱟ ᱢᱤᱫᱴᱮᱱ ᱦᱤᱫᱟᱹᱵ ᱠᱷᱟᱛᱟ ᱛᱮᱭᱟᱨᱢᱮ]]᱾", "nosuchusershort": "\"$1\" ńutuman jahãe beoharko do banuḱkoa. Ńutum reaḱ banan biḍaomẽ.", "nouserspecified": "Am do pusṭaote laṛcaṛićaḱ ńutum em hoyoḱtama.", "login-userblocked": "Nui laṛcaṛic doe esetgea. bhitri boloḱ ạidạri bań emoḱ kana.", - "wrongpassword": "Bań milaoaḱ oku nambar em hoyakana.\nDaya kate arhõ mitdhom kurumuṭuyme.", + "wrongpassword": "ᱵᱮᱷᱟᱨᱤᱭᱟᱜ ᱧᱩᱛᱩᱢ ᱥᱮ ᱩᱠᱩ ᱱᱟᱢᱵᱟᱨ ᱵᱟᱝ ᱢᱤᱞᱟᱹᱜ ᱠᱟᱱᱟ᱾ ᱫᱚᱲᱦᱟᱛᱮ ᱠᱩᱨᱩᱢᱩᱴᱩᱭᱢᱮ᱾", "wrongpasswordempty": "Em hoyen oku nambar do cetge banuḱa.\nDaya katet́ arhõ kurumuṭuyme.", "passwordtooshort": "Uku nambar do {{PLURAL:$1 1 horop reaḱ $1 horop reaḱ}} mudre hoyoḱ jạruṛa.", "password-name-match": "Amaḱ oku nambar do amaḱ ńutum khon eṭaḱ hoyoḱ jạruṛtama.", @@ -414,9 +414,9 @@ "noemail": "\"$1\" beoharić lạgit́te do jahan e-mail ṭhikana rukhiyạ doho bạnuḱa.", "noemailcreate": "Am do mitṭen jewet e-mail ṭhikạna em jaruṛ menaḱtama.", "passwordsent": "\"$1\" ṭhikạnate resṭariyen e-mail lạgit́te mitṭen oku nambar em hoyena.\nDaya kate ńam porte arhõ bhitri boloḱme.", - "blocked-mailpassword": "Amaḱ IP ṭhikạna khon sompadon do bondo menaḱa, Onate noa ṭhikạna baṅ beohar kate uku nambar ruạṛ baṅ hoyoḱa.", + "blocked-mailpassword": "ᱟᱢᱟᱜ IP ᱴᱷᱤᱠᱟᱹᱱᱟ ᱠᱷᱚᱱ ᱥᱟᱯᱲᱟᱣ ᱰᱚᱱᱫᱷ ᱜᱮᱭᱟ᱾ ᱚᱱᱟᱛᱮ ᱱᱚᱣᱟ ᱴᱷᱤᱠᱟᱹᱱᱟ ᱵᱟᱝ ᱵᱮᱵᱷᱟᱨ ᱠᱟᱛᱮ ᱩᱠᱩ ᱱᱟᱢᱵᱟᱨ ᱨᱩᱣᱟᱹᱲ ᱵᱟᱝ ᱦᱩᱭᱩᱜ-ᱟ᱾", "mailerror": "E-mail kulte eṭkẽṭõrẽ: $1", - "emailauthenticated": "Amaḱ e-mail ṭhikạna do $2 tạrikh reaḱ $3 re jạhirena.", + "emailauthenticated": "ᱟᱢᱟᱜ e-mail ᱴᱷᱤᱠᱟᱹᱱᱟ ᱫᱚ $2 ᱛᱟᱹᱨᱤᱠᱷ ᱨᱮᱭᱟᱜ $3 ᱨᱮ ᱡᱟᱹᱦᱤᱨᱮᱱᱟ᱾", "emailnotauthenticated": "Amaḱ e-mail reaḱ ṭhikạna do nit hõ baṅ jacay akana latar reaḱ features lạgit́te jahan e-mail do baṅkuloḱa.", "noemailprefs": "Noa features ko kạmie ocoy lạgit́te mit́ṭen e-mail ṭhikạna dohoe hoyoḱa.", "emailconfirmlink": "Amaḱ e-mail ṭhikana do sạriyme.", diff --git a/languages/i18n/scn.json b/languages/i18n/scn.json index fc69e1e3dd..3f8abdfb72 100644 --- a/languages/i18n/scn.json +++ b/languages/i18n/scn.json @@ -2361,8 +2361,6 @@ "markedaspatrollederrornotify": "La marcatura comu virificatu nun arriniscìu.", "patrol-log-page": "Riggistru dî canciamenti virificati", "patrol-log-header": "Chistu è nu riggistru dî virsioni virificati.", - "log-show-hide-patrol": "$1 lu riggistru dî canciamenti virificati", - "log-show-hide-tag": "$1 lu riggistru di l'etichetti", "deletedrevision": "Cancillata na virsioni vecchia di $1", "filedeleteerror-short": "Erruri ntâ cancillazzioni dû file: $1", "filedeleteerror-long": "Ammatteru erruri ntô tintativu di cancillari lu file:\n\n$1", diff --git a/languages/i18n/sco.json b/languages/i18n/sco.json index fd746f1732..aabc640dc8 100644 --- a/languages/i18n/sco.json +++ b/languages/i18n/sco.json @@ -2596,8 +2596,6 @@ "markedaspatrollederrornotify": "Maurking aes patrowed failed.", "patrol-log-page": "Patrow log", "patrol-log-header": "This is ae log o patrowed reveesions.", - "log-show-hide-patrol": "$1 patrow log", - "log-show-hide-tag": "$1 tag log", "deletedrevision": "Delytit auld reveesion $1.", "filedeleteerror-short": "Mistak delytin file: $1", "filedeleteerror-long": "mistaks were encoontered while delytin the file:\n\n$1", diff --git a/languages/i18n/sd.json b/languages/i18n/sd.json index 5d4e0c49ed..6bd59b7be3 100644 --- a/languages/i18n/sd.json +++ b/languages/i18n/sd.json @@ -139,7 +139,7 @@ "listingcontinuesabbrev": "جاري.", "index-category": "ڏسڻيل صفحا", "noindex-category": "غيرڏسڻيل صفحا", - "broken-file-category": "فائيل جي ٽٽل ڳنڍڻن وارا صفحا", + "broken-file-category": "ٽٽل فائل ڳنڍڻن وارا صفحا", "about": "بابت", "article": "موادي صفحو", "newwindow": "(نئين دريءَ ۾ کلندو)", @@ -732,6 +732,7 @@ "prefs-email": "برقٽپال چارا", "prefs-rendering": "حليو", "saveprefs": "سانڍيو", + "restoreprefs": "شروعاتي ترتيبون واپس ڪيو (سمورن خانن ۾)", "prefs-editing": "سنوارڻ", "searchresultshead": "ڳولا", "stub-threshold-sample-link": "نمونو", @@ -759,6 +760,8 @@ "timezoneregion-indian": "سنڌي ساگر", "timezoneregion-pacific": "ماٺو ساگر", "allowemail": "ٻين واپرائيندڙن کي مون ڏانھن برقٽپال ڪرڻ جي اجازت ڏيو", + "email-allow-new-users-label": "نوان واپرائيندڙ برق ٽپال موڪلين", + "email-blacklist-label": "هنن واپرائندڙن کي مون ڏانهن برقٽپال ڪرڻ جي اجازت نه ڏيو:", "prefs-searchoptions": "ڳولا", "prefs-namespaces": "نانءُپولار", "default": "ڏنل", @@ -774,6 +777,7 @@ "yourrealname": "اصل نالو:", "yourlanguage": "ٻولي:", "yournick": "نئين صحيح:", + "prefs-help-signature": "بحث صفحي تي رايا ڏيڻ وقت هن نشانين ذريعي \"~~~~\" دستخط ڪيو، جيڪي پاڻ مرادو توهان جي دستخط ۽ وقت ۾ تبديل ٿي ويندا.", "badsiglength": "اها صحيح هيڪاندي ڊگھي آهي.\nاها وڌ ۾ وڌ $1 {{PLURAL:$1|اکر|اکرن}} تي ٻڌل هوڻ گھرجي.", "yourgender": "توهان ڪهڙو تعارف چاهيندا؟", "gender-unknown": "توهان جو ذڪر ڪندي، جيترو ٿي سگھيو، منطقگري بي جنس لفظن جو استعمال ڪندي.", @@ -783,6 +787,7 @@ "email": "برقٽپال", "prefs-help-realname": "اصل نالو اختياري آهي.\nجيڪڏهن توهان اصل نالو ڄاڻائڻ جو فيصلو ٿا ڪريو، تہ اهو توهان کي توهان جي ڪم جي مڃتا ڏيڻ لاءِ ڪم آندو ويندو.", "prefs-help-email": "برقٽپال ڄاڻائڻ اختياري آهي، پر جڏهن توهان ڳجھولفظ وسري ويندا آهيو، تڏهن ان جو استعمال توهان کي نئون ڳجھولفظ ڏيڻ لاءِ استعمال ڪيو ويندو آهي.", + "prefs-help-email-others": "اوهان چونڊ ڪري سگھو ٿا ته اوهان جي ذاتي يا بحث صفحي تي موجود ڳنڍڻي ذريعي ٻيو ڪو واپرائيندڙ اوهان کي برقٽپال ڪري سگھي ٿو يا نه.\nاوهان جو برقٽپال پتو ٻين پاران رابطي ڪرڻ وقت ڳجهو رکيو ويندو.", "prefs-help-email-required": "برقٽپال پتو گھربل آهي.", "prefs-info": "بنيادي ڄاڻ", "prefs-i18n": "بين‌الاقوامڪاري", @@ -949,6 +954,7 @@ "rcfilters-days-show-days": "$1 {{PLURAL:$1|ڏينھُن|ڏينھَن}}", "rcfilters-highlighted-filters-list": "نمايان-ٿيل:$1", "rcfilters-quickfilters": "سانڍيل ڇاڻيون", + "rcfilters-quickfilters-placeholder-title": "اڃان ڪا به ڇاڻي سانڍيل ناهي", "rcfilters-savedqueries-defaultlabel": "سانڍيل ڇاڻيون", "rcfilters-savedqueries-rename": "ٻيھر نالو ڏيو", "rcfilters-savedqueries-new-name-label": "نالو", @@ -1484,6 +1490,7 @@ "block": "واپرائيندڙ کي بندشيو", "unblock": "واپرائيندڙ کي اڻبندشيو", "blockip": "{{GENDER:$1|واپرائيندڙ}} تي بندش وجھو", + "ipaddressorusername": "آئي پي پتو يا واپرائيندڙ-نانءُ:", "ipbexpiry": "اختتام:", "ipbreason": "سبب:", "ipbother": "ٻيو وقت:", @@ -1491,6 +1498,7 @@ "ipb-confirm": "بندش جي پڪ ڪريو", "badipaddress": "ناقابلڪار آءِ پي پتو", "blockipsuccesssub": "بندش ڪامياب ٿي", + "ipb-blockingself": "اوهان پنهنجي پاڻ تي بندش وجهي رهيا آهيو! ڇا اوهان اهو ڪرڻ پسند ڪندو؟", "unblockip": "واپرائيندڙ کي اڻبندشيو", "ipusubmit": "اها بندش هٽايو", "unblocked-range": "$1 تان بندش هٽي چڪي آهي.", @@ -1531,6 +1539,7 @@ "movepagetext": "هيٺيون فارم استعمال ڪندي ڪنهن صفحي کي نئون عنوان ڏئي سگھجي ٿو، جنهن سان سمورو صفحو نئين عنوان ڏانهن هليو ويندو. \nاڳوڻو عنوان نئين عنوان ڏانهن چورڻو بنجي ويندو. \nتوهان چورڻن کي سنواري سگھو ٿا جيڪي اصل عنوان ڏانهن خودبخود اشارو ڪن ٿا.\nانهي ڳالهه جي پڪ ڪري وٺو ته [[Special:BrokenRedirects|ٽٽل چورڻا]] يا [[Special:DoubleRedirects|ٻٽا چورڻا]] نه هجن.\nان ڳالهه جي پڪ ڪرڻ ذميواري توهان تي آهي ته ڳنڍڻا اتي ئي وٺي وڃن ٿا جتي انهن کي وٺي وڃڻ گھرجي.\n\nياد رکندا ته جيڪڏهن نئين عنوان سان اڳي ئي ڪو مضمون موجود آهي ته پوءِ صفحو '''نه''' چوريو ويندو، سوا ان جي ته موجوده صفحو محظ خالي آهي يا ڪا به سوانح نه رکندڙ ڪو چورڻو آهي.\n\nنوٽ!\nاها هڪ مقبول صفحي لاءِ ڪا غير متوقه ۽ انتهائي اڻوڻندڙ تبديلي ثابت ٿي سگھي ٿي؛ براءِ مهرباني اڳتي وڌڻ کان اڳ پڪ ڪندا ته توهان اها تبديلي آڻڻ جي نتيجن کان چڱيءَ ريت واقف آهيو.", "movepagetext-noredirectfixer": "هيٺيون فارم استعمال ڪندي ڪنهن صفحي کي نئون عنوان ڏئي سگھجي ٿو، جنهن سان سمورو صفحو نئين عنوان ڏانهن هليو ويندو. \nاڳوڻو عنوان نئين عنوان ڏانهن چورڻو بنجي ويندو. \nتوهان چورڻن کي سنواري سگھو ٿا جيڪي اصل عنوان ڏانهن خودبخود اشارو ڪن ٿا.\nانهي ڳالهه جي پڪ ڪري وٺو ته [[Special:BrokenRedirects|ٽٽل چورڻا]] يا [[Special:DoubleRedirects|ٻٽا چورڻا]] نه هجن.\nان ڳالهه جي پڪ ڪرڻ ذميواري توهان تي آهي ته ڳنڍڻا اتي ئي وٺي وڃن ٿا جتي انهن کي وٺي وڃڻ گھرجي.\n\nياد رکندا ته جيڪڏهن نئين عنوان سان اڳي ئي ڪو مضمون موجود آهي ته پوءِ صفحو '''نه''' چوريو ويندو، سوا ان جي ته موجوده صفحو محظ خالي آهي يا ڪا به سوانح نه رکندڙ ڪو چورڻو آهي.\n\nنوٽ!\nاها هڪ مقبول صفحي لاءِ ڪا غير متوقه ۽ انتهائي اڻوڻندڙ تبديلي ثابت ٿي سگھي ٿي؛ مهرباني ڪري اڳتي وڌڻ کان اڳ پڪ ڪندا ته توهان اها تبديلي آڻڻ جي نتيجن کان چڱيءَ ريت واقف آهيو.", "movepagetalktext": "جيڪڏهن توهان هن خاني کي نشان لڳائيندئو، واسطيدار مباحثي صفحو پاڻ ئي چوريو ويندو ماسواءِ اتي ڪو اڳ ئي ڪو غيرخالي مباحثي صفحو موجود هجي.\n\nان صورت ۾، جيڪڏهن توهان چاهيو ته صفحي کي پاڻ چوري يا ضم ڪري سگھو ٿا.", + "movecategorypage-warning": "چتاءُ: اوهان زمري واري صفحي کي چورڻ وڃي رهيا آهيو. ياد رکو صرف صفحو چورندو، جيڪڏهن ڪي به صفحا پراڻي زمري ۾ شامل آهن، انهن جي نئين زمري ۾ درجابندي نه ٿيندي.", "movenotallowed": "توهان کي صفحا چورڻ جي اجازت حاصل ڪانهي.", "movenotallowedfile": "توهان کي فائيلس چورڻ جي اجازت حاصل ڪانهي.", "newtitle": "نئون عنوان:", @@ -1672,6 +1681,7 @@ "file-info-gif-frames": "$1 {{PLURAL:$1|فريم|فريمَ}}", "file-info-png-frames": "$1 {{PLURAL:$1|فريم|فريمَ}}", "newimages": "نون فائيلن جي گيلري", + "newimages-user": "آئي پي پتو يا واپرائيندڙ-نانءُ", "noimages": "ڏسڻ لاءِ ڪجھہ ناهي.", "ilsubmit": "ڳوليو", "bydate": "تاريخوار", @@ -1925,6 +1935,7 @@ "logentry-delete-revision": "$1 $3: $4 صفحي تي {{PLURAL:$5|ھڪ مسودي|$5 مسودن}} جي ظاھريت {{GENDER:$2|تبديل ڪئي}}", "revdelete-content-hid": "مواد لڪيل", "revdelete-uname-hid": "واپرائيندڙ-نانءُ لڪل", + "logentry-block-block": "$1، {{GENDER:$4|$3}} تي $5 وقت جي خاتمي تائين {{GENDER:$2|بندش هئي آهي}} $6", "logentry-move-move": "$1 {{GENDER:$2|چوريو}} صفحو $3 ڏانهن $4", "logentry-move-move-noredirect": "$1 $3 صفحي کي $4 ڏانھن {{GENDER:$2|چوريو}} سواءِ ڪو ريڊائريڪٽ ڇڏيندي", "logentry-move-move_redir": "$1 $3 کي $4 ڏانھن ريڊائريڪٽ مٿان {{GENDER:$2|چوريو}}", @@ -1981,6 +1992,7 @@ "mw-widgets-mediasearch-noresults": "ڪي-بہ نتيجا نہ لڌا.", "mw-widgets-titleinput-description-new-page": "اڃا اهو صفحو وجود نہ ٿو رکي", "mw-widgets-titleinput-description-redirect": "$1 ڏانهن چوريل", + "mw-widgets-usersmultiselect-placeholder": "وڌيڪ شامل ڪيو...", "date-range-from": "تاريخ کان:", "date-range-to": "تاريخ تائين:", "log-action-filter-all": "سڀ" diff --git a/languages/i18n/ses.json b/languages/i18n/ses.json index d98c844a7c..9a26fdc243 100644 --- a/languages/i18n/ses.json +++ b/languages/i18n/ses.json @@ -2292,7 +2292,6 @@ "markedaspatrollederrornotify": "Goo ma šilbay kaŋ a ga kurandi.", "patrol-log-page": "Kuryan taariki", "patrol-log-header": "Woo ti filla kurantey taarikoo.", - "log-show-hide-patrol": "kuryan taariki $1", "deletedrevision": "Filla žeena tuusante $1", "filedeleteerror-short": "Tuku tuusuyan firka: $1", "filedeleteerror-long": "Firkayaŋ bangay tukoo tuusuyanoo waate:\n\n$1", diff --git a/languages/i18n/sgs.json b/languages/i18n/sgs.json index e1e2ee9cf0..be33940379 100644 --- a/languages/i18n/sgs.json +++ b/languages/i18n/sgs.json @@ -1700,7 +1700,6 @@ "markedaspatrolled": "Pažīmiets kāp patėkrints", "markedaspatrolledtext": "Pasėrinkta versėjė siekmingā pažīmieta kāp patėkrinta", "patrol-log-page": "Patikrinėma istuorėjė", - "log-show-hide-patrol": "$1 patvirtėnėmu saraša", "deletedrevision": "Ėštrinta sena versėjė $1.", "filedeleteerror-short": "Klaida trėnont faila: $1", "previousdiff": "← Onkstesnis pakeitėms", diff --git a/languages/i18n/sh.json b/languages/i18n/sh.json index f4b87edb39..d8a7a88003 100644 --- a/languages/i18n/sh.json +++ b/languages/i18n/sh.json @@ -2371,7 +2371,6 @@ "markedaspatrollederrornotify": "Nije uspjelo označavanje ove stranice kao patrolirane.", "patrol-log-page": "Evidencija patroliranja", "patrol-log-header": "Ovdje se nalazi evidencija patroliranih revizija.", - "log-show-hide-patrol": "$1 zapis patroliranja", "deletedrevision": "Obrisana stara revizija $1", "filedeleteerror-short": "Greška pri brisanju datoteke: $1", "filedeleteerror-long": "Desile su se greške pri brisanju datoteke:\n\n$1", diff --git a/languages/i18n/si.json b/languages/i18n/si.json index 3d4068c711..ebec29982f 100644 --- a/languages/i18n/si.json +++ b/languages/i18n/si.json @@ -2361,8 +2361,6 @@ "markedaspatrollederror-noautopatrol": "ඔබගේ ස්වීය වෙනස්වීම් පරික්‍ෂාකර බැලූ ලෙස සලකුණු කිරීමට ඔබ හට ඉඩ දෙනු නොලැබේ.", "patrol-log-page": "පරික්ෂාකිරීම් සටහන", "patrol-log-header": "මෙය පරික්‍ෂාකර බැලූ සංශෝධනයන්ගේ ලඝු-සටහනකි.", - "log-show-hide-patrol": "පරික්‍ෂාකිරීම් ලඝු-සටහන් $1", - "log-show-hide-tag": "$1 ටැගය ලඝු-සටහන", "deletedrevision": "පැරැණි සංශෝධනය $1 මකාදමන ලදි", "filedeleteerror-short": "ගොනුව මකාදැමීමේ දෝෂය: $1", "filedeleteerror-long": "ගොනුව මකාදැමීමේදී දෝෂයන් හමුවුණි:\n\n$1", diff --git a/languages/i18n/sk.json b/languages/i18n/sk.json index 3fe3bc86a2..4accf55533 100644 --- a/languages/i18n/sk.json +++ b/languages/i18n/sk.json @@ -2726,8 +2726,6 @@ "markedaspatrollederrornotify": "Nepodarilo sa označiť ako preverené.", "patrol-log-page": "Záznam preverených úprav", "patrol-log-header": "Toto je záznam preverených revízií.", - "log-show-hide-patrol": "$1 záznam preverených úprav", - "log-show-hide-tag": "$1 záznam značiek", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Označiť revíziu $3 stránky $2 ako preverenú?", "deletedrevision": "Zmazať staré verzie $1", diff --git a/languages/i18n/sl.json b/languages/i18n/sl.json index a2303f5bc4..f30b990702 100644 --- a/languages/i18n/sl.json +++ b/languages/i18n/sl.json @@ -920,6 +920,8 @@ "diff-paragraph-moved-toold": "Odstavek je bil premaknjen. Kliknite, da skočite na staro nahajališče.", "difference-missing-revision": "{{PLURAL:$2|Ene redakcije|$2 redakcij}} razlike ($1) {{PLURAL:$2|nisem}} našel.\n\nPo navadi se to zgodi, ko sledite zastareli povezavi na razliko redakcij strani, ki jo je nekdo izbrisal.\nPodrobnosti lahko najdete v [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} dnevniku brisanja].", "searchresults": "Izid iskanja", + "search-filter-title-prefix": "Išči samo na straneh, katerih naslovi se začnejo z \"$1\"", + "search-filter-title-prefix-reset": "Išči vse strani", "searchresults-title": "Zadetki za povpraševanje »$1«", "titlematches": "Ujemanje z naslovom članka", "textmatches": "Ujemanje z besedilom članka", @@ -985,7 +987,7 @@ "prefs-rc": "Zadnje spremembe", "prefs-watchlist": "Spisek nadzorov", "prefs-editwatchlist": "Uredi spisek nadzorov", - "prefs-editwatchlist-label": "Uredite vnose na svojem spisku nadzorov:", + "prefs-editwatchlist-label": "Uredi vnose na svojem spisku nadzorov:", "prefs-editwatchlist-edit": "Preglejte in odstranite naslove s svojega spiska nadzorov", "prefs-editwatchlist-raw": "Uredite gol spisek nadzorov", "prefs-editwatchlist-clear": "Počistite svoj spisek nadzorov", @@ -1726,6 +1728,7 @@ "http-timed-out": "Zahteva HTTP je potekla.", "http-curl-error": "Napaka pri doseganju URL: $1", "http-bad-status": "Med zahtevo HTTP je prišlo do težave: $1 $2", + "http-internal-error": "Notranja napaka HTTP.", "upload-curl-error6": "Ni možno doseči URL", "upload-curl-error6-text": "Navedenega naslova URL ni mogoče doseči.\nProsimo, ponovno preverite pravilnost URL-a in delovanje strani.", "upload-curl-error28": "Časovna prekinitev nalaganja", @@ -2018,7 +2021,7 @@ "speciallogtitlelabel": "Cilj (naslov ali {{ns:user}}:uporabniškoime za uporabnika):", "log": "Dnevniki", "logeventslist-submit": "Prikaži", - "logeventslist-more-filters": "Več filtrov:", + "logeventslist-more-filters": "Prikaži dodatne dnevnike:", "logeventslist-patrol-log": "Dnevnik patrulje", "logeventslist-tag-log": "Dnevnik oznak", "all-logs-page": "Vsi javni dnevniki", @@ -2862,8 +2865,6 @@ "markedaspatrollederrornotify": "Označevanje kot nadzorovano ni uspelo.", "patrol-log-page": "Dnevnik patrulje", "patrol-log-header": "To je dnevnik nadzorovanih redakcij.", - "log-show-hide-patrol": "$1 dnevnik nadzora", - "log-show-hide-tag": "$1 dnevnik oznak", "confirm-markpatrolled-button": "V redu", "confirm-markpatrolled-top": "Označimo redakcijo $3 strani $2 kot nadzorovano?", "deletedrevision": "Prejšnja redakcija $1 je izbrisana", diff --git a/languages/i18n/sli.json b/languages/i18n/sli.json index 0c01fdd720..2514d5b47f 100644 --- a/languages/i18n/sli.json +++ b/languages/i18n/sli.json @@ -1407,7 +1407,6 @@ "markedaspatrollederror-noautopatrol": "Is ies ne erlaubt, eigene Beoarbeetunga ols kontrolliert zu markieren.", "patrol-log-page": "Kontroll-Logbichl", "patrol-log-header": "Dies ies doas Kontroll-Logbuch.", - "log-show-hide-patrol": "Kontroll-Logbichl $1", "deletedrevision": "aale Version: $1", "filedeleteerror-short": "Fahler bei Datei-Läschung: $1", "filedeleteerror-long": "Bei dar Datei-Läschung wurden Fahler festgestellt:\n\n$1", diff --git a/languages/i18n/sq.json b/languages/i18n/sq.json index c1be4c365c..d1f3d62cfe 100644 --- a/languages/i18n/sq.json +++ b/languages/i18n/sq.json @@ -2639,8 +2639,6 @@ "markedaspatrollederrornotify": "Shënimi si i patrulluar dështoi.", "patrol-log-page": "Regjistri i patrollimeve", "patrol-log-header": "Këto janë të dhëna të revizioneve të patrulluara.", - "log-show-hide-patrol": "$1 regjistri i patrollimeve", - "log-show-hide-tag": "$1 regjistri i etiketave", "confirm-markpatrolled-button": "Në rregull", "confirm-markpatrolled-top": "Shëno versionin $3 nga $2 si të patrolluar", "deletedrevision": "Gris versionin e vjetër $1", diff --git a/languages/i18n/sr-ec.json b/languages/i18n/sr-ec.json index d615041943..03df866b0d 100644 --- a/languages/i18n/sr-ec.json +++ b/languages/i18n/sr-ec.json @@ -38,7 +38,8 @@ "Acamicamacaraca", "BokicaK", "BadDog", - "Fitoschido" + "Fitoschido", + "Stalker" ] }, "tog-underline": "Подвлачење веза:", @@ -287,9 +288,9 @@ "youhavenewmessagesmulti": "Имате нове поруке на $1", "editsection": "уреди", "editold": "уреди", - "viewsourceold": "изворни код", + "viewsourceold": "изворник", "editlink": "уреди", - "viewsourcelink": "изворни код", + "viewsourcelink": "изворник", "editsectionhint": "Уредите одељак „$1“", "toc": "Садржај", "showtoc": "прикажи", @@ -375,13 +376,13 @@ "perfcached": "Следећи подаци су кеширани и можда нису ажурирани. У кешу {{PLURAL:$1|је доступан највише један резултат|су доступна највише $1 резултата|је доступно највише $1 резултата}}.", "perfcachedts": "Следећи подаци су кеширани и последњи пут ажурирани на датум $2 у $3 ч. У кешу {{PLURAL:$4|је доступан највише један резултат|су доступна највише $4 резултата|је доступно највише $4 резултата}}.", "querypage-no-updates": "Ажурирање ове странице је тренутно онемогућено.\nПодаци који се овде налазе могу бити застарели.", - "viewsource": "Изворни код", - "viewsource-title": "Изворни код за страницу $1", + "viewsource": "Изворник", + "viewsource-title": "Изворник странице $1", "actionthrottled": "Радња је успорена", "actionthrottledtext": "У циљу борбе против непожељних порука, ограничене су вам измене у одређеном времену, а управо сте прешли то ограничење. Покушајте поново за неколико минута.", "protectedpagetext": "Ова страница је закључана за измене и друге радње.", "viewsourcetext": "Можете да читате и копирате изворник ове странице.", - "viewyourtext": "Можете да погледате и копирате изворни код Ваших измена на овој страници.", + "viewyourtext": "Можете да погледате и копирате изворник Ваших измена на овој страници.", "protectedinterface": "Ова страница садржи текст интерфејса за софтвер на овом викију и заштићена је ради спречавања злоупотребе.\nДа бисте додали или изменили преводе било којег викија, посетите [https://translatewiki.net/ translatewiki.net], пројекат за локализацију Медијавикија.", "editinginterface": "Упозорење: уређујете страницу која се користи за приказивање текста корисничког окружења.\nИзмене на овој страници ће утицати на све кориснике овог викија.", "translateinterface": "Да додате или промените преводе за све викије, посетите [https://translatewiki.net/ Транслејтвики], пројекат за локализацију Медијавикија.", @@ -550,7 +551,7 @@ "botpasswords-label-resetpassword": "Ресетуј лозинку", "botpasswords-label-grants": "Применљиве дозволе:", "botpasswords-label-grants-column": "Одобрено", - "botpasswords-bad-appid": "„$1” није валидан назив бота.", + "botpasswords-bad-appid": "Име бота „$1” није валидно.", "botpasswords-insert-failed": "Неуспешно додавање бота \"$1\". Да ли је већ додат?", "botpasswords-update-failed": "Није могуће ажурирати бота \"$1\". Да ли је обрисан?", "botpasswords-created-title": "Направљена лозинка бота", @@ -979,7 +980,7 @@ "powersearch-togglelabel": "Изабери:", "powersearch-toggleall": "Све", "powersearch-togglenone": "Ништа", - "powersearch-remember": "Запамти мој избор за будуће претраге", + "powersearch-remember": "Запамти избор за будуће претраге", "search-external": "Спољашња претрага", "searchdisabled": "Претрага је онемогућена.\nУ међувремену можете тражити преко Гугла.\nУпамтите да његови пописи овог викија могу бити застарели.", "search-error": "Дошло је до грешке приликом претраге: $1", @@ -1709,7 +1710,7 @@ "img-auth-accessdenied": "Приступ је одбијен", "img-auth-nopathinfo": "Недостаје PATH_INFO.\nВаш сервер није подешен да прослеђује овакве податке.\nМожда је заснован на CGI-ју који не подржава img_auth.\nПогледајте https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:Image_Authorization?uselang=sr-ec.", "img-auth-notindir": "Захтевана путања није у подешеној фасцикли за отпремање.", - "img-auth-badtitle": "Не могу да створим исправан наслов за „$1“.", + "img-auth-badtitle": "Не могу да направим ваљан наслов за „$1“.", "img-auth-nologinnWL": "Нисте пријављени и „$1” није на списку дозвољених.", "img-auth-nofile": "Датотека „$1“ не постоји.", "img-auth-isdir": "Покушавате да приступите фасцикли „$1“.\nДозвољен је само приступ датотекама.", @@ -2008,6 +2009,8 @@ "speciallogtitlelabel": "Циљ (наслов или {{ns:user}}:корисничко име):", "log": "Дневници", "logeventslist-submit": "Прикажи", + "logeventslist-patrol-log": "Дневник патролирања", + "logeventslist-tag-log": "Дневник ознака", "all-logs-page": "Сви јавни дневници", "alllogstext": "Скупни приказ свих доступних историја овог викија.\nМожете сузити приказ одабирући врсту историје, корисничког имена или тражене странице.", "logempty": "Нема пронађених уноса у дневнику.", @@ -2027,7 +2030,7 @@ "allinnamespace": "Све странице (именски простор $1)", "allpagessubmit": "Иди", "allpagesprefix": "Прикажи странице с префиксом:", - "allpagesbadtitle": "Наведени назив странице није исправан или садржи међујезички или међувики префикс.\nМожда садржи знакове који се не могу користити у насловима.", + "allpagesbadtitle": "Наведени назив странице није ваљан или садржи међујезички или међувики префикс.\nМожда садржи један или више знакова који се не могу користити у насловима.", "allpages-bad-ns": "{{SITENAME}} нема именски простор „$1“.", "allpages-hide-redirects": "Сакриј преусмерења", "cachedspecial-viewing-cached-ttl": "Гледате кеширану верзију ове странице, која може бити стара и до $1.", @@ -2095,7 +2098,7 @@ "trackingcategories-nodesc": "Опис није доступан.", "trackingcategories-disabled": "Категорија је онемогућена", "mailnologin": "Нема адресе за слање", - "mailnologintext": "Морате бити [[Special:UserLogin|пријављени]] и имати исправан имејл адресу у [[Special:Preferences|подешавањима]] да бисте слали имејлове другим корисницима.", + "mailnologintext": "Морате бити [[Special:UserLogin|пријављени]] и имати ваљану имејл адресу у [[Special:Preferences|подешавањима]] да бисте слали имејлове другим корисницима.", "emailuser": "Пошаљи имејл", "emailuser-title-target": "Слање имејла {{GENDER:$1|кориснику|корисници}}", "emailuser-title-notarget": "Слање имејла кориснику", @@ -2197,6 +2200,8 @@ "dellogpage": "Дневник брисања", "dellogpagetext": "Испод је списак последњих брисања.", "deletionlog": "дневник брисања", + "log-name-create": "Дневник прављења страница", + "log-description-create": "Испод је списак скорашњих прављења страница.", "logentry-create-create": "$1 је {{GENDER:$2|направио|направила}} страницу $3", "reverted": "Враћено на ранију измену", "deletecomment": "Разлог:", @@ -2219,7 +2224,7 @@ "cantrollback": "Не могу да вратим измену.\nПоследњи аутор је уједно и једини.", "alreadyrolled": "Враћање последње измене странице [[:$1]] од стране {{GENDER:$2|корисника|кориснице|корисника}} [[User:$2|$2]] ([[User talk:$2|разговор]]{{int:pipe-separator}}[[Special:Contributions/$2|{{int:contribslink}}]]) није успело; неко други је у међувремену изменио или вратио страницу.\n\nПоследњу измену је {{GENDER:$3|направио|направила|направио}} [[User:$3|$3]] ([[User talk:$3|разговор]]{{int:pipe-separator}}[[Special:Contributions/$3|{{int:contribslink}}]]).", "editcomment": "Опис измене: $1.", - "revertpage": "Враћене измене {{GENDER:$2|корисника|кориснице}} [[Special:Contribs/$2|$2]] ([[User talk:$2|разговор]]) на последњу измену {{GENDER:$1|корисника|кориснице}} [[User:$1|$1]]", + "revertpage": "Враћене измене {{GENDER:$2|корисника|кориснице}} [[Special:Contributions/$2|$2]] ([[User talk:$2|разговор]]) на последњу измену {{GENDER:$1|корисника|кориснице}} [[User:$1|$1]]", "revertpage-nouser": "Измене скривеног корисника су враћене на последњу измену {{GENDER:$1|корисника|кориснице}} [[User:$1|$1]]", "rollback-success": "Измене {{GENDER:$1|корисника|кориснице}} {{GENDER:$3|$1}} су враћене на последњу измену {{GENDER:$2|корисника|кориснице}} {{GENDER:$4|$2}}.", "rollback-success-notify": "Враћене измене корисника $1;\nвраћено на последњу измену корисника $2. [$3 Прикажи измене]", @@ -2356,6 +2361,7 @@ "uctop": "(тренутна)", "month": "од месеца (и раније):", "year": "од године (и раније):", + "date": "Од датума (и раније):", "sp-contributions-newbies": "Прикажи само доприносе нових корисника", "sp-contributions-newbies-sub": "За нове кориснике", "sp-contributions-newbies-title": "Доприноси нових корисника", @@ -2377,7 +2383,7 @@ "whatlinkshere": "Шта води овде", "whatlinkshere-title": "Странице које су повезане са „$1”", "whatlinkshere-page": "Страница:", - "linkshere": "Следеће странице имају везу до $1:", + "linkshere": "Следеће странице имају везу до $2:", "nolinkshere": "Ниједна страница није повезана са: $2.", "nolinkshere-ns": "Ниједна страница не води до '''$2''' у изабраном именском простору.", "isredirect": "преусмерење", @@ -2523,7 +2529,7 @@ "databaselocked": "База података је већ закључана.", "databasenotlocked": "База није закључана.", "lockedbyandtime": "(од $1 дана $2 у $3)", - "move-page": "Премештање „$1“", + "move-page": "Премештање „$1”", "move-page-legend": "Премештање странице", "movepagetext": "Доњи образац ће преименовати страницу, премештајући целу историју на ново име.\nСтари наслов постаће преусмерење на нови.\nМожете ажурирати преусмерења која воде до изворног наслова;\nпогледајте [[Special:DoubleRedirects|двострука]] или [[Special:BrokenRedirects|покварена]] преусмерења.\nНа вама је одговорност да везе и даље иду тамо где треба.\n\nСтраница неће бити премештена ако већ постоји страница с тим именом (осим ако је празна, садржи преусмерење или нема историју измена).\nТо значи да можете вратити страницу на претходно име ако погрешите, али не можете ''преписати'' постојећу.\n\nНапомена:\nОво може представљати драстичну и неочекивану измену за популарну страницу;\nдобро размислите о последицама пре него што наставите.", "movepagetext-noredirectfixer": "Доњи образац ће преименовати страницу, премештајући целу историју на ново име.\nСтари наслов постаће преусмерење на нови.\nПогледајте [[Special:DoubleRedirects|двострука]] или [[Special:BrokenRedirects|покварена]] преусмерења.\nНа вама је одговорност да везе и даље иду тамо где треба.\n\nСтраница неће бити премештена ако већ постоји страница с тим именом (осим ако је празна, садржи преусмерење или нема историју измена).\nТо значи да можете вратити страницу на претходно име ако погрешите, али не можете ''преписати'' постојећу.\n\nНапомена:\nОво може представљати драстичну и неочекивану измену за популарну страницу;\nдобро размислите о последицама пре него што наставите.", @@ -2696,7 +2702,7 @@ "tooltip-ca-talk": "Разговор о страници са садржајем", "tooltip-ca-edit": "Уредите ову страницу", "tooltip-ca-addsection": "Започните нови одељак", - "tooltip-ca-viewsource": "Ова страница је закључана. \nМожете да погледате њен изворни код", + "tooltip-ca-viewsource": "Ова страница је закључана. \nМожете да погледате њен изворник", "tooltip-ca-history": "Претходне измене ове странице", "tooltip-ca-protect": "Заштитите ову страницу", "tooltip-ca-unprotect": "Промени заштиту ове странице", @@ -2849,8 +2855,6 @@ "markedaspatrollederrornotify": "Означавање ове измене патролираном није успело.", "patrol-log-page": "Дневник патролирања", "patrol-log-header": "Ово је дневник патролираних измена.", - "log-show-hide-patrol": "$1 дневник патролирања", - "log-show-hide-tag": "$1 дневник ознака", "confirm-markpatrolled-button": "У реду", "confirm-markpatrolled-top": "Означити измену $3 странице $2 патролираном?", "deletedrevision": "Обрисана стара измена $1.", @@ -3087,7 +3091,7 @@ "exif-keywords": "Кључне речи", "exif-worldregioncreated": "Област света где је сликана фотографија", "exif-countrycreated": "Земља где је сликана фотографија", - "exif-countrycodecreated": "Кôд земље где је слика направљена", + "exif-countrycodecreated": "Код земље где је слика направљена", "exif-provinceorstatecreated": "Покрајина или држава где је сликана фотографија", "exif-citycreated": "Град где је сликана фотографија", "exif-sublocationcreated": "Област града где је сликана фотографија", @@ -3865,6 +3869,7 @@ "log-description-pagelang": "Ово је дневник измена у језицима страница.", "logentry-pagelang-pagelang": "$1 је {{GENDER:$2|променио|променила}} језик странице $3 из $4 у $5.", "default-skin-not-found-row-enabled": "* $1 / $2 (омогућена)", + "default-skin-not-found-row-disabled": "* $1 / $2 (онемогућена)", "mediastatistics": "Статистика датотека", "mediastatistics-summary": "Статистике о типовима послатих датотека. Овде су урачунате само најновије верзије датотека. Старе или обрисане верзије нису урачунате.", "mediastatistics-nbytes": "{{PLURAL:$1|$1 бајт|$1 бајта|$1 бајтова}} ($2; $3%)", @@ -3897,7 +3902,7 @@ "headline-anchor-title": "Веза до овог одељка", "special-characters-group-latin": "Латиница", "special-characters-group-latinextended": "Проширена латиница", - "special-characters-group-ipa": "ИПА", + "special-characters-group-ipa": "МФА", "special-characters-group-symbols": "Симболи", "special-characters-group-greek": "Грчки", "special-characters-group-greekextended": "Проширени грчки", @@ -3968,6 +3973,7 @@ "log-action-filter-newusers-create": "отворио анониман корисник", "log-action-filter-newusers-create2": "отворио регистрован корисник", "log-action-filter-newusers-autocreate": "аутоматски отворен", + "log-action-filter-newusers-byemail": "отварање лозинком посланом на имејлу", "log-action-filter-patrol-patrol": "ручно", "log-action-filter-patrol-autopatrol": "аутоматско", "log-action-filter-protect-protect": "закључавање", @@ -4066,5 +4072,13 @@ "undelete-cantcreate": "Не можете повратити ову страницу јер нема постојеће странице са овим именом и немате дозволу да направите ову страницу.", "pagedata-title": "Подаци странице", "pagedata-not-acceptable": "Није пронађен одговарајући облик. Подржане MIME-врсте: $1", - "pagedata-bad-title": "Невалидан наслов: $1." + "pagedata-bad-title": "Невалидан наслов: $1.", + "passwordpolicies": "Правила за лозинке", + "passwordpolicies-group": "Група", + "passwordpolicies-policies": "Правила", + "passwordpolicies-policy-minimalpasswordlength": "Лозинка мора да има најмање {{PLURAL:$1|један знак|$1 знака|$1 знакова}}", + "passwordpolicies-policy-passwordcannotmatchusername": "Лозинка не може да буде иста као корисничко име", + "passwordpolicies-policy-passwordcannotmatchblacklist": "Лозинка се не може подударати са лозинкама на црној листи", + "passwordpolicies-policy-maximalpasswordlength": "Лозинка мора да буде краћа од $1 {{PLURAL:$1|знака|знакова}}", + "passwordpolicies-policy-passwordcannotbepopular": "Лозинка не може да буде {{PLURAL:$1|популарна лозинка|на списку $1 популарних лозинки}}" } diff --git a/languages/i18n/sr-el.json b/languages/i18n/sr-el.json index 9c5ef9b737..7d879a1e2f 100644 --- a/languages/i18n/sr-el.json +++ b/languages/i18n/sr-el.json @@ -2518,7 +2518,7 @@ "databaselocked": "Baza podataka je već zaključana.", "databasenotlocked": "Baza nije zaključana.", "lockedbyandtime": "(od $1 dana $2 u $3)", - "move-page": "Premeštanje „$1“", + "move-page": "Premeštanje „$1”", "move-page-legend": "Premeštanje stranice", "movepagetext": "Donji obrazac će preimenovati stranicu, premeštajući celu istoriju na novo ime.\nStari naslov postaće preusmerenje na novi.\nMožete ažurirati preusmerenja koja vode do izvornog naslova;\npogledajte [[Special:DoubleRedirects|dvostruka]] ili [[Special:BrokenRedirects|pokvarena]] preusmerenja.\nNa vama je odgovornost da veze i dalje idu tamo gde treba.\n\nStranica neće biti premeštena ako već postoji stranica s tim imenom (osim ako je prazna, sadrži preusmerenje ili nema istoriju izmena).\nTo znači da možete vratiti stranicu na prethodno ime ako pogrešite, ali ne možete ''prepisati'' postojeću.\n\nNapomena:\nOvo može predstavljati drastičnu i neočekivanu izmenu za popularnu stranicu;\ndobro razmislite o posledicama pre nego što nastavite.", "movepagetext-noredirectfixer": "Donji obrazac će preimenovati stranicu, premeštajući celu istoriju na novo ime.\nStari naslov postaće preusmerenje na novi.\nPogledajte [[Special:DoubleRedirects|dvostruka]] ili [[Special:BrokenRedirects|pokvarena]] preusmerenja.\nNa vama je odgovornost da veze i dalje idu tamo gde treba.\n\nStranica neće biti premeštena ako već postoji stranica s tim imenom (osim ako je prazna, sadrži preusmerenje ili nema istoriju izmena).\nTo znači da možete vratiti stranicu na prethodno ime ako pogrešite, ali ne možete ''prepisati'' postojeću.\n\nNapomena:\nOvo može predstavljati drastičnu i neočekivanu izmenu za popularnu stranicu;\ndobro razmislite o posledicama pre nego što nastavite.", @@ -2844,8 +2844,6 @@ "markedaspatrollederrornotify": "Označavanje ove izmene patroliranom nije uspelo.", "patrol-log-page": "Dnevnik patroliranja", "patrol-log-header": "Ovo je dnevnik patroliranih izmena.", - "log-show-hide-patrol": "$1 dnevnik patroliranja", - "log-show-hide-tag": "$1 dnevnik oznaka", "confirm-markpatrolled-button": "U redu", "confirm-markpatrolled-top": "Označiti izmenu $3 stranice $2 patroliranom?", "deletedrevision": "Obrisana stara izmena $1.", diff --git a/languages/i18n/stq.json b/languages/i18n/stq.json index 682a1b6c66..83390c7875 100644 --- a/languages/i18n/stq.json +++ b/languages/i18n/stq.json @@ -1830,7 +1830,6 @@ "markedaspatrollederror-noautopatrol": "Et is nit ferlööwed, oaine Beoarbaidengen as kontrollierd tou markierjen.", "patrol-log-page": "Kontrol-Logbouk", "patrol-log-header": "Dit is dät Kontroll-Logbouk.", - "log-show-hide-patrol": "Kontroll-Logbouk $1", "deletedrevision": "Oolde Version $1 läsked", "filedeleteerror-short": "Failer bie dät Doatäi-Läskjen: $1", "filedeleteerror-long": "Bie dät Doatäi-Läskjen wuuden Failere fääststoald:\n\n$1", diff --git a/languages/i18n/su.json b/languages/i18n/su.json index f4f0840a0a..bcf7bc5e7d 100644 --- a/languages/i18n/su.json +++ b/languages/i18n/su.json @@ -2606,8 +2606,6 @@ "markedaspatrollederrornotify": "Nandaan minangka kaawas gagal.", "patrol-log-page": "Log patroli", "patrol-log-header": "Ieu minangka log pikeun révisi nu geus diroris.", - "log-show-hide-patrol": "$1 log rorisan", - "log-show-hide-tag": "log tag $1", "confirm-markpatrolled-button": "Heug", "confirm-markpatrolled-top": "Tandaan révisi $3 ti $2 minangka kaawas?", "deletedrevision": "Révisi heubeul nu dihapus $1", diff --git a/languages/i18n/sv.json b/languages/i18n/sv.json index 9185b78960..57b789a8d6 100644 --- a/languages/i18n/sv.json +++ b/languages/i18n/sv.json @@ -982,6 +982,8 @@ "diff-paragraph-moved-toold": "Avsnittet flyttades. Klicka för att hoppa till den gamla platsen.", "difference-missing-revision": "Det gick inte att hitta {{PLURAL:$2|en version|$2 versioner}} av den här differensen ($1).\n\nDetta beror oftast på att du har försökt följa en utgången difflänk till en sida som har raderats.\nMer detaljerad information finns i [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} raderingsloggen].", "searchresults": "Sökresultat", + "search-filter-title-prefix": "Sök endast på sidor vars titel börjar med \"$1\"", + "search-filter-title-prefix-reset": "Sök på alla sidor", "searchresults-title": "Sökresultat för \"$1\"", "titlematches": "Träffar i sidtitlar", "textmatches": "Artikeltexter som matchar sökningen", @@ -2081,7 +2083,7 @@ "speciallogtitlelabel": "Mål (titel eller {{ns:user}}:användarnamn för användare):", "log": "Loggar", "logeventslist-submit": "Visa", - "logeventslist-more-filters": "Fler filter:", + "logeventslist-more-filters": "Visa ytterligare loggar:", "logeventslist-patrol-log": "Patrulleringslogg", "logeventslist-tag-log": "Märkeslogg", "all-logs-page": "Alla offentliga loggar", @@ -2939,8 +2941,6 @@ "markedaspatrollederrornotify": "Markering som patrullerad misslyckades.", "patrol-log-page": "Patrulleringslogg", "patrol-log-header": "Detta är en logg över patrullerade sidversioner.", - "log-show-hide-patrol": "$1 patrulleringslogg", - "log-show-hide-tag": "$1 märkeslogg", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Markera sidversionen $3 av $2 som patrullerad?", "deletedrevision": "Raderade gammal sidversion $1", diff --git a/languages/i18n/sw.json b/languages/i18n/sw.json index 38f8e66272..083df6b4ba 100644 --- a/languages/i18n/sw.json +++ b/languages/i18n/sw.json @@ -19,7 +19,8 @@ "Kwisha", "Macofe", "Muddyb", - "Fitoschido" + "Fitoschido", + "Rance" ] }, "tog-underline": "Wekea mstari viungo:", @@ -783,6 +784,8 @@ "editundo": "tengua", "diff-empty": "(Hakuna tofauti)", "searchresults": "Matokeo ya utafutaji", + "search-filter-title-prefix": "Kutafuta katika kurasa zenye kichwa kianzacho na \"$1\" pekee", + "search-filter-title-prefix-reset": "Tafuta kurasa zote", "searchresults-title": "Matokeo ya utafutaji kwa ajili ya \"$1\"", "titlematches": "Kurasa zinazo majina yenye maneno ya ulizo", "textmatches": "Kurasa zinazo maandishi yenye maneno ya ulizo", @@ -1491,6 +1494,7 @@ "specialloguserlabel": "Mtendaji:", "speciallogtitlelabel": "Kusudio (jina la ukurasa au mtumiaji):", "log": "Kumbukumbu", + "logeventslist-more-filters": "Onyesha taarifa za ziada", "all-logs-page": "Kumbukumbu zote zilizo wazi", "alllogstext": "Hapa panaonyeshwa kumbukumbu zote za {{SITENAME}} kwa pamoja.\nUnaweza kuona baadhi yao tu kwa kuchagua aina fulani ya kumbukumbu, jina la mtumiaji fulani (zingatia herufi kubwa na ndogo), au jina la ukurasa fulani (zingatia herufi kubwa na ndogo).", "logempty": "Vitu vyenye vipengele hivi havipo kwenye kumbukumbu.", diff --git a/languages/i18n/szl.json b/languages/i18n/szl.json index d48650df50..2b449682c1 100644 --- a/languages/i18n/szl.json +++ b/languages/i18n/szl.json @@ -1743,7 +1743,6 @@ "markedaspatrollederror-noautopatrol": "Ńy moš uprawńyń wymaganych do uoznačańo swojich sprawjyń kej „sprawdzůne”.", "patrol-log-page": "Dźynńik patrolowańo", "patrol-log-header": "Půniżej je dźeńńik patrolowańo zajtůw.", - "log-show-hide-patrol": "$1 rejer sprawdzańo", "deletedrevision": "Wyćepano popředńy wersyje $1", "filedeleteerror-short": "Feler při wyćepywańu plika $1", "filedeleteerror-long": "Wystůmpiuy felery při wyćepywańu pliku:\n\n$1", diff --git a/languages/i18n/ta.json b/languages/i18n/ta.json index ea4f828fa8..f92970ebe8 100644 --- a/languages/i18n/ta.json +++ b/languages/i18n/ta.json @@ -2538,8 +2538,6 @@ "markedaspatrollederrornotify": "சுற்றுக்காவல் தோல்வியடைந்ததாக குறிக்கப்பட்டது.", "patrol-log-page": "சுற்றுக்காவல் பதிகை", "patrol-log-header": "இது ரோந்து செய்யப்பட்ட பரிசீலனைகளுக்கான குறிப்பேடு.", - "log-show-hide-patrol": "$1 ரோந்து குறிப்பேடு", - "log-show-hide-tag": "$1 அடையாள பதிவு", "confirm-markpatrolled-button": "சரி", "deletedrevision": "பழைய திருத்தம் $1 நீக்கப்பட்டது", "filedeleteerror-short": "பின்வரும் கோப்பை நீக்குவதில் தவறு: $1", diff --git a/languages/i18n/tay.json b/languages/i18n/tay.json index c5ecd77a6f..6bfb7e73cc 100644 --- a/languages/i18n/tay.json +++ b/languages/i18n/tay.json @@ -1199,8 +1199,6 @@ "markaspatrolleddiff": "Sinbbaq sa wayal gawzyagan mita’", "markedaspatrolled": "Sinbbaq sa wayal gawzyagan mita’", "patrol-log-page": "Inblaq gmawzyaw mita’ binrwan", - "log-show-hide-patrol": "$1 inblaq gmawzyaw mita’ binrwan", - "log-show-hide-tag": "$1 bniru’ sa lalu’ na qinlah", "confirm-markpatrolled-button": "Wal balay", "previousdiff": "← Smural sinr’zyut miru’", "nextdiff": "Giqas hazi’ sinr’zyut→", diff --git a/languages/i18n/te.json b/languages/i18n/te.json index 9d131fdee1..754257720c 100644 --- a/languages/i18n/te.json +++ b/languages/i18n/te.json @@ -56,7 +56,7 @@ "tog-shownumberswatching": "వీక్షకుల సంఖ్యను చూపు", "tog-oldsig": "మీ ప్రస్తుత సంతకం:", "tog-fancysig": "సంతకాన్ని వికీపాఠ్యంగా తీసుకో (ఆటోమెటిక్‌ లింకు లేకుండా)", - "tog-uselivepreview": "తాజా మునుజూపును వాడు", + "tog-uselivepreview": "పేజీని మళ్ళీ లోడు చెయ్యకుండా మునుజూపులను చూపించు", "tog-forceeditsummary": "దిద్దుబాటు సారాంశం ఖాళీగా ఉంటే ఆ విషయాన్ని నాకు సూచించు", "tog-watchlisthideown": "నా మార్పులను వీక్షణా జాబితాలో చూపించొద్దు", "tog-watchlisthidebots": "బాట్లు చేసిన మార్పులను నా వీక్షణా జాబితాలో చూపించొద్దు", @@ -169,7 +169,7 @@ "mypage": "పుట", "mytalk": "చర్చ", "anontalk": "చర్చ", - "navigation": "మార్గదర్శకం", + "navigation": "మార్గసూచీ", "and": " మరియు", "faq": "తరచూ అడిగే ప్రశ్నలు", "actions": "పనులు", @@ -194,7 +194,7 @@ "print": "ముద్రించు", "view": "చూపు", "view-foreign": "$1 లో చూడండి", - "edit": "సవరించు", + "edit": "మార్చు", "edit-local": "స్థానిక వివరణని మార్చు", "create": "సృష్టించు", "create-local": "స్థానిక వివరణను చేర్చు", @@ -227,7 +227,7 @@ "lastmodifiedat": "ఈ పేజీలో చివరి మార్పు $1న $2కు జరిగింది.", "viewcount": "ఈ పేజీ {{PLURAL:$1|ఒక్క సారి|$1 సార్లు}} దర్శించబడింది.", "protectedpage": "సంరక్షణలోని పేజీ", - "jumpto": "ఇక్కడికి గెంతు:", + "jumpto": "ఇక్కడికి దూకు:", "jumptonavigation": "మార్గసూచీ", "jumptosearch": "వెతుకు", "view-pool-error": "క్షమించండి, ప్రస్తుతం సర్వర్లన్నీ ఓవర్‌లోడ్ అయిఉన్నాయి.\nచాలామంది వాడుకరులు ఈ పేజీని చూస్తున్నారు.\nఈ పేజీని వీక్షించడానికి కొద్దిసేపు నిరీక్షించండి.\n\n$1", @@ -466,7 +466,7 @@ "wrongpasswordempty": "ఖాళీ సంకేతపదం ఇచ్చారు. మళ్ళీ ప్రయత్నించండి.", "passwordtooshort": "సంకేతపదం కనీసం {{PLURAL:$1|1 అక్షరం|$1 అక్షరాల}} నిడివి ఉండాలి.", "passwordtoolong": "సంకేతపదం పొడవు {{PLURAL:$1|1 అక్షరం|$1 అక్షరాల}} కన్నా ఎక్కువ ఉండకూడదు.", - "passwordtoopopular": "మామూలుగా వాడే సంకేతపదాలను వాడే వీల్లేదు. మరింత విశిష్టమైన సంకేతపదాన్ని ఎంచుకోండి.", + "passwordtoopopular": "సాధారణంగా వాడే సంకేతపదాలను వాడే వీల్లేదు. ఊహించడానికి కష్టమైన సంకేతపదాన్ని ఎంచుకోండి.", "password-name-match": "మీ సంకేతపదం మీ వాడుకరిపేరుకి భిన్నంగా ఉండాలి.", "password-login-forbidden": "ఈ వాడుకరిపేరు మరియు సంకేతపదాలను ఉపయోగించడం నిషిద్ధం.", "mailmypassword": "సంకేతపదాన్ని మార్చు", @@ -544,13 +544,13 @@ "resetpass-submit-loggedin": "సంకేతపదాన్ని మార్చు", "resetpass-submit-cancel": "రద్దుచేయి", "resetpass-wrong-oldpass": "తప్పుడు తాత్కాలిక లేదా ప్రస్తుత సంకేతపదం.\nమీరు మీ సంకేతపదాన్ని ఇప్పటికే మార్చుకొని ఉండవచ్చు లేదా కొత్త తాత్కాలిక సంకేతపదం కోసం అభ్యర్థించి ఉండవచ్చు.", - "resetpass-recycled": "మీ ప్రస్తుత సంకేతపదాన్ని వేరే సంకేతపదంతో మార్చుకోండి", + "resetpass-recycled": "ప్రస్తుత సంకేతపదం కంటే భిన్నమైన దానితో సంకేతపదాన్ని మార్చుకోండి.", "resetpass-temp-emailed": "మీరు మీ ఈమెయిలుకు పంపించిన తాత్కాలిక కోడుతో లాగినయ్యారు. లాగిన్ను పూర్తి చేసేందుకు, ఇక్కడ మీరు తప్పనిసరిగా సంకేతపదం మార్చుకోవాలి:", "resetpass-temp-password": "తాత్కాలిక సంకేతపదం:", "resetpass-abort-generic": "ఓ పొడిగింత (ఎక్స్టెన్‍షన్) సంకేతపదం మార్పిడిని ఆపేసింది.", "resetpass-expired": "మీ సంకేతపదానికి కాలం చెల్లింది. కొత్త సంకేతపదం ఇచ్చి లాగినవండి.", - "resetpass-expired-soft": "మీ సంకేతపదానికి కాలం చెల్లింది, కాబట్టి కొత్తది ఇవ్వాలి. కొత్తది ఇప్పుడే ఇవ్వండి లేదా \"{{int:authprovider-resetpass-skip-label}}\" నొక్కి, తరువాత మార్చుకోండి.", - "resetpass-validity-soft": "మీ సంకేతపదానికి కాలం చెల్లింది:$1\nకొత్తది ఇప్పుడే ఎంచుకోండి, లేదా \"{{int:authprovider-resetpass-skip-label}}\" నొక్కి, తరువాత మార్చుకోండి.", + "resetpass-expired-soft": "మీ సంకేతపదానికి కాలం చెల్లింది, కాబట్టి దాన్ని మార్చాలి. కొత్తదాన్ని ఇప్పుడే ఎంచుకోండి లేదా \"{{int:authprovider-resetpass-skip-label}}\" నొక్కి, తరువాత మార్చుకోవచ్చు.", + "resetpass-validity-soft": "మీ సంకేతపదం సరైనది కాదు:$1\nకొత్తది ఇప్పుడే ఎంచుకోండి, లేదా \"{{int:authprovider-resetpass-skip-label}}\" నొక్కి, తరువాత మార్చుకోవచ్చు.", "passwordreset": "సంకేతపదాన్ని మార్చుకోండి", "passwordreset-text-one": "ఈమెయిలు ద్వారా తాత్కాలిక సంకేతపదాన్ని పొందేందుకు ఈ ఫారమును నింపండి.", "passwordreset-text-many": "{{PLURAL:$1|ఈమెయిలు ద్వారా తాత్కాలిక సంకేతపదాన్ని పొందేందుకు ఏదో ఒక ఫీల్డును నింపండి.}}", @@ -629,8 +629,9 @@ "subject-preview": "విషయపు మునుజూపు:", "previewerrortext": "మీ మార్పులు మునుజూపు చూపడంలో లోపం దొర్లింది.", "blockedtitle": "వాడుకరి నిరోధించబడ్డారు", - "blockedtext": "మీ వాడుకరి పేరు లేదా ఐ.పీ. చిరునామా నిరోధించబడింది.\n\nనిరోధించినది $1.\nఅందుకు ఇచ్చిన కారణం: $2.\n\n* నిరోధం మొదలైన సమయం: $8\n* నిరోధించిన కాలం: $6\n* నిరోధానికి గురైనవారు: $7\n\nఈ నిరోధంపై చర్చించేందుకు మీరు $1 ను గాని, మరెవరైనా [[{{MediaWiki:Grouppage-sysop}}|నిర్వాహకులను]] గాని సంప్రదించవచ్చు.\nమీ [[Special:Preferences|ఖాతా అభిరుచులలో]] సరైన ఈ-మెయిలు చిరునామా ఇచ్చివుండకపోయినా లేదా మిమ్మల్ని 'ఈ వాడుకరికి ఈ-మెయిలు పంపు' సౌలభ్యాన్ని వాడుకోవడం నుండి నిరోధించివున్నా మీరు ఈమెయిలు ద్వారా సంప్రదించలేరు.\nమీ ప్రస్తుత ఐ.పీ. చిరునామా $3, మరియు నిరోధపు ID #$5.\nమీ సంప్రదింపులన్నిటిలోనూ వీటిని పేర్కొనండి.", - "autoblockedtext": "మీ ఐపీ చిరునామా ఆటోమాటిగ్గా నిరోధించబడింది. ఎందుకంటే ఇదే ఐపీ చిరునామాని ఓ నిరోధిత వాడుకరి ఉపయోగించారు. ఆ వాడుకరిని $1 నిరోధించారు.\nఅందుకు ఇచ్చిన కారణం ఇదీ:\n\n:$2\n\n* నిరోధం మొదలైన సమయం: $8\n* నిరోధించిన కాలం: $6\n* ఉద్దేశించిన నిరోధిత వాడుకరి: $7\n\nఈ నిరోధం గురించి చర్చించేందుకు మీరు $1 ను గానీ, లేదా ఇతర [[{{MediaWiki:Grouppage-sysop}}|నిర్వాహకులను]] గానీ సంప్రదించండి.\n\nమీ [[Special:Preferences|అభిరుచులలో]] సరైన ఈమెయిలు ఐడీని ఇచ్చి ఉంటే తప్ప, మీరు \"ఈ సభ్యునికి మెయిలు పంపు\" అనే అంశాన్ని వాడజాలరని గమనించండి. ఆ సౌలభ్యాన్ని వాడటం నుండి మిమ్మల్ని నిరోధించలేదు.\n\nమీ ప్రస్తుత ఐపీ చిరునామా $3, మరియు నిరోధపు ఐడీ: $5.\nమీ సంప్రదింపులన్నిటిలోను అన్ని పై వివరాలను ఉదహరించండి.", + "blockedtext": "మీ వాడుకరిపేరును లేదా ఐ.పి. చిరునామాను నిరోధించారు.\n\nనిరోధించినవారు $1.\nఅందుకు వారు ఇచ్చిన కారణం: $2.\n\n* నిరోధం మొదలైన సమయం: $8\n* నిరోధించిన కాలం: $6\n* నిరోధానికి గురైనవారు: $7\n\nఈ నిరోధంపై చర్చించేందుకు మీరు $1 ను గాని, మరెవరైనా [[{{MediaWiki:Grouppage-sysop}}|నిర్వాహకుని]] గాని సంప్రదించవచ్చు.\nమీ [[Special:Preferences|ఖాతా అభిరుచులలో]] సరైన ఈ-మెయిలు చిరునామా ఇచ్చివుండకపోయినా లేదా మిమ్మల్ని 'ఈ వాడుకరికి ఈ-మెయిలు పంపు' సౌలభ్యాన్ని వాడుకోవడం నుండి నిరోధించివున్నా మీరు ఈమెయిలు ద్వారా సంప్రదించలేరు.\nమీ ప్రస్తుత ఐ.పీ. చిరునామా $3, మరియు నిరోధపు ID #$5.\nమీ సంప్రదింపులన్నిటిలోనూ పై వివరాలను పేర్కొనండి.", + "autoblockedtext": "మీ ఐపీ చిరునామా ఆటోమాటిగ్గా నిరోధించబడింది. ఎందుకంటే ఇదే ఐపీ చిరునామాని ఓ నిరోధిత వాడుకరి ఉపయోగించారు. ఆ వాడుకరిని $1 నిరోధించారు.\nఅందుకు ఇచ్చిన కారణం ఇదీ:\n\n:$2\n\n* నిరోధం మొదలైన సమయం: $8\n* నిరోధించిన కాలం: $6\n* ఉద్దేశించిన నిరోధిత వాడుకరి: $7\n\nఈ నిరోధం గురించి చర్చించేందుకు మీరు $1 ను గానీ, లేదా ఇతర [[{{MediaWiki:Grouppage-sysop}}|నిర్వాహకులను]] గానీ సంప్రదించండి.\n\nమీ [[Special:Preferences|అభిరుచులలో]] సరైన ఈమెయిలు ఐడీని ఇచ్చి ఉంటే తప్ప, మీరు \"ఈ వాడుకరికి ఈమెయిలు పంపు\" అనే అంశాన్ని వాడజాలరని గమనించండి. ఆ సౌలభ్యాన్ని వాడటం నుండి మిమ్మల్ని నిరోధించలేదు.\n\nమీ ప్రస్తుత ఐపీ చిరునామా $3, మరియు నిరోధపు ఐడీ: $5.\nమీ సంప్రదింపులన్నిటిలోను అన్ని పై వివరాలను ఉదహరించండి.", + "systemblockedtext": "మీడియావికీ మీ వాడుకరిపేరు లేదా ఐపీ అడ్రసును ఆటోమాటిగ్గా నిరోధించింది.\nఅందుకు ఇచ్చిన కారణం:\n\n:$2\n\n* నిరోధం మొదలైన సమయం: $8\n* నిరోధం ముగిసే సమయం: $6\n* నిరోధానికి గురైనవారు: $7\n\nమీ ప్రస్తుత ఐపీ అడ్రసు $3.\nమీ సంప్రదింపులన్నిటిలోనూ పై వివరాలను పేర్కొనండి.", "blockednoreason": "కారణమేమీ ఇవ్వలేదు", "whitelistedittext": "పుటలలో మార్పులు చెయ్యడానికి $1.", "confirmedittext": "పేజీల్లో మార్పులు చేసేముందు మీ ఈమెయిలు చిరునామాను ధృవీకరించాలి. [[Special:Preferences|మీ అభిరుచుల]]లో మీ ఈమెయిలు చిరునామా రాసి, ధృవీకరించండి.", @@ -701,6 +702,7 @@ "permissionserrorstext-withaction": "ఈ క్రింది {{PLURAL:$1|కారణం|కారణాల}} వల్ల, $2 అనుమతి మీకు లేదు:", "recreate-moveddeleted-warn": "హెచ్చరిక: ఇంతకు మునుపు ఒకసారి తొలగించిన పేజీని మళ్లీ సృష్టిద్దామని మీరు ప్రయత్నిస్తున్నారు.\n\nఈ పేజీపై మార్పులు చేసేముందు, అవి ఇక్కడ ఉండతగినవేనా కాదా అని ఒకసారి ఆలోచించండి.\nమీ సౌలభ్యం కొరకు ఈ పేజీ యొక్క తొలగింపు మరియు తరలింపు చిట్టా ఇక్కడ ఇచ్చాము:", "moveddeleted-notice": "ఈ పేజీని తొలగించారు.\nఈ పేజీ యొక్క తొలగింపు, సంరక్షణ, తరలింపు చిట్టాను క్రింద ఇచ్చాం.", + "moveddeleted-notice-recent": "సారీ, ఈ పేజీని ఈమధ్యే తొలగించారు (గత 24 గంటల్లో).\nఈ పేజీకి సంబంధించిన తొలగింపు, సంరక్షణ, తరలింపు లాగ్‌లను కింద ఇచ్చాం.", "log-fulllog": "పూర్తి చిట్టాని చూడండి", "edit-hook-aborted": "కొక్కెం ఈ మార్పుని విచ్ఛిన్నం చేసింది.\nఅది ఎటువంటి వివరణా ఇవ్వలేదు.", "edit-gone-missing": "పేజీని తాజాకరించలేకపోయాం.\nదాన్ని తొలగించినట్టున్నారు.", @@ -724,6 +726,8 @@ "content-model-css": "CSS", "content-json-empty-object": "ఖాళీ అంశం", "content-json-empty-array": "ఖాళీ అరే", + "duplicate-args-warning": "హెచ్చరిక: [[:$1]], \"$3\" పరామితికి ఒకటి కంటే ఎక్కువ విలువలు ఇచ్చి [[:$2]] ను పిలుస్తోంది. చిట్టచివరిగా ఇచ్చిన విలువను మాత్రమే వాడుతాం.", + "duplicate-args-category-desc": "ఈ పేజీ డూప్లికేట్ ఆర్గ్యుమెంట్లను ఇచ్చి మూసలను పిలుస్తోంది, ఇలా: {{foo|bar=1|bar=2}} లేదా ఇలా: {{foo|bar|1=baz}}.", "expensive-parserfunction-warning": "హెచ్చరిక: ఈ పేజీలో ఖరీదైన పార్సరు పిలుపులు చాలా ఉన్నాయి.\n\nపార్సరు {{PLURAL:$2|పిలుపు|పిలుపులు}} $2 కంటే తక్కువ ఉండాలి, ప్రస్తుతం {{PLURAL:$1|$1 పిలుపు ఉంది|$1 పిలుపులు ఉన్నాయి}}.", "expensive-parserfunction-category": "పార్సరు సందేశాలు అధికంగా ఉన్న పేజీలు", "post-expand-template-inclusion-warning": "హెచ్చరిక: మూస ఇముడ్పు సైజు చాలా పెద్దదిగా ఉంది.\nకొన్ని మూసలు ఇమడ్చబడవు.", @@ -824,7 +828,7 @@ "revdelete-submit": "ఎంచుకున్న {{PLURAL:$1|కూర్పుకు|కూర్పులకు}} ఆపాదించు", "revdelete-success": "కూర్పు కనబడే విధానాన్ని జయప్రదంగా తాజాకరించాం.", "revdelete-failure": "కూర్పు కనబడే పద్ధతిని తాజాపరచలేకపోయాం:\n$1", - "logdelete-success": "ఘటన కనబడే విధానాన్ని జయప్రదంగా అమర్చాం.", + "logdelete-success": "లాగ్ కనబడే విధానాన్ని సెట్ చేసాం.", "logdelete-failure": "'''చిట్టా కనబడే పద్ధతిని అమర్చలేకపోయాం:'''\n$1", "revdel-restore": "దృశ్యతని మార్చు", "pagehist": "పేజీ చరిత్ర", @@ -973,7 +977,7 @@ "stub-threshold-disabled": "అచేతనం", "recentchangesdays": "ఇటీవలి మార్పులు లో చూపించవలసిన రోజులు:", "recentchangesdays-max": "గరిష్ఠంగా $1 {{PLURAL:$1|రోజు|రోజులు}}", - "recentchangescount": "అప్రమేయంగా చూపించాల్సిన దిద్దుబాట్ల సంఖ్య:", + "recentchangescount": "ఇటీవలి మార్పులలో, పేజీ చరిత్రలలో, చిట్టాలలో అప్రమేయంగా చూపించాల్సిన దిద్దుబాట్ల సంఖ్య:", "prefs-help-recentchangescount": "గరిష్ఠ సంఖ్య: 1000", "prefs-help-watchlist-token2": "మీ వీక్షణజాబితా యొక్క జాలవడ్డింపుకు చెందిన రహస్య తాళమిది.\nఈ తాళం తెలిసిన ఎవరైనా మీ వీక్షణజాబితాను చదవగలుగుతారు. అందుచేత దీన్ని ఎవరికీ ఇవ్వకండి.\nఅవసరమైతే [[Special:ResetTokens|దాన్ని మార్చుకోవచ్చు]].", "savedprefs": "మీ అభిరుచులను భద్రపరిచాం.", @@ -1128,8 +1132,8 @@ "right-viewsuppressed": "ఏ వాడుకరి నుండైనా వీక్షణ సంస్కరణలు దాయబడ్డాయి", "right-suppressionlog": "గోప్యంగా ఉన్న లాగ్‌లను చూడడం", "right-block": "దిద్దుబాటు చెయ్యకుండా ఇతర వాడుకరులను నిరోధించగలగడం", - "right-blockemail": "ఈమెయిలు పంపకుండా సభ్యుని నిరోధించు", - "right-hideuser": "ప్రజలకు కనబడకుండా చేసి, సభ్యనామాన్ని నిరోధించు", + "right-blockemail": "ఈమెయిలు పంపకుండా వాడుకరిని నిరోధించు", + "right-hideuser": "బయటికి కనబడకుండా చేసి, వాడుకరిపేరును నిరోధించు", "right-ipblock-exempt": "ఐపీ నిరోధాలు, ఆటో నిరోధాలు, శ్రేణి నిరోధాలను తప్పించు", "right-unblockself": "స్వీయ అనిరోధం", "right-protect": "సంరక్షణ స్థాయిలను మార్చు, కాస్కేడ్-రక్షిత పేజీలలో దిద్దుబాటు చెయ్యి", @@ -1410,7 +1414,7 @@ "minoreditletter": "చి", "newpageletter": "కొ", "boteditletter": "బా", - "number_of_watching_users_pageview": "[వీక్షిస్తున్న సభ్యులు: {{PLURAL:$1|ఒక్కరు|$1}}]", + "number_of_watching_users_pageview": "[వీక్షిస్తున్న వాడుకరులు: {{PLURAL:$1|ఒక్కరు|$1}}]", "rc-change-size-new": "మార్పు తర్వాత $1 {{PLURAL:$1|బైటు|బైట్లు}}", "newsectionsummary": "/* $1 */ కొత్త విభాగం", "rc-enhanced-expand": "వివరాలను చూపించు", @@ -1820,7 +1824,7 @@ "unusedimagestext": "ఈ క్రింది ఫైళ్ళు ఉన్నాయి కానీ వాటిని ఏ పేజీలోనూ ఉపయోగించట్లేదు.\nఇతర వెబ్ సైట్లు సూటి URL ద్వారా ఇక్కడి ఫైళ్ళకు లింకు ఇవ్వవచ్చు, మరియు ఆవిధంగా క్రియాశీలంగా వాడుకలో ఉన్నప్పటికీ అటువంటివి ఈ జాబితాలో చేరి ఉండవచ్చునని గమనించండి.", "unusedcategoriestext": "కింది వర్గాలకు పేజీలైతే ఉన్నాయి గానీ, వీటిని వ్యాసాలు గానీ, ఇతర వర్గాలు గానీ ఉపయోగించడం లేదు.", "notargettitle": "గమ్యం లేదు", - "notargettext": "ఈ పని ఏ పేజీ లేదా సభ్యునిపై జరగాలనే గమ్యాన్ని మీరు సూచించలేదు.", + "notargettext": "ఈ పని ఏ పేజీ లేదా వాడుకరిపై జరగాలనే గమ్యాన్ని మీరు సూచించలేదు.", "nopagetitle": "అలాంటి పేజీ లేదు", "nopagetext": "మీరు అడిగిన పేజీ లేదు", "pager-newer-n": "{{PLURAL:$1|1 కొత్తది|$1 కొత్తవి}}", @@ -1904,6 +1908,8 @@ "activeusers-intro": "ఇది గత $1 {{PLURAL:$1|రోజులో|రోజులలో}} ఏదైనా కార్యకలాపం చేసిన వాడుకరుల జాబితా.", "activeusers-count": "గడచిన {{PLURAL:$3|ఒక రోజు|$3 రోజుల}}లో $1 {{PLURAL:$1|చర్య|చర్యలు}}", "activeusers-from": "వాడుకరులను ఇక్కడ నుండి చూపించు:", + "activeusers-groups": "ఈ గుంపులకు చెందిన వాడుకరులను చూపించు:", + "activeusers-excludegroups": "ఈ గుంపులకు చెందిన వాడుకరులను చూపించవద్దు:", "activeusers-noresult": "వాడుకరులెవరూ లేరు.", "activeusers-submit": "చేతనంగా ఉన్న వాడుకరులను చూపించు", "listgrouprights": "వాడుకరి గుంపుల హక్కులు", @@ -2037,6 +2043,8 @@ "dellogpage": "తొలగింపుల చిట్టా", "dellogpagetext": "ఇది ఇటీవలి తుడిచివేతల జాబితా.", "deletionlog": "తొలగింపుల చిట్టా", + "log-name-create": "పేజీల సృష్టి చిట్టా", + "log-description-create": "ఇటీవల సృష్టించిన కొత్త పేజీల జాబితా ఇది.", "logentry-create-create": "$3 పేజీని $1 {{GENDER:$2|సృష్టించారు}}", "reverted": "పాత కూర్పుకు తీసుకువెళ్ళాం.", "deletecomment": "కారణం:", @@ -2047,7 +2055,7 @@ "delete-toobig": "ఈ పేజీకి $1 {{PLURAL:$1|కూర్పుకు|కూర్పులకు}} మించిన, చాలా పెద్ద దిద్దుబాటు చరితం ఉంది. {{SITENAME}}కు అడ్డంకులు కలగడాన్ని నివారించేందుకు గాను, అలాంటి పెద్ద పేజీల తొలగింపును నియంత్రించాం.", "delete-warning-toobig": "ఈ పేజీకి $1 {{PLURAL:$1|కూర్పుకు|కూర్పులకు}} మించిన, చాలా పెద్ద దిద్దుబాటు చరితం ఉంది. దాన్ని తొలగిస్తే {{SITENAME}}కి చెందిన డేటాబేసు కార్యాలకు ఆటంకం కలగొచ్చు; అప్రమత్తతో ముందుకుసాగండి.", "deleteprotected": "ఈ పేజీ సంరక్షణలో ఉంది కనుక మీరు తొలగించలేరు.", - "deleting-backlinks-warning": "'''హెచ్చరిక:''' మీరు తొలగించబోతున్న పేజీకి [[Special:WhatLinksHere/{{FULLPAGENAME}}|ఇతర పేజీల]] నుండి లింకులు ఉన్నాయి లేదా ఇక్కడ నుండి ట్రాన్స్‍క్లూడు అవుతున్నాయి.", + "deleting-backlinks-warning": "హెచ్చరిక: మీరు తొలగించబోతున్న పేజీకి [[Special:WhatLinksHere/{{FULLPAGENAME}}|ఇతర పేజీల]] నుండి లింకులు ఉన్నాయి. లేదా ఇతర పేజీల్లో అది ట్రాన్స్‍క్లూడు అవుతోంది.", "rollback": "దిద్దుబాట్లను రద్దుచేయి", "rollbacklink": "రద్దుచేయి", "rollbacklinkcount": "$1 {{PLURAL:$1|మార్పును|మార్పులను}} రద్దుచేయి", @@ -2060,7 +2068,8 @@ "revertpage-nouser": "దాచబడిన వాడుకరి చేసిన మార్పులను [[User:$1|$1]] యొక్క చివరి కూర్పుకి తిప్పికొట్టారు", "rollback-success": "$1 చేసిన దిద్దుబాట్లను వెనక్కు తీసుకెళ్ళాం; తిరిగి $2 చేసిన చివరి కూర్పుకు మార్చాం.", "sessionfailure-title": "సెషను వైఫల్యం", - "sessionfailure": "మీ ప్రవేశపు సెషనుతో ఏదో సమస్య ఉన్నట్లుంది;\nసెషను హైజాకు కాకుండా ఈ చర్యను రద్దు చేసాం.\n\"back\" కొట్టి, ఎక్కడి నుండి వచ్చారో ఆ పేజీని మళ్ళీ లోడు చేసి, తిరిగి ప్రయత్నించండి.", + "sessionfailure": "మీ లాగిన్ సెషనుతో ఏదో సమస్య ఉన్నట్లుంది;\nసెషను హైజాకు కాకుండా ఈ చర్యను రద్దు చేసాం.\nఫారమును తిరిగి సమర్పించండి.", + "changecontentmodel": "పేజీ కంటెంటు మోడలును మార్చు", "changecontentmodel-legend": "కంటెంటు మోడల్‌ మార్పు", "changecontentmodel-title-label": "పేజీ శీర్షిక", "changecontentmodel-model-label": "కొత్త కంటెంటు మోడల్", @@ -2149,6 +2158,7 @@ "undeletehistorynoadmin": "ఈ పుటని తొలగించివున్నారు.\nతొలగింపునకు కారణం, తొలగింపునకు క్రితం ఈ పుటకి మార్పులు చేసిన వాడుకరుల వివరాలతో సహా, ఈ కింద సారాంశంలో చూపబడింది.\nతొలగించిన కూర్పులలోని వాస్తవ పాఠ్యం నిర్వాహకులకు మాత్రమే అందుబాటులో ఉంటుంది.", "undelete-revision": "$1 యొక్క తొలగించబడిన కూర్పు (చివరగా $4 నాడు, $5కి $3 మార్చారు):", "undeleterevision-missing": "తప్పుడు లేదా తప్పిపోయిన కూర్పు. మీరు నొక్కింది తప్పుడు లింకు కావచ్చు, లేదా భాండాగారం నుండి కూర్పు పునఃస్థాపించబడి లేదా తొలగించబడి ఉండవచ్చు.", + "undeleterevision-duplicate-revid": "{{PLURAL:$1|ఒక కూర్పు|$1 కూర్పుల}}ను పునస్థాపించలేకపోయాం. ఎందుకంటే {{PLURAL:$1|దాని|వాటి}} rev_id ఈసరికే వినియోగంలో ఉంది.", "undelete-nodiff": "గత కూర్పులేమీ లేవు.", "undeletebtn": "పునఃస్థాపించు", "undeletelink": "చూడండి/పునస్థాపించండి", @@ -2161,6 +2171,7 @@ "undelete-search-title": "తొలగించిన పేజీల అన్వేషణ", "undelete-search-box": "తొలగించిన పేజీలను వెతుకు", "undelete-search-prefix": "దీనితో మొదలయ్యే పేజీలు చూపించు:", + "undelete-search-full": "ఇవి ఉన్న పేజీ శీర్షికలను చూపించు:", "undelete-search-submit": "వెతుకు", "undelete-no-results": "తొలగింపు సంగ్రహాల్లో దీనిని పోలిన పేజీలు లేవు.", "undelete-filename-mismatch": "$1 టైమ్‌స్టాంపు కలిగిన ఫైలుకూర్పు తొలగింపును రద్దు చెయ్యలేకపోయాం: ఫైలుపేరు సరిపోలలేదు", @@ -2237,11 +2248,11 @@ "ipbcreateaccount": "ఖాతా సృష్టిని నివారించు", "ipbemailban": "వాడుకరిని ఈ-మెయిల్ చెయ్యకుండా నివారించు", "ipbenableautoblock": "ఈ వాడుకరి వాడిన చివరి ఐపీ అడ్రసును, అలాగే ఆ తరువాత వాడే అడ్రసులను కూడా ఆటోమాటిగ్గా నిరోధించు", - "ipbsubmit": "ఈ సభ్యుని నిరోధించు", + "ipbsubmit": "ఈ వాడుకరిని నిరోధించు", "ipbother": "వేరే గడువు", "ipboptions": "2 గంటలు:2 hours,ఒక రోజు:1 day,3 రోజులు:3 days,ఒక వారం:1 week,2 వారాలు:2 weeks,ఒక నెల:1 month,3 నెలలు:3 months,6 నెలలు:6 months,ఒక సంవత్సరం:1 year,ఎప్పటికీ:infinite", "ipbhidename": "మార్పులు మరియు జాబితాల నుండి ఈ వాడుకరిపేరుని దాచు", - "ipbwatchuser": "ఈ సభ్యుని సభ్యుని పేజీ, చర్చాపేజీలను వీక్షణలో ఉంచు", + "ipbwatchuser": "ఈ వాడుకరి వాడుకరి పేజీ, చర్చాపేజీలను వీక్షణలో ఉంచు", "ipb-disableusertalk": "నిరోధంలో ఉండగా ఈ వాడుకరి తన స్వంత చర్చ పేజీలో మార్పుచేర్పులు చెయ్యకుండా నిరోధించు", "ipb-change-block": "ఈ అమరికలతో వాడుకరిని పునర్నిరోధించు", "ipb-confirm": "నిరోధాన్ని ధృవపరచండి", @@ -2258,7 +2269,7 @@ "ipb-blocklist-contribs": "{{GENDER:$1|$1}} మార్పులు-చేర్పులు", "ipb-blocklist-duration-left": "ఇంకా $1 మిగిలి ఉంది.", "unblockip": "వాడుకరిపై నిరోధాన్ని తొలగించు", - "unblockiptext": "కింది ఫారం ఉపయోగించి, నిరోధించబడిన ఐ.పీ. చిరునామా లేదా సభ్యునికి తిరిగి రచనలు చేసే అధికారం ఇవ్వవచ్చు.", + "unblockiptext": "కింది ఫారం ఉపయోగించి, నిరోధించబడిన ఐ.పీ. చిరునామా లేదా వాడుకరికి తిరిగి రచనలు చేసే అధికారం ఇవ్వవచ్చు.", "ipusubmit": "ఈ నిరోధాన్ని తొలగించు", "unblocked": "[[User:$1|$1]]పై నిరోధం తొలగించబడింది", "unblocked-range": "$1 పై నిరోధాన్ని తీసేసాం", @@ -2289,7 +2300,7 @@ "emailblock": "ఈ-మెయిలుని నిరోధించాం", "blocklist-nousertalk": "తమ చర్చాపేజీని మార్చలేరు", "ipblocklist-empty": "నిరోధపు జాబితా ఖాళీగా ఉంది.", - "ipblocklist-no-results": "మీరడిగిన ఐపీ అడ్రసు లేదా సభ్యనామాన్ని నిరోధించలేదు.", + "ipblocklist-no-results": "మీరడిగిన ఐపీ అడ్రసు లేదా వాడుకరిపేరును నిరోధించలేదు.", "blocklink": "నిరోధించు", "unblocklink": "నిరోధాన్ని ఎత్తివేయి", "change-blocklink": "నిరోధాన్ని మార్చండి", @@ -2331,7 +2342,7 @@ "ipbnounblockself": "మిమ్మల్ని మీరే అనిరోధించుకునే అనుమతి మీకు లేదు", "lockdb": "డాటాబేసును లాక్‌ చెయ్యి", "unlockdb": "డాటాబేసుకి తాళంతియ్యి", - "lockdbtext": "డాటాబేసును లాక్‌ చెయ్యడం వలన సభ్యులు పేజీలు మార్చడం, అభిరుచులు మార్చడం, వీక్షణ జాబితాను మార్చడం వంటి డాటాబేసు ఆధారిత పనులు చెయ్యలేరు. మీరు చెయ్యదలచినది ఇదేనని, మీ పని కాగానే తిరిగి డాటాబేసును ప్రారంభిస్తాననీ ధృవీకరించండి.", + "lockdbtext": "డాటాబేసును లాక్‌ చెయ్యడం వలన వాడుకరులు పేజీలు మార్చడం, అభిరుచులు మార్చడం, వీక్షణ జాబితాను మార్చడం వంటి డాటాబేసు ఆధారిత పనులు చెయ్యలేరు. మీరు చెయ్యదలచినది ఇదేనని, మీ పని కాగానే తిరిగి డాటాబేసును ప్రారంభిస్తాననీ ధృవీకరించండి.", "unlockdbtext": "డేటాబేసుకు తాళం తీసేసిన తరువాత, వాడుకరులందరూ పేజీలను మార్చటం మొదలు పెట్టగలరు,\nతమ అభిరుచులను మార్చుకోగలరు, వీక్షణా జాబితాకు పేజీలను కలుపుకోగలరు తీసివేయనూగలరు,\nఅంతేకాక డేటాబేసులో మార్పులు చేయగలిగే ఇంకొన్ని పనులు కూడా చేయవచ్చు.\nమీరు చేయదలుచుకుంది ఇదేనాకాదా అని ఒకసారి నిర్ధారించండి.", "lockconfirm": "అవును, డేటాబేసును లాకు చెయ్యాలని నిజంగానే అనుకుంటున్నాను.", "unlockconfirm": "అవును, నేను నిజంగానే డాటాబేసుకి తాళం తియ్యాలనుకుంటున్నాను.", @@ -2388,7 +2399,7 @@ "delete_and_move_text": "గమ్యపు పేజీ \"[[:$1]]\" ఇప్పటికే ఉనికిలో ఉంది. \nప్రస్తుత తరలింపుకు వీలుగా దాన్ని తొలగించేయమంటారా?", "delete_and_move_confirm": "అవును, పేజీని తొలగించు", "delete_and_move_reason": "\"[[$1]]\"ను తరలించడానికి వీలుగా తొలగించారు", - "selfmove": "మూలం, గమ్యం పేర్లు ఒకటే; పేజీని దాని పైకే తరలించడం కుదరదు.", + "selfmove": " శీర్షిక ఒకటే;\nపేజీని దాని పైకే తరలించడం కుదరదు.", "immobile-source-namespace": "\"$1\" పేరుబరిలోని పేజీలను తరలించలేరు", "immobile-target-namespace": "\"$1\" పేరుబరిలోనికి పేజీలను తరలించలేరు", "immobile-target-namespace-iw": "పేజీని తరలించడానికి అంతర్వికీ లింకు సరైన లక్ష్యం కాదు.", @@ -2402,7 +2413,7 @@ "fix-double-redirects": "పాత పేజీని సూచిస్తున్న దారిమార్పులను తాజాకరించు", "move-leave-redirect": "పాత పేజీని దారిమార్పుగా ఉంచు", "protectedpagemovewarning": "'''హెచ్చరిక:''' ఈ పేజీని సంరక్షించారు కనుక నిర్వాహక హక్కులు కలిగిన వాడుకరులు మాత్రమే దీన్ని తరలించగలరు.\nమీ సమాచారం కోసం చివరి చిట్టా పద్దుని ఇక్కడ ఇస్తున్నాం:", - "semiprotectedpagemovewarning": "'''గమనిక:''' ఈ పేజీని సంరక్షించారు కనుక నమోదైన వాడుకరులు మాత్రమే దీన్ని తరలించగలరు.\nమీ సమాచారం కోసం చివరి చిట్టా పద్దుని ఇక్కడ ఇస్తున్నాం:", + "semiprotectedpagemovewarning": "గమనిక: ఈ పేజీని సంరక్షించారు కనుక ఆటోకన్ఫర్మ్‌డ్ వాడుకరులు మాత్రమే దీన్ని తరలించగలరు.\nమీ సమాచారం కోసం చివరి చిట్టా పద్దుని ఇక్కడ ఇస్తున్నాం:", "move-over-sharedrepo": "[[:$1]] సామూహిక నిక్షేపంలో ఉంది. ఈ పేరుకు మరొక ఫైలును తరలిస్తే అది ఆ సామూహిక ఫైలును ఓవర్‌రైడు చేస్తుంది.", "file-exists-sharedrepo": "ఎంచుకున్న ఫైలు పేరు ఇప్పటికే సామాన్య భాండాగారంలో వాడుకలో ఉంది.\nదయచేసి మరొక పేరుని ఎంచుకోండి.", "export": "పేజీల ఎగుమతి", @@ -2606,6 +2617,7 @@ "pageinfo-robot-index": "అనుమతించబడింది", "pageinfo-robot-noindex": "అనుమతించబడలేదు", "pageinfo-watchers": "పేజీ గమనింపుదారుల సంఖ్య", + "pageinfo-visiting-watchers": "ఈ పేజీలో ఇటీవల జరిగిన దిద్దుబాట్లను చూసిన వీక్షకుల సంఖ్య", "pageinfo-few-watchers": "$1 {{PLURAL:$1|వీక్షకుడి|వీక్షకుల}} కంటే తక్కువ", "pageinfo-redirects-name": "ఈ పేజీకి ఉన్న దారిమార్పుల సంఖ్య", "pageinfo-subpages-name": "ఈ పేజీకి ఉన్న ఉపపేజీల సంఖ్య", @@ -2631,7 +2643,7 @@ "pageinfo-protect-cascading-yes": "అవును", "pageinfo-protect-cascading-from": "సంరక్షణ ఇక్కడినుంచి వ్యాపిస్తుంది", "pageinfo-category-info": "వర్గపు సమాచారం", - "pageinfo-category-total": "మొత్తం సభ్యుల సంఖ్య", + "pageinfo-category-total": "మొత్తం వాడుకరుల సంఖ్య", "pageinfo-category-pages": "పేజీల సంఖ్య", "pageinfo-category-subcats": "ఉపవర్గాల సంఖ్య", "pageinfo-category-files": "దస్త్రాల సంఖ్య", @@ -2647,8 +2659,6 @@ "markedaspatrollednotify": "$1 లో చేసిన ఈ మార్పు పర్యవేక్షణలో ఉన్నట్టుగా గుర్తించబడింది.", "patrol-log-page": "నిఘా చిట్టా", "patrol-log-header": "ఇది పర్యవేక్షించిన కూర్పుల చిట్టా.", - "log-show-hide-patrol": "$1 పర్యవేక్షణ చిట్టా", - "log-show-hide-tag": "ట్యాగుల చిట్టాను $1", "confirm-markpatrolled-button": "సరే", "deletedrevision": "పాత సంచిక $1 తొలగించబడినది.", "filedeleteerror-short": "ఫైలు తొలగించడంలో పొరపాటు: $1", @@ -3257,7 +3267,9 @@ "tags-delete-explanation-initial": "మీరు \"$1\" ట్యాగును డేటాబేసు నుండి తొలగించబోతున్నారు.", "tags-delete-reason": "కారణం:", "tags-delete-not-found": "\"$1\" అనే ట్యాగు లేదు.", + "tags-activate-question": "\"$1\" ట్యాగును మీరు చేతనం చెయ్యబోతున్నారు.", "tags-activate-reason": "కారణం:", + "tags-activate-not-allowed": "\"$1\" ట్యాగును చేతనం చెయ్యడం కుదరలేదు.", "tags-activate-not-found": "\"$1\" అనే ట్యాగు లేదు.", "tags-activate-submit": "చేతనంచేయి", "tags-deactivate-title": "ట్యాగును అచేతనం చేయి", @@ -3266,10 +3278,18 @@ "tags-deactivate-not-allowed": "\"$1\" ట్యాగును అచేతనం చేయడం సాధ్యం కాదు.", "tags-deactivate-submit": "అచేతనం చేయి", "tags-apply-no-permission": "మీ మార్పులతో పాటు వాటికి ట్యాగులను ఆపాదించే అనుమతి మీకు లేదు.", + "tags-apply-blocked": "{{GENDER:$1|మీరు}} నిరోధంలో ఉండగా మీ మార్పులతో పాటు మార్పు ట్యాగులను అమలు చెయ్యడం కుదరదు.", "tags-apply-not-allowed-one": "\"$1\" ట్యాగును మానవీయంగా ఆపాదించలేరు.", - "tags-apply-not-allowed-multi": "ఈ {{PLURAL:$2|ట్యాగును|ట్యాగులను}} మానవీయంగా ఆపాదించడానికి అనుమతించరు:", + "tags-apply-not-allowed-multi": "ఈ {{PLURAL:$2|ట్యాగును|ట్యాగులను}} మానవీయంగా ఆపాదించడానికి అనుమతి లేదు:$1", + "tags-update-no-permission": "కూర్పులు లేదా చిట్టా లోని అంశాలకు మార్పు ట్యాగులను మార్చే, తీసేసే అనుమతి మీకు లేదు", + "tags-update-blocked": "{{GENDER:$1|మీరు}} నిరోధంలో ఉండగా మీ మార్పులతో పాటు మార్పు ట్యాగులను చేర్చడం, తీసెయ్యడం కుదరదు.", + "tags-update-add-not-allowed-one": "\"$1\" ట్యాగును మానవికంగా చేర్చే అనుమతి లేదు.", + "tags-update-add-not-allowed-multi": "కింది {{PLURAL:$2|ట్యాగును|ట్యాగులను}} మానవికంగా చేర్చే అనుమతి లేదు: $1", + "tags-update-remove-not-allowed-one": "\"$1\" ట్యాగును తీసేసే అనుమతి లేదు.", + "tags-update-remove-not-allowed-multi": "కింది {{PLURAL:$2|ట్యాగును|ట్యాగులను}} మానవికంగా తీసేసే అనుమతి లేదు: $1", "tags-edit-title": "ట్యాగులను సవరించు", "tags-edit-manage-link": "ట్యాగులను నిర్వహించండి", + "tags-edit-revision-selected": "[[:$2]] కు చెందిన {{PLURAL:$1|ఎంచుకున్న కూర్పు|ఎంచుకున్న కూర్పులు}}:", "tags-edit-existing-tags": "ప్రస్తుత ట్యాగులు:", "tags-edit-existing-tags-none": "ఏమీలేవు", "tags-edit-new-tags": "కొత్త ట్యాగులు:", @@ -3564,10 +3584,25 @@ "restrictionsfield-badip": "అసంబద్ధమైన ఐపీ అడ్రసు లేదా శ్రేణి: $1", "restrictionsfield-label": "అనుమతించబడ్డ ఐపీ శ్రేణులు:", "restrictionsfield-help": "వరుసకొక్క ఐపీ అడ్రసు లేదా CIDR శ్రేణి. ప్రతీ ఒక్కదాన్నీ చేతనం చేసేందుకు, వాడండి:
0.0.0.0/0\n::/0
", + "edit-error-short": "లోపం: $1", + "edit-error-long": "లోపాలు:\n\n$1", "revid": "కూర్పు $1", "pageid": "పేజీ ఐడీ $1", + "gotointerwiki": "{{SITENAME}} ను వీడిపోతున్నారు", + "gotointerwiki-invalid": "ఇచ్చిన శీర్షిక సరైనది కాదు.", + "gotointerwiki-external": "మీరు {{SITENAME}} ను వదలి [[$2]] కు వెళ్తున్నారు. అది వేరే సైటు.\n\n'''[$1 $1 కు తీసుకుపో]'''", + "undelete-cantedit": "ఈ పేజీ తొలగింపును రద్దు చెయ్యలేరు. ఎందుకంటే ఈ పేజీలో మార్పుచేర్పులు చేసే అనుమతి మీకు లేదు.", + "undelete-cantcreate": "ఈ పేజీ తొలగింపును రద్దు చెయ్యలేరు. ఎందుకంటే ఈ పేరుతో పేజీ లేదు, దాన్ని సృష్టించే అనుమతి మీకు లేదు.", + "pagedata-title": "పేజీ డేటా", "pagedata-bad-title": "చెల్లని శీర్షిక: $1.", "passwordpolicies": "సంకేతపదపు విధానాలు", + "passwordpolicies-summary": "ఈ వికీలో నిర్వ్చించిన వాడుకరి గుంపులకు వర్తించే సంకేతపద విధానాల జాబితా ఇది.", "passwordpolicies-group": "సమూహం", - "passwordpolicies-policies": "విధానాలు" + "passwordpolicies-policies": "విధానాలు", + "passwordpolicies-policy-minimalpasswordlength": "సంకేతపదం కనీసం $1 {{PLURAL:$1|క్యారెక్టరు|క్యారెక్టర్ల}} పొడవు ఉండాలి", + "passwordpolicies-policy-minimumpasswordlengthtologin": "లాగినవ్వాలంటే సంకేతపదం కనీసం $1 {{PLURAL:$1|క్యారెక్టరు|క్యారెక్టర్ల}} పొడవు ఉండాలి", + "passwordpolicies-policy-passwordcannotmatchusername": "సంకేతపదం, వాడుకరిపేరూ ఒకటే ఉండే వీల్లేదు.", + "passwordpolicies-policy-passwordcannotmatchblacklist": "సంకేతపదం నిషేధించిన సంకేతపదాలతో సరిపోలరాదు", + "passwordpolicies-policy-maximalpasswordlength": "సంకేతపదం $1 {{PLURAL:$1|క్యారెక్టరు|క్యారెక్టర్ల}} పొడవు కంటే తక్కువ ఉండాలి", + "passwordpolicies-policy-passwordcannotbepopular": "సంకేతపదం {{PLURAL:$1|ప్రజాదరణ పొందిన సంకేతపదం కారాదు|ప్రజాదరణ పొందిన $1 సంకేతపదాల్లో ఉండరాదు}}" } diff --git a/languages/i18n/th.json b/languages/i18n/th.json index 6cb3fbaecd..6043bae54f 100644 --- a/languages/i18n/th.json +++ b/languages/i18n/th.json @@ -2690,8 +2690,6 @@ "markedaspatrollederrornotify": "การทำเครื่องหมายว่าตรวจสอบแล้วล้มเหลว", "patrol-log-page": "ปูมการตรวจสอบ", "patrol-log-header": "หน้านี้คือปูมรุ่นการแก้ไขที่กำหนดว่าตรวจสอบแล้ว", - "log-show-hide-patrol": "$1 ปูมการตรวจสอบ", - "log-show-hide-tag": "$1ปูมป้ายระบุ", "confirm-markpatrolled-button": "ตกลง", "confirm-markpatrolled-top": "ทำเครื่องหมายรุ่น $3 ของ $2 ว่าตรวจสอบแล้วหรือไม่", "deletedrevision": "รุ่นเก่าที่ถูกลบ $1", diff --git a/languages/i18n/tk.json b/languages/i18n/tk.json index c6c93dbf17..eff94a5ef9 100644 --- a/languages/i18n/tk.json +++ b/languages/i18n/tk.json @@ -1745,7 +1745,6 @@ "markedaspatrollederror-noautopatrol": "Öz üýtgeşmeleriňizi patrullyk edilen diýip bellemekligiňize rugsat berilmeýär.", "patrol-log-page": "Patrullyk gündeligi", "patrol-log-header": "Bu patrullyk edilen wersiýalaryň gündeligidir.", - "log-show-hide-patrol": "Patrullyk gündeligini $1", "deletedrevision": "$1 köne wersiýasy öçürildi.", "filedeleteerror-short": "Faýl öçürmek säwligi: $1", "filedeleteerror-long": "Faýl öçürilýän mahaly säwlikler ýüze çykdy:\n\n$1", diff --git a/languages/i18n/tl.json b/languages/i18n/tl.json index 7bc2743fc3..a5ef7a73ba 100644 --- a/languages/i18n/tl.json +++ b/languages/i18n/tl.json @@ -653,7 +653,7 @@ "cascadeprotectedwarning": "'''Babala:''' Ikinandado ang pahinang ito upang tanging mga tagagamit na may mga karapatang pang-''sysop'' lamang ang makapagbago nito, dahil kabilang ito sa sumusunod na mga {{PLURAL:$1|pahinang|mga pahinang}} may baita-baitang na panananggalang:", "titleprotectedwarning": "'''Babala: Ikinandado ang pahinang ito upang [[Special:ListGroupRights|partikular na mga karapatan]] ang kakailanganin upang mailikha ito.'''\nAng pinakahuling entrada sa talaan ay ibinigay sa baba para sa inyong pagsasangguni:", "templatesused": "{{PLURAL:$1|Padron|Mga padron}} na ginagamit sa pahinang ito:", - "templatesusedpreview": "{{PLURAL:$1|Suleras|Mga suleras}} na ginagamit sa paunang-tinging ito:", + "templatesusedpreview": "{{PLURAL:$1|Padrong|Mga padrong}} ginagamit sa paunang-tinging ito:", "templatesusedsection": "{{PLURAL:$1|Suleras|Mga suleras}} na ginamit sa seksyong ito:", "template-protected": "(nakasanggalang)", "template-semiprotected": "(bahagyang nakasanggalang)", @@ -820,6 +820,7 @@ "compareselectedversions": "Paghambingin ang mga napiling bersyon", "showhideselectedversions": "Ipakita/itago ang napiling mga bersyon", "editundo": "ibalik", + "diff-empty": "(Walang pagkakaiba)", "diff-multi-manyusers": "({{PLURAL:$1|Isang panggitnang pagbabago|$1 panggitnang mga pagbabago}} ng {{PLURAL:$2|isang tagagamit|$2 mga tagagamit}} ang hindi ipinapakikita.)", "difference-missing-revision": "Hindi natagpuan ang {{PLURAL:$2|isang rebisyon|$2 mga rebisyon}} ng kaibahang ($1) ito.\n\nKaraniwang itong isinanhi ng pagsunod sa isang wala na sa panahong kawing sa pagkakaiba na papunta sa isang pahinang nabura na.\nMatatagpuan ang mga detalye sa loob ng [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} talaan ng pagbura].", "searchresults": "Kinalabasan/Resulta ng paghahanap", @@ -1835,7 +1836,7 @@ "whatlinkshere-hideredirs": "$1 ang mga pagpapapunta sa ibang pahina", "whatlinkshere-hidetrans": "$1 ang mga paglipat-sali (transklusyon)", "whatlinkshere-hidelinks": "$1 ang mga kawing", - "whatlinkshere-hideimages": "$1 kawing ng/sa talaksan", + "whatlinkshere-hideimages": "$1 kawing sa talaksan", "whatlinkshere-filters": "Mga pansala", "autoblockid": "Kusang harangin ang #$1", "block": "Harangin ang tagagamit", @@ -2202,11 +2203,13 @@ "pageinfo-default-sort": "Likas na nakatakdang susi ng pag-uuri", "pageinfo-length": "Haba ng pahina (na nasa mga byte)", "pageinfo-article-id": "ID ng pahina", - "pageinfo-robot-policy": "Katayuan ng makinang panghanap", - "pageinfo-robot-index": "Matataluntunan", + "pageinfo-language": "Wika ng nilalaman ng pahina", + "pageinfo-content-model": "Modelo ng nilalaman ng pahina", + "pageinfo-robot-policy": "Pagtatalatuntunang gawa ng robot", + "pageinfo-robot-index": "Pinapayagan", "pageinfo-robot-noindex": "Hindi pinayagan", "pageinfo-watchers": "Bilang ng mga nagbabantay ng pahina", - "pageinfo-redirects-name": "Napapapunta sa pahinang ito", + "pageinfo-redirects-name": "Bilang ng mga pagkarga sa pahinang ito", "pageinfo-redirects-value": "$1", "pageinfo-subpages-name": "Mga kabahaging pahina ng pahinang ito", "pageinfo-subpages-value": "$1 ($2 {{PLURAL:$2|pagpapapunta sa ibang pahina|mga pagpapapunta sa ibang pahina}}; $3 {{PLURAL:$3|hindi pagpapapunta sa ibang pahina|mga hindi pagpapapunta sa ibang pahina}})", @@ -2218,10 +2221,12 @@ "pageinfo-authors": "Kabuuang bilang ng magkakabukod na mga may-akda", "pageinfo-recent-edits": "Kamakailang bilang ng mga pamamatnugot (sa loob ng huling $1)", "pageinfo-recent-authors": "Kamakailang bilang ng magkakabukod na mga may-akda", - "pageinfo-magic-words": "{{PLURAL:$1|Salita|Mga salita}}ng mahiwaga ($1)", + "pageinfo-magic-words": "{{PLURAL:$1|Salitang|Mga salitang}} mahiwaga ($1)", "pageinfo-hidden-categories": "Nakatagong {{PLURAL:$1|kategorya|mga kategorya}} ($1)", - "pageinfo-templates": "{{PLURAL:$1|Suleras|Mga suleras}} ($1) na nasa transklusyon (kasama sa maraming mga lugar)", + "pageinfo-templates": "{{PLURAL:$1|Padrong nasa transklusyon|Mga padrong nasa transklusyon}} ($1)", "pageinfo-toolboxlink": "Impormasyon ng pahina", + "pageinfo-contentpage": "Binibilang bilang pahina ng nilalaman", + "pageinfo-contentpage-yes": "Oo", "markaspatrolleddiff": "Tatakan bilang napatrolya na", "markaspatrolledtext": "Tatakan ang pahinang ito bilang napatrolya na", "markedaspatrolled": "Tatakan bilang napatrolya na", @@ -2233,7 +2238,6 @@ "markedaspatrollederror-noautopatrol": "Wala kang pahintulot para tatakan ang ginawa mong mga pagbabago bilang napatrolya na.", "patrol-log-page": "Tala ng Pagpapatrolya", "patrol-log-header": "Tala ito ng mga pagbabagong napatrolya na.", - "log-show-hide-patrol": "$1 tala ng pagpatrolya", "deletedrevision": "Binurang lumang pagbabago $1", "filedeleteerror-short": "Kamalian sa pagbubura ng talaksan: $1", "filedeleteerror-long": "Nakaranas ng mga kamalian habang binubura ang talaksan:\n\n$1", @@ -2875,6 +2879,8 @@ "version-entrypoints-header-url": "URL", "version-entrypoints-articlepath": "[https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:$wgArticlePath Landas ng artikulo]", "version-entrypoints-scriptpath": "[https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:$wgScriptPath Landas ng panitik]", + "redirect-revision": "Rebisyon ng pahina", + "redirect-file": "Pangalan ng talaksan", "fileduplicatesearch": "Maghanap ng kaparehong mga talaksan", "fileduplicatesearch-summary": "Maghanap ng mga kaparehong mga talaksan sa baba ng kanyang halaga ng ''hash''.", "fileduplicatesearch-filename": "Pangalan ng file:", @@ -2913,6 +2919,8 @@ "tags-source-header": "Pinagmulan", "tags-hitcount-header": "Natatakang mga pagbabago", "tags-actions-header": "Mga hakbang", + "tags-active-yes": "Oo", + "tags-active-no": "Hindi", "tags-source-none": "Hindi na ginagamit pa", "tags-edit": "baguhin", "tags-delete": "Burahin", @@ -2970,7 +2978,7 @@ "revdelete-unrestricted": "tinanggal ang mga pagbabawal para sa mga tagapangasiwa", "logentry-move-move": "{{GENDER:$2|Inilipat}} ni $1 ang pahinang $3 papunta sa $4", "logentry-move-move-noredirect": "{{GENDER:$2|Inilipat}} ni $1 ang pahinang $3 papunta sa $4 na hindi nag-iiwan ng ibang kapupuntahan", - "logentry-move-move_redir": "Inilipat ni $1 ang pahinang $3 papunta sa $4 na nasa ibayo ng ibang kapupuntahan", + "logentry-move-move_redir": "{{GENDER:$2|Inilipat}} ni $1 ang pahinang \"$3\" sa \"$4\" sa ibayo ng pagkarga", "logentry-move-move_redir-noredirect": "Inilipat ni $1 ang pahinang $3 papunta sa $4 sa ibabaw ng isang pagpapunta sa iba na hindi nag-iiwan ng isang pagpapapunta sa iba", "logentry-patrol-patrol": "Minarkahan ni $1 ang rebisyong $4 ng pahinang $3 bilang napatrolya na", "logentry-patrol-patrol-auto": "Kusang minarkahan ni $1 ang rebisyong $4 ng pahinang $3 bilang napatrolya na", diff --git a/languages/i18n/tr.json b/languages/i18n/tr.json index 4b2080c0b4..196f1f0f00 100644 --- a/languages/i18n/tr.json +++ b/languages/i18n/tr.json @@ -136,6 +136,7 @@ "tog-watchlisthideminor": "Küçük düzenlemeleri izleme listesinde gizle", "tog-watchlisthideliu": "Oturum açmış kullanıcıların düzenlemelerini izleme listesinde gizle", "tog-watchlistreloadautomatically": "Her süzgeç değişikliği olduğunda izleme listesini otomatik olarak yeniden yükle (JavaScript gerekir)", + "tog-watchlistunwatchlinks": "Değişiklik içeren izleme sayfalarına doğrudan izle/izleme işareti ({{int:Watchlist-unwatch}}/{{int:Watchlist-unwatch-undo}}) ekle (Geçiş işlevi için JavaScript gereklidir)", "tog-watchlisthideanons": "Anonim kullanıcıların düzenlemelerini izleme listesinde gizle", "tog-watchlisthidepatrolled": "Devriyenin gördüğü düzenlemeleri izleme listesinde gizle", "tog-watchlisthidecategorization": "Sayfa kategorilendirmesini gizle", @@ -856,6 +857,7 @@ "converter-manual-rule-error": "Elle yapılandırma dil dönüşüm kuralı hatası tespit edildi", "undo-success": "Bu değişiklik geri alınabilir. Lütfen aşağıdaki karşılaştırmayı kontrol edin, gerçekten bu değişikliği yapmak istediğinizden emin olun ve sayfayı kaydederek bir önceki değişikliği geriye alın.", "undo-failure": "Değişikliklerin çakışması nedeniyle geri alma işlemi başarısız oldu.", + "undo-main-slot-only": "Düzenleme, ana alanın dışındaki içeriği içerdiği için geri alınamaz.", "undo-norev": "Değişiklik geri alınamaz çünkü ya silinmiş ya da varolmamaktadır.", "undo-nochange": "Düzeltme zaten geri alınmış.", "undo-summary": "$1 değişikliği [[Special:Contributions/$2|$2]] ([[User talk:$2|mesaj]]) tarafından geri alındı.", @@ -999,8 +1001,12 @@ "diff-multi-sameuser": "(Aynı kullanıcının {{PLURAL:$1|aradaki bir diğer değişikliği|aradaki diğer $1 değişikliği}} gösterilmiyor)", "diff-multi-otherusers": "({{PLURAL:$2|Bir diğer kullanıcıdan|$2 kullanıcıdan}} {{PLURAL:$1|bir ara revizyon|$1 ara revizyon}} gösterilmiyor)", "diff-multi-manyusers": "($2 kullancıdan fazla {{PLURAL:$2|kullanıcı|kullanıcı}} tarafından yapılan {{PLURAL:$1|bir ara revizyon|$1 ara revizyon}} gösterilmiyor)", + "diff-paragraph-moved-tonew": "Paragraf taşındı. Yeni yere gitmek için tıklayın.", + "diff-paragraph-moved-toold": "Paragraf taşındı. Eski yere gitmek için tıklayın.", "difference-missing-revision": "Bu farkın {{PLURAL:$2|bir revizyonu|$2 revizyonu}} ($1) {{PLURAL:$2|bulunamadı|bulunamadı}}.\n\nBu genellikle, silinen bir sayfaya olan eski tarihli bir fark sayfasına bağlantılardan dolayı olur.\nAyrıntılar [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} silme günlüğünde] bulunabilir.", "searchresults": "Arama sonuçları", + "search-filter-title-prefix": "Sadece başlığı \"$1\" ile başlayan sayfalarda arama", + "search-filter-title-prefix-reset": "Tüm sayfalarda ara", "searchresults-title": "\"$1\" için arama sonuçları", "titlematches": "Madde adı eşleşiyor", "textmatches": "Sayfa metni eşleşiyor", @@ -1075,6 +1081,7 @@ "prefs-watchlist-edits": "İzleme listesinde gösterilecek en fazla değişiklik sayısı:", "prefs-watchlist-edits-max": "En fazla sayı: 1000", "prefs-watchlist-token": "İzleme listesi anahtarı:", + "prefs-watchlist-managetokens": "Anahtarları yönet", "prefs-misc": "Diğer ayarlar", "prefs-resetpass": "Parolayı değiştir", "prefs-changeemail": "E-posta adresini değiştir veya kaldır", @@ -1093,6 +1100,7 @@ "recentchangescount": "Son değişiliklerde, sayfa geçmişlerinde ve günlüklerde varsayılan olarak gösterilecek değişiklik sayısı:", "prefs-help-recentchangescount": "Azami sayı: 1000", "prefs-help-watchlist-token2": "Bu izleme listenizin gizli anahtarıdır.\nAnahtarı bilen herkes izleme listenizi görebilir, bu nedenle kimseyle paylaşmayın.\nEğer isterseniz, [[Special:ResetTokens|sıfırlayabilirsiniz]].", + "prefs-help-tokenmanagement": "Hesabınızın izleme listenizdeki web akışına erişebilecek gizli anahtarını görebilir ve sıfırlayabilirsiniz. Anahtarı bilen herkes izleme listenizi okuyabilecek, bu yüzden paylaşmayın.", "savedprefs": "Tercihleriniz kaydedildi.", "savedrights": "{{GENDER:$1|$1}} için kullanıcı grupları kaydedildi.", "timezonelegend": "Zaman dilimi:", @@ -1112,12 +1120,14 @@ "timezoneregion-indian": "Hint Okyanusu", "timezoneregion-pacific": "Pasifik Okyanusu", "allowemail": "Diğer kullanıcıların bana e-posta gönderebilmesine izin ver", + "email-allow-new-users-label": "Yepyeni kullanıcılardan e-postalara izin ver", "email-blacklist-label": "Şu kullanıcıların bana e-posta göndermesine izin verme:", "prefs-searchoptions": "Arama", "prefs-namespaces": "İsim alanları", "default": "varsayılan", "prefs-files": "Dosyalar", "prefs-custom-css": "Özel CSS", + "prefs-custom-json": "Özel JSON", "prefs-custom-js": "Özel JS", "prefs-common-config": "Tüm temalar için paylaşılan CSS/JSON/Javascript:", "prefs-reset-intro": "Bu sayfayı tercihlerinizi site varsayılanına döndürmek için kullanabilirsiniz. Bu geri alınamaz.", @@ -1153,9 +1163,11 @@ "prefs-dateformat": "Tarih biçemi", "prefs-timeoffset": "Saat farkı", "prefs-advancedediting": "Genel seçenekler", + "prefs-developertools": "Geliştirici araçları", "prefs-editor": "Editör", "prefs-preview": "Önizleme", "prefs-advancedrc": "Gelişmiş seçenekler", + "prefs-opt-out": "İyileştirmeleri devre dışı bırak", "prefs-advancedrendering": "Gelişmiş seçenekler", "prefs-advancedsearchoptions": "Gelişmiş seçenekler", "prefs-advancedwatchlist": "Gelişmiş seçenekler", @@ -1171,6 +1183,7 @@ "userrights-user-editname": "Kullanıcı adı giriniz:", "editusergroup": "Kullanıcı gruplarını gör", "editinguser": "'''[[User:$1|$1]]''' $2 kullanıcısının yetkileri değiştiriliyor", + "viewinguserrights": "[[User:$1|$1]] $2 kullanıcısının {{GENDER:$1|kullanıcı}} haklarını görüntüleme", "userrights-editusergroup": "{{GENDER:$1|Kullanıcı}} gruplarını düzenle", "userrights-viewusergroup": "{{GENDER:$1|Kullanıcı}} gruplarını gör", "saveusergroups": "{{GENDER:$1|Kullanıcı}} gruplarını kaydet", @@ -1189,7 +1202,9 @@ "userrights-expiry-existing": "Mevcut bitiş süresi: $2 $3", "userrights-expiry-othertime": "Diğer süre:", "userrights-expiry-options": "1 gün:1 day,1 hafta:1 week,1 ay:1 month,3 ay:3 months,6 ay:6 months,1 yıl:1 year", + "userrights-invalid-expiry": "\"$1\" grubunun süre sonu geçersiz.", "userrights-expiry-in-past": "\"$1\" grubunun bitiş süresi geçmişte.", + "userrights-cannot-shorten-expiry": "Üyelik süresinin sona ermesini \"$1\" grubunda ileriye taşıyamazsınız. Yalnızca bu grubu ekleme ve kaldırma izni olan kullanıcılar, sürenin dolduğu süreyi getirebilir.", "userrights-conflict": "Kullanıcı hakları değişikliklerinde çakışma! Lütfen değişikliklerinizi gözden geçirin ve onaylayın.", "group": "Grup:", "group-user": "Kullanıcılar", @@ -1257,8 +1272,10 @@ "right-editcontentmodel": "Sayfanın içerik modelini düzenle", "right-editinterface": "Kullanıcı arayüzünü değiştirmek", "right-editusercss": "Diğer kullanıcıların CSS dosyalarında değişiklik yap", + "right-edituserjson": "Diğer kullanıcıların JSON dosyalarını düzenle", "right-edituserjs": "Diğer kullanıcıların JS dosyalarında değişiklik yap", "right-editmyusercss": "Kendi kullanıcı CSS dosyaları düzenle", + "right-editmyuserjson": "Kendi kullanıcı JSON dosyalarını düzenle", "right-editmyuserjs": "Kendi kullanıcı JavaScript dosyalarını düzenle", "right-viewmywatchlist": "Kendi izleme listeni gör", "right-editmywatchlist": "Kendi izleme listeni düzenle. Not, bazı eylemler bu yetki olmadan da sayfa ekleyebilir.", @@ -1283,14 +1300,30 @@ "right-managechangetags": "[[Special:Tags|Etiket]] oluşturma ve (de)aktive etme", "right-applychangetags": "Değişiklikleriyle beraber [[Special:Tags|etiketleri]] uygula", "right-changetags": "Tekil sürümler ve günlük kayıtlarına rastgele [[Special:Tags|etiket]] ekleme veya çıkarma", + "right-deletechangetags": "Veritabanından [[Special:Tags|etiketleri]] silin", + "grant-generic": "\"$1\" hak paketi", + "grant-group-page-interaction": "Sayfalarla etkileşim kur", + "grant-group-file-interaction": "Medya ile etkileşim kur", + "grant-group-watchlist-interaction": "İzleme listenle etkileşim kur", "grant-group-email": "E-posta gönder", + "grant-group-customization": "Özelleştirme ve tercihler", + "grant-group-private-information": "Sizinle ilgili özel verilere erişme", "grant-group-other": "Çeşitli aktivite", + "grant-blockusers": "Kullanıcıları engelle ve engeli kaldır", + "grant-createaccount": "Hesap oluştur", "grant-createeditmovepage": "Sayfaları oluşturma, düzenleme ve taşıma", + "grant-delete": "Sayfaları, sürümleri ve günlük girdileri sil", + "grant-editinterface": "MediaWiki alanadını ve kullanıcı CSS/JSON/JavaScript'ini düzenle", "grant-editmycssjs": "Kullanıcı CSS/JSON/JavaScript'ini düzenle", "grant-editmyoptions": "Kullanıcı tercihlerini Düzenle", "grant-editmywatchlist": "İzleme listeni düzenle", + "grant-editpage": "Mevcut sayfaları düzenle", "grant-editprotected": "Korumalı sayfaları Düzenle", + "grant-highvolume": "Yüksek hacimli düzenleme", + "grant-oversight": "Kullanıcıları gizle ve sürümleri durdur", "grant-patrol": "Sayfadaki değişiklikleri incele", + "grant-privateinfo": "Özel bilgilere eriş", + "grant-protect": "Sayfaları koru ve korumasını kaldır", "grant-sendemail": "Diğer kullanıcılara e-posta gönder", "grant-uploadeditmovefile": "Dosya yükle, yenisiyle değiştir ve taşı", "grant-uploadfile": "Dosya yükle", @@ -1360,6 +1393,9 @@ "recentchanges-legend": "Son değişiklikler seçenekleri", "recentchanges-summary": "Vikide yapılan en son değişiklikleri bu sayfadan izleyin.", "recentchanges-noresult": "Belirtilen kriterlere uyan herhangi bir değişiklik bulunamadı.", + "recentchanges-timeout": "Bu arama zaman aşımına uğradı. Farklı arama parametrelerini denemek isteyebilirsiniz.", + "recentchanges-network": "Teknik bir hatadan dolayı sonuç yüklenemedi. Lütfen sayfayı yenilemeyi deneyin.", + "recentchanges-notargetpage": "Bu sayfa ile ilgili değişiklikleri görmek için yukarıdaya bir sayfa adı girin.", "recentchanges-feed-description": "Bu beslemede, viki'de yapılan en son değişiklikleri takip edin.", "recentchanges-label-newpage": "Bu değişiklikle yeni bir sayfa oluşturuldu", "recentchanges-label-minor": "Bu küçük bir değişiklik", @@ -1369,10 +1405,15 @@ "recentchanges-legend-heading": "Gösterge:", "recentchanges-legend-newpage": "{{int:recentchanges-label-newpage}} (ayrıca [[Special:NewPages|yeni sayfalar listesine]] bakınız)", "recentchanges-submit": "Göster", + "rcfilters-tag-remove": "'$1' kaldır", "rcfilters-legend-heading": "Kısaltmalar listesi:", "rcfilters-other-review-tools": "Diğer inceleme araçları", "rcfilters-group-results-by-page": "Sayfalandırılmış grup sonuçları", "rcfilters-activefilters": "Etkin süzgeçler", + "rcfilters-activefilters-hide": "Gizle", + "rcfilters-activefilters-show": "Göster", + "rcfilters-activefilters-hide-tooltip": "Etkin Filtreler alanını gizle", + "rcfilters-activefilters-show-tooltip": "Etkin Filtreler alanını göster", "rcfilters-advancedfilters": "Gelişmiş süzgeçler", "rcfilters-limit-title": "Gösterilecek sonuçlar", "rcfilters-limit-and-date-label": "$1 değişiklik, $2", @@ -1381,6 +1422,7 @@ "rcfilters-hours-title": "Son saatler", "rcfilters-days-show-days": "$1 gün", "rcfilters-days-show-hours": "$1 saat", + "rcfilters-highlighted-filters-list": "Vurgulanan: $1", "rcfilters-quickfilters": "Kaydedilmiş süzgeçler", "rcfilters-quickfilters-placeholder-title": "Henüz hiçbir süzgeç kaydedilmedi", "rcfilters-quickfilters-placeholder-description": "Süzgeç ayarlarınızı kaydetmek ve sonrasında bunları kullanmak için, aşağıda Aktif Süzgeçler alanındaki yer imi simgesine tıklayın.", @@ -1392,7 +1434,10 @@ "rcfilters-savedqueries-new-name-label": "Ad", "rcfilters-savedqueries-new-name-placeholder": "Süzgecin amacını tanımlayın", "rcfilters-savedqueries-apply-label": "Süzgeç oluştur", + "rcfilters-savedqueries-apply-and-setdefault-label": "Varsayılan filtre oluştur", + "rcfilters-savedqueries-cancel-label": "İptal", "rcfilters-savedqueries-add-new-title": "Mevcut süzgeç ayarlarını kaydet", + "rcfilters-savedqueries-already-saved": "Bu filtreler zaten kaydedildi. Yeni bir Kayıtlı Filtre oluşturmak için ayarlarınızı değiştirin.", "rcfilters-restore-default-filters": "Varsayılan süzgeçleri geri getir", "rcfilters-clear-all-filters": "Tüm süzgeçleri temizle", "rcfilters-show-new-changes": "Yeni değişiklikleri görüntüle", @@ -1407,6 +1452,8 @@ "rcfilters-highlightmenu-help": "Bu özelliği vurgulamak için bir renk seçin", "rcfilters-filterlist-noresults": "Süzgeç bulunamadı", "rcfilters-noresults-conflict": "Arama kriterleri çelişkili olduğu için hiçbir sonuç bulunamadı", + "rcfilters-state-message-subset": "Buu filtrenin etkisi yok çünkü sonuçları aşağıdaki, daha geniş {{PLURAL:$2|filtreye|filtrelere}} dahil edilmiştir (ayırt etmek için vurgulamayı deneyin): $1", + "rcfilters-state-message-fullcoverage": "Bu gruptaki tüm filtreleri seçmek, hiçbirini seçmemekle aynıdır; bu nedenle bu filtrenin etkisi yoktur. Grup şunları içerir: $1", "rcfilters-filtergroup-authorship": "Katkı sahipliği", "rcfilters-filter-editsbyself-label": "Senin değişiklikleriniz", "rcfilters-filter-editsbyself-description": "Kendi katkılarınız.", @@ -1429,7 +1476,9 @@ "rcfilters-filter-humans-label": "İnsan (bot değil)", "rcfilters-filter-humans-description": "İnsan editörler tarafından yapılan düzenlemeler.", "rcfilters-filtergroup-reviewstatus": "İnceleme durumu", + "rcfilters-filter-reviewstatus-unpatrolled-description": "Devriye onayından el ile ya da otomatik olarak geçmemiş düzenlemeler.", "rcfilters-filter-reviewstatus-unpatrolled-label": "Devriye onayından geçmemiş", + "rcfilters-filter-reviewstatus-manual-description": "Devriye onayından el ile geçmiş düzenlemeler.", "rcfilters-filtergroup-significance": "Önem", "rcfilters-filter-minor-label": "Küçük düzenlemeler", "rcfilters-filter-minor-description": "Yazarın küçük olarak etiketlediği düzenlemeler.", @@ -1455,7 +1504,9 @@ "rcfilters-filter-categorization-description": "Kategorilere eklenen veya kaldırılan sayfaların kayıtları.", "rcfilters-filter-logactions-label": "Günlüğü tutulan işlemler", "rcfilters-filter-logactions-description": "Hizmetli işlemleri, hesap oluşturmalar, sayfa silmeler, yüklemeler...", + "rcfilters-filtergroup-lastRevision": "En son sürümler", "rcfilters-filter-lastrevision-label": "Son revizyon", + "rcfilters-filter-lastrevision-description": "Bir sayfadaki en yeni değişiklik.", "rcfilters-filter-previousrevision-label": "Son revizyon değil", "rcfilters-filter-excluded": "Hariç", "rcfilters-exclude-button-off": "Seçileni hariç tut", @@ -1470,6 +1521,9 @@ "rcfilters-liveupdates-button-title-off": "Yeni değişiklikleri yapıldıkları anda görüntüleyin", "rcfilters-watchlist-markseen-button": "Tüm değişiklikleri görüldü olarak işaretle", "rcfilters-watchlist-edit-watchlist-button": "İzlenen sayfaların listesini düzenle", + "rcfilters-watchlist-showupdated": "Gerçekleştirilen değişikliklerden bu yana ziyaret etmediğiniz sayfalarda yapılan değişiklikler koyu renktedir.", + "rcfilters-preference-label": "Son Değişikliklerin geliştirilmiş sürümünü gizle", + "rcfilters-watchlist-preference-label": "İzleme Listesinin geliştirilmiş sürümünü gizle", "rcfilters-target-page-placeholder": "Bir sayfa (ya da kategori) adı girin", "rcnotefrom": "$3, $4 tarihinden itibaren yapılan {{PLURAL:$5|değişiklik|değişiklik}} aşağıdadır ($1 tarhine kadar olanlar gösterilmektedir).", "rclistfrom": "$3 $2 tarihinden itibaren yeni değişiklikleri göster", @@ -1926,13 +1980,21 @@ "apisandbox-submit": "İstek yap", "apisandbox-reset": "Temizle", "apisandbox-retry": "Tekrar dene", + "apisandbox-no-parameters": "Bu API modülünde parametre yok.", "apisandbox-helpurls": "Yardım bağlantıları", "apisandbox-examples": "Örnekler", + "apisandbox-dynamic-parameters": "Ek parametreler", "apisandbox-dynamic-parameters-add-label": "Parametre ekle:", "apisandbox-dynamic-parameters-add-placeholder": "Parametre adı", + "apisandbox-deprecated-parameters": "Onaylanmamış parametreler", + "apisandbox-fetch-token": "Anahtarı otomatik olarak doldur", "apisandbox-add-multi": "Ekle", "apisandbox-submit-invalid-fields-title": "Bazı alanlar geçersiz", + "apisandbox-submit-invalid-fields-message": "Lütfen işaretli alanları düzeltin ve tekrar deneyin.", "apisandbox-results": "Sonuçlar", + "apisandbox-sending-request": "API isteği gönderiliyor...", + "apisandbox-loading-results": "API sonuçları alınıyor...", + "apisandbox-results-error": "API sorgusu yanıtı yüklenirken bir hata oluştu: $1.", "apisandbox-request-url-label": "İstek URL:", "apisandbox-request-time": "İstek zamanı: $1", "apisandbox-continue": "Devam et", @@ -2738,8 +2800,6 @@ "markedaspatrollederrornotify": "Kontrol edildi olarak işaretleme başarısız oldu.", "patrol-log-page": "Devriye günlüğü", "patrol-log-header": "Bu gözlenmiş revizyonların günlüğüdür.", - "log-show-hide-patrol": "Gözetim günlüğünü $1", - "log-show-hide-tag": "Etiket günlüğünü $1", "deletedrevision": "$1 sayılı eski sürüm silindi.", "filedeleteerror-short": "$1 dosyanın silinmesinde hata oldu", "filedeleteerror-long": "Dosyayı silerken hatalarla karşılaşıldı:\n\n$1", @@ -2777,6 +2837,7 @@ "newimages-legend": "Filtre", "newimages-label": "Dosya adı (ya da bir parçası):", "newimages-showbots": "Bot yüklemelerini göster", + "newimages-hidepatrolled": "Denetlenmiş yüklemeleri gizle", "noimages": "Görecek bir şey yok.", "ilsubmit": "Ara", "bydate": "kronolojik sırayla", diff --git a/languages/i18n/tt-cyrl.json b/languages/i18n/tt-cyrl.json index ba469465af..ea93a9faab 100644 --- a/languages/i18n/tt-cyrl.json +++ b/languages/i18n/tt-cyrl.json @@ -1835,7 +1835,6 @@ "markedaspatrolledtext": "Сайланган [[:$1]] мәкаләсенең әлеге юрамасы тикшерелгән дип тамгаланды.", "patrol-log-page": "Тикшерү көндәлеге", "patrol-log-header": "Бу тикшерелгән битләрнең көндәлеге.", - "log-show-hide-patrol": "$1 тикшерү көндәлеге", "confirm-markpatrolled-button": "Ярый", "deletedrevision": "$1 битенең иске юрамасы бетерелде", "filedeleteerror-short": "Файлны бетерү хатасы: $1", diff --git a/languages/i18n/tt-latn.json b/languages/i18n/tt-latn.json index bab7202acd..cab0be74d9 100644 --- a/languages/i18n/tt-latn.json +++ b/languages/i18n/tt-latn.json @@ -1344,7 +1344,6 @@ "markedaspatrolledtext": "Saylanğan [[:$1]] mäqäläseneñ älege yuraması tikşerelgän dip tamğalandı.", "patrol-log-page": "Tikşerü köndälege", "patrol-log-header": "Bu tikşerelgän bitlärneñ köndälege.", - "log-show-hide-patrol": "$1 tikşerü köndälege", "deletedrevision": "$1 biteneñ iske yuraması beterelde", "filedeleteerror-short": "Faylnı beterü xatası: $1", "filedeleteerror-long": "Faylnı beterü waqıtında xatalar çıqtı:\n\n$1", diff --git a/languages/i18n/ug-arab.json b/languages/i18n/ug-arab.json index cde8f30d57..15bf3144d4 100644 --- a/languages/i18n/ug-arab.json +++ b/languages/i18n/ug-arab.json @@ -2329,7 +2329,6 @@ "markedaspatrollederrornotify": "چارلىيالمىغانلىق بەلگىسى قويۇلدى.", "patrol-log-page": "چارلاش خاتىرىسى", "patrol-log-header": "بۇ چارلانغان تۈزىتىلگەن نەشرى.", - "log-show-hide-patrol": "$1 چارلاش خاتىرىسى", "deletedrevision": "$1 كونا تۈزىتىلگەن نەشرى ئۆچۈرۈلدى", "filedeleteerror-short": "ھۆججەت ئۆچۈرۈش خاتالىقى: $1", "filedeleteerror-long": "ھۆججەت ئۆچۈرۈۋاتقاندا خاتالىق كۆرۈلدى:\n\n$1", diff --git a/languages/i18n/uk.json b/languages/i18n/uk.json index e6fe0f26c6..e43963daba 100644 --- a/languages/i18n/uk.json +++ b/languages/i18n/uk.json @@ -987,6 +987,8 @@ "diff-paragraph-moved-toold": "Абзац було переміщено. Натисніть щоб перестрибнути до старого розташування.", "difference-missing-revision": "{{PLURAL:$2|$2 версія|$2 версії|$2 версій}} для цього порівняння ($1) не {{PLURAL:$2|1=знайдена|знайдені}}.\n\nІмовірно, ви перейшли за застарілим посиланням на порівняння версій вилученої сторінки.\nПодробиці можна дізнатися з [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} журналу вилучень].", "searchresults": "Результати пошуку", + "search-filter-title-prefix": "Лише пошук в сторінках, назви яких починаються з \"$1\"", + "search-filter-title-prefix-reset": "Пошук по всіх сторінках", "searchresults-title": "Результати пошуку для «$1»", "titlematches": "Збіги в назвах сторінок", "textmatches": "Збіги в текстах сторінок", @@ -1208,7 +1210,7 @@ "grouppage-suppress": "{{ns:project}}:Подавлювачі", "right-read": "перегляд сторінок", "right-edit": "редагування сторінок", - "right-createpage": "створення сторінок (але не обговорень)", + "right-createpage": "створення сторінок (які не є обговореннями)", "right-createtalk": "створення обговорень сторінок", "right-createaccount": "створення нових облікових записів", "right-autocreateaccount": "Автоматичний вхід в систему із зовнішнього облікового запису користувача", @@ -1266,7 +1268,7 @@ "right-markbotedits": "позначення відкинутих редагувань як редагування бота", "right-noratelimit": "нема обмежень за швидкістю", "right-import": "імпорт сторінок з інших вікі", - "right-importupload": "Імпорт сторінок через завантаження файлів", + "right-importupload": "імпорт сторінок через завантаження файлів", "right-patrol": "позначення редагувань патрульованими", "right-autopatrol": "автоматичне позначення редагувань патрульованими", "right-patrolmarks": "Перегляд патрульованих сторінок у нових редагуваннях", @@ -2092,7 +2094,7 @@ "speciallogtitlelabel": "Ціль (назва сторінки або {{ns:user}}:Ім'я_користувача):", "log": "Журнали", "logeventslist-submit": "Показати", - "logeventslist-more-filters": "Більше фільтрів:", + "logeventslist-more-filters": "Показати додаткові журнали:", "logeventslist-patrol-log": "Журнал патрулювання", "logeventslist-tag-log": "Журнал міток", "all-logs-page": "Усі публічні журнали", @@ -2952,8 +2954,6 @@ "markedaspatrollederrornotify": "Не вдалося поставити позначку про патрулювання.", "patrol-log-page": "Журнал патрулювання", "patrol-log-header": "Це журнал перевірених змін.", - "log-show-hide-patrol": "$1 журнал патрулювання", - "log-show-hide-tag": "$1 мітку журналу", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Позначити версію $3 сторінки $2 як відпатрульовану?", "deletedrevision": "Вилучена стара версія $1", diff --git a/languages/i18n/ur.json b/languages/i18n/ur.json index 09f4088e1f..20af4c013f 100644 --- a/languages/i18n/ur.json +++ b/languages/i18n/ur.json @@ -38,7 +38,8 @@ "Sayam Asjad", "Abdulq", "Fitoschido", - "Dcljr" + "Dcljr", + "Bukhari" ] }, "tog-underline": "ربط کی خط کشیدگی:", @@ -391,6 +392,7 @@ "customjsonprotected": "آپ کو اس JSON میں ترمیم کرنے کی اجازت نہیں کیونکہ اس میں کسی دوسرے صارف کی ذاتی ترتیبات موجود ہیں۔", "customjsprotected": "آپ کو اس جاوا اسکرپٹ میں ترمیم کرنے کی اجازت نہیں کیونکہ اس میں کسی دوسرے صارف کی ذاتی ترتیبات موجود ہیں۔", "mycustomcssprotected": "آپ اس سی ایس ایس (CSS) صفحہ میں ترمیم کرنے کا اختیار نہیں رکھتے۔", + "mycustomjsonprotected": "آپ اس صفحہ (جے ایس او این) میں تدوین کرنے کے مجاز نہیں ہیں", "mycustomjsprotected": "آپ اس جاوا اسکپرٹ (JavaScript) صفحہ میں ترمیم کرنے کا اختیار نہیں رکھتے۔", "myprivateinfoprotected": "آپ ان ذاتی معلوات (private information) میں ترمیم کرنے کا اختیار نہیں رکھتے۔", "mypreferencesprotected": "آپ اپنی ان ترجیحات (preferences) میں ترمیم کرنے کا اختیار نہیں رکھتے۔", @@ -430,7 +432,7 @@ "cannotcreateaccount-title": "کھاتے نہیں بنائے جا سکتے", "cannotcreateaccount-text": "اس ویکی پر براہ راست کھاتہ سازی فعال نہیں ہے۔", "yourdomainname": "آپکا ڈومین", - "password-change-forbidden": "آپ اس ویکی پر پارلفظ (پاس روڈ) تبدیل نہیں کر سکتے", + "password-change-forbidden": "آپ اس ویکی پر پاس روڈ تبدیل نہیں کر سکتے۔", "externaldberror": "یا تو توثیقی ڈیٹابیس میں خطا واقع ہوئی اور یا آپ کو بیرونی کھاتہ بتاریخ کرنے کی اِجازت نہیں ہے.", "login": "داخل ہوں", "login-security": "اپنی شناخت کی تصدیق کریں", @@ -466,27 +468,27 @@ "createacct-benefit-body3": "حالیہ {{PLURAL:$1|مشارکت کنندہ|مشارکت کنندگان}}", "badretype": "درج شدہ کلمۂ شناخت اصل سے مطابقت نہیں رکھتا۔", "usernameinprogress": "انتظار فرمائیے!
\nاس صارف نام سے کھاتہ بننے کا عمل ابھی جاری ہے۔", - "userexists": "داخل کردہ اسم صارف پہلے سے مستعمل ہے۔\nبراہِ کرم! کوئی دوسرا اسم منتخب کیجئے۔", + "userexists": "داخل کردہ صارف نام پہلے سے مستعمل ہے۔\nبراہِ مہرابنی کوئی دوسرا نام منتخب کیجیے۔", "loginerror": "داخلے میں غلطی", "createacct-error": "تخلیق کھاتہ میں نقص", "createaccounterror": "کھاتہ $1 بنایا نہیں جاسکا", - "nocookiesnew": "کھاتۂ صارف بنادیا گیا ہے، لیکن آپ کا داخلہ نہیں ہوا.\nصارفین کے داخلہ کیلئے {{SITENAME}} کوکیز استعمال کرتا ہے.\nآپ کے ہاں کوکیز غیر فعال ہیں.\nبراہِ کرم، انہیں فعال کیجئے، اور پھر اپنے نئے اسمِ صارف اور کلمۂ شناخت کے ساتھ داخل ہوجائیے.", + "nocookiesnew": "کھاتۂ صارف بنادیا گیا ہے، لیکن آپ کا داخلہ نہیں ہوا۔\nصارفین کے داخلہ کے لیے {{SITENAME}} کوکیز استعمال کرتا ہے۔\nآپ کے ہاں کوکیز غیر فعال ہیں۔\nبراہِ مہربانی، انہیں فعال کریں، اور پھر اپنے نئے صارف نام اور کلمۂ شناخت (پاسورڈ) کے ساتھ داخل ہو جائیں۔", "nocookieslogin": "صارفین کے داخل ہونے کیلئے {{SITENAME}} کوکیز استعمال کرتا ہے.\nآپ کے ہاں کوکیز غیر فعال ہیں.\nانہیں فعال کرنے کے بعد پھر کوشش کیجئے.", "nocookiesfornew": "اس صارف نام کا کھاتہ نہیں بن سکا۔ہم اس بات کی وضاحت نہیں کر سکتے (کہ ایسا کیوں ہوا)، براہ مہربانی! آپ\nیقین کر لیں کہ آپ کی کوکیز فعال ہیں، صفحہ تازہ کریں اور پھر کوشش کریں۔", "createacct-loginerror": "کھاتہ بن چکا ہے لیکن آپ اس میں خودکار طور پر داخل نہیں ہو سکے۔ براہ کرم [[Special:UserLogin|دستی طور پر داخل ہونے کی کوشش کریں]]۔", - "noname": "آپ نے صحیح اسم صارف نہیں چنا.", + "noname": "آپ نے صحیح صارف نام نہیں چنا۔", "loginsuccesstitle": "داخلہ کامیاب", "loginsuccess": "'''اب آپ {{SITENAME}} میں بنام \"$1\" داخل ہوچکے ہیں۔'''", "nosuchuser": "\"$1\" کے نام سے کوئی صارف موجود نہیں ہے۔\nبراہ کرم ہجوں کو جانچ لیں۔\nنیز اگر آپ چاہیں تو [[Special:CreateAccount|نیا کھاتہ بھی بنا سکتے ہیں]]۔", "nosuchusershort": "\"$1\" کے نام سے کوئی صارف موجود نہیں.\nاپنا ہجہ جانچئے.", - "nouserspecified": "آپ کو ایک اسمِ صارف مخصوص کرنا ہے.", + "nouserspecified": "آپ کو ایک صارف نام مخصوص کرنا ہے۔", "login-userblocked": "اِس صارف پر پابندی ہے. داخلِ نوشتہ ہونے کی اجازت نہیں.", "wrongpassword": "آپ نے غلط پاس ورڈ یا صارف نام درج کیا ہے۔ براہ مہربانی دوبارہ کوشش کریں۔", "wrongpasswordempty": "کلمۂ شناخت ندارد۔ دوبارہ کوشش کریں۔", - "passwordtooshort": "آپکا منتخب کردہ پارلفظ مختصر ہے. پارلفظ کم از کم {{PLURAL:$1|1 محرف|$1 محارف}} ہونا چاہئے.", + "passwordtooshort": "آپ کا منتخب کردہ پاسورڈ مختصر ہے۔ پاسورڈ کم از کم {{PLURAL:$1|1 حرف|$1 حروف}} پر مشتمل ہونا چاہیے۔", "passwordtoolong": "خفیہ رمز (پاس ورڈ) {{PLURAL:$1|1 حرف|$1 حروف}} سے زیادہ طویل نہیں ہو سکتا۔", "passwordtoopopular": "متداول پاس ورڈ استعمال نہیں کیا جا سکتا۔ براہ مہربانی آپ کوئی منفرد پاس ورڈ استعمال کریں تاکہ آپ کا کھاتہ محفوظ رہے۔", - "password-name-match": "آپکا پارلفظ آپکے اسمِ صارف سے مختلف ہونا چاہئے.", + "password-name-match": "آپ کا پاسورڈ آپ کے صارف نام سے مختلف ہونا چاہیے۔", "password-login-forbidden": "اس صارف نام یا کلمۂ شناخت (پاسورڈ) کا استعمال ممنوع ہے", "mailmypassword": "پاسورڈ تبدیل کریں", "passwordremindertitle": "نیا عارضی کلمۂ شناخت برائے {{SITENAME}}", @@ -496,7 +498,7 @@ "passwordsent": "ایک نیا کلمۂ شناخت \"$1\" کے نام سے بننے والی برقی ڈاک کے پتے کیلیے بھیج دیا گیا ہے۔\nجب وہ موصول ہو جاۓ تو براہ کرم اسکے ذریعے دوبارہ داخل ہوں۔", "blocked-mailpassword": "آپ کے آئی پی پتے کی ترمیم کاری پر پابندی لگا دی گئی ہے۔ غلط استعمال سے بچنے کے لیے اس آئی پی پتے سے پاس ورڈ کی بازیابی کی اجازت منسوخ کر دی گئی ہے۔", "eauthentsent": "ایک تصدیقی برقی خط نامزد کیے گئے برقی پتہ پر ارسال کردیا گیا ہے۔\nآپ کو موصول ہوئے برقی خط میں ہدایات پر عمل کرکے اس بات کی توثیق کرلیں کہ مذکورہ برقی پتہ آپ کا ہی ہے۔", - "throttled-mailpassword": "گزشتہ {{PLURAL:$1|گھنٹے|$1 گھنٹوں}} کے دوران پہلے سے ہی پارلفظ (پاسورڈ) کی تبدیلی کے لیے برقی خط بھیجا گيا ہے۔\nناجائز استعمال کے سدّباب کیلئے، {{PLURAL:$1|گھنٹہ|$1 گھنٹوں}} کے دوران صرف ایک برقی خط بھیجا جاسکتا ہے۔", + "throttled-mailpassword": "گزشتہ {{PLURAL:$1|گھنٹے|$1 گھنٹوں}} کے دوران پہلے سے ہی پاسورڈ کی تبدیلی کے لیے برقی خط بھیجا گيا ہے۔\nناجائز استعمال کے سدّباب کے لیے، {{PLURAL:$1|گھنٹہ|$1 گھنٹوں}} کے دوران صرف ایک برقی خط بھیجا جا سکتا ہے۔", "mailerror": "مسلہ دوران ترسیل خط:$1", "acct_creation_throttle_hit": "آپکی آئی پی کے ذریعے اِس ویکی پر آنے والے صارفین نے پچھلے $2 میں {{PLURAL:$1|1 کھاتہ بنایا ہے|$1 کھاتے بنائے ہیں}} جو اس مدت کے لیے کافی ہیں۔\nلہٰذا آپ کی آئی پی استعمال کرنے والے صارفین اِس وقت مزید کھاتے نہیں بنا سکتے۔", "emailauthenticated": "آپ کے برقی ڈاک پتہ کی تصدیق مورخہ $2 بوقت $3 بجے ہوئی۔", @@ -509,7 +511,7 @@ "accountcreated": "تخلیقِ کھاتہ", "accountcreatedtext": "[[{{ns:User}}:$1|$1]] ([[{{ns:User talk}}:$1|تبادلۂ خیال]]) کا صارف کھاتہ بن چکا ہے۔", "createaccount-title": "کھاتہ سازی برائے {{SITENAME}}", - "createaccount-text": "کسی نے {{SITENAME}} ($4) پر \"$2\" کے نام سے اور \"$3\" پارلفظ کے ساتھ آپ کا برقی پتہ استعمال کرتے ہوئے کھاتہ بنایا ہے.\nآپ کو چاہئے کہ ابھی داخلِ نوشتہ ہوکر اپنا پارلفظ تبدیل کردیں.\n\nاگر یہ کھاتہ غلطی سے بنا تھا تو آپ یہ پیغام نظرانداز کرسکتے ہیں.", + "createaccount-text": "کسی نے {{SITENAME}} ($4) پر «$2» کے نام سے اور \"$3\" پاسورڈ کے ساتھ آپ کا برقی پتہ استعمال کرتے ہوئے کھاتہ بنایا ہے۔\nآپ کو چاہیے کہ ابھی لاگ ان ہو کر اپنا پاسورڈ تبدیل کر دیں۔\n\nاگر یہ کھاتہ غلطی سے بنا ہے، تو آپ یہ پیغام نظر انداز کر دیں۔", "login-throttled": "آپ نے حال ہی میں متعدد مرتبہ لاگ ان ہونے کی کوشش کی ہے۔\nدوبارہ کوشش کرنے سے پہلے $1 انتظار فرمائیے۔", "login-abort-generic": "لاگ ان ناکام - منسوخ شد", "login-migrated-generic": "آپ کا کھاتہ منتقل کر دیا گیا، اب اس ویکی پر آپ کا صارف نام موجود نہیں۔", @@ -525,12 +527,12 @@ "user-mail-no-addy": "برقی ڈاک بھیجنے کی کوشش بغیر برقی ڈاک پتہ", "user-mail-no-body": "خالی یا بہت ہی مختصر برقی خط بھیجنے کی کوشش", "changepassword": "کلمۂ شناخت تبدیل کریں", - "resetpass_announce": "آپ ایک برقی ارسال کردہ عارضی رمز (کوڈ) کے ساتھ داخل ہوئے ہیں۔\nداخلِ نوشتہ کے عمل کو مکمل کرنے کیلئے آپ کو یہاں نیا پارلفظ (پاسورڈ) متعین کرنا ہوگا۔", - "resetpass_header": "کھاتہ کا پارلفظ تبدیل کریں", + "resetpass_announce": "لاگ ان کے عمل کو مکمل کرنے کے لیے آپ کو نیا پاسورڈ متعین کرنا ہو گا۔", + "resetpass_header": "کھاتہ کا پاسورڈ تبدیل کریں", "oldpassword": "پرانا کلمۂ شناخت:", "newpassword": "نیا کلمۂ شناخت", "retypenew": "نیا کلمۂ شناخت دوبارہ درج کریں:", - "resetpass_submit": "پارلفظ بناؤ اور داخل ہوجاؤ", + "resetpass_submit": "پاسورڈ بنائیں اور داخل ہوں", "changepassword-success": "آپ کا پاس ورڈ تبدیل کر دیا گیا!", "changepassword-throttled": "آپ نے حال ہی میں متعدد مرتبہ داخل ہونے کی کوشش کی ہے۔\nدوبارہ کوشش کرنے سے پہلے $1 انتظار کریں۔", "botpasswords": "روبہ پاس ورڈ", @@ -564,15 +566,15 @@ "botpasswords-restriction-failed": "روبہ کے پاس ورڈ کی پابندیاں اس لاگ ان سے مانع ہیں۔", "botpasswords-invalid-name": "درج کردہ صارف نام میں روبہ کے پاس ورڈ کا فاصل لفظ موجود نہیں ہے (\"$1\")۔", "botpasswords-not-exist": "صارف \"$1\" کے پاس \"$2\" کے نام سے روبہ کا پاس ورڈ نہیں ہے۔", - "resetpass_forbidden": "پارلفظ تبدیل نہیں ہوسکتا", + "resetpass_forbidden": "پاسورڈ تبدیل نہیں ہو سکتا", "resetpass_forbidden-reason": "پاس ورڈ تبدیل نہیں کیا جا سکتا: $1", "resetpass-no-info": "اِس صفحہ تک براہِ راست رسائی کیلئے آپ کو داخلِ نوشتہ ہونا پڑے گا.", - "resetpass-submit-loggedin": "پارلفظ کی تبدیلی", + "resetpass-submit-loggedin": "پاسورڈ تبدیل کریں", "resetpass-submit-cancel": "منسوخ", "resetpass-wrong-oldpass": "عارضی یا موجودہ پاس ورڈ نادرست ہے۔\nشاید آپ نے پہلے ہی اپنا پاس ورڈ تبدیل کر لیا ہے یا نئے عارضی پاس ورڈ کی درخواست کر چکے ہیں۔", "resetpass-recycled": "براہ کرم اپنے موجودہ پاس ورڈ سے مختلف پاس ورڈ رکھیں۔", - "resetpass-temp-emailed": "آپ عارضی برقی خط سے بھیجے گئے کوڈ سے لاگ ان ہیں\nمکمل طور پر لاگ ان ہونے کے لیے آپ کو نیا پاسورڈ سیٹ کرنا پڑے گا", - "resetpass-temp-password": "عارضی پارلفظ:", + "resetpass-temp-emailed": "آپ ایک برقی ارسال کردہ عارضی کوڈ کے ساتھ داخل ہوئے ہیں۔\nلاگ ان کے عمل کو مکمل کرنے کے لیے آپ کو یہاں نیا پاسورڈ متعین (سیٹ) کرنا ہو گا۔", + "resetpass-temp-password": "عارضی پاسورڈ:", "resetpass-abort-generic": "کسی توسیع نے پاس ورڈ کی تبدیلی کو منسوخ کر دیا ہے۔", "resetpass-expired": "آپ کے پاس ورد کی مدت ختم ہو چکی ہے۔ داخل ہونے کے لیے براہ کرم نیا پاس ورڈ بنائیں۔", "resetpass-expired-soft": "آپ کے پاس ورڈ کی مدت ختم ہو چکی ہے، لہذا اسے دوبارہ بنانے کی ضرورت ہے۔\nبراہ کرم نیا پاس ورڈ بنائیں یا اگر مستقبل میں اس کی ترتیب نو مقصود ہو تو «{{int:authprovider-resetpass-skip-label}}» پر کلک کریں۔", @@ -582,7 +584,7 @@ "passwordreset-text-many": "{{PLURAL:$1|برقی خط کے ذریعہ عارضی پاس ورڈ حاصل کرنے کے لیے کسی ایک خانے کو پُر کریں۔}}", "passwordreset-disabled": "اس ویکی پر پاس ورڈ کی ترتیب نو کی سہولت فعال نہیں ہے۔", "passwordreset-emaildisabled": "اس ویکی پر برقی خط کی سہولت غیر فعال ہیں۔", - "passwordreset-username": "اسمِ صارف:", + "passwordreset-username": "صارف نام:", "passwordreset-domain": "ساحہ:", "passwordreset-email": "برقی ڈاک پتہ:", "passwordreset-emailtitle": "{{SITENAME}} کھاتہ کی تفصیلات", @@ -730,7 +732,7 @@ "permissionserrorstext": "درج ذیل {{PLURAL:$1|وجہ|وجوہات}} کی بنا پر آپ کو ایسا کرنے کی اجازت نہیں ہے:", "permissionserrorstext-withaction": "درج ذیل {{PLURAL:$1|وجہ|وجوہات}} کی بنا پر آپ کو $2 کی اجازت نہیں ہے:", "contentmodelediterror": "آپ اس نسخے میں ترمیم نہیں کر سکتے کیونکہ اس کے مواد کا ماڈل ‌‌$1 ہے جو اس صفحہ کے مواد کے موجودہ ماڈل $2 سے مختلف ہے۔", - "recreate-moveddeleted-warn": "''' انتباہ: آپ ایک گزشتہ حذف شدہ صفحہ دوبارہ تخلیق کررہے ہیں. '''\n\nآپ کو اِس بات پر غور کرنا چاہئے کہ آیا اِس صفحہ کی تدوین جاری رکھنا موزوں ہے یا نہیں.\nصفحہ کا نوشتۂ حذف شدگی و منتقلی یہاں سہولت کی خاطر مہیّا کیا جارہا ہے:", + "recreate-moveddeleted-warn": "انتباہ: آپ ایک گزشتہ حذف شدہ صفحہ دوبارہ تخلیق کر رہے ہیں۔\n\nآپ کو اِس بات پر غور کرنا چاہیے کہ آیا اِس صفحہ کی تدوین جاری رکھنا موزوں ہے یا نہیں۔\nصفحہ کا نوشتۂ حذف شدگی و منتقلی یہاں سہولت کی خاطر مہیّا کیا جا رہا ہے:", "moveddeleted-notice": "اس صفحہ کو حذف کر دیا گیا ہے۔\nحوالہ کے لیے ذیل میں اس صفحہ کا نوشتہ حذف شدگی اور نوشتہ منتقلی درج ہے۔", "moveddeleted-notice-recent": "معذرت، اس صفحہ کو حال ہی میں حذف کیا گیا ہے (گزشتہ چوبیس گھنٹوں میں)۔\nحوالہ کے لیے ذیل میں اس صفحہ کا نوشتہ حذف اور نوشتہ منتقلی موجود ہے۔", "log-fulllog": "پورا نوشتہ دیکھیے", @@ -856,7 +858,7 @@ "revdelete-hide-image": "فائل کے مشمولات چھپائیں", "revdelete-hide-name": "ہدف اور پیرامیٹرز کو چھپائیں", "revdelete-hide-comment": "ترمیمی تبصرہ چھپاؤ", - "revdelete-hide-user": "ترمیم کار کا اسمِ صارف / آئی.پی پتہ چُھپاؤ", + "revdelete-hide-user": "ترمیم کنندہ کا صارف نام/آئی پی پتہ چھپائیں", "revdelete-hide-restricted": "منتظمین اور دیگر صارفین سے معلومات کو پوشیدہ کریں", "revdelete-radio-same": "(تبدیل مت کرو)", "revdelete-radio-set": "پوشیدہ", @@ -1067,7 +1069,7 @@ "yournick": "شخصی دستخط:", "prefs-help-signature": "تبادلۂ خیال صفحات پر تبصرہ تحریر کرنے کے بعد یہ \"~~~~\" علامتیں درج کرنی چاہئیں، یہ علامتیں از خود آپ کے دستخط اور وقت میں تبدیل ہو جائیں گی۔", "badsig": "ناقص خام دستخط.\nHTML tags جانچئے.", - "badsiglength": "آپ کا دستخط کافی طویل ہے.\nیہ $1 {{PLURAL:$1|حرف|حروف}} سے زیادہ نہیں ہونا چاہئے.", + "badsiglength": "آپ کا دستخط کافی طویل ہے۔\nیہ $1 {{PLURAL:$1|حرف|حروف}} سے زیادہ نہیں ہونا چاہیے۔", "yourgender": "جنس:", "gender-unknown": "اگر ممکن ہو تو آپ کے تذکرہ کے وقت سافٹ ویئر غیر جانبدار جنسی الفاظ استعمال کرے گا", "gender-male": "مرد", @@ -1101,7 +1103,7 @@ "prefs-tabs-navigation-hint": "نکتہ: مختلف خانوں میں جانے کے لیے آپ دائیں اور بائیں کی جہت نما کلیدیں استعمال کر سکتے ہیں۔", "userrights": "حقوق صارف", "userrights-lookup-user": "صارف کا انتخاب کریں", - "userrights-user-editname": "کوئی اسم‌صارف داخل کیجئے:", + "userrights-user-editname": "صارف نام درج کیجیے:", "editusergroup": "حلقہ ہائے صارف دکھائیں", "editinguser": "{{GENDER:$1|صارف}} [[User:$1|$1]] $2 کے اختیارات میں تبدیلی", "viewinguserrights": "{{GENDER:$1|صارف}} [[User:$1|$1]] $2 کے اختیارات میں تبدیلی", @@ -2143,7 +2145,7 @@ "deletepage": "حذف کریں", "confirm": "یقین", "excontent": "'$1':مواد تھا", - "excontentauthor": "حذف شدہ مواد: «$1» اور صرف «[[Special:Contributions/$2|$2]]» ([[User talk:$2|تبادلۂ خیال]]) نے اس میں ترمیم کی", + "excontentauthor": "مواد «$1» تھا اور صرف «[[Special:Contributions/$2|$2]]» ([[User talk:$2|تبادلۂ خیال]]) نے اس میں ترمیم کی تھی", "exbeforeblank": "خالی کرنے سے قبل موجود مواد: «$1»", "delete-confirm": "حذف ''$1''", "delete-legend": "حذف", @@ -2357,7 +2359,7 @@ "ipaddressorusername": "آئی پی پتہ یا صارف نام:", "ipbexpiry": "وقت اختتام:", "ipbreason": "وجہ:", - "ipbreason-dropdown": "* عمومی وجوہات پابندی\n** غلط معلومات کا اندراج\n** صفحات سے متن کا مٹانا\n** بیرونی روابط میں بے کار روابط کی فاضل کاری\n** صفحات میں لغو چیزوں کا اندراج\n** بدتمیزی/بداخلاقی\n** متعدد کھاتوں کا استعمال\n** ناقابلِ قبول اسمِ صارف", + "ipbreason-dropdown": "* پابندی کی عام وجوہات\n** غلط معلومات کا اندراج\n** صفحات سے متن کا مٹانا\n** بیرونی روابط میں بے کار روابط کی فاضل کاری\n** صفحات میں لغو چیزوں کا اندراج\n** بدتمیزی/بداخلاقی\n** متعدد کھاتوں کا استعمال\n** ناقابلِ قبول صارف نام", "ipb-hardblock": "اس آئی پی پتے سے داخل شدہ صارفین کو ترمیم کاری سے باز رکھیں", "ipbcreateaccount": "کھاتہ سازی سے باز رکھیں", "ipbemailban": "برقی خط بھیجنے سے باز رکھیں", @@ -2791,8 +2793,6 @@ "markedaspatrollederrornotify": "بطور مراجعت نشان زد نہیں کیا جا سکا۔", "patrol-log-page": "نوشتہ مراجعت", "patrol-log-header": "ذیل میں مراجعت شدہ ترامیم کا نوشتہ ہے۔", - "log-show-hide-patrol": "$1 نوشتہ مراجعت", - "log-show-hide-tag": "$1 نوشتہ ٹیگ", "confirm-markpatrolled-button": "ٹھیک ہے", "confirm-markpatrolled-top": "$2 کے نسخہ $3 کو بطور مراجعت شدہ نشان زد کریں؟", "deletedrevision": "حذف شدہ پرانی ترمیم $1۔", diff --git a/languages/i18n/vec.json b/languages/i18n/vec.json index 79664ece75..8a52c6446b 100644 --- a/languages/i18n/vec.json +++ b/languages/i18n/vec.json @@ -2199,7 +2199,6 @@ "markedaspatrollederrornotify": "Eror durante ła verifega.", "patrol-log-page": "Modifiche verificàe", "patrol-log-header": "Qua de sèvito xe elencàe le verifiche de le modifiche.", - "log-show-hide-patrol": "$1 el registro dei canbiamenti verificài", "deletedrevision": "Vecia version scancełà $1", "filedeleteerror-short": "Eror ne la scancelazion del file: $1", "filedeleteerror-long": "Se gà verificà dei eror nel tentativo de scancelar el file:\n\n$1", diff --git a/languages/i18n/vep.json b/languages/i18n/vep.json index 22fb275700..b55152f878 100644 --- a/languages/i18n/vep.json +++ b/languages/i18n/vep.json @@ -1764,7 +1764,6 @@ "markedaspatrollederror-noautopatrol": "Teile ei sa znamoita ičetoi toižetusid kut patruliruidud.", "patrol-log-page": "Patruliruindan aigkirj", "patrol-log-header": "Nece om patruliruidud versijoiden aiglehtez.", - "log-show-hide-patrol": "$1 patruliruindan aigkirj", "deletedrevision": "$1-lehtpolen vanh versii om čutud", "filedeleteerror-short": "Failan čudandan petuz: $1", "filedeleteerror-long": "Necen failan heitmižen aigan ozaižihe petused:\n\n$1", diff --git a/languages/i18n/vi.json b/languages/i18n/vi.json index 122c6df85e..a40a8ff2c5 100644 --- a/languages/i18n/vi.json +++ b/languages/i18n/vi.json @@ -942,6 +942,8 @@ "diff-paragraph-moved-toold": "Đoạn văn được chuyển từ vị trí khác. Nhấn chuột để nhảy tới vị trí cũ.", "difference-missing-revision": "Không tìm thấy {{PLURAL:$2|một phiên bản|$2 phiên bản}} trong khác biệt này ($1).\n\nLỗi này thường xuất hiện đối khi theo dõi liên kết lỗi thời đến khác biệt giữa các bản của trang đã bị xóa.\nXem chi tiết trong [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} nhật trình xóa].", "searchresults": "Kết quả tìm kiếm", + "search-filter-title-prefix": "Chỉ có tìm trong các trang có tên bắt đầu với “$1”", + "search-filter-title-prefix-reset": "Tìm kiếm tất cả các trang", "searchresults-title": "Kết quả tìm kiếm “$1”", "titlematches": "Đề mục tương tự", "textmatches": "Câu chữ tương tự", @@ -1098,6 +1100,7 @@ "prefs-editor": "Trình soạn", "prefs-preview": "Xem trước", "prefs-advancedrc": "Tùy chọn nâng cao", + "prefs-opt-out": "Quyết định không sử dụng các cải thiện", "prefs-advancedrendering": "Tùy chọn nâng cao", "prefs-advancedsearchoptions": "Tùy chọn nâng cao", "prefs-advancedwatchlist": "Tùy chọn nâng cao", @@ -1345,6 +1348,8 @@ "rcfilters-activefilters": "Bộ lọc hiện hành", "rcfilters-activefilters-hide": "Ẩn", "rcfilters-activefilters-show": "Hiện", + "rcfilters-activefilters-hide-tooltip": "Ẩn phần Bộ lọc kích hoạt", + "rcfilters-activefilters-show-tooltip": "Hiện phần Bộ lọc kích hoạt", "rcfilters-advancedfilters": "Bộ lọc nâng cao", "rcfilters-limit-title": "Số kết quả hiển thị", "rcfilters-limit-and-date-label": "$1 thay đổi, $2", @@ -1368,6 +1373,7 @@ "rcfilters-savedqueries-apply-and-setdefault-label": "Tạo bộ lọc mặc định", "rcfilters-savedqueries-cancel-label": "Hủy bỏ", "rcfilters-savedqueries-add-new-title": "Lưu thiết lập bộ lọc hiện tại", + "rcfilters-savedqueries-already-saved": "Đã lưu các bộ lọc này rồi. Thay đổi tùy chọn để tạo một Bộ lọc đã lưu mới.", "rcfilters-restore-default-filters": "Mặc định lại các bộ lọc", "rcfilters-clear-all-filters": "Xóa sạch các bộ lọc", "rcfilters-show-new-changes": "Xem các thay đổi mới nhất", @@ -1462,6 +1468,9 @@ "rcfilters-watchlist-edit-watchlist-button": "Sửa danh sách trang theo dõi", "rcfilters-watchlist-showupdated": "Thay đổi mới trên các trang kể lần cuối bạn xem trang được in đậm và có dấu tô màu.", "rcfilters-preference-label": "Ẩn phiên bản cải tiến của trang Thay đổi Gần đây", + "rcfilters-preference-help": "Hủy bỏ thiết kế lại giao diện năm 2017 và tất cả các công cụ được thêm từ lúc đó trở về nay.", + "rcfilters-watchlist-preference-label": "Ẩn danh sách theo dõi cải thiện", + "rcfilters-watchlist-preference-help": "Hủy bỏ thiết kế lại giao diện năm 2017 và tất cả các công cụ được thêm từ lúc đó trở về nay.", "rcfilters-filter-showlinkedfrom-label": "Xem các thay đổi tại trang có liên kết từ", "rcfilters-filter-showlinkedfrom-option-label": "Trang có liên kết từ trang được chọn", "rcfilters-filter-showlinkedto-label": "Xem các thay đổi tại trang có liên kết đến", @@ -1521,6 +1530,7 @@ "uploadbtn": "Tải tập tin lên", "reuploaddesc": "Hủy tác vụ tải và quay lại mẫu tải tập tin lên", "upload-tryagain": "Lưu miêu tả tập tin được sửa đổi", + "upload-tryagain-nostash": "Gửi lại tập tin được tải lên lại và miêu tả được sửa đổi", "uploadnologin": "Chưa đăng nhập", "uploadnologintext": "Bạn phải $1 để tải tập tin lên.", "upload_directory_missing": "Thư mục tải lên ($1) không có hoặc máy chủ web không thể tạo được.", @@ -1705,13 +1715,19 @@ "uploadstash-bad-path-invalid": "Đường dẫn không hợp lệ.", "uploadstash-bad-path-unknown-type": "Loại không xác định \"$1\".", "uploadstash-bad-path-unrecognized-thumb-name": "Tên hình thu nhỏ không nhận dạng được.", + "uploadstash-bad-path-no-handler": "Không tìm thấy trình xử lý kiểu MIME $1 của tập tin $2.", "uploadstash-bad-path-bad-format": "Chìa khóa “$1” không tuân theo định dạng.", "uploadstash-file-not-found-no-thumb": "Không thể tải hình thu nhỏ.", + "uploadstash-file-not-found-no-local-path": "Không tìm thấy đường dẫn trên máy cho hình nhỏ.", "uploadstash-file-not-found-no-object": "Không tạo được đối tượng tập tin cục bộ cho hình thu nhỏ.", "uploadstash-file-not-found-no-remote-thumb": "Nạp hình thu nhỏ thất bại: $1\nURL = $2", "uploadstash-file-not-found-missing-content-type": "Thiếu đầu đề kiểu-nội-dung (content-type).", + "uploadstash-file-not-found-not-exists": "Không tìm thấy đường dẫn hoặc không phải là tập tin thuần túy.", + "uploadstash-file-too-large": "Không thể phục vụ tập tin lớn hơn $1 byte.", "uploadstash-not-logged-in": "Người dùng chưa đăng nhập, các tập tin phải do người dùng đã đăng nhập tải lên.", + "uploadstash-wrong-owner": "Tập tin này ($1) không phải do người dùng hiện tại tải lên.", "uploadstash-no-such-key": "Khóa không tồn tại ($1), không thể xóa.", + "uploadstash-no-extension": "Phần mở rộng không có giá trị.", "uploadstash-zero-length": "Tập tin có dung lượng bằng không.", "invalid-chunk-offset": "Khúc lệch (chunk offset) không hợp lệ", "img-auth-accessdenied": "Không cho phép truy cập", @@ -1731,6 +1747,7 @@ "http-timed-out": "Hết thời gian yêu cầu HTTP.", "http-curl-error": "Có lỗi khi truy xuất URL: $1", "http-bad-status": "Có vấn đề khi yêu cầu HTTP: $1 $2", + "http-internal-error": "Lỗi nội bộ HTTP.", "upload-curl-error6": "Không thể truy cập URL", "upload-curl-error6-text": "Không thể truy cập URL mà bạn đưa vào. Xin hãy kiểm tra xem URL có đúng không và website vẫn còn hoạt động.", "upload-curl-error28": "Quá thời gian tải lên cho phép", @@ -2023,6 +2040,9 @@ "speciallogtitlelabel": "Mục tiêu (tiêu đề hoặc {{ns:user}}:Tên-người-dùng đối với người dùng):", "log": "Nhật trình", "logeventslist-submit": "Xem", + "logeventslist-more-filters": "Hiện thêm nhật trình:", + "logeventslist-patrol-log": "Nhật trình tuần tra", + "logeventslist-tag-log": "Nhật trình thẻ đánh dấu", "all-logs-page": "Tất cả các nhật trình công khai", "alllogstext": "Hiển thị tất cả các nhật trình đang có của {{SITENAME}} chung với nhau.\nBạn có thể thu hẹp kết quả bằng cách chọn loại nhật trình, tên thành viên (phân biệt chữ hoa-chữ thường), hoặc các trang bị ảnh hưởng (cũng phân biệt chữ hoa-chữ thường).", "logempty": "Không có mục nào khớp với từ khóa.", @@ -2376,6 +2396,7 @@ "uctop": "(hiện tại)", "month": "Từ tháng (trở về trước):", "year": "Từ năm (trở về trước):", + "date": "Từ ngày (trở về trước):", "sp-contributions-newbies": "Chỉ hiển thị đóng góp của tài khoản mới", "sp-contributions-newbies-sub": "Các thành viên mới", "sp-contributions-newbies-title": "Đóng góp của các thành viên mới", @@ -2394,6 +2415,7 @@ "sp-contributions-newonly": "Chỉ hiện các sửa đổi tạo trang", "sp-contributions-hideminor": "Ẩn các sửa đổi nhỏ", "sp-contributions-submit": "Tìm kiếm", + "sp-contributions-outofrange": "Không thể hiển thị kết quả cho dải địa chỉ IP quá giới hạn CIDR là /$1.", "whatlinkshere": "Các liên kết đến đây", "whatlinkshere-title": "Các trang liên kết đến “$1”", "whatlinkshere-page": "Trang:", @@ -2517,6 +2539,8 @@ "ipb_blocked_as_range": "Lỗi: Địa chỉ IP $1 không bị cấm trực tiếp và do đó không thể bỏ cấm. Tuy nhiên, nó bị cấm do là một bộ phận của dải IP $2, bạn có thể bỏ cấm dải này.", "ip_range_invalid": "Dải IP không hợp lệ.", "ip_range_toolarge": "Không được phép cấm dải IP lớn hơn /$1.", + "ip_range_exceeded": "Dải địa chỉ IP này vượt quá dải tối đa. Dải được cho phép: /$1.", + "ip_range_toolow": "Không cho phép dải địa chỉ IP trên thực tế.", "proxyblocker": "Cấm proxy", "proxyblockreason": "Địa chỉ IP của bạn đã bị cấm vì là proxy mở. Xin hãy liên hệ nhà cung cấp dịch vụ Internet hoặc bộ phận hỗ trợ kỹ thuật của bạn và thông báo với họ về vấn đề an ninh nghiêm trọng này.", "sorbsreason": "Địa chỉ IP của bạn bị liệt kê là một proxy mở trong DNSBL mà {{SITENAME}} đang sử dụng.", @@ -2875,8 +2899,6 @@ "markedaspatrollederrornotify": "Đánh dấu tuần tra bị thất bại.", "patrol-log-page": "Nhật trình tuần tra", "patrol-log-header": "Đây là nhật trình tuần tra phiên bản.", - "log-show-hide-patrol": "$1 nhật trình tuần tra", - "log-show-hide-tag": "Nhật trình đánh dấu $1", "confirm-markpatrolled-button": "OK", "confirm-markpatrolled-top": "Đánh dấu tuần tra phiên bản $3 của $2?", "deletedrevision": "Đã xóa phiên bản cũ $1", diff --git a/languages/i18n/vo.json b/languages/i18n/vo.json index 39b4c38fbc..60d1098d1c 100644 --- a/languages/i18n/vo.json +++ b/languages/i18n/vo.json @@ -1703,7 +1703,6 @@ "markedaspatrollederror-noautopatrol": "No dalol zepön votükamis lönik ola.", "patrol-log-page": "Jenotalised zepamas", "patrol-log-header": "Is lisedons revids pezepöl.", - "log-show-hide-patrol": "Jenotalised Zepamas: $1", "deletedrevision": "Fomam büik: $1 pemoükon.", "filedeleteerror-short": "Pöl pö moükam ragiva: $1", "filedeleteerror-long": "Pöls petuvons dü moükam ragiva:\n\n$1", diff --git a/languages/i18n/war.json b/languages/i18n/war.json index 7f670e1b6e..2d5c8ad9e7 100644 --- a/languages/i18n/war.json +++ b/languages/i18n/war.json @@ -1901,7 +1901,6 @@ "markedaspatrollederror": "Diri nakakamarka komo ginpatrolya na", "patrol-log-page": "Talaan han pagpatrolya", "patrol-log-header": "Ini in uska talaan hin mga ginpatrolya nga mga rebisyon.", - "log-show-hide-patrol": "$1 talaan hin pagpatrolya", "deletedrevision": "Ginpara an daan nga rebisyon $1", "filedeleteerror-short": "Nagsayop ha pagpara han paypay: $1", "filedeleteerror-long": "Mga sayop nga ginengkwentro samtang nagpapara hin paypay:\n\n$1", diff --git a/languages/i18n/yi.json b/languages/i18n/yi.json index 5f5df180d6..4d3ec300d7 100644 --- a/languages/i18n/yi.json +++ b/languages/i18n/yi.json @@ -2538,8 +2538,6 @@ "markedaspatrollederrornotify": "מארקירן ווי קאנטראלירט דורכגעפאלן.", "patrol-log-page": "פאטראלירן לאג-בוך", "patrol-log-header": "דאס איז א לאג-בוך פון פאַטראלירטע רעוויזיעס.", - "log-show-hide-patrol": "$1 פאַטראלירן לאג-בוך", - "log-show-hide-tag": "$1 טאג־לאגבוך", "confirm-markpatrolled-button": "יאָ", "confirm-markpatrolled-top": "מארקירן $3 פון $2 ווי קאנטראלירט?", "deletedrevision": "אויסגעמעקט אלטע ווערסיע $1.", diff --git a/languages/i18n/yo.json b/languages/i18n/yo.json index 823bfc7f87..7ad682b11c 100644 --- a/languages/i18n/yo.json +++ b/languages/i18n/yo.json @@ -9,7 +9,8 @@ "Macofe", "Matma Rex", "Wikicology", - "Fitoschido" + "Fitoschido", + "Olaniyan Olushola" ] }, "tog-underline": "Ìfàlàsábẹ́ àwọn àjápọ̀:", @@ -1045,6 +1046,7 @@ "recentchanges": "Àwọn àtúnṣe tuntun", "recentchanges-legend": "Àwọn àṣàyàn fún àtúnṣe tuntun", "recentchanges-summary": "Ẹ tẹ̀ lé àwọn àtúnṣe tuntun sí wiki lórí ojúewé yìí.", + "recentchanges-noresult": "Kò sì áwọ́n iyipada ni akókò yì ti o ba àwon ìlànà yí mu.", "recentchanges-feed-description": "Ẹ tẹ̀ lé àwọn àtúnṣe àìpẹ́ ọjọ́ sí wiki nínú àkótán feed yìí.", "recentchanges-label-newpage": "Àtúnṣe yìí dá ojúewé tuntun", "recentchanges-label-minor": "Àtùnṣe kékeré nìyí", @@ -2216,7 +2218,6 @@ "markedaspatrollederrornotify": "Ìkùnà ìṣàmìsí bíi sísọ́.", "patrol-log-page": "Àkọọ́lẹ̀ ìsọ́", "patrol-log-header": "Àkọọ́lẹ̀ àwọn àtúnyẹ̀wò sísọ́ nì yí.", - "log-show-hide-patrol": "$1 àkọọ́lẹ̀ ìsọ́", "confirm-markpatrolled-button": "OK", "deletedrevision": "Àtúnyẹ̀wò àtijọ́ píparẹ́ $1", "filedeleteerror-short": "Àsìṣe ìparẹ́ fáílì: $1", diff --git a/languages/i18n/yue.json b/languages/i18n/yue.json index b88ce6d0e0..9cf705988e 100644 --- a/languages/i18n/yue.json +++ b/languages/i18n/yue.json @@ -639,7 +639,7 @@ "previewerrortext": "預覽你嘅修改嗰陣出錯。", "blockedtitle": "用戶已經封鎖", "blockedtext": "你嘅用戶名或者IP地址已經俾人封咗。\n\n呢次封鎖係由$1所封嘅。\n俾咗嘅原因係$2。\n\n* 呢次封鎖嘅開始時間係:$8\n* 呢次封鎖嘅到期時間係:$6\n* 被封鎖者:$7\n\n你可以聯絡 $1 或者其他嘅[[{{MediaWiki:Grouppage-sysop}}|管理員]]討論呢次封鎖。\n除非你已經響你嘅[[Special:Preferences|戶口喜好設定]]入面設定咗有效嘅電郵地址,否則你係唔可以用「{{int:emailuser}}」嘅功能。當設定咗一個有效嘅電郵地址之後,呢個功能係唔會被封鎖嘅。\n你現時嘅IP地址係 $3 ,而個封鎖ID係 #$5。\n請喺你嘅查詢都註明以上封鎖嘅資料。", - "autoblockedtext": "你嘅IP地址已經被自動封鎖,由於之前嘅另一位用戶係畀$1封咗。\n而封鎖嘅原因係:\n\n:''$2''\n\n* 呢次封鎖嘅開始時間係:$8\n* 呢次封鎖嘅到期時間係:$6\n* 對於被封鎖者:$7\n\n你可以聯絡 $1 或者其他嘅[[{{MediaWiki:Grouppage-sysop}}|管理員]],討論呢次封鎖。\n\n除非你已經響你嘅[[Special:Preferences|戶口喜好設定]]入面設定咗有效嘅電郵地址,否則你係唔可以用「電郵呢個用戶」嘅功能。當設定咗一個有效嘅電郵地址之後,呢個功能係唔會封鎖嘅。\n\n你現時用緊嘅 IP 地址係 $3,個封鎖 ID 係 #$5。 請喺你嘅查詢都註明呢個封鎖上面嘅資料。", + "autoblockedtext": "你嘅IP地址已經被自動封鎖,原因係之前嘅另一位用戶係畀$1封咗。\n而封鎖嘅原因係:\n\n:''$2''\n\n* 呢次封鎖嘅開始時間係:$8\n* 呢次封鎖嘅到期時間係:$6\n* 對於被封鎖者:$7\n\n你可以聯絡 $1 或者其他嘅[[{{MediaWiki:Grouppage-sysop}}|管理員]],討論呢次封鎖。\n\n除非你已經響你嘅[[Special:Preferences|戶口喜好設定]]入面設定咗有效嘅電郵地址,否則你係唔可以用「電郵呢個用戶」嘅功能。當設定咗一個有效嘅電郵地址之後,呢個功能係唔會封鎖嘅。\n\n你現時用緊嘅 IP 地址係 $3,個封鎖 ID 係 #$5。 請喺你嘅查詢都註明呢個封鎖上面嘅資料。", "systemblockedtext": "你嘅用戶名或者IP地址已經俾MediaWiki自動封鎖。\n封鎖原因係:\n\n:$2\n\n* 開始時間:$8\n* 到期時間:$6\n* 目標用戶:$7\n\n你而家嘅IP地址係$3。\n當你作出任何查詢嘅時候,請包含以上所有資料。", "blockednoreason": "無原因畀低", "whitelistedittext": "你需要$1去編輯呢頁。", @@ -1287,6 +1287,8 @@ "rcfilters-other-review-tools": "第啲檢閱架撐", "rcfilters-group-results-by-page": "將相同頁面嘅結果夾埋", "rcfilters-activefilters": "用緊嘅篩選條件", + "rcfilters-activefilters-hide": "隱藏", + "rcfilters-activefilters-show": "顯示", "rcfilters-advancedfilters": "進階嘅篩選條件", "rcfilters-limit-title": "顯示幾多結果", "rcfilters-limit-and-date-label": "$1次{{PLURAL:$1|改動}},$2", @@ -1348,6 +1350,7 @@ "rcfilters-filter-humans-description": "真人做嘅編輯", "rcfilters-filtergroup-reviewstatus": "巡查狀態", "rcfilters-filter-reviewstatus-unpatrolled-label": "未巡查", + "rcfilters-filter-reviewstatus-auto-label": "已經自動巡查咗", "rcfilters-filtergroup-significance": "顯著度", "rcfilters-filter-minor-label": "細編輯", "rcfilters-filter-minor-description": "作者話程度細嘅修改。", @@ -2608,7 +2611,6 @@ "markedaspatrollederrornotify": "標做睇過失敗。", "patrol-log-page": "巡查日誌", "patrol-log-header": "呢個係已經巡查過嘅日誌。", - "log-show-hide-patrol": "$1巡查紀錄", "confirm-markpatrolled-button": "好", "deletedrevision": "刪除咗$1嘅舊有修訂", "filedeleteerror-short": "刪除檔案出錯: $1", diff --git a/languages/i18n/zgh.json b/languages/i18n/zgh.json index 1829c878b4..9cc2440333 100644 --- a/languages/i18n/zgh.json +++ b/languages/i18n/zgh.json @@ -13,11 +13,34 @@ }, "tog-underline": "ⵉⵣⵔⵉⵔⴳ ⴷⴷⵓ ⵓⵙⵖⵏ", "tog-hideminor": "ⵙⵙⵏⵜⵍ ⵜⵉⵙⵏⴼⵉⵍⵉⵏ ⵜⵉⵎⵥⵥⴰⵏⵉⵏ ⵙⴳ ⵉⵙⵏⴼⵍⵏ ⵉⵏⴳⴳⵓⵔⴰ", + "tog-hidepatrolled": "ⵙⵙⵏⵜⵍ ⵉⵙⵏⵉⴼⵉⵍⵏ ⵎⵉ ⵉⵜⵜⵓⴳⴰ ⵓⵣⵣⵔⴰⵢ ⴳ ⵉⵙⵏⵉⴼⵉⵍⵏ ⵉⵎⴳⴳⵓⵔⴰ", + "tog-newpageshidepatrolled": "ⵙⵙⵏⵜⵍ ⵜⴰⵙⵏⵉⵡⵉⵏ ⵎⵉ ⵉⵜⵜⵓⴳⴰ ⵓⵣⵣⵔⴰⵢ ⴳ ⵜⵍⴳⴰⵎⵜ ⵏ ⵜⴰⵙⵏⵉⵡⵉⵏ ⵜⵉⵎⴰⵢⵏⵓⵜⵉⵏ", "tog-hidecategorization": "ⵙⵙⵏⵜⵍ ⴰⵙⵎⵉⵍ ⵏ ⵜⴰⵙⵏⵉⵡⵉⵏ", + "tog-extendwatchlist": "ⵙⵙⵉⵔⵉⵡ ⵜⴰⵍⴳⴰⵎⵜ ⵏ ⵓⴹⴼⴼⵓⵔ ⴰⴼⴰⴷ ⴰⴷ ⵜⵙⴽⵏⴷ ⵉⵙⵏⵉⴼⵉⵍⵏ ⴰⴽⴽ ⵓⵔ ⴷ ⵖⴰⵙ ⵉⵎⴳⴳⵓⵔⴰ", + "tog-usenewrc": "ⵙⵎⵓⵏ ⵉⵙⵏⴼⵍⵏ ⴷ ⵜⴰⵙⵏⴰ ⵏⵙⵏ ⴳ ⵉⵙⵏⴼⵍⵏ ⵉⵎⴳⴳⵓⵔⴰ ⴷ ⵜⴰⵍⴳⴰⵎⵜ ⵏ ⵓⴹⴼⵓⵔ", + "tog-numberheadings": "ⴰⵙⵓⵟⵟⵏ ⴰⵡⵓⵔⵎⴰⵏ ⵏ ⵉⵣⵡⵍⴰⵏ", + "tog-showtoolbar": "ⵙⴽⵏ ⵜⴰⵙⵙⴼⵉⴼⵜ ⵏ ⵉⵎⴰⵙⵙⵏ ⵏ ⵓⵥⵔⴰⴳ", + "tog-editondblclick": "ⵙⵏⴼⵍ ⵜⴰⵙⵏⵉⵡⵉⵏ ⵙ ⵙⵉⵏ ⵉⴽⵍⵉⴽⵉⵜⵏ", + "tog-editsectiononrightclick": "ⵙⵙⵔⵎⴷ ⴰⵙⵏⴼⵍ ⵏ ⵜⵣⵓⵏⵉⵡⵉⵏ ⵙ ⵢⴰⵏ ⵓⴽⵍⵉⴽⵉ ⵖⴼ ⵉⵣⵡⵍⴰⵏ ⵏ ⵜⵣⵓⵏⵉ", + "tog-watchcreations": "ⵔⵏⵓ ⵖⵔ ⵜⴳⵍⴰⵎⵜ ⵉⵏⵓ ⵏ ⵓⴹⴼⴼⵓⵔ ⵜⴰⵙⵏⵉⵡⵉⵏ ⵏⵏⴰ ⵙⴽⵔⵖ ⴷ ⵉⴼⵓⵢⵍⴰ ⵏⵏⴰ ⴷ ⵙⴽⵛⵎⵖ", + "tog-watchdefault": "ⵔⵏⵓ ⵉ ⵜⵍⴳⴰⵎⵜ ⵉⵏⵓ ⵏ ⵓⴹⴼⴼⵓⵔ ⵜⴰⵙⵏⵉⵡⵉⵏ ⴷ ⵉⴼⵓⵢⵍⴰ ⵏⵏⴰ ⵙⵏⴼⴰⵍⵖ", + "tog-watchmoves": "ⵔⵏⵓ ⵜⴰⵙⵏⵉⵡⵉⵏ ⴷ ⵉⴼⵓⵢⵍⴰ ⵏⵏⴰ ⵙⵎⵓⵜⵜⵉⵖ ⵉ ⵜⵍⴳⴰⵎⵜ ⵉⵏⵓ ⵏ ⵓⴹⴼⴼⵓⵔ", + "tog-watchdeletion": "ⵔⵏⵓ ⵉ ⵜⴰⵙⵏⴰ ⵉⵏⵓ ⵏ ⵓⴹⴼⴼⵓⵔ ⵜⴰⵙⵏⵉⵡⵉⵏ ⴷ ⵉⴼⵓⵢⵍⴰ ⵏⵏⴰ ⴽⴽⵙⵖ", + "tog-watchuploads": "ⵔⵏⵓ ⵉⴼⵓⵢⵍⴰ ⵉⵎⴰⵢⵏⵓⵜⵏ ⵏⵏⴰ ⴷ ⵙⴽⵛⵎⵖ ⵉ ⵜⵍⴳⴰⵎⵜ ⵉⵏⵓ ⵏ ⵓⴹⴼⴼⵓⵔ", + "tog-watchrollback": "ⵔⵏⵓ ⵜⴰⵙⵏⵉⵡⵉⵏ ⵍⵍⵉ ⵅⴼ ⵙⴽⵔⵖ ⴰⵡⵔⵔⵉ ⵉ ⵜⵍⴳⴰⵎⵜ ⵏ ⵓⴹⴼⴼⵓⵔ ⵉⵏⵓ", "tog-minordefault": "ⵕⵛⵎ ⵎⴰⵕⵕⴰ ⵉⵙⵏⴼⵍⵏ ⵎⵥⵥⵉⵢⵏⵉⵏ ⵙ ⵓⵡⵏⵓⵍ", + "tog-previewontop": "ⵙⴽⵏ ⴰⴱⵔⵉⴼⵢⵓ ⵉⴳⴳⵉ ⵏ ⵓⴷⵖⴰⵔ ⵏ ⵓⵙⵏⴼⵍ", + "tog-previewonfirst": "ⵙⴽⵏ ⴰⴱⵔⵉⴱⵢⵓ ⴳ ⵓⵙⵏⴼⵍ ⵉⵣⵡⴰⵔⵏ", + "tog-enotifwatchlistpages": "ⴰⵣⵏ ⵢⵉ ⵏⵏ ⴳ ⵉⵎⴰⵢⵍ ⴰⴽⵓⴷ ⵏⵏⴰ ⵜⵡⴰⵙⵙⵏⴼⵍ ⴽⵔⴰ ⵏ ⵜⴰⵙⵏⴰ ⵏⵖ ⴰⴼⴰⵢⵍⵓ ⵉⵍⵍⴰⵏ ⴳ ⵜⵍⴳⴰⵎⵜ ⵏ ⵓⴹⴼⴼⵓⵔ ⵉⵏⵓ", + "tog-enotifusertalkpages": "ⴰⵣⵏ ⵢⵢⵉ ⵏⵏ ⵉⵎⴰⵢⵍ ⴰⴽⵓⴷ ⵏⵏⴰ ⵜⵡⴰⵙⵙⵏⴼⵍ ⵜⴰⵙⵏⴰ ⵏ ⵓⵎⵙⴰⵡⴰⵍ ⵉⵏⵓ", + "tog-enotifminoredits": "ⴰⵣⵏ ⵢⵢⵉ ⵏⵏ ⴰⵍⵜⵓ ⵉⵎⴰⵢⵍ ⵅⴼ ⵉⵙⵏⴼⵍⵏ ⵉⵎⵣⵢⴰⵏⵏ ⵏ ⵜⴰⵙⵏⵉⵡⵉⵏ ⴷ ⵉⴼⴰⵢⵍⵓⵜⵏ", + "tog-watchlisthideown": "ⵙⵙⵏⵜⵍ ⵉⵙⵏⵉⴼⵉⵍⵏ ⵉⵏⵓ ⵙⴳ ⵜⵍⴳⴰⵎⵜ ⵏ ⵓⴹⴼⴼⵓⵔ", + "tog-watchlisthidebots": "ⵙⵙⵏⵜⵍ ⵉⵙⵏⵉⴼⵉⵍⵏ ⵏ ⵉⵔⵓⴱⵓⵜⵏ ⵙⴳ ⵜⵍⴳⴰⵎⵜ ⵏ ⵓⴹⴼⴼⵓⵔ", + "tog-watchlisthideminor": "ⵙⵙⵏⵜⵍ ⵉⵙⵏⵉⴼⵉⵍⵏ ⵉⵎⵥⵢⴰⵏⴻⵏ ⵙⴳ ⵜⵍⴳⴰⵎⵜ ⵏ ⵓⴹⴼⴼⵓⵔ", "tog-ccmeonemails": "ⴰⵣⵏ ⵉⵢⵉ ⴷ ⵜⵓⵏⵖⵉⵍⵉⵏ ⵏ ⵉⵎⴰⵢⵍⵏ ⵏⵏⴰ ⵓⵣⵏⵖ ⵉ ⵉⵎⵙⵙⵎⵔⵙⵏ ⵢⴰⴹⵏ", "tog-diffonly": "ⴰⴷ ⵓⵔ ⵜⵙⵙⴽⴷ ⵜⵓⵎⴰⵢⵜ ⵏ ⵜⴰⵙⵏⴰ ⴷⴷⵓ ⵉⵎⵣⴰⵔⴰⵢⵏ", "tog-showhiddencats": "ⵙⴽⵏ ⵜⴰⴳⴳⴰⵢⵉⵏ ⵉⵜⵜⵓⵃⴹⴰⵏ", + "underline-always": "ⴽⵓ ⴰⵙⵙ", "underline-never": "ⵓⵙⴰⵔ", "sunday": "ⴰⵙⴰⵎⴰⵙ", "monday": "ⴰⵢⵏⴰⵙ", @@ -35,7 +58,7 @@ "sat": "ⴰⵙⴹ", "january": "ⵉⵏⵏⴰⵢⵔ", "february": "ⴱⵕⴰⵢⵕ", - "march": "ⵎⴰⵕⵚ", + "march": "ⵎⴰⵔⵙ", "april": "ⵉⴱⵔⵉⵔ", "may_long": "ⵎⴰⵢⵢⵓ", "june": "ⵢⵓⵏⵢⵓ", @@ -59,7 +82,7 @@ "december-gen": "ⴷⵓⵊⴰⵏⴱⵉⵔ", "jan": "ⵉⵏⵏ", "feb": "ⴱⵕⴰ", - "mar": "ⵎⴰⵕ", + "mar": "ⵎⴰⵔ", "apr": "ⴱⵕⴰ", "may": "ⵎⴰⵢ", "jun": "ⵢⵓⵏ", @@ -108,6 +131,7 @@ "navigation": "ⴰⵙⵜⴰⵔⴰ", "and": " ⴷ", "faq": "FAQ", + "actions": "ⵉⴳⵉⵜⵏ", "namespaces": "ⵜⵉⵔⵉⵡⵉⵏ ⵏ ⵉⵙⵎⴰⵡⵏ", "variants": "ⵜⵉⵎⵣⴰⵔⴰⵢⵉⵏ", "navigation-heading": "ⵓⵎⵓⵖ ⵏ ⵓⵙⵙⴰⵔⴰ", @@ -159,6 +183,7 @@ "pool-errorunknown": "ⵜⴰⵣⴳⴰⵍⵜ ⵜⴰⵔⵓⵙⵙⵉⵏⵜ", "aboutsite": "ⵖⴼ {{SITENAME}}", "aboutpage": "Project:ⵖⴼ", + "copyright": "ⵜⵓⵎⴰⵢⵜ ⵜⵍⵍⴰ ⴷⴷⵓ ⵜⵓⵔⴰⴳⵜ $1 ⵖⴰⵙ ⵎⴰ ⵉⵜⵜⵡⴰⴱⴷⴰⵔ ⵓⵏⵎⴳⴰⵍⵏⵏⵙ.", "copyrightpage": "{{ns:project}}:ⵉⵣⵔⴼⴰⵏ ⵏ ⵓⵙⵏⵖⵍ", "currentevents": "ⵜⵉⵎⵙⴰⵔⵉⵏ ⵜⵉⵎⵉⵔⴰⵏⵉⵏ", "currentevents-url": "Project:ⵜⵉⵎⵙⴰⵔⵉⵏ ⵜⵉⵎⵉⵔⴰⵏⵉⵏ", @@ -209,6 +234,7 @@ "nosuchspecialpage": "ⴰⵡⴷ ⵢⴰⵜ ⵜⴰⵙⵏⴰ ⵉⵥⵍⵉⵏ.", "nospecialpagetext": "ⵜⴻⵜⵜⵔⴷ ⵢⴰⵜ ⵜⴰⵙⵏⴰ ⵉⵥⵍⵉⵏ ⵓⵔ ⵉⴱⵓⵏⵉⵏ\n\nⵢⴰⵜ ⵜⵍⴳⴰⵎⵜ ⵏ ⵜⴰⵙⵏⵉⵡⵉⵏ ⵉⵥⵍⵉⵏ ⵔⴰⴷ ⵜⵜ ⵜⴰⴼⴷ ⴳ [[Special:SpecialPages|{{int:specialpages}}]].", "error": "ⵜⴰⵣⴳⵍⵜ", + "databaseerror-function": "ⵜⴰⵙⵖⵏⵜ: $1", "databaseerror-error": "ⵜⴰⵣⴳⵍⵜ: $1", "badtitle": "ⴳⴰⵔ ⴰⵣⵡⵍ", "badtitletext": "ⴰⵣⵡⵍ ⵏ ⵜⴰⵙⵏⴰ ⵉⵜⵜⵡⴰⵜⵜⴰⵔⵏ ⵢⴰ ⵓⵔ ⵉⵏⵉⵎ ⵢⴰ ⵢⵓⵔⴰ ⵢⴰ ⵓⵔ ⵢⵉⵍⵉⵖ ⵎⵍⵉⵃ ⵎⴽ ⵉⴳⴰ ⵢⴰⵏ ⵓⵣⵡⵍ ⵉⵙⵎⴰⵏⴻⵏ ⵙⵏⴰⵜ ⵜⵓⵜⵍⴰⵢⵉⵏ ⵏⵖ ⵙⵉⵏ ⵢⵉⵙⵏⴼⴰⵔⵏ. ⵄⵏⵉⵖ ⴷⵉⴳⵙ ⵢⴰⵏ ⵏⵖ ⵎⵏⵏⴰⵡ ⵏ ⵢⵉⵙⴽⴽⵉⵍⵏ ⵙ ⵓⵔ ⵉⵙⵙⵉⵏ ⴰⴷ ⵜⵜⵓⵙⵎⵔⵙⵏ ⴳ ⵢⵉⵣⵡⵍⴰⵏ.", @@ -299,9 +325,11 @@ "accmailtitle": "ⵜⴰⴳⵓⵔⵉ ⵓⵣⵔⴰⵢ ⵜⴻⵜⵜⵡⴰⵣⵏ", "newarticle": "(ⴰⵎⴰⵢⵏⵓ)", "newarticletext": "ⵜⴹⴼⴰⵔⴷ ⵢⴰⵏ ⵓⵙⵖⵏ ⵖⵔ ⵢⴰⵜ ⵜⴰⵙⵏⴰ ⵏⵏⴰ ⵓⵔ ⵜⴰ ⵉⵍⵍⵉⵏ. \nⴰⴼⴰⴷ ⴰⴷ ⵜⵙⵏⵓⵍⴼⵓⴷ ⵜⴰⵙⵏⴰ, ⵙⵙⵏⵜⵉ ⵜⵉⵔⵔⴰ ⴳ ⵓⴼⵏⵉⵇ ⴳ ⵉⵣⴷⴷⴰⵔ (ⵥⵔ [$1 ⵜⴰⵙⵏⴰ ⵏ ⵜⵡⵉⵙⵉ] ⵉ ⵡⵓⴳⴳⴰⵔ ⵏ ⵉⵏⵖⵎⵉⵙⵏ). \nⵎⴽ ⵜⵍⵍⵉⴷ ⴷⴰ ⵙ ⵓⵣⴳⴰⵍ, ⴰⴽⵍ ⵖⴼ ⴰⵖⵓⵍ ⴳ ⵓⵙⴰⵔⴰ ⵏⵏⴽ.", + "anontalkpagetext": "----\nⵜⵍⵍⵉⴷ ⴳ ⵜⴰⵙⵏ ⵏ ⵓⵎⵙⴰⵡⴰⵍ ⵏ ⵢⴰⵏ ⵓⵏⵙⵙⵎⵔⵙ ⵡⴰⵔⵉⵙⵎ ⵏⵏⴰ ⵜⴰ ⵓⵔ ⵉⵙⴽⵉⵔⵏ ⴰⵎⵉⴹⴰⵏ ⵏⵖ ⵏⵏⴰ ⵜ ⵓⵔ ⵉⵙⵙⵎⵔⵉⵙⵏ.\nⴰⵢⴰ ⴰ ⵖⴼ ⵉⴼⵓⴽⴽ ⴰⴷ ⵏⵙⵙⵎⵔⵙ ⵜⴰⵏⵙⴰ ⵏⵏⵙ IP ⴼⴰⴷ ⴰⴷ ⵜ ⵏⵙⵎⴰⴳⵉ.\nⵢⴰⵜ ⵜⴰⵏⵙⴰ IP ⵥⴹⴰⵔⵏ ⴰⴷ ⵜⵜ ⵙⵙⵓⵔⵏ ⵎⵏⵏⴰⵡ ⵏ ⵉⵏⵙⵙⵎⵔⵙⵏ.\nⵎⴽ ⵜⴳⵉⴷ ⵢⴰⵏ ⵓⵏⵙⵙⵎⵔⵙ ⵡⴰⵔⵉⵙⵎ ⴷ ⴽ ⵜⵖⴹⴼⴷ ⵎⴰⵙ ⴽ ⵡⴰⵜⵙⵏ ⴽⵔⴰ ⵏ ⵉⵅⴼⴰⵡⴰⵍⵏ ⵓⵔ ⵙⵉⴽ ⵉⵥⵍⵉⵏ, ⵜⵓⴼⵉⴷ ⴰⴷ [[Special:CreateAccount|ⵙⴽⵔ ⵢⴰⵏ ⵓⵎⵉⴹⴰⵏ]] ⵏⵖ ⴷ [[Special:UserLogin|ⴽⵛⵎ]] ⴱⴰⵔ ⴰⴷ ⵜⴰⵏⴼⴷ ⵉ ⴽⵔⴰⵢⴳⴰⵜ ⴰⵎⵔⴽⵙ ⴷ ⵉⵎⴷⵔⴰⵡⵏ ⵢⴰⴹⵏ.", "noarticletext": "ⵓⵔ ⵉⵍⵍⵉ ⴽⵔⴰ ⵏ ⵓⴹⵔⵉⵙ ⴳ ⵜⴰⵙⵏⴰ ⴰⴷ ⵖⵉⵍⴰ. \nⵜⵣⵎⵔⴷ ⴰⴷ [[Special:Search/{{PAGENAME}}|ⵜⵔⵣⵓⴷ ⵖⴼ ⵓⵣⵡⵍ ⵏⵏⵙ]] ⴳ ⵜⴰⵙⵏⵉⵡⵉⵏ ⵢⴰⴹⵏ, [{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} ⵔⵣⵓ ⵖⴼ logs ⵖⵔⵙ ⵉⵇⵇⵏⴻⵏ],\nⵏⵖ [{{fullurl:{{FULLPAGENAME}}|action=edit}} ⵙⵏⵓⵍⴼⵓ ⵜⴰⵙⵏⴰ].", "noarticletext-nopermission": "ⴷⵖⵉ ⵓⵔ ⵉⵍⵍⵉ ⴰⵡⴷ ⴽⵔⴰ ⵏ ⵓⴹⵔⵉⵚ ⴳ ⵜⴰⵙⵏⴰ ⴰ.\nⵜⵣⵎⵔⴷ ⴰⴷ [[Special:Search/{{PAGENAME}}|ⵜⵔⵣⵓⴷ ⵖⴼ ⵓⵣⵡⵍ ⵏⵏⵙ]] ⴳ ⵜⴰⵙⵏⵉⵡⵉⵏ ⵢⴰⴹⵏⵉⵏ, ⵏⵖ [{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} ⵔⵣⵓ ⵖⴼ ⵉⵣⵎⵎⴻⵎⵏ ⵉⵣⴷⵉⵏ], ⵎⴰⵛⴰ ⵓⵔ ⴷⴰⵔⴽ ⵜⵓⵔⴰⴳⵜ ⴰⴷ ⵜⵙⵏⵓⵍⴼⵓⴷ ⵜⴰⵙⵏⴰ ⴰ.", "userpage-userdoesnotexist-view": "ⴰⵎⵉⴹⴰⵏ ⵏ ⵓⵎⵙⵙⵎⵔⵙ $1 ⵓⵔ ⵉⵜⵜⵓⵣⵎⵎⴻⵎ.", + "clearyourcache": "ⵜⴰⵎⴰⵡⵜ : ⴷⴼⴼⵉⵔ ⴰⴷ ⵜⵙⴽⵍⵙⵍ ⵉⵙⵏⵉⴼⵉⵍⵏ ⵏⵏⴽ (ⵎ), ⵄⵏⵉⵖ ⵉⵇⵇⴰⵏ ⴷ ⴰⴷ ⵜⵙⵙⴽⵜⵔⴷ ⵜⵉⵏⵏⵓⵜⵍⴰ ⵏ ⵓⵎⵙⵜⴰⵔⴰ ⴰⴼⴰⴷ ⴰ ⵜⵥⵔⴷ ⵉⵙⵏⵉⴼⵉⵍⵏ.\n* ⴼⴰⵔⴼⵓⴽⵙ / ⵙⴰⴼⴰⵔⵉ : ⴰⵊⵊ ⴰⴹⴰⴹ ⵖⴼ ⵜⵙⴰⵔⵓⵜ Maj (Shift) ⵜⴰⴷⵔⴷ ⵉ ⵜⵙⴰⵔⵓⵜ Actualiser ⵏⵖ ⴰⴷⴷ ⵉ Ctrl-F5 ⵏⵖ Ctrl-R (⌘-R ⵖⴼ Mac) \n* ⴳⵓⴳⵍ ⴽⵔⵓⵎ : ⴰⴷⴷ ⵉ Ctrl-Maj-R (⌘-Shift-R ⴳ Mac) \n* ⴰⵏⵜⵉⵔⵏⵉⵜ ⵉⴽⵙⴱⵍⵓⵔⴻⵔ : ⴰⵊⵊ ⴰⴹⴰⴹ ⵖⴼ ⵜⵙⴰⵔⵓⵜ Ctrl ⵜⴰⴽⵍⴷ ⵜⵙⴰⵔⵓⵜ Actualiser ⵏⵖ ⵜⵓⴽⵍⴷ Ctrl-F5 \n* ⵓⴱⵉⵔⴰ : ⴷⴷⵓ ⵖⵔ ⵓⵎⵓⵖ → ⵜⵉⵙⵖⴰⵍ (ⵓⴱⵉⵔⴰ → ⵉⵙⵏⵢⵉⴼⵏ ⵖⴼ Mac) ⵙⴰⴽⵉⵏ ⵜⵓⵥⵍⵉⵢⵉⵏ ⴷ ⵜⵖⵍⵙⵜ → ⵙⴼⴹ ⵉⵙⴼⴽⴰ ⵏ ⵓⵙⴼⵓⴽⴽⵔ → ⵜⵓⴳⵏⵉⵡⵉⵏ ⴷ ⵉⴼⵓⵢⵍⴰ ⵉⵍⵍⴰⵏ ⴳ ⵜⵉⵏⵏⵓⵜⵍⴰ.", "previewnote": "ⴽⵜⵉ ⴷ ⵎⴰⵙ ⵓⵔ ⵜⴳⵉ ⵖⴰⵙ ⴰⵣⵔⵙⴽⴰⵏ.\nⵉⵙⵏⵉⴼⵉⵍⵏ ⵏⵏⴽ ⵓⵔ ⵜⴰ ⵜⵜⵓⵙⴽⵍⴰⵙⵏ!", "continue-editing": "ⴷⴷⵓ ⵙ ⴰⵏⵙⴰ ⵏ ⵓⵙⵏⴼⵍ", "editing": "ⴰⵙⵏⴼⵍ ⵏ $1", @@ -315,6 +343,7 @@ "hiddencategories": "ⵜⴰⵙⵏⴰ ⴰ ⴷ ⴰⴳⵎⴰⵎ ⵏ {{PLURAL:$1|1 ⵏⵜⵍ ⴰⵙⵎⵉⵍ|$1 ⵏⵜⵍ ⵉⵙⵎⵉⵍⵏ}}:", "permissionserrors": "ⴰⵙⵙⵓⵔⴳ ⵉⵣⴳⵜ", "permissionserrorstext-withaction": "ⵓⵔ ⴷⴰⵔⴽ ⵜⵓⵔⴰⴳⵜ ⴰⴼⴰⴷ ⴰⴷ $2, ⵙ {{PLURAL:$1|reason|reasons}}:", + "recreate-moveddeleted-warn": "ⴰⵡⵢ ⵉⵜⵏⴰⵏ : ⵀⴰⵜ ⴰⵔ ⵜⵙⴽⴰⵔⴷ ⵢⴰⵜ ⵜⴰⵙⵏⴰ ⵏⵏⴰ ⵜⵜ ⵏⵏ ⵉⴽⴽⴰⵏ ⵜⴻⵜⵜⵡⴰⴽⴽⵙ.\n\nⵏⵥⵉ ⴳ ⵉⵙ ⵉⵙⵙⵏ ⴰⴷ ⵜⵙⵎⴷⴻⴷ ⴳ ⵉⵙⵏⵉⴼⵉⵍⵏ ⵖⴼ ⵜⴰⵙⵏⴰ ⴰⴷ. \nⵜⵉⵎⵙⵙⴽⵜⵉⵜⵉⵏ ⵏ ⵜⵓⴽⴽⵙⵉⵡⵉⵏ ⴷ ⵉⵙⵎⵓⵜⵜⵓⵢⵏ ⵏ ⵜⴰⵙⵏⴰ ⴰⴷ, ⵍⵍⴰⵏⵜ ⴷⴰ ⵉ ⵓⵙⵏⵖⵎⵙ :", "moveddeleted-notice": "ⵜⴰⵙⵏⴰ ⴰⴷ ⵜⴻⵜⵜⵡⴰⴽⴽⵙ.\nⵜⵉⵎⵙⵙⴽⵜⵉⵜⵉⵏ ⵏ ⵜⵓⴽⴽⵙⵉⵡⵉⵏ, ⵉⴼⵔⴰⴳⵏ ⴷ ⵉⵙⵎⵓⵜⵜⵓⵢⵏ ⵉⵜⵜⵓⴳⴰⵏ ⵉ ⵜⴰⵙⵏⴰ ⵜⵜⵓⵙⴽⴰⵏⴻⵏ ⴳ ⵢⵉⵣⴷⴰⵔ ⴰⵎ ⵉⵙⴰⵖⵓⵍⵏ.", "content-model-wikitext": "wikitext", "content-model-javascript": "JavaScript", @@ -329,6 +358,7 @@ "cur": "ⵎⵔⵏ", "last": "ⵓⵣⵡⵔ", "page_last": "ⴰⵎⴳⴳⴰⵔⵓ", + "histlegend": "ⴰⵙⵜⴰⵢ ⵏ ⵓⵎⵣⴰⵔⴰⵢ : ⵔⵛⵎ ⵜⴰⵏⴽⵓⵍⵉⵏ ⵏ ⵜⵓⵏⵖⵉⵍⵉⵏ ⵏⵏⴰ ⵜⵔⵉⴷ ⴰⴷ ⵜⵙⵎⵣⴰⵣⴰⵍⴷ ⵜⴰⴷⵔⴷ ⵉ ⴰⴽⵎ ⵏⵖ ⵉ ⵜⵙⴰⵔⵓⵜ ⵏ ⵢⵉⵣⴷⴰⵔ.
\nⵜⴰⴱⴰⴷⵓⵜ : ({{int:cur}}) = ⴰⵎⵣⴰⵔⴰⵢ ⴰⴽⴷ ⵜⵓⵏⵖⵉⵍⵜ ⵜⴰⵎⴳⴳⴰⵔⵓⵜ, ({{int:last}}) = ⴰⵎⵣⴰⵔⴰⵢ ⴰⴽⴷ ⵜⵓⵏⵖⵉⵍⵜ ⵉⵣⵔⵉⵏ, {{int:minoreditletter}} = ⵉⵙⵏⵉⴼⵉⵍⵏ ⵉⵎⵥⵥⵉⵢⵏ.", "history-fieldset-title": "ⵔⵣⵓ ⵖⴼ ⵉⵣⵣⵔⴰⵢⵏ", "histfirst": "ⴰⵇⴱⵓⵔ", "histlast": "ⴰⵎⴰⵢⵏⵓ", @@ -348,6 +378,7 @@ "editundo": "ⵙⵔ", "diff-empty": "(ⵓⵔ ⵉⵍⵍⵉ ⵓⵎⵣⴰⵔⴰⵢ)", "diff-multi-sameuser": "({{PLURAL:$1|ⴽⵔⴰ ⵏ ⵓⵣⵣⵔⴰⵢ ⵉⵏⵏⵓⵎⵎⵙⵏ ⵉⵙⴽⵔ ⵓⵏⵙⵙⵎⵔⵙ ⵉⴳⴰⵏ ⵢⴰⵏ ⵓⵔ ⵜⴻⵜⵜⵓⵙⴽⴰⵏ|$1 ⴽⵔⴰ ⵏ ⵉⵣⵣⵔⴰⵢⵏ ⵉⵏⵏⵓⵎⵎⵙⵏ ⵉⵙⴽⵔ ⵓⵏⵙⵙⵎⵔⵙ ⵉⴳⴰⵏ ⵢⴰⵏ ⵓⵔ ⵜⵜⵓⵙⴽⴰⵏⴻⵏⵜ}})", + "diff-multi-otherusers": "({{PLURAL:$1|ⵢⴰⵏ ⵓⵣⵣⵔⴰⵢ ⴰⵎⵏⵏⵓⵎⵎⵙ|$1 ⵏ ⵉⵣⵣⵔⴰⵢⵏ ⵉⵎⵏⵏⵓⵎⵎⵙⵏ}} ⵏ {{PLURAL:$2|ⵢⴰⵏ ⵓⵏⵙⵙⵎⵔⵙ ⵢⴰⴹⵏ|$2 ⵏ ⵉⵏⵙⵙⵎⵔⵙⵏ}} ⵓⵔ ⵉⵜⵜⵓⵙⴽⴰⵏⴻⵏ).", "searchresults": "ⵜⵉⵢⴰⴼⵓⵜⵉⵏ ⵏ ⵓⵔⵣⵣⵓ", "searchresults-title": "ⵜⵉⵢⴰⴼⵓⵜⵉⵏ ⵏ ⵓⵔⵣⵣⵓ ⵖⴼ \"$1\"", "prevn": "{{PLURAL:$1|$1}} ⵉⵎⵣⵡⵓⵔⴰ", @@ -476,7 +507,7 @@ "filehist-revert": "ⵔⴰⵔ ⴷ", "filehist-current": "ⴰⵎⵉⵔⴰⵏ", "filehist-datetime": "ⴰⵙⴰⴽⵓⴷ/ⴰⴽⵓⴷ", - "filehist-thumb": "ⵜⴰⵛⵏⵢⴰⵍⵜ", + "filehist-thumb": "ⵜⴰⵡⵍⴰⴼⵜ ⵎⵥⵥⵉⵢⵏ", "filehist-thumbtext": "ⵜⴰⵛⵏⵢⴰⵍⵜ ⵏ ⵜⵓⵏⵖⵉⵍⵜ ⴳ $1", "filehist-nothumb": "ⵓⵔ ⵉⵍⵍⵉ ⵓⵙⵎⵥⵉⵢ", "filehist-user": "ⴰⵙⵎⵔⴰⵙ", @@ -484,6 +515,7 @@ "filehist-comment": "ⴰⵖⴼⴰⵡⴰⵍ", "imagelinks": "ⴰⵙⵎⵔⵙ ⵏ ⵓⴼⴰⵢⵍⵓ", "linkstoimage": "{{PLURAL:$1|ⵉⵣⴷⴰⵢⵏ ⵏ ⵜⵙⵏⴰ|$1 ⴰⵣⴷⴰⵢ ⵏ ⵜⵙⵏⴰ}} ⵖⵔ ⵓⴼⴰⵢⵍⵓ ⴰⴷ:", + "linkstoimage-more": "ⵓⴳⴳⴰⵔ ⵏ {{PLURAL:$1|ⵢⴰⵜ ⵜⴰⵙⵏⴰ ⴰⵢⴷ ⵉⵙⵙⵎⵔⴰⵙⵏ| $1 ⵏ ⵜⴰⵙⵏⵉⵡⵉⵏ ⴰⵢⴷ ⵉⵙⵙⵎⵔⴰⵙⵏ}} ⴰⴼⴰⵢⵍⵓ ⴰⴷ.\nⵜⵙⴽⴰⵏ ⵜⵍⴳⴰⵎⵜ ⴰⴷ ⵖⴰⵙ {{PLURAL:$1|ⵜⴰⵙⵏⴰ ⵜⴰⵎⵣⵡⴰⵔⵓⵜ ⵉⵙⵙⵎⵔⴰⵙⵏ $1 ⵜⴰⵙⵏⵉⵡⵉⵏ ⵜⵉⵎⵣⵡⴰⵔⴰ ⵉⵙⵙⵎⵔⴰⵙⵏ}} ⴰⴼⴰⵢⵍⵓ ⴰⴷ.\nⵜⵍⵍⴰ ⵢⴰⵜ [[Special:WhatLinksHere/$2|ⵜⴰⵍⴳⴰⵎⵜ ⵉⵎⴷⵏ]].", "nolinkstoimage": "ⵓⵔ ⵍⵍⵉⵏⵜ ⵜⴰⵙⵏⵉⵡⵉⵏ ⵏⵏⴰ ⵉⵇⵇⵏⴻⵏ ⵖⵔ ⵓⴼⴰⵢⵍⵓ ⴰ.", "linkstoimage-redirect": "$1 (ⴰⵙⵡⴰⵍⴰ ⵏ ⵓⴼⴰⵢⵍⵓ) $2", "sharedupload-desc-here": "ⴰⵙⴷⴰⵡ ⴰⴷ ⵙⴳ $1 ⵉⵥⴹⴰⵔ ⴰ ⵉⵜⵜⵡⴰⵙⵎⵔⵙ ⴳ ⵉⵙⵏⵜⴰⵢⵏ ⵢⴰⴹⵏ.\nⴰⵙⵏⵓⵎⵎⵍ ⵏⵙ ⴳ [$2 ⵜⴰⵙⵏⴰ ⵏⵙ ⵏ ⵓⵙⵏⵓⵎⵎⵍ] ⵜⵡⴰⵙⵎⴰⵍ ⵙⴰⴷⵓ.", @@ -522,6 +554,7 @@ "speciallogtitlelabel": "ⴰⵙⴰⵖⴷ (ⴰⵣⵡⵍ ⵏⵖ {{ns:user}}:ⵉⵙⵎ ⵏ ⵓⵏⵙⵙⵔⵙ) :", "log": "ⵉⵣⵎⵎⴻⵎⵏ", "all-logs-page": "ⵜⵉⵎⵙⵙⴽⵜⵉⵜⵉⵏ ⴰⴽⴽ ⵜⵉⵣⴰⵢⵣⵉⵏ", + "alllogstext": "ⴰⵙⴽⴰⵏ ⵉⵎⵎⵔⴽⵙⵏ ⵏ ⵜⵎⵙⵙⴽⵜⵉⵜⵉⵏ ⴰⴽⴽ ⵉⵍⵍⴰⵏ ⴳ {{SITENAME}}.\nⵜⵓⴼⵉⴷ ⴰⴷ ⵜⵙⵏⵏⵥⵍⵉⴷ ⴰⵙⴽⴰⵏ ⵙ ⵓⵙⵜⴰⵢ ⵏ ⵡⴰⵏⴰⵡ ⵏ ⵜⵎⵙⵙⴽⵜⵉⵜ, ⵉⵙⵎ ⵏ ⵓⵏⵙⵙⵎⵔⵙ ⵏⵖ ⵜⴰⵙⵏⴰ ⵉⴳⴰ ⵡⴰⴷⴷⴰⴷ (ⵙⵉⵏ ⵉⵎⴳⴳⵓⵔⴰ ⴰⴷ ⵇⵇⵏⴻⵏ ⵖⵔ ⵓⵙⵎⵉⵍ).", "logempty": "ⵓⵔ ⵜⵍⵍⵉ ⴰⵡⴷ ⵢⴰⵜ ⵜⵎⵀⵍⵜ ⵉⵎⵙⴰⵙⴰⵏ ⴳ ⵜⵎⵙⵙⴽⵜⵉⵜⵉⵏ.", "checkbox-all": "ⵎⴰⵕⵕⴰ", "allpages": "ⵜⴰⵙⵏⵉⵡⵉⵏ ⴰⴽⴽ", @@ -543,6 +576,7 @@ "unwatch": "ⴽⴽⵙ ⴰⴹⴼⴼⵓⵔ", "watchlist-details": "{{PLURAL:$1|$1 ⵜⴰⵙⵏⴰ|$1 ⵏ ⵜⴰⵙⵏⵉⵡⵉⵏ}} ⴳ ⵜⵍⴳⴰⵎⵜ ⵏ ⵓⴹⴼⴼⵓⵔ ⵏⵏⴽ (ⴰⴽⴷ ⵜⴰⵙⵏⵉⵡⵉⵏ ⵏ ⵓⵎⵙⴰⵡⴰⵍ).", "wlheader-showupdated": "ⵜⴰⵙⵏⵉⵡⵉⵏ ⵏⵏⴰ ⵉⵜⵜⵓⵙⵏⴼⵍⵏ ⵙⴳ ⵜⵔⵣⴼⵜ ⵏⵏⴳ ⵜⴰⵎⴳⴳⴰⵔⵓⵜ ⵜⵜⵓⵙⴽⴰⵏⴻⵏⵜ ⵙ ⴰⵣⵓⵔⴰⵔ.", + "wlnote": "ⴳ ⵓⴼⵍⵍⴰ, {{PLURAL:$1|ⵢⵓⵎⴰⵏ ⵓⵙⵏⴼⵍ ⴰⵎⴳⴳⴰⵔⵓ ⵉⵜⵜⵡⴰⵙⴽⴰⵔⵏ|ⵓⵎⴰⵏⴻⵏ $1 ⵏ ⵉⵙⵏⵉⴼⵉⵍⵏ ⵉⵎⴳⴳⵓⵔⴰ ⵉⵜⵜⵢⴰⵙⴽⴰⵔⵏ}} {{PLURAL:$2|ⵢⴰⵜ ⵜⵙⵔⴰⴳⵜ ⴰⵢⴰ|ⵢⴰⵏ $2 ⵏ ⵜⵙⵔⴰⴳⵉⵏ ⴰⵢⴰ}}, ⴰⵔ $3, $4.", "wlshowlast": "ⵙⴽⵏ $1 ⵜⴰⵙⵔⴰⴳⵉⵏ $2 ⵓⵙⵙⴰⵏ ⵉⵎⴳⴳⵓⵔⴰ", "watchlist-options": "ⵜⵉⴷⵖⵔⵉⵏ ⵏ ⵜⵍⴳⴰⵎⵜ ⵏ ⵓⴹⴼⴼⵓⵔ", "enotif_reset": "ⴷⵔⵣ ⵜⴰⵙⵏⵉⵡⵉⵏ ⴰⴽⴽ ⵏⵏⴰ ⵜⵔⵣⴼⴷ", @@ -654,7 +688,7 @@ "tooltip-n-currentevents": "ⴰⴼ ⵓⴳⴳⴰⵔ ⵏ ⵉⵏⵖⵎⵉⵙⵏ ⵖⴼ ⵜⵉⵎⵙⴰⵔⵉⵏ ⵜⵉⵎⵉⵔⴰⵏⵉⵏ", "tooltip-n-recentchanges": "ⵢⴰⵜ ⵜⵍⴳⴰⵎⵜ ⵏ ⵉⵙⵏⴼⵍⵏ ⵉⵎⴳⴳⵓⵔⴰ ⴳ ⵡⵉⴽⵉ", "tooltip-n-randompage": "ⵣⴷⵎ ⵜⴰⵙⵏⴰ ⵜⴰⴷⵀⵎⴰⵙⵜ", - "tooltip-n-help": "The place to find out", + "tooltip-n-help": "ⴰⴷⵖⴰⵔ ⴳ ⵜⴻⵜⵜⴰⴼⴰⴷ", "tooltip-t-whatlinkshere": "ⵓⵎⵓⵖ ⵏ ⵎⴰⵕⵕ ⵜⴰⵙⵏⵉⵡⵉⵏ ⵏ ⵡⵉⴽⵉ ⵉⵣⴷⵉⵏ ⵉ ⴷⴰ", "tooltip-t-recentchangeslinked": "ⵉⵙⵏⴼⵍⵏ ⵉⵏⴳⴳⵓⵔⴰ ⴳ ⵜⴰⵙⵏⵉⵡⵉⵏ ⵉⵣⴷⵉⵏ ⵖⵔ ⵜⴰⵙⵏⴰ ⴰ", "tooltip-feed-atom": "ⴰⵏⴳⵉ ⵏ ⴰⵜⵓⵎ ⵏ ⵜⴰⵙⵏⴰ ⴰⴷ", @@ -679,6 +713,7 @@ "tooltip-compareselectedversions": "ⵥⵔ ⴰⵎⵣⴰⵔⴰⵢ ⴳⵔ ⵙⵉⵏ ⵉⵣⵣⵔⴰⵢⵏ ⵉⵜⵜⵓⵙⵜⴰⵢⵏ ⵏ ⵜⴰⵙⵏⴰ ⴰⴷ", "tooltip-watch": "ⵔⵏⵓ ⵜⴰⵙⵏⴰ ⴰ ⵉ ⵜⵍⴳⴰⵎⵜ ⵏ ⵓⴹⴼⴼⵓⵔ {{GENDER:|ⵏⵏⴽ|ⵏⵏⵎ}}", "tooltip-rollback": "\"ⵔⴰⵔ\" ⵙⵙⵔ ⴰⵙⵏⴼⵍ ⵏⵖ ⵉⵙⵏⴼⴰⵍⵏ ⵏ ⵓⵎⴰⴷⵔⴰⵡ ⴰⵎⴳⴳⴰⵔⵓ ⴳ ⵜⴰⵙⵏⴰ ⴷ ⵙ ⵢⴰⵏ ⵓⴽⵍⵉⴽ", + "tooltip-undo": "\"ⵙⵔ\" ⴰⴷ ⵜⵔⴰⵔⴷ ⴰⵙⵏⴼⵍ ⴰ ⵜⵏⵏⵓⵔⵥⵎⴷ ⵜⴰⵍⵖⴰ ⵏ ⵓⵙⵏⴼⵍ ⴳ ⵜⵎⵓⵖⵍⵉ ⵜⴰⵣⵔⴰⵙⴽⴰⵏⵜ. ⵢⴰⵍⵍⴼⵓⵙ ⴰⴷ ⵜⵔⵏⵓⴷ ⴽⵔⴰ ⵏ ⵓⵙⵔⴰⴳ ⴳ ⵓⵙⴳⵣⵍ.", "tooltip-summary": "ⴰⵔⴰ ⴽⵔⴰ ⵏ ⵓⵙⴳⵣⵍ ⵎⵥⵥⵉⵢⵏ", "simpleantispam-label": "ⵜⵉⵎⵏⵥⵉⵜ ⵎⴳⵍ-ⴳⴰⵔⴰⵙⵎⵔⴰⵔⴰ.\nⴰⴷ ⵓⵔ ⵜⵣⵎⵎⴻⵎⴷ ⴰⵎⵢⴰ ⴳ ⵖⵉ!", "pageinfo-title": "ⵉⵏⵖⵎⵉⵙⵏ ⵖⴼ $1", @@ -710,10 +745,12 @@ "pageinfo-recent-authors": "ⵓⵟⵟⵓⵏ ⵏ ⵉⵎⴰⵔⴰⵜⵏ ⵉⵎⴳⴳⵓⵔⴰ ⵉⵎⵢⴰⵍⵍⴰⵏ", "pageinfo-magic-words": "ⵉⵎⴽⵓⵔⴰⵔⵏ {{PLURAL:$1|ⵜⴰⴳⵓⵔⵉ|ⵜⵉⴳⵓⵔⵉⵡⵉⵏ}} ($1)", "pageinfo-hidden-categories": "ⵏⵜⵍ {{PLURAL:$1|ⴰⵙⵎⵉⵍ|ⵉⵙⵎⵉⵍⵏ}}($1)", + "pageinfo-templates": "{{PLURAL:$1|ⵡⴰⵍⴱⵓⴹ ⵢⴰⵎⵓⵏ|ⵏ ⵡⴰⵍⴱⵓⴹⵏ ⵢⴰⵎⵓⵏ}} ($1)", "pageinfo-toolboxlink": "ⴰⵏⵖⵎⵉⵙ ⵖⴼ ⵜⴰⵙⵏⴰ", "pageinfo-contentpage": "ⵉⵜⵜⵓⵙⵉⴹⵏ ⴰⵎ ⵜⴰⵙⵏⴰ ⵏ ⵜⵓⵎⴰⵢⵜ", "pageinfo-contentpage-yes": "ⵢⴰⵀ", "pageinfo-protect-cascading-yes": "ⵢⴰⵀ", + "patrol-log-page": "ⵜⴰⵎⵙⵙⴽⵜⵉⵜ ⵏ ⵓⵣⵣⵔⴰⵢ", "previousdiff": "ⴰⵙⵏⴼⵍ ⴰⵎⴳⴳⴰⵔⵓ", "nextdiff": "ⴰⵙⵏⴼⵍ ⴰⵎⴰⵢⵏⵓ", "widthheightpage": "$1 × $2, $3 {{PLURAL:$3|ⵜⴰⵙⵏⴰ|ⵜⴰⵙⵏⵉⵡⵉⵏ}}", @@ -793,6 +830,7 @@ "htmlform-yes": "ⵢⴰⵀ", "logentry-delete-delete": "$1 {{GENDER:$2|ⵉⴽⴽⵙ|ⵜⴽⴽⵙ}} ⵜⴰⵙⵏⴰ $3", "logentry-delete-restore": "$1 {{GENDER:$2|ⵉⵔⵓⵔ ⴷ|ⵜⵔⵓⵔ ⴷ}} ⵜⴰⵙⵏⴰ $3 ($4)", + "logentry-delete-revision": "$1 {{GENDER:$2|ⵉⵙⵏⴼⵍ}} ⴰⵍⵍⴼⵓⵙ ⵏ ⵡⵓⵎⴰⵏ {{PLURAL:$5|ⵏ ⵢⴰⵏ ⵓⵣⵣⵔⴰⵢ|ⵏ $5 ⵏ ⵉⵣⵣⵔⴰⵢⵏ}} ⴳ ⵜⴰⵙⵏⴰ $3 : $4", "revdelete-content-hid": "ⵜⴻⵜⵜⵓⵏⵜⴰⵍ ⵜⵓⵎⴰⵢⵜ", "logentry-move-move": "$1 {{GENDER:$2|ⵉⵙⵎⵓⵜⵜⵉ|ⵜⵙⵎⵓⵜⵜⵉ}} ⵜⴰⵙⵏⴰ ⵙⴳ $3 ⵖⵔ $4", "logentry-move-move-noredirect": "{{GENDER:$2|ⵉⵙⵎⵓⵜⵜⵉ}} $1 ⵜⴰⵙⵏⴰ $3 ⵖⵔ $4 ⵎⵉⵏ ⴰⴷ ⵉⴼⵍ redirect", diff --git a/languages/i18n/zh-hans.json b/languages/i18n/zh-hans.json index dfa8a607e5..1d2dad0387 100644 --- a/languages/i18n/zh-hans.json +++ b/languages/i18n/zh-hans.json @@ -99,7 +99,9 @@ "WhitePhosphorus", "A2093064", "EagerLin", - "Deathkon" + "Deathkon", + "RyRubyy", + "Wxyveronica" ] }, "tog-underline": "链接下划线:", @@ -554,7 +556,7 @@ "noemailcreate": "您需要提供一个有效的电子邮件地址", "passwordsent": "用户\"$1\"的新密码已经寄往所登记的电子邮件地址。\n请在收到后再登录。", "blocked-mailpassword": "您的IP地址被禁止编辑,为预防滥用,也不允许从该IP地址使用密码恢复功能。", - "eauthentsent": "一封确认信已经发送至您设定的邮件地址。\n在任何其他邮件发送至您的账户前,您将不得不根据邮件中的指示,确认那个账户确实是您的。", + "eauthentsent": "一封确认信已经发送至您设定的邮件地址。\n在任何其他邮件发送至您的账户前,您将需要根据邮件中的指示,确认那个账户确实是您的。", "throttled-mailpassword": "密码提醒已在最近$1小时内发送。为了安全起见,在每$1小时内只能发送一个密码提醒。", "mailerror": "发送邮件错误:$1", "acct_creation_throttle_hit": "使用您的IP地址访问本wiki的访客在过去$2中创建了{{PLURAL:$1|$1个账户}},达到了这段时间所允许的最大值。因此,使用该IP地址的访客现在不能再创建账户。", @@ -1004,6 +1006,8 @@ "diff-paragraph-moved-toold": "段落已移动。点击跳到旧位置。", "difference-missing-revision": "此差异对比的{{PLURAL:$2|$2个版本}}($1){{PLURAL:$2|没有}}找到。\n\n这通常是因为进入了一个已被删除的页面的版本差异对比链接。\n详细信息可以在[{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} 删除日志]中找到。", "searchresults": "搜索结果", + "search-filter-title-prefix": "只在标题开头为“$1”的页面上搜索", + "search-filter-title-prefix-reset": "搜索所有页面", "searchresults-title": "“$1”的搜索结果", "titlematches": "页面标题匹配", "textmatches": "页面内容匹配", @@ -1810,6 +1814,7 @@ "http-timed-out": "HTTP请求已过时。", "http-curl-error": "撷取URL时出错:$1", "http-bad-status": "进行HTTP请求时出现问题:$1 $2", + "http-internal-error": "HTTP内部错误。", "upload-curl-error6": "无法访问URL", "upload-curl-error6-text": "无法访问提供的URL。请检查该URL是否正确,及其网站是否在线。", "upload-curl-error28": "上传超时", @@ -2104,7 +2109,7 @@ "speciallogtitlelabel": "目标(标题,或对于用户使用{{ns:user}}:用户名):", "log": "日志", "logeventslist-submit": "显示", - "logeventslist-more-filters": "更多过滤器:", + "logeventslist-more-filters": "显示更多日志:", "logeventslist-patrol-log": "巡查日志", "logeventslist-tag-log": "标签日志", "all-logs-page": "所有公开日志", @@ -2964,8 +2969,6 @@ "markedaspatrollederrornotify": "标记为已巡查失败。", "patrol-log-page": "巡查日志", "patrol-log-header": "这是已巡查版本的日志。", - "log-show-hide-patrol": "$1巡查纪录", - "log-show-hide-tag": "$1标签日志", "confirm-markpatrolled-button": "确定", "confirm-markpatrolled-top": "将$2的修订版本$3标记为已巡查么?", "deletedrevision": "已删除旧版本$1", diff --git a/languages/i18n/zh-hant.json b/languages/i18n/zh-hant.json index 99706494b3..b6499405fc 100644 --- a/languages/i18n/zh-hant.json +++ b/languages/i18n/zh-hant.json @@ -1002,6 +1002,8 @@ "diff-paragraph-moved-toold": "段落已被移動。點擊來跳至舊的位置。", "difference-missing-revision": "查無此差異 ($1) 中的{{PLURAL:$2|1 次修訂|$2 次修訂}}。\n\n這通常是因為差異的連結過時,頁面已被刪除。\n詳情資訊請參閱 [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} 刪除日誌]。", "searchresults": "搜尋結果", + "search-filter-title-prefix": "僅搜尋標題開頭為「$1」的頁面", + "search-filter-title-prefix-reset": "選擇所有頁面", "searchresults-title": "搜尋「$1」的結果", "titlematches": "頁面標題符合", "textmatches": "頁面內容符合", @@ -1807,6 +1809,7 @@ "http-timed-out": "HTTP 請求已逾時。", "http-curl-error": "擷取 URL 時錯誤:$1", "http-bad-status": "進行 HTTP 請求發生問題:$1 $2", + "http-internal-error": "HTTP 內部錯誤。", "upload-curl-error6": "無法連線至 URL", "upload-curl-error6-text": "無法連線至指定的 URL 。\n請重新檢查 URL 是否正確,且確認網站是否正常運作。", "upload-curl-error28": "上傳逾時", @@ -2100,7 +2103,7 @@ "speciallogtitlelabel": "目標 (標題或以 {{ns:user}}:使用者 表示使用者):", "log": "日誌", "logeventslist-submit": "顯示", - "logeventslist-more-filters": "更多篩選", + "logeventslist-more-filters": "顯示額外日誌:", "logeventslist-patrol-log": "巡查日誌", "logeventslist-tag-log": "標籤日誌", "all-logs-page": "所有公開日誌", @@ -2413,7 +2416,7 @@ "undeletehistory": "若您還原該頁面,所有的修訂歷史也會一併還原。\n若刪除之後已有使用相同名稱建立的新頁面,還原的修訂歷史會出現在此頁面之前的歷史中。", "undeleterevdel": "若最新頁面或檔案修訂被部份刪除,將無法執行取消刪除的動作。\n這種情況您必須取消勾選或取消隱藏已刪除的最新修訂。", "undeletehistorynoadmin": "已刪除此頁面。\n以下摘要顯示刪除原因與刪除前所有編輯過此頁面的使用者詳細資料。\n這些已刪除的實際文字修訂僅對管理員可用。", - "undelete-revision": "被 $3 刪除的 $1 (於 $4 $5) 修訂:", + "undelete-revision": "$1由$3(於$4 $5)所編輯的已刪除修訂版本", "undeleterevision-missing": "無效或遺失的修訂。\n您可能使用了錯誤的連結,或該修訂已從封存中還原或刪除。", "undeleterevision-duplicate-revid": "無法還原 {{PLURAL:$1|1 個修訂|$1 修訂}},因{{PLURAL:$1|修訂的|修訂的}} rev_id 已在使用中。", "undelete-nodiff": "查無先前的修訂。", @@ -2954,8 +2957,6 @@ "markedaspatrollederrornotify": "標記為已巡查失敗。", "patrol-log-page": "巡查日誌", "patrol-log-header": "這是已巡查的修訂版本的日誌。", - "log-show-hide-patrol": "$1 巡查日誌", - "log-show-hide-tag": "$1 標籤日誌", "confirm-markpatrolled-button": "確定", "confirm-markpatrolled-top": "標記 $2 的修訂 $3 為已巡查?", "deletedrevision": "已刪除舊修訂 $1", diff --git a/languages/i18n/zh-hk.json b/languages/i18n/zh-hk.json index 131172ad77..4b15837726 100644 --- a/languages/i18n/zh-hk.json +++ b/languages/i18n/zh-hk.json @@ -14,7 +14,9 @@ "Justincheng12345", "LNDDYL", "Liuxinyu970226", - "Quest for Truth" + "Quest for Truth", + "Wxyveronica", + "和平至上" ] }, "tog-watchlisthidebots": "隱藏監視清單中機械人的編輯", @@ -30,27 +32,64 @@ "october": "十月", "november": "十一月", "december": "十二月", + "jan": "1月", + "feb": "2月", + "mar": "3月", + "apr": "4月", + "may": "5月", + "jun": "6月", + "jul": "7月", + "aug": "8月", + "sep": "9月", + "oct": "10月", + "nov": "11月", + "dec": "12月", "mytalk": "我的討論頁", + "navigation": "導覽", + "namespaces": "命名空間", + "variants": "變體", + "navigation-heading": "導覽菜單", "tagline": "從 {{SITENAME}}", + "help": "說明", "search": "搜尋", + "searchbutton": "搜尋", + "searcharticle": "執行", "printableversion": "可打印版", "permalink": "靜態連結", "print": "打印", + "edit": "編輯", + "talkpagelinktext": "對話", "specialpage": "特殊頁面", + "personaltools": "個人工具", + "talk": "討論", + "views": "檢視", + "toolbox": "工具", "jumpto": "跳到:", + "jumptonavigation": "導覽", "jumptosearch": "搜尋", + "aboutsite": "關於 {{SITENAME}}", "aboutpage": "Project:關於我們", + "disclaimers": "免責聲明", + "disclaimerpage": "本專案:一般免責聲明", + "mainpage": "首頁", "privacy": "私隱政策", "privacypage": "Project:私隱政策", + "retrievedfrom": "取自 \"$1\"", + "editsection": "編輯", + "editsectionhint": "編輯章節:$1", + "site-atom-feed": "$1 Atom摘要", "red-link-title": "$1 (頁面不存在)", "nstab-user": "用戶頁面", "nstab-special": "特殊頁面", "nstab-template": "模板", + "mainpage-nstab": "首頁", "editinginterface": "警告:您正在編輯的頁面文字是用來作為軟件介面使用。更改此頁面將會影響其他用戶在此 Wiki 上看到的用戶介面。", "yourname": "用戶名稱:", "userlogin-yourname": "用戶名稱", "nav-login-createaccount": "登入/創造帳戶", "wrongpassword": "您輸入的密碼有錯誤,請再試一次。", + "pt-login": "登入", + "pt-createaccount": "建立賬號", "botpasswords": "機械人密碼", "botpasswords-summary": "機械人密碼可在不使用帳號的主要登入密碼情況下,允許透過 API 存取使用者帳號。使用機械人密碼登入的使用者權限或會有所限制。\n\n若你並非必須設定此密碼,你便不應使用此功能。任何人都不會索取你的機械人密碼。", "botpasswords-disabled": "機械人密碼已停用。", @@ -92,6 +131,7 @@ "rcshowhidebots": "$1機械人的編輯", "rcshowhideliu": "$1 已註冊的用戶", "rcshowhideanons": "$1 匿名用戶", + "rc-change-size-new": "變更後為$1{{PLURAL:$1|}}", "upload": "上載檔案", "listfiles_user": "用戶", "filehist-user": "用戶", @@ -102,23 +142,32 @@ "checkbox-select": "選擇: $1", "emailusername": "用戶名稱:", "wlshowhidebots": "機械人", + "blanknamespace": "(主要)", "blockip": "封鎖{{GENDER:$1|用戶}}", "contribslink": "貢獻", "blocklogtext": "這是用戶的封禁與解禁操作的日誌記錄。\n自動封禁的 IP 位址不予包含。\n請參考 [[Special:BlockList|封禁清單]] 以檢視目前的封禁。", + "tooltip-pt-login": "我們建議您登入,但這並非必要", + "tooltip-pt-createaccount": "我們建議您建立一個賬號并登入,但這並非必要", "tooltip-search": "搜尋 {{SITENAME}}", "tooltip-search-go": "若是真有其頁,則進入相同名字的頁面", "tooltip-search-fulltext": "在此頁面內搜尋此文字", + "tooltip-p-logo": "前往首頁", "tooltip-n-mainpage": "回到首頁", "tooltip-n-mainpage-description": "回到首頁", + "tooltip-n-recentchanges": "wiki近期變更清單", "tooltip-n-randompage": "跳到一個隨機抽取的頁面", + "tooltip-n-help": "尋求說明", "tooltip-t-contributions": "此用戶的貢獻清單", "tooltip-t-upload": "上載檔案", + "tooltip-t-specialpages": "特殊頁面總清單", "tooltip-t-print": "這個頁面的可打印版本", "tooltip-ca-nstab-user": "檢視用戶頁面", + "pageinfo-toolboxlink": "頁面資訊", "newimages-showbots": "顯示機械人上傳的檔案", "exif-rowsperstrip": "每帶行數", "redirect-user": "用戶 ID", "specialpages": "特殊頁面", "tags-source-manual": "由使用者與機械人手動套用", - "logentry-managetags-activate": "$1{{GENDER:$2|已啟用}}標籤「$4」供使用者與機械人使用" + "logentry-managetags-activate": "$1{{GENDER:$2|已啟用}}標籤「$4」供使用者與機械人使用", + "searchsuggest-search": "搜尋{{SITENAME}}" } diff --git a/languages/messages/MessagesSat.php b/languages/messages/MessagesSat.php index 3f52c8873c..4ae1d9d961 100644 --- a/languages/messages/MessagesSat.php +++ b/languages/messages/MessagesSat.php @@ -8,8 +8,6 @@ * */ -$fallback = 'bn'; - $namespaceNames = [ NS_MEDIA => 'ᱢᱤᱰᱤᱭᱟ', NS_SPECIAL => 'ᱟᱥᱚᱠᱟᱭ', diff --git a/maintenance/interwiki.list b/maintenance/interwiki.list index 5f87e16cc2..039666b76f 100644 --- a/maintenance/interwiki.list +++ b/maintenance/interwiki.list @@ -56,7 +56,7 @@ wikidata|https://www.wikidata.org/wiki/$1|0|https://www.wikidata.org/w/api.php wikif1|http://www.wikif1.org/$1|0| wikihow|https://www.wikihow.com/$1|0|https://www.wikihow.com/api.php wikinfo|http://wikinfo.co/English/index.php/$1|0| -wikimedia|https://wikimediafoundation.org/wiki/$1|0|https://wikimediafoundation.org/w/api.php +wikimedia|https://foundation.wikimedia.org/wiki/$1|0|https://foundation.wikimedia.org/w/api.php wikinews|https://en.wikinews.org/wiki/$1|0|https://en.wikinews.org/w/api.php wikipedia|https://en.wikipedia.org/wiki/$1|0|https://en.wikipedia.org/w/api.php wikiquote|https://en.wikiquote.org/wiki/$1|0|https://en.wikiquote.org/w/api.php diff --git a/maintenance/interwiki.sql b/maintenance/interwiki.sql index 9e6072b7f2..68ebedfad9 100644 --- a/maintenance/interwiki.sql +++ b/maintenance/interwiki.sql @@ -58,7 +58,7 @@ REPLACE INTO /*$wgDBprefix*/interwiki (iw_prefix,iw_url,iw_local,iw_api) VALUES ('wikif1','http://www.wikif1.org/$1',0,''), ('wikihow','https://www.wikihow.com/$1',0,'https://www.wikihow.com/api.php'), ('wikinfo','http://wikinfo.co/English/index.php/$1',0,''), -('wikimedia','https://wikimediafoundation.org/wiki/$1',0,'https://wikimediafoundation.org/w/api.php'), +('wikimedia','https://foundation.wikimedia.org/wiki/$1',0,'https://foundation.wikimedia.org/w/api.php'), ('wikinews','https://en.wikinews.org/wiki/$1',0,'https://en.wikinews.org/w/api.php'), ('wikipedia','https://en.wikipedia.org/wiki/$1',0,'https://en.wikipedia.org/w/api.php'), ('wikiquote','https://en.wikiquote.org/wiki/$1',0,'https://en.wikiquote.org/w/api.php'), diff --git a/maintenance/language/generateNormalizerDataAr.php b/maintenance/language/generateNormalizerDataAr.php index af47d65c89..fad35cb753 100644 --- a/maintenance/language/generateNormalizerDataAr.php +++ b/maintenance/language/generateNormalizerDataAr.php @@ -28,6 +28,11 @@ require_once __DIR__ . '/../Maintenance.php'; * * This data file is used after normalizing to NFC. * + * Example usage: + * + * curl 'https://unicode.org/Public/6.0.0/ucd/UnicodeData.txt' > /tmp/UnicodeData.txt + * php generateNormalizerDataAr.php --unicode-data-file /tmp/UnicodeData.txt + * * @ingroup MaintenanceLanguage */ class GenerateNormalizerDataAr extends Maintenance { diff --git a/maintenance/mysql.php b/maintenance/mysql.php index 6d0882a64a..1b575bb28a 100644 --- a/maintenance/mysql.php +++ b/maintenance/mysql.php @@ -165,6 +165,12 @@ class MysqlMaintenance extends Maintenance { $args = array_merge( $args, $this->mArgs ); + // Ignore SIGINT if possible, otherwise the wrapper terminates when the user presses + // ctrl-C to kill a query. + if ( function_exists( 'pcntl_signal' ) ) { + pcntl_signal( SIGINT, SIG_IGN ); + } + $pipes = []; $proc = proc_open( Shell::escape( $args ), $desc, $pipes ); if ( $proc === false ) { diff --git a/maintenance/resetAuthenticationThrottle.php b/maintenance/resetAuthenticationThrottle.php new file mode 100644 index 0000000000..9760c42000 --- /dev/null +++ b/maintenance/resetAuthenticationThrottle.php @@ -0,0 +1,152 @@ +addDescription( 'Reset login/signup throttling for a specified user and/or IP. ' + . "\n\n" + . 'When resetting signup only, provide the IP. When resetting login (or both), provide ' + . 'both username (as entered in login screen) and IP. An easy way to obtain them is ' + . "the 'throttler' log channel." ); + $this->addOption( 'login', 'Reset login throttle' ); + $this->addOption( 'signup', 'Reset account creation throttle' ); + $this->addOption( 'user', 'Username to reset', false, true ); + $this->addOption( 'ip', 'IP to reset', false, true ); + } + + public function execute() { + $forLogin = (bool)$this->getOption( 'login' ); + $forSignup = (bool)$this->getOption( 'signup' ); + $username = $this->getOption( 'user' ); + $ip = $this->getOption( 'ip' ); + + if ( !$forLogin && !$forSignup ) { + $this->fatalError( 'At least one of --login and --signup is required!' ); + } elseif ( $forLogin && ( $ip === null || $username === null ) ) { + $this->fatalError( '--usename and --ip are both required when using --login!' ); + } elseif ( $forSignup && $ip === null ) { + $this->fatalError( '--ip is required when using --signup!' ); + } elseif ( $ip !== null && !IP::isValid( $ip ) ) { + $this->fatalError( "Not a valid IP: $ip" ); + } + + if ( $forLogin ) { + $this->clearLoginThrottle( $username, $ip ); + } + if ( $forSignup ) { + $this->clearSignupThrottle( $ip ); + } + + LoggerFactory::getInstance( 'throttler' )->notice( 'Manually cleared {type} throttle', [ + 'type' => implode( ' and ', array_filter( [ + $forLogin ? 'login' : null, + $forSignup ? 'signup' : null, + ] ) ), + 'username' => $username, + 'ipKey' => $ip, + ] ); + } + + /** + * @param string|null $rawUsername + * @param string|null $ip + */ + protected function clearLoginThrottle( $rawUsername, $ip ) { + $this->output( 'Clearing login throttle... ' ); + + $passwordAttemptThrottle = $this->getConfig()->get( 'PasswordAttemptThrottle' ); + if ( !$passwordAttemptThrottle ) { + $this->output( "none set\n" ); + return; + } + + $throttler = new Throttler( $passwordAttemptThrottle, [ + 'type' => 'password', + 'cache' => ObjectCache::getLocalClusterInstance(), + ] ); + if ( $rawUsername !== null ) { + $usernames = AuthManager::singleton()->normalizeUsername( $rawUsername ); + if ( !$usernames ) { + $this->fatalError( "Not a valid username: $rawUsername" ); + } + } else { + $usernames = [ null ]; + } + foreach ( $usernames as $username ) { + $throttler->clear( $username, $ip ); + } + + $botPasswordThrottler = new Throttler( $passwordAttemptThrottle, [ + 'type' => 'botpassword', + 'cache' => ObjectCache::getLocalClusterInstance(), + ] ); + $botPasswordThrottler->clear( $username, $ip ); + + $this->output( "done\n" ); + } + + /** + * @param string $ip + */ + protected function clearSignupThrottle( $ip ) { + $this->output( 'Clearing signup throttle... ' ); + + $accountCreationThrottle = $this->getConfig()->get( 'AccountCreationThrottle' ); + if ( !is_array( $accountCreationThrottle ) ) { + $accountCreationThrottle = [ [ + 'count' => $accountCreationThrottle, + 'seconds' => 86400, + ] ]; + } + if ( !$accountCreationThrottle ) { + $this->output( "none set\n" ); + return; + } + $throttler = new Throttler( $accountCreationThrottle, [ + 'type' => 'acctcreate', + 'cache' => ObjectCache::getLocalClusterInstance(), + ] ); + + $throttler->clear( null, $ip ); + + $this->output( "done\n" ); + } + +} + +$maintClass = ResetAuthenticationThrottle::class; +require_once RUN_MAINTENANCE_IF_MAIN; diff --git a/resources/src/mediawiki.language/mediawiki.language.init.js b/resources/src/mediawiki.language/mediawiki.language.init.js index 83525f26dd..34add28def 100644 --- a/resources/src/mediawiki.language/mediawiki.language.init.js +++ b/resources/src/mediawiki.language/mediawiki.language.init.js @@ -37,8 +37,6 @@ * - `pluralRules` * - `digitGroupingPattern` * - `fallbackLanguages` - * - `bcp47Map` - * - `languageNames` * * @property */ diff --git a/resources/src/mediawiki.language/mediawiki.language.js b/resources/src/mediawiki.language/mediawiki.language.js index 808f347e71..45863a3e33 100644 --- a/resources/src/mediawiki.language/mediawiki.language.js +++ b/resources/src/mediawiki.language/mediawiki.language.js @@ -191,27 +191,18 @@ }, /** - * Formats language tags according the BCP 47 standard. + * Formats language tags according the BCP47 standard. * See LanguageCode::bcp47 for the PHP implementation. * * @param {string} languageTag Well-formed language tag * @return {string} */ bcp47: function ( languageTag ) { - var bcp47Map, - formatted, - segments, + var formatted, isFirstSegment = true, - isPrivate = false; + isPrivate = false, + segments = languageTag.split( '-' ); - languageTag = languageTag.toLowerCase(); - - bcp47Map = mw.language.getData( mw.config.get( 'wgUserLanguage' ), 'bcp47Map' ); - if ( bcp47Map && Object.prototype.hasOwnProperty.call( bcp47Map, languageTag ) ) { - languageTag = bcp47Map[ languageTag ]; - } - - segments = languageTag.split( '-' ); formatted = segments.map( function ( segment ) { var newSegment; diff --git a/resources/src/mediawiki.rcfilters/styles/mw.rcfilters.less b/resources/src/mediawiki.rcfilters/styles/mw.rcfilters.less index 390d873277..9101fba69b 100644 --- a/resources/src/mediawiki.rcfilters/styles/mw.rcfilters.less +++ b/resources/src/mediawiki.rcfilters/styles/mw.rcfilters.less @@ -114,27 +114,28 @@ left: 50%; // Make sure the middle of the spinner is centered, rather than its left edge margin-left: -3 * @rcfilters-spinner-size / 2; - - opacity: 0.8; white-space: nowrap; & .rcfilters-spinner-bounce, &:before, &:after { content: ''; - display: inline-block; + background-color: @colorGray7; + display: block; + float: left; width: @rcfilters-spinner-size; height: @rcfilters-spinner-size; - background-color: @colorGray12; border-radius: 100%; - .animation( rcfiltersBouncedelay 1.5s ease-in-out -0.16s infinite both ); + .animation( rcfiltersBouncedelay 1600ms ease-in-out -160ms infinite both ); } &:before { - .animation-delay( -0.33s ); + margin-right: 4px; + .animation-delay( -330ms ); } &:after { + margin-left: 4px; .animation-delay( 0s ); } } @@ -178,40 +179,36 @@ @-webkit-keyframes rcfiltersBouncedelay { 0%, - 80%, + 50%, // equals 800ms 100% { - -webkit-transform: scale( 0.7 ); - transform: scale( 0.7 ); + -webkit-transform: scale( 0.625 ); } - 40% { - background-color: @colorGray10; + 20% { // equals 320ms + opacity: 0.87; -webkit-transform: scale( 1 ); - transform: scale( 1 ); } } @-moz-keyframes rcfiltersBouncedelay { 0%, - 80%, + 50%, 100% { - -moz-transform: scale( 0.7 ); - transform: scale( 0.7 ); + -moz-transform: scale( 0.625 ); } - 40% { - background-color: @colorGray10; - -moz-transform: scale( 0.7 ); - transform: scale( 1 ); + 20% { + opacity: 0.87; + -moz-transform: scale( 1 ); } } @keyframes rcfiltersBouncedelay { 0%, - 80%, + 50%, 100% { - transform: scale( 0.7 ); + transform: scale( 0.625 ); } - 40% { - background-color: @colorGray10; + 20% { // equals 320ms + opacity: 0.87; transform: scale( 1 ); } } diff --git a/resources/src/mediawiki.rcfilters/styles/mw.rcfilters.ui.ItemMenuOptionWidget.less b/resources/src/mediawiki.rcfilters/styles/mw.rcfilters.ui.ItemMenuOptionWidget.less index ad0bc4a4a7..1cc48e2b4f 100644 --- a/resources/src/mediawiki.rcfilters/styles/mw.rcfilters.ui.ItemMenuOptionWidget.less +++ b/resources/src/mediawiki.rcfilters/styles/mw.rcfilters.ui.ItemMenuOptionWidget.less @@ -60,6 +60,12 @@ display: block; padding-top: 1em; } + + label { + // Workaround for Chrome browser bug (T199932) + // Override padding rule from FieldLayout + padding-left: 0 !important; /* stylelint-disable-line declaration-no-important */ + } } .mw-rcfilters-ui-cell { diff --git a/tests/parser/ParserTestRunner.php b/tests/parser/ParserTestRunner.php index ceee432fb8..68bc61e476 100644 --- a/tests/parser/ParserTestRunner.php +++ b/tests/parser/ParserTestRunner.php @@ -116,6 +116,30 @@ class ParserTestRunner { */ private $normalizationFunctions = []; + /** + * Run disabled parser tests + * @var bool + */ + private $runDisabled; + + /** + * Run tests intended only for parsoid + * @var bool + */ + private $runParsoid; + + /** + * Disable parse on article insertion + * @var bool + */ + private $disableSaveParse; + + /** + * Reuse upload directory + * @var bool + */ + private $keepUploads; + /** * @param TestRecorder $recorder * @param array $options @@ -148,6 +172,8 @@ class ParserTestRunner { $this->runDisabled = !empty( $options['run-disabled'] ); $this->runParsoid = !empty( $options['run-parsoid'] ); + $this->disableSaveParse = !empty( $options['disable-save-parse'] ); + $this->tidySupport = new TidySupport( !empty( $options['use-tidy-config'] ) ); if ( !$this->tidySupport->isEnabled() ) { $this->recorder->warning( @@ -1184,7 +1210,8 @@ class ParserTestRunner { 'site_stats', 'ipblocks', 'image', 'oldimage', 'recentchanges', 'watchlist', 'interwiki', 'logging', 'log_search', 'querycache', 'objectcache', 'job', 'l10n_cache', 'redirect', 'querycachetwo', - 'archive', 'user_groups', 'page_props', 'category' + 'archive', 'user_groups', 'page_props', 'category', + 'slots', 'content', 'slot_roles', 'content_models', ]; if ( $wgCommentTableSchemaMigrationStage >= MIGRATION_WRITE_BOTH ) { @@ -1451,7 +1478,6 @@ class ParserTestRunner { $this->checkSetupDone( 'setupDatabase' ); $this->dbClone->destroy(); - $this->databaseSetupDone = false; if ( $this->useTemporaryTables ) { if ( $this->db->getType() == 'sqlite' ) { @@ -1651,11 +1677,15 @@ class ParserTestRunner { ); } - // Use mock parser, to make debugging of actual parser tests simpler. + // Optionally use mock parser, to make debugging of actual parser tests simpler. // But initialise the MessageCache clone first, don't let MessageCache // get a reference to the mock object. - MessageCache::singleton()->getParser(); - $restore = $this->executeSetupSnippets( [ 'wgParser' => new ParserTestMockParser ] ); + if ( $this->disableSaveParse ) { + MessageCache::singleton()->getParser(); + $restore = $this->executeSetupSnippets( [ 'wgParser' => new ParserTestMockParser ] ); + } else { + $restore = false; + } try { $status = $page->doEditContent( $newContent, @@ -1663,7 +1693,9 @@ class ParserTestRunner { EDIT_NEW | EDIT_INTERNAL ); } finally { - $restore(); + if ( $restore ) { + $restore(); + } } if ( !$status->isOK() ) { diff --git a/tests/parser/parserTests.php b/tests/parser/parserTests.php index 6a423d5cb3..e1d943f2e4 100644 --- a/tests/parser/parserTests.php +++ b/tests/parser/parserTests.php @@ -62,6 +62,8 @@ class ParserTestsMaintenance extends Maintenance { 'be used.', false, true ); $this->addOption( 'run-disabled', 'run disabled tests' ); $this->addOption( 'run-parsoid', 'run parsoid tests (normally disabled)' ); + $this->addOption( 'disable-save-parse', 'Don\'t run the parser when ' . + 'inserting articles into the database' ); $this->addOption( 'dwdiff', 'Use dwdiff to display diff output' ); $this->addOption( 'mark-ws', 'Mark whitespace in diffs by replacing it with symbols' ); $this->addOption( 'norm', 'Apply a comma-separated list of normalization functions to ' . @@ -180,6 +182,7 @@ class ParserTestsMaintenance extends Maintenance { 'keep-uploads' => $this->hasOption( 'keep-uploads' ), 'run-disabled' => $this->hasOption( 'run-disabled' ), 'run-parsoid' => $this->hasOption( 'run-parsoid' ), + 'disable-save-parse' => $this->hasOption( 'disable-save-parse' ), 'use-tidy-config' => $this->hasOption( 'use-tidy-config' ), 'file-backend' => $this->getOption( 'file-backend' ), 'upload-dir' => $this->getOption( 'upload-dir' ), diff --git a/tests/phpunit/data/registration/duplicate_keys.json b/tests/phpunit/data/registration/duplicate_keys.json new file mode 100644 index 0000000000..40f2f7e7aa --- /dev/null +++ b/tests/phpunit/data/registration/duplicate_keys.json @@ -0,0 +1,4 @@ +{ + "name": "FooBar", + "name": "Test" +} diff --git a/tests/phpunit/includes/ExtraParserTest.php b/tests/phpunit/includes/ExtraParserTest.php index 75ebd31a21..164c83c7e4 100644 --- a/tests/phpunit/includes/ExtraParserTest.php +++ b/tests/phpunit/includes/ExtraParserTest.php @@ -17,7 +17,7 @@ class ExtraParserTest extends MediaWikiTestCase { $contLang = Language::factory( 'en' ); $this->setMwGlobals( [ - 'wgShowDBErrorBacktrace' => true, + 'wgShowExceptionDetails' => true, 'wgCleanSignatures' => true, ] ); $this->setUserLang( 'en' ); diff --git a/tests/phpunit/includes/GlobalFunctions/wfArrayFilterTest.php b/tests/phpunit/includes/GlobalFunctions/wfArrayFilterTest.php index 1011a37c3e..bc930be45d 100644 --- a/tests/phpunit/includes/GlobalFunctions/wfArrayFilterTest.php +++ b/tests/phpunit/includes/GlobalFunctions/wfArrayFilterTest.php @@ -5,8 +5,9 @@ * @covers ::wfArrayFilter * @covers ::wfArrayFilterByKey */ -class WfArrayFilterTest extends \PHPUnit\Framework\TestCase { +class WfArrayFilterTest extends MediaWikiTestCase { public function testWfArrayFilter() { + $this->hideDeprecated( 'wfArrayFilter' ); $arr = [ 'a' => 1, 'b' => 2, 'c' => 3 ]; $filtered = wfArrayFilter( $arr, function ( $val, $key ) { return $key !== 'b'; @@ -27,6 +28,7 @@ class WfArrayFilterTest extends \PHPUnit\Framework\TestCase { } public function testWfArrayFilterByKey() { + $this->hideDeprecated( 'wfArrayFilterByKey' ); $arr = [ 'a' => 1, 'b' => 2, 'c' => 3 ]; $filtered = wfArrayFilterByKey( $arr, function ( $key ) { return $key !== 'b'; diff --git a/tests/phpunit/includes/GlobalFunctions/wfExpandUrlTest.php b/tests/phpunit/includes/GlobalFunctions/wfExpandUrlTest.php index 1cd320fa00..159e4ad9a4 100644 --- a/tests/phpunit/includes/GlobalFunctions/wfExpandUrlTest.php +++ b/tests/phpunit/includes/GlobalFunctions/wfExpandUrlTest.php @@ -8,13 +8,14 @@ class WfExpandUrlTest extends MediaWikiTestCase { * @dataProvider provideExpandableUrls */ public function testWfExpandUrl( $fullUrl, $shortUrl, $defaultProto, - $server, $canServer, $httpsMode, $message + $server, $canServer, $httpsMode, $httpsPort, $message ) { // Fake $wgServer, $wgCanonicalServer and $wgRequest->getProtocol() $this->setMwGlobals( [ 'wgServer' => $server, 'wgCanonicalServer' => $canServer, - 'wgRequest' => new FauxRequest( [], false, null, $httpsMode ? 'https' : 'http' ) + 'wgRequest' => new FauxRequest( [], false, null, $httpsMode ? 'https' : 'http' ), + 'wgHttpsPort' => $httpsPort ] ); $this->assertEquals( $fullUrl, wfExpandUrl( $shortUrl, $defaultProto ), $message ); @@ -49,14 +50,14 @@ class WfExpandUrlTest extends MediaWikiTestCase { foreach ( $defaultProtos as $protoDesc => $defaultProto ) { $retval[] = [ 'http://example.com', 'http://example.com', - $defaultProto, $server, $canServer, $httpsMode, + $defaultProto, $server, $canServer, $httpsMode, 443, "Testing fully qualified http URLs (no need to expand) " . "(defaultProto: $protoDesc , wgServer: $server, " . "wgCanonicalServer: $canServer, current request protocol: $mode )" ]; $retval[] = [ 'https://example.com', 'https://example.com', - $defaultProto, $server, $canServer, $httpsMode, + $defaultProto, $server, $canServer, $httpsMode, 443, "Testing fully qualified https URLs (no need to expand) " . "(defaultProto: $protoDesc , wgServer: $server, " . "wgCanonicalServer: $canServer, current request protocol: $mode )" @@ -64,7 +65,7 @@ class WfExpandUrlTest extends MediaWikiTestCase { # Would be nice to support this, see fixme on wfExpandUrl() $retval[] = [ "wiki/FooBar", 'wiki/FooBar', - $defaultProto, $server, $canServer, $httpsMode, + $defaultProto, $server, $canServer, $httpsMode, 443, "Test non-expandable relative URLs (defaultProto: $protoDesc, " . "wgServer: $server, wgCanonicalServer: $canServer, " . "current request protocol: $mode )" @@ -91,7 +92,7 @@ class WfExpandUrlTest extends MediaWikiTestCase { $retval[] = [ "$p//wikipedia.org", '//wikipedia.org', - $defaultProto, $server, $canServer, $httpsMode, + $defaultProto, $server, $canServer, $httpsMode, 443, "Test protocol-relative URL (defaultProto: $protoDesc, " . "wgServer: $server, wgCanonicalServer: $canServer, " . "current request protocol: $mode )" @@ -103,6 +104,7 @@ class WfExpandUrlTest extends MediaWikiTestCase { $server, $canServer, $httpsMode, + 443, "Testing expanding URL beginning with / (defaultProto: $protoDesc, " . "wgServer: $server, wgCanonicalServer: $canServer, " . "current request protocol: $mode )" @@ -112,6 +114,39 @@ class WfExpandUrlTest extends MediaWikiTestCase { } } + // Don't add HTTPS port to foreign URLs + $retval[] = [ + 'https://foreign.example.com/foo', + 'https://foreign.example.com/foo', + PROTO_HTTPS, + '//wiki.example.com', + 'http://wiki.example.com', + 'https', + 111, + "Don't add HTTPS port to foreign URLs" + ]; + $retval[] = [ + 'https://foreign.example.com:222/foo', + 'https://foreign.example.com:222/foo', + PROTO_HTTPS, + '//wiki.example.com', + 'http://wiki.example.com', + 'https', + 111, + "Don't overwrite HTTPS port of foreign URLs" + ]; + // Do add HTTPS port to local URLs + $retval[] = [ + 'https://wiki.example.com:111/foo', + '/foo', + PROTO_HTTPS, + '//wiki.example.com', + 'http://wiki.example.com', + 'https', + 111, + "Do add HTTPS port to protocol-relative URLs" + ]; + return $retval; } } diff --git a/tests/phpunit/includes/MediaWikiServicesTest.php b/tests/phpunit/includes/MediaWikiServicesTest.php index 093cb07091..7763afff3a 100644 --- a/tests/phpunit/includes/MediaWikiServicesTest.php +++ b/tests/phpunit/includes/MediaWikiServicesTest.php @@ -364,6 +364,7 @@ class MediaWikiServicesTest extends MediaWikiTestCase { 'ExternalStoreFactory' => [ 'ExternalStoreFactory', ExternalStoreFactory::class ], 'PreferencesFactory' => [ 'PreferencesFactory', PreferencesFactory::class ], 'ActorMigration' => [ 'ActorMigration', ActorMigration::class ], + 'ConfigRepository' => [ 'ConfigRepository', \MediaWiki\Config\ConfigRepository::class ], ]; } diff --git a/tests/phpunit/includes/MediaWikiTest.php b/tests/phpunit/includes/MediaWikiTest.php index 7d7e637673..d79d2cf157 100644 --- a/tests/phpunit/includes/MediaWikiTest.php +++ b/tests/phpunit/includes/MediaWikiTest.php @@ -1,6 +1,8 @@ '/wiki/$1', 'wgActionPaths' => [], ] ); + + // phpcs:disable MediaWiki.Usage.SuperGlobalsUsage.SuperGlobals + $this->oldServer = $_SERVER; + $this->oldGet = $_GET; + $this->oldPost = $_POST; + } + + protected function tearDown() { + parent::tearDown(); + $_SERVER = $this->oldServer; + $_GET = $this->oldGet; + $_POST = $this->oldPost; } public static function provideTryNormaliseRedirect() { @@ -113,6 +127,13 @@ class MediaWikiTest extends MediaWikiTestCase { 'title' => 'Foo_Bar', 'redirect' => false, ], + [ + // Path with double slash prefix (T100782) + 'url' => 'http://example.org//wiki/Double_slash', + 'query' => [], + 'title' => 'Double_slash', + 'redirect' => false, + ], ]; } @@ -122,11 +143,13 @@ class MediaWikiTest extends MediaWikiTestCase { */ public function testTryNormaliseRedirect( $url, $query, $title, $expectedRedirect = false ) { // Set SERVER because interpolateTitle() doesn't use getRequestURL(), - // whereas tryNormaliseRedirect does(). + // whereas tryNormaliseRedirect does(). Also, using WebRequest allows + // us to test some quirks in that class. $_SERVER['REQUEST_URI'] = $url; + $_POST = []; + $_GET = $query; + $req = new WebRequest; - $req = new FauxRequest( $query ); - $req->setRequestURL( $url ); // This adds a virtual 'title' query parameter. Normally called from Setup.php $req->interpolateTitle(); diff --git a/tests/phpunit/includes/MultiHttpClientTest.php b/tests/phpunit/includes/MultiHttpClientTest.php new file mode 100644 index 0000000000..7073b71023 --- /dev/null +++ b/tests/phpunit/includes/MultiHttpClientTest.php @@ -0,0 +1,168 @@ +getMockBuilder( MultiHttpClient::class ) + ->setConstructorArgs( [ [] ] ) + ->setMethods( [ 'isCurlEnabled' ] )->getMock(); + $client->method( 'isCurlEnabled' )->willReturn( false ); + $this->client = $client; + } + + private function getHttpRequest( $statusValue, $statusCode, $headers = [] ) { + $httpRequest = $this->getMockBuilder( PhpHttpRequest::class ) + ->setConstructorArgs( [ '', [] ] ) + ->getMock(); + $httpRequest->expects( $this->any() ) + ->method( 'execute' ) + ->willReturn( Status::wrap( $statusValue ) ); + $httpRequest->expects( $this->any() ) + ->method( 'getResponseHeaders' ) + ->willReturn( $headers ); + $httpRequest->expects( $this->any() ) + ->method( 'getStatus' ) + ->willReturn( $statusCode ); + return $httpRequest; + } + + private function mockHttpRequestFactory( $httpRequest ) { + $factory = $this->getMockBuilder( MediaWiki\Http\HttpRequestFactory::class ) + ->getMock(); + $factory->expects( $this->any() ) + ->method( 'create' ) + ->willReturn( $httpRequest ); + return $factory; + } + + /** + * Test call of a single url that should succeed + */ + public function testMultiHttpClientSingleSuccess() { + // Mock success + $httpRequest = $this->getHttpRequest( StatusValue::newGood( 200 ), 200 ); + $this->setService( 'HttpRequestFactory', $this->mockHttpRequestFactory( $httpRequest ) ); + + list( $rcode, $rdesc, /* $rhdrs */, $rbody, $rerr ) = $this->client->run( [ + 'method' => 'GET', + 'url' => "http://example.test", + ] ); + + $this->assertEquals( 200, $rcode ); + } + + /** + * Test call of a single url that should not exist, and therefore fail + */ + public function testMultiHttpClientSingleFailure() { + // Mock an invalid tld + $httpRequest = $this->getHttpRequest( + StatusValue::newFatal( 'http-invalid-url', 'http://www.example.test' ), 0 ); + $this->setService( 'HttpRequestFactory', $this->mockHttpRequestFactory( $httpRequest ) ); + + list( $rcode, $rdesc, /* $rhdrs */, $rbody, $rerr ) = $this->client->run( [ + 'method' => 'GET', + 'url' => "http://www.example.test", + ] ); + + $failure = $rcode < 200 || $rcode >= 400; + $this->assertTrue( $failure ); + } + + /** + * Test call of multiple urls that should all succeed + */ + public function testMultiHttpClientMultipleSuccess() { + // Mock success + $httpRequest = $this->getHttpRequest( StatusValue::newGood( 200 ), 200 ); + $this->setService( 'HttpRequestFactory', $this->mockHttpRequestFactory( $httpRequest ) ); + + $reqs = [ + [ + 'method' => 'GET', + 'url' => 'http://example.test', + ], + [ + 'method' => 'GET', + 'url' => 'https://get.test', + ], + ]; + $responses = $this->client->runMulti( $reqs ); + foreach ( $responses as $response ) { + list( $rcode, $rdesc, /* $rhdrs */, $rbody, $rerr ) = $response['response']; + $this->assertEquals( 200, $rcode ); + } + } + + /** + * Test call of multiple urls that should all fail + */ + public function testMultiHttpClientMultipleFailure() { + // Mock page not found + $httpRequest = $this->getHttpRequest( + StatusValue::newFatal( "http-bad-status", 404, 'Not Found' ), 404 ); + $this->setService( 'HttpRequestFactory', $this->mockHttpRequestFactory( $httpRequest ) ); + + $reqs = [ + [ + 'method' => 'GET', + 'url' => 'http://example.test/12345', + ], + [ + 'method' => 'GET', + 'url' => 'http://example.test/67890' , + ] + ]; + $responses = $this->client->runMulti( $reqs ); + foreach ( $responses as $response ) { + list( $rcode, $rdesc, /* $rhdrs */, $rbody, $rerr ) = $response['response']; + $failure = $rcode < 200 || $rcode >= 400; + $this->assertTrue( $failure ); + } + } + + /** + * Test of response header handling + */ + public function testMultiHttpClientHeaders() { + // Represenative headers for typical requests, per MWHttpRequest::getResponseHeaders() + $headers = [ + 'content-type' => [ + 'text/html; charset=utf-8', + ], + 'date' => [ + 'Wed, 18 Jul 2018 14:52:41 GMT', + ], + 'set-cookie' => [ + 'COUNTRY=NAe6; expires=Wed, 25-Jul-2018 14:52:41 GMT; path=/; domain=.example.test', + 'LAST_NEWS=1531925562; expires=Thu, 18-Jul-2019 14:52:41 GMT; path=/; domain=.example.test', + ] + ]; + + // Mock success with specific headers + $httpRequest = $this->getHttpRequest( StatusValue::newGood( 200 ), 200, $headers ); + $this->setService( 'HttpRequestFactory', $this->mockHttpRequestFactory( $httpRequest ) ); + + list( $rcode, $rdesc, $rhdrs, $rbody, $rerr ) = $this->client->run( [ + 'method' => 'GET', + 'url' => 'http://example.test', + ] ); + + $this->assertEquals( 200, $rcode ); + $this->assertEquals( count( $headers ), count( $rhdrs ) ); + foreach ( $headers as $name => $values ) { + $value = implode( ', ', $values ); + $this->assertArrayHasKey( $name, $rhdrs ); + $this->assertEquals( $value, $rhdrs[$name] ); + } + } +} diff --git a/tests/phpunit/includes/PathRouterTest.php b/tests/phpunit/includes/PathRouterTest.php index 15c47917bb..d8916751c0 100644 --- a/tests/phpunit/includes/PathRouterTest.php +++ b/tests/phpunit/includes/PathRouterTest.php @@ -145,6 +145,58 @@ class PathRouterTest extends MediaWikiTestCase { [ 'title' => "Title_With Space" ] ], + // Double slash and dot expansion + 'Double slash in prefix' => [ + '/wiki/$1', + '//wiki/Foo', + [ 'title' => 'Foo' ] + ], + 'Double slash at start of $1' => [ + '/wiki/$1', + '/wiki//Foo', + [ 'title' => '/Foo' ] + ], + 'Double slash in middle of $1' => [ + '/wiki/$1', + '/wiki/.hack//SIGN', + [ 'title' => '.hack//SIGN' ] + ], + 'Dots removed 1' => [ + '/wiki/$1', + '/x/../wiki/Foo', + [ 'title' => 'Foo' ] + ], + 'Dots removed 2' => [ + '/wiki/$1', + '/./wiki/Foo', + [ 'title' => 'Foo' ] + ], + 'Dots retained 1' => [ + '/wiki/$1', + '/wiki/../wiki/Foo', + [ 'title' => '../wiki/Foo' ] + ], + 'Dots retained 2' => [ + '/wiki/$1', + '/wiki/./Foo', + [ 'title' => './Foo' ] + ], + 'Triple slash' => [ + '/wiki/$1', + '///wiki/Foo', + [ 'title' => 'Foo' ] + ], + // '..' only traverses one slash, see e.g. RFC 3986 + 'Dots traversing double slash 1' => [ + '/wiki/$1', + '/a//b/../../wiki/Foo', + [] + ], + 'Dots traversing double slash 2' => [ + '/wiki/$1', + '/a//b/../../../wiki/Foo', + [ 'title' => 'Foo' ] + ], ]; // Make sure the router doesn't break on special characters like $ used in regexp replacements diff --git a/tests/phpunit/includes/api/ApiBaseTest.php b/tests/phpunit/includes/api/ApiBaseTest.php index 4f65ae9685..866848b763 100644 --- a/tests/phpunit/includes/api/ApiBaseTest.php +++ b/tests/phpunit/includes/api/ApiBaseTest.php @@ -256,7 +256,6 @@ class ApiBaseTest extends ApiTestCase { } /** - * @dataProvider provideGetParameterFromSettings * @param string|null $input * @param array $paramSettings * @param mixed $expected @@ -264,13 +263,20 @@ class ApiBaseTest extends ApiTestCase { * 'parseLimits': true|false * 'apihighlimits': true|false * 'internalmode': true|false + * 'prefix': true|false * @param string[] $warnings */ - public function testGetParameterFromSettings( + private function doGetParameterFromSettings( $input, $paramSettings, $expected, $warnings, $options = [] ) { $mock = new MockApi(); $wrapper = TestingAccessWrapper::newFromObject( $mock ); + if ( $options['prefix'] ) { + $wrapper->mModulePrefix = 'my'; + $paramName = 'Param'; + } else { + $paramName = 'myParam'; + } $context = new DerivativeContext( $mock ); $context->setRequest( new FauxRequest( @@ -298,14 +304,14 @@ class ApiBaseTest extends ApiTestCase { if ( $expected instanceof Exception ) { try { - $wrapper->getParameterFromSettings( 'myParam', $paramSettings, + $wrapper->getParameterFromSettings( $paramName, $paramSettings, $parseLimits ); $this->fail( 'No exception thrown' ); } catch ( Exception $ex ) { $this->assertEquals( $expected, $ex ); } } else { - $result = $wrapper->getParameterFromSettings( 'myParam', + $result = $wrapper->getParameterFromSettings( $paramName, $paramSettings, $parseLimits ); if ( isset( $paramSettings[ApiBase::PARAM_TYPE] ) && $paramSettings[ApiBase::PARAM_TYPE] === 'timestamp' && @@ -339,6 +345,28 @@ class ApiBaseTest extends ApiTestCase { } } + /** + * @dataProvider provideGetParameterFromSettings + * @see self::doGetParameterFromSettings() + */ + public function testGetParameterFromSettings_noprefix( + $input, $paramSettings, $expected, $warnings, $options = [] + ) { + $options['prefix'] = false; + $this->doGetParameterFromSettings( $input, $paramSettings, $expected, $warnings, $options ); + } + + /** + * @dataProvider provideGetParameterFromSettings + * @see self::doGetParameterFromSettings() + */ + public function testGetParameterFromSettings_prefix( + $input, $paramSettings, $expected, $warnings, $options = [] + ) { + $options['prefix'] = true; + $this->doGetParameterFromSettings( $input, $paramSettings, $expected, $warnings, $options ); + } + public static function provideGetParameterFromSettings() { $warnings = [ [ 'apiwarn-badutf8', 'myParam' ], diff --git a/tests/phpunit/includes/api/ApiMainTest.php b/tests/phpunit/includes/api/ApiMainTest.php index f06d97efd9..20d758e3aa 100644 --- a/tests/phpunit/includes/api/ApiMainTest.php +++ b/tests/phpunit/includes/api/ApiMainTest.php @@ -967,8 +967,7 @@ class ApiMainTest extends ApiTestCase { $context->setLanguage( 'en' ); $context->setConfig( new MultiConfig( [ new HashConfig( [ - 'ShowHostnames' => true, 'ShowSQLErrors' => false, - 'ShowExceptionDetails' => true, 'ShowDBErrorBacktrace' => true, + 'ShowHostnames' => true, 'ShowExceptionDetails' => true, ] ), $context->getConfig() ] ) ); @@ -1052,7 +1051,8 @@ class ApiMainTest extends ApiTestCase { [ 'code' => 'existing-error', 'text' => 'existing error', 'module' => 'main' ], [ 'code' => 'internal_api_error_DBQueryError', - 'text' => "[$reqId] Database query error.", + 'text' => "[$reqId] Exception caught: A database query error has occurred. " . + "This may indicate a bug in the software.", ] ], 'trace' => $dbtrace, @@ -1098,4 +1098,21 @@ class ApiMainTest extends ApiTestCase { ], ]; } + + public function testPrinterParameterValidationError() { + $api = $this->getNonInternalApiMain( [ + 'action' => 'query', 'meta' => 'siteinfo', 'format' => 'json', 'formatversion' => 'bogus', + ] ); + + ob_start(); + $api->execute(); + $txt = ob_get_clean(); + + // Test that the actual output is valid JSON, not just the format of the ApiResult. + $data = FormatJson::decode( $txt, true ); + $this->assertInternalType( 'array', $data ); + $this->assertArrayHasKey( 'error', $data ); + $this->assertArrayHasKey( 'code', $data['error'] ); + $this->assertSame( 'unknown_formatversion', $data['error']['code'] ); + } } diff --git a/tests/phpunit/includes/api/format/ApiFormatBaseTest.php b/tests/phpunit/includes/api/format/ApiFormatBaseTest.php index d4aa80506e..03359f806b 100644 --- a/tests/phpunit/includes/api/format/ApiFormatBaseTest.php +++ b/tests/phpunit/includes/api/format/ApiFormatBaseTest.php @@ -10,6 +10,13 @@ class ApiFormatBaseTest extends ApiFormatTestBase { protected $printerName = 'mockbase'; + protected function setUp() { + parent::setUp(); + $this->setMwGlobals( [ + 'wgServer' => 'http://example.org' + ] ); + } + public function getMockFormatter( ApiMain $main = null, $format, $methods = [] ) { if ( $main === null ) { $context = new RequestContext; @@ -352,7 +359,7 @@ class ApiFormatBaseTest extends ApiFormatTestBase { public function testHtmlHeader( $post, $registerNonHtml, $expect ) { $context = new RequestContext; $request = new FauxRequest( [ 'a' => 1, 'b' => 2 ], $post ); - $request->setRequestURL( 'http://example.org/wx/api.php' ); + $request->setRequestURL( '/wx/api.php' ); $context->setRequest( $request ); $context->setLanguage( 'qqx' ); $main = new ApiMain( $context ); diff --git a/tests/phpunit/includes/htmlform/HTMLFormTest.php b/tests/phpunit/includes/htmlform/HTMLFormTest.php index 06772e5e68..d7dc4112b7 100644 --- a/tests/phpunit/includes/htmlform/HTMLFormTest.php +++ b/tests/phpunit/includes/htmlform/HTMLFormTest.php @@ -5,7 +5,6 @@ * * @license GPL-2.0-or-later * @author Gergő Tisza - * @author Thiemo Mättig */ class HTMLFormTest extends MediaWikiTestCase { diff --git a/tests/phpunit/includes/libs/CSSMinTest.php b/tests/phpunit/includes/libs/CSSMinTest.php index c711291483..04aecc9086 100644 --- a/tests/phpunit/includes/libs/CSSMinTest.php +++ b/tests/phpunit/includes/libs/CSSMinTest.php @@ -19,6 +19,30 @@ class CSSMinTest extends MediaWikiTestCase { ] ); } + /** + * @dataProvider providesReferencedFiles + * @covers CSSMin::getLocalFileReferences + */ + public function testGetLocalFileReferences( $input, $expected ) { + $output = CSSMin::getLocalFileReferences( $input, '/' ); + $this->assertEquals( + $expected, + $output, + 'getLocalFileReferences() must find the local file properly' + ); + } + + public static function providesReferencedFiles() { + // input, array of expected local file names + return [ + [ 'url("//example.org")', [] ], + [ 'url("https://example.org")', [] ], + [ 'url("#default#")', [] ], + [ 'url("WikiFont-Glyphs.svg#wikiglyph")', [ '/WikiFont-Glyphs.svg' ] ], + [ 'url("#some-anchor")', [] ], + ]; + } + /** * @dataProvider provideSerializeStringValue * @covers CSSMin::serializeStringValue @@ -292,6 +316,16 @@ class CSSMinTest extends MediaWikiTestCase { [ 'foo { behavior: url(#default#bar); }', false, '/w/', false ], 'foo { behavior: url("#default#bar"); }', ], + [ + 'Keeps anchors', + [ 'url(#other)', false, '/', false ], + 'url("#other")' + ], + [ + 'Keeps anchors after a path', + [ 'url(images/file.svg#id)', false, '/', false ], + 'url("/images/file.svg#id")' + ], ]; } diff --git a/tests/phpunit/includes/libs/MapCacheLRUTest.php b/tests/phpunit/includes/libs/MapCacheLRUTest.php index 79f7b96f6e..a06ef62dfc 100644 --- a/tests/phpunit/includes/libs/MapCacheLRUTest.php +++ b/tests/phpunit/includes/libs/MapCacheLRUTest.php @@ -158,10 +158,12 @@ class MapCacheLRUTest extends PHPUnit\Framework\TestCase { $now += 29; $this->assertTrue( $cache->has( 'd', 30 ) ); $this->assertEquals( 'xxx', $cache->get( 'd' ) ); + $this->assertEquals( 'xxx', $cache->get( 'd', 30 ) ); $now += 1.5; $this->assertFalse( $cache->has( 'd', 30 ) ); $this->assertEquals( 'xxx', $cache->get( 'd' ) ); + $this->assertNull( $cache->get( 'd', 30 ) ); } /** @@ -180,14 +182,17 @@ class MapCacheLRUTest extends PHPUnit\Framework\TestCase { $cache->setField( 'PMs', 'Margaret Thatcher', 'Tory' ); $this->assertTrue( $cache->hasField( 'PMs', 'Tony Blair', 30 ) ); $this->assertEquals( 'Labour', $cache->getField( 'PMs', 'Tony Blair' ) ); + $this->assertTrue( $cache->hasField( 'PMs', 'Tony Blair', 30 ) ); $now += 29; $this->assertTrue( $cache->hasField( 'PMs', 'Tony Blair', 30 ) ); $this->assertEquals( 'Labour', $cache->getField( 'PMs', 'Tony Blair' ) ); + $this->assertEquals( 'Labour', $cache->getField( 'PMs', 'Tony Blair', 30 ) ); $now += 1.5; $this->assertFalse( $cache->hasField( 'PMs', 'Tony Blair', 30 ) ); $this->assertEquals( 'Labour', $cache->getField( 'PMs', 'Tony Blair' ) ); + $this->assertNull( $cache->getField( 'PMs', 'Tony Blair', 30 ) ); $this->assertEquals( [ 'Tony Blair' => 'Labour', 'Margaret Thatcher' => 'Tory' ], diff --git a/tests/phpunit/includes/preferences/FiltersTest.php b/tests/phpunit/includes/preferences/FiltersTest.php index 42cbc2cc74..60b01b880c 100644 --- a/tests/phpunit/includes/preferences/FiltersTest.php +++ b/tests/phpunit/includes/preferences/FiltersTest.php @@ -102,7 +102,7 @@ class FiltersTest extends MediaWikiTestCase { [ '', '' ], [ "\n", '' ], [ '1', 'Foo' ], - [ "\n1\n\n2\666\n", "Foo\nBar" ], + [ "\n1\n\n2\377\n", "Foo\nBar" ], [ "666\n667", '' ], ]; } diff --git a/tests/phpunit/includes/registration/ExtensionJsonValidatorTest.php b/tests/phpunit/includes/registration/ExtensionJsonValidatorTest.php index 355f4ef0e3..46c697f8ba 100644 --- a/tests/phpunit/includes/registration/ExtensionJsonValidatorTest.php +++ b/tests/phpunit/includes/registration/ExtensionJsonValidatorTest.php @@ -52,6 +52,10 @@ class ExtensionJsonValidatorTest extends MediaWikiTestCase { 'notjson.txt', 'notjson.txt is not valid JSON' ], + [ + 'duplicate_keys.json', + 'Duplicate key: name' + ], [ 'no_manifest_version.json', 'no_manifest_version.json does not have manifest_version set.' diff --git a/tests/phpunit/includes/registration/VersionCheckerTest.php b/tests/phpunit/includes/registration/VersionCheckerTest.php index 35d4ea0997..b668a9adb0 100644 --- a/tests/phpunit/includes/registration/VersionCheckerTest.php +++ b/tests/phpunit/includes/registration/VersionCheckerTest.php @@ -17,8 +17,7 @@ class VersionCheckerTest extends PHPUnit\Framework\TestCase { 'FakeExtension' => [ 'MediaWiki' => $constraint, ], - ] ) - ); + ] ) ); } public static function provideCheck() { @@ -50,8 +49,7 @@ class VersionCheckerTest extends PHPUnit\Framework\TestCase { */ public function testType( $given, $expected ) { $checker = new VersionChecker( '1.0.0' ); - $checker - ->setLoadedExtensionsAndSkins( [ + $checker->setLoadedExtensionsAndSkins( [ 'FakeDependency' => [ 'version' => '1.0.0', ], @@ -59,8 +57,7 @@ class VersionCheckerTest extends PHPUnit\Framework\TestCase { ] ); $this->assertEquals( $expected, $checker->checkArray( [ 'FakeExtension' => $given, - ] ) - ); + ] ) ); } public static function provideType() { @@ -69,22 +66,22 @@ class VersionCheckerTest extends PHPUnit\Framework\TestCase { [ [ 'extensions' => [ - 'FakeDependency' => '1.0.0' - ] + 'FakeDependency' => '1.0.0', + ], ], - [] + [], ], [ [ - 'MediaWiki' => '1.0.0' + 'MediaWiki' => '1.0.0', ], - [] + [], ], [ [ 'extensions' => [ - 'NoVersionGiven' => '*' - ] + 'NoVersionGiven' => '*', + ], ], [], ], @@ -92,39 +89,59 @@ class VersionCheckerTest extends PHPUnit\Framework\TestCase { [ 'extensions' => [ 'NoVersionGiven' => '1.0', - ] + ], + ], + [ + [ + 'incompatible' => 'FakeExtension', + 'type' => 'incompatible-extensions', + 'msg' => 'NoVersionGiven does not expose its version, but FakeExtension requires: 1.0.', + ], ], - [ [ - 'incompatible' => 'FakeExtension', - 'type' => 'incompatible-extensions', - 'msg' => 'NoVersionGiven does not expose its version, but FakeExtension requires: 1.0.' - ] ], ], [ [ 'extensions' => [ 'Missing' => '*', - ] + ], + ], + [ + [ + 'missing' => 'Missing', + 'type' => 'missing-extensions', + 'msg' => 'FakeExtension requires Missing to be installed.', + ], ], - [ [ - 'missing' => 'Missing', - 'type' => 'missing-extensions', - 'msg' => 'FakeExtension requires Missing to be installed.', - ] ], ], [ [ 'extensions' => [ 'FakeDependency' => '2.0.0', - ] - ], - [ [ - 'incompatible' => 'FakeExtension', - 'type' => 'incompatible-extensions', - // phpcs:ignore Generic.Files.LineLength.TooLong - 'msg' => 'FakeExtension is not compatible with the current installed version of FakeDependency (1.0.0), it requires: 2.0.0.' - ] ], - ] + ], + ], + [ + [ + 'incompatible' => 'FakeExtension', + 'type' => 'incompatible-extensions', + // phpcs:ignore Generic.Files.LineLength.TooLong + 'msg' => 'FakeExtension is not compatible with the current installed version of FakeDependency (1.0.0), it requires: 2.0.0.', + ], + ], + ], + [ + [ + 'skins' => [ + 'FakeSkin' => '*', + ], + ], + [ + [ + 'missing' => 'FakeSkin', + 'type' => 'missing-skins', + 'msg' => 'FakeExtension requires FakeSkin to be installed.', + ], + ], + ], ]; } @@ -134,29 +151,26 @@ class VersionCheckerTest extends PHPUnit\Framework\TestCase { */ public function testInvalidConstraint() { $checker = new VersionChecker( '1.0.0' ); - $checker - ->setLoadedExtensionsAndSkins( [ + $checker->setLoadedExtensionsAndSkins( [ 'FakeDependency' => [ 'version' => 'not really valid', ], ] ); - $this->assertEquals( - [ [ + $this->assertEquals( [ + [ 'type' => 'invalid-version', - 'msg' => "FakeDependency does not have a valid version string." - ] ], - $checker->checkArray( [ - 'FakeExtension' => [ - 'extensions' => [ - 'FakeDependency' => '1.24.3', - ], + 'msg' => "FakeDependency does not have a valid version string.", + ], + ], $checker->checkArray( [ + 'FakeExtension' => [ + 'extensions' => [ + 'FakeDependency' => '1.24.3', ], - ] ) - ); + ], + ] ) ); $checker = new VersionChecker( '1.0.0' ); - $checker - ->setLoadedExtensionsAndSkins( [ + $checker->setLoadedExtensionsAndSkins( [ 'FakeDependency' => [ 'version' => '1.24.3', ], @@ -166,7 +180,28 @@ class VersionCheckerTest extends PHPUnit\Framework\TestCase { $checker->checkArray( [ 'FakeExtension' => [ 'FakeDependency' => 'not really valid', - ] + ], ] ); } + + /** + * T197478 + */ + public function testInvalidDependency() { + $checker = new VersionChecker( '1.0.0' ); + $this->setExpectedException( UnexpectedValueException::class, + 'Dependency type skin unknown in FakeExtension' ); + $this->assertEquals( [ + [ + 'type' => 'invalid-version', + 'msg' => 'FakeDependency does not have a valid version string.', + ], + ], $checker->checkArray( [ + 'FakeExtension' => [ + 'skin' => [ + 'FakeSkin' => '*', + ], + ], + ] ) ); + } } diff --git a/tests/phpunit/languages/LanguageCodeTest.php b/tests/phpunit/languages/LanguageCodeTest.php index f14d2cea06..544a063566 100644 --- a/tests/phpunit/languages/LanguageCodeTest.php +++ b/tests/phpunit/languages/LanguageCodeTest.php @@ -54,18 +54,14 @@ class LanguageCodeTest extends PHPUnit\Framework\TestCase { * @dataProvider provideLanguageCodes() */ public function testBcp47( $code, $expected ) { - $this->assertEquals( $expected, LanguageCode::bcp47( $code ), - "Applying BCP 47 standard to '$code'" - ); - $code = strtolower( $code ); $this->assertEquals( $expected, LanguageCode::bcp47( $code ), - "Applying BCP 47 standard to lower case '$code'" + "Applying BCP47 standard to lower case '$code'" ); $code = strtoupper( $code ); $this->assertEquals( $expected, LanguageCode::bcp47( $code ), - "Applying BCP 47 standard to upper case '$code'" + "Applying BCP47 standard to upper case '$code'" ); } @@ -159,41 +155,6 @@ class LanguageCodeTest extends PHPUnit\Framework\TestCase { // de-419-DE // a-DE // ar-a-aaa-b-bbb-a-ccc - - # Non-standard and deprecated language codes used by MediaWiki - [ 'als', 'gsw' ], - [ 'bat-smg', 'sgs' ], - [ 'be-x-old', 'be-tarask' ], - [ 'fiu-vro', 'vro' ], - [ 'roa-rup', 'rup' ], - [ 'zh-classical', 'lzh' ], - [ 'zh-min-nan', 'nan' ], - [ 'zh-yue', 'yue' ], - [ 'cbk-zam', 'cbk' ], - [ 'de-formal', 'de-x-formal' ], - [ 'eml', 'egl' ], - [ 'en-rtl', 'en-x-rtl' ], - [ 'es-formal', 'es-x-formal' ], - [ 'hu-formal', 'hu-x-formal' ], - [ 'kk-Arab', 'kk-Arab' ], - [ 'kk-Cyrl', 'kk-Cyrl' ], - [ 'kk-Latn', 'kk-Latn' ], - [ 'map-bms', 'jv-x-bms' ], - [ 'mo', 'ro-MD' ], - [ 'nrm', 'nrf' ], - [ 'nl-informal', 'nl-x-informal' ], - [ 'roa-tara', 'nap-x-tara' ], - [ 'simple', 'en-simple' ], - [ 'sr-ec', 'sr-Cyrl' ], - [ 'sr-el', 'sr-Latn' ], - [ 'zh-cn', 'zh-Hans-CN' ], - [ 'zh-sg', 'zh-Hans-SG' ], - [ 'zh-my', 'zh-Hans-MY' ], - [ 'zh-tw', 'zh-Hant-TW' ], - [ 'zh-hk', 'zh-Hant-HK' ], - [ 'zh-mo', 'zh-Hant-MO' ], - [ 'zh-hans', 'zh-Hans' ], - [ 'zh-hant', 'zh-Hant' ], ]; } diff --git a/tests/phpunit/languages/LanguageConverterTest.php b/tests/phpunit/languages/LanguageConverterTest.php index b5db2ec11a..82ab7def22 100644 --- a/tests/phpunit/languages/LanguageConverterTest.php +++ b/tests/phpunit/languages/LanguageConverterTest.php @@ -20,9 +20,7 @@ class LanguageConverterTest extends MediaWikiLangTestCase { $this->lang = new LanguageToTest(); $this->lc = new TestConverter( $this->lang, 'tg', - # Adding 'sgs' as a variant to ensure we handle deprecated codes - # adding 'simple' as a variant to ensure we handle non BCP 47 codes - [ 'tg', 'tg-latn', 'sgs', 'simple' ] + [ 'tg', 'tg-latn' ] ); } @@ -40,39 +38,6 @@ class LanguageConverterTest extends MediaWikiLangTestCase { $this->assertEquals( 'tg', $this->lc->getPreferredVariant() ); } - /** - * @covers LanguageConverter::getPreferredVariant - * @covers LanguageConverter::getURLVariant - */ - public function testGetPreferredVariantUrl() { - global $wgRequest; - $wgRequest->setVal( 'variant', 'tg-latn' ); - - $this->assertEquals( 'tg-latn', $this->lc->getPreferredVariant() ); - } - - /** - * @covers LanguageConverter::getPreferredVariant - * @covers LanguageConverter::getURLVariant - */ - public function testGetPreferredVariantUrlDeprecated() { - global $wgRequest; - $wgRequest->setVal( 'variant', 'bat-smg' ); - - $this->assertEquals( 'sgs', $this->lc->getPreferredVariant() ); - } - - /** - * @covers LanguageConverter::getPreferredVariant - * @covers LanguageConverter::getURLVariant - */ - public function testGetPreferredVariantUrlBCP47() { - global $wgRequest; - $wgRequest->setVal( 'variant', 'en-simple' ); - - $this->assertEquals( 'simple', $this->lc->getPreferredVariant() ); - } - /** * @covers LanguageConverter::getPreferredVariant * @covers LanguageConverter::getHeaderVariant @@ -84,17 +49,6 @@ class LanguageConverterTest extends MediaWikiLangTestCase { $this->assertEquals( 'tg-latn', $this->lc->getPreferredVariant() ); } - /** - * @covers LanguageConverter::getPreferredVariant - * @covers LanguageConverter::getHeaderVariant - */ - public function testGetPreferredVariantHeadersBCP47() { - global $wgRequest; - $wgRequest->setHeader( 'Accept-Language', 'en-simple' ); - - $this->assertEquals( 'simple', $this->lc->getPreferredVariant() ); - } - /** * @covers LanguageConverter::getPreferredVariant * @covers LanguageConverter::getHeaderVariant @@ -144,38 +98,6 @@ class LanguageConverterTest extends MediaWikiLangTestCase { $this->assertEquals( 'tg-latn', $this->lc->getPreferredVariant() ); } - /** - * @covers LanguageConverter::getPreferredVariant - */ - public function testGetPreferredVariantUserOptionDeprecated() { - global $wgUser; - - $wgUser = new User; - $wgUser->load(); // from 'defaults' - $wgUser->mId = 1; - $wgUser->mDataLoaded = true; - $wgUser->mOptionsLoaded = true; - $wgUser->setOption( 'variant', 'bat-smg' ); - - $this->assertEquals( 'sgs', $this->lc->getPreferredVariant() ); - } - - /** - * @covers LanguageConverter::getPreferredVariant - */ - public function testGetPreferredVariantUserOptionBCP47() { - global $wgUser; - - $wgUser = new User; - $wgUser->load(); // from 'defaults' - $wgUser->mId = 1; - $wgUser->mDataLoaded = true; - $wgUser->mOptionsLoaded = true; - $wgUser->setOption( 'variant', 'en-simple' ); - - $this->assertEquals( 'simple', $this->lc->getPreferredVariant() ); - } - /** * @covers LanguageConverter::getPreferredVariant * @covers LanguageConverter::getUserVariant @@ -194,42 +116,6 @@ class LanguageConverterTest extends MediaWikiLangTestCase { $this->assertEquals( 'tg-latn', $this->lc->getPreferredVariant() ); } - /** - * @covers LanguageConverter::getPreferredVariant - * @covers LanguageConverter::getUserVariant - */ - public function testGetPreferredVariantUserOptionForForeignLanguageDeprecated() { - global $wgContLang, $wgUser; - - $wgContLang = Language::factory( 'en' ); - $wgUser = new User; - $wgUser->load(); // from 'defaults' - $wgUser->mId = 1; - $wgUser->mDataLoaded = true; - $wgUser->mOptionsLoaded = true; - $wgUser->setOption( 'variant-tg', 'bat-smg' ); - - $this->assertEquals( 'sgs', $this->lc->getPreferredVariant() ); - } - - /** - * @covers LanguageConverter::getPreferredVariant - * @covers LanguageConverter::getUserVariant - */ - public function testGetPreferredVariantUserOptionForForeignLanguageBCP47() { - global $wgContLang, $wgUser; - - $wgContLang = Language::factory( 'en' ); - $wgUser = new User; - $wgUser->load(); // from 'defaults' - $wgUser->mId = 1; - $wgUser->mDataLoaded = true; - $wgUser->mOptionsLoaded = true; - $wgUser->setOption( 'variant-tg', 'en-simple' ); - - $this->assertEquals( 'simple', $this->lc->getPreferredVariant() ); - } - /** * @covers LanguageConverter::getPreferredVariant * @covers LanguageConverter::getUserVariant @@ -259,26 +145,6 @@ class LanguageConverterTest extends MediaWikiLangTestCase { $this->assertEquals( 'tg-latn', $this->lc->getPreferredVariant() ); } - /** - * @covers LanguageConverter::getPreferredVariant - */ - public function testGetPreferredVariantDefaultLanguageVariantDeprecated() { - global $wgDefaultLanguageVariant; - - $wgDefaultLanguageVariant = 'bat-smg'; - $this->assertEquals( 'sgs', $this->lc->getPreferredVariant() ); - } - - /** - * @covers LanguageConverter::getPreferredVariant - */ - public function testGetPreferredVariantDefaultLanguageVariantBCP47() { - global $wgDefaultLanguageVariant; - - $wgDefaultLanguageVariant = 'en-simple'; - $this->assertEquals( 'simple', $this->lc->getPreferredVariant() ); - } - /** * @covers LanguageConverter::getPreferredVariant * @covers LanguageConverter::getURLVariant @@ -326,8 +192,6 @@ class TestConverter extends LanguageConverter { function loadDefaultTables() { $this->mTables = [ - 'sgs' => new ReplacementArray(), - 'simple' => new ReplacementArray(), 'tg-latn' => new ReplacementArray( $this->table ), 'tg' => new ReplacementArray() ]; diff --git a/tests/qunit/suites/resources/mediawiki/mediawiki.language.test.js b/tests/qunit/suites/resources/mediawiki/mediawiki.language.test.js index af5433acc3..9ea3c110f3 100644 --- a/tests/qunit/suites/resources/mediawiki/mediawiki.language.test.js +++ b/tests/qunit/suites/resources/mediawiki/mediawiki.language.test.js @@ -691,57 +691,19 @@ // # Tags that use extensions [ 'en-us-u-islamcal', 'en-US-u-islamcal' ], [ 'zh-cn-a-myext-x-private', 'zh-CN-a-myext-x-private' ], - [ 'en-a-myext-b-another', 'en-a-myext-b-another' ], + [ 'en-a-myext-b-another', 'en-a-myext-b-another' ] // # Invalid: // de-419-DE // a-DE // ar-a-aaa-b-bbb-a-ccc - - // Non-standard and deprecated language codes used by MediaWiki - [ 'als', 'gsw' ], - [ 'bat-smg', 'sgs' ], - [ 'be-x-old', 'be-tarask' ], - [ 'fiu-vro', 'vro' ], - [ 'roa-rup', 'rup' ], - [ 'zh-classical', 'lzh' ], - [ 'zh-min-nan', 'nan' ], - [ 'zh-yue', 'yue' ], - [ 'cbk-zam', 'cbk' ], - [ 'de-formal', 'de-x-formal' ], - [ 'eml', 'egl' ], - [ 'en-rtl', 'en-x-rtl' ], - [ 'es-formal', 'es-x-formal' ], - [ 'hu-formal', 'hu-x-formal' ], - [ 'kk-Arab', 'kk-Arab' ], - [ 'kk-Cyrl', 'kk-Cyrl' ], - [ 'kk-Latn', 'kk-Latn' ], - [ 'map-bms', 'jv-x-bms' ], - [ 'mo', 'ro-MD' ], - [ 'nrm', 'nrf' ], - [ 'nl-informal', 'nl-x-informal' ], - [ 'roa-tara', 'nap-x-tara' ], - [ 'simple', 'en-simple' ], - [ 'sr-ec', 'sr-Cyrl' ], - [ 'sr-el', 'sr-Latn' ], - [ 'zh-cn', 'zh-Hans-CN' ], - [ 'zh-sg', 'zh-Hans-SG' ], - [ 'zh-my', 'zh-Hans-MY' ], - [ 'zh-tw', 'zh-Hant-TW' ], - [ 'zh-hk', 'zh-Hant-HK' ], - [ 'zh-mo', 'zh-Hant-MO' ], - [ 'zh-hans', 'zh-Hans' ], - [ 'zh-hant', 'zh-Hant' ] ]; QUnit.test( 'mw.language.bcp47', function ( assert ) { - mw.language.data = this.liveLangData; bcp47Tests.forEach( function ( data ) { var input = data[ 0 ], expected = data[ 1 ]; assert.strictEqual( mw.language.bcp47( input ), expected ); - assert.strictEqual( mw.language.bcp47( input.toLowerCase() ), expected ); - assert.strictEqual( mw.language.bcp47( input.toUpperCase() ), expected ); } ); } ); }( mediaWiki, jQuery ) );