From: jenkins-bot Date: Mon, 23 Sep 2019 12:30:46 +0000 (+0000) Subject: Merge "FauxRequest: don’t override getValues()" X-Git-Tag: 1.34.0-rc.0~122 X-Git-Url: https://git.heureux-cyclage.org/?p=lhc%2Fweb%2Fwiklou.git;a=commitdiff_plain;h=af80076034fb734d652eb043c523c1d8df974e51;hp=568631af97fdde99d1b218776c94b298c0fb171e Merge "FauxRequest: don’t override getValues()" --- diff --git a/.phan/config.php b/.phan/config.php index fc775fe5fe..0fdefe054d 100644 --- a/.phan/config.php +++ b/.phan/config.php @@ -101,11 +101,6 @@ $cfg['suppress_issue_types'] = array_merge( $cfg['suppress_issue_types'], [ //after dropping HHVM // approximate error count: 110 "PhanParamTooMany", // False positives with variargs. Unsuppress after dropping HHVM - - // approximate error count: 45 - "PhanTypeMismatchArgument", - // approximate error count: 693 - "PhanUndeclaredProperty", ] ); // This helps a lot in discovering bad code, but unfortunately it will always fail for @@ -113,6 +108,10 @@ $cfg['suppress_issue_types'] = array_merge( $cfg['suppress_issue_types'], [ // @todo Enable when the issue above is resolved and we update our config! $cfg['redundant_condition_detection'] = false; +// Do not use aliases in core. +// Use the correct name, because we don't need backward compatibility +$cfg['enable_class_alias_support'] = false; + $cfg['ignore_undeclared_variables_in_global_scope'] = true; // @todo It'd be great if we could just make phan read these from DefaultSettings, to avoid // duplicating the types. diff --git a/.travis.yml b/.travis.yml index d5607f1609..8dbc5f203c 100644 --- a/.travis.yml +++ b/.travis.yml @@ -26,8 +26,6 @@ matrix: include: - php: 7.3 - php: 7.2 - - php: 7.1 - - php: 7 services: - mysql diff --git a/CODE_OF_CONDUCT.md b/CODE_OF_CONDUCT.md index 498acf76f7..3d9f26ad44 100644 --- a/CODE_OF_CONDUCT.md +++ b/CODE_OF_CONDUCT.md @@ -1 +1,4 @@ +Code of Conduct +=============== + The development of this software is covered by a [Code of Conduct](https://www.mediawiki.org/wiki/Special:MyLanguage/Code_of_Conduct). diff --git a/INSTALL b/INSTALL index 07dd9c3090..0359166d22 100644 --- a/INSTALL +++ b/INSTALL @@ -7,7 +7,7 @@ Starting with MediaWiki 1.2.0, it's possible to install and configure the wiki Required software as of MediaWiki 1.34.0: -* Web server with PHP 7.0.13 or higher, plus the following extesnsions: +* Web server with PHP 7.2.0 or higher, plus the following extesnsions: ** ctype ** dom ** fileinfo diff --git a/RELEASE-NOTES-1.34 b/RELEASE-NOTES-1.34 index 09195e162c..508ba08955 100644 --- a/RELEASE-NOTES-1.34 +++ b/RELEASE-NOTES-1.34 @@ -141,7 +141,7 @@ $wgPasswordPolicy['policies']['default']['PasswordNotInLargeBlacklist'] = false; * Updated mediawiki/codesniffer from 25.0.0 to 26.0.0 (dev-only). * Updated cssjanus/cssjanus from 1.2.1 to 1.3.0. * Updated wikimedia/at-ease from 1.2.0 to 2.0.0. -* Updated wikimedia/remex-html from 2.0.1 to 2.0.3. +* Updated wikimedia/remex-html from 2.0.1 to 2.1.0. * Updated monolog/monolog from 1.22.1 to 1.24.0 (dev-only). * Updated wikimedia/object-factory from 1.0.0 to 2.1.0. * Updated wikimedia/timestamp from 2.2.0 to 3.0.0. @@ -164,6 +164,21 @@ $wgPasswordPolicy['policies']['default']['PasswordNotInLargeBlacklist'] = false; deprecated in 1.25, has been removed. * (T60993) action=query list=filearchive, list=alldeletedrevisions and prop=deletedrevisions no longer require the 'deletedhistory' user right. +* In the response to queries that use 'prop=imageinfo', entries for + non-existing files (indicated by the 'filemissing' field) now omit the + following fields, since they are meaningless in this context: + 'timestamp', 'userhidden', 'user', 'userid', 'anon', 'size', 'width', + 'height', 'pagecount', 'duration', 'commenthidden', 'parsedcomment', + 'comment', 'thumburl', 'thumbwidth', 'thumbheight', 'thumbmime', + 'thumberror', 'url', 'sha1', 'metadata', 'extmetadata', 'commonmetadata', + 'mime', 'mediadtype', 'bitdepth'. + Clients that process these fields should first check if 'filemissing' is + set. Fields that are supported even if the file is missing include: + 'canonicaltitle', ''archivename' (deleted files only), 'descriptionurl', + 'descriptionshorturl'. +* The 'blockexpiry' result property in list=users and list=allusers will now be + returned in the same format used by the rest of the API: ISO 8601 for + expiring blocks, and "infinite" for non-expiring blocks. === Action API internal changes in 1.34 === * The exception thrown in ApiModuleManager::getModule has been changed @@ -171,7 +186,7 @@ $wgPasswordPolicy['policies']['default']['PasswordNotInLargeBlacklist'] = false; ApiModuleManager::getModule now also throws InvalidArgumentExceptions when ObjectFactory is presented with an invalid spec or incorrectly constructed objects. -* … +* Added ApiQueryBlockInfoTrait. === Languages updated in 1.34 === MediaWiki supports over 350 languages. Many localisations are updated regularly. @@ -302,6 +317,11 @@ because of Phabricator reports. Use the mediawiki.String module instead. * mw.language.specialCharacters, deprecated in 1.33, has been removed. Use require( 'mediawiki.language.specialCharacters' ) instead. +* The jquery.colorUtil module was removed. Use jquery.color instead. +* The jquery.checkboxShiftClick module was removed. The functionality + is provided by mediawiki.page.ready instead (T232688). +* The 'jquery.accessKeyLabel' module has been removed. This jQuery + plugin now ships as part of the 'mediawiki.util' module bundle. * EditPage::submit(), deprecated in 1.29, has been removed. Use $this->edit() directly. * HTMLForm::getErrors(), deprecated in 1.28, has been removed. Use @@ -428,6 +448,9 @@ because of Phabricator reports. * Revision::selectTextFields() * Revision::selectPageFields() * Revision::selectUserFields() +* User::setNewpassword(), deprecated in 1.27 has been removed. +* The ObjectCache::getMainWANInstance and ObjectCache::getMainStashInstance + functions, deprecated since 1.28, have been removed. === Deprecations in 1.34 === * The MWNamespace class is deprecated. Use NamespaceInfo. @@ -483,8 +506,6 @@ because of Phabricator reports. * ResourceLoaderContext::getConfig and ResourceLoaderContext::getLogger have been deprecated. Inside ResourceLoaderModule subclasses, use the local methods instead. Elsewhere, use the methods from the ResourceLoader class. -* The 'jquery.accessKeyLabel' module has been deprecated. This jQuery - plugin is now ships as part of the 'mediawiki.util' module bundle. * The Profiler::setTemplated and Profiler::getTemplated methods have been deprecated. Use Profiler::setAllowOutput and Profiler::getAllowOutput instead. @@ -563,13 +584,21 @@ because of Phabricator reports. * The GetBlockedStatus hook is deprecated. Use GetUserBlock instead, to add or remove a block. * $wgContentHandlerUseDB is deprecated and should always be true. +* StreamFile::send404Message() and StreamFile::parseRange() are now deprecated. + Use HTTPFileStreamer::send404Message() and HTTPFileStreamer::parseRange() + respectively instead. +* Global variable $wgSysopEmailBans is deprecated; to allow sysops to ban + users from sending emails, use + $wgGroupPermissions['sysop']['blockemail'] = true; +* ApiQueryBase::showHiddenUsersAddBlockInfo() is deprecated. Use + ApiQueryBlockInfoTrait instead. === Other changes in 1.34 === * … == Compatibility == -MediaWiki 1.34 requires PHP 7.0.13 or later. Although HHVM 3.18.5 or later is -supported, it is generally advised to use PHP 7.0.13 or later for long term +MediaWiki 1.34 requires PHP 7.2.0 or later. Although HHVM 3.18.5 or later is +supported, it is generally advised to use PHP 7.2.0 or later for long term support. It also requires the following PHP extensions: * ctype diff --git a/autoload.php b/autoload.php index f95e0015a7..7ff29ce803 100644 --- a/autoload.php +++ b/autoload.php @@ -89,6 +89,7 @@ $wgAutoloadLocalClasses = [ 'ApiQueryBacklinks' => __DIR__ . '/includes/api/ApiQueryBacklinks.php', 'ApiQueryBacklinksprop' => __DIR__ . '/includes/api/ApiQueryBacklinksprop.php', 'ApiQueryBase' => __DIR__ . '/includes/api/ApiQueryBase.php', + 'ApiQueryBlockInfoTrait' => __DIR__ . '/includes/api/ApiQueryBlockInfoTrait.php', 'ApiQueryBlocks' => __DIR__ . '/includes/api/ApiQueryBlocks.php', 'ApiQueryCategories' => __DIR__ . '/includes/api/ApiQueryCategories.php', 'ApiQueryCategoryInfo' => __DIR__ . '/includes/api/ApiQueryCategoryInfo.php', @@ -272,6 +273,7 @@ $wgAutoloadLocalClasses = [ 'CleanupInvalidDbKeys' => __DIR__ . '/maintenance/cleanupInvalidDbKeys.php', 'CleanupPreferences' => __DIR__ . '/maintenance/cleanupPreferences.php', 'CleanupRemovedModules' => __DIR__ . '/maintenance/cleanupRemovedModules.php', + 'CleanupRevActorPage' => __DIR__ . '/maintenance/cleanupRevActorPage.php', 'CleanupSpam' => __DIR__ . '/maintenance/cleanupSpam.php', 'CleanupUploadStash' => __DIR__ . '/maintenance/cleanupUploadStash.php', 'CleanupUsersWithNoId' => __DIR__ . '/maintenance/cleanupUsersWithNoId.php', diff --git a/composer.json b/composer.json index c1f9037fb3..1f2776c266 100644 --- a/composer.json +++ b/composer.json @@ -28,7 +28,7 @@ "ext-xml": "*", "guzzlehttp/guzzle": "6.3.3", "liuggio/statsd-php-client": "1.0.18", - "oojs/oojs-ui": "0.34.0", + "oojs/oojs-ui": "0.34.1", "pear/mail": "1.4.1", "pear/mail_mime": "1.10.2", "pear/net_smtp": "1.8.1", @@ -49,7 +49,7 @@ "wikimedia/php-session-serializer": "1.0.7", "wikimedia/purtle": "1.0.7", "wikimedia/relpath": "2.1.1", - "wikimedia/remex-html": "2.0.3", + "wikimedia/remex-html": "2.1.0", "wikimedia/running-stat": "1.2.1", "wikimedia/scoped-callback": "3.0.0", "wikimedia/utfnormal": "2.0.0", diff --git a/docs/hooks.txt b/docs/hooks.txt index 43bfd8d4b4..55ba06e605 100644 --- a/docs/hooks.txt +++ b/docs/hooks.txt @@ -2921,7 +2921,7 @@ result augmentors. Note that lists should be in the format name => object and the names in both lists should be distinct. -'SecondaryDataUpdates': DEPRECATED! Use RevisionDataUpdates or override +'SecondaryDataUpdates': DEPRECATED since 1.32! Use RevisionDataUpdates or override ContentHandler::getSecondaryDataUpdates instead. Allows modification of the list of DataUpdates to perform when page content is modified. $title: Title of the page that is being edited. @@ -3969,7 +3969,7 @@ dumps. One, and only one hook should set this, and return false. &$opts: Options to use for the query &$join: Join conditions -'WikiPageDeletionUpdates': DEPRECATED! Use PageDeletionDataUpdates or +'WikiPageDeletionUpdates': DEPRECATED since 1.32! Use PageDeletionDataUpdates or override ContentHandler::getDeletionDataUpdates instead. Manipulates the list of DeferrableUpdates to be applied when a page is deleted. $page: the WikiPage diff --git a/includes/AjaxResponse.php b/includes/AjaxResponse.php index 0664652a7e..faff021859 100644 --- a/includes/AjaxResponse.php +++ b/includes/AjaxResponse.php @@ -55,7 +55,7 @@ class AjaxResponse { /** * HTTP response code - * @var string $mResponseCode + * @var int|string $mResponseCode */ private $mResponseCode; @@ -114,7 +114,7 @@ class AjaxResponse { /** * Set the HTTP response code - * @param string $code + * @param int|string $code */ function setResponseCode( $code ) { $this->mResponseCode = $code; diff --git a/includes/Autopromote.php b/includes/Autopromote.php index 2156787886..f8f3c24a6a 100644 --- a/includes/Autopromote.php +++ b/includes/Autopromote.php @@ -187,10 +187,10 @@ class Autopromote { } return $user->getEditCount() >= $reqEditCount; case APCOND_AGE: - $age = time() - wfTimestampOrNull( TS_UNIX, $user->getRegistration() ); + $age = time() - (int)wfTimestampOrNull( TS_UNIX, $user->getRegistration() ); return $age >= $cond[1]; case APCOND_AGE_FROM_EDIT: - $age = time() - wfTimestampOrNull( TS_UNIX, $user->getFirstEditTimestamp() ); + $age = time() - (int)wfTimestampOrNull( TS_UNIX, $user->getFirstEditTimestamp() ); return $age >= $cond[1]; case APCOND_INGROUPS: $groups = array_slice( $cond, 1 ); diff --git a/includes/DefaultSettings.php b/includes/DefaultSettings.php index 47fd073153..fd1affce3d 100644 --- a/includes/DefaultSettings.php +++ b/includes/DefaultSettings.php @@ -2733,16 +2733,17 @@ $wgExtensionInfoMTime = false; * although they are sometimes still referred to as Squid settings for * historical reasons. * - * Achieving a high hit ratio with an HTTP proxy requires special - * configuration. See https://www.mediawiki.org/wiki/Manual:Squid_caching for - * more details. + * Achieving a high hit ratio with an HTTP proxy requires special configuration. + * See https://www.mediawiki.org/wiki/Manual:Performance_tuning#Page_view_caching + * for more details. * * @{ */ /** * Enable/disable CDN. - * See https://www.mediawiki.org/wiki/Manual:Squid_caching + * + * See https://www.mediawiki.org/wiki/Manual:Performance_tuning#Page_view_caching * * @since 1.34 Renamed from $wgUseSquid. */ @@ -4444,7 +4445,8 @@ $wgCentralIdLookupProvider = 'local'; * The checks supported by core are: * - MinimalPasswordLength - Minimum length a user can set. * - MinimumPasswordLengthToLogin - Passwords shorter than this will - * not be allowed to login, regardless if it is correct. + * not be allowed to login, or offered a chance to reset their password + * as part of the login workflow, regardless if it is correct. * - MaximalPasswordLength - maximum length password a user is allowed * to attempt. Prevents DoS attacks with pbkdf2. * - PasswordCannotMatchUsername - Password cannot match the username. @@ -4990,6 +4992,8 @@ $wgBlockAllowsUTEdit = true; /** * Allow sysops to ban users from accessing Emailuser + * @deprecated since 1.34; `$wgGroupPermissions['sysop']['blockemail'] = true;` + * should be used instead */ $wgSysopEmailBans = true; diff --git a/includes/DevelopmentSettings.php b/includes/DevelopmentSettings.php index d93caa7dea..668de3975d 100644 --- a/includes/DevelopmentSettings.php +++ b/includes/DevelopmentSettings.php @@ -27,7 +27,7 @@ ini_set( 'display_errors', 1 ); global $wgDevelopmentWarnings, $wgShowExceptionDetails, $wgShowHostnames, $wgDebugRawPage, $wgCommandLineMode, $wgDebugLogFile, - $wgDBerrorLog, $wgDebugLogGroups; + $wgDBerrorLog, $wgDebugLogGroups, $wgLocalisationCacheConf; // Use of wfWarn() should cause tests to fail $wgDevelopmentWarnings = true; @@ -74,3 +74,6 @@ $wgSQLMode = 'TRADITIONAL'; // Disable legacy javascript globals in CI and for devs (T72470) $wgLegacyJavaScriptGlobals = false; + +// Localisation Cache to StaticArray (T218207) +$wgLocalisationCacheConf['store'] = 'array'; diff --git a/includes/EditPage.php b/includes/EditPage.php index c346b750d9..fe00149920 100644 --- a/includes/EditPage.php +++ b/includes/EditPage.php @@ -25,7 +25,7 @@ use MediaWiki\EditPage\TextboxBuilder; use MediaWiki\EditPage\TextConflictHelper; use MediaWiki\Logger\LoggerFactory; use MediaWiki\MediaWikiServices; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; use Wikimedia\ScopedCallback; /** @@ -1156,7 +1156,7 @@ class EditPage { $out->showErrorPage( 'modeleditnotsupported-title', 'modeleditnotsupported-text', - $modelName + [ $modelName ] ); return false; } @@ -1188,7 +1188,7 @@ class EditPage { /** * @param Content|null $def_content The default value to return * - * @return Content|null Content on success, $def_content for invalid sections + * @return Content|false|null Content on success, $def_content for invalid sections * * @since 1.21 */ @@ -1683,7 +1683,9 @@ class EditPage { case self::AS_CANNOT_USE_CUSTOM_MODEL: case self::AS_PARSE_ERROR: case self::AS_UNICODE_NOT_SUPPORTED: - $out->wrapWikiTextAsInterface( 'error', $status->getWikiText() ); + $out->wrapWikiTextAsInterface( 'error', + $status->getWikiText( false, false, $this->context->getLanguage() ) + ); return true; case self::AS_SUCCESS_NEW_ARTICLE: @@ -1757,7 +1759,8 @@ class EditPage { // is if an extension hook aborted from inside ArticleSave. // Render the status object into $this->hookError // FIXME this sucks, we should just use the Status object throughout - $this->hookError = '
' . "\n" . $status->getWikiText() . + $this->hookError = '
' . "\n" . + $status->getWikiText( false, false, $this->context->getLanguage() ) . '
'; return true; } @@ -2742,7 +2745,7 @@ ERROR; * content. * * @param Content|null|bool|string $content - * @return string The editable text form of the content. + * @return string|false|null The editable text form of the content. * * @throws MWException If $content is not an instance of TextContent and * $this->allowNonTextContent is not true. @@ -4045,11 +4048,11 @@ ERROR; if ( $this->isConflict ) { $conflict = Html::rawElement( - 'h2', [ 'id' => 'mw-previewconflict' ], + 'div', [ 'id' => 'mw-previewconflict', 'class' => 'warningbox' ], $this->context->msg( 'previewconflict' )->escaped() ); } else { - $conflict = '
'; + $conflict = ''; } $previewhead = Html::rawElement( @@ -4058,7 +4061,9 @@ ERROR; 'h2', [ 'id' => 'mw-previewheader' ], $this->context->msg( 'preview' )->escaped() ) . - $out->parseAsInterface( $note ) . $conflict + Html::rawElement( 'div', [ 'class' => 'warningbox' ], + $out->parseAsInterface( $note ) + ) . $conflict ); $pageViewLang = $this->mTitle->getPageViewLanguage(); diff --git a/includes/FeedUtils.php b/includes/FeedUtils.php index 8efae4f7d6..bfd1e2a6cd 100644 --- a/includes/FeedUtils.php +++ b/includes/FeedUtils.php @@ -21,7 +21,7 @@ * @ingroup Feed */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; /** * Helper functions for feeds diff --git a/includes/GlobalFunctions.php b/includes/GlobalFunctions.php index 38daab5c32..125b917caa 100644 --- a/includes/GlobalFunctions.php +++ b/includes/GlobalFunctions.php @@ -518,7 +518,7 @@ function wfExpandUrl( $url, $defaultProto = PROTO_CURRENT ) { } } - $defaultProtoWithoutSlashes = substr( $defaultProto, 0, -2 ); + $defaultProtoWithoutSlashes = $defaultProto !== null ? substr( $defaultProto, 0, -2 ) : ''; if ( substr( $url, 0, 2 ) == '//' ) { $url = $defaultProtoWithoutSlashes . $url; @@ -1816,10 +1816,11 @@ function mimeTypeMatch( $type, $avail ) { * * @param array $cprefs Client's acceptable type list * @param array $sprefs Server's offered types - * @return string + * @return string|null * * @todo FIXME: Doesn't handle params like 'text/plain; charset=UTF-8' * XXX: generalize to negotiate other stuff + * @todo The function appears unused. Is it worth to keep? */ function wfNegotiateType( $cprefs, $sprefs ) { $combine = []; @@ -2030,7 +2031,7 @@ function wfRecursiveRemoveDir( $dir ) { */ function wfPercent( $nr, $acc = 2, $round = true ) { $ret = sprintf( "%.${acc}f", $nr ); - return $round ? round( $ret, $acc ) . '%' : "$ret%"; + return $round ? round( (float)$ret, $acc ) . '%' : "$ret%"; } /** @@ -2793,7 +2794,7 @@ function wfMemoryLimit( $newLimit ) { function wfTransactionalTimeLimit() { global $wgTransactionalTimeLimit; - $timeLimit = ini_get( 'max_execution_time' ); + $timeLimit = (int)ini_get( 'max_execution_time' ); // Note that CLI scripts use 0 if ( $timeLimit > 0 && $wgTransactionalTimeLimit > $timeLimit ) { set_time_limit( $wgTransactionalTimeLimit ); diff --git a/includes/Linker.php b/includes/Linker.php index 1a5058d6f4..864019dcc7 100644 --- a/includes/Linker.php +++ b/includes/Linker.php @@ -21,7 +21,7 @@ */ use MediaWiki\Linker\LinkTarget; use MediaWiki\MediaWikiServices; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; /** * Some internal bits split of from Skin.php. These functions are used @@ -891,7 +891,7 @@ class Linker { * Make user link (or user contributions for unregistered users) * @param int $userId User id in database. * @param string $userName User name in database. - * @param string $altUserName Text to display instead of the user name (optional) + * @param string|false $altUserName Text to display instead of the user name (optional) * @return string HTML fragment * @since 1.16.3. $altUserName was added in 1.19. */ @@ -1912,7 +1912,7 @@ class Linker { * @since 1.16.3. $context added in 1.20. $editCount added in 1.21 * @param Revision $rev * @param IContextSource|null $context Context to use or null for the main context. - * @param int $editCount Number of edits that would be reverted + * @param int|false $editCount Number of edits that would be reverted * @return string HTML fragment */ public static function buildRollbackLink( $rev, IContextSource $context = null, diff --git a/includes/MergeHistory.php b/includes/MergeHistory.php index 4045a5436b..1a950c5f5e 100644 --- a/includes/MergeHistory.php +++ b/includes/MergeHistory.php @@ -273,6 +273,18 @@ class MergeHistory { return $status; } + // Update denormalized revactor_page too + $this->dbw->update( + 'revision_actor_temp', + [ 'revactor_page' => $this->dest->getArticleID() ], + [ + 'revactor_page' => $this->source->getArticleID(), + // Slightly hacky, but should work given the values assigned in this class + str_replace( 'rev_timestamp', 'revactor_timestamp', $this->timeWhere ) + ], + __METHOD__ + ); + // Make the source page a redirect if no revisions are left $haveRevisions = $this->dbw->lockForUpdate( 'revision', diff --git a/includes/MovePage.php b/includes/MovePage.php index 634e7affe2..59baae78e2 100644 --- a/includes/MovePage.php +++ b/includes/MovePage.php @@ -83,7 +83,7 @@ class MovePage { * @param ServiceOptions|null $options * @param ILoadBalancer|null $loadBalancer * @param NamespaceInfo|null $nsInfo - * @param WatchedItemStore|null $watchedItems + * @param WatchedItemStoreInterface|null $watchedItems * @param PermissionManager|null $permMgr */ public function __construct( diff --git a/includes/OutputPage.php b/includes/OutputPage.php index 7f005fb7cd..acf2d25532 100644 --- a/includes/OutputPage.php +++ b/includes/OutputPage.php @@ -50,7 +50,7 @@ class OutputPage extends ContextSource { /** @var array */ protected $mLinktags = []; - /** @var bool */ + /** @var string|bool */ protected $mCanonicalUrl = false; /** @@ -332,7 +332,7 @@ class OutputPage extends ContextSource { * a OutputPage tied to that context. * @param IContextSource $context */ - function __construct( IContextSource $context ) { + public function __construct( IContextSource $context ) { $this->setContext( $context ); } @@ -385,8 +385,8 @@ class OutputPage extends ContextSource { * @param string $name Name of the meta tag * @param string $val Value of the meta tag */ - function addMeta( $name, $val ) { - array_push( $this->mMetatags, [ $name, $val ] ); + public function addMeta( $name, $val ) { + $this->mMetatags[] = [ $name, $val ]; } /** @@ -406,8 +406,8 @@ class OutputPage extends ContextSource { * * @param array $linkarr Associative array of attributes. */ - function addLink( array $linkarr ) { - array_push( $this->mLinktags, $linkarr ); + public function addLink( array $linkarr ) { + $this->mLinktags[] = $linkarr; } /** @@ -425,7 +425,7 @@ class OutputPage extends ContextSource { * in preference to addLink(), to avoid duplicate link tags. * @param string $url */ - function setCanonicalUrl( $url ) { + public function setCanonicalUrl( $url ) { $this->mCanonicalUrl = $url; } @@ -447,7 +447,7 @@ class OutputPage extends ContextSource { * * @param string $script Raw HTML */ - function addScript( $script ) { + public function addScript( $script ) { $this->mScripts .= $script; } @@ -621,7 +621,7 @@ class OutputPage extends ContextSource { * * @return array */ - function getHeadItemsArray() { + public function getHeadItemsArray() { return $this->mHeadItems; } @@ -1598,6 +1598,7 @@ class OutputPage extends ContextSource { * @param ParserOptions|null $options Either the ParserOption to use or null to only get the * current ParserOption object. This parameter is deprecated since 1.31. * @return ParserOptions + * @suppress PhanUndeclaredProperty For isBogus */ public function parserOptions( $options = null ) { if ( $options !== null ) { @@ -1954,7 +1955,7 @@ class OutputPage extends ContextSource { * @param ParserOutput $parserOutput * @param array $poOptions Options to ParserOutput::getText() */ - function addParserOutput( ParserOutput $parserOutput, $poOptions = [] ) { + public function addParserOutput( ParserOutput $parserOutput, $poOptions = [] ) { $this->addParserOutputMetadata( $parserOutput ); $this->addParserOutputText( $parserOutput, $poOptions ); } @@ -2146,7 +2147,7 @@ class OutputPage extends ContextSource { } /** - * Get TTL in [$minTTL,$maxTTL] in pass it to lowerCdnMaxage() + * Get TTL in [$minTTL,$maxTTL] and pass it to lowerCdnMaxage() * * This sets and returns $minTTL if $mtime is false or null. Otherwise, * the TTL is higher the older the $mtime timestamp is. Essentially, the @@ -2162,10 +2163,10 @@ class OutputPage extends ContextSource { $maxTTL = $maxTTL ?: $this->getConfig()->get( 'CdnMaxAge' ); if ( $mtime === null || $mtime === false ) { - return $minTTL; // entity does not exist + return; // entity does not exist } - $age = MWTimestamp::time() - wfTimestamp( TS_UNIX, $mtime ); + $age = MWTimestamp::time() - (int)wfTimestamp( TS_UNIX, $mtime ); $adaptiveTTL = max( 0.9 * $age, $minTTL ); $adaptiveTTL = min( $adaptiveTTL, $maxTTL ); @@ -2188,7 +2189,7 @@ class OutputPage extends ContextSource { * * @return array */ - function getCacheVaryCookies() { + public function getCacheVaryCookies() { if ( self::$cacheVaryCookies === null ) { $config = $this->getConfig(); self::$cacheVaryCookies = array_values( array_unique( array_merge( @@ -2209,7 +2210,7 @@ class OutputPage extends ContextSource { * * @return bool */ - function haveCacheVaryCookies() { + public function haveCacheVaryCookies() { $request = $this->getRequest(); foreach ( $this->getCacheVaryCookies() as $cookieName ) { if ( $request->getCookie( $cookieName, '', '' ) !== '' ) { @@ -2269,7 +2270,7 @@ class OutputPage extends ContextSource { /** * Return a Link: header. Based on the values of $mLinkHeader. * - * @return string + * @return string|false */ public function getLinkHeader() { if ( !$this->mLinkHeader ) { @@ -2601,7 +2602,7 @@ class OutputPage extends ContextSource { * and optionally an custom HTML title (content of the "" tag). * * @param string|Message $pageTitle Will be passed directly to setPageTitle() - * @param string|Message $htmlTitle Will be passed directly to setHTMLTitle(); + * @param string|Message|false $htmlTitle Will be passed directly to setHTMLTitle(); * optional, if not passed the "<title>" attribute will be * based on $pageTitle */ @@ -2822,7 +2823,7 @@ class OutputPage extends ContextSource { /** * Add a "return to" link pointing to a specified title * - * @param Title $title Title to link + * @param LinkTarget $title Title to link * @param array $query Query string parameters * @param string|null $text Text of the link (input is not escaped) * @param array $options Options array to pass to Linker @@ -3282,7 +3283,7 @@ class OutputPage extends ContextSource { $vars['wgUserId'] = $user->getId(); $vars['wgUserEditCount'] = $user->getEditCount(); $userReg = $user->getRegistration(); - $vars['wgUserRegistration'] = $userReg ? wfTimestamp( TS_UNIX, $userReg ) * 1000 : null; + $vars['wgUserRegistration'] = $userReg ? (int)wfTimestamp( TS_UNIX, $userReg ) * 1000 : null; // Get the revision ID of the oldest new message on the user's talk // page. This can be used for constructing new message alerts on // the client side. diff --git a/includes/PHPVersionCheck.php b/includes/PHPVersionCheck.php index bf138c4b1e..8d642e1785 100644 --- a/includes/PHPVersionCheck.php +++ b/includes/PHPVersionCheck.php @@ -77,8 +77,8 @@ class PHPVersionCheck { /** * Return the version of the installed PHP implementation. * - * @param string $impl By default, the function returns the info of the currently installed PHP - * implementation. Using this parameter the caller can decide, what version info will be + * @param string|false $impl By default, the function returns the info of the currently installed + * PHP implementation. Using this parameter the caller can decide, what version info will be * returned. Valid values: HHVM, PHP * @return array An array of information about the PHP implementation, containing: * - 'version': The version of the PHP implementation (specific to the implementation, not @@ -108,8 +108,8 @@ class PHPVersionCheck { 'implementation' => 'PHP', 'version' => PHP_VERSION, 'vendor' => 'the PHP Group', - 'upstreamSupported' => '5.6.0', - 'minSupported' => '7.0.13', + 'upstreamSupported' => '7.1.0', + 'minSupported' => '7.2.0', 'upgradeURL' => 'https://www.php.net/downloads.php', ); } @@ -258,7 +258,7 @@ HTML; <head> <meta charset="UTF-8" /> <title>MediaWiki {$this->mwVersion} - - The MediaWiki logo + The MediaWiki logo

MediaWiki {$this->mwVersion} internal error

-
+

{$shortHtml}

diff --git a/includes/Permissions/PermissionManager.php b/includes/Permissions/PermissionManager.php index 0a8e515a32..ef6b8ac5a9 100644 --- a/includes/Permissions/PermissionManager.php +++ b/includes/Permissions/PermissionManager.php @@ -97,7 +97,7 @@ class PermissionManager { */ private $temporaryUserRights = []; - /** @var string[] Cached rights for isEveryoneAllowed */ + /** @var bool[] Cached rights for isEveryoneAllowed, [ right => allowed ] */ private $cachedRights = []; /** diff --git a/includes/ProtectionForm.php b/includes/ProtectionForm.php index 8b5d9956ab..3e639b92a2 100644 --- a/includes/ProtectionForm.php +++ b/includes/ProtectionForm.php @@ -58,6 +58,18 @@ class ProtectionForm { /** @var array Map of action to the expiry time of the existing protection */ protected $mExistingExpiry = []; + /** @var Article */ + protected $mArticle; + + /** @var Title */ + protected $mTitle; + + /** @var bool */ + protected $disabled; + + /** @var array */ + protected $disabledAttrib; + /** @var IContextSource */ private $mContext; @@ -78,7 +90,7 @@ class ProtectionForm { if ( wfReadOnly() ) { $this->mPermErrors[] = [ 'readonlytext', wfReadOnlyReason() ]; } - $this->disabled = $this->mPermErrors != []; + $this->disabled = $this->mPermErrors !== []; $this->disabledAttrib = $this->disabled ? [ 'disabled' => 'disabled' ] : []; @@ -321,7 +333,9 @@ class ProtectionForm { ); if ( !$status->isOK() ) { - $this->show( $out->parseInlineAsInterface( $status->getWikiText() ) ); + $this->show( $out->parseInlineAsInterface( + $status->getWikiText( false, false, $this->mContext->getLanguage() ) + ) ); return false; } diff --git a/includes/Rest/BasicAccess/MWBasicAuthorizer.php b/includes/Rest/BasicAccess/MWBasicAuthorizer.php index 43014f1379..92529b3679 100644 --- a/includes/Rest/BasicAccess/MWBasicAuthorizer.php +++ b/includes/Rest/BasicAccess/MWBasicAuthorizer.php @@ -2,24 +2,24 @@ namespace MediaWiki\Rest\BasicAccess; -use User; use MediaWiki\Permissions\PermissionManager; use MediaWiki\Rest\Handler; use MediaWiki\Rest\RequestInterface; +use MediaWiki\User\UserIdentity; /** - * A factory for MWBasicRequestAuthorizer which passes through a User object + * A factory for MWBasicRequestAuthorizer which passes through a UserIdentity. * * @internal */ class MWBasicAuthorizer extends BasicAuthorizerBase { - /** @var User */ + /** @var UserIdentity */ private $user; /** @var PermissionManager */ private $permissionManager; - public function __construct( User $user, PermissionManager $permissionManager ) { + public function __construct( UserIdentity $user, PermissionManager $permissionManager ) { $this->user = $user; $this->permissionManager = $permissionManager; } diff --git a/includes/Rest/BasicAccess/MWBasicRequestAuthorizer.php b/includes/Rest/BasicAccess/MWBasicRequestAuthorizer.php index 8c459c63f4..671488aaf2 100644 --- a/includes/Rest/BasicAccess/MWBasicRequestAuthorizer.php +++ b/includes/Rest/BasicAccess/MWBasicRequestAuthorizer.php @@ -2,7 +2,7 @@ namespace MediaWiki\Rest\BasicAccess; -use User; +use MediaWiki\User\UserIdentity; use MediaWiki\Permissions\PermissionManager; use MediaWiki\Rest\Handler; use MediaWiki\Rest\RequestInterface; @@ -13,14 +13,14 @@ use MediaWiki\Rest\RequestInterface; * @internal */ class MWBasicRequestAuthorizer extends BasicRequestAuthorizer { - /** @var User */ + /** @var UserIdentity */ private $user; /** @var PermissionManager */ private $permissionManager; public function __construct( RequestInterface $request, Handler $handler, - User $user, PermissionManager $permissionManager + UserIdentity $user, PermissionManager $permissionManager ) { parent::__construct( $request, $handler ); $this->user = $user; diff --git a/includes/Rest/EntryPoint.php b/includes/Rest/EntryPoint.php index ee3441e595..070451d9ce 100644 --- a/includes/Rest/EntryPoint.php +++ b/includes/Rest/EntryPoint.php @@ -10,6 +10,7 @@ use MediaWiki\Rest\Validator\Validator; use RequestContext; use Title; use WebResponse; +use Wikimedia\Message\ITextFormatter; class EntryPoint { /** @var RequestInterface */ @@ -49,12 +50,18 @@ class EntryPoint { 'cookiePrefix' => $conf->get( 'CookiePrefix' ) ] ); + $responseFactory = new ResponseFactory( self::getTextFormatters( $services ) ); + // @phan-suppress-next-line PhanAccessMethodInternal $authorizer = new MWBasicAuthorizer( $context->getUser(), $services->getPermissionManager() ); // @phan-suppress-next-line PhanAccessMethodInternal - $restValidator = new Validator( $objectFactory, $request, RequestContext::getMain()->getUser() ); + $restValidator = new Validator( $objectFactory, + $services->getPermissionManager(), + $request, + RequestContext::getMain()->getUser() + ); global $IP; $router = new Router( @@ -62,7 +69,7 @@ class EntryPoint { ExtensionRegistry::getInstance()->getAttribute( 'RestRoutes' ), $conf->get( 'RestPath' ), $services->getLocalServerObjectCache(), - new ResponseFactory, + $responseFactory, $authorizer, $objectFactory, $restValidator @@ -76,6 +83,25 @@ class EntryPoint { $entryPoint->execute(); } + /** + * Get a TextFormatter array from MediaWikiServices + * + * @param MediaWikiServices $services + * @return ITextFormatter[] + */ + public static function getTextFormatters( MediaWikiServices $services ) { + $langs = array_unique( [ + $services->getMainConfig()->get( 'ContLang' )->getCode(), + 'en' + ] ); + $textFormatters = []; + $factory = $services->getMessageFormatterFactory(); + foreach ( $langs as $lang ) { + $textFormatters[] = $factory->getTextFormatter( $lang ); + } + return $textFormatters; + } + public function __construct( RequestContext $context, RequestInterface $request, WebResponse $webResponse, Router $router ) { diff --git a/includes/Rest/LocalizedHttpException.php b/includes/Rest/LocalizedHttpException.php index 10d3a4034a..184fe164b7 100644 --- a/includes/Rest/LocalizedHttpException.php +++ b/includes/Rest/LocalizedHttpException.php @@ -5,7 +5,14 @@ namespace MediaWiki\Rest; use Wikimedia\Message\MessageValue; class LocalizedHttpException extends HttpException { - public function __construct( MessageValue $message, $code = 500 ) { - parent::__construct( 'Localized exception with key ' . $message->getKey(), $code ); + private $messageValue; + + public function __construct( MessageValue $messageValue, $code = 500 ) { + parent::__construct( 'Localized exception with key ' . $messageValue->getKey(), $code ); + $this->messageValue = $messageValue; + } + + public function getMessageValue() { + return $this->messageValue; } } diff --git a/includes/Rest/ResponseFactory.php b/includes/Rest/ResponseFactory.php index 5e5a19852d..fd0f3c7975 100644 --- a/includes/Rest/ResponseFactory.php +++ b/includes/Rest/ResponseFactory.php @@ -5,19 +5,31 @@ namespace MediaWiki\Rest; use Exception; use HttpStatus; use InvalidArgumentException; +use LanguageCode; use MWExceptionHandler; use stdClass; use Throwable; +use Wikimedia\Message\ITextFormatter; +use Wikimedia\Message\MessageValue; /** * Generates standardized response objects. */ class ResponseFactory { - const CT_PLAIN = 'text/plain; charset=utf-8'; const CT_HTML = 'text/html; charset=utf-8'; const CT_JSON = 'application/json'; + /** @var ITextFormatter[] */ + private $textFormatters; + + /** + * @param ITextFormatter[] $textFormatters + */ + public function __construct( $textFormatters ) { + $this->textFormatters = $textFormatters; + } + /** * Encode a stdClass object or array to a JSON string * @@ -167,13 +179,23 @@ class ResponseFactory { return $response; } + /** + * Create an HTTP 4xx or 5xx response with error message localisation + */ + public function createLocalizedHttpError( $errorCode, MessageValue $messageValue ) { + return $this->createHttpError( $errorCode, $this->formatMessage( $messageValue ) ); + } + /** * Turn an exception into a JSON error response. * @param Exception|Throwable $exception * @return Response */ public function createFromException( $exception ) { - if ( $exception instanceof HttpException ) { + if ( $exception instanceof LocalizedHttpException ) { + $response = $this->createLocalizedHttpError( $exception->getCode(), + $exception->getMessageValue() ); + } elseif ( $exception instanceof HttpException ) { // FIXME can HttpException represent 2xx or 3xx responses? $response = $this->createHttpError( $exception->getCode(), @@ -240,4 +262,18 @@ class ResponseFactory { return "Redirect$url"; } + public function formatMessage( MessageValue $messageValue ) { + if ( !$this->textFormatters ) { + // For unit tests + return []; + } + $translations = []; + foreach ( $this->textFormatters as $formatter ) { + $lang = LanguageCode::bcp47( $formatter->getLangCode() ); + $messageText = $formatter->format( $messageValue ); + $translations[$lang] = $messageText; + } + return [ 'messageTranslations' => $translations ]; + } + } diff --git a/includes/Rest/Router.php b/includes/Rest/Router.php index a520130d06..6821d89c27 100644 --- a/includes/Rest/Router.php +++ b/includes/Rest/Router.php @@ -4,6 +4,7 @@ namespace MediaWiki\Rest; use AppendIterator; use BagOStuff; +use Wikimedia\Message\MessageValue; use MediaWiki\Rest\BasicAccess\BasicAuthorizerInterface; use MediaWiki\Rest\PathTemplateMatcher\PathMatcher; use MediaWiki\Rest\Validator\Validator; @@ -226,18 +227,28 @@ class Router { $path = $request->getUri()->getPath(); $relPath = $this->getRelativePath( $path ); if ( $relPath === false ) { - return $this->responseFactory->createHttpError( 404 ); + return $this->responseFactory->createLocalizedHttpError( 404, + ( new MessageValue( 'rest-prefix-mismatch' ) ) + ->plaintextParams( $path, $this->rootPath ) + ); } + $requestMethod = $request->getMethod(); $matchers = $this->getMatchers(); - $matcher = $matchers[$request->getMethod()] ?? null; + $matcher = $matchers[$requestMethod] ?? null; $match = $matcher ? $matcher->match( $relPath ) : null; + // For a HEAD request, execute the GET handler instead if one exists. + // The webserver will discard the body. + if ( !$match && $requestMethod === 'HEAD' && isset( $matchers['GET'] ) ) { + $match = $matchers['GET']->match( $relPath ); + } + if ( !$match ) { // Check for 405 wrong method $allowed = []; foreach ( $matchers as $allowedMethod => $allowedMatcher ) { - if ( $allowedMethod === $request->getMethod() ) { + if ( $allowedMethod === $requestMethod ) { continue; } if ( $allowedMatcher->match( $relPath ) ) { @@ -245,12 +256,20 @@ class Router { } } if ( $allowed ) { - $response = $this->responseFactory->createHttpError( 405 ); + $response = $this->responseFactory->createLocalizedHttpError( 405, + ( new MessageValue( 'rest-wrong-method' ) ) + ->textParams( $requestMethod ) + ->commaListParams( $allowed ) + ->numParams( count( $allowed ) ) + ); $response->setHeader( 'Allow', $allowed ); return $response; } else { // Did not match with any other method, must be 404 - return $this->responseFactory->createHttpError( 404 ); + return $this->responseFactory->createLocalizedHttpError( 404, + ( new MessageValue( 'rest-no-match' ) ) + ->plaintextParams( $relPath ) + ); } } @@ -272,6 +291,7 @@ class Router { /** * Execute a fully-constructed handler + * * @param Handler $handler * @return ResponseInterface */ diff --git a/includes/Rest/Validator/ParamValidatorCallbacks.php b/includes/Rest/Validator/ParamValidatorCallbacks.php index 6c54a504d7..93de9112c0 100644 --- a/includes/Rest/Validator/ParamValidatorCallbacks.php +++ b/includes/Rest/Validator/ParamValidatorCallbacks.php @@ -3,21 +3,30 @@ namespace MediaWiki\Rest\Validator; use InvalidArgumentException; +use MediaWiki\Permissions\PermissionManager; use MediaWiki\Rest\RequestInterface; +use MediaWiki\User\UserIdentity; use Psr\Http\Message\UploadedFileInterface; -use User; use Wikimedia\ParamValidator\Callbacks; use Wikimedia\ParamValidator\ValidationException; class ParamValidatorCallbacks implements Callbacks { + /** @var PermissionManager */ + private $permissionManager; + /** @var RequestInterface */ private $request; - /** @var User */ + /** @var UserIdentity */ private $user; - public function __construct( RequestInterface $request, User $user ) { + public function __construct( + PermissionManager $permissionManager, + RequestInterface $request, + UserIdentity $user + ) { + $this->permissionManager = $permissionManager; $this->request = $request; $this->user = $user; } @@ -76,7 +85,7 @@ class ParamValidatorCallbacks implements Callbacks { } public function useHighLimits( array $options ) { - return $this->user->isAllowed( 'apihighlimits' ); + return $this->permissionManager->userHasRight( $this->user, 'apihighlimits' ); } } diff --git a/includes/Rest/Validator/Validator.php b/includes/Rest/Validator/Validator.php index cee1cdb359..be8d7a4e66 100644 --- a/includes/Rest/Validator/Validator.php +++ b/includes/Rest/Validator/Validator.php @@ -2,10 +2,11 @@ namespace MediaWiki\Rest\Validator; +use MediaWiki\Permissions\PermissionManager; use MediaWiki\Rest\Handler; use MediaWiki\Rest\HttpException; use MediaWiki\Rest\RequestInterface; -use User; +use MediaWiki\User\UserIdentity; use Wikimedia\ObjectFactory; use Wikimedia\ParamValidator\ParamValidator; use Wikimedia\ParamValidator\TypeDef\BooleanDef; @@ -62,16 +63,20 @@ class Validator { private $paramValidator; /** - * @internal * @param ObjectFactory $objectFactory + * @param PermissionManager $permissionManager * @param RequestInterface $request - * @param User $user + * @param UserIdentity $user + * @internal */ public function __construct( - ObjectFactory $objectFactory, RequestInterface $request, User $user + ObjectFactory $objectFactory, + PermissionManager $permissionManager, + RequestInterface $request, + UserIdentity $user ) { $this->paramValidator = new ParamValidator( - new ParamValidatorCallbacks( $request, $user ), + new ParamValidatorCallbacks( $permissionManager, $request, $user ), $objectFactory, [ 'typeDefs' => self::$typeDefs, diff --git a/includes/Revision/RevisionRecord.php b/includes/Revision/RevisionRecord.php index ff9ac579e8..cf353718f8 100644 --- a/includes/Revision/RevisionRecord.php +++ b/includes/Revision/RevisionRecord.php @@ -59,7 +59,7 @@ abstract class RevisionRecord { const FOR_THIS_USER = 2; const RAW = 3; - /** @var string Wiki ID; false means the current wiki */ + /** @var string|false Wiki ID; false means the current wiki */ protected $mWiki = false; /** @var int|null */ protected $mId; @@ -531,8 +531,6 @@ abstract class RevisionRecord { $text = $title->getPrefixedText(); wfDebug( "Checking for $permissionlist on $text due to $field match on $bitfield\n" ); - $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); - foreach ( $permissions as $perm ) { if ( $permissionManager->userCan( $perm, $user, $title ) ) { return true; diff --git a/includes/Revision/RevisionStore.php b/includes/Revision/RevisionStore.php index 735a2124d4..3ecef76fa0 100644 --- a/includes/Revision/RevisionStore.php +++ b/includes/Revision/RevisionStore.php @@ -1623,10 +1623,18 @@ class RevisionStore * @param object[]|IResultWrapper $slotRows * @param int $queryFlags * @param Title $title + * @param array|null $slotContents a map from blobAddress to slot + * content blob or Content object. * * @return SlotRecord[] */ - private function constructSlotRecords( $revId, $slotRows, $queryFlags, Title $title ) { + private function constructSlotRecords( + $revId, + $slotRows, + $queryFlags, + Title $title, + $slotContents = null + ) { $slots = []; foreach ( $slotRows as $row ) { @@ -1651,8 +1659,15 @@ class RevisionStore = $this->emulateContentId( intval( $row->rev_text_id ) ); } - $contentCallback = function ( SlotRecord $slot ) use ( $queryFlags ) { - return $this->loadSlotContent( $slot, null, null, null, $queryFlags ); + $contentCallback = function ( SlotRecord $slot ) use ( $slotContents, $queryFlags ) { + $blob = null; + if ( isset( $slotContents[$slot->getAddress()] ) ) { + $blob = $slotContents[$slot->getAddress()]; + if ( $blob instanceof Content ) { + return $blob; + } + } + return $this->loadSlotContent( $slot, $blob, null, null, $queryFlags ); }; $slots[$row->role_name] = new SlotRecord( $row, $contentCallback ); @@ -1804,8 +1819,10 @@ class RevisionStore /** * @param object $row A database row generated from a query based on getQueryInfo() - * @param null|object[] $slotRows Database rows generated from a query based on - * getSlotsQueryInfo with the 'content' flag set. + * @param null|object[]|RevisionSlots $slots + * - Database rows generated from a query based on getSlotsQueryInfo + * with the 'content' flag set. Or + * - RevisionSlots instance * @param int $queryFlags * @param Title|null $title * @param bool $fromCache if true, the returned RevisionRecord will ensure that no stale @@ -1816,11 +1833,10 @@ class RevisionStore * @see RevisionFactory::newRevisionFromRow * * MCR migration note: this replaces Revision::newFromRow - * */ public function newRevisionFromRowAndSlots( $row, - $slotRows, + $slots, $queryFlags = 0, Title $title = null, $fromCache = false @@ -1857,7 +1873,9 @@ class RevisionStore // Legacy because $row may have come from self::selectFields() $comment = $this->commentStore->getCommentLegacy( $db, 'rev_comment', $row, true ); - $slots = $this->newRevisionSlots( $row->rev_id, $row, $slotRows, $queryFlags, $title ); + if ( !( $slots instanceof RevisionSlots ) ) { + $slots = $this->newRevisionSlots( $row->rev_id, $row, $slots, $queryFlags, $title ); + } // If this is a cached row, instantiate a cache-aware revision class to avoid stale data. if ( $fromCache ) { @@ -1887,7 +1905,7 @@ class RevisionStore * loaded immediately. Supports falsy or truthy value as well * as an explicit list of slot role names. * 'content'- whether the actual content of the slots should be - * preloaded. TODO: no supported yet. + * preloaded. * @param int $queryFlags * @param Title|null $title * @return StatusValue a status with a RevisionRecord[] of successfully fetched revisions @@ -1957,24 +1975,40 @@ class RevisionStore }, $options['slots'] ); } - // TODO: Support optional fetching of the content - $queryInfo = self::getSlotsQueryInfo( [ 'content' ] ); + // We need to set the `content` flag because newRevisionFromRowAndSlots requires content + // metadata to be loaded. + $slotQueryInfo = self::getSlotsQueryInfo( [ 'content' ] ); $db = $this->getDBConnectionRefForQueryFlags( $queryFlags ); $slotRows = $db->select( - $queryInfo['tables'], - $queryInfo['fields'], + $slotQueryInfo['tables'], + $slotQueryInfo['fields'], $slotQueryConds, __METHOD__, [], - $queryInfo['joins'] + $slotQueryInfo['joins'] ); $slotRowsByRevId = []; foreach ( $slotRows as $slotRow ) { $slotRowsByRevId[$slotRow->slot_revision_id][] = $slotRow; } + + $slotContents = null; + if ( $options['content'] ?? false ) { + $blobAddresses = []; + foreach ( $slotRows as $slotRow ) { + $blobAddresses[] = $slotRow->content_address; + } + $slotContentFetchStatus = $this->blobStore + ->getBlobBatch( $blobAddresses, $queryFlags ); + foreach ( $slotContentFetchStatus->getErrors() as $error ) { + $result->warning( $error['message'], ...$error['params'] ); + } + $slotContents = $slotContentFetchStatus->getValue(); + } + $result->setResult( true, array_map( function ( $row ) use - ( $slotRowsByRevId, $queryFlags, $titlesByPageId, $result ) { + ( $slotRowsByRevId, $queryFlags, $titlesByPageId, $slotContents, $result ) { if ( !isset( $slotRowsByRevId[$row->rev_id] ) ) { $result->warning( 'internalerror', @@ -1985,7 +2019,15 @@ class RevisionStore try { return $this->newRevisionFromRowAndSlots( $row, - $slotRowsByRevId[$row->rev_id], + new RevisionSlots( + $this->constructSlotRecords( + $row->rev_id, + $slotRowsByRevId[$row->rev_id], + $queryFlags, + $titlesByPageId[$row->rev_page], + $slotContents + ) + ), $queryFlags, $titlesByPageId[$row->rev_page] ); diff --git a/includes/Revision/RevisionStoreFactory.php b/includes/Revision/RevisionStoreFactory.php index acecee1294..1de4d7fdd0 100644 --- a/includes/Revision/RevisionStoreFactory.php +++ b/includes/Revision/RevisionStoreFactory.php @@ -27,7 +27,7 @@ namespace MediaWiki\Revision; use ActorMigration; use CommentStore; -use MediaWiki\Logger\Spi as LoggerSpi; +use Psr\Log\LoggerInterface; use MediaWiki\Storage\BlobStoreFactory; use MediaWiki\Storage\NameTableStoreFactory; use WANObjectCache; @@ -54,8 +54,8 @@ class RevisionStoreFactory { private $dbLoadBalancerFactory; /** @var WANObjectCache */ private $cache; - /** @var LoggerSpi */ - private $loggerProvider; + /** @var LoggerInterface */ + private $logger; /** @var CommentStore */ private $commentStore; @@ -84,7 +84,7 @@ class RevisionStoreFactory { * @param CommentStore $commentStore * @param ActorMigration $actorMigration * @param int $migrationStage - * @param LoggerSpi $loggerProvider + * @param LoggerInterface $logger * @param bool $contentHandlerUseDB see {@link $wgContentHandlerUseDB}. Must be the same * for all wikis in the cluster. Will go away after MCR migration. */ @@ -97,7 +97,7 @@ class RevisionStoreFactory { CommentStore $commentStore, ActorMigration $actorMigration, $migrationStage, - LoggerSpi $loggerProvider, + LoggerInterface $logger, $contentHandlerUseDB ) { Assert::parameterType( 'integer', $migrationStage, '$migrationStage' ); @@ -109,7 +109,7 @@ class RevisionStoreFactory { $this->commentStore = $commentStore; $this->actorMigration = $actorMigration; $this->mcrMigrationStage = $migrationStage; - $this->loggerProvider = $loggerProvider; + $this->logger = $logger; $this->contentHandlerUseDB = $contentHandlerUseDB; } @@ -118,7 +118,7 @@ class RevisionStoreFactory { * * @param bool|string $dbDomain DB domain of the relevant wiki or false for the current one * - * @return RevisionStore for the given wikiId with all necessary services and a logger + * @return RevisionStore for the given wikiId with all necessary services */ public function getRevisionStore( $dbDomain = false ) { Assert::parameterType( 'string|boolean', $dbDomain, '$dbDomain' ); @@ -137,7 +137,7 @@ class RevisionStoreFactory { $dbDomain ); - $store->setLogger( $this->loggerProvider->getLogger( 'RevisionStore' ) ); + $store->setLogger( $this->logger ); $store->setContentHandlerUseDB( $this->contentHandlerUseDB ); return $store; diff --git a/includes/Revision/RevisionStoreRecord.php b/includes/Revision/RevisionStoreRecord.php index 469e494a3d..dabf62bb0b 100644 --- a/includes/Revision/RevisionStoreRecord.php +++ b/includes/Revision/RevisionStoreRecord.php @@ -151,7 +151,7 @@ class RevisionStoreRecord extends RevisionRecord { /** * @throws RevisionAccessException if the size was unknown and could not be calculated. - * @return string The nominal revision size, never null. May be computed on the fly. + * @return int The nominal revision size, never null. May be computed on the fly. */ public function getSize() { // If length is null, calculate and remember it (potentially SLOW!). diff --git a/includes/Revision/SlotRoleHandler.php b/includes/Revision/SlotRoleHandler.php index 85b4c5ab34..7c2623bebd 100644 --- a/includes/Revision/SlotRoleHandler.php +++ b/includes/Revision/SlotRoleHandler.php @@ -150,7 +150,7 @@ class SlotRoleHandler { * * The default implementation always returns false. * - * @return string + * @return bool */ public function supportsArticleCount() { return false; diff --git a/includes/ServiceWiring.php b/includes/ServiceWiring.php index 0b0aaf54c8..ab51eabd47 100644 --- a/includes/ServiceWiring.php +++ b/includes/ServiceWiring.php @@ -27,6 +27,13 @@ * For every service that MediaWiki core requires, an instantiator must be defined in * this file. * + * Note that, ideally, all information used to instantiate service objects should come + * from configuration. Information derived from the current request is acceptable, but + * only where there is no feasible alternative. It is preferred that such information + * (like the client IP, the acting user's identity, requested title, etc) be passed to + * the service object's methods as parameters. This makes the flow of information more + * obvious, and makes it easier to understand the behavior of services. + * * @note As of version 1.27, MediaWiki is only beginning to use dependency injection. * The services defined here do not yet fully represent all services used by core, * much of the code still relies on global state for this accessing services. @@ -107,14 +114,12 @@ return [ }, 'BlockManager' => function ( MediaWikiServices $services ) : BlockManager { - $context = RequestContext::getMain(); return new BlockManager( new ServiceOptions( BlockManager::$constructorOptions, $services->getMainConfig() ), - $context->getUser(), - $context->getRequest(), - $services->getPermissionManager() + $services->getPermissionManager(), + LoggerFactory::getInstance( 'BlockManager' ) ); }, @@ -269,6 +274,8 @@ return [ if ( defined( 'MW_NO_SESSION' ) ) { return $services->getLinkRendererFactory()->create(); } else { + // Normally information from the current request would not be passed in here; + // this is an exception. (See also the class documentation.) return $services->getLinkRendererFactory()->createForUser( RequestContext::getMain()->getUser() ); @@ -545,7 +552,8 @@ return [ $services->getContentLanguage(), AuthManager::singleton(), $services->getLinkRendererFactory()->create(), - $services->getNamespaceInfo() + $services->getNamespaceInfo(), + $services->getPermissionManager() ); $factory->setLogger( LoggerFactory::getInstance( 'preferences' ) ); @@ -634,7 +642,7 @@ return [ $services->getCommentStore(), $services->getActorMigration(), $config->get( 'MultiContentRevisionSchemaMigrationStage' ), - LoggerFactory::getProvider(), + LoggerFactory::getInstance( 'RevisionStore' ), $config->get( 'ContentHandlerUseDB' ) ); @@ -785,7 +793,8 @@ return [ $services->getDBLoadBalancer(), $services->getCommentStore(), $services->getActorMigration(), - $services->getWatchedItemStore() + $services->getWatchedItemStore(), + $services->getPermissionManager() ); }, diff --git a/includes/Setup.php b/includes/Setup.php index 518531aacf..d450bdd33c 100644 --- a/includes/Setup.php +++ b/includes/Setup.php @@ -440,6 +440,13 @@ if ( $wgEnableEmail ) { $wgUsersNotifiedOnAllChanges = []; } +// $wgSysopEmailBans deprecated in 1.34 +if ( isset( $wgSysopEmailBans ) && $wgSysopEmailBans === false ) { + foreach ( $wgGroupPermissions as $group => $_ ) { + unset( $wgGroupPermissions[$group]['blockemail'] ); + } +} + if ( $wgMetaNamespace === false ) { $wgMetaNamespace = str_replace( ' ', '_', $wgSitename ); } @@ -721,7 +728,7 @@ if ( is_null( $wgLocaltimezone ) ) { date_default_timezone_set( $wgLocaltimezone ); if ( is_null( $wgLocalTZoffset ) ) { - $wgLocalTZoffset = date( 'Z' ) / 60; + $wgLocalTZoffset = (int)date( 'Z' ) / 60; } // The part after the System| is ignored, but rest of MW fills it // out as the local offset. diff --git a/includes/Status.php b/includes/Status.php index 76b905eca4..932fd2a650 100644 --- a/includes/Status.php +++ b/includes/Status.php @@ -115,6 +115,7 @@ class Status extends StatusValue { * ] * * @return Status[] + * @suppress PhanUndeclaredProperty Status vs StatusValue */ public function splitByErrorType() { list( $errorsOnlyStatus, $warningsOnlyStatus ) = parent::splitByErrorType(); diff --git a/includes/Storage/DerivedPageDataUpdater.php b/includes/Storage/DerivedPageDataUpdater.php index 4903cf0095..b2c003ab4c 100644 --- a/includes/Storage/DerivedPageDataUpdater.php +++ b/includes/Storage/DerivedPageDataUpdater.php @@ -1531,7 +1531,9 @@ class DerivedPageDataUpdater implements IDBAccessObject, LoggerAwareInterface { if ( $this->options['changed'] && $title->getNamespace() == NS_USER_TALK && $shortTitle != $legacyUser->getTitleKey() - && !( $this->revision->isMinor() && $legacyUser->isAllowed( 'nominornewtalk' ) ) + && !( $this->revision->isMinor() && MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $legacyUser, 'nominornewtalk' ) ) ) { $recipient = User::newFromName( $shortTitle, false ); if ( !$recipient ) { diff --git a/includes/Storage/PageEditStash.php b/includes/Storage/PageEditStash.php index a0ef07d651..826d52675b 100644 --- a/includes/Storage/PageEditStash.php +++ b/includes/Storage/PageEditStash.php @@ -231,7 +231,7 @@ class PageEditStash { return false; } - $age = time() - wfTimestamp( TS_UNIX, $editInfo->output->getCacheTime() ); + $age = time() - (int)wfTimestamp( TS_UNIX, $editInfo->output->getCacheTime() ); $context['age'] = $age; $isCacheUsable = true; @@ -450,7 +450,7 @@ class PageEditStash { ) { // If an item is renewed, mind the cache TTL determined by config and parser functions. // Put an upper limit on the TTL for sanity to avoid extreme template/file staleness. - $age = time() - wfTimestamp( TS_UNIX, $parserOutput->getCacheTime() ); + $age = time() - (int)wfTimestamp( TS_UNIX, $parserOutput->getCacheTime() ); $ttl = min( $parserOutput->getCacheExpiry() - $age, self::MAX_CACHE_TTL ); // Avoid extremely stale user signature timestamps (T84843) if ( $parserOutput->getFlag( 'user-signature' ) ) { diff --git a/includes/Storage/SqlBlobStore.php b/includes/Storage/SqlBlobStore.php index 8c011dffa7..bcbc9e8a8f 100644 --- a/includes/Storage/SqlBlobStore.php +++ b/includes/Storage/SqlBlobStore.php @@ -103,10 +103,10 @@ class SqlBlobStore implements IDBAccessObject, BlobStore { * @param ExternalStoreAccess $extStoreAccess Access layer for external storage * @param WANObjectCache $cache A cache manager for caching blobs. This can be the local * wiki's default instance even if $dbDomain refers to a different wiki, since - * makeGlobalKey() is used to constructed a key that allows cached blobs from the - * same database to be re-used between wikis. For example, enwiki and frwiki will - * use the same cache keys for blobs from the wikidatawiki database, regardless of - * the cache's default key space. + * makeGlobalKey() is used to construct a key that allows cached blobs from the + * same database to be re-used between wikis. For example, wiki A and wiki B will + * use the same cache keys for blobs fetched from wiki C, regardless of the + * wiki-specific default key space. * @param bool|string $dbDomain The ID of the target wiki database. Use false for the local wiki. */ public function __construct( @@ -449,16 +449,15 @@ class SqlBlobStore implements IDBAccessObject, BlobStore { * Get a cache key for a given Blob address. * * The cache key is constructed in a way that allows cached blobs from the same database - * to be re-used between wikis. For example, enwiki and frwiki will use the same cache keys - * for blobs from the wikidatawiki database. + * to be re-used between wikis. For example, wiki A and wiki B will use the same cache keys + * for blobs fetched from wiki C. * * @param string $blobAddress * @return string */ private function getCacheKey( $blobAddress ) { return $this->cache->makeGlobalKey( - 'BlobStore', - 'address', + 'SqlBlobStore-blob', $this->dbLoadBalancer->resolveDomainID( $this->dbDomain ), $blobAddress ); diff --git a/includes/StreamFile.php b/includes/StreamFile.php index 2ad42e5616..c9b2c33b9a 100644 --- a/includes/StreamFile.php +++ b/includes/StreamFile.php @@ -25,8 +25,10 @@ */ class StreamFile { // Do not send any HTTP headers unless requested by caller (e.g. body only) + /** @deprecated since 1.34 */ const STREAM_HEADLESS = HTTPFileStreamer::STREAM_HEADLESS; // Do not try to tear down any PHP output buffers + /** @deprecated since 1.34 */ const STREAM_ALLOW_OB = HTTPFileStreamer::STREAM_ALLOW_OB; /** @@ -66,8 +68,10 @@ class StreamFile { * @param string $fname Full name and path of the file to stream * @param int $flags Bitfield of STREAM_* constants * @since 1.24 + * @deprecated since 1.34, use HTTPFileStreamer::send404Message() instead */ public static function send404Message( $fname, $flags = 0 ) { + wfDeprecated( __METHOD__, '1.34' ); HTTPFileStreamer::send404Message( $fname, $flags ); } @@ -78,8 +82,10 @@ class StreamFile { * @param int $size File size * @return array|string Returns error string on failure (start, end, length) * @since 1.24 + * @deprecated since 1.34, use HTTPFileStreamer::parseRange() instead */ public static function parseRange( $range, $size ) { + wfDeprecated( __METHOD__, '1.34' ); return HTTPFileStreamer::parseRange( $range, $size ); } @@ -105,7 +111,6 @@ class StreamFile { case 'png': return 'image/png'; case 'jpg': - return 'image/jpeg'; case 'jpeg': return 'image/jpeg'; } diff --git a/includes/Title.php b/includes/Title.php index 1e93c44250..9843e81962 100644 --- a/includes/Title.php +++ b/includes/Title.php @@ -23,7 +23,7 @@ */ use MediaWiki\Permissions\PermissionManager; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; use Wikimedia\Assert\Assert; use Wikimedia\Rdbms\Database; use Wikimedia\Rdbms\IDatabase; @@ -1059,7 +1059,7 @@ class Title implements LinkTarget, IDBAccessObject { $this->lazyFillContentModel( $this->loadFieldFromDB( 'page_content_model', $flags ) ); } elseif ( ( !$this->mContentModel || $flags & self::GAID_FOR_UPDATE ) && - $this->getArticleId( $flags ) + $this->getArticleID( $flags ) ) { $linkCache = MediaWikiServices::getInstance()->getLinkCache(); $linkCache->addLinkObj( $this ); # in case we already had an article ID @@ -1561,14 +1561,32 @@ class Title implements LinkTarget, IDBAccessObject { * Get a Title object associated with the talk page of this article * * @deprecated since 1.34, use getTalkPageIfDefined() or NamespaceInfo::getTalkPage() - * with NamespaceInfo::canHaveTalkPage(). + * with NamespaceInfo::canHaveTalkPage(). Note that the new method will + * throw if asked for the talk page of a section-only link, or of an interwiki + * link. * @return Title The object for the talk page * @throws MWException if $target doesn't have talk pages, e.g. because it's in NS_SPECIAL * or because it's a relative link, or an interwiki link. */ public function getTalkPage() { - return self::castFromLinkTarget( - MediaWikiServices::getInstance()->getNamespaceInfo()->getTalkPage( $this ) ); + // NOTE: The equivalent code in NamespaceInfo is less lenient about producing invalid titles. + // Instead of failing on invalid titles, let's just log the issue for now. + // See the discussion on T227817. + + // Is this the same title? + $talkNS = MediaWikiServices::getInstance()->getNamespaceInfo()->getTalk( $this->mNamespace ); + if ( $this->mNamespace == $talkNS ) { + return $this; + } + + $title = self::makeTitle( $talkNS, $this->mDbkeyform ); + + $this->warnIfPageCannotExist( $title, __METHOD__ ); + + return $title; + // TODO: replace the above with the code below: + // return self::castFromLinkTarget( + // MediaWikiServices::getInstance()->getNamespaceInfo()->getTalkPage( $this ) ); } /** @@ -1596,8 +1614,51 @@ class Title implements LinkTarget, IDBAccessObject { * @return Title The object for the subject page */ public function getSubjectPage() { - return self::castFromLinkTarget( - MediaWikiServices::getInstance()->getNamespaceInfo()->getSubjectPage( $this ) ); + // Is this the same title? + $subjectNS = MediaWikiServices::getInstance()->getNamespaceInfo() + ->getSubject( $this->mNamespace ); + if ( $this->mNamespace == $subjectNS ) { + return $this; + } + // NOTE: The equivalent code in NamespaceInfo is less lenient about producing invalid titles. + // Instead of failing on invalid titles, let's just log the issue for now. + // See the discussion on T227817. + $title = self::makeTitle( $subjectNS, $this->mDbkeyform ); + + $this->warnIfPageCannotExist( $title, __METHOD__ ); + + return $title; + // TODO: replace the above with the code below: + // return self::castFromLinkTarget( + // MediaWikiServices::getInstance()->getNamespaceInfo()->getSubjectPage( $this ) ); + } + + /** + * @param Title $title + * @param string $method + * + * @return bool whether a warning was issued + */ + private function warnIfPageCannotExist( Title $title, $method ) { + if ( $this->getText() == '' ) { + wfLogWarning( + $method . ': called on empty title ' . $this->getFullText() . ', returning ' + . $title->getFullText() + ); + + return true; + } + + if ( $this->getInterwiki() !== '' ) { + wfLogWarning( + $method . ': called on interwiki title ' . $this->getFullText() . ', returning ' + . $title->getFullText() + ); + + return true; + } + + return false; } /** @@ -1610,8 +1671,23 @@ class Title implements LinkTarget, IDBAccessObject { * @return Title */ public function getOtherPage() { - return self::castFromLinkTarget( - MediaWikiServices::getInstance()->getNamespaceInfo()->getAssociatedPage( $this ) ); + // NOTE: Depend on the methods in this class instead of their equivalent in NamespaceInfo, + // until their semantics has become exactly the same. + // See the discussion on T227817. + if ( $this->isSpecialPage() ) { + throw new MWException( 'Special pages cannot have other pages' ); + } + if ( $this->isTalkPage() ) { + return $this->getSubjectPage(); + } else { + if ( !$this->canHaveTalkPage() ) { + throw new MWException( "{$this->getPrefixedText()} does not have an other page" ); + } + return $this->getTalkPage(); + } + // TODO: replace the above with the code below: + // return self::castFromLinkTarget( + // MediaWikiServices::getInstance()->getNamespaceInfo()->getAssociatedPage( $this ) ); } /** @@ -1986,7 +2062,7 @@ class Title implements LinkTarget, IDBAccessObject { * * @see self::getLocalURL for the arguments. * @see wfExpandUrl - * @param string|string[] $query + * @param string|array $query * @param string|string[]|bool $query2 * @param string|int|null $proto Protocol type to use in URL * @return string The URL @@ -2047,7 +2123,7 @@ class Title implements LinkTarget, IDBAccessObject { * valid to link, locally, to the current Title. * @see self::newFromText to produce a Title object. * - * @param string|string[] $query An optional query string, + * @param string|array $query An optional query string, * not used for interwiki links. Can be specified as an associative array as well, * e.g., [ 'action' => 'edit' ] (keys and values will be URL-escaped). * Some query patterns will trigger various shorturl path replacements. @@ -2182,7 +2258,7 @@ class Title implements LinkTarget, IDBAccessObject { * protocol-relative, the URL will be expanded to http:// * * @see self::getLocalURL for the arguments. - * @param string|string[] $query + * @param string|array $query * @param string|bool $query2 Deprecated * @return string The URL */ @@ -2205,7 +2281,7 @@ class Title implements LinkTarget, IDBAccessObject { * NOTE: Unlike getInternalURL(), the canonical URL includes the fragment * * @see self::getLocalURL for the arguments. - * @param string|string[] $query + * @param string|array $query * @param string|bool $query2 Deprecated * @return string The URL * @since 1.18 @@ -4270,12 +4346,21 @@ class Title implements LinkTarget, IDBAccessObject { * on the number of links. Typically called on create and delete. */ public function touchLinks() { - DeferredUpdates::addUpdate( new HTMLCacheUpdate( $this, 'pagelinks', 'page-touch' ) ); + $jobs = []; + $jobs[] = HTMLCacheUpdateJob::newForBacklinks( + $this, + 'pagelinks', + [ 'causeAction' => 'page-touch' ] + ); if ( $this->mNamespace == NS_CATEGORY ) { - DeferredUpdates::addUpdate( - new HTMLCacheUpdate( $this, 'categorylinks', 'category-touch' ) + $jobs[] = HTMLCacheUpdateJob::newForBacklinks( + $this, + 'categorylinks', + [ 'causeAction' => 'category-touch' ] ); } + + JobQueueGroup::singleton()->lazyPush( $jobs ); } /** diff --git a/includes/WebRequest.php b/includes/WebRequest.php index a48d0325ee..c94e8d4e23 100644 --- a/includes/WebRequest.php +++ b/includes/WebRequest.php @@ -547,7 +547,7 @@ class WebRequest { * * @param string $name * @param array|null $default Option default (or null) - * @return array Array of ints + * @return int[]|null */ public function getIntArray( $name, $default = null ) { $val = $this->getArray( $name, $default ); diff --git a/includes/Xml.php b/includes/Xml.php index febf03e7a2..b368a131ca 100644 --- a/includes/Xml.php +++ b/includes/Xml.php @@ -266,7 +266,7 @@ class Xml { /** * Convenience function to build an HTML text input field * @param string $name Value of the name attribute - * @param int $size Value of the size attribute + * @param int|false $size Value of the size attribute * @param mixed $value Value of the value attribute * @param array $attribs Other attributes * @return string HTML @@ -289,7 +289,7 @@ class Xml { /** * Convenience function to build an HTML password input field * @param string $name Value of the name attribute - * @param int $size Value of the size attribute + * @param int|false $size Value of the size attribute * @param mixed $value Value of the value attribute * @param array $attribs Other attributes * @return string HTML @@ -600,7 +600,7 @@ class Xml { * * @param string|bool $legend Legend of the fieldset. If evaluates to false, * legend is not added. - * @param string $content Pre-escaped content for the fieldset. If false, + * @param string|false $content Pre-escaped content for the fieldset. If false, * only open fieldset is returned. * @param array $attribs Any attributes to fieldset-element. * diff --git a/includes/actions/Action.php b/includes/actions/Action.php index f892c5e34e..4be2f7d945 100644 --- a/includes/actions/Action.php +++ b/includes/actions/Action.php @@ -22,7 +22,7 @@ use MediaWiki\MediaWikiServices; /** - * @defgroup Actions Action done on pages + * @defgroup Actions Actions */ /** diff --git a/includes/actions/HistoryAction.php b/includes/actions/HistoryAction.php index db874f2de5..6a6104570c 100644 --- a/includes/actions/HistoryAction.php +++ b/includes/actions/HistoryAction.php @@ -433,27 +433,30 @@ class HistoryAction extends FormlessAction { * @return FeedItem */ function feedItem( $row ) { - $rev = new Revision( $row, 0, $this->getTitle() ); - + $revisionStore = MediaWikiServices::getInstance()->getRevisionStore(); + $rev = $revisionStore->newRevisionFromRow( $row, 0, $this->getTitle() ); + $prevRev = $revisionStore->getPreviousRevision( $rev ); + $revComment = $rev->getComment() === null ? null : $rev->getComment()->text; $text = FeedUtils::formatDiffRow( $this->getTitle(), - $this->getTitle()->getPreviousRevisionID( $rev->getId() ), + $prevRev ? $prevRev->getId() : false, $rev->getId(), $rev->getTimestamp(), - $rev->getComment() + $revComment ); - if ( $rev->getComment() == '' ) { + $revUserText = $rev->getUser() ? $rev->getUser()->getName() : ''; + if ( $revComment == '' ) { $contLang = MediaWikiServices::getInstance()->getContentLanguage(); $title = $this->msg( 'history-feed-item-nocomment', - $rev->getUserText(), + $revUserText, $contLang->timeanddate( $rev->getTimestamp() ), $contLang->date( $rev->getTimestamp() ), $contLang->time( $rev->getTimestamp() ) )->inContentLanguage()->text(); } else { - $title = $rev->getUserText() . + $title = $revUserText . $this->msg( 'colon-separator' )->inContentLanguage()->text() . - FeedItem::stripComment( $rev->getComment() ); + FeedItem::stripComment( $revComment ); } return new FeedItem( @@ -461,7 +464,7 @@ class HistoryAction extends FormlessAction { $text, $this->getTitle()->getFullURL( 'diff=' . $rev->getId() . '&oldid=prev' ), $rev->getTimestamp(), - $rev->getUserText(), + $revUserText, $this->getTitle()->getTalkPage()->getFullURL() ); } diff --git a/includes/actions/InfoAction.php b/includes/actions/InfoAction.php index 207721e583..0360fe44d2 100644 --- a/includes/actions/InfoAction.php +++ b/includes/actions/InfoAction.php @@ -23,7 +23,7 @@ */ use MediaWiki\MediaWikiServices; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; use Wikimedia\Rdbms\Database; /** @@ -280,11 +280,10 @@ class InfoAction extends FormlessAction { // Language in which the page content is (supposed to be) written $pageLang = $title->getPageLanguage()->getCode(); - $permissionManager = $services->getPermissionManager(); - $pageLangHtml = $pageLang . ' - ' . Language::fetchLanguageName( $pageLang, $lang->getCode() ); // Link to Special:PageLanguage with pre-filled page title if user has permissions + $permissionManager = $services->getPermissionManager(); if ( $config->get( 'PageLanguageUseDB' ) && $permissionManager->userCan( 'pagelang', $user, $title ) ) { @@ -344,8 +343,7 @@ class InfoAction extends FormlessAction { ]; $unwatchedPageThreshold = $config->get( 'UnwatchedPageThreshold' ); - if ( - $services->getPermissionManager()->userHasRight( $user, 'unwatchedpages' ) || + if ( $permissionManager->userHasRight( $user, 'unwatchedpages' ) || ( $unwatchedPageThreshold !== false && $pageCounts['watchers'] >= $unwatchedPageThreshold ) ) { @@ -360,7 +358,7 @@ class InfoAction extends FormlessAction { ) { $minToDisclose = $config->get( 'UnwatchedPageSecret' ); if ( $pageCounts['visitingWatchers'] > $minToDisclose || - $services->getPermissionManager()->userHasRight( $user, 'unwatchedpages' ) ) { + $permissionManager->userHasRight( $user, 'unwatchedpages' ) ) { $pageInfo['header-basic'][] = [ $this->msg( 'pageinfo-visiting-watchers' ), $lang->formatNum( $pageCounts['visitingWatchers'] ) diff --git a/includes/actions/McrUndoAction.php b/includes/actions/McrUndoAction.php index 41cd24e701..68c0ea1243 100644 --- a/includes/actions/McrUndoAction.php +++ b/includes/actions/McrUndoAction.php @@ -289,8 +289,9 @@ class McrUndoAction extends FormAction { 'h2', [ 'id' => 'mw-previewheader' ], $this->context->msg( 'preview' )->text() ) . - $out->parseAsInterface( $note ) . - "
" + Html::rawElement( 'div', [ 'class' => 'warningbox' ], + $out->parseAsInterface( $note ) + ) ); $pageViewLang = $this->getTitle()->getPageViewLanguage(); diff --git a/includes/actions/RawAction.php b/includes/actions/RawAction.php index 8fd4e0ad55..0586e093c5 100644 --- a/includes/actions/RawAction.php +++ b/includes/actions/RawAction.php @@ -238,23 +238,31 @@ class RawAction extends FormlessAction { */ public function getOldId() { $oldid = $this->getRequest()->getInt( 'oldid' ); + $rl = MediaWikiServices::getInstance()->getRevisionLookup(); switch ( $this->getRequest()->getText( 'direction' ) ) { case 'next': # output next revision, or nothing if there isn't one - $nextid = 0; + $nextRev = null; if ( $oldid ) { - $nextid = $this->getTitle()->getNextRevisionID( $oldid ); + $oldRev = $rl->getRevisionById( $oldid ); + if ( $oldRev ) { + $nextRev = $rl->getNextRevision( $oldRev ); + } } - $oldid = $nextid ?: -1; + $oldid = $nextRev ? $nextRev->getId() : -1; break; case 'prev': # output previous revision, or nothing if there isn't one + $prevRev = null; if ( !$oldid ) { # get the current revision so we can get the penultimate one $oldid = $this->page->getLatest(); } - $previd = $this->getTitle()->getPreviousRevisionID( $oldid ); - $oldid = $previd ?: -1; + $oldRev = $rl->getRevisionById( $oldid ); + if ( $oldRev ) { + $prevRev = $rl->getPreviousRevision( $oldRev ); + } + $oldid = $prevRev ? $prevRev->getId() : -1; break; case 'cur': $oldid = 0; diff --git a/includes/actions/RollbackAction.php b/includes/actions/RollbackAction.php index 519da617ba..1c9e63b99e 100644 --- a/includes/actions/RollbackAction.php +++ b/includes/actions/RollbackAction.php @@ -20,7 +20,7 @@ * @ingroup Actions */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; /** * User interface for the rollback action diff --git a/includes/actions/SpecialPageAction.php b/includes/actions/SpecialPageAction.php index 8a231cbe5f..56be456cac 100644 --- a/includes/actions/SpecialPageAction.php +++ b/includes/actions/SpecialPageAction.php @@ -35,6 +35,9 @@ class SpecialPageAction extends FormlessAction { 'editchangetags' => 'EditTags', ]; + /** + * @inheritDoc + */ public function getName() { $request = $this->getRequest(); $actionName = $request->getVal( 'action', 'view' ); diff --git a/includes/api/ApiBase.php b/includes/api/ApiBase.php index 056d10c3c9..7518008f9d 100644 --- a/includes/api/ApiBase.php +++ b/includes/api/ApiBase.php @@ -1585,6 +1585,7 @@ abstract class ApiBase extends ContextSource { 'integeroutofrange', [ 'min' => $min, 'max' => $max, 'botMax' => $botMax ?: $max ] ); + // @phan-suppress-next-line PhanTypeMismatchArgument $this->warnOrDie( $msg, $enforceLimits ); $value = $min; } @@ -1606,6 +1607,7 @@ abstract class ApiBase extends ContextSource { 'integeroutofrange', [ 'min' => $min, 'max' => $max, 'botMax' => $botMax ?: $max ] ); + // @phan-suppress-next-line PhanTypeMismatchArgument $this->warnOrDie( $msg, $enforceLimits ); $value = $botMax; } @@ -1616,6 +1618,7 @@ abstract class ApiBase extends ContextSource { 'integeroutofrange', [ 'min' => $min, 'max' => $max, 'botMax' => $botMax ?: $max ] ); + // @phan-suppress-next-line PhanTypeMismatchArgument $this->warnOrDie( $msg, $enforceLimits ); $value = $max; } @@ -2022,6 +2025,7 @@ abstract class ApiBase extends ContextSource { */ public function dieWithException( $exception, array $options = [] ) { $this->dieWithError( + // @phan-suppress-next-line PhanTypeMismatchArgument $this->getErrorFormatter()->getMessageFromException( $exception, $options ) ); } @@ -2464,6 +2468,7 @@ abstract class ApiBase extends ContextSource { if ( $m ) { $m = new ApiHelpParamValueMessage( $value, + // @phan-suppress-next-line PhanTypeMismatchArgument [ $m->getKey(), 'api-help-param-no-description' ], $m->getParams(), isset( $deprecatedValues[$value] ) diff --git a/includes/api/ApiComparePages.php b/includes/api/ApiComparePages.php index 05eb4382b3..6e788d550d 100644 --- a/includes/api/ApiComparePages.php +++ b/includes/api/ApiComparePages.php @@ -26,6 +26,9 @@ use MediaWiki\Revision\RevisionArchiveRecord; use MediaWiki\Revision\RevisionStore; use MediaWiki\Revision\SlotRecord; +/** + * @ingroup API + */ class ApiComparePages extends ApiBase { /** @var RevisionStore */ @@ -249,6 +252,7 @@ class ApiComparePages extends ApiBase { ); if ( $row ) { $rev = $this->revisionStore->newRevisionFromArchiveRow( $row ); + // @phan-suppress-next-line PhanUndeclaredProperty $rev->isArchive = true; } } @@ -617,6 +621,7 @@ class ApiComparePages extends ApiBase { } } + // @phan-suppress-next-line PhanUndeclaredProperty if ( !empty( $rev->isArchive ) ) { $this->getMain()->setCacheMode( 'private' ); $vals["{$prefix}archive"] = true; diff --git a/includes/api/ApiEditPage.php b/includes/api/ApiEditPage.php index fdf9cf1bf9..1936407ac3 100644 --- a/includes/api/ApiEditPage.php +++ b/includes/api/ApiEditPage.php @@ -20,7 +20,8 @@ * @file */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\MediaWikiServices; +use MediaWiki\Revision\RevisionRecord; /** * A module that allows for editing and creating pages. @@ -239,11 +240,15 @@ class ApiEditPage extends ApiBase { $params['text'] = $newContent->serialize( $contentFormat ); // If no summary was given and we only undid one rev, // use an autosummary - if ( is_null( $params['summary'] ) && - $titleObj->getNextRevisionID( $undoafterRev->getId() ) == $params['undo'] - ) { - $params['summary'] = wfMessage( 'undo-summary' ) - ->params( $params['undo'], $undoRev->getUserText() )->inContentLanguage()->text(); + + if ( is_null( $params['summary'] ) ) { + $nextRev = MediaWikiServices::getInstance()->getRevisionLookup() + ->getNextRevision( $undoafterRev->getRevisionRecord() ); + if ( $nextRev && $nextRev->getId() == $params['undo'] ) { + $params['summary'] = wfMessage( 'undo-summary' ) + ->params( $params['undo'], $undoRev->getUserText() ) + ->inContentLanguage()->text(); + } } } diff --git a/includes/api/ApiErrorFormatter.php b/includes/api/ApiErrorFormatter.php index 81ee9b9932..9dfd3705a5 100644 --- a/includes/api/ApiErrorFormatter.php +++ b/includes/api/ApiErrorFormatter.php @@ -237,6 +237,7 @@ class ApiErrorFormatter { */ public function formatException( $exception, array $options = [] ) { return $this->formatMessage( + // @phan-suppress-next-line PhanTypeMismatchArgument $this->getMessageFromException( $exception, $options ), $options['format'] ?? null ); diff --git a/includes/api/ApiFormatXmlRsd.php b/includes/api/ApiFormatXmlRsd.php index 6b892fa8ce..3052b89431 100644 --- a/includes/api/ApiFormatXmlRsd.php +++ b/includes/api/ApiFormatXmlRsd.php @@ -21,6 +21,9 @@ * @file */ +/** + * @ingroup API + */ class ApiFormatXmlRsd extends ApiFormatXml { public function __construct( ApiMain $main, $format ) { parent::__construct( $main, $format ); diff --git a/includes/api/ApiHelpParamValueMessage.php b/includes/api/ApiHelpParamValueMessage.php index 7aebf90e3c..0272dcd426 100644 --- a/includes/api/ApiHelpParamValueMessage.php +++ b/includes/api/ApiHelpParamValueMessage.php @@ -28,6 +28,7 @@ * 'APIGetParamDescriptionMessages' hook simple. * * @since 1.25 + * @ingroup API */ class ApiHelpParamValueMessage extends Message { diff --git a/includes/api/ApiImageRotate.php b/includes/api/ApiImageRotate.php index 1f8b012ef2..8a0e8c974d 100644 --- a/includes/api/ApiImageRotate.php +++ b/includes/api/ApiImageRotate.php @@ -1,7 +1,4 @@ addWhere( 'user_editcount > 0' ); } - $this->showHiddenUsersAddBlockInfo( $fld_blockinfo ); + $this->addBlockInfoToQuery( $fld_blockinfo ); if ( $fld_groups || $fld_rights ) { $this->addFields( [ 'groups' => @@ -263,13 +267,8 @@ class ApiQueryAllUsers extends ApiQueryBase { ); } - if ( $fld_blockinfo && !is_null( $row->ipb_by_text ) ) { - $data['blockid'] = (int)$row->ipb_id; - $data['blockedby'] = $row->ipb_by_text; - $data['blockedbyid'] = (int)$row->ipb_by; - $data['blockedtimestamp'] = wfTimestamp( TS_ISO_8601, $row->ipb_timestamp ); - $data['blockreason'] = $commentStore->getComment( 'ipb_reason', $row )->text; - $data['blockexpiry'] = $row->ipb_expiry; + if ( $fld_blockinfo && !is_null( $row->ipb_id ) ) { + $data += $this->getBlockDetails( DatabaseBlock::newFromRow( $row ) ); } if ( $row->ipb_deleted ) { $data['hidden'] = true; diff --git a/includes/api/ApiQueryBacklinks.php b/includes/api/ApiQueryBacklinks.php index d21f1119aa..a6b15e997b 100644 --- a/includes/api/ApiQueryBacklinks.php +++ b/includes/api/ApiQueryBacklinks.php @@ -41,6 +41,9 @@ class ApiQueryBacklinks extends ApiQueryGeneratorBase { private $redirect; private $bl_ns, $bl_from, $bl_from_ns, $bl_table, $bl_code, $bl_title, $bl_fields, $hasNS; + /** @var string */ + private $helpUrl; + /** * Maps ns and title to pageid * diff --git a/includes/api/ApiQueryBase.php b/includes/api/ApiQueryBase.php index 10db848d94..8d9cb48c1a 100644 --- a/includes/api/ApiQueryBase.php +++ b/includes/api/ApiQueryBase.php @@ -31,6 +31,7 @@ use Wikimedia\Rdbms\IResultWrapper; * @ingroup API */ abstract class ApiQueryBase extends ApiBase { + use ApiQueryBlockInfoTrait; private $mQueryModule, $mDb, $tables, $where, $fields, $options, $join_conds; @@ -424,47 +425,6 @@ abstract class ApiQueryBase extends ApiBase { return Hooks::run( 'ApiQueryBaseProcessRow', [ $this, $row, &$data, &$hookData ] ); } - /** - * Filters hidden users (where the user doesn't have the right to view them) - * Also adds relevant block information - * - * @param bool $showBlockInfo - * @return void - */ - public function showHiddenUsersAddBlockInfo( $showBlockInfo ) { - $db = $this->getDB(); - - $tables = [ 'ipblocks' ]; - $fields = [ 'ipb_deleted' ]; - $joinConds = [ - 'blk' => [ 'LEFT JOIN', [ - 'ipb_user=user_id', - 'ipb_expiry > ' . $db->addQuotes( $db->timestamp() ), - ] ], - ]; - - if ( $showBlockInfo ) { - $actorQuery = ActorMigration::newMigration()->getJoin( 'ipb_by' ); - $commentQuery = CommentStore::getStore()->getJoin( 'ipb_reason' ); - $tables += $actorQuery['tables'] + $commentQuery['tables']; - $joinConds += $actorQuery['joins'] + $commentQuery['joins']; - $fields = array_merge( $fields, [ - 'ipb_id', - 'ipb_expiry', - 'ipb_timestamp' - ], $actorQuery['fields'], $commentQuery['fields'] ); - } - - $this->addTables( [ 'blk' => $tables ] ); - $this->addFields( $fields ); - $this->addJoinConds( $joinConds ); - - // Don't show hidden names - if ( !$this->getPermissionManager()->userHasRight( $this->getUser(), 'hideuser' ) ) { - $this->addWhere( 'ipb_deleted = 0 OR ipb_deleted IS NULL' ); - } - } - /** @} */ /************************************************************************//** @@ -610,4 +570,24 @@ abstract class ApiQueryBase extends ApiBase { } /** @} */ + + /************************************************************************//** + * @name Deprecated methods + * @{ + */ + + /** + * Filters hidden users (where the user doesn't have the right to view them) + * Also adds relevant block information + * + * @deprecated since 1.34, use ApiQueryBlockInfoTrait instead + * @param bool $showBlockInfo + * @return void + */ + public function showHiddenUsersAddBlockInfo( $showBlockInfo ) { + wfDeprecated( __METHOD__, '1.34' ); + return $this->addBlockInfoToQuery( $showBlockInfo ); + } + + /** @} */ } diff --git a/includes/api/ApiQueryBlockInfoTrait.php b/includes/api/ApiQueryBlockInfoTrait.php new file mode 100644 index 0000000000..a3be35650e --- /dev/null +++ b/includes/api/ApiQueryBlockInfoTrait.php @@ -0,0 +1,94 @@ +getDB(); + + if ( $showBlockInfo ) { + $queryInfo = DatabaseBlock::getQueryInfo(); + } else { + $queryInfo = [ + 'tables' => [ 'ipblocks' ], + 'fields' => [ 'ipb_deleted' ], + 'joins' => [], + ]; + } + + $this->addTables( [ 'blk' => $queryInfo['tables'] ] ); + $this->addFields( $queryInfo['fields'] ); + $this->addJoinConds( $queryInfo['joins'] ); + $this->addJoinConds( [ + 'blk' => [ 'LEFT JOIN', [ + 'ipb_user=user_id', + 'ipb_expiry > ' . $db->addQuotes( $db->timestamp() ), + ] ], + ] ); + + // Don't show hidden names + if ( !$this->getPermissionManager()->userHasRight( $this->getUser(), 'hideuser' ) ) { + $this->addWhere( 'ipb_deleted = 0 OR ipb_deleted IS NULL' ); + } + } + + /** + * @name Methods required from ApiQueryBase + * @{ + */ + + /** @see ApiBase::getDB */ + abstract protected function getDB(); + + /** @see ApiBase::getPermissionManager */ + abstract protected function getPermissionManager(): PermissionManager; + + /** @see IContextSource::getUser */ + abstract public function getUser(); + + /** @see ApiQueryBase::addTables */ + abstract protected function addTables( $tables, $alias = null ); + + /** @see ApiQueryBase::addFields */ + abstract protected function addFields( $fields ); + + /** @see ApiQueryBase::addWhere */ + abstract protected function addWhere( $conds ); + + /** @see ApiQueryBase::addJoinConds */ + abstract protected function addJoinConds( $conds ); + + /**@}*/ + +} diff --git a/includes/api/ApiQueryDeletedrevs.php b/includes/api/ApiQueryDeletedrevs.php index eb787d1cd3..a47ca09522 100644 --- a/includes/api/ApiQueryDeletedrevs.php +++ b/includes/api/ApiQueryDeletedrevs.php @@ -22,7 +22,8 @@ use MediaWiki\MediaWikiServices; use MediaWiki\Storage\NameTableAccessException; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; +use MediaWiki\Revision\SlotRecord; /** * Query module to enumerate all deleted revisions. @@ -347,7 +348,9 @@ class ApiQueryDeletedrevs extends ApiQueryBase { $anyHidden = true; } if ( Revision::userCanBitfield( $row->ar_deleted, RevisionRecord::DELETED_TEXT, $user ) ) { - ApiResult::setContentValue( $rev, 'text', Revision::getRevisionText( $row, 'ar_' ) ); + ApiResult::setContentValue( $rev, 'text', + $revisionStore->newRevisionFromArchiveRow( $row ) + ->getContent( SlotRecord::MAIN )->serialize() ); } } diff --git a/includes/api/ApiQueryImageInfo.php b/includes/api/ApiQueryImageInfo.php index 97a9b0a5b5..285c0bfcc9 100644 --- a/includes/api/ApiQueryImageInfo.php +++ b/includes/api/ApiQueryImageInfo.php @@ -387,9 +387,13 @@ class ApiQueryImageInfo extends ApiQueryBase { $vals = [ ApiResult::META_TYPE => 'assoc', ]; + + // Some information will be unavailable if the file does not exist. T221812 + $exists = $file->exists(); + // Timestamp is shown even if the file is revdelete'd in interface // so do same here. - if ( isset( $prop['timestamp'] ) ) { + if ( isset( $prop['timestamp'] ) && $exists ) { $vals['timestamp'] = wfTimestamp( TS_ISO_8601, $file->getTimestamp() ); } @@ -408,7 +412,7 @@ class ApiQueryImageInfo extends ApiQueryBase { $user = isset( $prop['user'] ); $userid = isset( $prop['userid'] ); - if ( $user || $userid ) { + if ( ( $user || $userid ) && $exists ) { if ( $file->isDeleted( File::DELETED_USER ) ) { $vals['userhidden'] = true; $anyHidden = true; @@ -428,7 +432,7 @@ class ApiQueryImageInfo extends ApiQueryBase { // This is shown even if the file is revdelete'd in interface // so do same here. - if ( isset( $prop['size'] ) || isset( $prop['dimensions'] ) ) { + if ( ( isset( $prop['size'] ) || isset( $prop['dimensions'] ) ) && $exists ) { $vals['size'] = (int)$file->getSize(); $vals['width'] = (int)$file->getWidth(); $vals['height'] = (int)$file->getHeight(); @@ -449,7 +453,7 @@ class ApiQueryImageInfo extends ApiQueryBase { $pcomment = isset( $prop['parsedcomment'] ); $comment = isset( $prop['comment'] ); - if ( $pcomment || $comment ) { + if ( ( $pcomment || $comment ) && $exists ) { if ( $file->isDeleted( File::DELETED_COMMENT ) ) { $vals['commenthidden'] = true; $anyHidden = true; @@ -500,7 +504,7 @@ class ApiQueryImageInfo extends ApiQueryBase { } if ( $url ) { - if ( $file->exists() ) { + if ( $exists ) { if ( !is_null( $thumbParams ) ) { $mto = $file->transform( $thumbParams ); self::$transformCount++; @@ -529,8 +533,6 @@ class ApiQueryImageInfo extends ApiQueryBase { } } $vals['url'] = wfExpandUrl( $file->getFullUrl(), PROTO_CURRENT ); - } else { - $vals['filemissing'] = true; } $vals['descriptionurl'] = wfExpandUrl( $file->getDescriptionUrl(), PROTO_CURRENT ); @@ -540,11 +542,15 @@ class ApiQueryImageInfo extends ApiQueryBase { } } - if ( $sha1 ) { + if ( !$exists ) { + $vals['filemissing'] = true; + } + + if ( $sha1 && $exists ) { $vals['sha1'] = Wikimedia\base_convert( $file->getSha1(), 36, 16, 40 ); } - if ( $meta ) { + if ( $meta && $exists ) { Wikimedia\suppressWarnings(); $metadata = unserialize( $file->getMetadata() ); Wikimedia\restoreWarnings(); @@ -553,12 +559,12 @@ class ApiQueryImageInfo extends ApiQueryBase { } $vals['metadata'] = $metadata ? static::processMetaData( $metadata, $result ) : null; } - if ( $commonmeta ) { + if ( $commonmeta && $exists ) { $metaArray = $file->getCommonMetaArray(); $vals['commonmetadata'] = $metaArray ? static::processMetaData( $metaArray, $result ) : []; } - if ( $extmetadata ) { + if ( $extmetadata && $exists ) { // Note, this should return an array where all the keys // start with a letter, and all the values are strings. // Thus there should be no issue with format=xml. @@ -575,11 +581,11 @@ class ApiQueryImageInfo extends ApiQueryBase { $vals['extmetadata'] = $extmetaArray; } - if ( $mime ) { + if ( $mime && $exists ) { $vals['mime'] = $file->getMimeType(); } - if ( $mediatype ) { + if ( $mediatype && $exists ) { $vals['mediatype'] = $file->getMediaType(); } @@ -589,7 +595,7 @@ class ApiQueryImageInfo extends ApiQueryBase { $vals['archivename'] = $file->getArchiveName(); } - if ( $bitdepth ) { + if ( $bitdepth && $exists ) { $vals['bitdepth'] = $file->getBitDepth(); } diff --git a/includes/api/ApiQueryLogEvents.php b/includes/api/ApiQueryLogEvents.php index 47a6f87296..2c19c7d1aa 100644 --- a/includes/api/ApiQueryLogEvents.php +++ b/includes/api/ApiQueryLogEvents.php @@ -186,6 +186,7 @@ class ApiQueryLogEvents extends ApiQueryBase { // T71222: MariaDB's optimizer, at least 10.1.37 and .38, likes to choose a wildly bad plan for // some reason for this code path. Tell it not to use the wrong index it wants to pick. + // @phan-suppress-next-line PhanTypeMismatchArgument $this->addOption( 'IGNORE INDEX', [ 'logging' => [ 'times' ] ] ); } diff --git a/includes/api/ApiQueryQueryPage.php b/includes/api/ApiQueryQueryPage.php index 26c17c59b8..12e908ff11 100644 --- a/includes/api/ApiQueryQueryPage.php +++ b/includes/api/ApiQueryQueryPage.php @@ -61,7 +61,7 @@ class ApiQueryQueryPage extends ApiQueryGeneratorBase { * @param string $name * @return QueryPage */ - private function getSpecialPage( $name ) { + private function getSpecialPage( $name ) : QueryPage { $qp = $this->specialPageFactory->getPage( $name ); if ( !$qp ) { self::dieDebug( diff --git a/includes/api/ApiQuerySiteinfo.php b/includes/api/ApiQuerySiteinfo.php index 7e4a891adf..47212b321a 100644 --- a/includes/api/ApiQuerySiteinfo.php +++ b/includes/api/ApiQuerySiteinfo.php @@ -279,6 +279,8 @@ class ApiQuerySiteinfo extends ApiQueryBase { } protected function appendNamespaces( $property ) { + $nsProtection = $this->getConfig()->get( 'NamespaceProtection' ); + $data = [ ApiResult::META_TYPE => 'assoc', ]; @@ -303,6 +305,17 @@ class ApiQuerySiteinfo extends ApiQueryBase { $data[$ns]['content'] = $nsInfo->isContent( $ns ); $data[$ns]['nonincludable'] = $nsInfo->isNonincludable( $ns ); + if ( isset( $nsProtection[$ns] ) ) { + if ( is_array( $nsProtection[$ns] ) ) { + $specificNs = implode( "|", array_filter( $nsProtection[$ns] ) ); + } elseif ( $nsProtection[$ns] !== '' ) { + $specificNs = $nsProtection[$ns]; + } + if ( isset( $specificNs ) && $specificNs !== '' ) { + $data[$ns]['namespaceprotection'] = $specificNs; + } + } + $contentmodel = $nsInfo->getNamespaceContentModel( $ns ); if ( $contentmodel ) { $data[$ns]['defaultcontentmodel'] = $contentmodel; diff --git a/includes/api/ApiQueryUsers.php b/includes/api/ApiQueryUsers.php index ce51a672ba..0171a37733 100644 --- a/includes/api/ApiQueryUsers.php +++ b/includes/api/ApiQueryUsers.php @@ -20,12 +20,15 @@ * @file */ +use MediaWiki\Block\DatabaseBlock; + /** * Query module to get information about a list of users * * @ingroup API */ class ApiQueryUsers extends ApiQueryBase { + use ApiQueryBlockInfoTrait; private $tokenFunctions, $prop; @@ -150,7 +153,7 @@ class ApiQueryUsers extends ApiQueryBase { $this->addWhereFld( 'user_id', $userids ); } - $this->showHiddenUsersAddBlockInfo( isset( $this->prop['blockinfo'] ) ); + $this->addBlockInfoToQuery( isset( $this->prop['blockinfo'] ) ); $data = []; $res = $this->select( __METHOD__ ); @@ -232,13 +235,7 @@ class ApiQueryUsers extends ApiQueryBase { $data[$key]['hidden'] = true; } if ( isset( $this->prop['blockinfo'] ) && !is_null( $row->ipb_by_text ) ) { - $data[$key]['blockid'] = (int)$row->ipb_id; - $data[$key]['blockedby'] = $row->ipb_by_text; - $data[$key]['blockedbyid'] = (int)$row->ipb_by; - $data[$key]['blockedtimestamp'] = wfTimestamp( TS_ISO_8601, $row->ipb_timestamp ); - $data[$key]['blockreason'] = $commentStore->getComment( 'ipb_reason', $row ) - ->text; - $data[$key]['blockexpiry'] = $row->ipb_expiry; + $data[$key] += $this->getBlockDetails( DatabaseBlock::newFromRow( $row ) ); } if ( isset( $this->prop['emailable'] ) ) { diff --git a/includes/api/ApiResetPassword.php b/includes/api/ApiResetPassword.php index 77838269b4..6b1c217017 100644 --- a/includes/api/ApiResetPassword.php +++ b/includes/api/ApiResetPassword.php @@ -21,6 +21,7 @@ */ use MediaWiki\Auth\AuthManager; +use MediaWiki\MediaWikiServices; /** * Reset password, with AuthManager @@ -63,7 +64,11 @@ class ApiResetPassword extends ApiBase { $this->requireOnlyOneParameter( $params, 'user', 'email' ); - $passwordReset = new PasswordReset( $this->getConfig(), AuthManager::singleton() ); + $passwordReset = new PasswordReset( + $this->getConfig(), + AuthManager::singleton(), + MediaWikiServices::getInstance()->getPermissionManager() + ); $status = $passwordReset->isAllowed( $this->getUser() ); if ( !$status->isOK() ) { diff --git a/includes/api/ApiSetNotificationTimestamp.php b/includes/api/ApiSetNotificationTimestamp.php index 7e9f56d09c..3f6f14c1b3 100644 --- a/includes/api/ApiSetNotificationTimestamp.php +++ b/includes/api/ApiSetNotificationTimestamp.php @@ -93,13 +93,14 @@ class ApiSetNotificationTimestamp extends ApiBase { $titles = $pageSet->getGoodTitles(); $title = reset( $titles ); if ( $title ) { - $revid = $title->getNextRevisionID( $params['newerthanrevid'], Title::READ_LATEST ); - if ( $revid ) { - $timestamp = $dbw->timestamp( - MediaWikiServices::getInstance()->getRevisionStore()->getTimestampFromId( $title, $revid ) - ); - } else { - $timestamp = null; + $timestamp = null; + $rl = MediaWikiServices::getInstance()->getRevisionLookup(); + $currRev = $rl->getRevisionById( $params['newerthanrevid'], Title::READ_LATEST ); + if ( $currRev ) { + $nextRev = $rl->getNextRevision( $currRev, Title::READ_LATEST ); + if ( $nextRev ) { + $timestamp = $dbw->timestamp( $nextRev->getTimestamp() ); + } } } } diff --git a/includes/api/ApiTag.php b/includes/api/ApiTag.php index bb6c580385..f2b52cd33a 100644 --- a/includes/api/ApiTag.php +++ b/includes/api/ApiTag.php @@ -96,6 +96,7 @@ class ApiTag extends ApiBase { $valid = RecentChange::newFromId( $id ); if ( $valid && $this->getPermissionManager()->isBlockedFrom( $user, $valid->getTitle() ) ) { $idResult['status'] = 'error'; + // @phan-suppress-next-line PhanTypeMismatchArgument $idResult += $this->getErrorFormatter()->formatMessage( ApiMessage::create( 'apierror-blocked', 'blocked', @@ -111,6 +112,7 @@ class ApiTag extends ApiBase { $this->getPermissionManager()->isBlockedFrom( $user, $valid->getPageAsLinkTarget() ) ) { $idResult['status'] = 'error'; + // @phan-suppress-next-line PhanTypeMismatchArgument $idResult += $this->getErrorFormatter()->formatMessage( ApiMessage::create( 'apierror-blocked', 'blocked', diff --git a/includes/api/ApiUpload.php b/includes/api/ApiUpload.php index 373ec11271..4678e1f0cc 100644 --- a/includes/api/ApiUpload.php +++ b/includes/api/ApiUpload.php @@ -636,6 +636,7 @@ class ApiUpload extends ApiBase { } ApiResult::setIndexedTagName( $details, 'detail' ); $msg->setApiData( $msg->getApiData() + [ 'details' => $details ] ); + // @phan-suppress-next-line PhanTypeMismatchArgument $this->dieWithError( $msg ); break; diff --git a/includes/api/i18n/ar.json b/includes/api/i18n/ar.json index 09d9c468a5..58d2deed51 100644 --- a/includes/api/i18n/ar.json +++ b/includes/api/i18n/ar.json @@ -1607,8 +1607,10 @@ "apierror-cantoverwrite-sharedfile": "الملف الهدف موجود في مستودع مشترك وليست لديك صلاحية لتجاوزه.", "apierror-cantsend": "لم تقم بتسجيل الدخول أو ليس لديك عنوان بريد إلكتروني مؤكد أو غير مسموح لك بإرسال بريد إلكتروني إلى مستخدمين آخرين; لذلك لا يمكنك إرسال بريد إلكتروني.", "apierror-cantundelete": "تعذر الاسترجاع: قد لا تكون المراجعات المطلوبة موجودة، أو ربما تم الاسترجاع بالفعل.", - "apierror-cantview-deleted-description": "ليست لديك صلايبة لعرض أوصاف الملفات المحذوفة.", - "apierror-cantview-deleted-metadata": "ليست لديك صلايبة لعرض البيانات الوصفية للملفات المحذوفة.", + "apierror-cantview-deleted-comment": "ليست لديك صلاحية لعرض التعليقات المحذوفة.", + "apierror-cantview-deleted-description": "ليست لديك صلاحية لعرض أوصاف الملفات المحذوفة.", + "apierror-cantview-deleted-metadata": "ليست لديك صلاحية لعرض البيانات الوصفية للملفات المحذوفة.", + "apierror-cantview-deleted-revision-content": "ليست لديك صلاحية لعرض محتوى المراجعات المحذوفة.", "apierror-changeauth-norequest": "فشل في إنشاء طلب التغيير.", "apierror-chunk-too-small": "الحد الأدنى لحجم القطعة هو $1 {{PLURAL:$1|بايت}} للقطع غير النهائية.", "apierror-cidrtoobroad": "لا يُقبَل مدى $1 CIDR أكبر من /$2.", diff --git a/includes/api/i18n/fr.json b/includes/api/i18n/fr.json index 7c5d2b5676..12ece4c5e3 100644 --- a/includes/api/i18n/fr.json +++ b/includes/api/i18n/fr.json @@ -37,13 +37,13 @@ "Lucas Werkmeister (WMDE)" ] }, - "apihelp-main-extended-description": "
\n* [[mw:Special:MyLanguage/API:Main_page|Documentation]]\n* [[mw:Special:MyLanguage/API:FAQ|FAQ]]\n* [https://lists.wikimedia.org/mailman/listinfo/mediawiki-api Liste de diffusion]\n* [https://lists.wikimedia.org/mailman/listinfo/mediawiki-api-announce Annonces de l’API]\n* [https://phabricator.wikimedia.org/maniphest/query/GebfyV4uCaLd/#R Bogues et demandes]\n
\nÉtat : L’API MediaWiki est une interface stable et mature qui est supportée et améliorée de façon active. Bien que nous essayions de l’éviter, nous pouvons avoir parfois besoin de faire des modifications impactantes ; inscrivez-vous à [https://lists.wikimedia.org/pipermail/mediawiki-api-announce/ la liste de diffusion mediawiki-api-announce] pour être informé des mises à jour.\n\nRequêtes erronées : Si des requêtes erronées sont envoyées à l’API, un entête HTTP sera renvoyé avec la clé « MediaWiki-API-Error ». La valeur de cet entête et le code d’erreur renvoyé prendront la même valeur. Pour plus d’information, voyez [[mw:Special:MyLanguage/API:Errors_and_warnings|API:Errors and warnings]].\n\n

Test : Pour faciliter le test des requêtes à l’API, voyez [[Special:ApiSandbox]].

", + "apihelp-main-extended-description": "
\n* [[mw:Special:MyLanguage/API:Main_page|Documentation]]\n* [[mw:Special:MyLanguage/API:FAQ|FAQ]]\n* [https://lists.wikimedia.org/mailman/listinfo/mediawiki-api Liste de diffusion]\n* [https://lists.wikimedia.org/mailman/listinfo/mediawiki-api-announce Annonces de l’API]\n* [https://phabricator.wikimedia.org/maniphest/query/GebfyV4uCaLd/#R Bogues et demandes]\n
\nÉtat : l’API de MediaWiki est une interface stable et mature qui est supportée et améliorée de façon active. Bien que nous essayions de l’éviter, nous pouvons avoir parfois besoin de faire des modifications impactantes ; inscrivez-vous à [https://lists.wikimedia.org/pipermail/mediawiki-api-announce/ la liste de diffusion ''mediawiki-api-announce''] pour être informé des mises à jour.\n\nRequêtes erronées : si des requêtes erronées sont envoyées à l’API, un entête HTTP sera renvoyé avec la clé « MediaWiki-API-Error ». La valeur de cet entête et le code d’erreur renvoyé prendront la même valeur. Pour plus d’information, voyez [[mw:Special:MyLanguage/API:Errors_and_warnings|API:Errors and warnings]].\n\n

Test : Pour faciliter le test des requêtes à l’API, voyez [[Special:ApiSandbox]].

", "apihelp-main-param-action": "Quelle action effectuer.", "apihelp-main-param-format": "Le format de sortie.", - "apihelp-main-param-maxlag": "La latence maximale peut être utilisée quand MediaWiki est installé sur un cluster de base de données répliqué. Pour éviter des actions provoquant un supplément de latence de réplication de site, ce paramètre peut faire attendre le client jusqu’à ce que la latence de réplication soit inférieure à une valeur spécifiée. En cas de latence excessive, le code d’erreur maxlag est renvoyé avec un message tel que Attente de $host : $lag secondes de délai.
Voyez [[mw:Special:MyLanguage/Manual:Maxlag_parameter|Manuel: paramètre Maxlag]] pour plus d’information.", + "apihelp-main-param-maxlag": "La latence maximale peut être utilisée quand MediaWiki est installé sur une grappe de réplication de base de données. Pour éviter des actions provoquant un supplément de latence de réplication de site, ce paramètre peut faire attendre le client jusqu’à ce que la latence de réplication soit inférieure à une valeur spécifiée. En cas de latence excessive, le code d’erreur maxlag est renvoyé avec un message tel que Attente de $host : $lag secondes de délai.
Voyez [[mw:Special:MyLanguage/Manual:Maxlag_parameter|Manuel : paramètre Maxlag]] pour plus d’informations.", "apihelp-main-param-smaxage": "Fixer l’entête HTTP de contrôle de cache s-maxage à ce nombre de secondes. Les erreurs ne sont jamais mises en cache.", "apihelp-main-param-maxage": "Fixer l’entête HTTP de contrôle de cache max-age à ce nombre de secondes. Les erreurs ne sont jamais mises en cache.", - "apihelp-main-param-assert": "Vérifier si l’utilisateur est connecté si la valeur est user, ou s’il a le droit d’un utilisateur robot si la valeur est bot.", + "apihelp-main-param-assert": "Vérifier que l’utilisateur est connecté lorsque la valeur est user ou qu’il a le droit d’un utilisateur robot lorsque la valeur est bot.", "apihelp-main-param-assertuser": "Vérifier que l’utilisateur actuel est l’utilisateur nommé.", "apihelp-main-param-requestid": "Toute valeur fournie ici sera incluse dans la réponse. Peut être utilisé pour distinguer des demandes.", "apihelp-main-param-servedby": "Inclure le nom d’hôte qui a renvoyé la requête dans les résultats.", @@ -1630,8 +1630,10 @@ "apierror-cantoverwrite-sharedfile": "Le fichier cible existe dans un dépôt partagé et vous n’avez pas le droit de l’écraser.", "apierror-cantsend": "Vous n’êtes pas connecté, vous n’avez pas d’adresse de courriel confirmée, ou vous n’êtes pas autorisé à envoyer des courriels aux autres utilisateurs, donc vous ne pouvez envoyer de courriel.", "apierror-cantundelete": "Impossible d’annuler : les révisions demandées peuvent ne plus exister, ou avoir déjà été annulées.", + "apierror-cantview-deleted-comment": "Vous n’avez pas la permission de visualiser les commentaires supprimés.", "apierror-cantview-deleted-description": "Vous n’avez pas le droit d’afficher les descriptions des fichiers supprimés.", "apierror-cantview-deleted-metadata": "Vous n’avez pas le droit d’afficher les métadonnées des fichiers supprimés.", + "apierror-cantview-deleted-revision-content": "Vous n’avez pas la permission de visualiser le contenu des révisions supprimées.", "apierror-changeauth-norequest": "Échec à la création de la requête de modification.", "apierror-chunk-too-small": "La taille minimale d’un segment est de $1 {{PLURAL:$1|octet|octets}} pour les segments hors le dernier.", "apierror-cidrtoobroad": "Les plages CIDR $1 plus large que /$2 ne sont pas acceptées.", diff --git a/includes/api/i18n/gl.json b/includes/api/i18n/gl.json index cb4cd81d5b..f6076b4d52 100644 --- a/includes/api/i18n/gl.json +++ b/includes/api/i18n/gl.json @@ -47,6 +47,9 @@ "apihelp-block-param-reblock": "Se o usuario xa está bloqueado, sobreescribir o bloqueo existente.", "apihelp-block-param-watchuser": "Vixiar a páxina de usuario ou direccións IP e a de conversa deste usuario", "apihelp-block-param-tags": "Cambiar as etiquetas a aplicar á entrada no rexistro de bloqueos.", + "apihelp-block-param-partial": "Bloquear a un usuario en determinadas páxinas ou espazos de nomes no canto de todo o sitio.", + "apihelp-block-param-pagerestrictions": "Lista de títulos que o bloqueo impedirá editar ó usuario. Só se aplica cando partial (parcial) está definido como 'true' (verdadeiro).", + "apihelp-block-param-namespacerestrictions": "Lista de identificadores de espazos de nomes que o bloqueo impedirá que edite o usuario. Só se aplica cando partial (parcial) está definido como 'true' (verdadeiro).", "apihelp-block-example-ip-simple": "Bloquear dirección IP 192.0.2.5 durante tres días coa razón Primeiro aviso.", "apihelp-block-example-user-complex": "Bloquear indefinidamente ó usuario Vandal coa razón Vandalism, e impedir a creación de novas contas e envío de correos electrónicos.", "apihelp-changeauthenticationdata-summary": "Cambiar os datos de autenticación do usuario actual.", diff --git a/includes/api/i18n/he.json b/includes/api/i18n/he.json index e2c5fe7761..e7cf3d4f5e 100644 --- a/includes/api/i18n/he.json +++ b/includes/api/i18n/he.json @@ -418,6 +418,7 @@ "apihelp-query-param-indexpageids": "לכלול פסקת pageids נוספת עם רשימת כל מזהי הדף שהוחזרו.", "apihelp-query-param-export": "יצוא הגרסאות הנוכחיות של כל הדפים הנתונים המחוללים.", "apihelp-query-param-exportnowrap": "להחזיר את ה־XML של היצוא בלי לעטוף אותו בתוצאת XML (אותו תסדיר כמו [[Special:Export]]). אפשר להשתמש בזה רק עם $1export.", + "apihelp-query-param-exportschema": "להשתמש בגרסה הנתונה של תסדיר היטל XML בעת היצוא. יכול לשמש רק עם $1export.", "apihelp-query-param-iwurl": "האם לקבל את ה־URL המלא אם הכותרת היא קישור בינוויקי.", "apihelp-query-param-rawcontinue": "להחזיר נתוני query-continue גולמיים להמשך.", "apihelp-query-example-revisions": "אחזור [[Special:ApiHelp/query+siteinfo|site info]] ו־[[Special:ApiHelp/query+revisions|revisions]] של Main Page.", @@ -913,9 +914,20 @@ "apihelp-query+langlinks-param-inlanguagecode": "קוד שפה בשביל שמות שפות מתורגמות.", "apihelp-query+langlinks-example-simple": "קבלת קישורים בין־לשוניים מהדף Main Page.", "apihelp-query+languageinfo-summary": "מחזירה מידע על שפות זמינות.", + "apihelp-query+languageinfo-extended-description": "אפשר להחיל [[mw:API:Query#Continuing queries|המשך]] אם אחזור המידע לוקח יותר מדי זמן בשביל בקשה אחת.", "apihelp-query+languageinfo-param-prop": "איזה מידע לקבל עבור כל שפה.", + "apihelp-query+languageinfo-paramvalue-prop-code": "קוד השפה. (הקוד הזה ייחודי למדיה־ויקי, אם כי יש חפיפה עם תקנים אחרים.)", + "apihelp-query+languageinfo-paramvalue-prop-bcp47": "קוד שפת לפי BCP-47.", "apihelp-query+languageinfo-paramvalue-prop-dir": "כיוון הכתיבה של השפה (ltr או rtl).", + "apihelp-query+languageinfo-paramvalue-prop-autonym": "השם העצמי של השפה, כלומר השם באותה השפה.", + "apihelp-query+languageinfo-paramvalue-prop-name": "השם בשפה בשפה שצוינה בפרמטר uselang, עם שפת גיבוי כשזה נחוץ.", + "apihelp-query+languageinfo-paramvalue-prop-fallbacks": "קודי השפה של שפות הגיבוי שמוגדרים עבור השפה הזאת. הגיבוי המשתמע הסופי ל־\"en\" אינו כלול (אבל שפות אחדות יכולות להיות מגובות ב־\"en\" במפורש).", + "apihelp-query+languageinfo-paramvalue-prop-variants": "קודי השפה של ההגוונים שהשפה הזאת תומכת בהם.", + "apihelp-query+languageinfo-param-code": "קודי השפה של השפות שאמורות להיות מוחזרות, או * כדי לקבל את כל השפות.", "apihelp-query+languageinfo-example-simple": "קבלת קודי שפה של כל השפות הנתמכות.", + "apihelp-query+languageinfo-example-autonym-name-de": "קבלת השמות העצמיים והשמות הגרמניים של כל השפות הנתמכות.", + "apihelp-query+languageinfo-example-fallbacks-variants-oc": "קבלת שפות הגיבוי וההגוונים של אוקסיטנית.", + "apihelp-query+languageinfo-example-bcp47-dir": "קבלת קודי שפה ב־BCP-47 וכיוון עבור כל השפות הנתמכות.", "apihelp-query+links-summary": "החזרת כל הקישורים מהדפים שצוינו.", "apihelp-query+links-param-namespace": "להציג קישורים רק במרחבי השם האלה.", "apihelp-query+links-param-limit": "כמה קישורים להחזיר.", @@ -1510,7 +1522,7 @@ "api-help-param-templated-var-first": "יש להחליף את הטקסט {$1} (בשם הפרמטר) עם הערכים של הפרמטר $2", "api-help-param-templated-var": "{$1} עם הערכים של הפרמטר $2", "api-help-datatypes-header": "סוגי נתונים", - "api-help-datatypes": "קלט למדיה־ויקי צריך להיות בקידוד UTF-8 מנורמל ב־NFC. מדיה־ויקי יכולה לנסות להמיר קלט אחר, אבל זה עלול לגרום לפעולות מסוימות (כגון [[Special:ApiHelp/edit|עריכות]] עם בדיקות MD5) להיכשל.\n\nחלק מסוגי הפרמטרים בבקשות API דורשים הסבר נוסף:\n;בוליאני (boolean)\n:פרמטרים בוליאניים עובדים כמו תיבות סימון של HTML: אם הפרמטר צוין, בלי קשר לערך שלו, הוא אמת (true). בשביל ערך שקר (false), יש להשמיט את הפרמטר לגמרי.\n;חותם־זמן (timestamp)\n:אפשר לכתוב חותמי־זמן במספר תסדירים. תאריך ושעה לפי ISO 8601 הוא הדבר המומלת. כל הזמנים מצוינים ב־ UTC, לא תהיה השפעה לשום אזור זמן שיצוין.\n:* תאריך ושעה לפי ISO 8601‏, 2001-01-15T14:56:00Z (לא חובה לכתוב פיסוק ו־Z)\n:* תאריך ושעה לפי ISO 8601 עם חלקי שנייה (שלא תהיה להם שום השפעה), 2001-01-15T14:56:00.00001Z (לא חובה לכתוב קווים מפרידים, נקודתיים ו־Z)\n:* תסדיר MediaWiki‏, 20010115145600\n:* תסדיר מספרי כללי, 2001-01-15 14:56:00 (לאזור זמן אופציונלי של GMT‏, +##, או -## אין השפעה)\n:* תסדיר EXIF‏, 2001:01:15 14:56:00\n:* תסדיר RFC 2822 (אפשר להשמיט את אזור הזמן), Mon, 15 Jan 2001 14:56:00\n:* תסדיר RFC 850 (אפשר להשמיט את אזור הזמן), Monday, 15-Jan-2001 14:56:00\n:* תסדיר C ctime‏, Mon Jan 15 14:56:00 2001\n:* שניות מאז 1970-01-01T00:00:00Z בתור מספר שלך בין 1 ל־13 (לא כולל 0)\n:* המחרוזת now\n;מפריד ערכים מרובים חלופי\n:פרמטרים שלוקחים ערכים מרובים בדרך־כלל נשלחים עם הערכים מופרדים באמצעות תו מקל, למשל param=value1|value2 או param=value1%7Cvalue2. אם הערך צריך להכיל את תו המקל, יש להשתמש ב־U+001F (מפריד יחידות) בתור המפריד ''וגם'' להוסיף לתחילת הערך U+001F, למשל param=%1Fvalue1%1Fvalue2.", + "api-help-datatypes": "קלט למדיה־ויקי צריך להיות בקידוד UTF-8 מנורמל ב־NFC. מדיה־ויקי יכולה לנסות להמיר קלט אחר, אבל זה עלול לגרום לפעולות מסוימות (כגון [[Special:ApiHelp/edit|עריכות]] עם בדיקות MD5) להיכשל.\n\nחלק מסוגי הפרמטרים בבקשות API דורשים הסבר נוסף:\n;בוליאני (boolean)\n:פרמטרים בוליאניים עובדים כמו תיבות סימון של HTML: אם הפרמטר צוין, בלי קשר לערך שלו, הוא אמת (true). בשביל ערך שקר (false), יש להשמיט את הפרמטר לגמרי.\n;חותם־זמן (timestamp)\n:אפשר לכתוב חותמי־זמן במספר תסדירים, ר' את [[mw:Special:MyLanguage/Timestamp|תיעוד תסדירי הקלט של ספריית Timestamp באתר mediawiki.org]] לפרטים. תאריך ושעה לפי ISO 8601 הוא הדבר המומלץ: 2001-01-15T14:56:00Z. בנוסף, המחרוזת now יכולה לשמש לציון חום־הזמן הנוכחי.\n;מפריד ערכים מרובים חלופי\n:פרמטרים שלוקחים ערכים מרובים בדרך־כלל נשלחים עם הערכים מופרדים באמצעות תו מקל, למשל param=value1|value2 או param=value1%7Cvalue2. אם הערך צריך להכיל את תו המקל, יש להשתמש ב־U+001F (מפריד יחידות) בתור המפריד ''וגם'' להוסיף לתחילת הערך U+001F, למשל param=%1Fvalue1%1Fvalue2.", "api-help-templatedparams-header": "פרמטרים בתבניות", "api-help-templatedparams": "התכונה \"פרמטרים בתבניות\" תומכת במקרים שבהם מודול של API זקוק לערך כלשהו עבור ערכים של פרמטרים אחרים. למשל, אם היה מודול API לבקשת פרי, ייתכן שהוא היה זקוק לפרמטר בשם פירות על־מנת לציין מהם הפירות המבוקשים, ולפרמטר בתבנית בשם {פרי}-כמות על־מנת לציין את הכמות של כל פרי עבור הבקשה. לשם כך, לקוח API שמעוניין לקבל תפוח אחד, 5 בננות ו־20 תותים יכול היה ליצור בקשה בסגנון פירות=תפוחים|בננות|תותים&תפוחים-כמות=1&בננות-כמות=5&תותים-כמות=20.", "api-help-param-type-limit": "סוג: מספר שלם או max", @@ -1601,6 +1613,10 @@ "apierror-cantoverwrite-sharedfile": "קובץ היעד קיים במאגר משותף ואין לך הרשאה לעקוף אותו.", "apierror-cantsend": "לא נכנסת לחשבון, אין לך חשבון דואר אלקטרוני מאושר, או שאסור לך לשלוח דואר אלקטרוני למשתמשים אחרים, ולכן אין לך אפשרות לשלוח דואר אלקטרוני.", "apierror-cantundelete": "לא היה אפשר לשחזר ממחיקה: אולי הגרסאות המבוקשות אינן קיימות, ואולי הן כבר נמחקו.", + "apierror-cantview-deleted-comment": "אין לך הרשאה לצפות בהערות מחוקות.", + "apierror-cantview-deleted-description": "אין לך הרשאה לצפות בתיאורים של קבצים מחוקים.", + "apierror-cantview-deleted-metadata": "אין לך הרשאה לצפות במטא־נתונים של קבצים מחוקים.", + "apierror-cantview-deleted-revision-content": "אין לך הרשאה לצפות בתוכן של גרסאות מחוקות.", "apierror-changeauth-norequest": "יצירת בקשת השינוי נכשלה.", "apierror-chunk-too-small": "גודל הפלח המזערי הוא {{PLURAL:$1|בית אחד|$1 בתים}} בשביל פלחים לא סופיים.", "apierror-cidrtoobroad": "טווחי CIDR של $1 שרחבים יותר מ־/$2 אינם קבילים.", @@ -1780,6 +1796,7 @@ "apiwarn-deprecation-missingparam": "מכיוון שלא צוין $1, ישמש תסדיר ישן לפלט. התסדיר הזה מוכרז בתור מיושן, ובעתיד ישמש רק התסדיר החדש.", "apiwarn-deprecation-parameter": "הפרמטר $1 מיושן.", "apiwarn-deprecation-parse-headitems": "prop=headitems מיושן מאז מדיה־ויקי 1.28. יש להשתמש ב־prop=headhtml בעת יצירת מסמכי HTML חדשים, או ב־prop=modules|jsconfigvars בעת עדכון מסמך בצד הלקוח.", + "apiwarn-deprecation-post-without-content-type": "בקשת POST נעשתה ללא כותר Content-Type. זה לא עובד באופן מהימן.", "apiwarn-deprecation-purge-get": "שימוש ב־action=purge דרך GET מיושן. יש להשתמש ב־POST במקום זה.", "apiwarn-deprecation-withreplacement": "$1 מיושן. יש להשתמש ב־$2 במקום זה.", "apiwarn-difftohidden": "לא היה אפשר לעשות השוואה עם גרסה $1: התוכן מוסתר.", diff --git a/includes/api/i18n/it.json b/includes/api/i18n/it.json index e29c34af24..9d5d349ef9 100644 --- a/includes/api/i18n/it.json +++ b/includes/api/i18n/it.json @@ -684,6 +684,9 @@ "api-help-authmanagerhelper-continue": "Questa richiesta è una continuazione dopo una precedente risposta UI o REDIRECT. È necessario fornirlo, oppure fornire $1returnurl.", "api-help-authmanagerhelper-additional-params": "Questo modulo accetta parametri aggiuntivi a seconda delle richieste di autenticazione disponibili. Utilizza [[Special:ApiHelp/query+authmanagerinfo|action=query&meta=authmanagerinfo]] con amirequestsfor=$1 (o una precedente risposta da questo modulo, se applicabile) per determinare le richieste disponibili e i campi usati da queste.", "apierror-bad-badfilecontexttitle": "Titolo non valido nel parametro $1badfilecontexttitle.", + "apierror-cantview-deleted-description": "Non si dispone dei permessi necessari per vedere le descrizioni dei file cancellati.", + "apierror-cantview-deleted-metadata": "Non si dispone dei permessi necessari per vedere i metadati dei file cancellati.", + "apierror-cantview-deleted-revision-content": "Non si dispone dei permessi necessari per vedere il contenuto delle versioni cancellate.", "apierror-compare-notext": "Il parametro $1 non può essere usato senza $2.", "apierror-invalidoldimage": "Il parametro oldimage ha un formato non valido.", "apierror-invaliduserid": "L'ID utente $1 non è valido.", diff --git a/includes/api/i18n/ko.json b/includes/api/i18n/ko.json index c02963643e..6f390f992c 100644 --- a/includes/api/i18n/ko.json +++ b/includes/api/i18n/ko.json @@ -16,7 +16,8 @@ "Jonghaya", "Jerrykim306", "코코아", - "Macofe" + "Macofe", + "렌즈" ] }, "apihelp-main-extended-description": "
\n* [[mw:Special:MyLanguage/API:Main_page|설명문서]]\n* [[mw:Special:MyLanguage/API:FAQ|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상태: 이 페이지에 보이는 모든 기능은 정상적으로 작동하지만, API는 여전히 활발하게 개발되고 있으며, 언제든지 변경될 수 있습니다. 업데이트 공지를 받아보려면 [https://lists.wikimedia.org/pipermail/mediawiki-api-announce/ mediawiki-api-announce 메일링 리스트]를 구독하십시오.\n\n잘못된 요청: API에 잘못된 요청이 전송되면 \"MediaWiki-API-Error\" 키가 포함된 HTTP 헤더가 전송되며 반환되는 헤더와 오류 코드의 값은 모두 동일한 값으로 설정됩니다. 자세한 정보에 대해서는 [[mw:Special:MyLanguage/API:Errors and warnings/ko|API:오류와 경고]]를 참조하십시오.\n\n테스트하기: API 요청 테스트를 용이하게 하려면, [[Special:ApiSandbox]]를 보십시오.", @@ -99,7 +100,7 @@ "apihelp-compare-paramvalue-prop-title": "'from'과 'to' 판의 문서 제목입니다.", "apihelp-compare-paramvalue-prop-user": "'from'과 'to' 판의 사용자 이름과 ID입니다.", "apihelp-compare-paramvalue-prop-comment": "'from'과 'to' 판의 설명입니다.", - "apihelp-compare-paramvalue-prop-parsedcomment": "'from'과 to' 판의 구문 분석된 설명입니다.", + "apihelp-compare-paramvalue-prop-parsedcomment": "'from'과 to' 판의 변환된 설명입니다.", "apihelp-compare-paramvalue-prop-size": "'from'과 'to' 판의 크기입니다.", "apihelp-compare-example-1": "판 1과 2의 차이를 생성합니다.", "apihelp-createaccount-summary": "새 사용자 계정을 만듭니다.", @@ -256,39 +257,39 @@ "apihelp-options-example-complex": "모든 환경 설정을 초기화하고 skin과 nickname을 설정합니다.", "apihelp-paraminfo-summary": "API 모듈의 정보를 가져옵니다.", "apihelp-paraminfo-param-helpformat": "도움말 문자열 포맷.", - "apihelp-parse-summary": "내용의 구문을 분석하고 파서 출력을 반환합니다.", - "apihelp-parse-param-summary": "구문 분석할 요약입니다.", - "apihelp-parse-paramvalue-prop-text": "위키텍스트의 구문 분석된 텍스트를 제공합니다.", - "apihelp-parse-paramvalue-prop-langlinks": "구문 분석된 위키텍스트의 언어 링크를 제공합니다.", - "apihelp-parse-paramvalue-prop-categories": "구문 분석된 위키텍스트의 분류를 제공합니다.", + "apihelp-parse-summary": "내용을 변환하고 출력을 반환합니다.", + "apihelp-parse-param-summary": "변환할 요약입니다.", + "apihelp-parse-paramvalue-prop-text": "위키텍스트로 변환된 텍스트를 제공합니다.", + "apihelp-parse-paramvalue-prop-langlinks": "언어 링크를 위키텍스트로 변환하여 제공합니다.", + "apihelp-parse-paramvalue-prop-categories": "분류를 변환된 위키텍스트로 제공합니다.", "apihelp-parse-paramvalue-prop-categorieshtml": "분류의 HTML 버전을 제공합니다.", - "apihelp-parse-paramvalue-prop-links": "구문 분석된 위키텍스트의 내부 링크를 제공합니다.", - "apihelp-parse-paramvalue-prop-templates": "구문 분석된 위키텍스트의 틀을 제공합니다.", - "apihelp-parse-paramvalue-prop-images": "구문 분석된 위키텍스트의 그림을 제공합니다.", - "apihelp-parse-paramvalue-prop-externallinks": "구문 분석된 위키텍스트의 외부 링크를 제공합니다.", - "apihelp-parse-paramvalue-prop-sections": "구문 분석된 위키텍스트의 문단을 제공합니다.", - "apihelp-parse-paramvalue-prop-revid": "구문 분석된 페이지의 판 ID를 추가합니다.", - "apihelp-parse-paramvalue-prop-displaytitle": "구문 분석된 위키텍스트의 제목을 추가합니다.", + "apihelp-parse-paramvalue-prop-links": "내부 링크를 위키텍스트로 변환하여 제공합니다.", + "apihelp-parse-paramvalue-prop-templates": "틀을 변환된 위키텍스트로 제공합니다.", + "apihelp-parse-paramvalue-prop-images": "그림을 위키텍스트로 변환하여 제공합니다.", + "apihelp-parse-paramvalue-prop-externallinks": "외부 링크를 위키텍스트로 변환하여 제공합니다.", + "apihelp-parse-paramvalue-prop-sections": "문단을 변환된 위키텍스트로 제공합니다.", + "apihelp-parse-paramvalue-prop-revid": "변환할 페이지의 판 ID를 추가합니다.", + "apihelp-parse-paramvalue-prop-displaytitle": "제목을 변환된 위키텍스트로 추가합니다.", "apihelp-parse-paramvalue-prop-headitems": "문서의 <head> 안에 넣을 항목을 제공합니다.", - "apihelp-parse-paramvalue-prop-headhtml": "문서의 구문 분석된 <head>를 제공합니다.", + "apihelp-parse-paramvalue-prop-headhtml": "문서의 파싱된 doctype, 여는 <html>, <head>, <body>를 제공합니다.", "apihelp-parse-paramvalue-prop-modules": "문서에 사용되는 ResourceLoader 모듈을 제공합니다. 불러오려면, mw.loader.using()을 사용하세요. jsconfigvars 또는 encodedjsconfigvars는 modules와 함께 요청해야 합니다.", "apihelp-parse-paramvalue-prop-jsconfigvars": "문서에 특화된 자바스크립트 구성 변수를 제공합니다. 적용하려면 mw.config.set()을 사용하세요.", - "apihelp-parse-paramvalue-prop-iwlinks": "구문 분석된 위키텍스트의 인터위키 링크를 제공합니다.", - "apihelp-parse-paramvalue-prop-wikitext": "구문 분석된 위키텍스트 원문을 제공합니다.", - "apihelp-parse-paramvalue-prop-properties": "구문 분석된 위키텍스트에 정의된 다양한 속성을 제공합니다.", - "apihelp-parse-param-pst": "구문 분석 이전에 입력에 대한 사전 저장 변환을 수행합니다. 텍스트로 사용할 때에만 유효합니다.", + "apihelp-parse-paramvalue-prop-iwlinks": "인터위키 링크를 위키텍스트로 변환하여 제공합니다.", + "apihelp-parse-paramvalue-prop-wikitext": "변환한 원문 위키텍스트를 제공합니다.", + "apihelp-parse-paramvalue-prop-properties": "정의된 다양한 속성을 변환된 위키텍스트로 제공합니다.", + "apihelp-parse-param-pst": "파싱에 앞서 입력에 대한 저장 직전의 변환을 수행합니다. 텍스트로 사용할 때에만 유효합니다.", "apihelp-parse-param-disablelimitreport": "파서 출력에서 제한 보고서(\"NewPP limit report\")를 제외합니다.", "apihelp-parse-param-disablepp": "$1disablelimitreport를 대신 사용합니다.", "apihelp-parse-param-disableeditsection": "파서 출력에서 문단 편집 링크를 제외합니다.", "apihelp-parse-param-disabletidy": "파서 출력에서 HTML 정리(예: tidy)를 수행하지 않습니다.", - "apihelp-parse-param-preview": "미리 보기 모드에서 구문 분석을 합니다.", - "apihelp-parse-param-sectionpreview": "문단 미리 보기 모드에서 구문 분석을 합니다. (미리 보기 모드도 활성화함)", + "apihelp-parse-param-preview": "미리 보기 모드에서 파싱합니다.", + "apihelp-parse-param-sectionpreview": "문단 미리 보기 모드에서 파싱합니다. (미리 보기 모드도 활성화함)", "apihelp-parse-param-disabletoc": "출력에서 목차를 제외합니다.", "apihelp-parse-param-useskin": "선택한 스킨을 파서 출력에 적용합니다. 다음의 속성에 영향을 줄 수 있습니다: langlinks, headitems, modules, jsconfigvars, indicators.", "apihelp-parse-param-contentformat": "입력 텍스트에 사용할 내용 직렬화 포맷입니다. $1text와 함께 사용할 때에만 유효합니다.", - "apihelp-parse-example-page": "페이지의 구문을 분석합니다.", + "apihelp-parse-example-page": "페이지를 파싱합니다.", "apihelp-parse-example-text": "위키텍스트의 구문을 분석합니다.", - "apihelp-parse-example-summary": "요약을 구문 분석합니다.", + "apihelp-parse-example-summary": "요약을 변환합니다.", "apihelp-patrol-summary": "문서나 판을 점검하기.", "apihelp-patrol-param-rcid": "점검할 최근 바뀜 ID입니다.", "apihelp-patrol-param-revid": "점검할 판 ID입니다.", @@ -438,7 +439,7 @@ "apihelp-query+imageinfo-summary": "파일 정보와 업로드 역사를 반환합니다.", "apihelp-query+imageinfo-param-prop": "가져올 파일 정보입니다:", "apihelp-query+imageinfo-paramvalue-prop-timestamp": "업로드된 판에 대한 타임스탬프를 추가합니다.", - "apihelp-query+imageinfo-paramvalue-prop-parsedcomment": "판의 설명을 구문 분석합니다.", + "apihelp-query+imageinfo-paramvalue-prop-parsedcomment": "판의 설명을 변환합니다.", "apihelp-query+imageinfo-paramvalue-prop-sha1": "파일에 대한 SHA-1 해시를 추가합니다.", "apihelp-query+imageinfo-paramvalue-prop-mediatype": "파일의 미디어 유형을 추가합니다.", "apihelp-query+imageinfo-param-urlheight": "$1urlwidth와 유사합니다.", @@ -523,7 +524,7 @@ "apihelp-query+revisions+base-paramvalue-prop-contentmodel": "판의 콘텐츠 모델 ID.", "apihelp-query+revisions+base-paramvalue-prop-content": "판의 텍스트.", "apihelp-query+revisions+base-paramvalue-prop-tags": "판의 태그.", - "apihelp-query+revisions+base-param-parse": "[[Special:ApiHelp/parse|action=parse]]를 대신 사용합니다. 판 내용의 구문을 분석합니다. ($1prop=content 필요) 성능 상의 이유로 이 옵션을 사용할 경우 $1limit은 1로 강제됩니다.", + "apihelp-query+revisions+base-param-parse": "[[Special:ApiHelp/parse|action=parse]]를 대신 사용하세요. 판 내용을 파싱합니다. ($1prop=content 필요) 성능 상의 이유로 이 옵션을 사용할 경우 $1limit은 1로 강제됩니다.", "apihelp-query+search-summary": "전문 검색을 수행합니다.", "apihelp-query+search-param-qiprofile": "쿼리 독립적인 프로파일 사용(순위 알고리즘에 영향있음)", "apihelp-query+search-paramvalue-prop-size": "바이트 단위로 문서의 크기를 추가합니다.", @@ -845,6 +846,9 @@ "apierror-cantimport-upload": "업로드된 페이지를 가져올 권한이 없습니다.", "apierror-cantimport": "페이지를 가져올 권한이 없습니다.", "apierror-cantsend": "로그인하지 않았거나 인증된 이메일 주소가 없거나 다른 사용자로 이메일을 보낼 권한이 없기 때문에 이메일을 보낼 수 없습니다.", + "apierror-cantview-deleted-description": "삭제된 파일의 설명을 볼 권한이 없습니다.", + "apierror-cantview-deleted-metadata": "삭제된 파일의 메타데이터를 볼 권한이 없습니다.", + "apierror-cantview-deleted-revision-content": "삭제된 판의 내용을 볼 권한이 없습니다.", "apierror-compare-maintextrequired": "$1slots에 main이 포함되어 있다면 $1text-main 변수는 필수입니다. (메인 슬롯을 삭제할 수 없습니다)", "apierror-compare-notext": "$1 변수는 $2 없이 사용할 수 없습니다.", "apierror-emptynewsection": "비어있는 새 문단을 만들 수 없습니다.", diff --git a/includes/api/i18n/lt.json b/includes/api/i18n/lt.json index 907be26912..51350a176a 100644 --- a/includes/api/i18n/lt.json +++ b/includes/api/i18n/lt.json @@ -3,7 +3,8 @@ "authors": [ "Zygimantus", "Eitvys200", - "Hugo.arg" + "Hugo.arg", + "Homo" ] }, "apihelp-main-param-action": "Kurį veiksmą atlikti.", @@ -19,7 +20,7 @@ "apihelp-createaccount-summary": "Kurti naują vartotojo paskyrą.", "apihelp-delete-summary": "Ištrinti puslapį.", "apihelp-delete-param-watch": "Pridėti puslapį prie dabartinio vartotojo stebimųjų sąrašo.", - "apihelp-delete-param-unwatch": "Pašalinti puslapį iš dabartinio vartotojo stebimųjų sąrašo.", + "apihelp-delete-param-unwatch": "Pašalinti puslapį iš dabartinio naudotojo stebimųjų sąrašo.", "apihelp-delete-example-simple": "Ištrinti Main Page.", "apihelp-delete-example-reason": "Ištrinti Main Page su priežastimi Preparing for move.", "apihelp-disabled-summary": "Šis modulis buvo išjungtas.", @@ -36,7 +37,7 @@ "apihelp-edit-param-createonly": "Neredaguoti puslapio jei jis jau egzistuoja.", "apihelp-edit-param-nocreate": "Parodyti klaidą, jei puslapis neegzistuoja.", "apihelp-edit-param-watch": "Pridėti puslapį į dabartinio vartotojo stebimųjų sąrašą.", - "apihelp-edit-param-unwatch": "Pašalinti puslapį iš dabartinio vartotojo stebimųjų sąrašo.", + "apihelp-edit-param-unwatch": "Pašalinti puslapį iš dabartinio naudotojo stebimųjų sąrašo.", "apihelp-edit-param-redirect": "Automatiškai išspręsti peradresavimus.", "apihelp-edit-param-contentmodel": "Naujam turiniui taikomas turinio modelis.", "apihelp-edit-example-edit": "Redaguoti puslapį.", @@ -104,7 +105,7 @@ "apihelp-move-param-movetalk": "Pervadinti aptarimo puslapį, jei jis egzistuoja.", "apihelp-move-param-noredirect": "Nekurti nukreipimo.", "apihelp-move-param-watch": "Pridėti puslapį ir nukreipimą į dabartinio vartotojo stebimųjų sąrašą.", - "apihelp-move-param-unwatch": "Pašalinti puslapį ir nukreipimą iš dabartinio vartotojo stebimųjų sąrašo.", + "apihelp-move-param-unwatch": "Pašalinti puslapį ir nukreipimą iš dabartinio naudotojo stebimųjų sąrašo.", "apihelp-move-param-ignorewarnings": "Ignuoruoti bet kokius įspėjimus.", "apihelp-move-example-move": "Perkelti Badtitle į Goodtitle nepaliekant nukreipimo.", "apihelp-opensearch-summary": "Ieškoti viki naudojant OpenSearch protokolą.", @@ -301,7 +302,7 @@ "apihelp-query+watchlist-paramvalue-type-new": "Puslapio sukūrimai.", "apihelp-query+watchlist-paramvalue-type-log": "Žurnalo įrašai.", "apihelp-resetpassword-param-user": "Iš naujo nustatomas vartotojas.", - "apihelp-resetpassword-param-email": "Iš naujo nustatomo vartotojo el. pašto adresas.", + "apihelp-resetpassword-param-email": "Iš naujo nustatomo naudotojo el. pašto adresas.", "apihelp-setpagelanguage-summary": "Keisti puslapio kalbą.", "apihelp-setpagelanguage-param-reason": "Keitimo priežastis.", "apihelp-stashedit-param-title": "Puslapio pavadinimas buvo redaguotas.", diff --git a/includes/api/i18n/mk.json b/includes/api/i18n/mk.json index 59553e92d4..f72c344fb9 100644 --- a/includes/api/i18n/mk.json +++ b/includes/api/i18n/mk.json @@ -73,7 +73,7 @@ "apihelp-edit-param-summary": "Опис на уредувањето. Ова е и назив на поднасловот кога не се зададени $1section=new и $1sectiontitle.", "apihelp-edit-param-tags": "Ознаки за измена што се однесуваат на преработката.", "apihelp-edit-param-minor": "Означи го уредувањево како ситно.", - "apihelp-edit-param-notminor": "Неситно уредување.", + "apihelp-edit-param-notminor": "Да не се одбележува ова уредување како ситно дури и при поставена корисничката поставка „{{int:tog-minordefаult}}“.", "apihelp-edit-param-bot": "Означи го уредувањето како ботовско.", "apihelp-edit-param-basetimestamp": "Датум и време на преработката на базата, кои се користат за утврдување на спротиставености во уредувањето. Може да се добие преку [[Special:ApiHelp/query+revisions|action=query&prop=revisions&rvprop=timestamp]].", "apihelp-edit-param-starttimestamp": "Датум и време кога сте почнало уредувањето, кои се користат за утврдување на спротиставености во уредувањата. Соодветната вредност се добива користејќи [[Special:ApiHelp/main|curtimestamp]] кога ќе почнете со уредување (на пр. кога ќе се вчита содржината што ќе ја уредувате).", @@ -576,6 +576,10 @@ "apierror-cantchangecontentmodel": "Немате дозвола за менување содржинскиот модел на страница.", "apierror-cantimport-upload": "Немате дозвола да увезувате подигнати страници.", "apierror-cantimport": "Немате дозвола за увезуваање страници.", + "apierror-cantview-deleted-comment": "Немате дозвола за прегледување на избришаните коментари.", + "apierror-cantview-deleted-description": "Немате дозвола за прегледување описи на избришаните податотеки.", + "apierror-cantview-deleted-metadata": "Немате дозвола за прегледување метаподатоци на избришаните податотеки.", + "apierror-cantview-deleted-revision-content": "Немате дозвола за прегледување содржина на избришаните преработки.", "apierror-copyuploadbaddomain": "Подигањето преку URL не е дозволено од овој домен.", "apierror-copyuploadbadurl": "Подигањето не е дозволено од оваа URL-адреса.", "apierror-emptynewsection": "Создавањето на нови празни поднаслови не е дозволено.", diff --git a/includes/api/i18n/pl.json b/includes/api/i18n/pl.json index d8ff5398c1..65a091389c 100644 --- a/includes/api/i18n/pl.json +++ b/includes/api/i18n/pl.json @@ -659,8 +659,10 @@ "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-cantview-deleted-comment": "Nie masz uprawnień do podglądu usuniętych komentarzy.", "apierror-cantview-deleted-description": "Nie masz uprawnień do podglądu opisów usuniętych plików.", "apierror-cantview-deleted-metadata": "Nie masz uprawnień do podglądu metadanych usuniętych plików.", + "apierror-cantview-deleted-revision-content": "Nie masz uprawnień do podglądu treści usuniętych wersji.", "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 6e2c1f13c2..77f927dd8e 100644 --- a/includes/api/i18n/pt-br.json +++ b/includes/api/i18n/pt-br.json @@ -1610,6 +1610,10 @@ "apierror-cantoverwrite-sharedfile": "O arquivo de destino existe em um repositório compartilhado e você não tem permissão para substituí-lo.", "apierror-cantsend": "Você não está logado, não possui um endereço de e-mail confirmado ou não tem permissão para enviar e-mails para outros usuários, por isso não pode enviar e-mails.", "apierror-cantundelete": "Não foi possível recuperar arquivos: as revisões solicitadas podem não existir ou talvez já tenham sido eliminadas.", + "apierror-cantview-deleted-comment": "Você não tem permissão para visualizar comentários excluídos.", + "apierror-cantview-deleted-description": "Você não tem permissão para visualizar descrições de arquivos excluídos.", + "apierror-cantview-deleted-metadata": "Você não tem permissão para visualizar os metadados dos arquivos excluídos.", + "apierror-cantview-deleted-revision-content": "Você não tem permissão para visualizar o conteúdo das revisões excluídas.", "apierror-changeauth-norequest": "Falha ao criar pedido de mudança.", "apierror-chunk-too-small": "O tamanho mínimo do bloco é $1 {{PLURAL:$1|byte|bytes}} para os pedaços não finais.", "apierror-cidrtoobroad": "Os intervalos CIDR $1 maiores que /$2 não são aceitos.", diff --git a/includes/api/i18n/pt.json b/includes/api/i18n/pt.json index 8e31b51b18..0986c31b90 100644 --- a/includes/api/i18n/pt.json +++ b/includes/api/i18n/pt.json @@ -1605,6 +1605,10 @@ "apierror-cantoverwrite-sharedfile": "O ficheiro alvo existe num repositório partilhado e você não tem permissão para o substituir.", "apierror-cantsend": "Não está autenticado, não tem um endereço de correio eletrónico confirmado, ou não lhe é permitido enviar correio a outros utilizadores, por isso não pode enviar correios eletrónicos.", "apierror-cantundelete": "Não foi possível restaurar: as revisões solicitadas podem não existir ou podem já ter sido restauradas.", + "apierror-cantview-deleted-comment": "Não tem permissão para ver comentários eliminados.", + "apierror-cantview-deleted-description": "Não tem permissão para ver descrições de ficheiros eliminados.", + "apierror-cantview-deleted-metadata": "Não tem permissão para ver metadados de ficheiros eliminados.", + "apierror-cantview-deleted-revision-content": "Não tem permissão para ver o conteúdo de revisões eliminadas.", "apierror-changeauth-norequest": "A criação do pedido de modificação falhou.", "apierror-chunk-too-small": "O tamanho de segmento mínimo é $1 {{PLURAL:$1|byte|bytes}} para segmentos que não sejam segmentos finais.", "apierror-cidrtoobroad": "Não são aceites intervalos CIDR $1 maiores do que /$2.", diff --git a/includes/api/i18n/qqq.json b/includes/api/i18n/qqq.json index b648443729..25e7522f66 100644 --- a/includes/api/i18n/qqq.json +++ b/includes/api/i18n/qqq.json @@ -40,10 +40,10 @@ "apihelp-block-param-userid": "{{doc-apihelp-param|block|userid}}", "apihelp-block-param-expiry": "{{doc-apihelp-param|block|expiry}}\n{{doc-important|Do not translate \"5 months\", \"2 weeks\", \"infinite\", \"indefinite\" or \"never\"!}}", "apihelp-block-param-reason": "{{doc-apihelp-param|block|reason}}", - "apihelp-block-param-anononly": "{{doc-apihelp-param|block|anononly}}\n* See also {{msg-mw|ipb-hardblock}}", + "apihelp-block-param-anononly": "{{doc-apihelp-param|block|anononly}}\n\n* See also {{msg-mw|ipb-hardblock}}", "apihelp-block-param-nocreate": "{{doc-apihelp-param|block|nocreate}}\n* See also {{msg-mw|ipbcreateaccount}}", "apihelp-block-param-autoblock": "{{doc-singularthey}}\n{{doc-apihelp-param|block|autoblock}}\n* See also {{msg-mw|ipbenableautoblock}}", - "apihelp-block-param-noemail": "{{doc-apihelp-param|block|noemail}}\n* See also {{msg-mw|ipbemailban}}", + "apihelp-block-param-noemail": "{{doc-apihelp-param|block|noemail}}\n\n* See also {{msg-mw|ipbemailban}}", "apihelp-block-param-hidename": "{{doc-apihelp-param|block|hidename}}", "apihelp-block-param-allowusertalk": "{{doc-apihelp-param|block|allowusertalk}}\n* See also {{msg-mw|ipb-disableusertalk}}", "apihelp-block-param-reblock": "{{doc-apihelp-param|block|reblock}}", diff --git a/includes/api/i18n/ru.json b/includes/api/i18n/ru.json index 4d022047a8..3e5da0ad07 100644 --- a/includes/api/i18n/ru.json +++ b/includes/api/i18n/ru.json @@ -38,7 +38,8 @@ "Vlad5250", "Diralik", "DmitTrix", - "Марио" + "Марио", + "Katunchik" ] }, "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]].

", @@ -1589,6 +1590,10 @@ "apierror-cantoverwrite-sharedfile": "Целевой файл существует в общем репозитории и у вас нет прав перезаписать его.", "apierror-cantsend": "Вы не авторизованы, ваш электронный адрес не подтверждён или у вас нет прав на отправку электронной почты другим участникам, поэтому вы не можете отправить электронное письмо.", "apierror-cantundelete": "Невозможно восстановить: возможно, запрашиваемые версии не существуют или уже были восстановлены.", + "apierror-cantview-deleted-comment": "У вас нет разрешения на просмотр удаленных комментариев.", + "apierror-cantview-deleted-description": "У вас нет разрешения на просмотр описаний удаленных файлов.", + "apierror-cantview-deleted-metadata": "У вас нет разрешения на просмотр метаданных удаленных файлов.", + "apierror-cantview-deleted-revision-content": "У вас нет разрешения на просмотр содержимого удаленных редакций.", "apierror-changeauth-norequest": "Попытка создать запрос правки провалилась.", "apierror-chunk-too-small": "Минимальный размер кусочка — $1 {{PLURAL:$1|байт|байта|байт}}, если кусочек не является последним.", "apierror-cidrtoobroad": "Диапазоны $1 CIDR, шире /$2, не разрешены.", diff --git a/includes/api/i18n/zh-hant.json b/includes/api/i18n/zh-hant.json index 7ee3751ae0..cd5b4cebb7 100644 --- a/includes/api/i18n/zh-hant.json +++ b/includes/api/i18n/zh-hant.json @@ -1613,8 +1613,10 @@ "apierror-cantoverwrite-sharedfile": "目標檔案存在於分享儲存庫上,因此您沒有權限來覆蓋掉。", "apierror-cantsend": "您尚未登入,您沒有已確認的電子郵件地址,或是您未被允許發送電子郵件給其他人,因此您不能發送電子郵件。", "apierror-cantundelete": "無法取消刪除:請求的修訂可能不存在,或是可能已被取消刪除。", + "apierror-cantview-deleted-comment": "您沒有權限來檢視被刪除的註釋。", "apierror-cantview-deleted-description": "您沒有權限來檢視被刪除檔案的描述內容。", "apierror-cantview-deleted-metadata": "您沒有權限來檢視被刪除檔案的詮釋資料。", + "apierror-cantview-deleted-revision-content": "您沒有權限來檢視被刪除修訂的內容。", "apierror-changeauth-norequest": "建立更改請求失敗。", "apierror-chunk-too-small": "對於非最終塊,最小塊的大小為 $1 {{PLURAL:$1|位元組|位元組}}。", "apierror-cidrtoobroad": "不能接受超出 /$2 的 $1 CIDR 範圍。", diff --git a/includes/block/BlockManager.php b/includes/block/BlockManager.php index e27ebac7ef..077bdca7c8 100644 --- a/includes/block/BlockManager.php +++ b/includes/block/BlockManager.php @@ -29,6 +29,7 @@ use MediaWiki\Config\ServiceOptions; use MediaWiki\Permissions\PermissionManager; use MediaWiki\User\UserIdentity; use MWCryptHash; +use Psr\Log\LoggerInterface; use User; use WebRequest; use WebResponse; @@ -41,16 +42,12 @@ use Wikimedia\IPSet; * @since 1.34 Refactored from User and Block. */ class BlockManager { - // TODO: This should be UserIdentity instead of User - /** @var User */ - private $currentUser; - - /** @var WebRequest */ - private $currentRequest; - /** @var PermissionManager */ private $permissionManager; + /** @var ServiceOptions */ + private $options; + /** * TODO Make this a const when HHVM support is dropped (T192166) * @@ -69,23 +66,23 @@ class BlockManager { 'SoftBlockRanges', ]; + /** @var LoggerInterface */ + private $logger; + /** * @param ServiceOptions $options - * @param User $currentUser - * @param WebRequest $currentRequest * @param PermissionManager $permissionManager + * @param LoggerInterface $logger */ public function __construct( ServiceOptions $options, - User $currentUser, - WebRequest $currentRequest, - PermissionManager $permissionManager + PermissionManager $permissionManager, + LoggerInterface $logger ) { $options->assertRequiredOptions( self::$constructorOptions ); $this->options = $options; - $this->currentUser = $currentUser; - $this->currentRequest = $currentRequest; $this->permissionManager = $permissionManager; + $this->logger = $logger; } /** @@ -93,51 +90,116 @@ class BlockManager { * return a composite block that combines the strictest features of the applicable * blocks. * - * TODO: $user should be UserIdentity instead of User + * Different blocks may be sought, depending on the user and their permissions. The + * user may be: + * (1) The global user (and can be affected by IP blocks). The global request object + * is needed for checking the IP address, the XFF header and the cookies. + * (2) The global user (and exempt from IP blocks). The global request object is + * needed for checking the cookies. + * (3) Another user (not the global user). No request object is available or needed; + * just look for a block against the user account. + * + * Cases #1 and #2 check whether the global user is blocked in practice; the block + * may due to their user account being blocked or to an IP address block or cookie + * block (or multiple of these). Case #3 simply checks whether a user's account is + * blocked, and does not determine whether the person using that account is affected + * in practice by any IP address or cookie blocks. * * @internal This should only be called by User::getBlockedStatus * @param User $user + * @param WebRequest|null $request The global request object if the user is the + * global user (cases #1 and #2), otherwise null (case #3). The IP address and + * information from the request header are needed to find some types of blocks. * @param bool $fromReplica Whether to check the replica DB first. * To improve performance, non-critical checks are done against replica DBs. * Check when actually saving should be done against master. * @return AbstractBlock|null The most relevant block, or null if there is no block. */ - public function getUserBlock( User $user, $fromReplica ) { - $isAnon = $user->getId() === 0; + public function getUserBlock( User $user, $request, $fromReplica ) { $fromMaster = !$fromReplica; + $ip = null; - // TODO: If $user is the current user, we should use the current request. Otherwise, - // we should not look for XFF or cookie blocks. - $request = $user->getRequest(); + // If this is the global user, they may be affected by IP blocks (case #1), + // or they may be exempt (case #2). If affected, look for additional blocks + // against the IP address. + $checkIpBlocks = $request && + !$this->permissionManager->userHasRight( $user, 'ipblock-exempt' ); - # We only need to worry about passing the IP address to the block generator if the - # user is not immune to autoblocks/hardblocks, and they are the current user so we - # know which IP address they're actually coming from - $ip = null; - $sessionUser = $this->currentUser; - // the session user is set up towards the end of Setup.php. Until then, - // assume it's a logged-out user. - $globalUserName = $sessionUser->isSafeToLoad() - ? $sessionUser->getName() - : IP::sanitizeIP( $this->currentRequest->getIP() ); - if ( $user->getName() === $globalUserName && - !$this->permissionManager->userHasRight( $user, 'ipblock-exempt' ) ) { - $ip = $this->currentRequest->getIP(); + if ( $request && $checkIpBlocks ) { + + // Case #1: checking the global user, including IP blocks + $ip = $request->getIP(); + // TODO: remove dependency on DatabaseBlock (T221075) + $blocks = DatabaseBlock::newListFromTarget( $user, $ip, $fromMaster ); + $this->getAdditionalIpBlocks( $blocks, $request, !$user->isRegistered(), $fromMaster ); + $this->getCookieBlock( $blocks, $user, $request ); + + } elseif ( $request ) { + + // Case #2: checking the global user, but they are exempt from IP blocks + // TODO: remove dependency on DatabaseBlock (T221075) + $blocks = DatabaseBlock::newListFromTarget( $user, null, $fromMaster ); + $this->getCookieBlock( $blocks, $user, $request ); + + } else { + + // Case #3: checking whether a user's account is blocked + // TODO: remove dependency on DatabaseBlock (T221075) + $blocks = DatabaseBlock::newListFromTarget( $user, null, $fromMaster ); + + } + + // Filter out any duplicated blocks, e.g. from the cookie + $blocks = $this->getUniqueBlocks( $blocks ); + + $block = null; + if ( count( $blocks ) > 0 ) { + if ( count( $blocks ) === 1 ) { + $block = $blocks[ 0 ]; + } else { + $block = new CompositeBlock( [ + 'address' => $ip, + 'byText' => 'MediaWiki default', + 'reason' => wfMessage( 'blockedtext-composite-reason' )->plain(), + 'originalBlocks' => $blocks, + ] ); + } } - // User/IP blocking - // After this, $blocks is an array of blocks or an empty array - // TODO: remove dependency on DatabaseBlock - $blocks = DatabaseBlock::newListFromTarget( $user, $ip, $fromMaster ); + Hooks::run( 'GetUserBlock', [ clone $user, $ip, &$block ] ); + + return $block; + } - // Cookie blocking + /** + * Get the cookie block, if there is one. + * + * @param AbstractBlock[] &$blocks + * @param UserIdentity $user + * @param WebRequest $request + * @return void + */ + private function getCookieBlock( &$blocks, UserIdentity $user, WebRequest $request ) { $cookieBlock = $this->getBlockFromCookieValue( $user, $request ); - if ( $cookieBlock instanceof AbstractBlock ) { + if ( $cookieBlock instanceof DatabaseBlock ) { $blocks[] = $cookieBlock; } + } + + /** + * Check for any additional blocks against the IP address or any IPs in the XFF header. + * + * @param AbstractBlock[] &$blocks Blocks found so far + * @param WebRequest $request + * @param bool $isAnon The user is logged out + * @param bool $fromMaster + * @return void + */ + private function getAdditionalIpBlocks( &$blocks, WebRequest $request, $isAnon, $fromMaster ) { + $ip = $request->getIP(); // Proxy blocking - if ( $ip !== null && !in_array( $ip, $this->options->get( 'ProxyWhitelist' ) ) ) { + if ( !in_array( $ip, $this->options->get( 'ProxyWhitelist' ) ) ) { // Local list if ( $this->isLocallyBlockedProxy( $ip ) ) { $blocks[] = new SystemBlock( [ @@ -156,24 +218,8 @@ class BlockManager { } } - // (T25343) Apply IP blocks to the contents of XFF headers, if enabled - if ( $this->options->get( 'ApplyIpBlocksToXff' ) - && $ip !== null - && !in_array( $ip, $this->options->get( 'ProxyWhitelist' ) ) - ) { - $xff = $request->getHeader( 'X-Forwarded-For' ); - $xff = array_map( 'trim', explode( ',', $xff ) ); - $xff = array_diff( $xff, [ $ip ] ); - // TODO: remove dependency on DatabaseBlock - $xffblocks = DatabaseBlock::getBlocksForIPList( $xff, $isAnon, $fromMaster ); - $blocks = array_merge( $blocks, $xffblocks ); - } - // Soft blocking - if ( $ip !== null - && $isAnon - && IP::isInRanges( $ip, $this->options->get( 'SoftBlockRanges' ) ) - ) { + if ( $isAnon && IP::isInRanges( $ip, $this->options->get( 'SoftBlockRanges' ) ) ) { $blocks[] = new SystemBlock( [ 'address' => $ip, 'byText' => 'MediaWiki default', @@ -183,26 +229,17 @@ class BlockManager { ] ); } - // Filter out any duplicated blocks, e.g. from the cookie - $blocks = $this->getUniqueBlocks( $blocks ); - - $block = null; - if ( count( $blocks ) > 0 ) { - if ( count( $blocks ) === 1 ) { - $block = $blocks[ 0 ]; - } else { - $block = new CompositeBlock( [ - 'address' => $ip, - 'byText' => 'MediaWiki default', - 'reason' => wfMessage( 'blockedtext-composite-reason' )->plain(), - 'originalBlocks' => $blocks, - ] ); - } + // (T25343) Apply IP blocks to the contents of XFF headers, if enabled + if ( $this->options->get( 'ApplyIpBlocksToXff' ) + && !in_array( $ip, $this->options->get( 'ProxyWhitelist' ) ) + ) { + $xff = $request->getHeader( 'X-Forwarded-For' ); + $xff = array_map( 'trim', explode( ',', $xff ) ); + $xff = array_diff( $xff, [ $ip ] ); + // TODO: remove dependency on DatabaseBlock (T221075) + $xffblocks = DatabaseBlock::getBlocksForIPList( $xff, $isAnon, $fromMaster ); + $blocks = array_merge( $blocks, $xffblocks ); } - - Hooks::run( 'GetUserBlock', [ clone $user, $ip, &$block ] ); - - return $block; } /** @@ -255,7 +292,7 @@ class BlockManager { $blockCookieId = $this->getIdFromCookieValue( $cookieValue ); if ( !is_null( $blockCookieId ) ) { - // TODO: remove dependency on DatabaseBlock + // TODO: remove dependency on DatabaseBlock (T221075) $block = DatabaseBlock::newFromID( $blockCookieId ); if ( $block instanceof DatabaseBlock && @@ -368,15 +405,14 @@ class BlockManager { $ipList = $this->checkHost( $hostname ); if ( $ipList ) { - wfDebugLog( - 'dnsblacklist', + $this->logger->info( "Hostname $hostname is {$ipList[0]}, it's a proxy says $basename!" ); $found = true; break; } - wfDebugLog( 'dnsblacklist', "Requested $hostname, not found in $basename." ); + $this->logger->debug( "Requested $hostname, not found in $basename." ); } } @@ -419,12 +455,14 @@ class BlockManager { // TODO: Improve on simply tracking the first trackable block (T225654) foreach ( $block->getOriginalBlocks() as $originalBlock ) { if ( $this->shouldTrackBlockWithCookie( $originalBlock, $isAnon ) ) { + '@phan-var DatabaseBlock $originalBlock'; $this->setBlockCookie( $originalBlock, $response ); return; } } } else { if ( $this->shouldTrackBlockWithCookie( $block, $isAnon ) ) { + '@phan-var DatabaseBlock $block'; $this->setBlockCookie( $block, $response ); } } diff --git a/includes/cache/localisation/LocalisationCache.php b/includes/cache/localisation/LocalisationCache.php index 26468452b4..c6d6b8fa5b 100644 --- a/includes/cache/localisation/LocalisationCache.php +++ b/includes/cache/localisation/LocalisationCache.php @@ -519,17 +519,8 @@ class LocalisationCache { * @return array */ protected function readPHPFile( $_fileName, $_fileType ) { - // Disable APC caching - Wikimedia\suppressWarnings(); - $_apcEnabled = ini_set( 'apc.cache_by_default', '0' ); - Wikimedia\restoreWarnings(); - include $_fileName; - Wikimedia\suppressWarnings(); - ini_set( 'apc.cache_by_default', $_apcEnabled ); - Wikimedia\restoreWarnings(); - $data = []; if ( $_fileType == 'core' || $_fileType == 'extension' ) { foreach ( self::$allKeys as $key ) { diff --git a/includes/changes/CategoryMembershipChange.php b/includes/changes/CategoryMembershipChange.php index 2ef9c9f95f..5a7f45ea25 100644 --- a/includes/changes/CategoryMembershipChange.php +++ b/includes/changes/CategoryMembershipChange.php @@ -1,6 +1,7 @@ pageTitle->getPreviousRevisionID( $this->pageTitle->getLatestRevID() ) - ); - - return $previousRev ? $previousRev->getTimestamp() : null; + $rl = MediaWikiServices::getInstance()->getRevisionLookup(); + $latestRev = $rl->getRevisionByTitle( $this->pageTitle ); + if ( $latestRev ) { + $previousRev = $rl->getPreviousRevision( $latestRev ); + if ( $previousRev ) { + return $previousRev->getTimestamp(); + } + } + return null; } } diff --git a/includes/changes/ChangesFeed.php b/includes/changes/ChangesFeed.php index 79092ee37c..e60cc0937b 100644 --- a/includes/changes/ChangesFeed.php +++ b/includes/changes/ChangesFeed.php @@ -21,7 +21,7 @@ */ use MediaWiki\MediaWikiServices; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; /** * Feed to Special:RecentChanges and Special:RecentChangesLinked. diff --git a/includes/changes/ChangesList.php b/includes/changes/ChangesList.php index a48e191003..34d73d6505 100644 --- a/includes/changes/ChangesList.php +++ b/includes/changes/ChangesList.php @@ -23,7 +23,7 @@ */ use MediaWiki\Linker\LinkRenderer; use MediaWiki\MediaWikiServices; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; use Wikimedia\Rdbms\IResultWrapper; class ChangesList extends ContextSource { @@ -455,13 +455,21 @@ class ChangesList extends ContextSource { * @param string &$s HTML to update * @param Title $title * @param string $logtype + * @param bool $useParentheses (optional) Wrap log entry in parentheses where needed */ - public function insertLog( &$s, $title, $logtype ) { + public function insertLog( &$s, $title, $logtype, $useParentheses = true ) { $page = new LogPage( $logtype ); $logname = $page->getName()->setContext( $this->getContext() )->text(); - $s .= Html::rawElement( 'span', [ - 'class' => 'mw-changeslist-links' - ], $this->linkRenderer->makeKnownLink( $title, $logname ) ); + $link = $this->linkRenderer->makeKnownLink( $title, $logname, [ + 'class' => $useParentheses ? '' : 'mw-changeslist-links' + ] ); + if ( $useParentheses ) { + $s .= $this->msg( 'parentheses' )->rawParams( + $link + )->escaped(); + } else { + $s .= $link; + } } /** @@ -625,7 +633,7 @@ class ChangesList extends ContextSource { */ public function insertComment( $rc ) { if ( $this->isDeleted( $rc, RevisionRecord::DELETED_COMMENT ) ) { - return ' ' . + return ' ' . $this->msg( 'rev-deleted-comment' )->escaped() . ''; } else { return Linker::commentBlock( $rc->mAttribs['rc_comment'], $rc->getTitle(), diff --git a/includes/changes/EnhancedChangesList.php b/includes/changes/EnhancedChangesList.php index e461762c5e..d2c4dd48fa 100644 --- a/includes/changes/EnhancedChangesList.php +++ b/includes/changes/EnhancedChangesList.php @@ -1,6 +1,6 @@ mAttribs['rc_log_type'] ) { $logtitle = SpecialPage::getTitleFor( 'Log', $rc->mAttribs['rc_log_type'] ); - $this->insertLog( $html, $logtitle, $rc->mAttribs['rc_log_type'] ); + $this->insertLog( $html, $logtitle, $rc->mAttribs['rc_log_type'], false ); $flags = $this->recentChangesFlags( [ 'unpatrolled' => $unpatrolled, 'bot' => $rc->mAttribs['rc_bot'] ], '' ); if ( $flags !== '' ) { @@ -98,7 +98,7 @@ class OldChangesList extends ChangesList { list( $name, $htmlubpage ) = MediaWikiServices::getInstance()->getSpecialPageFactory()-> resolveAlias( $rc->mAttribs['rc_title'] ); if ( $name == 'Log' ) { - $this->insertLog( $html, $rc->getTitle(), $htmlubpage ); + $this->insertLog( $html, $rc->getTitle(), $htmlubpage, false ); } // Regular entries } else { diff --git a/includes/changes/RCCacheEntryFactory.php b/includes/changes/RCCacheEntryFactory.php index d448eae4a1..83720d3453 100644 --- a/includes/changes/RCCacheEntryFactory.php +++ b/includes/changes/RCCacheEntryFactory.php @@ -20,7 +20,7 @@ * @file */ use MediaWiki\Linker\LinkRenderer; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; class RCCacheEntryFactory { @@ -56,7 +56,6 @@ class RCCacheEntryFactory { */ public function newFromRecentChange( RecentChange $baseRC, $watched ) { $user = $this->context->getUser(); - $counter = $baseRC->counter; $cacheEntry = RCCacheEntry::newFromParent( $baseRC ); @@ -73,8 +72,8 @@ class RCCacheEntryFactory { // called too many times (50% of CPU time on RecentChanges!). $showDiffLinks = $this->showDiffLinks( $cacheEntry, $user ); - $cacheEntry->difflink = $this->buildDiffLink( $cacheEntry, $showDiffLinks, $counter ); - $cacheEntry->curlink = $this->buildCurLink( $cacheEntry, $showDiffLinks, $counter ); + $cacheEntry->difflink = $this->buildDiffLink( $cacheEntry, $showDiffLinks ); + $cacheEntry->curlink = $this->buildCurLink( $cacheEntry, $showDiffLinks ); $cacheEntry->lastlink = $this->buildLastLink( $cacheEntry, $showDiffLinks ); // Make user links @@ -109,11 +108,11 @@ class RCCacheEntryFactory { } /** - * @param RecentChange $cacheEntry + * @param RCCacheEntry $cacheEntry * * @return string */ - private function buildCLink( RecentChange $cacheEntry ) { + private function buildCLink( RCCacheEntry $cacheEntry ) { $type = $cacheEntry->mAttribs['rc_type']; // New unpatrolled pages @@ -182,11 +181,10 @@ class RCCacheEntryFactory { /** * @param RecentChange $cacheEntry * @param bool $showDiffLinks - * @param int $counter * * @return string */ - private function buildCurLink( RecentChange $cacheEntry, $showDiffLinks, $counter ) { + private function buildCurLink( RecentChange $cacheEntry, $showDiffLinks ) { $queryParams = $this->buildCurQueryParams( $cacheEntry ); $curMessage = $this->getMessage( 'cur' ); $logTypes = [ RC_LOG ]; @@ -217,11 +215,10 @@ class RCCacheEntryFactory { /** * @param RecentChange $cacheEntry * @param bool $showDiffLinks - * @param int $counter * * @return string */ - private function buildDiffLink( RecentChange $cacheEntry, $showDiffLinks, $counter ) { + private function buildDiffLink( RecentChange $cacheEntry, $showDiffLinks ) { $queryParams = $this->buildDiffQueryParams( $cacheEntry ); $diffMessage = $this->getMessage( 'diff' ); $logTypes = [ RC_NEW, RC_LOG ]; diff --git a/includes/changetags/ChangeTagsLogItem.php b/includes/changetags/ChangeTagsLogItem.php index 1827aab036..ce82b71fef 100644 --- a/includes/changetags/ChangeTagsLogItem.php +++ b/includes/changetags/ChangeTagsLogItem.php @@ -20,7 +20,7 @@ */ use MediaWiki\MediaWikiServices; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; /** * Item class for a logging table row with its associated change tags. diff --git a/includes/clientpool/SquidPurgeClient.php b/includes/clientpool/SquidPurgeClient.php index 6b5482cf8d..dffe6e14fa 100644 --- a/includes/clientpool/SquidPurgeClient.php +++ b/includes/clientpool/SquidPurgeClient.php @@ -191,11 +191,11 @@ class SquidPurgeClient { /** * Queue a purge operation * - * @param string $url + * @param string $url Fully expanded URL (with host and protocol) */ public function queuePurge( $url ) { global $wgSquidPurgeUseHostHeader; - $url = CdnCacheUpdate::expand( str_replace( "\n", '', $url ) ); + $url = str_replace( "\n", '', $url ); // sanity $request = []; if ( $wgSquidPurgeUseHostHeader ) { $url = wfParseUrl( $url ); diff --git a/includes/collation/CustomUppercaseCollation.php b/includes/collation/CustomUppercaseCollation.php index 170d5c2c69..8f4f058646 100644 --- a/includes/collation/CustomUppercaseCollation.php +++ b/includes/collation/CustomUppercaseCollation.php @@ -45,6 +45,9 @@ class CustomUppercaseCollation extends NumericUppercaseCollation { /** @var array $puaSubset List of private use area codes */ private $puaSubset; + /** @var array */ + private $firstLetters; + /** * @note This assumes $alphabet does not contain U+F3000-U+F3FFF * diff --git a/includes/content/ContentHandler.php b/includes/content/ContentHandler.php index 9fbb72cd1b..533f6397c5 100644 --- a/includes/content/ContentHandler.php +++ b/includes/content/ContentHandler.php @@ -26,7 +26,7 @@ * @author Daniel Kinzler */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; use Wikimedia\Assert\Assert; use MediaWiki\Logger\LoggerFactory; use MediaWiki\MediaWikiServices; diff --git a/includes/debug/logger/ConsoleLogger.php b/includes/debug/logger/ConsoleLogger.php index a48faf1e50..56fc0b32bc 100644 --- a/includes/debug/logger/ConsoleLogger.php +++ b/includes/debug/logger/ConsoleLogger.php @@ -10,6 +10,9 @@ use Psr\Log\AbstractLogger; * goal. */ class ConsoleLogger extends AbstractLogger { + /** @var string */ + private $channel; + /** * @param string $channel */ diff --git a/includes/deferred/CdnCacheUpdate.php b/includes/deferred/CdnCacheUpdate.php index ddffaa396b..b983e97406 100644 --- a/includes/deferred/CdnCacheUpdate.php +++ b/includes/deferred/CdnCacheUpdate.php @@ -24,12 +24,12 @@ use Wikimedia\Assert\Assert; use MediaWiki\MediaWikiServices; /** - * Handles purging appropriate CDN URLs given a title (or titles) + * Handles purging the appropriate CDN objects given a list of URLs or Title instances * @ingroup Cache */ class CdnCacheUpdate implements DeferrableUpdate, MergeableUpdate { /** @var string[] Collection of URLs to purge */ - protected $urls = []; + private $urls = []; /** * @param string[] $urlArr Collection of URLs to purge @@ -99,10 +99,9 @@ class CdnCacheUpdate implements DeferrableUpdate, MergeableUpdate { wfDebugLog( 'squid', __METHOD__ . ': ' . implode( ' ', $urlArr ) ); // Reliably broadcast the purge to all edge nodes - $relayer = MediaWikiServices::getInstance()->getEventRelayerGroup() - ->getRelayer( 'cdn-url-purges' ); $ts = microtime( true ); - $relayer->notifyMulti( + $relayerGroup = MediaWikiServices::getInstance()->getEventRelayerGroup(); + $relayerGroup->getRelayer( 'cdn-url-purges' )->notifyMulti( 'cdn-url-purges', array_map( function ( $url ) use ( $ts ) { @@ -138,7 +137,7 @@ class CdnCacheUpdate implements DeferrableUpdate, MergeableUpdate { foreach ( $chunks as $chunk ) { $client = new SquidPurgeClient( $server ); foreach ( $chunk as $url ) { - $client->queuePurge( $url ); + $client->queuePurge( self::expand( $url ) ); } $pool->addClient( $client ); } @@ -255,7 +254,7 @@ class CdnCacheUpdate implements DeferrableUpdate, MergeableUpdate { * @param string $url * @return string */ - public static function expand( $url ) { + private static function expand( $url ) { return wfExpandUrl( $url, PROTO_INTERNAL ); } diff --git a/includes/deferred/HTMLCacheUpdate.php b/includes/deferred/HTMLCacheUpdate.php index 29846bfb77..9e45241841 100644 --- a/includes/deferred/HTMLCacheUpdate.php +++ b/includes/deferred/HTMLCacheUpdate.php @@ -22,16 +22,15 @@ */ /** - * Class to invalidate the HTML cache of all the pages linking to a given title. + * Class to invalidate the HTML/file cache of all the pages linking to a given title * * @ingroup Cache */ class HTMLCacheUpdate extends DataUpdate { /** @var Title */ - public $mTitle; - + private $title; /** @var string */ - public $mTable; + private $table; /** * @param Title $titleTo @@ -42,16 +41,16 @@ class HTMLCacheUpdate extends DataUpdate { function __construct( Title $titleTo, $table, $causeAction = 'unknown', $causeAgent = 'unknown' ) { - $this->mTitle = $titleTo; - $this->mTable = $table; + $this->title = $titleTo; + $this->table = $table; $this->causeAction = $causeAction; $this->causeAgent = $causeAgent; } public function doUpdate() { $job = HTMLCacheUpdateJob::newForBacklinks( - $this->mTitle, - $this->mTable, + $this->title, + $this->table, [ 'causeAction' => $this->getCauseAction(), 'causeAgent' => $this->getCauseAgent() ] ); diff --git a/includes/deferred/LinksUpdate.php b/includes/deferred/LinksUpdate.php index 8345ee6575..2bfdc0edc9 100644 --- a/includes/deferred/LinksUpdate.php +++ b/includes/deferred/LinksUpdate.php @@ -1066,6 +1066,7 @@ class LinksUpdate extends DataUpdate { private function invalidateProperties( $changed ) { global $wgPagePropLinkInvalidations; + $jobs = []; foreach ( $changed as $name => $value ) { if ( isset( $wgPagePropLinkInvalidations[$name] ) ) { $inv = $wgPagePropLinkInvalidations[$name]; @@ -1073,12 +1074,16 @@ class LinksUpdate extends DataUpdate { $inv = [ $inv ]; } foreach ( $inv as $table ) { - DeferredUpdates::addUpdate( - new HTMLCacheUpdate( $this->mTitle, $table, 'page-props' ) + $jobs[] = HTMLCacheUpdateJob::newForBacklinks( + $this->mTitle, + $table, + [ 'causeAction' => 'page-props' ] ); } } } + + JobQueueGroup::singleton()->lazyPush( $jobs ); } /** @@ -1192,4 +1197,14 @@ class LinksUpdate extends DataUpdate { return $this->db; } + + /** + * Whether or not this LinksUpdate will also update pages which transclude the + * current page or otherwise depend on it. + * + * @return bool + */ + public function isRecursive() { + return $this->mRecursive; + } } diff --git a/includes/deferred/SearchUpdate.php b/includes/deferred/SearchUpdate.php index a508746c55..84f6fc0eaf 100644 --- a/includes/deferred/SearchUpdate.php +++ b/includes/deferred/SearchUpdate.php @@ -50,7 +50,7 @@ class SearchUpdate implements DeferrableUpdate { */ public function __construct( $id, $title, $c = null ) { if ( is_string( $title ) ) { - wfDeprecated( __METHOD__ . " with a string for the title", 1.34 ); + wfDeprecated( __METHOD__ . " with a string for the title", '1.34' ); $this->title = Title::newFromText( $title ); if ( $this->title === null ) { throw new InvalidArgumentException( "Cannot construct the title: $title" ); @@ -62,10 +62,10 @@ class SearchUpdate implements DeferrableUpdate { $this->id = $id; // is_string() check is back-compat for ApprovedRevs if ( is_string( $c ) ) { - wfDeprecated( __METHOD__ . " with a string for the content", 1.34 ); + wfDeprecated( __METHOD__ . " with a string for the content", '1.34' ); $c = new TextContent( $c ); } elseif ( is_bool( $c ) ) { - wfDeprecated( __METHOD__ . " with a boolean for the content", 1.34 ); + wfDeprecated( __METHOD__ . " with a boolean for the content", '1.34' ); $c = null; } $this->content = $c; diff --git a/includes/diff/DifferenceEngine.php b/includes/diff/DifferenceEngine.php index 8a5caa2dce..7e4e53e2b6 100644 --- a/includes/diff/DifferenceEngine.php +++ b/includes/diff/DifferenceEngine.php @@ -1713,14 +1713,29 @@ class DifferenceEngine extends ContextSource { * false signifies that there is no previous/next revision ($old is the oldest/newest one). */ public function mapDiffPrevNext( $old, $new ) { + $rl = MediaWikiServices::getInstance()->getRevisionLookup(); if ( $new === 'prev' ) { // Show diff between revision $old and the previous one. Get previous one from DB. $newid = intval( $old ); - $oldid = $this->getTitle()->getPreviousRevisionID( $newid ); + $oldid = false; + $newRev = $rl->getRevisionById( $newid ); + if ( $newRev ) { + $oldRev = $rl->getPreviousRevision( $newRev ); + if ( $oldRev ) { + $oldid = $oldRev->getId(); + } + } } elseif ( $new === 'next' ) { // Show diff between revision $old and the next one. Get next one from DB. $oldid = intval( $old ); - $newid = $this->getTitle()->getNextRevisionID( $oldid ); + $newid = false; + $oldRev = $rl->getRevisionById( $oldid ); + if ( $oldRev ) { + $newRev = $rl->getNextRevision( $oldRev ); + if ( $newRev ) { + $newid = $newRev->getId(); + } + } } else { $oldid = intval( $old ); $newid = intval( $new ); diff --git a/includes/exception/MWExceptionHandler.php b/includes/exception/MWExceptionHandler.php index b4e483bf53..4a72d72d6b 100644 --- a/includes/exception/MWExceptionHandler.php +++ b/includes/exception/MWExceptionHandler.php @@ -350,7 +350,7 @@ class MWExceptionHandler { // Look at message to see if this is a class not found failure // HHVM: Class undefined: foo - // PHP5: Class 'foo' not found + // PHP7: Class 'foo' not found if ( preg_match( "/Class (undefined: \w+|'\w+' not found)/", $message ) ) { // phpcs:disable Generic.Files.LineLength $msg = <<isLoggable() ) { $logger = LoggerFactory::getInstance( 'exception' ); + $context = self::getLogContext( $e, $catcher ); + if ( $extraData ) { + $context['extraData'] = $extraData; + } $logger->error( self::getLogNormalMessage( $e ), - self::getLogContext( $e, $catcher ) + $context ); $json = self::jsonSerializeException( $e, false, FormatJson::ALL_OK, $catcher ); diff --git a/includes/export/Dump7ZipOutput.php b/includes/export/Dump7ZipOutput.php index a50150e085..833d553696 100644 --- a/includes/export/Dump7ZipOutput.php +++ b/includes/export/Dump7ZipOutput.php @@ -60,8 +60,7 @@ class Dump7ZipOutput extends DumpPipeOutput { } /** - * @param string $newname - * @param bool $open + * @inheritDoc */ function closeAndRename( $newname, $open = false ) { $newname = $this->checkRenameArgCount( $newname ); diff --git a/includes/export/DumpFileOutput.php b/includes/export/DumpFileOutput.php index d0256fd877..ad68109999 100644 --- a/includes/export/DumpFileOutput.php +++ b/includes/export/DumpFileOutput.php @@ -59,7 +59,7 @@ class DumpFileOutput extends DumpOutput { } /** - * @param string $newname + * @inheritDoc */ function closeRenameAndReopen( $newname ) { $this->closeAndRename( $newname, true ); @@ -92,8 +92,7 @@ class DumpFileOutput extends DumpOutput { } /** - * @param string $newname - * @param bool $open + * @inheritDoc */ function closeAndRename( $newname, $open = false ) { $newname = $this->checkRenameArgCount( $newname ); diff --git a/includes/export/DumpFilter.php b/includes/export/DumpFilter.php index 75e149cea3..143fb8efe8 100644 --- a/includes/export/DumpFilter.php +++ b/includes/export/DumpFilter.php @@ -102,14 +102,16 @@ class DumpFilter { } /** - * @param string $newname + * @see DumpOutput::closeRenameAndReopen() + * @param string|string[] $newname */ function closeRenameAndReopen( $newname ) { $this->sink->closeRenameAndReopen( $newname ); } /** - * @param string $newname + * @see DumpOutput::closeAndRename() + * @param string|string[] $newname * @param bool $open */ function closeAndRename( $newname, $open = false ) { diff --git a/includes/export/DumpMultiWriter.php b/includes/export/DumpMultiWriter.php index 92118fe41d..2f5b3dc6df 100644 --- a/includes/export/DumpMultiWriter.php +++ b/includes/export/DumpMultiWriter.php @@ -27,6 +27,10 @@ * @ingroup Dump */ class DumpMultiWriter { + /** @var array */ + private $sinks; + /** @var int */ + private $count; /** * @param array $sinks diff --git a/includes/export/DumpOutput.php b/includes/export/DumpOutput.php index ab925b75ff..5c15c5f9c0 100644 --- a/includes/export/DumpOutput.php +++ b/includes/export/DumpOutput.php @@ -86,7 +86,7 @@ class DumpOutput { * and reopen new file with the old name. Use this * for writing out a file in multiple pieces * at specified checkpoints (e.g. every n hours). - * @param string|array $newname File name. May be a string or an array with one element + * @param string|string[] $newname File name. May be a string or an array with one element */ function closeRenameAndReopen( $newname ) { } @@ -95,7 +95,7 @@ class DumpOutput { * Close the old file, and move it to a specified name. * Use this for the last piece of a file written out * at specified checkpoints (e.g. every n hours). - * @param string|array $newname File name. May be a string or an array with one element + * @param string|string[] $newname File name. May be a string or an array with one element * @param bool $open If true, a new file with the old filename will be opened * again for writing (default: false) */ diff --git a/includes/export/DumpPipeOutput.php b/includes/export/DumpPipeOutput.php index 0521c5a131..4e61434f50 100644 --- a/includes/export/DumpPipeOutput.php +++ b/includes/export/DumpPipeOutput.php @@ -73,15 +73,14 @@ class DumpPipeOutput extends DumpFileOutput { } /** - * @param string $newname + * @inheritDoc */ function closeRenameAndReopen( $newname ) { $this->closeAndRename( $newname, true ); } /** - * @param string $newname - * @param bool $open + * @inheritDoc */ function closeAndRename( $newname, $open = false ) { $newname = $this->checkRenameArgCount( $newname ); diff --git a/includes/export/WikiExporter.php b/includes/export/WikiExporter.php index ec0b344e3c..fd200d1fbb 100644 --- a/includes/export/WikiExporter.php +++ b/includes/export/WikiExporter.php @@ -28,8 +28,9 @@ */ use MediaWiki\MediaWikiServices as MediaWikiServicesAlias; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; use Wikimedia\Rdbms\IResultWrapper; +use Wikimedia\Rdbms\IDatabase; /** * @ingroup SpecialPage Dump @@ -67,7 +68,7 @@ class WikiExporter { /** @var XmlDumpWriter */ private $writer; - /** @var Database */ + /** @var IDatabase */ protected $db; /** @var array|int */ @@ -86,7 +87,7 @@ class WikiExporter { } /** - * @param Database $db + * @param IDatabase $db * @param int|array $history One of WikiExporter::FULL, WikiExporter::CURRENT, * WikiExporter::RANGE or WikiExporter::STABLE, or an associative array: * - offset: non-inclusive offset at which to start the query @@ -303,29 +304,36 @@ class WikiExporter { if ( $cond ) { $where[] = $cond; } - # Get logging table name for logging.* clause - $logging = $this->db->tableName( 'logging' ); - $result = null; // Assuring $result is not undefined, if exception occurs early $commentQuery = CommentStore::getStore()->getJoin( 'log_comment' ); $actorQuery = ActorMigration::newMigration()->getJoin( 'log_user' ); + $tables = array_merge( + [ 'logging' ], $commentQuery['tables'], $actorQuery['tables'], [ 'user' ] + ); + $fields = [ + 'log_id', 'log_type', 'log_action', 'log_timestamp', 'log_namespace', + 'log_title', 'log_params', 'log_deleted', 'user_name' + ] + $commentQuery['fields'] + $actorQuery['fields']; + $options = [ + 'ORDER BY' => 'log_id', + 'USE INDEX' => [ 'logging' => 'PRIMARY' ], + 'LIMIT' => self::BATCH_SIZE, + ]; + $joins = [ + 'user' => [ 'JOIN', 'user_id = ' . $actorQuery['fields']['log_user'] ] + ] + $commentQuery['joins'] + $actorQuery['joins']; + $lastLogId = 0; while ( true ) { $result = $this->db->select( - array_merge( [ 'logging' ], $commentQuery['tables'], $actorQuery['tables'], [ 'user' ] ), - [ "{$logging}.*", 'user_name' ] + $commentQuery['fields'] + $actorQuery['fields'], + $tables, + $fields, array_merge( $where, [ 'log_id > ' . intval( $lastLogId ) ] ), __METHOD__, - [ - 'ORDER BY' => 'log_id', - 'USE INDEX' => [ 'logging' => 'PRIMARY' ], - 'LIMIT' => self::BATCH_SIZE, - ], - [ - 'user' => [ 'JOIN', 'user_id = ' . $actorQuery['fields']['log_user'] ] - ] + $commentQuery['joins'] + $actorQuery['joins'] + $options, + $joins ); if ( !$result->numRows() ) { diff --git a/includes/filerepo/FileRepo.php b/includes/filerepo/FileRepo.php index 42e78fffc6..ff8f0563fb 100644 --- a/includes/filerepo/FileRepo.php +++ b/includes/filerepo/FileRepo.php @@ -142,6 +142,12 @@ class FileRepo { /** @var WANObjectCache */ protected $wanCache; + /** + * @var string + * @protected Use $this->getName(). Public for back-compat only + */ + public $name; + /** * @param array|null $info * @throws MWException diff --git a/includes/filerepo/file/ArchivedFile.php b/includes/filerepo/file/ArchivedFile.php index 17fa146440..a968831b08 100644 --- a/includes/filerepo/file/ArchivedFile.php +++ b/includes/filerepo/file/ArchivedFile.php @@ -94,6 +94,9 @@ class ArchivedFile { /** @var Title */ protected $title; # image title + /** @var bool */ + private $exists; + /** * @throws MWException * @param Title $title @@ -435,7 +438,9 @@ class ArchivedFile { function pageCount() { if ( !isset( $this->pageCount ) ) { // @FIXME: callers expect File objects + // @phan-suppress-next-line PhanTypeMismatchArgument if ( $this->getHandler() && $this->handler->isMultiPage( $this ) ) { + // @phan-suppress-next-line PhanTypeMismatchArgument $this->pageCount = $this->handler->pageCount( $this ); } else { $this->pageCount = false; diff --git a/includes/filerepo/file/File.php b/includes/filerepo/file/File.php index 0d5776bba2..73b08e6a34 100644 --- a/includes/filerepo/file/File.php +++ b/includes/filerepo/file/File.php @@ -1467,13 +1467,15 @@ abstract class File implements IDBAccessObject { // Delete thumbnails and refresh file metadata cache $this->purgeCache(); $this->purgeDescription(); - // Purge cache of all pages using this file $title = $this->getTitle(); if ( $title ) { - DeferredUpdates::addUpdate( - new HTMLCacheUpdate( $title, 'imagelinks', 'file-purge' ) + $job = HTMLCacheUpdateJob::newForBacklinks( + $title, + 'imagelinks', + [ 'causeAction' => 'file-purge' ] ); + JobQueueGroup::singleton()->lazyPush( $job ); } } @@ -2040,7 +2042,7 @@ abstract class File implements IDBAccessObject { * Get the URL of the image description page. May return false if it is * unknown or not applicable. * - * @return string + * @return string|bool */ function getDescriptionUrl() { if ( $this->repo ) { diff --git a/includes/filerepo/file/LocalFile.php b/includes/filerepo/file/LocalFile.php index ceb8dda9c7..6d2943381f 100644 --- a/includes/filerepo/file/LocalFile.php +++ b/includes/filerepo/file/LocalFile.php @@ -452,6 +452,10 @@ class LocalFile extends File { * This covers fields that are sometimes not cached. */ protected function loadExtraFromDB() { + if ( !$this->title ) { + return; // Avoid hard failure when the file does not exist. T221812 + } + $fname = static::class . '::' . __FUNCTION__; # Unconditionally set loaded=true, we don't want the accessors constantly rechecking @@ -857,12 +861,24 @@ class LocalFile extends File { function getUser( $type = 'text' ) { $this->load(); - if ( $type === 'object' ) { - return $this->user; - } elseif ( $type === 'text' ) { - return $this->user->getName(); - } elseif ( $type === 'id' ) { - return $this->user->getId(); + if ( !$this->user ) { + // If the file does not exist, $this->user will be null, see T221812. + // Note: 'Unknown user' this is a reserved user name. + if ( $type === 'object' ) { + return User::newFromName( 'Unknown user', false ); + } elseif ( $type === 'text' ) { + return 'Unknown user'; + } elseif ( $type === 'id' ) { + return 0; + } + } else { + if ( $type === 'object' ) { + return $this->user; + } elseif ( $type === 'text' ) { + return $this->user->getName(); + } elseif ( $type === 'id' ) { + return $this->user->getId(); + } } throw new MWException( "Unknown type '$type'." ); @@ -876,9 +892,13 @@ class LocalFile extends File { * @since 1.27 */ public function getDescriptionShortUrl() { + if ( !$this->title ) { + return null; // Avoid hard failure when the file does not exist. T221812 + } + $pageId = $this->title->getArticleID(); - if ( $pageId !== null ) { + if ( $pageId ) { $url = $this->repo->makeUrl( [ 'curid' => $pageId ] ); if ( $url !== false ) { return $url; @@ -1145,6 +1165,10 @@ class LocalFile extends File { * @return OldLocalFile[] */ function getHistory( $limit = null, $start = null, $end = null, $inc = true ) { + if ( !$this->exists() ) { + return []; // Avoid hard failure when the file does not exist. T221812 + } + $dbr = $this->repo->getReplicaDB(); $oldFileQuery = OldLocalFile::getQueryInfo(); @@ -1198,9 +1222,13 @@ class LocalFile extends File { * 0 return line for current version * 1 query for old versions, return first one * 2, ... return next old version from above query - * @return bool + * @return stdClass|bool */ public function nextHistoryLine() { + if ( !$this->exists() ) { + return false; // Avoid hard failure when the file does not exist. T221812 + } + # Polymorphic function name to distinguish foreign and local fetches $fname = static::class . '::' . __FUNCTION__; @@ -2026,9 +2054,13 @@ class LocalFile extends File { /** * Get the URL of the file description page. - * @return string + * @return string|bool */ function getDescriptionUrl() { + if ( !$this->title ) { + return false; // Avoid hard failure when the file does not exist. T221812 + } + return $this->title->getLocalURL(); } @@ -2041,6 +2073,10 @@ class LocalFile extends File { * @return string|false */ function getDescriptionText( Language $lang = null ) { + if ( !$this->title ) { + return false; // Avoid hard failure when the file does not exist. T221812 + } + $store = MediaWikiServices::getInstance()->getRevisionStore(); $revision = $store->getRevisionByTitle( $this->title, 0, Revision::READ_NORMAL ); if ( !$revision ) { @@ -2090,6 +2126,10 @@ class LocalFile extends File { * @return bool|string */ public function getDescriptionTouched() { + if ( !$this->exists() ) { + return false; // Avoid hard failure when the file does not exist. T221812 + } + // The DB lookup might return false, e.g. if the file was just deleted, or the shared DB repo // itself gets it from elsewhere. To avoid repeating the DB lookups in such a case, we // need to differentiate between null (uninitialized) and false (failed to load). diff --git a/includes/filerepo/file/LocalFileDeleteBatch.php b/includes/filerepo/file/LocalFileDeleteBatch.php index 85988f6141..f363beb3b9 100644 --- a/includes/filerepo/file/LocalFileDeleteBatch.php +++ b/includes/filerepo/file/LocalFileDeleteBatch.php @@ -22,7 +22,7 @@ */ use MediaWiki\MediaWikiServices; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; /** * Helper class for file deletion diff --git a/includes/filerepo/file/LocalFileMoveBatch.php b/includes/filerepo/file/LocalFileMoveBatch.php index 21980b90eb..0cdc2d5de1 100644 --- a/includes/filerepo/file/LocalFileMoveBatch.php +++ b/includes/filerepo/file/LocalFileMoveBatch.php @@ -46,6 +46,24 @@ class LocalFileMoveBatch { /** @var IDatabase */ protected $db; + /** @var string */ + protected $oldHash; + + /** @var string */ + protected $newHash; + + /** @var string */ + protected $oldName; + + /** @var string */ + protected $newName; + + /** @var string */ + protected $oldRel; + + /** @var string */ + protected $newRel; + /** * @param File $file * @param Title $target diff --git a/includes/gallery/ImageGalleryBase.php b/includes/gallery/ImageGalleryBase.php index c6d8ddf3db..4781a489f5 100644 --- a/includes/gallery/ImageGalleryBase.php +++ b/includes/gallery/ImageGalleryBase.php @@ -88,6 +88,15 @@ abstract class ImageGalleryBase extends ContextSource { /** @var array */ protected $mAttribs = []; + /** @var int */ + protected $mPerRow; + + /** @var int */ + protected $mWidths; + + /** @var int */ + protected $mHeights; + /** @var array */ private static $modeMapping; diff --git a/includes/historyblob/ConcatenatedGzipHistoryBlob.php b/includes/historyblob/ConcatenatedGzipHistoryBlob.php index 6e760fae1b..a5d71454e8 100644 --- a/includes/historyblob/ConcatenatedGzipHistoryBlob.php +++ b/includes/historyblob/ConcatenatedGzipHistoryBlob.php @@ -149,6 +149,5 @@ if ( false ) { // autoload entries for the lowercase variants of these classes (T166759). // The code below is never executed, but it is picked up by the AutoloadGenerator // parser, which scans for class_alias() calls. - // @phan-suppress-next-line PhanRedefineClassAlias class_alias( ConcatenatedGzipHistoryBlob::class, 'concatenatedgziphistoryblob' ); } diff --git a/includes/historyblob/HistoryBlobCurStub.php b/includes/historyblob/HistoryBlobCurStub.php index cd2a935e6d..8858c8d1e2 100644 --- a/includes/historyblob/HistoryBlobCurStub.php +++ b/includes/historyblob/HistoryBlobCurStub.php @@ -69,6 +69,5 @@ if ( false ) { // autoload entries for the lowercase variants of these classes (T166759). // The code below is never executed, but it is picked up by the AutoloadGenerator // parser, which scans for class_alias() calls. - // @phan-suppress-next-line PhanRedefineClassAlias class_alias( HistoryBlobCurStub::class, 'historyblobcurstub' ); } diff --git a/includes/historyblob/HistoryBlobStub.php b/includes/historyblob/HistoryBlobStub.php index c92e1b5494..9a4df1f81d 100644 --- a/includes/historyblob/HistoryBlobStub.php +++ b/includes/historyblob/HistoryBlobStub.php @@ -149,6 +149,5 @@ if ( false ) { // autoload entries for the lowercase variants of these classes (T166759). // The code below is never executed, but it is picked up by the AutoloadGenerator // parser, which scans for class_alias() calls. - // @phan-suppress-next-line PhanRedefineClassAlias class_alias( HistoryBlobStub::class, 'historyblobstub' ); } diff --git a/includes/htmlform/HTMLForm.php b/includes/htmlform/HTMLForm.php index 04be6c4e60..58c16021fc 100644 --- a/includes/htmlform/HTMLForm.php +++ b/includes/htmlform/HTMLForm.php @@ -1329,7 +1329,7 @@ class HTMLForm extends ContextSource { } return $elementstr - ? Html::rawElement( 'div', [ 'class' => $elementsType ], $elementstr ) + ? Html::rawElement( 'div', [ 'class' => $elementsType . 'box' ], $elementstr ) : ''; } diff --git a/includes/htmlform/HTMLFormField.php b/includes/htmlform/HTMLFormField.php index 048abbbf49..b55b65287d 100644 --- a/includes/htmlform/HTMLFormField.php +++ b/includes/htmlform/HTMLFormField.php @@ -657,6 +657,7 @@ abstract class HTMLFormField { * @param OOUI\Widget $inputField * @param array $config * @return OOUI\FieldLayout|OOUI\ActionFieldLayout + * @suppress PhanUndeclaredProperty Only some subclasses declare mClassWithButton */ protected function getFieldLayoutOOUI( $inputField, $config ) { if ( isset( $this->mClassWithButton ) ) { diff --git a/includes/htmlform/fields/HTMLSelectAndOtherField.php b/includes/htmlform/fields/HTMLSelectAndOtherField.php index 354432bb28..05ab0bb3fa 100644 --- a/includes/htmlform/fields/HTMLSelectAndOtherField.php +++ b/includes/htmlform/fields/HTMLSelectAndOtherField.php @@ -11,6 +11,9 @@ * @todo FIXME: If made 'required', only the text field should be compulsory. */ class HTMLSelectAndOtherField extends HTMLSelectField { + /** @var string[] */ + private $mFlatOptions; + public function __construct( $params ) { if ( array_key_exists( 'other', $params ) ) { // Do nothing diff --git a/includes/htmlform/fields/HTMLTitleTextField.php b/includes/htmlform/fields/HTMLTitleTextField.php index 1eda33c296..3df5b7ec9b 100644 --- a/includes/htmlform/fields/HTMLTitleTextField.php +++ b/includes/htmlform/fields/HTMLTitleTextField.php @@ -7,9 +7,6 @@ use MediaWiki\Widget\TitleInputWidget; * Automatically does validation that the title is valid, * as well as autocompletion if using the OOUI display format. * - * Note: Forms using GET requests will need to make sure the title value is not - * an empty string. - * * Optional parameters: * 'namespace' - Namespace the page must be in * 'relative' - If true and 'namespace' given, strip/add the namespace from/to the title as needed @@ -33,14 +30,6 @@ class HTMLTitleTextField extends HTMLTextField { } public function validate( $value, $alldata ) { - if ( $this->mParent->getMethod() === 'get' && $value === '' ) { - // If the form is a GET form and has no value, assume it hasn't been - // submitted yet, and skip validation - // TODO This doesn't look right, we should be able to tell the difference - // between "not submitted" (null) and "submitted but empty" (empty string). - return parent::validate( $value, $alldata ); - } - // Default value (from getDefault()) is null, which breaks Title::newFromTextThrow() below if ( $value === null ) { $value = ''; diff --git a/includes/htmlform/fields/HTMLUserTextField.php b/includes/htmlform/fields/HTMLUserTextField.php index 5b3bc25ef8..0e4d8421ff 100644 --- a/includes/htmlform/fields/HTMLUserTextField.php +++ b/includes/htmlform/fields/HTMLUserTextField.php @@ -6,8 +6,6 @@ use MediaWiki\Widget\UserInputWidget; * Implements a text input field for user names. * Automatically auto-completes if using the OOUI display format. * - * FIXME: Does not work for forms that support GET requests. - * * Optional parameters: * 'exists' - Whether to validate that the user already exists * 'ipallowed' - Whether an IP adress is interpreted as "valid" diff --git a/includes/http/HttpRequestFactory.php b/includes/http/HttpRequestFactory.php index 8433df6e08..510d26d2bd 100644 --- a/includes/http/HttpRequestFactory.php +++ b/includes/http/HttpRequestFactory.php @@ -59,7 +59,7 @@ class HttpRequestFactory { * - originalRequest Information about the original request (as a WebRequest object or * an associative array with 'ip' and 'userAgent'). * @codingStandardsIgnoreStart - * @phan-param array{timeout?:int,connectTimeout?:int,postData?:array,proxy?:string,noProxy?:bool,sslVerifyHost?:bool,sslVerifyCert?:bool,caInfo?:string,maxRedirects?:int,followRedirects?:bool,userAgent?:string,logger?:\Psr\Logger\LoggerInterface,username?:string,password?:string,originalRequest?:WebRequest|array{ip:string,userAgent:string}} $options + * @phan-param array{timeout?:int,connectTimeout?:int,postData?:array,proxy?:string,noProxy?:bool,sslVerifyHost?:bool,sslVerifyCert?:bool,caInfo?:string,maxRedirects?:int,followRedirects?:bool,userAgent?:string,method?:string,logger?:\Psr\Log\LoggerInterface,username?:string,password?:string,originalRequest?:WebRequest|array{ip:string,userAgent:string}} $options * @codingStandardsIgnoreEnd * @param string $caller The method making this request, for profiling * @throws RuntimeException diff --git a/includes/http/MWCallbackStream.php b/includes/http/MWCallbackStream.php index a4120a3578..13ab9b7caf 100644 --- a/includes/http/MWCallbackStream.php +++ b/includes/http/MWCallbackStream.php @@ -29,6 +29,7 @@ use GuzzleHttp\Psr7\StreamDecoratorTrait; * * @private for use by GuzzleHttpRequest only * @since 1.33 + * @property StreamInterface $stream Defined in StreamDecoratorTrait via @property, not read by phan */ class MWCallbackStream implements StreamInterface { use StreamDecoratorTrait; diff --git a/includes/import/ImportStreamSource.php b/includes/import/ImportStreamSource.php index 2f8f5dda14..81e414e931 100644 --- a/includes/import/ImportStreamSource.php +++ b/includes/import/ImportStreamSource.php @@ -30,6 +30,9 @@ use MediaWiki\MediaWikiServices; * @ingroup SpecialPage */ class ImportStreamSource implements ImportSource { + /** @var resource */ + private $mHandle; + /** * @param resource $handle */ diff --git a/includes/import/ImportStringSource.php b/includes/import/ImportStringSource.php index fdd1f77774..b75ea1a192 100644 --- a/includes/import/ImportStringSource.php +++ b/includes/import/ImportStringSource.php @@ -32,6 +32,12 @@ * @ingroup SpecialPage */ class ImportStringSource implements ImportSource { + /** @var string */ + private $mString; + + /** @var bool */ + private $mRead; + /** * @param string $string */ diff --git a/includes/import/WikiImporter.php b/includes/import/WikiImporter.php index 0d1cc6804a..6eba4f3a3a 100644 --- a/includes/import/WikiImporter.php +++ b/includes/import/WikiImporter.php @@ -33,7 +33,8 @@ use MediaWiki\MediaWikiServices; * @ingroup SpecialPage */ class WikiImporter { - private $reader = null; + /** @var XMLReader */ + private $reader; private $foreignNamespaces = null; private $mLogItemCallback, $mUploadCallback, $mRevisionCallback, $mPageCallback; private $mSiteInfoCallback, $mPageOutCallback; diff --git a/includes/import/WikiRevision.php b/includes/import/WikiRevision.php index c29ba2144f..e0799c0909 100644 --- a/includes/import/WikiRevision.php +++ b/includes/import/WikiRevision.php @@ -185,9 +185,16 @@ class WikiRevision implements ImportableUploadRevision, ImportableOldRevision { /** @var bool */ private $mNoUpdates = false; - /** @var Config $config */ + /** + * @deprecated since 1.31, along with self::downloadSource() + * @var Config $config + */ private $config; + /** + * @param Config $config Deprecated since 1.31, along with self::downloadSource(). Just pass an + * empty HashConfig. + */ public function __construct( Config $config ) { $this->config = $config; } diff --git a/includes/installer/InstallDocFormatter.php b/includes/installer/InstallDocFormatter.php index 08cfd8689a..eb96e05941 100644 --- a/includes/installer/InstallDocFormatter.php +++ b/includes/installer/InstallDocFormatter.php @@ -21,6 +21,9 @@ */ class InstallDocFormatter { + /** @var string */ + private $text; + public static function format( $text ) { $obj = new self( $text ); diff --git a/includes/installer/LocalSettingsGenerator.php b/includes/installer/LocalSettingsGenerator.php index a2179c6e7f..6921361423 100644 --- a/includes/installer/LocalSettingsGenerator.php +++ b/includes/installer/LocalSettingsGenerator.php @@ -30,6 +30,7 @@ class LocalSettingsGenerator { protected $extensions = []; + protected $skins = []; protected $values = []; protected $groupPermissions = []; protected $dbSettings = ''; diff --git a/includes/installer/MysqlUpdater.php b/includes/installer/MysqlUpdater.php index 64c017bbd9..ea88411ec6 100644 --- a/includes/installer/MysqlUpdater.php +++ b/includes/installer/MysqlUpdater.php @@ -29,7 +29,7 @@ use MediaWiki\MediaWikiServices; * * @ingroup Deployment * @since 1.17 - * @property DatabaseMysqlBase $db + * @property Wikimedia\Rdbms\DatabaseMysqlBase $db */ class MysqlUpdater extends DatabaseUpdater { protected function getCoreUpdateList() { diff --git a/includes/installer/PostgresInstaller.php b/includes/installer/PostgresInstaller.php index 9a3d4a384a..e9b0c56059 100644 --- a/includes/installer/PostgresInstaller.php +++ b/includes/installer/PostgresInstaller.php @@ -22,6 +22,7 @@ */ use Wikimedia\Rdbms\Database; +use Wikimedia\Rdbms\DatabasePostgres; use Wikimedia\Rdbms\DBQueryError; use Wikimedia\Rdbms\DBConnectionError; diff --git a/includes/installer/i18n/be-tarask.json b/includes/installer/i18n/be-tarask.json index 168c937f3d..dfea0a5740 100644 --- a/includes/installer/i18n/be-tarask.json +++ b/includes/installer/i18n/be-tarask.json @@ -7,7 +7,8 @@ "Zedlik", "아라", "Red Winged Duck", - "Macofe" + "Macofe", + "Renessaince" ] }, "config-desc": "Праграма ўсталяваньня MediaWiki", @@ -85,7 +86,7 @@ "config-uploads-not-safe": "'''Папярэджаньне:''' дырэкторыя для загрузак па змоўчваньні $1 уразьлівая да выкананьня адвольнага коду.\nХоць MediaWiki і правярае ўсе файлы перад захаваньнем, вельмі рэкамэндуецца [https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:Security#Upload_security закрыць гэтую ўразьлівасьць] перад уключэньнем магчымасьці загрузкі файлаў.", "config-no-cli-uploads-check": "'''Папярэджаньне:''' Вашая дырэкторыя для загрузак па змоўчваньні ($1), не правераная на ўразьлівасьць да выкананьня адвольных скрыптоў падчас усталяваньня CLI.\n.", "config-brokenlibxml": "У Вашай сыстэме ўсталяваныя PHP і libxml2 зь несумяшчальнымі вэрсіямі, што можа прывесьці да пашкоджаньня зьвестак MediaWiki і іншых вэб-дастасаваньняў.\nАбнавіце libxml2 да вэрсіі 2.7.3 ці больш позьняй ([https://bugs.php.net/bug.php?id=45996 паведамленьне пра памылку на сайце PHP]).\nУсталяваньне перарванае.", - "config-suhosin-max-value-length": "Suhosin усталяваны і абмяжоўвае даўжыню парамэтру GET да $1 {{PLURAL:$1|1=байта|байтаў}}.\nResourceLoader, складнік MediaWiki, будзе абходзіць гэтае абмежаваньне, што адаб’ецца на прадукцыйнасьці.\nКалі магчыма, варта ўсталяваць у php.ini значэньне suhosin.get.max_value_length роўным 1024 ці больш, а таксама вызначыць тое ж значэньне для $wgResourceLoaderMaxQueryLength у LocalSettings.php.", + "config-suhosin-max-value-length": "Suhosin усталяваны і абмяжоўвае даўжыню парамэтру GET да $1 {{PLURAL:$1|1=байта|байтаў}}.\nMediaWiki патрабуе, каб suhosin.get.max_value_length складаў прынамсі $2. Адключыце гэтую наладу ці павялічце гэтае значэньня да $3 ў php.ini.", "config-using-32bit": "Папярэджаньне: падобна, што вашая сыстэма выкарыстоўвае 32-бітавыя цэлыя лікі. Гэта [https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:32-bit не рэкамэндуецца].", "config-db-type": "Тып базы зьвестак:", "config-db-host": "Хост базы зьвестак:", diff --git a/includes/installer/i18n/de.json b/includes/installer/i18n/de.json index 649f841323..403939157d 100644 --- a/includes/installer/i18n/de.json +++ b/includes/installer/i18n/de.json @@ -16,7 +16,8 @@ "Das Schäfchen", "Florian", "Macofe", - "ThePiscin" + "ThePiscin", + "Tobi 406" ] }, "config-desc": "Das MediaWiki-Installationsprogramm", @@ -58,15 +59,19 @@ "config-welcome": "=== Prüfung der Installationsumgebung ===\nDie Basisprüfungen werden jetzt durchgeführt, um festzustellen, ob die Installationsumgebung für MediaWiki geeignet ist.\nNotiere diese Informationen und gib sie an, sofern du Hilfe beim Installieren benötigst.", "config-welcome-section-copyright": "=== Lizenz und Nutzungsbedingungen ===\n\n$1\n\nDieses Programm ist freie Software, d. h. es kann, gemäß den Bedingungen der von der Free Software Foundation veröffentlichten ''GNU General Public License'', weiterverteilt und/oder modifiziert werden. Dabei kann die Version 2, oder nach eigenem Ermessen, jede neuere Version der Lizenz verwendet werden.\n\nDieses Programm wird in der Hoffnung verteilt, dass es nützlich sein wird, allerdings '''ohne jegliche Garantie''' und sogar ohne die implizierte Garantie einer '''Marktgängigkeit''' oder '''Eignung für einen bestimmten Zweck'''. Hierzu sind weitere Hinweise in der ''GNU General Public License'' enthalten.\n\nEine [$2 Kopie der GNU General Public License] sollte zusammen mit diesem Programm verteilt worden sein. Sofern dies nicht der Fall war, kann eine Kopie bei der Free Software Foundation Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA, schriftlich angefordert oder auf deren Website [https://www.gnu.org/copyleft/gpl.html online gelesen] werden.", "config-sidebar": "* [https://www.mediawiki.org/wiki/MediaWiki/de Website von MediaWiki]\n* [https://www.mediawiki.org/wiki/Special:MyLanguage/Help:Contents/de Benutzer­anleitung]\n* [https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:Contents/de Administratoren­anleitung]\n* [https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:FAQ/de Häufig gestellte Fragen]\n----\n* Lies mich\n* Versions­informationen\n* Lizenz­bestimmungen\n* Aktualisierung", + "config-sidebar-readme": "Lies mich", + "config-sidebar-relnotes": "Veröffentlichungsinformationen", + "config-sidebar-license": "Kopieren", + "config-sidebar-upgrade": "Aktualisieren", "config-env-good": "Die Installationsumgebung wurde geprüft.\nMediaWiki kann installiert werden.", "config-env-bad": "Die Installationsumgebung wurde geprüft.\nMediaWiki kann nicht installiert werden.", "config-env-php": "Die Skriptsprache „PHP“ ($1) ist installiert.", "config-env-hhvm": "HHVM $1 ist installiert.", - "config-unicode-using-intl": "Zur Unicode-Normalisierung wird die [https://pecl.php.net/intl PECL-Erweiterung intl] eingesetzt.", - "config-unicode-pure-php-warning": "'''Warnung:''' Die [https://pecl.php.net/intl PECL-Erweiterung intl] ist für die Unicode-Normalisierung nicht verfügbar, so dass stattdessen die langsame pure-PHP-Implementierung genutzt wird.\nSofern eine Website mit großer Benutzeranzahl betrieben wird, sollten weitere Informationen auf der Webseite [https://www.mediawiki.org/wiki/Special:MyLanguage/Unicode_normalization_considerations Unicode-Normalisierung (en)] gelesen werden.", + "config-unicode-using-intl": "Zur Unicode-Normalisierung wird die [https://www.php.net/manual/de/book.intl.php PHP-Erweiterung intl] eingesetzt.", + "config-unicode-pure-php-warning": "'''Warnung:''' Die [https://www.php.net/manual/de/book.intl.php PHP-Erweiterung intl] ist für die Unicode-Normalisierung nicht verfügbar, so dass stattdessen die langsame pure-PHP-Implementierung genutzt wird.\nSofern eine Website mit großer Benutzeranzahl betrieben wird, sollten weitere Informationen auf der Seite [https://www.mediawiki.org/wiki/Special:MyLanguage/Unicode_normalization_considerations Unicode-Normalisierung] gelesen werden.", "config-unicode-update-warning": "'''Warnung:''' Die installierte Version des Unicode-Normalisierungswrappers nutzt einer ältere Version der Bibliothek des [http://site.icu-project.org/ ICU-Projekts].\nDiese sollte [https://www.mediawiki.org/wiki/Special:MyLanguage/Unicode_normalization_considerations aktualisiert] werden, sofern auf die Verwendung von Unicode Wert gelegt wird.", "config-no-db": "Es konnte kein adäquater Datenbanktreiber gefunden werden. Es muss daher ein Datenbanktreiber für PHP installiert werden.\n{{PLURAL:$2|Das folgende Datenbanksystem wird|Die folgenden Datenbanksysteme werden}} unterstützt: $1\n\nWenn du PHP selbst kompiliert hast, konfiguriere es erneut mit einem aktivierten Datenbankclient, zum Beispiel durch Verwendung von ./configure --with-mysqli.\nWenn du PHP von einem Debian- oder Ubuntu-Paket installiert hast, dann musst du auch beispielsweise das php-mysql-Paket installieren.", - "config-outdated-sqlite": "'''Warnung:''' SQLite $1 ist installiert. Allerdings benötigt MediaWiki SQLite $2 oder höher. SQLite wird daher nicht verfügbar sein.", + "config-outdated-sqlite": "Warnung: du hast SQLite $2, was unter der benötigten Version $1 liegt. SQLite wird daher nicht verfügar sein.", "config-no-fts3": "'''Warnung:''' SQLite wurde ohne das [//sqlite.org/fts3.html FTS3-Modul] kompiliert, sodass keine Suchfunktionen für dieses Datenbanksystem zur Verfügung stehen werden.", "config-pcre-old": "Fataler Fehler: PCRE $1 oder neuer ist erforderlich!\nDie vorhandene PHP-Binärdatei ist mit PCRE $2 verknüpft.\n[https://www.mediawiki.org/wiki/Manual:Errors_and_symptoms/PCRE Weitere Informationen].", "config-pcre-no-utf8": "'''Fataler Fehler:''' Das PHP-Modul PCRE scheint ohne PCRE_UTF8-Unterstützung kompiliert worden zu sein.\nMediaWiki benötigt die UTF-8-Unterstützung, um fehlerfrei lauffähig zu sein.", diff --git a/includes/installer/i18n/diq.json b/includes/installer/i18n/diq.json index 721a8dc593..3617e18b93 100644 --- a/includes/installer/i18n/diq.json +++ b/includes/installer/i18n/diq.json @@ -27,7 +27,7 @@ "config-page-install": "Bar ke", "config-page-complete": "Temam!", "config-page-restart": "Barkerdışi fına ser kı", - "config-page-readme": "Mı bıwan", + "config-page-readme": "Mı bıwane", "config-page-releasenotes": "Notë versiyoni", "config-page-copying": "Kopyayeno", "config-page-upgradedoc": "Berzkerdış", diff --git a/includes/installer/i18n/io.json b/includes/installer/i18n/io.json index 74d8895172..3ce3fe2591 100644 --- a/includes/installer/i18n/io.json +++ b/includes/installer/i18n/io.json @@ -12,6 +12,7 @@ "config-localsettings-upgrade": "L'arkivo LocalSettings.php trovesis.\nPor plubonigar l'instaluro, voluntez informar la valoro dil $wgUpgradeKey en l'infra buxo.\nVu trovos ol en LocalSettings.php.", "config-session-error": "Eroro dum komenco di seciono: $1", "config-session-expired": "Vua sesiono probable finis.\nSesioni programesis por durar $1\nVu povas augmentar to per modifiko di session.gc_maxlifetime en php.ini.\nRikomencez l'instalo-procedo.", + "config-no-session": "La dati pri vua sesiono desaparis!\nVerifikez vua arkivo php.ini e certigez su pri session.save_path indikas la korekta libro di adresaro.", "config-your-language": "Vua idiomo:", "config-your-language-help": "Selektez l'idiomo por uzar dum l'instalo-procedo.", "config-wiki-language": "Wiki linguo:", @@ -36,23 +37,38 @@ "config-help-restart": "Ka vu deziras efacar omna dati qui vu sparis, e rikomencar la procedi pri instalo?", "config-restart": "Yes, rikomencez ol", "config-welcome-section-copyright": "=== Autoroyuro e termini ===\n\n$1\n\nCa informatikoprogramo esas libera; vu povas ridistributar ol e/o modifikar ol segun la termini de la Generala Licenco Publika GNU, quale stipulata da Free Software Foundation; segun lua versiono 2 o sequanta.\n\nNi expektas ke ca programo esas utila, kande ni distributas ol. Tamen, ni ne povas grantar ke ol fakte esos utila. Ni anke ne povas afirmar ke ol esos vendebla o ke ol esos utila por specifika intenco.\nLektez la Generala Licenco Publika GNU por plusa detali.\n\nKune ica programo vu certe recevis [$2 kopiuro di la Generala Licenco Publika GNU]. Se vu ne recevis ol, voluntez skribar a la fonduro Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA, o [https://www.gnu.org/copyleft/gpl.html lektez ol che l'interreto].", + "config-sidebar-readme": "Lektez me", + "config-sidebar-relnotes": "Informi pri la versiono", + "config-sidebar-license": "Kopiuro", + "config-sidebar-upgrade": "Nova versiono", "config-env-good": "Omno verifikesis.\nVu povas intalar MediaWiki.", "config-env-bad": "Omno verifikesis.\nVu NE POVAS intalar MediaWiki.", "config-env-php": "PHP $1 instalesis.", "config-env-hhvm": "HHVM $1 instalesis.", + "config-unicode-using-intl": "Uzanta [https://php.net/manual/en/book.intl.php PHP intl extension] por normaligo Unicode.", "config-unicode-pure-php-warning": "Atencez: La [https://php.net/manual/en/book.intl.php prolonguro PHP intl] ne esas disponebla por traktar skribo-normaligo \"Unicode\". Vice, uzesas la plu lenta laborado en pura PHP.\nSe vu administras pagini multe vizitata, vu mustas lektar la [https://www.mediawiki.org/wiki/Special:MyLanguage/Unicode_normalization_considerations skribo-normaligo Unicode].", + "config-unicode-update-warning": "Atencez: La versiono di ''Unicode normalization wrapper'' instalata en vua komputero uzas obsoleta versiono di la biblioteko del [http://site.icu-project.org/ projeto ICU].\nVu mustas instalar [https://www.mediawiki.org/wiki/Special:MyLanguage/Unicode_normalization_considerations la nova versiono] se vu deziras uzar Unicode.", "config-memory-raised": "Parametro memory_limit esas $1, modifikata a $2.", "config-memory-bad": "Atences: la limito por PHP memory_limit esas $1.\nTo probable esas nesuficanta.\nL'instalo-procedo povas faliar!", "config-apc": "[https://www.php.net/apc APC] instalesis", "config-apcu": "[https://www.php.net/apcu APCu] instalesis", "config-wincache": "[https://www.iis.net/downloads/microsoft/wincache-extension WinCache] instalesis", + "config-no-uri": "Eroro: Ne esis posibla identifikar l'existanta URI.\nInstalo interruptata.", + "config-no-cli-uri": "Avizo: Nula --scriptpath informata. Uzanta la preexistanta: $1.", + "config-using-server": "Uzanta ret-adreso (URL) dil servero \"$1\".", "config-using-uri": "Ret-adreso (URL) dil servero \"$1$2\".", + "config-db-type": "Tipo di datumaro:", + "config-db-host": "Loko dil datumaro:", "config-db-wiki-settings": "Identifikez ca wiki", "config-db-name": "Nomo dil datumaro (sen strekteti):", "config-db-install-account": "Konto dil uzero por instalo", "config-db-username": "Uzero-nomo dil datumaro:", "config-db-password": "Pasovorto dil datumaro:", "config-invalid-db-type": "Nevalida tipo di datumaro.", + "config-missing-db-name": "Vu mustas informar valoro por \"{{int:config-db-name}}\".", + "config-missing-db-host": "Vu mustas informar valoro por \"{{int:config-db-host}}\".", + "config-sqlite-readonly": "L'arkivo $1 esas nur lektebla.", + "config-sqlite-cant-create-db": "Ne povis krear l'arkivo di datumaro $1.", "config-ns-generic": "Projeto", "config-ns-site-name": "Sama kam la wiki-nomo: $1", "config-ns-other": "Altra (definez precise)", diff --git a/includes/installer/i18n/nap.json b/includes/installer/i18n/nap.json index c2d349af1c..ad0d285fbb 100644 --- a/includes/installer/i18n/nap.json +++ b/includes/installer/i18n/nap.json @@ -104,7 +104,7 @@ "config-db-schema-help": "Stu schema 'n genere sarrà buono.\nSi 'o vulite cagnà facite sulamente si ne tenite abbesuogno.", "config-pg-test-error": "Nun se può connettà a 'o database $1: $2", "config-sqlite-dir": "Cartella 'e data 'e SQLite:", - "config-sqlite-dir-help": "SQLite astipa tutte 'e date dint'a n'uneco file.\n\n'A cartella ca starraje a innecà adda essere scrivibbele d' 'o server webe pe' tramente ca sta l'istallazione.\n\nAvess'a essere nun trasibbele via web, è pecchesto ca nun se sta mettenno addò stanno 'e file PHP.\n\nL'installatore scriverrà nzieme a chesta nu file .htaccess, ma si 'o tentativo scassasse, coccheruno putesse tenè acciesso dint' 'o database ncruro.\nChesto pure cunzidera 'e date ncruro 'e ll'utente (indirizze, password cifrate) accussì comme 'e verziune luvate e ati dati d'accesso limmetato dint' 'o wiki.\n\nCunzidera ll'opportunità 'e sistimà ô tiempo 'o database 'a n'ata parte, p'esempio int'a /var/lib/mediawiki/tuowiki.", + "config-sqlite-dir-help": "SQLite astipa tutte 'e date dint'a n'uneco file.\n\n'A cartella ca starraje a innecà adda essere scrivibbele d' 'o server webe pe' tramente ca sta l'istallazione.\n\nAvess'a essere nun trasibbele via web, è pecchesto ca nun se sta mettenno addò stanno 'e file PHP.\n\nL'installatore scriverrà nzieme a chesta nu file .htaccess, ma si 'o tentativo scassasse, coccheruno putesse tenè acciesso dint' 'o database ncruro.\nChesto cunzidera purzì 'e date ncruro 'e ll'utente (indirizze, password cifrate) accussì comme 'e verziune luvate e ati dati d'accesso limmetato dint' 'o wiki.\n\nCunzidera ll'opportunità 'e sistimà ô tiempo 'o database 'a n'ata parte, p'esempio int'a /var/lib/mediawiki/tuowiki.", "config-type-mysql": "MariaDB, MySQL o compatibbele", "config-support-info": "MediaWiki supporta 'e sisteme 'e database ccà abbascio:\n\n$1\n\nSi nfra chiste ccà nun vedite 'o sistema 'e database ca vulite ausà, allora avite liegge 'e instruziune ccà ncoppa pe' ne dà supporto.", "config-dbsupport-mysql": "* [{{int:version-db-mariadb-url}} MariaDB] è 'a configurazione cchiù mmeglio p' 'o MediaWiki e è chilla meglio suppurtata. MediaWiki può faticà pure cu' [{{int:version-db-mariadb-url}} MariaDB] e [{{int:version-db-percona-url}} Percona Server], ca fossero MariaDB cumpatibbele. ([https://www.php.net/manual/en/mysqli.installation.php Comme s'adda fà pe' cumpilà PHP cu suppuorto MySQL])", diff --git a/includes/installer/i18n/pt.json b/includes/installer/i18n/pt.json index f08ea751b8..75e1cadb84 100644 --- a/includes/installer/i18n/pt.json +++ b/includes/installer/i18n/pt.json @@ -22,48 +22,49 @@ "MokaAkashiyaPT", "Athena in Wonderland", "CaiusSPQR", - "Waldyrious" + "Waldyrious", + "Mansil alfalb" ] }, "config-desc": "O instalador do MediaWiki", "config-title": "Instalação do MediaWiki $1", "config-information": "Informação", - "config-localsettings-upgrade": "Foi detetado um ficheiro LocalSettings.php.\nPara atualizar esta instalação, por favor introduza o valor de $wgUpgradeKey na caixa abaixo.\nEncontra este valor em LocalSettings.php.", - "config-localsettings-cli-upgrade": "Foi detetado um ficheiro LocalSettings.php.\nPara atualizar esta instalação, execute o update.php, por favor", + "config-localsettings-upgrade": "Foi detetado um ficheiro LocalSettings.php.\nPara atualizar esta instalação, por favor, insira o valor de $wgUpgradeKey na caixa abaixo.\nIrá encontrar este valor em LocalSettings.php.", + "config-localsettings-cli-upgrade": "Foi detetado um ficheiro LocalSettings.php.\nPara atualizar esta instalação, por favor, execute o update.php", "config-localsettings-key": "Chave de atualização:", "config-localsettings-badkey": "A chave de atualização que forneceu está incorreta.", - "config-upgrade-key-missing": "Foi detetada uma instalação existente do MediaWiki.\nPara atualizar esta instalação, por favor coloque a seguinte linha no final do seu LocalSettings.php:\n\n$1", - "config-localsettings-incomplete": "O ficheiro LocalSettings.php existente parece estar incompleto.\nA variável $1 não está definida.\nPor favor, defina esta variável no LocalSettings.php e clique \"{{int:Config-continue}}\".", + "config-upgrade-key-missing": "Foi detetada uma instalação existente do MediaWiki.\nPara atualizar esta instalação, por favor, coloque a seguinte linha no fim do seu LocalSettings.php:\n\n$1", + "config-localsettings-incomplete": "O ficheiro existente LocalSettings.php parece estar incompleto.\nA variável $1 não está definida.\nPor favor, altere LocalSettings.php e assim esta variável é definida, e clique em \"{{int:Config-continue}}\".", "config-localsettings-connection-error": "Ocorreu um erro ao ligar à base de dados usando as configurações especificadas no LocalSettings.php. Por favor corrija essas configurações e tente novamente.\n\n$1", "config-session-error": "Erro ao iniciar a sessão: $1", "config-session-expired": "Os seus dados de sessão parecem ter expirado.\nAs sessões estão configuradas para uma duração de $1.\nPode aumentar esta duração configurando session.gc_maxlifetime no php.ini.\nReinicie o processo de instalação.", "config-no-session": "Os seus dados de sessão foram perdidos!\nVerifique o seu php.ini e certifique-se de que em session.save_path está definido um diretório apropriado.", - "config-your-language": "A sua língua:", - "config-your-language-help": "Selecione a língua que será usada durante o processo de instalação.", - "config-wiki-language": "Língua da wiki:", - "config-wiki-language-help": "Selecione a língua que será predominante na wiki.", + "config-your-language": "O seu idioma:", + "config-your-language-help": "Selecione o idioma que será utilizado durante o processo de instalação.", + "config-wiki-language": "Idioma da wiki:", + "config-wiki-language-help": "Selecione o idioma que a wiki será predominante escrita.", "config-back": "← Voltar", "config-continue": "Continuar →", - "config-page-language": "Língua", - "config-page-welcome": "Bem-vindo(a) ao MediaWiki!", + "config-page-language": "Idioma", + "config-page-welcome": "Bem-vindo ao MediaWiki!", "config-page-dbconnect": "Ligar à base de dados", "config-page-upgrade": "Atualizar a instalação existente", "config-page-dbsettings": "Configurações da base de dados", "config-page-name": "Nome", "config-page-options": "Opções", "config-page-install": "Instalar", - "config-page-complete": "Terminado!", + "config-page-complete": "Concluída!", "config-page-restart": "Reiniciar a instalação", "config-page-readme": "Leia-me", "config-page-releasenotes": "Notas de lançamento", "config-page-copying": "A copiar", "config-page-upgradedoc": "A atualizar", "config-page-existingwiki": "Wiki existente", - "config-help-restart": "Deseja limpar todos os dados gravados que introduziu e reiniciar o processo de instalação?", + "config-help-restart": "Deseja limpar todos os dados guardados que inseriu e reiniciar o processo de instalação?", "config-restart": "Sim, reiniciar", "config-welcome": "=== Verificações do ambiente ===\nSerão agora realizadas verificações básicas para determinar se este ambiente é apropriado para instalação do MediaWiki.\nLembre-se de fornecer esta informação se necessitar de pedir ajuda para concluir a instalação.", - "config-welcome-section-copyright": "=== Direitos de autor e Condições de utilização ===\n\n$1\n\nEste programa é software livre; pode redistribuí-lo e/ou modificá-lo nos termos da licença GNU General Public License, tal como publicada pela Free Software Foundation; tanto a versão 2 da Licença, como (por opção sua) qualquer versão posterior.\n\nEste programa é distribuído na esperança de que seja útil, mas '''sem qualquer garantia'''; inclusive, sem a garantia implícita da '''possibilidade de ser comercializado''' ou de '''adequação para qualquer finalidade específica'''.\nConsulte a licença GNU General Public License para mais detalhes.\n\nEm conjunto com este programa deve ter recebido [$2 uma cópia da licença GNU General Public License]; se não a recebeu, peça-a por escrito a Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA ou [https://www.gnu.org/copyleft/gpl.html leia-a na Internet].", - "config-sidebar": "* [https://www.mediawiki.org/wiki/MediaWiki/pt Página principal do MediaWiki]\n* [https://www.mediawiki.org/wiki/Special:MyLanguage/Help:Contents/pt Ajuda]\n* [https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:Contents/pt Manual técnico]\n* [https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:FAQ/pt FAQ]", + "config-welcome-section-copyright": "=== Direitos de Autor e Termos ===\n\n$1\n\nEste programa é um software livre; pode redistribuí-lo e/ou modificá-lo nos termos da Licença Pública Geral GNU, tal como publicada pela Free Software Foundation; tanto a versão 2 da Licença, como (por opção sua) qualquer versão mais recente.\n\nEste programa é distribuído na esperança de que seja útil, mas '''sem qualquer garantia'''; inclusive, sem a garantia implícita da '''possibilidade de ser comercializado''' ou de '''adequação para qualquer finalidade específica'''.\nConsulte a Licença Pública Geral GNU para mais detalhes.\n\nEm conjunto com este programa deveria ter recebido [$2 uma cópia da Licença Pública Geral GNU]; se não, peça-a por escrito a Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA ou [https://www.gnu.org/copyleft/gpl.html leia-a on-line].", + "config-sidebar": "* [https://www.mediawiki.org/wiki/MediaWiki/pt Página principal do MediaWiki]\n* [https://www.mediawiki.org/wiki/Help:Contents/pt Guia do Utilizador]\n* [https://www.mediawiki.org/wiki/Manual:Contents/pt Guia do Administrador]\n* [https://www.mediawiki.org/wiki/Manual:FAQ/pt Perguntas Mais Frequentes]", "config-sidebar-readme": "Leia-me", "config-sidebar-relnotes": "Notas de lançamento", "config-sidebar-license": "Copiar", @@ -81,12 +82,12 @@ "config-pcre-old": "Erro fatal: É necessário o PCRE $1 ou versão posterior.\nO seu binário PHP foi linkado com o PCRE $2.\n[https://www.mediawiki.org/wiki/Manual:Errors_and_symptoms/PCRE Mais informações].", "config-pcre-no-utf8": "'''Erro fatal''': O módulo PCRE do PHP parece ter sido compilado sem suporte PCRE_UTF8.\nO MediaWiki necessita do suporte UTF-8 para funcionar corretamente.", "config-memory-raised": "A configuração memory_limit do PHP era $1; foi aumentada para $2.", - "config-memory-bad": "Aviso: A configuração memory_limit do PHP é $1.\nIsto é provavelmente demasiado baixo.\nA instalação poderá falhar!", - "config-apc": "[https://www.php.net/apc APC] instalada", - "config-apcu": "[https://www.php.net/apcu APCu] instalado", - "config-wincache": "[https://www.iis.net/downloads/microsoft/wincache-extension WinCache] instalada", - "config-no-cache-apcu": "Aviso: Não foi encontrado o [https://www.php.net/apcu APCu] nem o [https://www.iis.net/downloads/microsoft/wincache-extension WinCache].\nA cache de objetos não está ativa.", - "config-mod-security": "Aviso: O seu servidor de Internet tem o [https://modsecurity.org/ mod_security]/mod_security2 ativado. Muitas das suas configurações normais podem causar problemas ao MediaWiki e a outros programas, permitindo que os utilizadores publiquem conteúdos arbitrários.\nSe possível, isto deve ser desativado. Se não, consulte a [https://modsecurity.org/documentation/ mod_security documentação] ou peça apoio ao fornecedor do alojamento do seu servidor se encontrar erros aleatórios.", + "config-memory-bad": "Aviso: o parâmetro memory_limit é $1.\nIsto é provavelmente demasiado baixo.\nA instalação poderá falhar!", + "config-apc": "[https://www.php.net/apc APC] está instalada", + "config-apcu": "[https://www.php.net/apcu APCu] está instalado", + "config-wincache": "[https://www.iis.net/downloads/microsoft/wincache-extension WinCache] está instalada", + "config-no-cache-apcu": "Aviso: não foi possível encontrar o [https://www.php.net/apcu APCu] ou a [https://www.iis.net/downloads/microsoft/wincache-extension WinCache].\nA colocação em cache dos objetos não está ativa.", + "config-mod-security": "Aviso: o seu servidor da Web tem o [https://modsecurity.org/ mod_security]/mod_security2 ativado. Muitas configurações comuns irão causar problemas ao MediaWiki e a outro software que permite que os utilizadores publiquem conteúdos arbitrários.\nSe possível, isto deverá ser desativado. Se não, consulte a [https://modsecurity.org/documentation/ mod_security documentação] ou contacte o apoio do seu alojamento se encontrar erros aleatórios.", "config-diff3-bad": "O utilitário de comparação de texto GNU diff3 não foi encontrado. Pode ignorar esta situação por agora, mas poderá encontrar conflitos entre edições mais frequentemente.", "config-git": "Foi encontrado o software de controlo de versões Git: $1.", "config-git-bad": "Não foi encontrado o programa de controlo de versões Git. Pode ignorar esta situação por agora. Note que Especial:Versão não apresentará os resumos criptográficos das efetivações.", @@ -100,7 +101,7 @@ "config-uploads-not-safe": "Aviso: O diretório por omissão para carregamentos, $1, está vulnerável à execução arbitrária de listas de comandos (scripts).\nEmbora o MediaWiki verifique a existência de ameaças de segurança em todos os ficheiros enviados, é altamente recomendado que [https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:Security#Upload_security vede esta vulnerabilidade de segurança] antes de possibilitar uploads.", "config-no-cli-uploads-check": "Aviso: O diretório por omissão para carregamentos, $1, não é verificado para determinar se é vulnerável à execução de listas arbitrárias de comandos durante a instalação por CLI (\"Command-line Interface\").", "config-brokenlibxml": "O seu sistema tem uma combinação de versões do PHP e do libxml2 conhecida por ser problemática, podendo causar corrupção de dados no MediaWiki e noutras aplicações da Internet.\nAtualize para a versão 2.7.3 ou posterior do libxml2 ([https://bugs.php.net/bug.php?id=45996 incidência reportada no PHP]).\nInstalação cancelada.", - "config-suhosin-max-value-length": "O Suhosin está instalado e limita o parâmetro GET length a $1 bytes.\nO componente ResourceLoader do MediaWiki consegue exceder este limite, mas prejudicando o desempenho.\nSe lhe for possível, deve atribuir ao parâmetro suhosin.get.max_value_length o valor 1024 ou maior no ficheiro php.ini, e definir o mesmo valor para $wgResourceLoaderMaxQueryLength no ficheiro LocalSettings.php.", + "config-suhosin-max-value-length": "O Suhosin está instalado e limita o parâmetro GET length a $1 bytes.\nO MediaWiki requer que suhosin.get.max_value_length seja pelo menos $2. Desative esta definição, ou aumente este valor para $3 no php.ini.", "config-using-32bit": "Aviso: o seu sistema parece estar a funcionar com inteiros de 32 bits. Isto [https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:32-bit não é recomendado].", "config-db-type": "Tipo da base de dados:", "config-db-host": "Servidor da base de dados:", @@ -110,59 +111,59 @@ "config-db-name-help": "Escolha um nome para identificar a sua wiki.\nO nome não deve conter espaços.\n\nSe estiver a usar um servidor partilhado, o fornecedor do alojamento deve poder fornecer-lhe o nome de uma base de dados que possa usar, ou permite-lhe criar bases de dados através de um painel de controlo.", "config-db-install-account": "Conta do utilizador para a instalação", "config-db-username": "Nome do utilizador da base de dados:", - "config-db-password": "Palavra-passe do utilizador da base de dados:", - "config-db-install-username": "Introduza o nome de utilizador que será usado para aceder à base de dados durante o processo de instalação. Este utilizador não é o do MediaWiki; é o utilizador da base de dados.", + "config-db-password": "Palavra-passe da base de dados:", + "config-db-install-username": "Insira o nome de utilizador que será utilizado para aceder à base de dados durante o processo de instalação.\nNão é o nome de utilizador da conta MediaWiki; é o nome de utilizador da sua base de dados.", "config-db-install-password": "Introduza a palavra-passe do utilizador que será usado para aceder à base de dados durante o processo de instalação.\nEsta palavra-passe não é a do utilizador do MediaWiki; é a palavra-passe do utilizador da base de dados.", "config-db-install-help": "Introduza o nome de utilizador e a palavra-passe que serão usados para aceder à base de dados durante o processo de instalação.", "config-db-account-lock": "Usar o mesmo nome de utilizador e palavra-passe durante a operação normal", "config-db-wiki-account": "Conta de utilizador para a operação normal", "config-db-wiki-help": "Introduza o nome de utilizador e a palavra-passe que serão usados para aceder à base de dados durante a operação normal da wiki.\nSe o utilizador não existir na base de dados, mas a conta de instalação tiver privilégios suficientes, o utilizador que introduzir será criado na base de dados com os privilégios mínimos necessários para a operação normal da wiki.", - "config-db-prefix": "Prefixo para as tabelas da base de dados (sem hífenes):", + "config-db-prefix": "Prefixo para a tabela da base de dados (sem hífenes):", "config-db-prefix-help": "Se necessitar de partilhar uma só base de dados entre várias wikis, ou entre o MediaWiki e outra aplicação, pode escolher adicionar um prefixo ao nome de todas as tabelas desta instalação, para evitar conflitos.\nNão use espaços.\n\nNormalmente, este campo deve ficar vazio.", - "config-mysql-old": "É necessário o MySQL $1 ou posterior; tem a versão $2.", + "config-mysql-old": "É necessário o MySQL $1 ou superior. Tem a versão $2.", "config-db-port": "Porta da base de dados:", - "config-db-schema": "Esquema ''(schema)'' do MediaWiki (sem hífenes):", - "config-db-schema-help": "Normalmente, este esquema estará correto.\nAltere-o só se souber que precisa de o fazer.", - "config-pg-test-error": "Não foi possível criar uma ligação à base de dados $1: $2", - "config-sqlite-dir": "Diretório de dados do SQLite:", + "config-db-schema": "Esquema para o MediaWiki (sem hífenes):", + "config-db-schema-help": "Normalmente, este esquema estará correto.\nAltere-o apenas se souber que precisa de o fazer.", + "config-pg-test-error": "Não é possível aceder à base de dados $1: $2", + "config-sqlite-dir": "Diretoria de dados do SQLite:", "config-sqlite-dir-help": "O SQLite armazena todos os dados num único ficheiro.\n\nDurante a instalação, o servidor de Internet precisa de ter permissão de escrita no diretório que especificar.\n\nEste diretório não deve poder ser acedido diretamente da Internet, por isso está a ser colocado onde estão os seus ficheiros PHP.\n\nJuntamente com o diretório, o instalador irá criar um ficheiro .htaccess, mas se esta operação falhar é possível que alguém venha a ter acesso direto à base de dados.\nIsto inclui acesso aos dados dos utilizadores (endereços de correio eletrónico, palavras-passe encriptadas), às revisões eliminadas e a outros dados de acesso restrito na wiki.\n\nConsidere colocar a base de dados num local completamente diferente, como, por exemplo, em /var/lib/mediawiki/asuawiki.", "config-type-mysql": "MariaDB, MySQL (ou compatível)", "config-type-postgres": "PostgreSQL", "config-type-sqlite": "SQLite", - "config-support-info": "O MediaWiki suporta as seguintes plataformas de base de dados:\n\n$1\n\nSe a plataforma que pretende usar não está listada abaixo, siga as instruções nas hiperligações acima para ativar o suporte.", - "config-dbsupport-mysql": "* [{{int:version-db-mariadb-url}} MariaDB] é a base de dados preferida para o MediaWiki e a melhor suportada. O MediaWiki também trabalha com [{{int:version-db-mysql-url}} MySQL] e [{{int:version-db-percona-url}} Percona Server], que são compatíveis com MariaDB. ([https://www.php.net/manual/pt_BR/mysqli.installation.php Como compilar PHP com suporte para MySQL].)", + "config-support-info": "O MediaWiki suporta os seguintes sistemas de base de dados:\n\n$1\n\nSe não vê o sistema da base de dados que está a tentar utilizar listado abaixo, siga as instruções nas hiperligações acima para ativar o apoio.", + "config-dbsupport-mysql": "* [{{int:version-db-mariadb-url}} MariaDB] é a base de dados primária para o MediaWiki e a melhor suportada. O MediaWiki também trabalha com [{{int:version-db-mysql-url}} MySQL] e [{{int:version-db-percona-url}} Servidor Percona], que são compatíveis com MariaDB. ([https://www.php.net/manual/en/mysqli.installation.php Como compilar PHP com suporte para MySQL].)", "config-dbsupport-postgres": "* O [{{int:version-db-postgres-url}} PostgreSQL] é uma plataforma popular de base de dados de código aberto, alternativa ao MySQL. ([https://www.php.net/manual/en/pgsql.installation.php Como compilar PHP com suporte para PostgreSQL].)", "config-dbsupport-sqlite": "* O [{{int:version-db-sqlite-url}} SQLite] é uma plataforma de base de dados ligeira muito bem suportada. ([https://www.php.net/manual/en/pdo.installation.php Como compilar PHP com suporte para SQLite], usa PDO.)", - "config-header-mysql": "Definições MariaDB/MySQL", - "config-header-postgres": "Definições PostgreSQL", - "config-header-sqlite": "Definições SQLite", - "config-invalid-db-type": "O tipo de base de dados é inválido", - "config-missing-db-name": "Tem de introduzir um valor para \"{{int:config-db-name}}\".", - "config-missing-db-host": "Tem de introduzir um valor para \"{{int:config-db-host}}\".", - "config-invalid-db-name": "O nome da base de dados, \"$1\", é inválido.\nUse só letras (a-z, A-Z), algarismos (0-9), sublinhados (_) e hífens (-) dos caracteres ASCII.", - "config-invalid-db-prefix": "O prefixo da base de dados, \"$1\", é inválido.\nUse só letras (a-z, A-Z), algarismos (0-9), sublinhados (_) e hífens (-) dos caracteres ASCII.", + "config-header-mysql": "Definições de MariaDB/MySQL", + "config-header-postgres": "Definições de PostgreSQL", + "config-header-sqlite": "Definições de SQLite", + "config-invalid-db-type": "O tipo de base de dados é inválido.", + "config-missing-db-name": "Deve inserir um valor para \"{{int:config-db-name}}\".", + "config-missing-db-host": "Deve inserir um valor para \"{{int:config-db-host}}\".", + "config-invalid-db-name": "O nome da base de dados \"$1\" é inválido.\nUtilize apenas letras ASCII (a-z, A-Z), números (0-9), sublinhados (_) e hífenes (-).", + "config-invalid-db-prefix": "O prefixo da base de dados \"$1\" é inválido.\nUtilize apenas letras ASCII (a-z, A-Z), números (0-9), sublinhados (_) e hífenes (-).", "config-connection-error": "$1.\n\nVerifique o servidor, o nome do utilizador e a palavra-passe e tente novamente. Se estiver a usar \"localhost\" como servidor da base de dados, tente antes usar \"127.0.0.1\" (ou vice-versa).", "config-invalid-schema": "O esquema ''(schema)'' do MediaWiki, \"$1\", é inválido.\nUse só letras (a-z, A-Z), algarismos (0-9) e sublinhados (_) dos caracteres ASCII.", - "config-postgres-old": "É necessário o PostgreSQL $1 ou posterior; tem a versão $2.", - "config-sqlite-name-help": "Escolha o nome que identificará a sua wiki.\nNão use espaços ou hífens.\nEste nome será usado como nome do ficheiro de dados do SQLite.", - "config-sqlite-parent-unwritable-group": "Não é possível criar o diretório de dados $1, porque o servidor de internet não tem permissão de escrita no diretório que o contém $2.\n\nO instalador determinou em que nome de utilizador o seu servidor de internet está a correr.\nPara continuar, configure o diretório $3 para poder ser escrito por este utilizador.\nPara fazê-lo em sistemas Unix ou Linux, use:\n\n
cd $2\nmkdir $3\nchgrp $4 $3\nchmod g+w $3
", - "config-sqlite-parent-unwritable-nogroup": "Não é possível criar o diretório de dados $1, porque o servidor de internet não tem permissão de escrita no diretório que o contém $2.\n\nNão foi possível determinar em que nome de utilizador o seu servidor de internet está a correr.\nPara continuar, configure o diretório $3 para que este possa ser globalmente escrito por esse utilizador (e por outros!).\nPara fazê-lo em sistemas Unix ou Linux, use:\n\n
cd $2\nmkdir $3\nchmod a+w $3
", - "config-sqlite-mkdir-error": "Ocorreu um erro ao criar o diretório de dados \"$1\".\nVerifique a localização e tente novamente.", - "config-sqlite-dir-unwritable": "Não foi possível escrever no diretório \"$1\".\nAltere as permissões para que ele possa ser escrito pelo servidor de internet e tente novamente.", - "config-sqlite-connection-error": "$1.\n\nVerifique o diretório de dados e o nome da base de dados abaixo e tente novamente.", - "config-sqlite-readonly": "Não é possível escrever no ficheiro $1.", + "config-postgres-old": "É necessário o PostgreSQL $1 ou superior. Tem a versão $2.", + "config-sqlite-name-help": "Escolha um nome que identifique a sua wiki.\nNão utilize espaços ou hífenes.\nIsto será utilizado para o nome do ficheiro dos dados de SQLite.", + "config-sqlite-parent-unwritable-group": "Não é possível criar a diretoria de dados $1, porque a diretoria fonte $2 não é gravável pelo servidor da Web.\n\nO instalador determinou o nome de utilizador que o seu servidor da Web está a executar.\nTorne a diretoria $3 gravável para continuar.\nPara fazê-lo no sistema Unix/Linux:\n\n
cd $2\nmkdir $3\nchgrp $4 $3\nchmod g+w $3
", + "config-sqlite-parent-unwritable-nogroup": "Não é possível criar a diretoria de dados $1, porque o a diretoria fonte $2 não é gravável pelo servidor da Web.\n\nO instalador não conseguiu determinar em que nome de utilizador o seu servidor da Web está em execução.\nTorne a diretoria $3 globalmente gravável por esta (e por outros!) para continuar.\nPara fazê-lo no sistema Unix/Linux:\n\n
cd $2\nmkdir $3\nchmod a+w $3
", + "config-sqlite-mkdir-error": "Ocorreu um erro ao criar a diretoria de dados \"$1\".\nVerifique a localização e tente novamente.", + "config-sqlite-dir-unwritable": "Não foi possível escrever na diretoria \"$1\".\nAltere as suas permissões para que o servidor da Web possa gravar na mesma, e tente novamente.", + "config-sqlite-connection-error": "$1.\n\nVerifique a diretoria de dados e o nome da base de dados abaixo e tente novamente.", + "config-sqlite-readonly": "O ficheiro $1 não é gravável.", "config-sqlite-cant-create-db": "Não foi possível criar o ficheiro da base de dados $1.", - "config-sqlite-fts3-downgrade": "O PHP não tem suporte FTS3; a reverter o esquema das tabelas para o anterior", - "config-can-upgrade": "Esta base de dados contém tabelas do MediaWiki.\nPara atualizá-las para o MediaWiki $1, clique '''Continuar'''.", - "config-upgrade-error": "Ocorreu um erro ao atualizar as tabelas do MediaWiki na sua base de dados.\n\nPara mais informações consulte o registo acima, para tentar novamente clique Continuar.", - "config-upgrade-done": "Atualização terminada.\n\nAgora pode [$1 começar a usar a sua wiki].\n\nSe quiser regenerar o seu ficheiro LocalSettings.php, clique o botão abaixo.\nEsta operação '''não é recomendada''' a menos que esteja a ter problemas com a sua wiki.", - "config-upgrade-done-no-regenerate": "Atualização terminada.\n\nAgora pode [$1 começar a usar a sua wiki].", - "config-regenerate": "Regenerar o LocalSettings.php →", - "config-show-table-status": "A consulta SHOW TABLE STATUS falhou!", - "config-unknown-collation": "'''Aviso:''' A base de dados está a utilizar uma colação ''(collation)'' desconhecida.", - "config-db-web-account": "Conta na base de dados para acesso pela internet", - "config-db-web-help": "Selecione o nome de utilizador e a palavra-passe que o servidor de Internet irá utilizar para aceder ao servidor da base de dados, durante a operação normal da wiki.", - "config-db-web-account-same": "Usar a mesma conta usada na instalação", + "config-sqlite-fts3-downgrade": "PHP tem em falta o suporte para FTS3; a reverter as tabelas para estado antigo.", + "config-can-upgrade": "Existem tabelas do MediaWiki nesta base de dados.\nPara atualizá-las para o MediaWiki $1, clique em Continuar.", + "config-upgrade-error": "Ocorreu um erro ao atualizar as tabelas do MediaWiki na sua base de dados.\n\nPara mais informação consulte o registo acima, para tentar novamente clique em Continuar.", + "config-upgrade-done": "Atualização concluída.\n\nAgora pode [$1 começar a utilizar a sua wiki].\n\nSe quiser regenerar o seu ficheiro LocalSettings.php, clique no botão abaixo.\nIsto não é recomendada a menos que esteja a ter problemas com a sua wiki.", + "config-upgrade-done-no-regenerate": "Atualização concluída.\n\nAgora pode [$1 começar a utilizar a sua wiki].", + "config-regenerate": "Regenerar LocalSettings.php →", + "config-show-table-status": "A consulta de SHOW TABLE STATUS falhou!", + "config-unknown-collation": "Aviso: a base de dados está a utilizar uma colação desconhecida.", + "config-db-web-account": "Conta da base de dados para aceder à Web", + "config-db-web-help": "Selecione o nome de utilizador e a palavra-passe que o servidor da Web irá utilizar para aceder ao servidor da base de dados, durante a operação normal da wiki.", + "config-db-web-account-same": "Utilizar a mesma conta usada na instalação", "config-db-web-create": "Criar a conta se ainda não existir", "config-db-web-no-create-privs": "A conta que especificou para a instalação não tem privilégios suficientes para criar uma conta.\nA conta que especificar aqui já tem de existir.", "config-mysql-engine": "Motor de armazenamento:", diff --git a/includes/installer/i18n/ru.json b/includes/installer/i18n/ru.json index 3343d15768..2dbc294c96 100644 --- a/includes/installer/i18n/ru.json +++ b/includes/installer/i18n/ru.json @@ -107,7 +107,7 @@ "config-uploads-not-safe": "'''Внимание:''' директория, используемая по умолчанию для загрузок ($1) уязвима к выполнению произвольных скриптов.\nХотя MediaWiki проверяет все загружаемые файлы на наличие угроз, настоятельно рекомендуется [https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:Security#Upload_security закрыть данную уязвимость] перед включением загрузки файлов.", "config-no-cli-uploads-check": "'''Предупреждение:''' каталог для загрузки по умолчанию ( $1 ) не проверялся на уязвимости\n на выполнение произвольного сценария во время установки CLI.", "config-brokenlibxml": "В вашей системе имеется сочетание версий PHP и libxml2, которое может привести к скрытым повреждениям данных в MediaWiki и других веб-приложениях.\nОбновите libxml2 до версии 2.7.3 или старше ([https://bugs.php.net/bug.php?id=45996 сведения об ошибке]).\nУстановка прервана.", - "config-suhosin-max-value-length": "Suhosin установлен и ограничивает параметр GET length до $1 {{PLURAL:$1|байт|байта|байт}}. Компонент MediaWiki ResourceLoader будет обходить это ограничение, но это снизит производительность. Если это возможно, следует установить suhosin.get.max_value_length в значение 1024 или выше в php.ini, а также установить для $wgResourceLoaderMaxQueryLength такое же значение в LocalSettings.php.", + "config-suhosin-max-value-length": "Suhosin установлен и ограничивает параметр GET length до $1 {{PLURAL:$1|байт|байта|байт}}. Для MediaWiki требуется, чтоб значение suhosin.get.max_value_length было хотя бы $2. Отключите эту настройку или увеличьте значение в php.ini до $3.", "config-using-32bit": "Внимание: похоже, ваша система работает с 32-битными целыми числами. Это [https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:32-bit не рекомендуется].", "config-db-type": "Тип базы данных:", "config-db-host": "Хост базы данных:", diff --git a/includes/libs/MemoizedCallable.php b/includes/libs/MemoizedCallable.php index 5e7485c279..f5112295fc 100644 --- a/includes/libs/MemoizedCallable.php +++ b/includes/libs/MemoizedCallable.php @@ -48,6 +48,9 @@ class MemoizedCallable { /** @var string Unique name of callable; used for cache keys. */ private $callableName; + /** @var int */ + private $ttl; + /** * @throws InvalidArgumentException if $callable is not a callable. * @param callable $callable Function or method to memoize. diff --git a/includes/libs/StringUtils.php b/includes/libs/StringUtils.php index 51d108168a..19dd8fe4d3 100644 --- a/includes/libs/StringUtils.php +++ b/includes/libs/StringUtils.php @@ -1,4 +1,7 @@ doExecuteOpHandlesInternal( $fileOpHandles ); + $statuses = $this->doExecuteOpHandlesInternal( $fileOpHandles ); foreach ( $fileOpHandles as $fileOpHandle ) { $fileOpHandle->closeResources(); } - return $res; + return $statuses; } /** diff --git a/includes/libs/filebackend/SwiftFileBackend.php b/includes/libs/filebackend/SwiftFileBackend.php index edea75f71a..ce1e99f5da 100644 --- a/includes/libs/filebackend/SwiftFileBackend.php +++ b/includes/libs/filebackend/SwiftFileBackend.php @@ -172,64 +172,33 @@ class SwiftFileBackend extends FileBackendStore { } /** - * Sanitize and filter the custom headers from a $params array. - * Only allows certain "standard" Content- and X-Content- headers. + * Filter/normalize a header map to only include mutable "content-"/"x-content-" headers * - * @param array $params - * @return array Sanitized value of 'headers' field in $params - */ - protected function sanitizeHdrsStrict( array $params ) { - if ( !isset( $params['headers'] ) ) { - return []; - } - - $headers = $this->getCustomHeaders( $params['headers'] ); - unset( $headers[ 'content-type' ] ); - - return $headers; - } - - /** - * Sanitize and filter the custom headers from a $params array. - * Only allows certain "standard" Content- and X-Content- headers. - * - * When POSTing data, libcurl adds Content-Type: application/x-www-form-urlencoded - * if Content-Type is not set, which overwrites the stored Content-Type header - * in Swift - therefore for POSTing data do not strip the Content-Type header (the - * previously-stored header that has been already read back from swift is sent) + * Mutable headers can be changed via HTTP POST even if the file content is the same * - * @param array $params - * @return array Sanitized value of 'headers' field in $params + * @see https://docs.openstack.org/api-ref/object-store + * @param string[] $headers Map of (header => value) for a swift object + * @return string[] Map of (header => value) for Content-* headers mutable via POST */ - protected function sanitizeHdrs( array $params ) { - return isset( $params['headers'] ) - ? $this->getCustomHeaders( $params['headers'] ) - : []; - } - - /** - * @param array $rawHeaders - * @return array Custom non-metadata HTTP headers - */ - protected function getCustomHeaders( array $rawHeaders ) { - $headers = []; - + protected function extractMutableContentHeaders( array $headers ) { + $contentHeaders = []; // Normalize casing, and strip out illegal headers - foreach ( $rawHeaders as $name => $value ) { + foreach ( $headers as $name => $value ) { $name = strtolower( $name ); - if ( preg_match( '/^content-length$/', $name ) ) { - continue; // blacklisted - } elseif ( preg_match( '/^(x-)?content-/', $name ) ) { - $headers[$name] = $value; // allowed - } elseif ( preg_match( '/^content-(disposition)/', $name ) ) { - $headers[$name] = $value; // allowed + if ( !preg_match( '/^(x-)?content-(?!length$)/', $name ) ) { + // Only allow content-* and x-content-* headers (but not content-length) + continue; + } elseif ( $name === 'content-type' && !strlen( $value ) ) { + // This header can be set to a value but not unset for sanity + continue; } + $contentHeaders[$name] = $value; } // By default, Swift has annoyingly low maximum header value limits - if ( isset( $headers['content-disposition'] ) ) { + if ( isset( $contentHeaders['content-disposition'] ) ) { $disposition = ''; // @note: assume FileBackend::makeContentDisposition() already used - foreach ( explode( ';', $headers['content-disposition'] ) as $part ) { + foreach ( explode( ';', $contentHeaders['content-disposition'] ) as $part ) { $part = trim( $part ); $new = ( $disposition === '' ) ? $part : "{$disposition};{$part}"; if ( strlen( $new ) <= 255 ) { @@ -238,36 +207,40 @@ class SwiftFileBackend extends FileBackendStore { break; // too long; sigh } } - $headers['content-disposition'] = $disposition; + $contentHeaders['content-disposition'] = $disposition; } - return $headers; + return $contentHeaders; } /** - * @param array $rawHeaders - * @return array Custom metadata headers + * @see https://docs.openstack.org/api-ref/object-store + * @param string[] $headers Map of (header => value) for a swift object + * @return string[] Map of (metadata header name => metadata value) */ - protected function getMetadataHeaders( array $rawHeaders ) { - $headers = []; - foreach ( $rawHeaders as $name => $value ) { + protected function extractMetadataHeaders( array $headers ) { + $metadataHeaders = []; + foreach ( $headers as $name => $value ) { $name = strtolower( $name ); if ( strpos( $name, 'x-object-meta-' ) === 0 ) { - $headers[$name] = $value; + $metadataHeaders[$name] = $value; } } - return $headers; + return $metadataHeaders; } /** - * @param array $rawHeaders - * @return array Custom metadata headers with prefix removed + * @see https://docs.openstack.org/api-ref/object-store + * @param string[] $headers Map of (header => value) for a swift object + * @return string[] Map of (metadata key name => metadata value) */ - protected function getMetadata( array $rawHeaders ) { + protected function getMetadataFromHeaders( array $headers ) { + $prefixLen = strlen( 'x-object-meta-' ); + $metadata = []; - foreach ( $this->getMetadataHeaders( $rawHeaders ) as $name => $value ) { - $metadata[substr( $name, strlen( 'x-object-meta-' ) )] = $value; + foreach ( $this->extractMetadataHeaders( $headers ) as $name => $value ) { + $metadata[substr( $name, $prefixLen )] = $value; } return $metadata; @@ -283,19 +256,24 @@ class SwiftFileBackend extends FileBackendStore { return $status; } - $sha1Hash = Wikimedia\base_convert( sha1( $params['content'] ), 16, 36, 31 ); - $contentType = $params['headers']['content-type'] + // Headers that are not strictly a function of the file content + $mutableHeaders = $this->extractMutableContentHeaders( $params['headers'] ?? [] ); + // Make sure that the "content-type" header is set to something sensible + $mutableHeaders['content-type'] = $mutableHeaders['content-type'] ?? $this->getContentType( $params['dst'], $params['content'], null ); $reqs = [ [ 'method' => 'PUT', 'url' => [ $dstCont, $dstRel ], - 'headers' => [ - 'content-length' => strlen( $params['content'] ), - 'etag' => md5( $params['content'] ), - 'content-type' => $contentType, - 'x-object-meta-sha1base36' => $sha1Hash - ] + $this->sanitizeHdrsStrict( $params ), + 'headers' => array_merge( + $mutableHeaders, + [ + 'etag' => md5( $params['content'] ), + 'content-length' => strlen( $params['content'] ), + 'x-object-meta-sha1base36' => + Wikimedia\base_convert( sha1( $params['content'] ), 16, 36, 31 ) + ] + ), 'body' => $params['content'] ] ]; @@ -309,6 +287,8 @@ class SwiftFileBackend extends FileBackendStore { } else { $this->onError( $status, $method, $params, $rerr, $rcode, $rdesc ); } + + return SwiftFileOpHandle::CONTINUE_IF_OK; }; $opHandle = new SwiftFileOpHandle( $this, $handler, $reqs ); @@ -331,35 +311,57 @@ class SwiftFileBackend extends FileBackendStore { return $status; } + // Open a handle to the source file so that it can be streamed. The size and hash + // will be computed using the handle. In the off chance that the source file changes + // during this operation, the PUT will fail due to an ETag mismatch and be aborted. AtEase::suppressWarnings(); - $sha1Hash = sha1_file( $params['src'] ); + $srcHandle = fopen( $params['src'], 'rb' ); AtEase::restoreWarnings(); - if ( $sha1Hash === false ) { // source doesn't exist? - $status->fatal( 'backend-fail-store', $params['src'], $params['dst'] ); + if ( $srcHandle === false ) { // source doesn't exist? + $status->fatal( 'backend-fail-notexists', $params['src'] ); return $status; } - $sha1Hash = Wikimedia\base_convert( $sha1Hash, 16, 36, 31 ); - $contentType = $params['headers']['content-type'] - ?? $this->getContentType( $params['dst'], null, $params['src'] ); - $handle = fopen( $params['src'], 'rb' ); - if ( $handle === false ) { // source doesn't exist? - $status->fatal( 'backend-fail-store', $params['src'], $params['dst'] ); + // Compute the MD5 and SHA-1 hashes in one pass + $srcSize = fstat( $srcHandle )['size']; + $md5Context = hash_init( 'md5' ); + $sha1Context = hash_init( 'sha1' ); + $hashDigestSize = 0; + while ( !feof( $srcHandle ) ) { + $buffer = (string)fread( $srcHandle, 131072 ); // 128 KiB + hash_update( $md5Context, $buffer ); + hash_update( $sha1Context, $buffer ); + $hashDigestSize += strlen( $buffer ); + } + // Reset the handle back to the beginning so that it can be streamed + rewind( $srcHandle ); + + if ( $hashDigestSize !== $srcSize ) { + $status->fatal( 'backend-fail-hash', $params['src'] ); return $status; } + // Headers that are not strictly a function of the file content + $mutableHeaders = $this->extractMutableContentHeaders( $params['headers'] ?? [] ); + // Make sure that the "content-type" header is set to something sensible + $mutableHeaders['content-type'] = $mutableHeaders['content-type'] + ?? $this->getContentType( $params['dst'], null, $params['src'] ); + $reqs = [ [ 'method' => 'PUT', 'url' => [ $dstCont, $dstRel ], - 'headers' => [ - 'content-length' => filesize( $params['src'] ), - 'etag' => md5_file( $params['src'] ), - 'content-type' => $contentType, - 'x-object-meta-sha1base36' => $sha1Hash - ] + $this->sanitizeHdrsStrict( $params ), - 'body' => $handle // resource + 'headers' => array_merge( + $mutableHeaders, + [ + 'content-length' => $srcSize, + 'etag' => hash_final( $md5Context ), + 'x-object-meta-sha1base36' => + Wikimedia\base_convert( hash_final( $sha1Context ), 16, 36, 31 ) + ] + ), + 'body' => $srcHandle // resource ] ]; $method = __METHOD__; @@ -372,10 +374,12 @@ class SwiftFileBackend extends FileBackendStore { } else { $this->onError( $status, $method, $params, $rerr, $rcode, $rdesc ); } + + return SwiftFileOpHandle::CONTINUE_IF_OK; }; $opHandle = new SwiftFileOpHandle( $this, $handler, $reqs ); - $opHandle->resourcesToClose[] = $handle; + $opHandle->resourcesToClose[] = $srcHandle; if ( !empty( $params['async'] ) ) { // deferred $status->value = $opHandle; @@ -406,10 +410,13 @@ class SwiftFileBackend extends FileBackendStore { $reqs = [ [ 'method' => 'PUT', 'url' => [ $dstCont, $dstRel ], - 'headers' => [ - 'x-copy-from' => '/' . rawurlencode( $srcCont ) . - '/' . str_replace( "%2F", "/", rawurlencode( $srcRel ) ) - ] + $this->sanitizeHdrsStrict( $params ), // extra headers merged into object + 'headers' => array_merge( + $this->extractMutableContentHeaders( $params['headers'] ?? [] ), + [ + 'x-copy-from' => '/' . rawurlencode( $srcCont ) . '/' . + str_replace( "%2F", "/", rawurlencode( $srcRel ) ) + ] + ) ] ]; $method = __METHOD__; @@ -418,10 +425,14 @@ class SwiftFileBackend extends FileBackendStore { if ( $rcode === 201 ) { // good } elseif ( $rcode === 404 ) { - $status->fatal( 'backend-fail-copy', $params['src'], $params['dst'] ); + if ( empty( $params['ignoreMissingSource'] ) ) { + $status->fatal( 'backend-fail-copy', $params['src'], $params['dst'] ); + } } else { $this->onError( $status, $method, $params, $rerr, $rcode, $rdesc ); } + + return SwiftFileOpHandle::CONTINUE_IF_OK; }; $opHandle = new SwiftFileOpHandle( $this, $handler, $reqs ); @@ -451,16 +462,17 @@ class SwiftFileBackend extends FileBackendStore { return $status; } - $reqs = [ - [ - 'method' => 'PUT', - 'url' => [ $dstCont, $dstRel ], - 'headers' => [ - 'x-copy-from' => '/' . rawurlencode( $srcCont ) . - '/' . str_replace( "%2F", "/", rawurlencode( $srcRel ) ) - ] + $this->sanitizeHdrsStrict( $params ) // extra headers merged into object - ] - ]; + $reqs = [ [ + 'method' => 'PUT', + 'url' => [ $dstCont, $dstRel ], + 'headers' => array_merge( + $this->extractMutableContentHeaders( $params['headers'] ?? [] ), + [ + 'x-copy-from' => '/' . rawurlencode( $srcCont ) . '/' . + str_replace( "%2F", "/", rawurlencode( $srcRel ) ) + ] + ) + ] ]; if ( "{$srcCont}/{$srcRel}" !== "{$dstCont}/{$dstRel}" ) { $reqs[] = [ 'method' => 'DELETE', @@ -477,10 +489,17 @@ class SwiftFileBackend extends FileBackendStore { } elseif ( $request['method'] === 'DELETE' && $rcode === 204 ) { // good } elseif ( $rcode === 404 ) { - $status->fatal( 'backend-fail-move', $params['src'], $params['dst'] ); + if ( empty( $params['ignoreMissingSource'] ) ) { + $status->fatal( 'backend-fail-move', $params['src'], $params['dst'] ); + } else { + // Leave Status as OK but skip the DELETE request + return SwiftFileOpHandle::CONTINUE_NO; + } } else { $this->onError( $status, $method, $params, $rerr, $rcode, $rdesc ); } + + return SwiftFileOpHandle::CONTINUE_IF_OK; }; $opHandle = new SwiftFileOpHandle( $this, $handler, $reqs ); @@ -521,6 +540,8 @@ class SwiftFileBackend extends FileBackendStore { } else { $this->onError( $status, $method, $params, $rerr, $rcode, $rdesc ); } + + return SwiftFileOpHandle::CONTINUE_IF_OK; }; $opHandle = new SwiftFileOpHandle( $this, $handler, $reqs ); @@ -554,17 +575,20 @@ class SwiftFileBackend extends FileBackendStore { return $status; } - // POST clears prior headers, so we need to merge the changes in to the old ones - $metaHdrs = []; + // Swift object POST clears any prior headers, so merge the new and old headers here. + // Also, during, POST, libcurl adds "Content-Type: application/x-www-form-urlencoded" + // if "Content-Type" is not set, which would clobber the header value for the object. + $oldMetadataHeaders = []; foreach ( $stat['xattr']['metadata'] as $name => $value ) { - $metaHdrs["x-object-meta-$name"] = $value; + $oldMetadataHeaders["x-object-meta-$name"] = $value; } - $customHdrs = $this->sanitizeHdrs( $params ) + $stat['xattr']['headers']; + $newContentHeaders = $this->extractMutableContentHeaders( $params['headers'] ?? [] ); + $oldContentHeaders = $stat['xattr']['headers']; $reqs = [ [ 'method' => 'POST', 'url' => [ $srcCont, $srcRel ], - 'headers' => $metaHdrs + $customHdrs + 'headers' => $oldMetadataHeaders + $newContentHeaders + $oldContentHeaders ] ]; $method = __METHOD__; @@ -743,9 +767,9 @@ class SwiftFileBackend extends FileBackendStore { } // Find prior custom HTTP headers - $postHeaders = $this->getCustomHeaders( $objHdrs ); + $postHeaders = $this->extractMutableContentHeaders( $objHdrs ); // Find prior metadata headers - $postHeaders += $this->getMetadataHeaders( $objHdrs ); + $postHeaders += $this->extractMetadataHeaders( $objHdrs ); $status = $this->newStatus(); /** @noinspection PhpUnusedLocalVariableInspection */ @@ -1083,11 +1107,11 @@ class SwiftFileBackend extends FileBackendStore { protected function doStreamFile( array $params ) { $status = $this->newStatus(); - $flags = !empty( $params['headless'] ) ? StreamFile::STREAM_HEADLESS : 0; + $flags = !empty( $params['headless'] ) ? HTTPFileStreamer::STREAM_HEADLESS : 0; list( $srcCont, $srcRel ) = $this->resolveStoragePathReal( $params['src'] ); if ( $srcRel === null ) { - StreamFile::send404Message( $params['src'], $flags ); + HTTPFileStreamer::send404Message( $params['src'], $flags ); $status->fatal( 'backend-fail-invalidpath', $params['src'] ); return $status; @@ -1095,7 +1119,7 @@ class SwiftFileBackend extends FileBackendStore { $auth = $this->getAuthentication(); if ( !$auth || !is_array( $this->getContainerStat( $srcCont ) ) ) { - StreamFile::send404Message( $params['src'], $flags ); + HTTPFileStreamer::send404Message( $params['src'], $flags ); $status->fatal( 'backend-fail-stream', $params['src'] ); return $status; @@ -1104,7 +1128,7 @@ class SwiftFileBackend extends FileBackendStore { // If "headers" is set, we only want to send them if the file is there. // Do not bother checking if the file exists if headers are not set though. if ( $params['headers'] && !$this->fileExists( $params ) ) { - StreamFile::send404Message( $params['src'], $flags ); + HTTPFileStreamer::send404Message( $params['src'], $flags ); $status->fatal( 'backend-fail-stream', $params['src'] ); return $status; @@ -1293,11 +1317,6 @@ class SwiftFileBackend extends FileBackendStore { return $hdrs; } - /** - * @param FileBackendStoreOpHandle[] $fileOpHandles - * - * @return StatusValue[] - */ protected function doExecuteOpHandlesInternal( array $fileOpHandles ) { /** @var SwiftFileOpHandle[] $fileOpHandles */ '@phan-var SwiftFileOpHandle[] $fileOpHandles'; @@ -1334,13 +1353,18 @@ class SwiftFileBackend extends FileBackendStore { for ( $stage = 0; $stage < $reqCount; ++$stage ) { $httpReqs = $this->http->runMulti( $httpReqsByStage[$stage] ); foreach ( $httpReqs as $index => $httpReq ) { + /** @var SwiftFileOpHandle $fileOpHandle */ + $fileOpHandle = $fileOpHandles[$index]; // Run the callback for each request of this operation - $callback = $fileOpHandles[$index]->callback; - $callback( $httpReq, $statuses[$index] ); - // On failure, abort all remaining requests for this operation - // (e.g. abort the DELETE request if the COPY request fails for a move) - if ( !$statuses[$index]->isOK() ) { - $stages = count( $fileOpHandles[$index]->httpOp ); + $status = $statuses[$index]; + ( $fileOpHandle->callback )( $httpReq, $status ); + // On failure, abort all remaining requests for this operation. This is used + // in "move" operations to abort the DELETE request if the PUT request fails. + if ( + !$status->isOK() || + $fileOpHandle->state === $fileOpHandle::CONTINUE_NO + ) { + $stages = count( $fileOpHandle->httpOp ); for ( $s = ( $stage + 1 ); $s < $stages; ++$s ) { unset( $httpReqsByStage[$s][$index] ); } @@ -1670,9 +1694,9 @@ class SwiftFileBackend extends FileBackendStore { */ protected function getStatFromHeaders( array $rhdrs ) { // Fetch all of the custom metadata headers - $metadata = $this->getMetadata( $rhdrs ); + $metadata = $this->getMetadataFromHeaders( $rhdrs ); // Fetch all of the custom raw HTTP headers - $headers = $this->sanitizeHdrs( [ 'headers' => $rhdrs ] ); + $headers = $this->extractMutableContentHeaders( $rhdrs ); return [ // Convert various random Swift dates to TS_MW diff --git a/includes/libs/filebackend/fileophandle/SwiftFileOpHandle.php b/includes/libs/filebackend/fileophandle/SwiftFileOpHandle.php index 1119867800..70ed46a241 100644 --- a/includes/libs/filebackend/fileophandle/SwiftFileOpHandle.php +++ b/includes/libs/filebackend/fileophandle/SwiftFileOpHandle.php @@ -26,14 +26,28 @@ * @see FileBackendStoreOpHandle */ class SwiftFileOpHandle extends FileBackendStoreOpHandle { - /** @var array List of Requests for MultiHttpClient */ + /** @var array[] List of HTTP request maps for MultiHttpClient */ public $httpOp; - /** @var Closure */ + /** @var Closure Function to run after each HTTP request finishes */ public $callback; + /** @var int Class CONTINUE_* constant */ + public $state = self::CONTINUE_IF_OK; + + /** @var int Continue with the next requests stages if no errors occured */ + const CONTINUE_IF_OK = 0; + /** @var int Cancel the next requests stages */ + const CONTINUE_NO = 1; + /** + * Construct a handle to be use with SwiftFileOpHandle::doExecuteOpHandlesInternal() + * + * The callback returns a class CONTINUE_* constant and takes the following parameters: + * - An HTTP request map array with 'response' filled + * - A StatusValue instance to be updated as needed + * * @param SwiftFileBackend $backend - * @param Closure $callback Function that takes (HTTP request array, status) + * @param Closure $callback * @param array $httpOp MultiHttpClient op */ public function __construct( SwiftFileBackend $backend, Closure $callback, array $httpOp ) { diff --git a/includes/libs/lockmanager/QuorumLockManager.php b/includes/libs/lockmanager/QuorumLockManager.php index 6478a61b14..83dcc6be56 100644 --- a/includes/libs/lockmanager/QuorumLockManager.php +++ b/includes/libs/lockmanager/QuorumLockManager.php @@ -152,7 +152,7 @@ abstract class QuorumLockManager extends LockManager { * This is all or nothing; if any key is already pledged then this totally fails. * * @param int $bucket - * @param callable $callback Pledge method taking a server name and yeilding a StatusValue + * @param callable $callback Pledge method taking a server name and yielding a StatusValue * @return StatusValue */ final protected function collectPledgeQuorum( $bucket, callable $callback ) { @@ -194,7 +194,7 @@ abstract class QuorumLockManager extends LockManager { * Attempt to release pledges with the peers for a bucket * * @param int $bucket - * @param callable $callback Pledge method taking a server name and yeilding a StatusValue + * @param callable $callback Pledge method taking a server name and yielding a StatusValue * @return StatusValue */ final protected function releasePledges( $bucket, callable $callback ) { diff --git a/includes/libs/mime/MimeAnalyzer.php b/includes/libs/mime/MimeAnalyzer.php index bafe5e3098..6fca0438f5 100644 --- a/includes/libs/mime/MimeAnalyzer.php +++ b/includes/libs/mime/MimeAnalyzer.php @@ -1089,7 +1089,7 @@ EOT; // Special code for ogg - detect if it's video (theora), // else label it as sound. - if ( $mime == 'application/ogg' && file_exists( $path ) ) { + if ( $mime == 'application/ogg' && is_string( $path ) && file_exists( $path ) ) { // Read a chunk of the file $f = fopen( $path, "rt" ); if ( !$f ) { diff --git a/includes/libs/mime/XmlTypeCheck.php b/includes/libs/mime/XmlTypeCheck.php index 9d66326744..16cd5ca9ca 100644 --- a/includes/libs/mime/XmlTypeCheck.php +++ b/includes/libs/mime/XmlTypeCheck.php @@ -68,6 +68,9 @@ class XmlTypeCheck { */ protected $stackDepth = 0; + /** @var callable|null */ + protected $filterCallback; + /** * @var array Additional parsing options */ diff --git a/includes/libs/objectcache/MultiWriteBagOStuff.php b/includes/libs/objectcache/MultiWriteBagOStuff.php index 51f7316424..77a78830e2 100644 --- a/includes/libs/objectcache/MultiWriteBagOStuff.php +++ b/includes/libs/objectcache/MultiWriteBagOStuff.php @@ -46,7 +46,7 @@ class MultiWriteBagOStuff extends BagOStuff { /** * $params include: * - caches: A numbered array of either ObjectFactory::getObjectFromSpec - * arrays yeilding BagOStuff objects or direct BagOStuff objects. + * arrays yielding BagOStuff objects or direct BagOStuff objects. * If using the former, the 'args' field *must* be set. * The first cache is the primary one, being the first to * be read in the fallback chain. Writes happen to all stores diff --git a/includes/libs/objectcache/ReplicatedBagOStuff.php b/includes/libs/objectcache/ReplicatedBagOStuff.php index ff87829086..9f953e1721 100644 --- a/includes/libs/objectcache/ReplicatedBagOStuff.php +++ b/includes/libs/objectcache/ReplicatedBagOStuff.php @@ -47,9 +47,9 @@ class ReplicatedBagOStuff extends BagOStuff { /** * Constructor. Parameters are: - * - writeFactory: ObjectFactory::getObjectFromSpec array yeilding BagOStuff. + * - writeFactory: ObjectFactory::getObjectFromSpec array yielding BagOStuff. * This object will be used for writes (e.g. the master DB). - * - readFactory: ObjectFactory::getObjectFromSpec array yeilding BagOStuff. + * - readFactory: ObjectFactory::getObjectFromSpec array yielding BagOStuff. * This object will be used for reads (e.g. a replica DB). * - sessionConsistencyWindow: Seconds to read from the master source for a key * after writing to it. [Default: ReplicatedBagOStuff::MAX_WRITE_DELAY] diff --git a/includes/libs/objectcache/wancache/WANObjectCache.php b/includes/libs/objectcache/wancache/WANObjectCache.php index 629d2cdcaf..70f35532d2 100644 --- a/includes/libs/objectcache/wancache/WANObjectCache.php +++ b/includes/libs/objectcache/wancache/WANObjectCache.php @@ -2488,8 +2488,9 @@ class WANObjectCache implements IExpiringStore, IStoreKeyEncoder, LoggerAwareInt */ private function determineKeyClassForStats( $key ) { $parts = explode( ':', $key, 3 ); - - return $parts[1] ?? $parts[0]; // sanity + // Sanity fallback in case the key was not made by makeKey. + // Replace dots because they are special in StatsD (T232907) + return strtr( $parts[1] ?? $parts[0], '.', '_' ); } /** diff --git a/includes/libs/rdbms/lbfactory/LBFactoryMulti.php b/includes/libs/rdbms/lbfactory/LBFactoryMulti.php index 77b029f6d9..5d33e698db 100644 --- a/includes/libs/rdbms/lbfactory/LBFactoryMulti.php +++ b/includes/libs/rdbms/lbfactory/LBFactoryMulti.php @@ -60,7 +60,7 @@ class LBFactoryMulti extends LBFactory { private $masterTemplateOverrides = []; /** @var array[] Map of (host => server config map overrides) for main and external servers */ private $templateOverridesByServer = []; - /** @var string[]|bool[] A map of section name to read-only message */ + /** @var string[]|bool[] A map of section name to read-only message */ private $readOnlyBySection = []; /** @var string An ILoadMonitor class */ @@ -85,7 +85,7 @@ class LBFactoryMulti extends LBFactory { * data can be before the load balancer tries to avoid using it. The map can have 'is static' * set to disable blocking replication sync checks (intended for archive servers with * unchanging data). - + * * @see LBFactory::__construct() * @param array $conf Additional parameters include: * - hostsByName Optional (hostname => IP address) map. diff --git a/includes/logging/BlockLogFormatter.php b/includes/logging/BlockLogFormatter.php index d27643ce0d..d49e3c5710 100644 --- a/includes/logging/BlockLogFormatter.php +++ b/includes/logging/BlockLogFormatter.php @@ -22,6 +22,8 @@ * @since 1.25 */ +use MediaWiki\MediaWikiServices; + /** * This class formats block log entries. * @@ -138,7 +140,9 @@ class BlockLogFormatter extends LogFormatter { $linkRenderer = $this->getLinkRenderer(); if ( $this->entry->isDeleted( LogPage::DELETED_ACTION ) // Action is hidden || !( $subtype === 'block' || $subtype === 'reblock' ) - || !$this->context->getUser()->isAllowed( 'block' ) + || !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->context->getUser(), 'block' ) ) { return ''; } diff --git a/includes/logging/ContentModelLogFormatter.php b/includes/logging/ContentModelLogFormatter.php index e05357cd68..23c582c30f 100644 --- a/includes/logging/ContentModelLogFormatter.php +++ b/includes/logging/ContentModelLogFormatter.php @@ -1,5 +1,7 @@ context->getLanguage(); @@ -12,7 +14,9 @@ class ContentModelLogFormatter extends LogFormatter { public function getActionLinks() { if ( $this->entry->isDeleted( LogPage::DELETED_ACTION ) // Action is hidden || $this->entry->getSubtype() !== 'change' - || !$this->context->getUser()->isAllowed( 'editcontentmodel' ) + || !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->context->getUser(), 'editcontentmodel' ) ) { return ''; } diff --git a/includes/logging/DeleteLogFormatter.php b/includes/logging/DeleteLogFormatter.php index 3bc19ffd37..565a65f11b 100644 --- a/includes/logging/DeleteLogFormatter.php +++ b/includes/logging/DeleteLogFormatter.php @@ -23,7 +23,8 @@ * @since 1.22 */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\MediaWikiServices; +use MediaWiki\Revision\RevisionRecord; /** * This class formats delete log entries. @@ -31,6 +32,12 @@ use MediaWiki\Storage\RevisionRecord; * @since 1.19 */ class DeleteLogFormatter extends LogFormatter { + /** @var array|null */ + private $parsedParametersDeleteLog; + + /** + * @inheritDoc + */ protected function getMessageKey() { $key = parent::getMessageKey(); if ( in_array( $this->entry->getSubtype(), [ 'event', 'revision' ] ) ) { @@ -50,8 +57,11 @@ class DeleteLogFormatter extends LogFormatter { return $key; } + /** + * @inheritDoc + */ protected function getMessageParameters() { - if ( isset( $this->parsedParametersDeleteLog ) ) { + if ( $this->parsedParametersDeleteLog !== null ) { return $this->parsedParametersDeleteLog; } @@ -136,7 +146,8 @@ class DeleteLogFormatter extends LogFormatter { public function getActionLinks() { $user = $this->context->getUser(); $linkRenderer = $this->getLinkRenderer(); - if ( !$user->isAllowed( 'deletedhistory' ) + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); + if ( !$permissionManager->userHasRight( $user, 'deletedhistory' ) || $this->entry->isDeleted( LogPage::DELETED_ACTION ) ) { return ''; @@ -145,7 +156,7 @@ class DeleteLogFormatter extends LogFormatter { switch ( $this->entry->getSubtype() ) { case 'delete': // Show undelete link case 'delete_redir': - if ( $user->isAllowed( 'undelete' ) ) { + if ( $permissionManager->userHasRight( $user, 'undelete' ) ) { $message = 'undeletelink'; } else { $message = 'undeleteviewlink'; diff --git a/includes/logging/LogEventsList.php b/includes/logging/LogEventsList.php index 6791503bf7..2e7f065bf1 100644 --- a/includes/logging/LogEventsList.php +++ b/includes/logging/LogEventsList.php @@ -233,7 +233,10 @@ class LogEventsList extends ContextSource { foreach ( LogPage::validTypes() as $type ) { $page = new LogPage( $type ); $restriction = $page->getRestriction(); - if ( $this->getUser()->isAllowed( $restriction ) ) { + if ( MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), $restriction ) + ) { $typesByName[$type] = $page->getName()->text(); } } @@ -450,11 +453,12 @@ class LogEventsList extends ContextSource { } $del = ''; + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); // Don't show useless checkbox to people who cannot hide log entries - if ( $user->isAllowed( 'deletedhistory' ) ) { - $canHide = $user->isAllowed( 'deletelogentry' ); - $canViewSuppressedOnly = $user->isAllowed( 'viewsuppressed' ) && - !$user->isAllowed( 'suppressrevision' ); + if ( $permissionManager->userHasRight( $user, 'deletedhistory' ) ) { + $canHide = $permissionManager->userHasRight( $user, 'deletelogentry' ); + $canViewSuppressedOnly = $permissionManager->userHasRight( $user, 'viewsuppressed' ) && + !$permissionManager->userHasRight( $user, 'suppressrevision' ); $entryIsSuppressed = self::isDeleted( $row, LogPage::DELETED_RESTRICTED ); $canViewThisSuppressedEntry = $canViewSuppressedOnly && $entryIsSuppressed; if ( $row->log_deleted || $canHide ) { @@ -508,7 +512,9 @@ class LogEventsList extends ContextSource { in_array( $row->log_action, $action ) : $row->log_action == $action; if ( $match && $right ) { global $wgUser; - $match = $wgUser->isAllowed( $right ); + $match = MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $wgUser, $right ); } } @@ -572,7 +578,10 @@ class LogEventsList extends ContextSource { $user = $wgUser; } $logRestrictions = MediaWikiServices::getInstance()->getMainConfig()->get( 'LogRestrictions' ); - if ( isset( $logRestrictions[$type] ) && !$user->isAllowed( $logRestrictions[$type] ) ) { + if ( isset( $logRestrictions[$type] ) && !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, $logRestrictions[$type] ) + ) { return false; } return true; @@ -783,7 +792,10 @@ class LogEventsList extends ContextSource { // Don't show private logs to unprivileged users foreach ( $wgLogRestrictions as $logType => $right ) { - if ( $audience == 'public' || !$user->isAllowed( $right ) ) { + if ( $audience == 'public' || !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, $right ) + ) { $hiddenLogs[] = $logType; } } diff --git a/includes/logging/LogFormatter.php b/includes/logging/LogFormatter.php index 9e63ffee64..b4a682583c 100644 --- a/includes/logging/LogFormatter.php +++ b/includes/logging/LogFormatter.php @@ -163,7 +163,9 @@ class LogFormatter { $logRestrictions = $this->context->getConfig()->get( 'LogRestrictions' ); $type = $this->entry->getType(); return !isset( $logRestrictions[$type] ) - || $this->context->getUser()->isAllowed( $logRestrictions[$type] ); + || MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->context->getUser(), $logRestrictions[$type] ); } /** diff --git a/includes/logging/LogPager.php b/includes/logging/LogPager.php index 38710477cb..781df06f49 100644 --- a/includes/logging/LogPager.php +++ b/includes/logging/LogPager.php @@ -53,6 +53,12 @@ class LogPager extends ReverseChronologicalPager { /** @var bool */ private $actionRestrictionsEnforced = false; + /** @var array */ + private $mConds; + + /** @var string */ + private $mTagFilter; + /** @var LogEventsList */ public $mLogEventsList; @@ -80,12 +86,13 @@ class LogPager extends ReverseChronologicalPager { $this->mLogEventsList = $list; $this->limitType( $types ); // also excludes hidden types + $this->limitLogId( $logId ); + $this->limitFilterTypes(); $this->limitPerformer( $performer ); $this->limitTitle( $title, $pattern ); $this->limitAction( $action ); $this->getDateCond( $year, $month, $day ); $this->mTagFilter = $tagFilter; - $this->limitLogId( $logId ); $this->mDb = wfGetDB( DB_REPLICA, 'logpager' ); } @@ -101,7 +108,18 @@ class LogPager extends ReverseChronologicalPager { return $query; } - // Call ONLY after calling $this->limitType() already! + private function limitFilterTypes() { + if ( $this->hasEqualsClause( 'log_id' ) ) { // T220834 + return; + } + $filterTypes = $this->getFilterParams(); + foreach ( $filterTypes as $type => $hide ) { + if ( $hide ) { + $this->mConds[] = 'log_type != ' . $this->mDb->addQuotes( $type ); + } + } + } + public function getFilterParams() { global $wgFilterLogTypes; $filters = []; @@ -121,9 +139,6 @@ class LogPager extends ReverseChronologicalPager { } $filters[$type] = $hide; - if ( $hide ) { - $this->mConds[] = 'log_type != ' . $this->mDb->addQuotes( $type ); - } } return $filters; @@ -146,7 +161,9 @@ class LogPager extends ReverseChronologicalPager { $needReindex = false; foreach ( $types as $type ) { if ( isset( $wgLogRestrictions[$type] ) - && !$user->isAllowed( $wgLogRestrictions[$type] ) + && !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, $wgLogRestrictions[$type] ) ) { $needReindex = true; $types = array_diff( $types, [ $type ] ); @@ -462,12 +479,10 @@ class LogPager extends ReverseChronologicalPager { } $this->actionRestrictionsEnforced = true; $user = $this->getUser(); - if ( !$user->isAllowed( 'deletedhistory' ) ) { + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); + if ( !$permissionManager->userHasRight( $user, 'deletedhistory' ) ) { $this->mConds[] = $this->mDb->bitAnd( 'log_deleted', LogPage::DELETED_ACTION ) . ' = 0'; - } elseif ( !MediaWikiServices::getInstance() - ->getPermissionManager() - ->userHasAnyRight( $user, 'suppressrevision', 'viewsuppressed' ) - ) { + } elseif ( !$permissionManager->userHasAnyRight( $user, 'suppressrevision', 'viewsuppressed' ) ) { $this->mConds[] = $this->mDb->bitAnd( 'log_deleted', LogPage::SUPPRESSED_ACTION ) . ' != ' . LogPage::SUPPRESSED_USER; } @@ -483,12 +498,10 @@ class LogPager extends ReverseChronologicalPager { } $this->performerRestrictionsEnforced = true; $user = $this->getUser(); - if ( !$user->isAllowed( 'deletedhistory' ) ) { + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); + if ( !$permissionManager->userHasRight( $user, 'deletedhistory' ) ) { $this->mConds[] = $this->mDb->bitAnd( 'log_deleted', LogPage::DELETED_USER ) . ' = 0'; - } elseif ( !MediaWikiServices::getInstance() - ->getPermissionManager() - ->userHasAnyRight( $user, 'suppressrevision', 'viewsuppressed' ) - ) { + } elseif ( !$permissionManager->userHasAnyRight( $user, 'suppressrevision', 'viewsuppressed' ) ) { $this->mConds[] = $this->mDb->bitAnd( 'log_deleted', LogPage::SUPPRESSED_USER ) . ' != ' . LogPage::SUPPRESSED_ACTION; } diff --git a/includes/logging/MergeLogFormatter.php b/includes/logging/MergeLogFormatter.php index 7a6fb9df48..925c976d7a 100644 --- a/includes/logging/MergeLogFormatter.php +++ b/includes/logging/MergeLogFormatter.php @@ -22,6 +22,8 @@ * @since 1.25 */ +use MediaWiki\MediaWikiServices; + /** * This class formats merge log entries. * @@ -47,7 +49,9 @@ class MergeLogFormatter extends LogFormatter { public function getActionLinks() { if ( $this->entry->isDeleted( LogPage::DELETED_ACTION ) // Action is hidden - || !$this->context->getUser()->isAllowed( 'mergehistory' ) + || !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->context->getUser(), 'mergehistory' ) ) { return ''; } diff --git a/includes/logging/MoveLogFormatter.php b/includes/logging/MoveLogFormatter.php index 637a8e7821..6797f98f04 100644 --- a/includes/logging/MoveLogFormatter.php +++ b/includes/logging/MoveLogFormatter.php @@ -23,6 +23,8 @@ * @since 1.22 */ +use MediaWiki\MediaWikiServices; + /** * This class formats move log entries. * @@ -60,7 +62,9 @@ class MoveLogFormatter extends LogFormatter { public function getActionLinks() { if ( $this->entry->isDeleted( LogPage::DELETED_ACTION ) // Action is hidden || $this->entry->getSubtype() !== 'move' - || !$this->context->getUser()->isAllowed( 'move' ) + || !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->context->getUser(), 'move' ) ) { return ''; } diff --git a/includes/logging/ProtectLogFormatter.php b/includes/logging/ProtectLogFormatter.php index ba02457319..6e3b26b17f 100644 --- a/includes/logging/ProtectLogFormatter.php +++ b/includes/logging/ProtectLogFormatter.php @@ -101,7 +101,10 @@ class ProtectLogFormatter extends LogFormatter { ]; // Show change protection link - if ( $this->context->getUser()->isAllowed( 'protect' ) ) { + if ( !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->context->getUser(), 'protect' ) + ) { $links[] = $linkRenderer->makeKnownLink( $title, $this->msg( 'protect_change' )->text(), diff --git a/includes/mail/EmailNotification.php b/includes/mail/EmailNotification.php index cba68ef587..4d176fb0bc 100644 --- a/includes/mail/EmailNotification.php +++ b/includes/mail/EmailNotification.php @@ -129,7 +129,10 @@ class EmailNotification { if ( $watchers === [] && !count( $wgUsersNotifiedOnAllChanges ) ) { $sendEmail = false; // Only send notification for non minor edits, unless $wgEnotifMinorEdits - if ( !$minorEdit || ( $wgEnotifMinorEdits && !$editor->isAllowed( 'nominornewtalk' ) ) ) { + if ( !$minorEdit || ( $wgEnotifMinorEdits && !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $editor, 'nominornewtalk' ) ) + ) { $isUserTalkPage = ( $title->getNamespace() == NS_USER_TALK ); if ( $wgEnotifUserTalk && $isUserTalkPage @@ -214,7 +217,10 @@ class EmailNotification { $userTalkId = false; - if ( !$minorEdit || ( $wgEnotifMinorEdits && !$editor->isAllowed( 'nominornewtalk' ) ) ) { + if ( !$minorEdit || ( $wgEnotifMinorEdits && !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $editor, 'nominornewtalk' ) ) + ) { if ( $wgEnotifUserTalk && $isUserTalkPage && $this->canSendUserTalkEmail( $editor, $title, $minorEdit ) diff --git a/includes/mail/UserMailer.php b/includes/mail/UserMailer.php index 47fa16f87f..7b739027f8 100644 --- a/includes/mail/UserMailer.php +++ b/includes/mail/UserMailer.php @@ -34,8 +34,8 @@ class UserMailer { * Send mail using a PEAR mailer * * @param Mail_smtp $mailer - * @param string $dest - * @param string $headers + * @param string[]|string $dest + * @param array $headers * @param string $body * * @return Status @@ -382,6 +382,8 @@ class UserMailer { throw new MWException( 'PEAR mail package is not installed' ); } + $recips = array_map( 'strval', $to ); + Wikimedia\suppressWarnings(); // Create the mail object using the Mail::factory method @@ -391,19 +393,20 @@ class UserMailer { Wikimedia\restoreWarnings(); return Status::newFatal( 'pear-mail-error', $mail_object->getMessage() ); } + '@phan-var Mail_smtp $mail_object'; wfDebug( "Sending mail via PEAR::Mail\n" ); $headers['Subject'] = self::quotedPrintable( $subject ); // When sending only to one recipient, shows it its email using To: - if ( count( $to ) == 1 ) { - $headers['To'] = $to[0]->toString(); + if ( count( $recips ) == 1 ) { + $headers['To'] = $recips[0]; } // Split jobs since SMTP servers tends to limit the maximum // number of possible recipients. - $chunks = array_chunk( $to, $wgEnotifMaxRecips ); + $chunks = array_chunk( $recips, $wgEnotifMaxRecips ); foreach ( $chunks as $chunk ) { $status = self::sendWithPear( $mail_object, $chunk, $headers, $body ); // FIXME : some chunks might be sent while others are not! diff --git a/includes/media/DjVuHandler.php b/includes/media/DjVuHandler.php index 3b904e8418..d54dd6bc05 100644 --- a/includes/media/DjVuHandler.php +++ b/includes/media/DjVuHandler.php @@ -240,6 +240,7 @@ class DjVuHandler extends ImageHandler { * @param File|FSFile $image * @param string $path * @return DjVuImage + * @suppress PhanUndeclaredProperty Custom property */ function getDjVuImage( $image, $path ) { if ( !$image ) { @@ -290,6 +291,7 @@ class DjVuHandler extends ImageHandler { * @param File $image * @param bool $gettext DOCUMENT (Default: false) * @return bool|SimpleXMLElement + * @suppress PhanUndeclaredProperty Custom property */ public function getMetaTree( $image, $gettext = false ) { if ( $gettext && isset( $image->djvuTextTree ) ) { diff --git a/includes/media/DjVuImage.php b/includes/media/DjVuImage.php index 92fad528fe..50b13a413f 100644 --- a/includes/media/DjVuImage.php +++ b/includes/media/DjVuImage.php @@ -42,6 +42,9 @@ class DjVuImage { */ const DJVUTXT_MEMORY_LIMIT = 300000; + /** @var string */ + private $mFilename; + /** * @param string $filename The DjVu file name. */ diff --git a/includes/media/JpegMetadataExtractor.php b/includes/media/JpegMetadataExtractor.php index 8a26f606f9..dffb1f988b 100644 --- a/includes/media/JpegMetadataExtractor.php +++ b/includes/media/JpegMetadataExtractor.php @@ -122,14 +122,17 @@ class JpegMetadataExtractor { $temp = self::jpegExtractMarker( $fh ); // check what type of app segment this is. if ( substr( $temp, 0, 29 ) === "http://ns.adobe.com/xap/1.0/\x00" && $showXMP ) { - $segments["XMP"] = substr( $temp, 29 ); + // use trim to remove trailing \0 chars + $segments["XMP"] = trim( substr( $temp, 29 ) ); } elseif ( substr( $temp, 0, 35 ) === "http://ns.adobe.com/xmp/extension/\x00" && $showXMP ) { - $segments["XMP_ext"][] = substr( $temp, 35 ); + // use trim to remove trailing \0 chars + $segments["XMP_ext"][] = trim( substr( $temp, 35 ) ); } elseif ( substr( $temp, 0, 29 ) === "XMP\x00://ns.adobe.com/xap/1.0/\x00" && $showXMP ) { // Some images (especially flickr images) seem to have this. // I really have no idea what the deal is with them, but // whatever... - $segments["XMP"] = substr( $temp, 29 ); + // use trim to remove trailing \0 chars + $segments["XMP"] = trim( substr( $temp, 29 ) ); wfDebug( __METHOD__ . ' Found XMP section with wrong app identifier ' . "Using anyways.\n" ); } elseif ( substr( $temp, 0, 6 ) === "Exif\0\0" ) { diff --git a/includes/objectcache/ObjectCache.php b/includes/objectcache/ObjectCache.php index 5e99ac9d70..e49feae881 100644 --- a/includes/objectcache/ObjectCache.php +++ b/includes/objectcache/ObjectCache.php @@ -43,11 +43,6 @@ use MediaWiki\MediaWikiServices; * * Primary entry points: * - * - ObjectCache::getMainWANInstance() - * Purpose: Memory cache. - * Stored in the local data-center's main cache (keyspace different from local-cluster cache). - * Delete events are broadcasted to other DCs main cache. See WANObjectCache for details. - * * - ObjectCache::getLocalServerInstance( $fallbackType ) * Purpose: Memory cache for very hot keys. * Stored only on the individual web server (typically APC or APCu for web requests, @@ -60,13 +55,6 @@ use MediaWiki\MediaWikiServices; * Stored centrally within the local data-center. Not replicated to other DCs. * Configured by $wgMainCacheType. * - * - ObjectCache::getMainStashInstance() - * Purpose: Ephemeral global storage. - * Stored centrally within the primary data-center. - * Changes are applied there first and replicated to other DCs (best-effort). - * To retrieve the latest value (e.g. not from a replica DB), use BagOStuff::READ_LATEST. - * This store may be subject to LRU style evictions. - * * - ObjectCache::getInstance( $cacheType ) * Purpose: Special cases (like tiered memory/disk caches). * Get a specific cache type by key in $wgObjectCaches. @@ -351,30 +339,6 @@ class ObjectCache { return self::getInstance( $wgMainCacheType ); } - /** - * Get the main WAN cache object. - * - * @since 1.26 - * @return WANObjectCache - * @deprecated Since 1.28 Use MediaWikiServices::getInstance()->getMainWANObjectCache() - */ - public static function getMainWANInstance() { - wfDeprecated( __METHOD__, '1.28' ); - return MediaWikiServices::getInstance()->getMainWANObjectCache(); - } - - /** - * Get the cache object for the main stash. - * - * @return BagOStuff - * @since 1.26 - * @deprecated Since 1.28 Use MediaWikiServices::getInstance()->getMainObjectStash() - */ - public static function getMainStashInstance() { - wfDeprecated( __METHOD__, '1.28' ); - return MediaWikiServices::getInstance()->getMainObjectStash(); - } - /** * Clear all the cached instances. */ diff --git a/includes/objectcache/SqlBagOStuff.php b/includes/objectcache/SqlBagOStuff.php index d713396b57..4a3445e935 100644 --- a/includes/objectcache/SqlBagOStuff.php +++ b/includes/objectcache/SqlBagOStuff.php @@ -194,6 +194,10 @@ class SqlBagOStuff extends MediumSpecificBagOStuff { $conn = Database::factory( $type, $info ); $conn->clearFlag( DBO_TRX ); // auto-commit mode $this->conns[$shardIndex] = $conn; + // Automatically create the objectcache table for sqlite as needed + if ( $conn->getType() === 'sqlite' ) { + $this->initSqliteDatabase( $conn ); + } } $conn = $this->conns[$shardIndex]; } else { @@ -206,10 +210,6 @@ class SqlBagOStuff extends MediumSpecificBagOStuff { $attribs = $lb->getServerAttributes( $lb->getWriterIndex() ); $flags = $attribs[Database::ATTR_DB_LEVEL_LOCKING] ? 0 : $lb::CONN_TRX_AUTOCOMMIT; $conn = $lb->getMaintenanceConnectionRef( $index, [], false, $flags ); - // Automatically create the objectcache table for sqlite as needed - if ( $conn->getType() === 'sqlite' ) { - $this->initSqliteDatabase( $conn ); - } } $this->logger->debug( sprintf( "Connection %s will be used for SqlBagOStuff", $conn ) ); diff --git a/includes/page/Article.php b/includes/page/Article.php index 1c2e782b6b..4b37181c24 100644 --- a/includes/page/Article.php +++ b/includes/page/Article.php @@ -363,8 +363,16 @@ class Article implements Page { } } + $rl = MediaWikiServices::getInstance()->getRevisionLookup(); + $oldRev = $this->mRevision ? $this->mRevision->getRevisionRecord() : null; if ( $request->getVal( 'direction' ) == 'next' ) { - $nextid = $this->getTitle()->getNextRevisionID( $oldid ); + $nextid = 0; + if ( $oldRev ) { + $nextRev = $rl->getNextRevision( $oldRev ); + if ( $nextRev ) { + $nextid = $nextRev->getId(); + } + } if ( $nextid ) { $oldid = $nextid; $this->mRevision = null; @@ -372,7 +380,13 @@ class Article implements Page { $this->mRedirectUrl = $this->getTitle()->getFullURL( 'redirect=no' ); } } elseif ( $request->getVal( 'direction' ) == 'prev' ) { - $previd = $this->getTitle()->getPreviousRevisionID( $oldid ); + $previd = 0; + if ( $oldRev ) { + $prevRev = $rl->getPreviousRevision( $oldRev ); + if ( $prevRev ) { + $previd = $prevRev->getId(); + } + } if ( $previd ) { $oldid = $previd; $this->mRevision = null; @@ -794,7 +808,9 @@ class Article implements Page { $outputPage->enableClientCache( false ); $outputPage->setRobotPolicy( 'noindex,nofollow' ); - $errortext = $error->getWikiText( false, 'view-pool-error' ); + $errortext = $error->getWikiText( + false, 'view-pool-error', $this->getContext()->getLanguage() + ); $outputPage->wrapWikiTextAsInterface( 'errorbox', $errortext ); } # Connection or timeout error @@ -1310,7 +1326,10 @@ class Article implements Page { } $outputPage->preventClickjacking(); - if ( $user->isAllowed( 'writeapi' ) ) { + if ( MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'writeapi' ) + ) { $outputPage->addModules( 'mediawiki.page.patrol.ajax' ); } @@ -1596,8 +1615,9 @@ class Article implements Page { 'oldid' => $oldid ] + $extraParams ); - $prev = $this->getTitle()->getPreviousRevisionID( $oldid ); - $prevlink = $prev + $rl = MediaWikiServices::getInstance()->getRevisionLookup(); + $prevExist = (bool)$rl->getPreviousRevision( $revision->getRevisionRecord() ); + $prevlink = $prevExist ? Linker::linkKnown( $this->getTitle(), $context->msg( 'previousrevision' )->escaped(), @@ -1608,7 +1628,7 @@ class Article implements Page { ] + $extraParams ) : $context->msg( 'previousrevision' )->escaped(); - $prevdiff = $prev + $prevdiff = $prevExist ? Linker::linkKnown( $this->getTitle(), $context->msg( 'diff' )->escaped(), @@ -1827,7 +1847,10 @@ class Article implements Page { [ 'delete', $this->getTitle()->getPrefixedText() ] ) ) { # Flag to hide all contents of the archived revisions - $suppress = $request->getCheck( 'wpSuppress' ) && $user->isAllowed( 'suppressrevision' ); + + $suppress = $request->getCheck( 'wpSuppress' ) && MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'suppressrevision' ); $this->doDelete( $reason, $suppress ); @@ -1986,8 +2009,8 @@ class Article implements Page { ] ); } - - if ( $user->isAllowed( 'suppressrevision' ) ) { + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); + if ( $permissionManager->userHasRight( $user, 'suppressrevision' ) ) { $fields[] = new OOUI\FieldLayout( new OOUI\CheckboxInputWidget( [ 'name' => 'wpSuppress', @@ -2045,7 +2068,7 @@ class Article implements Page { ] ) ); - if ( $user->isAllowed( 'editinterface' ) ) { + if ( $permissionManager->userHasRight( $user, 'editinterface' ) ) { $link = Linker::linkKnown( $ctx->msg( 'deletereason-dropdown' )->inContentLanguage()->getTitle(), wfMessage( 'delete-edit-reasonlist' )->escaped(), @@ -2100,7 +2123,7 @@ class Article implements Page { if ( $error == '' ) { $outputPage->wrapWikiTextAsInterface( 'error mw-error-cannotdelete', - $status->getWikiText() + $status->getWikiText( false, false, $context->getLanguage() ) ); $deleteLogPage = new LogPage( 'delete' ); $outputPage->addHTML( Xml::element( 'h2', null, $deleteLogPage->getName()->text() ) ); diff --git a/includes/page/ImageHistoryList.php b/includes/page/ImageHistoryList.php index 9edacccd52..cf2497f94e 100644 --- a/includes/page/ImageHistoryList.php +++ b/includes/page/ImageHistoryList.php @@ -130,11 +130,10 @@ class ImageHistoryList extends ContextSource { $row = $selected = ''; // Deletion link - if ( $local && ( $pm->userHasAnyRight( $user, 'delete', 'deletedhistory' ) ) - ) { + if ( $local && ( $pm->userHasAnyRight( $user, 'delete', 'deletedhistory' ) ) ) { $row .= ''; # Link to remove from history - if ( $user->isAllowed( 'delete' ) ) { + if ( $pm->userHasRight( $user, 'delete' ) ) { $q = [ 'action' => 'delete' ]; if ( !$iscur ) { $q['oldimage'] = $img; @@ -146,9 +145,10 @@ class ImageHistoryList extends ContextSource { ); } # Link to hide content. Don't show useless link to people who cannot hide revisions. - $canHide = $user->isAllowed( 'deleterevision' ); - if ( $canHide || ( $user->isAllowed( 'deletedhistory' ) && $file->getVisibility() ) ) { - if ( $user->isAllowed( 'delete' ) ) { + $canHide = $pm->userHasRight( $user, 'deleterevision' ); + if ( $canHide || ( $pm->userHasRight( $user, 'deletedhistory' ) + && $file->getVisibility() ) ) { + if ( $pm->userHasRight( $user, 'delete' ) ) { $row .= '
'; } // If file is top revision or locked from this user, don't link diff --git a/includes/page/ImagePage.php b/includes/page/ImagePage.php index 653e443a66..bb15532c1e 100644 --- a/includes/page/ImagePage.php +++ b/includes/page/ImagePage.php @@ -603,7 +603,10 @@ EOT ); } - if ( $wgEnableUploads && $user->isAllowed( 'upload' ) ) { + if ( $wgEnableUploads && MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'upload' ) + ) { // Only show an upload link if the user can upload $uploadTitle = SpecialPage::getTitleFor( 'Upload' ); $nofile = [ diff --git a/includes/page/MovePageFactory.php b/includes/page/MovePageFactory.php index 2f3fac2e7d..ff7ee4bd44 100644 --- a/includes/page/MovePageFactory.php +++ b/includes/page/MovePageFactory.php @@ -27,7 +27,6 @@ use MovePage; use NamespaceInfo; use RepoGroup; use Title; -use WatchedItemStore; use WatchedItemStoreInterface; use Wikimedia\Rdbms\ILoadBalancer; @@ -44,7 +43,7 @@ class MovePageFactory { /** @var NamespaceInfo */ private $nsInfo; - /** @var WatchedItemStore */ + /** @var WatchedItemStoreInterface */ private $watchedItems; /** @var PermissionManager */ diff --git a/includes/page/PageArchive.php b/includes/page/PageArchive.php index 40c63d22e4..8b2ff6bca8 100644 --- a/includes/page/PageArchive.php +++ b/includes/page/PageArchive.php @@ -756,10 +756,14 @@ class PageArchive { Hooks::run( 'ArticleUndelete', [ &$this->title, $created, $comment, $oldPageId, $restoredPages ] ); + if ( $this->title->getNamespace() == NS_FILE ) { - DeferredUpdates::addUpdate( - new HTMLCacheUpdate( $this->title, 'imagelinks', 'file-restore' ) + $job = HTMLCacheUpdateJob::newForBacklinks( + $this->title, + 'imagelinks', + [ 'causeAction' => 'file-restore' ] ); + JobQueueGroup::singleton()->lazyPush( $job ); } } diff --git a/includes/page/WikiFilePage.php b/includes/page/WikiFilePage.php index acd506ba79..fd9f7b24d8 100644 --- a/includes/page/WikiFilePage.php +++ b/includes/page/WikiFilePage.php @@ -176,9 +176,12 @@ class WikiFilePage extends WikiPage { if ( $this->mFile->exists() ) { wfDebug( 'ImagePage::doPurge purging ' . $this->mFile->getName() . "\n" ); - DeferredUpdates::addUpdate( - new HTMLCacheUpdate( $this->mTitle, 'imagelinks', 'file-purge' ) + $job = HTMLCacheUpdateJob::newForBacklinks( + $this->mTitle, + 'imagelinks', + [ 'causeAction' => 'file-purge' ] ); + JobQueueGroup::singleton()->lazyPush( $job ); } else { wfDebug( 'ImagePage::doPurge no image for ' . $this->mFile->getName() . "; limiting purge to cache only\n" ); diff --git a/includes/page/WikiPage.php b/includes/page/WikiPage.php index bad75da4fb..c8566ac877 100644 --- a/includes/page/WikiPage.php +++ b/includes/page/WikiPage.php @@ -1896,7 +1896,8 @@ class WikiPage implements Page, IDBAccessObject { // TODO: this check is here for backwards-compatibility with 1.31 behavior. // Checking the minoredit right should be done in the same place the 'bot' right is // checked for the EDIT_FORCE_BOT flag, which is currently in EditPage::attemptSave. - if ( ( $flags & EDIT_MINOR ) && !$user->isAllowed( 'minoredit' ) ) { + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); + if ( ( $flags & EDIT_MINOR ) && !$permissionManager->userHasRight( $user, 'minoredit' ) ) { $flags = ( $flags & ~EDIT_MINOR ); } @@ -1916,7 +1917,6 @@ class WikiPage implements Page, IDBAccessObject { // TODO: this logic should not be in the storage layer, it's here for compatibility // with 1.31 behavior. Applying the 'autopatrol' right should be done in the same // place the 'bot' right is handled, which is currently in EditPage::attemptSave. - $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); if ( $needsPatrol && $permissionManager->userCan( 'autopatrol', $user, $this->getTitle() @@ -3249,14 +3249,12 @@ class WikiPage implements Page, IDBAccessObject { // Save $flags = EDIT_UPDATE | EDIT_INTERNAL; - if ( $guser->isAllowed( 'minoredit' ) ) { + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); + if ( $permissionManager->userHasRight( $guser, 'minoredit' ) ) { $flags |= EDIT_MINOR; } - if ( $bot && ( MediaWikiServices::getInstance() - ->getPermissionManager() - ->userHasAnyRight( $guser, 'markbotedits', 'bot' ) ) - ) { + if ( $bot && ( $permissionManager->userHasAnyRight( $guser, 'markbotedits', 'bot' ) ) ) { $flags |= EDIT_FORCE_BOT; } @@ -3291,7 +3289,6 @@ class WikiPage implements Page, IDBAccessObject { // TODO: this logic should not be in the storage layer, it's here for compatibility // with 1.31 behavior. Applying the 'autopatrol' right should be done in the same // place the 'bot' right is handled, which is currently in EditPage::attemptSave. - $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); if ( $wgUseRCPatrol && $permissionManager->userCan( 'autopatrol', $guser, $this->getTitle() @@ -3308,7 +3305,7 @@ class WikiPage implements Page, IDBAccessObject { // Set patrolling and bot flag on the edits, which gets rollbacked. // This is done even on edit failure to have patrolling in that case (T64157). $set = []; - if ( $bot && $guser->isAllowed( 'markbotedits' ) ) { + if ( $bot && $permissionManager->userHasRight( $guser, 'markbotedits' ) ) { // Mark all reverted edits as bot $set['rc_bot'] = 1; } @@ -3407,9 +3404,12 @@ class WikiPage implements Page, IDBAccessObject { MediaWikiServices::getInstance()->getLinkCache()->invalidateTitle( $title ); // Invalidate caches of articles which include this page - DeferredUpdates::addUpdate( - new HTMLCacheUpdate( $title, 'templatelinks', 'page-create' ) + $job = HTMLCacheUpdateJob::newForBacklinks( + $title, + 'templatelinks', + [ 'causeAction' => 'page-create' ] ); + JobQueueGroup::singleton()->lazyPush( $job ); if ( $title->getNamespace() == NS_CATEGORY ) { // Load the Category object, which will schedule a job to create @@ -3451,9 +3451,12 @@ class WikiPage implements Page, IDBAccessObject { // Images if ( $title->getNamespace() == NS_FILE ) { - DeferredUpdates::addUpdate( - new HTMLCacheUpdate( $title, 'imagelinks', 'page-delete' ) + $job = HTMLCacheUpdateJob::newForBacklinks( + $title, + 'imagelinks', + [ 'causeAction' => 'page-delete' ] ); + JobQueueGroup::singleton()->lazyPush( $job ); } // User talk pages @@ -3485,20 +3488,24 @@ class WikiPage implements Page, IDBAccessObject { $slotsChanged = null ) { // TODO: move this into a PageEventEmitter service - - if ( $slotsChanged === null || in_array( SlotRecord::MAIN, $slotsChanged ) ) { + $jobs = []; + if ( $slotsChanged === null || in_array( SlotRecord::MAIN, $slotsChanged ) ) { // Invalidate caches of articles which include this page. // Only for the main slot, because only the main slot is transcluded. // TODO: MCR: not true for TemplateStyles! [SlotHandler] - DeferredUpdates::addUpdate( - new HTMLCacheUpdate( $title, 'templatelinks', 'page-edit' ) + $jobs[] = HTMLCacheUpdateJob::newForBacklinks( + $title, + 'templatelinks', + [ 'causeAction' => 'page-edit' ] ); } - // Invalidate the caches of all pages which redirect here - DeferredUpdates::addUpdate( - new HTMLCacheUpdate( $title, 'redirect', 'page-edit' ) + $jobs[] = HTMLCacheUpdateJob::newForBacklinks( + $title, + 'redirect', + [ 'causeAction' => 'page-edit' ] ); + JobQueueGroup::singleton()->lazyPush( $jobs ); MediaWikiServices::getInstance()->getLinkCache()->invalidateTitle( $title ); diff --git a/includes/parser/CoreParserFunctions.php b/includes/parser/CoreParserFunctions.php index e1f4f38a59..b803241956 100644 --- a/includes/parser/CoreParserFunctions.php +++ b/includes/parser/CoreParserFunctions.php @@ -1121,7 +1121,7 @@ class CoreParserFunctions { * @param Parser $parser * @param Title $title * @param string $vary ParserOuput vary-* flag - * @return Revision + * @return Revision|null * @since 1.23 */ private static function getCachedRevisionObject( $parser, $title, $vary ) { diff --git a/includes/parser/PPDPart_Hash.php b/includes/parser/PPDPart_Hash.php index d4f66f7a48..597f851d4a 100644 --- a/includes/parser/PPDPart_Hash.php +++ b/includes/parser/PPDPart_Hash.php @@ -35,6 +35,7 @@ class PPDPart_Hash extends PPDPart { } else { $accum = []; } + // @phan-suppress-next-line PhanTypeMismatchArgument parent::__construct( $accum ); } } diff --git a/includes/parser/Parser.php b/includes/parser/Parser.php index b27338ca2b..ec1628f8d0 100644 --- a/includes/parser/Parser.php +++ b/includes/parser/Parser.php @@ -2312,6 +2312,11 @@ class Parser { $line = $a->current(); # Workaround for broken ArrayIterator::next() that returns "void" $s = substr( $s, 1 ); + if ( is_null( $this->mTitle ) ) { + throw new MWException( __METHOD__ . ": \$this->mTitle is null\n" ); + } + $nottalk = !$this->mTitle->isTalkPage(); + $useLinkPrefixExtension = $this->getTargetLanguage()->linkPrefixExtension(); $e2 = null; if ( $useLinkPrefixExtension ) { @@ -2319,14 +2324,6 @@ class Parser { # e.g. in the case of 'The Arab al[[Razi]]', 'al' will be matched $charset = $this->contLang->linkPrefixCharset(); $e2 = "/^((?>.*[^$charset]|))(.+)$/sDu"; - } - - if ( is_null( $this->mTitle ) ) { - throw new MWException( __METHOD__ . ": \$this->mTitle is null\n" ); - } - $nottalk = !$this->mTitle->isTalkPage(); - - if ( $useLinkPrefixExtension ) { $m = []; if ( preg_match( $e2, $s, $m ) ) { $first_prefix = $m[2]; diff --git a/includes/password/PasswordPolicyChecks.php b/includes/password/PasswordPolicyChecks.php index 8eecbcc2e2..1475c2053c 100644 --- a/includes/password/PasswordPolicyChecks.php +++ b/includes/password/PasswordPolicyChecks.php @@ -54,6 +54,8 @@ class PasswordPolicyChecks { /** * Check password is longer than minimum, fatal. + * Intended for locking out users with passwords too short to trust, requiring them + * to recover their account by some other means. * @param int $policyVal minimal length * @param User $user * @param string $password diff --git a/includes/preferences/DefaultPreferencesFactory.php b/includes/preferences/DefaultPreferencesFactory.php index 66c2bc33e5..68236e5f2e 100644 --- a/includes/preferences/DefaultPreferencesFactory.php +++ b/includes/preferences/DefaultPreferencesFactory.php @@ -20,7 +20,6 @@ namespace MediaWiki\Preferences; -use Config; use DateTime; use DateTimeZone; use Exception; @@ -37,6 +36,7 @@ use MediaWiki\Auth\PasswordAuthenticationRequest; use MediaWiki\Config\ServiceOptions; use MediaWiki\Linker\LinkRenderer; use MediaWiki\MediaWikiServices; +use MediaWiki\Permissions\PermissionManager; use MessageLocalizer; use MWException; use MWTimestamp; @@ -77,6 +77,9 @@ class DefaultPreferencesFactory implements PreferencesFactory { /** @var NamespaceInfo */ protected $nsInfo; + /** @var PermissionManager */ + protected $permissionManager; + /** * TODO Make this a const when we drop HHVM support (T192166) * @@ -114,35 +117,29 @@ class DefaultPreferencesFactory implements PreferencesFactory { /** * Do not call this directly. Get it from MediaWikiServices. * - * @param ServiceOptions|Config $options Config accepted for backwards compatibility + * @param ServiceOptions $options * @param Language $contLang * @param AuthManager $authManager * @param LinkRenderer $linkRenderer - * @param NamespaceInfo|null $nsInfo + * @param NamespaceInfo $nsInfo + * @param PermissionManager $permissionManager */ public function __construct( - $options, + ServiceOptions $options, Language $contLang, AuthManager $authManager, LinkRenderer $linkRenderer, - NamespaceInfo $nsInfo = null + NamespaceInfo $nsInfo, + PermissionManager $permissionManager ) { - if ( $options instanceof Config ) { - wfDeprecated( __METHOD__ . ' with Config parameter', '1.34' ); - $options = new ServiceOptions( self::$constructorOptions, $options ); - } - $options->assertRequiredOptions( self::$constructorOptions ); - if ( !$nsInfo ) { - wfDeprecated( __METHOD__ . ' with no NamespaceInfo argument', '1.34' ); - $nsInfo = MediaWikiServices::getInstance()->getNamespaceInfo(); - } $this->options = $options; $this->contLang = $contLang; $this->authManager = $authManager; $this->linkRenderer = $linkRenderer; $this->nsInfo = $nsInfo; + $this->permissionManager = $permissionManager; $this->logger = new NullLogger(); } @@ -209,7 +206,7 @@ class DefaultPreferencesFactory implements PreferencesFactory { # # Make sure that form fields have their parent set. See T43337. $dummyForm = new HTMLForm( [], $context ); - $disable = !$user->isAllowed( 'editmyoptions' ); + $disable = !$this->permissionManager->userHasRight( $user, 'editmyoptions' ); $defaultOptions = User::getDefaultOptions(); $userOptions = $user->getOptions(); @@ -390,8 +387,8 @@ class DefaultPreferencesFactory implements PreferencesFactory { ]; } - $canViewPrivateInfo = $user->isAllowed( 'viewmyprivateinfo' ); - $canEditPrivateInfo = $user->isAllowed( 'editmyprivateinfo' ); + $canViewPrivateInfo = $this->permissionManager->userHasRight( $user, 'viewmyprivateinfo' ); + $canEditPrivateInfo = $this->permissionManager->userHasRight( $user, 'editmyprivateinfo' ); // Actually changeable stuff $defaultPreferences['realname'] = [ @@ -631,7 +628,9 @@ class DefaultPreferencesFactory implements PreferencesFactory { ]; } - if ( $this->options->get( 'EnableUserEmail' ) && $user->isAllowed( 'sendemail' ) ) { + if ( $this->options->get( 'EnableUserEmail' ) && + $this->permissionManager->userHasRight( $user, 'sendemail' ) + ) { $defaultPreferences['disablemail'] = [ 'id' => 'wpAllowEmail', 'type' => 'toggle', @@ -921,7 +920,7 @@ class DefaultPreferencesFactory implements PreferencesFactory { 'label-message' => 'tog-numberheadings', ]; - if ( $user->isAllowed( 'rollback' ) ) { + if ( $this->permissionManager->userHasRight( $user, 'rollback' ) ) { $defaultPreferences['showrollbackconfirmation'] = [ 'type' => 'toggle', 'section' => 'rendering/advancedrendering', @@ -961,7 +960,7 @@ class DefaultPreferencesFactory implements PreferencesFactory { ]; } - if ( $user->isAllowed( 'minoredit' ) ) { + if ( $this->permissionManager->userHasRight( $user, 'minoredit' ) ) { $defaultPreferences['minordefault'] = [ 'type' => 'toggle', 'section' => 'editing/editor', @@ -1107,7 +1106,7 @@ class DefaultPreferencesFactory implements PreferencesFactory { $watchlistdaysMax = ceil( $this->options->get( 'RCMaxAge' ) / ( 3600 * 24 ) ); # # Watchlist ##################################### - if ( $user->isAllowed( 'editmywatchlist' ) ) { + if ( $this->permissionManager->userHasRight( $user, 'editmywatchlist' ) ) { $editWatchlistLinks = ''; $editWatchlistModes = [ 'edit' => [ 'subpage' => false, 'flags' => [] ], @@ -1221,20 +1220,20 @@ class DefaultPreferencesFactory implements PreferencesFactory { ]; // Kinda hacky - if ( $user->isAllowed( 'createpage' ) || $user->isAllowed( 'createtalk' ) ) { + if ( $this->permissionManager->userHasAnyRight( $user, 'createpage', 'createtalk' ) ) { $watchTypes['read'] = 'watchcreations'; } - if ( $user->isAllowed( 'rollback' ) ) { + if ( $this->permissionManager->userHasRight( $user, 'rollback' ) ) { $watchTypes['rollback'] = 'watchrollback'; } - if ( $user->isAllowed( 'upload' ) ) { + if ( $this->permissionManager->userHasRight( $user, 'upload' ) ) { $watchTypes['upload'] = 'watchuploads'; } foreach ( $watchTypes as $action => $pref ) { - if ( $user->isAllowed( $action ) ) { + if ( $this->permissionManager->userHasRight( $user, $action ) ) { // Messages: // tog-watchdefault, tog-watchmoves, tog-watchdeletion, tog-watchcreations, tog-watchuploads // tog-watchrollback @@ -1521,7 +1520,7 @@ class DefaultPreferencesFactory implements PreferencesFactory { } /** - * @var HTMLForm $htmlForm + * @var PreferencesFormOOUI $htmlForm */ $htmlForm = new $formClass( $formDescriptor, $context, 'prefs' ); @@ -1534,6 +1533,10 @@ class DefaultPreferencesFactory implements PreferencesFactory { ] ) ); $htmlForm->setModifiedUser( $user ); + $htmlForm->setOptionsEditable( $this->permissionManager + ->userHasRight( $user, 'editmyoptions' ) ); + $htmlForm->setPrivateInfoEditable( $this->permissionManager + ->userHasRight( $user, 'editmyprivateinfo' ) ); $htmlForm->setId( 'mw-prefs-form' ); $htmlForm->setAutocomplete( 'off' ); $htmlForm->setSubmitText( $context->msg( 'saveprefs' )->text() ); @@ -1541,7 +1544,7 @@ class DefaultPreferencesFactory implements PreferencesFactory { $htmlForm->setSubmitTooltip( 'preferences-save' ); $htmlForm->setSubmitID( 'prefcontrol' ); $htmlForm->setSubmitCallback( - function ( array $formData, HTMLForm $form ) use ( $formDescriptor ) { + function ( array $formData, PreferencesFormOOUI $form ) use ( $formDescriptor ) { return $this->submitForm( $formData, $form, $formDescriptor ); } ); @@ -1606,7 +1609,9 @@ class DefaultPreferencesFactory implements PreferencesFactory { $hiddenPrefs = $this->options->get( 'HiddenPrefs' ); $result = true; - if ( !$user->isAllowedAny( 'editmyprivateinfo', 'editmyoptions' ) ) { + if ( !$this->permissionManager + ->userHasAnyRight( $user, 'editmyprivateinfo', 'editmyoptions' ) + ) { return Status::newFatal( 'mypreferencesprotected' ); } @@ -1617,14 +1622,14 @@ class DefaultPreferencesFactory implements PreferencesFactory { // (not really "private", but still shouldn't be edited without permission) if ( !in_array( 'realname', $hiddenPrefs ) - && $user->isAllowed( 'editmyprivateinfo' ) + && $this->permissionManager->userHasRight( $user, 'editmyprivateinfo' ) && array_key_exists( 'realname', $formData ) ) { $realName = $formData['realname']; $user->setRealName( $realName ); } - if ( $user->isAllowed( 'editmyoptions' ) ) { + if ( $this->permissionManager->userHasRight( $user, 'editmyoptions' ) ) { $oldUserOptions = $user->getOptions(); foreach ( $this->getSaveBlacklist() as $b ) { diff --git a/includes/profiler/SectionProfiler.php b/includes/profiler/SectionProfiler.php index c27ab4f3f4..92e276d766 100644 --- a/includes/profiler/SectionProfiler.php +++ b/includes/profiler/SectionProfiler.php @@ -96,9 +96,15 @@ class SectionProfiler { public function getFunctionStats() { $this->collateData(); - $totalCpu = max( $this->end['cpu'] - $this->start['cpu'], 0 ); - $totalReal = max( $this->end['real'] - $this->start['real'], 0 ); - $totalMem = max( $this->end['memory'] - $this->start['memory'], 0 ); + if ( is_array( $this->start ) ) { + $totalCpu = max( $this->end['cpu'] - $this->start['cpu'], 0 ); + $totalReal = max( $this->end['real'] - $this->start['real'], 0 ); + $totalMem = max( $this->end['memory'] - $this->start['memory'], 0 ); + } else { + $totalCpu = 0; + $totalReal = 0; + $totalMem = 0; + } $profile = []; foreach ( $this->collated as $fname => $data ) { diff --git a/includes/resourceloader/DerivativeResourceLoaderContext.php b/includes/resourceloader/DerivativeResourceLoaderContext.php index d84a92a914..0a1d5f7789 100644 --- a/includes/resourceloader/DerivativeResourceLoaderContext.php +++ b/includes/resourceloader/DerivativeResourceLoaderContext.php @@ -1,7 +1,5 @@ . + */ + +/** + * ResourceLoader is a loading system for JavaScript and CSS resources. + * + * For higher level documentation, see . * - * Most of the documentation is on the MediaWiki documentation wiki starting at: - * https://www.mediawiki.org/wiki/ResourceLoader + * @ingroup ResourceLoader + * @since 1.17 */ class ResourceLoader implements LoggerAwareInterface { - /** @var Config $config */ + /** @var Config */ protected $config; /** @var MessageBlobStore */ protected $blobStore; diff --git a/includes/resourceloader/ResourceLoaderCircularDependencyError.php b/includes/resourceloader/ResourceLoaderCircularDependencyError.php index 7cd53fe126..5a62861963 100644 --- a/includes/resourceloader/ResourceLoaderCircularDependencyError.php +++ b/includes/resourceloader/ResourceLoaderCircularDependencyError.php @@ -1,6 +1,5 @@ ` root node to the `` wrapper while ( $root->firstChild ) { $node = $root->firstChild; + // @phan-suppress-next-line PhanUndeclaredProperty False positive if ( !$titleNode && $node->nodeType === XML_ELEMENT_NODE && $node->tagName === 'title' ) { // Remember the first encountered `` node $titleNode = $node; diff --git a/includes/resourceloader/ResourceLoaderImageModule.php b/includes/resourceloader/ResourceLoaderImageModule.php index 902fa91b79..0585cfdbe7 100644 --- a/includes/resourceloader/ResourceLoaderImageModule.php +++ b/includes/resourceloader/ResourceLoaderImageModule.php @@ -1,7 +1,5 @@ <?php /** - * ResourceLoader module for generated and embedded images. - * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or @@ -22,8 +20,9 @@ */ /** - * ResourceLoader module for generated and embedded images. + * Module for generated and embedded images. * + * @ingroup ResourceLoader * @since 1.25 */ class ResourceLoaderImageModule extends ResourceLoaderModule { diff --git a/includes/resourceloader/ResourceLoaderLanguageDataModule.php b/includes/resourceloader/ResourceLoaderLanguageDataModule.php index c0a0921e11..ffc9b3d589 100644 --- a/includes/resourceloader/ResourceLoaderLanguageDataModule.php +++ b/includes/resourceloader/ResourceLoaderLanguageDataModule.php @@ -20,7 +20,10 @@ */ /** - * ResourceLoader module for populating language specific data, such as grammar forms. + * Module for populating language specific data, such as grammar forms. + * + * @ingroup ResourceLoader + * @internal */ class ResourceLoaderLanguageDataModule extends ResourceLoaderFileModule { diff --git a/includes/resourceloader/ResourceLoaderLessVarFileModule.php b/includes/resourceloader/ResourceLoaderLessVarFileModule.php index 0269ec3ddb..49501ff735 100644 --- a/includes/resourceloader/ResourceLoaderLessVarFileModule.php +++ b/includes/resourceloader/ResourceLoaderLessVarFileModule.php @@ -1,7 +1,28 @@ <?php +/** + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program; if not, write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + * http://www.gnu.org/copyleft/gpl.html + * + * @file + */ /** - * Subclass with context specific LESS variables + * Module augmented with context-specific LESS variables. + * + * @ingroup ResourceLoader + * @since 1.32 */ class ResourceLoaderLessVarFileModule extends ResourceLoaderFileModule { protected $lessVariables = []; diff --git a/includes/resourceloader/ResourceLoaderModule.php b/includes/resourceloader/ResourceLoaderModule.php index ed2d09c8dc..c9fd267d12 100644 --- a/includes/resourceloader/ResourceLoaderModule.php +++ b/includes/resourceloader/ResourceLoaderModule.php @@ -1,7 +1,5 @@ <?php /** - * Abstraction for ResourceLoader modules. - * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or @@ -32,6 +30,9 @@ use Wikimedia\ScopedCallback; /** * Abstraction for ResourceLoader modules, with name registration and maxage functionality. + * + * @ingroup ResourceLoader + * @since 1.17 */ abstract class ResourceLoaderModule implements LoggerAwareInterface { /** @var Config */ diff --git a/includes/resourceloader/ResourceLoaderOOUIFileModule.php b/includes/resourceloader/ResourceLoaderOOUIFileModule.php index 7d39a58e9c..e1a2711f45 100644 --- a/includes/resourceloader/ResourceLoaderOOUIFileModule.php +++ b/includes/resourceloader/ResourceLoaderOOUIFileModule.php @@ -19,10 +19,11 @@ */ /** - * ResourceLoaderFileModule which magically loads the right skinScripts and skinStyles for every + * Module which magically loads the right skinScripts and skinStyles for every * skin, using the specified OOUI theme for each. * - * @since 1.30 + * @ingroup ResourceLoader + * @internal */ class ResourceLoaderOOUIFileModule extends ResourceLoaderFileModule { use ResourceLoaderOOUIModule; diff --git a/includes/resourceloader/ResourceLoaderOOUIIconPackModule.php b/includes/resourceloader/ResourceLoaderOOUIIconPackModule.php index c860362af7..11c59a07c5 100644 --- a/includes/resourceloader/ResourceLoaderOOUIIconPackModule.php +++ b/includes/resourceloader/ResourceLoaderOOUIIconPackModule.php @@ -21,6 +21,7 @@ /** * Allows loading arbitrary sets of OOUI icons. * + * @ingroup ResourceLoader * @since 1.34 */ class ResourceLoaderOOUIIconPackModule extends ResourceLoaderOOUIImageModule { diff --git a/includes/resourceloader/ResourceLoaderOOUIModule.php b/includes/resourceloader/ResourceLoaderOOUIModule.php index fdcc2135e2..007bbd14c0 100644 --- a/includes/resourceloader/ResourceLoaderOOUIModule.php +++ b/includes/resourceloader/ResourceLoaderOOUIModule.php @@ -21,7 +21,8 @@ /** * Convenience methods for dealing with OOUI themes and their relations to MW skins. * - * @since 1.30 + * @ingroup ResourceLoader + * @internal */ trait ResourceLoaderOOUIModule { protected static $knownScriptsModules = [ 'core' ]; diff --git a/includes/resourceloader/ResourceLoaderSiteModule.php b/includes/resourceloader/ResourceLoaderSiteModule.php index 236112ea2f..0ae8371f4a 100644 --- a/includes/resourceloader/ResourceLoaderSiteModule.php +++ b/includes/resourceloader/ResourceLoaderSiteModule.php @@ -1,7 +1,5 @@ <?php /** - * ResourceLoader module for site customizations. - * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or @@ -23,7 +21,10 @@ */ /** - * Module for site customizations + * Module for site customizations. + * + * @ingroup ResourceLoader + * @internal */ class ResourceLoaderSiteModule extends ResourceLoaderWikiModule { diff --git a/includes/resourceloader/ResourceLoaderSiteStylesModule.php b/includes/resourceloader/ResourceLoaderSiteStylesModule.php index 79922bfe36..be4e31ded4 100644 --- a/includes/resourceloader/ResourceLoaderSiteStylesModule.php +++ b/includes/resourceloader/ResourceLoaderSiteStylesModule.php @@ -1,7 +1,5 @@ <?php /** - * ResourceLoader module for site style customizations. - * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or @@ -23,7 +21,10 @@ */ /** - * Module for site style customizations + * Module for site style customizations. + * + * @ingroup ResourceLoader + * @internal */ class ResourceLoaderSiteStylesModule extends ResourceLoaderWikiModule { diff --git a/includes/resourceloader/ResourceLoaderSkinModule.php b/includes/resourceloader/ResourceLoaderSkinModule.php index 0f33666216..e7ab9512da 100644 --- a/includes/resourceloader/ResourceLoaderSkinModule.php +++ b/includes/resourceloader/ResourceLoaderSkinModule.php @@ -19,7 +19,10 @@ */ /** - * ResourceLoader module for skin stylesheets. + * Module for skin stylesheets. + * + * @ingroup ResourceLoader + * @internal */ class ResourceLoaderSkinModule extends ResourceLoaderFileModule { /** diff --git a/includes/resourceloader/ResourceLoaderStartUpModule.php b/includes/resourceloader/ResourceLoaderStartUpModule.php index 9f583a5933..78775fb597 100644 --- a/includes/resourceloader/ResourceLoaderStartUpModule.php +++ b/includes/resourceloader/ResourceLoaderStartUpModule.php @@ -38,6 +38,9 @@ use MediaWiki\MediaWikiServices; * - safemode: Only register modules that have ORIGIN_CORE as their origin. * This effectively disables ORIGIN_USER modules. (T185303) * See also: OutputPage::disallowUserJs() + * + * @ingroup ResourceLoader + * @internal */ class ResourceLoaderStartUpModule extends ResourceLoaderModule { protected $targets = [ 'desktop', 'mobile' ]; diff --git a/includes/resourceloader/ResourceLoaderUserDefaultsModule.php b/includes/resourceloader/ResourceLoaderUserDefaultsModule.php index 61cff822c9..9610cce2ff 100644 --- a/includes/resourceloader/ResourceLoaderUserDefaultsModule.php +++ b/includes/resourceloader/ResourceLoaderUserDefaultsModule.php @@ -1,7 +1,5 @@ <?php /** - * ResourceLoader module for default user preferences. - * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or @@ -23,6 +21,9 @@ /** * Module for default user preferences. + * + * @ingroup ResourceLoader + * @internal */ class ResourceLoaderUserDefaultsModule extends ResourceLoaderModule { diff --git a/includes/resourceloader/ResourceLoaderUserModule.php b/includes/resourceloader/ResourceLoaderUserModule.php index 026cea101e..479423146e 100644 --- a/includes/resourceloader/ResourceLoaderUserModule.php +++ b/includes/resourceloader/ResourceLoaderUserModule.php @@ -21,7 +21,10 @@ */ /** - * Module for user customizations scripts + * Module for user customizations scripts. + * + * @ingroup ResourceLoader + * @internal */ class ResourceLoaderUserModule extends ResourceLoaderWikiModule { diff --git a/includes/resourceloader/ResourceLoaderUserOptionsModule.php b/includes/resourceloader/ResourceLoaderUserOptionsModule.php index ecbb50193c..866d98bb14 100644 --- a/includes/resourceloader/ResourceLoaderUserOptionsModule.php +++ b/includes/resourceloader/ResourceLoaderUserOptionsModule.php @@ -1,7 +1,5 @@ <?php /** - * ResourceLoader module for user preference customizations. - * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or @@ -23,7 +21,10 @@ */ /** - * Module for user preference customizations + * Module for user preferences. + * + * @ingroup ResourceLoader + * @internal */ class ResourceLoaderUserOptionsModule extends ResourceLoaderModule { diff --git a/includes/resourceloader/ResourceLoaderUserStylesModule.php b/includes/resourceloader/ResourceLoaderUserStylesModule.php index 69e8a97a13..fe949aa058 100644 --- a/includes/resourceloader/ResourceLoaderUserStylesModule.php +++ b/includes/resourceloader/ResourceLoaderUserStylesModule.php @@ -21,7 +21,10 @@ */ /** - * Module for user customizations styles + * Module for user customizations styles. + * + * @ingroup ResourceLoader + * @internal */ class ResourceLoaderUserStylesModule extends ResourceLoaderWikiModule { diff --git a/includes/resourceloader/ResourceLoaderUserTokensModule.php b/includes/resourceloader/ResourceLoaderUserTokensModule.php index 85c14cb992..45edd6e903 100644 --- a/includes/resourceloader/ResourceLoaderUserTokensModule.php +++ b/includes/resourceloader/ResourceLoaderUserTokensModule.php @@ -1,7 +1,5 @@ <?php /** - * ResourceLoader module for user tokens. - * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or @@ -18,11 +16,13 @@ * http://www.gnu.org/copyleft/gpl.html * * @file - * @author Krinkle */ /** - * Module for user tokens + * Module for user authorization tokens. + * + * @ingroup ResourceLoader + * @internal */ class ResourceLoaderUserTokensModule extends ResourceLoaderModule { diff --git a/includes/resourceloader/ResourceLoaderWikiModule.php b/includes/resourceloader/ResourceLoaderWikiModule.php index a2501c40d0..37501d4f7a 100644 --- a/includes/resourceloader/ResourceLoaderWikiModule.php +++ b/includes/resourceloader/ResourceLoaderWikiModule.php @@ -1,7 +1,5 @@ <?php /** - * Abstraction for ResourceLoader modules that pull from wiki pages. - * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or @@ -23,7 +21,7 @@ */ use MediaWiki\Linker\LinkTarget; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; use Wikimedia\Assert\Assert; use Wikimedia\Rdbms\Database; use Wikimedia\Rdbms\IDatabase; @@ -48,6 +46,9 @@ use MediaWiki\MediaWikiServices; * - getDB() * - isKnownEmpty() * - getTitleInfo() + * + * @ingroup ResourceLoader + * @since 1.17 */ class ResourceLoaderWikiModule extends ResourceLoaderModule { diff --git a/includes/revisiondelete/RevDelArchivedFileItem.php b/includes/revisiondelete/RevDelArchivedFileItem.php index 5b03ad03ff..ab5d9541be 100644 --- a/includes/revisiondelete/RevDelArchivedFileItem.php +++ b/includes/revisiondelete/RevDelArchivedFileItem.php @@ -19,7 +19,7 @@ * @ingroup RevisionDelete */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; /** * Item class for a filearchive table row diff --git a/includes/revisiondelete/RevDelFileItem.php b/includes/revisiondelete/RevDelFileItem.php index 8c080baf83..33ce11b9fa 100644 --- a/includes/revisiondelete/RevDelFileItem.php +++ b/includes/revisiondelete/RevDelFileItem.php @@ -19,7 +19,7 @@ * @ingroup RevisionDelete */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; /** * Item class for an oldimage table row diff --git a/includes/revisiondelete/RevDelList.php b/includes/revisiondelete/RevDelList.php index f4ea54f0a1..746ca27b73 100644 --- a/includes/revisiondelete/RevDelList.php +++ b/includes/revisiondelete/RevDelList.php @@ -20,7 +20,7 @@ */ use MediaWiki\MediaWikiServices; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; /** * Abstract base class for a list of deletable items. The list class diff --git a/includes/revisiondelete/RevDelLogItem.php b/includes/revisiondelete/RevDelLogItem.php index edb86da98f..829eefa7a5 100644 --- a/includes/revisiondelete/RevDelLogItem.php +++ b/includes/revisiondelete/RevDelLogItem.php @@ -19,7 +19,7 @@ * @ingroup RevisionDelete */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; /** * Item class for a logging table row diff --git a/includes/revisiondelete/RevDelLogList.php b/includes/revisiondelete/RevDelLogList.php index fcdcb9a592..adb3974f23 100644 --- a/includes/revisiondelete/RevDelLogList.php +++ b/includes/revisiondelete/RevDelLogList.php @@ -19,7 +19,7 @@ * @ingroup RevisionDelete */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; use Wikimedia\Rdbms\IDatabase; /** diff --git a/includes/revisiondelete/RevDelRevisionItem.php b/includes/revisiondelete/RevDelRevisionItem.php index f61d378dc0..604ab2cfdc 100644 --- a/includes/revisiondelete/RevDelRevisionItem.php +++ b/includes/revisiondelete/RevDelRevisionItem.php @@ -19,7 +19,7 @@ * @ingroup RevisionDelete */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; /** * Item class for a live revision table row diff --git a/includes/revisiondelete/RevDelRevisionList.php b/includes/revisiondelete/RevDelRevisionList.php index 0705503e9b..011386e5ff 100644 --- a/includes/revisiondelete/RevDelRevisionList.php +++ b/includes/revisiondelete/RevDelRevisionList.php @@ -19,7 +19,7 @@ * @ingroup RevisionDelete */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; use Wikimedia\Rdbms\FakeResultWrapper; use Wikimedia\Rdbms\IDatabase; diff --git a/includes/revisiondelete/RevisionDeleteUser.php b/includes/revisiondelete/RevisionDeleteUser.php index 9a9ab196b5..00e77e105f 100644 --- a/includes/revisiondelete/RevisionDeleteUser.php +++ b/includes/revisiondelete/RevisionDeleteUser.php @@ -21,7 +21,7 @@ * @ingroup RevisionDelete */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; use Wikimedia\Rdbms\IDatabase; /** diff --git a/includes/revisiondelete/RevisionDeleter.php b/includes/revisiondelete/RevisionDeleter.php index 3ab96cb0c6..6361a7a8f3 100644 --- a/includes/revisiondelete/RevisionDeleter.php +++ b/includes/revisiondelete/RevisionDeleter.php @@ -21,7 +21,7 @@ * @ingroup RevisionDelete */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; /** * General controller for RevDel, used by both SpecialRevisiondelete and diff --git a/includes/revisionlist/RevisionItem.php b/includes/revisionlist/RevisionItem.php index bf90c068b6..85c01c8e84 100644 --- a/includes/revisionlist/RevisionItem.php +++ b/includes/revisionlist/RevisionItem.php @@ -20,7 +20,7 @@ * @file */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; /** * Item class for a live revision table row diff --git a/includes/site/MediaWikiSite.php b/includes/site/MediaWikiSite.php index 14c9a7315d..3e2a9a2b40 100644 --- a/includes/site/MediaWikiSite.php +++ b/includes/site/MediaWikiSite.php @@ -176,7 +176,7 @@ class MediaWikiSite extends Site { * * @param string|bool $pageName Page name or false (default: false) * - * @return string + * @return string|bool|null */ public function getPageUrl( $pageName = false ) { $url = $this->getLinkPath(); diff --git a/includes/site/Site.php b/includes/site/Site.php index bcf8b32b88..10711a6fbb 100644 --- a/includes/site/Site.php +++ b/includes/site/Site.php @@ -365,7 +365,7 @@ class Site implements Serializable { * * @param bool|string $pageName * - * @return string|bool + * @return string|bool|null */ public function getPageUrl( $pageName = false ) { $url = $this->getLinkPath(); diff --git a/includes/site/SiteImporter.php b/includes/site/SiteImporter.php index 956bdab37e..571b6e44c6 100644 --- a/includes/site/SiteImporter.php +++ b/includes/site/SiteImporter.php @@ -168,6 +168,7 @@ class SiteImporter { $pathTags = $siteElement->getElementsByTagName( 'path' ); for ( $i = 0; $i < $pathTags->length; $i++ ) { $pathElement = $pathTags->item( $i ); + '@phan-var DOMElement $pathElement'; $pathType = $this->getAttributeValue( $pathElement, 'type' ); $path = $pathElement->textContent; @@ -177,6 +178,7 @@ class SiteImporter { $idTags = $siteElement->getElementsByTagName( 'localid' ); for ( $i = 0; $i < $idTags->length; $i++ ) { $idElement = $idTags->item( $i ); + '@phan-var DOMElement $idElement'; $idType = $this->getAttributeValue( $idElement, 'type' ); $id = $idElement->textContent; diff --git a/includes/skins/BaseTemplate.php b/includes/skins/BaseTemplate.php index cd63796088..dedf83abc8 100644 --- a/includes/skins/BaseTemplate.php +++ b/includes/skins/BaseTemplate.php @@ -48,7 +48,7 @@ abstract class BaseTemplate extends QuickTemplate { * @deprecated since 1.33 Use ->msg() or ->getMsg() instead. */ function msgWiki( $str ) { - // TODO: Add wfDeprecated( __METHOD__, '1.33' ) after 1.33 got released + wfDeprecated( __METHOD__, '1.33' ); // Hard-deprecated in 1.34 echo $this->getMsg( $str )->parseAsBlock(); } @@ -756,6 +756,7 @@ abstract class BaseTemplate extends QuickTemplate { */ public function getTrail() { return WrappedString::join( "\n", [ + // @phan-suppress-next-line PhanTypeMismatchArgument MWDebug::getDebugHTML( $this->getSkin()->getContext() ), $this->get( 'bottomscripts' ), $this->get( 'reporttime' ) diff --git a/includes/skins/SkinTemplate.php b/includes/skins/SkinTemplate.php index 70df73bc21..327061c681 100644 --- a/includes/skins/SkinTemplate.php +++ b/includes/skins/SkinTemplate.php @@ -595,7 +595,7 @@ class SkinTemplate extends Skin { # $this->getTitle() will just give Special:Badtitle, which is # not especially useful as a returnto parameter. Use the title # from the request instead, if there was one. - if ( $this->getUser()->isAllowed( 'read' ) ) { + if ( $permissionManager->userHasRight( $this->getUser(), 'read' ) ) { $page = $this->getTitle(); } else { $page = Title::newFromText( $request->getVal( 'title', '' ) ); @@ -636,7 +636,7 @@ class SkinTemplate extends Skin { 'active' => ( $href == $pageurl ) ]; - if ( $this->getUser()->isAllowed( 'viewmywatchlist' ) ) { + if ( $permissionManager->userHasRight( $this->getUser(), 'viewmywatchlist' ) ) { $href = self::makeSpecialUrl( 'Watchlist' ); $personal_urls['watchlist'] = [ 'text' => $this->msg( 'mywatchlist' )->text(), @@ -689,9 +689,8 @@ class SkinTemplate extends Skin { $useCombinedLoginLink = false; } - $loginlink = $this->getUser()->isAllowed( 'createaccount' ) && $useCombinedLoginLink - ? 'nav-login-createaccount' - : 'pt-login'; + $loginlink = $permissionManager->userHasRight( $this->getUser(), 'createaccount' ) + && $useCombinedLoginLink ? 'nav-login-createaccount' : 'pt-login'; $login_url = [ 'text' => $this->msg( $loginlink )->text(), @@ -727,7 +726,7 @@ class SkinTemplate extends Skin { if ( $authManager->canCreateAccounts() - && $this->getUser()->isAllowed( 'createaccount' ) + && $permissionManager->userHasRight( $this->getUser(), 'createaccount' ) && !$useCombinedLoginLink ) { $personal_urls['createaccount'] = $createaccount_url; @@ -1074,8 +1073,7 @@ class SkinTemplate extends Skin { if ( $permissionManager->quickUserCan( 'protect', $user, $title ) && $title->getRestrictionTypes() && - $permissionManager->getNamespaceRestrictionLevels( $title->getNamespace(), - $user ) !== [ '' ] + $permissionManager->getNamespaceRestrictionLevels( $title->getNamespace(), $user ) !== [ '' ] ) { $mode = $title->isProtected() ? 'unprotect' : 'protect'; $content_navigation['actions'][$mode] = [ @@ -1345,7 +1343,10 @@ class SkinTemplate extends Skin { 'href' => self::makeSpecialUrlSubpage( 'Log', $rootUser ) ]; - if ( $this->getUser()->isAllowed( 'block' ) ) { + if ( MediawikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'block' ) + ) { $nav_urls['blockip'] = [ 'text' => $this->msg( 'blockip', $rootUser )->text(), 'href' => self::makeSpecialUrlSubpage( 'Block', $rootUser ) diff --git a/includes/specialpage/ChangesListSpecialPage.php b/includes/specialpage/ChangesListSpecialPage.php index 0954c45383..bf5734a0f9 100644 --- a/includes/specialpage/ChangesListSpecialPage.php +++ b/includes/specialpage/ChangesListSpecialPage.php @@ -884,87 +884,85 @@ abstract class ChangesListSpecialPage extends SpecialPage { } /** - * Get (cheap to compute) information about change tags. + * Get information about change tags, without parsing messages, for getRcFiltersConfigSummary(). + * + * Message contents are the raw values (->plain()), because parsing messages is expensive. + * Even though we're not parsing messages, building a data structure with the contents of + * hundreds of i18n messages is still not cheap (see T223260#5370610), so the result of this + * function is cached in WANCache for 24 hours. * * Returns an array of associative arrays with information about each tag: * - name: Tag name (string) * - labelMsg: Short description message (Message object) + * - label: Short description message (raw message contents) * - descriptionMsg: Long description message (Message object) + * - description: Long description message (raw message contents) * - cssClass: CSS class to use for RC entries with this tag * - hits: Number of RC entries that have this tag * * @param ResourceLoaderContext $context * @return array[] Information about each tag */ - protected static function getChangeTagInfo( ResourceLoaderContext $context ) { - $explicitlyDefinedTags = array_fill_keys( ChangeTags::listExplicitlyDefinedTags(), 0 ); - $softwareActivatedTags = array_fill_keys( ChangeTags::listSoftwareActivatedTags(), 0 ); - - $tagStats = ChangeTags::tagUsageStatistics(); - $tagHitCounts = array_merge( $explicitlyDefinedTags, $softwareActivatedTags, $tagStats ); - - $result = []; - foreach ( $tagHitCounts as $tagName => $hits ) { - if ( - ( - // Only get active tags - isset( $explicitlyDefinedTags[ $tagName ] ) || - isset( $softwareActivatedTags[ $tagName ] ) - ) && - // Only get tags with more than 0 hits - $hits > 0 - ) { - $labelMsg = ChangeTags::tagShortDescriptionMessage( $tagName, $context ); - if ( $labelMsg === false ) { - // Tag is hidden, skip it - continue; - } - $result[] = [ - 'name' => $tagName, - // 'label' and 'description' filled in by getChangeTagList() - 'labelMsg' => $labelMsg, - 'descriptionMsg' => ChangeTags::tagLongDescriptionMessage( $tagName, $context ), - 'cssClass' => Sanitizer::escapeClass( 'mw-tag-' . $tagName ), - 'hits' => $hits, - ]; - } - } - return $result; - } - - /** - * Get information about change tags for use in getRcFiltersConfigSummary(). - * - * This expands labelMsg and descriptionMsg to the raw values of each message, which captures - * changes in the messages but avoids the expensive step of parsing them. - * - * @param ResourceLoaderContext $context - * @return array[] Result of getChangeTagInfo(), with messages expanded to raw contents - */ protected static function getChangeTagListSummary( ResourceLoaderContext $context ) { - $tags = self::getChangeTagInfo( $context ); - foreach ( $tags as &$tagInfo ) { - $tagInfo['labelMsg'] = $tagInfo['labelMsg']->plain(); - if ( $tagInfo['descriptionMsg'] ) { - $tagInfo['descriptionMsg'] = $tagInfo['descriptionMsg']->plain(); + $cache = MediaWikiServices::getInstance()->getMainWANObjectCache(); + return $cache->getWithSetCallback( + $cache->makeKey( 'ChangesListSpecialPage-changeTagListSummary', $context->getLanguage() ), + WANObjectCache::TTL_DAY, + function ( $oldValue, &$ttl, array &$setOpts ) use ( $context ) { + $explicitlyDefinedTags = array_fill_keys( ChangeTags::listExplicitlyDefinedTags(), 0 ); + $softwareActivatedTags = array_fill_keys( ChangeTags::listSoftwareActivatedTags(), 0 ); + + $tagStats = ChangeTags::tagUsageStatistics(); + $tagHitCounts = array_merge( $explicitlyDefinedTags, $softwareActivatedTags, $tagStats ); + + $result = []; + foreach ( $tagHitCounts as $tagName => $hits ) { + if ( + ( + // Only get active tags + isset( $explicitlyDefinedTags[ $tagName ] ) || + isset( $softwareActivatedTags[ $tagName ] ) + ) && + // Only get tags with more than 0 hits + $hits > 0 + ) { + $labelMsg = ChangeTags::tagShortDescriptionMessage( $tagName, $context ); + if ( $labelMsg === false ) { + // Tag is hidden, skip it + continue; + } + $descriptionMsg = ChangeTags::tagLongDescriptionMessage( $tagName, $context ); + $result[] = [ + 'name' => $tagName, + 'labelMsg' => $labelMsg, + 'label' => $labelMsg->plain(), + 'descriptionMsg' => $descriptionMsg, + 'description' => $descriptionMsg ? $descriptionMsg->plain() : '', + 'cssClass' => Sanitizer::escapeClass( 'mw-tag-' . $tagName ), + 'hits' => $hits, + ]; + } + } + return $result; } - } - return $tags; + ); } /** * Get information about change tags to export to JS via getRcFiltersConfigVars(). * - * This removes labelMsg and descriptionMsg, and adds label and description, which are parsed, - * stripped and (in the case of description) truncated versions of these messages. Message + * This manipulates the label and description of each tag, which are parsed, stripped + * and (in the case of description) truncated versions of these messages. Message * parsing is expensive, so to detect whether the tag list has changed, use * getChangeTagListSummary() instead. * + * The result of this function is cached in WANCache for 24 hours. + * * @param ResourceLoaderContext $context - * @return array[] Result of getChangeTagInfo(), with messages parsed, stripped and truncated + * @return array[] Same as getChangeTagListSummary(), with messages parsed, stripped and truncated */ protected static function getChangeTagList( ResourceLoaderContext $context ) { - $tags = self::getChangeTagInfo( $context ); + $tags = self::getChangeTagListSummary( $context ); $language = Language::factory( $context->getLanguage() ); foreach ( $tags as &$tagInfo ) { $tagInfo['label'] = Sanitizer::stripAllTags( $tagInfo['labelMsg']->parse() ); diff --git a/includes/specialpage/LoginSignupSpecialPage.php b/includes/specialpage/LoginSignupSpecialPage.php index e5a28d9307..8be029aac8 100644 --- a/includes/specialpage/LoginSignupSpecialPage.php +++ b/includes/specialpage/LoginSignupSpecialPage.php @@ -441,7 +441,9 @@ abstract class LoginSignupSpecialPage extends AuthManagerSpecialPage { } if ( $extraMessages ) { $extraMessages = Status::wrap( $extraMessages ); - $out->addWikiTextAsInterface( $extraMessages->getWikiText() ); + $out->addWikiTextAsInterface( + $extraMessages->getWikiText( false, false, $this->getLanguage() ) + ); } $out->addHTML( $injected_html ); @@ -975,7 +977,11 @@ abstract class LoginSignupSpecialPage extends AuthManagerSpecialPage { } } if ( !$this->isSignup() && $this->showExtraInformation() ) { - $passwordReset = new PasswordReset( $this->getConfig(), AuthManager::singleton() ); + $passwordReset = new PasswordReset( + $this->getConfig(), + AuthManager::singleton(), + MediaWikiServices::getInstance()->getPermissionManager() + ); if ( $passwordReset->isAllowed( $this->getUser() )->isGood() ) { $fieldDefinitions['passwordReset'] = [ 'type' => 'info', @@ -1072,7 +1078,10 @@ abstract class LoginSignupSpecialPage extends AuthManagerSpecialPage { private function showCreateAccountLink() { if ( $this->isSignup() ) { return true; - } elseif ( $this->getUser()->isAllowed( 'createaccount' ) ) { + } elseif ( MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'createaccount' ) + ) { return true; } else { return false; diff --git a/includes/specialpage/SpecialPage.php b/includes/specialpage/SpecialPage.php index 7d3303584d..ba8e318bcd 100644 --- a/includes/specialpage/SpecialPage.php +++ b/includes/specialpage/SpecialPage.php @@ -292,7 +292,9 @@ class SpecialPage implements MessageLocalizer { * @return bool Does the user have permission to view the page? */ public function userCanExecute( User $user ) { - return $user->isAllowed( $this->mRestriction ); + return MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, $this->mRestriction ); } /** diff --git a/includes/specials/SpecialApiSandbox.php b/includes/specials/SpecialApiSandbox.php index 9e496845f8..f4a33c8c54 100644 --- a/includes/specials/SpecialApiSandbox.php +++ b/includes/specials/SpecialApiSandbox.php @@ -21,6 +21,8 @@ * @ingroup SpecialPage */ +use MediaWiki\MediaWikiServices; + /** * @ingroup SpecialPage * @since 1.27 @@ -35,7 +37,10 @@ class SpecialApiSandbox extends SpecialPage { $out = $this->getOutput(); $this->addHelpLink( 'Help:ApiSandbox' ); - $out->addJsConfigVars( 'apihighlimits', $this->getUser()->isAllowed( 'apihighlimits' ) ); + $out->addJsConfigVars( 'apihighlimits', MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'apihighlimits' ) + ); $out->addModuleStyles( [ 'mediawiki.special', 'mediawiki.hlist', diff --git a/includes/specials/SpecialAutoblockList.php b/includes/specials/SpecialAutoblockList.php index 34c3371bf2..3f98e93045 100644 --- a/includes/specials/SpecialAutoblockList.php +++ b/includes/specials/SpecialAutoblockList.php @@ -21,6 +21,8 @@ * @ingroup SpecialPage */ +use MediaWiki\MediaWikiServices; + /** * A special page that lists autoblocks * @@ -81,7 +83,10 @@ class SpecialAutoblockList extends SpecialPage { 'ipb_parent_block_id IS NOT NULL' ]; # Is the user allowed to see hidden blocks? - if ( !$this->getUser()->isAllowed( 'hideuser' ) ) { + if ( !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'hideuser' ) + ) { $conds['ipb_deleted'] = 0; } diff --git a/includes/specials/SpecialBlock.php b/includes/specials/SpecialBlock.php index 07214af4fa..a03455bbe6 100644 --- a/includes/specials/SpecialBlock.php +++ b/includes/specials/SpecialBlock.php @@ -25,6 +25,7 @@ use MediaWiki\Block\DatabaseBlock; use MediaWiki\Block\Restriction\PageRestriction; use MediaWiki\Block\Restriction\NamespaceRestriction; use MediaWiki\MediaWikiServices; +use MediaWiki\User\UserIdentity; /** * A special page that allows users with 'block' right to block users from @@ -269,7 +270,10 @@ class SpecialBlock extends FormSpecialPage { ]; # Allow some users to hide name from block log, blocklist and listusers - if ( $user->isAllowed( 'hideuser' ) ) { + if ( MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'hideuser' ) + ) { $a['HideUser'] = [ 'type' => 'check', 'label-message' => 'ipbhidename', @@ -363,7 +367,10 @@ class SpecialBlock extends FormSpecialPage { // If the username was hidden (ipb_deleted == 1), don't show the reason // unless this user also has rights to hideuser: T37839 - if ( !$block->getHideName() || $this->getUser()->isAllowed( 'hideuser' ) ) { + if ( !$block->getHideName() || MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'hideuser' ) + ) { $fields['Reason']['default'] = $block->getReason(); } else { $fields['Reason']['default'] = ''; @@ -545,7 +552,8 @@ class SpecialBlock extends FormSpecialPage { $user = $this->getUser(); # Link to edit the block dropdown reasons, if applicable - if ( $user->isAllowed( 'editinterface' ) ) { + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); + if ( $permissionManager->userHasRight( $user, 'editinterface' ) ) { $links[] = $linkRenderer->makeKnownLink( $this->msg( 'ipbreason-dropdown' )->inContentLanguage()->getTitle(), $this->msg( 'ipb-edit-dropdown' )->text(), @@ -579,7 +587,7 @@ class SpecialBlock extends FormSpecialPage { $text .= $out; # Add suppression block entries if allowed - if ( $user->isAllowed( 'suppressionlog' ) ) { + if ( $permissionManager->userHasRight( $user, 'suppressionlog' ) ) { LogEventsList::showLogExtract( $out, 'suppress', @@ -828,7 +836,10 @@ class SpecialBlock extends FormSpecialPage { } if ( $data['HideUser'] ) { - if ( !$performer->isAllowed( 'hideuser' ) ) { + if ( !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $performer, 'hideuser' ) + ) { # this codepath is unreachable except by a malicious user spoofing forms, # or by race conditions (user has hideuser and block rights, loads block form, # and loses hideuser rights before submission); so need to fail completely @@ -938,7 +949,10 @@ class SpecialBlock extends FormSpecialPage { } # If the name was hidden and the blocking user cannot hide # names, then don't allow any block changes... - if ( $currentBlock->getHideName() && !$performer->isAllowed( 'hideuser' ) ) { + if ( $currentBlock->getHideName() && !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $performer, 'hideuser' ) + ) { return [ 'cant-see-hidden-user' ]; } @@ -1106,13 +1120,15 @@ class SpecialBlock extends FormSpecialPage { /** * Can we do an email block? - * @param User $user The sysop wanting to make a block + * @param UserIdentity $user The sysop wanting to make a block * @return bool */ - public static function canBlockEmail( $user ) { - global $wgEnableUserEmail, $wgSysopEmailBans; + public static function canBlockEmail( UserIdentity $user ) { + global $wgEnableUserEmail; - return ( $wgEnableUserEmail && $wgSysopEmailBans && $user->isAllowed( 'blockemail' ) ); + return ( $wgEnableUserEmail && MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'blockemail' ) ); } /** @@ -1138,7 +1154,10 @@ class SpecialBlock extends FormSpecialPage { if ( $performer->getBlock() ) { if ( $target instanceof User && $target->getId() == $performer->getId() ) { # User is trying to unblock themselves - if ( $performer->isAllowed( 'unblockself' ) ) { + if ( MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $performer, 'unblockself' ) + ) { return true; # User blocked themselves and is now trying to reverse it } elseif ( $performer->blockedBy() === $performer->getName() ) { diff --git a/includes/specials/SpecialBlockList.php b/includes/specials/SpecialBlockList.php index 638535940d..4ba9b65e17 100644 --- a/includes/specials/SpecialBlockList.php +++ b/includes/specials/SpecialBlockList.php @@ -22,6 +22,8 @@ */ use MediaWiki\Block\DatabaseBlock; +use MediaWiki\MediaWikiServices; +use Wikimedia\Rdbms\IDatabase; /** * A special page that lists existing blocks @@ -139,7 +141,10 @@ class SpecialBlockList extends SpecialPage { $conds = []; $db = $this->getDB(); # Is the user allowed to see hidden blocks? - if ( !$this->getUser()->isAllowed( 'hideuser' ) ) { + if ( !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'hideuser' ) + ) { $conds['ipb_deleted'] = 0; } diff --git a/includes/specials/SpecialBrokenRedirects.php b/includes/specials/SpecialBrokenRedirects.php index 9431cefbaf..392b4e970d 100644 --- a/includes/specials/SpecialBrokenRedirects.php +++ b/includes/specials/SpecialBrokenRedirects.php @@ -21,6 +21,7 @@ * @ingroup SpecialPage */ +use MediaWiki\MediaWikiServices; use Wikimedia\Rdbms\IResultWrapper; use Wikimedia\Rdbms\IDatabase; @@ -114,6 +115,8 @@ class SpecialBrokenRedirects extends QueryPage { } $linkRenderer = $this->getLinkRenderer(); + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); + // $toObj may very easily be false if the $result list is cached if ( !is_object( $toObj ) ) { return '<del>' . $linkRenderer->makeLink( $fromObj ) . '</del>'; @@ -129,7 +132,7 @@ class SpecialBrokenRedirects extends QueryPage { // if the page is editable, add an edit link if ( // check user permissions - $this->getUser()->isAllowed( 'edit' ) && + $permissionManager->userHasRight( $this->getUser(), 'edit' ) && // check, if the content model is editable through action=edit ContentHandler::getForTitle( $fromObj )->supportsDirectEditing() ) { @@ -145,7 +148,7 @@ class SpecialBrokenRedirects extends QueryPage { $out = $from . $this->msg( 'word-separator' )->escaped(); - if ( $this->getUser()->isAllowed( 'delete' ) ) { + if ( $permissionManager->userHasRight( $this->getUser(), 'delete' ) ) { $links[] = $linkRenderer->makeKnownLink( $fromObj, $this->msg( 'brokenredirects-delete' )->text(), diff --git a/includes/specials/SpecialChangeContentModel.php b/includes/specials/SpecialChangeContentModel.php index 01f7e56769..46fa17e054 100644 --- a/includes/specials/SpecialChangeContentModel.php +++ b/includes/specials/SpecialChangeContentModel.php @@ -1,5 +1,7 @@ <?php +use MediaWiki\MediaWikiServices; + class SpecialChangeContentModel extends FormSpecialPage { public function __construct() { @@ -226,7 +228,10 @@ class SpecialChangeContentModel extends FormSpecialPage { $flags = $this->oldRevision ? EDIT_UPDATE : EDIT_NEW; $flags |= EDIT_INTERNAL; - if ( $user->isAllowed( 'bot' ) ) { + if ( MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'bot' ) + ) { $flags |= EDIT_FORCE_BOT; } diff --git a/includes/specials/SpecialChangeEmail.php b/includes/specials/SpecialChangeEmail.php index c95aa1b558..7331cd7c2b 100644 --- a/includes/specials/SpecialChangeEmail.php +++ b/includes/specials/SpecialChangeEmail.php @@ -23,6 +23,7 @@ use MediaWiki\Auth\AuthManager; use MediaWiki\Logger\LoggerFactory; +use MediaWiki\MediaWikiServices; /** * Let users change their email address. @@ -74,7 +75,10 @@ class SpecialChangeEmail extends FormSpecialPage { // This could also let someone check the current email address, so // require both permissions. - if ( !$this->getUser()->isAllowed( 'viewmyprivateinfo' ) ) { + if ( !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'viewmyprivateinfo' ) + ) { throw new PermissionsError( 'viewmyprivateinfo' ); } diff --git a/includes/specials/SpecialConfirmEmail.php b/includes/specials/SpecialConfirmEmail.php index f86a133a13..dc31eba61a 100644 --- a/includes/specials/SpecialConfirmEmail.php +++ b/includes/specials/SpecialConfirmEmail.php @@ -21,6 +21,8 @@ * @ingroup SpecialPage */ +use MediaWiki\MediaWikiServices; + /** * Special page allows users to request email confirmation message, and handles * processing of the confirmation code when the link in the email is followed @@ -57,7 +59,10 @@ class SpecialConfirmEmail extends UnlistedSpecialPage { // This could also let someone check the current email address, so // require both permissions. - if ( !$this->getUser()->isAllowed( 'viewmyprivateinfo' ) ) { + if ( !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'viewmyprivateinfo' ) + ) { throw new PermissionsError( 'viewmyprivateinfo' ); } @@ -136,7 +141,7 @@ class SpecialConfirmEmail extends UnlistedSpecialPage { return Status::newGood( $this->msg( 'confirmemail_sent' )->text() ); } else { return Status::newFatal( new RawMessage( - $status->getWikiText( 'confirmemail_sendfailed' ) + $status->getWikiText( 'confirmemail_sendfailed', false, $this->getLanguage() ) ) ); } } diff --git a/includes/specials/SpecialContributions.php b/includes/specials/SpecialContributions.php index 40c0edf542..e8b85fa024 100644 --- a/includes/specials/SpecialContributions.php +++ b/includes/specials/SpecialContributions.php @@ -126,7 +126,10 @@ class SpecialContributions extends IncludableSpecialPage { // Allows reverts to have the bot flag in recent changes. It is just here to // be passed in the form at the top of the page - if ( $user->isAllowed( 'markbotedits' ) && $request->getBool( 'bot' ) ) { + if ( MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'markbotedits' ) && $request->getBool( 'bot' ) + ) { $this->opts['bot'] = '1'; } @@ -373,7 +376,9 @@ class SpecialContributions extends IncludableSpecialPage { ); } - if ( $sp->getUser()->isAllowed( 'block' ) ) { # Block / Change block / Unblock links + # Block / Change block / Unblock links + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); + if ( $permissionManager->userHasRight( $sp->getUser(), 'block' ) ) { if ( $target->getBlock() && $target->getBlock()->getType() != DatabaseBlock::TYPE_AUTO ) { $tools['block'] = $linkRenderer->makeKnownLink( # Change block link SpecialPage::getTitleFor( 'Block', $username ), @@ -400,7 +405,7 @@ class SpecialContributions extends IncludableSpecialPage { ); # Suppression log link (T61120) - if ( $sp->getUser()->isAllowed( 'suppressionlog' ) ) { + if ( $permissionManager->userHasRight( $sp->getUser(), 'suppressionlog' ) ) { $tools['log-suppression'] = $linkRenderer->makeKnownLink( SpecialPage::getTitleFor( 'Log', 'suppress' ), $sp->msg( 'sp-contributions-suppresslog', $username )->text(), @@ -412,7 +417,7 @@ class SpecialContributions extends IncludableSpecialPage { # Don't show some links for IP ranges if ( !$isRange ) { # Uploads: hide if IPs cannot upload (T220674) - if ( !$isIP || $target->isAllowed( 'upload' ) ) { + if ( !$isIP || $permissionManager->userHasRight( $target, 'upload' ) ) { $tools['uploads'] = $linkRenderer->makeKnownLink( SpecialPage::getTitleFor( 'Listfiles', $username ), $sp->msg( 'sp-contributions-uploads' )->text() @@ -428,7 +433,7 @@ class SpecialContributions extends IncludableSpecialPage { # Add link to deleted user contributions for priviledged users # Todo: T183457 - if ( $sp->getUser()->isAllowed( 'deletedhistory' ) ) { + if ( $permissionManager->userHasRight( $sp->getUser(), 'deletedhistory' ) ) { $tools['deletedcontribs'] = $linkRenderer->makeKnownLink( SpecialPage::getTitleFor( 'DeletedContributions', $username ), $sp->msg( 'sp-contributions-deleted', $username )->text() @@ -628,7 +633,10 @@ class SpecialContributions extends IncludableSpecialPage { $filters = []; - if ( $this->getUser()->isAllowed( 'deletedhistory' ) ) { + if ( MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'deletedhistory' ) + ) { $filters[] = Html::rawElement( 'span', [ 'class' => 'mw-input-with-label' ], diff --git a/includes/specials/SpecialCreateAccount.php b/includes/specials/SpecialCreateAccount.php index cc2fc80970..637025c985 100644 --- a/includes/specials/SpecialCreateAccount.php +++ b/includes/specials/SpecialCreateAccount.php @@ -57,7 +57,9 @@ class SpecialCreateAccount extends LoginSignupSpecialPage { } public function userCanExecute( User $user ) { - return $user->isAllowed( 'createaccount' ); + return MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'createaccount' ); } public function checkPermissions() { diff --git a/includes/specials/SpecialDoubleRedirects.php b/includes/specials/SpecialDoubleRedirects.php index cccca5063a..540ac5aaef 100644 --- a/includes/specials/SpecialDoubleRedirects.php +++ b/includes/specials/SpecialDoubleRedirects.php @@ -21,6 +21,7 @@ * @ingroup SpecialPage */ +use MediaWiki\MediaWikiServices; use Wikimedia\Rdbms\IResultWrapper; use Wikimedia\Rdbms\IDatabase; @@ -155,7 +156,9 @@ class SpecialDoubleRedirects extends QueryPage { // if the page is editable, add an edit link if ( // check user permissions - $this->getUser()->isAllowed( 'edit' ) && + MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'edit' ) && // check, if the content model is editable through action=edit ContentHandler::getForTitle( $titleA )->supportsDirectEditing() ) { diff --git a/includes/specials/SpecialEditTags.php b/includes/specials/SpecialEditTags.php index 1dd19694c9..0b4577eb98 100644 --- a/includes/specials/SpecialEditTags.php +++ b/includes/specials/SpecialEditTags.php @@ -129,7 +129,7 @@ class SpecialEditTags extends UnlistedSpecialPage { $this->ids ); - $this->isAllowed = $user->isAllowed( 'changetags' ); + $this->isAllowed = $this->permissionManager->userHasRight( $user, 'changetags' ); $this->reason = $request->getVal( 'wpReason' ); // We need a target page! @@ -465,7 +465,7 @@ class SpecialEditTags extends UnlistedSpecialPage { protected function failure( $status ) { $this->getOutput()->setPageTitle( $this->msg( 'actionfailed' ) ); $this->getOutput()->wrapWikiTextAsInterface( - 'errorbox', $status->getWikiText( 'tags-edit-failure' ) + 'errorbox', $status->getWikiText( 'tags-edit-failure', false, $this->getLanguage() ) ); $this->showForm(); } diff --git a/includes/specials/SpecialEmailUser.php b/includes/specials/SpecialEmailUser.php index b42cdea08a..c8b92bd10d 100644 --- a/includes/specials/SpecialEmailUser.php +++ b/includes/specials/SpecialEmailUser.php @@ -253,7 +253,10 @@ class SpecialEmailUser extends UnlistedSpecialPage { return 'mailnologin'; } - if ( !$user->isAllowed( 'sendemail' ) ) { + if ( !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'sendemail' ) + ) { return 'badaccess'; } diff --git a/includes/specials/SpecialExpandTemplates.php b/includes/specials/SpecialExpandTemplates.php index a466f29436..72e881f967 100644 --- a/includes/specials/SpecialExpandTemplates.php +++ b/includes/specials/SpecialExpandTemplates.php @@ -273,7 +273,10 @@ class SpecialExpandTemplates extends SpecialPage { // allowed and a valid edit token is not provided (T73111). However, MediaWiki // does not currently provide logged-out users with CSRF protection; in that case, // do not show the preview unless anonymous editing is allowed. - if ( $user->isAnon() && !$user->isAllowed( 'edit' ) ) { + if ( $user->isAnon() && !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'edit' ) + ) { $error = [ 'expand_templates_preview_fail_html_anon' ]; } elseif ( !$user->matchEditToken( $request->getVal( 'wpEditToken' ), '', $request ) ) { $error = [ 'expand_templates_preview_fail_html' ]; diff --git a/includes/specials/SpecialExport.php b/includes/specials/SpecialExport.php index 5a6358147f..e680d240c0 100644 --- a/includes/specials/SpecialExport.php +++ b/includes/specials/SpecialExport.php @@ -327,7 +327,9 @@ class SpecialExport extends SpecialPage { * @return bool */ private function userCanOverrideExportDepth() { - return $this->getUser()->isAllowed( 'override-export-depth' ); + return MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'override-export-depth' ); } /** diff --git a/includes/specials/SpecialImport.php b/includes/specials/SpecialImport.php index f21c20651b..428556f33d 100644 --- a/includes/specials/SpecialImport.php +++ b/includes/specials/SpecialImport.php @@ -135,18 +135,19 @@ class SpecialImport extends SpecialPage { } $user = $this->getUser(); + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); if ( !$user->matchEditToken( $request->getVal( 'editToken' ) ) ) { $source = Status::newFatal( 'import-token-mismatch' ); } elseif ( $this->sourceName === 'upload' ) { $isUpload = true; $this->usernamePrefix = $this->fullInterwikiPrefix = $request->getVal( 'usernamePrefix' ); - if ( $user->isAllowed( 'importupload' ) ) { + if ( $permissionManager->userHasRight( $user, 'importupload' ) ) { $source = ImportStreamSource::newFromUpload( "xmlimport" ); } else { throw new PermissionsError( 'importupload' ); } } elseif ( $this->sourceName === 'interwiki' ) { - if ( !$user->isAllowed( 'import' ) ) { + if ( !$permissionManager->userHasRight( $user, 'import' ) ) { throw new PermissionsError( 'import' ); } $this->interwiki = $this->fullInterwikiPrefix = $request->getVal( 'interwiki' ); @@ -186,7 +187,8 @@ class SpecialImport extends SpecialPage { $out = $this->getOutput(); if ( !$source->isGood() ) { $out->wrapWikiTextAsInterface( 'error', - $this->msg( 'importfailed', $source->getWikiText() )->plain() + $this->msg( 'importfailed', $source->getWikiText( false, false, $this->getLanguage() ) ) + ->plain() ); } else { $importer = new WikiImporter( $source->value, $this->getConfig() ); @@ -199,7 +201,7 @@ class SpecialImport extends SpecialPage { "<div class=\"error\">\n$1\n</div>", [ 'import-options-wrong', - $statusRootPage->getWikiText(), + $statusRootPage->getWikiText( false, false, $this->getLanguage() ), count( $statusRootPage->getErrorsArray() ) ] ); @@ -238,7 +240,7 @@ class SpecialImport extends SpecialPage { # Zero revisions $out->wrapWikiMsg( "<div class=\"error\">\n$1\n</div>", - [ 'importfailed', $result->getWikiText() ] + [ 'importfailed', $result->getWikiText( false, false, $this->getLanguage() ) ] ); } else { # Success! @@ -325,10 +327,11 @@ class SpecialImport extends SpecialPage { private function showForm() { $action = $this->getPageTitle()->getLocalURL( [ 'action' => 'submit' ] ); $user = $this->getUser(); + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); $out = $this->getOutput(); $this->addHelpLink( 'https://meta.wikimedia.org/wiki/Special:MyLanguage/Help:Import', true ); - if ( $user->isAllowed( 'importupload' ) ) { + if ( $permissionManager->userHasRight( $user, 'importupload' ) ) { $mappingSelection = $this->getMappingFormPart( 'upload' ); $out->addHTML( Xml::fieldset( $this->msg( 'import-upload' )->text() ) . @@ -401,7 +404,7 @@ class SpecialImport extends SpecialPage { $out->addWikiMsg( 'importnosources' ); } - if ( $user->isAllowed( 'import' ) && !empty( $this->importSources ) ) { + if ( $permissionManager->userHasRight( $user, 'import' ) && !empty( $this->importSources ) ) { # Show input field for import depth only if $wgExportMaxLinkDepth > 0 $importDepth = ''; if ( $this->getConfig()->get( 'ExportMaxLinkDepth' ) > 0 ) { diff --git a/includes/specials/SpecialListFiles.php b/includes/specials/SpecialListFiles.php index 02a468b098..bc4f7e276f 100644 --- a/includes/specials/SpecialListFiles.php +++ b/includes/specials/SpecialListFiles.php @@ -40,6 +40,11 @@ class SpecialListFiles extends IncludableSpecialPage { $search = $this->getRequest()->getText( 'ilsearch', '' ); $showAll = $this->getRequest()->getBool( 'ilshowall', false ); } + if ( $userName ) { + $pageTitle = $this->msg( 'listfiles_subpage', $userName ); + } else { + $pageTitle = $this->msg( 'listfiles' ); + } $pager = new ImageListPager( $this->getContext(), @@ -51,6 +56,8 @@ class SpecialListFiles extends IncludableSpecialPage { ); $out = $this->getOutput(); + $out->setPageTitle( $pageTitle ); + $out->addModuleStyles( 'mediawiki.special' ); if ( $this->including() ) { $out->addParserOutputContent( $pager->getBodyOutput() ); } else { diff --git a/includes/specials/SpecialLog.php b/includes/specials/SpecialLog.php index ac8baa12c1..7c858147e1 100644 --- a/includes/specials/SpecialLog.php +++ b/includes/specials/SpecialLog.php @@ -94,7 +94,9 @@ class SpecialLog extends SpecialPage { if ( !LogPage::isLogType( $type ) ) { $opts->setValue( 'type', '' ); } elseif ( isset( $logRestrictions[$type] ) - && !$this->getUser()->isAllowed( $logRestrictions[$type] ) + && !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), $logRestrictions[$type] ) ) { throw new PermissionsError( $logRestrictions[$type] ); } diff --git a/includes/specials/SpecialMergeHistory.php b/includes/specials/SpecialMergeHistory.php index 5b77d5a112..1babf8c374 100644 --- a/includes/specials/SpecialMergeHistory.php +++ b/includes/specials/SpecialMergeHistory.php @@ -21,7 +21,7 @@ * @ingroup SpecialPage */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; /** * Special page allowing users with the appropriate permissions to diff --git a/includes/specials/SpecialMovepage.php b/includes/specials/SpecialMovepage.php index 6da362dd1b..0767fafe67 100644 --- a/includes/specials/SpecialMovepage.php +++ b/includes/specials/SpecialMovepage.php @@ -209,7 +209,9 @@ class MovePageForm extends UnlistedSpecialPage { } if ( count( $err ) == 1 && isset( $err[0][0] ) && $err[0][0] == 'file-exists-sharedrepo' - && $user->isAllowed( 'reupload-shared' ) + && MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'reupload-shared' ) ) { $out->wrapWikiMsg( "<div class='warningbox'>\n$1\n</div>\n", @@ -374,7 +376,10 @@ class MovePageForm extends UnlistedSpecialPage { ); } - if ( $user->isAllowed( 'suppressredirect' ) ) { + if ( MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'suppressredirect' ) + ) { if ( $handlerSupportsRedirects ) { $isChecked = $this->leaveRedirect; $isDisabled = false; @@ -520,6 +525,7 @@ class MovePageForm extends UnlistedSpecialPage { function doSubmit() { $user = $this->getUser(); + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); if ( $user->pingLimiter( 'move' ) ) { throw new ThrottledError; @@ -540,7 +546,7 @@ class MovePageForm extends UnlistedSpecialPage { # Show a warning if the target file exists on a shared repo $repoGroup = $services->getRepoGroup(); if ( $nt->getNamespace() == NS_FILE - && !( $this->moveOverShared && $user->isAllowed( 'reupload-shared' ) ) + && !( $this->moveOverShared && $permissionManager->userHasRight( $user, 'reupload-shared' ) ) && !$repoGroup->getLocalRepo()->findFile( $nt ) && $repoGroup->findFile( $nt ) ) { @@ -551,7 +557,7 @@ class MovePageForm extends UnlistedSpecialPage { # Delete to make way if requested if ( $this->deleteAndMove ) { - $permErrors = $nt->getUserPermissionsErrors( 'delete', $user ); + $permErrors = $permissionManager->getPermissionErrors( 'delete', $user, $nt ); if ( count( $permErrors ) ) { # Only show the first error $this->showForm( $permErrors, true ); @@ -592,7 +598,7 @@ class MovePageForm extends UnlistedSpecialPage { if ( !$handler->supportsRedirects() ) { $createRedirect = false; - } elseif ( $user->isAllowed( 'suppressredirect' ) ) { + } elseif ( $permissionManager->userHasRight( $user, 'suppressredirect' ) ) { $createRedirect = $this->leaveRedirect; } else { $createRedirect = true; @@ -607,7 +613,6 @@ class MovePageForm extends UnlistedSpecialPage { $this->moveTalk = false; } if ( $this->moveSubpages ) { - $permissionManager = $services->getPermissionManager(); $this->moveSubpages = $permissionManager->userCan( 'move-subpages', $user, $ot ); } diff --git a/includes/specials/SpecialMyLanguage.php b/includes/specials/SpecialMyLanguage.php index 537db9ee1d..408bd92883 100644 --- a/includes/specials/SpecialMyLanguage.php +++ b/includes/specials/SpecialMyLanguage.php @@ -71,14 +71,14 @@ class SpecialMyLanguage extends RedirectSpecialArticle { if ( $subpage !== null ) { $provided = Title::newFromText( $subpage ); $base = $provided; - } - if ( $provided && strpos( $subpage, '/' ) !== false ) { - $pos = strrpos( $subpage, '/' ); - $basepage = substr( $subpage, 0, $pos ); - $code = substr( $subpage, $pos + 1 ); - if ( strlen( $code ) && Language::isKnownLanguageTag( $code ) ) { - $base = Title::newFromText( $basepage ); + if ( $provided && strpos( $subpage, '/' ) !== false ) { + $pos = strrpos( $subpage, '/' ); + $basepage = substr( $subpage, 0, $pos ); + $code = substr( $subpage, $pos + 1 ); + if ( strlen( $code ) && Language::isKnownLanguageTag( $code ) ) { + $base = Title::newFromText( $basepage ); + } } } diff --git a/includes/specials/SpecialPagesWithProp.php b/includes/specials/SpecialPagesWithProp.php index 527b910fcf..8d6488de0a 100644 --- a/includes/specials/SpecialPagesWithProp.php +++ b/includes/specials/SpecialPagesWithProp.php @@ -40,7 +40,7 @@ class SpecialPagesWithProp extends QueryPage { private $existingPropNames = null; /** - * @var string|null + * @var int|null */ private $ns; @@ -69,6 +69,7 @@ class SpecialPagesWithProp extends QueryPage { $request = $this->getRequest(); $propname = $request->getVal( 'propname', $par ); + $this->ns = $request->getIntOrNull( 'namespace' ); $this->reverse = $request->getBool( 'reverse' ); $this->sortByValue = $request->getBool( 'sortbyvalue' ); @@ -87,8 +88,8 @@ class SpecialPagesWithProp extends QueryPage { 'type' => 'namespaceselect', 'name' => 'namespace', 'label-message' => 'namespace', - 'all' => null, - 'default' => null, + 'all' => '', + 'default' => $this->ns, ], 'reverse' => [ 'type' => 'check', @@ -120,7 +121,6 @@ class SpecialPagesWithProp extends QueryPage { public function onSubmit( $data, $form ) { $this->propName = $data['propname']; - $this->ns = $data['namespace']; parent::execute( $data['propname'] ); } @@ -167,7 +167,7 @@ class SpecialPagesWithProp extends QueryPage { 'options' => [] ]; - if ( $this->ns && isset( $this->ns ) ) { + if ( $this->ns !== null ) { $query['conds']['page_namespace'] = $this->ns; } diff --git a/includes/specials/SpecialPasswordReset.php b/includes/specials/SpecialPasswordReset.php index 3524d79e65..2ef96ad854 100644 --- a/includes/specials/SpecialPasswordReset.php +++ b/includes/specials/SpecialPasswordReset.php @@ -22,6 +22,7 @@ */ use MediaWiki\Auth\AuthManager; +use MediaWiki\MediaWikiServices; /** * Special page for requesting a password reset email. @@ -52,7 +53,11 @@ class SpecialPasswordReset extends FormSpecialPage { private function getPasswordReset() { if ( $this->passwordReset === null ) { - $this->passwordReset = new PasswordReset( $this->getConfig(), AuthManager::singleton() ); + $this->passwordReset = new PasswordReset( + $this->getConfig(), + AuthManager::singleton(), + MediaWikiServices::getInstance()->getPermissionManager() + ); } return $this->passwordReset; } diff --git a/includes/specials/SpecialPreferences.php b/includes/specials/SpecialPreferences.php index 0bc9147fad..d541eadcd6 100644 --- a/includes/specials/SpecialPreferences.php +++ b/includes/specials/SpecialPreferences.php @@ -115,7 +115,10 @@ class SpecialPreferences extends SpecialPage { } protected function showResetForm() { - if ( !$this->getUser()->isAllowed( 'editmyoptions' ) ) { + if ( !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'editmyoptions' ) + ) { throw new PermissionsError( 'editmyoptions' ); } @@ -134,7 +137,10 @@ class SpecialPreferences extends SpecialPage { } public function submitReset( $formData ) { - if ( !$this->getUser()->isAllowed( 'editmyoptions' ) ) { + if ( !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'editmyoptions' ) + ) { throw new PermissionsError( 'editmyoptions' ); } diff --git a/includes/specials/SpecialRecentChanges.php b/includes/specials/SpecialRecentChanges.php index 0bfe1855df..4683fe6861 100644 --- a/includes/specials/SpecialRecentChanges.php +++ b/includes/specials/SpecialRecentChanges.php @@ -185,7 +185,9 @@ class SpecialRecentChanges extends ChangesListSpecialPage { if ( !$this->including() && $this->getUser()->isLoggedIn() && - $this->getUser()->isAllowed( 'viewmywatchlist' ) + MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'viewmywatchlist' ) ) { $this->registerFiltersFromDefinitions( [ $this->watchlistFilterGroupDefinition ] ); $watchlistGroup = $this->getFilterGroup( 'watchlist' ); @@ -279,7 +281,10 @@ class SpecialRecentChanges extends ChangesListSpecialPage { $join_conds = array_merge( $join_conds, $rcQuery['joins'] ); // JOIN on watchlist for users - if ( $user->isLoggedIn() && $user->isAllowed( 'viewmywatchlist' ) ) { + if ( $user->isLoggedIn() && MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'viewmywatchlist' ) + ) { $tables[] = 'watchlist'; $fields[] = 'wl_user'; $fields[] = 'wl_notificationtimestamp'; diff --git a/includes/specials/SpecialRecentChangesLinked.php b/includes/specials/SpecialRecentChangesLinked.php index 26f3665597..0921adaab8 100644 --- a/includes/specials/SpecialRecentChangesLinked.php +++ b/includes/specials/SpecialRecentChangesLinked.php @@ -21,6 +21,8 @@ * @ingroup SpecialPage */ +use MediaWiki\MediaWikiServices; + /** * This is to display changes made to all articles linked in an article. * @@ -91,7 +93,10 @@ class SpecialRecentChangesLinked extends SpecialRecentChanges { // left join with watchlist table to highlight watched rows $uid = $this->getUser()->getId(); - if ( $uid && $this->getUser()->isAllowed( 'viewmywatchlist' ) ) { + if ( $uid && MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'viewmywatchlist' ) + ) { $tables[] = 'watchlist'; $select[] = 'wl_user'; $join_conds['watchlist'] = [ 'LEFT JOIN', [ diff --git a/includes/specials/SpecialRevisionDelete.php b/includes/specials/SpecialRevisionDelete.php index 437263f186..750e2c3dc3 100644 --- a/includes/specials/SpecialRevisionDelete.php +++ b/includes/specials/SpecialRevisionDelete.php @@ -21,7 +21,8 @@ * @ingroup SpecialPage */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\MediaWikiServices; +use MediaWiki\Revision\RevisionRecord; use MediaWiki\Permissions\PermissionManager; /** @@ -192,9 +193,11 @@ class SpecialRevisionDelete extends UnlistedSpecialPage { $this->typeLabels = self::$UILabels[$this->typeName]; $list = $this->getList(); $list->reset(); - $this->mIsAllowed = $user->isAllowed( RevisionDeleter::getRestriction( $this->typeName ) ); - $canViewSuppressedOnly = $this->getUser()->isAllowed( 'viewsuppressed' ) && - !$this->getUser()->isAllowed( 'suppressrevision' ); + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); + $this->mIsAllowed = $permissionManager->userHasRight( $user, + RevisionDeleter::getRestriction( $this->typeName ) ); + $canViewSuppressedOnly = $permissionManager->userHasRight( $user, 'viewsuppressed' ) && + !$permissionManager->userHasRight( $user, 'suppressrevision' ); $pageIsSuppressed = $list->areAnySuppressed(); $this->mIsAllowed = $this->mIsAllowed && !( $canViewSuppressedOnly && $pageIsSuppressed ); @@ -211,7 +214,7 @@ class SpecialRevisionDelete extends UnlistedSpecialPage { [ 'revdelete-hide-comment', 'wpHideComment', RevisionRecord::DELETED_COMMENT ], [ 'revdelete-hide-user', 'wpHideUser', RevisionRecord::DELETED_USER ] ]; - if ( $user->isAllowed( 'suppressrevision' ) ) { + if ( $permissionManager->userHasRight( $user, 'suppressrevision' ) ) { $this->checks[] = [ 'revdelete-hide-restricted', 'wpHideRestricted', RevisionRecord::DELETED_RESTRICTED ]; } @@ -223,7 +226,7 @@ class SpecialRevisionDelete extends UnlistedSpecialPage { $this->showForm(); } - if ( $user->isAllowed( 'deletedhistory' ) ) { + if ( $permissionManager->userHasRight( $user, 'deletedhistory' ) ) { $qc = $this->getLogQueryCond(); # Show relevant lines from the deletion log $deleteLogPage = new LogPage( 'delete' ); @@ -237,7 +240,7 @@ class SpecialRevisionDelete extends UnlistedSpecialPage { ); } # Show relevant lines from the suppression log - if ( $user->isAllowed( 'suppressionlog' ) ) { + if ( $permissionManager->userHasRight( $user, 'suppressionlog' ) ) { $suppressLogPage = new LogPage( 'suppress' ); $output->addHTML( "<h2>" . $suppressLogPage->getName()->escaped() . "</h2>\n" ); LogEventsList::showLogExtract( @@ -276,7 +279,10 @@ class SpecialRevisionDelete extends UnlistedSpecialPage { [ 'action' => 'history' ] ); # Link to deleted edits - if ( $this->getUser()->isAllowed( 'undelete' ) ) { + if ( MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'undelete' ) + ) { $undelete = SpecialPage::getTitleFor( 'Undelete' ); $links[] = $linkRenderer->makeKnownLink( $undelete, @@ -480,7 +486,10 @@ class SpecialRevisionDelete extends UnlistedSpecialPage { Xml::closeElement( 'fieldset' ) . "\n" . Xml::closeElement( 'form' ) . "\n"; // Show link to edit the dropdown reasons - if ( $this->getUser()->isAllowed( 'editinterface' ) ) { + if ( MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'editinterface' ) + ) { $link = $this->getLinkRenderer()->makeKnownLink( $this->msg( 'revdelete-reason-dropdown' )->inContentLanguage()->getTitle(), $this->msg( 'revdelete-edit-reasonlist' )->text(), @@ -506,7 +515,10 @@ class SpecialRevisionDelete extends UnlistedSpecialPage { 'revdelete-text-others' ); - if ( $this->getUser()->isAllowed( 'suppressrevision' ) ) { + if ( MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'suppressrevision' ) + ) { $this->getOutput()->addWikiMsg( 'revdelete-suppress-text' ); } @@ -611,7 +623,9 @@ class SpecialRevisionDelete extends UnlistedSpecialPage { } # Can the user set this field? if ( $bitParams[RevisionRecord::DELETED_RESTRICTED] == 1 - && !$this->getUser()->isAllowed( 'suppressrevision' ) + && !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'suppressrevision' ) ) { throw new PermissionsError( 'suppressrevision' ); } @@ -653,7 +667,7 @@ class SpecialRevisionDelete extends UnlistedSpecialPage { $this->getOutput()->setPageTitle( $this->msg( 'actionfailed' ) ); $this->getOutput()->wrapWikiTextAsInterface( 'errorbox', - $status->getWikiText( $this->typeLabels['failure'] ) + $status->getWikiText( $this->typeLabels['failure'], false, $this->getLanguage() ) ); $this->showForm(); } diff --git a/includes/specials/SpecialTags.php b/includes/specials/SpecialTags.php index 9a95249c75..34665dd99e 100644 --- a/includes/specials/SpecialTags.php +++ b/includes/specials/SpecialTags.php @@ -21,6 +21,8 @@ * @ingroup SpecialPage */ +use MediaWiki\MediaWikiServices; + /** * A special page that lists tags for edits * @@ -77,9 +79,10 @@ class SpecialTags extends SpecialPage { $out->wrapWikiMsg( "<div class='mw-tags-intro'>\n$1\n</div>", 'tags-intro' ); $user = $this->getUser(); - $userCanManage = $user->isAllowed( 'managechangetags' ); - $userCanDelete = $user->isAllowed( 'deletechangetags' ); - $userCanEditInterface = $user->isAllowed( 'editinterface' ); + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); + $userCanManage = $permissionManager->userHasRight( $user, 'managechangetags' ); + $userCanDelete = $permissionManager->userHasRight( $user, 'deletechangetags' ); + $userCanEditInterface = $permissionManager->userHasRight( $user, 'editinterface' ); // Show form to create a tag if ( $userCanManage ) { @@ -329,7 +332,9 @@ class SpecialTags extends SpecialPage { protected function showDeleteTagForm( $tag ) { $user = $this->getUser(); - if ( !$user->isAllowed( 'deletechangetags' ) ) { + if ( !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'deletechangetags' ) ) { throw new PermissionsError( 'deletechangetags' ); } @@ -376,6 +381,7 @@ class SpecialTags extends SpecialPage { $form = HTMLForm::factory( 'ooui', $fields, $this->getContext() ); $form->setAction( $this->getPageTitle( 'delete' )->getLocalURL() ); + // @phan-suppress-next-line PhanUndeclaredProperty $form->tagAction = 'delete'; // custom property on HTMLForm object $form->setSubmitCallback( [ $this, 'processTagForm' ] ); $form->setSubmitTextMsg( 'tags-delete-submit' ); @@ -388,7 +394,9 @@ class SpecialTags extends SpecialPage { $actionStr = $activate ? 'activate' : 'deactivate'; $user = $this->getUser(); - if ( !$user->isAllowed( 'managechangetags' ) ) { + if ( !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'managechangetags' ) ) { throw new PermissionsError( 'managechangetags' ); } @@ -426,6 +434,7 @@ class SpecialTags extends SpecialPage { $form = HTMLForm::factory( 'ooui', $fields, $this->getContext() ); $form->setAction( $this->getPageTitle( $actionStr )->getLocalURL() ); + // @phan-suppress-next-line PhanUndeclaredProperty $form->tagAction = $actionStr; $form->setSubmitCallback( [ $this, 'processTagForm' ] ); // tags-activate-submit, tags-deactivate-submit @@ -434,6 +443,12 @@ class SpecialTags extends SpecialPage { $form->show(); } + /** + * @param array $data + * @param HTMLForm $form + * @return bool + * @suppress PhanUndeclaredProperty $form->tagAction + */ public function processTagForm( array $data, HTMLForm $form ) { $context = $form->getContext(); $out = $context->getOutput(); diff --git a/includes/specials/SpecialUnblock.php b/includes/specials/SpecialUnblock.php index 9b8022b7c2..931b179a36 100644 --- a/includes/specials/SpecialUnblock.php +++ b/includes/specials/SpecialUnblock.php @@ -22,6 +22,7 @@ */ use MediaWiki\Block\DatabaseBlock; +use MediaWiki\MediaWikiServices; /** * A special page for unblocking users @@ -208,7 +209,10 @@ class SpecialUnblock extends SpecialPage { # If the name was hidden and the blocking user cannot hide # names, then don't allow any block removals... - if ( !$performer->isAllowed( 'hideuser' ) && $block->getHideName() ) { + if ( !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $performer, 'hideuser' ) && $block->getHideName() + ) { return [ 'unblock-hideuser' ]; } diff --git a/includes/specials/SpecialUndelete.php b/includes/specials/SpecialUndelete.php index fe629dba8b..c6f07217f1 100644 --- a/includes/specials/SpecialUndelete.php +++ b/includes/specials/SpecialUndelete.php @@ -102,7 +102,9 @@ class SpecialUndelete extends SpecialPage { $this->mDiff = $request->getCheck( 'diff' ); $this->mDiffOnly = $request->getBool( 'diffonly', $this->getUser()->getOption( 'diffonly' ) ); $this->mComment = $request->getText( 'wpComment' ); - $this->mUnsuppress = $request->getVal( 'wpUnsuppress' ) && $user->isAllowed( 'suppressrevision' ); + $this->mUnsuppress = $request->getVal( 'wpUnsuppress' ) && MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'suppressrevision' ); $this->mToken = $request->getVal( 'token' ); $block = $user->getBlock(); @@ -153,7 +155,7 @@ class SpecialUndelete extends SpecialPage { if ( $this->mTargetObj !== null ) { return $permissionManager->userCan( $permission, $user, $this->mTargetObj ); } else { - return $user->isAllowed( $permission ); + return $permissionManager->userHasRight( $user, $permission ); } } @@ -179,7 +181,10 @@ class SpecialUndelete extends SpecialPage { $out->addWikiMsg( 'undelete-header' ); # Not all users can just browse every deleted page from the list - if ( $user->isAllowed( 'browsearchive' ) ) { + if ( MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'browsearchive' ) + ) { $this->showSearchForm(); } @@ -774,7 +779,8 @@ class SpecialUndelete extends SpecialPage { LogEventsList::showLogExtract( $out, 'delete', $this->mTargetObj ); # Show relevant lines from the suppression log: $suppressLogPage = new LogPage( 'suppress' ); - if ( $this->getUser()->isAllowed( 'suppressionlog' ) ) { + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); + if ( $permissionManager->userHasRight( $this->getUser(), 'suppressionlog' ) ) { $out->addHTML( Xml::element( 'h2', null, $suppressLogPage->getName()->text() ) . "\n" ); LogEventsList::showLogExtract( $out, 'suppress', $this->mTargetObj ); } @@ -826,7 +832,7 @@ class SpecialUndelete extends SpecialPage { ] ) ); - if ( $this->getUser()->isAllowed( 'suppressrevision' ) ) { + if ( $permissionManager->userHasRight( $this->getUser(), 'suppressrevision' ) ) { $fields[] = new OOUI\FieldLayout( new OOUI\CheckboxInputWidget( [ 'name' => 'wpUnsuppress', @@ -866,7 +872,7 @@ class SpecialUndelete extends SpecialPage { if ( $haveRevisions ) { # Show the page's stored (deleted) history - if ( $this->getUser()->isAllowed( 'deleterevision' ) ) { + if ( $permissionManager->userHasRight( $this->getUser(), 'deleterevision' ) ) { $history .= Html::element( 'button', [ @@ -1210,7 +1216,8 @@ class SpecialUndelete extends SpecialPage { '<div id="mw-error-cannotundelete">' . $status->getWikiText( 'cannotundelete', - 'cannotundelete' + 'cannotundelete', + $this->getLanguage() ) . '</div>' ); } @@ -1222,7 +1229,8 @@ class SpecialUndelete extends SpecialPage { 'error', $status->getWikiText( 'undelete-error-short', - 'undelete-error-long' + 'undelete-error-long', + $this->getLanguage() ) ); } diff --git a/includes/specials/SpecialUpload.php b/includes/specials/SpecialUpload.php index 81c9d567f1..a2edca0850 100644 --- a/includes/specials/SpecialUpload.php +++ b/includes/specials/SpecialUpload.php @@ -311,16 +311,18 @@ class SpecialUpload extends SpecialPage { protected function showViewDeletedLinks() { $title = Title::makeTitleSafe( NS_FILE, $this->mDesiredDestName ); $user = $this->getUser(); + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); // Show a subtitle link to deleted revisions (to sysops et al only) if ( $title instanceof Title ) { $count = $title->isDeleted(); - if ( $count > 0 && $user->isAllowed( 'deletedhistory' ) ) { + if ( $count > 0 && $permissionManager->userHasRight( $user, 'deletedhistory' ) ) { $restorelink = $this->getLinkRenderer()->makeKnownLink( SpecialPage::getTitleFor( 'Undelete', $title->getPrefixedText() ), $this->msg( 'restorelink' )->numParams( $count )->text() ); - $link = $this->msg( $user->isAllowed( 'delete' ) ? 'thisisdeleted' : 'viewdeleted' ) - ->rawParams( $restorelink )->parseAsBlock(); + $link = $this->msg( + $permissionManager->userHasRight( $user, 'delete' ) ? 'thisisdeleted' : 'viewdeleted' + )->rawParams( $restorelink )->parseAsBlock(); $this->getOutput()->addHTML( Html::rawElement( 'div', @@ -486,7 +488,9 @@ class SpecialUpload extends SpecialPage { // Fetch the file if required $status = $this->mUpload->fetchFile(); if ( !$status->isOK() ) { - $this->showUploadError( $this->getOutput()->parseAsInterface( $status->getWikiText() ) ); + $this->showUploadError( $this->getOutput()->parseAsInterface( + $status->getWikiText( false, false, $this->getLanguage() ) + ) ); return; } @@ -557,7 +561,7 @@ class SpecialUpload extends SpecialPage { $changeTags, $this->getUser() ); if ( !$changeTagsStatus->isOK() ) { $this->showUploadError( $this->getOutput()->parseAsInterface( - $changeTagsStatus->getWikiText() + $changeTagsStatus->getWikiText( false, false, $this->getLanguage() ) ) ); return; @@ -574,7 +578,9 @@ class SpecialUpload extends SpecialPage { if ( !$status->isGood() ) { $this->showRecoverableUploadError( - $this->getOutput()->parseAsInterface( $status->getWikiText() ) + $this->getOutput()->parseAsInterface( + $status->getWikiText( false, false, $this->getLanguage() ) + ) ); return; diff --git a/includes/specials/SpecialUserrights.php b/includes/specials/SpecialUserrights.php index 5747f67b83..28626ea58e 100644 --- a/includes/specials/SpecialUserrights.php +++ b/includes/specials/SpecialUserrights.php @@ -21,6 +21,8 @@ * @ingroup SpecialPage */ +use MediaWiki\MediaWikiServices; + /** * Special page to allow managing user group membership * @@ -161,7 +163,10 @@ class UserrightsPage extends SpecialPage { * (e.g. they don't have the userrights permission), then don't * allow them to change any user rights. */ - if ( !$user->isAllowed( 'userrights' ) ) { + if ( !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'userrights' ) + ) { $block = $user->getBlock(); if ( $block && $block->isSitewide() ) { throw new UserBlockedError( $block ); @@ -172,7 +177,9 @@ class UserrightsPage extends SpecialPage { // save settings if ( !$fetchedStatus->isOK() ) { - $this->getOutput()->addWikiTextAsInterface( $fetchedStatus->getWikiText() ); + $this->getOutput()->addWikiTextAsInterface( + $fetchedStatus->getWikiText( false, false, $this->getLanguage() ) + ); return; } @@ -203,7 +210,9 @@ class UserrightsPage extends SpecialPage { return; } else { // Print an error message and redisplay the form - $out->wrapWikiTextAsInterface( 'error', $status->getWikiText() ); + $out->wrapWikiTextAsInterface( + 'error', $status->getWikiText( false, false, $this->getLanguage() ) + ); } } } @@ -477,7 +486,9 @@ class UserrightsPage extends SpecialPage { function editUserGroupsForm( $username ) { $status = $this->fetchUser( $username, true ); if ( !$status->isOK() ) { - $this->getOutput()->addWikiTextAsInterface( $status->getWikiText() ); + $this->getOutput()->addWikiTextAsInterface( + $status->getWikiText( false, false, $this->getLanguage() ) + ); return; } @@ -515,7 +526,10 @@ class UserrightsPage extends SpecialPage { if ( WikiMap::isCurrentWikiId( $dbDomain ) ) { $dbDomain = ''; } else { - if ( $writing && !$this->getUser()->isAllowed( 'userrights-interwiki' ) ) { + if ( $writing && !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'userrights-interwiki' ) + ) { return Status::newFatal( 'userrights-no-interwiki' ); } if ( !UserRightsProxy::validDatabase( $dbDomain ) ) { diff --git a/includes/specials/SpecialWatchlist.php b/includes/specials/SpecialWatchlist.php index 3d563309de..84b3331d5c 100644 --- a/includes/specials/SpecialWatchlist.php +++ b/includes/specials/SpecialWatchlist.php @@ -381,12 +381,10 @@ class SpecialWatchlist extends ChangesListSpecialPage { // Log entries with DELETED_ACTION must not show up unless the user has // the necessary rights. - if ( !$user->isAllowed( 'deletedhistory' ) ) { + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); + if ( !$permissionManager->userHasRight( $user, 'deletedhistory' ) ) { $bitmask = LogPage::DELETED_ACTION; - } elseif ( !MediaWikiServices::getInstance() - ->getPermissionManager() - ->userHasAnyRight( $user, 'suppressrevision', 'viewsuppressed' ) - ) { + } elseif ( !$permissionManager->userHasAnyRight( $user, 'suppressrevision', 'viewsuppressed' ) ) { $bitmask = LogPage::DELETED_ACTION | LogPage::DELETED_RESTRICTED; } else { $bitmask = 0; diff --git a/includes/specials/SpecialWhatLinksHere.php b/includes/specials/SpecialWhatLinksHere.php index 2840086526..5fe3605a93 100644 --- a/includes/specials/SpecialWhatLinksHere.php +++ b/includes/specials/SpecialWhatLinksHere.php @@ -21,6 +21,7 @@ * @todo Use some variant of Pager or something; the pagination here is lousy. */ +use MediaWiki\MediaWikiServices; use Wikimedia\Rdbms\IDatabase; /** @@ -416,7 +417,9 @@ class SpecialWhatLinksHere extends IncludableSpecialPage { // if the page is editable, add an edit link if ( // check user permissions - $this->getUser()->isAllowed( 'edit' ) && + MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'edit' ) && // check, if the content model is editable through action=edit ContentHandler::getForTitle( $target )->supportsDirectEditing() ) { diff --git a/includes/specials/forms/PreferencesFormOOUI.php b/includes/specials/forms/PreferencesFormOOUI.php index ea23973de4..36e14f0dfd 100644 --- a/includes/specials/forms/PreferencesFormOOUI.php +++ b/includes/specials/forms/PreferencesFormOOUI.php @@ -18,8 +18,6 @@ * @file */ -use MediaWiki\MediaWikiServices; - /** * Form to edit user preferences. * @@ -29,8 +27,15 @@ class PreferencesFormOOUI extends OOUIHTMLForm { // Override default value from HTMLForm protected $mSubSectionBeforeFields = false; + /** @var User|null */ private $modifiedUser; + /** @var bool */ + private $privateInfoEditable = true; + + /** @var bool */ + private $optionsEditable = true; + /** * @param User $user */ @@ -49,6 +54,35 @@ class PreferencesFormOOUI extends OOUIHTMLForm { } } + /** + * @return bool + */ + public function isPrivateInfoEditable() { + return $this->privateInfoEditable; + } + + /** + * Whether the + * @param bool $editable + */ + public function setPrivateInfoEditable( $editable ) { + $this->privateInfoEditable = $editable; + } + + /** + * @return bool + */ + public function areOptionsEditable() { + return $this->optionsEditable; + } + + /** + * @param bool $optionsEditable + */ + public function setOptionsEditable( $optionsEditable ) { + $this->optionsEditable = $optionsEditable; + } + /** * Get extra parameters for the query string when redirecting after * successful save. @@ -73,16 +107,13 @@ class PreferencesFormOOUI extends OOUIHTMLForm { * @return string */ function getButtons() { - if ( !MediaWikiServices::getInstance() - ->getPermissionManager() - ->userHasAnyRight( $this->getModifiedUser(), 'editmyprivateinfo', 'editmyoptions' ) - ) { + if ( !$this->areOptionsEditable() && !$this->isPrivateInfoEditable() ) { return ''; } $html = parent::getButtons(); - if ( $this->getModifiedUser()->isAllowed( 'editmyoptions' ) ) { + if ( $this->areOptionsEditable() ) { $t = $this->getTitle()->getSubpage( 'reset' ); $html .= new OOUI\ButtonWidget( [ @@ -109,6 +140,8 @@ class PreferencesFormOOUI extends OOUIHTMLForm { function filterDataForSubmit( $data ) { foreach ( $this->mFlatFields as $fieldname => $field ) { if ( $field instanceof HTMLNestedFilterable ) { + // @phan-suppress-next-next-line PhanUndeclaredProperty All HTMLForm fields have mParams, + // but the instanceof confuses phan, which doesn't support intersections $info = $field->mParams; $prefix = $info['prefix'] ?? $fieldname; foreach ( $field->filterDataForSubmit( $data[$fieldname] ) as $key => $value ) { diff --git a/includes/specials/forms/UploadForm.php b/includes/specials/forms/UploadForm.php index 1e5f8168d6..0b4e0589c0 100644 --- a/includes/specials/forms/UploadForm.php +++ b/includes/specials/forms/UploadForm.php @@ -76,7 +76,10 @@ class UploadForm extends HTMLForm { parent::__construct( $descriptor, $context, 'upload' ); # Add a link to edit MediaWiki:Licenses - if ( $this->getUser()->isAllowed( 'editinterface' ) ) { + if ( MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'editinterface' ) + ) { $this->getOutput()->addModuleStyles( 'mediawiki.special' ); $licensesLink = $linkRenderer->makeKnownLink( $this->msg( 'licenses' )->inContentLanguage()->getTitle(), diff --git a/includes/specials/pagers/ActiveUsersPager.php b/includes/specials/pagers/ActiveUsersPager.php index 0abe842e79..c9c3b07f81 100644 --- a/includes/specials/pagers/ActiveUsersPager.php +++ b/includes/specials/pagers/ActiveUsersPager.php @@ -19,6 +19,8 @@ * @ingroup Pager */ +use MediaWiki\MediaWikiServices; + /** * This class is used to get a list of active users. The ones with specials * rights (sysop, bureaucrat, developer) will have them displayed @@ -124,7 +126,10 @@ class ActiveUsersPager extends UsersPager { ] ]; $conds['ug2.ug_user'] = null; } - if ( !$this->getUser()->isAllowed( 'hideuser' ) ) { + if ( !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'hideuser' ) + ) { $conds[] = 'NOT EXISTS (' . $dbr->selectSQLText( 'ipblocks', '1', [ 'ipb_user=user_id', 'ipb_deleted' => 1 ] ) . ')'; diff --git a/includes/specials/pagers/BlockListPager.php b/includes/specials/pagers/BlockListPager.php index 4441a33314..718da6da0f 100644 --- a/includes/specials/pagers/BlockListPager.php +++ b/includes/specials/pagers/BlockListPager.php @@ -137,7 +137,10 @@ class BlockListPager extends TablePager { $value, /* User preference timezone */true ) ); - if ( $this->getUser()->isAllowed( 'block' ) ) { + if ( MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'block' ) + ) { $links = []; if ( $row->ipb_auto ) { $links[] = $linkRenderer->makeKnownLink( @@ -358,7 +361,10 @@ class BlockListPager extends TablePager { $info['conds'][] = 'ipb_expiry > ' . $db->addQuotes( $db->timestamp() ); # Is the user allowed to see hidden blocks? - if ( !$this->getUser()->isAllowed( 'hideuser' ) ) { + if ( !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'hideuser' ) + ) { $info['conds']['ipb_deleted'] = 0; } diff --git a/includes/specials/pagers/ContribsPager.php b/includes/specials/pagers/ContribsPager.php index d76dfb8825..95749ba9a8 100644 --- a/includes/specials/pagers/ContribsPager.php +++ b/includes/specials/pagers/ContribsPager.php @@ -25,7 +25,7 @@ */ use MediaWiki\MediaWikiServices; use MediaWiki\Linker\LinkRenderer; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; use Wikimedia\Rdbms\IResultWrapper; use Wikimedia\Rdbms\FakeResultWrapper; use Wikimedia\Rdbms\IDatabase; @@ -269,6 +269,7 @@ class ContribsPager extends RangeChronologicalPager { 'options' => [], 'join_conds' => $revQuery['joins'], ]; + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); // WARNING: Keep this in sync with getTargetTable()! $user = User::newFromName( $this->target, false ); @@ -313,14 +314,11 @@ class ContribsPager extends RangeChronologicalPager { $queryInfo['conds'] = array_merge( $queryInfo['conds'], $this->getNamespaceCond() ); // Paranoia: avoid brute force searches (T19342) - if ( !$user->isAllowed( 'deletedhistory' ) ) { + if ( !$permissionManager->userHasRight( $user, 'deletedhistory' ) ) { $queryInfo['conds'][] = $this->mDb->bitAnd( 'rev_deleted', RevisionRecord::DELETED_USER ) . ' = 0'; - } elseif ( !MediaWikiServices::getInstance() - ->getPermissionManager() - ->userHasAnyRight( $user, 'suppressrevision', 'viewsuppressed' ) - ) { + } elseif ( !$permissionManager->userHasAnyRight( $user, 'suppressrevision', 'viewsuppressed' ) ) { $queryInfo['conds'][] = $this->mDb->bitAnd( 'rev_deleted', RevisionRecord::SUPPRESSED_USER ) . ' != ' . RevisionRecord::SUPPRESSED_USER; diff --git a/includes/specials/pagers/DeletedContribsPager.php b/includes/specials/pagers/DeletedContribsPager.php index cd6294d67f..0ff54fd442 100644 --- a/includes/specials/pagers/DeletedContribsPager.php +++ b/includes/specials/pagers/DeletedContribsPager.php @@ -24,7 +24,7 @@ */ use MediaWiki\Linker\LinkRenderer; use MediaWiki\MediaWikiServices; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; use Wikimedia\Rdbms\IDatabase; use Wikimedia\Rdbms\IResultWrapper; use Wikimedia\Rdbms\FakeResultWrapper; @@ -90,13 +90,11 @@ class DeletedContribsPager extends IndexPager { ]; $conds = array_merge( $userCond, $this->getNamespaceCond() ); $user = $this->getUser(); + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); // Paranoia: avoid brute force searches (T19792) - if ( !$user->isAllowed( 'deletedhistory' ) ) { + if ( !$permissionManager->userHasRight( $user, 'deletedhistory' ) ) { $conds[] = $this->mDb->bitAnd( 'ar_deleted', RevisionRecord::DELETED_USER ) . ' = 0'; - } elseif ( !MediaWikiServices::getInstance() - ->getPermissionManager() - ->userHasAnyRight( $user, 'suppressrevision', 'viewsuppressed' ) - ) { + } elseif ( !$permissionManager->userHasAnyRight( $user, 'suppressrevision', 'viewsuppressed' ) ) { $conds[] = $this->mDb->bitAnd( 'ar_deleted', RevisionRecord::SUPPRESSED_USER ) . ' != ' . RevisionRecord::SUPPRESSED_USER; } @@ -325,8 +323,9 @@ class DeletedContribsPager extends IndexPager { ); $user = $this->getUser(); + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); - if ( $user->isAllowed( 'deletedtext' ) ) { + if ( $permissionManager->userHasRight( $user, 'deletedtext' ) ) { $last = $linkRenderer->makeKnownLink( $undelete, $this->messages['diff'], @@ -344,7 +343,9 @@ class DeletedContribsPager extends IndexPager { $comment = Linker::revComment( $rev ); $date = $this->getLanguage()->userTimeAndDate( $rev->getTimestamp(), $user ); - if ( !$user->isAllowed( 'undelete' ) || !$rev->userCan( RevisionRecord::DELETED_TEXT, $user ) ) { + if ( !$permissionManager->userHasRight( $user, 'undelete' ) || + !$rev->userCan( RevisionRecord::DELETED_TEXT, $user ) + ) { $link = htmlspecialchars( $date ); // unusable link } else { $link = $linkRenderer->makeKnownLink( diff --git a/includes/specials/pagers/ProtectedPagesPager.php b/includes/specials/pagers/ProtectedPagesPager.php index 747dea284a..bb5592ce95 100644 --- a/includes/specials/pagers/ProtectedPagesPager.php +++ b/includes/specials/pagers/ProtectedPagesPager.php @@ -20,6 +20,7 @@ */ use MediaWiki\Linker\LinkRenderer; +use MediaWiki\MediaWikiServices; class ProtectedPagesPager extends TablePager { @@ -159,7 +160,10 @@ class ProtectedPagesPager extends TablePager { $formatted = htmlspecialchars( $this->getLanguage()->formatExpiry( $value, /* User preference timezone */true ) ); $title = Title::makeTitleSafe( $row->page_namespace, $row->page_title ); - if ( $this->getUser()->isAllowed( 'protect' ) && $title ) { + if ( $title && MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'protect' ) + ) { $changeProtection = $linkRenderer->makeKnownLink( $title, $this->msg( 'protect_change' )->text(), diff --git a/includes/specials/pagers/UsersPager.php b/includes/specials/pagers/UsersPager.php index ba078e9f3c..ee0ac003ae 100644 --- a/includes/specials/pagers/UsersPager.php +++ b/includes/specials/pagers/UsersPager.php @@ -23,6 +23,8 @@ * @ingroup Pager */ +use MediaWiki\MediaWikiServices; + /** * This class is used to get a list of user. The ones with specials * rights (sysop, bureaucrat, developer) will have them displayed @@ -123,7 +125,10 @@ class UsersPager extends AlphabeticPager { $conds = []; // Don't show hidden names - if ( !$this->getUser()->isAllowed( 'hideuser' ) ) { + if ( !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $this->getUser(), 'hideuser' ) + ) { $conds[] = 'ipb_deleted IS NULL OR ipb_deleted = 0'; } diff --git a/includes/title/MediaWikiTitleCodec.php b/includes/title/MediaWikiTitleCodec.php index 3bd66d40c6..3ebb4430ec 100644 --- a/includes/title/MediaWikiTitleCodec.php +++ b/includes/title/MediaWikiTitleCodec.php @@ -237,6 +237,7 @@ class MediaWikiTitleCodec implements TitleFormatter, TitleParser { * @param LinkTarget $title * * @return string + * @suppress PhanUndeclaredProperty */ public function getPrefixedText( LinkTarget $title ) { if ( !isset( $title->prefixedText ) ) { diff --git a/includes/upload/UploadBase.php b/includes/upload/UploadBase.php index 3368e29aed..f60c4e3c10 100644 --- a/includes/upload/UploadBase.php +++ b/includes/upload/UploadBase.php @@ -20,7 +20,10 @@ * @file * @ingroup Upload */ + +use MediaWiki\MediaWikiServices; use MediaWiki\Shell\Shell; +use MediaWiki\User\UserIdentity; /** * @defgroup Upload Upload related @@ -145,12 +148,13 @@ abstract class UploadBase { * identifying the missing permission. * Can be overridden by subclasses. * - * @param User $user + * @param UserIdentity $user * @return bool|string */ - public static function isAllowed( $user ) { + public static function isAllowed( UserIdentity $user ) { + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); foreach ( [ 'upload', 'edit' ] as $permission ) { - if ( !$user->isAllowed( $permission ) ) { + if ( !$permissionManager->userHasRight( $user, $permission ) ) { return $permission; } } @@ -1312,7 +1316,7 @@ abstract class UploadBase { $enc = null; } - if ( $enc ) { + if ( $enc !== null ) { $chunk = iconv( $enc, "ASCII//IGNORE", $chunk ); } @@ -1954,7 +1958,10 @@ abstract class UploadBase { * wfFindFile finds a file, it exists in a shared repository. */ $file = wfFindFile( $this->getTitle(), [ 'latest' => true ] ); - if ( $file && !$user->isAllowed( 'reupload-shared' ) ) { + if ( $file && !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'reupload-shared' ) + ) { return [ 'fileexists-shared-forbidden', $file->getName() ]; } @@ -1969,9 +1976,10 @@ abstract class UploadBase { * @return bool */ public static function userCanReUpload( User $user, File $img ) { - if ( $user->isAllowed( 'reupload' ) ) { + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); + if ( $permissionManager->userHasRight( $user, 'reupload' ) ) { return true; // non-conditional - } elseif ( !$user->isAllowed( 'reupload-own' ) ) { + } elseif ( !$permissionManager->userHasRight( $user, 'reupload-own' ) ) { return false; } diff --git a/includes/upload/UploadFromUrl.php b/includes/upload/UploadFromUrl.php index b92fcc5aa9..b87810d540 100644 --- a/includes/upload/UploadFromUrl.php +++ b/includes/upload/UploadFromUrl.php @@ -1,7 +1,4 @@ <?php - -use MediaWiki\MediaWikiServices; - /** * Backend for uploading files from a HTTP resource. * @@ -24,6 +21,9 @@ use MediaWiki\MediaWikiServices; * @ingroup Upload */ +use MediaWiki\MediaWikiServices; +use MediaWiki\User\UserIdentity; + /** * Implements uploading from a HTTP resource. * @@ -43,12 +43,15 @@ class UploadFromUrl extends UploadBase { * user is not allowed, return the name of the user right as a string. If * the user is allowed, have the parent do further permissions checking. * - * @param User $user + * @param UserIdentity $user * * @return bool|string */ - public static function isAllowed( $user ) { - if ( !$user->isAllowed( 'upload_by_url' ) ) { + public static function isAllowed( UserIdentity $user ) { + if ( !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'upload_by_url' ) + ) { return 'upload_by_url'; } @@ -167,7 +170,9 @@ class UploadFromUrl extends UploadBase { $url = $request->getVal( 'wpUploadFileURL' ); return !empty( $url ) - && $wgUser->isAllowed( 'upload_by_url' ); + && MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $wgUser, 'upload_by_url' ); } /** diff --git a/includes/user/LocalIdLookup.php b/includes/user/LocalIdLookup.php index ca3db5b07d..4c9099e8b6 100644 --- a/includes/user/LocalIdLookup.php +++ b/includes/user/LocalIdLookup.php @@ -20,6 +20,8 @@ * @file */ +use MediaWiki\MediaWikiServices; + /** * A CentralIdLookup provider that just uses local IDs. Useful if the wiki * isn't part of a cluster or you're using shared user tables. @@ -69,7 +71,10 @@ class LocalIdLookup extends CentralIdLookup { 'user_id' => array_map( 'intval', array_keys( $idToName ) ), ]; $join = []; - if ( $audience && !$audience->isAllowed( 'hideuser' ) ) { + if ( $audience && !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $audience, 'hideuser' ) + ) { $tables[] = 'ipblocks'; $join['ipblocks'] = [ 'LEFT JOIN', 'ipb_user=user_id' ]; $fields[] = 'ipb_deleted'; @@ -100,7 +105,10 @@ class LocalIdLookup extends CentralIdLookup { 'user_name' => array_map( 'strval', array_keys( $nameToId ) ), ]; $join = []; - if ( $audience && !$audience->isAllowed( 'hideuser' ) ) { + if ( $audience && !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $audience, 'hideuser' ) + ) { $tables[] = 'ipblocks'; $join['ipblocks'] = [ 'LEFT JOIN', 'ipb_user=user_id' ]; $where[] = 'ipb_deleted = 0 OR ipb_deleted IS NULL'; diff --git a/includes/user/PasswordReset.php b/includes/user/PasswordReset.php index fd8eb3fac1..38707dec5b 100644 --- a/includes/user/PasswordReset.php +++ b/includes/user/PasswordReset.php @@ -22,6 +22,7 @@ use MediaWiki\Auth\AuthManager; use MediaWiki\Auth\TemporaryPasswordAuthenticationRequest; +use MediaWiki\Permissions\PermissionManager; use Psr\Log\LoggerAwareInterface; use Psr\Log\LoggerInterface; use MediaWiki\Logger\LoggerFactory; @@ -40,6 +41,9 @@ class PasswordReset implements LoggerAwareInterface { /** @var AuthManager */ protected $authManager; + /** @var PermissionManager */ + private $permissionManager; + /** @var LoggerInterface */ protected $logger; @@ -50,9 +54,14 @@ class PasswordReset implements LoggerAwareInterface { */ private $permissionCache; - public function __construct( Config $config, AuthManager $authManager ) { + public function __construct( + Config $config, + AuthManager $authManager, + PermissionManager $permissionManager + ) { $this->config = $config; $this->authManager = $authManager; + $this->permissionManager = $permissionManager; $this->permissionCache = new MapCacheLRU( 1 ); $this->logger = LoggerFactory::getInstance( 'authentication' ); } @@ -93,7 +102,7 @@ class PasswordReset implements LoggerAwareInterface { } elseif ( !$this->config->get( 'EnableEmail' ) ) { // Maybe email features have been disabled $status = StatusValue::newFatal( 'passwordreset-emaildisabled' ); - } elseif ( !$user->isAllowed( 'editmyprivateinfo' ) ) { + } elseif ( !$this->permissionManager->userHasRight( $user, 'editmyprivateinfo' ) ) { // Maybe not all users have permission to change private data $status = StatusValue::newFatal( 'badaccess' ); } elseif ( $this->isBlocked( $user ) ) { diff --git a/includes/user/User.php b/includes/user/User.php index 4445e1d3b1..fc96fe1952 100644 --- a/includes/user/User.php +++ b/includes/user/User.php @@ -1718,9 +1718,31 @@ class User implements IDBAccessObject, UserIdentity { // overwriting mBlockedby, surely? $this->load(); + // TODO: Block checking shouldn't really be done from the User object. Block + // checking can involve checking for IP blocks, cookie blocks, and/or XFF blocks, + // which need more knowledge of the request context than the User should have. + // Since we do currently check blocks from the User, we have to do the following + // here: + // - Check if this is the user associated with the main request + // - If so, pass the relevant request information to the block manager + $request = null; + + // The session user is set up towards the end of Setup.php. Until then, + // assume it's a logged-out user. + $sessionUser = RequestContext::getMain()->getUser(); + $globalUserName = $sessionUser->isSafeToLoad() + ? $sessionUser->getName() + : IP::sanitizeIP( $sessionUser->getRequest()->getIP() ); + + if ( $this->getName() === $globalUserName ) { + // This is the global user, so we need to pass the request + $request = $this->getRequest(); + } + // @phan-suppress-next-line PhanAccessMethodInternal It's the only allowed use $block = MediaWikiServices::getInstance()->getBlockManager()->getUserBlock( $this, + $request, $fromReplica ); @@ -2772,18 +2794,6 @@ class User implements IDBAccessObject, UserIdentity { } } - /** - * Set the password for a password reminder or new account email - * - * @deprecated Removed in 1.27. Use PasswordReset instead. - * @param string $str New password to set or null to set an invalid - * password hash meaning that the user will not be able to use it - * @param bool $throttle If true, reset the throttle timestamp to the present - */ - public function setNewpassword( $str, $throttle = true ) { - throw new BadMethodCallException( __METHOD__ . ' has been removed in 1.27' ); - } - /** * Get the user's e-mail address * @return string User's email address @@ -3716,11 +3726,17 @@ class User implements IDBAccessObject, UserIdentity { $this->setNewtalk( false ); // If there is a new, unseen, revision, use its timestamp - $nextid = $oldid - ? $title->getNextRevisionID( $oldid, Title::READ_LATEST ) - : null; - if ( $nextid ) { - $this->setNewtalk( true, Revision::newFromId( $nextid ) ); + if ( $oldid ) { + $rl = MediaWikiServices::getInstance()->getRevisionLookup(); + $oldRev = $rl->getRevisionById( $oldid, Title::READ_LATEST ); + if ( $oldRev ) { + $newRev = $rl->getNextRevision( $oldRev ); + if ( $newRev ) { + // TODO: actually no need to wrap in a revision, + // setNewtalk really only needs a RevRecord + $this->setNewtalk( true, new Revision( $newRev ) ); + } + } } } ); } @@ -4298,13 +4314,13 @@ class User implements IDBAccessObject, UserIdentity { 'password' => $password, ] ); - $res = AuthManager::singleton()->beginAuthentication( $reqs, 'null:' ); + $res = $manager->beginAuthentication( $reqs, 'null:' ); switch ( $res->status ) { case AuthenticationResponse::PASS: return true; case AuthenticationResponse::FAIL: // Hope it's not a PreAuthenticationProvider that failed... - \MediaWiki\Logger\LoggerFactory::getInstance( 'authentication' ) + LoggerFactory::getInstance( 'authentication' ) ->info( __METHOD__ . ': Authentication failed: ' . $res->message->plain() ); return false; default: diff --git a/includes/user/UserNamePrefixSearch.php b/includes/user/UserNamePrefixSearch.php index c185babcfb..b3489a2256 100644 --- a/includes/user/UserNamePrefixSearch.php +++ b/includes/user/UserNamePrefixSearch.php @@ -20,6 +20,8 @@ * @file */ +use MediaWiki\MediaWikiServices; + /** * Handles searching prefixes of user names * @@ -46,7 +48,10 @@ class UserNamePrefixSearch { $joinConds = []; // Filter out hidden user names - if ( $audience === 'public' || !$audience->isAllowed( 'hideuser' ) ) { + if ( $audience === 'public' || !MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $audience, 'hideuser' ) + ) { $tables[] = 'ipblocks'; $cond['ipb_deleted'] = [ 0, null ]; $joinConds['ipblocks'] = [ 'LEFT JOIN', 'user_id=ipb_user' ]; diff --git a/includes/utils/AvroValidator.php b/includes/utils/AvroValidator.php index f3a8810a98..77ea3d9d4c 100644 --- a/includes/utils/AvroValidator.php +++ b/includes/utils/AvroValidator.php @@ -34,7 +34,7 @@ class AvroValidator { * @return string|string[] An error or list of errors in the * provided $datum. When no errors exist the empty array is * returned. - * @suppress PhanUndeclaredMethod + * @suppress PhanUndeclaredMethod,PhanUndeclaredProperty */ public static function getErrors( AvroSchema $schema, $datum ) { switch ( $schema->type ) { diff --git a/includes/watcheditem/WatchedItemQueryService.php b/includes/watcheditem/WatchedItemQueryService.php index df5ea70441..d8e49852aa 100644 --- a/includes/watcheditem/WatchedItemQueryService.php +++ b/includes/watcheditem/WatchedItemQueryService.php @@ -1,7 +1,8 @@ <?php use MediaWiki\Linker\LinkTarget; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Permissions\PermissionManager; +use MediaWiki\Revision\RevisionRecord; use MediaWiki\User\UserIdentity; use Wikimedia\Assert\Assert; use Wikimedia\Rdbms\IDatabase; @@ -70,16 +71,21 @@ class WatchedItemQueryService { /** @var WatchedItemStoreInterface */ private $watchedItemStore; + /** @var PermissionManager */ + private $permissionManager; + public function __construct( ILoadBalancer $loadBalancer, CommentStore $commentStore, ActorMigration $actorMigration, - WatchedItemStoreInterface $watchedItemStore + WatchedItemStoreInterface $watchedItemStore, + PermissionManager $permissionManager ) { $this->loadBalancer = $loadBalancer; $this->commentStore = $commentStore; $this->actorMigration = $actorMigration; $this->watchedItemStore = $watchedItemStore; + $this->permissionManager = $permissionManager; } /** @@ -549,7 +555,7 @@ class WatchedItemQueryService { return $conds; } - private function getUserRelatedConds( IDatabase $db, User $user, array $options ) { + private function getUserRelatedConds( IDatabase $db, UserIdentity $user, array $options ) { if ( !array_key_exists( 'onlyByUser', $options ) && !array_key_exists( 'notByUser', $options ) ) { return []; } @@ -566,9 +572,11 @@ class WatchedItemQueryService { // Avoid brute force searches (T19342) $bitmask = 0; - if ( !$user->isAllowed( 'deletedhistory' ) ) { + if ( !$this->permissionManager->userHasRight( $user, 'deletedhistory' ) ) { $bitmask = RevisionRecord::DELETED_USER; - } elseif ( !$user->isAllowedAny( 'suppressrevision', 'viewsuppressed' ) ) { + } elseif ( !$this->permissionManager + ->userHasAnyRight( $user, 'suppressrevision', 'viewsuppressed' ) + ) { $bitmask = RevisionRecord::DELETED_USER | RevisionRecord::DELETED_RESTRICTED; } if ( $bitmask ) { @@ -578,13 +586,15 @@ class WatchedItemQueryService { return $conds; } - private function getExtraDeletedPageLogEntryRelatedCond( IDatabase $db, User $user ) { + private function getExtraDeletedPageLogEntryRelatedCond( IDatabase $db, UserIdentity $user ) { // LogPage::DELETED_ACTION hides the affected page, too. So hide those // entirely from the watchlist, or someone could guess the title. $bitmask = 0; - if ( !$user->isAllowed( 'deletedhistory' ) ) { + if ( !$this->permissionManager->userHasRight( $user, 'deletedhistory' ) ) { $bitmask = LogPage::DELETED_ACTION; - } elseif ( !$user->isAllowedAny( 'suppressrevision', 'viewsuppressed' ) ) { + } elseif ( !$this->permissionManager + ->userHasAnyRight( $user, 'suppressrevision', 'viewsuppressed' ) + ) { $bitmask = LogPage::DELETED_ACTION | LogPage::DELETED_RESTRICTED; } if ( $bitmask ) { diff --git a/jsduck.json b/jsduck.json index 6ba7796162..e675889a53 100644 --- a/jsduck.json +++ b/jsduck.json @@ -12,7 +12,7 @@ "--exclude": [ "resources/src/jquery.tablesorter", "resources/src/jquery.tipsy", - "resources/src/jquery/jquery.color.js", + "resources/src/jquery.color/jquery.color.js", "resources/src/jquery/jquery.highlightText.js", "resources/src/jquery/jquery.mw-jump.js", "resources/src/mediawiki.base/legacy.wikibits.js", diff --git a/languages/LanguageConverter.php b/languages/LanguageConverter.php index 9886425f8b..f42bb88204 100644 --- a/languages/LanguageConverter.php +++ b/languages/LanguageConverter.php @@ -21,7 +21,7 @@ use MediaWiki\MediaWikiServices; use MediaWiki\Logger\LoggerFactory; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; /** * Base class for language conversion. diff --git a/languages/data/Names.php b/languages/data/Names.php index 353127d22d..783a211cab 100644 --- a/languages/data/Names.php +++ b/languages/data/Names.php @@ -80,7 +80,7 @@ class Names { 'az' => 'azərbaycanca', # Azerbaijani 'azb' => 'تۆرکجه', # South Azerbaijani 'ba' => 'башҡортса', # Bashkir - 'ban' => 'Basa Bali', # Balinese + 'ban' => '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 ) 'bbc' => 'Batak Toba', # Batak Toba (falls back to bbc-latn) diff --git a/languages/data/ZhConversion.php b/languages/data/ZhConversion.php index 0a15530164..8fe3be31f8 100644 --- a/languages/data/ZhConversion.php +++ b/languages/data/ZhConversion.php @@ -2982,7 +2982,7 @@ public static $zh2Hant = [ '𫄨' => '絺', '𫄷' => '繶', '𫄸' => '纁', -'𫇭' => '蔿', +'𫇭' => '蒍', '𫌀' => '襀', '𫌨' => '覼', '𫍙' => '訑', @@ -3707,6 +3707,8 @@ public static $zh2Hant = [ '于少保' => '于少保', '于山国' => '于山國', '于山國' => '于山國', +'于山岛' => '于山島', +'于山島' => '于山島', '于帅' => '于帥', '于帥' => '于帥', '于幼军' => '于幼軍', @@ -3724,7 +3726,6 @@ public static $zh2Hant = [ '于志寧' => '于志寧', '于忠肃集' => '于忠肅集', '于忠肅集' => '于忠肅集', -'于思' => '于思', '于慎行' => '于慎行', '于慧' => '于慧', '于成龍' => '于成龍', @@ -3817,6 +3818,7 @@ public static $zh2Hant = [ '于都县' => '于都縣', '于都縣' => '于都縣', '于里察' => '于里察', +'于闐' => '于闐', '于阗' => '于闐', '于双戈' => '于雙戈', '于雙戈' => '于雙戈', @@ -4114,6 +4116,7 @@ public static $zh2Hant = [ '党進' => '党進', '党項' => '党項', '党项' => '党項', +'入侵并' => '入侵並', '内脏' => '內臟', '内制' => '內製', '内面包' => '內面包', @@ -4470,6 +4473,8 @@ public static $zh2Hant = [ '叮叮当当' => '叮叮噹噹', '叮当' => '叮噹', '可紧可松' => '可緊可鬆', +'可能干預' => '可能干預', +'可能干预' => '可能干預', '可自制' => '可自制', '可鉴' => '可鑑', '台子女' => '台子女', @@ -4802,7 +4807,7 @@ public static $zh2Hant = [ '大型钟面' => '大型鐘面', '大多只' => '大多只', '大伙' => '大夥', -'大干' => '大幹', +'大干一' => '大幹一', '大批涌到' => '大批湧到', '大折儿' => '大摺兒', '大明历' => '大明曆', @@ -5527,6 +5532,8 @@ public static $zh2Hant = [ '恶直丑正' => '惡直醜正', '恶斗' => '惡鬥', '惴栗' => '惴慄', +'意大利面临' => '意大利面臨', +'意大利面臨' => '意大利面臨', '意大利面' => '意大利麵', '愛河里花子' => '愛河里花子', '爱河里花子' => '愛河里花子', @@ -5991,6 +5998,8 @@ public static $zh2Hant = [ '方向' => '方向', '方法里' => '方法裡', '于吉林' => '於吉林', +'于格林' => '於格林', +'于越南' => '於越南', '于震中' => '於震中', '于震前' => '於震前', '于震后' => '於震後', @@ -6474,6 +6483,8 @@ public static $zh2Hant = [ '浅淀' => '淺澱', '清心寡欲' => '清心寡欲', '渠冲' => '渠衝', +'温岚' => '温嵐', +'温嵐' => '温嵐', '测不准' => '測不準', '港制' => '港製', '游离' => '游離', @@ -6699,6 +6710,7 @@ public static $zh2Hant = [ '版本里' => '版本裡', '牙签' => '牙籤', '牛只' => '牛隻', +'牢里' => '牢裡', '物欲' => '物慾', '抵牾' => '牴牾', '抵触' => '牴觸', @@ -7028,7 +7040,6 @@ public static $zh2Hant = [ '称赞' => '稱讚', '稻谷' => '稻穀', '稽征' => '稽徵', -'谷人' => '穀人', '谷保家商' => '穀保家商', '谷仓' => '穀倉', '谷圭' => '穀圭', @@ -7656,6 +7667,7 @@ public static $zh2Hant = [ '药签' => '藥籤', '药面儿' => '藥麵兒', '苏昆' => '蘇崑', +'𬞟' => '蘋', '苹婆' => '蘋婆', '苹果' => '蘋果', '苹果干' => '蘋果乾', @@ -7751,6 +7763,7 @@ public static $zh2Hant = [ '袋表' => '袋錶', '袖里' => '袖裡', '被废后' => '被廢後', +'被卷回' => '被捲回', '被系上' => '被繫上', '被里' => '被裡', '被夸' => '被誇', @@ -9319,6 +9332,7 @@ public static $zh2Hant = [ '鹰雕' => 'é¹°éµ°', 'é¹°éµ°' => 'é¹°éµ°', '咸、甜' => '鹹、甜', +'咸吃' => '鹹吃', '咸味' => '鹹味', '咸嘴淡舌' => '鹹嘴淡舌', '咸土' => '鹹土', @@ -11458,6 +11472,7 @@ public static $zh2Hans = [ '葦' => '苇', '葯' => '药', '葷' => '荤', +'蒍' => '𫇭', '蒓' => '莼', '蒔' => '莳', '蒞' => '莅', @@ -13699,6 +13714,7 @@ public static $zh2Hans = [ 'å­«ä¹¾' => '孙乾', '宏碁' => '宏碁', '官陞' => '官升', +'尋陞' => '寻升', '將軍抽俥' => '将军抽俥', '將軍抽車' => '将军抽車', '爾冬陞' => '尔冬升', @@ -14152,7 +14168,10 @@ public static $zh2TW = [ '克罗地亚' => '克羅埃西亞', '克羅地亞' => '克羅埃西亞', '克里斯托弗' => '克里斯多福', +'全角' => '全形', '万维网' => '全球資訊網', +'全角度' => '全角度', +'全角色' => '全角色', '八杆' => '八桿', '公共交通' => '公共運輸', '六杆' => '六桿', @@ -14259,6 +14278,7 @@ public static $zh2TW = [ '塞维利亚' => '塞維亞', '西維爾' => '塞維亞', '塞黑' => '塞蒙', +'多美和普林西比' => '多美普林西比', '塔希提' => '大溪地', '共和联邦' => '大英國協', '英联邦' => '大英國協', @@ -14330,6 +14350,7 @@ public static $zh2TW = [ '希拉里' => '希拉蕊', '希特拉' => '希特勒', '残疾人奥林匹克' => '帕拉林匹克', +'殘疾人奧林匹克' => '帕拉林匹克', '残奥会' => '帕運會', '殘奧會' => '帕運會', '巴尔米拉环礁' => '帕邁拉環礁', @@ -14413,6 +14434,7 @@ public static $zh2TW = [ '施罗德' => '施洛德', '旱烟' => '旱菸', '旱煙' => '旱菸', +'比勒陀利' => '普利托利', '普利策' => '普利茲', '普利策奖' => '普立茲獎', '芯片' => '晶片', @@ -14429,6 +14451,8 @@ public static $zh2TW = [ '马恩岛' => '曼島', '木杆' => '木桿', '尾班車' => '末班車', +'萨格勒布' => '札格瑞布', +'薩格勒布' => '札格瑞布', '列奥纳多' => '李奧納多', '杜塞尔多夫' => '杜塞道夫', '杜塞爾多夫' => '杜塞道夫', @@ -14496,6 +14520,8 @@ public static $zh2TW = [ '海洛英' => '海洛因', '侯賽因' => '海珊', '侯赛因' => '海珊', +'温得和克' => '溫荷克', +'溫得和克' => '溫荷克', '鼠标' => '滑鼠', '汉诺威' => '漢諾瓦', '漢诺威' => '漢諾瓦', @@ -14607,13 +14633,12 @@ public static $zh2TW = [ '卢浮宫' => '羅浮宮', '樂行童軍' => '羅浮童軍', '意大利' => '義大利', +'意大利面' => '義大利麵', '昂山素姬' => '翁山蘇姬', '昂山素季' => '翁山蘇姬', '圣基茨和尼维斯' => '聖克里斯多福及尼維斯', '聖吉斯納域斯' => '聖克里斯多福及尼維斯', '聖佐治' => '聖喬治', -'圣多美和普林西比' => '聖多美普林西比', -'聖多美和普林西比' => '聖多美普林西比', '圣文森特和格林纳丁斯' => '聖文森及格瑞那丁', '聖文森特和格林納丁斯' => '聖文森及格瑞那丁', '圣赫勒拿' => '聖赫倫那', @@ -14836,6 +14861,8 @@ public static $zh2TW = [ '亚拉巴马' => '阿拉巴馬', '阿联酋' => '阿聯', '阿聯酋' => '阿聯', +'亚的斯亚贝巴' => '阿迪斯阿貝巴', +'亞的斯亞貝巴' => '阿迪斯阿貝巴', '罗纳德·里根' => '隆納·雷根', '私隱' => '隱私', '耶加達' => '雅加達', @@ -14958,6 +14985,7 @@ public static $zh2HK = [ '因特网' => '互聯網', '網際網路' => '互聯網', '井里' => '井裏', +'阿迪斯阿貝巴' => '亞的斯亞貝巴', '亮著' => '亮着', '亮著《' => '亮著《', '亮著作' => '亮著作', @@ -15340,6 +15368,9 @@ public static $zh2HK = [ '柯林頓' => '克林頓', '克羅埃西亞' => '克羅地亞', '奈洛比' => '內羅畢', +'全角' => '全形', +'全角度' => '全角度', +'全角色' => '全角色', '公布' => '公佈', '公寓里' => '公寓裏', '冒著' => '冒着', @@ -16406,7 +16437,7 @@ public static $zh2HK = [ '格瑞那達' => '格林納達', '格莱美奖' => '格林美獎', '葛萊美獎' => '格林美獎', -'格鲁吉亚' => '格魯吉亞', +'喬治亞字母' => '格魯吉亞字母', '框里' => '框裏', '台式电脑' => '桌上型電腦', '台球' => '桌球', @@ -16462,6 +16493,7 @@ public static $zh2HK = [ '殺著錄' => '殺著錄', '壳里' => '殼裏', '殿里' => '殿裏', +'普利托利亞' => '比勒陀利亞', '茅利塔尼亞' => '毛里塔尼亞', '模里西斯' => '毛里裘斯', '毛里求斯' => '毛里裘斯', @@ -16587,6 +16619,7 @@ public static $zh2HK = [ '溢著者' => '溢著者', '溢著述' => '溢著述', '溢著錄' => '溢著錄', +'溫荷克' => '溫得和克', '演著' => '演着', '演著作' => '演著作', '演著名' => '演著名', @@ -16657,6 +16690,7 @@ public static $zh2HK = [ '版图里' => '版圖裏', '版本里' => '版本裏', '版权信息' => '版權資訊', +'牢里' => '牢裏', '千里達及托巴哥' => '特立尼達和多巴哥', '牽著' => '牽着', '牽著作' => '牽著作', @@ -17123,6 +17157,7 @@ public static $zh2HK = [ '聖克里斯多福及尼維斯' => '聖吉斯納域斯', '聖多美普林西比' => '聖多美和普林西比', '聖文森及格瑞那丁' => '聖文森特和格林納丁斯', +'聖文森國' => '聖文森特和格林納丁斯', '聖露西亞' => '聖盧西亞', '聖馬利諾' => '聖馬力諾', '聽不著' => '聽不着', @@ -17243,6 +17278,7 @@ public static $zh2HK = [ '肖邦' => '蕭邦', '薛丁格' => '薛定諤', '塞拉耶佛' => '薩拉熱窩', +'札格瑞布' => '薩格勒布', '萨达姆' => '薩達姆', '藉著' => '藉着', '藏著' => '藏着', @@ -18106,6 +18142,7 @@ public static $zh2CN = [ '網際網絡' => '互联网', '網際網路' => '互联网', '亞歷山卓' => '亚历山大', +'阿迪斯阿貝巴' => '亚的斯亚贝巴', '雅穆索戈' => '亚穆苏克罗', '交帳' => '交账', '亮著' => '亮着', @@ -18636,6 +18673,7 @@ public static $zh2CN = [ '聖吉斯納域斯' => '圣基茨和尼维斯', '聖多美普林西比' => '圣多美和普林西比', '聖文森及格瑞那丁' => '圣文森特和格林纳丁斯', +'聖文森國' => '圣文森特和格林纳丁斯', '聖馬利諾' => '圣马力诺', '蓋亞那' => '圭亚那', '坐著' => '坐着', @@ -19413,6 +19451,7 @@ public static $zh2CN = [ '格瑞那達' => '格林纳达', '格林美獎' => '格莱美奖', '葛萊美獎' => '格莱美奖', +'喬治亞字母' => '格鲁吉亚字母', '森巴舞' => '桑巴舞', '梅赫西迪' => '梅赛德斯', '夢著' => '梦着', @@ -19437,6 +19476,7 @@ public static $zh2CN = [ '帕運會' => '残奥会', '帕拉林匹克' => '残疾人奥林匹克', '庇里牛斯' => '比利牛斯', +'普利托利亞' => '比勒陀利亚', '披索' => '比索', '畢卡索' => '毕加索', '茅利塔尼亞' => '毛里塔尼亚', @@ -19524,6 +19564,7 @@ public static $zh2CN = [ '混帳' => 'æ··è´¦', '清澈' => '清澈', '清帳' => '清账', +'溫荷克' => '温得和克', '渴著' => '渴着', '渴著書' => '渴著书', '渴著作' => '渴著作', @@ -20108,6 +20149,7 @@ public static $zh2CN = [ '獲著述' => '获著述', '菁寮' => '菁寮', '塞拉耶佛' => '萨拉热窝', +'札格瑞布' => '萨格勒布', '落著' => '落着', '落著書' => '落著书', '落著作' => '落著作', diff --git a/languages/i18n/ace.json b/languages/i18n/ace.json index 65c46bbc1f..5722270384 100644 --- a/languages/i18n/ace.json +++ b/languages/i18n/ace.json @@ -470,22 +470,6 @@ "changeemail-none": "(hana)", "changeemail-password": "Lageuem rahsia {{SITENAME}} droeneuh:", "changeemail-submit": "Gantoe surat-e", - "bold_sample": "Rakam teubai", - "bold_tip": "Haraih teubai", - "italic_sample": "Rakam singèt naseukah nyoë", - "italic_tip": "Rakam singèt", - "link_sample": "Nan peunawôt", - "link_tip": "Peunawôt dalam", - "extlink_sample": "http://www.example.com nan peunawôt", - "extlink_tip": "Peunawôt luwa (neubôh http:// bak awai)", - "headline_sample": "Naseukah nan", - "headline_tip": "Aneuk beunagi tingkat 1", - "nowiki_sample": "Bèk format naseukah nyoë", - "nowiki_tip": "Bèk seutot beuntuk wiki", - "image_tip": "Pasoë beureukaih", - "media_tip": "Peunawôt beureukaih", - "sig_tip": "Tanda jaroë Droëneuh ngön tanda watèë", - "hr_tip": "Garéh data", "summary": "Éhtisa:", "subject": "Bhaih:", "minoredit": "Nyoë lôn peusaneut bacut", diff --git a/languages/i18n/ady-cyrl.json b/languages/i18n/ady-cyrl.json index 8066d917f0..ff58a7c58c 100644 --- a/languages/i18n/ady-cyrl.json +++ b/languages/i18n/ady-cyrl.json @@ -422,22 +422,6 @@ "resettokens-tokens": "Токенхэр:", "resettokens-done": "Токенхэр зэтедзыгъэх.", "resettokens-resetbutton": "ХэшыпыкIыгъэ токенхэр зэтедзэх", - "bold_sample": "Тхыбзэ Ӏужъу", - "bold_tip": "Тхыбзэ Ӏужъу", - "italic_sample": "Италикэ текст", - "italic_tip": "Италикэ текст", - "link_sample": "Зэпыщэм ыцӀэр", - "link_tip": "Къыдахьэрэ зэпыщэ", - "extlink_sample": "http://www.example.com зэпыщэм ыцӀэ", - "extlink_tip": "ДэкӀырэ зэпыщэ (http:// пэрыт пычыгъор зыщымгъэгъупш)", - "headline_sample": "Сатырышъхьэ текст", - "headline_tip": "Я-2-рэ чэзыу сатырышъхь", - "nowiki_sample": "Формат-хэӀэн зимыщыкӀэгъэ текстыр къигъэуцу", - "nowiki_tip": "Земгъэгъап вики-форматшэным", - "image_tip": "КӀоцӀрыгъэуцогъэ файл", - "media_tip": "Файл къакӀорэ зэпыщ", - "sig_tip": "Уи кӀэтхэжьыкӀэрэ уахътэрэ", - "hr_tip": "Горизонтал сатыр (пчъагъэу умыгъэфед)", "summary": "КӀэкӀэу:", "minoredit": "Мыр хэӀэзэныгъэ цӀыкӀу", "watchthis": "Мы нэкӀубгъом лъыплъ", diff --git a/languages/i18n/aeb-arab.json b/languages/i18n/aeb-arab.json index 9b06853dc3..a1b892a067 100644 --- a/languages/i18n/aeb-arab.json +++ b/languages/i18n/aeb-arab.json @@ -314,22 +314,6 @@ "changeemail-newemail": "عنوان البريد الإلكتروني الجديد:", "changeemail-none": "(لا شيء)", "changeemail-submit": "غيّر البريد الإلكتروني", - "bold_sample": "نص غليظ", - "bold_tip": "نص غليظ", - "italic_sample": "نص مائل", - "italic_tip": "نص مائل", - "link_sample": "عنوان وصلة", - "link_tip": "وصلة داخلية", - "extlink_sample": "http://www.example.com عنوان الوصلة", - "extlink_tip": "وصلة خارجية (تذكر بادئة http://)", - "headline_sample": "نص عنوان رئيسي", - "headline_tip": "عنوان من المستوى الثاني", - "nowiki_sample": "أدخل النص غير المنسق هنا", - "nowiki_tip": "أهمل تهيئة الويكي", - "image_tip": "ملف مدرج", - "media_tip": "وصلة ملف", - "sig_tip": "توقيعك مع الساعة والتاريخ", - "hr_tip": "خط أفقي (تجنب الاستخدام بكثرة)", "summary": "ملخص:", "subject": "موضوع/عنوان:", "minoredit": "هذا تعديل طفيف", diff --git a/languages/i18n/af.json b/languages/i18n/af.json index 636fc59c18..d144c3b53f 100644 --- a/languages/i18n/af.json +++ b/languages/i18n/af.json @@ -536,24 +536,6 @@ "changeemail-submit": "Wysig E-posadres", "changeemail-nochange": "Gee gerus 'n ander nuwe e-posadres", "resettokens-token-label": "$1 (huidige waarde: $2)", - "bold_sample": "Vetdruk", - "bold_tip": "Vetdruk", - "italic_sample": "Skuinsgedrukte teks", - "italic_tip": "Skuinsdruk", - "link_sample": "Skakelnaam", - "link_tip": "Interne skakel", - "extlink_sample": "http://www.voorbeeld.org skakel se titel", - "extlink_tip": "Eksterne skakel (onthou http:// vooraan)", - "headline_sample": "Opskrif", - "headline_tip": "Vlak 2-opskrif", - "nowiki_sample": "Plaas ongeformatteerde teks hier", - "nowiki_tip": "Ignoreer wiki-formattering", - "image_sample": "Voorbeeld.jpg", - "image_tip": "Medialêer", - "media_sample": "Voorbeeld.ogg", - "media_tip": "Lêerskakel", - "sig_tip": "Handtekening met datum", - "hr_tip": "Horisontale streep (selde nodig)", "summary": "Opsomming:", "subject": "Onderwerp:", "minoredit": "Klein wysiging", diff --git a/languages/i18n/ais.json b/languages/i18n/ais.json index 1e2ada388a..24b59bc6a3 100644 --- a/languages/i18n/ais.json +++ b/languages/i18n/ais.json @@ -556,22 +556,6 @@ "resettokens-watchlist-token": "sapiaca tu aazihan [[Special:Watchlist|miazihay a piazihan tu sulit]] Atom/RSS mima-sabuhat", "resettokens-done": "maliyaw tu patizeng mima-sabuhat", "resettokens-resetbutton": "miliyaw patizeng mapili’ay a mima-sabuhat", - "bold_sample": "kibetulay a sulit", - "bold_tip": "kibetulay a sulit", - "italic_sample": "tukenihay nisulit", - "italic_tip": "tukenihay nisulit", - "link_sample": "misiket satangahan a sulit", - "link_tip": "labu-labu misiket", - "extlink_sample": "http://www.example.com misiket satangahan a sulit", - "extlink_tip": "hekal-hekal misiket (amana katawal saka http:// paangangan)", - "headline_sample": "sakacacay a selal nu satangahan a sulit", - "headline_tip": "sakatusa a selal nu satangahan a sulit", - "nowiki_sample": "pacucuk caayay kesehwaay a cudad", - "nowiki_tip": "sekipo Wiki kesehwa sulit nu kamu", - "image_tip": "nicunusay a tangan", - "media_tip": "tangan-tangan misiket", - "sig_tip": "misuay a sulit nu ngangan atu demiad, tuki", - "hr_tip": "Sapisasuala (cayka yadah kawiza)", "summary": "pecu’ nu lacul:", "subject": "satangahan:", "minoredit": "payni mikilulay a mikawaway-kalumyiti", diff --git a/languages/i18n/aln.json b/languages/i18n/aln.json index 3d0da952ab..8a9f283eb4 100644 --- a/languages/i18n/aln.json +++ b/languages/i18n/aln.json @@ -367,24 +367,6 @@ "resetpass-temp-password": "Fjalëkalimi i përkohshëm:", "passwordreset": "reset Fjalëkalimi", "passwordreset-username": "Emri i përdoruesit:", - "bold_sample": "Tekst i trashë", - "bold_tip": "Tekst i nximë", - "italic_sample": "Tekst i pjerrët", - "italic_tip": "Tekst kurziv", - "link_sample": "Titulli i vegzës", - "link_tip": "Vegëz e mbrendshme", - "extlink_sample": "http://www.example.com Titulli i vegzës", - "extlink_tip": "Vegëz e jashtme (mos e harro prefiksin http://)", - "headline_sample": "Teksti i kryetitullit", - "headline_tip": "Kryetitull i nivelit 2", - "nowiki_sample": "Vendos tekst të paformatueshëm këtu", - "nowiki_tip": "Shpërfille formatimin wiki", - "image_sample": "Shembull.jpg", - "image_tip": "Skedë e ndërthurrun", - "media_sample": "Shembull.ogg", - "media_tip": "Vegëz në skedë", - "sig_tip": "Nënshkrimi juej me gjithë kohën", - "hr_tip": "Vijë horizontale (përdoreni rallë)", "summary": "Përmbledhje:", "subject": "Tema/kryetitulli:", "minoredit": "Ky asht redaktim i vogël", diff --git a/languages/i18n/am.json b/languages/i18n/am.json index 20d72d845a..eda4df995a 100644 --- a/languages/i18n/am.json +++ b/languages/i18n/am.json @@ -397,22 +397,6 @@ "changeemail-none": "(የለም)", "changeemail-password": "የ{{SITENAME}} መግቢያ ቃልዎ፦", "changeemail-submit": "አድራሻዎን ለመቀይር", - "bold_sample": "ጉልህ ፊደላት", - "bold_tip": "በጉልህ ፊደላት ይጻፍ", - "italic_sample": "ያንጋደደ ፊደላት", - "italic_tip": "ባንጋደደ (ኢታሊክ) ፊደላት ይጻፍ", - "link_sample": "የመያያዣ ስም", - "link_tip": "ባመለከቱት ቃላት ላይ የዊኪ-ማያያዣ ለማድረግ", - "extlink_sample": "http://www.example.com የውጭ መያያዣ", - "extlink_tip": "የውጭ መያያዣ ለመፍጠር (በ'http://' የሚቀደም)", - "headline_sample": "ንዑስ ክፍል", - "headline_tip": "የንዑስ-ክፍል አርዕስት ለመፍጠር", - "nowiki_sample": "በዚህ ውስጥ የሚከተት ሁሉ የዊኪ-ሥርአተ ቋንቋን ቸል ይላል", - "nowiki_tip": "የዊኪ-ሥርአተ ቋንቋን ቸል ለማድረግ", - "image_tip": "የስዕል መያያዣ ለመፍጠር", - "media_tip": "የድምጽ ፋይል መያያዣ ለመፍጠር", - "sig_tip": "ፊርማዎ ከነሰዓቱ (4x ~)", - "hr_tip": "አድማሳዊ መስመር (በ'----') ለመፍጠር", "summary": "ማጠቃለያ:", "subject": "ጥቅል ርዕስ:", "minoredit": "ይህ ለውጥ ጥቃቅን ነው።", diff --git a/languages/i18n/ami.json b/languages/i18n/ami.json index e9634e3962..1279b786a7 100644 --- a/languages/i18n/ami.json +++ b/languages/i18n/ami.json @@ -185,22 +185,6 @@ "resetpass-submit-cancel": "Sawaden miforic", "passwordreset": " misafaeloh patonek to mima’", "passwordreset-username": "o ngangan no micokaymasay", - "bold_sample": "kifetolay a tilid", - "bold_tip": "kifetolay a tilid", - "italic_sample": "matokenihay a tilid", - "italic_tip": "matokenihay a tilid", - "link_sample": "matongoday a sakacipinang a sowal", - "link_tip": "I laloma’ay a makakafit", - "extlink_sample": "http://www.example.com mipakakafit to sakacipinang a sowal", - "extlink_tip": "Makakafitay i papotal (aka kapawan a http:// a misatapang)", - "headline_sample": "o sakacipinang a sowal sorit i sakacecay a cakat", - "headline_tip": "o sakacipinang a sowal sorit i sakatosa a cakat", - "nowiki_sample": " co’eneken ko caay ko masalalekoay a sorit", - "nowiki_tip": "Kapawanan ko masalalekoay a sowal no Wiki", - "image_tip": "Sapakemel a tang^an", - "media_tip": " patatongod to tang’an", - "sig_tip": "o pisorit iso to ngangan ato romi’ad toki", - "hr_tip": "O rimadac no nanom\n(caay ka rarid a micokaymas)", "summary": " o nisa’amotoan a pakimad", "minoredit": "O sapado^do^ a mikawitan", "watchthis": "mitapal to inian a felih", diff --git a/languages/i18n/an.json b/languages/i18n/an.json index 7b105b8298..8ad164bc20 100644 --- a/languages/i18n/an.json +++ b/languages/i18n/an.json @@ -419,24 +419,6 @@ "changeemail-newemail": "No bi ha garra adreza de correu electronico", "changeemail-none": "(garra)", "changeemail-submit": "Cambiar adreza de correu-e", - "bold_sample": "Texto en negreta", - "bold_tip": "Texto en negreta", - "italic_sample": "Texto en cursiva", - "italic_tip": "Texto en cursiva", - "link_sample": "Títol d'o vinclo", - "link_tip": "Vinclo interno", - "extlink_sample": "http://www.example.com Títol d'o vinclo", - "extlink_tip": "Vinclo externo (recuerde o prefixo http://)", - "headline_sample": "Texto de subtítol", - "headline_tip": "Soztítol de livel 2", - "nowiki_sample": "Escriba aquí texto sin formateyar", - "nowiki_tip": "Ignorar o formato wiki", - "image_sample": "Exemplo.jpg", - "image_tip": "Imachen incorporada", - "media_sample": "Exemplo.ogg", - "media_tip": "Vinclo ta un fichero", - "sig_tip": "Sinyatura, calendata y hora", - "hr_tip": "Linia horizontal (faiga-ne un emplego amoderau)", "summary": "Resumen:", "subject": "Tema/títol:", "minoredit": "He feito una edición menor", diff --git a/languages/i18n/ang.json b/languages/i18n/ang.json index 69b758039b..0d0a729abc 100644 --- a/languages/i18n/ang.json +++ b/languages/i18n/ang.json @@ -433,24 +433,6 @@ "resetpass-submit-cancel": "Undōn", "passwordreset": "Settan þafungword eft", "passwordreset-username": "BrÅ«cendnama:", - "bold_sample": "Þicce traht", - "bold_tip": "Þicce traht", - "italic_sample": "Flōwende traht", - "italic_tip": "Flōwende traht", - "link_sample": "Hlencan nama", - "link_tip": "Innanweard hlenca", - "extlink_sample": "http://www.example.com hlencan nama", - "extlink_tip": "Ūtanweard hlenca (beþenc þone http:// foredÇ£l)", - "headline_sample": "HēafodlÄ«nan traht", - "headline_tip": "2. emnettes hēafodlÄ«n", - "nowiki_sample": "Unendebyrdodne traht hēr settan", - "nowiki_tip": "Wiki endebyrdunge forgietan", - "image_sample": "Bisen.jpg", - "image_tip": "Ingesett ymele", - "media_sample": "Bisen.ogg", - "media_tip": "Ymelan hlenca", - "sig_tip": "Þīn selfmearc mid tÄ«dmearce", - "hr_tip": "Brād lÄ«n (ne brÅ«c oft)", "summary": "Scortness:", "subject": "Ymbe/hēafodlÄ«n:", "minoredit": "Þēos is lytel adihtung", diff --git a/languages/i18n/anp.json b/languages/i18n/anp.json index 300dc821df..66b64caea9 100644 --- a/languages/i18n/anp.json +++ b/languages/i18n/anp.json @@ -370,22 +370,6 @@ "pt-createaccount": "खाता बनाबऽ", "pt-userlogout": "सत्रांत (लॉग आउट)", "passwordreset": "कूटशब्द रीसेट", - "bold_sample": "मोटा पाठ", - "bold_tip": "मोटा अक्षर", - "italic_sample": "तिरछा अक्षर", - "italic_tip": "तिरछा अक्षर", - "link_sample": "कड़ी शीर्षक", - "link_tip": "आंतरिक कड़ी", - "extlink_sample": "http://www.example.com कड़ी शीर्षक", - "extlink_tip": "बाहरी कड़ी (उपसर्ग http:// जरूर लगाबऽ)", - "headline_sample": "शीर्षक", - "headline_tip": "द्वितीय-स्तर शीर्षक", - "nowiki_sample": "अप्रारूपित सामग्री यहाँ डालऽ", - "nowiki_tip": "विकि प्रारूपण नज़रंदाज़ करऽ", - "image_tip": "संलग्न संचिका", - "media_tip": "फाईल लिंक", - "sig_tip": "आपन॑ के हस्ताक्षर व समय", - "hr_tip": "हॉरिझॉंटल लाईन (कम इस्तेमाल करऽ)", "summary": "सारांश:", "subject": "विषय/शीर्षक", "minoredit": "इ एगऽ छोटऽ परिवर्तन छेकै", diff --git a/languages/i18n/ar.json b/languages/i18n/ar.json index fc8e5f78f6..ce93ce2c06 100644 --- a/languages/i18n/ar.json +++ b/languages/i18n/ar.json @@ -126,6 +126,7 @@ "tog-useeditwarning": "حذّرني عندما أغادر تحرير صفحة فيها تغييرات لم أحفظها", "tog-prefershttps": "استخدم دائما اتصالا آمنا عند تسجيل الدخول", "tog-showrollbackconfirmation": "إظهار رسالة تأكيد عند النقر على رابط الاسترجاع", + "tog-requireemail": "تتطلب البريد الإلكتروني لإعادة تعيين كلمة المرور", "underline-always": "دائما", "underline-never": "أبدا", "underline-default": "وفق المظهر أو المتصفح", @@ -501,7 +502,7 @@ "createaccountmail": "استخدم كلمة سر عشوائية مؤقتة وارسلها إلى عنوان البريد الإلكتروني المحدد أدناه", "createaccountmail-help": "يمكن استخدامه لإنشاء حساب لشخص آخر من دون معرفة كلمة المرور.", "createacct-realname": "الاسم الحقيقي (اختياري)", - "createacct-reason": "السبب", + "createacct-reason": "السبب (مسجل بشكل عام)", "createacct-reason-ph": "لماذا تقوم بإنشاء حساب آخر", "createacct-reason-help": "رسالة تظهر في سجل إنشاء الحسابات", "createacct-submit": "افتح الحساب", @@ -669,22 +670,6 @@ "resettokens-watchlist-token": "رمز تغذية الويب (آتوم/آس إس إس) [[Special:Watchlist|للتغيرات التي على قائمة مراقبتك]]", "resettokens-done": "تغيير المفاتيح", "resettokens-resetbutton": "غير المفاتيح المختارة", - "bold_sample": "نص غليظ", - "bold_tip": "نص غليظ", - "italic_sample": "نص مائل", - "italic_tip": "نص مائل", - "link_sample": "عنوان وصلة", - "link_tip": "وصلة داخلية", - "extlink_sample": "http://www.example.com عنوان الوصلة", - "extlink_tip": "وصلة خارجية (تذكر بادئة http://)", - "headline_sample": "نص عنوان رئيسي", - "headline_tip": "عنوان من المستوى الثاني", - "nowiki_sample": "أدخل النص غير المنسق هنا", - "nowiki_tip": "أهمل تهيئة الويكي", - "image_tip": "ملف مدرج", - "media_tip": "وصلة ملف", - "sig_tip": "توقيعك مع الساعة والتاريخ", - "hr_tip": "خط أفقي (تجنب الاستخدام بكثرة)", "summary": "ملخص:", "subject": "موضوع/عنوان:", "minoredit": "هذا تعديل طفيف", @@ -1165,6 +1150,7 @@ "prefs-help-email": "تحديد عنوان البريد الإلكتروني اختياري، ولكنه يلزم لإعادة تعيين كلمة المرور في حال نسيت كلمة المرور الخاصة بك.", "prefs-help-email-others": "يمكنك أيضا أن تسمح للآخرين الاتصال بك عن طريق وصلة في صفحة المستخدم أو نقاش المستخدم الخاصة بك. لا يكشف بريدك الإلكتروني عندما يراسلك أحد بهذه الطريقة، ولكن إذا قمت بالرد سيرى بريدك الإلكتروني.", "prefs-help-email-required": "عنوان البريد الإلكتروني مطلوب.", + "prefs-help-requireemail": "إذا تم تحديده، فسوف يرسل رسائل البريد الإلكتروني الخاصة بإعادة تعيين كلمة المرور فقط إذا كان الشخص الذي قام بإعادة الضبط قد قدم اسم المستخدم والبريد الإلكتروني لهذا الحساب.", "prefs-info": "المعلومات الأساسية", "prefs-i18n": "الترجمة", "prefs-signature": "التوقيع", @@ -1882,6 +1868,7 @@ "listfiles-userdoesnotexist": "حساب المستخدم \"$1\" غير مسجل.", "imgfile": "ملف", "listfiles": "قائمة الملفات", + "listfiles_subpage": "المرفوعات بواسطة $1", "listfiles_thumb": "تصغير", "listfiles_date": "تاريخ", "listfiles_name": "الاسم", @@ -2618,6 +2605,7 @@ "ipblocklist-legend": "إيجاد مستخدم ممنوع", "blocklist-userblocks": "أخفِ منع الحسابات", "blocklist-tempblocks": "أخفِ المنع المؤقت", + "blocklist-indefblocks": "إخفاء عمليات المنع غير المحددة", "blocklist-addressblocks": "أخفِ منع عنوان أيبي واحد", "blocklist-type": "النوع:", "blocklist-type-opt-all": "الكل", @@ -3978,5 +3966,8 @@ "mycustomjsredirectprotected": "ليست لديك صلاحية لتعديل صفحة جافا سكريبت هذه لأنها تحويلة ولا تشير إلى نطاق المستخدمي الخاص بك.", "easydeflate-invaliddeflate": "المحتوى المقدم لا يتم تفريغه بشكل صحيح", "unprotected-js": "لأسباب تتعلق بالأمان; لا يمكن تحميل جافا سكريبت من الصفحات غير المحمية; الرجاء إنشاء جافا سكريبت فقط في نطاق ميدياويكي: أو كصفحة فرعية للمستخدم", - "userlogout-continue": "هل تريد تسجيل الخروج؟" + "userlogout-continue": "هل تريد تسجيل الخروج؟", + "rest-prefix-mismatch": "المسار المطلوب ($1) لم يكن داخل مسار جذر API REST ($2)", + "rest-wrong-method": "لم تكن طريقة الطلب ($1) {{PLURAL:$3|الطريقة|إحدى الطرق}} المسموح بها لهذا المسار ($2)", + "rest-no-match": "المسار النسبي المطلوب ($1) لا يتطابق مع أي معالج معروف" } diff --git a/languages/i18n/arc.json b/languages/i18n/arc.json index 3960826128..e8cc1e886f 100644 --- a/languages/i18n/arc.json +++ b/languages/i18n/arc.json @@ -327,19 +327,6 @@ "passwordreset-email": "ܡܘܢܥܐ ܕܒܝܠܕܪܐ ܐܠܩܛܪܘܢܝܐ:", "passwordreset-emailsentemail": "ܒܝܠܕܪܐ ܐܠܩܛܪܘܢܝܐ ܐܫܬܕܪ ܠܣܘܝܡ ܡܠܬܐ ܕܥܠܠܐ ܙܒܢ ܐܚܪܝܢ", "changeemail": "ܫܚܠܦ ܒܝܠܕܪܐ ܐܠܩܛܪܘܢܝܐ", - "bold_sample": "ܟܬܒܬܐ ܥܒܝܬܐ", - "bold_tip": "ܟܬܒܬܐ ܥܒܝܬܐ", - "italic_sample": "ܟܬܒܬܐ ܦܠܝܡܬܐ", - "italic_tip": "ܟܬܒܬܐ ܦܠܝܡܬܐ", - "link_sample": "ܟܘܢܝܐ ܕܐܣܘܪܐ", - "link_tip": "ܐܣܘܪܐ ܓܘܝܐ", - "extlink_tip": "ܐܣܘܪܐ ܒܪܝܐ (ܕܟܘܪ http:// ܩܕܡܝܬܐ)", - "headline_sample": "ܨܚܚܐ ܕܦܪܫܓܢܐ ܪܫܝܐ", - "nowiki_sample": "ܣܢܘܦ ܟܬܒܬܐ ܕܠܐ ܣܕܝܪܘܬܐ ܗܪܟܐ", - "nowiki_tip": "ܒܣܝ ܣܕܝܪܘܬܐ ܕܘܝܩܝ", - "image_tip": "ܠܦܦܐ ܛܡܝܪܐ", - "media_tip": "ܐܣܘܪܐ ܕܠܦܦܐ", - "sig_tip": "ܪܡܝ ܐܝܕܟ ܥܡ ܙܒܢܐ ܘܣܝܩܘܡܐ", "summary": "ܦܣܝܩܬ̈ܐ ܕܫܘܚܠܦܐ:", "subject": "ܡܠܘܐܐ/ܡܘܢܥܐ ܪܫܝܐ:", "minoredit": "ܗܢܐ ܗܘ ܫܘܚܠܦܐ ܙܥܘܪܐ", diff --git a/languages/i18n/arn.json b/languages/i18n/arn.json index d603a9714c..85357c28dd 100644 --- a/languages/i18n/arn.json +++ b/languages/i18n/arn.json @@ -207,22 +207,6 @@ "loginlanguagelabel": "Cezugun: $1", "pt-login": "Konkülen", "resetpass-submit-cancel": "Katrüntukun", - "bold_sample": "Kurükünualu wirin", - "bold_tip": "Kurükünualu wirin", - "italic_sample": "Küllüke wirin", - "italic_tip": "Küllüke wirin", - "link_sample": "Lasun ñi üy", - "link_tip": "Punwi lasun", - "extlink_sample": "http://www.example.com Lasun ñi üy", - "extlink_tip": "Kamapu lasun (Ngüneduamimi: wüne konkülekey \"http://\")", - "headline_sample": "Lonkolelu wirin", - "headline_tip": "Trürün 2 ñi lonkolelu wirin", - "nowiki_sample": "Üchaftukun ngenochumngen reke chi wirin tüfa mew.", - "nowiki_tip": "Kimfanuel wiki ñi chumkünuwe", - "image_tip": "Üchaftukülechi eltukawün", - "media_tip": "Eltukawün lasun", - "sig_tip": "Tami wirintukun üy ka antü/ora", - "hr_tip": "Kakül wif (Pünengelayafuy rumel)", "summary": "Pichi trokiñündungu:", "subject": "Dungu/üy:", "minoredit": "Püchin kümeelkünungey", diff --git a/languages/i18n/arq.json b/languages/i18n/arq.json index e0cb754bb7..ebc434fae4 100644 --- a/languages/i18n/arq.json +++ b/languages/i18n/arq.json @@ -559,22 +559,6 @@ "resettokens-watchlist-token": "المفتاح تاع السيل (Atom/RSS) تاع [[Special:Watchlist|التبدالات الّي فل ليستة تاع المتابعة تاعك]]", "resettokens-done": "المفاتح راهي تبدّلت.", "resettokens-resetbutton": "بدّل المفاتح الّي راك ختاريتها", - "bold_sample": "كتيبة غليظه", - "bold_tip": "كتيبة غليظه", - "italic_sample": "كتبة مايلة", - "italic_tip": "نص مايل", - "link_sample": "عنوان وصيلة", - "link_tip": "وصيلة داخليه", - "extlink_sample": "http://www.example.com اسم الوصيلة", - "extlink_tip": "وصيلة برانية (ما تنساش البديةhttp://)", - "headline_sample": "كتبة تاع علوان كبير", - "headline_tip": "عنوان من المستوى الثاني", - "nowiki_sample": "دخل الكتبة مشي مستفة هنا", - "nowiki_tip": "اهمل طريقةالويكي", - "image_tip": "ملف داخل", - "media_tip": "وصيلة ملف", - "sig_tip": "سنياتورتك بالساعة و التاريخ", - "hr_tip": "خط أفقي (ما تستعملوش بزاف)", "summary": "ملخص:", "subject": "موضوع:", "minoredit": "هذي تبديلة صغيرة", diff --git a/languages/i18n/ary.json b/languages/i18n/ary.json index fd99dc86a5..f300cd62f7 100644 --- a/languages/i18n/ary.json +++ b/languages/i18n/ary.json @@ -391,24 +391,6 @@ "changeemail-newemail": "ĝonwan dial l-email jdid:", "changeemail-none": "(walo)", "changeemail-submit": "bddel l-email", - "bold_sample": "كتابة غليضة", - "bold_tip": "كتابة غليضة", - "italic_sample": "كتابة مايلة", - "italic_tip": "كتابة مايلة", - "link_sample": "Ĝonwan l-lyan", - "link_tip": "Lyan daÄ¥ili", - "extlink_sample": "http://www.example.com Ĝonwan l-lyan", - "extlink_tip": "Lyan Ä¥ariji (ĝqel ĝla http:// préfiks)", - "headline_sample": "Neá¹£ de l-ĝonwan.", - "headline_tip": "Ĝonwan mosṫawa 2", - "nowiki_sample": "N-Neá¹£ li ma mformatéċ keṫbo hna", - "nowiki_tip": "Ĝti n-neĥĥal le l-formataj", - "image_sample": "Example.jpg", - "image_tip": "Fiċyé m'inséré", - "media_sample": "Example.ogg", - "media_tip": "Lyan dyal ċi fiċyé médya", - "sig_tip": "Ṫ-Ṫowqiĝ dyalek be s-saĝa o ṫ-ṫariÄ¥", - "hr_tip": "Ĥett horizontal (ma ṫkeṫṫerċ menno)", "summary": "Moleĥĥaá¹£:", "subject": "Mowḍoĝ/Ĝonwan", "minoredit": "Hada ṫeĝdil sÄ¡ir", diff --git a/languages/i18n/arz.json b/languages/i18n/arz.json index 4bba0c1a15..1b51a3049c 100644 --- a/languages/i18n/arz.json +++ b/languages/i18n/arz.json @@ -414,22 +414,6 @@ "resetpass-temp-password": "باسورد مؤقته:", "passwordreset": "تمت إعادة ضبط كلمة السر", "passwordreset-username": "اسم اليوزر:", - "bold_sample": "حروف عريضه", - "bold_tip": "حروف عريضه", - "italic_sample": "كلام مايل", - "italic_tip": "كلام مايل", - "link_sample": "عنوان وصله", - "link_tip": "وصله داخليه", - "extlink_sample": "http://www.example.com عنوان الوصله", - "extlink_tip": "وصله خارجيه (افتكر تحط http:// قبل عنوان الوصله)", - "headline_sample": "راس الموضوع", - "headline_tip": "عنوان فرعى من المستوى التانى", - "nowiki_sample": "حط الكلام اللى مش متنسق هنا", - "nowiki_tip": "ما تستعملش فورمات الويكى", - "image_tip": "ملف مغروس", - "media_tip": "وصلة ملف", - "sig_tip": "امضتك مع الساعه والتاريخ", - "hr_tip": "خط افقى (ما تستعملهموش كتير)", "summary": "ملخص:", "subject": "راس الموضوع/موضوع:", "minoredit": "التعديل ده تعديل صغير", diff --git a/languages/i18n/as.json b/languages/i18n/as.json index bf951b401e..78407eeb85 100644 --- a/languages/i18n/as.json +++ b/languages/i18n/as.json @@ -563,22 +563,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|আপোনাৰ লক্ষ্যতালিকাৰ পৃষ্ঠাৰ সালসলনিৰ]] ৱেব ফীডৰ বাবে ট'কেন (Atom/RSS)", "resettokens-done": "ট'কেন ৰিছে'ট কৰা হ'ল।", "resettokens-resetbutton": "নিৰ্বাচিত ট'কেনসমূহ ৰিছে'ট কৰক", - "bold_sample": "গাঢ় পাঠ্য", - "bold_tip": "গাঢ় পাঠ্য", - "italic_sample": "হেলনীয়া পাঠ্য", - "italic_tip": "বেঁকা পাঠ্য", - "link_sample": "শিৰোনামা সংযোগ", - "link_tip": "আভ্যন্তৰীণ সংযোগ", - "extlink_sample": "http://www.example.com শীৰ্ষক সংযোগ", - "extlink_tip": "বাহ্যিক সংযোগ (http:// উপসৰ্গ মনত ৰাখিব)", - "headline_sample": "শিৰোনামা পাঠ্য", - "headline_tip": "দ্বিতীয় স্তৰৰ শিৰোনামা", - "nowiki_sample": "নসজোৱা পাঠ্য ইয়াত অন্তৰ্ভুক্ত কৰক", - "nowiki_tip": "ৱিকি-সম্মত সাজ-সজ্জা অৱজ্ঞা কৰক", - "image_tip": "এম্বেডেড ফাইল", - "media_tip": "ফাইল সংযোগ", - "sig_tip": "সময়ৰ সৈতে আপোনাৰ স্বাক্ষৰ", - "hr_tip": "পথালি ৰেখা (কমকৈ ব্যৱহাৰ কৰিব)", "summary": "সাৰাংশ:", "subject": "বিষয়:", "minoredit": "এইটো এটা অগুৰুত্বপূৰ্ণ সম্পাদনা", diff --git a/languages/i18n/ase.json b/languages/i18n/ase.json index 538fd9b823..ca9149aae1 100644 --- a/languages/i18n/ase.json +++ b/languages/i18n/ase.json @@ -322,12 +322,6 @@ "passwordreset": "M521x532S10609498x496S10621487x512S21100500x483S2df20479x468 M518x531S33b00482x483S1f711482x509 M516x515S10018484x485S1f010487x485", "passwordreset-username": "M526x522S15a56499x510S11520503x479S20e00489x496S26a02474x489 M524x514S11541500x487S1154a477x490 S38a00464x490", "passwordreset-emailtitle": "M518x517S15a30482x489S1f750484x484S20500496x506S22a04505x495 M538x522S18517516x486S1851f461x495S2ff00482x483S14c00513x436S14c08461x445S26a00511x469S26a10459x478 M536x521S2ff00482x483S10011515x491S28108515x461 {{SITENAME}}", - "bold_sample": "M531x518S32a00482x483S15410516x488 M516x515S10018484x485S1f010487x485", - "bold_tip": "M531x518S32a00482x483S15410516x488 M516x515S10018484x485S1f010487x485", - "italic_sample": "M516x515S10018484x485S1f010487x485 M537x516S15a17514x493S15a19474x493S26906504x486S26916464x485", - "italic_tip": "M516x515S10018484x485S1f010487x485 M537x516S15a17514x493S15a19474x493S26906504x486S26916464x485", - "media_tip": "M520x523S14c19480x496S15a01497x497S20710483x477 M521x525S1ce10499x476S1ce48479x476S20a00491x510", - "sig_tip": "M507x523S15a28494x496S26500493x477 M518x518S15a37483x483S11551491x493 M521x508S1f748479x493S1f740501x493 M522x518S10050490x488S15a56495x482S20500478x483 M518x516S20b00483x503S15a37495x486S20340491x485", "summary": "M554x524S14c40530x477S14c48446x493S26502515x490S26516468x508S20340495x490S20348487x507 S38a00464x490", "minoredit": "M521x532S10609498x496S10621487x512S21100500x483S2df20479x468 M515x512S1f010486x488S2f900502x507", "savearticle": "M519x513S10e02489x498S20302482x488 M531x512S15a37501x488S1f550507x495S20e00487x499S26502469x498", diff --git a/languages/i18n/ast.json b/languages/i18n/ast.json index c5a76e6448..96329e5f3f 100644 --- a/languages/i18n/ast.json +++ b/languages/i18n/ast.json @@ -603,24 +603,6 @@ "resettokens-watchlist-token": "Pase pa la canal de noticies web (Atom/RSS) de los [[Special:Watchlist|cambios en páxines de la llista de vixilancia]]", "resettokens-done": "Reaniciaronse los pases.", "resettokens-resetbutton": "Reaniciar los pases seleicionaos", - "bold_sample": "Testu en negrina", - "bold_tip": "Testu en negrina", - "italic_sample": "Testu en cursiva", - "italic_tip": "Testu en cursiva", - "link_sample": "Títulu del enllaz", - "link_tip": "Enllaz internu", - "extlink_sample": "http://www.example.com títulu del enllaz", - "extlink_tip": "Enllaz esternu (recuerda'l prefixu http://)", - "headline_sample": "Testu de cabecera", - "headline_tip": "Cabecera de nivel 2", - "nowiki_sample": "Pon equí testu ensin formatu", - "nowiki_tip": "Inorar el formatu wiki", - "image_sample": "Exemplu.jpg", - "image_tip": "Ficheru incrustáu", - "media_sample": "Exemplu.ogg", - "media_tip": "Enllaz del ficheru", - "sig_tip": "La to robla con data y hora", - "hr_tip": "Llinia horizontal (úsala con moderación)", "summary": "Resume:", "subject": "Asuntu:", "minoredit": "Esta ye una edición menor", diff --git a/languages/i18n/atj.json b/languages/i18n/atj.json index acb7a74eff..59dd032acb 100644 --- a/languages/i18n/atj.json +++ b/languages/i18n/atj.json @@ -235,22 +235,6 @@ "passwordreset": "Ka ocehikaniin itewin koski masinaha", "passwordreset-username": "Icinikasowin:", "passwordreset-email": "Pamikicikwepitcikan matcetcicihikan:", - "bold_sample": "Atisokesinahikan e makatewasinatek", - "bold_tip": "Atisokesinahikan e makatewasinatek", - "italic_sample": "Atisokesinahikan ka kwectek", - "italic_tip": "Atisokesinahikan ka kwectek", - "link_sample": "Ka icinikatek takapikenikan", - "link_tip": "Pitc itapikesinikan", - "extlink_sample": "http://www.example.com ka icinikatek takapikenikan", - "extlink_tip": "Masinahikana ka ici tapitik kotakik masinahikanik", - "headline_sample": "Atisokesinahikan ke aicinikatek", - "headline_tip": "Icinikatamowinicic 2 ka iteritakok", - "nowiki_sample": "Acta atisokesinahikan aka moci ka ki otci nihipitcikatek ota", - "nowiki_tip": "Aka pamerita e itasinihak wiki", - "image_tip": "E pitakesinahikatek masinahikaniwoc", - "media_tip": "Ka ici tapitik onimiskimasinahikan", - "sig_tip": "Masinahotiso acit e tato konekisitc pisimw", - "hr_tip": "Ka mitaskosinatek(aka oraho)", "summary": "Nosem:", "minoredit": "Apicic meckotciparin", "watchthis": "Wi nosinetaine ohwe masinahikan", diff --git a/languages/i18n/avk.json b/languages/i18n/avk.json index e6d2412415..5311f70b41 100644 --- a/languages/i18n/avk.json +++ b/languages/i18n/avk.json @@ -436,24 +436,6 @@ "changeemail-newemail": "Warzafe e-mail mane", "changeemail-none": "(mek)", "changeemail-submit": "Betara va e-mail mane", - "bold_sample": "Bold krent", - "bold_tip": "Bold krent", - "italic_sample": "Italic krent", - "italic_tip": "Italic krent", - "link_sample": "Vergumveltgluyaxa", - "link_tip": "Kofa gluyaxa", - "extlink_sample": "http://www.example.com vergumveltgluyaxa", - "extlink_tip": "Divafa gluyaxa ( va http:// me vulkul )", - "headline_sample": "Krojkrent", - "headline_tip": "Vergumvelt ke 2-eafa ema", - "nowiki_sample": "Breviziskaf krent batliz cenkal", - "nowiki_tip": "Va wiki breviz afaná", - "image_sample": "Tula.jpg", - "image_tip": "Plekuyuna ewava", - "media_sample": "Tula.ogg", - "media_tip": "Gluyaxa va iyeltak", - "sig_tip": "Rinafa evlakirafa sugdara", - "hr_tip": "Zidafa gluyaxa ( me faversel )", "summary": "Vildeks:", "subject": "Detce :", "minoredit": "Betamaks.", diff --git a/languages/i18n/awa.json b/languages/i18n/awa.json index bdbe4b0f3e..25e2ae9312 100644 --- a/languages/i18n/awa.json +++ b/languages/i18n/awa.json @@ -594,22 +594,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|आप कय ध्यानसूची कय पन्नन् में बदलाव]] कय वेब फ़ीड (Atom/RSS)कय नाते टोकन", "resettokens-done": "टोकन रीसेट कई गय।", "resettokens-resetbutton": "चुनल टोकन रीसेट करा जाय", - "bold_sample": "मोट लेख", - "bold_tip": "मोट लेख", - "italic_sample": "तिरछा लेख", - "italic_tip": "इटैलिक लेख", - "link_sample": "कड़ी शीर्षक", - "link_tip": "आंतरिक कड़ी", - "extlink_sample": "http://www.example.com कड़ी शीर्षक", - "extlink_tip": "बाहरी कड़ी (उपसर्ग http:// जरुर लगावा जाई)", - "headline_sample": "शीर्षक लेख", - "headline_tip": "द्वितीय-स्तर शीर्षक", - "nowiki_sample": "अप्रारूपित लेख यहँ डारा जाय", - "nowiki_tip": "विकि प्रारूपण नज़रंदाज़ करा जाय", - "image_tip": "एम्बेड करल फ़ाइल", - "media_tip": "फ़ाइल कय कड़ी", - "sig_tip": "आप कय हस्ताक्षर अव समय", - "hr_tip": "सिधा लाइन (कम इस्तेमाल करा जाई)", "summary": "सारांश:", "subject": "विषय:", "minoredit": "ई छोट सम्पादन होय ।", @@ -714,6 +698,8 @@ "nocreate-loggedin": "आप कय नँवा पन्ना बनावे कय अनुमति नाई है ।", "sectioneditnotsupported-title": "अनुभाग सम्पादन समर्थित नाई है", "sectioneditnotsupported-text": "इ पन्ना पे अनुभाग सम्पादन समर्थित नाई है", + "modeleditnotsupported-title": "संपादन सपोर्ट नही करत", + "modeleditnotsupported-text": "सामग्री मॉडल $1 के बरे संपादन सपोर्ट नही अहै", "permissionserrors": "अनुमति त्रुटि", "permissionserrorstext": "निचे दिहा {{PLURAL:$1|कारण|कारणन्}} कय नाते आप कय ऐसन करे कय अनुमति नाइ है:", "permissionserrorstext-withaction": "आप कय $2 कय अनुमति नाई है,निचे दिहा {{PLURAL:$1|कारण|कारणन्}} कय नाते से:", @@ -2295,9 +2281,9 @@ "sessionfailure": "ऐसा प्रतीत होता है कि आपके लॉगिन सत्र के साथ कोई समस्या है।\nसत्र अपहरण से बचाने के लिए सावधानी के तौर पर आपका यह क्रियाकलाप रद्द कर दिया गया है।\nकृपया पीछे जाएँ और पृष्ठ को पुनः लोड करें, तब दुबारा कोशिश करें।", "changecontentmodel": "पन्ने का सामग्री प्रारूप बदलें", "changecontentmodel-legend": "पृष्ठ सामग्री का नमूना", - "changecontentmodel-title-label": "पृष्ठ शीर्षक", + "changecontentmodel-title-label": "पृष्ठ शीर्षक:", "changecontentmodel-current-label": "Current content model:", - "changecontentmodel-model-label": "नयि सामग्री का नमूना", + "changecontentmodel-model-label": "नयि सामग्री कय नमूना:", "changecontentmodel-reason-label": "कारण:", "changecontentmodel-submit": "बदला", "changecontentmodel-success-title": "सामगरि का नामुने मे बदलाव हुुुाा हेेे", diff --git a/languages/i18n/az.json b/languages/i18n/az.json index 402019eb17..c04aa00f75 100644 --- a/languages/i18n/az.json +++ b/languages/i18n/az.json @@ -627,24 +627,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|Ä°zləmə siyahınızdakı]] səhifələrdə dəyişikliklərin web feed-i (Atom / RSS) üçün jeton", "resettokens-done": "Jetonlar sıfırlandı.", "resettokens-resetbutton": "Seçilmiş jetonları sıfırla", - "bold_sample": "Qalın mətn", - "bold_tip": "Qalın mətn", - "italic_sample": "Kursiv mətn", - "italic_tip": "Kursiv mətn", - "link_sample": "Bağlantı başlığı", - "link_tip": "Daxili bağlantı", - "extlink_sample": "http://www.example.com başlıq", - "extlink_tip": "Xarici səhifə (http:// ekini unutma)", - "headline_sample": "Başlıq mətni", - "headline_tip": "2. səviyyə başlıq", - "nowiki_sample": "Formatlaşdırılmamış mətni bura daxil edin", - "nowiki_tip": "Viki formatını sayma", - "image_sample": "Misal.jpg", - "image_tip": "Şəkil əlavə etmə", - "media_sample": "Misal.ogg", - "media_tip": "Media-fayla keçid", - "sig_tip": "Ä°mza və vaxt", - "hr_tip": "Horizontal cizgi", "summary": "Qısa məzmun:", "subject": "Mövzu:", "minoredit": "Kiçik redaktə", diff --git a/languages/i18n/azb.json b/languages/i18n/azb.json index ad42134001..6c0a04624a 100644 --- a/languages/i18n/azb.json +++ b/languages/i18n/azb.json @@ -566,22 +566,6 @@ "resettokens-watchlist-token": "نیشانلامیش یئمک وپی [[Special:Watchlist|ایزلنمیش سون دییشیک اولان صفحه لر]](اتم/آراس‌اس)", "resettokens-done": "رمز لری دَییشلندی.", "resettokens-resetbutton": "سئچیلمیش دَییشلنن رمزلر.", - "bold_sample": "قالین یازی", - "bold_tip": "قالین یازی", - "italic_sample": "اَیری یازی", - "italic_tip": "اَیری یازی", - "link_sample": "باغلانتی باشلیغی", - "link_tip": "ایچری باغلانتی‌سی", - "extlink_sample": "http://www.example.com باغلانتی باشلیغی", - "extlink_tip": "ائشیک باغلانتی (http:// اؤن‌اکی‌نی اونوتمایین)", - "headline_sample": "باشلیق متنی", - "headline_tip": "Û² یوکسک باشلیق", - "nowiki_sample": "فورمت‌لشدیریلمه‌میش یازی‌نی بورا داخیل ائدین", - "nowiki_tip": "ویکی فورمت‌لندیرمه‌سینی سایما", - "image_tip": "یئرلشدیریلمیش فایل", - "media_tip": "فایل باغلانتی‌سی", - "sig_tip": "سیزین ایمضانیز واخت ایله", - "hr_tip": "دوزئی خط (آز ایشلدین)", "summary": "قیساسی:", "subject": "موضوع:", "minoredit": "بو بیر کیچیک دَییشدیرمه‌دیر", diff --git a/languages/i18n/ba.json b/languages/i18n/ba.json index 47496dd901..65064f3ae8 100644 --- a/languages/i18n/ba.json +++ b/languages/i18n/ba.json @@ -601,22 +601,6 @@ "resettokens-watchlist-token": " [[Special:Watchlist|күҙәтеүҙәрегеҙ исемлегендә биттәрҙең үҙгәрештәре]] веб-каналы өсөн токен(Atom/RSS)", "resettokens-done": "Токендар ташланды.", "resettokens-resetbutton": "Һайланған токендарҙы ташларға", - "bold_sample": "Ҡалын яҙылыш", - "bold_tip": "Ҡалын яҙылыш", - "italic_sample": "Курсив яҙылыш", - "italic_tip": "Курсив яҙылыш", - "link_sample": "Һылтанма исеме", - "link_tip": "Эске һылтанма", - "extlink_sample": "http://www.example.com һылтанма исеме", - "extlink_tip": "Тышҡы һылтанма (http:// префиксын онотмағыҙ)", - "headline_sample": "Исем", - "headline_tip": "2-се дәрәжәле исем", - "nowiki_sample": "Бында форматланмаған тексты өҫтәгеҙ.", - "nowiki_tip": "Вики-форматлауға иғтибар итмәҫкә", - "image_tip": "Индерелгән файл", - "media_tip": "Файл һылтанмаһы", - "sig_tip": "Имзағыҙ һәм ваҡыт", - "hr_tip": "Горизонталь һыҙыҡ (бик йыш ҡулланмағыҙ)", "summary": "Үҙгәртеү аңлатмаһы:", "subject": "Тема/исем:", "minoredit": "Әҙ генә үҙгәрештәр", diff --git a/languages/i18n/ban.json b/languages/i18n/ban.json index 37e59477b1..457680d2f6 100644 --- a/languages/i18n/ban.json +++ b/languages/i18n/ban.json @@ -13,12 +13,13 @@ "Joseagush", "Wandering ant", "Kadek Ayu Sulastri", - "Luh Gede Krismayanti" + "Luh Gede Krismayanti", + "Amire80" ] }, "tog-underline": "Garis ring beten pranala:", - "tog-hideminor": "engkebang suntingan ring gentosan sane pinih anyar", - "tog-hidepatrolled": "engkebang suntingan mapatrol ring gentosan sane pinih anyar", + "tog-hideminor": "Engkebang uahan alit saking uahan sané mangkin", + "tog-hidepatrolled": "Engkebang uahan sané kapatroli saking uahan sané mangkin", "tog-newpageshidepatrolled": "engkebang lembar mapatrol saking saking kepahan lembar anyar", "tog-hidecategorization": "Engkebang kacané", "tog-extendwatchlist": "kembangang kepahan pangiwasan antuk nampilang samian panguwahan, nenten sane anyar kewanten", @@ -30,6 +31,8 @@ "tog-watchdefault": "imbuhin lembar panyuntingansane sunting titiang ring kepahan pangiwasan", "tog-watchmoves": "imbuhang lembar sane kakisidang titiang ring kepahan pangiwasan", "tog-watchdeletion": "imbuhin lembar sane kaapus ring kepahan pangiwasan", + "tog-watchuploads": "Tambehin berkas anyar sané unggah tiang ka pupulan pantaun\nTambahkan berkas baru yang saya unggah ke daftar pantauan", + "tog-watchrollback": "Tambehin kaca sané sampun uliang tiang ka tengah pupulan pantauan tiangé", "tog-minordefault": "pingetin samian suntingan dados suntingan alit sane ajeg", "tog-previewontop": "tampilang pratayang sadurung kotak sunting lan nenten sadurungnyane", "tog-previewonfirst": "tampilang pratayang ring suntingan kapertama", @@ -46,6 +49,8 @@ "tog-watchlisthidebots": "engkebang panguwahan bot ring kepahan pangiwasan", "tog-watchlisthideminor": "engkebang panguwahan alit ring kepahan pangiwasan", "tog-watchlisthideliu": "engkebang suntingan penganggen malebu log ring kepahan pangiwasan", + "tog-watchlistreloadautomatically": "Ulangin pupulan pantauan manut otomatis ritatkala silih tunggil penyaringan kauah (JavaScript kaperluang)", + "tog-watchlistunwatchlinks": "Tambehin pacihna pantau/usap pantauan ka kaca sané kapantau tur kauah (JavaScript kaperluang anggén nganti tetujon puniki)", "tog-watchlisthideanons": "engkebangsuntingan penganggen tan maadan ring kepahan pangiwasan", "tog-watchlisthidepatrolled": "engkebang panguwahan mapatrol kepahan pangiwasan", "tog-watchlisthidecategorization": "Engkebang katégorisasi kacané", @@ -55,6 +60,8 @@ "tog-norollbackdiff": "Sampunang tampilang binanne sesampun ngewaliang", "tog-useeditwarning": "elingang titiang yening ngalahin lembar panyuntingan sadurung nyimpen pagentosan", "tog-prefershttps": "Setata nganggen sambungan sane aman rikala malebu log", + "tog-showrollbackconfirmation": "Sinahang konfirmasi ritatkala ngklik pranala sané kauliang\nTampilkan konfirmasi ketika mengeklik pranala pengembalian", + "tog-requireemail": "Perlu séwala éléktronik anggé nyumu ngardi kruna sandi", "underline-always": "Setata", "underline-never": "Nénten naénin", "underline-default": "kulit utawi penjelajah paaban", @@ -73,7 +80,7 @@ "mon": "Som", "tue": "Ang", "wed": "Bud", - "thu": "Wrs", + "thu": "Wra", "fri": "Suk", "sat": "San", "january": "Januari", @@ -107,44 +114,50 @@ "may": "Méi", "jun": "Jun", "jul": "Jul", - "aug": "Ags", + "aug": "Agu", "sep": "Sép", "oct": "Okt", "nov": "Nop", "dec": "Dés", - "january-date": "Januari $1", - "february-date": "Februari $1", - "march-date": "Maret $1", - "april-date": "April $1", - "may-date": "Mei $1", - "june-date": "Juni $1", - "july-date": "Juli $1", - "august-date": "Agustus $1", - "september-date": "September $1", - "october-date": "Oktober $1", - "november-date": "November $1", - "december-date": "Desember $1", + "january-date": "$1 Januari", + "february-date": "$1 Pébruari", + "march-date": "$1 Maret", + "april-date": "$1 April", + "may-date": "$1 Méi", + "june-date": "$1 Juni", + "july-date": "$1 Juli", + "august-date": "$1 Agustus", + "september-date": "$1 Séptémber", + "october-date": "$1 Oktober", + "november-date": "$1 Nopémber", + "december-date": "$1 Désémber", "period-am": "AM", "period-pm": "PM", "pagecategories": "{{PLURAL:$1|Kategori}}", "category_header": "Kaca ring ketegori \"$1\"", "subcategories": "Subkategori", "category-media-header": "Média ring kategori \"$1\"", - "category-empty": "\"mangkin, nenten madaging lembar utawi pekakas ring golongan puniki\"", - "hidden-categories": "{{plural:$1|punduhan sane kaengkebang| punduhan sane kaengkebang}}", - "hidden-category-category": "Kategori mengkeb", - "category-subcat-count": "{{PLURAL:$2| golongan puniki madue {{PLURAL:$1|$1 subkategori}} puniki, saking genepan $2.}}", - "category-article-count": "{{PLURAL:$2|golongan puniki madue{{PLURAL:$1|$1 lembar}}, saking total $2.}}", + "category-empty": "<em>Kategori puniki mangkin nénten madaging kaca utawi média.</em>", + "hidden-categories": "{{plural:$1|Kategori sané kaengkebang}}", + "hidden-category-category": "Kategori sané kaengkebang", + "category-subcat-count": "{{PLURAL:$2|Kategori iki wantah madué subkategori ring sor puniki|Kategori iki madué {{PLURAL:$1|subkategori|$1 subkategori}} ring sor puniki, saking $2 akéhnyané.}}", + "category-subcat-count-limited": "Kelompok puniki madué {{PLURAL:$1|$1 kategori alit}} sakadi punika.", + "category-article-count": "{{PLURAL:$2|Kategori puniki wantah madué kaca ring sor puniki.|{{PLURAL:$1|Kaca|$1 kaca}} ring sor puniki wénten ring kategori puniki, saking $2 akéhnyané.}}", + "category-article-count-limited": "Kelompok puniki madué {{PLURAL:$1|$1 kaca}} sakadi punika.", "category-file-count": "{{PLURAL:$2|golongan puniki madue{{PLURAL:$1|$1 lembar}}, saking total $2.}}", + "category-file-count-limited": "Kelompok puniki madué {{PLURAL:$1|$1 berkas}} sakadi punika.", "listingcontinuesabbrev": "lant.", "index-category": "Lembar sane maindeks", "noindex-category": "Lembar sane nenten maindeks", "broken-file-category": "Suratan sane ngelah pranala usak", + "categoryviewer-pagedlinks": "($1) ($2)", + "category-header-numerals": "$1–$2", "about": "Indik", "article": "Kaca daging", - "newwindow": "(bukak ring jendela anyar)", + "newwindow": "(métbét ring jendéla anyar)", "cancel": "Wangdé", "moredotdotdot": "Lianan...", + "morenotlisted": "Bacakan puniki asané nénten lengkap.", "mypage": "Kaca", "mytalk": "Pabligbagan", "anontalk": "Pabligbagan", @@ -152,7 +165,7 @@ "and": " miwah", "faq": "FAQ (pitaken sane jagi katakonang)", "actions": "Parilaksana", - "namespaces": "Genah wastan", + "namespaces": "Genah aran", "variants": "Varian", "navigation-heading": "Menu navigasi", "errorpagetitle": "Kaiwangan", @@ -161,21 +174,25 @@ "help": "Wantuan", "help-mediawiki": "Pitulung MediaWiki", "search": "Rereh", + "search-ignored-headings": "# <pre>\n# Murda sané jagi nénten karunguang olih pangrereh.\n# Suratan puniki jagi kalaksanayang sasampun kaca taler murda puniki kaindeks.\n# Ragané prasida ngmaksayang pangindeksan mawali kaca puniki antuk nglaksanayang suratan kosong (''null edit'')\n# Sintaksisnyané sakadi puniki:\n# * Makasami saking watek \"#\" ka bait untat inggih punika silih tunggil pabligbagan.\n# * Tiap bait ten-kosong inggih punika murda sané patut sané jagi nénten karunguang.\nReferensi\nPranala luar\nCingak taler\n #</pre>", "searchbutton": "Rereh", "go": "Lanturang", "searcharticle": "Rereh", "history": "Babad kaca", "history_short": "Babad", "history_small": "babad", + "updatedmarker": "kamutakhiran sekat pengunjung tiang sané kaping untat", "printableversion": "Vérsi cétak", "permalink": "Pranala ajeg", "print": "Citak", "view": "Cingak", "view-foreign": "Cingak ring $1", "edit": "Uah", - "create": "Karyanin", - "create-local": "Icénin daging sané marupa paparan lokal", + "edit-local": "Tambeh déskripsi lokal", + "create": "Kardi", + "create-local": "Tambeh déskripsi lokal", "delete": "Usap", + "undelete_short": "Wangdeang usap {{PLURAL:$1|$1 suratan}}", "viewdeleted_short": "Cingak {{PLURAL:$1|siki uahan sané kausapin|$1 uahan sané kausapin}}", "protect": "Saib", "protect_change": "uah", @@ -186,10 +203,12 @@ "personaltools": "Pekakas praragan", "talk": "Pabligbagan", "views": "Pakantenan", - "toolbox": "Pekakas", + "toolbox": "Piranti", + "tool-link-userrights": "Uah{{GENDER:$1|pangangge}}", + "tool-link-userrights-readonly": "Cingak kelompok {{GENDER:$1|pangangge}}", "tool-link-emailuser": "Kirim surel ring {{GENDER:$1|pengguna}} puniki", "imagepage": "Cingak kaca berkas", - "mediawikipage": "Cingak kaca séwalapatra", + "mediawikipage": "Cingak kaca séwala", "templatepage": "Cingak kaca cétakan", "viewhelppage": "Cingak kaca wantuan", "categorypage": "Cingak kaca kategori", @@ -198,14 +217,22 @@ "redirectedfrom": "(Kagingsirang saking $1)", "redirectpagesub": "Kaca gingsiran", "redirectto": "Magingsir ring:", - "lastmodifiedat": "Kaca puniki kaping untat kauah rikala $2, $1", + "lastmodifiedat": "Kaca puniki kaping untat kauah ri tatkala $2, $1", + "viewcount": "Kaca puniki sampun diaksés ping {{PLURAL:$1|$1 kali}}.<br />", "protectedpage": "Kaca sané kasaibin", "jumpto": "Lanturang ka:", "jumptonavigation": "navigasi", "jumptosearch": "rereh", + "view-pool-error": "Ampura, server kari sibuk mangkin.\nAkéh pisan panganggé sané mautsaha nyingakin kaca puniki.\nAntosang jebos sadurung ragané jagi ngeaksés kaca puniki. \nMaaf, server sedang sibuk pada saat ini.\nTerlalu banyak pengguna berusaha melihat halaman ini.\nTunggu sebentar sebelum Anda mencoba lagi mengakses halaman ini.\n\n$1", + "generic-pool-error": "Ampura, server kari sibuk mangkin.\nKaliwat akéh panganggé sané mautsaha nyingakin sumber puniki.\nAntosang jebos sadurung ragané jagi ngaksés kaca puniki malih.", + "pool-timeout": "Liwat galah ngantosang kunci", + "pool-queuefull": "Pupulan antrian sampun penuh", "pool-errorunknown": "Iwang sané durung kauningin", + "pool-servererror": "Layanan pangitung pool punika nénten kasayagayang ($1).", + "poolcounter-usage-error": "Pikobet panganggean: $1", "aboutsite": "Indik {{SITENAME}}", "aboutpage": "Project:Indik", + "copyright": "Daging kasayagayang ring sor $1 ri tatkala nénten wénten uahan.", "copyrightpage": "{{ns:project}}:Hak cipta", "currentevents": "Kawéntenané mangkin", "currentevents-url": "Project:Kawéntenané mangkin", @@ -215,18 +242,24 @@ "helppage-top-gethelp": "Wantuan", "mainpage": "Kaca Utama", "mainpage-description": "Kaca utama", + "policy-url": "Project:Kapatutan", "portal": "Kori sekaa", "portal-url": "Project:Kori sekaa", "privacy": "Awig-awig indik data praragan", "privacypage": "Project:Awig-awig indik data praragan", + "badaccess": "Pikobet lugra", + "badaccess-group0": "Ragané nénten kadurusang antuk nglaksanayang parilaksana sakadi sané kapinta.\nAnda tidak diizinkan untuk melakukan tindakan yang Anda minta.", + "badaccess-groups": "Parilaksana sané kapinta kawatesin antuk pangangge ring tengah {{PLURAL:$2|kelompok}}: $1.", + "versionrequired": "Kaperluang MediaWiki manut $1", + "versionrequiredtext": "MediaWiki versi $1 kaperluang antuk nglaksanayang kaca puniki. Cingak [[Special:Version|kaca versi]]", "ok": "OK", "retrievedfrom": "Kapolihang saking \"$1\"", - "youhavenewmessages": "{{PLURAL:$3|Jero madué}} $1 ($2)", - "youhavenewmessagesfromusers": "{{PLURAL:$4|Ida dané madué}} $1 saking {{PLURAL:$3|$3 sang anganggé lianan}} ($2).", + "youhavenewmessages": "{{PLURAL:$3|Ragané madué}} $1 ($2)", + "youhavenewmessagesfromusers": "{{PLURAL:$4|Ragané madué}} $1 saking {{PLURAL:$3|$3 sang anganggé lianan}} ($2).", "youhavenewmessagesmanyusers": "Jero madué $1 saking akéh sang anganggé ($2).", - "newmessageslinkplural": "{{PLURAL:$1|séwalapatra anyar abesik|999=séwalapatra anyar}}", + "newmessageslinkplural": "{{PLURAL:$1|séwala anyar abesik|999=séwala anyar}}", "newmessagesdifflinkplural": "$1 {{PLURAL:$1|uahan}}", - "youhavenewmessagesmulti": "Ida dané madué séwalapatra anyar ring $1", + "youhavenewmessagesmulti": "Ragané madué séwala anyar ring $1", "editsection": "uah", "editold": "uah", "viewsourceold": "cingak wit", @@ -236,54 +269,147 @@ "toc": "Daging", "showtoc": "sinahang", "hidetoc": "engkebang", + "collapsible-collapse": "Alitin malih", "collapsible-expand": "buka", "confirmable-confirm": "{{GENDER:$1|Jero}} yakin?", "confirmable-yes": "Inggih", "confirmable-no": "Nénten", + "thisisdeleted": "Cingak utawi uliang $1?", "viewdeleted": "Cingak $1?", "restorelink": "{{PLURAL:$1|siki uahan sané kausapin|$1 uahan sané kausapin}}", "feedlinks": "Asupan:", "feed-invalid": "Tipe permintaan asupan tusing beneh.", + "feed-unavailable": "Umpan sindikasi nénten kasayagayang", + "site-rss-feed": "Umpan RSS $1", "site-atom-feed": "$1 \"atom feed\"", + "page-rss-feed": "Umpan RSS \"$1\"", "page-atom-feed": "$1 \"atom feed\"", "red-link-title": "$1 (kaca nénten wénten)", + "sort-descending": "Urutang ka betén", + "sort-ascending": "Urutang menék", "nstab-main": "Kaca", "nstab-user": "Kaca sang anganggé", + "nstab-media": "Kaca media", "nstab-special": "Kaca kusus", "nstab-project": "Kaca proyék", "nstab-image": "Depukan", - "nstab-mediawiki": "Séwalapatra", + "nstab-mediawiki": "Séwala", "nstab-template": "Cétakan", "nstab-help": "Kaca wantuan", "nstab-category": "Kategori", "mainpage-nstab": "Kaca utama", + "nosuchaction": "Nénten wénten parilaksana sakadi punika", + "nosuchactiontext": "Parilaksana sané kapinta olih URL punika nénten valid. Ragané asané iwang ngetik URL, utawi ngikutin silih tunggil pranala sané ten patut. Unduk puniki taler asané kaindikasian silih tunggil bug ring perangkat lunak sané kaanggén olih {{SITENAME}}.", "nosuchspecialpage": "Nénten wénten kaca kusus sakadi punika", "nospecialpagetext": "<strong>Ida nagih kaca pinih luwih sane nenten patut.</strong>\n\nWacakan kaca pinih luwih dados kacingak ring [[Special:SpecialPages|{{int:specialpages}}]].", "error": "Kaiwangan", "databaseerror": "Database kaluputan", - "databaseerror-query": "Kueri: $1", + "databaseerror-text": "Silih tunggil galat kueri basis data sampun kalaksanayang.\nIndik puniki asané kaindikasian wénten pikobet ring perangkat lunaknyané.", + "databaseerror-textcl": "Silih tunggil galat kueri basis data sampun kajadian.", + "databaseerror-query": "Kuéri: $1", "databaseerror-function": "Pungsi: $1", "databaseerror-error": "Pelih: $1", - "missing-article": "data utama nenten prasida nemu tulisan saking lembar sane sepatutne wenten, inggih punika $1, $2\n\nindike puniki biasane keranayang olih pranala kaon nuju pabenahan sane dumun lembar sane sampun kaicalang\n\nyening nenten puniki sane ngranayang, ida dane minab sampun manggihin kaiwangang ring sajeroning piranti lunak.\nDurus sadokang indik puniki rin silih sinunggil anak \n\n[[Special:ListUsers/sysop|Pengurus]], antuk ngetik alamat URL sane katuju", + "transaction-duration-limit-exceeded": "Mangde nénten katunda saduran sané tegeh, kiriman puniki kawangdeang mawanin galah nyurat ($1) ngliwatin wates $2 ring limit dauh.\nYéning ragané jagi nguah akéh ring galah sané masikian, ngiring laksanayang ring karya sané alitan.", + "laggedslavemode": "Pangeling: Kaca asané nénten kadagingin uahan pinih anyar.", + "readonly": "Basis data kakunci", + "enterlockreason": "Asukan napi sané ngawinan penguncian, rumasuk kirang langkung ring galah napu kunci jagi kabuka", + "readonlytext": "Basis data kantun kakunci ring masukan miwah uahan sané anyar, asané pamecikan basis data, sasampun keadaan jagi normal sakadi sadurungnyané. \n\nPrajuru sané nglaksanayang panguncian ngemaang daging sakadi punika: $1", + "missing-article": "Genah datané nénten prasida manggihin suratan saking kaca sané sapatutné kapanggihin, mamurda \"$1\" $2.\n\nIndik puniki biasané keranayang olih pranala kaon nuju pabenahan sane dumun lembar sane sampun kaicalang\n\nyening nenten puniki sane ngranayang, ida dane minab sampun manggihin kaiwangang ring sajeroning piranti lunak.\nDurus sadokang indik puniki rin silih sinunggil anak \n\n[[Special:ListUsers/sysop|Pengurus]], antuk ngetik alamat URL sane katuju", "missingarticle-rev": "(pabenahan#:$1)", + "missingarticle-diff": "(Malianan: $1, $2)", + "readonly_lag": "Basis data sampun kakunci otomatis sakantun basis data sekunder nglaksanayang sinkronisasi antuk basis data sané utama", + "nonwrite-api-promise-error": "Manggala HTTP 'Promise-Non-Write-API-Action' sampun kakirim nanging paminta kabuat mantuké modul manyurat API.", + "internalerror": "Pikobet saking tengah", + "internalerror_info": "Pikobet saking tengah: $1", + "internalerror-fatal-exception": "Sajabaning fatal ngetik \"$1\"", + "filecopyerror": "Nénten mrasidayang nyadur berkas \"$1\" ka \"$2\".", + "filerenameerror": "Nénten prasida nguah wastan berkas \"$1\" manados \"$2\".", + "filedeleteerror": "Nénten prasida ngusap berkas \"$1\".", + "directorycreateerror": "Nénten prasida ngaé direktori \"$1\".", + "directoryreadonlyerror": "Direktori \"$1\" wantah-baca.", + "directorynotreadableerror": "Direktori \"$1\" nénten prasida kabaca.", + "filenotfound": "Nénten prasida ngusap berkas \"$1\".", + "unexpected": "Nilai di sisin jangkauan: \"$1\"=\"$2\".", + "formerror": "Pikobet: Nénten prasida ngirim blanko.", + "badarticleerror": "Parilaksana puniki nénten prasida ring kaca puniki.", + "cannotdelete": "Kaca utawi berkas \"$1\" nénten prasida kausap.\nAsané sampun kausap olih jadma lianan.", + "cannotdelete-title": "Nénten prasida ngusap kaca \"$1\"", + "delete-scheduled": "Kaca $1 karencanayang mangda kausap. Mangda trepti.", + "delete-hook-aborted": "Pangusapan kawangdeang olih kait parser.\nNénten wénten panlatarang.", + "no-null-revision": "Nénten prasida makarya revisi null anyar anggén kaca \"$1\"", "badtitle": "murda sane nenten manut", "badtitletext": "Judul halaman sane katagih nenten patut, kosong, atau judul antarbahasa atau antarwiki yang salah sambung.\n\nmurda lembar sane kaarsa nenten sida kaedengang, kosong, utawi murda murda antarbasa utawi antarwiki sane iwang", + "title-invalid-empty": "Murda kaca sané kapinta nénten madaging napi-napi utawi madaging wantah wasta saking silih tunggil genah aran\nJudul halaman yang diminta kosong atau berisi hanya nama sebuah ruang nama.", + "title-invalid-utf8": "Murda kaca sané kapinta madué paiketan UTF-8 sané nénten resmi.", + "title-invalid-interwiki": "Murda madué pranala pantaraningwiki sané nénten prasida kaanggén ring murda.", + "title-invalid-talk-namespace": "Murda situs sané kapinta nuju ka kaca pablibagan sané nénten prasida kasayagayang.", + "title-invalid-characters": "Murda kaca sané kapinta madué watek sané ten resmi:\"$1\".", + "title-invalid-relative": "Murda madué alamat relatif. Murda kaca relatif (./, ../) nénten resmi, mawinan prasida ngawinan wangde ritatkala kapindatangan olih prajuru panganggé.", + "title-invalid-magic-tilde": "Murda kaca madué paiketan tilda sané nénten resmi (<nowiki>~~~</nowiki>).", + "title-invalid-too-long": "Murda kaca sané kapinta kalintang dawa. Punika patut kasimbolang sareng $1 {{PLURAL:$1|byte|bytes}} ring simbol UTF-8.", + "title-invalid-leading-colon": "Murda kaca sané kapinta kakawitin antuk tanda petik kalih sané nénten resmi.", + "perfcached": "Data sakadi puniki kaambil saking pasinggahan miwah asané nénten data sané mutakhir. {{PLURAL:$1|Hasil}} sakwéhnyané wénten ring pasinggahan.", + "perfcachedts": "Data sakadi puniki kaambil saking pasinggahan miwah pinih untat kaanyarin ring $1. {{PLURAL:$4|Hasil}} sakwéhnyané wénten ring pasinggahan.", + "querypage-no-updates": "Pamutakhiran saking kaca puniki kantun kamatiang. Data sané wénten driki mangkin nénten jagi kamuat malih.", "viewsource": "Cingak wit", "viewsource-title": "Cingak wit saking $1", - "viewsourcetext": "Jero dados nyingakin miwah nurun wit kaca puniki.", + "actionthrottled": "Parilaksana kawatesin", + "actionthrottledtext": "Ragané kawatesin antuk nglaksanayang parilaksana puniki kalintang akéh ring galah sané nampek, miwah ragané sampun ngliwatin wates sané kadurusang. Ngiring ulang malih ring akudang menit malih.", + "protectedpagetext": "Kaca puniki sampun kakunci antuk ngahalangin pauahan utawi parilaksana lianan.", + "viewsourcetext": "Ragané dados nyingakin miwah nurun wit saking kaca puniki.", + "viewyourtext": "Ragané prasida nyingakin utawi nyadur sumber saking '''uahan Ragané''' ka kaca puniki.", + "protectedinterface": "Kaca puniki ngamuat teks pantaraningrai antuk perangkat lunak ring wiki puniki, miwah kalindungin ring parilaksana sané nénten patut. Antuk nambehin utawi nguah terjemahan ring makasami wiki, mangda nganggé [https://translatewiki.net/ translatewiki.net], pakarya pelokalan MediaWiki.", + "editinginterface": "<strong>Panginget:</strong> Ragané nguah silih tunggil kaca sané kaangén nyayagayang teks pantaraningrai antuk perangkat lunak.\nUahan ring kaca puniki jagi ngawinang mal ring pantaraningrai panganggé majeng panganggé lianan ring wiki puniki.", + "translateinterface": "Antuk nambehin utawi nguah terjemahan makasami wiki, mangda anggén [https://translatewiki.net/ translatewiki.net], pakarya pelokalan MediaWiki.", + "cascadeprotected": "Kaca puniki sampun kajaga saking uwahan mawinan kasarengi ring {{PLURAL:$1|kaca|kaca-kaca}} sakadi punika sané sampun kajaga malarapan opsi \"madérét\":\n$2", + "namespaceprotected": "Ragané ten madué kawenangan ngakses antuk nguah kaca ring genah aran '''$1'''.", + "customcssprotected": "Ragané nénten madué izin antuk nguah kaca CSS puniki, mawinan madaging tatacara praragan panganggé.", + "customjsonprotected": "Ragané nénten madué izin antuk nguah kaca JSON puniki mawinan madaging tatacara praragan panganggé.", + "customjsprotected": "Ragané nénten madué izin antuk nguah kaca JavaScrip puniki, mawinan madaging tatacara praragan panganggé lianan.", + "sitecssprotected": "Ragané nénten madué izin antuk nguah kaca CSS puniki mawinan parilaksana sakadi punika asané prasida mabuat ring makasami pamiarsa.", + "sitejsonprotected": "Ragané nénten madué izin antuk nguah kaca JSON puniki mawinan parilaksana sakadi punika prasida mabuat ring makasami pamiarsa.", + "sitejsprotected": "Ragané nénten madué izin antuk nguah kaca JavaScript puniki mawinan parilaksana sakadi punika asané prasida mabuat ring makasami pamiarsa.", + "mycustomcssprotected": "Ragané nénten madué izin antuk nguah kaca CSS puniki.", + "mycustomjsonprotected": "Ragané nénten madué izin antuk nguah kaca JSON puniki.", + "mycustomjsprotected": "Ragané nénten madué izin antuk nguah kaca JavaScript puniki.", + "myprivateinfoprotected": "Ragané nénten madué izin antuk nguah informasi praragan ragané.", + "mypreferencesprotected": "Ragané nénten madué izin antuk nguah kaca JavaScript puniki.", + "ns-specialprotected": "Kaca ring genah aran {{ns:special}} nénten prasida kauah.", + "titleprotected": "Murda puniki kajaga saking pabuat saking [[User:$1|$1]].\nNapi ngawinan asapunika wantah kaicénin sakadi <em>$2</em>.", + "filereadonlyerror": "Nénten prasida memodifikasi berkas \"$1\" mawinan berkas repositori \"$2\" inggih punika mode baca-manten.\n\nPrajuru sané ngunci madué napi sané ngawinan asapunika: \"$3\".", + "invalidtitle": "Murda nénten resmi", + "invalidtitle-knownnamespace": "Murda sané nénten resmi antuk genah aran \"$2\" miwah teks \"$3\"", + "invalidtitle-unknownnamespace": "Judul sané nénten resmi antuk nomor genah aran nénten kauningin $1 miwah teks \"$2\"", + "exception-nologin": "Durung manjing log", + "exception-nologin-text": "Durusang manjing log mangda prasida ngaksés kaca utawi parilaksana puniki.", + "exception-nologin-text-manual": "Durusang $1 mangda prasida ngaksés kaca utawi parilaksa puniki.", + "virus-badscanner": "Pikobet konfigurasi: pemindai virus nénten kauningin: ''$1''", + "virus-scanfailed": "Pemindaian nénten prasida (kode $1)", + "virus-unknownscanner": "Antivirus nénten kauningin:", + "logouttext": "'''Ragané sampun medal log saking sistem.'''\n\nélingan yéning makudang-kudang kaca asané kantun nampilang ragané sakadi kantun manjing log, ngantos ragané ngicalang pasinggahan penjelajahan web Ragané.", + "logging-out-notify": "Ragané kantun medal log, antosang jebos.", + "logout-failed": "Nénten prasida medal log mangkin: $1", + "cannotlogoutnow-title": "Nénten prasida medal log mangkin", + "cannotlogoutnow-text": "Medal log nénten kadadosang ritatkala nganggén $1.", + "welcomeuser": "Rahajeng rauh, $1!", + "welcomecreation-msg": "Akun ragané sampun kakaryanin. Elingan uwah konfigurasi [[Special:Preferences|preferensi {{SITENAME}}]] ragané.", "yourname": "Peséngan sang anganggé:", "userlogin-yourname": "Peséngan sang anganggé", - "userlogin-yourname-ph": "Dagingin peséngan sang anganggé jero", + "userlogin-yourname-ph": "Dagingin peséngan sang anganggé ragané", + "createacct-another-username-ph": "Dagingin peséngan sang anganggé", "yourpassword": "Kruna sandi:", "userlogin-yourpassword": "Kruna sandi", - "userlogin-yourpassword-ph": "Dagingin kruna sandi jero", + "userlogin-yourpassword-ph": "Dagingin kruna sandi ragané", "createacct-yourpassword-ph": "Dagingin kruna sandi", "yourpasswordagain": "jumunin kruna sandi", - "createacct-yourpasswordagain": "Mastiang kruna kunci", + "createacct-yourpasswordagain": "Pastiang kruna sandi", "createacct-yourpasswordagain-ph": "Dagingin malih kruna sandi", "userlogin-remembermypassword": "Banggayang mangda tetep ngranjing", "cannotlogin-title": "Nénten prasida manjing log", + "cannotlogin-text": "Nénten prasida manjing log.", "cannotloginnow-title": "Mangkin nénten prasida manjing log", + "cannotloginnow-text": "Nénten prasida manjing log yéning nganggé $1.", + "cannotcreateaccount-title": "Nénten prasida ngardi akun", "login": "Manjing log", "nav-login-createaccount": "Manjing log / karyanin akun", "logout": "Medal log", @@ -291,95 +417,117 @@ "notloggedin": "Durung manjing log", "userlogin-noaccount": "Durung madué akun?", "userlogin-joinproject": "Nyarengin {{SITENAME}}", - "createaccount": "Karyanin akun", - "userlogin-resetpassword-link": "Engsap ring kruna kunci?", + "createaccount": "Kardi akun", + "userlogin-resetpassword-link": "Lali ring kruna sandi ragané?", "userlogin-helplink2": "Wantuan indik manjing log", - "createacct-emailoptional": "Alamat email (becikang kadagingin)", - "createacct-email-ph": "Dagingin alamat email jero", - "createacct-submit": "Karyanin akun jero", - "createacct-benefit-heading": "{{SITENAME}} kakaryanin olih anak sakadi jero.", + "userlogin-createanother": "Kardi akun lianan", + "createacct-emailrequired": "Alamat séwala éléktronik", + "createacct-emailoptional": "Alamat séwala éléktronik (opsional)", + "createacct-email-ph": "Dagingin alamat séwala éléktronik ragané", + "createacct-another-email-ph": "Dagingin alamat séwala éléktronik", + "createacct-submit": "Kardi akun ragané", + "createacct-another-submit": "Kardi akun", + "createacct-continue-submit": "Lanturang ngardi akun", + "createacct-another-continue-submit": "Lanturang ngardi akun", + "createacct-benefit-heading": "{{SITENAME}} kakaryanin antuk anak sakadi ragané.", "createacct-benefit-body1": "{{PLURAL:$1|uahan}}", "createacct-benefit-body2": "{{PLURAL:$1|kaca}}", "createacct-benefit-body3": "{{PLURAL:$1|sang anuut}} sané mangkin", + "loginerror": "Pikobet manjing log", + "createacct-error": "Pikobet ngardi akun", + "createaccounterror": "Nénten prasida ngardi akun: $1", + "loginsuccesstitle": "Sampun manjing log", + "loginsuccess": "<strong>Ragané sané mangkin sampun manjing log {{SITENAME}} pinaka \"$1\".</strong>", "mailmypassword": "nyumu ngaryanin kruna sandi", + "accountcreated": "Akun sampun kakardi", + "accountcreatedtext": "Akun sang anganggé [[{{ns:User}}:$1|$1]] ([[{{ns:User talk}}:$1|pabligbagan]]) sampun kakardi.", "loginlanguagelabel": "Basa: $1", "pt-login": "Manjing log", "pt-login-button": "Manjing log", - "pt-createaccount": "Ngaryanin akun", + "pt-login-continue-button": "Lanturang manjing log.", + "pt-createaccount": "Kardi akun", "pt-userlogout": "Medal log", + "changepassword": "Uah kruna sandi", + "changepassword-success": "Kruna sandi ragané sampun kauah!", + "botpasswords": "Kruna sandi bot", + "botpasswords-createnew": "Kardi kruna sandi bot anyar", + "botpasswords-label-needsreset": "(perlu nyumu ngardi kruna sandi)", "botpasswords-label-create": "Ngae", "botpasswords-label-cancel": "Wangdé", "botpasswords-label-delete": "Usap", - "botpasswords-label-resetpassword": "Nyumu kruna sandi", + "botpasswords-label-resetpassword": "Nyumu ngardi kruna sandi", + "botpasswords-created-title": "Kruna sandi bot kakardi", + "resetpass_forbidden-reason": "Kruna sandi nénten prasida kauahin: $1", + "resetpass-submit-loggedin": "Uah kruna sandi", "resetpass-submit-cancel": "Wangdé", - "passwordreset": "Nyumu kruna sandi", - "bold_sample": "teks puniki mesurat tebel", - "bold_tip": "teks puniki mesurat tebel", - "italic_sample": "teks puniki masurat sendeh", - "italic_tip": "teks puniki masurat sendeh", - "link_sample": "murda pranala", - "link_tip": "pranala tengah", - "extlink_sample": "http://www.example.com murda pranala", - "extlink_tip": "pranala sisi (sampunang lali kakawitin http://)", - "headline_sample": "teks murda", - "headline_tip": "subgolongan undag 2", - "nowiki_sample": "lebuang teks sane nenten jagi keformat ring driki", - "nowiki_tip": "campahang format wiki", - "image_tip": "cantumin pupulan", - "media_tip": "Pranala depukan", - "sig_tip": "tanda tangan ida dane sareng tanda waktu", - "hr_tip": "garis horizontal", + "passwordreset": "Jumunin ngardi kruna sandi", + "changeemail-password": "Kruna sandi {{SITENAME}} ragané:", "summary": "Ringkesan:", "minoredit": "Puniki uahan alit", - "watchthis": "tinjo lembar puniki", + "watchthis": "Awasin kaca puniki", "savearticle": "Raksa kaca", - "publishpage": "Terbitang kaca", + "savechanges": "Raksa uahan", + "publishpage": "Wedar kaca", + "publishchanges": "Wedar uahan", "savearticle-start": "Raksa kaca...", - "publishpage-start": "Terbitang kaca…", - "preview": "tayangan sadurungnyane", - "showpreview": "Sinahang preview", + "savechanges-start": "Raksa uahan...", + "publishpage-start": "Wedar kaca…", + "publishchanges-start": "Wedar uahan...", + "preview": "Pracingak", + "showpreview": "Édéngang pracingak", "showdiff": "Cingak uahan", "anoneditwarning": "<strong>Pingetan:</strong> Ida dané nénten kacatet ngranjing. Alamat IP ida dané jagi kacatet ring sejarah (indik sané dumunan) ring lembar puniki. Yening ida dane <strong>[$1 log in]</strong> utawi <strong>[$2 create an account]</strong>, your edits will be attributed to your username, along with other benefits.", + "summary-preview": "Pracingak saking ringkesan uahan:", + "blockedtext": "<strong>Peséngan penganggé utawi genah IP ragané kablokir .</strong>\n\nBlokir puniki kalaksanayang olih $1.\nKablokir krana <em>$2</em>.\n\n* Kablokir saking: $8\n* Blokir kadaluwarsa ring: $6\n* Tetujon ngablokir: $7\n\nRagané dados ngubungin $1 utawi [[{{MediaWiki:Grouppage-sysop}}|prajuru]] antuk mabligbagin.\nRagané nénten dados nganggén fitur puniki \"{{int:emailuser}}\" sajabaning ragané sampun ngranjingang email sané patut ring [[Special:Preferences|pustaka]] tur ragané nénten kablokir antuk nganggén\nGenah IP ragané sané pinih anyar inggih punika $3, tur ID pamblokiran inggih punika #$5.\nTulung genahang silih sinunggil utawi kalih pidarta ring pitakén sané kakaryanin.", "loginreqlink": "manjing log", + "accmailtitle": "Kruna sandi kakirim", "newarticle": "(Anyar)", "newarticletext": "ida dane ngiring pranala nuju lembar sane durung wenten. yening jagi ngaryanang lembar punika, ketik daging lembar ring kotak sane wenten ring beten puniki. (cingak [$1 lembar wantuan] anggen wacana salanturnyane). yening ida dane nenten nyelapang neked ring lembar puniki, klik tombol \"back\" ring \"penjelajah web\" ida dane.", - "noarticletext": "mangkin nenten wenten teks ring lembar puniki. ida dane prasida [[Special:Search/{{PAGENAME}}|ngrereh murda nganggen lembar puniki]] ring lembar-lembar sane lianan, <span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} ngrereh log sane mapaiketan], utawi [{{fullurl:{{FULLPAGENAME}}|action=edit}} nguwah lembar puniki]</span>.", - "noarticletext-nopermission": "mangkin nenten wenten teks ring lembar puniki. ida dane prasida [[Special:Search/{{PAGENAME}}|ngarereh murda anggen lembar puniki]] ring lembar-lembar sane lianan, <span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} ngarereh log sane mapaiketan], utawi [{{fullurl:{{FULLPAGENAME}}|action=edit}} ngubah lembar puniki]</span>.", + "anontalkpagetext": "<em>Niki inggih punika kaca pabligbagan sang penganggé sané nénten nguningayang wasta utawi nénten nganggén wasta.</em> Nika mawinan penganggé punika patut nganggén genah IP sané mawentuk angka antuk manyihnayang.\nGenah IP punika prasida kaanggén sareng-sareng olih makudang-kudang panganggé sané lianan. \nYéning Ragané sang penganggé sané nénten mawasta tur marasa ngamolihang pidarta sané nénten patut, ngiring \n[[Special:CreateAccount|ngaryanin akun]] utawi [[Special:UserLogin|sang penganggé ngranjing log]] antuk ngelidin kabingungan saking sang penganggé sané lianan ring galah sané lianan.", + "noarticletext": "Mangkin nénten wénten suratan ring kaca puniki.\nRagané prasida [[Special:Search/{{PAGENAME}}|ngrereh murda kaca puniki]] ring kaca lianan,\n<span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} ngrereh log sané mapaiketan],\nutawi [{{fullurl:{{FULLPAGENAME}}|action=edit}} ngardi kaca puniki]</span>.", + "noarticletext-nopermission": "Mangkin nénten wénten suratan ring kaca puniki.\nRagané prasida [[Special:Search/{{PAGENAME}}|ngrereh murda kaca puniki]] ring kaca lianan,\n<span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} ngrereh log sané mapaiketan]</span>, nanging ragané tan kalugra ngardi kaca puniki.", "userpage-userdoesnotexist-view": "Akun sang anganggé \"$1\" nénten madaptar.", - "previewnote": "\"elingang yening puniki wantah sane lintang.\" Panguwahan ida dane durung kasimpen!", - "continue-editing": "Magingsir ka genah ngauwah", + "clearyourcache": "<strong>Catetan:</strong>Sesampun karaksayang, Ragané patut ngentasin tembolok peramban wéb antuk nyingakin uahan.\n* <strong>Firefox/Safari:</strong> Tahan <em>Shift</em> ritatkala ngaklik <em>Reload</em>, utawi teken <em>Ctrl-F5</em> utawi <em>Ctrl-R</em> (<em>⌘-R</em> ring Mac)\n* <strong>Google Chrome:</strong> Teken <em>Ctrl-Shift-R</em> (<em>⌘-Shift-R</em> ring Mac)\n* <strong>Internet Explorer:</strong> Teken <em>Ctrl</em> ritatkala ngaklik <em>Refresh</em>, utawi teken <em>Ctrl-F5</em>\n* <strong>Opera:</strong> Ngranjing ka <em>Ménu → Pengaturan </em> (<em>Opera → Pustaka</em> ring Mac) Salanturnyané ka <em>Privacy & security → Clear browsing data → Cached images and files</em>.", + "previewnote": "<strong>Éling yéning puniki wantah pracingak.</strong>\nUahan ragané durung karaksa!", + "continue-editing": "Magingsir ka genah panguah", "editing": "Nguahin $1", "creating": "Makarya $1", "editingsection": "Nguahin $1 (pahan)", "editingcomment": "Nguahin $1 (pahan anyar)", + "yourtext": "Suratan ragané", + "yourdiff": "Bina", "templatesused": "{{PLURAL:$1|Citakan}} sané kaanggén ring kaca puniki:", + "templatesusedpreview": "{{PLURAL:$1|Citakan}} sané kaanggén ring pracingak puniki:", "template-protected": "(kasaibin)", "template-semiprotected": "(semi-kasaibin)", "hiddencategories": "lembar niki inggih punika krama saking {{PLURAL:$1|1 golongan sane mengkeb|$1 golongan sane mengkeb}}", - "permissionserrors": "Kaiwangan ritatkala ngranjing", - "permissionserrorstext-withaction": "ida dané nénten madué kuasa ngranjing anggén $2, riantukan {{PLURAL:$1|alasan}} ring sor puniki:", + "permissionserrors": "Pikobet lugra", + "permissionserrorstext-withaction": "Ragané tan kalugra $2, antukan {{PLURAL:$1|larapan}} ring sor puniki:", "recreate-moveddeleted-warn": "\"pingetan\" ida dane ngawe malih lembar sane naenin maapus.'''\n\nmangda kayunin malih napike pantes lanturang suntingan ida dane. puniki log pengapusan lan pangisidan saking lembar puniki:", "moveddeleted-notice": "Kaca puniki sampun kausapin.\nAnggen pewarah, proteksi, lan pengisidan log saking lembar puniki cingakin pustaka beten.", "postedit-confirmation-created": "Kacanyané sampun kakaryanin.", "postedit-confirmation-saved": "Uahan jero sampun maraksa.", + "postedit-confirmation-published": "Uahan ragané sampun kawedar.", "content-model-wikitext": "sesuratan wiki", "post-expand-template-inclusion-warning": "pinget: ukuran templat sane keanggen kalangkung ageng. wenten templat sane kacampahang", "post-expand-template-inclusion-category": "lembar sane maukuran templat sane nglangkungin wates", "post-expand-template-argument-warning": "\"peminget\" lembar puniki madaging kiranglangkungnyane siki argumen templat anggen ukuran ekspansi sane kaliwat ageng. argumen-argumen punika sampun kacampahang.", "post-expand-template-argument-category": "lembar sane medaging argumen templat sane kacampahang", + "undo-failure": "Uwahan puniki nénten prasida kabalikang krana wénten konflik panguwahan antara.", "viewpagelogs": "Cingak log saking kaca puniki", - "currentrev-asof": "pabecikan sane anyar ring pinanggal$1", + "nohistory": "Nénten wénten babad uahan ring kaca puniki.", + "currentrev-asof": "Révisi sané pinih anyar ring $1", "revisionasof": "Uahan ri tatkala $1", - "revision-info": "Panguwahan per $1 olih {{GENDER:$6|$2}}$7", + "revision-info": "Révisi ri tatkala $1 antuk {{GENDER:$6|$2}}$7", "previousrevision": "← Uahan sadurungnyané", "nextrevision": "Uahan salanturnyané →", "currentrevisionlink": "Uahan sané mangkin", "cur": "mgkn", "last": "sdrg", "histlegend": "pilih kalih tombol radio lantur pecik tombol \"bandingang\" anggen ngebandingang indik lianan. klik siki tanggal anggen nyingak indik lianan lembar ring pinanggal punika.<br />(skr)= binanne saking indik lianan sane mangkin, (untat) = binanne saking indik lianan sane dumunan, '''k''' = panguwahan alit, '''b''' = panguwahan bot, → = panguwahan kepahan, ← = reringkesan otomatis", - "history-fieldset-title": "Nyaringin révisi", + "history-fieldset-title": "Saring révisi", "history-show-deleted": "wantah sane kaapus", - "histfirst": "pinih suwe", + "histfirst": "pinih sué", "histlast": "pinih anyar", "history-feed-title": "Babad uahan", "history-feed-description": "Babad uahan kaca puniki ring wiki", @@ -394,45 +542,46 @@ "mergelog": "Gabung log", "revertmerge": "tansida nyarengin", "history-title": "Babad uahan saking \"$1\"", - "difference-title": "$1: sane malianan ring revisi", + "difference-title": "Bina pantaraning révisi \"$1\"", "lineno": "Carik $1:", "compareselectedversions": "bandingang penguwahan sane kapilih", - "editundo": "nguliang", - "diff-empty": "(Nénten wénten sané malianan)", + "editundo": "ulihang", + "diff-empty": "(Nénten mabina)", "diff-multi-sameuser": "({{PLURAL:$1|$1 revisi pantaraning}} olih pangawi sane pateh nenten kacumawisang)", "diff-multi-otherusers": "({{PLURAL:$1|Siki pamecikan pantaraning|$1 pamecikan pantaraning}} olih {{PLURAL:$2|siki pangangge lianan|$2 panggange}} nenten katampilan)", - "searchresults": "asil pangrereh", - "searchresults-title": "Asil pangrereh anggén \"$1\"", + "searchresults": "Asil pangrereh", + "searchresults-title": "Asil pangrereh indik \"$1\"", "prevn": "{{PLURAL:$1|$1}} sadurungnyané", "nextn": "{{PLURAL:$1|$1}} salanturnyané", "prev-page": "kaca sadurungnyané", - "prevn-title": "$1 {{PLURAL:$1|asil}} sadurunge", - "nextn-title": "$1 {{PLURAL:$1|asil}} selanturnyane", + "prevn-title": "$1 {{PLURAL:$1|asil}} sadurungnyané", + "nextn-title": "$1 {{PLURAL:$1|asil}} salanturnyané", "shown-title": "Sinahang $1 {{PLURAL:$1|asil}} per kaca", "viewprevnext": "Cingak ($1 {{int:pipe-separator}}$2)($3)", "searchmenu-exists": "wenten lembar sane mamurda \"[[:$1]]\" ring wiki puniki. {{PLURAL:$2|0=| cingakin taler asil rerehan lianan sane kapolihang}}", - "searchmenu-new": "<strong> ngawi lembar \"[[:$1]] ring wiki puniki </ strong>! {{{{PLURAL:$2|}}| 0 = | cingak teler lembar sane kapolihang ring pangreregan | cingak taler asil pangrerehan sane kapolihang}}", + "searchmenu-new": "<strong>Kardi kaca \"[[:$1]]\" ring wiki puniki!</strong> {{PLURAL:$2|0=|Taler cingak kaca sané temunin ragané.|Taler cingak asil pangrereh.}}", "searchprofile-articles": "Kaca daging", - "searchprofile-images": "multimedia", + "searchprofile-images": "Multimédia", "searchprofile-everything": "Samian", - "searchprofile-advanced": "lanturane", + "searchprofile-advanced": "Lanturan", "searchprofile-articles-tooltip": "Rereh ring $1", "searchprofile-images-tooltip": "Rereh depukan", - "searchprofile-everything-tooltip": "pangrereh ring samian isi (taler lembar wecana)", - "searchprofile-advanced-tooltip": "Rereh ring genah wastan sané kapilih", + "searchprofile-everything-tooltip": "Rereh ring samian daging (rumasuk kaca pabligbagan)", + "searchprofile-advanced-tooltip": "Rereh ring genah aran sané kapilih", "search-result-size": "$1 ({{PLURAL:$2|1 kruna|$2 kruna}})", "search-result-category-size": "{{PLURAL:$1|1 krama|$1 krama}}({{PLURAL:$2|1 subgolongan|$2 subgolongan}}, {{PLURAL:$3|1 pupulan|$3 pupulan}})", "search-redirect": "(gingsiran saking $1)", "search-section": "(pahan $1)", "search-file-match": "(anut ring daging depukan)", - "search-suggest": "minab sane kearsaang $1", + "search-suggest": "Minab sané aptiang ragané: $1", "searchrelated": "paiketan", "searchall": "samian", - "search-showingresults": "{{PLURAL:$4|Asil <strong>$1</strong> of <strong>$3</strong>|Asil-asil <strong>$1 – $2</strong> saking <strong>$3</strong>}}", - "search-nonefound": "nenten wenten asil sane caklek ring arsa", + "search-showingresults": "{{PLURAL:$4|Asil <strong>$1</strong> saking <strong>$3</strong>|Asil <strong>$1 – $2</strong> saking <strong>$3</strong>}}", + "search-nonefound": "Nénten wénten asil sané cocok sareng kuéri.", "powersearch-ns": "Rereh ring genah wastan:", - "mypreferences": "Preferensi", + "mypreferences": "Préferénsi", "prefs-user-pages": "Kaca sang anganggé", + "prefs-resetpass": "Uah kruna sandi", "saveprefs": "Raksa", "prefs-editing": "Nguahin", "prefs-namespaces": "Genah wastan", @@ -447,20 +596,27 @@ "grouppage-bot": "{{ns:project}}:Bot", "grouppage-sysop": "{{ns:project}}:Prajuru", "right-edit": "Uah kaca", - "right-writeapi": "nganggén API sasuratan", + "right-writeapi": "Anggé API sasuratan", "right-delete": "Usap kaca", "right-editprotected": "Uah kaca sané kasaibin \"{{int:protect-level-sysop}}\"", "grant-createeditmovepage": "Karyanin, uah, miwah gingsirang kaca", "grant-editprotected": "Uah kaca sané kasaibin", + "grant-rollback": "Waliang uahan ring kaca", "newuserlogpage": "Log makarya sang anganggé", + "rightslog": "Log panguwahan hak ngaksés", "action-read": "wacén kaca puniki", - "action-edit": "uah kaca puniki", - "action-createpage": "karyanin kaca puniki", - "action-createaccount": "karyanin akun sang anganggé puniki", + "action-edit": "nguah kaca puniki", + "action-createpage": "ngardi kaca puniki", + "action-createaccount": "kardi akun sang anganggé puniki", + "action-history": "cingak babad kaca puniki", + "action-move": "ngingsirang kaca puniki", "action-delete": "usap kaca puniki", "action-deletedhistory": "cingak babad kaca sané kausapin", "action-browsearchive": "rereh kaca sané kausapin", - "action-editprotected": "uah kaca sané kasaibin \"{{int:protect-level-sysop}}\"", + "action-rollback": "ngwaliang kanti gelis uahan saking sang anganggé pinih untat sané nguah sinalih tunggil kaca", + "action-autopatrol": "nyihnain uahan ragané yéning sampun kapratroli", + "action-sendemail": "ngirim séwala éléktronik", + "action-editprotected": "nguah kaca sané kasaibin \"{{int:protect-level-sysop}}\"", "action-editsemiprotected": "uah kaca sané kasaibin \"{{int:protect-level-autoconfirmed}}\"", "nchanges": "$1 {{PLURAL:$1|uahan}}", "enhancedrc-history": "babad", @@ -469,12 +625,12 @@ "recentchanges-summary": "Track uahan sané mangkin ring wikiné indik kaca puniki.", "recentchanges-noresult": "Nénten wénten uahan ring galahnyané puniki sané anut sareng praciri puniki.", "recentchanges-feed-description": "molihang pagentosan anyar ring wiki ring \"umpan\" puniki", - "recentchanges-label-newpage": "Uahan puniki makarya kaca anyar", + "recentchanges-label-newpage": "Uahan puniki ngardi kaca anyar", "recentchanges-label-minor": "Punika uahan alit", "recentchanges-label-bot": "Uahan puniki kalaksanayang antuk bot", "recentchanges-label-unpatrolled": "Uahan puniki durung kapatroli", "recentchanges-label-plusminus": "Agengnyané kacané kauahin antuk akéhnyané bita puniki", - "recentchanges-legend-heading": "<strong>Legenda:</strong>", + "recentchanges-legend-heading": "<strong>Legénda:</strong>", "recentchanges-legend-newpage": "{{int:recentchanges-label-newpage}} (taler cingak [[Special:NewPages|bacakan kaca anyar]])", "recentchanges-submit": "Sinahang", "rcfilters-activefilters-show": "Sinahang", @@ -484,7 +640,7 @@ "rcfilters-filter-major-label": "Uahan tan alit", "rcfilters-filter-pageedits-label": "Uahan kaca", "rcnotefrom": "Ring beten puniki inggih punika {{PLURAL:$5|panguwahan}} saking <strong>$3, $4</strong> (kaedengang ngantos <strong>$1</strong> panguwahan).", - "rclistfrom": "edengang penguwahan sane anyar wit saking $3 $2", + "rclistfrom": "Édéngang uahan anyar saking $2, $3", "rcshowhideminor": "$1 uahan alit", "rcshowhideminor-show": "Sinahang", "rcshowhideminor-hide": "Engkebang", @@ -503,7 +659,7 @@ "rcshowhidemine-show": "Sinahang", "rcshowhidemine-hide": "Engkebang", "rcshowhidecategorization-show": "Sinahang", - "rclinks": "Edengang untat $1 gentosan anyar $2 dina kaping untat", + "rclinks": "Sinahang $1 uahan sané untat ring $2 dina sané lintang", "diff": "bina", "hist": "bbd", "hide": "Engkebang", @@ -512,14 +668,14 @@ "newpageletter": "A", "boteditletter": "b", "rc-change-size-new": "$1 {{PLURAL:$1|bita}} sasampun kauah", - "rc-enhanced-expand": "edengang rerincian", - "rc-enhanced-hide": "engkebang rerincian", - "rc-old-title": "witnyané kakaryanin pinaka \"$1\"", + "rc-enhanced-expand": "Sinahang rerincian", + "rc-enhanced-hide": "Engkebang rerincian", + "rc-old-title": "witnyané kakardi pinaka \"$1\"", "recentchangeslinked": "Uahan mapaiketan", "recentchangeslinked-toolbox": "Uahan mapaiketan", "recentchangeslinked-title": "Uahan sané mapaiketan $1", - "recentchangeslinked-summary": "lembar kautamayang puniki ngicenin kepahan penguwahan kaping untat ring lembar-lembar sana mapaiket. Lembar sane [[Special:Watchlist|ida dane iwasin]] mapinget antuk sesuratan tebel", - "recentchangeslinked-page": "Peséngan kaca:", + "recentchangeslinked-summary": "Dagingin aran kaca antuk nyingakin uahan ring kaca-kaca sané kasambung kaca punika. (Antuk nyingakin kapahan kategori, dagingin {{ns:category}}:Aran kategori). Uahan kaca-kaca ring [[Special:Watchlist|Pangawasan ragané]] kasurat <strong>tebel</strong>.", + "recentchangeslinked-page": "Aran kaca:", "recentchangeslinked-to": "Sinahang uahan saking kaca-kaca sané linked kaca puniki", "upload": "Unggahang depukan", "uploadlogpage": "Log unggahan", @@ -528,6 +684,7 @@ "upload-dialog-button-cancel": "Wangdé", "upload-dialog-button-save": "Raksa", "backend-fail-delete": "Tan prasida ngusapin berkas \"$1\".", + "uploadstash-summary": "Kaca puniki nyayagayang aksés ring berkas sané sampun kaunggah utawi sané jagi kaunggah, nanging durung kawedar ring wikiné. Berkas-berkas punika nénten sinah ring samian anak sajabaning anak sané ngunggahang.", "license": "kepahan lugra", "license-header": "Lisénsi", "listfiles-delete": "usap", @@ -535,25 +692,26 @@ "listfiles": "Bacakan depukan", "file-anchor-link": "Depukan", "filehist": "Babad berkas", - "filehist-help": "klik ring pinanggal/galah anggen nyingakin pupulan niki rikala punika", + "filehist-help": "Klik ring tanggal/galah anggén nyingakin berkas puniki ri tatkala galah punika.", "filehist-deleteall": "usap samian", - "filehist-revert": "buwungang", - "filehist-current": "sané mangkin", + "filehist-revert": "wangdéang", + "filehist-current": "mangkin", "filehist-datetime": "Tanggal/Galah", "filehist-thumb": "Miniatur", "filehist-thumbtext": "miniatur anggen versi ring $1", "filehist-nothumb": "Tusing ade miniatur", "filehist-user": "Sang anganggé", - "filehist-dimensions": "ukuran", - "filehist-comment": "tureksa", + "filehist-dimensions": "Diménsi", + "filehist-comment": "Pasaur", "imagelinks": "Panganggén depukan", "linkstoimage": "{{PLURAL:$1|Kaca|$1 kaca}} ring sor puniki nganggén depukan puniki:", + "linkstoimage-more": "Langkungan saking $1 {{PLURAL:$1|kaca|kaca-kaca}} nganggén berkas puniki.\nPupulan puniki nyinahang {{PLURAL:$1|kaca kapertama nganggén pranala langsung|$1 kaca sané nganggén pranala langsung}} ka berkasé puniki\nA [[Special:WhatLinksHere/$2|pupulan sané jangkep]] taler kasayagayang.", "nolinkstoimage": "Nénten wénten kaca sané nganggén berkas puniki.", "linkstoimage-redirect": "$1 (gingsiran berkas) $2", "sharedupload-desc-here": "Depukan puniki mawit saking $1 lan minab kaanggén olih proyék-proyék sané lianan. Déskripsinnyané ring [$2 kaca déskripsi depukannyané] kaarahin ring ungkur puniki.", - "filepage-nofile": "Nentén wénten berkas sané mamurda sakadi punika", + "filepage-nofile": "Nentén wénten berkas sané maaran sakadi punika.", "shared-repo-name-wikimediacommons": "Wikimedia Commons", - "upload-disallowed-here": "Jero nénten dados numpuk depukan puniki.", + "upload-disallowed-here": "Ragané nénten dados numpuk depukan puniki.", "filedelete": "Usap $1", "filedelete-submit": "Usap", "filedelete-success": "<strong>$1</strong> sampun kausapin.", @@ -586,35 +744,39 @@ "booksources-search-legend": "Rereh wit buku", "booksources-search": "Rereh", "specialloguserlabel": "Panggange", + "speciallogtitlelabel": "Tetujon (Murda utawi {{ns:user}}:sang panganggé antuk penganggé)", "log": "Log", "logeventslist-submit": "Sinahang", "all-logs-page": "Makasami log publik", + "alllogstext": "Pupulan tampilan log makasami sané kasayagayang ring {{SITENAME}}.\nRagané dados ngalaksanayang watesan tampilan nganggén ngamilih soroh log, sang anganggé (sénsitif kapitalisasi), utawi murdan kaca (taler sénsitif kapitalisasi).", "logempty": "Nenten katemonin entri log sane patut", "allpages": "Makasami kaca", "allarticles": "Makasami kaca", "allinnamespace": "Makasami kaca (genah wastan $1)", "allpagessubmit": "Lanturang", "allpages-bad-ns": "{{SITENAME}} nénten madué genah wastan \"$1\".", - "allpages-hide-redirects": "Ngengkebang pagingsirian", - "categories": "Golongan", + "allpages-hide-redirects": "Engkebang kaca gingsirian", + "categories": "Kategori", "categories-submit": "Sinahang", "deletedcontributions": "Pituut sang anganggé sané kausapin", "linksearch-ns": "Genah wastan:", "linksearch-line": "$1 masambung saking $2", "listusers-submit": "Sinahang", - "listgrouprights-members": "kepahan krama", - "emailuser": "email sane nganggo niki", - "emailmessage": "Séwalapatra:", - "usermessage-editor": "Séwalapatra sistem", - "watchlist": "kepahan peninjoan", - "mywatchlist": "kepahan peninjoan", + "listgrouprights-members": "(bacakan krama)", + "emailuser": "Kirim séwala éléktronik ring sang anganggé puniki", + "emailmessage": "Séwala:", + "usermessage-editor": "Séwala sistem", + "watchlist": "Pangawasan", + "mywatchlist": "Pangawasan", "watchlistfor2": "Anggén $1 $2", - "watch": "cingak", + "watch": "Awasin", "unwatch": "tan sida maninjo", - "watchlist-details": "{{PLURAL:$1|$1 kaca}} wénten ring bacakan pantauan ida dané (rumasuk kaca pabligbagan).", + "watchlist-details": "{{PLURAL:$1|$1 kaca}} wénten ring Pangawasan ragané (rumasuk kaca pabligbagan).", + "wlheader-showupdated": "Kaca-kaca puniki sampun kauwah saking kunjungan ragané sané pinih untat, kasinahang sareng <strong>tebel</strong>.", + "wlnote": "Ring sor puniki {{PLURAL:$1|uahan sané pinih untat| <strong>$1</strong> uahan}} pinih untat {{PLURAL:$2|jam|<strong>$2</strong> jam}},ngantos $3, $4.", "watchlist-submit": "Sinahang", "wlshowhideminor": "uahan alit", - "watchlist-options": "milih kepahan peninjo", + "watchlist-options": "Opsi pangawasan", "enotif_reset": "Cihnayang makasami kaca sané sampun karauhin", "enotif_subject_deleted": "Kaca {{SITENAME}} $1 sampun {{GENDER:$2|kausap}} $2", "enotif_body_intro_deleted": "Kaca{{SITENAME}} $1 sampun {{GENDER:$2|kausapin}} ring $PAGEEDITDATE olih $2, cingak $3.", @@ -623,107 +785,113 @@ "historyaction-submit": "Sinahang uahan", "actioncomplete": "pelaksanan sampun wusan", "actionfailed": "pelaksana luput", - "dellogpage": "log pangapus", + "dellogpage": "Log pangusap", + "rollback-confirmation-yes": "Waliang", "rollback-confirmation-no": "Wangdé", - "rollbacklink": "mabalik", - "rollbacklinkcount": "balikang $1 {{PLURAL:$1|suratan}}", + "rollbacklink": "waliang", + "rollbacklinkcount": "waliang $1 {{PLURAL:$1|uahan}}", "changecontentmodel-title-label": "Murda kaca", "protectlogpage": "Log saiban", "protectedarticle": "nyaib \"[[$1]]\"", + "modifiedarticleprotection": "nguwah tingkatan panyambi antuk \"[[$1]]\"", "protect-default": "Lugra makasami sang anganggé", + "protect-level-sysop": "Wantah prajuru sané kalugra", "restriction-edit": "Uah", "restriction-move": "Gingsirang", "undelete": "Cingak kaca sané kausapin", "undeleterevisions": "$1 {{PLURAL:$1|uahan}} kausapin", - "undeletelink": "cingak/uliang", + "undeletelink": "cingak/waliang", "undeleteviewlink": "cingak", "undelete-search-title": "Rereh kaca sané kausapin", - "namespace": "Genah wastan:", - "invert": "uliang pilihan", - "tooltip-invert": "Centang kotak puniki mangdané ngengkebang lembar sané kauwah ring genah wastan sané kapilih (miwah genah wastan sané mapaiketan yéning kacentang)", - "namespace_association": "Genah wasta sané mapaiketan", - "tooltip-namespace_association": "Céntang kotak puniki anggén nagingin genah wasta pabligbagan utawi subjék sané mapaiketan sareng genah wasta sané kapilih", + "namespace": "Genah aran:", + "invert": "Waliang pilihan", + "tooltip-invert": "Céntang kotak puniki mangda ngengkebang uahan kaca ring genah aran sané kapilih (miwah genah aran sané mapaiketan yéning kacéntang)", + "namespace_association": "Genah aran sané mapaiketan", + "tooltip-namespace_association": "Céntang kotak puniki mangda marengang genah aran pabligbagan utawi subyék sané mapaiketan genah aran sané kapilih", "blanknamespace": "(Utama)", "contributions": "Pituut {{GENDER:$1|sang anganggé}}", "contributions-title": "Pituut sang anganggé $1", "mycontris": "Pituut", "anoncontribs": "Pituut", - "contribsub2": "antuk {{GENDER:$3|$1}} ($2)", + "contribsub2": "Antuk {{GENDER:$3|$1}} ($2)", + "nocontribs": "Nénten wénten uwahan sané patut sareng cihna punika.", "uctop": "sane mangkin", "month": "Saking sasih (miwah sadurungnyané)", "year": "Saking warsa (miwah sadurungnyané):", - "sp-contributions-blocklog": "log pemblokiran", + "sp-contributions-blocklog": "log pangempet", "sp-contributions-deleted": "pituut {{GENDER:$1|sang anganggé}} sané kausapin", "sp-contributions-uploads": "unggahan", "sp-contributions-logs": "log", "sp-contributions-talk": "pabligbagan", "sp-contributions-search": "Rereh pituut", "sp-contributions-username": "Alamat IP wiadin peséngan sang anganggé:", - "sp-contributions-toponly": "tampilang wantah panguwahan sane anyar", - "sp-contributions-newonly": "Tampilang wantah panguwahan sane anyar", + "sp-contributions-toponly": "Wantah édéngang uahan sané pinih anyar", + "sp-contributions-newonly": "Wantah édéngang uahan sané ngardi kaca", "sp-contributions-submit": "Rereh", "whatlinkshere": "Pranala iriki", - "whatlinkshere-title": "lembar-lembar sane maduwe pranala kaping \"$1\"", + "whatlinkshere-title": "Kaca sané kasambung ring \"$1\"", "whatlinkshere-page": "Kaca:", - "linkshere": "lembar puniki maduwe pranala ke '''$2'''", + "linkshere": "Kaca-kaca ring sor puniki kasambung ring <strong>$2</strong>:", "nolinkshere": "Nénten wénten kaca sané madué pranala ring <strong>$2</strong>.", "isredirect": "Kaca gingsiran", "istemplate": "sareng kasurat", - "isimage": "pranala pupulan-pupulan", - "whatlinkshere-prev": "{{PLURAL:$1|sadurungnyane|$1 sadurungnyane}}", - "whatlinkshere-next": "{{PLURAL:$1|selanturnyane}}", + "isimage": "pranala berkas", + "whatlinkshere-prev": "{{PLURAL:$1|sadurungnyané|$1 sadurungnyané}}", + "whatlinkshere-next": "{{PLURAL:$1|salanturnyané|$1 salanturnyané}}", "whatlinkshere-links": "← pranala", - "whatlinkshere-hideredirs": "$1 pangalihan", + "whatlinkshere-hideredirs": "$1 kaca gingsiran", "whatlinkshere-hidetrans": "$1 transklusi", "whatlinkshere-hidelinks": "$1 pranala", "whatlinkshere-hideimages": "$1 pranala berkas", - "whatlinkshere-filters": "Panyaring", + "whatlinkshere-filters": "Panyaringan", "ipboptions": "2 jam:2 hours,1 dina:1 day,3 dina:3 days,1 minggu:1 week,2 minggu:2 weeks,1 sasih:1 month,3 sasih:3 months,6 sasih:6 months,1 taun:1 year,tanpa wates:infinite", "ipb-pages-label": "Kaca", "ipb-namespaces-label": "Genah wastan", "block-prevent-edit": "Nguahin", - "ipblocklist": "ngempetin sane nganggo", + "ipblocklist": "Sang anganggé sané kaempetin", "infiniteblock": "Nénten kawates", "blocklist-nousertalk": "tan prasida nguahin kaca pabligbagan praragan", "blocklist-editing-page": "kaca", "blocklist-editing-ns": "genah wastan", - "blocklink": "ngempetin", + "blocklink": "empet", "unblocklink": "ngicalang kaempetan", - "change-blocklink": "gentosin empetin", + "change-blocklink": "uah pangempet", "contribslink": "pituut", - "blocklogpage": "log pemblokiran", + "blocklogpage": "Log pangempet", "blocklogentry": "mlokir [[$1]] anggen pangwates galah $2$3", + "reblock-logentry": "nguwah blokiran aturan antuk [[$1]] sareng galah kadaluwarsa $2 $3", "block-log-flags-nocreate": "ngawe akun kaicalang", + "proxyblocker": "Sané ngablokir proxy", "movelogpage": "Log gingsiran", - "revertmove": "buwungang", - "export": "ekspor lembar", + "revertmove": "wangdéang", + "export": "Ékspor kaca", "export-download": "Raksa pinaka berkas", - "allmessages": "Séwalapatra sistem", + "allmessages": "Séwala sistem", "allmessagesname": "pesengan", "allmessagesdefault": "teks lingga", "thumbnail-more": "Ngedénang", "thumbnail_error": "luput ngaryanin bentuk cenik $1", "import-interwiki-sourcepage": "Kaca wit:", "importlogpage": "Log impor", - "tooltip-pt-userpage": "Kaca {{GENDER:|sang anganggé jero}}", - "tooltip-pt-mytalk": "Kaca pabligbagan {{GENDER:|jero}}", - "tooltip-pt-preferences": "Preferensi {{GENDER:|jero}}", - "tooltip-pt-watchlist": "kepahan-kepahan lembar sane katinjo titiang", - "tooltip-pt-mycontris": "Bacakan pituut {{GENDER:|jero}}", - "tooltip-pt-login": "Jero kaaptiang mangda manjing log; yadiastun nénten wajib", + "tooltip-pt-userpage": "Kaca {{GENDER:|sang anganggé ragané}}", + "tooltip-pt-mytalk": "Kaca pabligbagan {{GENDER:|ragané}}", + "tooltip-pt-preferences": "Préferénsi {{GENDER:|ragané}}", + "tooltip-pt-watchlist": "Bacakan kaca sané uahannyané awasin ragané", + "tooltip-pt-mycontris": "Bacakan pituut {{GENDER:|ragané}}", + "tooltip-pt-login": "Ragané kaaptiang mangda manjing log; yadiastun nénten wajib", "tooltip-pt-logout": "Medal log", - "tooltip-pt-createaccount": "Jero kaaptiang mangda makarya akun miwah manjing log; yadiastun nénten wajib", + "tooltip-pt-createaccount": "Ragané kaaptiang mangda ngardi akun miwah manjing log; yadiastun nénten wajib", "tooltip-ca-talk": "Pabligbagan indik kaca daging", "tooltip-ca-edit": "Uah kaca puniki", - "tooltip-ca-addsection": "nyumunin kepahan anyar", - "tooltip-ca-viewsource": "Kaca puniki kasaibin.\nJero wantah prasida nyingakin witnyané", + "tooltip-ca-addsection": "Wiwit bagian anyar", + "tooltip-ca-viewsource": "Kaca puniki kasaibin.\nRagané wantah prasida nyingakin witnyané", "tooltip-ca-history": "Uahan sadurungnyané saking kaca puniki", "tooltip-ca-protect": "Saib kaca puniki", "tooltip-ca-unprotect": "Uah saiban kaca puniki", "tooltip-ca-delete": "Usap kaca puniki", "tooltip-ca-move": "Gingsirang kaca puniki", - "tooltip-ca-watch": "Imbuhin kaca puniki ring bacakan pantauan ida dané", - "tooltip-ca-unwatch": "apus lembar niki ring daftar paninjoan ida dane", + "tooltip-ca-watch": "Tambeh kaca puniki ring pangawasan ragané", + "tooltip-ca-unwatch": "Usap kaca puniki saking pangawasan ragané", "tooltip-search": "Rereh ring {{SITENAME}}", "tooltip-search-go": "Rereh kaca sané mapeséngan pateh sakadi puniki yéning wénten", "tooltip-search-fulltext": "Rereh kaca sané madaging sesuratan puniki", @@ -736,61 +904,69 @@ "tooltip-n-randompage": "Cihnayang kaca ulah-aluh", "tooltip-n-help": "Genah ngrereh wantuan", "tooltip-t-whatlinkshere": "Bacakan makasami kaca ring wiki sané nuju iriki", - "tooltip-t-recentchangeslinked": "Uahan sané mangkin saking kaca-kaca sané linked ring kaca puniki", + "tooltip-t-recentchangeslinked": "Uahan sané mangkin saking kaca-kaca sané kasambung ring kaca puniki", "tooltip-feed-atom": "\"atom feed\" anggen lembar puniki", - "tooltip-t-contributions": "Bacakan pituut olih {{GENDER:$1|sang anganggé puniki}}", + "tooltip-t-contributions": "Bacakan pituut antuk {{GENDER:$1|sang anganggé puniki}}", "tooltip-t-emailuser": "Ngirim surel majeng ring {{GENDER:$1|penganggo puniki}}", "tooltip-t-upload": "Unggahang depukan", "tooltip-t-specialpages": "Bacakan makasami kaca kusus", "tooltip-t-print": "Vérsi cétak kaca puniki", - "tooltip-t-permalink": "Pranala ajeg anggén révisinnyané kacané puniki", + "tooltip-t-permalink": "Pranala ajeg anggén révisin kacané puniki", "tooltip-ca-nstab-main": "Cingak kaca daging", "tooltip-ca-nstab-user": "Cingak kaca sang anganggé", - "tooltip-ca-nstab-special": "Puniki kaca kusus tur nénten prasida kauwah", + "tooltip-ca-nstab-special": "Puniki kaca kusus tur nénten prasida kauah", "tooltip-ca-nstab-project": "Cingak kaca proyek", "tooltip-ca-nstab-image": "Cingak kaca depukannyané", - "tooltip-ca-nstab-mediawiki": "Cingak séwalapatra sistem", + "tooltip-ca-nstab-mediawiki": "Cingak séwala sistem", "tooltip-ca-nstab-template": "Cingak citakan", "tooltip-ca-nstab-help": "Cingak kaca wantuan", "tooltip-ca-nstab-category": "Cingak kaca kategori", "tooltip-minoredit": "pingetin puniki dados panguwahan kidik", - "tooltip-save": "Raksa uahan jero", - "tooltip-preview": "Pagentosan sane dumun duwen ida dane, mangda anggen niki sadurung jagi nyimpen!", - "tooltip-diff": "Sinahang uahan sané karyanin jero ring sesuratannyané", - "tooltip-compareselectedversions": "cingak binane makekalih kepahan lembar sane kasudi", - "tooltip-watch": "imbuhin lembar niki ring daftar paninjoan ida dane", - "tooltip-rollback": "\"nguliang\" muwungan jagi ngabecikang ring lembar puniki nuju haturan sane untat ngangge apisan klik", - "tooltip-undo": "\"nguliang\" ngabuwungin jagi ngabecikang niki lan ngagah kotak mecikang ngangge mode pratayang. dasar ipun prasida kaimbuhin ring kotak pamicutet", + "tooltip-save": "Raksa uahan ragané", + "tooltip-publish": "Wedar uahan ragané", + "tooltip-preview": "Pracingak uahan ragané. Rarisang nganggén pracingak puniki sadurung ngraksa.", + "tooltip-diff": "Édéngang uahan sané karyanin ragané ring suratannyané", + "tooltip-compareselectedversions": "Cingak bina pantaraning kalih révisi kaca puniki sané kapilih", + "tooltip-watch": "Tambeh kaca puniki ring pangawasan ragané", + "tooltip-rollback": "\"Waliang\" wantah ngwangdéang uahan kontributor sané pinih untat ring kaca puniki antuk klik apisan", + "tooltip-undo": "\"Ulihang\" wantah ngwangdéang uahan puniki miwah membuka formulir uahannyané ring mode pracingak. Larapan prasida katambehin ring ringkesannyané.", "tooltip-summary": "Dagingin ringkesan", - "simpleantispam-label": "Pamariksa anti-spam.\nPuniki <strong>wenten</strong> kaisi!", + "simpleantispam-label": "Panuréksa anti-spam.\n<strong>Sampunang</strong> nagingin puniki!", "pageinfo-title": "Pidarta indik \"$1\"", "pageinfo-header-basic": "Pidarta kaca", "pageinfo-header-edits": "Babad uahan", "pageinfo-header-restrictions": "Saiban kaca", - "pageinfo-header-properties": "Properti suratan", - "pageinfo-display-title": "Edengang judul", + "pageinfo-header-properties": "Properti kaca", + "pageinfo-display-title": "Murda tampilan", + "pageinfo-default-sort": "Kunci urut sané baku", "pageinfo-length": "Dawannyané kaca (ring bita)", "pageinfo-namespace": "Genah wastan", "pageinfo-article-id": "ID kaca", "pageinfo-language": "Basa ring daging kaca", "pageinfo-content-model": "Modél antuk daging kaca", + "pageinfo-robot-policy": "Kaindéksang antuk robot", "pageinfo-robot-index": "Kalugra", "pageinfo-robot-noindex": "Tan kalugra", - "pageinfo-watchers": "Akéh nomér sané negdeg kaca", - "pageinfo-few-watchers": "Kirang saking $1 {{PLURAL:$1|tamiu}}", + "pageinfo-watchers": "Akéh sané ngawasin kaca", + "pageinfo-few-watchers": "Kirang saking $1 {{PLURAL:$1|sané ngawasin}}", "pageinfo-redirects-name": "Akéh nomer sané magingsir ka kaca puniki", "pageinfo-subpages-name": "Kapahan kaca saking kaca puniki", + "pageinfo-subpages-value": "$1 ($2 {{PLURAL:$2|kaalihang}}; $3 {{PLURAL:$3|nénten-kaalihang}})", "pageinfo-firstuser": "Sang makarya kaca", - "pageinfo-firsttime": "Galah ritatkala ngripta kaca", - "pageinfo-lastuser": "Panguwah sané pinih anyar", + "pageinfo-firsttime": "Tanggal ngardi kaca", + "pageinfo-lastuser": "Sang nguah pinih untat", "pageinfo-lasttime": "Galah antuk uahan sané pinih anyar", - "pageinfo-edits": "Akéh nomer sané kauwah", + "pageinfo-edits": "Akéh uahan", "pageinfo-authors": "Akéh nomer makasami antuk panyurat sané lianan", "pageinfo-recent-edits": "Akéh nomer sané kauwah (ring $1 sané sampun lintang)", "pageinfo-recent-authors": "Akéh nomer antuk panyurat sané lianan", + "pageinfo-magic-words": "{{PLURAL:$1Kruna}} sakti ($1)", + "pageinfo-hidden-categories": "{{PLURAL:$1|Kategori}} sané kaengkebang ($1)", + "pageinfo-templates": "Katranslusi {{PLURAL:$1|template|templates}} ($1)", "pageinfo-toolboxlink": "Pidarta kaca", "pageinfo-contentpage": "Kapeték dados kaca daging", "pageinfo-contentpage-yes": "Inggih", + "patrol-log-page": "Log patroli", "previousdiff": "← Uahan sadurungnyané", "nextdiff": "Uahan sané pinih anyar →", "widthheightpage": "$1 × $2, $3 {{PLURAL:$3|kaca}}", @@ -800,13 +976,13 @@ "svg-long-desc": "Berkas SVG, jimbarnyané $1 × $2 piksel, agengnyané berkas: $3", "show-big-image": "Depukan sujati", "show-big-image-preview": "Agengnyané pratuduh puniki: $1.", - "show-big-image-other": "{{PLURAL:$2|Resolusi}} iianan: $1.", + "show-big-image-other": "{{PLURAL:$2|Résolusi}} lianan: $1.", "show-big-image-size": "$1 × $2 piksel", "sunday-at": "Redite jam $1", "bad_image_list": "bentukne sekadi puniki:\n\nwantah kepahan daftar ( baris sane kakawitin anggen tanda *) sane kaitung pranala kapertama ring baris mangda pranala ring berkas sane kaon.\nPranala-Pranala sane selanturnyane ring baris sane pateh kamanahang antuk pinangging, inggih punika lembar sane prasida ngedengang berkas punika.", "metadata": "Métadata", - "metadata-help": "pupulan puniki madaging wacana imbuhan minab sane kaimbuhin olih kamera digital utawi scanner sane kaanggen antuk ngawi atawi \"mendigitalisasi\" pupulan. Yening pupulan niki sampun taen kautak-atik, rerincine sane wenten minab nenten samian nyiriang wacan saking gambar sane sampun kautak-atik niki.", - "metadata-fields": "Widang métadata gambar sané kacantumang ring séwalapatra puniki jagi kalebuang ring tampilan kaca gambar ri tatkala tabél métadata kacenikang.\nSané lianan jagi kasenetang.\n* make\n* model\n* datetimeoriginal\n* exposuretime\n* fnumber\n* isospeedratings\n* focallength\n* artist\n* copyright\n* imagedescription\n* gpslatitude\n* gpslongitude\n* gpsaltitude", + "metadata-help": "Berkas puniki madaging pidarta tambehan, minab katambehin saking kaméra digital utawi pemindai sané kaanggén ngardi utawi nigitalisasi.\nYéning berkasnyané sampun kamodifikasi saking kawéntenan witnyané, rincian saking witnyané minab nénten samian pateh malih saking berkas sané kamodifikasi.", + "metadata-fields": "Widang métadata gambar ring séwala puniki jagi kalebuang ring tampilan kaca gambar ri tatkala tabél métadata kacenikang.\nSané lianan jagi kasenetang.\n* make\n* model\n* datetimeoriginal\n* exposuretime\n* fnumber\n* isospeedratings\n* focallength\n* artist\n* copyright\n* imagedescription\n* gpslatitude\n* gpslongitude\n* gpsaltitude", "namespacesall": "samian", "monthsall": "samian", "confirmemail_invalidated": "Konfirmasi alamat email kawangdéang", @@ -817,8 +993,8 @@ "table_pager_prev": "Kaca sadurungnyané", "watchlisttools-clear": "Ngicalang pupulan sané sampun karauhin", "watchlisttools-view": "Cingak uahan sane relevan", - "watchlisttools-edit": "Cingak miwah uah bacakan pantauan", - "watchlisttools-raw": "Uah kepahan paninjo mentah", + "watchlisttools-edit": "Cingak miwah uah pangawasan", + "watchlisttools-raw": "Uah pangawasan matah", "signature": "[[{{ns:user}}:$1|$2]] ([[{{ns:user_talk}}:$1|pabligbagan]])", "duplicate-defaultsort": "pingetan: sereg pangurutan lingga \"$2\" nyampahang sereg pangurutan lingga sadurunge \"$1\"", "version-specialpages": "Kaca kusus", @@ -830,11 +1006,13 @@ "redirect-user": "ID sang anganggé", "redirect-page": "ID kaca", "redirect-revision": "Uahan kaca", - "redirect-file": "Wastan berkas", + "redirect-file": "Aran berkas", "specialpages": "Kaca kusus", "external_image_whitelist": "#banggiang baris niki sapunapi kawentenanne<pre>\n#anggen fragmen akspresi reguler (wantah kepahan ring kekelaih//) ring sor puniki\n#fragmen-fragmen puniki jagi kaadungang sareng URL saking gambar-gambar eksternal (sane kasambungang langsung)\n#fragmen sane adung jagi katampilang dados gambar, sisanne wantah dados pranala kewanten\n#baris sane kakawitin antuk # jagi kadadosang baris komentar\n#niki nenten ngabinayang aksara ageng lan alit\n#genahang samian fragmen ekspresi reguler ring sor baris puniki. banggiang baris niki sapunapi kawentennane</pre>", - "tag-filter": "filter [[Special:Tags|tag]]:", - "tag-list-wrapper": "[[Special:Tags|{{PLURAL:$1|Tag}}]]: $2", + "tag-filter": "Panyaring [[Special:Tags|cihna]]:", + "tag-list-wrapper": "[[Special:Tags|{{PLURAL:$1|Cihna}}]]: $2", + "tag-mw-rollback": "Waliang", + "tag-mw-rollback-description": "Uahan sané ngwaliang uahan sadurungnyané nganggén pranala waliang", "tags-active-yes": "Inggih", "tags-active-no": "Nénten", "tags-edit": "uah", @@ -843,19 +1021,21 @@ "tags-delete-title": "Usap tag", "compare-page2": "Kaca 2", "logentry-delete-delete": "$1 {{GENDER:$2|ngusapin}} kaca $3", - "logentry-delete-restore": "$1 {{GENDER:$2|ngwalikan}} kaca $3 ($4)", + "logentry-delete-restore": "$1 {{GENDER:$2|ngwaliang}} kaca $3 ($4)", "logentry-delete-revision": "$1 {{GENDER:$2|mauah}} kaca utama {{PLURAL:$5|$5 pamecikan}} ring kaca $3: $4", - "revdelete-content-hid": "dagingnyané kaengkebang", - "logentry-move-move": "$1 {{GENDER:$2|ngingsirang}} kaca $3 ring $4", - "logentry-move-move-noredirect": "$1 {{GENDER:$2|maglisiran}} kaca $3 ka $4 tur nenten ngawe pengalihan", - "logentry-move-move_redir": "$1 {{GENDER:$2|maglisiran}} kaca $3 ka $4 tur nenten ngawe pengalihan", - "logentry-newusers-create": "Akun sang anganggé $1 {{GENDER:$2|kakaryanin}}", - "logentry-newusers-autocreate": "Akun sang anganggé $1 {{GENDER:$2|kakaryanin}} otomatis", + "revdelete-content-hid": "daging kaengkebang", + "logentry-move-move": "$1 {{GENDER:$2|ngingsirang}} kaca $3 ka $4", + "logentry-move-move-noredirect": "$1 {{GENDER:$2|ngingsirang}} kaca $3 ka $4 tur nenten ngawe pengalihan", + "logentry-move-move_redir": "$1 {{GENDER:$2|ngingsirang}} kaca $3 ka $4 tur nenten ngawe pengalihan", + "logentry-patrol-patrol-auto": "$1 otomatis {{GENDER:$2|kacihnayang}} sampun kabecikang $4 saking kaca $3 kaawasin", + "logentry-newusers-create": "Akun sang anganggé $1 {{GENDER:$2|kakardi}}", + "logentry-newusers-byemail": "Akun sang anganggé $3 {{GENDER:$2|sampun kakardi}} antuk $1 miwah kruna sandi sampun kakirim antuk séwala éléktronik", + "logentry-newusers-autocreate": "Akun sang anganggé $1 {{GENDER:$2|kakardi}} otomatis", "logentry-protect-protect": "$1 {{GENDER:$2|nyaibin}} $3 $4", "logentry-upload-upload": "$1 {{GENDER:$2|ngunggahang}} $3", "logentry-upload-overwrite": "$1 {{GENDER:$2|ngunggahang}} vèrsi anyar saking $3", "feedback-cancel": "Wangdé", - "feedback-message": "Séwalapatra:", + "feedback-message": "Séwala:", "searchsuggest-search": "Rereh ring {{SITENAME}}", "duration-days": "$1 {{PLURAL:$1|rahina}}", "pagelanguage": "Uah basa ring kaca", @@ -863,5 +1043,6 @@ "mw-widgets-abandonedit-keep": "Lanturang nguah", "randomrootpage": "Kaca pinih dasar sane mabrarakan", "log-action-filter-protect-protect": "Saiban", - "log-action-filter-protect-move_prot": "Ngingsirang saiban" + "log-action-filter-protect-move_prot": "Ngingsirang saiban", + "passwordpolicies-policy-passwordcannotmatchusername": "Kruna sandi nénten dados pateh sareng peséngan sang anganggé" } diff --git a/languages/i18n/bar.json b/languages/i18n/bar.json index 67059c71f5..75edef4df7 100644 --- a/languages/i18n/bar.json +++ b/languages/i18n/bar.json @@ -359,22 +359,6 @@ "resetpass-submit-cancel": "Obbrechen", "passwordreset": "Passwoat zrucksetzn", "passwordreset-username": "Nutzanama:", - "bold_sample": "Fetta Text", - "bold_tip": "Fetta Text", - "italic_sample": "Kursiva Text", - "italic_tip": "Kursiva Text", - "link_sample": "Link-Text", - "link_tip": "Interna Link", - "extlink_sample": "http://www.example.com Link-Text", - "extlink_tip": "Externa Link (http:// beochtn)", - "headline_sample": "Ibaschrift Text", - "headline_tip": "Ebane-2-Ibaschrift", - "nowiki_sample": "Nedformatiadn Text do eibaun", - "nowiki_tip": "Wiki-Format ignorian", - "image_tip": "Dateilink", - "media_tip": "Datei-Link", - "sig_tip": "Dei Untaschrift mit Zeitstempe", - "hr_tip": "Wogrechte Linie (sporsam vawendn)", "summary": "Zammfossung:", "subject": "Bedreff", "minoredit": "Nua Kloanigkeidn san vaendat worn", diff --git a/languages/i18n/bcc.json b/languages/i18n/bcc.json index a9af2effeb..4c4b3fd10a 100644 --- a/languages/i18n/bcc.json +++ b/languages/i18n/bcc.json @@ -530,22 +530,6 @@ "resettokens-watchlist-token": "ویب فیدء پجاروک [[Special:Watchlist|پیجانی تغییرات که آهانء رهگر کن ات]] (اتم/آراس‌اس)", "resettokens-done": "پجاروکانی واتر.", "resettokens-resetbutton": "درچتگین پجاروکانء واتر بکن", - "bold_sample": "پررنگین متن", - "bold_tip": "پررنگین متن", - "italic_sample": "ایتالیکی متن", - "italic_tip": "ایتالیکی متن", - "link_sample": "عنوان لینک", - "link_tip": "لینک درونی", - "extlink_sample": "http://www.example.com عنوان لینک", - "extlink_tip": "حارجی لینک(مشموش http:// پیشوند)", - "headline_sample": "متن سرخط", - "headline_tip": "سطح Û² سرخط", - "nowiki_sample": "متن بی فرمتءا ادان وارد کن", - "nowiki_tip": "فرمت وی کی شموش", - "image_tip": "فایل هورگین", - "media_tip": "لینک فایل", - "sig_tip": "شمی امضا گون مهر زمان", - "hr_tip": "خط افقی", "summary": "کمݔں:", "subject": "موضوع/سرخط:", "minoredit": "اݔشی یک ھُردݔں ٹگلے", diff --git a/languages/i18n/bcl.json b/languages/i18n/bcl.json index 11f3e1f095..7759c45b08 100644 --- a/languages/i18n/bcl.json +++ b/languages/i18n/bcl.json @@ -553,24 +553,6 @@ "resettokens-watchlist-token": "Paduos para sa hungitan nin web (Atom/RSS) kan [[Special:Watchlist|mga kaliwatan sa mga pahina nin saimong bantay-listahan]]", "resettokens-done": "Mga paduos pinagbago na.", "resettokens-resetbutton": "Pakibaguha an pinagpiling mga paduos", - "bold_sample": "Mahìbog na teksto", - "bold_tip": "Mahìbog na teksto", - "italic_sample": "Italikong teksto", - "italic_tip": "Italikong teksto", - "link_sample": "Titulo nin sugpon", - "link_tip": "Panlaog na sugpon", - "extlink_sample": "http://www.example.com títulong sugpon", - "extlink_tip": "Panluwas na sugpon(giromdomon an http:// pangenot na panigmit)", - "headline_sample": "Pamayuhang linya kan teksto", - "headline_tip": "Talangga 2 pamayuhang-linya", - "nowiki_sample": "Isaliot an dae nakapormat na teksto digde", - "nowiki_tip": "Balewalaon an pampormat na wiki", - "image_sample": "Halimbawa.jpg", - "image_tip": "Nakalubog na sagunson", - "media_sample": "Halimbawa.ogg", - "media_tip": "Kilyaw nin sagunson (file)", - "sig_tip": "An saimong pirma na igwang tatak-oras", - "hr_tip": "Pabalagbag na linya (gamiton paminsan-minsan)", "summary": "Sumaryo:", "subject": "Tema", "minoredit": "Ini sarong dikiton na pagliwat", diff --git a/languages/i18n/be-tarask.json b/languages/i18n/be-tarask.json index 19585c854d..58fa5b5a27 100644 --- a/languages/i18n/be-tarask.json +++ b/languages/i18n/be-tarask.json @@ -606,24 +606,6 @@ "resettokens-watchlist-token": "Токен стужкі (Atom/RSS) [[Special:Watchlist|зьменаў у вашым сьпісе назіраньня]]", "resettokens-done": "Токены скінутыя.", "resettokens-resetbutton": "Скінуць вылучаныя токены", - "bold_sample": "Тоўсты тэкст", - "bold_tip": "Тоўсты тэкст", - "italic_sample": "Курсіўны тэкст", - "italic_tip": "Курсіўны тэкст", - "link_sample": "Загаловак спасылкі", - "link_tip": "Унутраная спасылка", - "extlink_sample": "http://www.example.com загаловак спасылкі", - "extlink_tip": "Вонкавая спасылка (не забывайцеся пачынаць з http:// )", - "headline_sample": "Тэкст загалоўку", - "headline_tip": "Загаловак 2-га ўзроўню", - "nowiki_sample": "Устаўце сюды нефарматаваны тэкст", - "nowiki_tip": "Ігнараваць вікі-фарматаваньне", - "image_sample": "Прыклад.jpg", - "image_tip": "Укладзены файл", - "media_sample": "Прыклад.ogg", - "media_tip": "Спасылка на файл", - "sig_tip": "Ваш подпіс і момант часу", - "hr_tip": "Гарызантальная лінія (не выкарыстоўвайце часта)", "summary": "Кароткае апісаньне зьменаў:", "subject": "Тэма:", "minoredit": "Гэта дробная праўка", @@ -3783,9 +3765,9 @@ "specialmute-success": "Вашыя налады заглушэньня былі абноўленыя. Глядзіце ўсіх заглушаных удзельнікаў на старонцы [[Special:Preferences|вашых наладаў]].", "specialmute-submit": "Пацьвердзіць", "specialmute-label-mute-email": "Заглушыць лісты электроннай пошты ад гэтага ўдзельніка", - "specialmute-header": "Калі ласка, абярыце вашыя налады заглушэньня для <b>{{BIDI:[[User:$1]]}}</b>.", + "specialmute-header": "Калі ласка, абярыце вашыя налады заглушэньня для {{GENDER:$1|ўдзельніка|ўдзельніцы}} <b>{{BIDI:[[User:$1|$1]]}}</b>.", "specialmute-error-invalid-user": "Запытанае імя ўдзельніка ня можа быць знойдзенае.", - "specialmute-email-footer": "Для кіраваньня наладамі электроннай пошты для {{BIDI:$2}}, калі ласка, наведайце <$1>.", + "specialmute-email-footer": "Для кіраваньня наладамі электроннай пошты {{GENDER:$1|ўдзельніка|ўдзельніцы}} {{BIDI:$2}}, калі ласка, наведайце <$1>.", "specialmute-login-required": "Калі ласка, увайдзіце, каб зьмяніць вашыя налады заглушэньня.", "mute-preferences": "Налады заглушэньня", "revid": "вэрсія $1", diff --git a/languages/i18n/be.json b/languages/i18n/be.json index c356041461..baac1c5de9 100644 --- a/languages/i18n/be.json +++ b/languages/i18n/be.json @@ -406,6 +406,7 @@ "virus-scanfailed": "не ўдалося праверыць (код $1)", "virus-unknownscanner": "невядомы антывірус:", "logouttext": "<strong>Вы выйшлі з сістэмы.</strong>\n\nЗаўважце, што некаторыя старонкі могуць паказвацца так, быццам вы яшчэ не выйшлі; у такім разе трэба ачысціць кэш вашага браўзера.", + "logging-out-notify": "Вы выходзіце з сістемы, калі ласка, пачакайце.", "logout-failed": "Немагчыма выйсці зараз: $1", "cannotlogoutnow-title": "Зараз немагчыма выйсці", "cannotlogoutnow-text": "Пры выкарыстанні $1 выхад з сістэмы немагчымы.", @@ -618,24 +619,6 @@ "resettokens-watchlist-token": "Токен струменя (Atom/RSS) [[Special:Watchlist|зменаў старонак у вашым спісе назірання]]", "resettokens-done": "Токены скінуты.", "resettokens-resetbutton": "Скінуць выбраныя токены", - "bold_sample": "Цёмны тэкст", - "bold_tip": "Цёмны тэкст", - "italic_sample": "Курсіўны тэкст", - "italic_tip": "Курсіўны тэкст", - "link_sample": "Назва спасылкі", - "link_tip": "Унутраная спасылка", - "extlink_sample": "http://www.example.com назва спасылкі", - "extlink_tip": "Вонкавая спасылка (памятайце аб прэфіксе http://)", - "headline_sample": "Тэкст загалоўка", - "headline_tip": "Загаловак 2 узроўню", - "nowiki_sample": "Гэта нефарматаваны тэкст", - "nowiki_tip": "Без вікі-фарматавання", - "image_sample": "Напрыклад.jpg", - "image_tip": "Файл у тэксце", - "media_sample": "Напрыклад.ogg", - "media_tip": "Спасылка на медыяфайл", - "sig_tip": "Ваш подпіс і адзначаны час", - "hr_tip": "Гарызантальная рыса (не злоўжывайце гэтым)", "summary": "Тлумачэнне:", "subject": "Тэма/загаловак:", "minoredit": "Дробная праўка", @@ -989,6 +972,7 @@ "search-interwiki-more": "(яшчэ)", "search-interwiki-more-results": "больш вынікаў", "search-relatedarticle": "Дачыняюцца*", + "search-invalid-sort-order": "Парадак сартавання ў $1 не распазнаны, будзе ўжыта сартаванне па змоўчанні. Правільныя запыты на сартаванне: $2", "searchrelated": "маюць дачыненне", "searchall": "усе", "showingresults": "Ніжэй паказаны да {{PLURAL:$1|'''$1''' выніку|'''$1''' вынікаў}}, пачынаючы з нумару '''$2'''.", @@ -2225,7 +2209,7 @@ "exbeforeblank": "змесціва перад ачысткаю было: '$1'", "delete-confirm": "Выдаліць \"$1\"", "delete-legend": "Выдаліць", - "historywarning": "<strong>Увага:</strong> Старонка, якую вы хочаце выдаліць, мае гісторыю з прыблізна $1 {{PLURAL:$1|праўку|праўкі|правак}}:", + "historywarning": "<strong>Увага:</strong> Старонка, якую вы хочаце выдаліць, мае гісторыю правак з $1 {{PLURAL:$1|версіяй|версіямі|версіямі}}:", "historyaction-submit": "Паказаць", "confirmdeletetext": "Вы збіраецеся выдаліць старонку разам з усёй яе гісторыяй правак.\nПацвердзіце свой намер зрабіць гэта, сваё разуменне наступстваў, і што Вы робіце гэта ў адпаведнасці з [[{{MediaWiki:Policy-url}}|асноўнымі правіламі праекта]].", "actioncomplete": "Завершана аперацыя", @@ -2944,7 +2928,7 @@ "newimages-hidepatrolled": "Без паказу ўхваленых ўкладанняў", "newimages-mediatype": "Тып медиафайла:", "noimages": "Тут нічога няма.", - "gallery-slideshow-toggle": "Переключить мініяцюры", + "gallery-slideshow-toggle": "Пераключыць мініяцюры", "ilsubmit": "Знайсці", "bydate": "п. датаў", "sp-newimages-showfrom": "Паказаць новыя файлы, пачынаючы з $2, $1", diff --git a/languages/i18n/bg.json b/languages/i18n/bg.json index 485c9fe2a9..a209419084 100644 --- a/languages/i18n/bg.json +++ b/languages/i18n/bg.json @@ -462,7 +462,7 @@ "createacct-another-email-ph": "Въведете електронна поща", "createaccountmail": "Използване на случайна временна парола, която се изпраща на посочената електронната поща", "createacct-realname": "Истинско име (незадължително)", - "createacct-reason": "Причина", + "createacct-reason": "Причина (публично видима)", "createacct-reason-ph": "Защо създавате друга сметка", "createacct-reason-help": "Съобщение, показвано в дневника на създадени сметки", "createacct-submit": "Създаване на сметката", @@ -624,24 +624,6 @@ "resettokens-watchlist-token": "Маркер за уеб хранилка (Atom/RSS) на [[Special:Watchlist|промени на страници от списъка Ви за наблюдение]]", "resettokens-done": "Маркерите са изчистени.", "resettokens-resetbutton": "Изчистване на избраните маркери", - "bold_sample": "Получер текст", - "bold_tip": "Получер (удебелен) текст", - "italic_sample": "Наклонен текст", - "italic_tip": "Наклонен текст", - "link_sample": "Име на препратка", - "link_tip": "Вътрешна препратка", - "extlink_sample": "http://www.example.com Текст на външната препратка", - "extlink_tip": "Външна препратка (не забравяйте http:// отпред)", - "headline_sample": "Заглавие на раздел", - "headline_tip": "Заглавие от 2-ро ниво", - "nowiki_sample": "Тук въведете текст", - "nowiki_tip": "Пренебрегване на форматиращите команди", - "image_sample": "Пример.jpg", - "image_tip": "Вмъкване на картинка", - "media_sample": "Пример.ogg", - "media_tip": "Препратка към файл", - "sig_tip": "Вашият подпис заедно с времева отметка", - "hr_tip": "Хоризонтална линия (използвайте пестеливо)", "summary": "Резюме:", "subject": "Заглавие:", "minoredit": "Това е малка промяна", @@ -743,6 +725,8 @@ "nocreate-loggedin": "Нямате необходимите права да създавате нови страници.", "sectioneditnotsupported-title": "Не се поддържа редактиране на раздели", "sectioneditnotsupported-text": "Не се поддържа редактиране на раздели на тази страница.", + "modeleditnotsupported-title": "Редактирането не се поддържа", + "modeleditnotsupported-text": "Редактирането не се поддържа за модел на съдържанието $1.", "permissionserrors": "Грешка при правата на достъп", "permissionserrorstext": "Нямате правата да извършите това действие по {{PLURAL:$1|следната причина|следните причини}}:", "permissionserrorstext-withaction": "Нямате разрешение за $2 поради {{PLURAL:$1|следната причина|следните причини}}:", @@ -1395,6 +1379,7 @@ "rcfilters-clear-all-filters": "Изчистване на всички филтри", "rcfilters-show-new-changes": "Преглед на промените направени след $1", "rcfilters-search-placeholder": "Филтриране на промените (използвайте менюто или търсете по име на филтър)", + "rcfilters-search-placeholder-mobile": "Филтри", "rcfilters-invalid-filter": "Невалиден филтър", "rcfilters-empty-filter": "Няма активни филтри. Показани са всички редакции.", "rcfilters-filterlist-title": "Филтри", @@ -2215,6 +2200,7 @@ "changecontentmodel": "Промяна на модела на съдържанието на страница", "changecontentmodel-legend": "Промяна на модела на съдържанието", "changecontentmodel-title-label": "Заглавие на страницата:", + "changecontentmodel-current-label": "Текущ модел на съдържанието:", "changecontentmodel-model-label": "Нов модел на съдържанието:", "changecontentmodel-reason-label": "Причина:", "changecontentmodel-submit": "Променяне", @@ -2339,6 +2325,7 @@ "mycontris": "Приноси", "anoncontribs": "Приноси", "contribsub2": "За {{GENDER:$3|$1}} ($2)", + "contributions-subtitle": "За {{GENDER:$3|$1}}", "contributions-userdoesnotexist": "Няма регистрирана потребителска сметка за „$1“.", "negative-namespace-not-supported": "Именни пространства с негативни стойности не се поддържат.", "nocontribs": "Не са намерени промени, отговарящи на критерия.", @@ -3215,17 +3202,19 @@ "permanentlink": "Постоянна препратка", "permanentlink-revid": "ID на редакцията", "permanentlink-submit": "Към редакцията", + "newsection": "Нов раздел", + "newsection-page": "Целева страница", "dberr-problems": "Съжаляваме! Сайтът изпитва технически затруднения.", "dberr-again": "Изчакайте няколко минути и опитайте да презаредите.", "dberr-info": "(Няма достъп до базата от данни: $1)", "dberr-info-hidden": "(Няма връзка със сървъра на базата данни)", - "htmlform-invalid-input": "Има проблеми с част от въведения от вас вход", + "htmlform-invalid-input": "Има проблеми с част от въведения от вас текст", "htmlform-select-badoption": "Посочената от вас стойност не е валидна алтернатива.", "htmlform-int-invalid": "Въведената от вас стойност не е цяло число.", "htmlform-float-invalid": "Посочената стойност не е число.", "htmlform-int-toolow": "Посочената от вас стойност е под минимално допустимата $1.", "htmlform-int-toohigh": "Посочената от вас стойност надхвърля максимално допустимата $1.", - "htmlform-required": "Тази стойност се изисква", + "htmlform-required": "Тази стойност е задължителна.", "htmlform-submit": "Изпращане", "htmlform-reset": "Отказване на промените", "htmlform-selectorother-other": "Друга", diff --git a/languages/i18n/bgn.json b/languages/i18n/bgn.json index b5ee9f0248..94ca797559 100644 --- a/languages/i18n/bgn.json +++ b/languages/i18n/bgn.json @@ -509,22 +509,6 @@ "resettokens-token-label": "$1 (انونین اندازه Ú¯: $2)", "resettokens-done": "بیئر گردینتین نشانگ ئان.", "resettokens-resetbutton": "نشانی بوته ئین وسایلانی بیئرگردینتین.", - "bold_sample": "پر رنگین متن", - "bold_tip": "پر رنگین متن", - "italic_sample": "مورب متن", - "italic_tip": "مورب متن", - "link_sample": "خرابین ئنوان", - "link_tip": "داخلین لینک", - "extlink_sample": "http://www.example.com خرابین ئنوان", - "extlink_tip": "لینک په ڈنا (دیموند http://‎ ئا شه هوشا مه به ریت)", - "headline_sample": "متنئ سر ئنوان", - "headline_tip": "ئنوان سطح Û²", - "nowiki_sample": "ایدا چوکاٹ بندی نه بوته ئین متن ئه داخل کنیت", - "nowiki_tip": "نادیده گیپتین ویکی ئی چوکاٹ بندیا", - "image_tip": "متنی تئ اکس", - "media_tip": "فایل لینک", - "sig_tip": "شمی دستنام گو وختئ مهرئا", - "hr_tip": "افقی ئین خط (په مصرفئ کم کورتینا استفاده بیئت)", "summary": "خلاصه:", "subject": "موضو/ئنوان:", "minoredit": "ای یک گونڈین ایڈیٹئ است", diff --git a/languages/i18n/bho.json b/languages/i18n/bho.json index 30ebb28544..85165ed8d1 100644 --- a/languages/i18n/bho.json +++ b/languages/i18n/bho.json @@ -588,24 +588,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|आपके धियानसूची के पन्नन में बदलावसभ]] के वेब फीड (एटम/आरऍसऍस) खातिर टोकन", "resettokens-done": "टोकन रीसेट हो चुकल बा।", "resettokens-resetbutton": "चुनल गइल टोकन रीसेट करीं", - "bold_sample": "मोट अच्छर", - "bold_tip": "मोट अच्छर", - "italic_sample": "तिरछा पाठ", - "italic_tip": "तिरछा पाठ", - "link_sample": "कड़ी टाइटिल", - "link_tip": "अंदरूनी कड़ी", - "extlink_sample": "http://www.example.com कड़ी टाइटिल", - "extlink_tip": "बाहरी कड़ी (शुरू में http:// जरुर लगाईं)", - "headline_sample": "हेडिंग पाठ", - "headline_tip": "दुसरा लेवल के हेडिंग", - "nowiki_sample": "बिना-फारमेट कइल पाठ इहाँ डालीं", - "nowiki_tip": "विकि फारमेटिंग के अनदेखी करीं", - "image_sample": "उदाहरण.jpg", - "image_tip": "समाहित (एम्बेड कइल) फाइल", - "media_sample": "उदाहरण.ogg", - "media_tip": "फाइल कड़ी", - "sig_tip": "समय मोहर की संघे राउर दस्खत", - "hr_tip": "पड़ी लकीर (कम प्रयोग करीं)", "summary": "सारांश:", "subject": "बिसय:", "minoredit": "ई एगो छोट संपादन बा", diff --git a/languages/i18n/bjn.json b/languages/i18n/bjn.json index 937c0bb814..c82b5e02a7 100644 --- a/languages/i18n/bjn.json +++ b/languages/i18n/bjn.json @@ -452,22 +452,6 @@ "changeemail-none": "(kadada)", "changeemail-password": "Sandi {{SITENAME}} Pian:", "changeemail-submit": "Ganti suril", - "bold_sample": "Naskah kandal", - "bold_tip": "Naskah kandal", - "italic_sample": "Naskah hiring", - "italic_tip": "Naskah hiring", - "link_sample": "Judul tautan", - "link_tip": "Tautan dalam", - "extlink_sample": "http://www.example.com judul tautan", - "extlink_tip": "Tautan luar (Ingatakan bamula wan http://)", - "headline_sample": "Naskah judul", - "headline_tip": "Judul tingkat 2", - "nowiki_sample": "Masukakan naskah kada babantuk di sia", - "nowiki_tip": "Halinakan pambantukan/purmat wiki", - "image_tip": "Maktub'akan barakas", - "media_tip": "Tautan barakas", - "sig_tip": "Tandatangan Pian lawan tanda waktu", - "hr_tip": "Garis horisontal", "summary": "Kasimpulan:", "subject": "Parihal:", "minoredit": "Ngini adalah babakan sapalih", diff --git a/languages/i18n/bn.json b/languages/i18n/bn.json index 224e4ae2bf..c8b6b6c4d7 100644 --- a/languages/i18n/bn.json +++ b/languages/i18n/bn.json @@ -40,7 +40,8 @@ "Rasal Lia", "আফতাবুজ্জামান", "Tahmid02016", - "Ifsad" + "Ifsad", + "Nokib Sarkar" ] }, "tog-underline": "সংযোগের নিচে দাগ দেখানো হোক:", @@ -87,6 +88,7 @@ "tog-useeditwarning": "কোনো সম্পাদনা পাতা ত্যাগের সময় পরিবর্তনগুলি সংরক্ষিত না হয়ে থাকলে আমাকে সাবধান করা হোক", "tog-prefershttps": "অ্যাকাউন্টে প্রবেশ করার সময় সবসময় নিরাপদ সংযোগ ব্যবহার করুন", "tog-showrollbackconfirmation": "একটি রোলব্যাক লিঙ্ক ক্লিক করার সময় একটি নিশ্চিতকরণ বার্তা দেখান", + "tog-requireemail": "পাসওয়ার্ড পুনঃস্থাপন করার জন্য ইমেল প্রয়োজন", "underline-always": "সব সময়", "underline-never": "কখনো নয়", "underline-default": "আবরণ বা ব্রাউজারে যেমনভাবে নির্দিষ্ট করা আছে", @@ -460,7 +462,7 @@ "createaccountmail": "সাময়িকভাবে অজানা পাসওয়ার্ড ব্যবহার করুন এবং নির্ধারিত ইমেইল ঠিকানায় পাঠিয়ে দিন", "createaccountmail-help": "পাসওয়ার্ড জানা ছাড়াই অন্য ব্যক্তির জন্য অ্যাকাউন্ট তৈরি করতে ব্যবহার করা যেতে পারে।", "createacct-realname": "আসল নাম (ঐচ্ছিক)", - "createacct-reason": "কারণ", + "createacct-reason": "কারণ (জনসম্মুখে নিবন্ধিত)", "createacct-reason-ph": "কেন আপনি আরেকটি অ্যাকাউন্ট তৈরি করছেন", "createacct-reason-help": "অ্যাকাউন্ট তৈরির লগে দেখানো বার্তা", "createacct-submit": "আপনার অ্যাকাউন্ট তৈরি করুন", @@ -628,23 +630,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|নজরতালিকায় থাকা পাতাগুলোতে পরিবর্তন]] সংক্রান্ত ওয়েব ফিডের (Atom বা RSS) টোকেন", "resettokens-done": "টোকেনগুলি সফলভাবে পুনঃনির্ধারিত হয়েছে।", "resettokens-resetbutton": "নির্বাচিত টোকেনগুলি পুনঃনির্ধারণ করুন", - "bold_sample": "গাঢ় লেখা", - "bold_tip": "গাঢ় লেখা", - "italic_sample": "তির্যক লেখা", - "italic_tip": "তির্যক লেখা", - "link_sample": "অভ্যন্তরীণ সংযোগের শিরোনাম", - "link_tip": "অভ্যন্তরীণ সংযোগ", - "extlink_sample": "http://www.example.com বহিঃসংযোগ শিরোনাম", - "extlink_tip": "বহিঃসংযোগ (http:// উপসর্গটি যোগ করতে ভুলবেন না)", - "headline_sample": "শিরোনাম", - "headline_tip": "২য় স্তরের শিরোনাম", - "nowiki_sample": "অবিন্যাসকৃত পাঠ্য এখানে যোগ করুন", - "nowiki_tip": "উইকি বিন্যাসন উপেক্ষা করা হোক", - "image_sample": "উদাহরণ.jpg", - "image_tip": "গ্রথিত ফাইল", - "media_tip": "ফাইল সংযোগ", - "sig_tip": "সময় ও তারিখসহ আপনার স্বাক্ষর", - "hr_tip": "অনুভূমিক রেখা (সংযতভাবে ব্যবহার করুন)", "summary": "সারাংশ:", "subject": "বিষয়:", "minoredit": "এটি একটি অনুল্লেখ্য সম্পাদনা", @@ -826,6 +811,7 @@ "undo-norev": "সম্পাদনাটি বাতিল করা যাচ্ছেনা কারণ এটি আর নেই বা মুছে ফেলা হয়েছে।", "undo-nochange": "সম্পাদনাটি পূর্বেই বাতিল করা হয়েছে।", "undo-summary": "[[Special:Contributions/$2|$2]] ([[User talk:$2|আলাপ]])-এর সম্পাদিত $1 নম্বর সংশোধনটি বাতিল করা হয়েছে", + "undo-summary-anon": "[[Special:Contributions/$2|$2]]-এর সম্পাদিত $1 নম্বর সংশোধনটি বাতিল করা হয়েছে", "undo-summary-username-hidden": "একজন লুকানো ব্যবহারকারীর করা $1 নং সংশোধনটি বাতিল করা হয়েছে", "cantcreateaccount-text": "[[User:$3|$3]] এই আইপি ঠিকানা('''$1''') থেকে অ্যাকাউন্ট সৃষ্টিতে বাধা দিয়েছেন।\n\n$3-এর দেয়া কারণ হল ''$2''", "cantcreateaccount-range-text": "[[User:$3|$3]] কর্তৃক আইপি ঠিকানার ব্যাপ্তি <strong>$1</strong>-এর মধ্যে অ্যাকাউন্ট তৈরি করা অবরুদ্ধ করা হয়েছে। যাতে আপনার আইপি ঠিকানাও (<strong>$4</strong>) রয়েছে। \n\n$3 কর্তৃক <em>$2</em> কারণ দেখানো হয়েছে।", @@ -1835,6 +1821,7 @@ "listfiles-userdoesnotexist": "ব্যবহারকারী অ্যাকাউন্ট \"$1\" নিবন্ধিত নয়।", "imgfile": "ফাইল", "listfiles": "ছবির তালিকা", + "listfiles_subpage": "$1 কর্তৃক আপলোডসমূহ", "listfiles_thumb": "সংক্ষেপচিত্র", "listfiles_date": "তারিখ", "listfiles_name": "নাম", @@ -3890,5 +3877,8 @@ "passwordpolicies-policy-maximalpasswordlength": "পাসওয়ার্ড $1 {{PLURAL:$1|অক্ষরের}} চেয়ে কম দীর্ঘ হতে হবে", "passwordpolicies-policy-passwordnotinlargeblacklist": "পাসওয়ার্ড ১,০০,০০০ সর্বাধিক ব্যবহৃত পাসওয়ার্ডের তালিকায় থাকতে পারবে না।", "unprotected-js": "নিরাপত্তার কারণে জাভাস্ক্রিপ্ট অনিরাপদ পৃষ্ঠা থেকে লোড করা যাবে না। শুধুমাত্র মিডিয়াউইকি: নামস্থান বা ব্যবহারকারী উপপাতায় জাভাস্ক্রিপ্ট তৈরি করুন", - "userlogout-continue": "আপনি কি প্রস্থান করতে চান?" + "userlogout-continue": "আপনি কি প্রস্থান করতে চান?", + "rest-prefix-mismatch": "অনুরোধকৃত পথ ($1) রেস্ট API মূলপথের ($2) ভিতরে ছিল না।", + "rest-wrong-method": "অনুরোধ পদ্ধতি ($1) এই পথের {{PLURAL:$3|জন্য অনুমোদিত পদ্ধতির|জন্য অনুমোদিত পদ্ধতিগুলির}} অন্তর্ভুক্ত নয় ($2)", + "rest-no-match": "অনুরোধ করা আপেক্ষিক পথ ($1) কোনও পরিচিত হ্যান্ডলারের সাথে মেলে না" } diff --git a/languages/i18n/bo.json b/languages/i18n/bo.json index ef89699369..ec6526b35e 100644 --- a/languages/i18n/bo.json +++ b/languages/i18n/bo.json @@ -368,22 +368,6 @@ "changeemail-newemail": "དྲ་འཕྲིན་ཁ་བྱང་གསར་བ།", "changeemail-none": "(སྟོང་པ།)", "changeemail-submit": "དྲ་འཕྲིན་བརྗེ་བ།", - "bold_sample": "ཡིག་གཟུགས་སྦོམ་པོ།", - "bold_tip": "ཡིག་གཟུགས་སྦོམ་པོ།", - "italic_sample": "ཡིག་གཟུགས་གསེག་མ།", - "italic_tip": "ཡིག་གཟུགས་གསེག་མ།", - "link_sample": "མཚམས་སྦྱོར་ཁ་ཡིག", - "link_tip": "ཕྱི་རོལ་མཐུད་སྦྲེལ།", - "extlink_sample": "Http://www.example.com སྦྲེལ་མཐུད་ཁ་བྱང་།", - "extlink_tip": "ཕྱི་ཕྱོགས་དྲ་འབྲེལ།", - "headline_sample": "འགོ་བརྗོད་ཡིག་གཟུགས།", - "headline_tip": "རིམ་པ། ༢ འགོ་ཕྲེང་།", - "nowiki_sample": "རྣམ་བཞག་མེད་པའི་ཡི་གེ་འདྲེན་པ།", - "nowiki_tip": "ཝེ་ཁེའི་རྣམ་གཞག་དོར་བ།", - "image_tip": "བཙུད་འཇུག་ཡིག་ཆ།", - "media_tip": "ཡིག་ཆ་སྦྲེལ་མཐུད།", - "sig_tip": "མིང་རྟགས་མཉམ་དུ་ཟླ་ཚེས་ཐེལ་ཙེ།", - "hr_tip": "ཐད་ཐིག ༼ཆུད་ཟོས་མེད་པར།༽", "summary": "བསྡུས་དོན།:", "subject": "འགོ་བརྗོད།", "minoredit": "འདི་ནི་རྩོམ་སྒྲིག་ཕལ་བ་ཞིག་ཡིན།", diff --git a/languages/i18n/bpy.json b/languages/i18n/bpy.json index 10cb89719d..d1a004fa87 100644 --- a/languages/i18n/bpy.json +++ b/languages/i18n/bpy.json @@ -365,22 +365,6 @@ "changeemail-no-info": "পাতা এহানাত হমিতে গেলেগা তি যেসারেউ লগইন করানি লাগতই।", "changeemail-none": "(নেই)", "changeemail-submit": "ই-মেইল সিলকর", - "bold_sample": "গাঢ়পা ৱাহি", - "bold_tip": "গাঢ়পা ৱাহি", - "italic_sample": "ইটালিক মেয়েক", - "italic_tip": "ইটালিক মেয়েক", - "link_sample": "চিঙনাঙ মিলাপ", - "link_tip": "ভিতরর মিলাপ", - "extlink_sample": "http://www.example.com চিঙনাঙ মিলাপ", - "extlink_tip": "বারেদের মিলাপ (মুঙে http:// বারনি না পাহুরিস)", - "headline_sample": "চিঙনাঙর খন্তাহানি", - "headline_tip": "থাক ২র চিঙনাঙ", - "nowiki_sample": "ফরমেট নাকরিসি মেয়েক বরা", - "nowiki_tip": "উইকির পাজালানিহান লালুয়া যাগা", - "image_tip": "তিলকরিসি ফাইলগ", - "media_tip": "ফাইল মিলাপ", - "sig_tip": "তর স্বাক্ষরহান লগে খেন্তাম বরিয়া", - "hr_tip": "পাথারি খাস (খানি করা ইয়া আতা)", "summary": "সারমর্ম:", "subject": "বিষয়/চিঙনাঙ:", "minoredit": "এহান হুরু-মুরু সম্পাদনাহানহে।", diff --git a/languages/i18n/bqi.json b/languages/i18n/bqi.json index 99a3e29095..3d23273851 100644 --- a/languages/i18n/bqi.json +++ b/languages/i18n/bqi.json @@ -576,22 +576,6 @@ "resettokens-watchlist-token": "شناسانٱنڌاٛ خوراک ڤباٛی [[Special:Watchlist|آلشڌ بٱلٛگیٱلؽ کاْ دیناگری اْکونین]] (ٱتم/آراْس‌اْس)", "resettokens-done": "دوکرتشناسی شناسانٱنڌاٛیٱل", "resettokens-resetbutton": "دوکرتشناسی شناسانٱنڌاٛیٱل دزاْ آڤیڌاْ", - "bold_sample": "متن گٱپ نما", - "bold_tip": "متن گٱپ نما", - "italic_sample": "متن ایتالیک", - "italic_tip": "متن ایتالیک", - "link_sample": "داسوݩ هومپاٛیڤٱند", - "link_tip": "هومپاٛیڤٱند داخلی", - "extlink_sample": "http://www.example.com داسوݩ هومپاٛیڤٱند", - "extlink_tip": "(ڤٱن ڤا ڤیرت http:// prefix)\nهومپاٛیڤٱند خارجی", - "headline_sample": "سرخٱت متن", - "headline_tip": "ریتراز 2 سرخٱت", - "nowiki_sample": "ز ایچو متن بی شیڤات خوتۊناْ ڤارڌ کونین", - "nowiki_tip": "ز شیڤات ڤیکی تی پۊشی کو.", - "image_tip": "جانیا چارقر گرهڌاْ", - "media_tip": "جانیا هومپاٛیڤٱند", - "sig_tip": "اْمزا ایسا ڤا گاتدیساْ", - "hr_tip": "خٱت ٱوفوتی (کم ڤٱنین ڤا کار)", "summary": "چکستٱ:", "subject": "داسوݩ", "minoredit": "یو یٱ ڤیرایشد کۊچیراْ", diff --git a/languages/i18n/br.json b/languages/i18n/br.json index 2447773b71..1fffac0eaf 100644 --- a/languages/i18n/br.json +++ b/languages/i18n/br.json @@ -602,24 +602,6 @@ "resettokens-watchlist-token": "Jedouer evit lanvad web (Atom/RSS) [[Special:Watchlist|kemmañ pajennoù eus ho roll evezhiañ]]", "resettokens-done": "Jedoueroù adderaouekaet.", "resettokens-resetbutton": "Adderaouekaat ar jedoueroù diuzet", - "bold_sample": "Testenn dev", - "bold_tip": "Testenn dev", - "italic_sample": "Testenn italek", - "italic_tip": "Testenn italek", - "link_sample": "Liamm titl", - "link_tip": "Liamm diabarzh", - "extlink_sample": "http://www.example.com liamm titl", - "extlink_tip": "Liamm diavaez (na zisoñjit ket http://)", - "headline_sample": "Testenn istitl", - "headline_tip": "Istitl live 2", - "nowiki_sample": "Lakait an destenn anfurmadet amañ", - "nowiki_tip": "Na ober van ouzh ereadur ar wiki", - "image_sample": "Skouer.jpg", - "image_tip": "Skeudenn enframmet", - "media_sample": "Skouer.ogg", - "media_tip": "Liamm restr media", - "sig_tip": "Ho sinadur gant an deiziad", - "hr_tip": "Liamm a-led (arabat implijout re)", "summary": "Diverrañ :", "subject": "Danvez :", "minoredit": "Kemm dister", diff --git a/languages/i18n/bs.json b/languages/i18n/bs.json index d376b9e616..b08b2ec476 100644 --- a/languages/i18n/bs.json +++ b/languages/i18n/bs.json @@ -600,24 +600,6 @@ "resettokens-watchlist-token": "Token za web niz (Atom/RSS) [[Special:Watchlist|promjena na stranicama sa vaÅ¡eg spiska praćenja]]", "resettokens-done": "Žetoni su resetovani", "resettokens-resetbutton": "Resetuj izabrane žetone", - "bold_sample": "Podebljan tekst", - "bold_tip": "Podebljan tekst", - "italic_sample": "Kurzivan tekst", - "italic_tip": "Kurzivan tekst", - "link_sample": "Naslov linka", - "link_tip": "UnutraÅ¡nji link", - "extlink_sample": "http://www.example.com opis adrese", - "extlink_tip": "Vanjski link (zapamti prefiks http://)", - "headline_sample": "Naslov", - "headline_tip": "Podnaslov", - "nowiki_sample": "Dodaj neformatirani tekst ovdje", - "nowiki_tip": "Zanemari wikiformatiranje", - "image_sample": "ime_slike.jpg", - "image_tip": "Uklopljena slika", - "media_sample": "ime_medija_fajla.ogg", - "media_tip": "Putanja ka multimedijalnoj datoteci", - "sig_tip": "VaÅ¡ potpis s trenutnim vremenom", - "hr_tip": "Horizontalna linija (koristite oskudno)", "summary": "Sažetak:", "subject": "Tema:", "minoredit": "Ovo je manja izmjena", diff --git a/languages/i18n/btm.json b/languages/i18n/btm.json index cca63b2198..139fe92902 100644 --- a/languages/i18n/btm.json +++ b/languages/i18n/btm.json @@ -262,22 +262,6 @@ "botpasswords-label-needsreset": "(sandi porlu isitel mulak)", "botpasswords-needs-reset": "Hata sandi bot tu gorar bot \"$2\" ni {{GENDER:$1|user}} \"$1\" angkon na isitel mulak.", "passwordreset": "Gonti hata kunci", - "bold_sample": "Teks naapal", - "bold_tip": "Teks naapal", - "italic_sample": "Teks Italic", - "italic_tip": "Teks italic", - "link_sample": "Judul tautan", - "link_tip": "Pranala", - "extlink_sample": "http://www.example.com judul tautan", - "extlink_tip": "Tautan ruar (ingot http://prefix)", - "headline_sample": "Teks judul", - "headline_tip": "Judul tingkat 2", - "nowiki_sample": "Pamasuk teks naso iformat tuson", - "nowiki_tip": "Nangkon roaon pamformatan wiki", - "image_tip": "Berkas naisematkon", - "media_tip": "Tautan berkas", - "sig_tip": "Tekenanmu dot tando woktu", - "hr_tip": "Garis horizontal (pake dohot denggan)", "summary": "Ringkasan:", "minoredit": "On suntingan namenek", "watchthis": "Pamatai alamanon", diff --git a/languages/i18n/bto.json b/languages/i18n/bto.json index 62b9f078f4..d8ad3cdffd 100644 --- a/languages/i18n/bto.json +++ b/languages/i18n/bto.json @@ -301,7 +301,6 @@ "passwordreset-email": "Email address:", "changeemail": "Ribayan a email adres", "changeemail-none": "(uda)", - "extlink_sample": "http://www.example.com titulo kan link", "watchthis": "Silungon ading pahina", "blockednoreason": "udang binutang na rason", "nosuchsectiontitle": "diri maturakan a seksyon", diff --git a/languages/i18n/ca.json b/languages/i18n/ca.json index ba84f4ed69..bf8a682240 100644 --- a/languages/i18n/ca.json +++ b/languages/i18n/ca.json @@ -656,24 +656,6 @@ "resettokens-watchlist-token": "Testimoni del canal web (Atom/RSS) dels [[Special:Watchlist|canvis a la llista de seguiment]]", "resettokens-done": "S'han reiniciat els testimonis.", "resettokens-resetbutton": "Reinicia els testimonis seleccionats", - "bold_sample": "Text en negreta", - "bold_tip": "Text en negreta", - "italic_sample": "Text en cursiva", - "italic_tip": "Text en cursiva", - "link_sample": "Títol de l'enllaç", - "link_tip": "Enllaç intern", - "extlink_sample": "http://www.example.com títol de l'enllaç", - "extlink_tip": "Enllaç extern (recordeu el prefix http://)", - "headline_sample": "Text de l'encapçalament", - "headline_tip": "Encapçalat de secció de 2n nivell", - "nowiki_sample": "Inseriu ací text sense format", - "nowiki_tip": "Ignora el format wiki", - "image_sample": "Exemple.jpg", - "image_tip": "Fitxer incrustat", - "media_sample": "Exemple.ogg", - "media_tip": "Enllaç del fitxer", - "sig_tip": "La vostra signatura amb marca horària", - "hr_tip": "Línia horitzontal (feu-la servir amb moderació)", "summary": "Resum:", "subject": "Assumpte:", "minoredit": "Aquesta és una modificació menor", diff --git a/languages/i18n/cdo.json b/languages/i18n/cdo.json index b0b7e0185e..945690ab2c 100644 --- a/languages/i18n/cdo.json +++ b/languages/i18n/cdo.json @@ -477,23 +477,6 @@ "changeemail-none": "(無)", "changeemail-password": "汝其{{SITENAME}}密碼:", "changeemail-submit": "修改電批地址", - "bold_sample": "粗體文字", - "bold_tip": "粗體文字", - "italic_sample": "敧其文字", - "italic_tip": "敧其文字", - "link_sample": "鏈接標題", - "link_tip": "內部鏈接", - "extlink_sample": "http://www.example.com 鏈接標題", - "extlink_tip": "外部鏈接(記𡅏http:// 開頭)", - "headline_sample": "標題文字", - "headline_tip": "第二等標題", - "nowiki_sample": "敆嚽塊插入無格式其文本", - "nowiki_tip": "無察維基格式", - "image_tip": "嵌入其文件", - "media_sample": "Liê.ogg", - "media_tip": "文件鏈接", - "sig_tip": "汝其帶時間戳其簽名", - "hr_tip": "水平線(廮𡅏保護使其)", "summary": "總結:", "subject": "主題:", "minoredit": "過幼修改", diff --git a/languages/i18n/ce.json b/languages/i18n/ce.json index 050fac0aab..d2056c446d 100644 --- a/languages/i18n/ce.json +++ b/languages/i18n/ce.json @@ -545,24 +545,6 @@ "resettokens-watchlist-token": "Веб-каналан (Atom/RSS) токен [[Special:Watchlist|хьан тергаме могӀанан чура агӀонашна хийцамаш бар]]", "resettokens-done": "Токенаш кхиссина.", "resettokens-resetbutton": "Къастина токенаш кхоссар", - "bold_sample": "Йоза Ӏаьржа къастор", - "bold_tip": "Йоза Ӏаьржа къастор", - "italic_sample": "Курсиваца къастор", - "italic_tip": "Курсиваца къастор", - "link_sample": "Хьажориган коьрта могlа", - "link_tip": "Чоьхьа хьажорг", - "extlink_sample": "http://www.example.com хьажорг корта", - "extlink_tip": "Арахьара хьажорг (йиц ма йе хӀотталушерг http://)", - "headline_sample": "Йозан корта", - "headline_tip": "Корта 2-гlа локхаллийца", - "nowiki_sample": "Кхуза хӀоттаде хийца оьшуш доцу йоза", - "nowiki_tip": "Тергал ца бо вики-бáрамхlоттор", - "image_sample": "Example.jpg", - "image_tip": "Файл чуйиллар", - "media_sample": "Example.ogg", - "media_tip": "Хьажорг медиа-файлан тӀе", - "sig_tip": "Хьан куьгтаlор аъ хlоттина хан", - "hr_tip": "Ана сиз (сих сиха ма леладайша)", "summary": "Хийцамех лаьцна:", "subject": "ДӀахьедар/коьрта могӀа:", "minoredit": "Жима хийцам", @@ -617,7 +599,7 @@ "sitejspreview": "'''ХӀара хьалх хьажар ду, хӀара JavaScript-код.'''\n'''хӀинца Ӏалашйина яц!'''", "updated": "(Карла йаькхина)", "note": "'''Билгалдаккхар:'''", - "previewnote": "'''Дагахь дита хьайна! ХӀара деккъа хьалххе хьажар хилар.'''\nХьан хийцамаш хӀинца а дӀабазбина бац!.", + "previewnote": "'''Дагахь дита! ХӀара хьалххе хьажар хилар.'''\nХьан хийцамаш хӀинца а дӀабазбина бац!.", "continue-editing": "Кхин дӀа тадар", "session_fail_preview": "Сервер лара ца йира ахьа бина хийцамаш дӀаязба. Кхиъ цкъа а гӀортахь.\nНагахь санна хӀара гӀалат юха а далахь, [[Special:UserLogout|сеанс дӀа а къоьвлин]], юха а системин чугӀо.", "edit_form_incomplete": "'''Цхьайолу тадаран формаш серверан тӀекхаьчча яц. Тидаме хьажа хьай нисдарш доьхна дуй, ТӀакха южу гӀорта.'''", diff --git a/languages/i18n/ceb.json b/languages/i18n/ceb.json index 7e551689e4..f1f0ad8353 100644 --- a/languages/i18n/ceb.json +++ b/languages/i18n/ceb.json @@ -323,22 +323,6 @@ "pt-createaccount": "Paghimo og akawnt", "changepassword": "Usba ang pasword", "passwordreset": "Usba ang password", - "bold_sample": "Gilugom nga teksto", - "bold_tip": "Gilugom nga teksto", - "italic_sample": "Gitakilid nga teksto", - "italic_tip": "Gitakilid nga teksto", - "link_sample": "Titulo sa sumpay", - "link_tip": "Sumpay nga internal", - "extlink_sample": "http://www.example.com titulo sa sumpay", - "extlink_tip": "Sumpay sa gawas (hinumdomi http:// prefix)", - "headline_sample": "Teksto sa hedlayn", - "headline_tip": "Level 2 nga hedlayn", - "nowiki_sample": "Dinhi ang dili-pormaton nga teksto", - "nowiki_tip": "Dili i-wikipormat", - "image_tip": "Embedded nga payl", - "media_tip": "Sumpay sa payl", - "sig_tip": "Ang imong pirma uban ang takna", - "hr_tip": "Pahigda nga linya (palihog usahay ra gamita)", "summary": "Mubong sugid:", "subject": "Sabdyek/hedlayn:", "minoredit": "Ginagmay lang nga kausaban", diff --git a/languages/i18n/ch.json b/languages/i18n/ch.json index f4ca5e3c34..7126069bd6 100644 --- a/languages/i18n/ch.json +++ b/languages/i18n/ch.json @@ -281,21 +281,6 @@ "newpassword": "Password nuebu:", "retypenew": "Na'tekla nuebu na password:", "resetpass_submit": "Po'lo i password ya log in", - "bold_sample": "Tinige' potpot", - "bold_tip": "Tinige' potpot", - "italic_sample": "Tinige' mana'echong", - "italic_tip": "Tinige' mana'echong", - "link_sample": "Titulon inachetton", - "link_tip": "Inachetton sanhalom", - "extlink_sample": "http://www.example.com titulon inachetton", - "extlink_tip": "Inachetton sanhiyong (munga mamalefa ni http://)", - "headline_sample": "Tinige' i titulo mo'na", - "headline_tip": "Titulon nibet mina'dos", - "nowiki_tip": "Iknora i estrokturan wiki", - "image_tip": "Mana'halom na atkibu", - "media_tip": "Inachetton atkibu", - "sig_tip": "Fitma-mu yan i ora", - "hr_tip": "RÃ¥ya ni umadespatta (uho' fan)", "summary": "Sumaria:", "subject": "Suhetu/titulo mo'na:", "minoredit": "Dikike' este na tiniliaka", diff --git a/languages/i18n/ckb.json b/languages/i18n/ckb.json index e71e02f01c..4b93b9a808 100644 --- a/languages/i18n/ckb.json +++ b/languages/i18n/ckb.json @@ -184,7 +184,7 @@ "history": "مێژووی پەڕە", "history_short": "مێژووی پەڕە", "history_small": "مێژوو", - "updatedmarker": "لە دوایین سەردانمدا نوێ کراوەتەوە", + "updatedmarker": "لە دوایین سەردانتدا نوێکراوەتەوە", "printableversion": "وەشانی ئامادەی چاپ", "permalink": "بەستەری ھەمیشەیی", "print": "چاپ", @@ -454,7 +454,7 @@ "password-login-forbidden": "بەکارهێنانی ئەم ناوی بەکارهێنەر و تێپەڕەووشەیە قەدەغەکراوە.", "mailmypassword": "تێپەڕوشەکە ڕێک بخەوە", "passwordremindertitle": "تێپەڕوشەیەکی نوێی کاتی بۆ {{SITENAME}}", - "passwordremindertext": "کەسێک (لەوانەیە خۆت، لە ناونیشانی IPی $1ـەوە) داوای تێپەڕوشەیەکی نوێی کردووە بۆ {{SITENAME}} ($4). تێپەڕوشەیەکی کاتی بۆ بەکارھێنەر «$2» دروست کراوە و بە «$3» دانراوه. ئەگەر ئەمە داخوازی تۆ بووە، پێویستت بەوەیە ئێستا بچیتە ژوورەوە و تێپەڕوشەیەکی نوێ هەڵبژێریت. ماوەی‌ تێپەڕوشە کاتییەکەت لە {{PLURAL:$5|یەک ڕۆژدا|$5 ڕۆژدا}} بەسەر دەچێت.\n\nئەگەر کەسێکی تر ئەم داوایەی کردووە یان تێپەڕوشەکەت هاتووەتەوە بیرت و ئیدی پێویستت بە گۆڕینی نییە، دەتوانیت گوێ بەم پەیامە نەدەیت و لە تێپەڕوشە کۆنەکەت کەڵک وەربگریت.", + "passwordremindertext": "کەسێک (لە ناونیشانی IPی $1ـەوە) داوای تێپەڕوشەیەکی نوێی کردووە بۆ {{SITENAME}} ($4). تێپەڕوشەیەکی کاتی بۆ بەکارھێنەر «$2» دروست کراوە و بە «$3» دانراوه. ئەگەر ئەمە داخوازی تۆ بووە، پێویستت بەوەیە ئێستا بچیتە ژوورەوە و تێپەڕوشەیەکی نوێ هەڵبژێریت. ماوەی‌ تێپەڕوشە کاتییەکەت لە {{PLURAL:$5|یەک ڕۆژدا|$5 ڕۆژدا}} بەسەر دەچێت.\n\nئەگەر کەسێکی تر ئەم داوایەی کردووە یان تێپەڕوشەکەت هاتووەتەوە بیرت و ئیدی پێویستت بە گۆڕینی نییە، دەتوانیت گوێ بەم پەیامە نەدەیت و لە تێپەڕوشە کۆنەکەت کەڵک وەربگریت.", "noemail": "ھیچ ئەدرەسێکی ئیمەیل تۆمار نەکراوە بۆ بەکارھێنەر « $1 ».", "noemailcreate": "دەبێ ناونیشانێکی دروستی ئیمەیل بنووسی", "passwordsent": "تێپەڕوشەیەکی نوێ نێررا بۆ ئەدرەسی ئیمێلی تۆمارکراوی «$1».\nتکایە دوای وەرگرتنی، دیسان بچۆ ژوورەوە.", @@ -462,7 +462,7 @@ "eauthentsent": "ئیمێلێکی پشتڕاستکردنەوە بۆ ناونیشانی ئیمێلی دیاریکراو نێررا.\nپێش ئەوەی ئیمەیلی تر بۆ ئەم ھەژمارە بنێررێت، دەبێت پەیڕەوی ڕێکارەکانی ناو ئیمێلەکە بکەیت بۆ پشتڕاستکردنەوەی ئەوەی کە ئەم هەژمارە بە ڕاستی ھی تۆیە.", "throttled-mailpassword": "ئیمەیلێکی ڕیکخستنەوەی تێپەڕوشە لە ماوەی {{PLURAL:$1|ساعەت}}ی ڕابردوودا نێردراوە.\nبۆ ڕێگری لە بەکارھێنانی خراپ، ھەر {{PLURAL:$1|ساعەت}} تاکە یەک ئیمەیلی ڕیکخستنەوەی تێپەڕوشە دەنێردرێت.", "mailerror": "هەڵە ڕوویدا لە ناردنی ئیمەیل: $1", - "acct_creation_throttle_hit": "بینەرانی ویکی بەکەڵک وەرگرتن لەم ناونیشانی ئای-پییەی تۆ لە ڕۆژانی ڕابردوودا، دەستیان کردە بە درووست‌کردنی {{PLURAL:$1|هەژمارە}}، کە زۆرینە ڕیگەپێدان لە یەک ماوە‌دایە.\nوەک ئەنجامی ئەو ڕووداوە، ئەو بینەرانی لەم ئای‌پی ئەدرەسە کەڵک وەر دەگرن لەم کاتەدا ناتوانن هەژماری دیکە درووست‌بکەن.", + "acct_creation_throttle_hit": "بینەرانی ویکی بەکەڵک وەرگرتن لەم ناونیشانی ئای-پییەی تۆ دەستیان کردووە بە دروستکردنی {{PLURAL:$1|هەژمار}} لەدوایین $2، کە زۆرینە ڕیگەپێدان لەو ماوەیە.\nوەک ئەنجامی ئەو ڕووداوە، ئەو بینەرانی لەم ئای‌پی ئەدرەسە کەڵک وەر دەگرن لەم کاتەدا ناتوانن هەژماری دیکە درووست‌بکەن.", "emailauthenticated": "ناونیشانی ئیمەیلەکەت پشتڕاست کرایەوە لە $3ی $2دا.", "emailnotauthenticated": "ناونیشانی ئیمەیلەکەت ھێشتا پشتڕاست نەکراوتەوە.\nھیچ ئیمەیلێک بۆ ئەم تایبەتمەندییانەی ژێرەوە نانێردرێت.", "noemailprefs": "بۆ کەوتنە کاری ئەو تایبەتمەندیانە، لە هەڵبژاردەکانت ئەدرەسەکی ئی‌مێڵ دابین بکە.", @@ -512,9 +512,9 @@ "botpasswords-insert-failed": "نەتواندرا ناوی بۆت «$1» زیاد بکرێت. ئایا پێشووتر زیاد کراوە؟", "botpasswords-update-failed": "نەتواندرا ناوی بۆت «$1» نوێ بکرێتەوە. ئایا سڕدراوەتەوە؟", "botpasswords-created-title": "تێپەڕ وشەی بۆت دروست کرا", - "botpasswords-created-body": "تێپەڕوشەی بۆت بۆ بۆتی «$1» بەکارھێنەر «$2» دروست کرا.", + "botpasswords-created-body": "تێپەڕوشەی بۆت بۆ بۆتی «$1»ی {{GENDER:$2|بەکارھێنەر}} $2 دروست کرا.", "botpasswords-updated-title": "تێپەڕ وشەی بۆتەکە نوێ کرایەوە", - "botpasswords-updated-body": "تێپەڕ وشەی بۆت بۆ «$1»ی بەکارھێنەر «$2» نوێ کرایەوە.", + "botpasswords-updated-body": "تێپەڕ وشەی بۆت بۆ «$1»ی {{GENDER:$2|بەکارھێنەر}} «$2» نوێکرایەوە.", "botpasswords-deleted-title": "تێپەڕ وشەی بۆت سڕدرایەوە", "resetpass_forbidden": "تێپەڕوشەکە ناگۆڕدرێت", "resetpass-no-info": "بۆ گەیشتنی راستەوخۆ بەم پەڕە ئەشێ بچیتە ژوورەوە.", @@ -550,24 +550,6 @@ "changeemail-password": "تێپەڕوشەکەت لە {{SITENAME}}:", "changeemail-submit": "ئەمەیل بگۆڕە", "changeemail-nochange": "تکایە ناونیشانی ئیمەیڵێکی جیاواز بەکار بھێنە.", - "bold_sample": "دەقی ئەستوور", - "bold_tip": "دەقی ئەستوور", - "italic_sample": "دەقی لار", - "italic_tip": "دەقی لار", - "link_sample": "نێوی بەستەر", - "link_tip": "بەستەری ناوخۆ", - "extlink_sample": "http://www.example.com سەردێڕی بەستەر", - "extlink_tip": "بەستەری دەرەکی (لەبیرت بێ نووسینی پێشگری http:// )", - "headline_sample": "دەقی سەردێڕ", - "headline_tip": "سەردێڕی ئاست Û²", - "nowiki_sample": "لەگەرە دەقی نەڕازراو تێ‌بخە", - "nowiki_tip": "لەبەرچاو نەگرتنی دارشتنەکانی ویکی", - "image_sample": "نموونە.jpg", - "image_tip": "وێنەی نێو دەق", - "media_sample": "نموونە.ogg", - "media_tip": "لینکی پەڕگە", - "sig_tip": "واژووەکەت بە مۆری ڕێکەوتەوە", - "hr_tip": "هێڵی ئاسۆیی (دەگمەن بەکاری بێنە)", "summary": "کورتەی دەستکاری:", "subject": "بابەت:", "minoredit": "ئەمە دەستکارییەکی بچووکە", @@ -594,9 +576,9 @@ "subject-preview": "پێشبینینی بابەت:", "previewerrortext": "ھەڵەیەک دروست بوو لەکاتی ھەوڵدان بۆ بینینی دەستکارییەکانت.", "blockedtitle": "بەکارھێنەر بەربەست کراوە", - "blocked-email-user": "<strong>ھەژمارەکەت لە ناردنی پۆستی ئەلیکترۆنی بەربەستکراوە، بەڵام ھێشتا دەتوانیت دەستکاری پەڕە بکەیت لەم ویکییەدا.</strong> دەتوانیت وردەکارییەکانی بەربەستن لە [[Special:MyContributions|بەشدارییەکانی ھەژمار]] ببینیت.\n\nبەربەستنەکە لەلایەن $1 کراوە.\n\n* دەستپێکردنی بەربەستن: $8\n* بەسەرچوونی بەربەستن: $6\n* ھەژماری مەبەست: $7\n* پێناسی بەربەستن #$5", + "blocked-email-user": "<strong>ھەژمارەکەت لە ناردنی پۆستی ئەلیکترۆنی بەربەستکراوە، بەڵام ھێشتا دەتوانیت دەستکاری پەڕە بکەیت لەم ویکییەدا.</strong> دەتوانیت وردەکارییەکانی بەربەستن لە [[Special:MyContributions|بەشدارییەکانی ھەژمار]] ببینیت.\n\nبەربەستنەکە لەلایەن $1 کراوە.\n\nھۆکاری ئاماژەپێکراو بۆ بەربەستن: <em>$2</em>\n\n* دەستپێکردنی بەربەستن: $8\n* بەسەرچوونی بەربەستن: $6\n* ھەژماری مەبەست: $7\n* پێناسی بەربەستن #$5", "blockedtext-partial": "<strong>ھەژمارەکەت یان ناونیشانی ئایپیی ھەژمارەکەت لە دەستکاریکردنی ئەم پەڕەیە بەربەست کراوە، بەڵام ھێشتا دەتوانیت دەستکاری پەڕەکانی تری ئەم ویکییە بکەیت.</strong> دەتوانیت وردەکاری تەواوی بەربەستنەکە لە [[Special:MyContributions|بەشدارییەکانی ھەژمار]] ببینیت.\n\nبەربەستنەکە لەلایەن $1 ئەنجام دراوە.\n\nھۆکاری ئاماژە پێکراو بۆ بەربەستن: <em>$2</em>\n\n* دەستپێکردنی بەربەستن: $8\n* بەسەرچوونی بەربەستن: $6\n* ھەژماری مەبەست: $7\n* پێناسی بەربەستن #$5", - "blockedtext": "'''ناوی بەکارهێنەری یان ئای‌پی ئەدرەسی تۆ بەربەست‌ کراوە.'''\n\nبەربەست لە لایەن $1 کراوە.\nهۆکاری بەربەست کردن ''$2''ە.\n\n* دەستپێکی بەربەست‌کران: $8\n* کۆتایی هاتنی بەربەست‌کران: $6\n* بابەتی بەربەست: $7\n\nبۆ وتووێژ سەبارەت بە بەربەست‌کرانەکە دەبێ پەیوەندی بکەی بە $1 یان یەکێ دی لە [[{{MediaWiki:Grouppage-sysop}}|بەڕێوبەران]].\nلە بیرت بێ تاکوو ئیمەیل ئەدرەسێکی بڕوا پێ‌کراو لە [[Special:Preferences|ھەڵبژاردەکانی بەکارھێنەر]] ڕاچاو نەکەی، نابێت لە هەلی «ئیمەیل ناردن بۆ ئەم بەکارهێنەرە» کەڵک وەر بگری؛ کەڵک وەرگرتن لەوە بەربەست نەکراوە بۆت.\n\nئای‌پی ئەدرەسی ئێستای تۆ $3 و پێناسەی بەربەست‌کراو #$5.\nتکایە لە هەر پرس و داواکاریەکت‌دا هەموو وردەکاریەکانی سەرەوە بگونجێنە.", + "blockedtext": "<strong>ناوی بەکارهێنەری یان ئای‌پی ئەدرەسی تۆ بەربەست‌ کراوە.</strong>\n\nبەربەست لە لایەن $1 کراوە.\nهۆکاری بەربەست کردن <em>$2</em>ە.\n\n* دەستپێکی بەربەست‌کران: $8\n* کۆتایی هاتنی بەربەست‌کران: $6\n* بابەتی بەربەست: $7\n\nبۆ وتووێژ سەبارەت بە بەربەست‌کرانەکە دەبێ پەیوەندی بکەی بە $1 یان یەکێ دی لە [[{{MediaWiki:Grouppage-sysop}}|بەڕێوبەران]].\nلە بیرت بێ تاکوو ئیمەیل ئەدرەسێکی بڕوا پێ‌کراو لە [[Special:Preferences|ھەڵبژاردەکانی بەکارھێنەر]] ڕاچاو نەکەی، نابێت لە هەلی «ئیمەیل ناردن بۆ ئەم بەکارهێنەرە» کەڵک وەر بگری؛ کەڵک وەرگرتن لەوە بەربەست نەکراوە بۆت.\n\nئای‌پی ئەدرەسی ئێستای تۆ $3 و پێناسەی بەربەست‌کراو #$5.\nتکایە لە هەر پرس و داواکاریەکت‌دا هەموو وردەکاریەکانی سەرەوە بگونجێنە.", "autoblockedtext": "ناونیشانی IPی تۆ بە شێوەی خۆکارانە بەرگیری لێ کراوە چوونکە بەکارھێنەرێکی دیکە بە خراپی بە کاری ھێناوە و بە دەستی $1 بەرگیری لێ کراوە.\nبەم ھۆکارەوە:\n\n:<em>$2</em>\n\n* دەست پێ کردنی بەرگیری: $8\n* بە سەر چوونی بەرگیری: $6\n* Intended blockee: $7\n\nدەتوانیت پەیوەندی بکەیت بە $1 یان یەکێکی دیکە لە [[{{MediaWiki:Grouppage-sysop}}|بەڕێوەبەران]] بۆ وتووێژ لە سەر بەرگیرییەکە.\n\nتێ بگە کە ناتوانیت ئامرازی «ئیمێل بنێرە بۆ ئەم بەکارھێنەرە» بە کار بھێنیت مەگەر ئەوەی کە پێشتر لە [[Special:Preferences|ھەڵبژاردەکانی بەکارھێنەر]]تدا ناونیشانێکی گونجاوی ئیمێلت تۆمار کردبێت و بەرگیریت لێ نەکرابێت لە بەکارھێنانی ئەو ئامرازەش.\n\nناونیشانی IPی ئێستای تۆ $3ـە و پێناسەی یەرگیرییەکە #$5ـە.\nتکایە ھەموو وردەکارییەکانی سەرەوە ھەبێت لە ھەر پرس و داوایک کە دەیکەیت.", "systemblockedtext": "ھەژمارەکەت یان ئایپییەکەت بە شێوەیەکی خۆگەڕانە لەلایەن میدیاویکییەوە بەربەستکراوە. ھۆکاری بەربەستنەکە ئەمەیە: \n\n:<em>$2</em>\n\n* دەستپێکردنی بەربەستن: $8\n* بەسەرچوونی بەربەستن: $6\n* ھەژماری مەبەست: $7\n\nناونیشانی ئایپیی ئێستات پێکھاتووە لە $3.\nتکایە ئەم زانیارییانە لەکاتی داواکردنی یارمەتی دابنێ.", "blockednoreason": "هیچ هۆکارێک نەدراوە", @@ -727,7 +709,7 @@ "histfirst": "کۆنترین", "histlast": "نوێترین", "historysize": "({{PLURAL:$1|1 بایت|$1 بایت}})", - "historyempty": "(پووچ)", + "historyempty": "واڵا", "history-feed-title": "مێژووی پێداچوونەوەکان", "history-feed-description": "مێژووی پیاچوونەوە بۆ ئەم پەڕە لە ویکییەکە", "history-feed-item-nocomment": "$1 لە $2", @@ -1066,7 +1048,7 @@ "right-reupload-own": "بارکردنەوە لەسەر ئەو پەڕگانەی وا هەن و خۆی باری کردووە", "right-reupload-shared": "بارکردنی خۆماڵیی ئەو پەڕگانەی وا ھەن لەسەر خەزێنەی ھاوبەش", "right-upload_by_url": "بارکردنی پەڕگەکان لە ناونیشانێکی ئینتەرنێتی", - "right-purge": "واڵاکردنی کەشی پێگە بۆ پەڕەیەک بەبێ پشتڕاستکردنەوە", + "right-purge": "واڵاکردنی کەشی پێگە بۆ پەڕەیەک", "right-autoconfirmed": "کاریگەری وەرنەگرتن لە سنوورەکانی خێراییی ئایپی", "right-bot": "هەڵسوکەوت وەک پرۆسەیەکی خۆگەڕ", "right-nominornewtalk": "دەستکاریی بچووکی پەڕەی وتووێژ جۆرێک نەبێتە ھۆی دروستبوونی پەیامی نوێ", @@ -1133,7 +1115,7 @@ "grant-createaccount": "دروستکردنی ھەژمار", "grant-createeditmovepage": "دروستکردن، دەستکاریکردن و گواستنەوەی پەڕەکان", "grant-delete": "سڕینەوەی پەڕەکان، بەسەرداچوونەوەکان و لۆگەکان", - "grant-editmyoptions": "دەستکاریی ھەڵبژاردەکانی خۆت", + "grant-editmyoptions": "دەستکاریی ھەڵبژاردەکان و ڕێکخستنەکانی JSONت", "grant-editmywatchlist": "دەستکاریکردنی لیستی چاودێرییەکەت", "grant-editpage": "پەڕە ھەبووەکان دەستکاری بکە", "grant-editprotected": "پەڕە پارێزراوەکان دەستکاری بکە", @@ -1194,7 +1176,7 @@ "action-deletechangetags": "سڕینەوەی تاگەکان لە بنکەدراوەکەدا", "action-purge": "پاکسازی ئەم پەڕەیە بکە", "nchanges": "$1 {{PLURAL:$1|گۆڕانکاری}}", - "enhancedrc-since-last-visit": "$1 لە ماوەی دوایین سەردانەوە", + "enhancedrc-since-last-visit": "$1 {{PLURAL:$1|لە ماوەی دوایین سەردانەوە}}", "enhancedrc-history": "مێژوو", "recentchanges": "دوایین گۆڕانکارییەکان", "recentchanges-legend": "ھەڵبژاردەکانی دوایین گۆڕانکارییەکان", @@ -1220,12 +1202,12 @@ "rcfilters-activefilters-show": "نیشاندان", "rcfilters-advancedfilters": "پاڵوێنە پێشکەوتووەکان", "rcfilters-limit-title": "ئەنجام بۆ نیشاندان", - "rcfilters-limit-and-date-label": "$1 گۆڕانکاری، $2", + "rcfilters-limit-and-date-label": "$1 {{PLURAL:$1|گۆڕانکاری}}، $2", "rcfilters-date-popup-title": "ماوە بۆ گەڕان", "rcfilters-days-title": "ڕۆژ", "rcfilters-hours-title": "کاتژمێر", "rcfilters-days-show-days": "$1 {{PLURAL:$1|ڕۆژ}}", - "rcfilters-days-show-hours": "$1 سەعات", + "rcfilters-days-show-hours": "$1 {{PLURAL:$1|کاتژمێر}}", "rcfilters-highlighted-filters-list": "ڕووناککراو: $1", "rcfilters-quickfilters": "پاڵوێنە پاشەکەوتکراوەکان", "rcfilters-quickfilters-placeholder-title": "ھیچ پاڵوێنەیەک پاشەکەوت نەکراوە", @@ -1243,12 +1225,12 @@ "rcfilters-savedqueries-add-new-title": "پاشەکەوتکردنی ھەڵبژاردەکانی پاڵوێنەکەی ئێستا", "rcfilters-restore-default-filters": "ھێنانەوەی پاڵوێنە بنچینەییەکان", "rcfilters-clear-all-filters": "ھەموو فیلتەرەکان بسڕەوە", - "rcfilters-show-new-changes": "نیشاندانی نوێترین دەستکارییەکان", - "rcfilters-search-placeholder": "پاڵاوتنی گۆڕانکارییە نوێیەکان (بگەڕێ یان دەست بە نووسین بکە)", + "rcfilters-show-new-changes": "نیشاندانی گۆڕانکارییە نوێیەکان لە $1", + "rcfilters-search-placeholder": "گۆڕانکارییەکان بپاڵێوە (لیست بەکاربھێنە یان بگەڕێ بەدوای ناوی پاڵێوراو)", "rcfilters-empty-filter": "ھیچ پاڵوێنەیەک چالاک نییە. ھەموو بەشدارییەکان نیشان دەدرێن.", "rcfilters-filterlist-title": "پاڵێوکەکان", "rcfilters-filterlist-whatsthis": "ئەمە چۆن کاردەکات؟", - "rcfilters-filterlist-feedbacklink": "ڕای خۆتمان پێ بڵێ لەسەر ئەم ئامرازە نوێیانە", + "rcfilters-filterlist-feedbacklink": "ڕای خۆتمان پێ بڵێ لەسەر ئەم ئامرازی پاڵاوتنانە", "rcfilters-highlightbutton-title": "ئەنجامەکان ڕووناک بکە", "rcfilters-highlightmenu-title": "ڕەنگێکی نوێ ھەڵبژێرە", "rcfilters-filtergroup-authorship": "بەشدارییەکان", @@ -1307,9 +1289,9 @@ "rcfilters-watchlist-markseen-button": "ھەموو گۆڕانکارییەکان وەک بینراو نیشان بکە", "rcfilters-watchlist-edit-watchlist-button": "دەستکاریکردنی پێڕستی پەڕە چاودێریکراوەکانت", "rcfilters-watchlist-showupdated": "ئەو پەڕانەی دەستکاریکراون و لەکاتی دەستکاریکردنەکەوە سەردانت نەکردوونەتەوە بە <strong>تۆخ</strong> دەردەکەون، بە نیشانی پڕکراوەوە.", - "rcfilters-preference-label": "گەڕاندنەوەی وەشانی نوێی دوایین گۆڕانکارییەکان", + "rcfilters-preference-label": "ڕووکاری بێ جاڤاسکریپت بەکاربھێنە", "rcfilters-preference-help": "ئەم ھەڵبژاردەیە وەشانی نوێی ڕووکار و ھەموو ئامرازەکانی لەو کاتەوە زیاد کراون دەگەڕێنێتەوە.", - "rcfilters-watchlist-preference-label": "شاردنەوەی وەشانی نوێی پێڕستی چاودێری", + "rcfilters-watchlist-preference-label": "ڕووکاری بێ جاڤاسکریپت بەکاربھێنە", "rcfilters-watchlist-preference-help": "ئەم ھەڵبژاردەیە وەشانی نوێی ڕووکار و ھەموو ئامرازەکانی لەو کاتەوە زیاد کراون دەگەڕێنێتەوە.", "rcnotefrom": "ژێرەوە {{PLURAL:$5|گۆڕانکارییەکەیە|گۆڕانکارییەکانە}} لە <strong>$3، $4</strong>ەوە (ھەتا <strong>$1</strong> نیشان دراوە).", "rclistfromreset": "گەڕاندنەوەی ھەڵبژاردەی بەروار", @@ -1369,8 +1351,8 @@ "upload-recreate-warning": "'''ھۆشیار بە: پەرگەیەک بەو ناوەوە سڕاوەتەوە یان گوێزاوەتەوە.'''\n\nلۆگی سڕینەوە یان گواستنەوەی ئەم پەڕە لێرە لەبەردەستدایە:", "uploadtext": "فۆرمی خوارەوە بەکاربێنە بۆ بارکردنی پەڕگەکان.\nبۆ بینینی و گەڕان لەو پەڕگانەی پێشتر بار کراون، بڕۆ بۆ [[Special:FileList|لیستی پەڕگە بارکراوەکان]]، ھەروەھا [[Special:Log/upload|ڕەشنووسی بارکردنەکان]] و [[Special:Log/delete|ڕەشنووسی سڕینەوەکان]].\n\nبۆ بەکارھێنانی پەڕگەیەک لە پەڕەیەکدا، بەستەرێک بە یەکێک لەم شێوازانەی خوارەوە بە کار بێنە:\n* '''<code><nowiki>[[</nowiki>{{ns:file}}<nowiki>:File.jpg]]</nowiki></code>''' بۆ بەکارهێنانی وەشانی تەواوی پەڕگە\n* '''<code><nowiki>[[</nowiki>{{ns:file}}<nowiki>:File.png|200px|thumb|left|دەقی جێگر]]</nowiki></code>''' بۆ بەکارهێنانی نمایشێکی بە پانتایی ٢٠٠ پیکسەڵ لە چوارچێوەیەک لە لای چەپەوە بە «دەقی جێگر» وەک شرۆڤە\n* '''<code><nowiki>[[</nowiki>{{ns:media}}<nowiki>:File.ogg]]</nowiki></code>''' بۆ بەستەرپێدان بە پەڕگەکە بێ نیشاندانی خودی پەڕگەکە", "upload-permitted": "جۆرە پەڕگە {{PLURAL:$2|ڕێگەپێدراوەکە|ڕێگەپێدراوەکان}}: $1.", - "upload-preferred": "جۆرە پەڕگانەی بە باشتر دەزانرێن: $1.", - "upload-prohibited": "جۆرە پەڕگانەی قەدەغە کراون: $1.", + "upload-preferred": "جۆرە پەڕگە {{PLURAL:$2|ڕێگەپێدراوەکە|ڕێگەپێدراوەکان}}: $1.", + "upload-prohibited": "جۆرە پەڕگە {{PLURAL:$2|قەدەغەکراوەکە|قەدەغەکراوەکان}}: $1.", "uploadlogpage": "لۆگی بارکردن", "uploadlogpagetext": "لەخوارەوە لیستی دوایین بارکراوەکان دەبینی.\nبۆ ئەوەی چاوێکیان لێ بکەی، [[Special:NewFiles|گالەری پەڕگە نوێکان]] ببینە.", "filename": "ناوی پەڕگە", @@ -1901,7 +1883,7 @@ "rollback-success": "دەستکارییەکانی $1 وەرگێرایەوە؛<br />\nگۆڕدرا بۆ دوایین پێداچوونەوەی $2.", "sessionfailure": "لەوەدەچی کێشەیەک لە دانیشتنی چوونەژوورەوەت (login session)دا ببێت.\nئەم کردەوە هەڵوەشێندرایەوە بۆ بەرگری لە دزینی دراوەکانی دانیشتن.\nتکایە بگەڕێوە بۆ پەڕەی پێشوو و نوێی بکەوە، ئینجا دیسان تاقیی بکەوە.", "changecontentmodel-legend": "گۆڕینی مۆدێلی ناوەڕۆک", - "changecontentmodel-title-label": "سەرناوی پەڕە", + "changecontentmodel-title-label": "سەرناوی پەڕە:", "changecontentmodel-reason-label": "هۆکار:", "changecontentmodel-submit": "گۆڕین", "log-name-contentmodel": "لۆگی گۆڕینی مۆدێلی ناوەڕۆک", diff --git a/languages/i18n/co.json b/languages/i18n/co.json index 2559468d00..c3fd6fd4c4 100644 --- a/languages/i18n/co.json +++ b/languages/i18n/co.json @@ -224,20 +224,6 @@ "pt-userlogout": "Scunnessione", "retypenew": "Scrive torna a nova parulla secreta:", "resetpass-submit-cancel": "Cancillà", - "bold_sample": "Grassettu", - "bold_tip": "Grassettu", - "italic_sample": "Italicu", - "italic_tip": "Italicu", - "link_sample": "Titulu di u ligame", - "link_tip": "Ligame internu", - "extlink_sample": "http://www.example.com tìtulu di ligame", - "extlink_tip": "Ligamu esternu (cù u prefissu http:// )", - "headline_sample": "Testu di intestatura", - "headline_tip": "Intestamentu di 2° livellu", - "nowiki_sample": "Inserisce quì u testu micca furmattatu", - "nowiki_tip": "Ignurà a furmattazione wiki", - "image_sample": "Esempiu.jpg", - "hr_tip": "Linia orizuntale (da imprudà incù ghjudiziu)", "summary": "sommariu", "minoredit": "Hè una mudifica minore", "watchthis": "Fighjulà 'ssa pagina", diff --git a/languages/i18n/cps.json b/languages/i18n/cps.json index ff9ef93141..c65ddb0a1c 100644 --- a/languages/i18n/cps.json +++ b/languages/i18n/cps.json @@ -328,22 +328,6 @@ "resetpass_forbidden": "Indi pwede ma-islan ang password", "resetpass-no-info": "Nakasulod ka dapat para makadtu-an ang mini nga pahina sang diretso.", "resetpass-temp-password": "Temporaryo nga password:", - "bold_sample": "Madukot nga teksto", - "bold_tip": "Madukot nga teksto", - "italic_sample": "Gahilay nga teksto", - "italic_tip": "Gahilay nga teksto", - "link_sample": "Titulo sang link", - "link_tip": "Sa sulod nga link", - "extlink_sample": "http://www.example.com titulo nga link", - "extlink_tip": "Halin sa gwa nga link (tandaan ang http:// nga prefiks)", - "headline_sample": "Teksto sang pangulong-dinalan", - "headline_tip": "Lebel 2 pangulong-dinalan", - "nowiki_sample": "Isal-ot ang wala na-format nga teksto diya", - "nowiki_tip": "Pabay-an ang wiki nga sulundan", - "image_tip": "Ginpilit nga file", - "media_tip": "Link sa file", - "sig_tip": "Imo pirma upod sang timestamp", - "hr_tip": "Gapahigda nga linya (gamiton sang laka)", "summary": "Kabilugan:", "subject": "Ginatukoy/pangulong-dinalan:", "minoredit": "Ini gamay nga pag-ilis", diff --git a/languages/i18n/crh-cyrl.json b/languages/i18n/crh-cyrl.json index b81a67fd7a..51cdddcaa8 100644 --- a/languages/i18n/crh-cyrl.json +++ b/languages/i18n/crh-cyrl.json @@ -400,24 +400,6 @@ "resetpass-submit-cancel": "Лягъу", "resetpass-wrong-oldpass": "Рухсетсиз мувакъкъат я да шимдики пароль.\nПаролинъизни энди мувафакъиетнен денъиштирдинъиз я да янъы бир мувакъкъат пароль истединъиз.", "resetpass-temp-password": "Мувакъкъат пароль:", - "bold_sample": "Къалын язылыш", - "bold_tip": "Къалын язылыш", - "italic_sample": "Италик (курсив) язылыш", - "italic_tip": "Италик (курсив) язылыш", - "link_sample": "Саифенинъ серлевасы", - "link_tip": "Ички багъланты", - "extlink_sample": "http://www.example.com саифенинъ серлевасы", - "extlink_tip": "Тыш багъланты (Адрес огюне http:// къоймагъа унутманъыз)", - "headline_sample": "Серлева язысы", - "headline_tip": "2-нджи севие серлева", - "nowiki_sample": "Сербест формат метининъизни мында язынъыз.", - "nowiki_tip": "вики формат этювини игнор эт", - "image_sample": "Resim.jpg", - "image_tip": "Эндирильген файл", - "media_sample": "Ses.ogg", - "media_tip": "Медиа файлына багъланты", - "sig_tip": "Имзанъыз ве тарих", - "hr_tip": "Горизонталь сызыкъ (пек сыкъ къулланманъыз)", "summary": "Денъиштирменинъ къыскъа тарифи:", "subject": "Мевзу:", "minoredit": "Бу, кичик денъиштирмедир", diff --git a/languages/i18n/crh-latn.json b/languages/i18n/crh-latn.json index e0326c5c0a..597afd26b8 100644 --- a/languages/i18n/crh-latn.json +++ b/languages/i18n/crh-latn.json @@ -397,24 +397,6 @@ "resetpass-submit-cancel": "Lâğu", "resetpass-wrong-oldpass": "Ruhsetsiz muvaqqat ya da şimdiki parol.\nParoliñizni endi muvafaqiyetnen deñiştirdiñiz ya da yañı bir muvaqqat parol istediñiz.", "resetpass-temp-password": "Muvaqqat parol:", - "bold_sample": "Qalın yazılış", - "bold_tip": "Qalın yazılış", - "italic_sample": "Ä°talik (kursiv) yazılış", - "italic_tip": "Ä°talik (kursiv) yazılış", - "link_sample": "Saifeniñ serlevası", - "link_tip": "İçki bağlantı", - "extlink_sample": "http://www.example.com saifeniñ serlevası", - "extlink_tip": "Tış bağlantı (Adres ögüne http:// qoymağa unutmañız)", - "headline_sample": "Serleva yazısı", - "headline_tip": "2-nci seviye serleva", - "nowiki_sample": "Serbest format metiniñizni mında yazıñız.", - "nowiki_tip": "viki format etüvini ignor et", - "image_sample": "Resim.jpg", - "image_tip": "Endirilgen fayl", - "media_sample": "Ses.ogg", - "media_tip": "Media faylına bağlantı", - "sig_tip": "Ä°mzañız ve tarih", - "hr_tip": "Gorizontal sızıq (pek sıq qullanmañız)", "summary": "Deñiştirmeniñ qısqa tarifi:", "subject": "Mevzu:", "minoredit": "Bu, kiçik deñiştirmedir", diff --git a/languages/i18n/cs.json b/languages/i18n/cs.json index e8c22b492d..884bd4df82 100644 --- a/languages/i18n/cs.json +++ b/languages/i18n/cs.json @@ -45,7 +45,8 @@ "Jaroslav Cerny", "Slepi", "Tchoř", - "SimonV" + "SimonV", + "MrJaroslavik" ] }, "tog-underline": "Podtrhávat odkazy:", @@ -63,7 +64,7 @@ "tog-watchmoves": "Přidávat mnou přesouvané stránky a soubory mezi sledované", "tog-watchdeletion": "Přidávat stránky a soubory, které smažu, mezi sledované", "tog-watchuploads": "Přidávat mnou načtené soubory ke sledovaným", - "tog-watchrollback": "Přidávat stránky, které jsem {{GENDER:|vrátil|vrátila}} zpět, ke sledovaným", + "tog-watchrollback": "Přidávat stránky, kde jsem {{GENDER:|použil|použila}} vrácení zpět, ke sledovaným", "tog-minordefault": "Označovat editace implicitně jako malé", "tog-previewontop": "Zobrazovat náhled před editačním oknem (ne za ním)", "tog-previewonfirst": "Zobrazit při první editaci náhled", @@ -91,7 +92,8 @@ "tog-norollbackdiff": "Po vrácení změny nezobrazovat porovnání rozdílů", "tog-useeditwarning": "Upozornit, když budu opouÅ¡tět editaci bez uložení změn", "tog-prefershttps": "Po přihlášení vždy používat zabezpečené připojení", - "tog-showrollbackconfirmation": "Při kliknutí na odkaz pro vrácení editace zobrazit žádost o potvrzení", + "tog-showrollbackconfirmation": "Při kliknutí na odkaz pro rychlý revert zobrazit žádost o potvrzení", + "tog-requireemail": "Pro obnovu hesla vyžadovat e-mail", "underline-always": "Vždy", "underline-never": "Nikdy", "underline-default": "Podle nastavení prohlížeče nebo vzhledu", @@ -167,7 +169,7 @@ "category_header": "Stránky v kategorii „$1“", "subcategories": "Podkategorie", "category-media-header": "Soubory v kategorii „$1“", - "category-empty": "''Tato kategorie neobsahuje žádné stránky či soubory.''", + "category-empty": "<em>Tato kategorie neobsahuje žádné stránky či soubory.</em>", "hidden-categories": "{{PLURAL:$1|Skrytá kategorie|Skryté kategorie|Skryté kategorie}}", "hidden-category-category": "Skryté kategorie", "category-subcat-count": "{{PLURAL:$2|V této kategorii je pouze následující podkategorie.|{{PLURAL:$1|Zobrazuje se jedna podkategorie|Zobrazují se $1 podkategorie|Zobrazuje se $1 podkategorií}} z celkového počtu $2 podkategorií v této kategorii.|{{PLURAL:$1|Zobrazuje se jedna podkategorie|Zobrazují se $1 podkategorie|Zobrazuje se $1 podkategorií}} z celkového počtu $2 podkategorií v této kategorii.}}", @@ -465,7 +467,7 @@ "createaccountmail": "Použít dočasné náhodné heslo a odeslat ho na uvedenou e-mailovou adresu", "createaccountmail-help": "Lze využít k založení účtu pro jinou osobu bez prozrazení hesla.", "createacct-realname": "Skutečné jméno (nepovinné)", - "createacct-reason": "Důvod", + "createacct-reason": "Důvod (veřejně zaznamenaný)", "createacct-reason-ph": "Proč si vytváříte další účet", "createacct-reason-help": "Zpráva zobrazená v knize nových uživatelů", "createacct-submit": "Vytvořit účet", @@ -633,24 +635,6 @@ "resettokens-watchlist-token": "Klíč k webovému kanálu (Atom/RSS) [[Special:Watchlist|změn sledovaných stránek]]", "resettokens-done": "Klíče reinicializovány", "resettokens-resetbutton": "Reinicializovat vybrané klíče", - "bold_sample": "Tučný text", - "bold_tip": "Tučný text", - "italic_sample": "Kurzíva", - "italic_tip": "Kurzíva", - "link_sample": "Název odkazu", - "link_tip": "Vnitřní odkaz", - "extlink_sample": "http://www.example.com Titulek odkazu", - "extlink_tip": "Externí odkaz (nezapomeňte na předponu http://)", - "headline_sample": "Text nadpisu", - "headline_tip": "Nadpis druhé úrovně", - "nowiki_sample": "Sem vložte neformátovaný text", - "nowiki_tip": "Ignorovat formátování wiki", - "image_sample": "Příklad.jpg", - "image_tip": "Soubor", - "media_sample": "Příklad.ogg", - "media_tip": "Odkaz na mediální soubor", - "sig_tip": "Váš podpis s datem a časem", - "hr_tip": "Vodorovná čára (používejte střídmě)", "summary": "Shrnutí editace:", "subject": "Předmět:", "minoredit": "Tato změna je malá editace.", @@ -684,6 +668,8 @@ "systemblockedtext": "VaÅ¡e IP adresa byla automaticky zablokována softwarem MediaWiki.\nUdaný důvod blokování:\n\n:<em>$2</em>\n\n* Začátek blokování: $8\n* Konec blokování: $6\n* Původně blokovaný uživatel: $7\n\nVaÅ¡e současná IP adresa je $3.\nProsíme, uveďte tyto údaje při komunikaci se správci.", "blockednoreason": "důvod nebyl zadán", "blockedtext-composite": "<strong>VaÅ¡e uživatelské jméno nebo IP adresa byla zablokována.</strong>\n\nUdaný důvod blokování:\n\n:<em>$2</em>\n\n* Začátek blokování: $8\n* Konec nejdelšího blokování: $6\n\n* $5\n\nVaÅ¡e současná IP adresa je $3.\nProsíme, uveďte tyto údaje při komunikaci se správci.", + "blockedtext-composite-ids": "Odpovídající ID bloku: $1 (může být zablokována také vaÅ¡e IP adresa)", + "blockedtext-composite-no-ids": "VaÅ¡e IP adresa se objevuje na několika černých listinách", "blockedtext-composite-reason": "Na váš účet a/nebo vaÅ¡i IP adresu se vztahuje více blokování.", "whitelistedittext": "Pro editaci se musíte $1.", "confirmedittext": "Pro editaci stránek je vyžadováno potvrzení vaší e-mailové adresy.\nNa stránce [[Special:Preferences|nastavení]] zadejte a nechte potvrdit svou e-mailovou adresu.", @@ -754,6 +740,8 @@ "nocreate-loggedin": "Nemáte povoleno zakládat nové stránky.", "sectioneditnotsupported-title": "Editace sekcí není podporována", "sectioneditnotsupported-text": "Na této editační stránce není podporována editace jedné sekce.", + "modeleditnotsupported-title": "Editace není podporována", + "modeleditnotsupported-text": "Pro model obsahu $1 není podporována editace.", "permissionserrors": "Chyba povolení", "permissionserrorstext": "Nemáte povoleno toto provést z {{PLURAL:$1|následujícího důvodu|následujících důvodů|následujících důvodů}}:", "permissionserrorstext-withaction": "Z {{PLURAL:$1|následujícího důvodu|následujících důvodů}} nemáte oprávnění $2:", @@ -1010,6 +998,8 @@ "search-interwiki-more": "(více)", "search-interwiki-more-results": "další výsledky", "search-relatedarticle": "Související", + "search-invalid-sort-order": "Řazení $1 není známo, použije se výchozí řazení. Platná řazení jsou: $2", + "search-unknown-profile": "Vyhledávací profil $1 není znám, použije se výchozí profil.", "searchrelated": "související", "searchall": "vÅ¡e", "showingresults": "Níže zobrazuji nejvýše <strong>$1</strong> {{PLURAL:$1|výsledek|výsledky|výsledků}} počínaje od <strong>$2</strong>.", @@ -1124,6 +1114,7 @@ "prefs-help-email": "Uvedení e-mailu není povinné, ale umožní zaslání nového hesla v případě, že své heslo zapomenete.", "prefs-help-email-others": "Také můžete dovolit ostatním uživatelům vás prostřednictvím uživatelské stránky kontaktovat.\nVaÅ¡e adresa v takovém případě není prozrazena.", "prefs-help-email-required": "Je vyžadována e-mailová adresa.", + "prefs-help-requireemail": "Pokud je zaÅ¡krtnuto, e-mail pro obnovu hesla se zaÅ¡le jen v případě, že osoba žádající o nové heslo uvede jak uživatelské jméno, tak e-mail tohoto účtu.", "prefs-info": "Základní údaje", "prefs-i18n": "Lokalizace", "prefs-signature": "Podpis", @@ -1761,6 +1752,8 @@ "backend-fail-contenttype": "Nelze určit typ obsahu souboru k uložení do „$1“.", "backend-fail-batchsize": "Koncový úložný systém přijal dávku s $1 {{PLURAL:$1|souborovou operací|souborovými operacemi}}; limit je {{PLURAL:$2|jedna operace|$2 operace|$2 operací}}.", "backend-fail-usable": "Nepodařilo se zapsat do souboru „$1“ kvůli nedostatečným oprávněním nebo chybějícím adresářům/kontejnerům.", + "backend-fail-stat": "Nepodařilo se načíst stav souboru „$1“.", + "backend-fail-hash": "Nepodařilo se určit kryptografický haÅ¡ souboru „$1“.", "filejournal-fail-dbconnect": "Nelze se připojit k žurnálové databázi pro koncový úložný systém „$1“.", "filejournal-fail-dbquery": "Nepodařilo se aktualizovat žurnálovou databázi pro koncový úložný systém „$1“.", "lockmanager-notlocked": "Soubor „$1“ nelze odemknout, neboÅ¥ není zamčen.", @@ -1840,6 +1833,7 @@ "listfiles-userdoesnotexist": "Uživatelský účet „$1“ není zaregistrován.", "imgfile": "soubor", "listfiles": "Seznam souborů", + "listfiles_subpage": "Soubory {{GENDER:$1|uživatele|uživatelky}} $1", "listfiles_thumb": "Náhled", "listfiles_date": "Datum", "listfiles_name": "Název", @@ -2574,6 +2568,7 @@ "ipblocklist-legend": "Hledat zablokovaného uživatele", "blocklist-userblocks": "Skrýt zablokované účty", "blocklist-tempblocks": "Skrýt dočasná zablokování", + "blocklist-indefblocks": "Skrýt zablokování do odvolání", "blocklist-addressblocks": "Skrýt blokování jedné IP adresy", "blocklist-type": "Typ:", "blocklist-type-opt-all": "VÅ¡e", @@ -3854,6 +3849,8 @@ "linkaccounts": "Propojení účtů", "linkaccounts-success-text": "Účet byl propojen.", "linkaccounts-submit": "Propojit účty", + "cannotunlink-no-provider-title": "Žádné propojené účty k rozpojení", + "cannotunlink-no-provider": "Neexistují žádné propojené účty, které by bylo možno rozpojit.", "unlinkaccounts": "ZruÅ¡ení propojení účtů", "unlinkaccounts-success": "Propojení účtu bylo zruÅ¡eno.", "authenticationdatachange-ignored": "Změna autentizačních údajů nebyla zpracována. Možná není nakonfigurován žádný poskytovatel?", diff --git a/languages/i18n/csb.json b/languages/i18n/csb.json index 88dcf0e2a3..a813722c61 100644 --- a/languages/i18n/csb.json +++ b/languages/i18n/csb.json @@ -409,24 +409,6 @@ "resetpass-submit-cancel": "Anulujë", "passwordreset": "Zresëtëjë parolã", "passwordreset-username": "Pòzwa brëkòwnika", - "bold_sample": "Wëtłëszczony drëk", - "bold_tip": "Wëtłëszczony drëk", - "italic_sample": "Ùchëłi tekst", - "italic_tip": "Ùchëłi tekst (italic)", - "link_sample": "Titel lënka", - "link_tip": "Bënowi lënk", - "extlink_sample": "http://www.example.com titel lënka", - "extlink_tip": "Bùtnowi lënk (pamiãtôj ò http:// prefiks)", - "headline_sample": "Tekst nadgłówka", - "headline_tip": "Nadgłówk 2 lédżi", - "nowiki_sample": "Wstawi tuwò niesfòrmatowóny tekst", - "nowiki_tip": "Jignorëjë wiki-fòrmatowanié", - "image_sample": "Przëmiôr.jpg", - "image_tip": "Òbsôdzony lopk (n.p. òbrôzk)", - "media_sample": "Przëmiôr.ogg", - "media_tip": "Lënk lopka", - "sig_tip": "Twój pòdpisënk z datumã a czasã", - "hr_tip": "Hòrizontalnô linijô (brëkùjë szpórowno)", "summary": "Pòdrechòwanié:", "subject": "Téma:", "minoredit": "To je drobnô edicjô", diff --git a/languages/i18n/cu.json b/languages/i18n/cu.json index b59502d9e0..2c3c6c51fd 100644 --- a/languages/i18n/cu.json +++ b/languages/i18n/cu.json @@ -258,14 +258,6 @@ "passwordreset": "нова таина слова оуставлѥниѥ", "passwordreset-username": "польꙃєватєлꙗ имѧ :", "changeemail-none": "(нѣстъ)", - "link_sample": "съвѧꙁи имѧ", - "link_tip": "вънѫтрьнꙗ съвѧꙁь", - "extlink_sample": "http://www.example.com съвѧꙁи имѧ", - "extlink_tip": "вънѣщьнꙗ съвѧꙁь (помьни о http://)", - "headline_sample": "тїтла напьсаниѥ", - "headline_tip": "тїтлъ рѧда В҃", - "media_tip": "дѣла съвѧꙁь", - "sig_tip": "твои аѵтографъ и нꙑнѣшьна врѣмѧ и дьнь", "summary": "опьсаниѥ :", "subject": "ѳєма :", "minoredit": "малаꙗ мѣна", diff --git a/languages/i18n/cv.json b/languages/i18n/cv.json index 70eb32857e..b989ec2e72 100644 --- a/languages/i18n/cv.json +++ b/languages/i18n/cv.json @@ -331,22 +331,6 @@ "passwordreset-domain": "Домен:", "changeemail-none": "(çук)", "resettokens": "Токенĕсене пăрах", - "bold_sample": "Çурмахулăм текст", - "bold_tip": "Çурмахулăм текст", - "italic_sample": "Тайлăк текст", - "italic_tip": "Тайлăк текст", - "link_sample": "Каçăн ячĕ", - "link_tip": "Шалти каçă", - "extlink_sample": "http://www.example.com каçăн ячĕ", - "extlink_tip": "Тулаш каçи (http:// префикс çинчен ан манăр)", - "headline_sample": "Пуçелĕк", - "headline_tip": "Иккĕмĕш шайри ят", - "nowiki_sample": "Кунта фотматламан текста кĕртĕр.", - "nowiki_tip": "Вики-ĕрешлевне пăхмалла мар", - "image_tip": "Кĕртсе лартнă ӳкерчĕк", - "media_tip": "Медиа-файл çине каçă", - "sig_tip": "Сирĕн алă пусни тата вăхăт", - "hr_tip": "Горизонтальлĕ йĕр (сахалтарах усă курăр)", "summary": "Улăштарнисене ăнлантарни:", "subject": "Тема:", "minoredit": "Пĕчĕк улшăну", diff --git a/languages/i18n/cy.json b/languages/i18n/cy.json index fc9a9bd73d..b4c894223d 100644 --- a/languages/i18n/cy.json +++ b/languages/i18n/cy.json @@ -582,24 +582,6 @@ "resettokens-watchlist-token": "Tocyn i borthiant gwe (Atom/RSS) y [[Special:Watchlist|newidiadau i'r tudalennau ar eich rhestr wylio]]", "resettokens-done": "Ailosodwyd y tocynnau.", "resettokens-resetbutton": "Ailosoder y tocynnau a ddewiswyd", - "bold_sample": "Testun cryf", - "bold_tip": "Testun cryf", - "italic_sample": "Testun italig", - "italic_tip": "Testun italig", - "link_sample": "Teitl y cyswllt", - "link_tip": "Cyswllt mewnol", - "extlink_sample": "http://www.example.com teitl y cyswllt", - "extlink_tip": "Cyswllt allanol (cofiwch y rhagddodiad http:// )", - "headline_sample": "Testun pennawd", - "headline_tip": "Pennawd lefel 2", - "nowiki_sample": "Rhowch destun di-fformatedig yma", - "nowiki_tip": "Anwybyddu'r gystrawen wici", - "image_sample": "Enghraifft.jpg", - "image_tip": "Ffeil mewnosodol", - "media_sample": "Example.ogg", - "media_tip": "Cyswllt ffeil media", - "sig_tip": "Eich llofnod gyda stamp amser", - "hr_tip": "Llinell lorweddol (peidiwch â'i gor-ddefnyddio)", "summary": "Crynodeb:", "subject": "Pwnc:", "minoredit": "Golygiad bychan yw hwn", diff --git a/languages/i18n/da.json b/languages/i18n/da.json index b1a1cceac4..fac7ebda5e 100644 --- a/languages/i18n/da.json +++ b/languages/i18n/da.json @@ -670,24 +670,6 @@ "resettokens-watchlist-token": "Nøgle for web-feed (Atom/RSS) af [[Special:Watchlist|ændringer af sider pÃ¥ din overvÃ¥gningsliste]]", "resettokens-done": "Nøgler er nulstillet.", "resettokens-resetbutton": "Nulstil valgte nøgler", - "bold_sample": "Fed tekst", - "bold_tip": "Fed tekst", - "italic_sample": "Kursiv tekst", - "italic_tip": "Kursiv tekst", - "link_sample": "Link titel", - "link_tip": "Intern link", - "extlink_sample": "http://www.example.com link titel", - "extlink_tip": "Ekstern link (husk http:// præfiks)", - "headline_sample": "Tekst til overskrift", - "headline_tip": "Niveau 2 overskrift", - "nowiki_sample": "Indsæt ikke formateret tekst her", - "nowiki_tip": "Ignorer wiki formatering", - "image_sample": "Eksempel.jpg", - "image_tip": "Indlejret fil", - "media_sample": "Eksempel.ogg", - "media_tip": "Fil link", - "sig_tip": "Din signatur med tidsstempel", - "hr_tip": "Horisontal linje (bruges sparsomt)", "summary": "Sammenfatning:", "subject": "Emne:", "minoredit": "Dette er en mindre ændring", diff --git a/languages/i18n/de-formal.json b/languages/i18n/de-formal.json index 52813b97b3..25a2d9eb76 100644 --- a/languages/i18n/de-formal.json +++ b/languages/i18n/de-formal.json @@ -136,7 +136,6 @@ "changeemail-password": "Ihr {{SITENAME}}-Passwort:", "changeemail-throttled": "Sie haben zu viele Anmeldeversuche unternommen.\nBitte warten Sie $1, bevor Sie es erneut versuchen.", "resettokens-text": "Sie können Tokens zurücksetzen, welche Ihnen den Zugriff auf bestimmte private Daten ermöglichen, die mit Ihrem Benutzerkonto hier verknüpft sind.\n\nSie sollten dies nur machen, wenn Sie die Tokens versehentlich mit jemandem geteilt haben oder Ihr Konto gefährdet ist.", - "sig_tip": "Ihre Signatur mit Zeitstempel", "blankarticle": "<strong>Warnung:</strong> Die Seite, die Sie erstellen, ist leer.\nWenn Sie erneut auf „$1“ klicken, wird die Seite ohne Inhalt erstellt.", "anoneditwarning": "<strong>Warnung:</strong> Sie sind nicht angemeldet. Ihre IP-Adresse wird öffentlich sichtbar, falls Sie Bearbeitungen durchführst. Sofern Sie sich <strong>[$1 anmelden]</strong> oder <strong>[$2 ein Benutzerkonto erstellen]</strong>, werden Ihre Bearbeitungen zusammen mit anderen Beiträgen Ihrem Benutzernamen zugeordnet.", "anonpreviewwarning": "<em>Sie sind nicht angemeldet. Beim Speichern wird Ihre IP-Adresse in der Versionsgeschichte aufgezeichnet.</em>", diff --git a/languages/i18n/de.json b/languages/i18n/de.json index 08aaa49f9c..5c60cff615 100644 --- a/languages/i18n/de.json +++ b/languages/i18n/de.json @@ -100,7 +100,8 @@ "Andi-3", "1233qwer1234qwer4", "MarkusRost", - "Mcandri13" + "Mcandri13", + "Tobi 406" ] }, "tog-underline": "Links unterstreichen:", @@ -147,6 +148,7 @@ "tog-useeditwarning": "Warnen, sofern eine zur Bearbeitung geöffnete Seite verlassen wird, die nicht gespeicherte Änderungen enthält", "tog-prefershttps": "Immer eine sichere Verbindung benutzen, solange ich angemeldet bin", "tog-showrollbackconfirmation": "Bei Klick auf „kommentarlos zurücksetzen“ eine Sicherheitsabfrage anzeigen", + "tog-requireemail": "E-Mail-Adresse zum Zurücksetzen des Passworts erforderlich", "underline-always": "immer", "underline-never": "nie", "underline-default": "abhängig von der Benutzeroberfläche oder Browsereinstellung", @@ -520,7 +522,7 @@ "createaccountmail": "Ein temporäres Zufallspasswort verwenden und an die angegebene E-Mail-Adresse versenden", "createaccountmail-help": "Kann verwendet werden, um für eine andere Person ein Benutzerkonto zu erstellen, ohne das Passwort zu erfahren.", "createacct-realname": "Bürgerlicher Name (optional)", - "createacct-reason": "Begründung", + "createacct-reason": "Begründung (öffentlich geloggt)", "createacct-reason-ph": "Warum erstellst du ein anderes Benutzerkonto?", "createacct-reason-help": "Im Neuanmeldungs-Logbuch angezeigte Nachricht", "createacct-submit": "Benutzerkonto erstellen", @@ -688,24 +690,6 @@ "resettokens-watchlist-token": "Token für den Webfeed (Atom/RSS) der [[Special:Watchlist|Änderungen an Seiten auf deiner Beobachtungsliste]]", "resettokens-done": "Tokens zurückgesetzt.", "resettokens-resetbutton": "Ausgewählte Token zurücksetzen", - "bold_sample": "Fetter Text", - "bold_tip": "Fetter Text", - "italic_sample": "Kursiver Text", - "italic_tip": "Kursiver Text", - "link_sample": "Link-Text", - "link_tip": "Interner Link", - "extlink_sample": "http://www.example.com Link-Text", - "extlink_tip": "Externer Link (http:// beachten)", - "headline_sample": "Ebene-2-Überschrift", - "headline_tip": "Ebene-2-Überschrift", - "nowiki_sample": "Unformatierten Text hier einfügen", - "nowiki_tip": "Unformatierter Text", - "image_sample": "Beispiel.jpg", - "image_tip": "Dateilink", - "media_sample": "Beispiel.ogg", - "media_tip": "Mediendatei-Link", - "sig_tip": "Deine Signatur mit Zeitstempel", - "hr_tip": "Horizontale Linie (sparsam verwenden)", "summary": "Zusammenfassung:", "subject": "Betreff:", "minoredit": "Nur Kleinigkeiten wurden verändert", @@ -811,6 +795,8 @@ "nocreate-loggedin": "Du hast nicht die erforderliche Berechtigung, um neue Seiten erstellen zu können.", "sectioneditnotsupported-title": "Die Bearbeitung von Abschnitten wird nicht unterstützt", "sectioneditnotsupported-text": "Die Bearbeitung von Abschnitten wird auf dieser Bearbeitungsseite nicht unterstützt.", + "modeleditnotsupported-title": "Bearbeiten nicht möglich", + "modeleditnotsupported-text": "Das Bearbeiten wird für Seiten des Inhaltsmodells $1 nicht unterstützt.", "permissionserrors": "Berechtigungsfehler", "permissionserrorstext": "Du bist nicht berechtigt, die Aktion auszuführen. {{PLURAL:$1|Grund|Gründe}}:", "permissionserrorstext-withaction": "Du bist aus {{PLURAL:$1|dem folgenden Grund|den folgenden Gründen}} nicht berechtigt, $2:", @@ -847,6 +833,9 @@ "content-model-css": "CSS", "content-json-empty-object": "Leeres Objekt", "content-json-empty-array": "Leeres Array", + "unsupported-content-model": "<strong>Warnung:</strong> Das Inhaltsmodell $1 wird auf diesem Wiki nicht unterstützt.", + "unsupported-content-diff": "Versionsvergleiche werden für Seiten des Inhaltsmodells $1 nicht unterstützt.", + "unsupported-content-diff2": "Versionsvergleiche zwischen den Inhaltsmodellen $1 und $2 werden auf diesem Wiki nicht unterstützt.", "deprecated-self-close-category": "Seiten, die ungültige selbstschließende HTML-Tags verwenden", "deprecated-self-close-category-desc": "Die Seite enthält ungültige selbstschließende HTML-Tags wie <code><b/></code> oder <code><span/></code>. Das Verhalten dieser Tags wird bald geändert, um mit der HTML5-Spezifikation konsistent zu sein, so dass ihre Verwendung im Wikitext veraltet ist.", "duplicate-args-warning": "<strong>Warnung:</strong> [[:$1]] ruft [[:$2]] mit mehr als einem Wert für den Parameter „$3“ auf. Nur der letzte angegebene Wert wird verwendet.", @@ -882,6 +871,7 @@ "undo-norev": "Die Bearbeitung konnte nicht rückgängig gemacht werden, da sie nicht vorhanden ist oder gelöscht wurde.", "undo-nochange": "Anscheinend wurde diese Bearbeitung bereits rückgängig gemacht.", "undo-summary": "Änderung $1 von [[Special:Contributions/$2|$2]] ([[User talk:$2|Diskussion]]) rückgängig gemacht.", + "undo-summary-anon": "Änderung $1 von [[Special:Contributions/$2|$2]] rückgängig gemacht", "undo-summary-username-hidden": "Änderung $1 eines versteckten Benutzers rückgängig gemacht.", "cantcreateaccount-text": "Die Erstellung eines Benutzerkontos von der IP-Adresse '''($1)''' aus wurde durch [[User:$3|$3]] gesperrt.\n\nGrund der Sperre: ''$2''", "cantcreateaccount-range-text": "Das Erstellen von Benutzerkonten von IP-Adressen im Bereich <strong>$1</strong>, der deine IP-Adresse (<strong>$4</strong>) enthält, wurde von [[User:$3|$3]] gesperrt.\n\nDer angegebene Grund von $3 lautet: <em>$2</em>", @@ -1181,6 +1171,7 @@ "prefs-help-email": "Die Angabe einer E-Mail-Adresse ist optional, ermöglicht aber die Zusendung eines Ersatzpasswortes, sofern du dein Passwort vergessen hast.", "prefs-help-email-others": "Mit anderen Benutzern kannst du auch über die Benutzerdiskussionsseiten Kontakt aufnehmen, ohne dass du deine Identität offenlegen musst.", "prefs-help-email-required": "Es wird eine gültige E-Mail-Adresse benötigt.", + "prefs-help-requireemail": "Wird diese Option ausgewählt, werden nur dann E-Mails zum Zurücksetzen des Passworts versandt, wenn die Person beim Zurücksetzen den Benutzernamen und die E-Mail-Adresse dieses Kontos angegeben hat.", "prefs-info": "Basisinformationen", "prefs-i18n": "Sprache", "prefs-signature": "Signatur", @@ -1608,6 +1599,8 @@ "rcfilters-filter-showlinkedto-label": "Änderungen auf Seiten anzeigen, die verlinken auf", "rcfilters-filter-showlinkedto-option-label": "<strong>Seiten</strong>, die <strong>auf</strong> die ausgewählte Seite <strong>verlinken</strong>", "rcfilters-target-page-placeholder": "Einen Seitennamen (oder eine Kategorie) eingeben", + "rcfilters-allcontents-label": "Alle Inhaltsseiten", + "rcfilters-alldiscussions-label": "Alle Diskussionsseiten", "rcnotefrom": "Angezeigt {{PLURAL:$5|wird die Änderung|werden die Änderungen}} seit <strong>$3, $4</strong> (max. <strong>$1</strong> Einträge).", "rclistfromreset": "Datumsauswahl zurücksetzen", "rclistfrom": "Nur Änderungen seit $3, $2 Uhr zeigen.", @@ -1818,6 +1811,8 @@ "backend-fail-contenttype": "Der Inhaltstyp, der im Pfad „$1“ zu speichernden Datei, konnte nicht bestimmt werden.", "backend-fail-batchsize": "Der Datenbank wurde eine Stapelverarbeitungsdatei mit {{PLURAL:$1|einem Verarbeitungsschritt|$1 Verarbeitungsschritten}} übermittelt. Die zulässige Obergrenze liegt indes bei {{PLURAL:$2|einem Verarbeitungsschritt|$2 Verarbeitungsschritten}}.", "backend-fail-usable": "Die Datei „$1“ konnte entweder aufgrund eines nicht vorhandenen Verzeichnisses oder wegen unzureichender Berechtigungen weder abgerufen noch gespeichert werden.", + "backend-fail-stat": "Konnte den Status der Datei $1 nicht auslesen.", + "backend-fail-hash": "Konnte den kryptographischen Hash der Datei $1 nicht ermitteln.", "filejournal-fail-dbconnect": "Es konnte keine Verbindung zur Journaldatenbank des Datenbanksystems „$1“ hergestellt werden.", "filejournal-fail-dbquery": "Die Journaldatenbank des Datenbanksystems „$1“ konnte nicht aktualisiert werden.", "lockmanager-notlocked": "„$1“ konnte nicht entsperrt werden, da keine Sperrung besteht.", @@ -1897,6 +1892,7 @@ "listfiles-userdoesnotexist": "Das Benutzerkonto „$1“ ist nicht registriert.", "imgfile": "Datei", "listfiles": "Dateiliste", + "listfiles_subpage": "Von $1 hochgeladene Dateien", "listfiles_thumb": "Vorschaubild", "listfiles_date": "Datum", "listfiles_name": "Name", @@ -2395,15 +2391,16 @@ "alreadyrolled": "Das Zurücksetzen der Änderungen von [[User:$2|$2]] ([[User talk:$2|Diskussion]]{{int:pipe-separator}}[[Special:Contributions/$2|{{int:contribslink}}]]) an [[:$1]] ist gescheitert, da bereits ein anderer Benutzer die Seite geändert hat.\n\nDie letzte Änderung stammt von [[User:$3|$3]] ([[User talk:$3|Diskussion]]{{int:pipe-separator}}[[Special:Contributions/$3|{{int:contribslink}}]]).", "editcomment": "Die Änderungszusammenfassung lautet: <em>$1</em>.", "revertpage": "Änderungen von [[Special:Contributions/$2|$2]] ([[User talk:$2|Diskussion]]) wurden auf die letzte Version von [[User:$1|$1]] zurückgesetzt", + "revertpage-anon": "Änderungen von [[Special:Contributions/$2|$2]] wurden auf die letzte Version von [[User:$1|$1]] zurückgesetzt", "revertpage-nouser": "Änderungen von einem versteckten Benutzer rückgängig gemacht und letzte Version von {{GENDER:$1|[[User:$1|$1]]}} wiederhergestellt", "rollback-success": "Die Änderungen von {{GENDER:$3|$1}} wurden rückgängig gemacht und die letzte Version von {{GENDER:$4|$2}} wurde wiederhergestellt.", "sessionfailure-title": "Sitzungsfehler", "sessionfailure": "Es gab ein Problem bei der Übertragung deiner Benutzerdaten.\nDiese Aktion wurde daher sicherheitshalber abgebrochen, um eine falsche Zuordnung deiner Änderungen zu einem anderen Benutzer zu verhindern.\nBitte sende das Formular erneut ab.", "changecontentmodel": "Inhaltsmodell einer Seite ändern", "changecontentmodel-legend": "Inhaltsmodell ändern", - "changecontentmodel-title-label": "Seitentitel", + "changecontentmodel-title-label": "Seitentitel:", "changecontentmodel-current-label": "Aktuelles Inhaltsmodell:", - "changecontentmodel-model-label": "Neues Inhaltsmodell", + "changecontentmodel-model-label": "Neues Inhaltsmodell:", "changecontentmodel-reason-label": "Grund:", "changecontentmodel-submit": "Ändern", "changecontentmodel-success-title": "Das Inhaltsmodell wurde geändert", @@ -2631,6 +2628,7 @@ "ipblocklist-legend": "Suche nach einem gesperrten Benutzer", "blocklist-userblocks": "Benutzersperren ausblenden", "blocklist-tempblocks": "Befristete Sperren ausblenden", + "blocklist-indefblocks": "Unbefristete Sperren ausblenden", "blocklist-addressblocks": "Sperren einzelner IP-Adressen ausblenden", "blocklist-type": "Typ:", "blocklist-type-opt-all": "Alle", @@ -2681,6 +2679,7 @@ "block-log-flags-angry-autoblock": "erweiterter Autoblock aktiviert", "block-log-flags-hiddenname": "Benutzername versteckt", "range_block_disabled": "Die Möglichkeit, ganze Adressräume zu sperren, ist nicht aktiviert.", + "ipb-prevent-user-talk-edit": "Das Bearbeiten der eigenen Diskussionsseite muss bei einer partiellen Sperre erlaubt bleiben, es sei denn, diese enthält Beschränkungen zum Benutzerdiskussions-Namensraum.", "ipb_expiry_invalid": "Die eingegebene Dauer ist ungültig.", "ipb_expiry_old": "Der Zeitpunkt des Ablaufs liegt in der Vergangenheit.", "ipb_expiry_temp": "Benutzernamens-Sperren mit der Verstecken-Option müssen permanent sein.", @@ -2726,6 +2725,7 @@ "move-page-legend": "Seite verschieben", "movepagetext": "Mit untenstehendem Formular kannst du eine Seite umbenennen, indem du sie mitsamt allen Versionen auf einen neuen Titel verschiebst.\nDer alte Titel wird danach zum neuen weiterleiten.\nDu kannst Weiterleitungen, die auf den Originaltitel verlinken, automatisch korrigieren lassen.\nStelle sicher, dass du im Anschluss alle [[Special:DoubleRedirects|doppelten]] oder [[Special:BrokenRedirects|defekten Weiterleitungen]] überprüfst.\nDu bist dafür verantwortlich, dass Links weiterhin auf das korrekte Ziel verweisen.\n\nDie Seite wird <strong>nicht</strong> verschoben, sofern es bereits eine Seite mit dem vorgesehenen Titel gibt, es sei denn, letztere ist eine Weiterleitung ohne Versionsgeschichte.\nDies bedeutet, dass du die Umbenennung rückgängig machen kannst, sofern du einen Fehler gemacht hast. Du kannst hingegen keine existierende Seite überschreiben.\n\n<strong>Hinweis:</strong>\nDie Verschiebung kann weitreichende und unerwartete Folgen für häufig besuchte Seiten haben.\nDu solltest daher die Konsequenzen verstanden haben, bevor du jetzt fortfährst.", "movepagetext-noredirectfixer": "Mit untenstehendem Formular kannst du eine Seite umbenennen, indem du sie mitsamt allen Versionen auf einen neuen Titel verschiebst.\nDer alte Titel wird danach zum neuen weiterleiten.\nStelle sicher, dass du im Anschluss alle [[Special:DoubleRedirects|doppelten]] oder [[Special:BrokenRedirects|defekten Weiterleitungen]] überprüfst.\nDu bist dafür verantwortlich, dass Links weiterhin auf das korrekte Ziel verweisen.\n\nDie Seite wird <strong>nicht</strong> verschoben, sofern es bereits eine Seite mit dem vorgesehenen Titel gibt, es sei denn, diese ist eine Weiterleitung ohne Versionsgeschichte.\nDies bedeutet, dass du die Umbenennung rückgängig machen kannst, sofern du einen Fehler gemacht hast. Du kannst hingegen keine existierende Seite überschreiben.\n\n<strong>Hinweis:</strong>\nDie Verschiebung kann weitreichende und unerwartete Folgen für häufig besuchte Seiten haben.\nDu solltest daher die Konsequenzen verstanden haben, bevor du jetzt fortfährst.", + "movepagetext-noredirectsupport": "Mit untenstehendem Formular kannst du eine Seite umbenennen, indem du sie mitsamt allen Versionen auf einen neuen Titel verschiebst. Du bist dafür verantwortlich, dass Links weiterhin auf das korrekte Ziel verweisen. \n\nDie Seite wird <strong>nicht</strong> verschoben, sofern es bereits eine Seite mit dem vorgesehenen Titel gibt. Dies bedeutet, dass du die Umbenennung rückgängig machen kannst, sofern du einen Fehler gemacht hast. Du kannst hingegen keine existierende Seite überschreiben.\n\n<strong>Hinweis:</strong> Die Verschiebung kann weitreichende und unerwartete Folgen für häufig besuchte Seiten haben. Du solltest daher die Konsequenzen verstanden haben, bevor du jetzt fortfährst.", "movepagetalktext": "Falls du dieses Kästchen aktivierst, wird die dazugehörige Diskussionsseite automatisch auf den neuen Titel verschoben, sofern nicht bereits eine nicht-leere Diskussionsseite dort vorhanden ist.\n\nIn diesem Fall musst du die Seite manuell verschieben oder zusammenführen, falls erforderlich.", "moveuserpage-warning": "<strong>Warnung:</strong> Du bist dabei, eine Benutzerseite zu verschieben. Bitte bedenke, dass dadurch nur die Benutzerseite verschoben, <em>nicht</em> aber der Benutzer umbenannt wird.", "movecategorypage-warning": "<strong>Warnung:</strong> Du bist gerade dabei, eine Kategorieseite zu verschieben. Bitte sei dir bewusst, dass nur die Seite verschoben wird. Alle der alten Kategorie zugeordneten Seiten werden <em>nicht</em> neu kategorisiert.", @@ -2982,8 +2982,8 @@ "lastmodifiedatby": "Diese Seite wurde zuletzt am $1 um $2 Uhr von $3 bearbeitet.", "othercontribs": "Basierend auf der Arbeit von $1.", "others": "anderen", - "siteusers": "{{SITENAME}}-{{PLURAL:$2|{{GENDER:$1|Benutzer|Benutzerin}}|Benutzer}} $1", - "anonusers": "{{PLURAL:$2|unangemeldetem|unangemeldeten}} {{SITENAME}}-{{PLURAL:$2|Benutzer|Benutzern}} $1", + "siteusers": "{{PLURAL:$2|{{GENDER:$1|Benutzer|Benutzerin}}|Benutzer}} $1", + "anonusers": "{{PLURAL:$2|unangemeldetem|unangemeldeten}} {{PLURAL:$2|Benutzer|Benutzern}} $1", "creditspage": "Seitenzuschreibung", "nocredits": "Für diese Seite sind keine Zuschreibungen vorhanden.", "spamprotectiontitle": "Spamschutzfilter", @@ -3878,6 +3878,8 @@ "linkaccounts": "Benutzerkonten verknüpfen", "linkaccounts-success-text": "Das Benutzerkonto wurde verknüpft.", "linkaccounts-submit": "Benutzerkonten verknüpfen", + "cannotunlink-no-provider-title": "Es gibt keine verbundenen Konten, die getrennt werden könnten.", + "cannotunlink-no-provider": "Es gibt keine verbundenen Konten, die getrennt werden könnten.", "unlinkaccounts": "Benutzerkonten trennen", "unlinkaccounts-success": "Das Benutzerkonto wurde getrennt.", "authenticationdatachange-ignored": "Die Änderung der Authentifizierungsdaten wurde nicht bearbeitet. Vielleicht wurde kein Anbieter konfiguriert?", @@ -3895,8 +3897,10 @@ "specialmute-label-mute-email": "E-Mails von diesem Benutzer stummschalten", "specialmute-header": "Bitte wähle deine Stummschaltungseinstellungen für Benutzer <b>{{BIDI:[[User:$1|$1]]}}</b>.", "specialmute-error-invalid-user": "Der gesuchte Benutzername konnte nicht gefunden werden.", + "specialmute-error-no-options": "Stummschaltungs-Funktionen sind nicht verfügbar. Gründe dafür könnten sein: du hast deine E-Mail-Adresse nicht bestätigt oder ein Administrator hat die E-Mail-Funktionen deaktiviert oder eine E-Mail-Blacklist in diesem Wiki eingerichtet.", "specialmute-email-footer": "Um deine E-Mail Einstellungen für Benutzer {{BIDI:$2}} zu verwalten besuche bitte <$1>.", "specialmute-login-required": "Bitte melde dich an um deine Stummschaltungseinstellungen zu ändern.", + "mute-preferences": "Stummschaltungs-Einstellungen", "revid": "Version $1", "pageid": "Seitenkennung $1", "interfaceadmin-info": "$1\n\nBerechtigungen für das Bearbeiten von wikiweiten CSS/JS/JSON-Dateien wurden kürzlich vom Recht <code>editinterface</code> getrennt. Falls du nicht verstehst, warum du diesen Fehler erhältst, siehe [[mw:MediaWiki_1.32/interface-admin]].", @@ -3924,7 +3928,9 @@ "passwordpolicies-policy-passwordnotinlargeblacklist": "Das Passwort kann nicht in der Liste der 100.000 am häufigsten verwendeten Passwörter sein.", "passwordpolicies-policyflag-forcechange": "muss bei der Anmeldung geändert werden", "passwordpolicies-policyflag-suggestchangeonlogin": "Änderung bei der Anmeldung vorschlagen", + "mycustomjsredirectprotected": "Du hast keine Berechtigung, diese JavaScript-Seite zu bearbeiten, da sie eine Weiterleitung, die nicht in deinen Benutzernamensraum zeigt, enthält.", "easydeflate-invaliddeflate": "Der angegebene Inhalt ist nicht ordnungsgemäß komprimiert", "unprotected-js": "Aus Sicherheitsgründen kann JavaScript-Code nicht mehr von ungeschützten Seiten geladen werden. Erstelle die JavaScript-Seite bitte ausschließlich im Namensraum „MediaWiki“ oder als Benutzerunterseite.", - "userlogout-continue": "Möchtest du dich abmelden?" + "userlogout-continue": "Möchtest du dich abmelden?", + "rest-prefix-mismatch": "Der angeforderte Pfad ($1) kannte nicht innerhalb des REST-API-Root-Pfades ($2) gefunden werden" } diff --git a/languages/i18n/diq.json b/languages/i18n/diq.json index b64046bcf5..67cdbad752 100644 --- a/languages/i18n/diq.json +++ b/languages/i18n/diq.json @@ -78,6 +78,7 @@ "tog-norollbackdiff": "Peyser ardışi ra dıme ferqi measne", "tog-useeditwarning": "Wexto ke mı yew pela nizami be vurnayışanê nêqeydbiyayeyan caverdê, hay be mı ser de", "tog-prefershttps": "Ronışten akerden de tım greyo itimadın bıkarne", + "tog-requireemail": "Parolapeysernayene rê email lazımo", "underline-always": "Tım", "underline-never": "Qet", "underline-default": "Cild ya zi cı geyrayoğo hesebiyaye", @@ -86,8 +87,8 @@ "editfont-sansserif": "Fontê Sans-serifi", "editfont-serif": "Font (çêşıdê nuştey) Serif", "sunday": "Bazar", - "monday": "Bahdêbazari", - "tuesday": "Telete", + "monday": "Dışeme", + "tuesday": "Sêşeme", "wednesday": "Çarşeme", "thursday": "Pancşeme", "friday": "Êne", @@ -100,19 +101,19 @@ "fri": "Yen", "sat": "Şem", "january": "Çele", - "february": "Gucige", + "february": "Sıbate", "march": "Adar", "april": "Nisan", - "may_long": "Gulan", + "may_long": "Gulane", "june": "Heziran", "july": "Temuz", "august": "Tebaxe", "september": "Keşkelun", - "october": "Cıtmeng", - "november": "Kelverdan", - "december": "Gağan", + "october": "Tışrino Verên", + "november": "Tışrino Peyên", + "december": "Kanun", "january-gen": "Çele", - "february-gen": "Şıbat", + "february-gen": "Sıbate", "march-gen": "Mert", "april-gen": "Nisane", "may-gen": "Gulane", @@ -120,11 +121,11 @@ "july-gen": "Temuz", "august-gen": "Tebaxe", "september-gen": "Keşkelun", - "october-gen": "Cıtmeng", - "november-gen": "Kelverdan", - "december-gen": "Gağan", + "october-gen": "Tışrino Verên", + "november-gen": "Tışrino Peyên", + "december-gen": "Kanun", "jan": "Çel", - "feb": "Şbt", + "feb": "Sbt", "mar": "Adr", "apr": "Nsn", "may": "Gul", @@ -136,20 +137,20 @@ "nov": "Tşp", "dec": "Gğn", "january-date": "$1 Çele", - "february-date": "$1 Şıbat", + "february-date": "$1 Sıbate", "march-date": "$1 Adar", "april-date": "$1 Nisan", - "may-date": "$1 Gulan", + "may-date": "$1 Gulane", "june-date": "$1 Heziran", "july-date": "$1 Temuze", "august-date": "$1 Tebaxe", "september-date": "$1 Keşkelun", "october-date": "$1 Cıtmeng", "november-date": "$1 Kelverdan", - "december-date": "$1 Gağan", + "december-date": "$1 Kanun", "period-am": "VD", "period-pm": "BD", - "pagecategories": "{{PLURAL:$1|Kategori|Kategoriy}}", + "pagecategories": "{{PLURAL:$1|Kategoriye|Kategoriyi}}", "category_header": "Perrê kategoriya \"$1\"'i", "subcategories": "Kategoriyê bınêni", "category-media-header": "Dosye yê ke kategoriya \"$1\" dı", @@ -163,19 +164,19 @@ "category-file-count": "{{PLURAL:$2|Na kategori tenya dosya ya cêri muhtewa kena.|Na kategori de $2 ra pêro piya {{PLURAL:$1|1 dosya est a|$1 dosyey est ê}}.}}", "category-file-count-limited": "{{PLURAL:$1|Dosye|$1 Dosyey}} na kategori de yê.", "listingcontinuesabbrev": "dewam...", - "index-category": "Perrê rêzıni", + "index-category": "Pelê rêzıni", "noindex-category": "Perrê bêrêzıni", "broken-file-category": "Perri be linkanê dosya çewte", "categoryviewer-pagedlinks": "($1) ($2)", "about": "Heqa", "article": "Pela zerreki", "newwindow": "(pençerey newey de beno a)", - "cancel": "Ä°btal", + "cancel": "Bıtexelne", "moredotdotdot": "Vêşi...", "morenotlisted": "Na lista qay kemi ya.", - "mypage": "Perr", - "mytalk": "Vaten", - "anontalk": "Vaten", + "mypage": "Pele", + "mytalk": "Werênayış", + "anontalk": "Werênayış", "navigation": "Pusula", "and": " u", "faq": "PVP", @@ -199,20 +200,20 @@ "printableversion": "Versiyono nustenaye", "permalink": "Gıreyo daimi", "print": "Bınustenê", - "view": "Bıvin", + "view": "Bıvêne", "view-foreign": "$1 de bıvin", - "edit": "Bıvurn", + "edit": "Bıvurne", "edit-local": "Şınasnayışê lokali bıvurne", "create": "Vıraz", "create-local": "Şınasnayışê lokali cı ke", - "delete": "Bestern", + "delete": "Bestere", "undelete_short": "{{PLURAL:$1|nê vırnayışi|$1 vırnayışa}} peyser bıyarê", "viewdeleted_short": "{{PLURAL:$1|Jew vurnayış esternayi|$1 Vurnayışanê esternayan}} bımotne", "protect": "Bışevekne", "protect_change": "bıvırne", "unprotect": "Starnayışi bıvurne", "newpage": "Perra newi", - "talkpagelinktext": "vaten", + "talkpagelinktext": "werênayış", "specialpage": "Pela xısusiye", "personaltools": "Hacetê şexsiy", "talk": "Vaten", @@ -255,7 +256,7 @@ "edithelp": "Peştdariya vurnayışi", "helppage-top-gethelp": "Peşti", "mainpage": "Perra Seri", - "mainpage-description": "Pera seri", + "mainpage-description": "Pela seri", "policy-url": "Project:Terzê hereketi", "portal": "Portalê cemati", "portal-url": "Project:Portalê cemati", @@ -289,12 +290,12 @@ "collapsible-collapse": "Teng ke", "collapsible-expand": "Hera kerê", "confirmable-confirm": "{{GENDER:$1|Şıma}} bêgumanê?", - "confirmable-yes": "E", + "confirmable-yes": "Eya", "confirmable-no": "Nê", "thisisdeleted": "Bıvêne ya zi $1 peyser biya?", "viewdeleted": "$1 bıvin?", "restorelink": "{{PLURAL:$1|jew vurnayış besteriya|$1 vurnayışi besteriyaye}}", - "feedlinks": "Resnayış:", + "feedlinks": "Weyiyekerdış:", "feed-invalid": "Qeydey cıresnayışê beğşi nêvêreno.", "feed-unavailable": "Cıresnayışê şebekey çıniyê", "site-rss-feed": "$1 Cıresnayışê RSSi", @@ -306,16 +307,16 @@ "red-link-title": "$1 (pele çıniya)", "sort-descending": "Rêzkerdışo kêmbiyaye", "sort-ascending": "Rêzkerdışo zêdiyaye", - "nstab-main": "Perr", + "nstab-main": "Pele", "nstab-user": "Pera karberi", "nstab-media": "Pela medya", - "nstab-special": "Perra bağse", + "nstab-special": "Pela xısusiye", "nstab-project": "Perra procey", "nstab-image": "Dosya", "nstab-mediawiki": "Mesac", "nstab-template": "Şablon", "nstab-help": "Perra pasti", - "nstab-category": "Kategori", + "nstab-category": "Kategoriye", "mainpage-nstab": "Pera seri", "nosuchaction": "Fealiyeto wınasi çıniyo", "nosuchactiontext": "URL ra kar qebul nêbı.\nŞıma belka URL şaş nuşt, ya zi gıreyi şaş ra ameyi.\nKeyepelê {{SITENAME}} eşkeno xeta aşkera bıkero.", @@ -351,7 +352,7 @@ "badarticleerror": "Kar ke şıma kenê, qebul nêbi.", "cannotdelete": "Pel \"$1\" o ke şıma nişane kerd hewn a neşı.\nBelka yewna ten kerdo hewn a.", "cannotdelete-title": "Şıma nêşenê pela \"$1\" besterê", - "delete-hook-aborted": "Esterıtışi terefê çengeli ra ibtal bi.\nQet tesrih beyan nêbi.", + "delete-hook-aborted": "Esterıtışi terefê çengeli ra nêtexeliya.\nQet tesrih beyan nêbi.", "no-null-revision": "Qandé \"$1\" zew rewizyono newe névıraziya.", "badtitle": "Sernameyo xırabın", "badtitletext": "Sernameyê pela ke şıma waşt, nêvêrd, vengo ya zi zıwano miyanêno ğelet gırêdaye ya zi sernameyê wiki.\nBeno ke, tede yew ya zi zêdê işareti estê ke sernameyan de nêxebetiyenê.", @@ -394,6 +395,7 @@ "virus-scanfailed": "cıgerayiş tamam nêbı (kod $1)", "virus-unknownscanner": "antiviruso ke nêzanyeno:", "logouttext": "'''Henda şıma hesab ra veciyay.'''\n\nDiqat kerê ke tayê perri şenê hewna zey şıma kewtê ra cı bıasê, heta şıma ver-virê şanekerê (browserê) xo besterê.", + "logging-out-notify": "Şımayê cı ra veciyê, kerem kerê bıpawên.", "logout-failed": "Enewke ronıştışo nêracneyêno:$1", "cannotlogoutnow-title": "Enewke ronıştışo nêracneyêno", "cannotlogoutnow-text": "Gurenayışê $1i de veciyayış mımkın niyo.", @@ -441,7 +443,7 @@ "createacct-another-email-ph": "Adresa e-posta de fi", "createaccountmail": "Yew parolaya rastameyiya ravêrdiye bıgurene û parola ena adresa e-postey rê bırışe", "createacct-realname": "Nameyo raştıkên (mecburi niyo)", - "createacct-reason": "Sebeb", + "createacct-reason": "Sebeb (eşkera kewto cı)", "createacct-reason-ph": "Şımaye çı xo re zewbi hesab vırazeni?", "createacct-reason-help": "Roceka hesabvıraştışi de mesaco asaye", "createacct-submit": "Hesabê xo vıraze", @@ -532,8 +534,8 @@ "botpasswords-label-appid": "Nameyê boti:", "botpasswords-label-create": "Vıraze", "botpasswords-label-update": "Rocane ke", - "botpasswords-label-cancel": "Ä°btal", - "botpasswords-label-delete": "Bestern", + "botpasswords-label-cancel": "Bıtexelne", + "botpasswords-label-delete": "Bestere", "botpasswords-label-resetpassword": "Parola raçarne", "botpasswords-label-grants": "Ä°mtıyazê ravêrdeyi:", "botpasswords-label-grants-column": "Dayen", @@ -546,7 +548,7 @@ "resetpass_forbidden-reason": "Parola nêvuriyena: $1", "resetpass-no-info": "şıma gani hesab akere u hona bıeşke bırese cı", "resetpass-submit-loggedin": "Parola bıvurne", - "resetpass-submit-cancel": "Ä°btal", + "resetpass-submit-cancel": "Bıtexelne", "resetpass-wrong-oldpass": "parolayo parola maqbul niyo.\nşıma ya parolaye xo vurnayo ya zi parolayo muwaqqat waşto.", "resetpass-recycled": "Parolaya şımaya newiye, wa paroloya şımaya verêne ra ciya bo.", "resetpass-temp-emailed": "E postaya rışyayê yubkoda şıma ronıştış akerdo. Ronıştışi xo temammkerdışi rê yu parolaya newi lazım a", @@ -589,24 +591,6 @@ "resettokens-watchlist-token": "Web Feed rê nışan (Atom/RSS)ê [[Special:Watchlist|vêreno perranê lista şımawa seyrkerdışi]]", "resettokens-done": "Nışanan reset ke", "resettokens-resetbutton": "Nışananê weçıniteyan reset ke", - "bold_sample": "Metno qalın", - "bold_tip": "Metno qalın", - "italic_sample": "Metno çewt", - "italic_tip": "Metno çewt", - "link_sample": "Serekê gıri", - "link_tip": "Gırey Å»erri", - "extlink_sample": "http://www.misal.com sernamey gırey", - "extlink_tip": "Gırey teberi (xo vira mekerên http:// prefix)", - "headline_sample": "metnê sernamey", - "headline_tip": "Sewiya 2ıne sername", - "nowiki_sample": "metnê formatkerdey berze etıya", - "nowiki_tip": "Goş formatê Wiki ra mekûwe", - "image_sample": "Nımune.jpg", - "image_tip": "Dosya tewrkerdiye", - "media_sample": "Nımune.ogg", - "media_tip": "Gırey dosye", - "sig_tip": "Ä°mzay şıma be morê zemani", - "hr_tip": "Xeta verardiye (teserrufın bıgureyne/bıxebetne)", "summary": "Xulasa:", "subject": "Mewzu:", "minoredit": "No yew vırnayışo werdiyo", @@ -1421,6 +1405,8 @@ "rcfilters-watchlist-preference-label": "Mabeynrıyê non-JavaScript'i bıkarne", "rcfilters-filter-showlinkedfrom-label": "Gıreyê pelan ra vurnayışan bıvêne", "rcfilters-target-page-placeholder": "Yew nameyê pele (ya zi kategoriye) cı kerê", + "rcfilters-allcontents-label": "Zerrek pêro", + "rcfilters-alldiscussions-label": "Werênayışi pêro", "rcnotefrom": "Cêr de <strong>$2</strong> ra nata {{PLURAL:$5|vurnayışiyê}} asenê (tewr vêşi <strong>$1</strong> asenê) <strong>$3, $4</strong>", "rclistfromreset": "Weçinayışê tarixi ragoze", "rclistfrom": "$3 sehat $2 ra tepiya vurnayışanê neweyan bımotne", @@ -1480,7 +1466,7 @@ "upload_directory_read_only": "Direktorê dosyayê ($1)î webserver de nieşkeno binuse.", "uploaderror": "Ğeletê bar kerdişî", "upload-recreate-warning": "'''Diqet: Yew dosya pê ena name wedariya ya zi vurniya.'''\n\nLogê wedariyayiş u berdişi seba ena pele a ti ra xezir kerda:", - "uploadtext": "Qey barkerdişê dosyayî, formê cêrinî bişuxulne.\nDosyayê ke vera cû bar biyê eke şima qayîl e ney dosyayan bivînê ya zî bigerî biewnê[[Special:FileList|listeyê dosyayê bar bîyaye]] (tekrar) bar bîyaye [[Special:Log/upload|rocaneyê barkerdişî]] de, hewn a şîyaye zî tîya de [[Special:Log/delete|rocaneyê hewn a kerdişî]] pawiyene.\n\nwexta şima qayîl e yew peli re dosya bierzî, formanê cêrinan ra yewi bişuxulne;\n* Qey xebitnayişê dosyayî: '''<code><nowiki>[[</nowiki>{{ns:file}}<nowiki>:Dosya.jpg]]</nowiki></code>'''\n*Heto çep de zerreyê yew qutî de, qey xebitnayişi 'nuşteyê binîn' û 200 pikseli: '''<code><nowiki>[[</nowiki>{{ns:file}}<nowiki>:Dosya.png|200px|thumb|left|alt metin]]</nowiki></code>'''\n* Dosya memocın, dosya te direk gırey bıerz: '''<code><nowiki>[[</nowiki>{{ns:media}}<nowiki>:Dosya.ogg]]</nowiki></code>'''", + "uploadtext": "Seba '''dosya''' barkerdışi rê formê cerênê bıgurenê. Veri ra dosyeyê barbiyayeyan vênayış u cıgeyrayışi rê bıewni rê [[Special:FileList|lista dosyeyan]], seba (fına) barbiyayeyan rê [[Special:Log/upload|rocekê barkerdışi]] u, esterıtan zi pela [[Special:Log/delete|rocekê esterıtışi]] de tepışiyeno.\n\nYew pele rê dosyacıkerdışi rê formanê cêrênan ra yewi bıgurenê;\n* Versiyonê gurenayışê dosyeyanê pêroyiyan rê: '''<code><nowiki>[[</nowiki>{{ns:file}}<nowiki>:Dosya.jpg]]</nowiki></code>'''\n* Kışta çepê yew doreki miyan de, vêniyayo cı de 'metinê bıni' ra, 200 piksel ebadê dosyagurenayışi rê : '''<code><nowiki>[[</nowiki>{{ns:file}}<nowiki>:Dosya.png|200px|thumb|left|alt metin]]</nowiki></code>'''\n* Dosyaya nêmusnayışi ra, dosya rê direkt gıredayışi rê : '''<code><nowiki>[[</nowiki>{{ns:media}}<nowiki>:Dosya.ogg]]</nowiki></code>'''", "upload-permitted": "{{PLURAL:$2|Babetê|Babetên}} dosyayanê vêrdeyan: $1.", "upload-preferred": "{{PLURAL:$2|Babetê|Babetên}} dosyayanê tercihbiyayeyan: $1.", "upload-prohibited": "{{PLURAL:$2|Babetê|Babetên}} dosyayanê tometebiyayeyan: $1.", @@ -1923,7 +1909,7 @@ "checkbox-all": "Pêro", "checkbox-none": "Çıniyo", "checkbox-invert": "Dimlaşt ke", - "allpages": "Perri pêro", + "allpages": "Peli pêro", "nextpage": "Pela bahdoyêne ($1)", "prevpage": "Pela veri ($1)", "allpagesfrom": "Herfa kı pa liste bo:", @@ -2121,9 +2107,9 @@ "sessionfailure": "cıkewtışê hesabê şıma de yew problem aseno;\nno kar semedê dızdiyê hesabi ibtal biyo.\nkerem kerê \"tepiya\" şiyerê u pel o ke şıma tera ameyî u o pel newe ra bar kerê , newe ra tesel/cereb kerê.", "changecontentmodel": "Modelê zerrekê pele bıvurne", "changecontentmodel-legend": "Modelê zerreki bıvurne", - "changecontentmodel-title-label": "Sernameyê pele", + "changecontentmodel-title-label": "Sernameyê pele:", "changecontentmodel-current-label": "Mewcud zerrekê modeli:", - "changecontentmodel-model-label": "Modelê zerrekiyo newe", + "changecontentmodel-model-label": "Modelê zerrekiyo newe:", "changecontentmodel-reason-label": "Sebeb:", "changecontentmodel-submit": "Bıvırne", "changecontentmodel-success-title": "Modelê zerreki vurriya", @@ -2172,7 +2158,7 @@ "protect-othertime-op": "wexto bin", "protect-existing-expiry": "wextê qediyayişi yê mewcudi: $3, $2", "protect-existing-expiry-infinity": "Mewcud drmê qedyayışi:Bewext", - "protect-otherreason": "sebebo bin/sebebê ilaveyi", + "protect-otherreason": "Sebebo bin/ilaweyın:", "protect-otherreason-op": "Sebebo bin", "protect-dropdown": "*sebebê pawıtışi ye pêroyiye\n** vandalizmo hed ra vecaye\n** spamo hed ra vecaye\n** şêrê/herbê vurnayişi\n** pel o ke zaf wayirê trafiki yo", "protect-edit-reasonlist": "sebebê pawıtışi bıvurn", @@ -2183,7 +2169,7 @@ "maximum-size": "Ebatê maximumî", "pagesize": "(bitî)", "restriction-edit": "Bıvurne", - "restriction-move": "Bıkırış", + "restriction-move": "Bıkırışe", "restriction-create": "Vıraze", "restriction-upload": "Bar ke", "restriction-level-sysop": "tam pawiyayo", @@ -2214,6 +2200,7 @@ "undelete-search-title": "Bıgeyre pelanê eserıtiyan", "undelete-search-box": "bıgêr pelê hewn a biyayeyani", "undelete-search-prefix": "pel ê ke pê ney destpêkenî, ramocın", + "undelete-search-full": "Zerrekê sernameyanê pele bımocne:", "undelete-search-submit": "Cı geyre", "undelete-no-results": "Zerre arşîvê esterayîşî de peleyan match nibiyê.", "undelete-filename-mismatch": "Vurnayîşê ke pê wextê puli ye $1î nieşkenî biyare: nameyê dosyayî match nibeno", @@ -2248,7 +2235,7 @@ "sp-contributions-deleted": "iştırakê {{GENDER:$1|karberi}} esterdi", "sp-contributions-uploads": "Barkerdışi", "sp-contributions-logs": "qeydi", - "sp-contributions-talk": "vaten", + "sp-contributions-talk": "werênayış", "sp-contributions-userrights": "idareyê heqanê {{GENDER:$1|karberan}}", "sp-contributions-blocked-notice": "Eno karber/ena karbere emanet blokekerdeyo/blokekerdiya.\nCıkewtışo tewr peyêno ke bloke biyo, cêr seba referansi belikerdeyo:", "sp-contributions-blocked-notice-anon": "Eno adresê IPi bloke biyo.\nCıkewtışo tewr peyêno ke bloke biyo, cêr seba referansi belikerdeyo:", @@ -2258,7 +2245,7 @@ "sp-contributions-newonly": "Tenya vurnayışanê pelevıraştışi bımocne", "sp-contributions-hideminor": "Vurriyayışanê werdiyan bınımne", "sp-contributions-submit": "Cı geyre", - "whatlinkshere": "Gırey na perer", + "whatlinkshere": "Çı tiyayi rê gıre beno", "whatlinkshere-title": "Wesiqe da \"$1\" rê gıre dayen perri", "whatlinkshere-page": "Pele:", "linkshere": "Pera <strong>$2</strong> rê gıre dayen perri", @@ -2298,6 +2285,7 @@ "ipb-confirm": "Bloke kerdışi tesdik ke", "ipb-sitewide": "Site hemi de", "ipb-partial": "Qısmi", + "ipb-partial-help": "Peli ya zi nameyê cayanê spesifikan.", "ipb-pages-label": "Peli", "ipb-namespaces-label": "Heruna nameyan", "badipaddress": "Adresê IPî raşt niyo", @@ -2311,7 +2299,9 @@ "ipb-blocklist": "Blokî ke hama estê ey bivîne", "ipb-blocklist-contribs": "İştirakê {{GENDER:$1|$1}}`i", "ipb-blocklist-duration-left": "$1 vet", + "block-actions": "Hereketê kıliti:", "block-expiry": "Qedyayış:", + "block-options": "Weçinıtışê vêşi:", "block-prevent-edit": "Vurnayış", "block-reason": "Sebeb:", "block-target": "Nameyê karberi ya zi adresa eposteyi", @@ -2321,11 +2311,13 @@ "unblocked": "[[User:$1|$1]] blok biyo", "unblocked-range": "Blokey $1'i wederya", "unblocked-id": "Blokê $1î wedariyayo", + "unblocked-ip": "Kılitê [[Special:Contributions/$1|$1]] dariyo we.", "blocklist": "Karberê kılitbiyayey", "autoblocklist": "Blokeyê otomatiki", "autoblocklist-submit": "Cı geyre", "autoblocklist-legend": "Lista blokanê otomatikan", "autoblocklist-localblocks": "{{PLURAL:$1|otoblokoyo lokal|otoblokeyê lokali}}", + "autoblocklist-total-autoblocks": "Amarê kılitkerdışê xoseri pêro piya: $1", "autoblocklist-otherblocks": "{{PLURAL:$1|otobloqeyo bin|otobloqeyê bini}}", "ipblocklist": "Karberê kılitbiyayey", "ipblocklist-legend": "Karberê kılit biyayey bıvin", @@ -2417,7 +2409,7 @@ "lockfilenotwritable": "dosyaya qefılnayişê databaseyi ser ra çiyek nênusyena.", "databasenotlocked": "Database a nibiya.", "lockedbyandtime": "({{GENDER:$1|$1}} ra $2 tepya $3 biyo)", - "move-page": "$1 Bıkırış", + "move-page": "$1 Bıkırışe", "move-page-legend": "Pele bere", "movepagetext": "Pe form ki ho bın de, tı eşkeno name yew pele bıvurni u tarixê pele hemi ya zi pyeran beri.\nMa nameyê kıhanyeri keno pele redireksiyoni ser nameyê newe.\nTı eşkeno pele redireksiyoni ki şıno nameyê originali bıvurni.\nEg tı nıwazeno, ma tı ra rica keni tı [[Special:DoubleRedirects|double]] ya zi [[Special:BrokenRedirects|broken redirects]] qontrol bıki.\nTı gani qontrol bıki eg gıreyan şıno peleyanê raşti.\n\nTeme eka ser yew name de yew nuşte esti, sistemê ma '''nıeşkeno''' nuşte tı beri. Eka ser ena name de yew pele vengi esti, sistemê ma eşkeno nuşte tı beri.\nTı nıeşkeni name yew pele reyna bıvurni.\n\n'''Teme!'''\nEna transfer ser peleyanê populari zaf muhumo;\nMa tu ra rica keni, tı en verni dı qontrol bıki u bışıravi.", "movepagetext-noredirectfixer": " Gırwenayışê formê bınêni do namey perre newe vırazo, pêro vêrorê cı bıkırışo namey newe ser.\nMa namey kıhanêri keni perra serşıkıtışi ser nameyo newe.\nŞıma şenê perra serşıkıtışı zi berê namey raştıkên bıvırnên.\n\nEger şıma nêwazenê, ma şıma ra reca keni şıma [[Special:DoubleRedirects|açarnayışo (tadayışo) dılet]] ya zi [[Special:BrokenRedirects|açarnayışo (tadayışon) çewt]]i kontrol kerên.\nŞıma gani kontrol kerên eger linki şınê perranê raştan ser.\n\nTeme eger ser yew name de yew nuşte esto, sistemê wiki '''nêşeno''' nuştey şıma bıkırışo. Eger ser enê namey de yew perra venge esta, sistemê wiki şeno nuştey şıma bıkırışo.\nTı nıeşkeni name yew pele reyna bıvurni.\n\n'''Ä°qaz!'''\nNo kırıştış şeno yew perra populere rê wışkên u nêpawiyay bo. Ma şıma ra reca kenime, kerdışê xo ra ver peyniyê cı bıvênên.", @@ -2569,7 +2561,7 @@ "javascripttest-qunit-intro": "Mediawiki.org dı [dokumanê $1] bıvinê.", "tooltip-pt-userpage": "Pela {{GENDER:|şımaya karberi}}", "tooltip-pt-anonuserpage": "pelê karberê IPyi", - "tooltip-pt-mytalk": "Pera {{GENDER:|şıma}}ya vaten", + "tooltip-pt-mytalk": "Pela {{GENDER:|toya}} werênayışi", "tooltip-pt-anontalk": "'''Ena adresa IP ra vurnayışa sero qal bıqerê'''", "tooltip-pt-preferences": "Tercihê {{GENDER:|şıma}}", "tooltip-pt-watchlist": "Listey peranê ke to gırotê seyr kerdış", @@ -2948,6 +2940,7 @@ "watchlistedit-clear-legend": "Lista serykerdışê pak kerê", "watchlistedit-clear-explain": "Listeya serykerdış da şıma dı sernamey pêro besteryay", "watchlistedit-clear-titles": "Sernamey:", + "watchlistedit-clear-done": "Lista seyrkerdişê şıma biya pak.", "watchlisttools-clear": "Lista serykerdışê xo pak kı", "watchlisttools-view": "Vurnayışanê elaqedaran bıvêne", "watchlisttools-edit": "Lista seyrkerdışi bıvêne û bıvurne", @@ -3163,6 +3156,9 @@ "permanentlink": "Gıreyo daimi", "permanentlink-revid": "Revizyonê IDyi", "permanentlink-submit": "Şo revizyoni", + "newsection": "Leteyo newe", + "newsection-page": "Etiketê pele", + "newsection-submit": "Şo be pele", "dberr-problems": "Mayê muxulêm! Ena sita dı newke xırabiya teknik esta.", "dberr-again": "Dı-rê deqiqeyi vınde û heni bar ke.", "dberr-info": "(Erzmelumati ra xızmetkari nêreseno: $1)", diff --git a/languages/i18n/dsb.json b/languages/i18n/dsb.json index b9a48fce1e..6413455e0d 100644 --- a/languages/i18n/dsb.json +++ b/languages/i18n/dsb.json @@ -500,24 +500,6 @@ "resettokens-watchlist-token": "Token za webkanal (Atom/RSS) [[Special:Watchlist|změnow na bokach w twójich woglědowankach]]", "resettokens-done": "Tokeny slědk stajone.", "resettokens-resetbutton": "Wubrane tokeny slědk stajiś", - "bold_sample": "Tucny tekst", - "bold_tip": "Tucny tekst", - "italic_sample": "Kursiwny tekst", - "italic_tip": "Kursiwny tekst", - "link_sample": "Tekst wótkaza", - "link_tip": "Interny wótkaz", - "extlink_sample": "http://www.example.com nadpismo wótkaza", - "extlink_tip": "Eksterny wótkaz (źiwaś na http://)", - "headline_sample": "Nadpismo", - "headline_tip": "Nadpismo rowniny 2", - "nowiki_sample": "Zapódaj how njeformatěrowany tekst", - "nowiki_tip": "Wiki-syntaksu ignorěrowaś", - "image_sample": "Pokazka.jpg", - "image_tip": "Zasajźona dataja", - "media_sample": "pokazka.ogg", - "media_tip": "Datajowy wótkaz", - "sig_tip": "Twója signatura z casowym kołkom", - "hr_tip": "Horicontalna linija (rědko wužywaś)", "summary": "Zespominanje:", "subject": "Tema/Nadpismo:", "minoredit": "Snadna změna", diff --git a/languages/i18n/dtp.json b/languages/i18n/dtp.json index 9921c1318b..6d326360ca 100644 --- a/languages/i18n/dtp.json +++ b/languages/i18n/dtp.json @@ -432,22 +432,6 @@ "changeemail-newemail": "Porikatan surat-i it kawawagu:", "changeemail-none": "(ingaa)", "changeemail-submit": "Alanai surat-i", - "bold_sample": "Polombono tik", - "bold_tip": "Polombono tik", - "italic_sample": "Tik lingging", - "italic_tip": "Tik lingging", - "link_sample": "Noputan tuluhon", - "link_tip": "Noputan poinsuang", - "extlink_sample": "http://www.example.com tuluon do noput", - "extlink_tip": "Noputan poinlabus (soroho no do potitimpuun http://)", - "headline_sample": "Tik potuluhon", - "headline_tip": "Nuludan-tulu loting ko-2", - "nowiki_sample": "Posuango tik awu-nokoulud do hiti", - "nowiki_tip": "Pologoso ponguludan wiki", - "image_tip": "Potopilo pail", - "media_tip": "Toput do pail", - "sig_tip": "Tinonduktunturunu miampai sinokot-timpu", - "hr_tip": "Puralan pointibabar (inta-taan do mongoguno)", "summary": "Koinibaan:", "subject": "Ahal/tuluhon", "minoredit": "Iti nopo nga niditan tokoto", diff --git a/languages/i18n/dty.json b/languages/i18n/dty.json index 9ea6ec5dc0..a60c5ac3a9 100644 --- a/languages/i18n/dty.json +++ b/languages/i18n/dty.json @@ -37,7 +37,7 @@ "tog-shownumberswatching": "निगरानी गरिरहेका प्रयोगकर्ताहरूको संख्या धेखाउन्या", "tog-oldsig": "तमरो अहिलको हस्ताक्षर:", "tog-fancysig": "मेरा दस्तखतलाई विकि पाठको रुपमी लिने (स्वत लिङ्क बिना)", - "tog-uselivepreview": "प्रत्यक्ष पैल्लीकोरुप प्रयोग गर", + "tog-uselivepreview": "पृष्ठ पुनर्भरण नअरेइ पूर्वावलोकन धेकाः", "tog-forceeditsummary": "खाली सम्पादन शीर्षक प्रविष्टि गरेपछा मलाई सोधन्या", "tog-watchlisthideown": "मेरा सम्पादनहरू निगनारी सूचीबठेई लुकाऊन्या", "tog-watchlisthidebots": "बोट सम्पादनहरू ध्यान सूचीबठेई लुकाउन्या", @@ -53,6 +53,7 @@ "tog-norollbackdiff": "पैलास्थितिमी फर्काएपछा भिन्नता हटाउन्या", "tog-useeditwarning": "सम्पादनहरू सङ्ग्रह नगरिएका अवस्थामी अर्को पानामी जान खोज्या चेतावनी धेखाउन्या", "tog-prefershttps": "प्रवेश गरन्ज्या जबलै सुरक्षित जडानको प्रयोग गर्न्या", + "tog-requireemail": "पासवर्ड पुनःचयन खिलाइ इमेल चायीन्छ", "underline-always": "जबलै", "underline-never": "कभैई नाई", "underline-default": "खोल और ब्राउजर निर्धारित", @@ -141,6 +142,8 @@ "index-category": "क्रमाङ्कित पानाहरू", "noindex-category": "अनुक्रमित नअरियाऽ पन्नाअन", "broken-file-category": "टुटेको फाइल लिङ्कहरूसितको पाना", + "categoryviewer-pagedlinks": "($1) ($2)", + "category-header-numerals": "$1–$2", "about": "बारेमी", "article": "सामाग्री पानो", "newwindow": "(नौलो विन्डोमी खुलन्छ)", @@ -161,6 +164,7 @@ "returnto": "$1 मी फर्क।", "tagline": "{{SITENAME}} बठेइ", "help": "मद्दत", + "help-mediawiki": "मिडियाविकि का बारेमी मद्दत", "search": "खोजी", "search-ignored-headings": " #<!-- leave this line exactly as it is --> <pre>\n# Headings that will be ignored by search.\n# Changes to this take effect as soon as the page with the heading is indexed.\n# You can force page reindexing by doing a null edit.\n# The syntax is as follows:\n# * Everything from a \"#\" character to the end of the line is a comment.\n# * Every non-blank line is the exact title to ignore, case and everything.\nReferences\nExternal links\nSee also\n #</pre> <!-- leave this line exactly as it is -->", "searchbutton": "खोज:", @@ -207,14 +211,14 @@ "redirectto": "पठाएको पाना:", "lastmodifiedat": "यै पन्नालाई छाड्डीबार $1मी $2 बजे सम्पादन गरियाऽ थ्यो।", "viewcount": "यो पाना हेरियाको थियो {{PLURAL:$1|एकपटक|$1 पटक}}", - "protectedpage": "सुरक्षित गर्याका पानाहरू", + "protectedpage": "सुरक्षित गरियाका पन्नाअन", "jumpto": "यैमी फट्टाक:", "jumptonavigation": "भ्रमण गरऽ", "jumptosearch": "खोजऽ", "view-pool-error": "माफ गर्या , अहिल सर्भरहरूमी कामको भार भौत रह्या छ।\nभौत भौत प्रयोगकर्ताहरू यै पाना हेद्या प्रयास गरी रह्या छन्।\nकृपया यो पाना पुन: हेर्नु अगाडि थोक्कै पख ।\n\n$1", "generic-pool-error": "माफ गर्या , अहिल सर्भरहरूमी कामको भार भौत रह्या छ।\nभौत भौत प्रयोगकर्ताहरू यै पाना हेद्या प्रयास गरी रह्या छन् ।\nकृपया यो पाना पुन: हेर्नु अगाडि थोक्कै पख ।", - "pool-timeout": "समय सकियो बन्द गर्ने प्रतीक्षामी", - "pool-queuefull": "प्रतीक्षा पङ्क्ति भरियो", + "pool-timeout": "बन्द गद्दाइ समयसीमा सकीन्या प्रतिक्षा मी", + "pool-queuefull": "प्रतिक्षा पङ्क्ति भरियो", "pool-errorunknown": "अज्ञात गल्ती", "pool-servererror": "पुल काउन्टर सेवा उपलब्ध नाइथिन् ($1)।", "poolcounter-usage-error": "प्रयोग गल्ती:$1", @@ -241,6 +245,9 @@ "versionrequired": "MediaWiki संस्करण $1 चाईन्या", "versionrequiredtext": "ये पाना प्रयोग गर्नका लागि MediaWiki $1 संस्करण चाहिन्छ ।\nहेर [[Special:Version|version page]]", "ok": "भयो", + "pagetitle": "$1 - {{SITENAME}}", + "pagetitle-view-mainpage": "{{SITENAME}}", + "backlinksubtitle": "← $1", "retrievedfrom": " \"$1\" बठे निकालियाऽ", "youhavenewmessages": "{{PLURAL:$3|तम सित छन}} $1 ($2)।", "youhavenewmessagesfromusers": "{{PLURAL:$3|अर्खा प्रयोगकर्ता|$3 प्रयोगकर्ताअन}} ($2) मी है {{PLURAL:$4|तम सित}} $1 छन।", @@ -272,6 +279,7 @@ "site-atom-feed": "$1 एटम फीड", "page-rss-feed": "\"$1\" आरएसएस फिड", "page-atom-feed": "\"$1\" एटम फिड", + "feed-rss": "आरएसएस", "red-link-title": "$1 (पन्ना उपलब्ध नाइँथिन)", "sort-descending": "अवरोहण क्रममी मिलाउन्या", "sort-ascending": "आरोहण क्रममी मिलाउन्या", @@ -322,6 +330,7 @@ "badarticleerror": "यो कार्य यै पनामी गर्न नाईंमिल्लो।", "cannotdelete": "\"$1\" पाना वा फाइल मेट्ट सकिएन।\nयो पैल्लीबठे मेटियाको हुनु पडन्छ।", "cannotdelete-title": "पाना \"$1\" लाई मेट्टू सकिएन", + "delete-scheduled": "$1 पन्ना मेटौनाइ खिलाइ समय निर्धारित अरीरैछ।\nकृपया धीरज राखः।", "delete-hook-aborted": "हुकले सम्पादनकार्य बन्द गरिदियो ।\nकोइ कारण दिइएन ।", "no-null-revision": "$1 पाना लागि खालि पुनरावलोकन सिर्जना गर्न सकिएन", "badtitle": "गलत शीर्षक", @@ -359,6 +368,7 @@ "ns-specialprotected": "विशेष पृष्ठहरू सम्पादन अद्दु नाइँ सकिनो।", "titleprotected": "[[User:$1|$1]]द्वारा ये शीर्षक निर्माणहुनबठे जोगाइया छ।\nकारण <em>$2</em> हो ।", "filereadonlyerror": "\"$1\" फाइललाई परिवर्तन अद्दु नाइँ सकिनो क्याईकि फाइल भण्डार \"$2\" केवल पड्ड्या स्थिति (read-only mode)मी छ।\n\nयेलाई सुरक्षित अद्द्या प्रवन्धकले यो कारण दीराइछ: ''$3''।", + "invalidtitle": "अमान्य शीर्षक", "invalidtitle-knownnamespace": "\"$2\" नाउँबार रे \"$3\" पाठ भया: अमान्य शीर्षक", "invalidtitle-unknownnamespace": "अपछ्याणो नाउँबार अङ्क $1 रे पाठ \"$2\" भया: अमान्य शीर्षक", "exception-nologin": "प्रवेश (लग ईन) नगरिएको", @@ -368,6 +378,8 @@ "virus-scanfailed": "जँचाई असफल(कोड $1)", "virus-unknownscanner": "थानभया एन्टीभाइरस:", "logouttext": "<strong>तमी अहिल बाहिर निस्क्याका छौ।</strong>\n\nयाद राख्या तमीले ब्राउजरको क्याच खालि नगर्यासम्म कुनै पानाहरूमी तमी अझैं प्रवेश गरिरख्याको धेकाउन सक्छ।", + "logging-out-notify": "तम लगआउट हुन्नाछः, पख्याः हाँ।", + "logout-failed": "अइल लगआउट नाइहोइसकियो: $1", "cannotlogoutnow-title": "अईल भाईर निकल्ल नाइँ पाईनो", "cannotlogoutnow-text": "भाईर निकल्ल असंभव छ जब प्रयोग $1", "welcomeuser": "$1स्वागत छ!", @@ -444,6 +456,7 @@ "mailmypassword": "पासवर्ड पूर्वनिर्धारित गर", "passwordremindertitle": "{{SITENAME}}का लागि नयाँ अस्थायी पासवर्ड", "passwordremindertext": "कसैले (सायद तमी, IP ठेगाना $1 बाट), {{SITENAME}}($4) को लागि नौलो पासवर्ड अनुरोध गर्या छ । प्रयोगकर्ता \"$2\" को लागि नौलो अस्थायी पासवर्ड \"$3\"तयार पारिया छ । यदि यो तमरो इच्छामी भयाको भया अहिले तमीले लगइन गरीबर नौलो पासवर्ड छान्नु पड्ड्या हुन्छ ।\nतमरो अस्थायी पासवर्ड {{PLURAL:$5|एक दिन|$5 दिनहरू पछि}} अमान्य हुन्याछ ।\n\nयदि कोही अरुले नै अनुरोध गर्याको हो भण्या , या तमीले आफ्नो पासवर्ड सम्झ्यौ भण्या, अथवा\nत्यैलाई परिवर्तन गर्न चाहन्नौ भण्या, तमीले यो सन्देसको वेवास्ता गद्दसक्द्याहौ र पुरानै पासवर्ड प्रयोग गरिरहन सक्द्याहौ ।", + "noemailcreate": "तम ले मान्य इमेल ठिगाना दिन आवश्यक छ।", "blocked-mailpassword": "तमरा IP ठेगानालाई सम्पादन गद्द बठे रोक लाइराइछ। दुरुपयोग रोक्दाइ, तमरा IP ठेगाना बठेइ प्रवेसशब्द पुनर्लाभ प्रक्रिया प्रयोग अद्द्या अनुमति आथिन।", "mailerror": " चिठी :$1 पठाउँदा गल्ती भयो", "noemailprefs": "निम्न सुविधाहरू राम्डरी काम गद्दको लागि तमरो रोजाईमी आफ्नो ई-मेल ठेगाना खुलाओ ।", @@ -525,22 +538,6 @@ "resettokens-token-label": "$1 (यैलको मूल्यः $2)", "resettokens-done": "टोकन पूर्वरुपमी फर्काइयो ।", "resettokens-resetbutton": "चयन गरिया टोकनहरूलाई पुनमिलाउनुहोस्", - "bold_sample": "गाढा अक्षर", - "bold_tip": "गाढा अक्षर", - "italic_sample": "इटालिक पाठ", - "italic_tip": "इटालिक पाठ", - "link_sample": "शीर्षक लिंङ्क", - "link_tip": "भित्रि लिङ्क", - "extlink_sample": "http://www.उदाहरण.com लिङ्क शीर्षक", - "extlink_tip": "भाईरको लिङ्क (समझ्या http:// prefix)", - "headline_sample": "शीर्षक अक्षर", - "headline_tip": "दोसरो स्तर शीर्षपंक्ति", - "nowiki_sample": "प्रारुप नभया पाठ याँ दिया", - "nowiki_tip": "विकि फरम्याटिङ्लाई वास्ता जनगरया", - "image_tip": "इम्बेडेड(जडान गरिया) चित्र", - "media_tip": "फाइल लिङ्क", - "sig_tip": "तमरो समयछाप सहितको दस्तखत", - "hr_tip": "क्षितिजिय रेखा (कम प्रयोग गर्नुहोस्)", "summary": "सारांश:", "subject": "विषय:", "minoredit": "यो नानो सम्पादन हो", @@ -556,7 +553,7 @@ "anoneditwarning": "<strong>चेतावनी:</strong> तमले प्रवेश अरेको नाइथिन । तमरो आइपि ठेगाना पाना सम्पादन इतिहासमि दर्ता गरिन्या छ र यो सब्बैले हेद्द सक्कान । यदि तमलाईँ <strong>[$1 लगईन]</strong> वा <strong>[$2 नयाँ खाता बनाउन्या] गर्याभण्या तमबठे गरियाको सम्पादन तमरो प्रयोगकर्तानाममि जोडिन्याछ ।", "missingsummary": "'''यादगर्या :''' तमीले सम्पादन सारांश दियाका छैनौ ।\nयदि तमीले \"$1\" थिच्यौ भण्या , सारांश बिना नै सङ्ग्रहित गरिन्या छ ।", "selfredirect": "<strong>चेतावनी:</strong> तम यै पानालाई आफुमी पुनः निर्देशित गद्द लाग्याछौ ।\nहुनसक्छ तम अनुप्रेषितको लागि गलत लक्ष्य निर्दिष्ट गद्द लाग्याछौ, वा गलत पानाको सम्पादन गद्द लाग्याछौ ।\nतम पुनः एकपल्ट \"$1\" क्लिक गद्दाछौ, पुनः निर्देशित तसै लै बनाइन्याछ।", - "missingcommenttext": "कृपया तलतिर टिप्पणी राख ।", + "missingcommenttext": "कृपया टिप्पणी राखः।", "missingcommentheader": "'''याद गर :''' तमले टिप्पणीमी विषय /शीर्ष पंक्ति दियाका छैनौ ।\nतमले फेरि \"$1\" थिच्यौ भण्या , तमरो सम्पादन यसै रुपमी संग्रहित हुन्याछ ।", "summary-preview": "सम्पादन सारांशोः पूर्वालोकन:", "subject-preview": "विषयोः पूर्वरुप:", @@ -658,12 +655,12 @@ "page_first": "पैल्लो", "page_last": "छाड्डीबारको", "histlegend": "अन्तर चयन:संशोधनहरूको तुलनाको लागि रेडियो बाकसमी क्लिक गरिबर इण्टर गर अथवा तल दियाको बटनमी थिच <br />\nलिजेंड: (चालू): '''({{int:cur}})''' = अवतरणको बीचमी अन्तर, '''({{int:last}})''' = पैल्लीका अवतरणको बीचमी अन्तर, '''{{int:minoreditletter}}''' = नानो परिवर्तन।", - "history-fieldset-title": "संशोधनअन खिलाइ खोजऽ", + "history-fieldset-title": "संशोधनअन छानः", "history-show-deleted": "संशोधन मेटियाको मात्तरै", "histfirst": "सबहै पुरानो", "histlast": "नयाँ", "historysize": "({{PLURAL:$1|१ अक्षर|$1 अक्षरहरू}})", - "historyempty": "(खाली)", + "historyempty": "खालि", "history-feed-title": "पुनरावलोकन इतिहास", "history-feed-description": "विकीमा यो पानको पुनरावलोकन इतिहास", "history-feed-item-nocomment": "$1 $2मी", @@ -672,7 +669,7 @@ "rev-deleted-user": "(प्रयोगकर्ता नाम हटाइयो)", "rev-deleted-event": "(लग विवरण हटाइयो)", "rev-suppressed-text-unhide": "यै पानाको पुनरावलोकन '''दमन''' गरियाको छ ।\nविस्तृत जानकारी [{{fullurl:{{#Special:Log}}/delete|पानो={{FULLPAGENAMEE}}}} दमन लग] पाउन सकिन्छ ।\nयदि तम अगाडि बढ्ड चाहन्छौ भण्या पनि तमीले [$1 यि संशोधनहरू हेद्द] पाउन्या हौ ।", - "rev-delundel": "दधेखाउने/लुकाउन्या", + "rev-delundel": "दृश्यता बदेलः", "rev-showdeleted": "धेकाउन्या", "revisiondelete": "पुनरावलोकनअन मेट्याऽ/मेट्याऽ रद्द अद्द्या", "revdelete-nooldid-title": "अमान्य पुनरावलोकन लक्ष", @@ -806,7 +803,7 @@ "prefs-editwatchlist-clear": "तमरो अवलोकनसूची मेटा", "prefs-watchlist-days": "ध्यान सूचीमी धेकाउने दिनहरू:", "prefs-watchlist-days-max": "बर्ती है बर्ती $1 {{PLURAL:$1|दिन|दिनअन}}", - "prefs-watchlist-edits": "उच्चतम परिवर्तन संख्या बढाइएको निगरानी सूचीमी धकाउनका लागि :", + "prefs-watchlist-edits": "अवलोकनसूची मी धेकौना परिवर्तनअन को उच्चतम संख्या:", "prefs-watchlist-edits-max": "सबै है ज्यादा संख्या : १०००", "prefs-watchlist-token": "अवलोकन सूची टोकन:", "prefs-misc": "साधारण", @@ -840,14 +837,14 @@ "timezoneregion-europe": "युरोप", "timezoneregion-indian": "हिन्द महासागर", "timezoneregion-pacific": "प्राशान्त महासागर", - "allowemail": "और प्रयोगकर्ताबठे पौन्या ईमेल सक्षम गर।", + "allowemail": "और प्रयोगकर्ताअन लाइ मुइ लाइ ईमेल पठौनेइ अनुमति दिय", "prefs-searchoptions": "खोज", "prefs-namespaces": "नामठौर:", "default": "पूर्वनिर्धारित", "prefs-files": "फाइलहरू", "prefs-custom-css": "अनुकुलित CSS", "prefs-custom-js": "अनुकुल जाभास्क्रिप्ट", - "prefs-common-config": "साझा CSS/जाभा स्क्रिप्ट सबै कि लेखा:", + "prefs-common-config": "सबै खोलअन खिलाइ साझा सीएसएस/जेसन/जावास्क्रिप्ट:", "prefs-reset-intro": "तम ये पृष्ठलाई आफनो अभिरुचीहरू साइट पूर्वावस्थामी फर्काउनत फर्काउन प्रयोग गद्दु सकन्छौ । तै पाछा ये लाई रद्द गद्दु सकन्छौ ।", "prefs-emailconfirm-label": "इ-मेल एकिन प्रक्रिया:", "youremail": "ईमेल", @@ -915,7 +912,7 @@ "grouppage-bureaucrat": "{{ns:project}}:प्रशासकअन", "grouppage-suppress": "{{ns:project}}:लुकौन्या", "right-read": "पृष्ठहरू पढ", - "right-edit": "पृष्ठहरू सम्पादन गर", + "right-edit": "पन्नाअन सम्पादन गरः", "right-createpage": "पृष्ठ निर्माण गर(छलफल पृष्ठहरू बाहेक)", "right-createtalk": "छलफल पृष्ठ सृजना गर", "right-createaccount": "नयाँ प्रयोगकर्ता खाता सृजना गर।", @@ -931,7 +928,7 @@ "right-reupload-own": "आफैले अपलोड गरया रई आया फाइल अधिलेखन गर्न्या", "right-reupload-shared": "साझा मिडिया भण्डारमी स्थानियरुपमी फाइलहरू अधिक्रमण गर्न्या", "right-upload_by_url": "URL बठे फाइल उर्ध्वभरण गर्ने", - "right-purge": "साइटको क्याश( cache) निश्चित नगरिकनै पर्ज(Purge) गर्ने", + "right-purge": "येइ पन्ना को साइट क्याश(cache) पर्ज(Purge) गरः", "right-writeapi": "लेखन API प्रयोग गद्य्या", "right-delete": "पृष्ठहरू मेट्ने", "right-bigdelete": "लामो इतिहास भयाका पानाहरू मेट्ट्या", @@ -953,8 +950,8 @@ "right-userrights-interwiki": "अन्य विकिहरूमी प्रयोगकर्ताहरूको अधिकार सम्पादन गद्या", "right-override-export-depth": "गहिराइ ५ सम्म लिंक गरियाका पानाहरू सहित निर्यात गद्या", "right-sendemail": "अन्य प्रयोगकर्तानलाई इमेल पठाउन्या", - "grant-editmycssjs": "तमरो प्रयोगकर्ता CSS/JavaScript सम्पादन गरऽ", - "grant-editmyoptions": "तमरा प्रयोगकर्ता अभिरुचीइनलाई सम्पादन गरऽ", + "grant-editmycssjs": "तमरो प्रयोगकर्ता CSS/JSON/JavaScript सम्पादन गरः", + "grant-editmyoptions": "तमरा प्रयोगकर्ता अभिरुचिइन रे जेसन(JSON) मिलान सम्पादन गरः", "grant-editmywatchlist": "तमरो अवलोकनसूची सम्पादन गर", "grant-editpage": "भैरया पृष्ठहरू सम्पादन गर", "grant-editprotected": "सुरक्षित पृष्ठ सम्पादन", @@ -985,7 +982,7 @@ "recentchanges-legend-heading": "<strong>आदर्श वाक्य:</strong>", "recentchanges-legend-newpage": "{{int:recentchanges-label-newpage}} ([[Special:NewPages|नौला पानाको सूची]] यैलाई लै हेरिदिय)", "rcfilters-savedqueries-rename": "पुनर्नामकरण", - "rcfilters-savedqueries-remove": "हटाऽ", + "rcfilters-savedqueries-remove": "मेटः", "rcfilters-savedqueries-new-name-label": "नाउँ", "rcfilters-savedqueries-cancel-label": "रद्द", "rcfilters-filter-editsbyself-label": "तम हताँ अरियाऽ फेरबदेलाअन", @@ -993,7 +990,7 @@ "rcfilters-filter-editsbyother-label": "अउर हताँ अरियाऽ फेरबदेलाअन", "rcfilters-filter-editsbyother-description": "तमरा आफ्फुनाइ बाहेक अउर सप्पै फेरबदेलाअन।", "rcfilters-filtergroup-lastrevision": "छाड्डीबारोः संशोधन", - "rcfilters-filter-lastrevision-label": "छाड्डीबारोः संशोधन", + "rcfilters-filter-lastrevision-label": "सबहै नौलो संशोधन", "rclistfrom": "$3 $2 देखिका नयाँ परिवर्तनहरू देखाउन्या", "rcshowhideminor": "$1 सानतिनो सम्पादन", "rcshowhideminor-show": "धेकाइदिय", @@ -1070,7 +1067,7 @@ "filehist-comment": "टिप्पणी", "imagelinks": "फाइल उपयोग", "linkstoimage": "यै चित्रमी निम्न{{PLURAL:$1|पाना जोडिनान{{PLURAL:$1|}}|$1 पानाहरू जोडिनान्}}:", - "nolinkstoimage": "यो चित्रसित लिंकभयाकि कोइ पाना नाइथी", + "nolinkstoimage": "येइ फाइल प्रयोग भयाः कोइ लै पन्ना नाइथिन।", "morelinkstoimage": "यै फाइलको [[Special:WhatLinksHere/$1|थप लिंकहरू]] हेर ।", "sharedupload-desc-here": "यो फाइल $1 बठे हो र और परियोजनाहरू बठे पन प्रयोग गद्द सकिन्याछ । \nताखाइ यैको [$2 फ़ाइल विवरण पानो]मि रयाका विवरण तल्तिर दियाको छ।", "filepage-nofile": "येइ नाउँ को कोइ लै फाइल नाइथिन।", @@ -1301,7 +1298,7 @@ "tooltip-rollback": "\"पूर्वरुप\" ले यो पानाक्क सम्पादन(हरू) खारेज अरिबरे पानालाई एक क्लिकमि पाछाडीको सम्पादनमि पुगाइदिन्छ ।", "tooltip-undo": "\"रद्द\"ले पछिल्लो सम्पादन खारेज गरिबरे पूर्वावलोकनमा धेकाउछ ।\nयैले सारांशमा कारण राख्ख दिन्याछ।", "tooltip-summary": "नानो सारांश हालिदिय", - "siteusers": "{{SITENAME}} {{PLURAL:$2|प्रयोगकर्ता|प्रयोगकर्ताहरू}} $1", + "siteusers": "{{SITENAME}} {{PLURAL:$2|{{GENDER:$1|प्रयोगकर्ता}}|प्रयोगकर्ताअन}} $1", "anonusers": "{{SITENAME}} का नाम नभयाका {{PLURAL:$2| प्रयोगकर्ता|प्रयोगकर्ताहरू}} $1", "simpleantispam-label": "ऐन्टी-स्प्याम जाँच।\nयैलाई <strong>नाइँ</strong> भद्य्या!", "pageinfo-title": "\"$1\" खिलाइ जानकारी", @@ -1366,7 +1363,7 @@ "imgmultipagenext": "अर्खो पन्ना →", "imgmultigo": "जाऽ!", "imgmultigoto": "$1 पन्ना मैं जाऽ", - "size-bytes": "$1 अक्षरहरू", + "size-bytes": "$1 {{PLURAL:$1|बाइट|बाइटअन}}", "size-kilobytes": "$1 किलोबाइट", "size-megabytes": "$1 मेगाबाइट", "size-gigabytes": "$1 गिगाबाइट", diff --git a/languages/i18n/ee.json b/languages/i18n/ee.json index 71def4607f..dd511c2238 100644 --- a/languages/i18n/ee.json +++ b/languages/i18n/ee.json @@ -313,11 +313,6 @@ "changeemail-throttled": "Ètee kpɔ be yeage ɖe eme hedo kpoe zi geɖe akpa le É£eyiÉ£i kpui siawo me. Taflatsɛ lala $1 hafi nàgatee kpɔ.", "changeemail-nochange": "Taflatsɛ ŋlɔ email adrɛs yeye.", "resettokens-watchlist-token": "Ɖɔɖeɖɔdzi nukakala (Atom/RSS) ƒe mɔfiadzesi nyaŋui ƒe [[Special:Tɔtrɔkpɔƒe|tɔtrɔ siwo wowɔ le axa siwo le wò tɔtrɔkpɔƒe ŋu]]", - "bold_sample": "Nuŋɔŋlɔ toto", - "bold_tip": "Nuŋɔŋlɔ toto", - "italic_sample": "Nuŋɔŋlɔ biɖeŋgɔ", - "italic_tip": "Nuŋɔŋlɔ biɖeŋgɔ", - "sig_tip": "Wò asidenute kple gaƒoƒoa", "subject": "Tanya:", "minoredit": "Esia nye tɔtrɔ sue aɖe ko", "watchthis": "Kpɔ axa sia", diff --git a/languages/i18n/egl.json b/languages/i18n/egl.json index 4cf6771d5a..b6226b5189 100644 --- a/languages/i18n/egl.json +++ b/languages/i18n/egl.json @@ -498,22 +498,6 @@ "resettokens-watchlist-token": "Token p'r al feed web (Atom/RSS) dal [[Special:Watchlist|mudéfichi al pàgini ch'ét tîn sòt' ôc]]", "resettokens-done": "Token turnê a impustêr.", "resettokens-resetbutton": "Més a zēro i token sernî", - "bold_sample": "Grasèt", - "bold_tip": "Grasèt", - "italic_sample": "Cursîv", - "italic_tip": "Cursîv", - "link_sample": "Tétol dal colegamèint", - "link_tip": "Colegamèint intêren", - "extlink_sample": "http://www.example.com tétol dal colegamèint", - "extlink_tip": "Colegamèin d'ed fōra (ricôrdet ed mèter préma http://)", - "headline_sample": "Intestasiòun", - "headline_tip": "Intestasiòun ed 2° livèl", - "nowiki_sample": "Mèt dèinter ché al tèst mìa furmatê", - "nowiki_tip": "An badêr mìa la furmatasiòun wiki", - "image_tip": "Mèt dèinter al file", - "media_tip": "Colegamèint al file", - "sig_tip": "Fîrma cun la dâta e l'ōra", - "hr_tip": "Rîga spiâna (drōva cun giudési)", "summary": "Ogèt:", "subject": "Argumèint:", "minoredit": "Còsta l'é 'na mudéfica céca", diff --git a/languages/i18n/el.json b/languages/i18n/el.json index 18534a19bf..266fdb4f7f 100644 --- a/languages/i18n/el.json +++ b/languages/i18n/el.json @@ -648,24 +648,6 @@ "resettokens-watchlist-token": "Κλειδί για την δικτυακή ροή (Atom/RSS) των [[Special:Watchlist|αλλαγών σε σελίδες στη λίστα παρακολούθησής σας]]", "resettokens-done": "Επαναφορά κλειδιών.", "resettokens-resetbutton": "Επαναφορά επιλεγμένων κλειδιών", - "bold_sample": "Έντονο κείμενο", - "bold_tip": "Έντονο κείμενο", - "italic_sample": "Πλάγιο κείμενο", - "italic_tip": "Κείμενο με πλάγιους χαρακτήρες", - "link_sample": "Τίτλος συνδέσμου", - "link_tip": "Εσωτερικός σύνδεσμος", - "extlink_sample": "http://www.example.com τίτλος συνδέσμου", - "extlink_tip": "Εξωτερικός σύνδεσμος (μην ξεχνάτε το πρόθεμα http://)", - "headline_sample": "Κείμενο επικεφαλίδας", - "headline_tip": "Επικεφαλίδα επιπέδου 2", - "nowiki_sample": "Εισαγωγή μη μορφοποιημένου κειμένου εδώ", - "nowiki_tip": "Να αγνοηθεί η μορφοποίηση wiki", - "image_sample": "paradeigma.jpg", - "image_tip": "Ενσωματωμένο αρχείο", - "media_sample": "paradeigma.ogg", - "media_tip": "Σύνδεσμος αρχείου", - "sig_tip": "Η υπογραφή σας με ώρα και ημερομηνία", - "hr_tip": "Οριζόντια γραμμή (να χρησιμοποιείται με φειδώ)", "summary": "Σύνοψη:", "subject": "Θέμα:", "minoredit": "Αυτή είναι μια μικροαλλαγή", diff --git a/languages/i18n/en-gb.json b/languages/i18n/en-gb.json index b42423f28f..188383bb81 100644 --- a/languages/i18n/en-gb.json +++ b/languages/i18n/en-gb.json @@ -562,8 +562,6 @@ "passwordreset-username": "Username:", "changeemail-none": "(none)", "resettokens-tokens": "Tokens:", - "bold_sample": "Bold text", - "italic_sample": "Italic text", "savearticle": "Save page", "anonpreviewwarning": "<em>You are not logged in. Saving will record your IP address in this page's edit history.</em>", "blockedtext": "<strong>Your username or IP address has been blocked.</strong>\n\nThe block was made by $1.\nThe reason given is <em>$2</em>.\n\n* Start of block: $8\n* Expiration of block: $6\n* Intended blockee: $7\n\nYou can contact $1 or another [[{{MediaWiki:Grouppage-sysop}}|administrator]] to discuss the block.\nYou cannot use the \"{{int:emailuser}}\" feature unless a valid e-mail address is specified in your [[Special:Preferences|account preferences]] and you have not been blocked from using it.\nYour current IP address is $3, and the block ID is #$5.\nPlease include all above details in any queries you make.", diff --git a/languages/i18n/en.json b/languages/i18n/en.json index 82826c513f..7944a374f8 100644 --- a/languages/i18n/en.json +++ b/languages/i18n/en.json @@ -442,7 +442,7 @@ "createaccountmail": "Use a temporary random password and send it to the specified email address", "createaccountmail-help": "Can be used to create account for another person without learning the password.", "createacct-realname": "Real name (optional)", - "createacct-reason": "Reason", + "createacct-reason": "Reason (publicly logged)", "createacct-reason-ph": "Why you are creating another account", "createacct-reason-help": "Message shown in the account creation log", "createacct-imgcaptcha-help": "", @@ -628,25 +628,7 @@ "resettokens-watchlist-token": "Token for the web feed (Atom/RSS) of [[Special:Watchlist|changes to pages on your watchlist]]", "resettokens-done": "Tokens reset.", "resettokens-resetbutton": "Reset selected tokens", - "bold_sample": "Bold text", - "bold_tip": "Bold text", - "italic_sample": "Italic text", - "italic_tip": "Italic text", - "link_sample": "Link title", - "link_tip": "Internal link", - "extlink_sample": "http://www.example.com link title", - "extlink_tip": "External link (remember http:// prefix)", - "headline_sample": "Headline text", - "headline_tip": "Level 2 headline", - "nowiki_sample": "Insert non-formatted text here", - "nowiki_tip": "Ignore wiki formatting", - "image_sample": "Example.jpg", - "image_tip": "Embedded file", - "media_sample": "Example.ogg", - "media_tip": "File link", "sig-text": "--$1", - "sig_tip": "Your signature with timestamp", - "hr_tip": "Horizontal line (use sparingly)", "summary": "Summary:", "subject": "Subject:", "minoredit": "This is a minor edit", @@ -1893,6 +1875,7 @@ "listfiles-userdoesnotexist": "User account \"$1\" is not registered.", "imgfile": "file", "listfiles": "File list", + "listfiles_subpage": "Uploads by $1", "listfiles_thumb": "Thumbnail", "listfiles_date": "Date", "listfiles_name": "Name", @@ -4262,5 +4245,8 @@ "mycustomjsredirectprotected": "You do not have permission to edit this JavaScript page because it is a redirect and it does not point inside your userspace.", "easydeflate-invaliddeflate": "Content provided is not properly deflated", "unprotected-js": "For security reasons JavaScript cannot be loaded from unprotected pages. Please only create javascript in the MediaWiki: namespace or as a User subpage", - "userlogout-continue": "Do you want to log out?" + "userlogout-continue": "Do you want to log out?", + "rest-prefix-mismatch": "The requested path ($1) was not inside the REST API root path ($2)", + "rest-wrong-method": "The request method ($1) was not {{PLURAL:$3|the allowed method for this path|one of the allowed methods for this path}} ($2)", + "rest-no-match": "The requested relative path ($1) did not match any known handler" } diff --git a/languages/i18n/eo.json b/languages/i18n/eo.json index a472dc59b9..35223c3e60 100644 --- a/languages/i18n/eo.json +++ b/languages/i18n/eo.json @@ -645,24 +645,6 @@ "resettokens-watchlist-token": "Ä´etono por la retfluo (Atom/RSS) de [[Special:Watchlist|ŝanĝoj je paĝoj sur via atentaro]]", "resettokens-done": "Ä´etonoj restarigitaj.", "resettokens-resetbutton": "Restarigi elektitajn ĵetonojn", - "bold_sample": "Grasa teksto", - "bold_tip": "Grasa teksto", - "italic_sample": "Kursiva teksto", - "italic_tip": "Kursiva teksto", - "link_sample": "Titolo de la ligilo", - "link_tip": "Interna ligilo", - "extlink_sample": "http://www.example.com ligtitolo", - "extlink_tip": "Ekstera ligilo (ne forgesu la prefikson http://)", - "headline_sample": "Titola teksto", - "headline_tip": "Titololinio je dua nivelo", - "nowiki_sample": "Enigi ne formatitan tekston ĉi tie", - "nowiki_tip": "Ignori vikiformatadon", - "image_sample": "Ekzemplo.jpg", - "image_tip": "Enigita dosiero", - "media_sample": "Ekzemplo.ogg", - "media_tip": "Ligilo al dosiero", - "sig_tip": "Via subskribo kun tempindiko", - "hr_tip": "Horizontala linio (uzu ŝpareme)", "summary": "Resumo:", "subject": "Temo:", "minoredit": "Ĉi tiu ŝanĝo estas redakteto", diff --git a/languages/i18n/es.json b/languages/i18n/es.json index 484a44868b..bdf7e75b2c 100644 --- a/languages/i18n/es.json +++ b/languages/i18n/es.json @@ -191,7 +191,8 @@ "Agusbou2015", "Waldyrious", "Johny Weissmuller Jr", - "Dark Dragoon" + "Dark Dragoon", + "Elisardojm" ] }, "tog-underline": "Subrayar enlaces:", @@ -238,6 +239,7 @@ "tog-useeditwarning": "Avisarme cuando abandone una página en edición con cambios sin guardar", "tog-prefershttps": "Utilizar siempre conexiones seguras en mis sesiones", "tog-showrollbackconfirmation": "Mostrar una pantalla de confirmación al hacer clic en un enlace de reversión", + "tog-requireemail": "Es necesario un correo electrónico para reinicializar las contraseña", "underline-always": "Siempre", "underline-never": "Nunca", "underline-default": "Configuración predeterminada de la apariencia o el navegador", @@ -617,7 +619,7 @@ "createaccountmail": "Utilizar una contraseña aleatoria temporal y enviarla a la dirección de correo electrónico especificada", "createaccountmail-help": "Puede usarse para crear una cuenta para otra persona sin revelar la contraseña.", "createacct-realname": "Nombre real (opcional)", - "createacct-reason": "Motivo", + "createacct-reason": "Motivo (registrado públicamente)", "createacct-reason-ph": "Por qué estás creando otra cuenta", "createacct-reason-help": "Mensaje que se muestra en el registro de creación de cuentas", "createacct-submit": "Crea tu cuenta", @@ -786,24 +788,6 @@ "resettokens-watchlist-token": "Clave del canal (Atom/RSS) de [[Special:Watchlist|cambios en las páginas de tu lista de seguimiento]]", "resettokens-done": "Restablecimiento de claves.", "resettokens-resetbutton": "Restablecer las claves", - "bold_sample": "Texto en negrita", - "bold_tip": "Texto en negrita", - "italic_sample": "Texto en cursiva", - "italic_tip": "Texto en cursiva", - "link_sample": "Título del enlace", - "link_tip": "Enlace interno", - "extlink_sample": "http://www.ejemplo.com título del enlace", - "extlink_tip": "Enlace externo (recuerda añadir el prefijo http://)", - "headline_sample": "Texto de encabezado", - "headline_tip": "Título de 2.º nivel", - "nowiki_sample": "Insertar aquí texto sin formato", - "nowiki_tip": "Ignorar el formato wiki", - "image_sample": "Ejemplo.jpg", - "image_tip": "Archivo incrustado", - "media_sample": "Ejemplo.ogg", - "media_tip": "Enlace a archivo", - "sig_tip": "Tu firma con fecha y hora", - "hr_tip": "Línea horizontal (utilizar con moderación)", "summary": "Resumen:", "subject": "Asunto:", "minoredit": "Esta es una edición menor", @@ -987,6 +971,7 @@ "undo-norev": "No se ha podido deshacer la edición porque no existe o ha sido borrada.", "undo-nochange": "Parece que ya se había deshecho la edición.", "undo-summary": "Se ha deshecho la revisión $1 de [[Special:Contributions/$2|$2]] ([[User talk:$2|disc.]])", + "undo-summary-anon": "Deshacer la modificación $1 de [[Special:Contributions/$2|$2]]", "undo-summary-username-hidden": "Se ha deshecho la revisión $1 de un usuario oculto", "cantcreateaccount-text": "[[User:$3|$3]] ha bloqueado la creación de cuentas desde esta dirección IP (<strong>$1</strong>).\n\nEl motivo dado por $3 es <em>$2</em>", "cantcreateaccount-range-text": "[[User:$3|$3]] ha bloqueado la creación de cuentas de usuario desde direcciones IP en el rango <strong>$1</strong>, en el que se encuentra tu dirección IP (<strong>$4</strong>).\n\nEl motivo dado por $3 es <em>$2</em>", @@ -1169,6 +1154,7 @@ "search-interwiki-more": "(más)", "search-interwiki-more-results": "más resultados", "search-relatedarticle": "Relacionado", + "search-invalid-sort-order": "La ordenación $1 no está reconocida, se aplicará la ordenación por defecto. Las ordenaciones válidas sonː $2", "search-unknown-profile": "No se reconoce el perfil de búsqueda $1; se aplicará el perfil predeterminado.", "searchrelated": "relacionado", "searchall": "todos", @@ -1286,6 +1272,7 @@ "prefs-help-email": "La dirección de correo electrónico es opcional, pero es necesaria para el restablecimiento de tu contraseña, en caso de que la olvides.", "prefs-help-email-others": "También puedes permitir que otros usuarios contacten contigo por correo electrónico a través de un enlace en tu página de usuario o de discusión.\nTu dirección de correo no se muestra cuando otros usuarios se ponen en contacto contigo.", "prefs-help-email-required": "Es necesario proporcionar una dirección de correo electrónico.", + "prefs-help-requireemail": "Si está marcado, solo enviará correos electrónicos de restablecimiento de contraseña si la persona que hace el reinicio proporcionó un nombre de usuario y correo electrónico para esta cuenta.", "prefs-info": "Información básica", "prefs-i18n": "Internacionalización", "prefs-signature": "Firma", @@ -1540,9 +1527,9 @@ "action-editusercss": "editar archivos CSS de otros usuarios", "action-edituserjson": "editar archivos JSON de otros usuarios", "action-edituserjs": "editar archivos JavaScript de otros usuarios", - "action-editsitecss": "editar CSS global de la web", + "action-editsitecss": "editar CSS global del sitio", "action-editsitejson": "editar JSON global de la web", - "action-editsitejs": "editar JavaScript global de la web", + "action-editsitejs": "editar JavaScript global del sitio", "action-editmyusercss": "editar tus propios archivos CSS", "action-editmyuserjson": "editar tus propios archivos JSON", "action-editmyuserjs": "editar tus propios archivos JavaScript", @@ -2503,6 +2490,7 @@ "alreadyrolled": "No se puede revertir la última edición de [[:$1]] hecha por [[User:$2|$2]] ([[User talk:$2|discusión]]{{int:pipe-separator}}[[Special:Contributions/$2|{{int:contribslink}}]]);\nalguien más ya ha editado o revertido esa página.\n\nLa última edición fue hecha por [[User:$3|$3]] ([[User talk:$3|discusión]]{{int:pipe-separator}}[[Special:Contributions/$3|{{int:contribslink}}]]).", "editcomment": "El resumen de la edición fue: <em>$1</em>.", "revertpage": "Revertidos los cambios de [[Special:Contributions/$2|$2]] ([[User talk:$2|disc.]]) a la última edición de [[User:$1|$1]]", + "revertpage-anon": "Revertidas las modificaciones de [[Special:Contributions/$2|$2]] a la última versión de [[User:$1|$1]]", "revertpage-nouser": "Revertidas las ediciones hechas por un usuario oculto a la última revisión hecha por {{GENDER:$1|[[User:$1|$1]]}}", "rollback-success": "Revertidas las ediciones de {{GENDER:$3|$1}};\nrecuperada la última versión de {{GENDER:$4|$2}}.", "sessionfailure-title": "Error de sesión", @@ -2739,10 +2727,11 @@ "ipblocklist-legend": "Encontrar a un usuario bloqueado", "blocklist-userblocks": "Ocultar bloqueos de cuenta", "blocklist-tempblocks": "Ocultar bloqueos temporales", + "blocklist-indefblocks": "Ocultar los bloqueos indefinidos", "blocklist-addressblocks": "Ocultar bloqueos de una sola dirección IP", "blocklist-type": "Tipo:", "blocklist-type-opt-all": "Todo", - "blocklist-type-opt-sitewide": "En toda la web", + "blocklist-type-opt-sitewide": "En todo el sitio", "blocklist-type-opt-partial": "Parcial", "blocklist-rangeblocks": "Ocultar bloqueos por intervalo", "blocklist-timestamp": "Marca de tiempo", diff --git a/languages/i18n/et.json b/languages/i18n/et.json index 93bf174fab..b2aa80c705 100644 --- a/languages/i18n/et.json +++ b/languages/i18n/et.json @@ -620,24 +620,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|Jälgimisloendis olevatel lehekülgedel tehtud muudatuste]] veebivoo (Atom/RSS) luba", "resettokens-done": "Load lähtestatud.", "resettokens-resetbutton": "Lähtesta valitud load", - "bold_sample": "Rasvane kiri", - "bold_tip": "Rasvane kiri", - "italic_sample": "Kaldkiri", - "italic_tip": "Kaldkiri", - "link_sample": "Lingitav pealkiri", - "link_tip": "Siselink", - "extlink_sample": "http://www.example.com Lingi nimi", - "extlink_tip": "Välislink (ära unusta eesliidet http://)", - "headline_sample": "Pealkiri", - "headline_tip": "2. taseme pealkiri", - "nowiki_sample": "Sisesta vormindamata tekst", - "nowiki_tip": "Ignoreeri vikivormindust", - "image_sample": "Näidis.jpg", - "image_tip": "Manusfail", - "media_sample": "Näidis.ogg", - "media_tip": "Link failile", - "sig_tip": "Sinu allkiri ajatempliga", - "hr_tip": "Rõhtkriips (kasuta liialdamata)", "summary": "Resümee:", "subject": "Teema:", "minoredit": "See on pisiparandus", diff --git a/languages/i18n/eu.json b/languages/i18n/eu.json index 305043e44f..bd3f140bf2 100644 --- a/languages/i18n/eu.json +++ b/languages/i18n/eu.json @@ -621,24 +621,6 @@ "resettokens-watchlist-token": "(Atom/RSS) jarioarentzako tokenak [[Special:Watchlist|jarraitzen dituzun orrialdeen aldaketetarako]]", "resettokens-done": "Tokenak berrezarrita.", "resettokens-resetbutton": "Hautatutako tokenak berrezarri", - "bold_sample": "Letra lodiko testua", - "bold_tip": "Letra lodiko testua", - "italic_sample": "Testu etzana", - "italic_tip": "Testu etzana", - "link_sample": "Loturaren izenburua", - "link_tip": "Barne lotura", - "extlink_sample": "http://www.example.com loturaren izenburua", - "extlink_tip": "Kanpo lotura (gogoratu http:// aurrizkia)", - "headline_sample": "Goiburuko testua", - "headline_tip": "2. mailako goiburukoa", - "nowiki_sample": "Formatu gabeko testua hemen idatzi", - "nowiki_tip": "Ez egin jaramonik wiki formatuari", - "image_sample": "Adibidea.jpg", - "image_tip": "Txertatutako irudia", - "media_sample": "Adibidea.ogg", - "media_tip": "Media fitxategi lotura", - "sig_tip": "Zure sinadura, gehi data eta ordua", - "hr_tip": "Lerro horizontala (gutxitan erabili)", "summary": "Laburpena:", "subject": "Gaia:", "minoredit": "Aldaketa hau txikia da", diff --git a/languages/i18n/exif/cs.json b/languages/i18n/exif/cs.json index 8bb3f074f2..af2001124f 100644 --- a/languages/i18n/exif/cs.json +++ b/languages/i18n/exif/cs.json @@ -268,6 +268,12 @@ "exif-scenetype-1": "Přímo fotografováno", "exif-customrendered-0": "Běžné zpracování", "exif-customrendered-1": "Uživatelské zpracování", + "exif-customrendered-2": "HDR (bez uložení originálu)", + "exif-customrendered-3": "HDR (originál uložen)", + "exif-customrendered-4": "Originál (pro HDR)", + "exif-customrendered-6": "Panorama", + "exif-customrendered-7": "Portrétní HDR", + "exif-customrendered-8": "Portrét", "exif-exposuremode-0": "Automatická expozice", "exif-exposuremode-1": "Ruční expozice", "exif-exposuremode-2": "Bracketing", diff --git a/languages/i18n/exif/nb.json b/languages/i18n/exif/nb.json index d2c74f5c32..ae5341684a 100644 --- a/languages/i18n/exif/nb.json +++ b/languages/i18n/exif/nb.json @@ -272,6 +272,12 @@ "exif-scenetype-1": "Direktefotografert bilde", "exif-customrendered-0": "Normal prosess", "exif-customrendered-1": "Tilpasset prosess", + "exif-customrendered-2": "HDR (ingen original lagret)", + "exif-customrendered-3": "HDR (original lagret)", + "exif-customrendered-4": "Original (for HDR)", + "exif-customrendered-6": "Panorama", + "exif-customrendered-7": "Portrett-HDR", + "exif-customrendered-8": "Portrett", "exif-exposuremode-0": "Automatisk eksponering", "exif-exposuremode-1": "Manuell eksponering", "exif-exposuremode-2": "Automatisk alternativeksponering", diff --git a/languages/i18n/exif/nds-nl.json b/languages/i18n/exif/nds-nl.json index 3eea40fa3a..73b2b7ba06 100644 --- a/languages/i18n/exif/nds-nl.json +++ b/languages/i18n/exif/nds-nl.json @@ -4,170 +4,170 @@ "Servien" ] }, - "exif-imagewidth": "Wiedte", - "exif-imagelength": "Heugte", + "exif-imagewidth": "Wydde", + "exif-imagelength": "Höygde", "exif-bitspersample": "Bits per komponent", - "exif-compression": "Kompressiemethode", - "exif-photometricinterpretation": "Beeldpuntsamenstelling", - "exif-orientation": "Oriëntasie", - "exif-samplesperpixel": "Antal compenenten", - "exif-planarconfiguration": "Gegevensstructuur", + "exif-compression": "Kompressymetode", + "exif-photometricinterpretation": "Bealdpuntsamenstelling", + "exif-orientation": "Orientaty", + "exif-samplesperpixel": "Antal kompenenten", + "exif-planarconfiguration": "Gegeavensstruktuur", "exif-ycbcrsubsampling": "Subsamplingsverhouwige van Y tot C", - "exif-ycbcrpositioning": "Y- en C-posisionering", - "exif-xresolution": "Horizontale resolusie", - "exif-yresolution": "Verticale resolusie", - "exif-stripoffsets": "Lokasie aofbeeldingsgegevens", - "exif-rowsperstrip": "Riejen per strip", - "exif-stripbytecounts": "Bytes per ekomprimeerden strip", - "exif-jpeginterchangeformat": "Aofstaand tot JPEG SOI", - "exif-jpeginterchangeformatlength": "Bytes van JPEG-gegevens", + "exif-ycbcrpositioning": "Y- en C-positionering", + "exif-xresolution": "Horizontale resoluty", + "exif-yresolution": "Vertikale resoluty", + "exif-stripoffsets": "Lokaty afbealdingsgegeavens", + "exif-rowsperstrip": "Rygen per strip", + "exif-stripbytecounts": "Bytes per komprimeerde strip", + "exif-jpeginterchangeformat": "Afstand tot JPEG SOI", + "exif-jpeginterchangeformatlength": "Bytes van JPEG-gegeavens", "exif-whitepoint": "Witpuntchromaticiteit", - "exif-primarychromaticities": "Chromasiteit van primaere kleuren", - "exif-ycbcrcoefficients": "Transformasiematrixkoëfficiënten veur de kleurruumte", - "exif-referenceblackwhite": "Referensieweerden veur zwart/wit", - "exif-datetime": "Tiedstip van digitalisasie", - "exif-imagedescription": "Aofbeeldingnaam", + "exif-primarychromaticities": "Chromaciteit van primäre klören", + "exif-ycbcrcoefficients": "Transformatymatrixkoefficienten vöär de klöörruumde", + "exif-referenceblackwhite": "Referensywaerden vöär swart/wit", + "exif-datetime": "Tydstip van digitalisaty", + "exif-imagedescription": "Afbealdingname", "exif-make": "Kameramark", "exif-model": "Kameramodel", - "exif-software": "Programmatuur die gebruukt wörden", - "exif-artist": "Eschreven deur", - "exif-copyright": "Auteursrechtenhouwer", - "exif-exifversion": "Exif-versie", - "exif-flashpixversion": "Ondersteunden Flashpix-versie", - "exif-colorspace": "Kleurruumte", - "exif-componentsconfiguration": "Betekenisse van elk compenent", - "exif-compressedbitsperpixel": "Beeldkompressiemethode", - "exif-pixelxdimension": "Aofbeeldingsbreedte", - "exif-pixelydimension": "Aofbeeldingsheugte", - "exif-usercomment": "Opmarkingen", - "exif-relatedsoundfile": "Biebeheurend geluudsbestaand", - "exif-datetimeoriginal": "Tiedstip van datagenerasie", - "exif-datetimedigitized": "Tiedstip van digitalisasie", - "exif-subsectime": "Subseconden tiedstip bestaandswieziging", - "exif-subsectimeoriginal": "Subseconden tiedstip datagenerasie", - "exif-subsectimedigitized": "Subseconden tiedstip digitalisasie", - "exif-exposuretime": "Belochtingstied", + "exif-software": "Programmatuur dee bruked wördt", + "exif-artist": "Autöör", + "exif-copyright": "Autöörsrechtenholder", + "exif-exifversion": "Exif-versy", + "exif-flashpixversion": "Understöände Flashpix-versy", + "exif-colorspace": "Klöörruumde", + "exif-componentsconfiguration": "Beteykenisse van elk kompenent", + "exif-compressedbitsperpixel": "Bealdkompressymetode", + "exif-pixelxdimension": "Afbealdingsbreydde", + "exif-pixelydimension": "Afbealdingshöygde", + "exif-usercomment": "Upmarkingen", + "exif-relatedsoundfile": "Bybehöyrend gelüüdsbestand", + "exif-datetimeoriginal": "Tydstip van datageneraty", + "exif-datetimedigitized": "Tydstip van digitalisaty", + "exif-subsectime": "Subsekonden tydstip bestandswysiging", + "exif-subsectimeoriginal": "Subsekonden tydstip datageneraty", + "exif-subsectimedigitized": "Subsekonden tydstip digitalisaty", + "exif-exposuretime": "Belichtingstyd", "exif-exposuretime-format": "$1 sek ($2)", "exif-fnumber": "F-getal", - "exif-exposureprogram": "Belochtingsprogramma", - "exif-spectralsensitivity": "Spektrale geveuligheid", - "exif-isospeedratings": "ISO-weerde.", + "exif-exposureprogram": "Belichtingsprogramma", + "exif-spectralsensitivity": "Spektrale gevöligheid", + "exif-isospeedratings": "ISO-waerde", "exif-shutterspeedvalue": "Slutersnelheid in APEX", "exif-aperturevalue": "Diafragma in APEX", "exif-brightnessvalue": "Helderheid in APEX", - "exif-exposurebiasvalue": "Belochtingscompensasie", - "exif-maxaperturevalue": "Maximale diafragmaweerde van de lenze", - "exif-subjectdistance": "Aofstaand tot onderwarp", - "exif-meteringmode": "Methode lochmeting", - "exif-lightsource": "Lochbron", + "exif-exposurebiasvalue": "Belichtingskompensaty", + "exif-maxaperturevalue": "Maksimale diafragma-oapening", + "exif-subjectdistance": "Afstand tot underwarp", + "exif-meteringmode": "Metode lichtmeating", + "exif-lightsource": "Lichtbron", "exif-flash": "Flitser", - "exif-focallength": "Braandpuntofstand", - "exif-subjectarea": "Objektruumte", - "exif-flashenergy": "Flitserstarkte", - "exif-focalplanexresolution": "X-resolusie van CDD", - "exif-focalplaneyresolution": "Y-resolusie van CCD", - "exif-focalplaneresolutionunit": "Eenheid CCD-resolusie", - "exif-subjectlocation": "Objeklokasie", - "exif-exposureindex": "Belochtingsindex", - "exif-sensingmethod": "Meetmethode", - "exif-filesource": "Bestaandsnaam op de hardeschieve", - "exif-scenetype": "Scènetype", - "exif-customrendered": "An-epassen beeldbewarking", - "exif-exposuremode": "Belochtingsinstelling", + "exif-focallength": "Brandpuntafstand", + "exif-subjectarea": "Objektruumde", + "exif-flashenergy": "Flitserstarkde", + "exif-focalplanexresolution": "Sensorresoluty horizontaal", + "exif-focalplaneyresolution": "Sensorresoluty vertikaal", + "exif-focalplaneresolutionunit": "Eynheid CCD-resoluty", + "exif-subjectlocation": "Objektlokaty", + "exif-exposureindex": "Belichtingsindeks", + "exif-sensingmethod": "Meatmetode", + "exif-filesource": "Bestandsbron", + "exif-scenetype": "Scenetype", + "exif-customrendered": "Anpasde bealdverwarking", + "exif-exposuremode": "Belichtingsinstelling", "exif-whitebalance": "Witbalans", - "exif-digitalzoomratio": "Digitale zoomfactor", - "exif-focallengthin35mmfilm": "Braandpuntaofstaand (35mm-equivalent)", - "exif-scenecapturetype": "Soort opname", - "exif-gaincontrol": "Piekbeheersing", + "exif-digitalzoomratio": "Digitale zoomfaktor", + "exif-focallengthin35mmfilm": "Brandpuntafstand (35mm-ekwivalent)", + "exif-scenecapturetype": "Soort upnÃ¥me", + "exif-gaincontrol": "Pykbeheyrsing", "exif-contrast": "Kontrast", - "exif-saturation": "Verzaojiging", - "exif-sharpness": "Scharpte", - "exif-devicesettingdescription": "Umschrieving apperaotinstellingen", - "exif-subjectdistancerange": "Aofstaandskategorie", - "exif-imageuniqueid": "Unieke ID-aofbeelding", - "exif-gpsversionid": "GPS-versienummer", - "exif-gpslatituderef": "Noorder- of zujerbreedte", - "exif-gpslatitude": "Breedte", - "exif-gpslongituderef": "Ooster- of westerlengte", - "exif-gpslongitude": "Lengtegraod", - "exif-gpsaltituderef": "Heugtereferensie", - "exif-gpsaltitude": "Heugte", - "exif-gpstimestamp": "GPS-tied (atoomklokke)", - "exif-gpssatellites": "Satellieten die gebruuk bin veur de meting", - "exif-gpsstatus": "Ontvangerstaotus", - "exif-gpsmeasuremode": "Meetmodus", - "exif-gpsdop": "Meetpresisie", - "exif-gpsspeedref": "Snelheidseenheid", - "exif-gpsspeed": "Snelheid van GPS-ontvanger", - "exif-gpstrackref": "Referensie veur bewegingsrichting", - "exif-gpstrack": "Bewegingsrichting", - "exif-gpsimgdirectionref": "Referensie veur aofbeeldingsrichting", - "exif-gpsimgdirection": "Aofbeeldingsrichtige", - "exif-gpsmapdatum": "Geodetiese onderzeuksgegevens die gebruukt bin", - "exif-gpsdestlatituderef": "Referensie veur breedtegraod tot bestemming", - "exif-gpsdestlatitude": "Breedtegraod bestemming", - "exif-gpsdestlongituderef": "Referensie veur lengtegraod bestemming", - "exif-gpsdestlongitude": "Lengtegraod bestemming", - "exif-gpsdestbearingref": "Referensie veur richting naor bestemming", - "exif-gpsdestbearing": "Richting naor bestemming", - "exif-gpsdestdistanceref": "Referensie veur aofstaand tot bestemming", - "exif-gpsdestdistance": "Aofstaand tot bestemming", - "exif-gpsprocessingmethod": "Naam van de GPS-verwarkingsmethode", - "exif-gpsareainformation": "Naam van t GPS-gebied", - "exif-gpsdatestamp": "GPS-daotum", - "exif-gpsdifferential": "Differensiële GPS-korreksie", - "exif-jpegfilecomment": "Opmarking bie JPEG-bestaand", + "exif-saturation": "VersÃ¥diging", + "exif-sharpness": "Skarpde", + "exif-devicesettingdescription": "Ümskryving apparaatinstellingen", + "exif-subjectdistancerange": "Bereik objektafstand", + "exif-imageuniqueid": "Unike ID-afbealding", + "exif-gpsversionid": "GPS-versynummer", + "exif-gpslatituderef": "Noorder- of süderbreydde", + "exif-gpslatitude": "Breydde", + "exif-gpslongituderef": "Ouster- of westerlängde", + "exif-gpslongitude": "LängdegrÃ¥d", + "exif-gpsaltituderef": "Höygdereferensy", + "exif-gpsaltitude": "Höygde", + "exif-gpstimestamp": "GPS-tyd (atoomklokke)", + "exif-gpssatellites": "Satelliten dee bruked binnet vöär de meating", + "exif-gpsstatus": "UntvangerstÃ¥tus", + "exif-gpsmeasuremode": "Meatmodus", + "exif-gpsdop": "Meatprecisy", + "exif-gpsspeedref": "Snelheid eynheid", + "exif-gpsspeed": "Snelheid van GPS-untvanger", + "exif-gpstrackref": "Referensy vöär beweagingsrichting", + "exif-gpstrack": "Beweagingsrichting", + "exif-gpsimgdirectionref": "Referensy vöär afbealdingsrichting", + "exif-gpsimgdirection": "Afbealdingsrichting", + "exif-gpsmapdatum": "Geodetiske undersööksgegeavens dee bruked binnet", + "exif-gpsdestlatituderef": "Referensy vöär breyddegrÃ¥d tot bestemming", + "exif-gpsdestlatitude": "BreyddegrÃ¥d bestemming", + "exif-gpsdestlongituderef": "Referensy vöär längdegrÃ¥d bestemming", + "exif-gpsdestlongitude": "LängdegrÃ¥d bestemming", + "exif-gpsdestbearingref": "Referensy vöär richting nÃ¥ bestemming", + "exif-gpsdestbearing": "Richting nÃ¥ bestemming", + "exif-gpsdestdistanceref": "Referensy vöär afstand tot bestemming", + "exif-gpsdestdistance": "Afstand tot bestemming", + "exif-gpsprocessingmethod": "Name van de GPS-verwarkingsmetode", + "exif-gpsareainformation": "Name van et GPS-gebeed", + "exif-gpsdatestamp": "GPS-dÃ¥tum", + "exif-gpsdifferential": "Differentiele GPS-korrekty", + "exif-jpegfilecomment": "Upmarking by JPEG-bestand", "exif-keywords": "Trefwoorden", - "exif-worldregioncreated": "Regio in de wereld waor de aofbeelding emaakt is", - "exif-countrycreated": "Laand waor de aofbeelding emaakt is", - "exif-countrycodecreated": "Kode veur t laand waor de aofbeelding emaakt is", - "exif-provinceorstatecreated": "Provinsie of staot waor de aofbeelding emaakt is", - "exif-citycreated": "Plaotse waor de aofbeelding emaakt is", - "exif-sublocationcreated": "Wiek van de plaotse waor de aofbeelding emaakt is", - "exif-worldregiondest": "Weeregeven wereldregio", - "exif-countrydest": "Weeregeven laand", - "exif-countrycodedest": "Kode veur t weeregeven laand", - "exif-provinceorstatedest": "Weeregeven provinsie of staot", - "exif-citydest": "Weeregeven plaotse", - "exif-sublocationdest": "Weeregeven wiek in plaotse", - "exif-objectname": "Korte naam", - "exif-specialinstructions": "Spesiale instruksies", - "exif-headline": "Kopjen", - "exif-credit": "Krediet/leverancier", + "exif-worldregioncreated": "Regio in de wearld wÃ¥r de afbealding maked is", + "exif-countrycreated": "Land wÃ¥r de afbealding maked is", + "exif-countrycodecreated": "Kode vöär et land wÃ¥r de afbealding maked is", + "exif-provinceorstatecreated": "Provinsy of stÃ¥t wÃ¥r de afbealding maked is", + "exif-citycreated": "Plaatse wÃ¥r de afbealding maked is", + "exif-sublocationcreated": "Wyk van de plaatse wÃ¥r de afbealding maked is", + "exif-worldregiondest": "Weadergeaven wearldregio", + "exif-countrydest": "Weadergeaven land", + "exif-countrycodedest": "Kode vöär et weadergeaven land", + "exif-provinceorstatedest": "Weadergeaven provinsy of stÃ¥t", + "exif-citydest": "Weadergeaven plaatse", + "exif-sublocationdest": "Weadergeaven wyk in plaatse", + "exif-objectname": "Korte name", + "exif-specialinstructions": "Speciale instruktys", + "exif-headline": "Upskrivt", + "exif-credit": "Kredit/leaveransyr", "exif-source": "Bron", - "exif-editstatus": "Bewarkingsstaotus van de aofbeelding", - "exif-urgency": "Urgensie", - "exif-fixtureidentifier": "Groepsnaam", - "exif-locationdest": "Weeregeven lokasie", - "exif-locationdestcode": "Kode veur de weeregeven lokasie", - "exif-objectcycle": "Tied van de dag waor de media veur bedoeld is", - "exif-contact": "Kontaktgegevens", - "exif-writer": "Schriever", - "exif-languagecode": "Taal", - "exif-iimversion": "IIM-versie", - "exif-iimcategory": "Kategorie", - "exif-iimsupplementalcategory": "Anvullende kategorieën", - "exif-datetimeexpires": "Niet te gebruken nao", - "exif-datetimereleased": "Uutebröcht op", - "exif-originaltransmissionref": "Oorspronkelike taaklokasiekode", + "exif-editstatus": "BewarkingsstÃ¥tus van de afbealding", + "exif-urgency": "Urgensy", + "exif-fixtureidentifier": "Grupsname", + "exif-locationdest": "Weadergeaven lokaty", + "exif-locationdestcode": "Kode vöär de weadergeaven lokaty", + "exif-objectcycle": "Tyd van de dag wÃ¥r de media vöär bedoold is", + "exif-contact": "Kontaktgegeavens", + "exif-writer": "Skryver", + "exif-languagecode": "SprÃ¥ke", + "exif-iimversion": "IIM-versy", + "exif-iimcategory": "Kategory", + "exif-iimsupplementalcategory": "Anvüllende kategoryen", + "exif-datetimeexpires": "Neet te bruken nÃ¥", + "exif-datetimereleased": "Uutbröcht up", + "exif-originaltransmissionref": "Oorsprungelike sprÃ¥klokatykode", "exif-identifier": "ID", - "exif-lens": "Lenze die gebruukt wörden", - "exif-serialnumber": "Serienummer van de camera", - "exif-cameraownername": "Eigenaar van camera", + "exif-lens": "Brukede lense", + "exif-serialnumber": "Serynummer van de kamera", + "exif-cameraownername": "Eigenaar van kamera", "exif-label": "Etiket", - "exif-datetimemetadata": "Daotum waorop de metadata veur t lest bie-ewörken bin", - "exif-nickname": "Informele naam van de aofbeelding", - "exif-rating": "Werdering (op n schaole van 5)", - "exif-rightscertificate": "Rechtenbeheercertificaot", - "exif-copyrighted": "Auteursrechtstaotus", - "exif-copyrightowner": "Auteursrechtenhouwer", - "exif-usageterms": "Gebruuksveurweerden", - "exif-webstatement": "Internetauteursrechverklaoring", - "exif-originaldocumentid": "Uniek ID van t originele dokument", - "exif-licenseurl": "Webadres veur auteursrechlisensie", - "exif-morepermissionsurl": "Alternatieve lisensiegegevens", - "exif-attributionurl": "Gebruuk de volgende verwiezing bie hergebruuk van dit wark", - "exif-preferredattributionname": "Gebruuk de volgende makersvermelding bie hergebruuk van dit wark", + "exif-datetimemetadata": "DÃ¥tum wÃ¥rup de metadata vöär et lätst bywarked is", + "exif-nickname": "Informele name van de afbealding", + "exif-rating": "Wardering (up en skale van 5)", + "exif-rightscertificate": "Rechtenbeheyrcertifikaat", + "exif-copyrighted": "AutöörsrechtenstÃ¥tus", + "exif-copyrightowner": "Autöörsrechtenholder", + "exif-usageterms": "Bruuksbeding", + "exif-webstatement": "Binnennetse autöörsrechtenverklÃ¥ring", + "exif-originaldocumentid": "Unik ID van et originele dokument", + "exif-licenseurl": "Webadres vöär autöörsrechtenlicensy", + "exif-morepermissionsurl": "Alternative licensygegeavens", + "exif-attributionurl": "Bruuk de volgende verwysing as dit wark herbruked wördt", + "exif-preferredattributionname": "Bruuk de volgende makersvermelding as dit wark herbruked wördt", "exif-pngfilecomment": "Opmarking bie PNG-bestaand", "exif-disclaimer": "Vöärbehold", "exif-contentwarning": "Waorschuwing over inhoud", diff --git a/languages/i18n/exif/sr-ec.json b/languages/i18n/exif/sr-ec.json index 44e3c94339..fdc959c0a9 100644 --- a/languages/i18n/exif/sr-ec.json +++ b/languages/i18n/exif/sr-ec.json @@ -297,6 +297,12 @@ "exif-scenetype-1": "Директно фотографисана слика", "exif-customrendered-0": "Нормалан процес", "exif-customrendered-1": "Нестандардан процес", + "exif-customrendered-2": "HDR (није оригинално сачувано)", + "exif-customrendered-3": "HDR (оригинал сачуван)", + "exif-customrendered-4": "Оригинал (за HDR)", + "exif-customrendered-6": "Панорама", + "exif-customrendered-7": "HDR портрет", + "exif-customrendered-8": "Портрет", "exif-exposuremode-0": "Аутоматска експозиција", "exif-exposuremode-1": "Ручна експозиција", "exif-exposuremode-2": "Аутоматски са задатим распоном", diff --git a/languages/i18n/exif/tt-cyrl.json b/languages/i18n/exif/tt-cyrl.json index 5752beefee..74bc787ad0 100644 --- a/languages/i18n/exif/tt-cyrl.json +++ b/languages/i18n/exif/tt-cyrl.json @@ -96,6 +96,12 @@ "exif-gpsspeed": "Хәрәкәт тизлеге", "exif-gpsdatestamp": "GPS датасы", "exif-keywords": "Иң мөһиме", + "exif-countrydest": "Күрсәтелгән ил", + "exif-countrycodedest": "Күрсәтелгән илнең коды", + "exif-provinceorstatedest": "Күрсәтелгән өлкә яки штат", + "exif-citydest": "Күрсәтелгән шәһәр", + "exif-sublocationdest": "Күрсәтелгән шәһәрнең җире", + "exif-objectname": "Кыска исем", "exif-headline": "Башисем", "exif-source": "Чыганак", "exif-contact": "Элемтә өчен мәгълүмат", @@ -104,8 +110,9 @@ "exif-iimversion": "IIM юрамасы", "exif-iimcategory": "Төркем", "exif-iimsupplementalcategory": "Өстәмә төркемнәр", - "exif-datetimereleased": "Чыгарылу вакыты", + "exif-datetimereleased": "Чыгарылыш вакыты", "exif-identifier": "Идентификатор", + "exif-cameraownername": "Камера иясе", "exif-label": "Билгеләү", "exif-copyrighted": "Авторлык хокукы халәте", "exif-copyrightowner": "Авторлык хокукы иясе", @@ -124,6 +131,7 @@ "exif-subjectdistance-value": "$1 {{PLURAL:$1|метр}}", "exif-meteringmode-0": "Билгесез", "exif-meteringmode-1": "Уртача", + "exif-meteringmode-2": "Үзәк буенча уртача үлчәүле", "exif-meteringmode-3": "Нокталы", "exif-meteringmode-4": "Күп нокталы", "exif-meteringmode-5": "Паттернлы", @@ -131,13 +139,20 @@ "exif-meteringmode-255": "Башка", "exif-lightsource-0": "Билгесез", "exif-lightsource-1": "Көндезге яктылык", + "exif-lightsource-2": "Көн яктылыгы лампасы", + "exif-lightsource-3": "Кыздыру лампасы", "exif-lightsource-4": "Яктылык", "exif-lightsource-9": "Аяз", "exif-lightsource-10": "Болытлы", "exif-lightsource-11": "Күләгә", + "exif-lightsource-12": "Көн яктылыгы лампасы (D 5700–7100 K)", + "exif-lightsource-13": "Көн яктылыгы лампасы (N 4600–5400 K)", + "exif-lightsource-14": "Көн яктылыгы лампасы (W 3900–4500 K)", + "exif-lightsource-15": "Көн яктылыгы лампасы (WW 3200–3700 K)", "exif-flash-mode-3": "автоматик режим", "exif-focalplaneresolutionunit-2": "дюйм", "exif-sensingmethod-1": "Билгесез", + "exif-customrendered-6": "Манзара", "exif-scenecapturetype-0": "Стандарт", "exif-scenecapturetype-1": "Ландшафт", "exif-scenecapturetype-2": "Портрет", @@ -164,8 +179,12 @@ "exif-gpslatitude-s": "көньяк киңлек", "exif-gpslongitude-e": "көнчыгыш озынлык", "exif-gpslongitude-w": "көнбатыш озынлык", - "exif-gpsstatus-a": "Үлчәү тәмамланмаган", + "exif-gpsaltitude-above-sealevel": "Диңгез биеклеге өстеннән $1 {{PLURAL:$1|метр}}", + "exif-gpsaltitude-below-sealevel": "Диңгез биеклеге астыннан $1 {{PLURAL:$1|метр}}", + "exif-gpsstatus-a": "Үлчәү бара", "exif-gpsstatus-v": "Мәгълүматларны җибәрүгә әзер", + "exif-gpsmeasuremode-2": "2 координат буенча үлчәү", + "exif-gpsmeasuremode-3": "3 координат буенча үлчәү", "exif-gpsspeed-k": "км/сәг", "exif-gpsspeed-m": "миль/сәг", "exif-gpsspeed-n": "узел", @@ -188,7 +207,9 @@ "exif-dc-type": "Медиа төре", "exif-rating-rejected": "Кире кагылды", "exif-isospeedratings-overflow": "65535 тән күбрәк", + "exif-iimcategory-clj": "Җинаять һәм хокук", "exif-iimcategory-fin": "Экономика һәм бизнес", + "exif-iimcategory-edu": "Мәгариф", "exif-iimcategory-evn": "Әйләнә-тирәдәге мохит", "exif-iimcategory-hth": "Сәламәтлек", "exif-iimcategory-lab": "Хезмәт", @@ -196,6 +217,7 @@ "exif-iimcategory-rel": "Дин һәм иман", "exif-iimcategory-sci": "Фән һәм техника", "exif-iimcategory-spo": "Спорт", + "exif-iimcategory-war": "Сугыш, низаг һәм чуалыш", "exif-iimcategory-wea": "Һава торышы", "exif-urgency-normal": "Гадәти ($1)", "exif-urgency-low": "Түбән ($1)", diff --git a/languages/i18n/exif/zh-hans.json b/languages/i18n/exif/zh-hans.json index 50d1db2f02..72c8fbe88b 100644 --- a/languages/i18n/exif/zh-hans.json +++ b/languages/i18n/exif/zh-hans.json @@ -10,7 +10,8 @@ "Qiyue2001", "Xiaomingyan", "神樂坂秀吉", - "予弦" + "予弦", + "Wenyuan Liu" ] }, "exif-imagewidth": "宽度", @@ -277,6 +278,12 @@ "exif-scenetype-1": "直接照像图片", "exif-customrendered-0": "标准处理", "exif-customrendered-1": "自定义处理", + "exif-customrendered-2": "HDR(没有保留原始信息)", + "exif-customrendered-3": "HDR(保留原始信息)", + "exif-customrendered-4": "原始(用于HDR)", + "exif-customrendered-6": "全景", + "exif-customrendered-7": "竖向 HDR", + "exif-customrendered-8": "竖向", "exif-exposuremode-0": "自动曝光", "exif-exposuremode-1": "手动曝光", "exif-exposuremode-2": "自动曝光感知调节", diff --git a/languages/i18n/ext.json b/languages/i18n/ext.json index 5df7c1521a..4d42667ede 100644 --- a/languages/i18n/ext.json +++ b/languages/i18n/ext.json @@ -364,24 +364,6 @@ "resetpass-submit-loggedin": "Escambial consínia", "resetpass-submit-cancel": "Cancelal", "resetpass-temp-password": "Consínia temporal:", - "bold_sample": "Testu en letra \"Bold\"", - "bold_tip": "Testu en letra \"Bold\"", - "italic_sample": "Testu en letra \"Itálica\"", - "italic_tip": "Testu en letra \"Itálica\"", - "link_sample": "Atihal entítulu", - "link_tip": "Atihu entelnu", - "extlink_sample": "http://www.example.com Entítulu el atihu", - "extlink_tip": "Atihu esternu (alcuerdati el prefihu http://)", - "headline_sample": "Entítulu", - "headline_tip": "Entítulu e nivel 2", - "nowiki_sample": "Añiil testu sin hormatu aquí", - "nowiki_tip": "Inoral hormatu güiqui", - "image_sample": "Sabulugal.jpg", - "image_tip": "Imahin encuairá", - "media_sample": "Sabulugal.ogg", - "media_tip": "Atihu d'archivu", - "sig_tip": "Firma, fecha i ora", - "hr_tip": "Línia orizontal (deseparaol)", "summary": "Síntesis:", "subject": "Tema/entítulu:", "minoredit": "Esta es una eición chiquenina", diff --git a/languages/i18n/fa.json b/languages/i18n/fa.json index 0b0f7ce0e4..66db5bdfa7 100644 --- a/languages/i18n/fa.json +++ b/languages/i18n/fa.json @@ -665,24 +665,6 @@ "resettokens-watchlist-token": "شناسانندهٔ خوراک وبِی [[Special:Watchlist|تغییرات صفحه‌هایی که پی‌گیری می‌کنید]] (اتم/آراس‌اس)", "resettokens-done": "بازنشانی شناساننده‌ها.", "resettokens-resetbutton": "بازشناسی شناساننده‌های گزیده‌شده.", - "bold_sample": "متن پررنگ", - "bold_tip": "متن پررنگ", - "italic_sample": "متن مورب", - "italic_tip": "متن مورب", - "link_sample": "عنوان پیوند", - "link_tip": "پیوند درونی", - "extlink_sample": "http://www.example.com عنوان پیوند", - "extlink_tip": "پیوند به بیرون (پیشوند http://‎ را فراموش نکنید)", - "headline_sample": "متن عنوان", - "headline_tip": "عنوان سطح Û²", - "nowiki_sample": "متن قالب‌بندی‌نشده اینجا وارد شود", - "nowiki_tip": "نادیده‌گرفتن قالب‌بندی ویکی", - "image_sample": "Example.jpg", - "image_tip": "تصویر داخل متن", - "media_sample": "Example.ogg", - "media_tip": "پیوند پرونده", - "sig_tip": "امضای شما و برچسب زمان", - "hr_tip": "خط افقی (از آن کم استفاده کنید)", "summary": "خلاصه:", "subject": "عنوان:", "minoredit": "این ویرایش، جزئی است", diff --git a/languages/i18n/fi.json b/languages/i18n/fi.json index 994b1e1de5..7d8e5964ec 100644 --- a/languages/i18n/fi.json +++ b/languages/i18n/fi.json @@ -658,24 +658,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|Tarkkailulistan]] verkkosyötteen (Atom tai RSS) avain", "resettokens-done": "Avaimet on uudistettu.", "resettokens-resetbutton": "Uudista valitut avaimet", - "bold_sample": "Lihavoitu teksti", - "bold_tip": "Lihavointi", - "italic_sample": "Kursivoitu teksti", - "italic_tip": "Kursivointi", - "link_sample": "linkki", - "link_tip": "Sisäinen linkki", - "extlink_sample": "http://www.example.com linkin otsikko", - "extlink_tip": "Ulkoinen linkki (muista http:// edessä)", - "headline_sample": "Otsikkoteksti", - "headline_tip": "Otsikko", - "nowiki_sample": "Lisää muotoilematon teksti tähän", - "nowiki_tip": "Tekstiä, jota wiki ei muotoile", - "image_sample": "Esimerkki.jpg", - "image_tip": "Tallennettu tiedosto", - "media_sample": "Esimerkki.ogg", - "media_tip": "Tiedostolinkki", - "sig_tip": "Allekirjoitus aikaleiman kanssa", - "hr_tip": "Vaakasuora viiva", "summary": "Yhteenveto:", "subject": "Aiheotsikko:", "minoredit": "Tämä on pieni muutos", @@ -3531,7 +3513,7 @@ "logentry-partialblock-block-page": "{{PLURAL:$1|sivua|sivuja}} $2", "logentry-partialblock-block-ns": "{{PLURAL:$1|nimiavaruutta|nimiavaruuksia}} $2", "logentry-partialblock-block": "$1 {{GENDER:$2|esti}} käyttäjää {{GENDER:$4|$3}} muokkaamasta $7. Eston kesto on $5 $6", - "logentry-partialblock-reblock": "$1 {{GENDER:$2|muutti}} käyttäjän {{GENDER:$4|$3}} muokkauseston asetuksia estäen muokkausten tekemisen $7. Eston kesto on $5 $6", + "logentry-partialblock-reblock": "$1 {{GENDER:$2|muutti}} käyttäjän {{GENDER:$4|$3}} muokkauseston asetuksia niin, että hän ei voi muokata $7. Eston kesto on $5 $6", "logentry-non-editing-block-block": "$1 {{GENDER:$2|esti}} käyttäjää {{GENDER:$4|$3}} suorittamasta määrättyjä toimenpiteitä (lukuun ottamatta muokkaamista). Eston kesto on $5 $6", "logentry-non-editing-block-reblock": "$1 {{GENDER:$2|muutti}} käyttäjän {{GENDER:$4|$3}} toimintaeston asetuksia, jotka koskevat määrättyjä toimenpiteitä. Eston kesto on $5 $6", "logentry-suppress-block": "$1 {{GENDER:$2|esti}} käyttäjän {{GENDER:$4|$3}}. Eston kesto on $5 $6", diff --git a/languages/i18n/fit.json b/languages/i18n/fit.json index 5ce9fd5844..57f8978415 100644 --- a/languages/i18n/fit.json +++ b/languages/i18n/fit.json @@ -205,22 +205,6 @@ "passwordreset-email": "E-postin atressi:", "changeemail": "Muuta tai poista E-postin atressi", "changeemail-newemail": "Uusi E-postin atressi:", - "bold_sample": "Lihava teksti", - "bold_tip": "Lihava teksti", - "italic_sample": "Kyrsiveerattu teksti", - "italic_tip": "Kyrsiveerattu", - "link_sample": "linkin nimi", - "link_tip": "Sisäinen linkki", - "extlink_sample": "http://www.example.com linkin rypriikki", - "extlink_tip": "Eksterni linkki (muista http:// eessä)", - "headline_sample": "Rypriikkiteksti", - "headline_tip": "Aste 2 rypriikki", - "nowiki_sample": "Lissää muotoilematon teksti tähhään", - "nowiki_tip": "Iknureeraa wiki formateerinkin", - "image_tip": "Piilotettu fiili", - "media_tip": "Linkki fiilhiin", - "sig_tip": "Allekirjotus aikaleimala", - "hr_tip": "Horisontaali linja (käytethään säästävästi)", "summary": "Yhteenveto", "minoredit": "Tämä on pieni muutos", "watchthis": "Valvo tätä sivua", diff --git a/languages/i18n/fo.json b/languages/i18n/fo.json index 74a6574ee2..a41b6312f7 100644 --- a/languages/i18n/fo.json +++ b/languages/i18n/fo.json @@ -504,24 +504,6 @@ "resettokens-token-label": "$1 (dagsins virði: $2)", "resettokens-done": "Nullstilla lyklar.", "resettokens-resetbutton": "Nullstilla útvaldu lyklar (tokens)", - "bold_sample": "Feitir stavir", - "bold_tip": "Feitir stavir", - "italic_sample": "Skákstavir", - "italic_tip": "Skákstavir", - "link_sample": "Slóðarheiti", - "link_tip": "Innanhýsis slóð", - "extlink_sample": "http://www.example.com slóðarheiti", - "extlink_tip": "Útvortis slóð (minst til http:// forskoytið)", - "headline_sample": "Yvirskriftartekstur", - "headline_tip": "Annars stigs yvirskrift", - "nowiki_sample": "Skriva ikki-formateraðan tekst her", - "nowiki_tip": "Ignorera wiki-forsniðan", - "image_sample": "Dømi.jpg", - "image_tip": "Innset mynd", - "media_sample": "Dømi.ogg", - "media_tip": "Fílu slóð", - "sig_tip": "Tín undirskrift við tíðarstempli", - "hr_tip": "Vatnrøtt linja (vera sparin við)", "summary": "Samandráttur:", "subject": "Evni:", "minoredit": "Hetta er smábroyting", diff --git a/languages/i18n/fr.json b/languages/i18n/fr.json index 41b229309a..07f248d7f7 100644 --- a/languages/i18n/fr.json +++ b/languages/i18n/fr.json @@ -218,6 +218,7 @@ "tog-useeditwarning": "M’avertir quand je quitte une page en cours de modification sans avoir sauvegardé", "tog-prefershttps": "Toujours utiliser une connexion sécurisée lorsque je suis connecté", "tog-showrollbackconfirmation": "Afficher une demande de confirmation en cliquant sur un lien d’annulation", + "tog-requireemail": "Nécessiter un courriel pour les réinitialisations de mot de passe", "underline-always": "Toujours", "underline-never": "Jamais", "underline-default": "Valeur par défaut du thème ou du navigateur", @@ -597,7 +598,7 @@ "createaccountmail": "Utiliser un mot de passe aléatoire temporaire et l’envoyer à l’adresse de courriel spécifiée", "createaccountmail-help": "Peut être utilisé pour créer un compte pour une autre personne sans connaître le mot de passe.", "createacct-realname": "Nom réel (facultatif)", - "createacct-reason": "Motif", + "createacct-reason": "Motif (connecté publiquement)", "createacct-reason-ph": "Pourquoi créez-vous un autre compte", "createacct-reason-help": "Message affiché dans le journal de création de compte", "createacct-submit": "Créez votre compte", @@ -623,7 +624,7 @@ "noname": "Vous n’avez pas saisi un nom d’utilisateur valide.", "loginsuccesstitle": "Connecté", "loginsuccess": "<strong>Vous êtes maintenant connecté{{GENDER:$1||e|(e)}} à {{SITENAME}} en tant que « $1 ».</strong>", - "nosuchuser": "L’utilisateur « $1 » n’existe pas.\nLes noms d’utilisateur sont sensibles à la casse.\nVérifiez l’orthographe, ou [[Special:CreateAccount|créez un nouveau compte]].", + "nosuchuser": "L’utilisateur « $1 » n’existe pas.\nLes noms d’utilisateur sont sensibles à la casse.\nVérifiez l’orthographe ou [[Special:CreateAccount|créez un nouveau compte]].", "nosuchusershort": "Il n’y a pas de contributeur avec le nom « $1 ».\nVeuillez vérifier l’orthographe.", "nouserspecified": "Vous devez saisir un nom d’utilisateur.", "login-userblocked": "{{GENDER:$1|Cet utilisateur|Cette utilisatrice}} est bloqué{{GENDER:$1||e}}. La connexion n’est pas autorisée.", @@ -637,7 +638,7 @@ "password-login-forbidden": "L’utilisation de ce nom d’utilisateur ou de ce mot de passe a été interdite.", "mailmypassword": "Réinitialiser le mot de passe", "passwordremindertitle": "Nouveau mot de passe temporaire pour {{SITENAME}}", - "passwordremindertext": "Quelqu’un (depuis l’adresse IP $1) a demandé un nouveau mot de\npasse pour {{SITENAME}} ($4). Un mot de passe temporaire pour l’utilisateur\n« $2 » a été créé et défini comme « $3 ». Si c’était bien votre intention,\nvous devrez vous connecter et choisir un nouveau mot de passe.\nVotre mot de passe temporaire expirera dans $5 jour{{PLURAL:$5||s}}.\n\nSi vous n’êtes pas l’auteur de cette demande, ou si vous vous avez retrouvé votre mot de passe et ne souhaitez plus en changer, vous pouvez ignorer ce message\net continuer à utiliser votre ancien mot de passe.", + "passwordremindertext": "Quelqu’un (depuis l’adresse IP $1) a demandé un nouveau mot de passe\npour {{SITENAME}} ($4). Un mot de passe temporaire pour l’utilisateur\n« $2 » a été créé et défini comme « $3 ». Si c’était bien votre intention,\nvous devrez vous connecter et choisir un nouveau mot de passe.\nVotre mot de passe temporaire expirera dans $5 jour{{PLURAL:$5||s}}.\n\nSi vous n’êtes pas l’auteur de cette demande ou si vous vous avez retrouvé votre\nmot de passe et ne souhaitez plus en changer, vous pouvez ignorer ce message et\ncontinuer à utiliser votre ancien mot de passe.", "noemail": "Aucune adresse de courriel n’a été enregistrée pour l’utilisat{{GENDER:$1|eur|rice}} « $1 ».", "noemailcreate": "Vous devez fournir une adresse de courriel valide", "passwordsent": "Un nouveau mot de passe a été envoyé à l’adresse de courriel de l’utilisat{{GENDER:$1|eur|rice}} « $1 ».\nVeuillez vous reconnecter après l’avoir reçu.", @@ -766,24 +767,6 @@ "resettokens-watchlist-token": "Jeton pour le flux (Atom/RSS) web de [[Special:Watchlist|modifications de pages de votre liste de suivi]]", "resettokens-done": "Jetons réinitialisés.", "resettokens-resetbutton": "Réinitialiser les jetons sélectionnés", - "bold_sample": "Texte gras", - "bold_tip": "Texte gras", - "italic_sample": "Texte italique", - "italic_tip": "Texte italique", - "link_sample": "Titre du lien", - "link_tip": "Lien interne", - "extlink_sample": "http://www.example.com/ titre du lien", - "extlink_tip": "Lien externe (n'oubliez pas le préfixe http://)", - "headline_sample": "Texte du titre", - "headline_tip": "Sous-titre niveau 2", - "nowiki_sample": "Entrez le texte non formaté ici", - "nowiki_tip": "Ignorer la syntaxe wiki", - "image_sample": "Exemple.jpg", - "image_tip": "Fichier inséré", - "media_sample": "Exemple.ogg", - "media_tip": "Lien vers un fichier média", - "sig_tip": "Votre signature avec la date", - "hr_tip": "Ligne horizontale (ne pas en abuser)", "summary": "Résumé :", "subject": "Sujet :", "minoredit": "Modification mineure", @@ -838,23 +821,23 @@ "userpage-userdoesnotexist": "Le compte utilisateur « <nowiki>$1</nowiki> » n’est pas enregistré. Veuillez vérifier que vous voulez créer cette page.", "userpage-userdoesnotexist-view": "Le compte utilisateur « $1 » n'est pas enregistré.", "blocked-notice-logextract": "Cet utilisateur est actuellement bloqué.\nLa dernière entrée du journal des blocages est affichée ci-dessous pour référence :", - "clearyourcache": "<strong>Note :</strong> après avoir enregistré vos modifications, il se peut que vous deviez forcer le rechargement complet du cache de votre navigateur pour voir les changements.\n* <strong>Firefox / Safari :</strong> maintenez la touche <em>Maj</em> (<em>Shift</em>) en cliquant sur le bouton <em>Actualiser</em> ou pressez <em>Ctrl-F5</em> ou <em>Ctrl-R</em> (<em>⌘-R</em> sur un Mac) \n* <strong>Google Chrome :</strong> appuyez sur <em>Ctrl-Maj-R</em> (<em>⌘-Shift-R</em> sur un Mac) \n* <strong>Internet Explorer :</strong> maintenez la touche <em>Ctrl</em> en cliquant sur le bouton <em>Actualiser</em> ou pressez <em>Ctrl-F5</em> \n* <strong>Opera :</strong> allez dans <em>Menu → Settings</em> (<em>Opera → Préférences</em> sur un Mac) et ensuite à <em>Confidentialité & sécurité → Effacer les données d’exploration → Images et fichiers en cache</em>.", + "clearyourcache": "<strong>Note :</strong> après avoir enregistré vos modifications, il se peut que vous deviez forcer le rechargement complet du cache de votre navigateur pour voir les changements.\n* <strong>Firefox / Safari :</strong> maintenez la touche <em>Maj</em> (<em>Shift</em>) en cliquant sur le bouton <em>Actualiser</em> ou pressez <em>Ctrl-F5</em> ou <em>Ctrl-R</em> (<em>⌘-R</em> sur un Mac).\n* <strong>Google Chrome :</strong> appuyez sur <em>Ctrl-Maj-R</em> (<em>⌘-Shift-R</em> sur un Mac).\n* <strong>Internet Explorer :</strong> maintenez la touche <em>Ctrl</em> en cliquant sur le bouton <em>Actualiser</em> ou pressez <em>Ctrl-F5</em>.\n* <strong>Opera :</strong> allez dans <em>Menu → Settings</em> (<em>Opera → Préférences</em> sur un Mac) et ensuite à <em>Confidentialité et sécurité → Effacer les données d’exploration → Images et fichiers en cache</em>.", "usercssyoucanpreview": "<strong>Astuce :</strong> utilisez le bouton « {{int:showpreview}} » pour tester votre nouvelle feuille CSS avant de l’enregistrer.", "userjsonyoucanpreview": "<strong>Conseil :</strong> utilisez le bouton « {{int:showpreview}} » pour tester votre nouveau JSON avant enregistrement.", "userjsyoucanpreview": "<strong>Astuce :</strong> utilisez le bouton « {{int:showpreview}} » pour tester votre nouvelle feuille JavaScript avant de l’enregistrer.", - "usercsspreview": "<strong>Rappelez-vous que vous ne faites que prévisualiser votre propre feuille CSS. \nElle n’a pas encore été enregistrée !</strong>", + "usercsspreview": "<strong>Rappelez-vous que vous ne faites que prévisualiser votre propre feuille CSS.\nElle n’a pas encore été enregistrée !</strong>", "userjsonpreview": "<strong>Rappelez-vous que vous êtes seulement en train de tester/voir un aperçu de votre configuration utilisateur JSON.\nElle n’a pas encore été enregistrée !</strong>", - "userjspreview": "<strong>Rappelez-vous que vous ne faites que visualiser ou tester votre code JavaScript.\nIl n’a pas encore été enregistré !</strong>", - "sitecsspreview": "<strong>Rappelez-vous que vous ne faites que prévisualiser cette feuille de style. \nElle n’a pas encore été enregistrée !</strong>", + "userjspreview": "<strong>Rappelez-vous que vous ne faites que visualiser ou tester votre code JavaScript.\nIl n’a pas encore été enregistré !</strong>", + "sitecsspreview": "<strong>Rappelez-vous que vous ne faites que prévisualiser cette feuille de style. \nElle n’a pas encore été enregistrée !</strong>", "sitejsonpreview": "<strong>Souvenez-vous que vous ne faites que regarder un aperçu de cette configuration JSON.\nElle n’a pas encore été enregistrée !</strong>", - "sitejspreview": "<strong>Rappelez-vous que vous ne faites que prévisualiser ce code JavaScript. \nIl n’a pas encore été enregistré !</strong>", - "userinvalidconfigtitle": "<strong>Attention :</strong> il n’existe pas d’habillage « $1 ».\nLes pages personnelles avec extensions .css, .json et .js utilisent des titres en minuscules, par exemple {{ns:user}}:Foo/vector.css et non {{ns:user}}:Foo/Vector.css.", + "sitejspreview": "<strong>Rappelez-vous que vous ne faites que prévisualiser ce code JavaScript.\nIl n’a pas encore été enregistré !</strong>", + "userinvalidconfigtitle": "<strong>Attention :</strong> il n’existe pas d’habillage « $1 ».\nLes pages personnelles avec extensions .css, .json et .js utilisent des titres en minuscules, par exemple <tt>{{ns:user}}:Foo/vector.css</tt> et non <tt>{{ns:user}}:Foo/Vector.css</tt>.", "updated": "(Mis à jour)", "note": "<strong>Note :</strong>", "previewnote": "<strong>Rappelez-vous que ce n’est qu’une prévisualisation.</strong>\nVos modifications n’ont pas encore été enregistrées !", "continue-editing": "Aller à la zone de modification", "previewconflict": "Cette prévisualisation montre le texte de la boîte supérieure de modification tel qu’il apparaîtra si vous choisissez de le publier.", - "session_fail_preview": "Désolé, nous ne pouvons enregistrer votre modification à cause d’une perte d’informations concernant votre session.\n\nVous avez peut-être été déconnecté. <strong>Veuillez vérifier que vous êtes toujours connecté et réessayer.</strong>\nSi cela échoue de nouveau, essayez en vous [[Special:UserLogout|déconnectant]], puis en vous reconnectant, et vérifiez que votre navigateur accepte les témoins (''cookies'') de ce site.", + "session_fail_preview": "Désolé, nous ne pouvons enregistrer votre modification à cause d’une perte d’informations concernant votre session.\n\nVous avez peut-être été déconnecté. <strong>Veuillez vérifier que vous êtes toujours connecté et réessayer.</strong>\nSi cela échoue de nouveau, essayez en vous [[Special:UserLogout|déconnectant]] puis en vous reconnectant. Vérifiez également que votre navigateur accepte les témoins (''cookies'') de ce site.", "session_fail_preview_html": "Désolé, nous ne pouvons enregistrer votre modification à cause d’une perte d’informations concernant votre session.\n\n<em>Parce que {{SITENAME}} a activé le HTML brut, la prévisualisation est masquée afin de prévenir les attaques par JavaScript.</em>\n\n<strong>Si la tentative de modification est légitime, veuillez réessayer.</strong>\nSi cela échoue de nouveau, [[Special:UserLogout|déconnectez-vous]], puis reconnectez-vous, et vérifiez que votre navigateur accepte les témoins (''cookies'') de ce site.", "token_suffix_mismatch": "<strong>Votre modification n’a pas été acceptée car votre navigateur a mal codé les caractères de ponctuation dans l’identifiant de modification.</strong>\nCe rejet est nécessaire pour empêcher la corruption du texte de la page.\nCe problème se produit parfois lorsque vous utilisez un serveur mandataire anonyme problématique basé sur le web.", "edit_form_incomplete": "<strong>Certaines parties du formulaire de modification n’ont pas atteint le serveur, vérifiez que vos modifications sont intactes et essayez à nouveau.</strong>", @@ -863,21 +846,21 @@ "editingsection": "Modification de $1 (section)", "editingcomment": "Modification de $1 (nouvelle section)", "editconflict": "Conflit de modification : $1", - "explainconflict": "Cette page a été changée après que vous avez commencé à la modifier.\nLa zone de modification supérieure contient le texte tel qu’il est actuellement enregistré dans la base de données.\nVos modifications apparaissent dans la zone de modification inférieure.\nVous allez devoir fusionner vos modifications dans le texte existant.\n<strong>Seul</strong> le texte de la zone supérieure sera sauvegardé si vous cliquez sur « $1 ».", + "explainconflict": "Cette page a été changée après que vous avez commencé à la modifier.\nLa zone de modification supérieure contient le texte tel qu’il est actuellement enregistré dans la base de données.\nVos modifications apparaissent dans la zone de modification inférieure.\nVous allez devoir fusionner vos modifications dans le texte existant.\n<strong>Seul</strong> le texte de la zone supérieure sera sauvegardé si vous cliquez sur « $1 ».", "yourtext": "Votre texte", "storedversion": "La version enregistrée", "editingold": "<strong>Attention : vous êtes en train de modifier une ancienne version de cette page.</strong>\nSi vous la publiez, toutes les modifications effectuées depuis cette version seront perdues.", - "unicode-support-fail": "Votre navigateur semble ne pas rendre en charge l'Unicode. Ceci est nécessaire pour modifier les pages, aussi vos modifications n'ont pas été sauvegardées.", + "unicode-support-fail": "Votre navigateur semble ne pas rendre en charge l’Unicode. Ceci est nécessaire pour modifier les pages, aussi vos modifications n'ont pas été sauvegardées.", "yourdiff": "Différences", - "copyrightwarning": "Toutes les contributions à {{SITENAME}} sont considérées comme publiées sous les termes de la $2 (voir $1 pour plus de détails). \nSi vous ne désirez pas que vos écrits soient modifiés et distribués à volonté, merci de ne pas les soumettre ici.<br /> \nVous nous promettez aussi que vous avez écrit ceci vous-même, ou que vous l’avez copié d’une source provenant du domaine public ou d’une ressource libre similaire. \n<strong>N’UTILISEZ PAS DE TRAVAUX SOUS DROIT D’AUTEUR SANS AUTORISATION EXPRESSE !</strong>", - "copyrightwarning2": "Notez bien que toutes les contributions à {{SITENAME}} peuvent être modifiées, transformées ou supprimées par d’autres utilisateurs. \nSi vous ne désirez pas que vos écrits soient modifiés contre votre gré, merci de ne pas les soumettre ici.<br /> \nVous nous promettez aussi que vous avez écrit ceci vous-même, ou que vous l’avez copié d’une source provenant du domaine public, ou d’une ressource libre. (voir $1 pour plus de détails).\n<strong>N’UTILISEZ PAS DE TRAVAUX SOUS DROIT D’AUTEUR SANS AUTORISATION EXPRESSE !</strong>", + "copyrightwarning": "Toutes les contributions à {{SITENAME}} sont considérées comme publiées sous les termes de la $2 (voir $1 pour plus de détails). \nSi vous ne désirez pas que vos écrits soient modifiés et distribués à volonté, merci de ne pas les soumettre ici.<br /> \nVous nous promettez aussi que vous avez écrit ceci vous-même, ou que vous l’avez copié d’une source provenant du domaine public ou d’une ressource libre similaire.\n<strong>N’UTILISEZ PAS DE TRAVAUX SOUS DROIT D’AUTEUR SANS AUTORISATION EXPRESSE !</strong>", + "copyrightwarning2": "Notez bien que toutes les contributions à {{SITENAME}} peuvent être modifiées, transformées ou supprimées par d’autres utilisateurs.\nSi vous ne désirez pas que vos écrits soient modifiés contre votre gré, merci de ne pas les soumettre ici.<br />\nVous nous promettez aussi que vous avez écrit ceci vous-même ou que vous l’avez copié d’une source provenant du domaine public ou d’une ressource libre (voir $1 pour plus de détails).\n<strong>N’UTILISEZ PAS DE TRAVAUX SOUS DROIT D’AUTEUR SANS AUTORISATION EXPRESSE !</strong>", "editpage-cannot-use-custom-model": "Le modèle de contenu de cette page ne peut pas être modifié.", "longpageerror": "<strong>Erreur : Le texte que vous avez soumis fait {{PLURAL:$1|un Kio|$1 Kio}}, ce qui dépasse la limite fixée à {{PLURAL:$2|un Kio|$2 Kio}}.</strong>\nIl ne peut pas être sauvegardé.", - "readonlywarning": "<strong>AVERTISSEMENT : la base de données a été verrouillée pour des opérations de maintenance. Vous ne pouvez donc pas publier vos modifications pour l’instant.</strong>\nVous pouvez copier et coller votre texte dans un fichier texte et l’enregistrer pour plus tard.\n\nL’administrateur système ayant verrouillé la base de données a donné l’explication suivante : $1", - "protectedpagewarning": "<strong>AVERTISSEMENT : cette page est protégée afin que seuls les utilisateurs ayant le statut d'administrateur puissent la modifier.</strong>\nLa dernière entrée du journal est affichée ci-dessous pour référence :", - "semiprotectedpagewarning": "<strong>Note :</strong>Cette page a été protégée pour que seuls les contributeurs confirmés automatiquement puissent la modifier. \nLa dernière entrée du journal est affichée ci-dessous pour référence :", - "cascadeprotectedwarning": "<strong>ATTENTION :</strong> Cette page a été protégée de manière à ce que seuls les utilisateurs avec [[Special:ListGroupRights|des droits spécifiques]] puissent la modifier car elle est incluse dans {{PLURAL:$1|la page suivante, protégée en cascade|les pages suivantes, protégées en cascade}} :", - "titleprotectedwarning": "<strong>ATTENTION : Cette page a été protégée de telle manière que des [[Special:ListGroupRights|droits spécifiques]] sont requis pour pouvoir la créer.</strong> \nLa dernière entrée du journal est affichée ci-dessous pour référence :", + "readonlywarning": "<strong>AVERTISSEMENT : la base de données a été verrouillée pour des opérations de maintenance. Vous ne pouvez donc pas publier vos modifications pour l’instant.</strong>\nVous pouvez copier et coller votre texte dans un fichier texte et l’enregistrer pour plus tard.\n\nL’administrateur système ayant verrouillé la base de données a donné l’explication suivante : $1", + "protectedpagewarning": "<strong>AVERTISSEMENT : cette page est protégée afin que seuls les utilisateurs ayant le statut d’administrateur puissent la modifier.</strong>\nLa dernière entrée du journal est affichée ci-dessous pour référence :", + "semiprotectedpagewarning": "<strong>Note :</strong>Cette page a été protégée pour que seuls les contributeurs confirmés automatiquement puissent la modifier.\nLa dernière entrée du journal est affichée ci-dessous pour référence :", + "cascadeprotectedwarning": "<strong>ATTENTION :</strong> cette page a été protégée de manière à ce que seuls les utilisateurs avec [[Special:ListGroupRights|des droits spécifiques]] puissent la modifier car elle est incluse dans {{PLURAL:$1|la page suivante, protégée en cascade|les pages suivantes, protégées en cascade}} :", + "titleprotectedwarning": "<strong>ATTENTION : cette page a été protégée de telle manière que des [[Special:ListGroupRights|droits spécifiques]] sont requis pour pouvoir la créer.</strong>\nLa dernière entrée du journal est affichée ci-dessous pour référence :", "templatesused": "{{PLURAL:$1|Modèle utilisé|Modèles utilisés}} par cette page :", "templatesusedpreview": "{{PLURAL:$1|Modèle utilisé|Modèles utilisés}} dans cette prévisualisation :", "templatesusedsection": "{{PLURAL:$1|Modèle utilisé|Modèles utilisés}} dans cette section :", @@ -887,16 +870,16 @@ "edittools": "<!-- Tout texte entré ici sera affiché sous les boîtes de modification ou les formulaires de téléversement de fichier. -->", "edittools-upload": "—", "nocreatetext": "{{SITENAME}} a restreint la possibilité de créer de nouvelles pages.\nVous pouvez revenir en arrière et modifier une page existante, ou bien [[Special:UserLogin|vous connecter ou créer un compte]].", - "nocreate-loggedin": "Vous n'avez pas la permission de créer de nouvelles pages.", + "nocreate-loggedin": "Vous n’avez pas la permission de créer de nouvelles pages.", "sectioneditnotsupported-title": "Modification de section non prise en charge", "sectioneditnotsupported-text": "La modification d’une section n’est pas prise en charge pour cette page.", "modeleditnotsupported-title": "Modification non prise en charge", "modeleditnotsupported-text": "La modification n’est pas prise en charge pour le modèle de contenu $1.", "permissionserrors": "Erreur de permissions", - "permissionserrorstext": "Vous n'avez pas la permission d'effectuer l'opération demandée pour {{PLURAL:$1|la raison suivante|les raisons suivantes}} :", - "permissionserrorstext-withaction": "Vous ne pouvez pas $2, pour {{PLURAL:$1|la raison suivante|les raisons suivantes}} :", + "permissionserrorstext": "Vous n’avez pas la permission d'effectuer l'opération demandée pour {{PLURAL:$1|la raison suivante|les raisons suivantes}} :", + "permissionserrorstext-withaction": "Vous ne pouvez pas $2, pour {{PLURAL:$1|la raison suivante|les raisons suivantes}} :", "contentmodelediterror": "Vous ne pouvez pas modifier cette révision car son modèle de contenu est <code>$1</code>, ce qui diffère du modèle de contenu actuel de la page <code>$2</code>.", - "recreate-moveddeleted-warn": "<strong>Attention : vous êtes en train de recréer une page qui a été précédemment supprimée.</strong>\n\nAssurez-vous qu'il est pertinent de poursuivre les modifications sur cette page.\nLes journaux des suppressions et déplacements pour cette page sont fournis ici pour information :", + "recreate-moveddeleted-warn": "<strong>Attention : vous êtes en train de recréer une page qui a été précédemment supprimée.</strong>\n\nAssurez-vous qu’il est pertinent de poursuivre les modifications sur cette page.\nLes journaux des suppressions et déplacements pour cette page sont fournis ici pour information :", "moveddeleted-notice": "Cette page a été supprimée.\nLes journaux des suppressions, protections et déplacements pour la page sont fournis ci-dessous pour référence.", "moveddeleted-notice-recent": "Désolé, cette page a été récemment supprimée (dans les dernières 24 heures).\nLes journaux des suppressions, protections et déplacements pour la page sont fournis ci-dessous pour référence.", "log-fulllog": "Voir le journal complet", @@ -904,9 +887,9 @@ "edit-gone-missing": "N’a pas pu mettre à jour la page.\nIl semble qu’elle ait été supprimée.", "edit-conflict": "Conflit de modification.", "edit-no-change": "Votre modification a été ignorée car aucun changement n’a été apporté au texte.", - "edit-slots-cannot-add": "{{PLURAL:$1|L’emplacement suivant n’est pas supporté|Les emplacements suivants ne sont pas supportés}} ici : $2.", - "edit-slots-cannot-remove": "{{PLURAL:$1|L’emplacement suivant est obligatoire et ne peut pas être supprimé|Les emplacements suivants sont obligatoires et ne peuvent pas être supprimés}} : $2.", - "edit-slots-missing": "{{PLURAL:$1|L’emplacement suivant est absent|Les emplacements suivants sont absents}} : $2.", + "edit-slots-cannot-add": "{{PLURAL:$1|L’emplacement suivant n’est pas supporté|Les emplacements suivants ne sont pas supportés}} ici : $2.", + "edit-slots-cannot-remove": "{{PLURAL:$1|L’emplacement suivant est obligatoire et ne peut pas être supprimé|Les emplacements suivants sont obligatoires et ne peuvent pas être supprimés}} : $2.", + "edit-slots-missing": "{{PLURAL:$1|L’emplacement suivant est absent|Les emplacements suivants sont absents}} : $2.", "postedit-confirmation-created": "La page a été créée.", "postedit-confirmation-restored": "La page a été restaurée.", "postedit-confirmation-saved": "Votre modification a été enregistrée.", @@ -918,9 +901,9 @@ "content-not-allowed-here": "Le contenu « $1 » n’est pas autorisé sur la page [[:$2]] dans l’emplacement « $3 »", "editwarning-warning": "Quitter cette page vous fera perdre toutes les modifications que vous avez faites.\nSi vous êtes connecté{{GENDER:||e}}, vous pouvez désactiver cet avertissement dans la section « {{int:prefs-editing}} » de vos préférences.", "editpage-invalidcontentmodel-title": "Modèle de contenu non pris en charge", - "editpage-invalidcontentmodel-text": "Le modèle de contenu \"$1\" n'est pas pris en charge.", + "editpage-invalidcontentmodel-text": "Le modèle de contenu « $1 » n’est pas pris en charge.", "editpage-notsupportedcontentformat-title": "Format de contenu non pris en charge", - "editpage-notsupportedcontentformat-text": "Le format de contenu $1 n'est pas pris en charge par le modèle de contenu $2 .", + "editpage-notsupportedcontentformat-text": "Le format de contenu $1 n’est pas pris en charge par le modèle de contenu $2 .", "slot-name-main": "Principal", "content-model-wikitext": "wikitexte", "content-model-text": "texte brut", @@ -933,20 +916,20 @@ "unsupported-content-diff": "Les diffs ne sont pas supportés pour le modèle de contenu $1.", "unsupported-content-diff2": "Les diffs entre les modèles de contenu $1 et $2 ne sont pas supportés sur ce wiki.", "deprecated-self-close-category": "Pages utilisant des balises HTML auto-fermantes non valides", - "deprecated-self-close-category-desc": "La page contient des balises HTML auto-fermantes non valides, comme <code><b/></code> ou <code><span/></code>. Le comportement de celles-ci changera prochainement pour être en accord avec la spécification HTML5, donc leur utilisation dans le wikitexte est désuète.", - "duplicate-args-warning": "<strong>Avertissement :</strong> [[:$1]] appelle [[:$2]] avec plus d'une valeur pour le paramètre « $3 ». Seule la dernière valeur fournie sera utilisée.", + "deprecated-self-close-category-desc": "La page contient des balises HTML auto-fermantes non valides, comme <code><b/></code> ou <code><span/></code>. Le comportement de celles-ci changera prochainement pour être en accord avec la spécification HTML5, donc leur utilisation dans le wikitexte est désormais désuète.", + "duplicate-args-warning": "<strong>Avertissement :</strong> [[:$1]] appelle [[:$2]] avec plus d'une valeur pour le paramètre « $3 ». Seule la dernière valeur fournie sera utilisée.", "duplicate-args-category": "Pages utilisant des arguments dupliqués dans les appels de modèle", "duplicate-args-category-desc": "La page contient des appels de modèle qui utilisent des arguments dupliqués, comme <code><nowiki>{{foo|bar=1|bar=2}}</nowiki></code> ou <code><nowiki>{{foo|bar|1=baz}}</nowiki></code>.", "expensive-parserfunction-warning": "<strong>Attention :</strong> cette page contient de trop nombreux appels à des fonctions coûteuses de l’analyseur syntaxique.\n\nIl devrait y avoir moins de $2 appel{{PLURAL:$2||s}}, alors qu’il y en a maintenant $1.", - "expensive-parserfunction-category": "Pages avec trop d'appels dispendieux aux fonctions de l'analyseur syntaxique", + "expensive-parserfunction-category": "Pages avec trop d’appels dispendieux aux fonctions de l’analyseur syntaxique", "post-expand-template-inclusion-warning": "<strong>Attention :</strong> cette page contient trop d’inclusions de modèles. Certaines inclusions ne seront pas effectuées.", "post-expand-template-inclusion-category": "Pages contenant trop d'inclusions de modèles", - "post-expand-template-argument-warning": "<strong>Attention :</strong> cette page contient au moins un paramètre de modèle dont la taille après expansion est trop importante. \nCes arguments n’ont donc pas été inclus.", + "post-expand-template-argument-warning": "<strong>Attention :</strong> cette page contient au moins un paramètre de modèle dont la taille après expansion est trop importante.\nCes arguments n’ont donc pas été inclus.", "post-expand-template-argument-category": "Pages contenant des paramètres de modèle non évalués", "parser-template-loop-warning": "Modèle en boucle détecté : [[$1]]", "template-loop-category": "Pages avec des boucles de modèle", - "template-loop-category-desc": "La page contient une boucle dans le modèle, c.à.d. un modèle qui s’appelle lui-même récursivement.", - "template-loop-warning": "<strong>Avertissement :</strong> Cette page appelle [[:$1]] ce qui provoque une boucle de modèles (un appel récursif infini).", + "template-loop-category-desc": "La page contient une boucle de modèle, c.à.d. un modèle qui s’appelle lui-même récursivement.", + "template-loop-warning": "<strong>Avertissement :</strong> cette page appelle [[:$1]] ce qui provoque une boucle de modèles (un appel récursif potentiellement infini).", "parser-template-recursion-depth-warning": "Limite de profondeur des appels récursifs de modèles dépassée ($1)", "language-converter-depth-warning": "Limite de profondeur du convertisseur de langue dépassée ($1)", "node-count-exceeded-category": "Pages dépassant le nombre de nœuds maximal", @@ -955,22 +938,22 @@ "expansion-depth-exceeded-category": "Pages dépassant la profondeur d'expansion maximale", "expansion-depth-exceeded-category-desc": "La page dépasse la profondeur d’expansion maximale.", "expansion-depth-exceeded-warning": "Page dépassant la profondeur d’expansion maximale", - "parser-unstrip-loop-warning": "Boucle non dépilable détectée", - "unstrip-depth-warning": "Limite de récursion non dépilable dépassée ($1)", + "parser-unstrip-loop-warning": "Boucle de développement (<code>unstrip</code>) détectée", + "unstrip-depth-warning": "Limite de récursion de développement (<code>unstrip</code>) dépassée ($1)", "unstrip-depth-category": "Pages où la limite de profondeur de développement est dépassée", - "unstrip-size-warning": "Limite de taille de développement dépassée ($1)", + "unstrip-size-warning": "Limite de taille de développement (<code>unstrip</code>) dépassée ($1)", "unstrip-size-category": "Pages où la limite de taille de développement est dépassée", "converter-manual-rule-error": "Erreur détectée dans la règle manuelle de conversion de langue", - "undo-success": "Cette modification va être annulée.\nVeuillez vérifier les différences ci-dessous, puis publier l’annulation si c’est bien ce que vous voulez faire.", + "undo-success": "La précédente modification va être annulée.\nVeuillez vérifier les différences ci-dessous, puis publier l’annulation ci-dessous si c’est bien ce que vous voulez faire.", "undo-failure": "Cette modification ne peut pas être défaite : cela entrerait en conflit avec les modifications intermédiaires.", - "undo-main-slot-only": "La modification n'a pas pu être annulée car elle implique un contenu en dehors de la tranche principale.", + "undo-main-slot-only": "La modification n’a pas pu être annulée car elle implique un contenu en dehors de la tranche principale.", "undo-norev": "La modification n’a pas pu être défaite parce qu’elle est inexistante ou qu’elle a été supprimée.", "undo-nochange": "Il semblerait que la modification ait déjà été annulée.", "undo-summary": "Annulation des modifications $1 de [[Special:Contributions/$2|$2]] ([[User talk:$2|discussion]])", "undo-summary-anon": "Annuler la modification $1 de [[Special:Contributions/$2|$2]]", "undo-summary-username-hidden": "Annuler la révision $1 par un utilisateur masqué", - "cantcreateaccount-text": "La création de compte depuis cette adresse IP (<strong>$1</strong>) a été bloquée par [[User:$3|$3]]. \n\nLa raison donnée par $3 était : <em>$2</em>", - "cantcreateaccount-range-text": "La création de compte depuis les adresses IP de la plage <strong>$1</strong>, où se trouve votre adresse IP (<strong>$4</strong>), a été bloquée par [[User:$3|$3]].\n\nLe motif fourni par $3 est <em>$2</em>", + "cantcreateaccount-text": "La création de compte depuis cette adresse IP (<strong>$1</strong>) a été bloquée par [[User:$3|$3]]. \n\nLa raison donnée par $3 était : <em>$2</em>", + "cantcreateaccount-range-text": "La création de compte depuis les adresses IP de la plage <strong>$1</strong>, où se trouve votre adresse IP (<strong>$4</strong>), a été bloquée par [[User:$3|$3]].\n\nLe motif fourni par $3 est : <em>$2</em>", "viewpagelogs": "Voir les opérations sur cette page", "nohistory": "Il n’existe pas d’historique des modifications pour cette page.", "currentrev": "Version actuelle", @@ -985,17 +968,17 @@ "last": "diff", "page_first": "première", "page_last": "dernière", - "histlegend": "Sélection du diff : cochez les boutons radio des versions à comparer et appuyez sur entrée ou sur le bouton en bas.<br />\nLégende : <strong>({{int:cur}})</strong> = différence avec la dernière version, <strong>({{int:last}})</strong> = différence avec la version précédente, <strong>{{int:minoreditletter}}</strong> = modification mineure.", - "history-fieldset-title": "Filtrer les versions", + "histlegend": "Sélection du diff : cochez les boutons radio des versions à comparer et appuyez sur entrée ou sur le bouton en bas.<br />\nLégende : <strong>({{int:cur}})</strong> = différence avec la dernière version, <strong>({{int:last}})</strong> = différence avec la version précédente, <strong>{{int:minoreditletter}}</strong> = modification mineure.", + "history-fieldset-title": "Filtrer les révisions", "history-show-deleted": "Révision supprimée uniquement", "histfirst": "les plus anciennes", "histlast": "les plus récentes", "historysize": "($1 octet{{PLURAL:$1||s}})", "historyempty": "vide", "history-feed-title": "Historique des versions", - "history-feed-description": "Historique des versions pour cette page sur le wiki", + "history-feed-description": "Historique des révisions pour cette page sur le wiki", "history-feed-item-nocomment": "$1 le $2", - "history-feed-empty": "La page demandée n'existe pas.\nElle a peut-être été effacée ou renommée.\nEssayez de [[Special:Search|rechercher sur le wiki]] pour trouver de nouvelles pages en rapport avec le sujet.", + "history-feed-empty": "La page demandée n’existe pas.\nElle a peut-être été effacée ou renommée.\nEssayez de [[Special:Search|rechercher sur le wiki]] pour trouver de nouvelles pages en rapport avec le sujet.", "history-edit-tags": "Modifier les balises des versions sélectionnées", "rev-deleted-comment": "(résumé de modification retiré)", "rev-deleted-user": "(nom d'utilisateur retiré)", @@ -1017,35 +1000,35 @@ "rev-showdeleted": "afficher", "revisiondelete": "Supprimer ou restaurer des événements", "revdelete-nooldid-title": "Version cible non valide", - "revdelete-nooldid-text": "Vous n’avez pas précisé de révision(s) cible(s) pour cette fonction, ou bien la révision spécifiée n’existe pas, ou bien vous tentez de masquer la révision actuelle.", + "revdelete-nooldid-text": "Vous n’avez pas précisé de révision(s) cible(s) pour cette fonction, ou la révision spécifiée n’existe pas, ou bien vous tentez de masquer la révision actuelle.", "revdelete-no-file": "Le fichier spécifié n'existe pas.", - "revdelete-show-file-confirm": "Êtes-vous sûr{{GENDER:||e}} de vouloir voir la révision supprimée du fichier « <nowiki>$1</nowiki> » datant du $2 à $3 ?", + "revdelete-show-file-confirm": "Êtes-vous sûr{{GENDER:||e}} de vouloir voir la révision supprimée du fichier « <nowiki>$1</nowiki> » datant du $2 à $3 ?", "revdelete-show-file-submit": "Oui", - "revdelete-selected-text": "{{PLURAL:$1|Révision sélectionnée|Révisions sélectionnées}} de [[:$2]] :", - "revdelete-selected-file": "{{PLURAL:$1|Version de fichier sélectionnée|Versions de fichier sélectionnées}} de [[:$2]] :", - "logdelete-selected": "{{PLURAL:$1|Événement d'historique sélectionné|Événements d'historique sélectionnés}} :", + "revdelete-selected-text": "{{PLURAL:$1|Révision sélectionnée|Révisions sélectionnées}} de [[:$2]] :", + "revdelete-selected-file": "{{PLURAL:$1|Version de fichier sélectionnée|Versions de fichier sélectionnées}} de [[:$2]] :", + "logdelete-selected": "{{PLURAL:$1|Événement d’historique sélectionné|Événements d’historique sélectionnés}} :", "revdelete-text-text": "Les révisions supprimées continueront à apparaître dans l’historique de la page, mais une partie de leur contenu sera inaccessible au public.", "revdelete-text-file": "Les versions de fichier supprimées continueront à apparaître dans l’historique des fichiers, mais une partie de leur contenu sera indisponible au public.", - "logdelete-text": "Les évènements supprimés du journal continueront à apparaître dans les journaux, mais une partie de leur contenu sera indisponible au public.", - "revdelete-text-others": "Les autres administrateurs seront toujours en mesure d'accéder au contenu caché et le restaurer, à moins que des restrictions supplémentaires soient fixées.", - "revdelete-confirm": "Confirmez que vous voulez effectuer cette action, que vous en comprenez les conséquences, et que vous le faites en accord avec [[{{MediaWiki:Policy-url}}|les règles]].", - "revdelete-suppress-text": "La suppression ne doit être utilisée <strong>que</strong> dans les cas suivants :\n* informations potentiellement diffamatoires\n* informations personnelles inappropriées\n*: <em>adresse, numéro de téléphone, numéro de sécurité sociale, …</em>", + "logdelete-text": "Les événements supprimés du journal continueront à apparaître dans les journaux, mais une partie de leur contenu sera indisponible au public.", + "revdelete-text-others": "Les autres administrateurs seront toujours en mesure d’accéder au contenu caché et le restaurer, à moins que des restrictions supplémentaires soient fixées.", + "revdelete-confirm": "Confirmez que vous voulez effectuer cette action, que vous en comprenez les conséquences et que vous le faites en accord avec [[{{MediaWiki:Policy-url}}|les règles]].", + "revdelete-suppress-text": "La suppression ne doit être utilisée <strong>que</strong> dans les cas suivants :\n* informations potentiellement diffamatoires\n* informations personnelles inappropriées\n*: <em>adresse, numéro de téléphone, numéro de sécurité sociale, …</em>", "revdelete-legend": "Mettre en place des restrictions de visibilité", "revdelete-hide-text": "Texte de la révision", "revdelete-hide-image": "Masquer le contenu du fichier", "revdelete-hide-name": "Masquer la cible et les paramètres", "revdelete-hide-comment": "Résumé de modification", - "revdelete-hide-user": "Nom d’utilisateur/Adresse IP de l’éditeur", - "revdelete-hide-restricted": "Supprimer ces données aux administrateurs ainsi qu'aux autres", + "revdelete-hide-user": "Nom d’utilisateur / adresse IP de l’auteur", + "revdelete-hide-restricted": "Supprimer ces données aux administrateurs ainsi qu’aux autres", "revdelete-radio-same": "(ne pas changer)", "revdelete-radio-set": "Masqué", "revdelete-radio-unset": "Visible", "revdelete-suppress": "Masquer également les données pour les administrateurs", "revdelete-unsuppress": "Enlever les restrictions sur les versions restaurées", - "revdelete-log": "Motif :", + "revdelete-log": "Motif :", "revdelete-submit": "Appliquer {{PLURAL:$1|à la révision sélectionnée|aux révisions sélectionnées}}", "revdelete-success": "Visibilité des versions mise à jour.", - "revdelete-failure": "'''La visibilité de la version n'a pas pu être mise à jour :'''\n$1", + "revdelete-failure": "'''La visibilité de la version n'a pas pu être mise à jour :'''\n$1", "logdelete-success": "Visibilité du journal modifiée.", "logdelete-failure": "'''La visibilité du journal n'a pas pu être définie :'''\n$1", "revdel-restore": "modifier la visibilité", @@ -1268,6 +1251,7 @@ "prefs-help-email": "L'adresse de courriel est facultative, mais elle est nécessaire pour réinitialiser votre mot de passe, en cas d'oubli.", "prefs-help-email-others": "Vous pouvez aussi choisir de laisser les autres vous contacter par courriel via un lien sur votre page de discussion ou page utilisateur. \nVotre adresse courriel n'est pas révélée quand les autres utilisateurs vous contactent.", "prefs-help-email-required": "Une adresse de courriel est requise.", + "prefs-help-requireemail": "Si coché, enverra seulement les courriels de réinitialisation des mots de passe si la personne qui réinitialise a fourni à la fois un nom d’utilisateur et un courriel pour ce compte.", "prefs-info": "Informations de base", "prefs-i18n": "Internationalisation", "prefs-signature": "Signature", @@ -1991,6 +1975,7 @@ "listfiles-userdoesnotexist": "Le compte utilisateur « $1 » n’est pas enregistré.", "imgfile": "fichier", "listfiles": "Liste de fichiers", + "listfiles_subpage": "Téléchargés par $1", "listfiles_thumb": "Miniature", "listfiles_date": "Date", "listfiles_name": "Nom", @@ -2733,6 +2718,7 @@ "ipblocklist-legend": "Chercher un utilisateur bloqué", "blocklist-userblocks": "Masquer les blocages de comptes", "blocklist-tempblocks": "Masquer les blocages temporaires", + "blocklist-indefblocks": "Masquer les blocs non définis", "blocklist-addressblocks": "Masquer les blocages d’adresses IP uniques", "blocklist-type": "Type :", "blocklist-type-opt-all": "Tous", @@ -3001,10 +2987,10 @@ "tooltip-pt-watchlist": "Une liste des pages dont vous suivez les modifications", "tooltip-pt-mycontris": "La liste de {{GENDER:|vos}} contributions", "tooltip-pt-anoncontribs": "Une liste des modifications effectuées depuis cette adresse IP", - "tooltip-pt-login": "Nous vous encourageons à vous connecter ; ce n’est cependant pas obligatoire", + "tooltip-pt-login": "Nous vous encourageons à vous connecter ; ce n’est cependant pas obligatoire.", "tooltip-pt-login-private": "Vous devez vous connecter pour utiliser ce wiki", "tooltip-pt-logout": "Se déconnecter", - "tooltip-pt-createaccount": "Nous vous encourageons à créer un compte utilisateur et vous connecter; ce n’est cependant pas obligatoire", + "tooltip-pt-createaccount": "Nous vous encourageons à créer un compte utilisateur et vous connecter ; ce n’est cependant pas obligatoire.", "tooltip-ca-talk": "Discussion au sujet de cette page de contenu", "tooltip-ca-edit": "Modifier le wikicode", "tooltip-ca-addsection": "Commencer une nouvelle section", @@ -3137,7 +3123,7 @@ "pageinfo-hidden-categories": "{{PLURAL:$1|Catégorie cachée|Catégories cachées}} ($1)", "pageinfo-templates": "{{PLURAL:$1|Modèle inclu|Modèles inclus}} ($1)", "pageinfo-transclusions": "{{PLURAL:$1|Page dans laquelle|Pages dans lesquelles}} cette page est incluse ($1)", - "pageinfo-toolboxlink": "Information sur la page", + "pageinfo-toolboxlink": "Informations sur la page", "pageinfo-redirectsto": "Rediriger vers", "pageinfo-redirectsto-info": "info", "pageinfo-contentpage": "Comptée comme page de contenu", @@ -4124,5 +4110,8 @@ "mycustomjsredirectprotected": "Vous n’avez pas le droit de modifier cette page JavaScript parce qu’elle est une redirection et qu’elle ne pointe pas dans votre espace utilisateur.", "easydeflate-invaliddeflate": "Le contenu fourni n'est pas correctement développé", "unprotected-js": "Pour des raisons de sécurité, JavaScript ne peut pas être chargé depuis des pages non protégées. Veuillez ne créer du javascript que dans l’espace de noms MediaWiki: ou comme sous-page utilisateur", - "userlogout-continue": "Voulez-vous vous déconnecter ?" + "userlogout-continue": "Voulez-vous vous déconnecter ?", + "rest-prefix-mismatch": "Le chemin requis ($1) n’était pas dans le chemin racine de l’API REST ($2)", + "rest-wrong-method": "La méthode requise ($1) n’était pas {{PLURAL:$3|la méthode autorisée pour ce chemin|une des méthodes autorisées pour ce chemin}} ($2)", + "rest-no-match": "Le chemin relatif requis ($1) ne correspondait à aucun gestionnaire connu" } diff --git a/languages/i18n/frc.json b/languages/i18n/frc.json index 0448259d86..2226a734c5 100644 --- a/languages/i18n/frc.json +++ b/languages/i18n/frc.json @@ -376,24 +376,6 @@ "changeemail-none": "(aucun)", "changeemail-password": "Ton mot de passe sur {{SITENAME}}:", "changeemail-submit": "Changer l’adresse d'email", - "bold_sample": "Gras", - "bold_tip": "Gras", - "italic_sample": "Italique", - "italic_tip": "Italique", - "link_sample": "Nom du lien", - "link_tip": "Lien intérieur", - "extlink_sample": "http://www.example.com nom du lien", - "extlink_tip": "Lien extérieur (Oubliez pas de mettre http:// avant.)", - "headline_sample": "Sujet", - "headline_tip": "Sujet niveau 2", - "nowiki_sample": "Mettez du texte non-préparé ici", - "nowiki_tip": "Ignorez le code wiki", - "image_sample": "Exemple.jpg", - "image_tip": "Mettez un portrait", - "media_sample": "Exemple.ogg", - "media_tip": "Lien dossier", - "sig_tip": "Votre signature avec la date", - "hr_tip": "Ligne horizontale (Abusez-lé pas.)", "summary": "Description:", "subject": "Sujet:", "minoredit": "Ça ici, c'est un petit changement.", diff --git a/languages/i18n/frp.json b/languages/i18n/frp.json index d2afe373ea..d781bbc993 100644 --- a/languages/i18n/frp.json +++ b/languages/i18n/frp.json @@ -557,24 +557,6 @@ "resettokens-watchlist-token": "Jeton por lo flux (Atom/RSS) Vouèbe de [[Special:Watchlist|changements de pâges de voutra lista de gouârda]]", "resettokens-done": "Jetons rebetâs a zérô.", "resettokens-resetbutton": "Rebetar los jetons chouèsis", - "bold_sample": "Grôs tèxto", - "bold_tip": "Grôs tèxto", - "italic_sample": "Tèxto étalico", - "italic_tip": "Tèxto étalico", - "link_sample": "Titro du lim", - "link_tip": "Lim de dedens", - "extlink_sample": "http://www.example.com titro du lim", - "extlink_tip": "Lim de defôr (oubliâd pas lo prèfixo http://)", - "headline_sample": "Tèxto du titro", - "headline_tip": "Sot-titro nivél 2", - "nowiki_sample": "Buchiéd lo tèxto pas formatâ ique", - "nowiki_tip": "Ignorar lo formatâjo vouiqui", - "image_sample": "Ègzemplo.jpg", - "image_tip": "Fichiér apondu", - "media_sample": "Ègzemplo.ogg", - "media_tip": "Lim de vers un fichiér", - "sig_tip": "Voutra signatura avouéc la dâta et l’hora", - "hr_tip": "Legne plana (pas nen abusar)", "summary": "Rèsumâ :", "subject": "Chousa :", "minoredit": "O est un petiôt changement", diff --git a/languages/i18n/frr.json b/languages/i18n/frr.json index f867a5aeaa..9174a9e284 100644 --- a/languages/i18n/frr.json +++ b/languages/i18n/frr.json @@ -587,22 +587,6 @@ "resettokens-watchlist-token": "Token för webfeed (Atom/RSS) mä [[Special:Watchlist|feranrangen faan sidjen, diar dü uun't uug behual wel]]", "resettokens-done": "Tokems san turagsaat wurden.", "resettokens-resetbutton": "Enkelt tokens turagsaat", - "bold_sample": "Fäät buksteewen", - "bold_tip": "Fäät buksteewen", - "italic_sample": "Kursiif buksteewen", - "italic_tip": "Kursiif buksteewen", - "link_sample": "Link-tekst", - "link_tip": "Intern ferwisang", - "extlink_sample": "http://www.example.com link-tekst", - "extlink_tip": "Ekstern ferwisang (seenk am http:// prefix)", - "headline_sample": "Auerskraft (grate 2)", - "headline_tip": "Auerskraft (grate 2)", - "nowiki_sample": "Ünformatiaret tekst diar tusaat.", - "nowiki_tip": "Ünformatiaret tekst", - "image_tip": "Iinbünjen datei", - "media_tip": "Meediendatei-link", - "sig_tip": "Din onerskraft mä tidjstempel", - "hr_tip": "Horisontaal streg (ei auerdriiw diarmä)", "summary": "Tuupfaadet:", "subject": "Teemo:", "minoredit": "Det as man en letj feranrang", diff --git a/languages/i18n/fur.json b/languages/i18n/fur.json index ac4eedc4bc..8316338c4d 100644 --- a/languages/i18n/fur.json +++ b/languages/i18n/fur.json @@ -423,24 +423,6 @@ "resetpass-submit-cancel": "Scancele", "passwordreset": "Azere la password", "passwordreset-username": "Non utent:", - "bold_sample": "Test in gruessut", - "bold_tip": "Test in gruessut", - "italic_sample": "Test in corsîf", - "italic_tip": "Test in corsîf", - "link_sample": "Titul dal leam", - "link_tip": "Leams internis", - "extlink_sample": "http://www.example.com titul leam", - "extlink_tip": "Leam esterni (visiti dal prefìs http://)", - "headline_sample": "Test dal titul", - "headline_tip": "Titul di nivel 2", - "nowiki_sample": "Inserìs test no formatât culì", - "nowiki_tip": "Ignore la formatazion wiki", - "image_sample": "Esempli.jpg", - "image_tip": "Figure includude", - "media_sample": "Esempli.ogg", - "media_tip": "Leam a un file multimediâl", - "sig_tip": "La tô firme cun ore e date", - "hr_tip": "Rie orizontâl (no stâ doprâle masse spes)", "summary": "Somari:", "subject": "Argoment (intestazion):", "minoredit": "Chest al è un piçul cambiament", diff --git a/languages/i18n/fy.json b/languages/i18n/fy.json index a0983f15a2..6f1c119680 100644 --- a/languages/i18n/fy.json +++ b/languages/i18n/fy.json @@ -472,23 +472,6 @@ "resettokens-watchlist-token": "Kaai foar de webfied (Atom/RSS) fan [[Special:Watchlist|wizigings oan jo folchlistsiden]]", "resettokens-done": "Kaaien fernijd.", "resettokens-resetbutton": "Selektearre kaaien fernije", - "bold_sample": "Fette tekst", - "bold_tip": "Fette tekst", - "italic_sample": "Skeane tekst", - "italic_tip": "Skeane tekst", - "link_sample": "Link titel", - "link_tip": "Ynterne ferwizing", - "extlink_sample": "http://www.example.com linktekst", - "extlink_tip": "Eksterne link (ferjit http:// net)", - "headline_sample": "Koptekst", - "headline_tip": "Underkopke", - "nowiki_sample": "Foechje hjir platte tekst yn", - "nowiki_tip": "Wiki-opmaak negearje", - "image_sample": "Foarbyld.jpg", - "image_tip": "Mediabestân", - "media_tip": "Link nei bestân", - "sig_tip": "Jo sinjatuer mei dei en oere", - "hr_tip": "Horizontale line (mei ferdrach brûke)", "summary": "Gearfetting:", "subject": "Underwerp:", "minoredit": "Dit is fan lytse betsjutting", diff --git a/languages/i18n/ga.json b/languages/i18n/ga.json index 88103d8ed4..d075bdc071 100644 --- a/languages/i18n/ga.json +++ b/languages/i18n/ga.json @@ -409,24 +409,6 @@ "passwordreset-email": "Seoladh ríomhphoist:", "changeemail-none": "(neamhní)", "changeemail-password": "D'fhocal faire {{SITENAME}}:", - "bold_sample": "Cló trom", - "bold_tip": "Cló trom", - "italic_sample": "Cló iodálach", - "italic_tip": "Cló iodálach", - "link_sample": "Teideal an naisc", - "link_tip": "Nasc inmheánach", - "extlink_sample": "http://www.example.com ainm naisc", - "extlink_tip": "Nasc seachtrach (cuimhnigh an réimír http://)", - "headline_sample": "Cló ceannlíne", - "headline_tip": "Ceannlíne Leibhéil 2", - "nowiki_sample": "Cuir téacs neamhfhormáidithe anseo", - "nowiki_tip": "Cuir vicífhormáidiú ar ceal", - "image_sample": "Sámpla.jpg", - "image_tip": "Íomhá leabaithe", - "media_sample": "Sámpla.ogg", - "media_tip": "Nasc do chomhad meáin", - "sig_tip": "Do shíniú le stampa ama", - "hr_tip": "Líne cothrománach (inúsáidte go coigilteach)", "summary": "Achoimriú:", "subject": "Ábhar/ceannlíne:", "minoredit": "Is mionathrú é seo", diff --git a/languages/i18n/gag.json b/languages/i18n/gag.json index 9ac4cb6718..1a16d7bedc 100644 --- a/languages/i18n/gag.json +++ b/languages/i18n/gag.json @@ -268,22 +268,6 @@ "loginlanguagelabel": "Dil: $1", "retypenew": "Eni parolu tekrar girin", "resetpass_forbidden": "Saytında parol yok nicä diiştirilsin", - "bold_sample": "Kalın tekst", - "bold_tip": "Kalın tekst", - "italic_sample": "Ä°talik tekst", - "italic_tip": "Ä°talik tekst", - "link_sample": "Sayfanın adı", - "link_tip": "İç baalantı", - "extlink_sample": "http://www.example.com adres adı", - "extlink_tip": "Dış baalantı (Unutmayın adresin önüne http:// koymaa)", - "headline_sample": "Başlık teksti", - "headline_tip": "2. düzey başlık", - "nowiki_sample": "Serbest format yazınızı buraya yazınız", - "nowiki_tip": "Wiki formatlamasını ignor et", - "image_tip": "Pätret eklemää", - "media_tip": "Faylına baalantı", - "sig_tip": "Ä°mzanız hem data", - "hr_tip": "Gorizontal liniya (çok sık kullanmayın)", "summary": "Kısaca:", "subject": "Konu/başlık:", "minoredit": "Küçük diişilmäkler", diff --git a/languages/i18n/gan-hans.json b/languages/i18n/gan-hans.json index 29a361ef1d..6abecec861 100644 --- a/languages/i18n/gan-hans.json +++ b/languages/i18n/gan-hans.json @@ -347,22 +347,6 @@ "resetpass_forbidden": "到{{SITENAME}}上改伓正密码", "resetpass-submit-loggedin": "设过帐户密码", "resetpass-submit-cancel": "取消", - "bold_sample": "粗体字", - "bold_tip": "粗体字", - "italic_sample": "斜体字", - "italic_tip": "斜体字", - "link_sample": "链接标题", - "link_tip": "内部链接", - "extlink_sample": "http://www.example.com 链接标题", - "extlink_tip": "外部链接(头上加 http://)", - "headline_sample": "标题文字", - "headline_tip": "二级标题", - "nowiki_sample": "到个首扻入非格式文本", - "nowiki_tip": "扻入非格式文本", - "image_tip": "扻进文件", - "media_tip": "档案链接", - "sig_tip": "倷带时间𠮶签名", - "hr_tip": "横线 (好生使用)", "summary": "摘要:", "subject": "主题/头条:", "minoredit": "个系只细修改", diff --git a/languages/i18n/gan-hant.json b/languages/i18n/gan-hant.json index e7cd619075..0b339acae7 100644 --- a/languages/i18n/gan-hant.json +++ b/languages/i18n/gan-hant.json @@ -338,22 +338,6 @@ "resetpass_forbidden": "到{{SITENAME}}上改伓正密碼", "resetpass-submit-loggedin": "設過帳戶密碼", "resetpass-submit-cancel": "取消", - "bold_sample": "粗體字", - "bold_tip": "粗體字", - "italic_sample": "斜體字", - "italic_tip": "斜體字", - "link_sample": "連結標題", - "link_tip": "內部連結", - "extlink_sample": "http://www.example.com 連結標題", - "extlink_tip": "外部連結(頭上加 http://)", - "headline_sample": "標題文字", - "headline_tip": "二級標題", - "nowiki_sample": "到箇首扻入非格式文本", - "nowiki_tip": "扻入非格式文本", - "image_tip": "扻進文件", - "media_tip": "檔案連結", - "sig_tip": "汝帶時間嗰簽名", - "hr_tip": "橫線 (好生使用)", "summary": "摘要:", "subject": "主題/頭條:", "minoredit": "箇係隻細修改", diff --git a/languages/i18n/gcr.json b/languages/i18n/gcr.json index 058d0ad71d..c55dcd0712 100644 --- a/languages/i18n/gcr.json +++ b/languages/i18n/gcr.json @@ -577,22 +577,6 @@ "resettokens-watchlist-token": "Jéton pou flux (Atom/RSS) web di [[Special:Watchlist|modifikasyon di paj di zòt lis di swivi]]", "resettokens-done": "Jéton réynisyalizé.", "resettokens-resetbutton": "Réynisyalizé jéton-yan ki sélègsyonnen", - "bold_sample": "Tègs gra", - "bold_tip": "Tègs gra", - "italic_sample": "Tègs italik", - "italic_tip": "Tègs italik", - "link_sample": "Tit di yannaj", - "link_tip": "Yannaj entèrn", - "extlink_sample": "http://www.example.com/ tit di yannaj", - "extlink_tip": "Yannaj èstèrn (pa bliyé préfigs-a http://)", - "headline_sample": "Tègs di tit", - "headline_tip": "Titit nivèl 2", - "nowiki_sample": "Rantré tègs-a ki pa fòrmaté isi", - "nowiki_tip": "Ignoré sentags wiki-a", - "image_tip": "Fiché enséré", - "media_tip": "Yannaj bò'd roun fiché médja", - "sig_tip": "Zòt signatir ké dat", - "hr_tip": "Lign orizontal (pa an abizé)", "summary": "Rézimen :", "subject": "Sijè :", "minoredit": "Sa modifikasyon sa minò.", diff --git a/languages/i18n/gd.json b/languages/i18n/gd.json index a025c24642..f27c9616ed 100644 --- a/languages/i18n/gd.json +++ b/languages/i18n/gd.json @@ -580,24 +580,6 @@ "resettokens-watchlist-token": "Tòcan airson an inbhir-lìn (Atom/RSS) a sheallas dhut [[Special:Watchlist|atharraichean air duilleagan a tha air a' chlàr-fhaire agad]]", "resettokens-done": "Chaidh na tòcanan ath-shuidheachadh.", "resettokens-resetbutton": "Ath-shuidhich na tòcanan a chaidh a thaghadh", - "bold_sample": "Teacs trom", - "bold_tip": "Teacs trom", - "italic_sample": "Teacsa Eadailteach", - "italic_tip": "Teacsa Eadailteach", - "link_sample": "Tiotal a' cheangail", - "link_tip": "Ceangal am broinn na làraich", - "extlink_sample": "http://www.example.com tiotal a' cheangail", - "extlink_tip": "Ceangal dhan taobh a-muigh (cuimhnich an ro-leasachan http://)", - "headline_sample": "Teacsa ceann-loidhne", - "headline_tip": "Ceann-loidhne ìre 2", - "nowiki_sample": "Cuir a-steach teacsa gun fhòrmatadh an-seo", - "nowiki_tip": "Leig seachad fòrmatadh uicidh", - "image_sample": "Eisimpleir.jpg", - "image_tip": "Faidhle air a leabachadh", - "media_sample": "Eisimpleir.ogg", - "media_tip": "Ceangal faidhle", - "sig_tip": "D' ainm sgrìobhte le stampa-ama", - "hr_tip": "Loidhne rèidh (na cleachd ro thric e)", "summary": "Gearr-chunntas:", "subject": "Cuspair:", "minoredit": "Seo mùthadh beag", diff --git a/languages/i18n/gl.json b/languages/i18n/gl.json index d8dffa5958..7d18ae6020 100644 --- a/languages/i18n/gl.json +++ b/languages/i18n/gl.json @@ -76,6 +76,7 @@ "tog-useeditwarning": "Avisar ao deixar unha páxina de edición cos cambios sen gardar", "tog-prefershttps": "Utilizar sempre unha conexión segura para acceder ao sistema", "tog-showrollbackconfirmation": "Amosar unha mensaxe de confirmación ó facer clic nunha ligazón de reversión", + "tog-requireemail": "É necesario un correo electrónico para reinicializar os contrasinais", "underline-always": "Sempre", "underline-never": "Nunca", "underline-default": "Opción predeterminada da aparencia ou do navegador", @@ -455,7 +456,7 @@ "createaccountmail": "Utilizar un contrasinal aleatorio temporal e envialo ao enderezo de correo electrónico especificado", "createaccountmail-help": "Pode usarse para crear unha conta para outra persoa sen coñecer o contrasinal.", "createacct-realname": "Nome real (opcional)", - "createacct-reason": "Motivo", + "createacct-reason": "Motivo (rexistrado publicamente)", "createacct-reason-ph": "Por que crea outra conta?", "createacct-reason-help": "Mensaxe amosada no rexistro de creación de contas", "createacct-submit": "Crear a conta", @@ -624,24 +625,6 @@ "resettokens-watchlist-token": "Pase para a fonte de novas (Atom/RSS) web dos [[Special:Watchlist|cambios feitos nas páxinas da súa lista de vixilancia]]", "resettokens-done": "Restablecéronse os pases.", "resettokens-resetbutton": "Restablecer os pases seleccionados", - "bold_sample": "Texto en letra grosa", - "bold_tip": "Texto en letra grosa", - "italic_sample": "Texto en cursiva", - "italic_tip": "Texto en cursiva", - "link_sample": "Título da ligazón", - "link_tip": "Ligazón interna", - "extlink_sample": "http://www.exemplo.com título da ligazón", - "extlink_tip": "Ligazón externa (lembre o prefixo http://)", - "headline_sample": "Texto de cabeceira", - "headline_tip": "Cabeceira de nivel 2", - "nowiki_sample": "Insira aquí un texto sen formato", - "nowiki_tip": "Ignorar o formato wiki", - "image_sample": "Exemplo.jpg", - "image_tip": "Ficheiro incorporado", - "media_sample": "Exemplo.ogg", - "media_tip": "Ligazón a un ficheiro", - "sig_tip": "A súa sinatura con data e hora", - "hr_tip": "Liña horizontal (úsea con moderación)", "summary": "Resumo:", "subject": "Asunto:", "minoredit": "Esta é unha edición pequena", @@ -675,6 +658,7 @@ "systemblockedtext": "O seu nome de usuario ou enderezo IP foi bloqueado automaticamente polo sistema MediaWiki.\nO motivo do bloqueo é:\n\n:<em>$2</em>\n\n* Comezo do bloqueo: $8\n* Expiración do bloqueo: $6\n* Destinatario do bloqueo: $7\n\nO seu enderezo IP actual é $3.\nPor favor, inclúa todos estes detalles en calquera consulta que realice.", "blockednoreason": "non se deu ningunha razón", "blockedtext-composite": "<strong>O seu nome de usuario ou enderezo IP foron bloqueados.</strong>\n\nO motivo dado é:\n\n:<em>$2</em>.\n\n* Comezo do bloqueo: $8\n* Remate do bloqueo máis longo: $6\n\n* $5\n\nO seu enderezo IP actual é $3.\nPor favor, inclúa todos os detalles de arriba en calquera contacto sobre este asunto.", + "blockedtext-composite-ids": "Identificadores de bloqueo relevantes: $1 (o seu enderezo IP pode atoparse tamén nalgunha lista negra)", "blockedtext-composite-no-ids": "O seu enderezo IP aparece en múltiples listas negras", "blockedtext-composite-reason": "Existen varios bloqueos contra a súa conta ou enderezo IP", "whitelistedittext": "Debe $1 para poder editar páxinas.", @@ -747,6 +731,8 @@ "nocreate-loggedin": "Non ten os permisos necesarios para crear páxinas novas.", "sectioneditnotsupported-title": "A edición de seccións non está soportada", "sectioneditnotsupported-text": "A edición de seccións non está soportada nesta páxina.", + "modeleditnotsupported-title": "Non se permite a edición", + "modeleditnotsupported-text": "Non se admite a edición no modelo de contidos $1.", "permissionserrors": "Erro de permisos", "permissionserrorstext": "Non ten os permisos necesarios para facelo {{PLURAL:$1|pola seguinte razón|polas seguintes razóns}}:", "permissionserrorstext-withaction": "Non ten os permisos necesarios para $2, {{PLURAL:$1|pola seguinte razón|polas seguintes razóns}}:", @@ -784,6 +770,9 @@ "content-model-json": "JSON", "content-json-empty-object": "Obxecto baleiro", "content-json-empty-array": "Matriz baleira", + "unsupported-content-model": "<strong>Atención:</strong> nesta wiki non se admite o modelo de contidos $1.</strong>", + "unsupported-content-diff": "Non se admiten as diferenzas entre edicións no modelo de contidos $1.", + "unsupported-content-diff2": "As diferenzas entre edicións dos modelos de contido $1 e $2 non están soportadas nesta wiki.", "deprecated-self-close-category": "Páxinas que usan etiquetas HTML de auto-pechado non válidas", "deprecated-self-close-category-desc": "A páxina contén algunha etiqueta HTML de auto-pechado non válida, como <code><b/></code> ou <code><span/></code>. O comportamento destas etiquetas vai cambiar axiña para gardar a consistencia coa especificación HTML5, polo que cómpre desbotar o seu uso no texto wiki.", "duplicate-args-warning": "<strong>Atención:</strong> \"[[:$1]]\" está chamando a \"[[:$2]]\" con máis dun valor para o parámetro \"$3\". Só se usará o último valor proporcionado.", @@ -819,6 +808,7 @@ "undo-norev": "A edición non se pode desfacer porque non existe ou foi eliminada.", "undo-nochange": "Semella que alguén xa desfixo a edición.", "undo-summary": "Desfíxose a edición $1 de [[Special:Contributions/$2|$2]] ([[User talk:$2|conversa]])", + "undo-summary-anon": "Desfacer a modificación $1 de [[Special:Contributions/$2|$2]]", "undo-summary-username-hidden": "Desfíxose a edición $1 dun usuario agochado", "cantcreateaccount-text": "A creación de contas desde este enderezo IP ('''$1''') foi bloqueada por [[User:$3|$3]].\n\nA razón dada por $3 foi ''$2''", "cantcreateaccount-range-text": "O usuario [[User:$3|$3]] bloqueou a creación de contas desde enderezos IP no rango <strong>$1</strong>, no que se atopa o seu enderezo IP (<strong>$4</strong>).\n\nA razón que deu $3 foi <em>$2</em>.", @@ -1001,6 +991,8 @@ "search-interwiki-more": "(máis)", "search-interwiki-more-results": "máis resultados", "search-relatedarticle": "Relacionado", + "search-invalid-sort-order": "A ordenación $1 non está recoñecida, aplicarase a ordenación por defecto. As ordenacións válidas sonː $2", + "search-unknown-profile": "No se recoñece o perfil de procura $1; aplicarase o perfil predeterminado.", "searchrelated": "relacionado", "searchall": "todo", "showingresults": "{{PLURAL:$1|Móstrase <strong>1</strong> resultado|Móstranse <strong>$1</strong> resultados}}, comezando polo número <strong>$2</strong>.", @@ -1117,6 +1109,7 @@ "prefs-help-email": "O enderezo de correo electrónico é opcional, pero permite que se lle envíe un contrasinal novo se se esquece del.", "prefs-help-email-others": "Tamén pode optar por deixar que outras persoas se poñan en contacto con vostede a través dunha ligazón na súa páxina de usuario e de conversa.\nO seu enderezo non se revela cando contacten con vostede.", "prefs-help-email-required": "Cómpre o enderezo de correo electrónico.", + "prefs-help-requireemail": "Se está marcado, só enviará correos electrónicos de restablecemento de contrasinal se a persoa que fai o reinicio proporcionou un nome de usuario e correo electrónico para esta conta.", "prefs-info": "Información básica", "prefs-i18n": "Internacionalización", "prefs-signature": "Sinatura", @@ -1247,6 +1240,7 @@ "right-editmyusercss": "Editar os ficheiros CSS propios", "right-editmyuserjson": "Editar os ficheiros JSON do propio usuario", "right-editmyuserjs": "Editar os ficheiros JavaScript propios", + "right-editmyuserjsredirect": "Editar os seus propios ficheios JavaScript de usuario cando sexan redireccións", "right-viewmywatchlist": "Ver a lista de vixilancia propia", "right-editmywatchlist": "Editar a lista de vixilancia propia. Teña en conta que algunhas accións engadirán páxinas igualmente mesmo sen este dereito.", "right-viewmyprivateinfo": "Ver os datos privados propios (por exemplo, o enderezo de correo electrónico ou o nome real)", @@ -1377,6 +1371,7 @@ "action-editmyusercss": "editar os ficheiros CSS propios", "action-editmyuserjson": "editar os ficheiros JSON propios", "action-editmyuserjs": "editar os ficheiros JavaScript propios", + "action-editmyuserjsredirect": "editar os seus proprios ficheiros JavaScript de usuario que son redireccións", "action-viewsuppressed": "ver revisións agochadas de calquera usuario", "action-hideuser": "bloquear un nome de usuario, agochándoo do público", "action-ipblock-exempt": "evitar bloqueos de IPs, autobloqueos e bloqueos de rango", @@ -1757,6 +1752,8 @@ "backend-fail-contenttype": "Non se puido determinar o tipo de contido do ficheiro a almacenar en \"$1\".", "backend-fail-batchsize": "O sistema de almacenamento recibiu un feixe de $1 {{PLURAL:$1|operación|operacións}} de ficheiro; o límite está en $2 {{PLURAL:$2|operación|operacións}}.", "backend-fail-usable": "Non se puido ler ou escribir o ficheiro \"$1\" debido a que os permisos son insuficientes ou faltan os directorios/contenedores.", + "backend-fail-stat": "Non se puido ler o estado do ficheiro \"$1\".", + "backend-fail-hash": "Non se puido determinar o resumo criptográfico do ficheiro \"$1\".", "filejournal-fail-dbconnect": "Non se pode conectar coa base de datos do rexistro do sistema de almacenamento \"$1\".", "filejournal-fail-dbquery": "Non se pode actualizar a base de datos do rexistro do sistema de almacenamento \"$1\".", "lockmanager-notlocked": "Non se puido desbloquear \"$1\". Non está bloqueado.", @@ -2339,14 +2336,16 @@ "alreadyrolled": "Non se pode desfacer a edición en \"[[:$1]]\" feita por [[User:$2|$2]] ([[User talk:$2|conversa]]{{int:pipe-separator}}[[Special:Contributions/$2|{{int:contribslink}}]]); alguén máis editou ou desfixo os cambios desta páxina.\n\nA última edición fíxoa [[User:$3|$3]] ([[User talk:$3|conversa]]{{int:pipe-separator}}[[Special:Contributions/$3|{{int:contribslink}}]]).", "editcomment": "O resumo de edición foi: <em>$1</em>.", "revertpage": "Desfixéronse as edicións de [[Special:Contributions/$2|$2]] ([[User talk:$2|conversa]]); cambiado á última versión feita por [[User:$1|$1]]", + "revertpage-anon": "Revertidas as modificacións de [[Special:Contributions/$2|$2]] á última versión de [[User:$1|$1]]", "revertpage-nouser": "Desfixéronse as edicións dun usuario agochado; cambiado á última versión feita por {{GENDER:$1|[[User:$1|$1]]}}", "rollback-success": "Desfixéronse as edicións de {{GENDER:$3|$1}};\nvolveuse á última edición, feita por {{GENDER:$4|$2}}.", "sessionfailure-title": "Erro de sesión", "sessionfailure": "Parece que hai un problema co rexistro da súa sesión;\nesta acción cancelouse como precaución fronte ao secuestro de sesións.\nPor favor, volva enviar o formulario.", "changecontentmodel": "Cambiar o modelo de contido dunha páxina", "changecontentmodel-legend": "Cambiar o modelo de contido", - "changecontentmodel-title-label": "Título da páxina", - "changecontentmodel-model-label": "Novo modelo de contido", + "changecontentmodel-title-label": "Título da páxinaː", + "changecontentmodel-current-label": "Modelo de contido actual:", + "changecontentmodel-model-label": "Novo modelo de contidoː", "changecontentmodel-reason-label": "Motivo:", "changecontentmodel-submit": "Cambiar", "changecontentmodel-success-title": "Modificouse o modelo de contido", @@ -2576,6 +2575,7 @@ "ipblocklist-legend": "Procurar un usuario bloqueado", "blocklist-userblocks": "Agochar os bloqueos de contas", "blocklist-tempblocks": "Agochar os bloqueos temporais", + "blocklist-indefblocks": "Ocultar os bloqueos indefinidos", "blocklist-addressblocks": "Agochar os bloqueos a enderezos IP únicos", "blocklist-type": "Tipo:", "blocklist-type-opt-all": "Todos", @@ -2626,6 +2626,7 @@ "block-log-flags-angry-autoblock": "realzou o autobloqueo permitido", "block-log-flags-hiddenname": "nome de usuario agochado", "range_block_disabled": "A funcionalidade de administrador de crear rangos de bloqueos está deshabilitada.", + "ipb-prevent-user-talk-edit": "Débese permitir editar a propia páxina de conversa nun bloqueo parcial, agás que inclúa unha restrición no espazo de nomes \"Usuario conversa\".", "ipb_expiry_invalid": "O tempo de duración non é válido.", "ipb_expiry_old": "O tempo de expiración é no pasado.", "ipb_expiry_temp": "Os bloqueos a nomes de usuario agochados deberían ser permanentes.", @@ -2671,6 +2672,7 @@ "move-page-legend": "Mover unha páxina", "movepagetext": "Ao usar o formulario inferior vai cambiar o nome da páxina, movendo todo o seu historial ao novo nome.\nO título vello vaise converter nunha páxina de redirección ao novo título.\nPode actualizar automaticamente as redireccións que van dar ao título orixinal.\nSe escolle non facelo, asegúrese de verificar que non hai redireccións [[Special:DoubleRedirects|dobres]] ou [[Special:BrokenRedirects|crebadas]].\nVostede é responsable de asegurarse de que as ligazóns continúan a apuntar cara a onde se supón que deberían.\n\nTeña en conta que a páxina <strong>non</strong> será trasladada se xa existe unha páxina co novo título, a menos que esta última sexa unha redirección e non teña historial de edicións.\nIsto significa que pode volver renomear unha páxina ao seu nome antigo se comete un erro, e que non pode sobrescribir unha páxina que xa existe.\n\n<strong>Nota:</strong>\nEste cambio nunha páxina popular pode ser drástico e inesperado;\npor favor, asegúrese de que entende as consecuencias disto antes de proseguir.", "movepagetext-noredirectfixer": "Ao usar o formulario inferior vai cambiar o nome da páxina, movendo todo o seu historial ao novo nome.\nO título vello vaise converter nunha páxina de redirección ao novo título.\nAsegúrese de verificar que non hai redireccións [[Special:DoubleRedirects|dobres]] ou [[Special:BrokenRedirects|crebadas]].\nVostede é responsable de asegurarse de que as ligazóns continúan a apuntar cara a onde se supón que deberían.\n\nTeña en conta que a páxina <strong>non</strong> será trasladada se xa existe unha páxina co novo título, a menos que esta última sexa unha redirección e non teña historial de edicións.\nIsto significa que pode volver renomear unha páxina ao seu nome antigo se comete un erro, e que non pode sobrescribir unha páxina que xa existe.\n\n<strong>Nota:</strong>\nEste cambio nunha páxina popular pode ser drástico e inesperado;\npor favor, asegúrese de que entende as consecuencias disto antes de proseguir.", + "movepagetext-noredirectsupport": "Ó usar o seguinte formulario, renomearase unha páxina e trasladarase todo o seu historial ó novo nome.\nÉ responsable de asegurarse de que tódalas ligazóns tralo traslado seguen apuntando cara onde deberían.\n\nLembre que a páxina <strong>non</strong> se trasladará se xa existe unha páxina co título novo.\nIsto significa que poderá renomear unha páxina ó seu título orixinal se cometeu un erro, pero non poderá sobrescribir unha páxina existente.\n\n<strong>Nota:</strong>\nEste pode ser un cambio drástico e inesperado para unha páxina popular;\nasegúrese de entender as consecuencias antes de seguir adiante.", "movepagetalktext": "Se marca esta caixa, a páxina de conversa asociada moverase automaticamente ó título novo a menos que xa exista unha páxina de conversa non baleira alí.\n\nNeste caso, deberá trasladar ou fusionar manualmente a páxina se así o desexa.", "moveuserpage-warning": "'''Aviso:''' Está a piques de mover unha páxina de usuario. Por favor, teña en conta que só se trasladará a páxina e que o usuario '''non''' será renomeado.", "movecategorypage-warning": "'''Aviso:''' Está a piques de mover unha páxina de categoría. Por favor, teña en conta que só se trasladará a páxina e que as páxinas presentes na categoría vella '''non''' serán recategorizadas na categoría nova.", @@ -2698,6 +2700,7 @@ "move-subpages": "Mover as subpáxinas (ata $1)", "move-talk-subpages": "Mover as subpáxinas da páxina de conversa (ata $1)", "movepage-page-exists": "A páxina \"$1\" xa existe e non pode ser sobrescrita automaticamente.", + "movepage-source-doesnt-exist": "A páxina $1 non existe polo que non pode ser trasladada.", "movepage-page-moved": "A páxina \"$1\" foi movida a \"$2\".", "movepage-page-unmoved": "A páxina \"$1\" non pode ser movida a \"$2\".", "movepage-max-pages": "Foi movido o número máximo {{PLURAL:$1|dunha páxina|de $1 páxinas}} e non poderán ser movidas automaticamente máis.", @@ -2714,10 +2717,12 @@ "delete_and_move_reason": "Eliminado para facer sitio para mover \"[[$1]]\"", "selfmove": "O título é o mesmo; \nnon se pode mover unha páxina sobre si mesma.", "immobile-source-namespace": "Non se poden mover as páxinas que están no espazo de nomes \"$1\"", + "immobile-source-namespace-iw": "Non é posible trasladar páxinas doutras wikis dende esta.", "immobile-target-namespace": "Non se poden mover as páxinas ao espazo de nomes \"$1\"", "immobile-target-namespace-iw": "A ligazón interwiki non é válida para o movemento da páxina.", "immobile-source-page": "Esta páxina non se pode mover.", "immobile-target-page": "Non se pode mover a ese título.", + "movepage-invalid-target-title": "O nome solicitado non é válido.", "bad-target-model": "O destino desexado utiliza un modelo de contido diferente. Non se pode facer a conversión entre $1 e $2.", "imagenocrossnamespace": "Non se pode mover o ficheiro a un espazo de nomes que non o admite", "nonfile-cannot-move-to-file": "Non se pode mover algo que non é un ficheiro ao espazo de nomes reservado aos ficheiros", @@ -3838,6 +3843,8 @@ "linkaccounts": "Vincular contas", "linkaccounts-success-text": "A conta foi vinculada.", "linkaccounts-submit": "Vincular contas", + "cannotunlink-no-provider-title": "Non hai contas ligadas a desligar", + "cannotunlink-no-provider": "Non hai contas ligadas que poidan desligarse.", "unlinkaccounts": "Desvincular contas", "unlinkaccounts-success": "A conta foi desvinculada.", "authenticationdatachange-ignored": "Os cambios de datos de autenticación non foron xerados. Está configurado o provedor?", @@ -3850,13 +3857,15 @@ "edit-error-short": "Erro: $1", "edit-error-long": "Erros:\n\n$1", "specialmute": "Silenciar", - "specialmute-success": "As súas preferencias de silenciamento foron actualizadas. Ver todos os usuarios silenciados en [[Special:Preferences]].", + "specialmute-success": "As súas preferencias de silenciamento foron actualizadas. Ver todos os usuarios silenciados nas súas [[Special:Preferences|preferencias]].", "specialmute-submit": "Confirmar", "specialmute-label-mute-email": "Silenciar os correos electrónicos deste usuario", - "specialmute-header": "Por favor, seleccione as súas preferencias de silenciamento para <b>{{BIDI:[[User:$1]]}}</b>.", + "specialmute-header": "Por favor, seleccione as súas preferencias de silenciamento para o usuario <b>{{BIDI:[[User:$1|$1]]}}</b>.", "specialmute-error-invalid-user": "Non se atopou o nome de usuario indicado.", - "specialmute-email-footer": "Para xestionar as preferencias de correo electrónico de {{BIDI:$2}}, por favor, visite <$1>.", + "specialmute-error-no-options": "As funcionalidades de silenciamento non están dispoñibles. Isto pode ser porque: non confirmou o seu enderezo de correo electrónico ou o administrador da wiki desactivou as funcionalidades de correo electrónico e/ou a lista negra de enderezos de correo electrónico para esta wiki.", + "specialmute-email-footer": "Para xestionar as preferencias de correo electrónico do usuario {{BIDI:$2}}, por favor, visite <$1>.", "specialmute-login-required": "Por favor, inicie sesión para alterar as súas preferencias de silenciamento.", + "mute-preferences": "Preferencias de silenciamento", "revid": "revisión $1", "pageid": "identificador de páxina $1", "interfaceadmin-info": "$1\n\nOs permisos para editar os ficheiros CSS/JS/JSON globais separáronse recentemente do dereito <code>editinterface</code>. Se non comprende porqué está vendo este erro, vexa [[mw:MediaWiki_1.32/interface-admin]].", @@ -3884,6 +3893,7 @@ "passwordpolicies-policy-passwordnotinlargeblacklist": "O contrasinal non pode estar na lista dos 100.000 contrasinais máis usados.", "passwordpolicies-policyflag-forcechange": "debe modificarse ó iniciar sesión", "passwordpolicies-policyflag-suggestchangeonlogin": "suxerir cambio ó iniciar sesión", + "mycustomjsredirectprotected": "Non ten permiso para editar esta páxina JavaScript porque é unha redirección e non apunta cara ó seu propio espazo de usuario.", "easydeflate-invaliddeflate": "O contido fornecido non está debidamente comprimido", "unprotected-js": "Por motivos de seguridade non se pode cargar JavaScript desde páxinas non protexidas. Por favor, cree só JavaScript no espazo de nomes MediaWiki ou como subpáxina de usuario", "userlogout-continue": "Quere rematar a sesión?" diff --git a/languages/i18n/glk.json b/languages/i18n/glk.json index 890a16c84d..843b98038b 100644 --- a/languages/i18n/glk.json +++ b/languages/i18n/glk.json @@ -309,21 +309,6 @@ "passwordreset-emailelement": "کارگيري نؤم: \n$1\n\nمؤوقتي رمز: \n$2", "changeemail-newemail": "تازه ايميلˇ آدرس:", "changeemail-none": "(هيچ)", - "bold_sample": "پۊررنگˇ وؤت", - "bold_tip": "پۊررنگˇ وؤت", - "italic_sample": "کجˇ وؤت", - "italic_tip": "کجˇ وؤت", - "link_sample": "خالˇ تيتر", - "link_tip": "دۊيريني خال", - "extlink_sample": "http://www.example.com خالˇ تيتر", - "extlink_tip": "بيريني خال (http://‎ پيشونده ىادانکۊنين)", - "headline_sample": "تيترˇ وؤت", - "headline_tip": "سطحˇ ۲ˇ تيتر", - "nowiki_sample": "قالب-بندي نۊبؤ وؤت ائره واردأبي", - "image_tip": "وؤتˇ مئنˇ تصوير", - "media_tip": "فاىلˇ خال", - "sig_tip": "شيمي ايمضا ؤ زمتˇ برچسب", - "hr_tip": "اؤفؤقي خط (اۊن أجي کم کارأگيرين)", "summary": "فيچالسه:", "minoredit": "اي نيميزگره دچينواچينه", "watchthis": "اي ولگه پى بگير", diff --git a/languages/i18n/gom-deva.json b/languages/i18n/gom-deva.json index 2a427a291b..3f68f63af1 100644 --- a/languages/i18n/gom-deva.json +++ b/languages/i18n/gom-deva.json @@ -13,7 +13,8 @@ "The Discoverer", "Cliffa fernandes", "Rxy", - "Isidore Dantas" + "Isidore Dantas", + "Abijeet Patro" ] }, "tog-hideminor": "हालींच बदल केल्ल्यांतले बारीक संपादन लिपय", @@ -24,15 +25,15 @@ "tog-previewonfirst": "पयल्याच संपादनाचेर पुर्वनियाळ दाखय", "tog-enotifwatchlistpages": "म्हज्या सादुरवळेरेंतलें पान वा फायल बदल्ली जाल्यार म्हाका इमेल करात", "tog-shownumberswatching": "ध्यान दवरपी वांगड्यांची संख्या दाखय", - "tog-oldsig": "सद्याची निशाणी", - "tog-uselivepreview": "लायव पुर्वनियाळाचो वापर", + "tog-oldsig": "तुज्या सध्याची निशाणी", + "tog-uselivepreview": "पान परत उगडनासताना झलक दाखय", "tog-watchlisthideown": "सादुरवळेरीतलें म्हजे संपादन लिपय", "tog-watchlisthidebots": "ध्यानसुचीतले रोबोट संपादन लिपय", "tog-watchlisthideminor": "सादुरवळेरीतले ल्हान संपादन लिपय", "tog-showhiddencats": "लिपोवन दवरिल्ले विभाग दाखय", "underline-always": "सदा (केधन्नय) (केन्नय)", "underline-never": "केधन्नयना (केन्नना)", - "underline-default": "ब्राउज़र डिफ़ॉल्ट", + "underline-default": "स्कीन वा ब्रावसरा प्रमाणें", "sunday": "आयतार", "monday": "सोमार", "tuesday": "मंगळार", @@ -99,20 +100,21 @@ "category_header": "\"$1\" ह्या वर्गातलीं पानां", "subcategories": "उपवर्ग", "category-media-header": "\"$1\" वर्गातलें प्रसार माध्यम", + "category-empty": "<em>ह्या वर्गान सध्या एकूय पान वा माध्यम ना.</em>", "hidden-categories": "{{PLURAL:$1|लिपिल्लें वर्ग|लिपिल्लें वर्ग }}", "hidden-category-category": "लिपयिल्ले विभाग", "category-subcat-count": "{{PLURAL:$2|ह्या वर्गान फकत सकयल दिल्ले उपविभाग आसात.|ह्या वर्गातल्या $2 वट्ट {{PLURAL:$1|सकयल दिल्ले उपवर्ग आसात.|$1सकयल दिल्ले उपवर्ग आसात.}}}}", "category-article-count": "{{PLURAL:$2|ह्या वर्गांत सकयल दिल्लीं पानां आसात.|ह्या वर्गांत सकलय दिल्लीं {{PLURAL:$1|पानां आसात|$1 पानां आसात}}, वट्ट पानां $2}}", "category-file-count": "{{PLURAL:$2|ह्या वर्गांत फकत सकयली फायल आसपावता.|ह्या वर्गांत सकयल दिल्लीं {{PLURAL:$1|फायल|$1 फायलीं}} आसता, वट्ट फायलीं $2}}", "listingcontinuesabbrev": "चालू.", - "noindex-category": "बिननिर्देशांकी पानां", + "noindex-category": "सुचीपत्रान जोडूंक-नासलेलीं पानां", "broken-file-category": "तुटलेल्या फायलींचो दुवे आसलेलीं पानां", "about": "विशीं", "article": "मजकूराचीं पानां", "newwindow": "(नव्या ज़ोणेलांत उकतें जाता)", "cancel": "रद्द करात", "moredotdotdot": "आनीक", - "morenotlisted": "ही सूची पूर्ण ना", + "morenotlisted": "ही सुची पूर्ण नासूंक शक्ता.", "mypage": "पान", "mytalk": "चर्चा", "navigation": "दिशा-नियंत्रण", @@ -174,6 +176,7 @@ "poolcounter-usage-error": "उपयोगी त्रुटि: $1", "aboutsite": "{{SITENAME}}विशीं", "aboutpage": "Project:विशीं", + "copyright": "मजकूर $1 हाच्या खाला उपलब्ध आसा खेरीज हेर नोंदी केल्या शिवाय.", "copyrightpage": "{{ns:project}}:प्रात-हक", "currentevents": "चालंत घडणुकों", "currentevents-url": "Project:चालंत घडणुको", @@ -189,6 +192,10 @@ "privacypage": "Project:गुप्ततायेचें धोरण", "ok": "बरें", "retrievedfrom": "\"$1\" चे कडल्यान परतून मेळयलें", + "youhavenewmessages": "{{PLURAL:$3|तुमकां}} $1 ($2) आसात.", + "youhavenewmessagesfromusers": "तुका {{PLURAL:$3एक वापरपी|$3 वापरपी}} कडल्यान $1 {{PLURAL:$4|आसा|आसात}} ($2).‎", + "newmessageslinkplural": "{{PLURAL:$1|नवो संदेश|999=नवे संदेश}}‎", + "newmessagesdifflinkplural": "{{PLURAL:$1|निमाणो बदल|999=निमाणे बदल}}", "youhavenewmessagesmulti": "$1 चेर तुका नवो संदेश आसा", "editsection": "बदल", "editold": "बदल", @@ -203,7 +210,7 @@ "collapsible-expand": "विस्तार", "confirmable-yes": "हय", "confirmable-no": "ना", - "thisisdeleted": "पळय आनी परतून हाड 1?", + "thisisdeleted": "$1 पळय वा परत हाड?", "viewdeleted": "दाखयात $1?", "feedlinks": "पुरवय :", "feed-invalid": "चुकीचें सब्सक्रिप्शन फीड प्रकार", @@ -233,7 +240,7 @@ "databaseerror-textcl": "डॅटाबेज विरोध त्रुटी आयिल्ली आसा", "databaseerror-query": "अनुरोध: $1", "databaseerror-error": "चूक: $1", - "missing-article": "डेटाबेजाक \"$1\" $2 ह्या नांवाचें जे मजकूराचें पान मेळूंक जाय आसलें तें मेळ्ळेंना. हें चड करून जेन्ना काडून उडयिल्ल्या पानाक मुजत सोंपिळ्ळे डिफ वा इतिहासाचो दुवो दिवप जाता तेन्ना घडटा..जर अशें नासत तर तुमकां सॉफ्टवेरांत चूक सांपडूंक जाय हें अँडमिनिस्ट्रेटराक URLची नोंद करून कळयात.", + "missing-article": "डेटाबेजाक \"$1\" $2 ह्या नांवाचें जे मजकूराचें पान मेळूंक जाय आसलें तें मेळ्ळेंना. हें चड करून जेन्ना काडून उडयिल्ल्या पानाक मुजत सोंपिळ्ळे डिफ वा इतिहासाचो दुवो दिवप जाता तेन्ना घडटा..जर अशें नासत तर तुमकां सॉफ्टवेरांत चूक सांपडूंक जाय हें अँडमिनिस्ट्रेटराक URLची नोंद करून कळयात.\n\n\nम्हायतीकोश (Database) हांतूत मेळूंक जाय आसलें तें मजकूर \"$1\" $2 मेळूंक नां.\n\nहरर्शीं, अशें एक पोरणें एक फरक वा एका पानाच्या इतिहासाचो दुवो काडून उडयला, तेन्ना जाता.\n\nअशें न्हय जाल्यार, तुका सोफ्टवेरान चूक सांपडलेया जायत.\nउपकार करून एका [[Special:ListUsers/sysop|कार्भारीच्या]] नतरेक हाड, अतरजाळ्यांत जागो सोदपी (यु. आर. एल.) हाची नोंद घेवन.", "missingarticle-rev": "पुनर्नियाळ $1", "badtitle": "चुकीचो माथाळो", "badtitletext": "विनवणी केल्लें पानाचो माथाळो अवैध, रितो वा अयोग्य तरेन आंतरभाशी वा आंतर विकी माथाळ्या कडे जोडिल्लो आशिल्लो. तातूंत माथाळ्यांत वापरुं नजो अशी एक वा चड अक्षरां आसूं येतात.", @@ -284,11 +291,11 @@ "loginerror": "लॉन इन त्रुटी", "createacct-error": "खातें निर्माण त्रुटी", "createaccounterror": "खातें तयार करूंक जायना: $1", - "loginsuccesstitle": "लॉन इन यशस्वी जालां", + "loginsuccesstitle": "सत्रारंभ जालें", "nosuchusershort": "\"$1\" ह्या नांवान कोण वापरपी ना.\nउतरां तपासून पळय", "nouserspecified": "वापरप्याचें नांव तुवें सांगूंक जाय", "login-userblocked": "ह्या वापरप्याक बंद केला. लॉग इन करूंक जायना.", - "wrongpassword": "चुकिचें गुपीत उतर घातलां.\nउपकार करून परतून यत्न कर.", + "wrongpassword": "चुकीचें वापरप्याचें नांव वा गुपीतउतर घातलां.\nउपकार करून परतून प्रयत्न कर.", "wrongpasswordempty": "गुपीत उतर घालूंक ना.\nउपकार करून परतून यत्न कर.", "passwordtoolong": "गुपीत उतर हाच्या परस चड व्हड आसूंक फावना{{PLURAL:$1|1 वर्ण|$1 वर्णां}}.", "password-name-match": "तुजें गुपीत उतर वापरप्याच्या नांवा परस वेगळें आसूंक जाय.", @@ -302,7 +309,7 @@ "emaildisabled": "ही साइट मेल धाडपाक शकना.", "accountcreated": "खातें तयाओर केलें", "createaccount-title": "{{SITENAME}} हाका लागून खातें तयार केलां", - "login-abort-generic": "तुमचें लॉग इन अपेशी थारलां - निश्फलीत", + "login-abort-generic": "तुजें सत्रारंभ अपेशी थारलां – निशफळीत", "login-migrated-generic": "तुमचें खातें स्थलांतरीत जालां आनी तुजें वापरप्याचें नांव ह्या विकीचेर उपस्थीत ना.", "loginlanguagelabel": "भास:$1", "pt-login": "सत्रारंभ", @@ -315,7 +322,7 @@ "newpassword": "नवें गुपीत उतर", "retypenew": "नवें गुपीत उतर परतून टाइप कर", "resetpass_submit": "गुपीत उतर तयार कर आनी लॉग इन कर", - "changepassword-success": "तुजें गुपीत उतर बदलप यशस्वी थारलां", + "changepassword-success": "तुजें गुपीतउतर बदल्लां!", "resetpass_forbidden": "गुपीत उतरां बदलूंक शकनात", "resetpass-submit-loggedin": "गुपीत उतर बदलात", "resetpass-submit-cancel": "रद्द करात", @@ -327,8 +334,8 @@ "passwordreset-domain": "डोमेन:", "passwordreset-email": "ईमेल नामो:", "passwordreset-emailelement": "वापरप्याचें नांव: \n$1\n\nतात्पुरतें गुपीत उतर: \n$2", - "passwordreset-emailsentemail": "गुपीत उतर परतून तयार करपाचो ईमेल धाडला", - "changeemail": "ईमेल संदेश बदल्ला", + "passwordreset-emailsentemail": "हो ईमेल पत्तो तुज्या हिशोबांत जोडलोलों आसा जाल्यार, गुपीतउतर परतून थारावपाचो ईमेल धाडलेलें जातेलें.", + "changeemail": "ईमेल पत्तो बदल वा काड", "changeemail-oldemail": "सद्याचो ईमेल नामो:", "changeemail-newemail": "नवो ईमेल नामो:", "changeemail-none": "(कांय ना)", @@ -338,22 +345,6 @@ "resettokens-no-tokens": "पुनर्स्थापित करपा खातीर कसलेंच चावी ना", "resettokens-tokens": "चाव्यो :", "resettokens-token-label": "$1 (सद्याचें मूल्य: $2)", - "bold_sample": "डाट बरप", - "bold_tip": "डाट मजकूर", - "italic_sample": "पालसो बरप", - "italic_tip": "पालसो मजकूर", - "link_sample": "दुवेचो माथाळो", - "link_tip": "भीतरलो दुवो", - "extlink_sample": "http://www.udaronn.in दुवयाचो माथाळो", - "extlink_tip": "भायलो दुवो (उपसर्ग http:// याद दवरात)", - "headline_sample": "माथाळयाचो मजकूर", - "headline_tip": "दुसऱ्या पांवड्याचो माथाळो", - "nowiki_sample": "असरूपीत मजकूर हांगा शिरकटायात", - "nowiki_tip": "विकिचें सरूपण आडनदर करात", - "image_tip": "अंत: स्थापीत फायल", - "media_tip": "फायलीचो दुवो", - "sig_tip": "वेळ-छाप सयत तुमची निशाणी", - "hr_tip": "आडवी वळ (उणो वापरचो)", "summary": "आपरोस:", "subject": "विशय:", "minoredit": "हें दाकटें संपादन", @@ -365,26 +356,32 @@ "showpreview": "पूर्वनियाळ दाखय", "showdiff": "बदल दाखयात", "anoneditwarning": "'''शिटकावणी:''' तुवें सत्रारंभ करूंक ना.\nतुजो IP पत्तो ह्या पानाच्या संपादन इतिहासांत नोंद जातलो.जर तुमी <strong>[$1 सत्रारंभ]</strong> करता वा <strong>[$2 खातें उगडटा]</strong> जाल्यार हेर सुविधांसयत तुमच्या संपादनाचें श्रेय तुमच्या सदस्य नांवाचेर दितलें.", - "missingcommenttext": "उपकार करून तुमच्यो शिरो सकयल घाल.", + "missingcommenttext": "उपकार करून तुजो शेरो बरय.", "blockedtitle": "वापरप्याक बंद केला", + "blockedtext": "<strong>तुजें वापरप्याचें नांव वा आय पा पत्तो आडावपांत आयला.</strong>\n\nआडावप $1 हाणें केलां.\nकारण दिलां तें <em>$2</em>.\n\n* आडावपाची सुरवात: $8\n* आडावप सोंपोवपाचो वेळ: $6\n* आडावपाक येवजिला: $7\n\nतुज्यान $1-आक वा दूसऱ्या [[{{MediaWiki:Grouppage-sysop}}|कारभार्याक]] आडावणे विशीं भासाभास करुंक संपर्क करुंक जाता. तुज्यान \"{{int:emailuser}}\" सभावगूण वापरुंक जायना खेरीज एक वैद ईमेल पत्तो तुज्या [[Special:Preferences|खातें पसंतिंत]] निशचीत केल्या शिवाय आनी तुका तें वापरपाक आडावंक ना जाल्यार. तुजो चालंत IP पत्तो आसा $3, आनी आडावणेच्यो आंक #$5 आसा. सगळ्यो वयल्यो बारिकसाणी तूं करताय त्या विचारांत समावेश कर.", "blockednoreason": "कांयच कारण दिवंक ना", "loginreqtitle": "लॉग इन जाय", "loginreqlink": "सत्रारंभ करात", "accmailtitle": "गुपीत उतर धाडलां", "newarticle": "(नवें)", "newarticletext": "जें पान अजून अस्तित्वांत ना अशा पानाचे दुवे फाटल्यान तुमी आसात. पान रचपाक सकयले चौकटींत टायप करपाक सुरु करात (चड म्हायती खातीर [$1 आदाराचें पान] पळेयात) जर ह्या पानार तुमी चुकून पावल्यात तर ब्रावजराचो बॅक (<strong>फटीं</strong>) हो बटन दामात", + "anontalkpagetext": "----\n<em>हें भासाभासेचें पान एक निनामी वापरप्याक जाणें अजून एक खातें उगडुंक ना, वो तो तें वापर्ना.</em>\nह्या खातीर आमकां आंकड्यांचो IP पत्तो वापरुंक पडता ताका वळखुंक.\nतसलो IP पत्तो साबार वापरप्यानी वापरूं येता.\nतूं जर एक निनामी वापरपी आसा आनी तुका दिसता की तुमका संबंद नासलेले शेरे तुजे विशीं केल्यात, उपकार करून [[Special:CreateAccount|एक खातें रच]] वा[[Special:UserLogin|सत्रारंभ कर]] फुडले गुस्पप निनामी वापरप्या ताळूंक.‎", "noarticletext": "सध्याक हें पान रिंते आसा.\nतुज्यान दूसऱ्या पानानी [[Special:Search/{{PAGENAME}}| ह्या पानाचे नांव सोदूंक जाता]], <span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAME}}}} संबंधी सत्रानी सोदूंक जाता], वा [{{fullurl:{{FULLPAGENAME}}|action=edit}} हें पान रचूंक जाता]</span>.", "noarticletext-nopermission": "तुर्ताक ह्या पानाचेर कसलोच मजकूर ना. तुमी हेर पानांचेर [[Special:Search/{{PAGENAME}}|ह्या माथाळ्याचो सोद]] घेवं शकतात,\nवा <span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} संबंदीत लॉग सोदूं शकतात]</span>, पूण तुमकां हें पानाची रचणूक करपाची परवानगी ना।", "userpage-userdoesnotexist-view": "\"$1\" ह्या वापरप्याच्या खात्याची नोंदणी करूंक ना.", + "clearyourcache": "<strong>चत्राय:</strong> सांबाळ्ळ्या उपरांत, तुका घडयेक तुज्या ब्रावसराचो कॅश कडसरावंक पडत बदल पळोंवचे खातीर.\n* <strong>Firefox / Safari:</strong> <em>Shift</em> > धर <em>Reload</em> क्लीक करताना, वा दाम <em>Ctrl-F5</em> वा <em>Ctrl-R</em> (<em>⌘-R</em> मॅक-आचेर)\n* <strong>Google Chrome:</strong> <em>Ctrl-Shift-R</em> दाम (<em>⌘-Shift-R</em> एका मॅक-आचेर)\n* <strong>Internet Explorer:</strong> <em>Ctrl</em> dhor <em>Refresh</em> क्लीक करताना, वा दाम <em>Ctrl-F5</em>\n* <strong>Opera:</strong> हांगा वच: <em>Menu → Settings</em> (<em>Opera → Preferences</em> मॅक-आचेर) आनी उपरांत <em>Privacy & security → Clear browsing data → Cached images and files</em>.‎", "previewnote": "'''ही फकत एक दाखवण हें मतींत दवरात.'''\nतुमचें बदल आडून राखून दवरूंक ना!", + "continue-editing": "संपादन करपाच्या जाग्यार वच", "editing": "संपादता $1", "creating": "$1 रोचता", "editingsection": "(विभाग) $1 संपादन", "yourtext": "तुमचो मजकूर", "templatesused": "ह्या पानाचेर {{PLURAL:$1|वापरिल्लें}} सांचे", + "templatesusedpreview": "{{PLURAL:$1सांचो|सांचे}} ह्या झलकेंत वापरल्यात:‎", "template-protected": "(राखिल्लें)", "template-semiprotected": "(अर्द-सुरक्षीत)", "hiddencategories": "हें पान {{PLURAL:$1|लिपिल्ले वर्गाचें}} आसा", + "permissionserrors": "परवांगेची चूक", "permissionserrorstext-withaction": "ह्या {{PLURAL:$1|कारण|कारणां}}: खातीर तुका $2 मान्यताय ना.", "recreate-moveddeleted-warn": "शिटकावणीः तुमी आदीं काडून उडयिल्लें पान परतून तयार करतात ह्या पानाचे फासून उडोवपी आनी दुसरे कडे व्हरपी लाग फकत सोपेपणा खातीर दिल्यात", "moveddeleted-notice": "हें पान काडून उडयला.\nह्या पानाचें काडून उडोवपाचें, राखपाचें, आनी हालोवपाचें सत्र संदर्भा खातीर सकयल दिला.", @@ -394,6 +391,7 @@ "post-expand-template-inclusion-category": "जंय सांचे धरून आवांठ व्हड जाता अशीं पानां", "post-expand-template-argument-warning": "<strong>शिटकावणीः</strong> ह्या पानाचेर खुब व्हड आंवाठ आशिल्लो एक तरी सांच्याचो मुद्दो आसा. हे मुद्दे भायरायल्यात", "post-expand-template-argument-category": "भायरायिल्ल्या सांच्यांसंबंदीचे मुद्दे आशिल्लीं पानां", + "undo-failure": "बदल परतावूंक जावंक ना कित्याक गुस्पणेचे मदले बदल आसात.", "viewpagelogs": "ह्या पाना खातीर सोत्रां पळेयात", "currentrev-asof": "$1 मेरेनचो सगळ्यांत निमणो पुनर्नियाळ", "revisionasof": " $1 मेरेन पुनर्नियाळ", @@ -408,9 +406,11 @@ "page_last": "निमणें", "histlegend": "फरकाची निवडणी : पुनर्नियाळांची तुळा करपा खातीर रेडियो चौकटीं चेर कुरु करात आनी ''एंटर'' ना तर तळाकडे आशिल्लो बुतांव दामात।<br />\nविवरण : <strong>({{int:cur}})</strong> = हालींची पुनर्नियाळा बरोबर फरक, <strong>({{int:last}})</strong> = आदली पुनर्नियाळा बरोबर फरक, <strong>{{int:minoreditletter}}</strong> = दाक्टें बदल।", "history-fieldset-title": "उजळण्यो चाळ", - "history-show-deleted": "फकत काडून उडयिल्लें", + "history-show-deleted": "फकत उजळणी काडून उदयलेलें", "histfirst": "पोरणो", "histlast": "नवो ताल्ल", + "history-feed-title": "पुनर्नियाळाचो इतिहास", + "history-feed-description": "विकीचेर ह्या पाना खातीर पुनर्नियाळाचो इतिहास", "history-feed-item-nocomment": "$1 हांगा $2", "rev-delundel": "दृश्य मानताय बदलात", "rev-showdeleted": "दाखयात", @@ -421,13 +421,16 @@ "revdel-restore": "दृश्य मानताय बदलात", "pagehist": "पानाचो इतिहास", "mergehistory-reason": "कारण:", + "mergelog": "विलीन करपाचें सत्र", "revertmerge": "वेगळावप", "history-title": "\"$1\" च्या पुनर्नियाळाचो इतिहास", "difference-title": "\"$1\" च्या आवृत्तींत अंतर", "lineno": "$1 वळ :", "compareselectedversions": "वेंचिल्ल्या पुनर्नियाळांची तुळा करात", "editundo": "केल्लें परतावचें", + "diff-empty": "(कांय फरक ना)‎", "diff-multi-sameuser": "(ह्या वांगड्या सयत {{PLURAL:$1|केल्लें मदलें एक अवतरण दाखोवंक ना|केल्लें मदलें $1 अवतरण दाखोवंक ना}})", + "diff-multi-otherusers": "({{PLURAL:$2|एक हेर वापरप्या|$2 हेर वापरप्यां}} वर्वीं {{PLURAL:$1|एक मदली उजळणी|$1 मदल्यो उजळण्यो}} दाखोवंक ना)‎", "searchresults": "सोदाचो निकाल", "searchresults-title": "\"$1\" हाच्या सोदाचे परिणामां", "prevn": "आदलें{{PLURAL:$1|$1}}", @@ -448,9 +451,10 @@ "searchprofile-everything-tooltip": "सगळो मजकूर सोदात(चर्चेचें पाना सयत)", "searchprofile-advanced-tooltip": "खाशेल्या नांवथोळाणी सोदात", "search-result-size": "$1 ({{PLURAL:$2|1 उतर|$2 उतरां}})", - "search-result-category-size": "{PLURAL:$1|1 सदस्य|$1 सदस्य}} ({{PLURAL:$2|1 उपगट|$2 उपगट}}, {{PLURAL:$3|1 फायल|$3 फायलीं}})", + "search-result-category-size": "{{PLURAL:$1|$1 वांगडी}} ({{PLURAL:$2|$2 उपवर्ग}}, {{PLURAL:$3|1 फायल|$3 फायली}})", "search-redirect": "($1 सावन पुनर्निर्देशीत)", "search-section": "(विभाग $1)", + "search-file-match": "(फायलीच्या मजकुराक जुळटा)‎", "search-suggest": "तुमकां $1 अशें म्हणपाचें आसलें?", "search-rewritten": "$1 हाचो निकाल दाखयता.नाजाल्यार $2 हें सोदात.", "search-interwiki-more": "(आनी)", @@ -468,10 +472,16 @@ "prefs-watchlist": "सादुरवळेरी", "youremail": "इमेल", "yourrealname": "खरें नांवः", + "group-bot": "रोबोटां", + "group-sysop": "कारभारी", + "grouppage-bot": "{{ns:project}}:रोबोटां", + "grouppage-sysop": "{{ns:project}}:कारभारी", "right-writeapi": "Write API चो उपेग", "newuserlogpage": "वापरपी रोचनेचे वळेरी", + "rightslog": "वापरप्याच्या हकांचो सत्र", "action-edit": "हें पान संपादीत कर", - "nchanges": "$1 {{PLURAL:$1|बदल|बदल}}", + "action-createaccount": "हें वापरप्याचें खातें रच", + "nchanges": "$1 {{PLURAL:$1|बदल}}", "enhancedrc-history": "इतिहास", "recentchanges": "हालींचे बदल", "recentchanges-legend": "हालींच जाल्ल्या बदलाचो विकल्प", @@ -499,6 +509,7 @@ "rcshowhideanons": "$1 निनांवी वापरपी", "rcshowhideanons-show": "दाखयात", "rcshowhideanons-hide": "लिपयात", + "rcshowhidepatr": "$1 पारो केलेले सुदारप", "rcshowhidepatr-show": "दाखयात", "rcshowhidepatr-hide": "लिपयात", "rcshowhidemine": "$1 म्हजें संपादन आंकडे", @@ -515,6 +526,7 @@ "rc-change-size-new": "$1 {{PLURAL:$1|बाय्ट|बाय्टी}} बदल केल्या उपरांत", "rc-enhanced-expand": "म्हायती दाखय", "rc-enhanced-hide": "म्हायती लिपय", + "rc-old-title": "आरंभांत रचलली \"$1\" ह्या नांवान‎", "recentchangeslinked": "संबंदित बदल", "recentchangeslinked-toolbox": "संबंदीत बदल", "recentchangeslinked-title": "\"$1\" च्या संबंदातले बदल", @@ -523,6 +535,7 @@ "recentchangeslinked-to": "ह्या पाना बदला दिल्ल्या पानांक जडून आशिल्ल्या पानांचे बदल दाखय", "upload": "फायल अपलोड करात", "uploadbtn": "फायल अपलोड करात", + "uploadlogpage": "अपलोडाचें सत्र", "filedesc": "सारांश", "fileuploadsummary": "आपरोस:", "license": "लायसन्सीग", @@ -543,24 +556,30 @@ "filehist-datetime": "दिस / वेळ", "filehist-thumb": "ल्हान-इमाज़", "filehist-thumbtext": " $1मेरेनचे आवृत्ती खातीर ल्हान-इमाज़", + "filehist-nothumb": "ल्हान-इमाज ना", "filehist-user": "वापरपी", "filehist-dimensions": "परिमाण", "filehist-comment": "शेरो", "imagelinks": "फायलिचो वापर", "linkstoimage": "{{PLURAL:$1|हें पान|$1 हीं पानां}} ही फायल {{PLURAL:$1|वापरता|वापरतात}}:", + "linkstoimage-more": "$1 परस अदीक {{PLURAL:$1|पान वापरता|पानां वापरतात}} ही फायल.\nसकयली वळेरी दाखयता {{PLURAL:$1|पयलें पान|पयलीं $1 पानां}} जें हीच फायल वापरता. एक [[Special:WhatLinksHere/$2|पूर्ण वळेरी]] उपलब्ध आसा.‎", "nolinkstoimage": "ह्या फायलीक वापरतात तसलीं पानां नांत.", + "linkstoimage-redirect": "$1 (फायल पुनर्देशन) $2", "sharedupload-desc-here": "ही फयल $1 हांगाची आनी ती हे प्रकल्पां खातीर वापरल्यार चलता. (तिच्या $2 ह्या फयलींतलें वर्णनाचे पान) तातूंतलें वर्णन सकयल दिलां.", + "filepage-nofile": "ह्या नांवाची फायल असतित्वांत ना.", "upload-disallowed-here": "तूं ह्या फायलीचेर अधिलेखीत करूंक शकना", "randompage": "खंयचेंय पान", "statistics": "संख्याशास्त्र", "statistics-pages": "पान:", "statistics-files": "फायल अपलोड करात", + "double-redirect-fixer": "पुनर्निर्देशन थारावपी", "brokenredirects-edit": "बदल", "brokenredirects-delete": "काडून उडयात", "nbytes": "$1 {{PLURAL:$1|बाय्ट}}", "nmembers": "$1 {{PLURAL:$1|वांगडी}}", "prefixindex": "उपसर्ग आशिल्लीं सगळीं पानां", - "usercreated": "$1 ह्या दिसा $2 ह्या वेळार तयार केलें", + "listusers": "वापरप्यांची वळेरी", + "usercreated": "$3 हाणें $1 दिसा $2 वोराचेर {{GENDER:$3|रचलेलें}}", "newpages": "नवीं पानां", "move": "हालय", "pager-newer-n": "{{PLURAL:$1|नवो 1|नवें $1}}", @@ -568,12 +587,18 @@ "booksources": "पुस्तकांचो स्त्रोत", "booksources-search-legend": "पुस्तकाचे स्त्रोत सोदात", "booksources-search": "सोद", + "specialloguserlabel": "करपी:", + "speciallogtitlelabel": "मोख (माथाळो वा {{ns:user}}:वापरप्याचें नांव):", "log": "सोत्रां", + "all-logs-page": "सगळीं भौसाचीं सत्रां", + "alllogstext": "{{SITENAME}} हाच्यो सगळ्या उपलब्ध सत्रांची एकठांय दाखोवणी.\nतुज्यान तुजो देखावो अर्नूं येता एक सत्राचो प्रकार विंचून, वापरप्याचें नांव (व्हदल्या आनी धाकट्या अक्षरा मदें फरक पडटा), वा पोरणें जालेलें पान (हांगाय व्ह़डले आनी धाक्टे अक्षरा मदें फरक पडटा).‎", + "logempty": "सत्रान जुळपी नग नांत.‎", "allpages": "सगळीं पाना", "nextpage": "फुडलें पान ($1)", "prevpage": "फाटलें पान ($1)", "allarticles": "सगळीं पानां", "allpagessubmit": "वचात", + "allpages-hide-redirects": "पुनर्देर्शनां लिपय", "categories": "वर्ग", "linksearch-ns": "नांवाची सुवात", "linksearch-ok": "सोद", @@ -582,14 +607,18 @@ "listgrouprights-members": "सदस्यांची वळेरी", "emailuser": "ह्या वापरप्याक इमेल करात.", "emailusername": "वापरप्याचे नांव", + "usermessage-editor": "यंत्रणाचो संदेशकार", "watchlist": "सादुरवळेरी", "mywatchlist": "सादुरवळेरी", "watchlistfor2": "$1 $2 खातीर", "addedwatchtext": "\"[[:$1]]\" आनी हाचे भासाभास पान तुमचें [[Special:Watchlist|सादुरवळेरेक]] जोडलां.", "watch": "नदर दवरात", "unwatch": "पळोवंक नासलें", - "watchlist-details": "लक्ष {{PLURAL:$1|$1वळेरींतलें|$1 वळेंरींतली}} {{PLURAL:$1|$1पान|$1 पानां}} उलोवपाची पानां सोडून", + "watchlist-details": "तुज्या सादूरवळेरिंत {{PLURAL:$1|$1 पान आसा|$1 पानां आसात}} (त्या भायर उलोवपाचीं पानां आसात).", + "wlheader-showupdated": "तुज्या फाटले भेटे सावन बदल्ल्यान तीं पानां <strong>दाट</strong> दाखयल्यांत.", + "wlnote": "सकयल {{PLURAL:$1|हो निमाणो बदल|हें निमाण्यो <strong>$1</strong> बदल}} निमाण्या {{PLURAL:$2|वोरान|<strong>$2</strong>वोरानीं}}, $3, $4 पर्यान.‎", "watchlist-options": "सादुरवळेरींतलो पर्याय", + "enotif_reset": "सगळीं पानां भेट दिलेलीं म्हूण खुणाय", "delete-legend": "काडून उडयात", "actioncomplete": "क्रिया पुराय जाल्या", "actionfailed": "क्रिया अपेस जाल्या", @@ -600,6 +629,8 @@ "changecontentmodel-reason-label": "कारण:", "protectlogpage": "सुरक्षितेचें सोत्र", "protectedarticle": "राखिल्ले\"[[$1]]\"", + "modifiedarticleprotection": "सुरक्षेची पातळी \"[[$1]]\"‎ हाचे खातीर बदल्ल्या", + "protect-default": "सगळ्या वापरप्यांक परवांगी दी", "restriction-edit": "बदल", "restriction-move": "दुसरेकडे व्हरात", "restriction-create": "निर्माण कर", @@ -616,6 +647,7 @@ "mycontris": "योगदान", "anoncontribs": "योगदान", "contribsub2": "{{GENDER:$3|$1}} हाच्यो ($2)", + "nocontribs": "ह्या निशकशांक खयंचेच बदल जूळ्ळेले मेळूंक नांत.", "uctop": "हालीचें", "month": "ह्या म्हयन्या सावन (आनी आदलें):", "year": "ह्या वर्सा सावन (आनी आदलें):", @@ -642,16 +674,19 @@ "whatlinkshere-hideredirs": "$1 पुनर्निर्देशन", "whatlinkshere-hidetrans": "$1 दुरास्थ-समावेस", "whatlinkshere-hidelinks": "$1 दुवे", - "whatlinkshere-hideimages": "$1 फायल दुवे", + "whatlinkshere-hideimages": "$1 फायलींचे दुवे", "whatlinkshere-filters": "गाळणे", "ipboptions": "2 वरां:2 hours,1 दीस:1 day,3 दीस:3 days,1 सुमान:1 week,2 सुमनां:2 weeks,1 म्हयनो:1 month,3 म्हयने:3 months,6 म्हयने:6 months,1 वर्स:1 year,शेवट ना:infinite", "ipblocklist": "आडायल्लें वापरपी", + "infiniteblock": "शेवट ना", "blocklink": "आडावणी", "change-blocklink": "विभाग सुदारप", "contribslink": "योगदान", "blocklogpage": "कार्यवळेरी आडायात", - "blocklogentry": "$2 $3 हो सोंपपी वेळ आशिल्लो $1 बंद दवरल्ला", + "blocklogentry": "[[$1]] आक आडायला, इतल्या वेळाक: $2, कारण: $3", + "reblock-logentry": "आडावपाचें बसोवप बदल्लां [[$1]] हाचे खातीर सोंपोवपाचो वेळ दिला $2 $3‎", "block-log-flags-nocreate": "खातें निर्माण जावूंक ना", + "proxyblocker": "प्रतिनिधी सिरविदोर आडावपी‎", "movepagebtn": "पान हालय", "movelogpage": "पान हालोवण्यांचो सोत्र", "revertmove": "मूळ पदार व्हरप", @@ -660,6 +695,7 @@ "allmessagesdefault": "पूर्वनिर्धारित संदेशाचो मजकूर", "thumbnail-more": "व्हड करात", "thumbnail_error": "$1ः लघुप्रतिमा करतांनाची चूक", + "importlogpage": "आयाताचें सत्र", "tooltip-pt-userpage": "{{GENDER:|तुमचें वापरप्याचें}} पान", "tooltip-pt-mytalk": "{{GENDER:|तुमचें}} भासाभासाचें पान", "tooltip-pt-preferences": "{{GENDER:|तुमची}} पसंती", @@ -703,6 +739,7 @@ "tooltip-ca-nstab-special": "हें एक खेरीत पान, आनी हें बदलूंक जायना", "tooltip-ca-nstab-project": "प्रकल्पाचें पान पळेयात", "tooltip-ca-nstab-image": "फायलीचें पान पळेयात", + "tooltip-ca-nstab-mediawiki": "यंत्रणाचो संदेश पळय", "tooltip-ca-nstab-template": "सांचो पळेयात", "tooltip-ca-nstab-category": "वर्गांचे पान पळेयात", "tooltip-minoredit": "हो ल्हानसो बदल म्हूण कुरू करात", @@ -715,11 +752,45 @@ "tooltip-undo": "\"आदलें स्थितीर हाडचें\" ह्या बदलाक परत व्हरुन संपादन स्थितीन झलक रितीन दाखयतात.\nहाचेवरवीं सारांशान आदल्या स्थितीर हाडपाचें कारण बरोवं शकता.", "tooltip-summary": "आपरोसाची नोंदणी करात", "simpleantispam-label": "स्पमविरूध तपासणी.\nहें भर <strong>नाका</strong>!", + "pageinfo-title": "\"$1\" ‎खातीर म्हायती", + "pageinfo-header-basic": "मूळ म्हायती", + "pageinfo-header-edits": "बदलाचो इतिहास", + "pageinfo-header-restrictions": "पानाची सुरक्षा", + "pageinfo-header-properties": "पानाचे गुणधर्म", + "pageinfo-display-title": "मांडलेलें माथाळें", + "pageinfo-default-sort": "डिफोल्ट आरीन मांडूंक चावी", + "pageinfo-length": "पानाची लांबाय (बायटांत)‎", + "pageinfo-article-id": "पानाचो आंक", + "pageinfo-language": "पानाच्या मजकुराची भास", + "pageinfo-content-model": "पानाच्या मजकुराचो नमुनो", + "pageinfo-robot-policy": "रोबोटां कडल्यान सुचेंत घालप", + "pageinfo-robot-index": "परवांगी आसा", + "pageinfo-robot-noindex": "परवांगी ना", + "pageinfo-watchers": "पानाचेर दिश्ट दवरतेल्यांचो आंकडो", + "pageinfo-few-watchers": "$1 परस थोडें {{PLURAL:$1|दिश्ट दवरपी}}‎", + "pageinfo-redirects-name": "ह्या पाना खातीर पुनर्निर्देशनांचो आंकडो", + "pageinfo-subpages-name": "ह्या पानाच्या ऊप-पानाचो आंकडो", + "pageinfo-subpages-value": "$1 ($2 {{PLURAL:$2|पुनर्निर्देशन|पुनर्निर्देशनां}}; $3 {{PLURAL:$3|पुनर्निर्देशन नासलेलें}})‎", + "pageinfo-firstuser": "पान रचपी", + "pageinfo-firsttime": "पान रचपाची तारीख", + "pageinfo-lastuser": "हालींचो संपादक", + "pageinfo-lasttime": "हालींच्या बदलाची तारीख", + "pageinfo-edits": "एकूण बदलाचो आंकडो", + "pageinfo-authors": "वेगळे बरोवप्यांचो एकूण आंकडो", + "pageinfo-recent-edits": "हालींच्या बदलांचे आंकडे (गेले $1)‎", + "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": "हय", + "patrol-log-page": "पारो करप्याचे सत्र", "previousdiff": "← आदलें संपादन", "nextdiff": "नवें संपादन →", + "widthheightpage": "$1 × $2, $3 {{PLURAL:$3|पान|पानां}}", "file-info-size": "$1 × $2 चित्रतत्व, फायलीचो आकार: $3, माइम प्रकार: $4", + "file-info-size-pages": "$1 × $2 चित्रत्वां, फायलिचो आकार: $3, MIME प्रकार: $4, $5 {{PLURAL:$5|पान|पानां}}‎", "file-nohires": "हाच्या परस वयले बारिक्साय उपल्बद ना", "svg-long-desc": "SVG फायल, नांवाक $1 × $2 चित्रतत्वां, फायलीचो आकार: $3", "show-big-image": "मुळावी फायल", @@ -734,22 +805,44 @@ "monthsall": "सगळे", "confirm-rollback-button": "बरें", "confirm-rollback-top": "ह्या पाना वयलें संपादन आशिल्ले तशें करात?", + "imgmultipagenext": "फुडलें पान →", + "imgmultigo": "वचात!", + "imgmultigoto": "$1 ‎पानार वचात", + "watchlisttools-clear": "सादूरवळेरी निवळ कर", "watchlisttools-view": "प्रस्तूत बदल पळयात.", "watchlisttools-edit": "सादुरवळेरी पळय आनी संपादीत करात", + "watchlisttools-raw": "सादूरवळेरिची मूळान बदल कर", "signature": "[[{{ns:user}}:$1|$2]] ([[{{ns:user_talk}}:$1|उलयात]])", + "redirect": "फायल, वापरपी, पान, उजळणी वा सत्र आंक‎ वर्वीं पुनर्देशन कर", + "redirect-summary": "हें विशेश पान पुनर्देशीत करता एका फायलीक (फायलीचें नांव दिल्यार), एका पानाक (उजळणेचो आंक वा पानाचो आंक दिल्यार), एक वापरप्याच्या पानाक (एके वापरप्याचो आंक दिल्यार), वा एक सत्र नोंद (सत्राचो आंक दिल्यार). वापर: [[{{#Special:Redirect}}/file/देखीक.jpg]], [[{{#Special:Redirect}}/page/64308]], [[{{#Special:Redirect}}/revision/328429]], [[{{#Special:Redirect}}/user/101]], vo [[{{#Special:Redirect}}/logid/186]].", "redirect-submit": "वचात", + "redirect-lookup": "सुचींत पळय:", "redirect-value": "मोल:", + "redirect-user": "वापरप्यांचो आंक", + "redirect-page": "पानाचो आंक", + "redirect-revision": "पानाची उजळणी", + "redirect-file": "फायलीचें नांव", "specialpages": "विशेश पानां", "tag-filter": "[[Special:Tags|कुर्वेचीट]] गाळणो:", "tag-list-wrapper": "[[Special:Tags|{{PLURAL:$1|कुरवेचीट|कुरवेचीटी}}]]: $2", "tags-active-yes": "हय", "tags-active-no": "ना", + "tags-hitcount": "$1 {{PLURAL:$1|बदल}}", "htmlform-title-not-exists": "$1 अस्तित्वांत ना.", "logentry-delete-delete": "$1 {{GENDER:$2|काडून उडयल्ले पान}} $3", + "logentry-delete-restore": "$1 हाणें {{GENDER:$2|परत हाडलां}} पान $3 ($4)‎", + "logentry-delete-revision": "$1 हाणें {{PLURAL:$5|उजळणेचें}} दिसणे $3, ह्या पानार {{GENDER:$2|बदल्ला}}: $4‎", + "revdelete-content-hid": "मजकूर लिपयला", "logentry-move-move": "$1 हाणें $3 पानाक $4 {{GENDER:$2|हालयला}}", + "logentry-move-move-noredirect": "$1, हाणें पान $3 सावन $4 {{GENDER:$2|हालयलां}} पुनर्देर्शन दवरिनासतानां", + "logentry-move-move_redir": "$1 हाणें पान $3 सावन $4 {{GENDER:$2||हालयल्लो}} पुनर्दिशनावयर", + "logentry-patrol-patrol-auto": "$1-आन $3, ह्या पानाचें $4, ह्या उजळणेचो पारो केलां म्हण आपोआप {{GENDER:$2|खुणायलां}}", "logentry-newusers-create": "उपयोगकत्याचें $1 {{GENDER:$2|तयार केलें}}", + "logentry-newusers-autocreate": "वापरप्याचें खातें $1 आपोआप {{GENDER:$2|रचून}} आयलें", "logentry-upload-upload": "$1 {{GENDER:$2|अपलोड केला}} $3", + "logentry-upload-overwrite": "$1, हाणें $3‎, हाची एक नवी आवृत्ती {{GENDER:$2|अपलोड केलां}}", "searchsuggest-search": "{{SITENAME}} सोद", + "duration-days": "$1 {{PLURAL:$1|दीस}}", "special-characters-group-latin": "रोमी", "special-characters-group-latinextended": "रोमी (आनिंक-उइ)", "special-characters-group-ipa": "IPA", @@ -771,5 +864,6 @@ "special-characters-group-khmer": "ख्मेर", "mw-widgets-dateinput-no-date": "तारीख निवडूंक ना", "mw-widgets-dateinput-placeholder-day": "वर्स-म्हयनो-दीस", - "mw-widgets-dateinput-placeholder-month": "वर्स-म्हयनो" + "mw-widgets-dateinput-placeholder-month": "वर्स-म्हयनो", + "randomrootpage": "खयंचेंय मूळ पान" } diff --git a/languages/i18n/gom-latn.json b/languages/i18n/gom-latn.json index 9f1f7067f4..e339a77a22 100644 --- a/languages/i18n/gom-latn.json +++ b/languages/i18n/gom-latn.json @@ -343,22 +343,6 @@ "resettokens-no-tokens": "Punorsthapit korpa khatir koslench chavi na.", "resettokens-tokens": "Chavio:", "resettokens-token-label": "$1 (sodhyache valor: $2)", - "bold_sample": "Datt mozkur", - "bold_tip": "Datt mozkur", - "italic_sample": "Palso mozkur", - "italic_tip": "Palso mozkur", - "link_sample": "Duvyeche nanv", - "link_tip": "Bhitorlo duvo", - "extlink_sample": "http://www.udaronn.in duvyachem nanv", - "extlink_tip": "Bhailo duvo (survatek http:// visronakai)", - "headline_sample": "Mathalleacho mozkur", - "headline_tip": "Dusrea patllicho mathallo", - "nowiki_sample": "Sworup diunk naslelem mozkur hanga ghal", - "nowiki_tip": "Wiki sworup durlokx kor", - "image_tip": "Bosoileli fayl", - "media_tip": "Failicho duvo", - "sig_tip": "Tuji soi, vell-chaap soit", - "hr_tip": "Adhvem rang (unnem vapor)", "summary": "Sar:", "subject": "Vishoy:", "minoredit": "Hem ek dhaktem bodol", @@ -375,18 +359,18 @@ "anoneditwarning": "<strong>Chotrai:</strong> Tuven sotrorombh korunk nai. Tu bodol korit zalear tuzo IP pot'to soglleank polleunk zatelem. Tu <strong>[$1 sotrorombh korit]</strong> vo <strong>[$2 kont rochit]</strong> zalear, tuje bodol tuzo vaporpeachem nanvak zoddteleo ani anik-ui faide asat.", "missingcommenttext": "Upkar korun tuzo xero boroi.", "blockedtitle": "Vapurpeak addaila", - "blockedtext": "<strong>Tujem vaporpeachem nanv vo IP pot'to addavpant aila.</strong>\n\nAddavop $1 hannem kelam.\nKaronn dilam tem <em>$2</em>.\n\n* Addavpachi survat: $8\n* Addavop sompovpacho vell: $6\n* Addavpak ievjila: $7\n\nTujean $1-ak vo dusrea [[{{MediaWiki:Grouppage-sysop}}|karbhariak]] addavnne bodol bhasabhas korunk sompork korunk zata. Tujean \"{{int:emailuser}}\" sobhavgunn vaprunk zaina kheriz ek void email pot'to tujea [[Special:Preferences|khatem posontint]] nischit kelea xivai ani tuka tem vaporpak addavnk na zalear. Tuzo chalont IP pot'to asa $3, ani addavnnecheo ank #$5 asa. Soglleo voileo bariksanno tum kortai tea vicharant somavex kor.", + "blockedtext": "<strong>Tujem vaporpeachem nanv vo IP pot'to addavpant aila.</strong>\n\nAddavop $1 hannem kelam.\nKaronn dilam tem <em>$2</em>.\n\n* Addavpachi survat: $8\n* Addavop sompovpacho vell: $6\n* Addavpak ievjila: $7\n\nTujean $1-ak vo dusrea [[{{MediaWiki:Grouppage-sysop}}|karbhariak]] addavnne vixim bhasabhas korunk sompork korunk zata. Tujean \"{{int:emailuser}}\" sobhavgunn vaprunk zaina kheriz ek void email pot'to tujea [[Special:Preferences|khatem posontint]] nischit kelea xivai ani tuka tem vaporpak addavnk na zalear. Tuzo chalont IP pot'to asa $3, ani addavnnecheo ank #$5 asa. Soglleo voileo bariksanno tum kortai tea vicharant somavex kor.", "blockednoreason": "Kainch karonn diunk na", "loginreqtitle": "Sotrorombh gorjechem", "loginreqlink": "sotrorombh kor", "accmailtitle": "Gupitutor dhaddlea", "newarticle": "(Novem)", "newarticletext": "Tuven ek duveche patlav kelai, zachem pan azun rochunk na.\nPan rochunk, khallchea chovkottan boroi (anik mahitik [$1 adar pan] polloi).\nTu hangasor chukin pavlai zalear tujea internet browser-achi <strong>Fatim</strong> vo <strong>Back</strong> butao dab.", - "anontalkpagetext": "----\n<em>Hem bhasabhasechem pan ek ninami vaporpeak zannem ozun ek khatem ugddunk na, vo to tem vaporna.</em>\nHea khatir amkam ankddeancho IP pot'to vaprunk podta taka vollkhunk.\nToslo IP pot'to sabar vaporpeamni vaprum ieta.\nTum zor ek ninami vaporpi asa ani tuka dista ki sombondit xere tuje vixim keleat, upkar korun [[Special:CreateAccount|ek khatem roch]] vo [[Special:UserLogin|log in]] fuddle guspop ninami vaporpeanchem tallunk.‎", + "anontalkpagetext": "----\n<em>Hem bhasabhasechem pan ek ninami vaporpeak zannem ozun ek khatem ugddunk na, vo to tem vaporna.</em>\nHea khatir amkam ankddeancho IP pot'to vaprunk podta taka vollkhunk.\nToslo IP pot'to sabar vaporpeamni vaprum ieta.\nTum zor ek ninami vaporpi asa ani tuka dista ki tukam sombond naslele xere tuje vixim keleat, upkar korun [[Special:CreateAccount|ek khatem roch]] vo [[Special:UserLogin|sotrarombh kor]] fuddle guspop ninami vaporpeanchem tallunk.‎", "noarticletext": "Sodheak hem pan ritem asa.\nTujean dusrea panani [[Special:Search/{{PAGENAME}}|hea panache nanv sodunk zata]], <span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} sombondhi sotrani sodunk zata], vo [{{fullurl:{{FULLPAGENAME}}|action=edit}} hem pan rochunk zata]</span>.", "noarticletext-nopermission": "Sodheak hem pan ritem asa.\nTujean dusrea panani [[Special:Search/{{PAGENAME}}|hea panache nanv sodunk zata]], vo <span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} sombondhi sotrani sodunk zata], pun tuka hem pan rochunk porvangi na.", "userpage-userdoesnotexist-view": "\"$1\" hea vapurpeachea khateachi nondnni korunk na.", - "clearyourcache": "<strong>Note:</strong> Samball’llea uprant, tuka ghoddiek tujea browseracho cache koddsoravnk poddot bodol pollonvche khatir.\n* <strong>Firefox / Safari:</strong> <em>Shift</em> dhor <em>Reload</em> klik kortana, vo dam <em>Ctrl-F5</em> vo <em>Ctrl-R</em> (<em>⌘-R</em> Mac-acher)\n* <strong>Google Chrome:</strong> <em>Ctrl-Shift-R</em> dam (<em>⌘-Shift-R</em> eka Mac-acher)\n* <strong>Internet Explorer:</strong> <em>Ctrl</em> dhor <em>Refresh</em> klik kortana, vo dam <em>Ctrl-F5</em>\n* <strong>Opera:</strong> Hanga voch: <em>Menu → Settings</em> (<em>Opera → Preferences</em> Mac-acher) ani uprant <em>Privacy & security → Clear browsing data → Cached images and files</em>.‎", + "clearyourcache": "<strong>Chotrai:</strong> Samball’llea uprant, tuka ghoddiek tujea browseracho cache koddsoravnk poddot bodol pollonvche khatir.\n* <strong>Firefox / Safari:</strong> <em>Shift</em> dhor <em>Reload</em> klik kortana, vo dam <em>Ctrl-F5</em> vo <em>Ctrl-R</em> (<em>⌘-R</em> Mac-acher)\n* <strong>Google Chrome:</strong> <em>Ctrl-Shift-R</em> dam (<em>⌘-Shift-R</em> eka Mac-acher)\n* <strong>Internet Explorer:</strong> <em>Ctrl</em> dhor <em>Refresh</em> klik kortana, vo dam <em>Ctrl-F5</em>\n* <strong>Opera:</strong> Hanga voch: <em>Menu → Settings</em> (<em>Opera → Preferences</em> Mac-acher) ani uprant <em>Privacy & security → Clear browsing data → Cached images and files</em>.‎", "previewnote": "<strong>Hem fokot ek zholok mhonn ugddas dhor.</strong>\nTuje bodol azun sambhallun dovrunk nant!", "continue-editing": "Sompadon korpachea zagear voch", "editing": "Sompadon kortai: $1", @@ -448,7 +432,7 @@ "editundo": "kel'lem portavchem", "diff-empty": "(Kaim forok na)‎", "diff-multi-sameuser": "(Heach vaporpean {{PLURAL:$1|kel'lo modlo ek bodol dakhounk na|kel'le modle $1 bodol dakhounk nan}})", - "diff-multi-otherusers": "({{PLURAL:$1|Ek modli uzollnni|$1 modleo uzollnneo}} {{PLURAL:$2|ek her vaporpi|$2 her vaporpi}}, hache vorvim dakhovnk na)‎", + "diff-multi-otherusers": "({{PLURAL:$2|Ek her vaporpea|$2 her vaporpeam}} vorvim {{PLURAL:$1|ek modli uzollnni|$1 modleo uzollnneo}} dakhovnk na)", "searchresults": "Sodache porinaman", "searchresults-title": "\"$1\" -khatir sodache porinaman", "prevn": "adlem {{PLURAL:$1|$1}}", @@ -520,6 +504,7 @@ "recentchanges-legend-newpage": "{{int:recentchanges-label-newpage}} ([[Special:NewPages|nove pananchi suchi]]-ui polloi)", "rcfilters-tag-remove": "'$1' kadd", "rcfilters-legend-heading": "<strong>Sonkxepachi volleri:</strong>", + "rcfilters-group-results-by-page": "Pana pormonnem pongddache porinnam", "rcfilters-activefilters": "Kriaxil challnneo", "rcfilters-activefilters-hide": "Lipoi", "rcfilters-activefilters-show": "Dakhoi", @@ -541,7 +526,9 @@ "rcfilters-savedqueries-unsetdefault": "Default aslolem kaddun uddoi", "rcfilters-savedqueries-remove": "Kadun udoi", "rcfilters-savedqueries-new-name-label": "Nanv", + "rcfilters-savedqueries-new-name-placeholder": "Challnnecho hetu vornnon kor", "rcfilters-savedqueries-apply-label": "Challnni roch", + "rcfilters-savedqueries-apply-and-setdefault-label": "Default challnni roch", "rcfilters-savedqueries-cancel-label": "Rod'd kor", "rcfilters-savedqueries-add-new-title": "Chalont challnnechi manddavoll samball", "rcfilters-savedqueries-already-saved": "Heo challnneo adinch samball’lloleo asat. Ek novi Samball’lloli Challnni rochunk, tujeo manddavolleo bodol.", @@ -555,15 +542,22 @@ "rcfilters-filterlist-feedbacklink": "Hea challnnechea avtam vixim tuka kitem dista tem amkam sang", "rcfilters-highlightmenu-title": "Ek rong vinch", "rcfilters-filterlist-noresults": "Kosleoch challnneo mellunk nant", + "rcfilters-state-message-fullcoverage": "Hea pongddantle soglleo challnneo vinchop mhonnche kainch vinchop na, hea khatir he challnnek kainch porinnam na. Pongddant hacho somavex asa: $1", "rcfilters-filtergroup-authorship": "Iogdanachem borovp", "rcfilters-filter-editsbyself-label": "Tuven kel'leo bodol", "rcfilters-filter-editsbyself-description": "Tujeo svotacheo yogdanam.", "rcfilters-filter-editsbyother-label": "Dusreanim kel'le bodol", "rcfilters-filter-editsbyother-description": "Tuje khas bhairavn, soglle bodol", "rcfilters-filtergroup-user-experience-level": "Vaporpeachi nondnni ani onnbhov", + "rcfilters-filter-user-experience-level-registered-label": "Nondnni kelolem", "rcfilters-filter-user-experience-level-registered-description": "Sotrarombh zalole sompadok.", + "rcfilters-filter-user-experience-level-unregistered-label": "Nondnni korunk naslolem", + "rcfilters-filter-user-experience-level-unregistered-description": "Sompadok je sotrarombhit nant.", + "rcfilters-filter-user-experience-level-newcomer-description": "Nondnni aslole sompadok zanche 10 poros unnem sompadon vo 4 disanchem kario asa.", "rcfilters-filter-user-experience-level-learner-label": "Xikpi", + "rcfilters-filter-user-experience-level-learner-description": "Nondnni kelole sompadok zancho onnubhov \"Nove ievpi\" ani \"Onnbhovi vaporpi\" modem urta.", "rcfilters-filter-user-experience-level-experienced-label": "Onnbhovi vaporpi", + "rcfilters-filter-user-experience-level-experienced-description": "500 odik sompadon ani 30 disanchem kario aslolem nondnni kelolem sompadok.", "rcfilters-filtergroup-automated": "Apoap zalolem iogdan", "rcfilters-filter-bots-label": "Robot", "rcfilters-filter-bots-description": "Apoap avtamni kelolem sompadon", @@ -571,6 +565,9 @@ "rcfilters-filter-humans-description": "Monxani kelolem sompadon", "rcfilters-filter-reviewstatus-unpatrolled-description": "Paro kela mhonn hatan vo apoap khunnavnk naslolem sompadon.", "rcfilters-filter-reviewstatus-unpatrolled-label": "Paro korunk naslolem", + "rcfilters-filter-reviewstatus-manual-description": "Sompadon zaka paro kelam mhonn hatan khunnailam.", + "rcfilters-filter-reviewstatus-manual-label": "Hatan paro korpant ailolem", + "rcfilters-filter-reviewstatus-auto-label": "Apoap paro korpant ailolem", "rcfilters-filtergroup-significance": "Mhotv", "rcfilters-filter-minor-label": "Dhakte bodol", "rcfilters-filter-minor-description": "Borovpean dhaktem mhonn khunne chitt kelolem sompadon", @@ -578,9 +575,10 @@ "rcfilters-filter-major-description": "Dhaktem mhonn khunne chitt korunk naslolem sompadon", "rcfilters-filtergroup-watchlist": "Sadurvollerintlim panam", "rcfilters-filter-watchlist-watched-label": "Sadurvollerintlim", + "rcfilters-filter-watchlist-watched-description": "Tujea Sadurvollerichea panamche bodol.", "rcfilters-filter-watchlist-watchednew-label": "Sadurvolleriche nove bodol", "rcfilters-filter-watchlist-watchednew-description": "Bodol ghoddleat ten’na savn tuvem bhett divnk nant tea sadurvollerintlim panache bodol.", - "rcfilters-filter-watchlist-notwatched-label": "Sadurvollerintlim nhoi", + "rcfilters-filter-watchlist-notwatched-label": "Sadurvollerint na", "rcfilters-filter-watchlist-notwatched-description": "Sadurvollerichim panank bodol soddun her sogllem.", "rcfilters-filtergroup-watchlistactivity": "Sadurvollerichem kario", "rcfilters-filter-watchlistactivity-unseen-label": "Pollovnk naslole bodol", @@ -604,9 +602,13 @@ "rcfilters-view-tags": "Khunnechittichem sompadon", "rcfilters-view-tags-tooltip": "Sompadonacheo khunne chitti vaprun porinnam chall", "rcfilters-view-tags-help-icon-tooltip": "Khunnechittichem sompadona babtint odik xikun ghe", + "rcfilters-liveupdates-button-title-off": "Nove bodol ghoddtta ten’na dakhol kor", "rcfilters-watchlist-markseen-button": "Soglle bodol polleleat mhonn khunnai.", + "rcfilters-watchlist-edit-watchlist-button": "Nodor dovorlolea panachi volleri sompadon kor", "rcfilters-watchlist-showupdated": "Bodol zal'leak savn je panank tuvem bhett dinvk na, te bodol <strong>datt</strong> okxoramni, ani ghott khunnamni dileat.", + "rcfilters-filter-showlinkedfrom-option-label": "Vinchlolea panant <strong>savn zulltat tim panam</strong>", "rcfilters-filter-showlinkedto-label": "Panak zoddtat tea panache bodol dakhoi", + "rcfilters-filter-showlinkedto-option-label": "Vinchlolea panak <strong>zulltat tim pana</strong>", "rcfilters-target-page-placeholder": "Ek panache nanv ( vo vorg) ghal", "rcnotefrom": "Sokoil <strong>$3, $4<strong> savn {{PLURAL:$5|zalelem bodol dilam|zalelem bodol dileant}} (<strong>$1<strong> meren {{PLURAL:$5|dakhoilam|dakhoileant}}).", "rclistfrom": "$3 $2 savn suru zatelim nove bodol dakhoi", @@ -678,7 +680,7 @@ "filehist-comment": "Xero", "imagelinks": "Faylicho vapor", "linkstoimage": "{{PLURAL:$1|Hem pan|$1 Him panam}} hi fayl {{PLURAL:$1|vaporta|vaportat}}:", - "linkstoimage-more": "$1 poros odik {{PLURAL:$1|pan vaporta|panam vaporta}} hi fayl.\nSokoili volleri dakhoita {{PLURAL:$1|poilem pan|poilim $1 panam}} jem hich fayl vaporta. Ek [[Special:WhatLinksHere/$2|purnn volleri]] uplobdh asa.‎", + "linkstoimage-more": "$1 poros odik {{PLURAL:$1|pan vaporta|panam vaportat}} hi fayl.\nSokoili volleri dakhoita {{PLURAL:$1|poilem pan|poilim $1 panam}} jem hich fayl vaporta. Ek [[Special:WhatLinksHere/$2|purnn volleri]] uplobdh asa.‎", "nolinkstoimage": "Hea faylik vaportat toslim panam nant", "linkstoimage-redirect": "$1 (fayl punornirdexon) $2", "sharedupload-desc-here": "Hi fayl $1, hachi ani dusrea prokolpanim hachem upeog korunk zata.\nHachem [$2 faylichem vivron panan] asleli vivron khala dilea:", @@ -812,7 +814,7 @@ "change-blocklink": "Addavnnni bodol", "contribslink": "yogdan", "blocklogpage": "addavnnechem sotr", - "blocklogentry": "[[$1]] addailelem $2 asun vellacho ont: $3", + "blocklogentry": "[[$1]] ak addaila, itlea vellak: $2, karonn: $3", "reblock-logentry": "addavpachem bosovp bodol’lam [[$1]] hache khatir sompovpacho vell dila $2 $3‎", "block-log-flags-nocreate": "Khatem rochop opatr kelam", "proxyblocker": "Protinidhi-sirvidor addavpi‎", @@ -823,6 +825,8 @@ "movepage-moved": "<strong>\"$1\" haka \"$2\" hanga haloila</strong>", "movepage-moved-redirect": "Punornirdexon rochun ailam.", "movepage-moved-noredirect": "Punornirdexon rochop addaila.", + "movepage-delete-first": "Mokhichea panak chodd uzollnneo asat ek pan halovtana kadun udovche khatir. Poilim hostukim pan kadun udoi, ani uprant porot proiotn kor.", + "movepage-page-exists": "Pan $1 adinch ostitvant asa ani apoap tache voir borounk zaina.", "movepage-page-moved": "$1 panak $2 hanga haloila.", "movepage-page-unmoved": "$1 haka $2 hanga halounk zaunk na.", "movelogpage": "Pan halovneancho sotr", diff --git a/languages/i18n/gor.json b/languages/i18n/gor.json index 58fddbe835..2b95547fca 100644 --- a/languages/i18n/gor.json +++ b/languages/i18n/gor.json @@ -463,22 +463,6 @@ "botpasswords-label-cancel": "Bataliya", "botpasswords-label-delete": "Luluta", "passwordreset": "Boli'a tahe u'unti", - "bold_sample": "Teks botiye ma cetakiyolo mohulodu", - "bold_tip": "Teks mohulodu", - "italic_sample": "Teks botiye ma cetakiyolo yinti-yintili", - "italic_tip": "Teks yinti-yintili", - "link_sample": "Judul wumbuta", - "link_tip": "Wumbuta to delomiyo", - "extlink_sample": "http://www.example.com judul wumbuta", - "extlink_tip": "Wumbuta to diluwari (eelayi awalan http://)", - "headline_sample": "Judul teks", - "headline_tip": "Lenggota 2 Judul", - "nowiki_sample": "Tuwota teks u ja format teeye", - "nowiki_tip": "Pelehiya moformat wiki", - "image_tip": "Dembinga berkas", - "media_tip": "Wumbuta lo berkas", - "sig_tip": "Pali lo ulu'umu wawu tuwoto wakutu", - "hr_tip": "Garisi bula-bulawahu", "summary": "Limbu'o", "minoredit": "Utiye biloli'o ngo'idi", "watchthis": "Dahayi halaman botiye", diff --git a/languages/i18n/got.json b/languages/i18n/got.json index 70648d7048..f968ec3471 100644 --- a/languages/i18n/got.json +++ b/languages/i18n/got.json @@ -358,22 +358,6 @@ "resetpass-submit-cancel": "𐍃𐍅𐌴𐌹𐌱", "passwordreset": "𐌰𐍆𐍄𐍂𐌰 𐍃𐌰𐍄𐌴𐌹 𐌲𐌰𐌼𐍉𐍄𐌰𐍅𐌰𐌿𐍂𐌳", "passwordreset-username": "𐌰𐍄𐌲𐌰𐌲𐌲𐌰𐌽𐌰𐌼𐍉:", - "bold_sample": "𐍃𐍅𐌹𐌽𐌸𐍉𐍃 𐌱𐍉𐌺𐍉𐍃", - "bold_tip": "𐍃𐍅𐌹𐌽𐌸𐍉𐍃 𐌱𐍉𐌺𐍉𐍃", - "italic_sample": "𐍅𐍂𐌰𐌹𐌵𐍉𐍃 𐌱𐍉𐌺𐍉𐍃", - "italic_tip": "𐍅𐍂𐌰𐌹𐌵𐍉𐍃 𐌱𐍉𐌺𐍉𐍃", - "link_sample": "𐌲𐌰𐍅𐌹𐍃𐍃𐌹-𐌿𐍆𐌰𐍂𐌼𐌴𐌻𐌹", - "link_tip": "𐌹𐌽𐌽𐌰𐌽𐌰 𐌲𐌰𐍅𐌹𐍃𐍃", - "extlink_sample": "http://www.example.com 𐌲𐌰𐍅𐌹𐍃𐍃𐌹-𐌿𐍆𐌰𐍂𐌼𐌴𐌻𐌹", - "extlink_tip": "𐌿𐍄𐌰𐌲𐌰𐍅𐌹𐍃𐍃 (𐌲𐌰𐌼𐌹𐌽𐌸𐌴𐌹 http:// 𐍆𐌰𐌿𐍂𐌰𐌻𐌰𐌲𐌴𐌹𐌽𐍃)", - "headline_sample": "𐌿𐍆𐌰𐍂𐍃𐍄𐍂𐌹𐌺𐌰𐌱𐍉𐌺𐍉𐍃", - "headline_tip": "𐌷𐌰𐌿𐌷𐌹𐌸𐌰 •𐌱• 𐌿𐍆𐌰𐍂𐍃𐍄𐍂𐌹𐌺𐍃", - "nowiki_sample": "𐍃𐌰𐍄𐌴𐌹 𐌱𐍉𐌺𐍉𐍃 𐌹𐌽𐌿𐌷 𐌲𐌰𐍂𐍅𐌹 𐌷𐌴𐍂", - "nowiki_tip": "𐌽𐌹 𐌱𐍂𐌿𐌺𐌴𐌹 𐍅𐌹𐌺𐌹-𐍆𐌰𐌿𐍂𐌼𐌰𐍄𐌴𐌹𐌽𐌰𐌹𐍃", - "image_tip": "𐌹𐌽𐌻𐌰𐌲𐌹𐌸 𐍆𐌰𐌾𐌻", - "media_tip": "𐌲𐌰𐍅𐌹𐍃𐍃 𐌳𐌿 𐍆𐌰𐌾𐌻𐌰", - "sig_tip": "𐌸𐌴𐌹𐌽𐌰 𐌿𐍆𐌼𐌴𐌻𐌴𐌹𐌽𐍃 𐌼𐌹𐌸 𐌲𐌻𐌰𐌲𐌲𐍅𐌰𐌼𐌼𐌰 𐌼𐌴𐌻𐌰", - "hr_tip": "𐍂𐌰𐌹𐌷𐍄𐍃 𐍃𐍄𐍂𐌹𐌺𐍃 (𐌽𐌹 𐌱𐍂𐌿𐌺𐌴𐌹 𐌿𐍆𐌰𐍂𐍆𐌹𐌻𐌿)", "summary": "𐌼𐌰𐌿𐍂𐌲𐌿𐍃 𐍃𐌺𐌴𐌹𐍂𐌴𐌹𐌽𐍃:", "subject": "𐌿𐍆𐍅𐌰𐌿𐍂𐍀𐌰:", "minoredit": "𐌸𐌰𐍄𐌰 𐌹𐍃𐍄 𐌼𐌹𐌽𐌽𐌹𐌶𐌴𐌹 𐌹𐌽𐌼𐌰𐌹𐌳𐌴𐌹𐌽𐍃", diff --git a/languages/i18n/grc.json b/languages/i18n/grc.json index 83be9d1faf..32c6414efd 100644 --- a/languages/i18n/grc.json +++ b/languages/i18n/grc.json @@ -408,22 +408,6 @@ "passwordreset-username": "Ὄνομα χρωμένου:", "changeemail-none": "(οὐδέν)", "changeemail-submit": "Ἀλλάττειν ἠλ.-ταχυδρομεῖον", - "bold_sample": "Γράμματα παχέα", - "bold_tip": "Γράμματα παχέα", - "italic_sample": "Γράμματα πλάγια", - "italic_tip": "Γράμματα πλάγια", - "link_sample": "Συνδέσμου ὄνομα", - "link_tip": "Σύνδεσμος οἰκεῖος", - "extlink_sample": "http://www.example.com ὄνομα συνδέσμου", - "extlink_tip": "Ἐξώτερος σύνδεσμος (μέμνησο τοῦ προθέματος http://)", - "headline_sample": "Κείμενον ἐπικεφαλίδος", - "headline_tip": "Κλίμακος 2 ἐπικεφαλίς", - "nowiki_sample": "Εἰσάγειν ἀμόρφωτον κείμενον ὧδε", - "nowiki_tip": "Ἀγνοεῖν βικι-μορφοποιίαν", - "image_tip": "Ἐμβεβαπτισμένον ἀρχεῖον", - "media_tip": "Τὸ προσάγον πρὸς τὸ φορτίον", - "sig_tip": "Ὑπογραφή σου μετὰ χρονοσφραγίδος", - "hr_tip": "Ὁριζόντιος γραμμή (χρηστέα φειδωλώς)", "summary": "Σύνοψις:", "subject": "Χρῆμα:", "minoredit": "Μικρὰ ἥδε ἡ μεταβολή", diff --git a/languages/i18n/gsw.json b/languages/i18n/gsw.json index 935210073a..3a735a3893 100644 --- a/languages/i18n/gsw.json +++ b/languages/i18n/gsw.json @@ -561,24 +561,6 @@ "resettokens-watchlist-token": "Token fir dr Webfeed (Atom/RSS) vu dr [[Special:Watchlist|Änderigen an Syten uf Dyre Beobachtigslischt]]", "resettokens-done": "Token zruckgsetzt.", "resettokens-resetbutton": "Uusgwehlti Token zrucksetze", - "bold_sample": "fetti Schrift", - "bold_tip": "Fetti Schrift", - "italic_sample": "kursiv gschribe", - "italic_tip": "Kursiv gschribe", - "link_sample": "Stichwort", - "link_tip": "Interne Link", - "extlink_sample": "http://www.example.com Linktekscht", - "extlink_tip": "Externer Link (http:// beachte)", - "headline_sample": "Abschnitts-Überschrift", - "headline_tip": "Überschrift Äbeni 2", - "nowiki_sample": "Doo nit-formatierte Text yygee", - "nowiki_tip": "Wiki-Formatierige ignoriere", - "image_sample": "Byschpil.jpg", - "image_tip": "Bildverwys", - "media_sample": "Byschpil.ogg", - "media_tip": "Dateie-Link", - "sig_tip": "Dyni Signatur mit Zytagab", - "hr_tip": "Horizontali Linie (sparsam verwende)", "summary": "Zämmefassig:", "subject": "Beträff:", "minoredit": "Numen es birebitzeli gänderet", diff --git a/languages/i18n/gu.json b/languages/i18n/gu.json index a06f3156e2..0b3f837598 100644 --- a/languages/i18n/gu.json +++ b/languages/i18n/gu.json @@ -541,24 +541,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|તમારી ધ્યાનસૂચિના પાનામાં ફેરફાર ]]ની વેબ ફીડ (Atom/RSS) નિશાની", "resettokens-done": "નિશાનીઓ ફરી ગોઠવવામાં આવી.", "resettokens-resetbutton": "પસંદ કરેલ નિશાનીઓ ફરી ગોઠવો", - "bold_sample": "ઘાટા અક્ષર", - "bold_tip": "ઘાટું લખાણ", - "italic_sample": "ત્રાંસા અક્ષર", - "italic_tip": "ઇટાલિક (ત્રાંસુ) લખાણ", - "link_sample": "કડીનું શીર્ષક", - "link_tip": "આંતરિક કડી", - "extlink_sample": "http://www.example.com કડીનું શીર્ષક", - "extlink_tip": "બાહ્ય કડી (શરૂઆતમાં http:// ઉમેરવાનું ભુલશો નહી)", - "headline_sample": "મથાળાનાં મોટા અક્ષર", - "headline_tip": "બીજા ક્રમનું મથાળું", - "nowiki_sample": "ફોર્મેટ કર્યા વગરનું લખાણ અહીં ઉમેરો", - "nowiki_tip": "વિકિ ફોર્મેટીંગને અવગણો", - "image_sample": "Example.jpg", - "image_tip": "અંદર વણાયેલી (Embedded) ફાઇલ", - "media_sample": "Example.ogg", - "media_tip": "ફાઇલની કડી", - "sig_tip": "સમયછાપ સાથે તમારા હસ્તાક્ષર", - "hr_tip": "આડી લીટી (શક્ય તેટલો ઓછો ઉપયોગ કરો)", "summary": "સારાંશ:", "subject": "વિષય:", "minoredit": "આ એક નાનો ફેરફાર છે", diff --git a/languages/i18n/gv.json b/languages/i18n/gv.json index 3cb79ca4da..a1f5c31afd 100644 --- a/languages/i18n/gv.json +++ b/languages/i18n/gv.json @@ -232,6 +232,7 @@ "nstab-template": "Clowan", "nstab-help": "Duillag choonee", "nstab-category": "Ronney", + "mainpage-nstab": "Ard-ghuillag", "nosuchaction": "Cha nel lheid yn obbyr ayn", "nosuchspecialpage": "Cha nel y duillag er lheh shoh ayn", "error": "Marranys", @@ -259,7 +260,10 @@ "virus-scanfailed": "vrish y ronsaght (coad $1)", "virus-unknownscanner": "ronseyder noi-veerys gyn enney", "yourname": "Dt'ennym ymmydeyr:", + "userlogin-yourname": "Ennym ymmydeyr", + "userlogin-yourname-ph": "Screeu ennym ymmydeyr", "yourpassword": "Fockle yn arrey:", + "userlogin-yourpassword": "Fockle yn arrey", "yourpasswordagain": "Aascreeu dt'ockle arrey:", "login": "Log stiagh", "nav-login-createaccount": "Log stiagh / croo coontys", @@ -268,6 +272,7 @@ "notloggedin": "Cha nel ou loggit stiagh", "createaccount": "Croo coontys", "createaccountmail": "Croo fockle arrey shallidagh gyn tort as cur eh da'n post-l reiht ayd", + "createacct-benefit-body2": "{{PLURAL:$1|duillag|duillagyn}}", "loginerror": "Marranys loggal stiagh", "createaccounterror": "Cha nod shin croo coontys: $1", "noname": "Cha honree uss ennym ymmydeyr fondagh.", @@ -303,22 +308,6 @@ "passwordreset-emailelement": "Ennym ymmydeyr: \n$1\n\nFockle arrey shallidagh: \n$2", "passwordreset-emailsentemail": "Ta post-l cur gys cooinaghtyn er ny chur dhyt.", "changeemail-none": "(gyn)", - "bold_sample": "Clou trome", - "bold_tip": "Clou trome", - "italic_sample": "Clou iddaalagh", - "italic_tip": "Clou iddaalagh", - "link_sample": "Ennym y chianglee", - "link_tip": "Kiangley ynveanagh", - "extlink_sample": "http://www.example.com ennym chianglee", - "extlink_tip": "Kiangley mooie (cooiney roie-ockle http://)", - "headline_sample": "Teks y chione-linney", - "headline_tip": "Kione-linney corrym 2", - "nowiki_sample": "Cur stiagh teks gyn cummey ayns shoh", - "nowiki_tip": "Ny chur tastey da cummey wiki", - "image_tip": "Coadan jingit", - "media_tip": "Kiangley yn choadan", - "sig_tip": "Dt'ennym screeuit lesh clouag hraa", - "hr_tip": "Linney cochruinnagh (ymmyd dy spaarailagh)", "summary": "Giare-choontey:", "subject": "Cooish/kione-linney:", "minoredit": "She myn-reaghey eh shoh", @@ -346,6 +335,7 @@ "note": "'''Note:'''", "previewnote": "'''Cooinnee nagh vel agh roie-haishbynys eh shoh;\ncha nel dty chaghlaaghyn sauailt foast!'''", "editing": "Reaghey $1", + "creating": "Croo $1", "editingsection": "Reaghey $1 (rheynn)", "editingcomment": "Reaghey $1 (meer noa)", "yourtext": "Dty heks", @@ -538,6 +528,7 @@ "action-browsearchive": "duillagyn scrysst y ronsaghey", "action-undelete": "yn duillag shoh y yee-scryssey", "nchanges": "$1 {{PLURAL:$1|caghlaa|chaghlaa|chaghlaa|caghlaaghyn}}", + "enhancedrc-history": "skeeal", "recentchanges": "Caghlaaghyn s'noa", "recentchanges-legend": "Reihyssyn da ny caghlaaghyn s'noa", "recentchanges-summary": "Shirr ny caghlaaghyn s'noa da'n wiki er y duillag shoh.", @@ -976,6 +967,8 @@ "specialpages-group-other": "Duillagyn elley er lheh", "specialpages-group-login": "Log stiagh / croo coontys", "specialpages-group-users": "Ymmydeyryn as kiartyn", + "tags-active-yes": "Ta", + "tags-active-no": "Cha nel", "tags-edit": "reaghey", "rightsnone": "(veg)", "searchsuggest-search": "Ronsaghey", diff --git a/languages/i18n/ha.json b/languages/i18n/ha.json index ab9c729927..ca17ca4180 100644 --- a/languages/i18n/ha.json +++ b/languages/i18n/ha.json @@ -269,22 +269,6 @@ "botpasswords-label-delete": "Share", "resetpass-submit-cancel": "Soke", "resetpass-temp-password": "Kalmar sirri na lokaci", - "bold_sample": "Rubutu mai gwaɓi", - "bold_tip": "Rubutu mai gwaɓi", - "italic_sample": "Rubutun tsutsa", - "italic_tip": "Rubutun tsutsa", - "link_sample": "Sunan mahaɗi", - "link_tip": "Mahaɗin ciki", - "extlink_sample": "http://www.example.com sunan mahaɗi", - "extlink_tip": "Mahaɗi mai zuwa waje (a tuna da zagin http://)", - "headline_sample": "Sunan kai", - "headline_tip": "Kan mataki na 2", - "nowiki_sample": "shigar da ɗanyen rubutu a nan", - "nowiki_tip": "Kawar da sufantawar Wiki", - "image_tip": "Ƙumsashen fayil", - "media_tip": "Mahaɗi zuwa fayil", - "sig_tip": "Sa-hannunku da dagin rana", - "hr_tip": "Layin kwance", "summary": "Taƙaici:", "subject": "Jigo/Kai:", "minoredit": "Ƙaramin gyara", diff --git a/languages/i18n/hak.json b/languages/i18n/hak.json index 86a19ed001..881b116d74 100644 --- a/languages/i18n/hak.json +++ b/languages/i18n/hak.json @@ -467,22 +467,6 @@ "changeemail-newemail": "新嘅電郵地址:", "changeemail-none": "(mò)", "changeemail-submit": "Kiên-kói thien-yù thi-chí", - "bold_sample": "Chhû-thí vùn-sá¹³", - "bold_tip": "Chhû-thí vùn-sá¹³", - "italic_sample": "Chhià-thí vùn-sá¹³", - "italic_tip": "Chhià-thí vùn-sá¹³", - "link_sample": "Lièn-chiap phiêu-thì", - "link_tip": "Nui-phu lièn-chiap", - "extlink_sample": "http://www.example.com lièn-chiap phiêu-thì", - "extlink_tip": "Ngoi-phu lièn-chiap (kâ chhièn-tot http://)", - "headline_sample": "Thai phiêu-thì vùn-sá¹³", - "headline_tip": "2-kip phiêu-thì vùn-sá¹³", - "nowiki_sample": "Chhai liá chhap-ngi̍p fî kak-sá¹³t vùn-sá¹³", - "nowiki_tip": "Chhap-ngi̍p fî kak-sá¹³t vùn-sá¹³", - "image_tip": "Chhap-ngi̍p vùn-khien", - "media_tip": "Vùn-khien lièn-chiap", - "sig_tip": "Tai yû sṳ̀-kiên ke chhiâm-miàng", - "hr_tip": "Súi-phìn sien (séu-sîm sṳ́-yung)", "summary": "Chak-yeu:", "subject": "標題:", "minoredit": "Liá-he yit-chak se-mì siû-kói", diff --git a/languages/i18n/haw.json b/languages/i18n/haw.json index 2d6a8218f4..b75d6bb4e9 100644 --- a/languages/i18n/haw.json +++ b/languages/i18n/haw.json @@ -414,22 +414,6 @@ "changeemail-password": "Kāu ʻōlelo hÅ«nā {{SITENAME}}:", "changeemail-submit": "Loli i kāu lekauila", "resettokens-token-label": "$1 (helu okamanawa: $2)", - "bold_sample": "Ho‘okā‘ele", - "bold_tip": "Ho‘okā‘ele", - "italic_sample": "Ho‘ohiō", - "italic_tip": "Ho‘ohiō", - "link_sample": "Inoa loulou", - "link_tip": "Loulou kÅ«loko", - "extlink_sample": "http://www.example.com inoa loulou", - "extlink_tip": "Loulou kÅ«waho (e ho‘omana‘o i ka poÊ»o pāʻālua http://)", - "headline_sample": "Po‘o‘ōlelo", - "headline_tip": "PoÊ»omanaÊ»o kau 2", - "nowiki_sample": "HoÊ»okomo i nā kikokikona huluÊ»ole ma Ê»aneÊ»i", - "nowiki_tip": "NānaÊ»ole i ka hulu wiki", - "image_tip": "Waihona kauloko", - "media_tip": "Loulou waihona", - "sig_tip": "Kau pÅ«lima me ka manawa", - "hr_tip": "Laina ‘ilikai (e hana pākiko)", "summary": "HōʻuluÊ»ulu manaÊ»o:", "subject": "KumumanaÊ»o/poÊ»o laina:", "minoredit": "He hoÊ»ololi iki kēia", diff --git a/languages/i18n/he.json b/languages/i18n/he.json index 6480a93794..714f258037 100644 --- a/languages/i18n/he.json +++ b/languages/i18n/he.json @@ -87,6 +87,7 @@ "tog-useeditwarning": "הצגת אזהרה בעת עזיבת דף עריכה עם שינויים שטרם נשמרו", "tog-prefershttps": "תמיד להשתמש בתקשורת מאובטחת לאחר הכניסה לחשבון", "tog-showrollbackconfirmation": "הצגת הודעת אישור לאחר לחיצה על קישור \"שחזור\"", + "tog-requireemail": "דרישת דואר אלקטרוני כדי לאפס סיסמה", "underline-always": "תמיד", "underline-never": "לעולם לא", "underline-default": "ברירת המחדל של העיצוב או של הדפדפן", @@ -461,7 +462,7 @@ "createaccountmail": "שימוש בסיסמה זמנית אקראית ושליחתה לכתובת הדוא\"ל שצוינה", "createaccountmail-help": "יכול לשמש ליצירת חשבון עבור אדם אחר בלי ללמוד את הסיסמה.", "createacct-realname": "שם אמיתי (לא חובה)", - "createacct-reason": "סיבה", + "createacct-reason": "סיבה (נרשמת ביומן ציבורי)", "createacct-reason-ph": "סיבה ליצירת חשבון נוסף", "createacct-reason-help": "הודעה שמוצגת ביומן רישום המשתמשים", "createacct-submit": "יצירת החשבון שלך", @@ -629,22 +630,6 @@ "resettokens-watchlist-token": "אסימון להזנת הרשת (Atom/RSS) של [[Special:Watchlist|שינויים של דפים ברשימת המעקב]]", "resettokens-done": "האסימונים אופסו.", "resettokens-resetbutton": "איפוס האסימונים שנבחרו", - "bold_sample": "טקסט מודגש", - "bold_tip": "טקסט מודגש", - "italic_sample": "טקסט נטוי", - "italic_tip": "טקסט נטוי", - "link_sample": "קישור", - "link_tip": "קישור פנימי", - "extlink_sample": "http://www.example.com כותרת הקישור לתצוגה", - "extlink_tip": "קישור חיצוני (כולל קידומת <span dir=\"ltr\">http://</span> מלאה)", - "headline_sample": "כותרת", - "headline_tip": "כותרת – דרגה 2", - "nowiki_sample": "טקסט לא מעוצב", - "nowiki_tip": "התעלמות מעיצוב ויקי", - "image_tip": "קובץ מוטבע", - "media_tip": "קישור לקובץ מדיה", - "sig_tip": "חתימה + תאריך ושעה", - "hr_tip": "קו אופקי (רצוי להימנע משימוש בקו)", "summary": "תקציר:", "subject": "נושא:", "minoredit": "זוהי עריכה משנית", @@ -788,9 +773,9 @@ "content-model-css": "CSS", "content-json-empty-object": "אובייקט ריק", "content-json-empty-array": "מערך ריק", - "unsupported-content-model": "<strong>אזהרה:</strong> מודל התוכן $1 אינו נתמך בוויקי הזה.", - "unsupported-content-diff": "השוואות אינן נתמכות במודל התוכן $1.", - "unsupported-content-diff2": "השוואות בין מודל התוכן $1 לבין מודל $2 אינן נתמכות בוויקי הזה.", + "unsupported-content-model": "<strong>אזהרה:</strong> מודל התוכן $1 אינו נתמך באתר הוויקי הזה.", + "unsupported-content-diff": "השוואה בין גרסאות אינה נתמכת במודל התוכן $1.", + "unsupported-content-diff2": "השוואה בין גרסאות ממודל התוכן $1 לגרסאות ממודל התוכן $2 אינה נתמכת באתר הוויקי הזה.", "deprecated-self-close-category": "דפים שמשתמשים בתגיות HTML עם סגירה עצמית בלתי־תקינה", "deprecated-self-close-category-desc": "הדף מכיל תגיות HTML עם סגירה עצמית בלתי־תקינה, כגון <code dir=\"ltr\"><b/></code> או <code dir=\"ltr\"><span/></code>. ההתנהגות של תגיות אלה תשתנה בקרוב לצורך תאימות עם מפרט HTML5, ולכן יש להימנע משימוש בהן בקוד ויקי.", "duplicate-args-warning": "<strong>אזהרה:</strong> [[:$1]] קורא לדף [[:$2]] עם יותר מערך אחד עבור הפרמטר \"$3\". ייעשה שימוש רק בערך האחרון.", @@ -826,6 +811,7 @@ "undo-norev": "לא ניתן היה לבטל את העריכה כי היא אינה קיימת או כי היא נמחקה.", "undo-nochange": "נראה שהעריכה כבר בוטלה.", "undo-summary": "ביטול גרסה $1 של [[Special:Contributions/$2|$2]] ([[User talk:$2|שיחה]])", + "undo-summary-anon": "ביטול גרסה $1 של [[Special:Contributions/$2|$2]]", "undo-summary-username-hidden": "ביטול גרסה $1 של משתמש מוסתר", "cantcreateaccount-text": "אפשרות יצירת החשבונות מכתובת ה־IP הזאת (<strong>$1</strong>) נחסמה על־ידי [[User:$3|$3]].\n\nהסיבה שניתנה על־ידי $3 היא: <em>$2</em>", "cantcreateaccount-range-text": "אפשרות יצירת החשבונות מכתובות IP בתוך הטווח <strong>$1</strong>, כולל כתובת ה־IP שלך (<strong>$4</strong>), נחסמה על־ידי [[User:$3|$3]].\n\nהסיבה שניתנה על־ידי $3 היא: <em>$2</em>", @@ -1123,6 +1109,7 @@ "prefs-help-email": "כתובת דואר אלקטרוני היא אופציונלית, אבל היא חיונית לאיפוס הסיסמה במקרה ש{{GENDER:|תשכח|תשכחי}} אותה.", "prefs-help-email-others": "באפשרותך גם לאפשר למשתמשים ליצור איתך קשר באמצעות דוא\"ל דרך קישור בדף המשתמש או בדף השיחה שלך.\nכתובת הדוא\"ל שלך לא תיחשף כשמשתמשים יצרו איתך קשר.", "prefs-help-email-required": "כתובת דואר אלקטרוני נדרשת לכתיבה באתר.", + "prefs-help-requireemail": "אם אפשרות זו סומנה, האתר ישלח הודעת דוא\"ל המאפשרת את איפוס הסיסמה רק לאחר שמי שביקש אותה יספק גם את שם המשתמש וגם את כתובת הדוא\"ל של החשבון הזה.", "prefs-info": "מידע בסיסי", "prefs-i18n": "בינאום", "prefs-signature": "חתימה", @@ -1760,8 +1747,8 @@ "backend-fail-contenttype": "לא ניתן היה לקבוע את סוג התוכן של הקובץ לאחסון ב־\"$1\".", "backend-fail-batchsize": "למאגר אחסון הקבצים הפנימי הועבר אוסף של {{PLURAL:$1|פעולת קובץ אחת|$1 פעולות קובץ}}; המגבלה היא {{PLURAL:$2|פעולה אחת|$2 פעולות}}.", "backend-fail-usable": "קריאת או כתיבת הקובץ \"$1\" לא הצליחה כיוון שההרשאות אינן מספיקות או כיוון שהספריות/המכלים חסרים.", - "backend-fail-stat": "לא היה אפשר לקרוא את המצב של הקובץ \"$1\".", - "backend-fail-hash": "לא היה אפשר להחליט מהו גיבוב ההצפנה של הקובץ \"$1\".", + "backend-fail-stat": "קריאת מצב הקובץ \"$1\" לא הצליחה.", + "backend-fail-hash": "מציאת ערך הגיבוב הקריפטוגרפי של הקובץ \"$1\" לא הצליחה.", "filejournal-fail-dbconnect": "לא ניתן היה להתחבר לבסיס הנתונים של היומן עבור מאגר אחסון הקבצים הפנימי \"$1\".", "filejournal-fail-dbquery": "לא ניתן היה לעדכן את בסיס הנתונים של היומן עבור מאגר אחסון הקבצים הפנימי \"$1\".", "lockmanager-notlocked": "פתיחת הנעילה של \"$1\" לא הצליחה; הוא לא נעול.", @@ -1841,6 +1828,7 @@ "listfiles-userdoesnotexist": "חשבון המשתמש \"$1\" אינו רשום.", "imgfile": "קובץ", "listfiles": "רשימת קבצים", + "listfiles_subpage": "העלאות של $1", "listfiles_thumb": "תמונה ממוזערת", "listfiles_date": "תאריך", "listfiles_name": "שם", @@ -2342,6 +2330,7 @@ "alreadyrolled": "לא ניתן לשחזר את העריכה של [[User:$2|$2]] ([[User talk:$2|שיחה]]{{int:pipe-separator}}[[Special:Contributions/$2|{{int:contribslink}}]]) בדף [[:$1]];\nהדף כבר נערך או שוחזר.\n\nהעריכה האחרונה הייתה של [[User:$3|$3]] ([[User talk:$3|שיחה]]{{int:pipe-separator}}[[Special:Contributions/$3|{{int:contribslink}}]]).", "editcomment": "תקציר העריכה היה: <em>$1</em>.", "revertpage": "שוחזר מעריכות של [[Special:Contributions/$2|$2]] ([[User talk:$2|שיחה]]) לעריכה האחרונה של [[User:$1|$1]]", + "revertpage-anon": "שוחזר מעריכות של [[Special:Contributions/$2|$2]] לעריכה האחרונה של [[User:$1|$1]]", "revertpage-nouser": "שוחזר מעריכות של משתמש מוסתר לעריכה האחרונה של {{GENDER:$1|[[User:$1|$1]]}}", "rollback-success": "שוחזר מעריכות של {{GENDER:$3|$1}}\nלעריכה האחרונה של {{GENDER:$4|$2}}.", "sessionfailure-title": "בעיה בחיבור", @@ -2578,6 +2567,7 @@ "ipblocklist-legend": "מציאת משתמש חסום", "blocklist-userblocks": "הסתרת חסימות של משתמשים רשומים", "blocklist-tempblocks": "הסתרת חסימות זמניות", + "blocklist-indefblocks": "הסתרת חסימות בלתי מוגבלות בזמן", "blocklist-addressblocks": "הסתרת חסימות של כתובות IP בודדות", "blocklist-type": "סוג:", "blocklist-type-opt-all": "הכול", diff --git a/languages/i18n/hi.json b/languages/i18n/hi.json index daf9cf993f..8b55325b14 100644 --- a/languages/i18n/hi.json +++ b/languages/i18n/hi.json @@ -687,24 +687,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|आपकी ध्यानसूची के पृष्ठों में बदलावों]] की वेब फ़ीड (Atom/RSS) हेतु टोकन", "resettokens-done": "टोकन रीसेट कर दिए गए।", "resettokens-resetbutton": "चुने हुए टोकन रीसेट करें", - "bold_sample": "मोटा पाठ", - "bold_tip": "गहरा पाठ", - "italic_sample": "तिरछा पाठ", - "italic_tip": "तिरछा पाठ", - "link_sample": "कड़ी शीर्षक", - "link_tip": "आंतरिक कड़ी", - "extlink_sample": "http://www.example.com कड़ी शीर्षक", - "extlink_tip": "बाहरी कड़ी (उपसर्ग http:// अवश्य लगाएँ)", - "headline_sample": "शीर्षक पाठ", - "headline_tip": "द्वितीय-स्तर शीर्षक", - "nowiki_sample": "अप्रारूपित पाठ यहाँ डालें", - "nowiki_tip": "विकि प्रारूपण नज़रंदाज़ करें", - "image_sample": "उदाहरण.jpg", - "image_tip": "एम्बेड की हुई फ़ाइल", - "media_sample": "उदाहरण.ogg", - "media_tip": "फ़ाइल की कड़ी", - "sig_tip": "आपका हस्ताक्षर व समय", - "hr_tip": "हॉरिज़ौंटल लाइन (कम इस्तेमाल करें)", "summary": "सारांश:", "subject": "विषय:", "minoredit": "यह एक छोटा बदलाव है", diff --git a/languages/i18n/hif-latn.json b/languages/i18n/hif-latn.json index 9355e7c4d9..7133a17005 100644 --- a/languages/i18n/hif-latn.json +++ b/languages/i18n/hif-latn.json @@ -589,22 +589,6 @@ "resettokens-watchlist-token": "Dhyan suchi ke web feed token (Atom/RSS) of [[Special:Watchlist|changes to pages on your watchlist]]", "resettokens-done": "Token ke reset kar dewa gais hae.", "resettokens-resetbutton": "Chuna gais token ke reset karo", - "bold_sample": "Motaa text", - "bold_tip": "Motaa text", - "italic_sample": "Tirchha akchhar", - "italic_tip": "Tirchha akchhar", - "link_sample": "Jorr ke title", - "link_tip": "Bhitari jorr", - "extlink_sample": "http://www.example.com jorr ke padwi", - "extlink_tip": "Bahari jorr (yaad rakhna http:// prefix)", - "headline_sample": "Khaas samaachar ke akchhar", - "headline_tip": "Duusra level ke headline", - "nowiki_sample": "Non-formatted text ke hian par insert karo", - "nowiki_tip": "Wiki bhasa ke anusaar badlao nahi karo", - "image_tip": "Jamawa gais suchi", - "media_tip": "File ke jorre waala", - "sig_tip": "Aapke signature time ke saathe", - "hr_tip": "Samthar line (bahut jaada nai kaam me laana)", "summary": "Sanchhipt:", "subject": "Visay:", "minoredit": "Ii chhota badlao hai", diff --git a/languages/i18n/hil.json b/languages/i18n/hil.json index 30320ed102..b94023ae78 100644 --- a/languages/i18n/hil.json +++ b/languages/i18n/hil.json @@ -413,22 +413,6 @@ "changeemail-none": "(wala)", "changeemail-password": "Ang imong {{SITENAME}} nga password:", "changeemail-submit": "Ilisan and E-mail", - "bold_sample": "Dukot nga teksto", - "bold_tip": "Dukot nga teksto", - "italic_sample": "Gahilay nga teksto", - "italic_tip": "Gahilay nga teksto", - "link_sample": "Panig-ulo sang tabid", - "link_tip": "Sulodlon nga tabid", - "extlink_sample": "http://www.example.com panig-ulo sang tabid", - "extlink_tip": "Sa guha nga Tabid (tandaan http:// prefiks)", - "headline_sample": "Teksto sang pangunang-dinalang", - "headline_tip": "Lebel 2 pangunang-dinalan", - "nowiki_sample": "Ibutang ang di-sulundan nga teksto diri", - "nowiki_tip": "Pabay-an ang wiki sulundanon", - "image_tip": "Gintapik nga file", - "media_tip": "Pagtabid sa File", - "sig_tip": "Ang imo pirma upod sang timestamp", - "hr_tip": "Gapahigda nga linya (gamiton laka lang)", "summary": "Kabilogan:", "subject": "Ginatukoy/Pangulong-dinalang:", "minoredit": "Diutay lang ini nga pagliwat", diff --git a/languages/i18n/hr.json b/languages/i18n/hr.json index d04622afcc..8fc0095e81 100644 --- a/languages/i18n/hr.json +++ b/languages/i18n/hr.json @@ -620,24 +620,6 @@ "resettokens-watchlist-token": "Tajni ključ za uvoženje u mrežno sjediÅ¡te (Atom/RSS) [[Special:Watchlist|promjena na stranicama s VaÅ¡ega popisa praćenih stranica]]", "resettokens-done": "Ponovno postavljanje tajnih ključeva", "resettokens-resetbutton": "Ponovo postavi odabrane tajne ključeve", - "bold_sample": "Podebljani tekst", - "bold_tip": "Podebljani tekst", - "italic_sample": "Kurzivni tekst", - "italic_tip": "Kurzivni tekst", - "link_sample": "Tekst poveznice", - "link_tip": "Unutarnja poveznica", - "extlink_sample": "http://www.example.com Tekst poveznice", - "extlink_tip": "Vanjska poveznica (pazi, nužan je prefiks http://)", - "headline_sample": "Tekst naslova", - "headline_tip": "Podnaslov", - "nowiki_sample": "Ovdje unesite neoblikovani tekst", - "nowiki_tip": "Neoblikovani tekst", - "image_sample": "Primjer.jpg", - "image_tip": "Uložena slika", - "media_sample": "Primjer.ogg", - "media_tip": "Uloženi medij", - "sig_tip": "VaÅ¡ potpis s datumom", - "hr_tip": "Vodoravna crta (koristiti rijetko)", "summary": "Sažetak:", "subject": "Predmet:", "minoredit": "Ovo je manja promjena", @@ -1011,7 +993,7 @@ "prefs-resetpass": "promijeni zaporku", "prefs-changeemail": "promijeni ili ukloni adresu e-poÅ¡te", "prefs-setemail": "Postavite adresu e-poÅ¡te", - "prefs-email": "Mogućnosti e-maila", + "prefs-email": "Mogućnosti e-poÅ¡te", "prefs-rendering": "Izgled", "saveprefs": "Spremi", "restoreprefs": "Vrati sve postavke na prvobitno zadane (u svim odjeljcima)", @@ -1055,7 +1037,7 @@ "prefs-custom-js": "Prilagođen JS", "prefs-common-config": "Dijeljeni CSS/JSON/JavaScript za sve izglede:", "prefs-reset-intro": "Možete koristiti ovu stranicu za povrat VaÅ¡ih postavki na prvotne postavke. Ovo se ne može poniÅ¡titi.", - "prefs-emailconfirm-label": "Potvrda e-mail adrese:", + "prefs-emailconfirm-label": "Potvrda adrese e-poÅ¡te:", "youremail": "VaÅ¡a adresa e-poÅ¡te:", "username": "Ime {{GENDER:$1|suradnika|suradnice}}:", "prefs-memberingroups": "{{GENDER:$2|Suradnik je član|Suradnica je članica}} {{PLURAL:$1|sljedeće skupine|sljedećih skupina}}:", diff --git a/languages/i18n/hrx.json b/languages/i18n/hrx.json index 6aebc20d74..4f2dbffaa7 100644 --- a/languages/i18n/hrx.json +++ b/languages/i18n/hrx.json @@ -485,22 +485,6 @@ "resettokens-watchlist-token": "Token für den Webfeed (Atom/RSS) von der [[Special:Watchlist|Ännrunge an Seite uff deiner Beobachtungslist]]", "resettokens-done": "Tokens zurückgesetzt.", "resettokens-resetbutton": "Ausgewählte Token ännre", - "bold_sample": "Fetter Text", - "bold_tip": "Fetter Text", - "italic_sample": "Kursiver Text", - "italic_tip": "Kursiver Text", - "link_sample": "Link-Text", - "link_tip": "Interner Link", - "extlink_sample": "http://www.example.com Link-Text", - "extlink_tip": "Externer Link (http:// beachte)", - "headline_sample": "Ebene-2-Üwerschrift", - "headline_tip": "Ebene-2-Üwerschrift", - "nowiki_sample": "Unformatierte Text hie renfüche", - "nowiki_tip": "Unformatierter Text", - "image_tip": "Dateilink", - "media_tip": "Mediedatei-Link", - "sig_tip": "Dein Signatur mit Zeitstempel", - "hr_tip": "Horizontoole Linie (spoorsam verwenne)", "summary": "Zusammerfassung:", "subject": "Betreff:", "minoredit": "Nuar Klenichkeite woore verännert", diff --git a/languages/i18n/hsb.json b/languages/i18n/hsb.json index 60a4e6b8e4..1a4f91c7ca 100644 --- a/languages/i18n/hsb.json +++ b/languages/i18n/hsb.json @@ -533,24 +533,6 @@ "resettokens-watchlist-token": "Token za webkanal (Atom/RSS) [[Special:Watchlist|změnow na stronach w twojich wobkedźbowankach]]", "resettokens-done": "Tokeny wróćostajene.", "resettokens-resetbutton": "Wubrane tokeny wróćo stajić", - "bold_sample": "Tučny tekst", - "bold_tip": "Tučny tekst", - "italic_sample": "Kursiwny tekst", - "italic_tip": "Kursiwny tekst", - "link_sample": "Mjeno wotkaza", - "link_tip": "Znutřkowny wotkaz", - "extlink_sample": "http://www.example.com mjeno wotkaza", - "extlink_tip": "Zwonkowny wotkaz (pomysli sej na prefiks http://)", - "headline_sample": "Tekst nadpisma", - "headline_tip": "Nadpismo runiny 2", - "nowiki_sample": "Tu njeformatowany tekst zasunyć", - "nowiki_tip": "Wikiformatowanje ignorować", - "image_sample": "Přikład.jpg", - "image_tip": "Zasadźena dataja", - "media_sample": "Přikład.ogg", - "media_tip": "Datajowy wotkaz", - "sig_tip": "Twoja signatura z časowym kołkom", - "hr_tip": "Wodoruna linija (zrědka wužiwać!)", "summary": "Zjeće:", "subject": "Tema:", "minoredit": "Snadna změna", diff --git a/languages/i18n/ht.json b/languages/i18n/ht.json index e4b7a1d56e..64a286226a 100644 --- a/languages/i18n/ht.json +++ b/languages/i18n/ht.json @@ -442,22 +442,6 @@ "resetpass-wrong-oldpass": "Mopas sa pa bon ditou; li te mèt mopas ou an kounye a oubyen yon mopas tanporè.\nGendwa ou te deja modifye li oubyen ou te mande yon nouvo mopas tanporè.", "resetpass-temp-password": "Mopas tanporè yo ba ou an:", "passwordreset-username": "Non itilizatè :", - "bold_sample": "Tèks fonse", - "bold_tip": "Tèks fonse", - "italic_sample": "Tèks italik", - "italic_tip": "Tèks italik", - "link_sample": "Lyen pou tit an", - "link_tip": "Lyen anndan", - "extlink_sample": "http://www.example.com yon tit pou lyen an", - "extlink_tip": "Lyen andeyò (pa blye prefiks http:// an)", - "headline_sample": "Tèks pou tit", - "headline_tip": "Sou-tit nivo 2", - "nowiki_sample": "Antre tèks ki pa fòmate a", - "nowiki_tip": "Pa konte sentaks wiki an", - "image_tip": "Fichye anndan paj sa", - "media_tip": "Lyen pou fichye sa", - "sig_tip": "Siyati ou ak dat an", - "hr_tip": "Liy orizontal (pa abize)", "summary": "Somè:", "subject": "Sijè/tit:", "minoredit": "Modifikasyon sa a tou piti", diff --git a/languages/i18n/hu.json b/languages/i18n/hu.json index 37106e5d10..a346ed2324 100644 --- a/languages/i18n/hu.json +++ b/languages/i18n/hu.json @@ -99,6 +99,7 @@ "tog-useeditwarning": "Figyelmeztessen, ha szerkesztéskor a módosítások mentése nélkül akarom elhagyni a lapot", "tog-prefershttps": "Mindig biztonságos kapcsolatot használjon, amikor be vagyok jelentkezve", "tog-showrollbackconfirmation": "Megerősítés kérése, amikor a visszaállítás linkre kattintasz", + "tog-requireemail": "E-mail-cím megkövetelése jelszó-visszaállításkor", "underline-always": "mindig", "underline-never": "soha", "underline-default": "Felület és böngésző alapértelmezése szerint", @@ -473,7 +474,7 @@ "createaccountmail": "Átmeneti, véletlenszerű jelszó beállítása és kiküldése a megadott e-mail-címre", "createaccountmail-help": "A jelszó megismerése nélkül készíthető valaki másnak fiók.", "createacct-realname": "Igazi neved (nem kötelező)", - "createacct-reason": "Indoklás", + "createacct-reason": "Indoklás (nyilvánosan naplózva)", "createacct-reason-ph": "Miért hozol létre egy másik fiókot", "createacct-reason-help": "A fióklétrehozási naplóban megjelenő üzenet", "createacct-submit": "Felhasználói fiók létrehozása", @@ -640,24 +641,6 @@ "resettokens-watchlist-token": "Kulcs egy hírcsatornához (Atom/RSS), ami a [[Special:Watchlist|figyelőlistádon lévő lapok változásaiból]] készül", "resettokens-done": "Tokenek újragenerálva.", "resettokens-resetbutton": "Kijelőlt tokenek újragenerálása", - "bold_sample": "Félkövér szöveg", - "bold_tip": "Félkövér szöveg", - "italic_sample": "Dőlt szöveg", - "italic_tip": "Dőlt szöveg", - "link_sample": "Hivatkozás megnevezése", - "link_tip": "Belső hivatkozás", - "extlink_sample": "http://www.példa-hivatkozás.hu hivatkozás megnevezése", - "extlink_tip": "Külső hivatkozás (ne felejtsd el a http:// előtagot)", - "headline_sample": "Alfejezet címe", - "headline_tip": "Alfejezetcím", - "nowiki_sample": "Ide írd a formázatlan szöveget", - "nowiki_tip": "Wikiformázás kikapcsolása", - "image_sample": "Pelda.jpg", - "image_tip": "Fájl (pl. kép) beszúrása", - "media_sample": "Peldaegyketto.ogg", - "media_tip": "Fájlhivatkozás", - "sig_tip": "Aláírás időponttal", - "hr_tip": "Vízszintes vonal (ritkán használd)", "summary": "Összefoglaló:", "subject": "Tárgy:", "minoredit": "Apró változtatás", @@ -1130,6 +1113,7 @@ "prefs-help-email": "Az e-mail-cím megadása nem kötelező, de szükséges új jelszó kéréséhez, ha elfelejtenéd a meglévőt.", "prefs-help-email-others": "Úgy is dönthetsz, hogy lehetővé teszed mások számára, hogy kapcsolatba lépjenek veled a felhasználói vagy vitalapodon keresztül, anélkül, hogy fel kellene fedned a személyazonosságodat.", "prefs-help-email-required": "Meg kell adnod az e-mail címedet.", + "prefs-help-requireemail": "Amennyiben bekapcsolod, csak akkor küldünk jelszó-visszaállító e-mailt, ha az ezt kérő személy helyesen megadja a fiók szerkesztői nevét és e-mail-címét.", "prefs-info": "Alapinformációk", "prefs-i18n": "Nyelvi beállítások", "prefs-signature": "Aláírás", @@ -1550,7 +1534,7 @@ "rcfilters-preference-help": "Friss változtatások betöltése szűrők közti keresés és kiemelések lehetősége nélkül.", "rcfilters-watchlist-preference-label": "JavaScript nélküli felület használata", "rcfilters-watchlist-preference-help": "Figyelőlista betöltése szűrők közti keresés és kiemelések lehetősége nélkül.", - "rcfilters-filter-showlinkedfrom-label": "A következő lapra hivatkozó lapok változtatásainak megjelenítése", + "rcfilters-filter-showlinkedfrom-label": "A következő lapról hivatkozott lapok változtatásainak megjelenítése", "rcfilters-filter-showlinkedfrom-option-label": "A kiválasztott <strong>lapról</strong> hivatkozott lapok", "rcfilters-filter-showlinkedto-label": "A következő lapról hivatkozott lapok változtatásainak megjelenítése", "rcfilters-filter-showlinkedto-option-label": "A kiválasztott <strong>lapra</strong> hivatkozó lapok", @@ -1810,7 +1794,7 @@ "uploadstash-zero-length": "A fájl nulla méretű.", "invalid-chunk-offset": "Érvénytelen darab eltolás", "img-auth-accessdenied": "Hozzáférés megtagadva", - "img-auth-nopathinfo": "Hiányzó PATH_INFO.\nA szerver nincs beállítva, hogy továbbítsa ezt az információt.\nLehet, hogy CGI-alapú, és nem támogatja az img_auth-ot.\nLásd https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:Image_Authorization!", + "img-auth-nopathinfo": "Hiányzó elérési út információ.\nA szerveredet úgy kell beállítanod, hogy továbbítsa a REQUEST_URI és/vagy a PATH_INFO változókat.\nHa már be vannak, próbáld engedélyezni a $wgUsePathInfo-t.\nLásd https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:Image_Authorization!", "img-auth-notindir": "A kért elérési út nincs a beállított feltöltési könyvtárban.", "img-auth-badtitle": "Nem sikerült érvényes címet készíteni a(z) „$1” szövegből.", "img-auth-nofile": "A fájl („$1”) nem létezik.", @@ -1843,6 +1827,7 @@ "listfiles-userdoesnotexist": "A(z) „$1” felhasználó nincs regisztrálva.", "imgfile": "fájl", "listfiles": "Fájllista", + "listfiles_subpage": "$1 feltöltései", "listfiles_thumb": "Bélyegkép", "listfiles_date": "Dátum", "listfiles_name": "Név", @@ -2575,6 +2560,7 @@ "ipblocklist-legend": "Blokkolt felhasználó keresése", "blocklist-userblocks": "Fiókblokkolások elrejtése", "blocklist-tempblocks": "Ideiglenes blokkolások elrejtése", + "blocklist-indefblocks": "Végtelen blokkolások elrejtése", "blocklist-addressblocks": "IP-címek blokkolásainak elrejtése", "blocklist-type": "Típus:", "blocklist-type-opt-all": "Összes", diff --git a/languages/i18n/hy.json b/languages/i18n/hy.json index 6ec9c9e85f..255b8742bf 100644 --- a/languages/i18n/hy.json +++ b/languages/i18n/hy.json @@ -553,22 +553,6 @@ "changeemail-submit": "Փոխել էլ․ հասցեն", "changeemail-nochange": "Խնդրում ենք մուտքագրեք Õ¡ÕµÕ¬ նոր էլեկտրոնային փոստի հասցեն։", "resettokens-tokens": "Կտրոններ՝", - "bold_sample": "Ô¹Õ¡Õ¾Õ¡Õ¿Õ¡Õ¼ տեքստ", - "bold_tip": "Ô¹Õ¡Õ¾Õ¡Õ¿Õ¡Õ¼ տեքստ", - "italic_sample": "Շեղատառ տեքստ", - "italic_tip": "Շեղատառ տեքստ", - "link_sample": "Հղման վերնագիր", - "link_tip": "Ներքին հղում", - "extlink_sample": "http://www.example.com Õ°Õ²Õ´Õ¡Õ¶ վերնագիրը", - "extlink_tip": "Արտաքին հղում (հիշեք http:// նախածանցը)", - "headline_sample": "Ենթագլուխ", - "headline_tip": "Ենթագլուխ", - "nowiki_sample": "Մուտքագրեք չձևավորված տեքստը Õ¡ÕµÕ½Õ¿Õ¥Õ²", - "nowiki_tip": "Ô±Õ¶Õ¿Õ¥Õ½Õ¥Õ¬ վիքի ձևավորումը", - "image_tip": "Ներդրված նիշք", - "media_tip": "Հղում նիշքին", - "sig_tip": "Ձեր ստորագրությունը Õ¡Õ´Õ½Õ¡Õ©Õ¾Õ¸Õ¾", - "hr_tip": "Հորիզոնական Õ£Õ«Õ® (Õ´Õ«Õ¡ÕµÕ¶ անհրաժեշտության դեպքում)", "summary": "Ամփոփում:", "subject": "Վերնագիր:", "minoredit": "Սա Õ¹Õ¶Õ¹Õ«Õ¶ խմբագրում Õ§", diff --git a/languages/i18n/hyw.json b/languages/i18n/hyw.json index dd2d0073d1..7585679471 100644 --- a/languages/i18n/hyw.json +++ b/languages/i18n/hyw.json @@ -362,24 +362,6 @@ "changeemail-none": "(Õ¸Õ¹ Õ´Õ§Õ¯)", "changeemail-password": "Ձեր {{SITENAME}} անցաբառը՝", "changeemail-submit": "Փոխել ելեկտրոնային հասցէն", - "bold_sample": "Թաւատառ գրութիւն", - "bold_tip": "Թաւատառ գրութիւն", - "italic_sample": "Շեղատառ գրութիւն", - "italic_tip": "Շեղատառ գրութիւն", - "link_sample": "Յղման վերնագիր", - "link_tip": "Ներքին յղում", - "extlink_sample": "http://www.example.com ÕµÕ²Õ´Õ¡Õ¶ վերնագիրը", - "extlink_tip": "Արտաքին յղում (ÕµÕ«Õ·Õ¥Õ¬ http:// նախածանց)", - "headline_sample": "Վերնագրի գրութիւն", - "headline_tip": "Երկրորդ մակարդակի վերնագիր", - "nowiki_sample": "Մուտքագրեցէ՛ք չձեւաւորուած գրութիւնը Õ¡ÕµÕ½Õ¿Õ¥Õ²", - "nowiki_tip": "Ô±Õ¶Õ¿Õ¥Õ½Õ¥Õ¬ ուիքի ձեւաւորումը", - "image_sample": "Օրինակ.jpg", - "image_tip": "Ներփակ նիշք", - "media_sample": "Օրինակ.jpg", - "media_tip": "Նիշքին յղումը", - "sig_tip": "Ձեր ստորագրութիւնը ժամակնիքով", - "hr_tip": "Հորիզոնական Õ£Õ«Õ® (գործածել խնայողաբար)", "summary": "Ամփոփում՝", "subject": "Նիւթ.", "minoredit": "Ô±Õ½Õ«Õ¯Õ¡ մանր խմբագրում Õ§", diff --git a/languages/i18n/ia.json b/languages/i18n/ia.json index eb94cd015e..6bee178a3a 100644 --- a/languages/i18n/ia.json +++ b/languages/i18n/ia.json @@ -64,6 +64,7 @@ "tog-useeditwarning": "Advertir me quando io quita un pagina de modification sin publicar le cambiamentos", "tog-prefershttps": "Sempre usar un connexion secur durante session aperte", "tog-showrollbackconfirmation": "Monstrar un demanda de confirmation al cliccar sur un ligamine de revocation", + "tog-requireemail": "Requirer e-mail pro reinitialisar contrasigno", "underline-always": "Sempre", "underline-never": "Nunquam", "underline-default": "Como definite per tu navigator o apparentia", @@ -436,7 +437,7 @@ "createaccountmail": "Usar un contrasigno aleatori temporari e inviar lo al adresse de e-mail specificate", "createaccountmail-help": "Pro crear un conto pro un altere persona sin cognoscer le contrasigno.", "createacct-realname": "Nomine real (optional)", - "createacct-reason": "Motivo", + "createacct-reason": "Motivo (visibile publicamente)", "createacct-reason-ph": "Proque crea tu un altere conto?", "createacct-reason-help": "Message pro le registro de creation de contos", "createacct-submit": "Crear tu conto", @@ -604,24 +605,6 @@ "resettokens-watchlist-token": "Indicio pro syndication web (Atom/RSS) de [[Special:Watchlist|modificationes a paginas in tu observatorio]]", "resettokens-done": "Indicios reinitialisate.", "resettokens-resetbutton": "Reinitialisar le indicios seligite", - "bold_sample": "Texto grasse", - "bold_tip": "Texto grasse", - "italic_sample": "Texto italic", - "italic_tip": "Texto italic", - "link_sample": "Titulo del ligamine", - "link_tip": "Ligamine interne", - "extlink_sample": "http://www.example.com titulo del ligamine", - "extlink_tip": "Ligamine externe (non oblida le prefixo http://)", - "headline_sample": "Texto del titulo", - "headline_tip": "Titulo de nivello 2", - "nowiki_sample": "Inserer texto non formatate hic", - "nowiki_tip": "Ignorar formatation wiki", - "image_sample": "Exemplo.jpg", - "image_tip": "File incastrate", - "media_sample": "Exemplo.ogg", - "media_tip": "Ligamine a un file", - "sig_tip": "Tu signatura con data e hora", - "hr_tip": "Linea horizontal (usa con moderation)", "summary": "Summario:", "subject": "Subjecto:", "minoredit": "Isto es un modification minor", @@ -1101,6 +1084,7 @@ "prefs-help-email": "Le adresse de e-mail es optional, ma es necessari pro le reinitialisation de tu contrasigno, in caso que tu lo oblida.", "prefs-help-email-others": "Tu pote etiam optar pro permitter que altere personas te contacta via tu pagina de usator o de discussion, sin necessitate de revelar tu identitate.", "prefs-help-email-required": "Un adresse de e-mail es obligatori.", + "prefs-help-requireemail": "Si es marcate, inviar messages pro reinitialisar contrasigno solmente si le persona reinitialisante forni non solmente le nomine de usator ma etiam le adresse de e-mail pro iste conto.", "prefs-info": "Informationes de base", "prefs-i18n": "Internationalisation", "prefs-signature": "Signatura", @@ -1819,6 +1803,7 @@ "listfiles-userdoesnotexist": "Le conto de usator \"$1\" non es registrate.", "imgfile": "file", "listfiles": "Lista de files", + "listfiles_subpage": "Files incargate per $1", "listfiles_thumb": "Miniatura", "listfiles_date": "Data", "listfiles_name": "Nomine", @@ -2552,6 +2537,7 @@ "ipblocklist-legend": "Cercar un usator blocate", "blocklist-userblocks": "Celar blocadas de conto", "blocklist-tempblocks": "Celar blocadas temporari", + "blocklist-indefblocks": "Celar blocadas infinite", "blocklist-addressblocks": "Celar blocadas de singule adresse IP", "blocklist-type": "Typo:", "blocklist-type-opt-all": "Totes", @@ -3820,5 +3806,8 @@ "mycustomjsredirectprotected": "Tu non ha le permission de modificar iste pagina JavaScript perque illo es un redirection e non puncta a un pagina in tu spatio de usator.", "easydeflate-invaliddeflate": "Le contento fornite non es correctemente comprimite", "unprotected-js": "Pro motivos de securitate, non es possibile cargar codice JavaScript de paginas non protegite. Crea JavaScript solmente in le spatio de nomines \"MediaWiki:\" o como un subpagina de usator.", - "userlogout-continue": "Vole tu clauder le session?" + "userlogout-continue": "Vole tu clauder le session?", + "rest-prefix-mismatch": "Le cammino requestate ($1) non es intra le cammino radice del REST API ($2)", + "rest-wrong-method": "Le methodo del requesta ($1) non es {{PLURAL:$3|le methodo|inter le methodos}} permittite pro iste cammino ($2)", + "rest-no-match": "Le cammino relative requestate ($1) non corresponde a un gestor cognoscite" } diff --git a/languages/i18n/id.json b/languages/i18n/id.json index 0ba4725088..f4bc1c9eec 100644 --- a/languages/i18n/id.json +++ b/languages/i18n/id.json @@ -660,24 +660,6 @@ "resettokens-watchlist-token": "Token untuk sindikasi web (Atom/RSS) dari [[Special:Watchlist|perubahan di daftar pantauan Anda]]", "resettokens-done": "Reset token.", "resettokens-resetbutton": "Reset token yang dipilih", - "bold_sample": "Teks ini akan dicetak tebal", - "bold_tip": "Teks tebal", - "italic_sample": "Teks ini akan dicetak miring", - "italic_tip": "Teks miring", - "link_sample": "Judul pranala", - "link_tip": "Pranala internal", - "extlink_sample": "http://www.example.com judul pranala", - "extlink_tip": "Pranala luar (jangan lupa awalan http:// )", - "headline_sample": "Teks judul", - "headline_tip": "Subbagian tingkat 1", - "nowiki_sample": "Masukkan teks yang tidak akan diformat di sini", - "nowiki_tip": "Abaikan pemformatan wiki", - "image_sample": "Contoh.jpg", - "image_tip": "Cantumkan berkas", - "media_sample": "Contoh.ogg", - "media_tip": "Pranala berkas media", - "sig_tip": "Tanda tangan Anda dengan tanda waktu", - "hr_tip": "Garis horisontal", "summary": "Ringkasan:", "subject": "Subjek:", "minoredit": "Ini adalah suntingan kecil.", diff --git a/languages/i18n/ie.json b/languages/i18n/ie.json index 321548b548..5c7e052e3a 100644 --- a/languages/i18n/ie.json +++ b/languages/i18n/ie.json @@ -366,22 +366,6 @@ "passwordreset-username": "Nómine de usator:", "changeemail-none": "(null)", "resettokens-token-label": "$1 (valor actual: $2)", - "bold_sample": "Nigri textu", - "bold_tip": "Nigri textu", - "italic_sample": "Cursiv textu", - "italic_tip": "Cursiv textu", - "link_sample": "Nómine de referentie", - "link_tip": "Intern referentie", - "extlink_sample": "http://www.example.com nómine del referentie", - "extlink_tip": "Extern referentie (ne oblivia prefixar http://)", - "headline_sample": "Titul de nivell 2", - "headline_tip": "Titul de nivell 2", - "nowiki_sample": "Intrar ínformatat textu ci.", - "nowiki_tip": "Ignorar formate wiki", - "image_tip": "Fixat file", - "media_tip": "Referentie a un multimedial file.", - "sig_tip": "Tui subscrit con hor e date", - "hr_tip": "Horizontal linea (ples usar sin excess)", "summary": "Resummation:", "subject": "Tema:", "minoredit": "To es un bagatellic change", diff --git a/languages/i18n/ig.json b/languages/i18n/ig.json index 91311a964c..f71a5a89d8 100644 --- a/languages/i18n/ig.json +++ b/languages/i18n/ig.json @@ -391,22 +391,6 @@ "passwordreset-username": "Ahàǹjìème:", "passwordreset-emailelement": "Áhà Ọ'banife: \n$1\n\nPasswod nke gi gbanwe: \n$2", "changeemail-none": "(efù)", - "bold_sample": "Mkpúrù èdè íke", - "bold_tip": "Mkpúrù èdè íke", - "italic_sample": "Mkpurụ okwu sélénsé", - "italic_tip": "Mkpurụ okwu sélénsé", - "link_sample": "Ishi edemede nke jikodo", - "link_tip": "Jikodo nke ímé", - "extlink_sample": "http://www.example.com ishi jikodo", - "extlink_tip": "Jikodo nọr na ẹzí (chètá íshí http://)", - "headline_sample": "Ahiri ishi mkpurụ edemede", - "headline_tip": "Larri 2 ishiahiri", - "nowiki_sample": "Tinyé mkụrụ edemede enweghị ihe ọbula na ya ti ya nga", - "nowiki_tip": "É gekwàlà otu wiki shi edé", - "image_tip": "Njikota édé a pọrọgwụla", - "media_tip": "Jikodo usòrò", - "sig_tip": "Nkábị gị nwéré nkábị nke ógè", - "hr_tip": "Áhìrì na ga nà àlà (jí ya nke ntàkírí)", "summary": "Mmẹkụwátá:", "subject": "Ihe gbasara/Ishi ahiri", "minoredit": "Ihe bu orü ntakírí", diff --git a/languages/i18n/ilo.json b/languages/i18n/ilo.json index d9df46968d..89b202c1c9 100644 --- a/languages/i18n/ilo.json +++ b/languages/i18n/ilo.json @@ -580,22 +580,6 @@ "resettokens-watchlist-token": "Tandaan para iti pakan ti web (Atom/RSS) kadagiti [[Special:Watchlist|panagbalbaliw ti pampanid iti listaan ti bambantayam]]", "resettokens-done": "Naisaad manen dagiti tandaan.", "resettokens-resetbutton": "Isaad manen dagiti napili a tandaan", - "bold_sample": "Napuskol a teksto", - "bold_tip": "Napuskol a teksto", - "italic_sample": "Teksto nga italiko", - "italic_tip": "Teksto nga italiko", - "link_sample": "Titulo ti silpo", - "link_tip": "Akin-uneg a silpo", - "extlink_sample": "http://www.example.com titulo ti silpo", - "extlink_tip": "Akinruar a silpo (laglagipen ti http:// a pasakbay)", - "headline_sample": "Teksto ti paulo", - "headline_tip": "Maika-2 nga agasmang ti paulo", - "nowiki_sample": "Isengngat ti saan a naporma a teksto ditoy", - "nowiki_tip": "Saan nga ikaskaso ti pannakaporma ti wiki", - "image_tip": "Naisengngat a papeles", - "media_tip": "Silpo ti papeles", - "sig_tip": "Ti pirmam nga addaan iti oras ken petsa", - "hr_tip": "Horisontal a linia (manmano laeng nga aramaten)", "summary": "Pakabuklan:", "subject": "Suheto:", "minoredit": "Daytoy ket bassit a panagurnos", diff --git a/languages/i18n/inh.json b/languages/i18n/inh.json index baee1f0b39..84e719596b 100644 --- a/languages/i18n/inh.json +++ b/languages/i18n/inh.json @@ -363,22 +363,6 @@ "passwordreset-email": "Электронни почта адрес:", "changeemail": "дIахувца е дIаяккха электронни пошт", "resettokens-tokens": "Токенаш:", - "bold_sample": "Сома йоазон текст", - "bold_tip": "Сома йоазон текст", - "italic_sample": "Сиха йоазон текст", - "italic_tip": "Сиха йоазон текст", - "link_sample": "Тӏатовжама кепакерта цIи", - "link_tip": "Чура тӏатовжам", - "extlink_sample": "http://www.example.com тIахьожаярга дáкъа цIи", - "extlink_tip": "Арахьара тIахьожаярг (йиц ма ялийтта префикс http://)", - "headline_sample": "Дáкъа цIера текст", - "headline_tip": "2-гӀа лагӀара дáкъа цIи", - "nowiki_sample": "Укхаза хувца езаш йоаца текст хьачуоттае", - "nowiki_tip": "Теркал ма е вики-форматировани", - "image_tip": "Чухьнахьара файл", - "media_tip": "Файлá тIатовжам", - "sig_tip": "Хьа кулгаяздар а, хӀанзара ха а", - "hr_tip": "ПхьорагIен така (цох пайда эцар тIехдаьнна кастта ма де)", "summary": "Хувцамий сурт оттадар", "subject": "Тема/даькъа цIи:", "minoredit": "ЗӀамига хувцам", diff --git a/languages/i18n/io.json b/languages/i18n/io.json index 28cbba6d4a..de3255bfdc 100644 --- a/languages/i18n/io.json +++ b/languages/i18n/io.json @@ -598,24 +598,6 @@ "resettokens-token-label": "$1 (nuna valoro: $2)", "resettokens-done": "Klefi rinovigita.", "resettokens-resetbutton": "Rinovigar selektita klefi", - "bold_sample": "Dika literi", - "bold_tip": "Dika literi", - "italic_sample": "Kursiva literi", - "italic_tip": "Kursiva literi", - "link_sample": "Titulo dil ligilo", - "link_tip": "Interna ligilo", - "extlink_sample": "http://www.example.com Titulo dil ligilo", - "extlink_tip": "Extera ligilo (memorez adjuntar la prefixo \"http://\")", - "headline_sample": "Texto dil titulo", - "headline_tip": "Titulo di duesma nivelo", - "nowiki_sample": "Insertar senformizita texto hike", - "nowiki_tip": "Ignorez formatigo wikial", - "image_sample": "Exemplo.jpg", - "image_tip": "Imajo enkorpigita", - "media_sample": "Exemplo.ogg", - "media_tip": "Ligilo di arkivo", - "sig_tip": "Vua signaturo kun 'timestamp'", - "hr_tip": "Horizontala lineo (ne trouzez ol)", "summary": "Rezumo:", "subject": "Temo:", "minoredit": "Ico esas mikra redaktajo", @@ -1749,6 +1731,7 @@ "block-expiry": "Expiro:", "block-options": "Plusa agadi:", "block-reason": "Motivo:", + "block-target": "Nomo od IP-adreso dil uzero:", "unblockip": "Desblokusar uzero", "unblockiptext": "Uzez la sequanta formularo por restaurar la skribo-aceso ad IP-adreso qua blokusesis antee.", "ipusubmit": "Desblokusar", @@ -1799,7 +1782,7 @@ "movepagetext": "Uzante ica formularo onu povas rinomizar pagino, movante olua omna versionaro ad la nova titulo.\nLa antea titulo konvertesos a ridirektilo a la nova titulo.\nLa ligili a la antea titulo dil pagino ne chanjesos.\nVoluntez certigar ke ne esas [[Special:DoubleRedirects|duopla]] o [[Special:BrokenRedirects|ruptota ridirektili]].\nVu responsas ke la ligili duros direktante a la pagino korespondanta.\n\nMemorez ke la pagino '''ne''' rinomizesos se ja existus pagino kun la nova titulo, eceptuante ke la pagino esas vakua o ridirektilo sen versionaro.\nIco signifikas ke vu povos rinomizar pagino a olua originala titulo se eroras skribante la nova titulo, ma ne povos riskribar existanta pagino.\n\n'''EGARDEZ!'''\nIca povas esar drastika chanjo e ne-esperinda por populara pagino;\nvoluntez certigar ke vu komprenas la konsequi qui eventos ante durar adavane.", "movepagetext-noredirectfixer": "Uzar la formulario infre rinomizos la pagino, e tota lua historio-listo a la nova nomo.\nL'anciena titulo ridirektesos a la nova titulo.\nVerifikez la [[Special:DoubleRedirects|duopla]] e/o la [[Special:BrokenRedirects|krevita ridirekti]].\n<strong>Esas vua responso verifikar se omna ligili esas korekta.</strong>\n\nVidez ke la pagino <strong>ne rinomizesos se existar pagino kun la sama titulo</strong>, ecepte se ol ridirektesas a la prezenta pagino e ne havas pasinta historio pri redaktado.\nTo signifikas ke vu povas retroe rinomizar pagino a lua antea nomo se ol rinomizesis erore, e ke vu ne povas supresar existanta pagino per ridirektado di altra pagino.\n\n<strong>Atencez:</strong>\nLa rinomizo povas esar drastika chanjo por pagini qui esas populara;\nhavez klara certezo pri la konsequi di la posibla rinomizo di la pagino, ante facar ol!", "movepagetalktext": "Se vu markizos ca buxo, la diskuto-pagino asociita anke modifikesos a la nova titulo, ecepte se diskuto-pagino nevakua ja existar ibe.\n\nCakaze, vu propra mustos movar la diskuto-pagino o mixar la du texti, se vu deziros.", - "movecategorypage-warning": "<strong>Atencez:</strong> Vu balde rinomizos pagino di \"KATEGORIO\". Nur la titulo di la kategorio chanjesos, ma <em>nula pagino kategoriizita segun l'anciena kategorio</em> modifikesos automatale por la nova kategorio.", + "movecategorypage-warning": "<strong>Atencez:</strong> Vu balde rinomizos pagino pri \"KATEGORIO\". Nur la titulo di la kategorio chanjesos, ma <em>nula pagino kategoriizita segun l'anciena kategorio</em> modifikesos automatale por la nova kategorio.", "movenologintext": "Vu mustas esar registragita uzero ed [[Special:UserLogin|enirir]] por rinomizar pagino.", "newtitle": "Nova titulo:", "move-watch": "Surveyar ca pagino", @@ -1969,6 +1952,7 @@ "newimages": "Galerio di nova arkivi", "imagelisttext": "Infre esas listo di '''$1''' {{PLURAL:$1|arkivo|arkivi}} rangizita $2.", "newimages-legend": "Filtrilo", + "newimages-user": "IP-adreso o nomo dil uzero", "ilsubmit": "Serchar", "bydate": "per dato", "minutes": "{{PLURAL:$1|$1 minuto|$1 minuti}}", diff --git a/languages/i18n/is.json b/languages/i18n/is.json index 029e1731f9..5cb29165b6 100644 --- a/languages/i18n/is.json +++ b/languages/i18n/is.json @@ -593,24 +593,6 @@ "resettokens-token-label": "$1 (núverandi gildi: $2)", "resettokens-done": "Lyklarnir hafa verið endurstilltir.", "resettokens-resetbutton": "Endurstilla valda lykla", - "bold_sample": "Feitletraður texti", - "bold_tip": "Feitletraður texti", - "italic_sample": "Skáletraður texti", - "italic_tip": "Skáletraður texti", - "link_sample": "Titill tengils", - "link_tip": "Innri tengill", - "extlink_sample": "http://www.dæmi.is titill tengils", - "extlink_tip": "Ytri tengill (muna að setja http:// á undan)", - "headline_sample": "Fyrirsagnartexti", - "headline_tip": "Annars stigs fyrirsögn", - "nowiki_sample": "Innsetjið ósniðinn texta hér", - "nowiki_tip": "Hunsa wiki-snið", - "image_sample": "Sýnishorn.jpg", - "image_tip": "Innfellt skjal", - "media_sample": "Sýnishorn.ogg", - "media_tip": "Tengill skjals", - "sig_tip": "Undirskrift þín auk tímasetningar", - "hr_tip": "Lárétt lína (notist sparlega)", "summary": "Breytingarágrip:", "subject": "Umræðuefni:", "minoredit": "Þetta er minniháttar breyting", diff --git a/languages/i18n/it.json b/languages/i18n/it.json index ba8f515a7c..5cbecc3f0f 100644 --- a/languages/i18n/it.json +++ b/languages/i18n/it.json @@ -547,7 +547,7 @@ "createaccountmail": "Usa una password casuale temporanea e inviala all'indirizzo di posta elettronica specificato", "createaccountmail-help": "Può essere utilizzato per creare un'utenza per un'altra persona senza doverne conoscere la password.", "createacct-realname": "Nome reale (opzionale)", - "createacct-reason": "Motivo", + "createacct-reason": "Motivo (registrato pubblicamente)", "createacct-reason-ph": "Perché stai creando un'altra utenza", "createacct-reason-help": "Messaggio visualizzato nel registro della creazione dell'utenza", "createacct-submit": "Crea la tua utenza", @@ -715,24 +715,6 @@ "resettokens-watchlist-token": "Token per il feed web (Atom/RSS) delle [[Special:Watchlist|modifiche alle pagine nei tuoi osservati speciali]]", "resettokens-done": "Token reimpostati.", "resettokens-resetbutton": "Reimposta token selezionati", - "bold_sample": "Grassetto", - "bold_tip": "Grassetto", - "italic_sample": "Corsivo", - "italic_tip": "Corsivo", - "link_sample": "Titolo del collegamento", - "link_tip": "Collegamento interno", - "extlink_sample": "http://www.example.com titolo del collegamento", - "extlink_tip": "Collegamento esterno (ricorda il prefisso http:// )", - "headline_sample": "Intestazione", - "headline_tip": "Intestazione di 2° livello", - "nowiki_sample": "Inserire qui il testo non formattato", - "nowiki_tip": "Ignora la formattazione wiki", - "image_sample": "Esempio.jpg", - "image_tip": "Incorpora file", - "media_sample": "Esempio.ogg", - "media_tip": "Collegamento a file multimediale", - "sig_tip": "Firma con data e ora", - "hr_tip": "Linea orizzontale (usare con giudizio)", "summary": "Oggetto:", "subject": "Oggetto:", "minoredit": "Questa è una modifica minore", @@ -1918,6 +1900,7 @@ "listfiles-userdoesnotexist": "L'utenza \"$1\" non è registrata.", "imgfile": "file", "listfiles": "Elenco dei file", + "listfiles_subpage": "Caricamenti di $1", "listfiles_thumb": "Miniatura", "listfiles_date": "Data", "listfiles_name": "Nome", diff --git a/languages/i18n/ja.json b/languages/i18n/ja.json index 8bd7bc052e..f143c93b54 100644 --- a/languages/i18n/ja.json +++ b/languages/i18n/ja.json @@ -145,6 +145,7 @@ "tog-useeditwarning": "変更を保存せずに編集画面から離れようとしたら警告", "tog-prefershttps": "ログインする際、常に安全な接続を使用する", "tog-showrollbackconfirmation": "巻き戻しリンクをクリックした際に確認画面を表示する", + "tog-requireemail": "パスワードの変更にはメーフアドレスが必要です", "underline-always": "常に付ける", "underline-never": "常に付けない", "underline-default": "外装またはブラウザーの既定値を使用", @@ -693,24 +694,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|あなたのウォッチリストに登録されているページの変更]]を列挙するフィード (Atom/RSS) のトークン", "resettokens-done": "トークンを再設定しました。", "resettokens-resetbutton": "選択したトークンを再設定", - "bold_sample": "太字", - "bold_tip": "太字", - "italic_sample": "斜体", - "italic_tip": "斜体", - "link_sample": "リンクの名前", - "link_tip": "内部リンク", - "extlink_sample": "http://www.example.com リンクの名前", - "extlink_tip": "外部リンク (http:// を忘れずに付けてください)", - "headline_sample": "見出し文", - "headline_tip": "2段目の見出し", - "nowiki_sample": "ここにマークアップを無効にするテキストを入力します", - "nowiki_tip": "ウィキ書式を無視", - "image_sample": "サンプル.jpg", - "image_tip": "ファイルの埋め込み", - "media_sample": "サンプル.ogg", - "media_tip": "ファイルへのリンク", - "sig_tip": "時刻印付きの署名", - "hr_tip": "水平線を挿入 (利用は控えめに)", "summary": "編集内容の要約:", "subject": "題名:", "minoredit": "細部の編集", @@ -817,6 +800,8 @@ "nocreate-loggedin": "新しいページを作成する権限がありません。", "sectioneditnotsupported-title": "節単位編集はサポートされていません", "sectioneditnotsupported-text": "このページでは節単位編集はサポートされません。", + "modeleditnotsupported-title": "編集はサポートしていません", + "modeleditnotsupported-text": "コンテンツモデル$1の編集はサポートしていません", "permissionserrors": "権限エラー", "permissionserrorstext": "あなたにはこの操作を行う権限がありません。{{PLURAL:$1|理由}}は以下の通りです:", "permissionserrorstext-withaction": "あなたには「$2」を行う権限がありません。{{PLURAL:$1|理由}}は以下の通りです:", diff --git a/languages/i18n/jam.json b/languages/i18n/jam.json index 09816828cc..389f209f02 100644 --- a/languages/i18n/jam.json +++ b/languages/i18n/jam.json @@ -380,22 +380,6 @@ "passwordreset": "Riiset paaswod‎", "passwordreset-username": "Yuuzaniem:", "passwordreset-domain": "Domien:", - "bold_sample": "Buol tex", - "bold_tip": "Buol tex", - "italic_sample": "Aitalik tex", - "italic_tip": "Aitalik tex", - "link_sample": "Lingk taikl", - "link_tip": "Intoernal lingk", - "extlink_sample": "http://www.example.com lingk taikl", - "extlink_tip": "Extoernal lingk (memba http:// priifix)", - "headline_sample": "Edlain tex", - "headline_tip": "Lebl 2 edlain", - "nowiki_sample": "Insoert nan-faamatid tex yaso", - "nowiki_tip": "Ignuor wiki faamatin", - "image_tip": "Embedid fail", - "media_tip": "Fail lingk", - "sig_tip": "Yu signicha wid taimtamp", - "hr_tip": "Arizantal lain (yuuz spierinli)", "summary": "Somari:", "subject": "Sobjik/edlain", "minoredit": "Dis a maina edit", diff --git a/languages/i18n/jut.json b/languages/i18n/jut.json index 317b5a71d4..994a17857e 100644 --- a/languages/i18n/jut.json +++ b/languages/i18n/jut.json @@ -373,22 +373,6 @@ "resetpass-submit-cancel": "Åbryd", "passwordreset": "Nullstell adgÃ¥ngskode", "passwordreset-username": "Brugenaun:", - "bold_sample": "Fied tekst", - "bold_tip": "Fied tekst", - "italic_sample": "Kursiw tekst", - "italic_tip": "Kursiw tekst", - "link_sample": "Henwisneng", - "link_tip": "Intern henwisneng", - "extlink_sample": "http://www.example.com titel pÃ¥ henwisneng", - "extlink_tip": "Ekstern henwisneng (husk http:// præfiks)", - "headline_sample": "Tekst te öweskrift", - "headline_tip": "Typ 2-øweskrift", - "nowiki_sample": "Insätt tekst her som ett skal wikiformatiirs", - "nowiki_tip": "Ignoriir wikiformatiireng", - "image_tip": "Inlejretj fil", - "media_tip": "Henwisneng te fil", - "sig_tip": "Din signatur mä tidsstempel", - "hr_tip": "Horisontal linje (brug den spÃ¥rsom)", "summary": "Sammelfattneng:", "subject": "Emn/öweskrift:", "minoredit": "Detj ä en lie øndreng", diff --git a/languages/i18n/jv.json b/languages/i18n/jv.json index 243c68cb9c..bd286c9a9c 100644 --- a/languages/i18n/jv.json +++ b/languages/i18n/jv.json @@ -32,18 +32,18 @@ "tog-numberheadings": "Wènèhi angkaning sesirah kanthi otomatis", "tog-editondblclick": "Besut kaca sarana ngeklik pindho", "tog-editsectiononrightclick": "Idinaké mbesut pérangan sarana klik tengen ing sesirahing pérangan", - "tog-watchcreations": "Wuwuh kaca gawéanku lan barkas unggahanku menyang pawawanganku", - "tog-watchdefault": "Wuwuh kaca lan barkas besutanku menyang pawawanganku", - "tog-watchmoves": "Wuwuh kaca lan barkas lih-lihanku menyang pawawanganku", - "tog-watchdeletion": "Wuwuh kaca lan barkas busakanku menyang pawawanganku", - "tog-watchuploads": "Wuwuh barkas anyar unggahanku menyang pawawanganku", + "tog-watchcreations": "Wuwuh kaca gawéanku lan berkas unggahanku menyang pawawanganku", + "tog-watchdefault": "Wuwuh kaca lan berkas besutanku menyang pawawanganku", + "tog-watchmoves": "Wuwuh kaca lan berkas lih-lihanku menyang pawawanganku", + "tog-watchdeletion": "Wuwuh kaca lan berkas busekanku menyang pawawanganku", + "tog-watchuploads": "Wuwuh berkas anyar unggahanku menyang pawawanganku", "tog-watchrollback": "Wuwuh kaca kang dakpulihaké menyang pawawanganku", "tog-minordefault": "Tengeri kabèh besutan minangka besutan cilik sacara baku", "tog-previewontop": "Deleng pratuduh sadurungé mbesut kothak", "tog-previewonfirst": "Delelng pratuduh nalika mbesut pisanan", - "tog-enotifwatchlistpages": "Kirimi aku layang-èl yèn ana kaca utawa barkas ing pawawanganku kang diowahi", + "tog-enotifwatchlistpages": "Kirimi aku layang-èl yèn ana kaca utawa berkas ing pawawanganku kang ingowahan", "tog-enotifusertalkpages": "Kirimi aku layang-èl yèn kaca parembuganku ana kang ngowahi", - "tog-enotifminoredits": "Uga kirimi aku layang-èl yèn ana besutan cilik ing kaca lan barkas", + "tog-enotifminoredits": "Uga kirimi aku layang-èl yèn ana besutan cilik ing kaca lan berkas", "tog-enotifrevealaddr": "Tuduhaké alamat layang-èlku ing layang wara-wara", "tog-shownumberswatching": "Tuduhaké cacah wong kang ngawasi", "tog-oldsig": "Tandha tanganmu kang wis cumawis:", @@ -146,12 +146,12 @@ "category-subcat-count-limited": "Kategori iki duwé {{PLURAL:$1|anak kategori|$1 anak kategori}} kaya ngisor iki.", "category-article-count": "{{PLURAL:$2|Kategori iki mung ngandhut kaca ngisor iki.|{{PLURAL:$1|Kaca|$1 kaca}} ngisor iki ana ing kategori iki saka gunggung $2 kaca.}}", "category-article-count-limited": "Kategori iki ngemu {{PLURAL:$1|kaca|$1 kaca}} kang kapacak ing isor iki.", - "category-file-count": "{{PLURAL:$2|Kategori iki mung isi barkas iki.|{{PLURAL:$1|Barkas|$1 barkas}} iki ana sajeroning kategori iki saka $2 gunggungé.}}", - "category-file-count-limited": "Kategori iki duwé {{PLURAL:$1|barkas|$1 barkas}} kang kapacak ing isor iki.", + "category-file-count": "{{PLURAL:$2|Kategori iki mung isi berkas iki.|{{PLURAL:$1|Berkas|$1 berkas}} iki ana ing jero kategori iki saka $2 gunggungé.}}", + "category-file-count-limited": "Kategori iki duwé {{PLURAL:$1|berkas|$1 berkas}} kang kapacak ing sor iki.", "listingcontinuesabbrev": "samb.", "index-category": "Kaca kaindhèks", "noindex-category": "Kaca ora kaindhèks", - "broken-file-category": "Kaca mawa pranala barkas rusak", + "broken-file-category": "Kaca mawa pranala berkas rusak", "categoryviewer-pagedlinks": "($1) ($2)", "category-header-numerals": "$1–$2", "about": "Bab", @@ -184,7 +184,7 @@ "history_short": "Sajarah", "history_small": "sajarah", "updatedmarker": "wis dianyari kawit tekaku mréné pungkasan", - "printableversion": "Vèrsi céthak", + "printableversion": "Vèrsi cithak", "permalink": "Pranala permanèn", "print": "Cithak", "view": "Deleng", @@ -209,7 +209,7 @@ "tool-link-userrights": "Owahi golongan {{GENDER:$1|panganggo}}", "tool-link-userrights-readonly": "Deleng golongan {{GENDER:$1|panganggo}}", "tool-link-emailuser": "Kirimi {{GENDER:$1|panganggo}} iki layang-é", - "imagepage": "Deleng kaca barkas", + "imagepage": "Deleng kaca berkas", "mediawikipage": "Deleng kaca layang", "templatepage": "Deleng kaca cithakan", "viewhelppage": "Deleng kaca pitulung", @@ -248,10 +248,10 @@ "portal-url": "Project:Garupa paguyuban", "privacy": "Niti privasi", "privacypage": "Project:Niti privasi", - "badaccess": "Aksès ora olèh", + "badaccess": "Masalah idin", "badaccess-group0": "Kowé ora kawogan ngayahi laku kang kojaluk.", "badaccess-groups": "Laku kang koarepi mung winates tumrap panganggo ing {{PLURAL:$2|golongan}}: $1.", - "versionrequired": "Dibutuhaké MediaWiki vèrsi $1", + "versionrequired": "Butuh MediaWiki vèrsi $1", "versionrequiredtext": "MediaWiki vèrsi $1 dibutuhaké kanggo nggunakaké kaca iki. Mangga mirsani [[Special:Version|kaca iki]]", "ok": "Oké", "pagetitle": "$1 - {{SITENAME}}", @@ -261,7 +261,7 @@ "youhavenewmessages": "{{PLURAL:$3|Kowé duwé}} $1 ($2).", "youhavenewmessagesfromusers": "{{PLURAL:$4|Kowé duwé}} $1 saka {{PLURAL:$3|panganggo liya|$3 panganggo}} ($2).", "youhavenewmessagesmanyusers": "Kowé duwé $1 saka manéka panganggo ($2).", - "newmessageslinkplural": "{{PLURAL:$1|layang anyar|999=layang anyar}}", + "newmessageslinkplural": "{{PLURAL:$1|siji layang anyar|999=layang anyar}}", "newmessagesdifflinkplural": "{{PLURAL:$1|owahan|999=owahan}} pungkasan", "youhavenewmessagesmulti": "Kowé éntuk layang anyar ing $1", "editsection": "besut", @@ -297,7 +297,7 @@ "nstab-media": "Kaca médhia", "nstab-special": "Kaca mirunggan", "nstab-project": "Kaca proyèk", - "nstab-image": "Barkas", + "nstab-image": "Berkas", "nstab-mediawiki": "Layang", "nstab-template": "Cithakan", "nstab-help": "Kaca pitulung", @@ -324,17 +324,17 @@ "readonly_lag": "Database wis dikunci mawa otomatis sawetara database sékundhèr lagi nglakoni sinkronisasi mawa database utama", "internalerror": "Masalah njero", "internalerror_info": "Masalah njero: $1", - "filecopyerror": "Ora bisa nurun barkas \"$1\" dadi \"$2\".", + "filecopyerror": "Ora bisa nurun berkas \"$1\" dadi \"$2\".", "filerenameerror": "Ora bisa ngowahi saka \"$1\" dadi \"$2\".", - "filedeleteerror": "Ora bisa mbusek barkas \"$1\".", + "filedeleteerror": "Ora bisa mbusek berkas \"$1\".", "directorycreateerror": "Ora bisa nggawé dirèktori \"$1\".", "directoryreadonlyerror": "Pérangan \"$1\" mung kena diwaca.", "directorynotreadableerror": "Pérangan \"$1\" ora kena diwaca.", - "filenotfound": "Ora bisa nemu barkas \"$1\".", + "filenotfound": "Ora bisa nemu berkas \"$1\".", "unexpected": "Biji (''nilai'') ing njabaning jangkauan: \"$1\"=\"$2\".", "formerror": "Masalah: Ora bisa ngirim formulir", "badarticleerror": "Laku iki ora bisa kalakokaké ing kaca iki.", - "cannotdelete": "Kaca utawa barkas \"$1\" ora bisa kobusek.\nBokmanawa kaca utawa barkasé wis dibusek wong liya.", + "cannotdelete": "Kaca utawa berkas \"$1\" ora bisa kobusek.\nBokmanawa kaca utawa berkasé wis dibusek wong liya.", "cannotdelete-title": "Ora bisa mbusek kaca \"$1\"", "delete-hook-aborted": "Pambusakan dibatalaké déning ''hook''.\nOra ana alesané.", "no-null-revision": "Ora isa nggawe revisi 'null' anyar kanggo kaca \"$1\"", @@ -367,12 +367,13 @@ "customcssprotected": "Kowé ora kawogan mbesut kaca CSS iki amarga ngemu setèlan pribadi panganggo liya.", "customjsprotected": "Kowé ora kawogan mbesut kaca JavaScript iki amarga ngemu setèlan pribadi panganggo liya.", "mycustomcssprotected": "Sampèyan ora duwé idin kanggo ngowah kaca CSS iki.", + "mycustomjsonprotected": "Kowé ora kawogan mbesut kaca JSON iki.", "mycustomjsprotected": "Sampèyan ora duwé idin kanggo ngowah kaca JavaScript iki.", "myprivateinfoprotected": "Sampèyan ora duwé idin kanggo ngowah informasi privat sampèyan.", "mypreferencesprotected": "Sampèyan ora duwé idin kanggo ngowah preferensi sampèyan.", "ns-specialprotected": "Kaca mirunggan ora bisa dibesut.", "titleprotected": "Irah-irahan iki direksa ora olèh digawé déning [[User:$1|$1]].\nAlesané yaiku <em>$2</em>.", - "filereadonlyerror": "Ora bisa ndandani barkas \"$1\" amarga panyimpenan barkas \"$2\" mung bisa diwaca.\n\nPangurus sistem kang ngunci iku njlèntrèhaké: \"$3\".", + "filereadonlyerror": "Ora bisa ndandani berkas \"$1\" amarga panyimpenan berkas \"$2\" mung bisa kawaca.\n\nPangurus sistem kang nggembok iku wèwèh pawadan: \"$3\".", "invalidtitle": "Sesirah ora trep", "invalidtitle-knownnamespace": "Sesirah ora trep mawa mandhala aran \"$2\" lan tulisan \"$3\"", "invalidtitle-unknownnamespace": "Sesirah ora trep mawa angka $1 lan tulisan \"$2\" mandhala aran kang ora kaweruhan", @@ -383,6 +384,8 @@ "virus-scanfailed": "''Pemindaian'' utawa ''scan'' gagal (kode $1)", "virus-unknownscanner": "antivirus buhbuhan:", "logouttext": "<strong>Kowé wis metu log.</strong>\n\nTulung gatèkaké yèn sawenèh kaca bokmanawa bakal isih katon kaya déné yèn kowé isih mlebu log, kajaba kowé mbusek telihing panglurumu.", + "logging-out-notify": "Kowé metu log, entèni sadhéla.", + "logout-failed": "Saiki ora bisa metu log: $1", "cannotlogoutnow-title": "Ora bisa metu saiki", "cannotlogoutnow-text": "Mokal metu log nalika nganggo $1.", "welcomeuser": "Sugeng Rawuh, $1!", @@ -458,7 +461,7 @@ "nosuchuser": "Ora ana panganggo mawa jeneng \"$1\".\nJeneng panganggo iku sènsitif tumrap gedhé-ciliké huruf.\nJajan priksanen pangéjamu, utawa [[Special:CreateAccount|gawénen akun anyar]].", "nosuchusershort": "Ora ana panganggo mawa asma \"$1\". Coba dipriksa manèh pasang aksarané (éjaané).", "nouserspecified": "Kowé kudu ngisi jeneng panganggo.", - "login-userblocked": "Panganggo iki pinalangan. Ora kena mbelu.", + "login-userblocked": "Panganggo iki kapenggak. Ora kena mbelu.", "wrongpassword": "Jenang panganggo utawa tembung wadi kang koisèkaké salah.\nMangga jajal manèh.", "wrongpasswordempty": "Tembung wadi kosong.\nJajalen manèh.", "passwordtooshort": "Tembung sesinglon paling sethithik cacahé {{PLURAL:$1|1 aksara|$1 aksara}}.", @@ -472,28 +475,28 @@ "noemail": "Ora ana alamat layang-èl kang kacathet tumrap ing panganggo \"$1\".", "noemailcreate": "Kowé kudu mènèhi alamat layang-èl kang trep", "passwordsent": "Tembung wadi anyar wis kinirim menyang alamat layang-èl kang kadhaftar tumrap \"$1\". \nMangga mlebu log manèh sawisé kowé nampa iku.", - "blocked-mailpassword": "Alamat IP-mu kablokir saka mbesut. Kanggo ngéndhani laku salah-guna, ora kena nganggo pamulih tembung wadi saka alamat IP iki.", + "blocked-mailpassword": "Alamat IP-mu kapenggak saka mbesut. Kanggo ngéndhani laku salah-guna, ora kena nganggo pamulih tembung wadi saka alamat IP iki.", "eauthentsent": "Layang-èl konfirmasi wis kinirim menyang alamat layang-èl kang koisèkaké. Sadurungé ana layang-èl liyané kang kinirim menyang akun iku, kowé kudu nututi panuntun ing layang-èl iku saperlu ngonfirmasi yèn akun iku pancèn duwèmu.", "throttled-mailpassword": "Layang kanggo mbalèkaké tembung wadi wis dikirim sasuwené ing {{PLURAL:$1|jam|$1 jam}}.\nKanggo nyegah ananing tumindhak culika, namung sak layang kanggo mbalèkaké tembung wadi kang bakal dikirim sasuwéné ing {{PLURAL:$1|jam|$1 jam}}.", "mailerror": "Masalah pangirim layang: $1", - "acct_creation_throttle_hit": "Para neneka menyang wiki iki kang nganggo alamat IP-né panjenengan wis gawé {{PLURAL:$1|akun cacah 1|akun cacah $1}} sajeroné $2 pungkasan, kang cacahé nyandhak cacah maksimum kang diidinaké.\nTemahané, para neneka kang nganggo alamat IP iki ora bisa gawé akun manèh sauntara iki.", - "emailauthenticated": "Alamat layang-èlé panjenengan wis dikonfirmasi ing tanggal $2 pukul $3.", - "emailnotauthenticated": "Alamat layang-èlé panjenengan durung dikonfirmasi.\nLayang-èl ora bakal dikirim yèn gegayutan karo fitur-fitur iki.", - "noemailprefs": "Panjenengan kudu milih alamat e-mail supaya bisa nganggo fitur iki.", - "emailconfirmlink": "Ndhedhes (konfirmasi) alamat e-mail panjenengan", + "acct_creation_throttle_hit": "Para neneka menyang wiki iki kang nganggo alamat IP-mu wis gawé {{PLURAL:$1|akun cacah 1|akun cacah $1}} ing dalem $2 pungkasan, kang cacahé nyandhak cacah maksimum kang kaolèhaké.\nTemahané, para neneka kang nganggo alamat IP iki ora bisa gawé akun manèh sawatara wektu iki.", + "emailauthenticated": "Alamat layang èlèktronikmu wis kakonfirmasi ing tanggal $2 pukul $3.", + "emailnotauthenticated": "Alamat layang-èlèktronikmu durung kakonfirmasi.\nLayang èlèktronik ora bakal kakirim amarga gegayutan fitur-fitur ing sor iki.", + "noemailprefs": "Isi alamat layang èlèktronikmu ing pilalanmu supaya fitur-fitur iki murub.", + "emailconfirmlink": "Konfirmasi alamat layang èlèktronikmu", "invalidemailaddress": "Alamat e-mail iki ora bisa ditampa amarga formaté ora bener. Tulung lebokna alamat mawa format kang bener utawa kosongaké waé isèn mau.", "cannotchangeemail": "Alamat layang-èl akun ora bisa diowah ing wiki iki.", "emaildisabled": "Situs iki ora bisa ngirim layang èlèktronik.", "accountcreated": "Akun wis kagawé", "accountcreatedtext": "Akun panganggo [[{{ns:User}}:$1|$1]] ([[{{ns:User talk}}:$1|rembug]]) wis digawé.", "createaccount-title": "Gawé akun kanggo {{SITENAME}}", - "createaccount-text": "Ana kang nggawé akun nganggo alamat layang-èlé panjenengan ing {{SITENAME}} ($4) kanthi aran \"$2\", mawa tembung wadi \"$3\".\nPanjenengan kudu mlebu log lan ngowahi tembung wadiné panjenengan saiki.\n\nPanjenengan kena nglirwakaké layang iki, manawa akun iki ginawé awit kaluputan.", - "login-throttled": "Panjenengan wis ping akèh njajal mlebu log.\nTulung nunggu dhisik $1 sadurungé njajal manèh.", - "login-abort-generic": "Panjenengan ora bisa mlebu log - Kawurungan", - "login-migrated-generic": "Akuné panjenengan wis dimigrasi, lan jeneng panganggoné wis ora ana manèh ing wiki iki.", + "createaccount-text": "Ana kang nggawé akun nganggo alamat layang èlèktronikmu ing {{SITENAME}} ($4) aran \"$2\", mawa tembung wadi \"$3\".\nKowé kudu mlebu log lan ngowahi tembung wadimu saiki.\n\nKowé kena nglirwakaké layang iki, manawa akun iki kagawé ora sengaja amarga luput.", + "login-throttled": "Kowé wis njajal mlebu log ping akèh.\nEntènana $1 sadurung njajal manèh.", + "login-abort-generic": "Kowé ora bisa mlebu log - Kawurungaké", + "login-migrated-generic": "Akunmu wis ingalihan, lan jeneng panganggomu wis ora ana manèh ing wiki iki.", "loginlanguagelabel": "Basa: $1", - "suspicious-userlogout": "Panjaluk panjenengan supaya metu ditolak amarga katoné panjlajah internt utawa proksi panyinggah.", - "createacct-another-realname-tip": "Jeneng asli ora kudu diisi.\nYèn diisi, jeneng asliné panjenengan bakal kanggo atribusi awit karyané panjenengan.", + "suspicious-userlogout": "Panjalukmu supaya metu log tinulak amarga panjaluké kakirim saka pangluru kang rusak utawa proksi telih.", + "createacct-another-realname-tip": "Jeneng asli ora kudu kaisi.\nYèn koisi, jeneng asliné bakal kaanggo ing atribusi tumrap karyané.", "pt-login": "Mlebu log", "pt-login-button": "Mlebu log", "pt-login-continue-button": "Banjuraké mlebu log", @@ -503,22 +506,22 @@ "user-mail-no-addy": "Njajal ngirim layang èlèktronik tanpa alamat layang èlèktronik.", "user-mail-no-body": "Nyoba ngirim layang e-mail, tapi isine kosong.", "changepassword": "Ganti tembung wadi", - "resetpass_announce": "Saperlu ngrampungaké olèhé mlebu log, panjenengan kudu nggawé tembung wadi anyar.", + "resetpass_announce": "Saperlu ngrampungaké olèhé mlebu log, kowé kudu nggawé tembung wadi anyar.", "resetpass_text": "<!-- Tambahaké teks ing kéné -->", "resetpass_header": "Ganti tembung wadining akun", "oldpassword": "Tembung wadi lawas:", "newpassword": "Tembung wadi anyar:", "retypenew": "Isi manèh tembung wadi anyaré:", "resetpass_submit": "Setèl tembung wadi lan mlebu log", - "changepassword-success": "Tembung wadiné panjenengan kasil diowah!", - "changepassword-throttled": "Panjenengan wis kakèhan njajal mlebu log.\nTulung nunggu dhisik $1 sadurungé njajal manèh.", + "changepassword-success": "Tembung wadimu bisa ingowahan!", + "changepassword-throttled": "Kowé wis njajal mlebu log ping akèh.\nEntènana $1 sadurung njajal manèh.", "botpasswords": "Tembung wadi bot", "botpasswords-disabled": "Tembung wadiné bot dipatèni.", - "botpasswords-no-central-id": "Saperlu nganggo tembung wadiné bot, panjenengan kudu mlebu log menyang akun séntral.", + "botpasswords-no-central-id": "Saperlu nganggo tembung wadiné bot, kowé kudu mlebu log akun séntral.", "botpasswords-existing": "Tembung wadiné bot kang cumepak", "botpasswords-createnew": "Gawé anyar tembung wadiné bot", "botpasswords-editexisting": "Besut tembung wadiné bot kang anyar", - "botpasswords-label-needsreset": "(tembung wadi kudu panjenengan ambali setèl)", + "botpasswords-label-needsreset": "(tembung wadi kudu kasetèl ulang)", "botpasswords-label-appid": "Jeneng bot:", "botpasswords-label-create": "Gawé", "botpasswords-label-update": "Anyari", @@ -528,12 +531,13 @@ "botpasswords-bad-appid": "Jeneng bot \"$1\" ora trep.", "botpasswords-insert-failed": "Wurung nambah jeneng bot \"$1\". Apa wis tinambahaké sadurungé?", "resetpass_forbidden": "Tembung wadi ora bisa diganti", - "resetpass-no-info": "Panjenengan kudu mlebu log saperlu langsung ngaksès kaca iki.", + "resetpass-no-info": "Kowé kudu mlebu log saperlu ngaksès kaca iki langsung.", "resetpass-submit-loggedin": "Ganti tembung wadi", "resetpass-submit-cancel": "Wurung", - "resetpass-wrong-oldpass": "Tembung wadi saiki utawa sauntara ora trep.\nPanjengen bokmanawa wis ngganti tembung wadiné panjenengan utawa nyuwun tembung wadi sauntara kang anyar.", + "resetpass-wrong-oldpass": "Tembung wadi saiki utawa sadhéla ora trep.\nKowé bokmanawa wis ngganti tembung wadimu utawa njaluk tembung wadi sadhéla kang anyar.", "resetpass-temp-password": "Tembung wadi sauntara:", "resetpass-abort-generic": "Ngowahi tembung wadi kawurungaké déning èkstènsi.", + "resetpass-expired": "Tembung wadimu wis kadaluwarsa. Setèl tembung wadi anyar saperlu mlebu log.", "passwordreset": "Balèni gawé tembung wadi", "passwordreset-text-one": "Isi formulir iki kanthi jangkep kanggo nampa tembung wadi sauntara lumantar layang-èl.", "passwordreset-text-many": "{{PLURAL:$1|Isi salah siji babagan ing ngisor iki supaya bisa nampa tembung wadi sauntara lumantar layang-èl.}}", @@ -548,6 +552,9 @@ "passwordreset-emailelement": "Jeneng panganggo: \n$1\n\nTembung wadi sauntara: \n$2", "passwordreset-emailsentemail": "Yèn layang èlèktronik iki nggayut akun panjenengan, layang kanggo salin tembung wadi bakal dikirim.", "passwordreset-emailsentusername": "Manawa ana alamat layang-èl kang ana gayutané karo jeneng panganggo iki, layang-èl kanggo nyetèl ulang tembung wadi bakal dikirim.", + "passwordreset-nocaller": "Panyeluk kudu kaisi", + "passwordreset-nosuchcaller": "Panyeluk ora ana: $1", + "passwordreset-invalidemail": "Alamat layang èlèktronik ora trep", "changeemail": "Owah utawa busak alamat layang-èl", "changeemail-header": "Isi formulir iki saperlu salin alamat layang-èl panjenengan. Manawa panjenengan péngin ngilangi gegayutané alamat layang-èl saka akuné panjenengan, kosongaké waé babagan layang-èl anyar nalika ngirim formuliré.", "changeemail-no-info": "Panjenengan kudu mlebu log kanggo ngaksès kaca iki langsung.", @@ -565,24 +572,6 @@ "resettokens-watchlist-token": "Token kangge sindikasi web (Atom/RSS) saking [[Special:Watchlist|pangowahan ing pawawangané panjenengan]]", "resettokens-done": "Reset token.", "resettokens-resetbutton": "Reset token kang dipilih", - "bold_sample": "Tulisan kandel", - "bold_tip": "Tulisan kandel", - "italic_sample": "Tulisan dhoyong", - "italic_tip": "Tulisan dhoyong", - "link_sample": "Sesirah pranala", - "link_tip": "Pranala njero", - "extlink_sample": "http://www.example.com sesirahing pranala", - "extlink_tip": "Pranala jaba (élinga ater-ater http://)", - "headline_sample": "Tulisan sesirah", - "headline_tip": "Sesirah tataran 2", - "nowiki_sample": "Isi nganggo tulisan tanpa format ing kéné", - "nowiki_tip": "Aja nganggo format wiki", - "image_sample": "Conto.jpg", - "image_tip": "Barkas sisipan", - "media_sample": "Conto.ogg", - "media_tip": "Pranala barkas", - "sig_tip": "Tapak asmané panjenengan mawa tandha wektu", - "hr_tip": "Garis horisontal", "summary": "Ringkesan:", "subject": "Jejer:", "minoredit": "Iki besutan cilik", @@ -607,8 +596,8 @@ "summary-preview": "Pratuduh ringkesan besutan:", "subject-preview": "Pratuduh jejer:", "previewerrortext": "Ana masalah nalika njajal mratuduhaké owahané panjenengan.", - "blockedtitle": "Panganggo kapalangan", - "blockedtext": "<b>Asma panganggo utawa alamat IP panjenengan diblokir.</b>\n\nBlokir iki kang nglakoni $1.\nAlesané <i>$2</i>.\n\n* Diblokir wiwit: $8\n* Kadaluwarsa pemblokiran ing: $6\n* Kang arep diblokir: $7\n\nPanjenengan bisa ngubungi $1 utawa [[{{MediaWiki:Grouppage-sysop}}|pangurus liyané]] kanggo ngomongaké prakara iki.\n\nPanjenengan ora bisa nggunakaké fitur 'Kirim layang é-mail panganggo iki' kejaba panjenengan wis nglebokaké alamat é-mail kang trep ing [[Special:Preferences|prèferènsi]] panjenengan.\n\nAlamat IP panjenengan iku $3, lan ID pamblokiran iku #$5.\nTulung kabèh informasi ing ndhuwur iki disertakaké ing saben pitakon panjenengan.", + "blockedtitle": "Panganggo kapenggak", + "blockedtext": "<strong>Aran panganggomu utawa alamat IP-mu kapenggak.</strong>\n\nKang menggak ya iku $1.\nDhedhasaré <i>$2</i>.\n\n* Kapenggak wiwit: $8\n* Kapenggak nganti: $6\n* Kang arep diblokir: $7\n\nPanjenengan bisa ngubungi $1 utawa [[{{MediaWiki:Grouppage-sysop}}|pangurus liyané]] kanggo ngomongaké prakara iki.\n\nPanjenengan ora bisa nggunakaké fitur 'Kirim layang é-mail panganggo iki' kejaba panjenengan wis nglebokaké alamat é-mail kang trep ing [[Special:Preferences|prèferènsi]] panjenengan.\n\nAlamat IP panjenengan iku $3, lan ID pamblokiran iku #$5.\nTulung kabèh informasi ing ndhuwur iki disertakaké ing saben pitakon panjenengan.", "autoblockedtext": "Alamat IP-né panjenangan wis otomatis diblokir amarga dienggo déning panganggo liyané, kang diblokir déning $1.\n\n:<em>$2</em>\n\n* Wiwit diblokir: $8\n* Rampung diblokir: $6\n* Kang diblokir: $7\n\nPanjenengan bisa ngubungi $1 utawa [[{{MediaWiki:Grouppage-sysop}}|pangurus]] liyané kanggo ngrembug blokirané.\n\nPanjenengan ora bisa nganggo fitur \"kirim layang-èl panganggo iki\" kajaba panjenengan wis ndhaftaraké alamat layang-èl kang trep ing [[Special:Preferences|pilalan panganggoné]] panjenengan lan panjenengan durung tau diblokir nalika nganggo iku.\n\nAlamat IP-né panjenengan kang saiki ya iku $3, lan ID blokirané ya iku $5. \nMangga wuwuhen kabèh rerincèn ing ndhuwur sajeroné samubarang pitakoné panjenengan.", "blockednoreason": "ora ana alesan kang diwènèhaké", "whitelistedittext": "Mangga $1 dhisik yèn arep mbesut kaca.", @@ -628,7 +617,7 @@ "missing-revision": "Révisi #$1 saka kaca aran \"{{FULLPAGENAME}}\" ora ana.\n\nIki biyasané kasababaké awit nututi pranala sajarah kang wis lawas saka kaca kang wis binusek.\nRerincèné bisa digolèki ing [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} log besakan].", "userpage-userdoesnotexist": "Akun panganggo \"$1\" ora kadhaftar.\nMangga pesthèkaké dhisik yèn panjenengan péngin nggawé/mbesut kaca iki.", "userpage-userdoesnotexist-view": "Akun panganggo \"$1\" ora kadhaftar.", - "blocked-notice-logextract": "Panganggo iki saiki lagi diblokir.\nLog pamblokiran pungkasan dituduhaké ing ngisor iki minangka bahan rujukan:", + "blocked-notice-logextract": "Panganggo iki lagi kapenggak.\nÈntri log penggakan kang pungkasan cumawis ing sor iki minangka rujukan:", "clearyourcache": "<strong>Cathetan:</strong> Nalika rampung nyimpen, panjenengan kudu mbusek telihing pangluruné panjenengan supaya owahané katon.\n* <strong>Firefox / Safari:</strong> Pencèt <em>Shift</em> nalika ngeklik <em>Reload</em>, utawa pencèt <em>Ctrl-F5</em> utawa <em>Ctrl-R</em> (<em>⌘-R</em> ing Mac)\n* <strong>Google Chrome:</strong> Pencèt <em>Ctrl-Shift-R</em> (<em>⌘-Shift-R</em> ing Mac)\n* <strong>Internet Explorer:</strong> Pencèt <em>Ctrl</em> nalika ngeklik <em>Refresh</em>, utawa pencèt <em>Ctrl-F5</em>\n* <strong>Opera:</strong> Menyang <em>Menu → Settings</em> (<em>Opera → Preferences</em> ing Mac) nuli menyang <em>Privacy & security → Clear browsing data → Cached images and files</em>.", "usercssyoucanpreview": "'''Tips:''' Gunakna tombol \"{{int:showpreview}}\" kanggo ngetès CSS anyar panjenengan sadurungé disimpen.", "userjsyoucanpreview": "'''Tips:''' Gunakna tombol \"{{int:showpreview}}\" kanggo ngetès JavaScript anyar panjenengan sadurungé disimpen.", @@ -659,7 +648,7 @@ "copyrightwarning": "Tulung dipun-gatèkaké manawa kabèh sumbangsih utawa kontribusi kanggo {{SITENAME}} iku dianggep wis diluncuraké miturut $2 GNU (mangga priksanen $1 kanggo ditèlé).\nManawa panjenengan ora karsa manawa tulisan panjenengan bakal disunting karo disebar, aja didokok ing kéné.<br />\nPanjenengan uga janji manawa apa-apa kang katulis ing kéné, iku karyané panjenengan dhéwé, utawa disalin saka sumber bébas. '''AJA NDOKOK KARYA KANG DIREKSA DÉNING UNDHANG-UNDHANG HAK CIPTA TANPA IDIN!'''", "copyrightwarning2": "Mangga digatèkaké yèn kabèh kontribusi marang {{SITENAME}} bisa disunting, diowahi, utawa dibusek penyumbang liyané. Yèn panjenengan ora karsa yèn tulisan panjenengan bisa disunting wong liya, aja ngirim artikel panjenengan ing kéné.<br />Panjenengan uga janji yèn tulisan panjenengan iku kasil karya panjenengan dhéwé, utawa disalin saka sumber umum utawa sumber bébas liyané (mangga delengen $1 kanggo informasi sabanjuré). '''AJA NGIRIM KARYA KANG DIREKSA DÉNING UNDHANG-UNDHANG HAK CIPTA TANPA IDIN!'''", "longpageerror": "'''Masalah: Tèks kang panjenengan lebokaké dawané {{PLURAL:$1|sak kilobita|$1 kilobita}}, luwih dawa saka maksimal {{PLURAL:$2|sak kilobita|$2 kilobita}}.'''\nKang mangkono ora bisa kasimpen.", - "readonlywarning": "<strong>Pepéling: Basis dhatah lagi ginembok amarga lagi karukti, mula panjenengan saiki ora bisa nyimpen besutané panjenengan.</strong>\nPanjenengan bokmanawa arep nurun tulisané panjenengan ing barkas tèks lan nyimpen iku kanggo mengko.\n\nPangurus kang nggembok basis dhatahé mènèhi panjlèntrèh mengkéné: $1", + "readonlywarning": "<strong>Pepéling: Sasana dhatah lagi ginembok amarga lagi karukti, mula kowé saiki ora bisa nyimpen besutanmu.</strong>\nKowé bokmanawa arep nurun tulisanmu menyang berkas tulisan lan nyimpen iku kanggo mengko.\n\nPangurus sistem kang nggembok iku wèwèh pawadan: $1", "protectedpagewarning": "<strong>Pélik: Kaca iki wis direksa, mula mung panganggo mawa hak mirunggan pangurus kang bisa mbesut.</strong>\nÈntri log kang pungkasan ana ing ngisor iki minangka rujukan:", "semiprotectedpagewarning": "<strong>Cathetan:</strong> Kaca iki pinuju direksa, mula mung panganggo kang kadhaftar kang bisa mbesut.\nÈntri log pungkasan cumepak ana ing ngisor kanggo rujukan:", "cascadeprotectedwarning": "<strong>Pènget:</strong> Kaca iki wis direksa saéngga mung panganggo kanthi hak pangurus waé kang bisa mbesut amarga kaca iki katranklusi ing {{PLURAL:$1|kaca|kaca-kaca}} kang kareksa runut ngisor iki:", @@ -688,8 +677,8 @@ "edit-no-change": "Besutané panjenengan dilirwakaké amarga ora ana owahan apa-apa tumraping tèksé.", "postedit-confirmation-created": "Kaca wis kagawé.", "postedit-confirmation-restored": "Kacané wis kapulihaké.", - "postedit-confirmation-saved": "Besutané panjenengan wis kasimpen.", - "postedit-confirmation-published": "Besutané panjenengan wis kababar.", + "postedit-confirmation-saved": "Besutanmu wis kasimpen.", + "postedit-confirmation-published": "Besutanmu wis kababar.", "edit-already-exists": "Ora bisa nggawé kaca anyar.\nKacané wis ana.", "defaultmessagetext": "Tèks layang gawan", "content-failed-to-parse": "Gagal menjabarkan konten $2 untuk model $1: $3", @@ -728,7 +717,7 @@ "undo-norev": "Besutan iki ora bisa diwurungaké amarga wis ora ana utawa wis binusek.", "undo-summary": "Mbalèkaké owahan $1 déning [[Special:Contributions/$2|$2]] ([[User talk:$2|rembugan]])", "undo-summary-username-hidden": "Balèkaké owahan $1 déning panganggo kang didhelikaké", - "cantcreateaccount-text": "Saka alamat IP iki ('''$1''') ora diparengaké nggawé akun utawa kang. Kang mblokir utawa ora marengaké iku [[User:$3|$3]].\n\nAlesané miturut $3 yaiku ''$2''", + "cantcreateaccount-text": "Panggawéning akun saka alamat IP iki (<strong>$1</strong>) wis dipenggak [[User:$3|$3]].\n\nDhedhasaré pamenggak miturut $3 iku ''$2''", "cantcreateaccount-range-text": "Nggawe akun saka alamat IP \"$1\", kang kalebu IP panjenengan (<strong>$4</strong>), wis diblokir kaliyan [[User:$3|$3]].\n\nAlesan pamblokiran yaiku \"$2\"", "viewpagelogs": "Deleng cathetaning kaca iki", "nohistory": "Babading besutan kaca iki ora ana.", @@ -776,8 +765,8 @@ "revisiondelete": "Busak/wurung busak révisi", "revdelete-nooldid-title": "Révisi tujuan ora trep", "revdelete-nooldid-text": "Panjenengan durung mènèhi target revisi kanggo nglakoni fungsi iki.", - "revdelete-no-file": "Barkas kang panjenengan karsakaké ora ana.", - "revdelete-show-file-confirm": "Apa panjenengan yakin arep mriksa révisi kang kabusek saka barkas \"<nowiki>$1</nowiki>\" nalika $2 jam $3?", + "revdelete-no-file": "Berkas kang koarepi ora ana.", + "revdelete-show-file-confirm": "Apa kowé yakin arep mriksa révisi kang kabusek saka berkas \"<nowiki>$1</nowiki>\" nalika $2 pukul $3?", "revdelete-show-file-submit": "Iya", "logdelete-selected": "{{PLURAL:$1|Log kapilih|Log kapilih}} kanggo:", "revdelete-text-others": "Administrator liya isih bisa ngaksès isian ndhelik lan mulihaké iku saka pambusakan, kajaba rereksan tambahan disetèl.", @@ -785,7 +774,7 @@ "revdelete-suppress-text": "Pandhelikan révisi '''mung''' bisa dipigunakaké kanggo kasus ing ngisor:\n* Informasi kang kagolong pitnah\n* Informasi pribadi kang kurang pantes\n*: ''alamat omah lan nomer telepon, nomer kartu idhèntitas, lsp..''", "revdelete-legend": "Atur watesan:", "revdelete-hide-text": "Tulisan owahan", - "revdelete-hide-image": "Dhelikaké isi barkas", + "revdelete-hide-image": "Dhelikaké isining berkas", "revdelete-hide-name": "Dhelikaké tujuan lan paramèter", "revdelete-hide-comment": "Tingkesan besutan", "revdelete-hide-user": "Alamat IPné/jeneng panganggoné kang mbesut", @@ -885,15 +874,15 @@ "searchprofile-everything": "Kabèh", "searchprofile-advanced": "Lungidan", "searchprofile-articles-tooltip": "Golèkan ing $1", - "searchprofile-images-tooltip": "Golèk barkas", + "searchprofile-images-tooltip": "Golèk berkas", "searchprofile-everything-tooltip": "Golèk kabèh kontèn (kalebu ing kaca parembugan)", "searchprofile-advanced-tooltip": "Golèk ing mandhala aran tinamtu", "search-result-size": "$1 ({{PLURAL:$2|1 tembung|$2 tembung}})", - "search-result-category-size": "{{PLURAL:$1|1 anggota|$1 anggota}} ({{PLURAL:$2|1 subkategori|$2 subkategori}}, {{PLURAL:$3|1 barkas|$3 barkas}})", + "search-result-category-size": "{{PLURAL:$1|1 warga|$1 warga}} ({{PLURAL:$2|1 subkategori|$2 subkategori}}, {{PLURAL:$3|1 berkas|$3 berkas}})", "search-redirect": "(alihan saka $1)", "search-section": "(pérangan $1)", "search-category": "(kategori $1)", - "search-file-match": "(cocog karo isi barkas)", + "search-file-match": "(cocog karo isi berkas)", "search-suggest": "Apa kang panjenengan karsakaké iki: $1", "search-rewritten": "Tuduhaké kasilé $1, nanging golèkaké $2.", "search-interwiki-caption": "Kasil saka proyèk-proyèk sababon", @@ -981,7 +970,7 @@ "prefs-searchoptions": "Golèk", "prefs-namespaces": "Mandhala aran", "default": "baku", - "prefs-files": "Barkas", + "prefs-files": "Berkas", "prefs-custom-css": "CSS priangga", "prefs-custom-js": "JavaScript priangga", "prefs-common-config": "CSS/JS barengan kabèh ules:", @@ -1046,8 +1035,8 @@ "userrights-reason": "Alesan:", "userrights-no-interwiki": "Panjenengan ora ana hak kanggo ngowahi hak panganggo ing wiki liyané.", "userrights-nodatabase": "Basis dhatah $1 ora ana utawa ora enggonan.", - "userrights-changeable-col": "Grup kang bisa panjenengan owahi", - "userrights-unchangeable-col": "Grup kang ora bisa diowahi panjenengan", + "userrights-changeable-col": "Golongan kang bisa koowahi", + "userrights-unchangeable-col": "Golongan kang ora bisa koowahi", "userrights-irreversible-marker": "$1*", "userrights-no-shorten-expiry-marker": "$1#", "userrights-expiry-current": "Kadaluwarsa $1", @@ -1058,7 +1047,7 @@ "userrights-expiry-options": "1 dina:1 dina,1 minggu:1 minggu,1 wulan:1 wulan,3 wulan:3 wulan,6 wulan:6 wulan,1 taun:1 taun", "userrights-invalid-expiry": "Wektu kadaluwarsa golongan \"$1\" ora trep.", "userrights-expiry-in-past": "Wektu kadaluwarsa golongan \"$1\" ana ing kala kawuri.", - "userrights-conflict": "Konflik pangowahan hak-hak panganggo! Tulung ditinjau maneh lan konfirmasi owah-owahané panjenengan.", + "userrights-conflict": "Cengkah owahan hak panganggo! Mangga priksa lan konfirmasi owahanmu.", "group": "Golongan:", "group-user": "Para panganggo", "group-autoconfirmed": "Panganggo kang otomatis kakonfirmasi", @@ -1090,13 +1079,13 @@ "right-move-subpages": "Pindhahaké kaca lan kabèh anak-kacané", "right-move-rootuserpages": "Ngalih kaca panganggo oyod", "right-move-categorypages": "Lih kaca kategori", - "right-movefile": "Lih barkas", + "right-movefile": "Lih berkas", "right-suppressredirect": "Aja nggawé pangalihan saka kaca kang lawas yèn mindhah kaca", - "right-upload": "Unggah barkas", - "right-reupload": "Tindhihana barkas kang ana", - "right-reupload-own": "Nimpa barkas kang ana lan diunggah panganggo kang padha", - "right-reupload-shared": "Timpanana barkas ing panyimpenan médhiya barengan lokal", - "right-upload_by_url": "Ngunggahaké barkas saka alamat URL", + "right-upload": "Unggah berkas", + "right-reupload": "Tindhihi berkas kang ana", + "right-reupload-own": "Tindhihi berkas kang ana kang diunggah siji wong", + "right-reupload-shared": "Tindhihi berkas ing panyimpenan médhiyah barengan lokal", + "right-upload_by_url": "Unggah berkas saka URL", "right-purge": "Kosongna ''cache'' situs iki kanggo kaca tanpa konfirmasi", "right-autoconfirmed": "Owah kaca-kaca sémi-reksa", "right-bot": "Anggepen minangka prosès otomatis", @@ -1124,22 +1113,22 @@ "right-editsemiprotected": "Owah kaca kang kareksa \"{{int:protect-level-autoconfirmed}}\"", "right-editcontentmodel": "Besut modhèl kontèn kaca", "right-editinterface": "Besut antarmuka panganggo", - "right-editusercss": "Besut barkas-barkas CSS panganggo liya", - "right-edituserjson": "Besut barkas-barkas JSON panganggo liya", - "right-edituserjs": "Besut barkas-barkas JavaScript panganggo liya", - "right-editmyusercss": "Owahi barkas CSS panganggo panjenengan", - "right-editmyuserjson": "Owahi barkas JSON panganggo panjenengan", - "right-editmyuserjs": "Owahi barkas JavaScript panganggo panjenengan", - "right-viewmywatchlist": "Deleng pawawangané panjenengan", + "right-editusercss": "Besut berkas CSS panganggo liya", + "right-edituserjson": "Besut berkas JSON panganggo liya", + "right-edituserjs": "Besut berkas JavaScript panganggo liya", + "right-editmyusercss": "Besut berkas CSS panganggomu", + "right-editmyuserjson": "Besut berkas JSON panganggomu", + "right-editmyuserjs": "Besut berkas JavaScript panganggomu", + "right-viewmywatchlist": "Deleng pawawanganmu", "right-editmywatchlist": "Owahi pawawangané panjenengan. Cathetan: ana cara liyane kanggo nambahi kaca menyang pratélan, sanadyan ora duwe hak iki.", "right-viewmyprivateinfo": "Deleng dhata prianggané panjenengan dhéwé (kaya ta alamat layang-èl, jeneng asli)", "right-editmyprivateinfo": "Besut dhata prianggané panjenengan dhéwé (kaya ta alamat layang-èl, jeneng asli)", - "right-editmyoptions": "Owahi pilalané panjenengan", + "right-editmyoptions": "Besut pilalanmu dhéwé", "right-rollback": "Balèkaké kanthi gelis besutaning panganggo pungkasan kang mbesut kaca tinamtu", "right-markbotedits": "Tandhani besutan kang kawurungan yèn besutan bot", "right-noratelimit": "Ora kadayan watesing cacah besutan.", "right-import": "Impor kaca-kaca saka wiki liya", - "right-importupload": "Impor kaca saka unggahan barkas", + "right-importupload": "Impor kaca saka unggahan berkas", "right-patrol": "Tandhani besutané wong liya yèn wis kapriksa", "right-autopatrol": "Gawé supaya besutan otomatis tinengeran wis kapriksa", "right-patrolmarks": "Ndeleng tandha-tandha patroli owah-owahan anyar", @@ -1152,12 +1141,12 @@ "right-sendemail": "Ngirim layang listrik (e-mail) menyang panganggo liya", "grant-group-page-interaction": "Srawungan karo kaca", "grant-group-file-interaction": "Srawungan karo médhia", - "grant-group-watchlist-interaction": "Srawungan karo pawawangané panjenengan", + "grant-group-watchlist-interaction": "Srawung karo pawawanganmu", "grant-group-email": "Kirim layang-èl", "grant-group-high-volume": "Ngayahi kagiyatan kang akih", "grant-group-customization": "Panglarasan lan pilalan", "grant-group-administration": "Ngayahi laku administratif", - "grant-group-private-information": "Ngaksès dhata pribadhi ngenani panjenengan", + "grant-group-private-information": "Aksès dhatah pribadi bab kowé", "grant-group-other": "Kagiyatan rena-rena", "grant-blockusers": "Blokir lan uculaké blokirané panganggo", "grant-createaccount": "Gawé akun", @@ -1166,7 +1155,7 @@ "grant-editinterface": "Besut jagad aran MediaWiki lan CSS/JavaScript panganggo", "grant-editmycssjs": "Besut CSS/JavaScript panganggomu", "grant-editmyoptions": "Besut préferènsi panganggomu", - "grant-editmywatchlist": "Besut pawawangané panjenengan", + "grant-editmywatchlist": "Besut pawawangmu", "grant-editpage": "Besut kaca kang ana", "grant-editprotected": "Besut kaca kang kareksa", "grant-highvolume": "Besutan gedhi", @@ -1176,11 +1165,11 @@ "grant-protect": "Reksa lan uculi rereksané kaca", "grant-rollback": "Wurungaké owahané kaca", "grant-sendemail": "Kirim layang-èl menyang panganggo liyané", - "grant-uploadeditmovefile": "Unggah, ganti, lan lih barkas", - "grant-uploadfile": "Unggah barkas anyar", + "grant-uploadeditmovefile": "Unggah, ganti, lan lih berkas", + "grant-uploadfile": "Unggah berkas anyar", "grant-basic": "Hak pokok", - "grant-viewdeleted": "Deleng barkas lan kaca kang kabusek", - "grant-viewmywatchlist": "Deleng pawawangané panjenengan", + "grant-viewdeleted": "Deleng berkas lan kaca kang kabusek", + "grant-viewmywatchlist": "Deleng pawawanganmu", "grant-viewrestrictedlogs": "Deleng isian log kang winates", "newuserlogpage": "Log panganggo anyar", "newuserlogpagetext": "Ing ngisor iki kapacak log pandaftaran panganggo anyar.", @@ -1198,11 +1187,11 @@ "action-move-subpages": "lih kaca iki, lan anak-kacané", "action-move-rootuserpages": "ngalih kaca panganggo oyod", "action-move-categorypages": "alih kaca kategori", - "action-movefile": "alih barkas iki", - "action-upload": "ngunggah barkas iki", - "action-reupload": "nindhih barkas kang wis ana", - "action-reupload-shared": "nindhih barkas kang wis ana ing papan panyimpanan barkas kang dianggo bebarengan", - "action-upload_by_url": "unggahna barkas iki saka alamat URL", + "action-movefile": "ngalih berkas iki", + "action-upload": "ngunggah berkas iki", + "action-reupload": "nindhihi berkas kang ana iki", + "action-reupload-shared": "nindhihi berkas kang ana ing panyimpanan barengan iki", + "action-upload_by_url": "ngunggah berkas iki saka URL", "action-writeapi": "migunakaké API panulisan", "action-delete": "busak kaca iki", "action-deleterevision": "busak révisi", @@ -1217,17 +1206,17 @@ "action-protect": "owahi tataran rereksané kaca iki", "action-rollback": "gelis mbalèkaké suntingané panganggo pungkasan ing kaca tinamtu", "action-import": "impor kaca saka wiki liyané", - "action-importupload": "impor kaca iki saka pamunggahan barkas", + "action-importupload": "impor kaca saka unggahan berkas", "action-patrol": "nandhani besutan wong liya yèn wis kapriksa", - "action-autopatrol": "nandhani besutané panjenengan dhéwé yèn wis kapriksa", + "action-autopatrol": "nandhani besutanmu yèn wis kapriksa", "action-unwatchedpages": "deleng pratélan kaca kang ingawasan", "action-mergehistory": "nggabungaké sajarah kaca iki", "action-userrights": "besut kabèh hak panganggo", "action-userrights-interwiki": "besut hak aksès panganggo ing wiki liyané", "action-siteadmin": "nggembok utawa mbukak gembok basis dhatah", "action-sendemail": "kirim layang-èl", - "action-editmyoptions": "besut pilalané panjenengan", - "action-editmywatchlist": "owahi pawawangané panjenengan", + "action-editmyoptions": "besut pilalanmu", + "action-editmywatchlist": "besut pawawanganmu", "action-viewmywatchlist": "deleng pawawangané panjenengan", "action-viewmyprivateinfo": "deleng katerangan prianggané panjenengan", "action-editmyprivateinfo": "besut katerangan prianggané panjenengan", @@ -1301,10 +1290,10 @@ "rcfilters-filterlist-noresults": "Saringan ora katemu", "rcfilters-noresults-conflict": "Ora ana kasil amarga wewatoné kanggo nggolèk ana masalah", "rcfilters-filtergroup-authorship": "Pangripta besutan", - "rcfilters-filter-editsbyself-label": "Owah-owahané panjenengan", + "rcfilters-filter-editsbyself-label": "Owah-owahanmu", "rcfilters-filter-editsbyself-description": "Pasumbangmu dhéwé.", "rcfilters-filter-editsbyother-label": "Owah-owahané liyan", - "rcfilters-filter-editsbyother-description": "Kabèh owahan kajaba duwèké panjenengan.", + "rcfilters-filter-editsbyother-description": "Kabèh owahan kajaba duwému.", "rcfilters-filtergroup-user-experience-level": "Pandhaftaran lan pangalaman pangguna", "rcfilters-filter-user-experience-level-registered-label": "Kadhaftar", "rcfilters-filter-user-experience-level-registered-description": "Pambesut kang mlebu log.", @@ -1330,7 +1319,7 @@ "rcfilters-filter-major-description": "Besutan kang ora ditandhani minangka besutan cilik.", "rcfilters-filtergroup-watchlist": "Kaca ing pawawangan", "rcfilters-filter-watchlist-watched-label": "Ana ing Pawawangan", - "rcfilters-filter-watchlist-watched-description": "Owahané kaca-kaca ing Pawawangané panjenengan.", + "rcfilters-filter-watchlist-watched-description": "Owahaning kaca-kaca ing Pawawanganmu.", "rcfilters-filter-watchlist-watchednew-label": "Owah-owahané Pawawangan anyar", "rcfilters-filter-watchlist-watchednew-description": "Owah-owahan ngenani kaca-kaca ing Pawawangané panjenengan kang durung ditiliki.", "rcfilters-filter-watchlist-notwatched-label": "Ora ana ing Pawawangan", @@ -1400,46 +1389,46 @@ "recentchanges-page-removed-from-category": "[[:$1]] dibusak saka kategori", "recentchanges-page-removed-from-category-bundled": "[[:$1]] dibusak saka kategori, [[Special:WhatLinksHere/$1|kaca iki kalebu ing njeroné kaca liyané]]", "autochange-username": "Salin otomatis MediaWiki", - "upload": "Unggah barkas", - "uploadbtn": "Unggah barkas", + "upload": "Unggah berkas", + "uploadbtn": "Unggah berkas", "reuploaddesc": "Wurung ngunggah lan bali menyang formulir unggahan", - "upload-tryagain": "Kirim déskripsi barkas kang wis diowah", + "upload-tryagain": "Kirim wedharan barkas kang wis kadandani", "uploadnologin": "Durung mlebu log", - "uploadnologintext": "Sumangga $1 saperlu ngunggah barkas.", + "uploadnologintext": "Mangga $1 saperlu ngunggah berkas.", "upload_directory_missing": "Dhirèktori unggahan ($1) ora tinemu lan ora bisa digawé déning server wèb.", "upload_directory_read_only": "Dhirèktori pangunggahan ($1) ora bisa ditulis déning paladèn jaringan.", "uploaderror": "Masalah pangunggah", - "upload-recreate-warning": "'''Pèngetan: Barkas mawa jeneng iku wis dibusak utawa disingkiraké.'''\n\nLog pambusakan lan panyingkiran saka kaca iki sumadhiya ing kéné:", + "upload-recreate-warning": "<strong>Pepéling: Siji berkas mawa aran mangkono wis binusek utawa ingalihan.</strong>\n\nLog busekan lan lih-lihan tumrap kaca iki cumawis ing kéné:", "uploadtext": "Anggonen formulir ngisor iki saperlu ngunggah barkas.\nKanggo ndeleng utawa nggolèki barkas kang wis diunggah sadurungé, panjenengan menyanga [[Special:FileList|pratélan barkas unggahan]]. Barkas unggahan ulang uga kacathet ing [[Special:Log/upload|log unggah]], déné barkas busakan ing [[Special:Log/delete|log busak]].\n\nKanggo muwuhi barkas ing kaca, anggonen pranala kanthi formulir ing ngisor iki, pilih salah siji:\n* <strong><code><nowiki>[[</nowiki>{{ns:file}}<nowiki>:File.jpg]]</nowiki></code></strong> saperlu nganggo barkasé kanthi vèrsi kang wutuh\n* <strong><code><nowiki>[[</nowiki>{{ns:file}}<nowiki>:File.png|200px|thumb|left|alt text]]</nowiki></code></strong> saperlu nganggo barkasé kanthi amba 200 piksel déné ana ing njeron kothak lan kapacak ing sisih kiwané kaca mawa \"alt text\" minangka katerangané\n* <strong><code><nowiki>[[</nowiki>{{ns:media}}<nowiki>:File.ogg]]</nowiki></code></strong> saperlu nggayutaké langsung barkasé tanpa mitontonaké barkasé dhéwé", - "upload-permitted": "{{PLURAL:$2|Jinis}} barkas kang kaolèhaké: $1.", - "upload-preferred": "{{PLURAL:$2|Jinis}} barkas kang kaprayogakaké: $1.", - "upload-prohibited": "{{PLURAL:$2|Jinis}} barkas kang kalarang: $1.", + "upload-permitted": "{{PLURAL:$2|Jinis}} berkas kang kaolèhaké: $1.", + "upload-preferred": "{{PLURAL:$2|Jinis}} berkas kang kaprayogakaké: $1.", + "upload-prohibited": "{{PLURAL:$2|Jinis}} berkas kang kalarang: $1.", "uploadlogpage": "Log unggah", - "uploadlogpagetext": "Ing ngisor iki kapacak log pangunggahan barkas kang anyar dhéwé.\nMangga mirsani [[Special:NewFiles|galeri barkas anyar]] kanggo pratélan visual.", - "filename": "Jeneng barkas", + "uploadlogpagetext": "Ing sor iki kapacak log unggahan berkas kang anyar dhéwé.\nDeleng [[Special:NewFiles|gladri berkas anyar]] kapurih luwih cethané.", + "filename": "Aran berkas", "filedesc": "Ringkesan", "fileuploadsummary": "Ringkesan:", - "filereuploadsummary": "Owah-owahan barkas:", + "filereuploadsummary": "Owah-owahan berkas:", "filestatus": "Status hak cipta", "filesource": "Sumber", - "ignorewarning": "Lirwakaké pepéling lan simpen langsung barkasé.", + "ignorewarning": "Lirwakaké pepéling lan simpen langsung berkasé.", "ignorewarnings": "Lirwakaké samubarang pepéling", - "minlength1": "Jeneng barkas saorané ngemu sakurup.", - "illegalfilename": "Jeneng barkas \"$1\" ngandhut aksara kang ora diparengaké ana sajroning irah-irahan kaca. Mangga owahana jeneng barkas iku lan cobanen diunggahaké manèh.", - "filename-toolong": "Jeneng barkas ora kena munjuli 240 bèt.", - "badfilename": "Jeneng barkas wis diowah dadi \"$1\".", - "filetype-mime-mismatch": "Èkstènsi barkas \".$1\" ora cocog karo jinis MIME kang kadètèk saka barkas ($2).", - "filetype-badmime": "Barkas jinis MIME \"$1\" ora kena kaunggah.", + "minlength1": "Jeneng berkas saorané ngemu sakurup.", + "illegalfilename": "Aran barkas \"$1\" ngemu karakter kang ora kaolèhaké ing sesirah kaca.\nMangga ganti araning berkasé lan jajal manèh ngunggah berkasé.", + "filename-toolong": "Aran barkas ora kena munjuli 240 bèt.", + "badfilename": "Aran berkas wis ingowahan dadi \"$1\".", + "filetype-mime-mismatch": "Èstènsi berkas \".$1\" ora cocog karo jinis MIME kang tinemu ing berkas ($2).", + "filetype-badmime": "Berkas mawa jinis MIME \"$1\" ora kena kaunggah.", "filetype-bad-ie-mime": "Ora bisa ngunggahaké barkas iki amarga Internet Explorer ndhétèksi minangka \"$1\", kang ora diidinaké lan minangka tipe barkas kang nduwèni potènsi mbebayani.", "filetype-unwanted-type": "<strong>\".$1\"</strong> iku jinis barkas kang ora kapéngini.\nAluwung {{PLURAL:$3|jinis barkasé}} $2.", "filetype-banned-type": "<strong>\".$1\"</strong> {{PLURAL:$4|dudu jinis barkas kang diidinaké}}.\n{{PLURAL:$3|Jinis barkas}} kang diidinaké $2.", "filetype-missing": "Barkas ini ora duwé ekstènsi (contoné \".jpg\").", - "empty-file": "Barkas kang panjenengan lebokaké kosong.", - "file-too-large": "Barkas kang panjenengan lebokaké kagedhèn.", + "empty-file": "Berkas kang kolebokaké kosong.", + "file-too-large": "Berkas kang kolebokaké kegedhèn.", "filename-tooshort": "Jeneng barkas kecendhèken.", "filetype-banned": "Barkas jinis iki dilarang.", "verification-error": "Barkas iki ora lulus vèrifikasi.", - "hookaborted": "Owahan kang panjenengan ayahi diwurungaké déning èkstènsi.", + "hookaborted": "Olèhmu ndandani diwurungaké èstènsi.", "illegal-filename": "Jeneng barkas ora diidinaké.", "overwrite": "Nibani barkas kang wis ana ora dililakaké.", "unknown-error": "Ana masalah kang ora dingertèni.", @@ -1447,7 +1436,7 @@ "tmp-write-error": "Ora bisa nulis barkas sauntara.", "large-file": "Ukuran barkas disaranaké supaya ora ngluwihi $1 bita; barkas iki ukurané $2 bita.", "largefileserver": "Barkas iki luwih gedhé tinimbang kang diidinaké ing paladèn.", - "emptyfile": "Barkas kang panjenengan unggahaké katoné kosong. Bokmanawa iki amarga anané salah ketik ing jeneng barkas. Mangga dipastèkaké apa panjenengan pancèn kersa ngunggahaké barkas iki.", + "emptyfile": "Berkas kang kounggah katon kosong.\nBokmanawa ana salah tik ing aran berkasé.\nMangga pesthèkaké yèn kowé pancèn péngin ngunggah berkas iki.", "windows-nonascii-filename": "Wiki iki ora nyengkuyung jeneng berkas mawa karakter kusus.", "fileexists": "Barkas mawa jeneng iku wis ana, mangga dipriksa <strong>[[:$1]]</strong> yèn panjenengan ora yakin sumedya ngowahiné.\n[[$1|thumb]]", "filepageexists": "Kaca dhèskripsi kanggo berkas iki wis digawé ing <strong>[[:$1]]</strong>, nanging saiki iki ora tinemu berkas mawa jeneng iku. Ringkesan kang panjenengan lebokaké ora bakal metu ing kaca dhèskripsi. Kanggo ngetokaké dhèskripsi iki, panjenengan kudu mbesut kanthi manual. [[$1|thumb]]", @@ -1543,7 +1532,7 @@ "zip-bad": "Barkas rusak utawa barkas ZIP kang ora bisa diwaca.\nKang mangkono ora bisa kapriksa kanthi patut kanggo kamanan.", "zip-unsupported": "Barkasé iku barkas ZIP kang nganggo piranti ZIP kang ora disengkuyung MediaWiki.\nKang mangkono ora bisa kapriksa kanthi patut kanggo kamanan.", "uploadstash": "Unggah pandhelikan", - "uploadstash-summary": "Kaca iki nyadhiyakaké dalan ing barkas-barkas kang wis diunggah (utawa lagi diunggah) naning durung kababar ing wiki. Barkas-barkas iki ora katon kanggo sapa baé nanging namung kanggo panganggo kang ngunggah baé.", + "uploadstash-summary": "Kaca iki nyawisaké aksès marang berkas-berkas kang wis kaunggah utawa kang lagi kaunggah. Berkas-berkas iki ora katon tumrap sesapaa kajaba panganggo kang ngunggah baé.", "uploadstash-clear": "Busek barkas kadhelikaké", "uploadstash-nofiles": "Panjenengan ora duwé barkas simpenan.", "uploadstash-badtoken": "Nglakoni iki ora dadi, bokamanawa amarga hak besut panjenengan wis kadaluwarsa. Sumangga jajal manèh.", @@ -1882,7 +1871,7 @@ "listusersfrom": "Tuduhna panganggo kang diawali karo:", "listusers-submit": "Tuduhna", "listusers-noresult": "Panganggo ora ana.", - "listusers-blocked": "(diblokir)", + "listusers-blocked": "(kapenggak)", "activeusers": "Pratélan panganggo aktif", "activeusers-intro": "Iki pratélan panganggo kang katon lakuné ing $1 {{PLURAL:$1|dina|dina}} kapungkur.", "activeusers-count": "$1 {{PLURAL:$1|laku|laku}} ing {{PLURAL:$3|dina|$3 dina}} pungkasan", @@ -2073,7 +2062,7 @@ "protect_expiry_old": "Wektu kadaluwarsané ana ing kala kawuri.", "protect-unchain-permissions": "Urubaké opsi rereksan lanjutan", "protect-text": "Ing kéné, panjenengan bisa ndeleng lan ngganti tataran kareksan tumrap kaca <strong>$1</strong>.", - "protect-locked-blocked": "Panjenengan ora bisa ngowahi tataran rereksan nalika diblokir.\nMangkéné setèlan saiki tumrap kaca <strong>$1</strong>:", + "protect-locked-blocked": "Kowé ora bisa ngowahi tataran rereksan nalika kapenggak.\nMangkéné setèlan saiki tumrap kaca <strong>$1</strong>:", "protect-locked-dblock": "Tataran rereksan ora bisa diowahi amarga sasana dhatané digembok.\nMangkéné setèlan saiki tumrap kaca <strong>$1</strong>:", "protect-locked-access": "Akuné panjenengan ora kawogan ngowahi tataran rereksan kaca.\nMangkéné setèlan saiki tumrap kaca <strong>$1</strong>:", "protect-cascadeon": "Kaca iki lagi direksa amarga disertakaké ing {{PLURAL:$1|kaca|kaca-kaca}} kang wis direksa mawa pilihan pangreksan runtun diaktifaké. Panjenengan bisa ngganti tingkat pangreksan kanggo kaca iki, nanging perkara iku ora awèh pengaruh pangreksan runtun.", @@ -2159,14 +2148,14 @@ "uctop": "saiki", "month": "Saka wulan (lan sadurungé):", "year": "Saka taun (lan sadurungé):", - "sp-contributions-blocklog": "log blokir", + "sp-contributions-blocklog": "log penggakan", "sp-contributions-deleted": "pasumbangé {{GENDER:$1|panganggo}} kang kabusek", "sp-contributions-uploads": "unggahan", "sp-contributions-logs": "log", "sp-contributions-talk": "rembug", "sp-contributions-userrights": "panataning hak {{GENDER:$1|panganggo}}", - "sp-contributions-blocked-notice": "Panganggo iki lagi diblokir.\nÈntri log blokiran pungkasan sumadhiya ing ngisor kanggo rujukan:", - "sp-contributions-blocked-notice-anon": "Alamat IP iki lagi diblokir.\nÈntri log blokiran pungkasan sumadhiya ing ngisor kanggo rujukan:", + "sp-contributions-blocked-notice": "Panganggo iki lagi kapenggak.\nÈntri log penggakan kang pungkasan cumawis ing sor iki minangka rujukan:", + "sp-contributions-blocked-notice-anon": "Alamat IP iki lagi kapenggak.\nÈntri log penggakan kang pungkasan cumawis ing sor iki minangka rujukan:", "sp-contributions-search": "Golèk pasumbang", "sp-contributions-username": "Alamat IP utawa jeneng panganggo:", "sp-contributions-toponly": "Tuduhaké besutan mligi révisi anyaran", @@ -2511,7 +2500,7 @@ "tooltip-t-info": "Katerangan liyané ngenani kaca iki", "tooltip-t-upload": "Unggah barkas", "tooltip-t-specialpages": "Pratélaning kabèh kaca mirunggan", - "tooltip-t-print": "Vèrsi céthak kaca iki", + "tooltip-t-print": "Vèrsi cithak kaca iki", "tooltip-t-permalink": "Pranala permanèn saka owahan iki", "tooltip-ca-nstab-main": "Deleng kaca kontèn", "tooltip-ca-nstab-user": "Deleng kaca panganggo", @@ -2525,7 +2514,7 @@ "tooltip-ca-nstab-category": "Deleng kaca kategori", "tooltip-minoredit": "Tandhani iki yèn besutan cilik", "tooltip-save": "Simpen owah-owahaning panjenengan", - "tooltip-publish": "Babar owahané panjenengan", + "tooltip-publish": "Babar owahanmu", "tooltip-preview": "Pratuduhana owah-owahaning panjenengan. Tulung ayahana iku sadurungé nyimpen.", "tooltip-diff": "Tuduhaké owahan endi kang panjenengan gawé tumrap tulisané", "tooltip-compareselectedversions": "Delengen prabédan antara rong vèrsi kaca iki kang dipilih.", @@ -3036,7 +3025,7 @@ "feedback-cancel": "Wurung", "feedback-close": "Rampung", "feedback-external-bug-report-button": "Kirim ayahan tèhnis", - "feedback-dialog-title": "Awèh saran", + "feedback-dialog-title": "Kirimi pamrayoga", "feedback-error1": "Masalah: Kasil ora dingertèni saka API", "feedback-error2": "Masalah: Besutané wurung", "feedback-error3": "Masalah: Ora ana tanggepan saka API", @@ -3050,19 +3039,19 @@ "searchsuggest-containing": "ngemu...", "api-error-badtoken": "Masalah njero: Token ala.", "api-error-emptypage": "Nggawé kaca kosong anyar ora dilikaké.", - "api-error-publishfailed": "Masalah njero: Paladèn wurung mbabar barkas sawetara.", + "api-error-publishfailed": "Masalah njero: Paladèn wurung mbabar berkas sawetara.", "api-error-stashfailed": "Masalah njero: Paladèn wurung ndèkèk barkas sawetara.", "api-error-unknown-warning": "Pélik ora dingertèni: \"$1\".", "api-error-unknownerror": "Masalah ora dingertèni: \"$1\".", - "duration-seconds": "$1 {{PLURAL:$1|detik|detik}}", + "duration-seconds": "$1 {{PLURAL:$1|sekon|sekon}}", "duration-minutes": "$1 {{PLURAL:$1|menit|menit}}", "duration-hours": "$1 {{PLURAL:$1|jam|jam}}", "duration-days": "$1 {{PLURAL:$1|dina|dina}}", "duration-weeks": "$1 {{PLURAL:$1|minggu|minggu}}", "duration-years": "$1 {{PLURAL:$1|taun|taun}}", - "duration-decades": "$1 {{PLURAL:$1|dékade|dékade}}", + "duration-decades": "$1 {{PLURAL:$1|dasawarsa|dasawarsa}}", "duration-centuries": "$1 {{PLURAL:$1|abad|abad}}", - "duration-millennia": "$1 {{PLURAL:$1|milénium|milénium}}", + "duration-millennia": "$1 {{PLURAL:$1|miléniyum|miléniyum}}", "rotate-comment": "Gambar diubengaké $1 {{PLURAL:$1|drajat|drajat}} sak arah domé jam", "limitreport-title": "Parser profiling data:", "limitreport-cputime": "CPU time usage", @@ -3142,7 +3131,7 @@ "date-range-from": "Kawit tanggal:", "date-range-to": "Tumeka tanggal:", "randomrootpage": "Kaca wod sembarang", - "log-action-filter-block": "Jinis blokiran:", + "log-action-filter-block": "Jinis penggakan:", "log-action-filter-contentmodel": "Jinis owahan modhèl isi:", "log-action-filter-delete": "Jinis busakan:", "log-action-filter-import": "Jinis imporan:", @@ -3154,7 +3143,7 @@ "log-action-filter-rights": "Jinis owahan hak:", "log-action-filter-upload": "Jinis unggahan:", "log-action-filter-all": "Kabèh", - "log-action-filter-block-block": "Blokir", + "log-action-filter-block-block": "Penggak", "log-action-filter-block-reblock": "Modhifikasi blokiran", "log-action-filter-block-unblock": "Copot blokiran", "log-action-filter-contentmodel-change": "Owahan modhèl isi", diff --git a/languages/i18n/ka.json b/languages/i18n/ka.json index ffdeba8468..7cfb2f8f1c 100644 --- a/languages/i18n/ka.json +++ b/languages/i18n/ka.json @@ -612,24 +612,6 @@ "resettokens-watchlist-token": "ტოკენი ვებ-არხისთვის (Atom/RSS) [[Special:Watchlist|გვერდების ცვლილებები თქვენი კონტროლის სიაში]]", "resettokens-done": "ტოკენების ჩამოყრა", "resettokens-resetbutton": "არჩეული ტოკენების ჩამოყრა", - "bold_sample": "მუქი ტექსტი", - "bold_tip": "მუქი ტექსტი", - "italic_sample": "კურსივი", - "italic_tip": "კურსივი", - "link_sample": "ბმულის სათაური", - "link_tip": "შიდა ბმული", - "extlink_sample": "http://www.example.com ბმულის სათაური", - "extlink_tip": "გარე ბმული (გახსოვდეთ http:// პრეფიქსი)", - "headline_sample": "სათაურის ტექსტი", - "headline_tip": "ქვესათაური", - "nowiki_sample": "ჩასვით დაუფორმატებელი ტექსტი აქ", - "nowiki_tip": "ვიკის ფორმატირების იგნორირება", - "image_sample": "მაგალითი.jpg", - "image_tip": "ჩასმული ფაილი", - "media_sample": "მაგალითი.ogg", - "media_tip": "ბმული ფაილზე", - "sig_tip": "თქვენი ხელმოწერა და დრო", - "hr_tip": "ჰორიზონტალური ხაზი (ნუ გამოიყენებთ ხშირად)", "summary": "რეზიუმე:", "subject": "თემა:", "minoredit": "მცირე რედაქტირება", @@ -808,7 +790,7 @@ "page_first": "პირველი", "page_last": "ბოლო", "histlegend": "ვერსიების შედარება: აირჩიეთ სასურველი ვერსიები რადიო-რგოლების მონიშვნით და დააწკაპუნეთ შედარების ღილაკზე.<br />\nლეგენდა: '''({{int:cur}})''' = სხვაობა მიმდინარე ვერსიასთან, '''({{int:last}})''' = სხვაობა წინა ვერსიასთან, '''{{int:minoreditletter}}''' = მცირე შესწორება.", - "history-fieldset-title": "ვერსიების ძიება", + "history-fieldset-title": "ცვლილებების გაფილტვრა", "history-show-deleted": "მხოლოდ წაშლილი ვერსიები", "histfirst": "უძველესი", "histlast": "უახლესი", @@ -1008,6 +990,7 @@ "prefs-watchlist-edits": "კონტროლის სიაში საჩვენებელი ცვლილებების მაქსიმალური რაოდენობა:", "prefs-watchlist-edits-max": "მაქსიმალური რაოდენობა: 1000", "prefs-watchlist-token": "კონტროლის სიის ტოკენი:", + "prefs-watchlist-managetokens": "ტოკენების მართვა", "prefs-misc": "სხვადასხვა", "prefs-resetpass": "შეცვალეთ პაროლი", "prefs-changeemail": "ელ-ფოსტის მისამართის შეცვლა ან წაშლა", @@ -1462,6 +1445,8 @@ "rcfilters-watchlist-preference-help": "აუქმებს 2017 წლის ინტერფეისისა და ყველა ხელსაწყოს რედიზაინს დამატებულს მაშინ და შემდგომ.", "rcfilters-filter-showlinkedfrom-label": "ცვლილებების ჩვენება დაკავშირებულ გვერდებზე", "rcfilters-filter-showlinkedto-option-label": "<strong>არჩეულზე, დაკავშირებული</strong> გვერდები", + "rcfilters-allcontents-label": "მთელი სახელთა სივრცე", + "rcfilters-alldiscussions-label": "ყველა განხილვა", "rcnotefrom": "ქვემოთ {{PLURAL:$5|ნაჩვენებია ცვლილება|ნაჩვენებია ცვლილებები}} <strong>$3, $4</strong>-დან (ნაჩვენებია არაუმეტეს <strong>$1</strong>).", "rclistfromreset": "თარიღის საწყის კონფიგურაციაზე დაბრუნება", "rclistfrom": "ახალი ცვლილებების ჩვენება დაწყებული $3 $2-დან", @@ -1758,9 +1743,9 @@ "filehist-filesize": "ფაილის ზომა", "filehist-comment": "კომენტარი", "imagelinks": "ფაილის გამოყენება", - "linkstoimage": "მომდევნო {{PLURAL:$1|გვერდი|გვერდები}} ებმის ამ ფაილს:", + "linkstoimage": "მომდევნო {{PLURAL:$1|გვერდი იყენებს|გვერდები იყენებენ}} ამ ფაილს:", "linkstoimage-more": "$1-ზე მეტი {{PLURAL:$1|გვერდები|გვერდების|გვერდები}} რომლებსაც აქვთ ბმულები ამ ფაილზე.\nმოცემულ სიაში {{PLURAL:$1|წარმოდგენილია მხოლოდ $1 ბმული|წარმოდგენილია მხოლოდ $1 ბმულები|წარმოდგენილია მხოლოდ $1 ბმულების}} ამ ფაილზე.\nშეგიძლიათ ნახოთ ასევე [[Special:WhatLinksHere/$2|სრული სია]].", - "nolinkstoimage": "არ არსებობს ამ ფაილთან დაკავშირებული გვერდები.", + "nolinkstoimage": "ეს ფაილი არცერთ გვერდზე არ გამოიყენება.", "morelinkstoimage": "იხილეთ [[Special:WhatLinksHere/$1|სხვა ბმულები]] ამ ფაილზე.", "linkstoimage-redirect": "$1 (ფაილის გადამისამართება) $2", "duplicatesoffile": "{{PLURAL:$1|შემდეგი $1 ფაილი არის დუბლიკატი|შემდეგი $1 ფაილები არიან დუბლიკატები|შემდეგი $1 ფაილები არიან დუბლიკატები}} ამ ფაილისა ([[Special:FileDuplicateSearch/$2|დამატებითი ინფორმაცია]]):", diff --git a/languages/i18n/kaa.json b/languages/i18n/kaa.json index 306806baf2..ca8c721076 100644 --- a/languages/i18n/kaa.json +++ b/languages/i18n/kaa.json @@ -323,22 +323,6 @@ "resetpass_forbidden": "Paroller o'zgertile almaydi", "resetpass-submit-loggedin": "Paroldi o'zgertiw", "resetpass-temp-password": "Waqtınshalıq parol:", - "bold_sample": "Yarım juwan tekst", - "bold_tip": "Yarım juwan tekst", - "italic_sample": "Kursiv tekst", - "italic_tip": "Kursiv tekst", - "link_sample": "Siltew ataması", - "link_tip": "Ä°shki siltew", - "extlink_sample": "http://www.example.com siltew ataması", - "extlink_tip": "Sırtqı siltew (http:// prefiksin kiritin')", - "headline_sample": "Atama teksti", - "headline_tip": "2-shi da'rejeli atama", - "nowiki_sample": "Formatlanbag'an tekstti usı jerge qoyın'", - "nowiki_tip": "Wiki formatlawın esapqa almaw", - "image_tip": "Jaylastırılg'an fayl", - "media_tip": "Fayl siltewi", - "sig_tip": "Sizin' imzan'iz ha'mde waqıt belgisi", - "hr_tip": "Gorizont bag'ıtındag'ı sızıq (dım ko'p paydalanban')", "summary": "Juwmaq:", "subject": "Ataması:", "minoredit": "Bul kishi o'zgeris", diff --git a/languages/i18n/kab.json b/languages/i18n/kab.json index 667f65985a..4ec93d5e3c 100644 --- a/languages/i18n/kab.json +++ b/languages/i18n/kab.json @@ -558,24 +558,6 @@ "resettokens-watchlist-token": "Tiddest i usuddem (Atom/RSS) web n [[Special:Watchlist|ibeddilen n isebtar n umuÉ£ inek/inem n uḍfar]]", "resettokens-done": "Tiddas i wennezen.", "resettokens-resetbutton": "Wennez tiddas i fernen", - "bold_sample": "Aḍris aberbuz", - "bold_tip": "Aḍris aberbuz", - "italic_sample": "Aḍris aá¹­alyani", - "italic_tip": "Aḍris aá¹­alyani", - "link_sample": "Azwel n uzday", - "link_tip": "Azday zdaxel", - "extlink_sample": "http://www.example.com azwel n uzday", - "extlink_tip": "Azday aberrani (cfu belli yessefk at tebduḍ s http://)", - "headline_sample": "Aḍris n uzwel azellum", - "headline_tip": "Aswir 2 n uzwel azellum", - "nowiki_sample": "Sideff da tirra bla taseddast(formatting) n wiki", - "nowiki_tip": "Ttu taseddast n wiki", - "image_sample": "Amedya.jpg", - "image_tip": "Tugna yettussekcmen", - "media_sample": "Amedya.ogg", - "media_tip": "Azday n ufaylu media", - "sig_tip": "Azmul inek s uzemz", - "hr_tip": "Ajerriḍ aglawan (ur teččerɛiḍ ara)", "summary": "Agzul:", "subject": "Asentel:", "minoredit": "Wagi d abeddel afessas", diff --git a/languages/i18n/kbd-cyrl.json b/languages/i18n/kbd-cyrl.json index a291572e02..d1123a81cc 100644 --- a/languages/i18n/kbd-cyrl.json +++ b/languages/i18n/kbd-cyrl.json @@ -357,22 +357,6 @@ "resetpass-submit-cancel": "ЩӀегъуэжын", "resetpass-wrong-oldpass": "Парол щӀэхыр иэ щыӀэр тэрэзкъым.\nУи паролыр узыншу зэпхъуэкӀагъэн иэ щӀэуэ щӀэх парол узщӀэлъэӀуар узыншу зэфӀэкӀа.", "resetpass-temp-password": "ЩӀэх паролыр:", - "bold_sample": "Ӏуву щӀын хьэрыфхэр", - "bold_tip": "Ӏуву щӀын хьэрыфхэр", - "italic_sample": "Текстыр укъуэншауэ", - "italic_tip": "Хьэрыфхэр укъэншауэ щӀын", - "link_sample": "ТехьэпӀэм и цIэр", - "link_tip": "КІуэцІ техьэпІэ", - "extlink_sample": "http://www.example.com техьэпӀэхэм я псэлъащхьэ", - "extlink_tip": "ТехьэпӀэ зэIухар (зыщывмыгъэгъупщэ http:// префиксыр)", - "headline_sample": "Псалъащхьэм и тхылъ", - "headline_tip": "ТІуанэ щхьэгъэ псалъащхьэ", - "nowiki_sample": "Формациэ мыщӀа тхыгъэр мыбдеж игъэувэ", - "nowiki_tip": "Вики-форматыр Iухын", - "image_tip": "Теплъэ кӀуэцӀылъу", - "media_tip": "Теплъэм и техьэпӀэ", - "sig_tip": "Уи ӀэпэщӀэдзымрэ зэман щытехуэмрэ", - "hr_tip": "ЩӀэтхъэгъуэ щӀыхь (куэдрэ къэвмыгъэмэбэп)", "summary": "Хъуэжахэм тепсэлъыхь:", "subject": "Темэ/псалъащхьэ:", "minoredit": "МащIэу хъуэжа", diff --git a/languages/i18n/khw.json b/languages/i18n/khw.json index 7310bd36a8..4153130f4e 100644 --- a/languages/i18n/khw.json +++ b/languages/i18n/khw.json @@ -487,22 +487,6 @@ "passwordreset-domain": "ڈومین:", "passwordreset-email": "ای میل پتہ:", "changeemail-none": "(نو)", - "bold_sample": "بوسک متن", - "bold_tip": "بولڈ ٹیکسٹ", - "italic_sample": "کولی/اٹالک نیویشیرو", - "italic_tip": "کولی نیویشیرو", - "link_sample": "ربطو عنوان", - "link_tip": "اندرینو لنک", - "extlink_sample": "http://groups.yahoo.com/group/khowaracademy ربطو عنوان", - "extlink_tip": "بیریو ربطو (یاد لکھے http:// prefix)", - "headline_sample": "شہ سرخی", - "headline_tip": "شہ سرخی درجہ دوم", - "nowiki_sample": "غیرشکلبندشدہ متنو ھیارا درج کورور", - "nowiki_tip": "ویکی شکلبندیو نظرانداز کورے", - "image_tip": "ݯوکیرو فائل", - "media_tip": "مسلو لنک", - "sig_tip": "تہ دستخط بمع مہرِ وخت", - "hr_tip": "تھروسکی لکیر (زیادہ استعمال مو کورے)", "summary": "خلاصہ:", "subject": "مضمون/شہ سرخی:", "minoredit": "معمولی ترمیم", diff --git a/languages/i18n/kiu.json b/languages/i18n/kiu.json index 32ed1c25f4..214cace021 100644 --- a/languages/i18n/kiu.json +++ b/languages/i18n/kiu.json @@ -9,7 +9,8 @@ "Macofe", "Kumkumuk", "Asmen", - "Gırd" + "Gırd", + "1917 Ekim Devrimi" ] }, "tog-underline": "Bınê gırey de xete bonce:", @@ -345,22 +346,6 @@ "resetpass-submit-cancel": "Bıtexelne", "resetpass-temp-password": "Parola vêrdiye:", "passwordreset-username": "Namê karberi:", - "bold_sample": "Nusto qolınd", - "bold_tip": "Nusto qolınd", - "italic_sample": "Meqalo italik", - "italic_tip": "Meqalo italik", - "link_sample": "Serrêza girêy", - "link_tip": "Girê zerri", - "extlink_sample": "http://www.example.com arezekerdena adrese", - "extlink_tip": "Girê teberi (verbendê http:// ho vira mekerê)", - "headline_sample": "Nustê serrêze", - "headline_tip": "Serrêza sewiya 2ine", - "nowiki_sample": "Formatê nustê huyo serbeti ita bınuse", - "nowiki_tip": "Ehemêt formatê wikiy mede", - "image_tip": "Dosya arêkerdiye", - "media_tip": "Girê dosya", - "sig_tip": "Ä°mza to be tarix", - "hr_tip": "Xeta ufqiye (zaf megurene)", "summary": "Xulasa:", "subject": "Mewzu/serrêze:", "minoredit": "No jü vurnaiso qızkeko", @@ -964,7 +949,7 @@ "thumbnail_error": "Vıraştena resımê qıckeki de xeta: $1", "import-upload-filename": "Namê dosya:", "tooltip-pt-userpage": "Pela sımawa karberi", - "tooltip-pt-mytalk": "Pela sımawa hurênaişi", + "tooltip-pt-mytalk": "Pela {{GENDER:|toya}} werênayışi", "tooltip-pt-preferences": "Tercihê mı", "tooltip-pt-watchlist": "Lista pelunê ke to guretê şêrkerdene", "tooltip-pt-mycontris": "Lista iştıraqunê sıma", diff --git a/languages/i18n/kjp.json b/languages/i18n/kjp.json index 452d0287ac..3b25d6d399 100644 --- a/languages/i18n/kjp.json +++ b/languages/i18n/kjp.json @@ -271,22 +271,6 @@ "passwordreset": "ၜီးၜါ်သင့် မ်ုအင်းတင်", "passwordreset-username": "ဆ်ုသုံႋဆာႋမိင်:", "changeemail-none": "(ပၠဝ်ပြေ)", - "bold_sample": "လိက်ဖၠုံးသိုင့်", - "bold_tip": "လိက်ဖၠုံးသိုင့်", - "italic_sample": "လိက်ဖၠုံးပ်ု", - "italic_tip": "လိက်ဖၠုံးပ်ု", - "link_sample": "လင့်ခ် အ်ုခေါဟ်တင်", - "link_tip": "အ်ုဒှဲႋဖိုင် လင့်ခ်", - "extlink_sample": "http://www.example.com လင့်ခ် ခေါဟ်ဍံင်", - "extlink_tip": "အ်ုၰံင်လင့်သယ် (http:// ၮှ် သာ့ၮင့်ဆူ့ဍုဂ် လ်ုအ်ုမေံယာ့ခဝ့်ၯေဝ်)", - "headline_sample": "အ်ုခေါဟ်တင်ဍောဟ်လိက်ဖၠုံး", - "headline_tip": "အ်ုဆင့် ၂ ခေါဟ်ဍောဟ်", - "nowiki_sample": "ဖောမတ်လ်ုမာထဝး လိက်သယ်အိုဝ် ထါင်ႋယိုဝ် မ်ုဆူ့လင်", - "nowiki_tip": "ဝီကီလာၯင် ဖော်မတ်သယ်လ်ုဖး လ်ုအှ်ကှ်ေဆ်ုပ်ုယောဝ်ႋ", - "image_tip": "Embedded ဍုဂ်ထး ဖိုင်", - "media_tip": "File လင့်", - "sig_tip": "မူႋသင့်ခိင်ႋခါ့ၮဲဖှ်ေ ၮ်ုစူးဍံင်", - "hr_tip": "ပၞံင့်ထီ့ဖါ (အင်းကုံဆၟိုဝ်လာႋ)", "summary": "အ်ုအိင်း", "subject": "လိက်ဘာႋသါ့:", "minoredit": "အ်ုယိုဝ် မွာဲဝေ့ဆ်ုအင်းတါင်ဖေါဟ်လှ်", diff --git a/languages/i18n/kk-arab.json b/languages/i18n/kk-arab.json index 70219d9944..80d7452c75 100644 --- a/languages/i18n/kk-arab.json +++ b/languages/i18n/kk-arab.json @@ -309,22 +309,6 @@ "resetpass_submit": "قۇپىييا ٴسوزدى قويىڭىز دا كىرىڭىز", "changepassword-success": "قۇپىييا ٴسوزىڭىز ٴساتتى وزگەرتىلدى! ەندى كىرىڭىز…", "resetpass_forbidden": "{{SITENAME}} جوباسىندا قۇپىييا سوزدەر وزگەرتىلمەيدى", - "bold_sample": "جۋان ٴماتىن", - "bold_tip": "جۋان ٴماتىن", - "italic_sample": "قىيعاش ٴماتىن", - "italic_tip": "قىيعاش ٴماتىن", - "link_sample": "سىلتەمە تاقىرىبىن اتى", - "link_tip": "ىشكى سىلتەمە", - "extlink_sample": "http://www.example.com سىلتەمە تاقىرىبىن اتى", - "extlink_tip": "شەتتىك سىلتەمە (الدىنان http:// ەنگىزۋىن ۇمىتپاڭىز)", - "headline_sample": "باس جول ٴماتىنى", - "headline_tip": "2-ٴشى دەڭگەيلى باس جول", - "nowiki_sample": "پىشىمدەلىنبەگەن ٴماتىندى مىندا ەنگىزىڭىز", - "nowiki_tip": "ۋىيكىي ٴپىشىمىن ەلەمەۋ", - "image_tip": "ەندىرىلگەن فايل", - "media_tip": "فايل سىلتەمەسى", - "sig_tip": "قولتاڭباڭىز جانە ۋاقىت بەلگىسى", - "hr_tip": "دەرەلەي سىزىق (ۇنەمدى قولدانىڭىز)", "summary": "قىسقاشا مازمۇنداماسى:", "subject": "تاقىرىبى/باس جولى:", "minoredit": "بۇل شاعىن وڭدەمە", diff --git a/languages/i18n/kk-cyrl.json b/languages/i18n/kk-cyrl.json index 8c3da99f38..81bf09dab0 100644 --- a/languages/i18n/kk-cyrl.json +++ b/languages/i18n/kk-cyrl.json @@ -551,23 +551,6 @@ "resettokens-watchlist-token": "(Atom/RSS) [[Special:Watchlist|сіздің бақылау тізіміңіздегі беттердегі өзгерістер]]дегі уеб тізбегі (Atom/RSS) үшін токен", "resettokens-done": "Байрақшаларды ысыру", "resettokens-resetbutton": "Таңдалған байрақшаларды ысыру", - "bold_sample": "Жуан мәтін", - "bold_tip": "Жуан мәтін", - "italic_sample": "Қиғаш мәтін", - "italic_tip": "Қиғаш мәтін", - "link_sample": "Сілтеме тақырыбының аты", - "link_tip": "Ішкі сілтеме", - "extlink_sample": "http://www.example.com сілтеме тақырыбының аты", - "extlink_tip": "Сыртқы сілтеме (алдынан http:// енгізуін ұмытпаңыз)", - "headline_sample": "Бас жол мәтіні", - "headline_tip": "2-ші деңгейлі бас жол", - "nowiki_sample": "Форматталмаған мәтінді мында кірістіріңіз", - "nowiki_tip": "Уики форматтауын елемеу", - "image_sample": "Мысал.jpg", - "image_tip": "Ендірілген файл", - "media_tip": "Файл сілтемесі", - "sig_tip": "Қолтаңбаңыз және уақыт белгісі", - "hr_tip": "Көлденең сызық (үнемді қолданыңыз)", "summary": "Түйіндемесі:", "subject": "Тақырыбы:", "minoredit": "Бұл шағын өңдеме", diff --git a/languages/i18n/kk-latn.json b/languages/i18n/kk-latn.json index 0eb23521fa..ee6939e6ee 100644 --- a/languages/i18n/kk-latn.json +++ b/languages/i18n/kk-latn.json @@ -311,22 +311,6 @@ "resetpass_submit": "Qupïya sözdi qoýıñız da kiriñiz", "changepassword-success": "Qupïya söziñiz sätti özgertildi! Endi kiriñiz…", "resetpass_forbidden": "{{SITENAME}} jobasında qupïya sözder özgertilmeýdi", - "bold_sample": "Jwan mätin", - "bold_tip": "Jwan mätin", - "italic_sample": "Qïğaş mätin", - "italic_tip": "Qïğaş mätin", - "link_sample": "Silteme taqırıbın atı", - "link_tip": "İşki silteme", - "extlink_sample": "http://www.example.com silteme taqırıbın atı", - "extlink_tip": "Şettik silteme (aldınan http:// engizwin umıtpañız)", - "headline_sample": "Bas jol mätini", - "headline_tip": "2-şi deñgeýli bas jol", - "nowiki_sample": "Pişimdelinbegen mätindi mında engiziñiz", - "nowiki_tip": "Wïkï pişimin elemew", - "image_tip": "Endirilgen faýl", - "media_tip": "Faýl siltemesi", - "sig_tip": "Qoltañbañız jäne waqıt belgisi", - "hr_tip": "Dereleý sızıq (ünemdi qoldanıñız)", "summary": "Tüýindemesi:", "subject": "Taqırıbı/bas jolı:", "minoredit": "Bul şağın öñdeme", diff --git a/languages/i18n/km.json b/languages/i18n/km.json index eae59c792c..ada3245174 100644 --- a/languages/i18n/km.json +++ b/languages/i18n/km.json @@ -553,24 +553,6 @@ "resettokens-token-label": "$1 (តម្លៃបច្ចុប្បន្ន $2)", "resettokens-done": "កូនសោរកំណត់ឡើងវិញហើយ។", "resettokens-resetbutton": "កំណត់ឡើងវិញនូវកូនសោរដែលបានរើស។", - "bold_sample": "អក្សរដិត", - "bold_tip": "អក្សរដិត", - "italic_sample": "អក្សរទ្រេត", - "italic_tip": "អក្សរទ្រេត", - "link_sample": "ចំណងជើង​តំណភ្ជាប់", - "link_tip": "តំណភ្ជាប់​ខាងក្នុង", - "extlink_sample": "http://www.example.com ចំណងជើង​តំណភ្ជាប់", - "extlink_tip": "តំណភ្ជាប់​ខាងក្រៅ (កុំភ្លេច​ដាក់ http:// នៅពីមុខ)", - "headline_sample": "ចំណងជើងរងនៃអត្ថបទ", - "headline_tip": "ចំណងជើងរង​កម្រិត​២", - "nowiki_sample": "បញ្ចូល​អត្ថបទគ្មានទម្រង់​នៅទីនេះ", - "nowiki_tip": "មិនគិត​ទម្រង់​នៃ​វិគី", - "image_sample": "ឧទាហរណ៍.jpg", - "image_tip": "រូបភាពបង្កប់", - "media_sample": "ឧទាហរណ៍.ogg", - "media_tip": "តំណភ្ជាប់ឯកសារ", - "sig_tip": "ហត្ថលេខា​របស់អ្នកជាមួយនឹងកាលបរិច្ឆេទ", - "hr_tip": "បន្ទាត់ដេក (មិនសូវប្រើទេ)", "summary": "ចំណារពន្យល់៖", "subject": "ប្រធានបទ៖", "minoredit": "នេះជា​កំណែប្រែតិចតួចប៉ុណ្ណោះ", diff --git a/languages/i18n/kn.json b/languages/i18n/kn.json index fbdb05a05f..1a7b78fb2d 100644 --- a/languages/i18n/kn.json +++ b/languages/i18n/kn.json @@ -543,22 +543,6 @@ "changeemail-submit": "ಇಮೇಲ್ ಬದಲಾಯಿಸಿ", "resettokens-tokens": "ಸಂಕೇತಗಳು:", "resettokens-token-label": "$1(ಪ್ರಸ್ತುತ ಮೌಲ್ಯ:$2)", - "bold_sample": "ದಪ್ಪಗಿನ ಅಚ್ಚು", - "bold_tip": "ದಪ್ಪಗಿನ ಅಚ್ಚು", - "italic_sample": "ಓರೆ ಅಕ್ಷರಗಳು", - "italic_tip": "ಓರೆ ಅಕ್ಷರಗಳು", - "link_sample": "ಲಿಂಕ್ ಶೀರ್ಷಿಕೆ", - "link_tip": "ಆಂತರಿಕ ಸಂಪರ್ಕ", - "extlink_sample": "http://www.example.com ಸಂಪರ್ಕ ಶೀರ್ಷಿಕೆ", - "extlink_tip": "ಬಾಹ್ಯ ಸಂಪರ್ಕ (http:// ಇಂದ ಶುರು ಮಾಡಿ)", - "headline_sample": "ಶಿರೋಲೇಖ", - "headline_tip": "೨ನೇ ಮಟ್ಟದ ತಲೆಬರಹ", - "nowiki_sample": "ಇಲ್ಲಿ ವಿಕೀ ಫಾರ್ಮಾಟ್ ಮಾಡದ ಪಠ್ಯವನ್ನು ಸೇರಿಸಿ", - "nowiki_tip": "ವಿಕಿ ರಚನಕ್ರಮವನ್ನು ಅಲಕ್ಷಿಸು", - "image_tip": "ಅಳವಡಿಸಲ್ಪಟ್ಟ ಕಡತ", - "media_tip": "ಕಡತದ ಕೊಂಡಿ", - "sig_tip": "ಸಮಯಮುದ್ರೆಯೊಂದಿಗೆ ನಿಮ್ಮ ಸಹಿ", - "hr_tip": "ಅಡ್ಡ ಗೆರೆ (ಆದಷ್ಟು ಕಡಿಮೆ ಉಪಯೋಗಿಸಿ)", "summary": "ಸಾರಾಂಶ:", "subject": "ವಿಷಯ:", "minoredit": "ಇದು ಚುಟುಕಾದ ಬದಲಾವಣೆ", diff --git a/languages/i18n/ko.json b/languages/i18n/ko.json index 769891d54e..e8081a4860 100644 --- a/languages/i18n/ko.json +++ b/languages/i18n/ko.json @@ -125,6 +125,7 @@ "tog-useeditwarning": "바꾼 내용을 저장하지 않고 편집 페이지를 벗어날 때 내게 알리기", "tog-prefershttps": "로그인하는 동안 항상 보안 연결 사용", "tog-showrollbackconfirmation": "되돌리기 링크를 클릭할 때 확인창을 표시", + "tog-requireemail": "비밀번호 재설정을 위한 이메일 필요", "underline-always": "항상", "underline-never": "항상 긋지 않기", "underline-default": "스킨 또는 브라우저 기본값", @@ -497,7 +498,7 @@ "createaccountmail": "임의의 임시 비밀번호를 이메일로 보내기", "createaccountmail-help": "비밀번호를 기억하지 않고도 다른 사용자를 위한 계정을 만들 수 있습니다.", "createacct-realname": "실명 (선택 사항)", - "createacct-reason": "이유", + "createacct-reason": "이유 (기록은 공개됨)", "createacct-reason-ph": "다른 계정을 만들어야 하는 이유가 있나요", "createacct-reason-help": "계정 생성 로그에 표시되는 메시지", "createacct-submit": "계정 만들기", @@ -665,22 +666,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|주시문서 목록에 있는 문서의 바뀜]]의 웹 피드(Atom/RSS)에 대한 토큰", "resettokens-done": "토큰을 재설정했습니다.", "resettokens-resetbutton": "선택한 토큰 재설정", - "bold_sample": "굵은 글씨", - "bold_tip": "굵은 글씨", - "italic_sample": "기울인 글씨", - "italic_tip": "기울인 글씨", - "link_sample": "링크 제목", - "link_tip": "내부 링크", - "extlink_sample": "http://www.example.com 사이트 이름", - "extlink_tip": "외부 링크 (http://를 앞에 붙여야 합니다)", - "headline_sample": "제목", - "headline_tip": "2단계 문단 제목", - "nowiki_sample": "여기에 위키 문법을 사용하지 않을 글을 적어 주세요", - "nowiki_tip": "위키 문법 사용하지 않기", - "image_tip": "파일 넣기", - "media_tip": "파일 링크하기", - "sig_tip": "내 서명과 현재 시각", - "hr_tip": "가로 줄 (사용을 되도록 삼가주세요)", "summary": "요약:", "subject": "주제:", "minoredit": "사소한 편집입니다", @@ -2648,11 +2633,11 @@ "empty-username": "(사용 가능한 사용자 이름 없음)", "contribslink": "기여", "emaillink": "이메일 보내기", - "autoblocker": "당신의 IP 주소는 최근에 \"[[User:$1|$1]]\"님이 사용하였기 때문에 자동으로 차단되었습니다.\n$1님이 차단된 이유는 다음과 같습니다: \"$2\"", + "autoblocker": "당신의 IP 주소는 최근에 \"[[User:$1|$1]]\" 님이 사용하였기 때문에 자동으로 차단되었습니다.\n$1 님이 차단된 이유는 다음과 같습니다: \"$2\"", "blocklogpage": "차단 기록", "blocklog-showlog": "이 사용자는 과거에 차단된 기록이 있습니다.\n해당 사용자의 차단 기록은 다음과 같습니다:", "blocklog-showsuppresslog": "이 사용자는 과거에 차단된 적이 있으며, ê·¸ 기록이 숨겨져 있습니다.\n해당 사용자의 차단 기록은 다음과 같습니다:", - "blocklogentry": "님이 [[$1]]님을 $2 차단했습니다 $3", + "blocklogentry": "님이 [[$1]] 님을 $2 차단했습니다 $3", "reblock-logentry": " 님이 [[$1]] 님의 차단 기간을 $2(으)로 바꾸었습니다 $3", "blocklogtext": "이 목록은 사용자 차단/차단 해제 기록입니다.\n자동으로 차단된 IP 주소는 여기에 나오지 않습니다.\n[[Special:BlockList|여기]]에서 현재 차단된 사용자 목록을 ë³¼ 수 있습니다.", "unblocklogentry": "님이 $1님을 차단 해제했습니다", diff --git a/languages/i18n/krc.json b/languages/i18n/krc.json index 8bcc1d0a6e..4a81ccf602 100644 --- a/languages/i18n/krc.json +++ b/languages/i18n/krc.json @@ -477,24 +477,6 @@ "resettokens": "Токенлени джибер", "resettokens-tokens": "Токенле:", "resettokens-token-label": "$1 (бусагъатдагъы: $2)", - "bold_sample": "Къалын джазыу", - "bold_tip": "Къалын джазыу", - "italic_sample": "Сёдегей джазыу", - "italic_tip": "Сёдегей джазыу", - "link_sample": "Джибериуню башлыгъы", - "link_tip": "Ич джибериу", - "extlink_sample": "http://www.example.com линкни ачыкълауу", - "extlink_tip": "Тыш джибериу (http:// префиксни унутмагъыз)", - "headline_sample": "Башлыкъны тексти", - "headline_tip": "2-чи дараджалы башлыкъ", - "nowiki_sample": "Формат этилинмеген текстни бери салыгъыз", - "nowiki_tip": "Вики-формат этиуню игнор эт", - "image_sample": "Юлгю.jpg", - "image_tip": "Эндирилген файл", - "media_sample": "Юлгю.ogg", - "media_tip": "Медиа-файлгъа джибериу", - "sig_tip": "Къол салыуугъуз эмда заман", - "hr_tip": "Горизонтал сыз (кёб хайырландырмагъыз)", "summary": "Тюрлениулени къысха ачыкълау:", "subject": "Тема/башлыкъ:", "minoredit": "Бу гитче тюрлениудю", diff --git a/languages/i18n/krl.json b/languages/i18n/krl.json index a49150d67c..38ee466216 100644 --- a/languages/i18n/krl.json +++ b/languages/i18n/krl.json @@ -223,22 +223,6 @@ "passwordreset": "Kirjuta Å¡alaÅ¡ana uuvveÅ¡tah", "passwordreset-username": "Käyttäjänimi:", "passwordreset-domain": "Domain:", - "bold_sample": "Lihavointa", - "bold_tip": "Lihavointa", - "italic_sample": "KurÅ¡ivoitu teksti", - "italic_tip": "KurÅ¡ivointa", - "link_sample": "Linkki", - "link_tip": "Å iämilinkki", - "extlink_sample": "http://www.example.com linkin nimi", - "extlink_tip": "Ulkopuolini linkki (muissa laittua http:// alkuh)", - "headline_sample": "Očikkoteksti", - "headline_tip": "TaÅ¡on 2 očikko", - "nowiki_sample": "Lisyä täh teksti, kumpaista ei pijä korjata", - "nowiki_tip": "Penkuo wiki-korjauÅ¡ta", - "image_tip": "Tallennettu faili", - "media_tip": "Linkki failih", - "sig_tip": "Teijän allakirjutuÅ¡ ta aika", - "hr_tip": "VuakaÅ¡uora viiva (elä käytä liijakÅ¡i)", "summary": "Yhtehveto", "minoredit": "Tämä on pieni kohennuÅ¡", "watchthis": "Tarkkaile tätä Å¡ivuo", diff --git a/languages/i18n/ksh.json b/languages/i18n/ksh.json index d44431be91..7a594635e9 100644 --- a/languages/i18n/ksh.json +++ b/languages/i18n/ksh.json @@ -578,24 +578,6 @@ "resettokens-watchlist-token": "ä schlößel för dä <i lang=\"en\" xml:lang=\"en\">Atom</i>- udder <i lang=\"en\" xml:lang=\"en\">RSS</i>-Kanaal met de [[Special:Watchlist|Änderonge aan Sigge en Dinger Oppaßleß]]", "resettokens-done": "Schlößel neu jemaat.", "resettokens-resetbutton": "Lohß Jonn!", - "bold_sample": "Fätte Schreff", - "bold_tip": "Fätte Schreff", - "italic_sample": "Scheive Schreff", - "italic_tip": "Scheive Schreff", - "link_sample": "Anker Tex", - "link_tip": "Ene Link en {{GRAMMAR:Akkusativ|{{SITENAME}}}}", - "extlink_sample": "http://www.example.com/dat_he_oohne_Zwescheräum Donoh dä Anker Tex", - "extlink_tip": "Ene Link noh drusse (denk dran, http:// aan dr Aanfang!)", - "headline_sample": "Üvverschreff", - "headline_tip": "Övverschreff om bövverschte Nivvo", - "nowiki_sample": "Heh kütt dä Tex hen, dä vun de Wiki-Soffwär nit bearbeid, un en Rauh jelooße wääde soll", - "nowiki_tip": "Der Wikki_Kohd för et Fommattehre övverjonn", - "image_sample": "Beispill.jpg", - "image_tip": "E Beldche enbaue", - "media_sample": "Beispill.ogg", - "media_tip": "Ene Link op en Tondatei, e Filmche, oder esu jet", - "sig_tip": "Dinge Nahme, med de Uhrzigk unn_em Dattum", - "hr_tip": "En Querlinnich", "summary": "Koot zosammejefaß, Quäll:", "subject": "Övverschreff - wodröm jeiht et?", "minoredit": "Dat es en klein Änderong (mini)", diff --git a/languages/i18n/ku-latn.json b/languages/i18n/ku-latn.json index b6fcb4ddc8..30e327d2c2 100644 --- a/languages/i18n/ku-latn.json +++ b/languages/i18n/ku-latn.json @@ -471,24 +471,6 @@ "changeemail-password": "Şîfreya te ya {{SITENAME}}ê:", "changeemail-submit": "Enameyê biguherîne", "resettokens": "Mifteya jê bibe", - "bold_sample": "Nivîsa stûr", - "bold_tip": "Nivîsa stûr", - "italic_sample": "Nivîsa xwehr (îtalîk)", - "italic_tip": "Nivîsa xwehr (îtalîk)", - "link_sample": "Sernavê girêdanê", - "link_tip": "Girêdana navxweyî", - "extlink_sample": "http://www.example.com navê lînkê", - "extlink_tip": "Girêdana derve (http:// di destpêkê de ji bîr neke)", - "headline_sample": "Nivîsara sernameyê", - "headline_tip": "Sername asta 2", - "nowiki_sample": "Nivîs ku nebe formatkirin", - "nowiki_tip": "Guh nede formatkirina wiki", - "image_sample": "Mînak.jpg", - "image_tip": "Wêne li hundirê gotarê", - "media_sample": "Mînak.ogg", - "media_tip": "Girêdana pelê", - "sig_tip": "Îmze û demxeya wext ya te", - "hr_tip": "Rastexêza berwarî (kêm bi kar bîne)", "summary": "Kurte (Te çi kir?):", "subject": "Mijar:", "minoredit": "Ev guhertineke biçûk e", diff --git a/languages/i18n/kum.json b/languages/i18n/kum.json index 8ab6117b06..7afa390e1d 100644 --- a/languages/i18n/kum.json +++ b/languages/i18n/kum.json @@ -264,22 +264,6 @@ "passwordreset": "Чечилни янгыдан бегетмек", "passwordreset-username": "Къоллавчу аты", "changeemail-none": "(ёкъ)", - "bold_sample": "Къалын матын", - "bold_tip": "Къалын матын", - "italic_sample": "Авункъу матын", - "italic_tip": "Авункъу матын", - "link_sample": "Байланывну аты", - "link_tip": "Ич байланыв", - "extlink_sample": "http://www.example.com байланывну аты", - "extlink_tip": "Тыш байланыв (бу префиксни http:// эсде сакъла)", - "headline_sample": "Язывбашны матыны", - "headline_tip": "2 даражаны язывбашы", - "nowiki_sample": "Форматланмагъа гере тюгюл матынны бери сал", - "nowiki_tip": "Вики форматлавну сан этме", - "image_tip": "Гийирилген саплам", - "media_tip": "Сапламгъа байланыв", - "sig_tip": "Къол басымынг ва заман мюгьюрю", - "hr_tip": "Гёнделен гьыз (къоралап къолла)", "summary": "Алышывну къысгъартылымы:", "minoredit": "Увакъ тюзлев", "watchthis": "Бу сагьифаны гьызарламакъ", diff --git a/languages/i18n/kw.json b/languages/i18n/kw.json index e18937ffbb..cc32812ea2 100644 --- a/languages/i18n/kw.json +++ b/languages/i18n/kw.json @@ -364,22 +364,6 @@ "changeemail-none": "(nagonan)", "changeemail-password": "Agas ger tremena war {{SITENAME}}:", "changeemail-submit": "Chanjya an trigva ebost", - "bold_sample": "Tekst tew", - "bold_tip": "Tekst tew", - "italic_sample": "Tekst italek", - "italic_tip": "Tekst italek", - "link_sample": "Titel an gevren", - "link_tip": "Kevren bervedhel", - "extlink_sample": "http://www.example.com titel an gevren", - "extlink_tip": "Kevren a-ves (na ankevewgh an rager http://)", - "headline_sample": "Tekst an bennlinen", - "headline_tip": "Pennlinen nivel 2", - "nowiki_sample": "Keworrewgh tekst heb furvyans omma", - "nowiki_tip": "Skonya aswon furvyans wiki", - "image_tip": "Restren neythys", - "media_tip": "Kevren restren", - "sig_tip": "Agas sinans ha stampa-termyn", - "hr_tip": "Linen worwelyek (na usyowgh re)", "summary": "Berrskrif:", "subject": "Testen:", "minoredit": "Chanj byghan yw hemma", diff --git a/languages/i18n/ky.json b/languages/i18n/ky.json index de4b5e7823..89237f8833 100644 --- a/languages/i18n/ky.json +++ b/languages/i18n/ky.json @@ -431,22 +431,6 @@ "changeemail-none": "(жок)", "changeemail-password": "«{{SITENAME}}» долбоору үчүн сиздин сырсөзүңүз:", "changeemail-submit": "E-mail'ди өзгөртүү", - "bold_sample": "Калың текст", - "bold_tip": "Калың текст", - "italic_sample": "жантык текст", - "italic_tip": "жантык текст", - "link_sample": "Шилтеменин аты", - "link_tip": "Ички шилтеме", - "extlink_sample": "http://www.example.com шилтеме аталышы", - "extlink_tip": "Сырткы шилтемелерге (http:// префиксин койгонду унутпаңыз)", - "headline_sample": "Башсөз тексти", - "headline_tip": "2-деңгээлдеги башсөз", - "nowiki_sample": "Форматталбаган текстти бул жерге киргизиңиз", - "nowiki_tip": "Уики-форматтоого көңүл бурбоо", - "image_tip": "Кыстарылган файл", - "media_tip": "Файл шилтемеси", - "sig_tip": "Кол тамгаңыз жана убакыт мөөрү", - "hr_tip": "Туура сызык (жыш колдонбоңуз)", "summary": "Жыйынтыгы:", "subject": "Тема/баш аты:", "minoredit": "Майда оңдоо", diff --git a/languages/i18n/la.json b/languages/i18n/la.json index 9f7a0629fc..b128eaf703 100644 --- a/languages/i18n/la.json +++ b/languages/i18n/la.json @@ -417,24 +417,6 @@ "passwordreset-emailelement": "Nomen usoris: \n$1\n\nMomentarius Tessera: \n$2", "changeemail-none": "(nulla)", "changeemail-submit": "Inscriptionem electronicam mutare", - "bold_sample": "Litterae pingues", - "bold_tip": "Litterae pingues", - "italic_sample": "Textus litteris Italicis scriptus", - "italic_tip": "Textus litteris Italicis scriptus", - "link_sample": "Titulum nexere", - "link_tip": "Nexus internus", - "extlink_sample": "http://www.example.com titulus nexus externi", - "extlink_tip": "Nexus externus (memento praefixi http://)", - "headline_sample": "Textus capituli", - "headline_tip": "Linea capitalis scalae 2", - "nowiki_sample": "Adde textum (sine indiciis)", - "nowiki_tip": "Indicia neglige", - "image_sample": "Exemplum.jpg", - "image_tip": "Fasciculus in pagina impositus", - "media_sample": "Exemplum.ogg", - "media_tip": "Nexus ad fasciculum", - "sig_tip": "Subscriptio tua cum indicatione temporis", - "hr_tip": "Linea horizontalis (noli saepe uti)", "summary": "Summarium:", "subject": "Res/titulus:", "minoredit": "Haec est recensio minor", diff --git a/languages/i18n/lad.json b/languages/i18n/lad.json index df56a40b60..bdfc178923 100644 --- a/languages/i18n/lad.json +++ b/languages/i18n/lad.json @@ -382,22 +382,6 @@ "changeemail-password": "Tu kontrasenya en {{SITENAME}}:", "changeemail-submit": "Trocar letral", "resettokens-token-label": "$1(valor aktual: $2)", - "bold_sample": "Teksto reforçado", - "bold_tip": "Teksto reforçado", - "italic_sample": "Teksto aladado", - "italic_tip": "Teksto aladado", - "link_sample": "Títolo del atamiento", - "link_tip": "Atamiento (link) interno", - "extlink_sample": "http://www.example.com Títolo del atamiento", - "extlink_tip": "Atamiento esterno (link de afuera: acόdrate de ajustar el prefikso http://)", - "headline_sample": "Teksto del títolo", - "headline_tip": "Títolo de nivel 2", - "nowiki_sample": "El teksto sin formato, escrívelo aquí", - "nowiki_tip": "Iñora el formato viki", - "image_tip": "Dosya encaxada", - "media_tip": "Atamiento de la dosya", - "sig_tip": "Tu firma con la data y la ora", - "hr_tip": "Liña orizontal (kulanea poco)", "summary": "Rezümé:", "subject": "Tema/título:", "minoredit": "Esto es un trocamiento chiquitico", diff --git a/languages/i18n/lb.json b/languages/i18n/lb.json index 643e52f73f..fd1cab2291 100644 --- a/languages/i18n/lb.json +++ b/languages/i18n/lb.json @@ -427,7 +427,7 @@ "createaccountmail": "En temporäert zoufällegt Passwuert benotzen an et per E-Mail un déi spezifizéiert E-Mailadress schécken", "createaccountmail-help": "Ka benotzt gi fir e Benotzerkont fir eng aner Persoun unzeleeën ouni d'Passwuert gewuer ze ginn.", "createacct-realname": "Richtegen Numm (fakultativ)", - "createacct-reason": "Grond", + "createacct-reason": "Grond (ëffentlech geloggt)", "createacct-reason-ph": "Fir wat Dir een anere Benotzerkonnt uleet", "createacct-reason-help": "Message deen am Logbuch vun den ugeluechte Benotzerkonte gewise gëtt", "createacct-submit": "Äre Benotzerkont uleeën", @@ -584,24 +584,6 @@ "resettokens-watchlist-token": "Token fir de Webfeed (Atom/RSS) vun den [[Special:Watchlist|Ännerungen op Säite vun Ärer Iwwerwaachungslëscht]]", "resettokens-done": "Token zréckgesat.", "resettokens-resetbutton": "Selectionéiert Tokens zrécksetzen", - "bold_sample": "Fettgedréckten Text", - "bold_tip": "Fettgedréckten Text", - "italic_sample": "Kursiven Text", - "italic_tip": "Kursiven Text", - "link_sample": "Link-Text", - "link_tip": "Interne Link", - "extlink_sample": "http://www.example.com Link Titel", - "extlink_tip": "Externe Link (Vergiesst net den http:// Prefix)", - "headline_sample": "Titel Text", - "headline_tip": "Iwwerschrëft vum Niveau 2", - "nowiki_sample": "Net-formatéierten Text hei androen", - "nowiki_tip": "Wiki-Format ignoréieren", - "image_sample": "Beispill.jpg", - "image_tip": "Bildlink", - "media_sample": "Beispill.ogg", - "media_tip": "Link op e Medieichier", - "sig_tip": "Är Ënnerschrëft mat Zäitstempel", - "hr_tip": "Horizontal Linn (mat Mooss gebrauchen)", "summary": "Resumé:", "subject": "Sujet:", "minoredit": "Dëst ass eng kleng Ännerung", diff --git a/languages/i18n/lez.json b/languages/i18n/lez.json index 1aa45fa4f7..82e3f89ede 100644 --- a/languages/i18n/lez.json +++ b/languages/i18n/lez.json @@ -285,22 +285,6 @@ "changeemail": "Э-почта дегишарун", "changeemail-none": "(садни)", "changeemail-submit": "E-адрес дегишун", - "bold_sample": "ЯцIу текст", - "bold_tip": "Къалин текст", - "italic_sample": "Курсивдин текст", - "italic_tip": "Курсивдин текст", - "link_sample": "Элячlунин кьилин цlар", - "link_tip": "Къенепатан элячlун", - "extlink_sample": "http://www.example.com элячlунин кьилин цlар", - "extlink_tip": "Къецепатан элячlун ( http:// префикс рикlел хуьх)", - "headline_sample": "Кьилинцlарцlин текст", - "headline_tip": "2-й дережадин кьилин цlар", - "nowiki_sample": "Формат тавунвай текст иниз тур", - "nowiki_tip": "Викидин форматун гьисаба кьамир", - "image_tip": "Ттунвай файл", - "media_tip": "Файлдин элячlун", - "sig_tip": "Куь къулни вахт", - "hr_tip": "Къаткай цlар (фад-фад кардик кутумир )", "summary": "Нетижа:", "subject": "Тема/кьилинцIар", "minoredit": "ГъвечIи дуьзар хъувун", diff --git a/languages/i18n/lfn.json b/languages/i18n/lfn.json index 65ade148e4..daeb72f5b6 100644 --- a/languages/i18n/lfn.json +++ b/languages/i18n/lfn.json @@ -585,22 +585,6 @@ "resettokens-watchlist-token": "Marca per la flue ueb (Atom/RSS) de [[Special:Watchlist|cambias a tua pajes monitorida]]", "resettokens-done": "Marcas reinisiada.", "resettokens-resetbutton": "Reinisia marcas elejeda", - "bold_sample": "Testo spesa", - "bold_tip": "Testo spesa", - "italic_sample": "Testo apoiada", - "italic_tip": "Testo apoiada", - "link_sample": "Titulo de lia", - "link_tip": "Lia interna", - "extlink_sample": "http://www.example.com titulo de lia", - "extlink_tip": "Lia esterna (no oblida la prefisa http://)", - "headline_sample": "Testo de titulo", - "headline_tip": "Titulo de nivel 2", - "nowiki_sample": "Ajunta asi testo nonformatida", - "nowiki_tip": "Iniora sintatica de vici", - "image_tip": "Fix interna", - "media_tip": "Lia de fix", - "sig_tip": "Tua suscrive con indica de ora", - "hr_tip": "Linia orizonal (per usas rara)", "summary": "Resoma:", "subject": "Tema:", "minoredit": "Esta es un cambia minor", diff --git a/languages/i18n/lg.json b/languages/i18n/lg.json index 8ac21e368a..c697544f4e 100644 --- a/languages/i18n/lg.json +++ b/languages/i18n/lg.json @@ -356,22 +356,6 @@ "passwordreset-email": "Endagiriro eya 'email':", "passwordreset-emailtitle": "Ebya akawunti ey'oku {{SITENAME}}", "passwordreset-emailelement": "Ery'obwa memba: \n$1\n <br />\nEkyama kyo eky'ekiseerabuseera: \n$2", - "bold_sample": "Ennukuta z'owandika wano zonna ziba nziggumivu", - "bold_tip": "Bw'onyiga kano, ofuna w'oyinza okuwandikira ennukuta ezo ne zivaamu nga nziggumivu", - "italic_sample": "Ennukuta z'owandika wano zonna ziba za italiki", - "italic_tip": "Bw'onyiga ku kano, ennukuta z'oddako okuwandika ziba za italiki (ez'esurise). Okuddamu okufuna ennukuta eza bulijjo, ddamu okukanyiga ko.", - "link_sample": "Enyunzi yo eno egguke wa?", - "link_tip": "Nyiga wano ob'oyagala okukolawo enyunzi egguka ku kifo ekiri ku wiki eno", - "extlink_sample": "http://www.example.com linnya lya nyunzi", - "extlink_tip": "Nyiga ku kano ob'oyagala okuteekawo enyunzi egguka ku kifo ekitali ku wiki eno. (genderera ne kutabulako ennukuta ezikulembedde, http:// )", - "headline_sample": "Mutwe omukulu", - "headline_tip": "Nyiga ku kano okuwandika omutwe ogw'eddaala ery'okubiri", - "nowiki_sample": "Byowandika wano tebijjakufuulafuulibwa enkola ya wiki", - "nowiki_tip": "Nyiga ku kano ob'oyagala okufuna w'owandikira ebintu ebitafuulibwafuulibwa enkola ya wiki", - "image_tip": "Bw'onyiga ku kano, we wakomye okuwandika wajjawo enyunzi eteekawo ekifaananyi", - "media_tip": "Bw'onyiga ku kano, w'okomye okuwandika wajjawo enyunzi gy'okozesa okugguka ku fayiro eya mediya (eya vidiyo oba maloboozi)", - "sig_tip": "Nyiga ku kano ob'oyagala okuteekawo n'erinnya lyo ko n'obudde kw'omalidde bino by'okoze.", - "hr_tip": "Bw'onyiga ku kano ofuna olusaze olwawula mu by'owandika. (Gezaako butakozesa nyingi)", "summary": "Wandika wano ebinyonyola enkyukakyuka z'okoze:", "subject": "Ekyogerwako/Mutwe:", "minoredit": "Eno nkyukakyuka ntono", diff --git a/languages/i18n/li.json b/languages/i18n/li.json index 70cd91ef8c..2698845ce7 100644 --- a/languages/i18n/li.json +++ b/languages/i18n/li.json @@ -591,22 +591,6 @@ "resettokens-watchlist-token": "Teike veur webfeed van [[Special:Watchlist|dien volglies]] (Atom/RSS)", "resettokens-done": "Teikes oppernuuj ingestèldj.", "resettokens-resetbutton": "Stèl gesillekteerde teikes oppernuuj in", - "bold_sample": "Vètten teks", - "bold_tip": "Vetten teks", - "italic_sample": "Sjuunsen tèks", - "italic_tip": "Sjuunsen tèks", - "link_sample": "Link titel", - "link_tip": "Interne link", - "extlink_sample": "http://www.example.com link titel", - "extlink_tip": "Extern link (mit de http:// prefix)", - "headline_sample": "Deilongerwerp", - "headline_tip": "Tusseköpske (hoogste niveau)", - "nowiki_sample": "Veur hiej de neet op te make teks in", - "nowiki_tip": "Verloup wiki-opmaak", - "image_tip": "Mediabesjtandj", - "media_tip": "Link nao bestandj", - "sig_tip": "Dien handjteikening mit datum en tied", - "hr_tip": "Horizontaal lien (gebroek spaarzaam)", "summary": "Samevatting:", "subject": "Óngerwirp:", "minoredit": "Dit is 'n klein verangering", diff --git a/languages/i18n/lij.json b/languages/i18n/lij.json index 6115d5ad71..474ede4792 100644 --- a/languages/i18n/lij.json +++ b/languages/i18n/lij.json @@ -596,24 +596,6 @@ "resettokens-watchlist-token": "Token pe-o feed web (Atom/RSS) de [[Special:Watchlist|modiffiche a-e paggine inti teu sott'oservaçion]]", "resettokens-done": "Token reimpostæ.", "resettokens-resetbutton": "Reimposta token selessionæ", - "bold_sample": "Grascetto", - "bold_tip": "Grascetto", - "italic_sample": "Corscîvo", - "italic_tip": "Corscîvo", - "link_sample": "Tìtolo do colegaménto", - "link_tip": "Colegaménto intèrno", - "extlink_sample": "http://www.example.com tittolo de l'ingancio", - "extlink_tip": "Colegaménto esterno (inclûdde o prefisso http:// )", - "headline_sample": "Tìtolo", - "headline_tip": "Tìtolo de 2° livello", - "nowiki_sample": "Inserî chì o testo sensa formattaçion", - "nowiki_tip": "Ignorâ a formattassion wiki", - "image_sample": "Exempio.jpg", - "image_tip": "Incorpora file", - "media_sample": "Exempio.ogg", - "media_tip": "Ingancio a file moltimediâ", - "sig_tip": "Firma con dæta e ôa", - "hr_tip": "Linnia orizontâ", "summary": "Ògetto:", "subject": "Sogetto:", "minoredit": "Quésta a l'é 'na modìfica minô", diff --git a/languages/i18n/lki.json b/languages/i18n/lki.json index d0b7d94e5b..af7eb7383d 100644 --- a/languages/i18n/lki.json +++ b/languages/i18n/lki.json @@ -584,24 +584,6 @@ "resettokens-watchlist-token": "شناسانندهٔ خوراک وبِی [[Special:Watchlist|تغییرات صفحه‌هایی که پی‌گیری می‌کنید]] (اتم/آراس‌اس)", "resettokens-done": "بازنشانی شناساننده‌ها.", "resettokens-resetbutton": "بازشناسی شناساننده‌های گزیده‌شده.", - "bold_sample": "متن پررنگ", - "bold_tip": "متن پررنگ", - "italic_sample": "متن کۀچ/هؤۀل", - "italic_tip": "متن کۀچ/هؤۀل", - "link_sample": "عنوان پیوند", - "link_tip": "پیوند درونی", - "extlink_sample": "http://www.example.com عنوان پیوند", - "extlink_tip": ") را فراموش نکنید http:// پیوند به بیرون (پیشوند", - "headline_sample": "متن عنوان", - "headline_tip": "عنوان سطح Û²", - "nowiki_sample": "متن قالب‌بندی‌نشده اینجا وارد شود", - "nowiki_tip": "نادیده‌گرفتن قالب‌بندی ویکی", - "image_sample": "نموونە.jpg", - "image_tip": "تصویر داخل متن", - "media_sample": "نموونە.ogg", - "media_tip": "پیوند پرونده", - "sig_tip": "امضای هومۀ و برچسب زۀمان", - "hr_tip": " )خط افقی(از آن کم استفاده کنید", "summary": "خلاصه:", "subject": "عنوان:", "minoredit": "یۀ دۀسکاری جزئیکۀ", diff --git a/languages/i18n/lmo.json b/languages/i18n/lmo.json index 42e8957ffd..744e5bf07c 100644 --- a/languages/i18n/lmo.json +++ b/languages/i18n/lmo.json @@ -458,22 +458,6 @@ "resettokens-token-label": "$1 (valùr de adès: $2)", "resettokens-done": "Tokens redefinìcc.", "resettokens-resetbutton": "Redefenés i tokens selesiunàcc", - "bold_sample": "Test in grasset", - "bold_tip": "Test in grasset", - "italic_sample": "Test in cursiv", - "italic_tip": "Test in cursiv", - "link_sample": "Titul del ligam", - "link_tip": "Ligam de dent", - "extlink_sample": "http://www.example.com titul del ligam", - "extlink_tip": "Ligam de föra (regordess el prefiss http:// )", - "headline_sample": "Intestazión de l'articul", - "headline_tip": "Intestazión de 2° nivel", - "nowiki_sample": "Met dent chì el test minga furmataa", - "nowiki_tip": "Ignora la furmatazión wiki", - "image_tip": "File inglubaa in del test", - "media_tip": "Ligam a un file multimedial", - "sig_tip": "Firma cun data e ura", - "hr_tip": "Riga urizuntala (duprala cun giüdizi)", "summary": "Mutiv per la mudifega:", "subject": "Suget (intestazión)", "minoredit": "Questa chì l'è una mudifega piscinina", diff --git a/languages/i18n/lo.json b/languages/i18n/lo.json index bb300a75ca..98c5a30615 100644 --- a/languages/i18n/lo.json +++ b/languages/i18n/lo.json @@ -380,17 +380,6 @@ "resetpass_submit": "ຕັ້ງລະຫັດຜ່ານ ແລະ ເຊັນເຂົ້າ", "changepassword-success": "ລະຫັດຜ່ານຂອງທ່ານຖືກປ່ຽນແລ້ວ!", "passwordreset-invalidemail": "ທີ່ຢູ່ອີເມລບໍ່ຖືກຕ້ອງ", - "bold_sample": "ໂຕໜັງສືເຂັ້ມ", - "bold_tip": "ໂຕໜັງສືເຂັ້ມ", - "italic_sample": "ໂຕເນີ້ງ", - "italic_tip": "ໂຕເນີ້ງ", - "link_sample": "ຫົວຂໍ້ລິ້ງຄ໌", - "link_tip": "ລິ້ງຄ໌ພາຍໃນ", - "extlink_sample": "http://www.example.com ຫົວຂໍ້ລິ້ງຄ໌", - "headline_sample": "ສຳຄັນ", - "headline_tip": "ຫົວຂໍ້ລະດັບ 2", - "image_tip": "ໄຟລ໌ຕິດຄັດ", - "media_tip": "ລິ້ງຄ໌ຫາໄຟລ໌", "summary": "ຄຳອະທິບາຍໂດຍຫຍໍ້:", "subject": "ຫົວຂໍ້:", "minoredit": "ນີ້ແມ່ນການດັດແກ້ເລັກນ້ອຍ", diff --git a/languages/i18n/loz.json b/languages/i18n/loz.json index 9bfc84d138..ff47e86477 100644 --- a/languages/i18n/loz.json +++ b/languages/i18n/loz.json @@ -246,24 +246,6 @@ "resetpass_header": "Lisetize sebu dafi", "retypenew": "Sebu dafi:", "resetpass_submit": "Setize sebu dafi e menuhile", - "bold_sample": "Selt ombelu", - "bold_tip": "Selt ombelu", - "italic_sample": "Selt itali", - "italic_tip": "Selt itali", - "link_sample": "Sebu di ling'ko", - "link_tip": "Ling'ko bulili in", - "extlink_sample": "http://www.example.com sebu di ling'ko", - "extlink_tip": "Ling'ko bulili out (¡con http://!)", - "headline_sample": "Selt di pagafi", - "headline_tip": "Pagafi (2)", - "nowiki_sample": "Sebu di 'ni-Wikicode' apukisize", - "nowiki_tip": "'Ni Wiki-code' apukisize", - "image_sample": "Kamukile.jpg", - "image_tip": "Kamukile imegi", - "media_sample": "Kamukile.ogg", - "media_tip": "Kamukile media", - "sig_tip": "Sebu di sebelu con xete data (4× ~)", - "hr_tip": "Lani - (sepalati)", "summary": "Lyangutukezi:", "subject": "Lyangutukezi selt:", "minoredit": "A sa pili kenki", diff --git a/languages/i18n/lrc.json b/languages/i18n/lrc.json index 3aa19f4346..e23bf5bed0 100644 --- a/languages/i18n/lrc.json +++ b/languages/i18n/lrc.json @@ -523,24 +523,6 @@ "resettokens-watchlist-token": "دیارگأر سی حوڤال حوٙن تورگە(أتوم/آر ئس ئس) سی [[Special:سئیل بأرگ|آلئشت دأئن بألگە یا د سئیل بأرگئتوٙ]]", "resettokens-done": "نشونٱیا تازٱ بینٱ", "resettokens-resetbutton": "نشونٱ گلٛٱ ڤرچیٱ د نۊ زنٱ بیٱ", - "bold_sample": "نیسسٱ مؽن پور", - "bold_tip": "نیسسٱ مؽن پور", - "italic_sample": "نیسسٱیا هٱلٛ ۉ هار", - "italic_tip": "نیسسٱیا هٱلٛ ۉ هار", - "link_sample": "داسون هوم پاٛڤٱن", - "link_tip": "هوم پاٛڤٱن مؽنجایی", - "extlink_sample": "http://www.example.com داسون هوم پاٛڤٱن", - "extlink_tip": "هوم پاٛڤٱن خارجی(د ڤیر داشتۊیؽت)", - "headline_sample": "سٱرخٱت نیسسٱ", - "headline_tip": "ریتراز 2 خٱت سٱرڤٱن", - "nowiki_sample": "د ایچاْ یاٛ نیسسٱ ڤارد بٱکؽت", - "nowiki_tip": "د شکل ڤیکی تیٱپۊشی بٱک", - "image_sample": "Example.jpg", - "image_tip": "جانؽا چار قر گرتٱ", - "media_sample": "Example.ogg", - "media_tip": "جانؽا هوم پاٛڤٱن", - "sig_tip": "اْمزا شما ڤا گاتدیس", - "hr_tip": "خٱت آسو ڤٱنٱ(جگا جگا Ú¤ کار گرتن)", "summary": "چکسٱ", "subject": "ذاسوٙن/سأرتال:", "minoredit": "یٱ یاٛ ڤیرایش کوچکٱ", diff --git a/languages/i18n/lt.json b/languages/i18n/lt.json index d5dd5946a7..5286b97c27 100644 --- a/languages/i18n/lt.json +++ b/languages/i18n/lt.json @@ -609,24 +609,6 @@ "resettokens-watchlist-token": "Žetonas skirtas interneto pateikčiai (Atom/RSS) [[Special:Watchlist|pakeitimai puslapiuose, kuriuose jÅ«s stebite]]", "resettokens-done": "Žetonų atnaujinimas.", "resettokens-resetbutton": "Atnaujinti pasirinktus žetonus", - "bold_sample": "ParyÅ¡kintas tekstas", - "bold_tip": "ParyÅ¡kinti tekstą", - "italic_sample": "Tekstas kursyvu", - "italic_tip": "Tekstas kursyvu", - "link_sample": "Nuorodos pavadinimas", - "link_tip": "Vidinė nuoroda", - "extlink_sample": "http://www.pavyzdys.lt nuorodos pavadinimas", - "extlink_tip": "IÅ¡orinė nuoroda (nepamirÅ¡kite http:// priedėlio)", - "headline_sample": "Skyriaus pavadinimas", - "headline_tip": "Antro lygio skyriaus pavadinimas", - "nowiki_sample": "Čia įterpkite neformuotą tekstą", - "nowiki_tip": "Ignoruoti wiki formatą", - "image_sample": "Pavyzdys.jpg", - "image_tip": "Ä®terpta rinkmena", - "media_sample": "Pavyzdys.ogg", - "media_tip": "Nuoroda į rinkmeną", - "sig_tip": "JÅ«sų paraÅ¡as bei laikas", - "hr_tip": "Horizontali linija (naudokite saikingai)", "summary": "PaaiÅ¡kinimas:", "subject": "Tema:", "minoredit": "Tai smulkus pataisymas", @@ -2071,7 +2053,7 @@ "emailuser-title-target": "Siųsti el. paÅ¡to žinutę {{GENDER:$1|naudotojui|naudotojai}}", "emailuser-title-notarget": "El. paÅ¡to vartotojas", "emailpagetext": "JÅ«s galite pasinaudoti Å¡iuo pavyzdžiu, norėdami nusiųsti elektroninį laiÅ¡ką {{GENDER:$1|Å¡iam naudotojui|Å¡iai naudotojai}}.\nElektroninio paÅ¡to adresas, kurį įvedėte [[Special:Preferences|savo naudotojo nustatymuose]], bus rodomas kaip el. paÅ¡to siuntėjo adresas tam, kad gavėjas galėtų tiesiogiai jums atsakyti.", - "defemailsubject": "{{SITENAME}} el. paÅ¡to iÅ¡ vartotojo \" $1 \"", + "defemailsubject": "{{SITENAME}} laiÅ¡kas iÅ¡ naudotojo „$1“", "usermaildisabled": "Naudotojo elektroninis paÅ¡tas iÅ¡jungtas", "usermaildisabledtext": "JÅ«s negalite siÅ«lsti el. laiÅ¡ko kitiems Å¡io wiki projekto naudotojams.", "noemailtitle": "Nėra el. paÅ¡to adreso", diff --git a/languages/i18n/ltg.json b/languages/i18n/ltg.json index 3d492d5e49..6d0a7d8bba 100644 --- a/languages/i18n/ltg.json +++ b/languages/i18n/ltg.json @@ -183,24 +183,6 @@ "resetpass-submit-cancel": "Atsaukt", "passwordreset-username": "Slāgvuords:", "passwordreset-email": "E-posta adress:", - "bold_sample": "Pamalnais roksts", - "bold_tip": "Pamalnais roksts", - "italic_sample": "Sleipais roksts", - "italic_tip": "Sleipais roksts", - "link_sample": "Saitys pasauka", - "link_tip": "Vydyskuo saita", - "extlink_sample": "http://www.example.com saitys pasauka", - "extlink_tip": "Uorejuo saite (naaizmierst suokumā dalikt \"http://\")", - "headline_sample": "Viersroksta teksts", - "headline_tip": "2 leidzīņa viersroksts", - "nowiki_sample": "Ite rokst naformatietu tekstu", - "nowiki_tip": "Najimt vārā wiki formatiejumu", - "image_sample": "Paraugs.jpg", - "image_tip": "Paguļdeits fails", - "media_sample": "Paraugs.ogg", - "media_tip": "Saite iz multimediju failu", - "sig_tip": "Tovs paroksts ar laika atzeimi", - "hr_tip": "Horizontaluo lineja (nalÄ«c bez vajadzeibys)", "summary": "KÅ«psavylkums", "subject": "Tema/viersroksts:", "minoredit": "nanÅ«zeimeigs lobuojums", diff --git a/languages/i18n/lus.json b/languages/i18n/lus.json index ca6a195401..d11bc2eba6 100644 --- a/languages/i18n/lus.json +++ b/languages/i18n/lus.json @@ -378,22 +378,6 @@ "changeemail-none": "(pakhat mah)", "changeemail-password": "I {{SITENAME}} thurûk:", "changeemail-submit": "E-chenhmun thlâk rawh", - "bold_sample": "Hawrawp thau", - "bold_tip": "Hawrawp thau", - "italic_sample": "Hawrawp äwn", - "italic_tip": "Hawrawp äwn", - "link_sample": "Zawmna hming", - "link_tip": "Inzawm chhawnna", - "extlink_sample": "http://www.example.com zawmna hming", - "extlink_tip": "Pawnlam zawmna (http:// tih hmabet kha theihnghilh suh la)", - "headline_sample": "Thupui", - "headline_tip": "Chhawng 2-na thupui", - "nowiki_sample": "Hetah hian thu siamrem sa ni lo dahlut rawh", - "nowiki_tip": "Wiki siamrem ngaihthah rawh", - "image_tip": "Taksa telh", - "media_tip": "Taksa zawmna", - "sig_tip": "I hmingnem leh hun", - "hr_tip": "Rin khamphei (ren deuh la)", "summary": "A thu tlangpui (laktawi):", "subject": "Thupui:", "minoredit": "Hei hi siamÅ£hatna tenau a ni", diff --git a/languages/i18n/luz.json b/languages/i18n/luz.json index 70f259bd0c..f8503f34a3 100644 --- a/languages/i18n/luz.json +++ b/languages/i18n/luz.json @@ -396,22 +396,6 @@ "resetpass-temp-password": "رمز جایگزین", "resetpass-expired": "رمز ایشانه اعتبار ناره.لطفا یه رمز نو سیخوتون بونیت.", "passwordreset": "تعویض رمز", - "bold_sample": "مأتن Ú¾ گأپ نیما", - "bold_tip": "مأتن Ú¾ گأپ نیما", - "italic_sample": "مأتن Ú¾ شیکأستە", - "italic_tip": "مأتن Ú¾ شیکأستە", - "link_sample": "عۉنڤان Ú¾ لینک", - "link_tip": "لینک Ú¾ داخلی", - "extlink_sample": "http://www.example.com عۉنڤان Ú¾ لینک", - "extlink_tip": "(ڤە خاطیر بیسپار http:// prefix)\nلینک Ú¾ خاریجی", - "headline_sample": "سأرخأط مأتن", - "headline_tip": "2سأرخأط یکسان", - "nowiki_sample": "مأتن شیکل نأدائە یا فۉرمأت نأڤابیدھ رنە ئبچۉ بنین", - "nowiki_tip": "زھ فۉرمأت کیردأن یا شیکل دائن ڤیکی دس ڤیردار", - "image_tip": "فایل مۉحاط ڤابید", - "media_tip": "لینک Ú¾ فایل", - "sig_tip": "ئیمضا ئیشا Ú¤ بأرچأسب زیموٙن", - "hr_tip": "خأط ئوفۉقی (کأم ئیستیفادھ کۉنین)", "summary": "خۉلاصە:", "minoredit": "ئی یە ئیصلاح کوٙچیر ڤابی", "watchthis": "پیگیری ئی بألگە", diff --git a/languages/i18n/lv.json b/languages/i18n/lv.json index b50b012412..f355e60f41 100644 --- a/languages/i18n/lv.json +++ b/languages/i18n/lv.json @@ -192,7 +192,7 @@ "history": "hronoloÄ£ija", "history_short": "Vēsture", "history_small": "vēsture", - "updatedmarker": "atjaunināts kopÅ¡ mana pēdējā apmeklējuma", + "updatedmarker": "atjaunināts kopÅ¡ tava pēdējā apmeklējuma", "printableversion": "Drukājama versija", "permalink": "PastāvÄ«gā saite", "print": "Drukāt", @@ -434,7 +434,7 @@ "createacct-another-email-ph": "Ievadiet e-pasta adresi", "createaccountmail": "Izmantot nejauÅ¡i Ä£enerētu pagaidu paroli un nosÅ«tÄ«t to uz norādÄ«to e-pasta adresi", "createacct-realname": "Īstais vārds (nav obligāts)", - "createacct-reason": "Iemesls", + "createacct-reason": "Iemesls (publiski redzams)", "createacct-reason-ph": "Kāpēc jÅ«s veidojat citu kontu", "createacct-submit": "Izveidot savu kontu", "createacct-another-submit": "Izveidot citu dalÄ«bnieka kontu", @@ -561,24 +561,6 @@ "changeemail-nochange": "LÅ«dzu, ievadi atÅ¡Ä·irÄ«gu jauno e-pasta adresi.", "resettokens-tokens": "MarÄ·ieri:", "resettokens-token-label": "$1 (Å¡Ä«brīža vērtÄ«ba: $2)", - "bold_sample": "Teksts treknrakstā", - "bold_tip": "Teksts treknrakstā", - "italic_sample": "Teksts kursÄ«vā", - "italic_tip": "Teksts kursÄ«vā", - "link_sample": "Lapas nosaukums", - "link_tip": "Iekšējā saite", - "extlink_sample": "http://www.example.com saites apraksts", - "extlink_tip": "Ārējā saite (neaizmirsti sākumā pierakstÄ«t \"http://\")", - "headline_sample": "Virsraksta teksts", - "headline_tip": "2. lÄ«meņa virsraksts", - "nowiki_sample": "Å eit raksti neformatētu tekstu", - "nowiki_tip": "Ignorēt wiki formatējumu", - "image_sample": "Piemers.jpg", - "image_tip": "Ievietots attēls", - "media_sample": "Piemers.ogg", - "media_tip": "Faila saite", - "sig_tip": "Tavs paraksts ar laika atzÄ«mi", - "hr_tip": "Horizontāla lÄ«nija (neizmanto lieki)", "summary": "Kopsavilkums:", "subject": "Temats:", "minoredit": "MaznozÄ«mÄ«gs labojums", @@ -599,7 +581,7 @@ "anonpreviewwarning": "''Tu neesi ienācis. Saglabājot lapu, Tava IP adrese tiks ierakstÄ«ta Å¡Ä«s lapas hronoloÄ£ijā.''", "missingsummary": "'''Atgādinājums''': Tu neesi norādÄ«jis izmaiņu kopsavilkumu. Vēlreiz klikÅ¡Ä·inot uz \"Saglabāt lapu\", Tavas izmaiņas tiks saglabātas bez kopsavilkuma.", "missingcommenttext": "LÅ«dzu, ievadi komentāru.", - "missingcommentheader": "'''Atgādinājums:''' Tu Å¡im komentāram neesi norādÄ«jis virsrakstu/tematu.\nJa tu vēlreiz spiedÄ«si uz \"$1\", tavas izmaiņas tiks saglabātas bez virsraksta.", + "missingcommentheader": "<strong>Atgādinājums:</strong> Å im komentāram nav norādÄ«ts temats.\nVēlreiz spiežot uz \"$1\", tavs labojums tiks saglabāts bez tā.", "summary-preview": "Labojuma kopsavilkuma priekÅ¡skatÄ«jums:", "subject-preview": "Temata pirmskats:", "blockedtitle": "DalÄ«bnieks ir bloķēts.", @@ -666,6 +648,8 @@ "nocreate-loggedin": "Tev nav atļaujas veidot jaunas lapas.", "sectioneditnotsupported-title": "Sadaļa rediģēšana nav atbalstÄ«ta", "sectioneditnotsupported-text": "Sadaļu rediģēsana Å¡ajā lapā nav atļauta.", + "modeleditnotsupported-title": "LaboÅ¡ana nav atbalstÄ«ta", + "modeleditnotsupported-text": "Satura modelim \"$1\" laboÅ¡ana nav atbalstÄ«ta.", "permissionserrors": "Atļauju kļūda", "permissionserrorstext": "Tev nav atļauts veikt Å¡o darbÄ«bu {{PLURAL:$1|šādu iemeslu|šāda iemesla|šādu iemeslu}} dēļ:", "permissionserrorstext-withaction": "Tev nav atļauts $2 {{PLURAL:$1|šādu iemeslu|šāda iemesla|šādu iemeslu}} dēļ:", @@ -689,6 +673,7 @@ "editpage-invalidcontentmodel-text": "Satura modelis \"$1\" nav atbalstÄ«ts.", "editpage-notsupportedcontentformat-title": "Satura formāts nav atbalstÄ«ts", "editpage-notsupportedcontentformat-text": "Satura formātu $1 neatbalsta satura modelis $2.", + "slot-name-main": "Galvenais", "content-model-wikitext": "vikiteksts", "content-model-text": "vienkārÅ¡s teksts", "content-model-javascript": "JavaScript kods", @@ -1637,6 +1622,7 @@ "prefixindex": "Meklēt pēc virsraksta pirmajiem burtiem", "prefixindex-namespace": "Visas lapas ar prefiksu ($1 vārdtelpa)", "prefixindex-submit": "RādÄ«t", + "prefixindex-strip": "Rezultātos paslēpt prefiksu", "shortpages": "Īsākās lapas", "longpages": "Garākās lapas", "deadendpages": "Lapas bez izejošām saitēm", @@ -1864,6 +1850,7 @@ "dellogpagetext": "Å ajā lapā ir pēdējo dzēsto lapu saraksts.", "deletionlog": "dzēšanas reÄ£istrs", "log-name-create": "Lapu izveides žurnāls", + "logentry-create-create": "$1 {{GENDER:$2|izveidoja}} lapu $3", "reverted": "Atjaunots uz iepriekšējo versiju", "deletecomment": "Iemesls:", "deleteotherreason": "Cits/papildu iemesls:", @@ -1889,8 +1876,8 @@ "sessionfailure": "Ir radusies problēma ar sesijas autentifikāciju;\nÅ¡Ä« darbÄ«ba ir atcelta, lai novērstu lietotājvārda iespējami ļaunprātÄ«gu izmantoÅ¡anu.\nLÅ«dzu, spied \"''back''\" un atjaunini iepriekšējo lapu. Tad mēģini vēlreiz.", "changecontentmodel": "MainÄ«t lapas satura modeli", "changecontentmodel-legend": "MainÄ«t satura modeli", - "changecontentmodel-title-label": "Lapas nosaukums", - "changecontentmodel-model-label": "Jauns satura modelis", + "changecontentmodel-title-label": "Lapas nosaukums:", + "changecontentmodel-model-label": "Jaunais satura modelis:", "changecontentmodel-reason-label": "Iemesls:", "changecontentmodel-submit": "MainÄ«t", "changecontentmodel-success-title": "Satura modelis tika izmainÄ«ts", @@ -2203,7 +2190,7 @@ "fix-double-redirects": "Automātiski izmainÄ«t visas pāradresācijas, kas ved uz sākotnējo nosaukumu", "move-leave-redirect": "Atstāt pāradresāciju", "protectedpagemovewarning": "'''BrÄ«dinājums:''' Å Ä« lapa ir aizsargāta, tikai lietotāji ar administratora privilēģijām var to pārvietot.\nPēdējais reÄ£istra ieraksts ir apskatāms zemāk:", - "semiprotectedpagemovewarning": "'''PiezÄ«me:''' Å Ä« lapa ir aizsargāta, tikai reÄ£istrētie lietotāji var to pārvietot.\nPēdējais reÄ£istra ieraksts ir apskatāms zemāk:", + "semiprotectedpagemovewarning": "<strong>PiezÄ«me:</strong> Å Ä« lapa ir aizsargāta tā, lai tikai paÅ¡pārbaudÄ«tie lietotāji varētu to pārvietot.\nPēdējais reÄ£istra ieraksts ir apskatāms zemāk:", "move-over-sharedrepo": "[[:$1]] jau pastāv koplietotā repozitorijā. PārvietoÅ¡ana uz Å¡o nosaukumu aizstās koplietoto failu.", "file-exists-sharedrepo": "Å is faila nosaukums jau tiek izmantots kopÄ«gajā failu krātuvē.\nLÅ«dzu, izvēlies citu nosaukumu.", "export": "Eksportēt lapas", @@ -2265,7 +2252,7 @@ "importcantopen": "Nevarēja atvērt importējamo failu", "importbadinterwiki": "Slikta starpviki saite", "importsuccess": "Importēšana pabeigta!", - "importnosources": "Tiešā hronoloÄ£ijas augÅ¡uplāde ir atslēgta. Nav definēts neviens ''Transwiki'' importa avots (''source'').", + "importnosources": "Nav definēta neviena vikivietne, no kuras importēt un tiešā hronoloÄ£ijas augÅ¡upielāde ir atslēgta.", "importnofile": "Neviens importējamais fails netika augÅ¡upielādēts.", "importuploaderrorsize": "AugÅ¡upielādēt importējamo failu neizdevās. \nÅ is fails ir lielāks par atļauto augÅ¡upielādes lielumu.", "importuploaderrorpartial": "Importējamā faila augÅ¡upielāde neizdevās.\nFails tika tikai daļēji importēts.", @@ -2323,6 +2310,7 @@ "tooltip-feed-atom": "Å Ä«s lapas Atom barotne", "tooltip-t-contributions": "{{GENDER:$1|Å Ä« dalÄ«bnieka|Å Ä«s dalÄ«bnieces}} ieguldÄ«jumu uzskaitÄ«jums", "tooltip-t-emailuser": "SÅ«tÄ«t e-pastu {{GENDER:$1|Å¡im dalÄ«bniekam|Å¡ai dalÄ«bniecei}}", + "tooltip-t-info": "Vairāk informācijas par Å¡o lapu", "tooltip-t-upload": "AugÅ¡upielādēt failus", "tooltip-t-specialpages": "Visu Ä«paÅ¡o lapu uzskaitÄ«jums", "tooltip-t-print": "Drukājama lapas versija", @@ -2727,8 +2715,10 @@ "diff-form-submit": "ParādÄ«t atÅ¡Ä·irÄ«bas", "permanentlink": "PastāvÄ«gā saite", "permanentlink-revid": "Versijas ID", + "permanentlink-submit": "Doties uz versiju", "newsection": "Jauna sadaļa", "newsection-page": "MērÄ·a lapa", + "newsection-submit": "Doties uz lapu", "dberr-problems": "Atvainojiet!\nÅ ai vietnei ir radušās tehniskas problēmas.", "dberr-again": "Uzgaidiet dažas minÅ«tes un pārlādējiet Å¡o lapu.", "dberr-info": "(Nevar piekļūt datubāzei: $1)", @@ -2748,6 +2738,7 @@ "htmlform-chosen-placeholder": "Izvēlieties iespēju", "htmlform-cloner-create": "Pievienot vairāk", "htmlform-cloner-delete": "Noņemt", + "htmlform-cloner-required": "Vismaz viena vērtÄ«ba ir obligāta.", "htmlform-date-placeholder": "GGGG-MM-DD", "htmlform-title-not-creatable": "\"$1\" nav izveidojams lapas nosaukums", "htmlform-title-not-exists": "$1 nepastāv.", @@ -2899,6 +2890,7 @@ "randomrootpage": "NejauÅ¡a saknes lapa", "log-action-filter-block": "Bloķēšanas veids:", "log-action-filter-protect": "AizsardzÄ«bas veids:", + "log-action-filter-rights": "TiesÄ«bu izmaiņas veids:", "log-action-filter-suppress": "Cenzēšanas veids:", "log-action-filter-upload": "AugÅ¡upielādes veids:", "log-action-filter-block-unblock": "Atbloķēšana", diff --git a/languages/i18n/lzh.json b/languages/i18n/lzh.json index 5924ed247b..659bbeccce 100644 --- a/languages/i18n/lzh.json +++ b/languages/i18n/lzh.json @@ -435,7 +435,7 @@ "cannotchangeemail": "郵址不可更於此wiki", "emaildisabled": "是站不可遣函也。", "accountcreated": "簿增矣", - "accountcreatedtext": "[[{{ns:User}}:$1|$1]] ([[{{ns:User talk}}:$1|書]])簿增矣。", + "accountcreatedtext": "[[{{ns:User}}:$1|$1]]([[{{ns:User talk}}:$1|書]])簿增矣。", "createaccount-title": "於{{SITENAME}}增簿", "createaccount-text": "有人以汝電郵於{{SITENAME}}增簿。簿名為 \"$2\" ($4)。符節為 \"$3\" 。汝應登而更符節。\n\n如簿誤增,汝可略之。", "login-throttled": "汝嘗登簿甚矣。\n請候 $1 而試之。", @@ -488,22 +488,6 @@ "changeemail-password": "汝 {{SITENAME}} 之符節", "changeemail-submit": "更郵址", "changeemail-throttled": "汝嘗登簿甚矣。\n請候 $1 而試之。", - "bold_sample": "粗體", - "bold_tip": "粗體", - "italic_sample": "斜體", - "italic_tip": "斜體", - "link_sample": "鏈", - "link_tip": "鏈內", - "extlink_sample": "http://www.example.com 鍵 題", - "extlink_tip": "冠 http:// 以外鏈", - "headline_sample": "題", - "headline_tip": "二題", - "nowiki_sample": "此不排版", - "nowiki_tip": "不排維基之版", - "image_tip": "嵌檔", - "media_tip": "鏈檔", - "sig_tip": "署名刻時", - "hr_tip": "縱線,慎用之", "summary": "概:", "subject": "題:", "minoredit": "細謹", diff --git a/languages/i18n/lzz.json b/languages/i18n/lzz.json index 5326de6a42..8c4406c229 100644 --- a/languages/i18n/lzz.json +++ b/languages/i18n/lzz.json @@ -242,22 +242,6 @@ "newpassword": "Ağani P'arola:", "passwordreset": "Ağne pʼarola-çkimi moncğoni", "passwordreset-username": "Skani maxmare-coxo:", - "bold_sample": "Mçxu nçʼara", - "bold_tip": "Mçxu nçʼara", - "italic_sample": "Elakteri nçʼara", - "italic_tip": "Elakteri nçʼara", - "link_sample": "Kʼontʼaktʼiş dudicoxo", - "link_tip": "Doloxeni linkʼi", - "extlink_sample": "http://www.example.com adresiş oxo3ʼonapa", - "extlink_tip": "Galeni kʼontʼaktʼi (Adresiş dudis http:// ukʼatit)", - "headline_sample": "Dudicoxoşi nçʼara", - "headline_tip": "2. derece dudicoxo", - "nowiki_sample": "Oxoşkveri formatʼi nçʼara-tkvani ak doçʼarit.", - "nowiki_tip": "vikʼiş formatʼi ipʼtʼali qʼvi.", - "image_tip": "Doxveri dosya", - "media_tip": "Media dosyasişa kʼontʼaktʼi", - "sig_tip": "Xeşçʼara-tkvani do tarixi", - "hr_tip": "Horizontʼali ğara (m3ika ixmarit)", "summary": "Mkʼule nçʼarate:", "subject": "Tema/dudi-coxo:", "minoredit": "Çʼitʼa oktiroba", diff --git a/languages/i18n/mai.json b/languages/i18n/mai.json index 6670969cf1..d887aff07a 100644 --- a/languages/i18n/mai.json +++ b/languages/i18n/mai.json @@ -580,24 +580,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|अहाँके साकांक्षसूची के पृष्ठसभ में परिवर्तन सभ]] के वेब फिट (Atom/RSS) लेल स्तोक", "resettokens-done": "टोकन रीसेट भेल अछि।", "resettokens-resetbutton": "चुनल टोकन रीसेट करी", - "bold_sample": "मोट पाठ", - "bold_tip": "मोट पाठ", - "italic_sample": "कटि लेखन", - "italic_tip": "कटि लेखन", - "link_sample": "लिङ्क शीर्षक", - "link_tip": "आन्तरिक लिङ्क", - "extlink_sample": "http://www.example.com लिङ्क शीर्षक", - "extlink_tip": "बाह्य लिङ्क (यादि राखी http:// उपसर्ग)", - "headline_sample": "शीर्षक पाठ", - "headline_tip": "द्वितीय-स्तर शीर्षक", - "nowiki_sample": "अप्रारूपित पाठ एतय राखी", - "nowiki_tip": "विकी प्रारूपण नजरअन्दाज करी", - "image_sample": "उदाहरण.jpg", - "image_tip": "समाहित चित्र", - "media_sample": "उदाहरण.ogg", - "media_tip": "मिडिया फाइल लिङ्क", - "sig_tip": "अहाँक हस्ताक्षर समयक मोहरकसंग", - "hr_tip": "अक्षांशीय पंक्ति (अल्प उपयोग)", "summary": "सारांश:", "subject": "विषय:", "minoredit": "अल्प सम्पादन", diff --git a/languages/i18n/map-bms.json b/languages/i18n/map-bms.json index e91de7ec31..49295c1cae 100644 --- a/languages/i18n/map-bms.json +++ b/languages/i18n/map-bms.json @@ -516,24 +516,6 @@ "resettokens-token-label": "$1 (siki bijiné:$2)", "resettokens-done": "Token wis disetel maning.", "resettokens-resetbutton": "Nyetel maning token sing dipilih", - "bold_sample": "Tèks kiye bakal dicithak kandel", - "bold_tip": "Cithak kandel", - "italic_sample": "Teks kiye bakal dicithak miring", - "italic_tip": "Teks kiye bakal dicithak miring", - "link_sample": "Judhul pranala", - "link_tip": "Pranala internal", - "extlink_sample": "http://www.example.com judhul pranala", - "extlink_tip": "Pranala njaba (aja kelalen wiwitan http:// )", - "headline_sample": "Tèks judhul", - "headline_tip": "Subbagian tingkat 1", - "nowiki_sample": "Lebokna teks sing ora bakal diformat nang kene", - "nowiki_tip": "Aja nganggo format wiki", - "image_sample": "Conto.jpg", - "image_tip": "Ngaweh berkas", - "media_sample": "Conto.ogg", - "media_tip": "Pranala berkas media", - "sig_tip": "Tapak astane Rika nganggo tandha wektu", - "hr_tip": "Garis horisontal", "summary": "Ringkesan:", "subject": "Subyèk:", "minoredit": "Kiye suntingan cilik", diff --git a/languages/i18n/mdf.json b/languages/i18n/mdf.json index bf50721964..6e44051d99 100644 --- a/languages/i18n/mdf.json +++ b/languages/i18n/mdf.json @@ -402,22 +402,6 @@ "passwordreset-username": "Тиить лемоц", "passwordreset-domain": "Домен:", "passwordreset-emailtitle": "Серматфтомать колга {{SITENAME}}са", - "bold_sample": "Эчке сёрмадома", - "bold_tip": "Эчке сёрмадома", - "italic_sample": "Комафтф сёрмадома", - "italic_tip": "Комафтф сёрмадома", - "link_sample": "Сюлмафксонь конякс", - "link_tip": "Потмоширень сюлмафкс", - "extlink_sample": "http://www.example.com кепотькс", - "extlink_tip": "Ушеширень сюлмафкс (киртть мяльса http:// инголькс)", - "headline_sample": "Конякссонь валхне", - "headline_tip": "2-це аськолксонь конякс", - "nowiki_sample": "Сувафтомс тязк форматфтома текст", - "nowiki_tip": "Нулгодемс Викить текст латцемась", - "image_tip": "Путф медиа файлсь", - "media_tip": "Файлть сюлмафкссь", - "sig_tip": "Тонь кядьтяшксоце пинге мархта", - "hr_tip": "Туркс китькс (тевс нолдамс ванфтозь)", "summary": "Нюрьхкяня лихтема:", "subject": "Тема/конякс:", "minoredit": "Тя ёмланя видептема", diff --git a/languages/i18n/mg.json b/languages/i18n/mg.json index a29d435f73..43938bb0c7 100644 --- a/languages/i18n/mg.json +++ b/languages/i18n/mg.json @@ -584,24 +584,6 @@ "resettokens-watchlist-token": "Token ho an'ny fahna web (Atom/RSS) ho an'ny [[Special:Watchlist|fanovana ny pejy ao amin'ny lisitry ny pejy arahanao]]", "resettokens-done": "Natao reset ny token", "resettokens-resetbutton": "Hanao reset ny token voafidy", - "bold_sample": "Soratra matavy", - "bold_tip": "Soratra matavy", - "italic_sample": "Sora-mandry", - "italic_tip": "Sora-mandry", - "link_sample": "Soratra eo amin'ny rohy", - "link_tip": "Rohy anatiny", - "extlink_sample": "http://www.example.com rohy lohateny", - "extlink_tip": "Rohy ivelany (tadidio ny tovana http://)", - "headline_sample": "Lohateny anankiray", - "headline_tip": "Lohatena ambaratonga faha 2", - "nowiki_sample": "Apetraho eto ny lahatsoratra tsy manaraka format", - "nowiki_tip": "Aza ampiasaina ny formatage wiki", - "image_sample": "ohatra.jpg", - "image_tip": "sary", - "media_sample": "Ohatra.ogg", - "media_tip": "Rohy rakitra sary sy/na feo", - "sig_tip": "Ny sonianao miaraka amin'ny daty", - "hr_tip": "Tsipika mitsivalana (aza anaranam-po loatra)", "summary": "Ambangovangony:", "subject": "Lohateny:", "minoredit": "Fanovàna kely", diff --git a/languages/i18n/mhr.json b/languages/i18n/mhr.json index 24e70de1a2..3cde613fed 100644 --- a/languages/i18n/mhr.json +++ b/languages/i18n/mhr.json @@ -263,22 +263,6 @@ "retypenew": "Пеҥгыдемдыза у шолыпмутым:", "resetpass-submit-loggedin": "Шолыпмутым вашталташ", "passwordreset-username": "Пайдаланышын лӱмжӧ", - "bold_sample": "Кӱжгӧ текст", - "bold_tip": "Кӱжгӧ текст", - "italic_sample": "Шӧрын текст", - "italic_tip": "Шӧрын текст", - "link_sample": "Кылверын лӱмжӧ", - "link_tip": "Кӧргысӧ кылвер", - "extlink_sample": "http://www.example.com кылверын лӱмжӧ", - "extlink_tip": "Ӧрдыж кылвер (http:// префиксым ит мондо)", - "headline_sample": "Вуймут", - "headline_tip": "2-шо кӱкшытан вуймут", - "nowiki_sample": "Форматироватлыдыме текстым тышке шынде", - "nowiki_tip": "Вики-форматированийым шотыш налаш огыл", - "image_tip": "Пуртымо сӱрет", - "media_tip": "Пуртымо медиа-файл", - "sig_tip": "Тыйын кидпалет, шындыме жап да кече", - "hr_tip": "Тореш (чӱчкыдын ит кучылт)", "summary": "Тӧрлатымаш нерген:", "subject": "Теме/вуймут:", "minoredit": "Тиде изи вашталтыш", diff --git a/languages/i18n/min.json b/languages/i18n/min.json index b56f0656d5..3767ed8da4 100644 --- a/languages/i18n/min.json +++ b/languages/i18n/min.json @@ -21,7 +21,7 @@ "NoiX180" ] }, - "tog-underline": "Garih bawah pautan:", + "tog-underline": "Garih bawahi pautan:", "tog-hideminor": "Suruakkan suntiangan ketek di parubahan baru", "tog-hidepatrolled": "Suruakkan suntiangan nan lah dipatroli di parubahan tabaru", "tog-newpageshidepatrolled": "Suruakkan laman nan lah dipatroli dari daftar laman baru", @@ -62,11 +62,12 @@ "tog-diffonly": "Jan tampilan isi laman di bawah pabedoan suntiangan", "tog-showhiddencats": "Tunjuakan kategori tasuruak", "tog-norollbackdiff": "Jan tampilan pabedoan sasudah malakukan pangambalian", - "tog-useeditwarning": "Ingekan denai jikok maninggakan laman suntiang sabalun manyimpan parubahan", + "tog-useeditwarning": "Ingekan ambo kok maninggakan laman suntiang sabalun manyimpan parubahan", "tog-prefershttps": "Selalu gunokan koneksi aman katiko masuak log", "tog-showrollbackconfirmation": "Tampilkan konfirmasi katiko mangklik pautan pangambalian", + "tog-requireemail": "Paralu email untuak maatua ulang kato sandi", "underline-always": "Taruih", - "underline-never": "Indak pernah", + "underline-never": "Indak panah", "underline-default": "Kulik atau pangaturan paramban web", "editfont-style": "Gaya tulisan komputer pado kotak panyuntiangan:", "editfont-monospace": "Tulisan Monospace", @@ -390,6 +391,8 @@ "virus-scanfailed": "Pamindaian gagal (kode $1)", "virus-unknownscanner": "Antivirus indak dikenal:", "logouttext": "<strong>Sanak alah kalua log</strong>\n\nMohon diingek kalau babarapo laman mungkin masih tampil cando Sanak alun kalua log. Silakan untuak mambarasiahan singgahan panjalajah web Sanak.", + "logging-out-notify": "Sanak sadang kalua log, mohon manunggu sabanta", + "logout-failed": "Indak bisa kalua kini:$1", "cannotlogoutnow-title": "Indak bisa kalua kini", "cannotlogoutnow-text": "Indak bisa kalua katiko manggunoan $1.", "welcomeuser": "Salamaik datang, $1!", @@ -437,8 +440,9 @@ "createaccountmail": "Mohon pakai kato sandi samantaro dan kirim ka alamaik surek elektronik nan alah disabuikkan.", "createaccountmail-help": "Indak dapek digunoan untuak mambuek akun urang lain tanpa tau kato sandinyo.", "createacct-realname": "Namo asli (opsional)", - "createacct-reason": "Alasan", + "createacct-reason": "Alasan (log publik)", "createacct-reason-ph": "Manga Sanak mambuek akun lain", + "createacct-reason-help": "Pasan yang ditunjuakan dalam log pambuatan akun", "createacct-submit": "Buek akun Sanak", "createacct-another-submit": "ګڼون جوړول", "createacct-continue-submit": "Lanjuikan mambuek akun", @@ -448,6 +452,7 @@ "createacct-benefit-body2": "{{PLURAL:$1|laman}}", "createacct-benefit-body3": "{{PLURAL:$1|panyuntiang}} tarakhia", "badretype": "Kato sandi nan Sanak masuakan salah.", + "usernameinprogress": "Pambuatan akun untuak namo pangguno ko sadang dalam proses. Mohon manunggu", "userexists": "Namo pangguno nan dipiliah alah tapakai.\nPiliah namo nan lain.", "createacct-normalization": "Namo pangguno sanak akan disasuaian manjadi \"$2\" karano batasan teknis.", "loginerror": "Kasalahan masuak log", @@ -499,6 +504,7 @@ "login-migrated-generic": "Akun sanak alah dipindahan, namo pangguno Sanak alah indak tadaftar ini wiki ko.", "loginlanguagelabel": "Baso: $1", "suspicious-userlogout": "Pamintaan Sanak untuak kalua log ditulak karano tampaknyo dikirim oleh paramban nan rusak atau proksi panyinggah.", + "createacct-another-realname-tip": "Namo usali basifaik opsional. Kok Sanak mamakainyo, namo tu digunoan untuak manandoan jariah pangguno Sanak.", "pt-login": "Masuak log", "pt-login-button": "Masuak log", "pt-login-continue-button": "Lanjuikan masuak log", @@ -517,6 +523,7 @@ "changepassword-success": "Kato sandi Sanak alah berhasil dituka!", "changepassword-throttled": "Sanak alah acok bana mancubo masuak log. Mohon tunggu $1 sabalun mancubo baliak.", "botpasswords": "Kato sandi bot", + "botpasswords-summary": "<em>Kato sandi bot</em> mamungkinkan akses ka akun pangguno manggunokan API jo indak manggunokan kredensial masuak log utamo akun tasabuik. Hak pangguno nan tasadio katiko masuak log jo kato sandi bot mungkin ka dibatasi.\n\nKok Sanak indak tau dek a Sanak ka malakukan hal ko, sarancaknyo jan lakukan. Samustinyo indak ado urang lain nan buliah mamintak Sanak untuak mambuek jo manyarahan kato sandi bot ko kapadonyo.", "botpasswords-disabled": "Kato sandi bot indak diaktifan.", "botpasswords-no-central-id": "Untuak manggunoan kato sandi bot, Sanak harus masuak log ka akun nan alah disentralisasi.", "botpasswords-existing": "Kato sandi bot tasadio", @@ -529,6 +536,8 @@ "botpasswords-label-cancel": "Batalan", "botpasswords-label-delete": "Hapuih", "botpasswords-label-resetpassword": "Setel ulang kato sandi", + "botpasswords-label-grants": "Akses nan dapek diagiah:", + "botpasswords-help-grants": "Izin ka akses tatantu alah dipunyoi akun pangguno Sanak. Maaktifkan sabuah hak di siko indak maagiah akses ka akses lain nan indak dimiliki dek akun pangguno Sanak. Caliak [[Special:ListGrants|daftar hak akses]] untuak informasi salangkoknyo.", "botpasswords-label-grants-column": "Izin diagiah", "botpasswords-bad-appid": "Namo bot \"$1\" indak sah.", "botpasswords-insert-failed": "Gagal manambah namo bot \"$1\". Alah ditambahan sabalun iko?", @@ -598,22 +607,6 @@ "resettokens-watchlist-token": "Token untuak sindikasi web (Atom/RSS) dari [[Special:Watchlist|parubahan di daftar pantauan Sanak]]", "resettokens-done": "Reset token.", "resettokens-resetbutton": "Reset token nan dipiliah", - "bold_sample": "Teks taba", - "bold_tip": "Teks taba", - "italic_sample": "Teks miriang", - "italic_tip": "Teks miriang", - "link_sample": "Judul pautan", - "link_tip": "Pautan dalam", - "extlink_sample": "http://www.hanyo-contoh.com judul pautan", - "extlink_tip": "Pautan lua (ingek awalannyo http://)", - "headline_sample": "Teks judul", - "headline_tip": "Tingkek 2 judul", - "nowiki_sample": "Masuakkan disiko teks nan indak baformat", - "nowiki_tip": "Abaikan format wiki", - "image_tip": "Cantumkan berkas", - "media_tip": "Pautan berkas", - "sig_tip": "Tandotangan sanak jo wakatu", - "hr_tip": "Garih mandata", "summary": "Ikhtisar:", "subject": "Perihal:", "minoredit": "Suntiangan ketek", @@ -646,6 +639,7 @@ "autoblockedtext": "Alamaik IP Sanak alah kanai sakek sacaro otomatih dek dipakai jo pangguno lain, nan alah disakek dek $1. Alasannyo dek:\n\n:<em>$2</em>\n\n* Kanai sakek sajak: $8\n* Maso sakek habih pado: $6\n* Sasaran nan disakek: $7\n\nSanak dapek maubuangi $1 atau [[{{MediaWiki:Grouppage-sysop}}|panguruih lainnya]] untuak marundiangan pakaro ko.\n\nSanak indak dapek manggunoan pakakeh \"{{int:emailuser}}\" kacuali Sanak alah mamasuakan alamaik surel nan sah pado [[Special:Preferences|pangaturan akun]] dan Sanak indak sadang disakek untuak manggunoannyo.\n\nAlamaik IP Sanak adolah $3, dan ID panyakekan adolah $5.\nTolong saratoan informasi di ateh pado satiok patanyaan nan Sanak buek.", "systemblockedtext": "Namo pangguno atau alamaik IP Sanak alah disakek sacaro otomatis dek MediaWiki.\nAlasan nan diagiah adolah:\n\n:<em>$2</em>\n\n* Disakek sajak: $8\n* Sakek kadaluwarsa pado: $6\n* Sasaran panyakekan: $7\n\nAlamaik IP Sanak kini adolah $3\nMohon saratokan sadoalah parincian di ateh dalam satiok patanyoan nan Sanak ajukan.", "blockednoreason": "indak ado alasan nan diagiah.", + "blockedtext-composite": "Namo pangguno atau alamaik IP Sanak alah disakek sacaro otomatis dek MediaWiki.\nAlasan nan diagiah adolah:\n\n:<em>$2</em>\n\n* Disakek sajak: $8\n* Sakek kadaluwarsa pado: $6\n* Sasaran panyakekan: $7\n\nAlamaik IP Sanak kini adolah $3\nMohon saratokan sadoalah parincian di ateh dalam satiok patanyoan nan Sanak ajukan.", "blockedtext-composite-ids": "Panyakekan ID relevan: $1 (alamaik IP Sanak juo dapek dicekal)", "blockedtext-composite-no-ids": "Alamaik IP Sanak muncua dalam daftar itam gando", "blockedtext-composite-reason": "Ado panyakekan bagando ka bakeh akun Sanak dan/atau alamaik IP Sanak.", @@ -760,6 +754,9 @@ "unsupported-content-diff2": "Pabedaan antaro model konten $1 jo $2 indak didukuang di wiki ko.", "deprecated-self-close-category": "Laman nan menggunoan tag HTML tatutuik-surang indak sah", "deprecated-self-close-category-desc": "Laman ko manganduang tag HTML tatutuik-surang nan indak sah, sarupo <code><b/></code> atau <code><span/></code>. Parilaku tag sarupo ko ka sagiro barubah supayo konsisten jo spesifikasi HTML5, jadi panggunoannyo dalam teks wiki indak lai disarankan.", + "duplicate-args-warning": "<strong>Paringatan:</strong> [[:$1]] maimbau [[:$2]] jo nilai labiah dari ciek untuak parameter \"$3\". Anyo nilai tarakhia nan tasadio nan ka digunokan.", + "duplicate-args-category": "Laman jo argumen gando di pamanggilan templat", + "duplicate-args-category-desc": "Laman ko barisi pamanggilan templat nan manggunokan argumen gando, sarupo <code><nowiki>{{foo|bar=1|bar=2}}</nowiki></code> atau <code><nowiki>{{foo|bar|1=baz}}</nowiki></code>.", "expensive-parserfunction-warning": "'''Paringatan:''' Laman ko manganduang talalu banyak panggilan fungsi parser.\n\nSeharusnyo kurang dari $2 {{PLURAL:$2|panggilan}}, tapi {{PLURAL:$1|kini ado $1 panggilan}}.", "expensive-parserfunction-category": "Laman nan talalu banyak panggilan fungsi parser", "post-expand-template-inclusion-warning": "'''Peringatan:''' Ukuran templat talalu gadang.\nBabarapo templat akan diabaikan.", @@ -768,21 +765,32 @@ "post-expand-template-argument-category": "Laman nan barisi uraian templat nan diabaikan", "parser-template-loop-warning": "Hubungan barulang templat tadeteksi: [[$1]]", "template-loop-category": "Laman jo templat barulang", + "template-loop-category-desc": "Laman ko manganduang templat malingka, yaitu templat nan maimbau dirinyo surang sacaro bolak-balik.", + "template-loop-warning": "<strong>Paringatan:</strong> Laman ko maimbau [[:$1]] nan manyababkan <i>template loop</i> (panggilan rekursif tak inggo).", "parser-template-recursion-depth-warning": "Limit kadalaman hubungan barulang templat lah talampau ($1)", "language-converter-depth-warning": "Bateh kadalaman pangonversi bahaso lah talampau ($1)", "node-count-exceeded-category": "Laman dimano hitungan-node talampaui", + "node-count-exceeded-category-desc": "Laman ko malampaui jumlah node maksimum.", "node-count-exceeded-warning": "Laman nan labiah jumlah node", "expansion-depth-exceeded-category": "Laman dima kadalaman ekspansi lah talampau", + "expansion-depth-exceeded-category-desc": "Laman nan malabiahi kadalaman laweh maksimum.", "expansion-depth-exceeded-warning": "Laman kadalaman ekspansi lah talampau", "parser-unstrip-loop-warning": "Unstrip loop detected", "unstrip-depth-warning": "Unstrip recursion limit exceeded ($1)", + "unstrip-depth-category": "Laman-laman di mano bateh kadalaman unstrip alah malabiahi bateh", + "unstrip-size-warning": "Bateh ukuran unstrip alah malabiahi bateh ($1)", + "unstrip-size-category": "Laman-laman di mano bateh ukuran unstrip alah malabiahi bateh", "converter-manual-rule-error": "Kasalahan tadeteksi di aturan manual konversi bahaso", "undo-success": "Suntiangan ko dapek dibatalan. \nTolong cek pabedoan di bawah untuak mayakinkan bahwa bana nan tu Sanak nio buek, lalu simpan parubahan tasabuik untuak manyalasaikan pambatalan suntiangan.", "undo-failure": "Suntiangan ko indak dapek dibatalan dek konflik panyuntiangan antaro.", + "undo-main-slot-only": "Suntiangan ko indak dapek dibatalkan dek tindakan ko malibaikkan konten di lua slot utamo.", "undo-norev": "Suntiangan ko indak dapek dibatalan dek laman indak ditamukan atau lah dihapuih.", + "undo-nochange": "Suntiangan ko nampaknyo alah dibatalkan.", "undo-summary": "Mambatalan revisi $1 oleh [[Special:Contributions/$2|$2]] ([[User talk:$2|maota]])", "undo-summary-anon": "Baliakan revisi $1 dek [[Special:Contributions/$2|$2]]", + "undo-summary-username-hidden": "Batalkan revisi $1 dek surang pangguno tasuruak", "cantcreateaccount-text": "Mambuek akun dari alamat IP ko ('''$1''') alah diblok jo [[User:$3|$3]].\n\nAlasan nan diagiah jo $3 adolah ''$2''", + "cantcreateaccount-range-text": "Pambuatan akun dari alamaik IP dalam rantang <strong>$1</strong>, nan mancakuik alamaik IP Sanak (<strong>$4</strong>), alah disakek dek [[User:$3|$3]].\n\nAlasan nan diagiah dek $3 adolah <em>$2</em>", "viewpagelogs": "Caliak log untuak laman ko", "nohistory": "Indak ado sajarah panyuntiangan untuak laman ko", "currentrev": "Revisi tabaru", @@ -808,11 +816,13 @@ "history-feed-description": "Riwayaik revisi laman ko di wiki", "history-feed-item-nocomment": "$1 pado $2", "history-feed-empty": "Laman nan dicari indak ado.\nMungkin alah dihapuih dari wiki, atau diagiah namo baru.\nCuba [[Special:Search|cari dulu]] untuak laman lain nan relevan.", + "history-edit-tags": "Suntiang tag dari revisi nan tapiliah", "rev-deleted-comment": "(ikhtisar suntiangan dihapuih)", "rev-deleted-user": "(namo pangguno dihapuih)", "rev-deleted-event": "(rincian log dihapuih)", "rev-deleted-user-contribs": "[namo pangguno atau alamaik IP dihapuih - suntiangan disuruakan dari daftar jariah]", "rev-deleted-text-permission": "Revisi laman ko alah '''dihapuih'''.\nRinciannyo mungkin ado di [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} log pangapuihan]", + "rev-suppressed-text-permission": "Laman revisi ko alah '''dihapuih'''.\nSanak dapek mancaliaknyo; rinciannyo mungkin ado di [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} log pangapuihan].", "rev-deleted-text-unhide": "Revisi laman ko alah '''dihapuih'''.\nRinciannyo mungkin ado di [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} log pangapuihan].\nSanak masih dapek [$1 mancaliak revisi ko] ko' amuah.", "rev-suppressed-text-unhide": "Revisi laman ko alah '''tabanam'''.\nRinciannyo mungkin ado di [{{fullurl:{{#Special:Log}}/suppress|page={{FULLPAGENAMEE}}}} log pambanaman].\nAngku masih dapek [$1 maliek revisi ko] ko' amuah.", "rev-deleted-text-view": "Laman revisi ko alah '''dihapuih'''.\nSanak dapek mancaliaknyo; rinciannyo mungkin ado di [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} log pangapuihan].", @@ -831,7 +841,13 @@ "revdelete-no-file": "Berkas nan dituju indak basobok.", "revdelete-show-file-confirm": "Apokah Sanak yakin nio mancaliak revisi nan alah dihapuih dari berkas \"<nowiki>$1</nowiki>\" per $3, $2?", "revdelete-show-file-submit": "Yo", + "revdelete-selected-text": "{{PLURAL:$1|Revisi tapiliah|Revisi tapiliah}} dari [[:$2]]:", + "revdelete-selected-file": "{{PLURAL:$1|Versi berkas tapilih|Versi berkas tapiliah}} dari [[:$2]]:", "logdelete-selected": "{{PLURAL:$1|Log piliahan}}:", + "revdelete-text-text": "Revisi nan diapuik ka tatap muncua di laman riwayaik, tapi bagian dari kontennyo ka manjadi indak dapek diakses untuak umum.", + "revdelete-text-file": "Versi berkas nan diapuih ka tatap muncua di riwayaik berkas, tapi bagian dari kontennyo ka manjadi indak dapek diakses untuak umum.", + "logdelete-text": "Acara log nan diapuih ka tatap muncua di log, tapi bagian dari kontennyo manjadi indak dapek diakses untuak umum.", + "revdelete-text-others": "Panguruih lain masih dapek maakses konten tasuruak dan dapek mambatalkan pangapuihannyo, salain kok ado panarapan batasan tambahan.", "revdelete-confirm": "Tolong konfirmasi baso Sanak samemang bamakasuik malakuan iko, mamahami konsekuensinyo, dan baso Sanak malakuannyo sasuai jo [[{{MediaWiki:Policy-url}}|kabijakan]].", "revdelete-suppress-text": "Panyambunyian revisi <strong>hanyo</strong> buliah digunoan untuak kasus-kasus barikuik:\n* Informasi bapotensi pancemaran namo baiak\n* Informasi paribadi nan indak patuik\n*: <em>alamaik rumah jo nomor telepon, nomor kartu identitas, dll.</em>", "revdelete-legend": "Pangaturan bateh", @@ -870,17 +886,32 @@ "suppressionlog": "Log pambanaman", "suppressionlogtext": "Di bawah ko adolah daftar panghapuihan jo panyakekan, tamasuak isi nan disambunyian dari panguruih.\nCaliak [[Special:BlockList|daftar sakek]] untuak daftar nan paliang baru.", "mergehistory": "Gabuangan sijarah laman", + "mergehistory-header": "Laman ko mambuliahan Sanak untuak manggabuangkan revisi-revisi dari ciek laman sumber ka laman nan labiah baru.\nPastikan baso parubahan ko tatap mampatahankan kontinuitas versi laman tadahulu.", "mergehistory-box": "Gabuang parubahan-parubahan dari duo laman:", "mergehistory-from": "Laman sumber:", "mergehistory-into": "Laman tujuan:", + "mergehistory-list": "Mergeable edit history", + "mergehistory-merge": "Revisi-revisi barikuik dari [[:$1]] dapek digabuangkan ka [[:$2]]. Gunokan tombol radio untuak manggabuangkan revisi-revisi nan dibuek sabalun wakatu tatantu. Paratikan, manggunokan pautan navigasi ka mangeset ulang kolom.", "mergehistory-go": "Tampilan suntiangan nan dapek digabuang", "mergehistory-submit": "Gabuang revisi", "mergehistory-empty": "Indak ado parubahan nan dapek digabuang.", "mergehistory-done": "$3 {{PLURAL:$3|revision|revisions}} dari $1 {{PLURAL:$3|was|were}} berhasil digabuangan ka [[:$2]].", "mergehistory-fail": "Indak dapek digabuang, mohon pareso baliak laman jo parameter wakatu.", + "mergehistory-fail-bad-timestamp": "Stempel wakatu indak valid.", "mergehistory-fail-invalid-source": "Laman asal indak sah.", "mergehistory-fail-invalid-dest": "Laman tujuan indak sah.", + "mergehistory-fail-no-change": "Panggabuangan sijarah indak barhasil manggabuangkan revisi apo pun. Mohon pareso baliak parameter laman jo waktu.", + "mergehistory-fail-permission": "Izin panggabuangan sijarah laman indak mancukupi.", "mergehistory-fail-self-merge": "Laman sumber jo tujuannyo samo.", + "mergehistory-fail-timestamps-overlap": "Revisi asa tumpang tindih atau labiah baru dari revisi tujuan.", + "mergehistory-fail-toobig": "Indak dapek malakukan panggabuangan sabagai labiah dari bateh dari $1 {{PLURAL:$1|revisi|revisi}} ka dipindahkan.", + "mergehistory-no-source": "Laman sumber $1 indak ado.", + "mergehistory-no-destination": "Halaman tujuan $1 indak ado.", + "mergehistory-invalid-source": "Judul laman sumber harus judul nan balaku.", + "mergehistory-invalid-destination": "Judul halaman tujuan harus judul yang valid.", + "mergehistory-autocomment": "[[:$1]] alah digabuangkan ka [[:$2]]", + "mergehistory-comment": "[[:$1]] alah digabuangkan ka [[:$2]]: $3", + "mergehistory-same-destination": "Laman sumber jo tujuannyo indak samo.", "mergehistory-reason": "Alasan:", "mergelog": "Log panggabuangan", "revertmerge": "Batal gabuang", @@ -896,7 +927,12 @@ "diff-empty": "(Indak ado pabedaan)", "diff-multi-sameuser": "({{PLURAL:$1|Ciek parubahan antaro|$1 parubahan antaro}} dek pangguno nan samo indak ditampilkan)", "diff-multi-otherusers": "({{PLURAL:$1|Ciek parubahan antaro|$1 parubahan antaro}} dek {{PLURAL:$2|ciek pangguno lain|$2 pangguno}} indak ditampilkan)", + "diff-multi-manyusers": "({{PLURAL:$1|Ciek parubahan antaro|$1 parubahan antaro}} dek {{PLURAL:$2|ciek pangguno lain|$2 pangguno}} indak ditampakan)", + "diff-paragraph-moved-tonew": "Paragraf alah dipindahan. Klik untuak mamindahan ka lokasi baru.", + "diff-paragraph-moved-toold": "Paragraf dipindahkan. Klik untuak malumpek ka lokasi lamo.", + "difference-missing-revision": "{{PLURAL:$2|One revision|$2 revisions}} of this difference ($1) {{PLURAL:$2|was|were}} indak basuo.\n\nIko biasonyo dek karano pautan sijarah alah kadaluarsa. Rinciannyo dapek dicaliak di [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} deletion log].", "searchresults": "Hasil pancarian", + "search-filter-title-prefix": "Anyo mancari laman nan judulnyo diawali dek \"$1\"", "search-filter-title-prefix-reset": "Cari kasado laman", "searchresults-title": "Hasil pancarian untuak \"$1\"", "titlematches": "Judul laman pas", @@ -927,27 +963,35 @@ "search-category": "(kategori $1)", "search-file-match": "(isi berkas nan sasuai)", "search-suggest": "Mungkin makasuiknyo: $1", + "search-rewritten": "Manampilan hasil untuak $1. Cari selain $2.", "search-interwiki-caption": "Hasil dari proyek lain", "search-interwiki-default": "Hasil dari $1:", "search-interwiki-more": "(salanjuiknyo)", "search-interwiki-more-results": "hasil lainnyo", "search-relatedarticle": "Bakaitan", + "search-invalid-sort-order": "Parintah manyortir $1 indak dikenali, panyortiran standar ka ditarapan. Parintah-parintah manyortir nan sah iolah: $2", + "search-unknown-profile": "Profil pancarian $1 tidak dikenali, profil pancarian standar ka diterapan.", "searchrelated": "bakaitan", "searchall": "sadonyo", "showingresults": "Di bawah ko dikaluaan sampai {{PLURAL:$1|'''$1''' hasil}}, dimulai dari #'''$2'''.", "showingresultsinrange": "Manampilkan {{PLURAL:$1|<strong>$1</strong> hasil}} dalam rantang #<strong>$2</strong> sampai #<strong>$3</strong>.", "search-showingresults": "{{PLURAL:$4|Hasia <strong>$1</strong> dari <strong>$3</strong>|Hasia <strong>$1 - $2</strong> dari <strong>$3</strong>}}", "search-nonefound": "Indak ado hasil nan sasuai jo pamintaan", + "search-nonefound-thiswiki": "Indak ado hasil nan sasuai jo pamintaan", "powersearch-legend": "Pencarian lanjut", "powersearch-ns": "Mancari di ruangnamo:", "powersearch-togglelabel": "Piliah:", "powersearch-toggleall": "Sadonyo", "powersearch-togglenone": "Dak ado", + "powersearch-remember": "Ingek piliahan untuak pancarian salanjuiknyo", "search-external": "Pancarian lua", "searchdisabled": "Pancarian {{SITENAME}} dimatian.\nSanak samantaro dapek mancari lewaik Google.\nIngek indeks Google untuak {{SITENAME}} mungkin lah kadaluarsa.", + "search-error": "Kasalahan tajadi wakatu mancari: $1", + "search-warning": "Paringatan tajadi katiko mancari:$1", "preferences": "Pangaturan", "mypreferences": "Pangaturan", "prefs-edits": "Jumlah suntiangan:", + "prefsnologintext2": "Silakan masuak log untuak mangubah preferensi Sanak.", "prefs-skin": "Kulik", "skin-preview": "Caliak", "datedefault": "Indak usah diatua", @@ -958,11 +1002,15 @@ "prefs-watchlist": "Daftar pantau", "prefs-editwatchlist": "Suntiang daftar pantauan", "prefs-editwatchlist-label": "Suntiang entri daftar pantauan Sanak:", + "prefs-editwatchlist-edit": "Caliak jo apuih judul di daftar pantauan Sanak", + "prefs-editwatchlist-raw": "Suntiang pantauan mantah", + "prefs-editwatchlist-clear": "Apuih daftar pantauan", "prefs-watchlist-days": "Jumlah hari dalam daftar pantau:", "prefs-watchlist-days-max": "Maksimum $1 {{PLURAL:$1|hari}}", "prefs-watchlist-edits": "Jumlah parubahan tabanyak nan ditunjuakan pado daftar pantau:", "prefs-watchlist-edits-max": "Nilai maksimum: 1000", "prefs-watchlist-token": "Token pantauan:", + "prefs-watchlist-managetokens": "Kalola token", "prefs-misc": "Lain-lain", "prefs-resetpass": "Tuka kato sandi", "prefs-changeemail": "Tuka atau hapuih alamaik surel", @@ -980,11 +1028,15 @@ "recentchangesdays-max": "Maksimum $1 {{PLURAL:$1|hari}}", "recentchangescount": "Jumlah suntiangan nan ditunjuakan dalam parubahan baru, riwayaik laman, dan dalam log, sacaro baku:", "prefs-help-recentchangescount": "Nilai maksimum: 1000", + "prefs-help-watchlist-token2": "Iko adolah kunci rasio (token) ka umpan web dari daftar pantauan sanak.\nSia se nan tau dapek mancaliak daftar pantauan Sanak, jadi jan dibagian.\nKok diparaluan [[Special:ResetTokens|you can reset it]].", + "prefs-help-tokenmanagement": "Sanak dapek mancaliak jo maatua ulang kunci rahasio akun Sanak nan dapek maakses umpan Web dari daftar pantauan Sanak. Sia se nan tau bisa sajo mancaliak daftar pantauan Sanak, jadi jan dibagian.", "savedprefs": "Pangaturan lah tasimpan", + "savedrights": "Kalompok hak pangguno {{GENDER:$1|$1}} alah disimpan.", "timezonelegend": "Zona wakatu:", "localtime": "Wakatu satampaik:", "timezoneuseserverdefault": "Gunokan nan dari wiki ($1)", "timezoneuseoffset": "Lainnyo (tantuan pabedoannyo)", + "timezone-useoffset-placeholder": "Contoh nilai: \"-07:00\" atau \"01:00\"", "servertime": "Wakatu server:", "guesstimezone": "Isian dari paramban web", "timezoneregion-africa": "Afrika", @@ -1005,6 +1057,7 @@ "default": "baku", "prefs-files": "Berkas", "prefs-custom-css": "CSS surang", + "prefs-custom-json": "JSON kustom", "prefs-custom-js": "JS surang", "prefs-common-config": "CSS/JS babagi untuak kasado kulik:", "prefs-reset-intro": "Angku dapek manggunokan laman ko untuak mangambalikan pangaturan ka setelan baku situs ko.\nPangambalian pangaturan indak dapek dibatalan.", @@ -1048,13 +1101,19 @@ "prefs-displayrc": "Piliahan tampilan", "prefs-displaywatchlist": "Piliahan tampilan", "prefs-changesrc": "Parubahan ditampilkan", + "prefs-changeswatchlist": "Parubahan ditampilan", + "prefs-pageswatchlist": "Halaman nan dipantau", "prefs-tokenwatchlist": "Token", "prefs-diffs": "Pabedoan", + "prefs-help-prefershttps": "Preferensi ko akan diaktifkan salunjuiknyo katiko Sanak masuak log.", + "prefswarning-warning": "Parubahan preferensi Sanak alun tasimpan. Kok Sanak maninggaan halaman ko tanpa ma klik $1 preferensi Sanak indak akan dipabarui.", + "prefs-tabs-navigation-hint": "Tip: Sanak dapek manggunoan tombol panah kida jo suok untuak banavigasi antartab di dalam daftar tab.", "userrights": "Hak pangguno", "userrights-lookup-user": "Piliah pangguno", "userrights-user-editname": "Masuakan namo pangguno:", "editusergroup": "Muek kalompok pangguno", "editinguser": "Mangganti hak pangguno untuak {{GENDER:$1|pangguno}} <strong>[[User:$1|$1]]</strong> $2", + "viewinguserrights": "Mancaliak hak pengguna dari {{GENDER:$1|pengguno}} <strong>[[User:$1|$1]]</strong> $2", "userrights-editusergroup": "Suntiang kalompok {{GENDER:$1|pangguno}}", "userrights-viewusergroup": "Caliak kalompok {{GENDER:$1|pangguno}}", "saveusergroups": "Simpan kalompok {{GENDER:$1|pangguno}}", @@ -1074,6 +1133,8 @@ "userrights-expiry-options": "1 hari:1 hari,1 minggu:1 minggu,1 bulan:1 bulan,3 bulan:3 bulan,6 bulan:6bulan,1 taun:1 taun", "userrights-invalid-expiry": "Wakatu usang untuak kalompok \"$1\" indak sah.", "userrights-expiry-in-past": "Wakatu usang untuak kalompok \"$1\" alah balalu.", + "userrights-cannot-shorten-expiry": "Sanak indak dapek mamajuan wakatu kadaluarsa dari kaanggotaan dalam kalompok $1. Hanyo pangguno yang punyo hak akses manambahan jo mancabuik kalompok ko yang dapek mamajuan wakatu kadaluarsa.", + "userrights-conflict": "Konflik parubahan hak pangguno! Sila tinjau ulang jo konfirmasi parubahan Sanak.", "group": "Kalompok:", "group-user": "Pangguno", "group-autoconfirmed": "Pangguno takonfirmasi otomatih", @@ -1102,15 +1163,19 @@ "right-createpage": "Mambuek laman baru (nan bukan laman diskusi)", "right-createtalk": "Mambuek laman diskusi", "right-createaccount": "Mambuek akun baru", + "right-autocreateaccount": "Masuak log otomatis jo akun pangguno lua", "right-minoredit": "Manandoi suntiangan ketek", "right-move": "Mamindahan laman", "right-move-subpages": "Mamindahan laman jo kasado sublaman", "right-move-rootuserpages": "Mamindahan laman pangguno", + "right-move-categorypages": "Pindahan halaman kategori", "right-movefile": "Mamindahan berkas", "right-suppressredirect": "Indak mambuek pangaliahan wakatu mamindahan laman", "right-upload": "Mamuek berkas", "right-reupload": "Manimpo berkas lamo", "right-reupload-own": "Manimpo berkas nan dimuek surang", + "right-reupload-shared": "Manolak berkas-berkas pado panyimpanan media lokal basamo", + "right-upload_by_url": "Masuakan berkas dari alamat URL", "right-purge": "Mangapuih singgahan laman untuak laman", "right-autoconfirmed": "Indak dipangaruahi bateh limik babasis IP", "right-bot": "Dipalakuan sabagai proses otomatih", @@ -1118,8 +1183,23 @@ "right-apihighlimits": "Manggunoan bateh labiah tinggi dalam kueri API", "right-writeapi": "Manggunoan panulisan API", "right-delete": "Mangapuih laman", + "right-bigdelete": "Apuih halaman yang banyak versi terdahulunyo", + "right-deletelogentry": "Maapuih jo mambatalan pangapuihan entri log tatantu", + "right-deleterevision": "Maapuih jo mambatalan pangapuihan parubahan tatantu suatu halaman", + "right-deletedhistory": "Caliak revisi entri-entri yang diapuih, tanpa teks yang bahubuangan", + "right-deletedtext": "Caliak teks yang diapuih jo parubahan antaro revisi yang diapuih", + "right-browsearchive": "Cari laman nan dihapuih", + "right-undelete": "Mambaliakan halaman nan diapuih", + "right-suppressrevision": "Manampilan, manyambunyian jo mambatalan panyambunyian revisi tatantu suatu halaman dari pangguno", + "right-viewsuppressed": "Caliak parubahan yang disambunyian dari sadolah pangguno", "right-suppressionlog": "Mancaliak log privat", + "right-block": "Blokir pangguno lain dari panyuntingan", + "right-blockemail": "Mamblokir pangiriman surel dek pangguno", + "right-hideuser": "Mamblokir namo pangguno jo manyambunyiannyo dari publik", + "right-ipblock-exempt": "Mangabaikan pamblokiran IP, pamblokiran otomatis, jo jarak pamblokiran", "right-unblockself": "Malapehan sakek surang", + "right-protect": "Ubah tingkek palinduangan jo suntiang halaman yang dilinduangi baruntun", + "right-editprotected": "Manyuntiang halaman yang dilinduangi sabagai \"{{int:protect-level-sysop}}\"", "right-editinterface": "Manyuntiang antarmuko pangguno", "right-editusercss": "Manyuntiang berkas CSS pangguno lain", "right-edituserjson": "Manyuntiang berkas JSON pangguno lain", @@ -1128,11 +1208,49 @@ "right-import": "Mangimpor laman dari wiki lain", "right-importupload": "Mangimpor laman dari berkas nan dimuek", "right-autopatrol": "Suntiangan surang sacaro otomatih ditandoi tapantau", + "right-userrights": "Manyuntiang sadoalah hak pangguno", + "right-userrights-interwiki": "Manyuntiang hak pangguno-pangguno di wiki lain", + "right-siteadmin": "Mangunci jo mambukak kunci basis data", + "right-override-export-depth": "Ekspor laman tamasuak laman-laman takaik inggo kadalaman 5", + "right-sendemail": "Mangirim surel ka pangguno lain", + "right-managechangetags": "Buek jo matikan [[Special:Tags|tag]]", + "right-applychangetags": "Terapkan [[Special:Tags|tags]] basamoan jo parubahan pangguno", + "right-changetags": "Tambah jo apuih [[Special:Tags|tag]] arbitrari pado tiok-tiok revisi jo entri log", + "right-deletechangetags": "ApuIh [[Special:Tags|tag]] dari basisdata", + "grant-generic": "\"$1\" bundel hak akses", + "grant-group-page-interaction": "Barinteraksi jo laman", + "grant-group-file-interaction": "Barinteraksi jo media", + "grant-group-watchlist-interaction": "Barinteraksi jo daftar pantauan Sanak", "grant-group-email": "Kirim surel", + "grant-group-high-volume": "Malakukan aktivitas nan amaik banyak", + "grant-group-customization": "Kustomisasi jo preferensi", + "grant-group-administration": "Malakukan tindakan administratif", + "grant-group-private-information": "Akses data pribadi tantang Sanak", + "grant-group-other": "Aktivitas lain-lain", + "grant-blockusers": "Sakek jo bukak panyakekan pangguno", "grant-createaccount": "Buek akun", "grant-createeditmovepage": "Buek, suntiang, dan pindahkan laman", "grant-delete": "Hapuih laman, revisi, dan log entri", + "grant-editinterface": "Suntiang ruang namo MediaWiki jo JSON pangguno untuak kasadoalahan situs", + "grant-editmycssjs": "Manyuntiang laman CSS/JSON/JavaScript Sanak", + "grant-editmyoptions": "Manyuntiang preferensi pangguno Sanak jo konfigurasi JSON", + "grant-editmywatchlist": "Suntiang daftar pantauan Sanak", + "grant-editsiteconfig": "Suntiang CSS/JS pangguno untuak kasadoalahan situs", + "grant-editpage": "Manyuntiang laman nan ado", + "grant-editprotected": "Manyuntiang laman nan dilinduangi", + "grant-highvolume": "Panyuntiangan jo volume tinggi", + "grant-oversight": "Suruakan pangguno jo revisinyo", + "grant-patrol": "Tandoi laman tapatroli", + "grant-privateinfo": "Akses informasi pribadi", + "grant-protect": "Malinduangi jo mambukak palinduangan laman", + "grant-rollback": "Mambaliakan parubahan pado laman", + "grant-sendemail": "Mangirim surel ka pangguno lain", + "grant-uploadeditmovefile": "Maunggah, mangganti, jo mamindahan berkas", + "grant-uploadfile": "Muek berkas baru", "grant-basic": "Akses dasar", + "grant-viewdeleted": "Mancaliak laman jo berkas nan diapuih", + "grant-viewmywatchlist": "Caliak daftar pantauan Sanak", + "grant-viewrestrictedlogs": "Caliak entri log tabateh", "newuserlogpage": "Log pangguno baru", "newuserlogpagetext": "Di bawah ko log pandaftaran pangguno baru", "rightslog": "Log parubahan hak akses", @@ -1142,16 +1260,83 @@ "action-createpage": "buek laman ko", "action-createtalk": "buek laman rundiang ko", "action-createaccount": "buek akun pangguno ko", + "action-autocreateaccount": "buek otommatis akun pangguno lua", + "action-history": "Caliak riwayaik suntiangan laman ko", "action-minoredit": "tandoi sabagai suntiangan ketek", "action-move": "pindahan laman ko", "action-move-subpages": "pindahkan laman ko, jo sublamannyo", "action-move-rootuserpages": "pindahan laman pangguno", + "action-move-categorypages": "Pindahan halaman kategori", "action-movefile": "pindahkan berkas ko", "action-upload": "muek berkas ko", "action-reupload": "timpo berkas lamo", + "action-reupload-shared": "manimpo berkas nan alah ado di tampek panyimpanan berkas basamo", + "action-upload_by_url": "mamuek berkas ko dari sabuah alamaik URL", "action-writeapi": "manggunoan panulisan API", + "action-delete": "Hapuih laman ko", + "action-deleterevision": "Apuih revisi", + "action-deletelogentry": "apuih entri log", + "action-deletedhistory": "mancaliak versi tadaulu laman nan alah diapuih", + "action-deletedtext": "caliak teks revisi nan diapuih", + "action-browsearchive": "Cari laman nan dihapuih", + "action-undelete": "batalkan pangapuihan laman", + "action-suppressrevision": "tinjau jo baliakan revisi nan disuruakan", + "action-suppressionlog": "mancaliak log privat ko", + "action-block": "Sakek pangguno lain dari panyuntiangan", + "action-protect": "mangganti tingkek palinduangan laman ko", + "action-rollback": "mambaliakan sacaro capek suntiangan-suntiangan pangguno tarakhia nan manyuntiang laman tatantu", "action-import": "impor laman dari wiki lain", + "action-importupload": "maimpor laman ko dari berkas nan dimuek", + "action-patrol": "manandoi suntiangan pangguno lain sabagai tapatroli", + "action-autopatrol": "manandoi suntiangan Sanak surang sabagai tapatroli", + "action-unwatchedpages": "mancaliak daftar laman nan indak tapantau", + "action-mergehistory": "manggabuangkan revisi-revisi tadaulu dari laman ko", + "action-userrights": "manyuntiang sadoalah hak pangguno", + "action-userrights-interwiki": "manyuntiang hak pangguno-pangguno dari wiki lain", + "action-siteadmin": "mangunci jo mambukak basisdata", + "action-sendemail": "kirim surel", + "action-editmyoptions": "manyuntiang preferensi Sanak", + "action-editmywatchlist": "suntiang daftar pantauan Sanak", + "action-viewmywatchlist": "caliak daftar pantauan Sanak", + "action-viewmyprivateinfo": "caliak informasi pribadi Sanak", + "action-editmyprivateinfo": "manyuntiang informasi pribadi Sanak", + "action-editcontentmodel": "manyuntiang model konten sabuah laman", + "action-managechangetags": "buek jo matikan tag", + "action-applychangetags": "terapkan tag basamoan jo parubahan Sanak", + "action-changetags": "Tambah jo apuih [[Special:Tags|tag]] arbitrari pado tiok-tiok revisi jo entri log", + "action-deletechangetags": "apuih tag dari basisdata", + "action-purge": "apuih singgahan laman ko", + "action-apihighlimits": "manggunoan bateh labiah tinggi dalam kueri API", + "action-autoconfirmed": "indak dipangaruahi bateh laju babasis IP", + "action-bigdelete": "Apuih halaman nan banyak versi tadahulunyo", + "action-blockemail": "manyakek pangiriman surel dek pangguno", + "action-bot": "dipalakukan sabagai proses otomatis", + "action-editprotected": "manyuntiang laman talinduangi sabagai \"{{int:protect-level-sysop}}\"", + "action-editsemiprotected": "manyuntiang laman nan talinduangi sabagai \"{{int:protect-level-sysop}}\"", + "action-editinterface": "manyuntiang antarmuko pangguno", + "action-editusercss": "manyuntiang berkas CSS pangguno lain", + "action-edituserjson": "manyuntiang berkas JSON pangguno lain", + "action-edituserjs": "manyuntiang berkas JS pangguno lain", + "action-editsitecss": "manyunting CSS untuak kasadoalahan situs", + "action-editsitejson": "suntiang JSON untuak kasadoalahan situs", + "action-editsitejs": "suntiang JavaScript untuak kasadoalahan situs", + "action-editmyusercss": "suntiang berkas CSS pangguno Sanak", + "action-editmyuserjson": "suntiang berkas JSON pangguno Sanak", + "action-editmyuserjs": "suntiang berkas JavaScript pangguno Sanak", + "action-editmyuserjsredirect": "suntiang berkas JavaScript Sanak nan marupokan aliahan.", + "action-viewsuppressed": "caliak parubahan nan tasuruak dari sadoalah pangguno", + "action-hideuser": "sakek namo pangguno jo suruakan dari publik", + "action-ipblock-exempt": "abaikan panyakekan IP, panyakekan otomatis, jo rantang panyakekan", + "action-unblockself": "malapehan sakek surang", + "action-noratelimit": "indak dipangaruahi jo pambatehan jumlah suntiangan", + "action-reupload-own": "manimpo berkas nan dimuek surang", + "action-nominornewtalk": "indak ado tando suntiangan ketek di laman rundiang mamicu pasan baru", + "action-markbotedits": "tandoi pambaliakan revisi sabagai suntiangan bot", + "action-patrolmarks": "caliak panandoan patroli parubahan tabaru", + "action-override-export-depth": "ekspor laman tamasuak laman-laman takaik inggo kadalaman 5", + "action-suppressredirect": "indak mambuek pangaliahan wakatu mamindahan laman", "nchanges": "$1 {{PLURAL:$1|parubahan}}", + "enhancedrc-since-last-visit": "$1 {{PLURAL:$1|sajak kunjuangan tarakhia}}", "enhancedrc-history": "versi", "recentchanges": "Parubahan baru", "recentchanges-legend": "Piliahan parubahan baru", @@ -1212,6 +1397,8 @@ "rcfilters-filter-newpages-label": "Laman baru", "rcfilters-filter-categorization-label": "Parubahan kategori", "rcfilters-filter-logactions-label": "Tindakan tacataik", + "rcfilters-filter-lastrevision-label": "Revisi tabaru", + "rcfilters-filter-lastrevision-description": "Anyo parubahan tabaru pado laman ko.", "rcfilters-view-tags": "Suntiangan ditandoi", "rcfilters-liveupdates-button": "Parubahan langsuang", "rcfilters-liveupdates-button-title-on": "Matian parubahan langsuang", diff --git a/languages/i18n/mk.json b/languages/i18n/mk.json index 410e3abded..f33e981a32 100644 --- a/languages/i18n/mk.json +++ b/languages/i18n/mk.json @@ -71,6 +71,7 @@ "tog-useeditwarning": "Предупреди ме кога сакам да напуштам страница за уредување без да ги имам зачувано промените", "tog-prefershttps": "Секогаш најавувај ме преку безбедна врска", "tog-showrollbackconfirmation": "Прикажи потврдница при стискање на врската за отповикување", + "tog-requireemail": "Барај е-пошта за ставање нова лозинка", "underline-always": "Секогаш", "underline-never": "Никогаш", "underline-default": "Според рувото или прелистувачот", @@ -447,7 +448,7 @@ "createaccountmail": "Дај привремена произволна лозинка и испрати ја на укажаната адреса", "createaccountmail-help": "Може да се користи за создавање на сметка во туѓо име без да ја знаете лозинката.", "createacct-realname": "Вистинско име (незадолжително)", - "createacct-reason": "Причина", + "createacct-reason": "Причина (јавно заведена)", "createacct-reason-ph": "Зошто правите друга сметка", "createacct-reason-help": "Порака што се прикажува во дневникот на создадени сметки", "createacct-submit": "Направи ја сметката", @@ -616,24 +617,6 @@ "resettokens-watchlist-token": "Шифра за тековникот (Атом/RSS) на [[Special:Watchlist|измени во набљудуваните]]", "resettokens-done": "Шифрата е вратена одново.", "resettokens-resetbutton": "Врати избрани шифри", - "bold_sample": "Задебелен текст", - "bold_tip": "Задебелен текст", - "italic_sample": "Закосен текст", - "italic_tip": "Закосен текст", - "link_sample": "Наслов на врска", - "link_tip": "Внатрешна врска", - "extlink_sample": "http://www.example.com наслов на врска", - "extlink_tip": "Надворешна врска (со претставката http://)", - "headline_sample": "Наслов", - "headline_tip": "Поднаслов", - "nowiki_sample": "Овде внесете неформатиран текст", - "nowiki_tip": "Занемари викиформатирање", - "image_sample": "Пример.jpg", - "image_tip": "Вметната слика", - "media_sample": "Пример.ogg", - "media_tip": "Врска до податотека", - "sig_tip": "Вашиот потпис со време", - "hr_tip": "Хоризонтална линија", "summary": "Опис:", "subject": "Наслов:", "minoredit": "Ова е ситна промена", @@ -1114,6 +1097,7 @@ "prefs-help-email": "Е-поштата е незадолжителна, но ќе ви треба за добивање на нова лозинка ако си ја заборавите постоечката.", "prefs-help-email-others": "Можете да изберете другите да ве контактираат преку вашата корисничка страница без да го откриете вашиот идентитет.", "prefs-help-email-required": "Е-поштенска адреса е задолжително да се наведе.", + "prefs-help-requireemail": "Ако е штиклирано, можноста за нова лозинка ќе ја имаат само корисниците што навеле корисничко име и е-пошта.", "prefs-info": "Основни информации", "prefs-i18n": "Јазик", "prefs-signature": "Потпис", @@ -1834,6 +1818,7 @@ "listfiles-userdoesnotexist": "Корисничката сметка „$1“ не е регистрирана.", "imgfile": "податотека", "listfiles": "Список на податотеки", + "listfiles_subpage": "Подигања на $1", "listfiles_thumb": "Минијатура", "listfiles_date": "Датум", "listfiles_name": "Име", @@ -2571,6 +2556,7 @@ "ipblocklist-legend": "Најди блокиран корисник", "blocklist-userblocks": "Скриј блокирања на корис. сметки", "blocklist-tempblocks": "Скриј привремени блокирања", + "blocklist-indefblocks": "Скриј бесконечни блокови", "blocklist-addressblocks": "Скри блокирања на поединечни IP-адреси", "blocklist-type": "Вид:", "blocklist-type-opt-all": "Сите", @@ -3972,5 +3958,8 @@ "mycustomjsredirectprotected": "Немате дозвола да ја уредувате оваа страница со JavaScript бидејќи претставува пренасочување и не води кон вашиот именски простор.", "easydeflate-invaliddeflate": "Содржината не е соодветно прочистена", "unprotected-js": "JavaScript не може да се вчита од незаштитени страници од безбедносни причини. Создавајте JavaScript само во именскиот простор МедијаВики: или како корисничка потстраница", - "userlogout-continue": "Дали сакате да се одјавите?" + "userlogout-continue": "Дали сакате да се одјавите?", + "rest-prefix-mismatch": "Побараната патека ($1) не беше во основната приложничка патека REST ($2)", + "rest-wrong-method": "Наинот на барање ($1) {{PLURAL:$3|не е допуштениот за оваа патека|не е меѓу допуштените за оваа патека}} ($2)", + "rest-no-match": "Побараната односна патека ($1) не одговара на познат обработувач" } diff --git a/languages/i18n/ml.json b/languages/i18n/ml.json index 30edb01613..63b7e6580b 100644 --- a/languages/i18n/ml.json +++ b/languages/i18n/ml.json @@ -604,22 +604,6 @@ "resettokens-watchlist-token": " [[Special:Watchlist|താങ്കൾ ശ്രദ്ധിക്കുന്ന താളുകളിലുണ്ടാകുന്ന മാറ്റങ്ങളുടെ]] വെബ് ഫീഡ് (ആറ്റം/ആർ.എസ്.എസ്.) ചീട്ട്", "resettokens-done": "ചീട്ടുകൾ പുനഃസജ്ജീകരിക്കപ്പെട്ടു.", "resettokens-resetbutton": "തിരഞ്ഞെടുത്ത ചീട്ടുകൾ പുനഃസജ്ജീകരിക്കുക", - "bold_sample": "കടുപ്പിച്ച എഴുത്ത്", - "bold_tip": "കടുപ്പിച്ചെഴുതുവാൻ", - "italic_sample": "ചെരിച്ചുള്ള എഴുത്ത്", - "italic_tip": "ചെരിച്ചുള്ള എഴുത്ത്", - "link_sample": "വിക്കികണ്ണി", - "link_tip": "വിക്കികണ്ണി ചേർക്കുവാൻ", - "extlink_sample": "http://www.example.com കണ്ണി തലക്കെട്ട്", - "extlink_tip": "പുറത്തേക്കുള്ള കണ്ണി (http:// എന്ന ഉപസർഗ്ഗം ചേർക്കാൻ ഓർമ്മിക്കുക)", - "headline_sample": "തലക്കെട്ടിനുള്ള വാചകം ഇവിടെ ചേർക്കുക", - "headline_tip": "രണ്ടാംഘട്ട തലക്കെട്ട്", - "nowiki_sample": "വിക്കിഫോർമാറ്റിങ്ങ് ഉപയോഗിക്കേണ്ടാത്ത എഴുത്ത് ഇവിടെ ചേർക്കുക", - "nowiki_tip": "വിക്കിരീതി അവഗണിക്കുക", - "image_tip": "ചിത്രം ചേർക്കുവാൻ", - "media_tip": "മീഡിയയിലേക്ക് വിക്കി-കണ്ണി ചേർക്കുവാൻ", - "sig_tip": "തിരുത്തൽ സമയമടക്കമുള്ള താങ്കളുടെ ഒപ്പ്", - "hr_tip": "തിരശ്ചീനരേഖ (മിതമായി മാത്രം ഉപയോഗിക്കുക)", "summary": "ചുരുക്കം:", "subject": "വിഷയം:", "minoredit": "ഇതൊരു ചെറിയ തിരുത്താണ്", diff --git a/languages/i18n/mn.json b/languages/i18n/mn.json index e9b8a087e2..ff9297a632 100644 --- a/languages/i18n/mn.json +++ b/languages/i18n/mn.json @@ -512,24 +512,6 @@ "resettokens-token-label": "$1 (одоогийн утга: $2)", "resettokens-done": "Токен ресет хийлээ.", "resettokens-resetbutton": "Сонгосон токеныг ресет хийх", - "bold_sample": "Тодруулсан бичиг", - "bold_tip": "Тодруулсан бичиг", - "italic_sample": "Налуу бичиг", - "italic_tip": "Налуу бичиг", - "link_sample": "Холбоосны нэр", - "link_tip": "Дотоод холбоос", - "extlink_sample": "http://www.example.com холбоосны нэр", - "extlink_tip": "Гадны холбоос (эхэнд нь http:// бичихээ мартуузай)", - "headline_sample": "Гарчгийн текст", - "headline_tip": "2-р түвшний гарчиг", - "nowiki_sample": "Энд хэлбэршүүлээгүй текстээ оруулна уу", - "nowiki_tip": "Вики форматыг хэрэглэхгүй байх", - "image_sample": "жишээ.jpg", - "image_tip": "Оруулсан файл", - "media_sample": "Жишээ.ogg", - "media_tip": "Файлын холбоос", - "sig_tip": "Таны бичлэг үйлдсэн цагтай гарын үсэг", - "hr_tip": "Хөндлөн шугам (бага хэрэглээрэй)", "summary": "Товч агуулга:", "subject": "Сэдэв/гарчиг:", "minoredit": "Энэ бол бага зэргийн засвар", diff --git a/languages/i18n/mni.json b/languages/i18n/mni.json index 17a46a4fda..e3ca807368 100644 --- a/languages/i18n/mni.json +++ b/languages/i18n/mni.json @@ -470,22 +470,6 @@ "changeemail-none": "(ꯑꯃꯥꯇꯥ ꯅꯠꯇꯦ)", "changeemail-password": "ꯅꯪꯒꯤ {{SITENAME}} ꯄꯥꯁꯋ꯭ꯔꯠ:", "changeemail-submit": "ꯏ-ꯃꯦꯜ ꯍꯣꯡꯕꯥ", - "bold_sample": "ꯆꯥꯎꯅꯥ ꯏꯕꯥ", - "bold_tip": "ꯆꯥꯎꯅꯥ ꯏꯕꯥ", - "italic_sample": "ꯋꯥꯔꯦꯡ ꯐꯩꯅꯥ ꯏꯕꯥ", - "italic_tip": "ꯋꯥꯔꯦꯡ ꯐꯩꯅꯥ ꯏꯕꯥ", - "link_sample": "ꯑꯄꯤꯕ ꯃꯃꯤꯡ ꯁꯝꯅꯐꯝ", - "link_tip": "ꯃꯅꯨꯡꯒꯥ ꯁꯝꯅꯐꯝ", - "extlink_sample": "http://www.example.com ꯁꯝꯅꯐꯝꯒꯤꯃꯃꯤꯡ", - "extlink_tip": "ꯑꯇꯣꯞꯄꯥꯒꯥ ꯁꯝꯅꯐꯝ (ꯀꯥꯎꯒꯅꯨ http:// prefix)", - "headline_sample": "ꯃꯀꯣꯛꯀꯤ ꯋꯥꯔꯦꯡ ꯄꯥꯔꯦꯡ", - "headline_tip": "꯲ ꯁꯨꯕꯥ ꯃꯀꯣꯛꯀꯤ ꯄꯔꯦꯡ", - "nowiki_sample": "ꯍꯥꯞꯆꯤꯟꯂꯨ non formating ꯋꯥꯔꯦꯡꯗꯨ ꯁꯤꯗꯥ", - "nowiki_tip": "ꯋꯤꯀꯤꯒꯤ ꯃꯥꯑꯣꯡ ꯁꯦꯝꯕꯗꯨ ꯊꯧꯑꯣꯏꯗꯕꯥ", - "image_tip": "ꯅꯝꯁꯤꯟꯂꯕꯥ ꯐꯥꯏꯜ", - "media_tip": "ꯐꯥꯏꯜꯒꯤ ꯁꯝꯅꯐꯝ", - "sig_tip": "ꯃꯇꯝꯒꯤ ꯏꯁꯇꯥꯝꯒꯥ ꯂꯣꯏꯟꯅꯥ ꯅꯪꯒꯤ ꯈꯨꯇꯌꯦꯛ", - "hr_tip": "ꯐꯩꯅꯥ ꯆꯤꯡꯕꯥ ꯂꯥ ꯏ (ꯃꯔꯤꯛ ꯃꯔꯤꯛ ꯑꯣꯏꯅꯥ ꯁꯤꯖꯤꯟꯅꯧ)", "summary": "ꯑꯇꯦꯟꯕꯥ ꯁꯟꯗꯣꯛꯅꯥ ꯇꯥꯛꯄꯥ:", "subject": "ꯍꯤꯔꯝ:", "minoredit": "ꯃꯁꯤ ꯑꯄꯤꯛꯄꯥ ꯁꯦꯝꯒꯠꯄꯅꯤ", diff --git a/languages/i18n/mnw.json b/languages/i18n/mnw.json index 35b1be24d3..fd31873496 100644 --- a/languages/i18n/mnw.json +++ b/languages/i18n/mnw.json @@ -466,22 +466,6 @@ "resettokens-token-label": "$1 (ၚုဟ်မးလၟုဟ်: $2)", "resettokens-done": "ကလေၚ်ချိၚ်ဟီုတုဲတအ်.", "resettokens-resetbutton": "ကလေၚ်ချိၚ် မဟီုတုဲမရုဲစှ်လဝ်တအ်", - "bold_sample": "မလိက် တီု", - "bold_tip": "မလိက် တီု", - "italic_sample": "မလိက်ဓစေင်", - "italic_tip": "မလိက်ဓစေင်", - "link_sample": "လေန် က္ဍိုပ်လိက်", - "link_tip": "လေန် ဗွဲအပ္ဍဲ", - "extlink_sample": "http://www.example.com လေန် က္ဍိုပ်လိက်", - "extlink_tip": "လေန် ဗွဲမ္ၚး (remember http:// prefix)", - "headline_sample": "မလိက် က္ဍိုပ်လိက်", - "headline_tip": "က္ဍိုပ်လိက် ကဆံင် ၂", - "nowiki_sample": "စုတ် မလိက် ဟွံ-ဖျေဟ်ဗီုပြင်ဏီ ပ္ဍဲဒၞာဲဏအ်", - "nowiki_tip": "Ignore wiki formatting", - "image_tip": "ဝှာင် မစုတ်လဝ် Embedded", - "media_tip": "လေန် ဝှာင်", - "sig_tip": "စၟတ်တဲ မၞး နကဵု တဆိပ်အခိင်", - "hr_tip": "လာင် ဗွဲလနေင်", "summary": "သကေမ်", "subject": "ပရူပရာ\nဒါန်ပေၚ်အာ ၁၀၀၀ တုဲညးပလံၚ်နၚ် အခေါၚ်ခၞံမုက်လိက်ဏအ်။\nတၚ်ဂုဏ်ရ။", "minoredit": "ဣဏအ်ဂှ် ဒှ်အရာ မပလေဝ်ဒါန် ညိည", diff --git a/languages/i18n/mr.json b/languages/i18n/mr.json index 8c20f92f59..69374058a2 100644 --- a/languages/i18n/mr.json +++ b/languages/i18n/mr.json @@ -630,22 +630,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|आपल्या निरीक्षणसूचीतील पानांमधील बदलाचा]] वेब रसद बिल्ला (अॅटम/आरएसएस)", "resettokens-done": "ओळखचिन्हे पुनर्स्थापन.", "resettokens-resetbutton": "निवडलेली ओळखचिन्हे पुनर्स्थापित करा", - "bold_sample": "ठळक मजकूर", - "bold_tip": "ठळक मजकूर", - "italic_sample": "तिरकी अक्षरे", - "italic_tip": "तिरकी अक्षरे", - "link_sample": "दुव्याचे शीर्षक", - "link_tip": "अंतर्गत दुवा", - "extlink_sample": "http://www.example.com दुव्याचे शीर्षक", - "extlink_tip": "बाह्य दुव्यात (http:// हा उपसर्ग विसरू नका)", - "headline_sample": "मथळा मजकुर", - "headline_tip": "द्वितीय-स्तर अग्रशीर्ष", - "nowiki_sample": "अस्वरूपित मजकूर येथे भरा", - "nowiki_tip": "विकिभाषेप्रमाणे बदल करू नका", - "image_tip": "संलग्न संचिका", - "media_tip": "संचिकेचा दुवा", - "sig_tip": "वेळेबरोबर तुमची सही", - "hr_tip": "आडवी रेषा (अपवादानेच वापरा)", "summary": "बदलांचा आढावा :", "subject": "विषय:", "minoredit": "हा एक छोटा बदल आहे", diff --git a/languages/i18n/ms.json b/languages/i18n/ms.json index 6874d1c971..a193b3e80f 100644 --- a/languages/i18n/ms.json +++ b/languages/i18n/ms.json @@ -621,24 +621,6 @@ "resettokens-watchlist-token": "Token untuk suapan sesawang (Atom/RSS) bagi [[Special:Watchlist|perubahan pada halaman dalam senarai pantau anda]]", "resettokens-done": "Token diset semula.", "resettokens-resetbutton": "Set semula token terpilih", - "bold_sample": "Teks tebal", - "bold_tip": "Teks tebal", - "italic_sample": "Teks condong", - "italic_tip": "Teks condong", - "link_sample": "Tajuk pautan", - "link_tip": "Pautan dalaman", - "extlink_sample": "http://www.example.com tajuk pautan", - "extlink_tip": "Pautan luar (ingat awalan http://)", - "headline_sample": "Teks tajuk", - "headline_tip": "Tajuk peringkat 2", - "nowiki_sample": "Masukkan teks tak berformat di sini", - "nowiki_tip": "Abaikan pemformatan wiki", - "image_sample": "Contoh.jpg", - "image_tip": "Imej terbenam", - "media_sample": "Contoh.ogg", - "media_tip": "Pautan fail media", - "sig_tip": "Tandatangan dengan cap waktu", - "hr_tip": "Garis melintang (gunakan dengan hemat)", "summary": "Ringkasan:", "subject": "Perkara:", "minoredit": "Ini ialah suntingan kecil", diff --git a/languages/i18n/mt.json b/languages/i18n/mt.json index c8ec925294..71135aa472 100644 --- a/languages/i18n/mt.json +++ b/languages/i18n/mt.json @@ -509,24 +509,6 @@ "resettokens-no-tokens": "M'hemm l-ebda ''token'' biex jerÄ¡a' jiÄ¡i ssettjat.", "resettokens-tokens": "''Tokens'':", "resettokens-token-label": "$1 (valur attwali: $2)", - "bold_sample": "Tipa ħoxna", - "bold_tip": "Tipa ħoxna", - "italic_sample": "Tipa korsiva", - "italic_tip": "Tipa korsiva", - "link_sample": "Titlu tal-link", - "link_tip": "Link intern", - "extlink_sample": "http://www.example.com titlu tal-link", - "extlink_tip": "Link estern (ftakar il-prefiss http://)", - "headline_sample": "Kliem ta' l-ewwel vers", - "headline_tip": "L-ewwel vers ta' livell 2", - "nowiki_sample": "Daħħal test mhux formatjat hawnhekk", - "nowiki_tip": "Tagħtix każ il-formatjar tal-wiki", - "image_sample": "Eżempju.jpg", - "image_tip": "Fajl ingastat", - "media_sample": "Eżempju.ogg", - "media_tip": "Link tal-fajl", - "sig_tip": "Il-Firma tiegħek u it-timbru tal-ħin", - "hr_tip": "Linja mimduda (uża bil-qies)", "summary": "Taqsira:", "subject": "SuÄ¡Ä¡ett/Titlu:", "minoredit": "Din hija modifika minuri", diff --git a/languages/i18n/mwl.json b/languages/i18n/mwl.json index 861e85b0bd..05416cc312 100644 --- a/languages/i18n/mwl.json +++ b/languages/i18n/mwl.json @@ -361,22 +361,6 @@ "changeemail": "Altarar ó zarredar l andereço de correio eiletrónico", "changeemail-none": "(nanhun)", "resettokens": "Redefenir chabes", - "bold_sample": "Testo a negrito", - "bold_tip": "Testo a negrito", - "italic_sample": "Testo an eitálico", - "italic_tip": "Testo an eitálico", - "link_sample": "Títalo de la lhigaçon", - "link_tip": "Lhigaçon anterna", - "extlink_sample": "http://www.example.com títalo de la lhigaçon", - "extlink_tip": "Lhigaçon sterna (lembra-te de l perfixo http://)", - "headline_sample": "Testo de l cabeçailho", - "headline_tip": "Cacho de nible 2", - "nowiki_sample": "Poner testo nun-formatado eiqui", - "nowiki_tip": "Nun fazer causo de la formataçon biqui", - "image_tip": "Fexeiro ambutido", - "media_tip": "Lhigaçon pa fexeiro", - "sig_tip": "La tue assinatura, cun hora i data", - "hr_tip": "Lhinha hourizontal (outeliza cun regra)", "summary": "Resumo:", "subject": "Assunto/cabeçailho:", "minoredit": "Marcar cumo eidiçon pequerrixa", diff --git a/languages/i18n/my.json b/languages/i18n/my.json index cd64fb3c78..ecf4a40cfe 100644 --- a/languages/i18n/my.json +++ b/languages/i18n/my.json @@ -532,24 +532,6 @@ "resettokens-tokens": "တိုကင်များ-", "resettokens-token-label": "$1 (လက်ရှိတန်ဖိုး: $2)", "resettokens-resetbutton": "ရွေးချယ်ထားသော တိုကင်များကို ပြန်ချိန်ရန်", - "bold_sample": "စာလုံးမည်း", - "bold_tip": "စာလုံးမည်း", - "italic_sample": "စာလုံး အစောင်း", - "italic_tip": "စာလုံး အစောင်း", - "link_sample": "လင့်ခ် ခေါင်းစဉ်", - "link_tip": "အတွင်းပိုင်း လင့်ခ်", - "extlink_sample": "http://www.example.com လင့်ခ် ခေါင်းစဉ်", - "extlink_tip": "ပြင်ပလင့်များ (http:// ကို ရှေ့ဆုံးမှ ထည့်ရေးရန် မမေ့ပါနှင့်)", - "headline_sample": "ခေါင်းကြီးစာသား", - "headline_tip": "အဆင့် ၂ ခေါင်းစီး", - "nowiki_sample": "ဖောမတ်မလုပ်ထားသော စာများကို ဤနေရာတွင် ထည့်ရန်", - "nowiki_tip": "ဝီကီပုံစံ ဖော်မတ်များကို လျစ်လျူရှုရန်", - "image_sample": "ဥပမာ.jpg", - "image_tip": "Embedded ထည့်ထားသော ဖိုင်", - "media_sample": "ဥပမာ.ogg", - "media_tip": "ဖိုင်လင့်", - "sig_tip": "အချိန်ပါပြသော သင့်လက်မှတ်", - "hr_tip": "မျဉ်းလဲ (စိစစ်သုံးရန်)", "summary": "အ​ကျဉ်း​ချုပ်​ -", "subject": "အကြောင်းအရာ:", "minoredit": "အရေးမကြီးသော ​ပြင်​ဆင်​မှု ​ဖြစ်​သည်​", @@ -1750,12 +1732,15 @@ "rollbacklinkcount": "{{PLURAL:$1|တည်းဖြတ်မှု|တည်းဖြတ်မှုများ}} $1 ကို နောက်ပြန်ပြင်ရန်", "rollbacklinkcount-morethan": "$1 ထက်ပိုသော {{PLURAL:$1|တည်းဖြတ်မှု|တည်းဖြတ်မှုများ}}ကို နောက်ပြန်ပြင်ရန်", "rollbackfailed": "နောက်ပြန်ပြင်ခြင်း မအောင်မြင်ခဲ့ပါ။", + "cantrollback": "နောက်ပြန်မပြင်နိုင်ပါ၊ နောက်ဆုံးပံ့ပိုးသူမှာ ဤစာမျက်နှာ၏ တစ်ဦးတည်းသော စာရေးသူဖြစ်ပါသည်။", "editcomment": "တည်းဖြတ်မှု အကျဉ်းချုပ်မှာ: <em>$1</em>။", "revertpage": "[[Special:Contributions/$2|$2]] ([[User talk:$2|ဆွေးနွေး]]) ၏ ပြင်ဆင်မှုများကို [[User:$1|$1]] ၏ နောက်ဆုံးတည်းဖြတ်မူသို့ နောက်ပြန် ပြန်ပြင်ခဲ့သည်", + "rollback-success": "{{GENDER:$3|$1}} မှ နောက်ပြန်ပြင်ခဲ့သည်၊ {{GENDER:$4|$2}} ၏ နောက်ဆုံးမူသို့ ပြန်ပြောင်းခဲ့သည်။", "changecontentmodel": "စာမျက်နှာ၏ မာတိကာမော်ဒယ်ကို ပြောင်းလဲရန်", "changecontentmodel-legend": "မာတိကာမော်ဒယ်ကို ပြောင်းလဲရန်", - "changecontentmodel-title-label": "စာမျက်နှာ ခေါင်းစဉ်", - "changecontentmodel-model-label": "မာတိကာမော်ဒယ် အသစ်", + "changecontentmodel-title-label": "စာမျက်နှာ ခေါင်းစဉ်:", + "changecontentmodel-current-label": "လက်ရှိမာတိကာမော်ဒယ်:", + "changecontentmodel-model-label": "မာတိကာမော်ဒယ် အသစ်:", "changecontentmodel-reason-label": "အ​ကြောင်း​ပြ​ချက်:", "changecontentmodel-submit": "ပြောင်းလဲရန်", "changecontentmodel-success-title": "မာတိကာမော်ဒယ် ပြောင်းလဲခဲ့သည်", @@ -2417,8 +2402,11 @@ "tag-mw-undo": "နောက်ပြန် ပြန်ပြင်ခြင်း", "tags-title": "အမည်တွဲများ", "tags-tag": "အမည်တွဲ အမည်", + "tags-display-header": "ပြောင်းလဲချက် စာရင်းများပေါ်တွင် ပေါ်ထင်မှု", "tags-description-header": "ဆိုလိုရင်းအဓိပ္ပာယ် အပြည့်အစုံ", "tags-source-header": "ရင်းမြစ်", + "tags-active-header": "သက်ဝင်?", + "tags-hitcount-header": "အမည်တွဲထားသော ပြောင်းလဲမှုများ", "tags-actions-header": "ဆောင်ရွက်ချက်များ", "tags-active-yes": "မှန်", "tags-active-no": "မလုပ်ပါ", @@ -2661,6 +2649,7 @@ "userjsispublic": "ကျေးဇူးပြု၍ မှတ်သားပါ- JavaScript စာမျက်နှာခွဲများတွင် အခြားအသုံးပြုသူများ ကြည့်ရှုနိုင်သော လျို့ဝှက်အပ်သည့်အချက်အလက် မပါဝင်သင့်ပါ။", "edit-error-short": "အမှား - $1", "edit-error-long": "အမှားများ:\n\n$1", + "specialmute-submit": "အတည်ပြုရန်", "pageid": "စာမျက်နှာအိုင်ဒီ $1", "gotointerwiki": "{{SITENAME}} မှ ထွက်ခွာနေသည်", "pagedata-title": "စာမျက်နှာ ဒေတာ", diff --git a/languages/i18n/myv.json b/languages/i18n/myv.json index 03397b1e42..fda38b44cf 100644 --- a/languages/i18n/myv.json +++ b/languages/i18n/myv.json @@ -441,24 +441,6 @@ "changeemail-none": "(арась мезе невтемс)", "changeemail-password": "«{{SITENAME}}» проектэнь салававалот:", "changeemail-submit": "Полавтомс е-сёрмапаргот", - "bold_sample": "Эчке текст", - "bold_tip": "Эчке текст", - "italic_sample": "Комавтонь текст", - "italic_tip": "Комавтонь текст", - "link_sample": "Сюлмавомапень конякс", - "link_tip": "Потмоёндонь сюлмавомапе", - "extlink_sample": "http://www.example.com налткенть лемезе", - "extlink_tip": "Ушо ёнксонь сюлмавкс / налтке (мельсэ кирдить http:// путовксонть)", - "headline_sample": "Конякссонть текстэсь", - "headline_tip": "Омбоце эскельксэнь конякс", - "nowiki_sample": "Совавтомс хворматтомо текст тезэнь", - "nowiki_tip": "Wiki -нь поладомантень-витнемантень мель апак яво", - "image_sample": "Саемга.jpg", - "image_tip": "Путонь медия файла", - "media_sample": "Саемга.ogg", - "media_tip": "Медия файлантень сюлмавома пе (налтке)", - "sig_tip": "Шка марто кедь путовксот", - "hr_tip": "Менель кирьксэнь кикс (тевс нолдыть ванстозь)", "summary": "Вейсэндязь:", "subject": "Сёрмадовксонть лемезэ:", "minoredit": "Те апокшке витнема-петнема", diff --git a/languages/i18n/mzn.json b/languages/i18n/mzn.json index 211031b5c3..1840532995 100644 --- a/languages/i18n/mzn.json +++ b/languages/i18n/mzn.json @@ -344,22 +344,6 @@ "changeemail-newemail": "ترنه ایمیل آدرس:", "changeemail-none": "(هچّی)", "changeemail-submit": "ایمیل ره عوض هاکردن", - "bold_sample": "ضخیم", - "bold_tip": "ضخیم", - "italic_sample": "کژ", - "italic_tip": "کژ", - "link_sample": "لینک ِسرنوم", - "link_tip": "درونی لینک", - "extlink_sample": "http://www.example.com مثال", - "extlink_tip": "بیرون بگردستن (پیشوند http://‎ ره یادنکانین)", - "headline_sample": "متن عنوان", - "headline_tip": "عنوان بند Û²", - "nowiki_sample": "شه بی فورمت بنویشته ره اینجه دکانین", - "nowiki_tip": "فورمت سر چش ره کوریک بَیره", - "image_tip": "بنویشته‌ی دله‌ی عکس", - "media_tip": "فایل ِلینک", - "sig_tip": "شمه امضا و ونه په‌ی ِتاریخ", - "hr_tip": "افقی خط (ونه کمته کار بکشین)", "summary": "کار ِگزارش:", "subject": "موضوع یا عنوان:", "minoredit": "اینتا دچی‌یه خله جزئی بی‌یه", diff --git a/languages/i18n/nah.json b/languages/i18n/nah.json index 64627e7a6d..3e10f78326 100644 --- a/languages/i18n/nah.json +++ b/languages/i18n/nah.json @@ -332,21 +332,6 @@ "resetpass-submit-loggedin": "Ticpatlāz motlahtōlichtacāyo", "resetpass-submit-cancel": "Moxitiniz", "passwordreset-username": "Tequihuihcātōcāitl:", - "bold_sample": "Tliltic tlahcuiloliztli", - "bold_tip": "Tliltic tlahcuiloliztli", - "italic_sample": "Nacacic tlahcuiloliztli", - "italic_tip": "Nacacic tlahcuiloliztli", - "link_sample": "Tzonhuiliztli Ä«tōcā", - "link_tip": "Tlahtic tzonhuiliztli", - "extlink_sample": "http://www.machiyōtl.com Tzonhuiliztōcāitl", - "extlink_tip": "Calān tzonhuiliztli (xiquilnamiqui ticaquiāz in http://)", - "headline_sample": "Cuātlahcuilōlli", - "headline_tip": "Iuhcāyōtl 2 tōcāyōtl", - "image_sample": "Machiyotl.jpg", - "media_sample": "Machiyotl.ogg", - "media_tip": "MēdiahuÄ«c tzonhuiliztli", - "sig_tip": "Motōcā Ä«ca cāhuitl", - "hr_tip": "Pāntli", "summary": "Mopatlaliz:", "subject": "Itechpa:", "minoredit": "Ca tepiton inin tlapatlaliztli", diff --git a/languages/i18n/nan.json b/languages/i18n/nan.json index 05bc973762..6f45db8edb 100644 --- a/languages/i18n/nan.json +++ b/languages/i18n/nan.json @@ -486,23 +486,6 @@ "changeemail-submit": "Kái-piàn tiān-chu-phoe", "changeemail-throttled": "Lí chi̍t-ê-á teng-ji̍p liáu siuⁿ chē kái.\nChiáⁿ tan-thāi $1 kòe-āu chài chhì chi̍t pái.", "changeemail-nochange": "Chhiáⁿ su-ji̍p chi̍t-ê bô-kâng ê sin tiān-chú-phoe chÅ«-chí.", - "bold_sample": "Chho·-thé bûn-jÄ«", - "bold_tip": "Chho·-thé jÄ«", - "italic_sample": "Chhú-thé ê bûn-jÄ«", - "italic_tip": "Chhú-thé jÄ«", - "link_sample": "Liân-kiat piau-tê", - "link_tip": "Lōe-pō· ê liân-kiat", - "extlink_sample": "http://www.example.com liân-kiat piau-tê", - "extlink_tip": "Gōa-pō· ê liân-kiat (ē-kì-tit thâu-chêng ài ke http://)", - "headline_sample": "Thâu-tiâu bûn-jÄ«", - "headline_tip": "Tē-2-chân (level 2) ê phiau-tê", - "nowiki_sample": "Chia siá bô keh-sek ê bûn-jÄ«", - "nowiki_tip": "Mài chhap wiki keh-sek", - "image_sample": "Iann-siong-e-le.jpg", - "image_tip": "Giap tÄ« lāi-bÄ«n ê iáⁿ-siōng", - "media_tip": "Tóng-àn liân-kiat", - "sig_tip": "Lí ê chhiam-miâ kap sî-kan ìn-á", - "hr_tip": "Thán-pîⁿ-chōa (hàn leh ēng)", "summary": "Khài-iàu:", "subject": "Tê-bo̍k:", "minoredit": "Che sÄ« sió siu-kái", diff --git a/languages/i18n/nap.json b/languages/i18n/nap.json index 3365b11fed..e4212521ae 100644 --- a/languages/i18n/nap.json +++ b/languages/i18n/nap.json @@ -207,11 +207,11 @@ "tool-link-userrights": "Càgna gruppe {{GENDER:$1|utente}}", "tool-link-userrights-readonly": "Vire gruppe {{GENDER:$1|utente}}", "tool-link-emailuser": "Manna na masciata email a st'{{GENDER:$1|utente}}", - "imagepage": "Vere a paggena d' 'o file", - "mediawikipage": "Vere 'a mmasciata", - "templatepage": "Vere 'o template", - "viewhelppage": "Vere 'a paggena 'e ajùto", - "categorypage": "Vere 'a categurìa", + "imagepage": "Vire 'a paggena d' 'o file", + "mediawikipage": "Vire 'a mmasciata", + "templatepage": "Vire 'o template", + "viewhelppage": "Vire 'a paggena 'e ajùto", + "categorypage": "Vire 'a categurìa", "viewtalkpage": "Vere 'a paggena 'e chiàcchierate", "otherlanguages": "Ate lengue", "redirectedfrom": "(Redirect 'a $1)", @@ -262,7 +262,7 @@ "youhavenewmessagesmulti": "Tiene nuove mmasciate $1", "editsection": "càgna", "editold": "càgna", - "viewsourceold": "vere sorgente", + "viewsourceold": "vire sorgente", "editlink": "càgna", "viewsourcelink": "Vire sorgente", "editsectionhint": "Modifica a sezzione $1", @@ -352,7 +352,7 @@ "perfcachedts": "'E ddate ca stanno ccà songhe asciute 'a na copia \"cache\" d' 'o database, 'o cuale tene l'úrdemo agghiurnamento 'o $1. Nu massimo 'e {{PLURAL:$4|unu risultato è|$4 risultate songhe}} a disposizione dint'a \"cache\".", "querypage-no-updates": "Ll'agghiurnamente pe' sta paggena songo sospese mmo'. 'E ddate cuntenute ccà nun s'agghiurnarranno.", "viewsource": "Vere sorgente", - "viewsource-title": "Vere surgente 'e $1", + "viewsource-title": "Vire surgente 'e $1", "actionthrottled": "Azione ritardata", "actionthrottledtext": "Comme mesùra anti-abuse, site lemmetato 'a ffà st'azione troppe vote dint'a nu curto spazio 'e tiempo, e mo stu lèmmeto l'avite superato.\nPe piacere pruvate n'ata vota dint'a quacche minuto.", "protectedpagetext": "Sta paggena s'è prutetta pe ne ntuppà 'o càgno o quacche ata azione.", @@ -603,23 +603,6 @@ "resettokens-watchlist-token": "Token p' 'o feed web (Atom/RSS) d' 'e [[Special:Watchlist|cagnamiente a 'e paggene dint'a l'osservate spiciale tuoje]]", "resettokens-done": "Token riabbiate.", "resettokens-resetbutton": "Riabbìa 'e token scigliute", - "bold_sample": "Grassetto", - "bold_tip": "Grassetto", - "italic_sample": "Corsivo", - "italic_tip": "Corsivo", - "link_sample": "Titulo d' 'o cullegamento", - "link_tip": "Jonte nterne", - "extlink_sample": "http://www.example.com titulo d' 'o cullegamento", - "extlink_tip": "Link esterno (arricuordate 'o prefisso http:// )", - "headline_sample": "Testate", - "headline_tip": "Testate 'e 2° livello", - "nowiki_sample": "Azzeccà 'o testo nun-furmattato ccà", - "nowiki_tip": "Lassa perde' 'a furmattazione wiki", - "image_sample": "Essempio.jpg", - "image_tip": "Fiùra ncuorporata", - "media_tip": "Cullegamente a file multimediale", - "sig_tip": "Firma cu data e ora", - "hr_tip": "Linea orizzontale (ausà cu gedizzio)", "summary": "Riepilego:", "subject": "Suggietto:", "minoredit": "Chisto è nu cagnamiénto piccerillo", @@ -942,8 +925,8 @@ "next-page": "paggena aroppo", "prevn-title": "{{PLURAL:$1|Risultato precediente|$1 risultate precedenti}}", "nextn-title": "{{PLURAL:$1|Risultato successivo|$1 risultate successive}}", - "shown-title": "Fa vere {{PLURAL:$1|'nu risultato|$1 risultate}} ppe paggena", - "viewprevnext": "Vere($1 {{int:pipe-separator}} $2) ($3).", + "shown-title": "Fa verè {{PLURAL:$1|nu risultato|$1 risultate}} pe paggena", + "viewprevnext": "Vire ($1 {{int:pipe-separator}} $2) ($3).", "searchmenu-exists": "'''Ncopp' 'o sito esiste na paggena c' 'o nomme \"[[:$1]]\"'''\n{{PLURAL:$2|0=|Vedite pure dint'a l'ati risultate 'e cerca.}}", "searchmenu-new": "<strong>'''Crèa 'a paggena \"[[:$1]]\" ncopp'a stu wiki!'''</strong> {{PLURAL:$2|0=|Vedite pure 'a paggena truvata c' 'a recerca vuosta|Vedite pure 'e risultate d\"a recerca}}", "searchprofile-articles": "Paggene 'e contenute", @@ -1060,7 +1043,7 @@ "youremail": "E-mail:", "username": "{{GENDER:$1|Nomme utente}}:", "prefs-memberingroups": "{{GENDER:$2|Membro}} {{PLURAL:$1|d' 'o gruppo|d' 'e gruppe}}:", - "group-membership-link-with-expiry": "$1 (nzin' 'a $2)", + "group-membership-link-with-expiry": "$1 (nzin' 'e $4 d' 'o $3)", "prefs-registration": "Data 'e riggistrazione:", "yourrealname": "Nomme vero", "yourlanguage": "Lengua:", @@ -1924,6 +1907,7 @@ "apisandbox-sending-request": "Mannanno na richiesta 'API..", "apisandbox-loading-results": "Ricezione d' 'e risultate 'e ll'API 'ncurzo...", "apisandbox-results-error": "N'errore cumparette pe' tramente ca se steva carrecanno na risposta 'e query API: $1.", + "apisandbox-request-selectformat-label": "Fa verè 'e ddati comme:", "apisandbox-request-url-label": "URL addimannata:", "apisandbox-request-json-label": "Spiata JSON:", "apisandbox-request-time": "Tiempo addimannato: {{PLURAL:$1|$1 ms}}", @@ -2631,7 +2615,7 @@ "tooltip-ca-talk": "Vide 'e chiacchere rilative a chesta paggena", "tooltip-ca-edit": "Cagna sta paggena", "tooltip-ca-addsection": "Cummincia 'na nova sezzione", - "tooltip-ca-viewsource": "Chista paggena è prutetta, ma puo vere 'o codice sorgente", + "tooltip-ca-viewsource": "Chista paggena è prutetta, ma può verè 'o codice sorgente", "tooltip-ca-history": "Vversione 'e primma 'e chesta paggena", "tooltip-ca-protect": "Prutegge chesta paggena", "tooltip-ca-unprotect": "Càgna 'a prutezzione 'e chesta paggena", @@ -2662,16 +2646,16 @@ "tooltip-t-specialpages": "Lista 'e tutte e paggene speciale", "tooltip-t-print": "Vversione pe stampà 'a chesta paggena", "tooltip-t-permalink": "Jonta permanente a chesta vversione dda paggena", - "tooltip-ca-nstab-main": "Vere a paggena e contenuto", - "tooltip-ca-nstab-user": "Vere a paggena utente", + "tooltip-ca-nstab-main": "Vire 'a paggena 'e contenuto", + "tooltip-ca-nstab-user": "Vire 'a paggena utente", "tooltip-ca-nstab-media": "Vide 'a pàggena d' 'e media", "tooltip-ca-nstab-special": "Chesta è 'na paggena speciale e nun può essere càgnata", - "tooltip-ca-nstab-project": "Vere a paggena 'e servizio", + "tooltip-ca-nstab-project": "Vire 'a paggena 'e servizio", "tooltip-ca-nstab-image": "Vere a paggena ddo file", "tooltip-ca-nstab-mediawiki": "Vide 'a mmasciata d' 'o sistema", - "tooltip-ca-nstab-template": "Vere 'o modello", + "tooltip-ca-nstab-template": "Vire 'o modello", "tooltip-ca-nstab-help": "Vide 'a paggena d'aiuto", - "tooltip-ca-nstab-category": "Vere a paggena d\"a categurìa", + "tooltip-ca-nstab-category": "Vire 'a paggena d' 'a categurìa", "tooltip-minoredit": "Rénne chìsto cagnamiénto cchiù ppiccirìllo.", "tooltip-save": "Sàrva 'e cagnamiénte.", "tooltip-publish": "Pubbreca 'e cagnamiente vuoste", diff --git a/languages/i18n/nb.json b/languages/i18n/nb.json index 7ccdd86e45..c41fa88276 100644 --- a/languages/i18n/nb.json +++ b/languages/i18n/nb.json @@ -100,6 +100,7 @@ "tog-useeditwarning": "Si ifra dersom jeg forlater en side uten Ã¥ lagre den.", "tog-prefershttps": "Bruk alltid en trygg forbindelse nÃ¥r du er innlogget", "tog-showrollbackconfirmation": "Be om bekreftelse nÃ¥r man klikker pÃ¥ en tilbakestillingslenke", + "tog-requireemail": "Krev epost for tilbakestilling av passord", "underline-always": "Alltid", "underline-never": "Aldri", "underline-default": "Drakta eller nettleserens standardinnstillinger", @@ -641,24 +642,6 @@ "resettokens-watchlist-token": "Webmatenøkkel (Atom/RSS) for [[Special:Watchlist|endringer av sider pÃ¥ din overvÃ¥kningsliste]]", "resettokens-done": "Nullstilling av merker.", "resettokens-resetbutton": "Nullstill valgte merker", - "bold_sample": "Fet tekst", - "bold_tip": "Fet tekst", - "italic_sample": "Kursiv tekst", - "italic_tip": "Kursiv tekst", - "link_sample": "Lenketittel", - "link_tip": "Intern lenke", - "extlink_sample": "http://www.example.com lenketittel", - "extlink_tip": "Ekstern lenke (husk prefikset http://)", - "headline_sample": "Overskriftstekst", - "headline_tip": "Overskrift, nivÃ¥ 2", - "nowiki_sample": "Sett inn uformatert tekst her", - "nowiki_tip": "Ignorer wikiformatering", - "image_sample": "Eksempel.jpg", - "image_tip": "Innbygd fil", - "media_sample": "Eksempel.ogg", - "media_tip": "Fillenke", - "sig_tip": "Din signatur med dato", - "hr_tip": "Horisontal linje (bruk sparsomt)", "summary": "Redigeringsforklaring:", "subject": "Emne:", "minoredit": "Dette er en mindre endring", @@ -840,6 +823,7 @@ "undo-norev": "Redigeringen kunne ikke fjernes fordi den ikke eksisterer eller ble slettet", "undo-nochange": "Det ser ut til at redigeringen allerede er tilbakestilt.", "undo-summary": "Fjerner revisjon $1 av [[Special:Contributions/$2|$2]] ([[User talk:$2|diskusjon]])", + "undo-summary-anon": "Fjerner revisjon $1 av [[Special:Contributions/$2|$2]]", "undo-summary-username-hidden": "Fjern revisjon $1 av en skjult bruker", "cantcreateaccount-text": "Kontooppretting fra denne IP-adressen ('''$1''') har blitt blokkert av [[User:$3|$3]].\n\nGrunnen som ble oppgitt av $3 er ''$2''", "cantcreateaccount-range-text": "Opprettelsen av en brukerkonto fra IP-adresser i intervallet <strong>$1</strong>, som inneholder din IP-adresse (<strong>$4</strong>), er blitt blokkert av [[User:$3|$3]].\n\nÅrsaken angitt av $3 er <em>$2</em>", @@ -1137,6 +1121,7 @@ "prefs-help-email": "Å angi e-postadresse er valgfritt, men er nødvendig for Ã¥ fÃ¥ tilsendt nytt passord om du skulle glemme det gamle.", "prefs-help-email-others": "Du kan ogsÃ¥ velge Ã¥ la andre brukere kontakte deg via brukersiden din uten Ã¥ røpe identiteten din.", "prefs-help-email-required": "E-postadresse er pÃ¥krevd.", + "prefs-help-requireemail": "Hvis denne er valgt vil vi kunne sende eposter om tilbakestilling av passord dersom den som ber om det oppgir bÃ¥de brukernavn og epostadresse for kontoen.", "prefs-info": "Grunnleggende informasjon", "prefs-i18n": "Internasjonalisering", "prefs-signature": "Signatur", @@ -2353,6 +2338,7 @@ "alreadyrolled": "Kan ikke fjerne den siste redigeringen pÃ¥ [[$1]] av [[User:$2|$2]] ([[User talk:$2|diskusjon]]{{int:pipe-separator}}[[Special:Contributions/$2|{{int:contribslink}}]]); en annen har allerede redigert siden eller fjernet redigeringen.\n\nDen siste redigeringen ble foretatt av [[User:$3|$3]] ([[User talk:$3|diskusjon]]{{int:pipe-separator}}[[Special:Contributions/$3|{{int:contribslink}}]]).", "editcomment": "Redigeringskommentaren var: <em>$1</em>", "revertpage": "Tilbakestilte endringer av [[Special:Contributions/$2|$2]] ([[User talk:$2|brukerdiskusjon]]) til siste versjon av [[User:$1|$1]]", + "revertpage-anon": "Tilbakestilte endringer av [[Special:Contributions/$2|$2]] til siste versjon av [[User:$1|$1]]", "revertpage-nouser": "Tilbakestilt endringer av skjult bruker til siste versjon av\n{{GENDER:$1|[[User:$1|$1]]}}", "rollback-success": "Tilbakestilte endringer av {{GENDER:$3|$1}}; endret til siste versjon av {{GENDER:$4|$2}}.", "sessionfailure-title": "Sesjonsfeil", diff --git a/languages/i18n/nds-nl.json b/languages/i18n/nds-nl.json index 4bf2965b23..d7e5a1c702 100644 --- a/languages/i18n/nds-nl.json +++ b/languages/i18n/nds-nl.json @@ -23,49 +23,49 @@ "PiefPafPier" ] }, - "tog-underline": "Verwiezingen onderstrepen", - "tog-hideminor": "Kleine wiezigingen verbargen in \"Leste wiezigingen\"", - "tog-hidepatrolled": "Wiezigingen die emarkeerd bin verbargen in \"Leste wiezigingen\"", - "tog-newpageshidepatrolled": "Ziejen die emarkeerd bin, verbargen in de lieste mit nieje artikels", - "tog-extendwatchlist": "Volglieste uutbreien, zodat alle wiezigingen zichtbaor bin, en niet allinnig de leste wieziging", - "tog-usenewrc": "Groepeer wiezigingen per zied in \"Leste wiezigingen\" en \"Mien volglieste\"", - "tog-numberheadings": "Koppen vanzelf nummeren", - "tog-editondblclick": "Mit dubbelklik bewarken", - "tog-editsectiononrightclick": "Bewarken van deelziejen meugelik maken mit n rechtermuusklik op n tussenkop", - "tog-watchcreations": "Spul wa'k anmake op mien volglieste zetten", - "tog-watchdefault": "Spul wa'k bewarke op mien volglieste zetten", - "tog-watchmoves": "Spul wa'k herneume op mien volglieste zetten", - "tog-watchdeletion": "Spul wa'k vortdo op mien volglieste zetten", - "tog-watchrollback": "Ziejen waorvan ik bewarkingen weerummedreid hebbe automaties volgen", - "tog-minordefault": "Markeer alle veraanderingen as 'kleine wieziging'", - "tog-previewontop": "De naokiekzied boven t bewarkingsveld zetten", - "tog-previewonfirst": "Naokieken bie eerste wieziging", - "tog-enotifwatchlistpages": "Stuur mien n berichjen over zied- of bestaandswiezigingen uut mien volglieste.", - "tog-enotifusertalkpages": "Stuur mien n berichjen as mien overlegzied ewiezigd is.", - "tog-enotifminoredits": "Stuur mien oek n berichjen bie kleine bewarkingen van ziejen en bestaanden", - "tog-enotifrevealaddr": "Mien netpostadres laoten zien in netposttiejigen", - "tog-shownumberswatching": "t Antal gebrukers bekieken die disse zied volgt", - "tog-oldsig": "Bestaonde haandtekening:", - "tog-fancysig": "Ondertekening zien as wikitekste (zonder automatiese verwiezing)", - "tog-uselivepreview": "Gebruuk \"rechtstreeks naokieken\"", - "tog-forceeditsummary": "Geef n melding bie n lege samenvatting", - "tog-watchlisthideown": "Verbarg mien eigen bewarkingen", - "tog-watchlisthidebots": "Verbarg botgebrukers", - "tog-watchlisthideminor": "Verbarg kleine wiezigingen in mien volglieste", - "tog-watchlisthideliu": "Bewarkingen van an-emelde gebrukers op mien volglieste verbargen", - "tog-watchlisthideanons": "Bewarkingen van anonieme gebrukers op mien volglieste verbargen", - "tog-watchlisthidepatrolled": "Wiezigingen die emarkeerd bin op volglieste verbargen", - "tog-ccmeonemails": "Stuur mien kopieën van berichten an aandere gebrukers", - "tog-diffonly": "Laot de inhoud van ziejen niet onder de an-egeven wiezigingen zien.", - "tog-showhiddencats": "Laot verbörgen kategorieën zien", - "tog-norollbackdiff": "Wiezigingen vortlaoten nao t weerummedreien", - "tog-useeditwarning": "Waorschuw mien a'k n bewörken zied aof wil sluten die nog niet op-esleugen is", - "tog-prefershttps": "Altied n beveiligde verbiending gebruken a'j an-emeld bin", - "underline-always": "Altied", + "tog-underline": "Verwysingen understreapen", + "tog-hideminor": "Kleine wysigingen verbargen in \"Lätste wysigingen\"", + "tog-hidepatrolled": "Wysigingen dee markeerd binnet verbargen in \"Lätste wysigingen\"", + "tog-newpageshidepatrolled": "Syden dee markeerd binnet, verbargen in de lyste mid nye artikels", + "tog-extendwatchlist": "Volglyste uutbreiden, sodat alle wysigingen sichtbÃ¥r binnet, en neet allinnig de lätste wysigingen", + "tog-usenewrc": "Gruppeer wysigingen per syde in \"Lätste wysigingen\" en \"Myn volglyste\"", + "tog-numberheadings": "Upskrivten vanselv nummeren", + "tog-editondblclick": "Mid dubbelklik bewarken", + "tog-editsectiononrightclick": "Bewarken van deylsyden möägelik maken mid een rechtermuusklik up een tüskenupskrivt", + "tog-watchcreations": "Spül wat ik anmake up myn volglyste setten", + "tog-watchdefault": "Spül wat ik bewarke up myn volglyste setten", + "tog-watchmoves": "Spül wat ik hernöme up myn volglyste setten", + "tog-watchdeletion": "Spül wat ik vordsmyte up myn volglyste setten", + "tog-watchrollback": "Syden wÃ¥rvan ik bewarkingen weaderümmedraid hebbe automatisk volgen", + "tog-minordefault": "Markeer alle veranderingen as 'kleine wysiging'", + "tog-previewontop": "De nÃ¥kyksyde boaven et bewarkingsveld setten", + "tog-previewonfirst": "NÃ¥kyken by eyrste wysiging", + "tog-enotifwatchlistpages": "Stüür my een bericht oaver syd- of bestandswysigingen uut myn volglyste.", + "tog-enotifusertalkpages": "Stüür my een bericht as myn oaverlegsyde wysigd is.", + "tog-enotifminoredits": "Stüür my ouk een bericht by kleine bewarkingen van syden en bestanden", + "tog-enotifrevealaddr": "Myn e-postadres lÃ¥ten seen in e-postberichten", + "tog-shownumberswatching": "Et antal brukers bekyken dee disse syde volgt", + "tog-oldsig": "BestÃ¥nde handteykening:", + "tog-fancysig": "Underteykening seen as wikitekst (sunder automatiske verwysing)", + "tog-uselivepreview": "NÃ¥kyksyde lÃ¥ten seen sunder eyrst te herladen", + "tog-forceeditsummary": "Geav een melding by een leadige samenvatting", + "tog-watchlisthideown": "Verbarg myn eigen bewarkingen", + "tog-watchlisthidebots": "Verbarg botbrukers", + "tog-watchlisthideminor": "Verbarg kleine wysigingen in myn volglyste", + "tog-watchlisthideliu": "Bewarkingen van anmeldede brukers up myn volglyste verbargen", + "tog-watchlisthideanons": "Bewarkingen van anonyme brukers up myn volglyste verbargen", + "tog-watchlisthidepatrolled": "Wysigingen dee markeerd binnet up volglyste verbargen", + "tog-ccmeonemails": "Stüür my kopien van berichten an andere brukers", + "tog-diffonly": "Under wysigingen neet de syde-inhold lÃ¥ten seen.", + "tog-showhiddencats": "LÃ¥t verbörgen kategoryen seen", + "tog-norollbackdiff": "Wysigingen vordlÃ¥ten nÃ¥ et weaderümmedraien", + "tog-useeditwarning": "WÃ¥rschüw my as ik een bewarkede syde afsluten wil dee noch neet seakerd is", + "tog-prefershttps": "Altyd een beveiligde verbinding bruken as jy anmelded binnet", + "underline-always": "Altyd", "underline-never": "Nooit", - "underline-default": "Standard in joew vormgeving of webkieker", - "editfont-style": "Lettertype veur de tekste t bewarkingsveld:", - "editfont-monospace": "Lettertype waorvan t tekenbreedte vaste steet", + "underline-default": "Standard in juw formgeaving of webkyker", + "editfont-style": "Lettertype vöär de tekst in et bewarkingsveld:", + "editfont-monospace": "Lettertype wÃ¥rvan de teykenbreydte vast steyt", "editfont-sansserif": "Sans-seriflettertype", "editfont-serif": "Seriflettertype", "sunday": "sündag", @@ -96,7 +96,7 @@ "december": "december", "january-gen": "januÃ¥ri", "february-gen": "februÃ¥ri", - "march-gen": "meert", + "march-gen": "määrt", "april-gen": "april", "may-gen": "mei", "june-gen": "juni", @@ -105,7 +105,7 @@ "september-gen": "september", "october-gen": "oktober", "november-gen": "november", - "december-gen": "desember", + "december-gen": "december", "jan": "jan", "feb": "feb", "mar": "mrt", @@ -118,9 +118,9 @@ "oct": "okt", "nov": "nov", "dec": "dec", - "january-date": "$1 jannewaori", - "february-date": "$1 febrewaori", - "march-date": "$1 meert", + "january-date": "$1 januÃ¥ri", + "february-date": "$1 februÃ¥ri", + "march-date": "$1 määrt", "april-date": "$1 april", "may-date": "$1 mei", "june-date": "$1 juni", @@ -129,42 +129,42 @@ "september-date": "$1 september", "october-date": "$1 oktober", "november-date": "$1 november", - "december-date": "$1 desember", + "december-date": "$1 december", "pagecategories": "{{PLURAL:$1|Kategory|Kategoryen}}", "category_header": "Artikels in kategory $1", - "subcategories": "Subkategorieën", - "category-media-header": "Media in kategorie \"$1\"", - "category-empty": "''In disse kategoria staon op t moment nog gien artikels of media.''", + "subcategories": "Subkategoryen", + "category-media-header": "Media in kategory \"$1\"", + "category-empty": "<em>In disse kategory stÃ¥n up et moment noch geen syden of media.</em>", "hidden-categories": "Verbörgen {{PLURAL:$1|kategory|kategoryen}}", - "hidden-category-category": "Verbörgen kategorieën", + "hidden-category-category": "Verbörgen kategoryen", "category-subcat-count": "{{PLURAL:$2|Disse kategory hevt de volgende subkategory.|Disse kategory hevt de volgende {{PLURAL:$1|subkategory|$1 subkategoryen}}, van in totaal $2.}}", - "category-subcat-count-limited": "Disse kategorie hef de volgende {{PLURAL:$1|subkategorie|$1 subkategorieën}}.", + "category-subcat-count-limited": "Disse kategory hevt de volgende {{PLURAL:$1|subkategory|$1 subkategoryen}}.", "category-article-count": "{{PLURAL:$2|In disse kategory steyt allinnig de volgende syde.|De volgende {{PLURAL:$1|syde steyt|$1 syden stÃ¥n}} in disse kategory, van in totaal $2.}}", - "category-article-count-limited": "In disse kategorie {{PLURAL:$1|steet de volgende zied|staon de volgende $1 ziejen}}.", - "category-file-count": "In disse kategorie {{PLURAL:$2|steet t volgende bestaand|staon de volgende $1 bestaanden, van in totaal $2}}.", - "category-file-count-limited": "In disse kategorie {{PLURAL:$1|steet t volgende bestaand|staon de volgende $1 bestaanden}}.", + "category-article-count-limited": "In disse kategory {{PLURAL:$1|steyt de volgende syde|stÃ¥n de volgende $1 syden}}.", + "category-file-count": "In disse kategory {{PLURAL:$2|steyt et volgende bestand|stÃ¥n de volgende $1 bestanden, van in totaal $2}}.", + "category-file-count-limited": "In disse kategory {{PLURAL:$1|steyt et volgende bestand|stÃ¥n de volgende $1 bestanden}}.", "listingcontinuesabbrev": "(vervolg)", - "index-category": "Te indexeren ziejen", + "index-category": "Te indekseren syden", "noindex-category": "Syden dee neet indexeerd binnen", - "broken-file-category": "Ziejen mit verkeerde bestaandsverwiezingen", - "about": "Informasie", + "broken-file-category": "Syden mid verkeyrde bestandsverwysingen", + "about": "Informaty", "article": "Artikel", - "newwindow": "(niej vienster)", + "newwindow": "(ny vinster)", "cancel": "Afbreaken", - "moredotdotdot": "Meer...", - "morenotlisted": "Disse lieste is niet kompleet...", - "mypage": "Gebrukerszied", + "moredotdotdot": "Meyr...", + "morenotlisted": "Disse lyste is möägelik neet kompleet.", + "mypage": "Brukerssyde", "mytalk": "Myn oaverleg", "anontalk": "Oaverleg", "navigation": "Navigaty", "and": " en", - "faq": "Vragen die vake esteld wörden", - "actions": "Haandeling", + "faq": "Vake stelde vrÃ¥gen", + "actions": "Handelingen", "namespaces": "Naamruumdes", "variants": "Varianten", "navigation-heading": "Navigatymenü", "errorpagetitle": "Foutmelding", - "returnto": "Weerumme naor $1.", + "returnto": "Weaderümme nÃ¥ $1.", "tagline": "Van {{SITENAME}}", "help": "Hülpe", "search": "Söken", @@ -176,50 +176,50 @@ "updatedmarker": "bie-ewörken sinds mien leste bezeuk", "printableversion": "AfdrükbÃ¥re versy", "permalink": "Vaste verwysing", - "print": "Aofdrokken", + "print": "Afdrükken", "view": "Leasen", "view-foreign": "Bekyken up $1", "edit": "Bewarken", "edit-local": "Lokale beschrieving bewarken", "create": "Anmaken", - "create-local": "Lokale beschrieving derbie doon", - "delete": "Vortdoon", - "undelete_short": "$1 {{PLURAL:$1|versie|versies}} weerummeplaotsen", - "viewdeleted_short": "{{PLURAL:$1|Eén versie die vortedaon is|$1 versies die vortedaon bin}} bekieken", + "create-local": "Lokale beskryving tovogen", + "delete": "Vordsmyten", + "undelete_short": "$1 {{PLURAL:$1|versy|versys}} weaderümmeplaatsen", + "viewdeleted_short": "{{PLURAL:$1|Eyn versy dee vordsmeaten is|$1 versys dee vortsmeaten binnet}} bekyken", "protect": "Beveiligen", - "protect_change": "wiezigen", + "protect_change": "wysigen", "unprotect": "Beveiliging wysigen", - "newpage": "Nieje zied", + "newpage": "Nye syde", "talkpagelinktext": "Oaverleg", "specialpage": "Speciale syde", "personaltools": "Persoonlike instellingen", "talk": "Oaverleg", "views": "WeadergÃ¥ven", - "toolbox": "Hülpmiddels", - "tool-link-userrights": "{{GENDER:$1|Gebrukersgruppen}} wysigen", - "tool-link-emailuser": "Disse {{GENDER:$1|gebruker}} een bericht stüren", - "imagepage": "Bestaandszied bekieken", - "mediawikipage": "Tiejige bekieken", - "templatepage": "Mal bekieken", - "viewhelppage": "Hulpzied bekieken", - "categorypage": "Kategoriezied bekieken", - "viewtalkpage": "Bekiek overlegzied", + "toolbox": "Warktügen", + "tool-link-userrights": "{{GENDER:$1|Brukersgruppen}} wysigen", + "tool-link-emailuser": "Disse {{GENDER:$1|bruker}} een bericht stüren", + "imagepage": "Bestandssyde bekyken", + "mediawikipage": "Berichtsyde bekyken", + "templatepage": "Mal bekyken", + "viewhelppage": "Hülpsyde bekyken", + "categorypage": "Kategorysyde bekyken", + "viewtalkpage": "Bekyk oaverlegsyde", "otherlanguages": "Andere sprÃ¥ken", "redirectedfrom": "(döärstüürd vanaf \"$1\")", - "redirectpagesub": "Deurverwieszied", - "redirectto": "Deurverwiezen naor:", + "redirectpagesub": "Döärverwyssyde", + "redirectto": "Döärverwysen nÃ¥:", "lastmodifiedat": "Disse syde is et lätst wysigd up $1 üm $2.", - "viewcount": "Disse zied is $1 {{PLURAL:$1|keer|keer}} bekeken.", - "protectedpage": "Beveiligden zied", + "viewcount": "Disse syde is $1 {{PLURAL:$1|keyr}} bekeaken.", + "protectedpage": "Beveiligde syde", "jumpto": "GÃ¥ nÃ¥:", "jumptonavigation": "navigaty", "jumptosearch": "söök", - "view-pool-error": "De servers bin op heden overbelast.\nTe veule gebrukers proberen disse zied te bekieken.\nWacht effen veurda'j opniej toegang proberen te kriegen tot disse zied.\n\n$1", - "generic-pool-error": "De servers bin op heden overbelast.\nTe veule gebrukers proberen disse zied te bekieken.\nWacht effen veurda'j opniej toegang proberen te kriegen tot disse zied.", - "pool-timeout": "De maximumwachttied veur databankvergrendeling is verleupen.", - "pool-queuefull": "De wachtrie van de poel is vol", - "pool-errorunknown": "Onbekende fout", - "pool-servererror": "De dienst \"pool counter\" is niet beschikbaor ($1).", + "view-pool-error": "De servers binnet momenteel oaverbelasted.\nTe vöäle lüde proberet disse syde te bekyken.\nWacht evven vöärdat jy upny togang proberet te krygen tot disse syde.\n\n$1", + "generic-pool-error": "De servers binnet momenteel oaverbelasted.\nTe vöäle lüde proberet disse syde te bekyken.\nWacht evven vöärdat jy upny togang proberet te krygen tot disse syde.", + "pool-timeout": "De maksimumwachttyd vöär databankvergrendeling is verlöypen.", + "pool-queuefull": "De wachtryge van de pool is vul", + "pool-errorunknown": "Unbekende faut", + "pool-servererror": "De deenst \"pool counter\" is neet beskikbÃ¥r ($1).", "aboutsite": "Oaver {{SITENAME}}", "aboutpage": "Project:Info", "copyright": "De inhoud is beschikbaor onder de $1 as der niks aanders an-egeven is.", @@ -228,8 +228,8 @@ "currentevents-url": "Project:In et nys", "disclaimers": "Vöärbehold", "disclaimerpage": "Project:Vöärbehold", - "edithelp": "Hulpe mit bewarken", - "helppage-top-gethelp": "Hulpe", + "edithelp": "Hülpe mid bewarken", + "helppage-top-gethelp": "Hülpe", "mainpage": "Vöärblad", "mainpage-description": "Vöärblad", "policy-url": "Project:Beleid", @@ -237,121 +237,121 @@ "portal-url": "Project:Gemeynskapsportaal", "privacy": "Gegeavensbeleid", "privacypage": "Project:Gegeavensbeleid", - "badaccess": "Gien toestemming", - "badaccess-group0": "Je hebben gien toestemming um disse aksie uut te voeren.", - "badaccess-groups": "Disse aksie kan allinnig uutevoerd wörden deur gebrukers uut {{PLURAL:$2|de groep|één van de groepen}}: $1.", - "versionrequired": "Versie $1 van MediaWiki is neudig", - "versionrequiredtext": "Versie $1 van MediaWiki is neudig um disse zied te gebruken. Zie [[Special:Version|Versie]].", - "ok": "Best", + "badaccess": "Geen tostemming", + "badaccess-group0": "Jy hebbet geen tostemming üm disse akty uut te voren.", + "badaccess-groups": "Disse akty kan allinnig uutvoord wörden döär brukers uut {{PLURAL:$2|de grup|eyn van de gruppen}}: $1.", + "versionrequired": "Versy $1 van MediaWiki is nöydig", + "versionrequiredtext": "Versy $1 van MediaWiki is nöydig üm disse syde te bruken. See [[Special:Version|Versy]].", + "ok": "Okee", "retrievedfrom": "Van \"$1\"", - "youhavenewmessages": "Je hebben $1 ($2).", - "youhavenewmessagesfromusers": "Je hebben $1 van {{PLURAL:$3|n aandere gebruker|$3 gebrukers}} ($2).", - "youhavenewmessagesmanyusers": "Je hebben $1 van n bulte gebrukers ($2).", - "newmessageslinkplural": "{{PLURAL:$1|n niej bericht|999=nieje berichten}}", - "newmessagesdifflinkplural": "leste {{PLURAL:$1|wieziging|999=wiezigingen}}", + "youhavenewmessages": "{{PLURAL:$3|Jy hebbet}} $1 ($2).", + "youhavenewmessagesfromusers": "{{PLURAL:$4|Jy hebbet}} $1 van {{PLURAL:$3|een andere bruker|$3 brukers}} ($2).", + "youhavenewmessagesmanyusers": "Jy hebbet $1 van een bült brukers ($2).", + "newmessageslinkplural": "{{PLURAL:$1|een ny bericht|999=nye berichten}}", + "newmessagesdifflinkplural": "läste {{PLURAL:$1|wysiging|999=wysigingen}}", "youhavenewmessagesmulti": "Jy hebbet nye berichten up $1", "editsection": "bewark", "editold": "bewark", - "viewsourceold": "brontekste bekyken", + "viewsourceold": "brontekst bekyken", "editlink": "bewark", "viewsourcelink": "brontekst bekyken", "editsectionhint": "Bewarkingsveld: $1", "toc": "Inhold", - "showtoc": "Bekieken", - "hidetoc": "Verbarg", + "showtoc": "bekyken", + "hidetoc": "verbargen", "collapsible-collapse": "Inklappen", "collapsible-expand": "Uutklappen", - "confirmable-confirm": "{{GENDER:$1|Bi'j}} daor wisse van?", + "confirmable-confirm": "{{GENDER:$1|Bin jy}} dÃ¥r wisse van?", "confirmable-yes": "Ja", - "confirmable-no": "Nee", - "thisisdeleted": "Bekieken of herstellen van $1?", - "viewdeleted": "Bekiek $1?", - "restorelink": "{{PLURAL:$1|versie die vortedaon is|versies die vortedaon bin}}", - "feedlinks": "Voer:", - "feed-invalid": "Voertype wörden niet ondersteunt.", - "feed-unavailable": "Syndicakievoer is niet beschikbaor", - "site-rss-feed": "$1 RSS-voer", - "site-atom-feed": "$1 Atom-voer", - "page-rss-feed": "\"$1\" RSS-voer", - "page-atom-feed": "\"$1\" Atom-voer", + "confirmable-no": "Ney", + "thisisdeleted": "Bekyken of herstellen van $1?", + "viewdeleted": "Bekyk $1?", + "restorelink": "{{PLURAL:$1|versy dee vordsmeaten is|versys dee vordsmeaten binnet}}", + "feedlinks": "Voder:", + "feed-invalid": "Vodertype wördt neet understöänt.", + "feed-unavailable": "Syndikatyvoder is neet beskikbÃ¥r", + "site-rss-feed": "$1 RSS-voder", + "site-atom-feed": "$1 Atom-voder", + "page-rss-feed": "\"$1\" RSS-voder", + "page-atom-feed": "\"$1\" Atom-voder", "red-link-title": "$1 (syde besteyt noch neet)", - "sort-descending": "Aoflopend sorteren", - "sort-ascending": "Oplopend sorteren", - "nstab-main": "Artikel", - "nstab-user": "Gebruker", - "nstab-media": "Media", + "sort-descending": "Afloupend sorteren", + "sort-ascending": "Uploupend sorteren", + "nstab-main": "Syde", + "nstab-user": "Brukerssyde", + "nstab-media": "Mediasyde", "nstab-special": "Speciale syde", "nstab-project": "Projektsyde", "nstab-image": "Bestand", - "nstab-mediawiki": "Bericht", + "nstab-mediawiki": "Systeembericht", "nstab-template": "Mal", "nstab-help": "Hülpe", "nstab-category": "Kategory", "mainpage-nstab": "Vöärblad", - "nosuchaction": "De op-egeven haandeling besteet niet", - "nosuchactiontext": "De opdrachte in t webadres in ongeldig.\nJe hebben t webadres misschien verkeerd in-etikt of de verkeerde verwiezing evolgd.\nDit kan oek dujen op n fout in de programmatuur van {{SITENAME}}.", - "nosuchspecialpage": "Der besteet gien spesiale zied mit disse naam", - "nospecialpagetext": "<strong>Disse spesiale zied wörden niet herkend deur de programmatuur.</strong>\n\nn Lieste mit bestaonde spesiale ziejen ku'j vienen op [[Special:SpecialPages|{{int:specialpages}}]].", - "error": "Foutmelding", - "databaseerror": "Fout in de databanke", - "databaseerror-text": "Der is wat mis egaon bie n databankzeukopdrachte.\nDit kan betekenen dat der n fout in de programmtuur zit.", - "databaseerror-textcl": "Der is wat mis egaon bie n databankzeukopdrachte.", - "databaseerror-query": "Zeukopdrachte: $1", - "databaseerror-function": "Funksie: $1", - "databaseerror-error": "Fout: $1", - "laggedslavemode": "<strong>Waorschuwing:</strong> t is meugelik dat leste wiezigingen in de tekste van dit artikel nog niet verwarkt bin.", + "nosuchaction": "De upgeaven handeling besteyt neet", + "nosuchactiontext": "De updracht in et webadres in ungeldig.\nJy hebbet et webadres meskeen verkeyrd intyped of de verkeyrde verwysing volgd.\nDit kan ouk düden up een faut in de programmatuur van {{SITENAME}}.", + "nosuchspecialpage": "Der besteyt geen speciale syde mid disse name", + "nospecialpagetext": "<strong>Disse speciale syde wördt neet herkend döär de programmatuur.</strong>\n\nEen lyste mid bestÃ¥nde speciale syden kün jy vinden up [[Special:SpecialPages|{{int:specialpages}}]].", + "error": "Faut", + "databaseerror": "Databankfaut", + "databaseerror-text": "Der is wat mis gÃ¥n by een databanksöökupdracht.\nDit kan beteykenen dat der een faut in de programmtuur sit.", + "databaseerror-textcl": "Der is wat mis gÃ¥n by een databanksöökupdracht.", + "databaseerror-query": "Söökupdracht: $1", + "databaseerror-function": "Funkty: $1", + "databaseerror-error": "Faut: $1", + "laggedslavemode": "<strong>WÃ¥rschüwing:</strong> et kan weasen dat de lätste wysigingen up disse syde noch neet upnöämen binnet.", "readonly": "De databanke is beveiligd", - "enterlockreason": "Waorumme en veur hoe lange is t eblokkeerd?", - "readonlytext": "De databanke van {{SITENAME}} is noen esleuten veur nieje bewarkingen en wiezigingen, warschienlik veur bestaandsonderhoud. De verantwoordelike systeembeheerder gaf hierveur de volgende reden op: '''$1'''", - "missing-article": "In de databanke steet gien tekste veur de zied \"$1\" die der wel in zol mutten staon ($2).\n\nDit kan koemen deurda'j n ouwe verwiezing naor t verschil tussen twee versies van n zied volgen of n versie opvragen die vortedaon is.\n\nAs dat niet zo is, dan he'j misschien n fout in de programmatuur evunnen.\nMeld t dan effen bie n [[Special:ListUsers/sysop|systeembeheerder]] van {{SITENAME}} en vermeld derbie de internetverwiezing van disse zied.", - "missingarticle-rev": "(versienummer: $1)", - "missingarticle-diff": "(Wieziging: $1, $2)", - "readonly_lag": "De databanke is automaties beveilig, zodat de ondergeschikten servers zich kunnen synchroniseren mit de sentrale server.", - "internalerror": "Interne fout", - "internalerror_info": "Interne fout: $1", - "filecopyerror": "Kon bestaand \"$1\" niet naor \"$2\" kopiëren.", - "filerenameerror": "Bestaandsnaamwieziging \"$1\" naor \"$2\" niet meugelik.", - "filedeleteerror": "Kon bestaand \"$1\" niet vortdoon.", - "directorycreateerror": "Map \"$1\" kon niet an-emaakt wörden.", - "directoryreadonlyerror": "De map \"$1\" is allinnig-lezen.", - "directorynotreadableerror": "De map \"$1\" kan niet elezen wörden.", - "filenotfound": "Kon bestaand \"$1\" niet vienen.", - "unexpected": "Onverwachten weerde: \"$1\"=\"$2\".", - "formerror": "Fout: kon formulier niet versturen", - "badarticleerror": "Disse haandeling kan op disse zied niet uutevoerd wörden.", - "cannotdelete": "De zied of t bestaand \"$1\" kon niet vortedaon wörden.\nt Kan ween dat n aander t al vortedaon hef.", - "cannotdelete-title": "Zied \"$1\" kan niet vortedaon wörden", - "delete-hook-aborted": "t Vortdoon wördt in t wiere eschopt deur n toepassige van MediaWiki.\nDer is gien veerdere informasie beschikbaor.", - "no-null-revision": "Kon gien lege nieje versie maken veur de zied \"$1\"", - "badtitle": "Ongeldige naam", - "badtitletext": "De naam van de op-evreugen zied is niet geldig, leeg, of n interwiki-verwiezing naor n onbekende of ongeldige wiki.", - "perfcached": "Disse gegevens koemen uut t tussengeheugen en bin misschien niet aktueel. Der {{PLURAL:$1|is hooguut een resultaot|bin hooguut $1 resultaoten}} beschikbaor in t tussengeheugen.", - "perfcachedts": "Disse gegevens koemen uut t tussengeheugen die veur t lest bie-ewörken is op $2 um $3. Der {{PLURAL:$4|is hooguut een resultaot|bin hooguut $4 resultaoten}} beschikbaor in t tussengeheugen.", - "querypage-no-updates": "'''Disse zied wördt niet meer bie-ewörken.'''", + "enterlockreason": "Voor een readen in vöär de vergrendeling, en geav up wanneyr et ungeaver vrygeaven wördt.", + "readonlytext": "De databanke is up et moment slöäten vöär nye inbreng en andere wysigingen, wÃ¥rskynlik vöär rutinemÃ¥tig underhold, wÃ¥rnÃ¥ et weader lös geyt. \n\nDe systeembeheyrder gav hyrvöär de volgende readen up: $1", + "missing-article": "In de databanke steyt geen tekst vöär de syde \"$1\" dee der wel in sol mütten stÃ¥n ($2).\n\nDit geböärt meystentyds as jy een olde verwysing nÃ¥ et verskil tüsken twey versys van een syde volgen of as jy een versy upvrÃ¥gen dee vordsmeaten is.\n\nAs dat neet so is, dan heb jy meskeen een faut in de programmatuur evünden.\nMeld et dan by een [[Special:ListUsers/sysop|systeembeheyrder]], en vermeld et webadres derby.", + "missingarticle-rev": "(versynummer: $1)", + "missingarticle-diff": "(Wysiging: $1, $2)", + "readonly_lag": "De databanke is automatisk vergrendeld terwyl de undergeskikede servers sik synchroniseren künnet mid de centrale server.", + "internalerror": "Interne faut", + "internalerror_info": "Interne faut: $1", + "filecopyerror": "Kun bestand \"$1\" neet nÃ¥ \"$2\" kopieren.", + "filerenameerror": "\"$1\" kun neet hernöömd wörden nÃ¥ \"$2\".", + "filedeleteerror": "Bestand \"$1\" kun neet vordsmeaten wörden.", + "directorycreateerror": "De map \"$1\" kun neet anmaked wörden.", + "directoryreadonlyerror": "De map \"$1\" is allinnig-leasen.", + "directorynotreadableerror": "De map \"$1\" kan neet leasen wörden.", + "filenotfound": "Bestand \"$1\" kun neet vünden wörden.", + "unexpected": "Unverwachtede waerde: \"$1\"=\"$2\".", + "formerror": "Faut: kun formulier neet verstüren", + "badarticleerror": "Disse handeling kan up disse syde neet uutvoord wörden.", + "cannotdelete": "De syde of et bestand \"$1\" kun neet vordsmeaten wörden.\nEt kan weasen dat een ander et al vordsmeaten hevt.", + "cannotdelete-title": "Syde \"$1\" kan neet vordsmeaten wörden", + "delete-hook-aborted": "Et vordsmyten wördt in et wyre skopped döär een topassing van MediaWiki.\nDer is wyder geen informaty beskikbÃ¥r.", + "no-null-revision": "Kun geen leadige nye versy maken vöär de syde \"$1\"", + "badtitle": "Ungeldige name", + "badtitletext": "De name van de upvrÃ¥gde syde is neet geldig, leadig, of der stünd een verkeyrde intersprÃ¥k- of interwikiverwysing in.\nMöägelik binnet der eyn of meyr teykens bruked dee neet in titels tostÃ¥n binnet.", + "perfcached": "Disse gegeavens kummen uut et tüskengehöägen en binnet meskeen neet aktueel. Der {{PLURAL:$1|is houguut eyn resultaat|binnet houguut $1 resultaten}} beskikbÃ¥r in et tüskengehöägen.", + "perfcachedts": "Disse gegeavens kummen uut et tüskengehöägen dee vöär et lätst bywarked is up $2 üm $3. Der {{PLURAL:$4|is houguut eyn resultaat|binnet houguut $4 resultaten}} beskikbÃ¥r in et tüskengehöägen.", + "querypage-no-updates": "Disse syde wördt neet bywarked.\nGegeavens up disse syde wördet neet vervarsd.", "viewsource": "Brontekst bekyken", - "viewsource-title": "Bron bekieken van $1", - "actionthrottled": "Haandeling tegenehöllen", - "actionthrottledtext": "As maotregel tegen t plaotsen van alderhaande moek, is t antal keren da'j disse haandeling in n korte tied uutvoeren kunnen beteund. Je hebben de limiet overschrejen. Probeer t over n antal minuten weer.", - "protectedpagetext": "Disse zied is beveiligd. Bewarken of aandere haandelingen bin niet meugelik.", - "viewsourcetext": "Je kunnen de brontekste van disse zied bewarken en bekieken.", - "viewyourtext": "Je kunnen <strong>joew bewarkingen</strong> an de brontekste van disse zied bekieken en kopiëren.", - "protectedinterface": "Op disse zied steet tekste die gebruukt wördt veur systeemteksten van disse wiki. Allinnig beheerders kunnen disse zied bewarken.\nUm vertalingen veur alle wiki's derbie te zetten of te wiezigen, gebruuk [https://translatewiki.net/ translatewiki.net], t vertaalprojekt veur MediaWiki.", - "editinginterface": "<strong>Waorschuwing:</strong> je bewarken n zied die gebruukt wördt deur de programmatuur. \nWa'j disse zied wiezigen is van invleud op t gebrukersuterlik veur aander gebrukers van disse wiki.", - "translateinterface": "Um vertalingen veur alle wiki's te doon of te wiezigen ku'j gebruukmaken van [https://translatewiki.net/ translatewiki.net], t vertaalprojekt veur MediaWiki.", - "cascadeprotected": "Disse zied is beveiligd umdat t veurkömp in de volgende {{PLURAL:$1|zied|ziejen}}, die beveiligd {{PLURAL:$1|is|bin}} mit de \"kaskade\"-opsie:\n$2", - "namespaceprotected": "Je maggen gien ziejen in de '''$1'''-naamruumte bewarken.", - "customcssprotected": "Je kunnen disse CSS-zied niet bewarken, umdat der persoonlike instellingen van n aandere gebruker in staon.", - "customjsprotected": "Je kunnen disse JavaScript-zied niet bewarken, umdat der persoonlike instellingen van n aandere gebruker in staon.", - "mycustomcssprotected": "Je hebben gien toestemming um disse CSS-zied te bewarken.", - "mycustomjsprotected": "Je hebben gien rechten um disse JavaScript-zied te bewarken.", - "myprivateinfoprotected": "Je hebben gien rechten um joew priveegegevens an te passen.", - "mypreferencesprotected": "Je hebben gien rechten um joew veurkeuren an te passen.", - "ns-specialprotected": "Spesiale ziejen kunnen niet bewarkt wörden.", - "titleprotected": "t Anmaken van disse zied is beveiligd deur [[User:$1|$1]].\nDe op-egeven reden is <em>$2</em>.", - "filereadonlyerror": "Kon t bestaand \"$1\" niet anpassen umdat de bestaandsmap \"$2\" op dit moment op allinnig-lezen steet.\n\nDe op-egeven reden is: \"$3\".", + "viewsource-title": "Bron bekyken van $1", + "actionthrottled": "Handeling teagenholden", + "actionthrottledtext": "As mÃ¥tregel teagen misbruuk, is et antal keyren dat jy disse handeling in een korte tyd uutvoren künnet betöänd. Jy hebbet de limit oaverskreaden. Probeer et oaver een antal minuten weader.", + "protectedpagetext": "Disse syde is beveiligd. Bewarken of andere handelingen binnet neet möägelik.", + "viewsourcetext": "Jy künnet de brontekst van disse syde bewarken en bekyken.", + "viewyourtext": "Jy künnet <strong>juw bewarkingen</strong> an de brontekst van disse syde bekyken en kopieren.", + "protectedinterface": "Up disse syde steyt tekst dee bruked wördt vöär systeemteksten van disse wiki, en is beveiligd üm misbruuk te vöärkommen. Bruuk [https://translatewiki.net/ translatewiki.net], et lokaliseringsprojekt vöär MediaWiki, üm oaversetingen vöär alle wikis to te vogen of te wysigen.", + "editinginterface": "<strong>WÃ¥rsküwing:</strong> jy bewarket een syde dee teksten bruukt vöär de brukersümgeaving van de programmatuur. \nWat jy up disse syde wysigen is van invlööd up de brukersümgeaving van andere brukers van disse wiki.", + "translateinterface": "Üm oaversettingen vöär alle wikis to te vogen of te wysigen, kün jy [https://translatewiki.net/ translatewiki.net] bruken, et lokaliseringsprojekt vöär MediaWiki.", + "cascadeprotected": "Disse syde is beveiligd ümdat et vöärkümt in de volgende {{PLURAL:$1|syde|syden}}, dee beveiligd {{PLURAL:$1|is|binnet}} mid de \"kaskade\"-opty:\n$2", + "namespaceprotected": "Jy möäget geen syden in de <strong>$1</strong>-naamruumde bewarken.", + "customcssprotected": "Jy möäget disse CSS-syde neet bewarken, ümdat der persoonlike instellingen van een andere bruker in stÃ¥n.", + "customjsprotected": "Jy möäget disse JavaScript-syde neet bewarken, ümdat der persoonlike instellingen van een andere bruker in stÃ¥n.", + "mycustomcssprotected": "Jy hebbet geen rechten üm disse CSS-syde te bewarken.", + "mycustomjsprotected": "Jy hebbet geen rechten üm disse JavaScript-syde te bewarken.", + "myprivateinfoprotected": "Jy hebbet geen rechten üm juw priveegegeavens te bewarken.", + "mypreferencesprotected": "Jy hebbet geen rechten üm juw vöärköären an te passen.", + "ns-specialprotected": "Speciale syden künnet neet bewarked wörden.", + "titleprotected": "Et anmaken van disse syde is beveiligd döär [[User:$1|$1]].\nDe upgeaven readen is <em>$2</em>.", + "filereadonlyerror": "Kun et bestand \"$1\" neet anpassen ümdat de bestandsmap \"$2\" up dit moment up allinnig-leasen steyt.\n\nDe upgeaven readen is: \"$3\".", "invalidtitle-knownnamespace": "Ongeldige titel mit naamruumte \"$2\" en tekste \"$3\"", "invalidtitle-unknownnamespace": "Ongeldige titel mit onbekend naamruumtenummer $1 en tekste \"$2\"", - "exception-nologin": "Neet an-emelded", + "exception-nologin": "Neet anmelded", "exception-nologin-text": "Um disse zied te bekieken of disse haandeling uut te kunnen voeren mu'j [[Special:Userlogin|an-emeld]] ween bie disse wiki.", "virus-badscanner": "Slichte konfigurasie: onbekend antivirusprogramma: ''$1''", "virus-scanfailed": "inlezen is mislokt (kode $1)", @@ -359,20 +359,20 @@ "logouttext": "'''Je bin noen aofemeld.'''\n\nt Kan ween dat der wat ziejen bin die weeregeven wörden as of je an-emeld bin totda'j t tussengeheugen van joew webkieker leegmaken.", "welcomeuser": "Welkom, $1!", "welcomecreation-msg": "Joew gebruker is an-emaakt.\nVergeet niet joew [[Special:Preferences|veurkeuren veur {{SITENAME}}]] an te passen.", - "yourname": "Gebrukersname", - "userlogin-yourname": "Gebrukersname", - "userlogin-yourname-ph": "Geef joew gebrukersnaam op", - "createacct-another-username-ph": "Vul de gebrukersnaam in", + "yourname": "Brukersname", + "userlogin-yourname": "Brukersname", + "userlogin-yourname-ph": "Geav juw brukersname up", + "createacct-another-username-ph": "Geav de brukersname up", "yourpassword": "Wachtwoord", "userlogin-yourpassword": "Wachtwoord", - "userlogin-yourpassword-ph": "Geef joew wachtwoord op", - "createacct-yourpassword-ph": "Geef n wachtwoord op", - "yourpasswordagain": "Opniej invoeren", - "createacct-yourpasswordagain": "Wachtwoord bevestigen", - "createacct-yourpasswordagain-ph": "Geef t wachtwoord opniej op", + "userlogin-yourpassword-ph": "Geav juw wachtwoord up", + "createacct-yourpassword-ph": "Geav een wachtwoord up", + "yourpasswordagain": "Wachtwoord upny invoren", + "createacct-yourpasswordagain": "Bevästig wachtwoord", + "createacct-yourpasswordagain-ph": "Geav et wachtwoord upny up", "userlogin-remembermypassword": "Vanselv anmelden", - "userlogin-signwithsecure": "Beveiligde verbiending gebruken", - "yourdomainname": "Joew domein", + "userlogin-signwithsecure": "Beveiligde verbinding bruken", + "yourdomainname": "Juw domein", "password-change-forbidden": "Je kunnen joew wachtwoord niet wiezigen op disse wiki.", "externaldberror": "Der gung iets fout bie de externe authentisering, of je maggen je gebrukersprofiel niet bewarken.", "login": "Anmelden", @@ -501,24 +501,6 @@ "resettokens-watchlist-token": "Token veur webvoer (Atom/RSS) van [[Special:Watchlist|wiezigingen van ziejen die joew volglieste staon]]", "resettokens-done": "Tokens ongedaonmaken.", "resettokens-resetbutton": "Ekeuzen tokens ongedaonmaken", - "bold_sample": "Vet-edrokten tekste", - "bold_tip": "Vet-edrokten tekste", - "italic_sample": "Schunedrokken tekste", - "italic_tip": "Schunedrok", - "link_sample": "Onderwarp", - "link_tip": "Interne verwiezing", - "extlink_sample": "http://www.example.com verwiezingstekste", - "extlink_tip": "Uutgaonde verwiezing", - "headline_sample": "Deelonderwarp", - "headline_tip": "Deelonderwarp", - "nowiki_sample": "Tekste zonder wiki-opmaak.", - "nowiki_tip": "Gien wiki-opmaak toepassen", - "image_sample": "Veurbeeld.jpg", - "image_tip": "Mediabestaand", - "media_sample": "Veurbeeld.ogg", - "media_tip": "Verwiezing naor bestaand", - "sig_tip": "Joew ondertekening (mit daotum en tied)", - "hr_tip": "Horizontale liende", "summary": "Samenvatting:", "subject": "Onderwarp:", "minoredit": "kleine wysiging", @@ -534,10 +516,10 @@ "anoneditwarning": "<strong>Waorschuwing:</strong> je bin niet an-emeld.\nJoew IP-adres zal op-esleugen wörden a'j wiezigingen op disse zied anbrengen. A'j je eigen <strong>[$1 anmelden]</strong> of <strong>[$2 inschrieven]</strong> dan koemen joew bewarkingen onder joew gebrukersnaam te staon, samen mit aandere veurdelen.", "anonpreviewwarning": "''Je bin niet an-emeld.''\n''Deur de bewarking op te slaon wörden joew IP-adres op-esleugen in de ziedgeschiedenisse.''", "missingsummary": "'''Herinnering:''' je hebben gien samenvatting op-egeven veur de bewarking. A'j noen weer op ''Opslaon'' klikken wörden de bewarking zonder samenvatting op-esleugen.", - "missingcommenttext": "Plaots joew opmarking hieronder.", + "missingcommenttext": "Skryv een upmarking.", "missingcommentheader": "<strong>Waorschuwing:</strong> je hebben der gien onderwarptitel bie ezet. A'j noen weer op \"$1\" klikken, dan wörden de bewarking op-esleugen zonder onderwarptitel.", - "summary-preview": "Samenvatting naokieken:", - "subject-preview": "Onderwarp naokieken:", + "summary-preview": "Samenvatting nÃ¥kyken:", + "subject-preview": "Underwarp nÃ¥kyken:", "blockedtitle": "Gebruker is eblokkeerd", "blockedtext": "<strong>Juw brukersname of IP-adres is blokkeerd.</strong>\n\nJy binnet blokkeerd döär $1.\nDe upgeaven readen is <em>$2</em>.\n\n* Blokkeerd vanaf: $8\n* Blokkeerd tot: $6\n* Bedoold üm te blokkeren: $7\n\nJy künnet kontakt upneamen mid $1 of een andere [[{{MediaWiki:Grouppage-sysop}}|beheyrder]] üm de blokkering te beprÃ¥ten.\nJy künnet de funkty \"{{int:emailuser}}\" neet bruken, behalven as jy een geldig e-postadres in juw [[Special:Preferences|instellingen]] upgeaven hebbet en et gebruuk van disse funkty neet blokkeerd is.\nEt IP-adres wat jy nu bruket is $3, en et blokkeringsnummer is #$5.\nVermeld de gegeavens dee hyrboaven stÃ¥n as jy argens up disse blokkering reageren.", "autoblockedtext": "Joew IP-adres is automaties eblokkeerd umdat t gebruukt wördt deur n aandere gebruker, die eblokkeerd wördt deur $1.\nDe reden hierveur was:\n\n:''$2''\n\n* Begint: $8\n* Löp of nao: $6\n* Wee eblokkeerd wördt: $7\n\nJe kunnen kontakt opnemen mit $1 of n van de aandere\n[[{{MediaWiki:Grouppage-sysop}}|beheerders]] um de blokkering te bepraoten.\n\nNB: je kunnen de opsie \"n bericht sturen\" niet gebruken, behalven a'j n geldig netpostadres op-egeven hebben in de [[Special:Preferences|gebrukersveurkeuren]] en je niet eblokkeerd bin.\n\nJoew IP-adres is $3 en joew blokkeernummer is $5.\nGeef disse nummers deur a'j kontakt mit ene opnemen over de blokkering.", @@ -570,8 +552,8 @@ "userinvalidconfigtitle": "'''Waorschuwing:''' der is gien uutvoering mit de naam \"$1\". Vergeet niet dat joew eigen .css- en .js-ziejen beginnen mit n kleine letter, bv. \"{{ns:user}}:Naam/'''v'''ector\" in plaotse van \"{{ns:user}}:Naam/'''V'''ector.css\".", "updated": "(Bewark)", "note": "'''Opmarking:'''", - "previewnote": "'''Waort je: dit is n naokiekzied.'''\nJoew tekste is niet op-esleugen!", - "continue-editing": "Gao naor t bewarkingsvienster", + "previewnote": "<strong>Denk derüm dat dit allinnig een nÃ¥kyksyde is.</strong>\nJuw wysigingen binnet noch neet seakerd!", + "continue-editing": "GÃ¥ nÃ¥ et bewarkingsveld", "previewconflict": "Disse versie löt zien hoe de tekste in t bovenste veld deruut kömp te zien a'j de tekste opslaon.", "session_fail_preview": "'''De bewarking kan niet verwarkt wörden wegens n verlies an data.'''\nProbeer t laoter weer.\nAs t probleem dan nog steeds veurkömp, probeer dan [[Special:UserLogout|opniej an te melden]].", "session_fail_preview_html": "'''De bewarking kan niet verwarkt wörden wegens n verlies an data.'''\n\n''Umdat in {{SITENAME}} roewe HTML in-eschakeld is, is de weergave dervan verbörgen um te veurkoemen dat t JavaScript an-evöllen wörden.''\n\n'''As dit n legitieme wieziging is, probeer t dan opniej.'''\nAs t dan nog problemen gif, probeer dan um [[Special:UserLogout|opniej an te melden]].", @@ -671,7 +653,7 @@ "histfirst": "Eerste", "histlast": "Leste", "historysize": "({{PLURAL:$1|1 byte|$1 bytes}})", - "historyempty": "(leeg)", + "historyempty": "leadig", "history-feed-title": "Wiezigingsoverzichte", "history-feed-description": "Wiezigingsoverzichte veur disse zied op de wiki", "history-feed-item-nocomment": "$1 op $2", @@ -803,7 +785,7 @@ "search-section": "(onderwarp $1)", "search-file-match": "(kümt oavereyne mid de inhold van et bestand)", "search-suggest": "Bedoelden je: $1", - "search-interwiki-caption": "Zusterprojekten", + "search-interwiki-caption": "Resultaten van süsterprojekten", "search-interwiki-default": "Resultaoten van $1:", "search-interwiki-more": "(meer)", "search-relatedarticle": "Verwaant", @@ -1087,22 +1069,22 @@ "recentchanges-legend-newpage": "{{int:recentchanges-label-newpage}}<br />(see ouk de [[Special:NewPages|lyste mid nye syden]])", "recentchanges-submit": "Bekiek", "rcfilters-legend-heading": "<strong>Lyste mid afkortingen:</strong>", - "rcfilters-group-results-by-page": "Resultaoten per zied groeperen", + "rcfilters-group-results-by-page": "Resultaten per syde grupperen", "rcfilters-activefilters": "Aktive filters", "rcfilters-activefilters-hide": "Verbarg", "rcfilters-activefilters-show": "Bekiek", "rcfilters-activefilters-hide-tooltip": "Verbarg aktive filters", "rcfilters-activefilters-show-tooltip": "Laot aktive filters seen", - "rcfilters-limit-title": "ResultÃ¥ten üm te lÃ¥ten seen", + "rcfilters-limit-title": "Resultaten üm te lÃ¥ten seen", "rcfilters-limit-and-date-label": "$1 {{PLURAL:$1|wysiging|wysigingen}}, $2", "rcfilters-date-popup-title": "Tydsperiode üm te döärsöken", "rcfilters-days-title": "De vöärbye dagen", "rcfilters-hours-title": "De lätste uren", "rcfilters-days-show-days": "$1 {{PLURAL:$1|dag|dagen}}", "rcfilters-days-show-hours": "$1 {{PLURAL:$1|uur|uren}}", - "rcfilters-quickfilters": "Upeslöägen filters", + "rcfilters-quickfilters": "Seakerde filters", "rcfilters-quickfilters-placeholder-title": "Noch geen filters up-eslöägen", - "rcfilters-quickfilters-placeholder-description": "Üm juuw filterinstellingen up te slÃ¥n en et lÃ¥ter te gebruken, klik up et bladwyserikoon underan by \"Aktive filters\".", + "rcfilters-quickfilters-placeholder-description": "Üm juw filterinstellingen te seakeren en et later te herbruken, klik up et bladwyserpiktogram underan by \"Aktive filters\".", "rcfilters-savedqueries-apply-label": "Instellingen opslaon", "rcfilters-savedqueries-cancel-label": "Aofbreken", "rcfilters-savedqueries-add-new-title": "Filterinstellingen seakeren", @@ -1111,7 +1093,7 @@ "rcfilters-show-new-changes": "LÃ¥t nyste wysigingen seen", "rcfilters-search-placeholder": "Filter wysigingen (bruuk et menü of söök up filtername)", "rcfilters-filterlist-feedbacklink": "LÃ¥t uns weaten wat jy van disse (nye) filterhülpmiddels vinden", - "rcfilters-highlightbutton-title": "ResultÃ¥ten markeren", + "rcfilters-highlightbutton-title": "Resultaten markeren", "rcfilters-highlightmenu-title": "Kies n kleur", "rcfilters-filtergroup-user-experience-level": "Gebrukersanmelding en ervÃ¥ring", "rcfilters-filter-user-experience-level-registered-label": "An-emeld", @@ -1147,7 +1129,7 @@ "rcfilters-filter-newpages-description": "Bewarkingen wÃ¥rmead jy een nye syde anmaket.", "rcfilters-filter-categorization-label": "Kategorywysigingen", "rcfilters-filter-categorization-description": "Upgave van syden dee to-evoogd of vordedÃ¥n wörden uut kategoryen.", - "rcfilters-filter-logactions-label": "Eregistreerde aktys", + "rcfilters-filter-logactions-label": "Registreerde aktys", "rcfilters-filter-logactions-description": "Administrative handelingen, nye kontos, vordedÃ¥ne syden, upladingen…", "rcfilters-filtergroup-lastrevision": "Lätste versys", "rcfilters-filter-lastrevision-label": "Lätste versy", @@ -1155,8 +1137,8 @@ "rcfilters-filter-previousrevision-label": "Neet de lätste versy", "rcfilters-filter-previousrevision-description": "Alle wysigingen dee neet de \"lätste versy\" binnen.", "rcfilters-view-tags": "Emarkeerde wysigingen", - "rcfilters-view-namespaces-tooltip": "Filter resultÃ¥ten up naamruumte", - "rcfilters-view-tags-tooltip": "Filter resultÃ¥ten döär gebrüük te maken van bewarkingsetiketten", + "rcfilters-view-namespaces-tooltip": "Filter resultaten up naamruumde", + "rcfilters-view-tags-tooltip": "Filter resultaten döär bewarkingsetiketten te bruken", "rcfilters-liveupdates-button": "Rechtstreakse aktualisering", "rcfilters-liveupdates-button-title-off": "Nye wysigingen voorddalik lÃ¥ten seen", "rcnotefrom": "Wysigingen sinds <strong>$3, $4</strong> (maximaal <strong>$1</strong> {{PLURAL:$1|wysiging|wysigingen}}).", @@ -2531,7 +2513,7 @@ "compare-invalid-title": "De titel die'j op-egeven hebben, is ongeldig.", "compare-title-not-exists": "De titel die'j op-egeven hebben, besteet niet.", "compare-revision-not-exists": "De versie die'j op-egeven hebben, besteet niet.", - "diff-form": "een '''formelier'''", + "diff-form": "Wysigingen", "dberr-problems": "t Spiet ons, mer disse webstee hef op t moment wat techniese problemen.", "dberr-again": "Wach n paor minuten en probeer t daornao opniej.", "dberr-info": "(Kan gien verbiending maken mit de databankeserver: $1)", @@ -2570,10 +2552,10 @@ "revdelete-unrestricted": "hef beparkingen veur beheerders deraof ehaold", "logentry-block-block": "$1 {{GENDER:$2|hef}} {{GENDER:$4|$3}} eblokkeerd veur de duur van $5 $6", "logentry-suppress-block": "$1 {{GENDER:$2|hef}} {{GENDER:$4|$3}} eblokkeerd veur de duur van $5 $6", - "logentry-move-move": "$1 hevt de syde $3 {{GENDER:$2|hernöömd}} nÃ¥r $4", - "logentry-move-move-noredirect": "$1 hevt de syde $3 {{GENDER:$2|hernöömd}} nÃ¥r $4 sunder een döärverwysing achter te lÃ¥ten", - "logentry-move-move_redir": "$1 hevt de syde $3 {{GENDER:$2|hernöömd}} nÃ¥r $4 oaver een döärverwysing hear", - "logentry-move-move_redir-noredirect": "$1 hevt de syde $3 {{GENDER:$2|hernöömd}} nÃ¥r $4 oaver een döärverwysing hear sunder een döärverwysing achter te lÃ¥ten", + "logentry-move-move": "$1 hevt de syde $3 {{GENDER:$2|hernöömd}} nÃ¥ $4", + "logentry-move-move-noredirect": "$1 hevt de syde $3 {{GENDER:$2|hernöömd}} nÃ¥ $4 sunder een döärverwysing achter te lÃ¥ten", + "logentry-move-move_redir": "$1 hevt de syde $3 {{GENDER:$2|hernöömd}} nÃ¥ $4 oaver een döärverwysing hinne", + "logentry-move-move_redir-noredirect": "$1 hevt de syde $3 {{GENDER:$2|hernöömd}} nÃ¥ $4 oaver een döärverwysing hinne sunder een döärverwysing achter te lÃ¥ten", "logentry-patrol-patrol": "$1 hef versie $4 van de zied $3 op {{GENDER:$2|nao-ekeken}} ezet", "logentry-patrol-patrol-auto": "$1 hef versie $4 van de zied $3 automaties op {{GENDER:$2|nao-ekeken}} ezet", "logentry-newusers-newusers": "Gebruker $1 is {{GENDER:$2|an-emaakt}}", @@ -2634,7 +2616,7 @@ "expandtemplates": "Mallen substitueren", "expand_templates_intro": "Disse spesiale zied leest de op-egeven tekste en substitueert rekursief alle mallen in de tekste. Oek ondersteunde parserfunksies zo as <code><nowiki>{{</nowiki>#language:…}}</code> en variabels zo as <nowiki>{{</nowiki>CURRENTDAY}}&mdash. Zwat alle teksten tussen dubbelde krulhaken wörden esubstitueerd.", "expand_templates_title": "Titel, veur {{FULLPAGENAME}}, enz.:", - "expand_templates_input": "Invoertekste:", + "expand_templates_input": "Wikitekst invoren:", "expand_templates_output": "Resultaot", "expand_templates_xml_output": "XML-uutvoer", "expand_templates_ok": "Oké", @@ -2673,7 +2655,7 @@ "special-characters-title-minus": "minteken", "mw-widgets-abandonedit": "Bi'j der wisse van da'j de naokiekmodus verlaoten willen zonder eerst op te slaon?", "mw-widgets-abandonedit-discard": "Wiezigingen vortsmieten", - "mw-widgets-abandonedit-keep": "Verdan gaon mit bewarken", - "mw-widgets-abandonedit-title": "Wee'j t zeker?", + "mw-widgets-abandonedit-keep": "Vöärdan gÃ¥n mid bewarken", + "mw-widgets-abandonedit-title": "Bin jy dÃ¥r wisse van?", "randomrootpage": "Willeköärige stamsyde" } diff --git a/languages/i18n/nds.json b/languages/i18n/nds.json index 19a7c4841d..992e7e158e 100644 --- a/languages/i18n/nds.json +++ b/languages/i18n/nds.json @@ -406,24 +406,6 @@ "passwordreset-email": "E-Mail-Adress:", "changeemail": "E-Mail-Adress ännern", "changeemail-newemail": "Nee E-Mail-Adress:", - "bold_sample": "Fetten Text", - "bold_tip": "Fetten Text", - "italic_sample": "Kursiven Text", - "italic_tip": "Kursiven Text", - "link_sample": "Link-Text", - "link_tip": "Internen Link", - "extlink_sample": "http://www.example.com Link-Text", - "extlink_tip": "Externen Link (http:// is wichtig)", - "headline_sample": "Evene 2 Överschrift", - "headline_tip": "Evene 2 Överschrift", - "nowiki_sample": "Unformateerten Text hier infögen", - "nowiki_tip": "Unformateerten Text", - "image_sample": "Bispeel.jpg", - "image_tip": "Bild-Verwies", - "media_sample": "Bispeel.ogg", - "media_tip": "Mediendatei-Verwies", - "sig_tip": "Diene Signatur mit Tietstempel", - "hr_tip": "Waagrechte Lien (sporsam bruken)", "summary": "Grund för’t Ännern:", "subject": "Bedrap:", "minoredit": "Blots lütte Ännern", diff --git a/languages/i18n/ne.json b/languages/i18n/ne.json index a2e6203532..2f1492d821 100644 --- a/languages/i18n/ne.json +++ b/languages/i18n/ne.json @@ -157,9 +157,9 @@ "category-empty": "''यो श्रेणीमा हाल कुनै पृष्ठ या मिडियाहरु रहेका छैनन् ।''", "hidden-categories": "{{PLURAL:$1|लुकाइएको श्रेणी|लुकाइएका श्रेणीहरू}}", "hidden-category-category": "लुकाइएका श्रेणीहरू", - "category-subcat-count": "{{PLURAL:$2|यो श्रेणीमा निम्न उपश्रेणीहरू मात्र छन्।|यो श्रेणीको निम्न {{PLURAL:$1|उपश्रेणी|$1 उपश्रेणीहरू}}, $2 कुल मध्ये श्रेणीहरू छन् ।}}", + "category-subcat-count": "{{PLURAL:$2|यो श्रेणीमा निम्न उपश्रेणीहरू मात्र छन्।|यो श्रेणीको निम्न {{PLURAL:$1|उपश्रेणी|$1 उपश्रेणीहरू}}, $2 कुल मध्ये श्रेणीहरू छन्।}}", "category-subcat-count-limited": "यो श्रेणीमा निम्न {{PLURAL:$1|उपश्रेणी|$1 उपश्रेणीहरू}} छन् ।", - "category-article-count": "{{PLURAL:$2|यो श्रेणीमा एक मात्र पृष्ठरहेको छ।|कुल $2 मध्ये यो श्रेणीमा {{PLURAL:$1|पृष्ठ|$1 पृष्ठहरू}} रहेका छन् । }}", + "category-article-count": "{{PLURAL:$2|यो श्रेणीमा एक मात्र पृष्ठरहेको छ।|कुल $2 मध्ये यो श्रेणीमा {{PLURAL:$1|पृष्ठ|$1 पृष्ठहरू}} रहेका छन्।}}", "category-article-count-limited": "निम्न {{PLURAL:$1|पृष्ठ|$1 पृष्ठहरू}} यस श्रेणीमा रहेको ।", "category-file-count": "{{PLURAL:$2|यो श्रेणीमा निम्न फाइल मात्र छ ।|निम्न श्रेणीमा {{PLURAL:$1|फाइल|$1 फाइलहरू}} , कुल $2 मध्ये रहेको ।}}", "category-file-count-limited": "निम्न {{PLURAL:$1|फाइल|$1 फाइलहरू}} यस श्रेणीमा रहेको ।", @@ -195,7 +195,7 @@ "history": "पृष्ठको इतिहास", "history_short": "पृष्ठको इतिहास", "history_small": "इतिहास", - "updatedmarker": "मेरो अन्तिम भ्रमण पछि अद्यतन गरिएको", + "updatedmarker": "तपाईँको अन्तिम भ्रमण पछि अद्यतन गरिएको", "printableversion": "छाप्नयोग्य संस्करण", "permalink": "स्थायी लिङ्क", "print": "छाप्नुहोस्", @@ -590,24 +590,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|तपाईंको ध्यानसूचीमा रहेका पृष्ठहरूमा भएको परिवर्तनहरू]]को वेब फिड (एटम/आरयसयस) निमित्त टोकन", "resettokens-done": "टोकन पूर्वरुपमा फर्काइयो ।", "resettokens-resetbutton": "चयन गरिएको टोकनहरूलाई पुनमिलाउनुहोस्", - "bold_sample": "गाढा अक्षर", - "bold_tip": "गाढा अक्षर", - "italic_sample": "इटालिक पाठ", - "italic_tip": "इटालिक पाठ", - "link_sample": "शीर्षक लिंङ्क", - "link_tip": "आन्तरिक लिङ्क", - "extlink_sample": "http://www.उदाहरण.com लिङ्क शीर्षक", - "extlink_tip": "बाह्य लिङ्क (सम्झनुहोस् http:// prefix)", - "headline_sample": "शीर्षक अक्षर", - "headline_tip": "दोस्रो स्तर शीर्षपंक्ति", - "nowiki_sample": "प्रारुप नभएको पाठ यहाँ दिनुहोस्", - "nowiki_tip": "विकि फरम्याटिङ्लाई वास्ता नगर्ने", - "image_sample": "उदाहरण.jpg", - "image_tip": "इम्बेडेड(जडान गरिएको) फाइल", - "media_sample": "उदाहरण.ogg", - "media_tip": "फाइल लिङ्क", - "sig_tip": "तपाईंको समयछाप सहितको दस्तखत", - "hr_tip": "क्षितिजिय रेखा (कम प्रयोग गर्नुहोस्)", "summary": "सारांश:", "subject": "विषय:", "minoredit": "यो सानो सम्पादन हो", @@ -649,7 +631,7 @@ "newarticle": "(नयाँ)", "newarticletext": "तपाईंले अहिले सम्म नभएको पृष्ठको लिङ्क पहिल्याउनु भएको छ।\nयो पृष्ठ निर्माण गर्न तलको कोष्ठमा टाइप गर्नुहोस् ।(थप जानकारीको लागि [$1 help page] हेर्नुहोस् )।\nयहाँ त्यत्तिकै आइपुग्नु भएको हो भने , ब्राउजरको '''back''' बटन थिच्नुहोस् ।", "anontalkpagetext": "----''यो वार्तालाप पृष्ठ अज्ञात प्रयोगकर्ताको हो जसले अहिलेसम्म खाता बनाएकै छैन, अथवा जसले यस पृष्ठको उपयोग गर्दैन।\nयस कारण हामीले उसलाई उसको आइपी ठेगानाले चिन्न सक्छौं। \nयस्तो आइपी ठेगाना धेरै प्रयोगकर्ताहरूको साझा हुनसक्छ।\nयदि तपाईं अज्ञात प्रयोगकर्ता हुनुहुन्छ र तपाईंमाथि नचाहिँदो टिप्पणी भएको अनुभव गर्नुहुन्छ भने भविष्यमा अन्य अज्ञात प्रयोगकर्तासित अलमलिनबाट बच्न कृपया [[Special:CreateAccount|खाता खोल्नुहोस्]] अथवा [[Special:UserLogin|प्रवेश गर्नुहोस्]] ''", - "noarticletext": "यस लेखमा अहिले केहि पनि पाठ छैन ।\nतपाईंले अन्य पृष्ठमा [[Special:Search/{{PAGENAME}}|यस पृष्ठको शीर्षकको लागि खोज]] गर्न सक्नुहुन्छ ।\n<span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} पृष्ठ सम्बन्धित ढड्डामा खोज],\nवा [{{fullurl:{{FULLPAGENAME}}|action=edit}} यसै पृष्ठलाई सम्पादन गर्ने]</span>.", + "noarticletext": "यस लेखमा अहिले केहि पनि पाठ छैन।\nतपाईँले अन्य पृष्ठमा [[Special:Search/{{PAGENAME}}|यस पृष्ठको शीर्षकको लागि खोज]] गर्न सक्नुहुन्छ।\n<span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} पृष्ठ सम्बन्धित ढड्डामा खोज्ने],\nवा [{{fullurl:{{FULLPAGENAME}}|action=edit}} यसै पृष्ठलाई सम्पादन गर्ने]</span>।", "noarticletext-nopermission": "यस लेखमा अहिले कुनै पनि पाठ छैन ।\nतपाईंले अन्य पृष्ठमा [[Special:Search/{{PAGENAME}}|यस पृष्ठको शीर्षकको लागि खोज]] गर्न सक्नुहुन्छ,\nअथवा <span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|पृष्ठ={{FULLPAGENAMEE}}}} सम्बन्धित लगहरू खोज्न सक्नुहुनेछ ]</span> तर तपाईंलाई नयाँ पृष्ठ बनाउने अधिकार छैन।", "missing-revision": "\"{{FULLPAGENAME}}\" पृष्ठको अवतरण #$1 रहेको छैन।\n\nसामान्य रूपमा यसो एउटा हटाइएको पृष्ठको पुरानो लिङ्कमा क्लिक गर्दा हुन्छ।\nअधिक जानकारीको लागि तपाईं [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} हटाएको लग] हेर्न सक्नुहुन्छ।", "userpage-userdoesnotexist": "प्रयोगकर्ताको खाता \"<nowiki>$1</nowiki>\" दर्ता गरिएको छैन ।\nतपाईंले पृष्ठ निर्माण/सम्पादन गर्न चाहनु भएको भए जाँच गर्नुहोस् ।", @@ -795,7 +777,7 @@ "rev-deleted-text-view": "यस पृष्ठको संशोधन '''मेटिएकोछ'''।\nतपाईंले हेर्न सक्नुहुन्छ; [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} मेटिएको लगमा विवरण पाउन सकिन्छ]।", "rev-suppressed-text-view": "यस पृष्ठको पुनरावलोकन <strong>थिचिएको छ</strong>।\nप्रबन्धकको हैसियतले हेर्न सक्नुहुन्छ; [{{fullurl:{{#Special:Log}}/delete|पृष्ठ={{FULLPAGENAMEE}}}}को थिचिएको लगमा विवरण पाउन सकिन्छ]", "rev-deleted-no-diff": "तपाईंले यसको भिन्नता पाउन सक्नुहुन्न किनभने यस पृष्ठको पुनरावलोकन <strong>मेटाइएको छ</strong>'।\nयसको विवरण [{{fullurl:{{#Special:Log}}/delete|पृष्ठ={{FULLPAGENAMEE}}}}को मेटाइएको लगमा पाउन सक्नुहुन्छ]।", - "rev-suppressed-no-diff": "तपाईं यसको भिन्नता हेर्न सक्नुहुन्न किनभने यसको एउटा संशोधन <strong>मेटाइएको</strong>छ।", + "rev-suppressed-no-diff": "तपाईँ यसको भिन्नता हेर्न सक्नुहुन्न किनभने यसको एउटा संशोधन <strong>मेटाइएको</strong>छ।", "rev-deleted-unhide-diff": "यस पृष्ठका पुनरावलोकनहरू मध्ये एउटा भिन्नता <strong>मेटाइएकोछ</strong>।\nयसको पूर्ण विवरण [{{fullurl:{{#Special:Log}}/delete|पृष्ठ={{FULLPAGENAMEE}}}}को मेटाइएको लगमा पाउन सकिन्छ]।\nयदि चाहनु भयो भने प्रवन्धकको हैसियतले [यो भिन्नता $1] हेर्न सक्नुहुन्छ।", "rev-suppressed-unhide-diff": "यस पृष्ठको पुनरावलोकनहरू मध्ये एउटा भिन्नता <strong>थिचिएको छ</strong>।\nयसको पूर्ण विवरण [{{fullurl:{{#Special:Log}}/suppress|पृष्ठ={{FULLPAGENAMEE}}}}को थिचिएको लगमा पाउन सकिन्छ]।\nयदि चाहनु भयो भने प्रबन्धकको हैसियतमा [यो भिन्नता $1] हेर्न सक्नुहुन्छ।", "rev-deleted-diff-view": "यस भिन्नताका संशोधनहरू मध्येको एउटा चाहिं <strong>मेटियो।<strong> \nतपाईंले यस भिन्नतालाई हेर्न सक्नुहुन्छ; सबै विवरण [{{fullurl:{{#Special:Log}}/delete|पृष्ठ={{FULLPAGENAMEE}}}} मेटाइएको लग]मा पाउन सकिनेछ।", @@ -882,7 +864,7 @@ "difference-title": "\"$1\" को बिचमा भिन्नता", "difference-title-multipage": "\"$1\" तथा \"$2\" को बिचमा भिन्नता", "difference-multipage": "(पृष्ठहरूमा भिन्नता)", - "lineno": "पंक्ति $1:", + "lineno": "पङ्क्ति $1:", "compareselectedversions": "छानिएका संस्करणहरू दाँज्नुहोस्", "showhideselectedversions": "छानिएका पुनरावलोकनहरू देखाउने/लुकाउने", "editundo": "रद्द गर्ने", @@ -1249,7 +1231,7 @@ "recentchanges-label-minor": "यो साधारण सम्पादन हो", "recentchanges-label-bot": "यो सम्पादन बोटद्वारा गरिएको थियो", "recentchanges-label-unpatrolled": "यो सम्पादन अहिले सम्म गस्ती गरिएको छैन", - "recentchanges-label-plusminus": "यति बाइटहरू संख्याले पृष्ठको आकार परिवर्तन भएको छ", + "recentchanges-label-plusminus": "यति बाइट सङ्ख्याले यस पृष्ठको आकार परिवर्तन भएको छ", "recentchanges-legend-heading": "<strong>आदर्श वाक्य:</strong>", "recentchanges-legend-newpage": "{{int:recentchanges-label-newpage}} ([[Special:NewPages|नयाँ पृष्ठहरूको सूची]] यो पनि हेर्नुहोस्)", "recentchanges-legend-plusminus": "(''±१२३'')", @@ -1280,7 +1262,7 @@ "rcfilters-filter-categorization-label": "परिवर्तित श्रेणी", "rcfilters-filter-lastrevision-label": "हालको संस्करण", "rcnotefrom": "तल <strong>$2</strong> देखि (<strong>$1</strong> सम्म) {{PLURAL:$5|भएका परिवर्तनहरू देखाइएको छ|भएका परिवर्तनहरू देखाइन्छ}}।", - "rclistfrom": "$3 $2 देखिका नयाँ परिवर्तनहरू देखाउनु", + "rclistfrom": "$3 $2 देखिका नयाँ परिवर्तनहरू देखाउनुहोस्", "rcshowhideminor": "$1 सामान्य सम्पादन", "rcshowhideminor-show": "देखाउनुहोस्", "rcshowhideminor-hide": "लुकाउनुहोस्", @@ -1320,7 +1302,7 @@ "recentchangeslinked-feed": "सम्बन्धित परिवर्तनहरू", "recentchangeslinked-toolbox": "सम्बन्धित परिवर्तनहरू", "recentchangeslinked-title": "\"$1\" सँग सम्बन्धित परिवर्तन", - "recentchangeslinked-summary": "कुनै पृष्ठको वा यससँग सम्बन्धित परिवर्तन हेर्नको लागि उक्त पृष्ठको नाम हाल्नुहोस। (कुनै श्रेणीको सामाग्रीहरुको लागि {{ns:category}}: श्रेणीको नाम हल्नुहोस । [[Special:Watchlist|तपाईंको अवलोकन सूची]]का पृष्ठहरू <strong>गाढा अक्षरमा</strong> छन् ।", + "recentchangeslinked-summary": "कुनै पृष्ठको वा यससँग सम्बन्धित परिवर्तन हेर्नको लागि उक्त पृष्ठको नाम हाल्नुहोस्। (कुनै श्रेणीको सामाग्रीहरूको लागि {{ns:category}}:श्रेणीको नाम) हाल्नुहोस्। [[Special:Watchlist|तपाईँको अवलोकन सूची]]का पृष्ठहरू <strong>गाढा अक्षरमा</strong> छन्।", "recentchangeslinked-page": "पृष्ठ नाम:", "recentchangeslinked-to": "यसको सट्टा यो पृष्ठसँग जोडिएका पृष्ठहरूको परिवर्तन देखाउने", "upload": "फाइल उर्ध्वभरण", @@ -1537,9 +1519,9 @@ "filehist-filesize": "फाइल आकार", "filehist-comment": "टिप्पणी", "imagelinks": "फाइलको प्रयोगहरू", - "linkstoimage": "यस फाइलमा निम्न{{PLURAL:$1|पृष्ठ जोडिन्छ|$1 पृष्ठहरू जोडिन्छन्}}:", + "linkstoimage": "यस फाइलमा निम्न {{PLURAL:$1|पृष्ठ जोडिन्छ|$1 पृष्ठहरू जोडिन्छन्}}:", "linkstoimage-more": "$1 भन्दा अधिक {{PLURAL:$1|पृष्ठ लिङ्क|पृष्ठ लिङ्कहरू}} यस फाइलसँग जोडिएको छ। \nनिम्नलिखित सूची फाइलसँग {{PLURAL:$1|पहिलो पृष्ठ लिङ्क|पहिलो $1 पृष्ठ लिङ्कहरू}} जोडिने देखाउँछ।\n[[Special:WhatLinksHere/$2|पूर्ण सूची]] पनि उपलब्ध छ।", - "nolinkstoimage": "यो फाईलसंग लिंकभएको कुनै पृष्ठ छैन.", + "nolinkstoimage": "यो फाइलसँग कुनै पनि पृष्ठ जोडिएको छैन।", "morelinkstoimage": "यस फाइलको [[Special:WhatLinksHere/$1|थप लिंकहरू]] हेर्नुहोस् ।", "linkstoimage-redirect": "$1 (फाइल अनुप्रेषण) $2", "duplicatesoffile": "निम्नलिखित {{PLURAL:$1|फाइलको प्रतिलिपि हो|$1 फाइलहरूको प्रतिलिपि हो}} ([[Special:FileDuplicateSearch/$2|अधिक जानकारीहरू]]):", @@ -1944,7 +1926,7 @@ "rollback-success": "$1द्वारा उल्टाइएका सम्पादनहरू;\nपछिल्लो संशोधनमा $2द्वारा परिवर्तन गरि पुनः फर्काइएको।", "sessionfailure-title": "सत्र त्रुटी", "sessionfailure": "यस्तो लाग्दैछ कि तपाईंको लगइन सत्रसँग कुनै समस्या छ। सत्र अपहरणबाट बचाउन को लागि सावधानीको रूपमा तपाईंको यो क्रियाकलाप रद्द गरिएको छ। कृपया पछाडी जानुहोस र पृष्ठलाई पुनः लोड गर्नुहोस्, अनि फेरी प्रयास गर्नुहोला।", - "changecontentmodel-title-label": "पाना शीर्षक", + "changecontentmodel-title-label": "पृष्ठ शीर्षक:", "changecontentmodel-reason-label": "कारण:", "changecontentmodel-submit": "परिवर्तन गर्नुहोस्", "logentry-contentmodel-change-revertlink": "पहिलेको रुपमा फर्काउने", @@ -2011,7 +1993,7 @@ "undeletepagetext": "निम्नलिखित {{PLURAL:$1|पृष्ठ मेटिएकोछ तर पूरालेखभित्रै छ|$1 पृष्ठ मेटिएकाछन् तर पूरालेखभित्रै छन्}} र पुनर्स्थापित गर्न सकिन्छ।\nपूरालेखको समय-समयमा सफाई गर्न सकिन्छ।", "undelete-fieldset-title": "पुनरावलोकनहरू पूर्वावस्थामा ल्याउनुहोस्", "undeleteextrahelp": "यस पृष्ठको पुरै इतिहास पूर्वरुपमा फर्काउनको लागि छनोट सन्दुकहरूलाई नछानी '''''{{int:undeletebtn}}''''' मा क्लिक गर्नुहोस।\nअनुकुल पूर्वरुपमा फर्काउने कार्य गर्न छनौट चाहिएका संस्करणका सन्दुकहरूलाई छानेर '''''{{int:undeletebtn}}'''''मा क्लिक गर्नुहोस।", - "undeleterevisions": "$1 {{PLURAL:$1|संशोधन|संशोधनहरू}} संग्रहित", + "undeleterevisions": "$1 {{PLURAL:$1|संशोधन|संशोधनहरू}} मेटाइयो", "undeletehistory": "यदि कुनै पृष्टलाई पुन: स्थापन गराउनु भयो भने सम्पूर्ण संस्करणहरू इतिहासमा पुन:स्थापन हुनेछन् ।\nयदि यसै नामबाट नयाँ पृष्ठ निर्माण भैसकेको छ भने पुन: स्थापित संस्करणहरू पूर्व इतिहासको रुपमा स्थापित हुनेछन् ।", "undeleterevdel": "यदि यो माथिल्लो पृष्ठ बन्छ या फाइल संस्करणहरू आंशिक मेटिएका छन् भने मेट्ने काम रद्द गरिने छैन।\nत्यस अवस्थामा तपाईंले छनौटमा अन्तिम मेटिएको नयाँ संस्करण नलुकाउनेमा चिनो लगाउनु पर्छ ।", "undeletehistorynoadmin": "यस पृष्ठ मेटिएको छ।\nमेटिनाको कारण निम्न जानकारीहरुमा खुलाइएको छ र मेटिनु अगिका योगदानकर्ताहरुको नाम पनि \nमेटिएका पृष्ठको पूरा पाठ प्रवन्धकहरुलाई मात्र उपलब्ध हुन्छ ।", @@ -2043,10 +2025,10 @@ "undelete-show-file-submit": "हो", "namespace": "नामस्थान:", "invert": "रोजाइ उल्टाउने", - "tooltip-invert": "छानिएका नेमस्पेसहरूमा रहेका पृष्ठहरूमा गरिएका परिवर्तनहरू लुकाउन यसमा चिनो लगाउनुहोस् (र सम्बन्धित नेमस्पेस यदि छानिएका भए)", + "tooltip-invert": "छानिएका नामपदहरूमा रहेका पृष्ठहरूमा गरिएका परिवर्तनहरू लुकाउन यसमा चिनो लगाउनुहोस् (र छानिएका भए सम्बन्धित नामपद)", "tooltip-whatlinkshere-invert": "छानिएको नामस्थानको पृष्ठहरूसँग लिङ्कहरूलाई लुकाउनका लागि यस बाकसलाई चिन्हित गर्नुहोस", - "namespace_association": "सम्बन्धित नेमस्पेस", - "tooltip-namespace_association": "वार्तालाप या विषय नेमस्पेसहरुलाई सम्वन्धित नेमस्पेसको रुपमा लिनको लागि सन्दुकमा चिनो लगाउनुहोस।", + "namespace_association": "सम्बन्धित नामपद", + "tooltip-namespace_association": "वार्तालाप या विषय नामपदहरूलाई सम्बन्धित नामपदको रुपमा लिनको लागि सन्दुकमा चिनो लगाउनुहोस्।", "blanknamespace": "(मुख्य)", "contributions": "{{GENDER:$1|प्रयोगकर्ता}}का योगदानहरू", "contributions-title": "$1को प्रयोगकर्ता योगदानहरू", @@ -2060,11 +2042,11 @@ "year": "वर्ष देखि( र पहिले):", "sp-contributions-blocklog": "रोकावट लग", "sp-contributions-suppresslog": "प्रयोगकर्ताको योगदानहरू दबाइएको छ ।", - "sp-contributions-deleted": "प्रयोगकर्ताका योगदानहरू मेटाइयो", + "sp-contributions-deleted": " {{GENDER:$1|प्रयोगकर्ता}}का योगदानहरू मेटाइयो", "sp-contributions-uploads": "उर्ध्वभरणहरू", "sp-contributions-logs": "लगहरू", "sp-contributions-talk": "वार्ता", - "sp-contributions-userrights": "प्रयोगकर्ता अधिकार व्यवस्थापन", + "sp-contributions-userrights": "{{GENDER:$1|प्रयोगकर्ता}} अधिकार व्यवस्थापन", "sp-contributions-blocked-notice": "यो प्रयोगकर्तालाई अहिले रोक लगाइएको छ।\nनवीनतम रोकाइ गरेको लग प्रविष्टि सन्दर्भको निम्ति तल दिएकोछ:", "sp-contributions-blocked-notice-anon": "यो IP ठेगानालाई अहिले रोक लगाइएको छ।\nनवीनतम रोकाइ गरेको लग प्रविष्टि सन्दर्भको निम्ति तल दिएकोछ:", "sp-contributions-search": "योगदानहरू खोज्नुहोस्", @@ -2230,7 +2212,7 @@ "cant-move-to-user-page": "तपाईंलाई पृष्ठहरू प्रयोगकर्ता पृष्ठमा सार्न अनुमती छैन (प्रयोगकर्ता सहपृष्ठहरूमा बाहेक)", "cant-move-category-page": "तपाईंलाई श्रेणीको पृष्ठहरू सार्ने अनुमति छैन ।", "cant-move-to-category-page": "कुनै श्रेणी पृष्ठमा सार्नको लागी तपाईँलाई अनुमति छैन ।", - "newtitle": "नयाँ शीर्षकमा :", + "newtitle": "नयाँ शीर्षक:", "move-watch": "यो पृष्ठ निगरानीमा राख्नुहोस्", "movepagebtn": "पृष्ठ सार्नुहोस्", "pagemovedsub": "सार्ने काम सफल भयो", @@ -2253,7 +2235,7 @@ "movenosubpage": "यस पृष्ठका उप पृष्ठहरू छैनन्।", "movereason": "कारण :", "revertmove": "पूर्ववत्", - "delete_and_move_text": "== मेटाउनु आवश्यक ==\nलक्ष्य गरिएको पृष्ठ \"[[:$1]]\" पहिलादेखि छ\nके तपाईं यो त्यहाँ सार्न त्यसलाई मेट्न चाहनुहुन्छ?", + "delete_and_move_text": "लक्ष्य गरिएको पृष्ठ \"[[:$1]]\" पहिल्यै छ।\nके तपाईं यसलाई मेटाएर यस कदमको लागि बाटो खुला गर्न चाहनुहुन्छ?", "delete_and_move_confirm": "हो, पृष्ठ मेट्नुहोस्", "delete_and_move_reason": " \"[[$1]]\"बाट सार्नलाई बाटो खुलाउन मेटियो", "selfmove": "स्रोत तथा लक्ष्य गरिएको पृष्ठको शीर्षक एउटै भएकाले;\nयसैमाथि पृष्ठ सार्न मिल्दैन", @@ -2379,7 +2361,7 @@ "tooltip-pt-mycontris": "{{GENDER:|तपाईंका}} योगदानहरूको सूची", "tooltip-pt-login": "तपाईंलाई प्रवेस गर्न सुझाव दिइन्छ ; तर यो जरुरी भने छैन", "tooltip-pt-logout": "निर्गमन", - "tooltip-pt-createaccount": "तपाईंलाई खाता बनाउन र लग इन गर्न हामि प्रोत्साहित गर्छौ; तथापि, यो अनिवार्य भने छैन ।", + "tooltip-pt-createaccount": "तपाईँलाई खाता बनाउन र प्रवेश गर्न हामी प्रोत्साहित गर्छौं; तथापि, यो अनिवार्य भने छैन।", "tooltip-ca-talk": "सामग्री पृष्ठबारेमा छलफल", "tooltip-ca-edit": "यो पृष्ठ सम्पादन गर्ने", "tooltip-ca-addsection": "नयाँ खण्ड सुरु गर्नुहोस्", @@ -2413,8 +2395,8 @@ "tooltip-t-upload": "फाइल अपलोड गर्ने", "tooltip-t-specialpages": "सबै विशेष पृष्ठहरूको सूची", "tooltip-t-print": "यो पृष्ठको मुद्रण योग्य संस्करण", - "tooltip-t-permalink": "पृष्ठको यो पुनरावलोकनको लागि स्थाई लिङ्क", - "tooltip-ca-nstab-main": "सामग्री पृष्ठ हेर्नुहोस", + "tooltip-t-permalink": "पृष्ठको यो पुनरावलोकनको लागि स्थायी लिङ्क", + "tooltip-ca-nstab-main": "सामग्री पृष्ठ हेर्नुहोस्", "tooltip-ca-nstab-user": "प्रयोगकर्ता पृष्ठ हेर्नुहोस्", "tooltip-ca-nstab-media": "मिडिया पृष्ठ हेर्नुहोस्", "tooltip-ca-nstab-special": "यो विशेष पृष्ठ हो, यो सम्पादन गर्न सकिदैन", @@ -2660,7 +2642,7 @@ "autoredircomment": "पृष्ठ[[$1]]मा पठाइएको", "autosumm-new": " $1 को साथमा पृष्ठ शृजना भयो", "autosumm-newblank": "खाली पृष्ठ तयार गर्ने", - "size-bytes": "$1 बाइटहरू", + "size-bytes": "$1 {{PLURAL:$1|बाइट|बाइटहरू}}", "size-kilobytes": "$1 किलोबाइटहरू", "size-megabytes": "$1 मेगाबाइटहरू", "size-gigabytes": "$1 गिगाबाइटहरू", @@ -2679,7 +2661,7 @@ "watchlistedit-raw-done": "तपाईंको निगरानी सूची अद्यावधिक गरिएको छ।", "watchlistedit-raw-added": "{{PLURAL:$1|१ शिर्षक|$1 शिर्षकरु}} थपियो:", "watchlistedit-raw-removed": "{{PLURAL:$1|१ शिर्षक|$1 शिर्षकरु}} हटाइयो:", - "watchlistedit-clear-title": "अवलोकन सूची खाली गरियो", + "watchlistedit-clear-title": "अवलोकनसूची खाली गर्नुहोस्", "watchlistedit-clear-legend": "अवलोकन सूची खाली गर्ने", "watchlistedit-clear-explain": "तपाईंको अवलोकन सूचीबाट सम्पूर्ण शिर्षकहरू मेटाइदै", "watchlistedit-clear-titles": "शीर्षकहरू :", @@ -2813,7 +2795,7 @@ "fileduplicatesearch-result-1": "फाइल\"$1\" को दुरुस्त नक्कलहरु छैनन् ।", "fileduplicatesearch-result-n": "फाइल\"$1\" को {{PLURAL:$2|1 दुरुस्त नक्कल|$2 दुरुस्त नक्कलहरु}} छन् ।", "fileduplicatesearch-noresults": "\"$1\" नामको फाइल पाइएन।", - "specialpages": "विशेष पृष्ठ", + "specialpages": "विशेष पृष्ठहरू", "specialpages-note-top": "आदर्श वाक्य", "specialpages-note-restricted": "* साधारण विशेष पृष्ठहरू।\n* <span class=\"mw-specialpagerestricted\">निषेधित विशेष पृष्ठहरू।</span>", "specialpages-group-maintenance": "मर्मत प्रतिवेदनहरू", @@ -2848,7 +2830,7 @@ "tags-actions-header": "कार्यहरु", "tags-active-yes": "हो", "tags-active-no": "हैन", - "tags-source-extension": "एक्सटेन्सनद्वारा परिभाषित गर्ने", + "tags-source-extension": "सफ्टवेयरद्वारा परिभाषित", "tags-source-manual": "प्रयोगकर्ताहरू तथा बोटहरूबाट म्यानुअल्ली लागु गरिएको", "tags-source-none": "प्रयोगमा नरहेको", "tags-edit": "सम्पादन गर्नुहोस्", @@ -2905,7 +2887,7 @@ "tags-edit-revision-legend": "ट्यागहरू {{PLURAL:$1|यस संशोधन|सबै $1 संशोधनहरू}}सँग जोड्ने वा हटाउने।", "tags-edit-logentry-legend": "ट्यागहरू {{PLURAL:$1|यस लग प्रविष्टि|सबै $1 लग प्रविष्टिहरू}}सँग जोड्ने वा हटाउने।", "tags-edit-existing-tags": "हाल भएको ट्यागहरूः", - "tags-edit-existing-tags-none": "''कुनै पनि होइन''", + "tags-edit-existing-tags-none": "<em>कुनै पनि होइन</em>", "tags-edit-new-tags": "नयाँ ट्यागहरूः", "tags-edit-add": "यी ट्यागहरू थप्नेः", "tags-edit-remove": "यी ट्यागहरू हटाउनेः", @@ -2915,7 +2897,7 @@ "tags-edit-reason": "कारण:", "tags-edit-revision-submit": "{{PLURAL:$1|यस संस्करण|$1 संस्करणहरू}} मा परिवर्तनहरूलाई लागु गर्ने", "tags-edit-logentry-submit": "{{PLURAL:$1|यस लग प्रविष्टी|$1 लग प्रविष्टीहरू}} मा परिवर्तनहरूलाई लागु गर्ने", - "tags-edit-success": "परिवर्तनहरू सफलता पूर्वक लागु भैसक्यो", + "tags-edit-success": "परिवर्तनहरू लागु गरियो", "tags-edit-failure": "यी परिवर्तनहरू लागु गर्न सकिएनः\n$1", "tags-edit-nooldid-title": "अवैध संशोधन लक्ष्य", "tags-edit-nooldid-text": "या त तपाईंले कुनै लक्षित संशोधनको विवरण दिनुभएको छैन जहाँ यस कार्यलाई सम्पन्न गर्नु पर्नेछ, या विवरण गरिएको संशोधन छंदै छैन।", @@ -2995,7 +2977,7 @@ "logentry-rights-autopromote": "$1 को प्रयोगकर्ता समूह स्वतः $4 बाट परिवर्तन गरेर $5 {{GENDER:$2|गरिएको}} थियो", "logentry-upload-upload": "$1 ले $3 {{GENDER:$2|अपलोड गरेका छन्}}", "logentry-upload-overwrite": "$1 ले $3 को नयाँ संस्करण {{GENDER:$2|अपलोड गरेका छन्}}", - "logentry-upload-revert": "$1 ले $3 {{GENDER:$2|अपलोड गरेका छन्}}", + "logentry-upload-revert": "$1ले $3लाई पुरानो संस्करणमा {{GENDER:$2|उल्टाउनुभयो}}", "log-name-managetags": "ट्याग व्यवस्थापन लग", "log-description-managetags": "यस पृष्ठमा ती प्रवन्धन कार्यहरूको सूची छ जुन [[Special:Tags|ट्यागहरू]]सँग सम्बन्धित छ। लगमा मात्रै ती क्रियाहरूको बयान गरिएको छ जुन मानवीय रूपले कुनै प्रवन्धकद्वारा पुरा गरिएको छ। ट्यागहरूलाई विकि सफ्टवेयरद्वारा बनउनु वा हटाउन सकिनेछ जसको प्रविष्टि लगमा हुनु आवश्यक छैन।", "logentry-managetags-create": "$1 ले ट्याग $4 {{GENDER:$2|तयार गरेको छ}}", @@ -3039,7 +3021,7 @@ "api-error-emptypage": "नयाँ तयार गर्दै, खाली पृष्ठ तयार गर्न अनुमति छैन ।", "api-error-publishfailed": "आन्तरिक समस्याः अस्थायी फाइल प्रकाशन गर्न सर्भर असफर भयो ।", "api-error-stashfailed": "आन्तरिक त्रुटि: अस्थाई फाइल राख्न सर्वर असफल भयो।", - "api-error-unknown-warning": "अज्ञात चेतावनी: \"$1\"", + "api-error-unknown-warning": "अज्ञात चेतावनी:\"$1\"।", "api-error-unknownerror": "अज्ञात त्रुटि: \"$1\".", "duration-seconds": "$1 {{PLURAL:$1|सेकेण्ड|सेकेण्डहरू}}", "duration-minutes": "$1 {{PLURAL:$1|मिनेट|मिनेटहरू}}", @@ -3147,11 +3129,11 @@ "special-characters-title-emdash": "इएम ड्यास", "special-characters-title-minus": "घटाउने चिन्ह", "mw-widgets-abandonedit": "के तपाई सम्पादन सङ्ग्रह नगरीकन सम्पादनबाट बाहिरिनेमा निश्चित हुनुहुन्छ?", - "mw-widgets-abandonedit-discard": "सम्पादन रद्द गर्नु", - "mw-widgets-abandonedit-keep": "सम्पादन जारी राख्ने", - "mw-widgets-abandonedit-title": "निश्चित हुनुहुन्छ ?", + "mw-widgets-abandonedit-discard": "सम्पादनहरू रद्द गर्नुहोस्", + "mw-widgets-abandonedit-keep": "सम्पादन जारी राख्नुहोस्", + "mw-widgets-abandonedit-title": "के तपाईँ पक्का हुनुहुन्छ?", "mw-widgets-titleinput-description-new-page": "हालसम्म पृष्ठ उपलब्ध छैन्", - "mw-widgets-titleinput-description-redirect": "$1 मा जाने", + "mw-widgets-titleinput-description-redirect": "$1 मा पुनर्निर्देश", "randomrootpage": "यादृच्छिक शीर्ष पृष्ठ", "log-action-filter-all": "सबै", "log-action-filter-block-block": "रोक्ने", diff --git a/languages/i18n/nl-informal.json b/languages/i18n/nl-informal.json index e3a8817f12..d52e8f46b4 100644 --- a/languages/i18n/nl-informal.json +++ b/languages/i18n/nl-informal.json @@ -71,7 +71,6 @@ "changeemail-header": "Vul dit formulier in om je e-mailadres te wijzigen. Je moet je wachtwoord invoeren om deze wijziging te bevestigen.", "changeemail-no-info": "Je moet aangemeld zijn om rechtstreeks toegang te hebben tot deze pagina.", "changeemail-password": "Jouw wachtwoord voor {{SITENAME}}:", - "sig_tip": "Je handtekening met datum en tijd", "anoneditwarning": "'''Waarschuwing:''' je bent niet aangemeld.\nJe IP-adres wordt opgeslagen als je wijzigingen op deze pagina maakt.", "anonpreviewwarning": "''Je bent niet aangemeld.''\n''Door je bewerking op te slaan wordt je IP-adres opgeslagen in de paginageschiedenis.''", "missingsummary": "'''Let op:''' je hebt geen samenvatting opgegeven voor je bewerking.\nAls je nogmaals op ''Pagina opslaan'' klikt wordt de bewerking zonder samenvatting opgeslagen.", diff --git a/languages/i18n/nl.json b/languages/i18n/nl.json index 2ea7cdce3b..5fb8323591 100644 --- a/languages/i18n/nl.json +++ b/languages/i18n/nl.json @@ -101,7 +101,7 @@ "RadioAzureus" ] }, - "tog-underline": "Verwijzingen onderstrepen:", + "tog-underline": "Links onderstrepen:", "tog-hideminor": "Kleine bewerkingen in recente wijzigingen verbergen", "tog-hidepatrolled": "Gemarkeerde bewerkingen in recente wijzigingen verbergen", "tog-newpageshidepatrolled": "Gemarkeerde pagina's in de lijst met nieuwe pagina's verbergen", @@ -517,7 +517,7 @@ "createaccountmail": "Gebruik een tijdelijk willekeurig wachtwoord en stuur het naar het opgegeven e-mailadres", "createaccountmail-help": "Kan worden gebruikt voor het aanmaken van een account voor een andere persoon zonder het wachtwoord te vernemen.", "createacct-realname": "Echte naam (optioneel)", - "createacct-reason": "Reden", + "createacct-reason": "Reden (door iedereen te zien)", "createacct-reason-ph": "Waarom u een ander account aanmaakt", "createacct-reason-help": "Weergegeven bericht in het logbestand van aangemaakte gebruikers", "createacct-submit": "Uw account aanmaken", @@ -685,24 +685,6 @@ "resettokens-watchlist-token": "Token voor webfeed van [[Special:Watchlist|uw volglijst]] (Atom/RSS)", "resettokens-done": "De tokens zijn opnieuw ingesteld.", "resettokens-resetbutton": "Geselecteerde tokens opnieuw instellen", - "bold_sample": "Vetgedrukte tekst", - "bold_tip": "Vet", - "italic_sample": "Schuingedrukte tekst", - "italic_tip": "Schuin", - "link_sample": "Onderwerp", - "link_tip": "Interne koppeling", - "extlink_sample": "http://www.example.com koppelingstekst", - "extlink_tip": "Externe koppeling (vergeet http:// niet)", - "headline_sample": "Deelonderwerp", - "headline_tip": "Tussenkopje (hoogste niveau)", - "nowiki_sample": "Voer hier de niet op te maken tekst in", - "nowiki_tip": "Wiki-opmaak negeren", - "image_sample": "Voorbeeld.png", - "image_tip": "Mediabestand", - "media_sample": "Voorbeeld.ogg", - "media_tip": "Koppeling naar bestand", - "sig_tip": "Uw handtekening met datum en tijd", - "hr_tip": "Horizontale lijn (gebruik spaarzaam)", "summary": "Samenvatting:", "subject": "Onderwerp:", "minoredit": "Dit is een kleine bewerking", @@ -1025,8 +1007,8 @@ "diff-multi-sameuser": "({{PLURAL:$1|Een tussenliggende versie|$1 tussenliggende versies}} door dezelfde gebruiker niet weergegeven)", "diff-multi-otherusers": "({{PLURAL:$1|Een tussenliggende versie|$1 tussenliggende versies}} door {{PLURAL:$2|een andere gebruiker|$2 gebruikers}} niet weergegeven)", "diff-multi-manyusers": "($1 tussenliggende {{PLURAL:$1|versie|versies}} door meer dan $2 {{PLURAL:$2|gebruiker|gebruikers}} worden niet weergegeven)", - "diff-paragraph-moved-tonew": "Deze paragraaf is verplaatst. Klik om naar de nieuwe locatie te springen.", - "diff-paragraph-moved-toold": "Deze paragraaf is verplaatst. Klik om naar de oude locatie te springen.", + "diff-paragraph-moved-tonew": "Deze alinea is verplaatst. Klik om naar de nieuwe locatie te springen.", + "diff-paragraph-moved-toold": "Deze alinea 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 pagina's doorzoeken waarvan de titel begint met \"$1\"", @@ -1900,6 +1882,7 @@ "listfiles-userdoesnotexist": "Gebruikersaccount \"$1\" bestaat niet.", "imgfile": "bestand", "listfiles": "Bestandslijst", + "listfiles_subpage": "Geplaatst door $1", "listfiles_thumb": "Miniatuur", "listfiles_date": "Datum", "listfiles_name": "Naam", @@ -2635,6 +2618,7 @@ "ipblocklist-legend": "Een geblokkeerde gebruiker zoeken", "blocklist-userblocks": "Geblokkeerde accounts verbergen", "blocklist-tempblocks": "Tijdelijke blokkades verbergen", + "blocklist-indefblocks": "Verberg blokkades met een oneindige loopduur", "blocklist-addressblocks": "Blokkades van één IP-adres verbergen", "blocklist-type": "Soort:", "blocklist-type-opt-all": "Alle", diff --git a/languages/i18n/nn.json b/languages/i18n/nn.json index 0e33ed57b6..8dfffc4b5f 100644 --- a/languages/i18n/nn.json +++ b/languages/i18n/nn.json @@ -569,24 +569,6 @@ "changeemail-throttled": "Du har freista for mange gonger Ã¥ logga inn. Du lyt venta $1 før du kan freista pÃ¥ nytt.", "changeemail-nochange": "Ver god Ã¥ oppgje ei ny e-postadresse.", "resettokens-token-label": "$1 (noverande verdi: $2)", - "bold_sample": "Halvfeit skrift", - "bold_tip": "Halvfeit skrift", - "italic_sample": "Kursivskrift", - "italic_tip": "Kursivskrift", - "link_sample": "Lenkjetittel", - "link_tip": "Intern lenkje", - "extlink_sample": "http://www.example.com lenkjetittel", - "extlink_tip": "Ekstern lenkje (hugs http:// prefiks)", - "headline_sample": "Overskriftstekst", - "headline_tip": "2. nivÃ¥-overskrift", - "nowiki_sample": "Skriv uformatert tekst her", - "nowiki_tip": "SjÃ¥ bort frÃ¥ wikiformatering", - "image_sample": "Døme.jpg", - "image_tip": "Bilete eller lenkje til filomtale", - "media_sample": "Døme.ogg", - "media_tip": "Filpeikar", - "sig_tip": "Signaturen din med tidsstempel", - "hr_tip": "Vassrett line", "summary": "Samandrag:", "subject": "Emne:", "minoredit": "SmÃ¥plukk", diff --git a/languages/i18n/nqo.json b/languages/i18n/nqo.json index e55b7534ed..eb628a897d 100644 --- a/languages/i18n/nqo.json +++ b/languages/i18n/nqo.json @@ -504,6 +504,9 @@ "botpasswords-updated-body": "ߓߏߕ ߕߊ߬ߡߌ߲߬ߞߊ߲ ߓߏߕ ߕߐ߮ ߦߋ߫ \"$1\" {{GENDER:$2|ߟߊ߬ߓߊ߰ߙߊ߬ߟߊ}} ߦߋ߫ \"$2\" ߕߎ߲߬ ߓߘߊ߫ ߟߏ߲ߘߐߦߊ߫.", "botpasswords-deleted-title": "ߓߏߕ ߕߊ߬ߡߌ߲߬ߞߊ߲ ߓߘߊ߫ ߖߏ߬ߛߌ߬", "botpasswords-deleted-body": "ߓߏߕ ߕߊ߬ߡߌ߲߬ߞߊ߲ ߓߏߕ ߕߐ߮ ߦߋ߫ \"$1\" {{GENDER:$2|ߟߊ߬ߓߊ߰ߙߊ߬ߟߊ}} ߦߋ߫ \"$2\" ߕߎ߲߬ ߓߘߊ߫ ߖߏ߬ߛߌ߬.", + "botpasswords-no-provider": "ߓߏߕ ߕߊ߬ߡߌ߲߬ߞߊ߲ ߥߎ߬ߛߎ ߡߊߛߐߟߊ ߕߍ߫ ߊ߬ ߟߊ߫.", + "botpasswords-restriction-failed": "ߓߏߕ ߕߊ߬ߡߌ߲߬ߞߊ߲ ߟߊ߬ߞߎ߲߬ߛߌ߲߬ߠߌ߲ ߓߘߊ߫ ߜߊ߲߬ߞߎ߲߬ߠߌ߲ ߣߌ߲߬ ߢߍߓߍ߲߬.", + "botpasswords-invalid-name": "ߓߏߕ ߕߊ߬ߡߌ߲߬ߞߊ߲ ߕߍߝߘߊߟߌ (\"$1\") ߕߍ߫ ߟߊ߬ߓߊ߰ߙߊ߬ߕߐ߰ ߞߙߍߞߙߍߣߍ߲ ߠߊ߫.", "botpasswords-not-exist": "ߓߏߕ ߕߊ߬ߡߌ߲߬ߞߊ߲ ߕߐ߯ߟߊߣߍ߲߫ \"$2\" ߕߍ߫ ߟߊ߬ߓߊ߰ߙߊ߬ߟߊ \"$1\" ߓߟߏ߫", "botpasswords-needs-reset": "ߓߏߕ ߕߊ߬ߡߌ߲߬ߞߊ߲ \"$1\" ߓߏߕ ߕߐ߯ \"$2\" ߦߋ߫ {{GENDER:$1|ߟߊ߬ߓߊ߰ߙߊ߬ߟߊ}} \"$1\" ߦߋ߫ ߡߊߦߟߍ߬ߡߊ߲߫.", "botpasswords-locked": "ߌ ߕߍߣߊ߬ ߛߋߟߴߌ ߜߊ߲߬ߞߎ߲߬ ߠߊ߫ ߓߏߕ ߕߊ߬ߡߌ߲߬ߞߊ߲ ߘߌ߫ ߓߊ ߌ ߟߊ߫ ߖߊ߬ߕߋ߬ߘߊ ߛߐ߰ߣߍ߲߫ ߠߋ߫.", @@ -512,8 +515,17 @@ "resetpass-no-info": "ߌ ߦߴߌ ߜߊ߲߬ߞߎ߲߬ ߡߎߣߎ߲߬ ߞߣߊ߬ ߕߏ߫ ߞߐߜߍ ߣߌ߲߬ ߡߊߛߐ߬ߘߐ߲߬ ߠߊ߫.", "resetpass-submit-loggedin": "ߕߊ߬ߡߌ߲߬ߞߊ߲ ߡߊߝߊ߬ߟߋ߲߬", "resetpass-submit-cancel": "ߊ߬ ߘߐߛߊ߬", + "resetpass-wrong-oldpass": "ߥߊ߯ߕߌߟߊߕߊߡߌ߲߫ ߕߊߡߌ߲ߞߊ߲ ߥߟߊ߫ ߕߋ߲߭ߕߋ߲߭ ߕߊ߬ߡߌ߲߬ߞߊ߲ ߓߍ߲߬ߓߊߟߌ.\nߕߎ߬ߡߊ߬ߘߐ߫ ߌ ߣߐ߬ ߘߌ߫ ߞߍ߫ ߌ ߟߊ߫ ߕߊ߬ߡߌ߲߬ߞߊ߲ ߡߊߝߊ߬ߟߋ߲߬ ߠߊ߫ ߥߟߊ߫ ߌ ߓߘߊ߫ ߥߊ߯ߕߌߟߊߕߊߡߌ߲߫ ߕߊߡߌ߲ߞߊ߲߫ ߞߎߘߊ߫ ߡߊߞߟߌ߫.", + "resetpass-recycled": "ߖߊ߰ߣߌ߲߬ ߌ ߦߴߌ ߟߊ߫ ߕߊ߬ߡߌ߲߬ߞߊ߲ ߡߊߝߊ߬ߟߋ߲߬ ߘߏ߫ ߜߘߍ߫ ߟߊ߫ ߡߍ߲ ߣߌ߫ ߘߐ ߣߌ߲߬ ߕߍ߫ ߞߋߟߋ߲߫ ߘߌ߫.", + "resetpass-temp-emailed": "ߌ ߓߘߴߌ ߜߊ߲߬ߞߎ߲߫ ߥߊ߯ߕߌߟߊߕߊߡߌ߲߫ ߗߋߛߓߍ ߘߏߝߙߍߕߍ ߟߊ߫.\nߖߐ߲߬ߛߊ߫ ߌ ߘߌ߫ ߓߊ߲߫ ߌ ߜߊ߲߬ߞߎ߲߬ ߠߊ߫߸ ߌ ߞߊߞߊ߲߫ ߞߊ߬ ߕߊ߬ߡߌ߲߬ߞߊ߲߬ ߞߎߘߊ߫ ߟߊߘߏ߲߬:", "resetpass-temp-password": "ߕߊߡߌ߲ߞߊ߲ ߕߎ߬ߡߊ߬ߞߎ߲߬ߡߊ", + "resetpass-abort-generic": "ߕߊ߬ߡߌ߲߬ߞߊ߲ ߡߊߝߊ߬ߟߋ߲߬ߠߌ߲ ߓߘߊ߫ ߘߐߛߊ߬ ߞߐߕߊ߲ߠߌ߲ ߘߏ߫ ߓߟߏ߫.", + "resetpass-expired": "ߌ ߟߊ߫ ߕߊ߬ߡߌ߲߬ߞߊ߲ ߛߕߊ ߓߘߊ߫ ߝߊ߫. ߕߊ߬ߡߌ߲߬ߞߊ߲߬ ߞߎߘߊ߫ ߟߊߘߏ߲߬ ߖߊ߰ߣߌ߲߫ ߞߵߌ ߜߊ߲߬ߞߎ߲߫.", + "resetpass-expired-soft": "ߌ ߟߊ߫ ߕߊ߬ߡߌ߲߬ߞߊ߲ ߛߕߊ ߓߘߊ߫ ߝߊ߫ ߊ߬ ߘߏ߲߬ ߡߊ߬ߞߏ ߦߋ߫ ߡߝߊ߬ߟߋ߲߬ߠߌ߲ ߠߊ߫.ߕߊ߬ߡߌ߲߬ߞߊ߲߬ ߞߎߘߊ߫ ߛߎߥߊ߲ߘߌ߫ ߖߊ߰ߣߌ߲߬߸ ߥߟߊ߫ ߌ ߦߋ߫ ߣߌ߲߬ ߛߐ߲߬ߞߌ߲߫ \"{{int:authprovider-resetpass-skip-label}}\" ߞߵߊ߬ ߡߊߝߊ߬ߟߋ߲߬ ߞߐߝߍ߬.", + "resetpass-validity": "ߌ ߟߊ߫ ߕߊ߬ߡߌ߲߬ߞߊ߲ ߓߍ߲߬ߣߍ߲߬ ߕߍ߫: $1\n\nߕߊ߬ߡߌ߲߬ߞߊ߲߬ ߞߎߘߊ߫ ߟߊߘߏ߲߬ ߖߊ߰ߣߌ߲߫ ߞߵߌ ߜߊ߲߬ߞߎ߲߫.", + "resetpass-validity-soft": "ߌ ߟߊ߫ ߕߊ߬ߡߌ߲߬ߞߊ߲ ߓߍ߲߬ߣߍ߲߬ ߕߍ߫: $1\n\nߕߊ߬ߡߌ߲߬ߞߊ߲߬ ߞߎߘߊ߫ ߟߊߘߏ߲߬ ߛߌߣߍ߲߬ ߖߊ߰ߣߌ߲߫߸ ߥߟߊ߫ ߣߌ߲߬ ߛߐ߲߬ߞߌ߲߫ \"{{int:authprovider-resetpass-skip-label}}\" ߞߵߊ߬ ߡߊߝߊ߬ߟߋ߲߬ ߞߐߝߍ߬.", "passwordreset": "ߕߊ߬ߡߌ߲߬ߞߊ߲ ߡߊߦߟߍ߬ߡߊ߲߬", + "passwordreset-text-one": "ߖߙߎߡߎ߲ ߣߌ߲߬ ߘߝߊ߫ ߛߴߌ ߘߌ߫ ߥߊ߯ߕߌߟߊߕߊߡߌ߲߫ ߕߊߡߌ߲ߞߊ߲ ߘߏ߫ ߡߊߛߐ߬ߘߐ߲߬ ߢߎߡߍߙߋ߲ߞߏ߲ߘߏ ߟߊ߫.", "passwordreset-disabled": "ߕߊ߬ߡߌ߲߬ߞߊ߲߬ ߡߊߦߟߍ߬ߡߊ߲߬ߣߍ߲ ߓߘߊ߫ ߛߋ߲߬ߓߐ߫ ߥߞߌ ߣߌ߲߬ ߘߐ߫.", "passwordreset-username": "ߟߊ߬ߓߊ߰ߙߊ߬ߟߊ ߕߐ߮:", "passwordreset-domain": "ߡߊ߬ߘߎ߮:", @@ -541,22 +553,6 @@ "resettokens-watchlist-token": "ߓߟߐߟߐ ߓߊߟߏ߫ ߖߐߟߐ߲ߞߐ (Atom/RSS) ߞߊ߬ ߓߍ߲߬ [[Special:Watchlist|changes to pages on your watchlist]] ߡߊ߬.", "resettokens-done": "ߖߐߟߐ߲ߞߐ ߡߊߝߊ߬ߟߋ߲߬", "resettokens-resetbutton": "ߖߐߟߐ߲ߞߐ߫ ߓߊߓߌ߬ߟߊ߬ߣߍ߲ ߡߊߝߊ߬ߟߋ߲߬", - "bold_sample": "ߛߓߍߘߋ߲߫ ߞߎ߲ߓߊ", - "bold_tip": "ߛߓߍߘߋ߲߫ ߞߎ߲ߓߊ", - "italic_sample": "ߛߓߍߟߌ߫ ߡߊߖߍ߲߬ߞߍ߬ߣߍ߲", - "italic_tip": "ߛߓߍߟߌ߫ ߡߊߖߍ߲߬ߞߍ߬ߣߍ߲", - "link_sample": "ߛߘߌ߬ߜߋ߲ ߞߎ߲߬ߕߐ߮", - "link_tip": "ߞߣߐߘߐ߫ ߛߘߌߜߋ߲", - "extlink_sample": "ߛߘߌ߬ߜߋ߲ ߞߎ߲߬ߕߐ߮ http://www.example.com", - "extlink_tip": "ߞߐߞߊ߲ߠߊ ߛߘߌ߬ߜߋ߲ (ߣߌ߲߬ ߠߊߓߊ߬ߕߏ߬ http:// prefix)", - "headline_sample": "ߞߎ߲߬ߕߐ߮ ߛߓߍߟߌ", - "headline_tip": "ߞߊߓߋ ߂߲ ߞߎ߲߬ߕߐ߮", - "nowiki_sample": "ߛߓߍߟߌ߫ ߖߙߎߡߎ߲ߕߊ߲ ߠߊߘߏ߲߬ ߦߊ߲߬", - "nowiki_tip": "ߥߞߌ߫ ߛߏ߯ߙߏߟߌ ߡߊߓߌ߬ߟߊ߬", - "image_tip": "ߞߐߕߐ߮ ߘߐߘߏ߲߬ߣߍ߲", - "media_tip": "ߞߐߕߐ߮ ߛߘߌ߬ߜߋ߲", - "sig_tip": "ߌ ߟߊ߫ ߞߟߊ߬ߣߐ ߕߎ߬ߡߊ߬ߘߊ ߓߊ߬ߘߌ߬ߟߊ߲߬ߡߊ", - "hr_tip": "ߛߌ߬ߕߊ߬ߙߌ߬ ߢߊߡߌߟߏߡߊ (ߊ߬ ߕߐ߬ߝߍ߬ߦߊ߬ ߟߊߓߊ߯ߙߊ߫)", "summary": "ߟߊ߬ߘߛߏ߬ߟߌ:", "subject": "ߝߐߡߊ", "minoredit": "ߣߌ߲߬ ߦߋ߫ ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲߬ ߘߋ߬ߣߍ߲ ߘߏ߫ ߟߋ߬ ߘߌ߫", @@ -1050,6 +1046,7 @@ "grant-editpage": "ߞߐߜߍ߫ ߓߍߓߊ߮ ߡߊߦߟߍ߬ߡߊ߲߫", "grant-editprotected": "ߞߐߜߍ߫ ߟߊߞߊ߲ߘߊߣߍ߲ ߡߊߦߟߍ߬ߡߊ߲߫", "grant-highvolume": "ߢߊ߲ߞߊ߲-ߛߊ߲ߘߐߕߊ ߡߊߦߟߍߡߊ߲ ߦߴߌ ߘߐ߫", + "grant-oversight": "ߟߊ߬ߓߊ߰ߙߊ߬ߟߊ ߢߡߊߘߏ߲߰ ߊ߬ ߣߌ߫ ߞߊ߬ ߟߢߊ߬ߟߌ ߟߎ߬ ߖߏ߬ߛߌ߬.", "grant-patrol": "ߞߐߜߍ ߟߎ߬ ߓߍ߬ߙߍ߲߬ߓߍ߬ߙߍ߲߬ߠߌ߲ ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲", "grant-privateinfo": "ߘߎ߲߬ߘߎ߬ߡߊ߬ ߞߌߓߊߙߏߦߊ ߟߊߛߐ߬ߘߐ߲߬", "grant-protect": "ߞߐߜߍ ߟߎ߬ ߟߊߞߊ߲ߘߊ߫ ߊ߬ ߣߌ߫ ߞߵߊ߬ߟߎ߬ ߟߊߞߊ߲ߘߊߣߍ߲ ߓߐ߫", @@ -1084,13 +1081,16 @@ "action-writeapi": "ߛߓߍߟߌ API ߟߊߓߊ߯ߙߊ߫", "action-delete": "ߞߐߜߍ ߣߌ߲߬ ߖߏ߰ߛߌ߬", "action-deleterevision": "ߟߢߊ߬ߟߌ ߟߎ߬ ߖߏ߬ߛߌ߬", + "action-deletelogentry": "ߘߊ߲ߖߐ ߡߎ߰ߡߍ ߖߏ߬ߛߌ߬", "action-deletedhistory": "ߞߐߜߍ ߟߎ߬ ߖߏ߰ߛߌ߬ߟߌ ߘߐ߬ߝߐ ߦߋ߫", "action-deletedtext": "ߟߢߊ߬ߟߌ ߖߏ߰ߛߌ߬ߣߍ߲ ߠߎ߬ ߛߓߍߟߌ ߦߋ߫.", "action-browsearchive": "ߞߐߜߍ߬ ߖߏ߰ߛߌ߬ߣߍ߲ ߠߎ߬ ߢߌߣߌ߲߫", "action-undelete": "ߞߐߜߍ ߖߏ߰ߛߌ߬ߓߊߟߌ ߟߎ߬", + "action-suppressrevision": "ߟߢߊ߬ߟߌ߬ ߢߡߊߘߏ߲߰ߣߍ߲ ߠߎ߬ ߦߋ߫ ߊ߬ ߣߌ߫ ߞߵߊ߬ߟߎ߬ ߟߊߞߎߣߎ߲߫.", "action-suppressionlog": "ߘߎ߲߬ߘߎ߬ߡߊ߬ ߘߎ߲ߛߓߍ ߣߌ߲߬ ߦߋ߫", "action-block": "ߟߊ߬ߓߊ߰ߙߊ߬ߟߊ ߣߌ߲߬ ߓߊ߬ߟߌ߬ ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲ ߡߊ߬", "action-protect": "ߞߐߜߍ ߣߌ߲߬ ߟߊ߬ߞߊ߲߬ߘߊ߬ߟߌ߬ ߞߛߊߞߊ ߡߊߝߊ߬ߟߋ߲߬", + "action-rollback": "ߟߊ߬ߓߊ߰ߙߊ߬ߟߊ ߞߐߟߕߊ ߟߊ߫ ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲ ߟߊߞߐߛߊ߬ߦߌ߬ ߖߏߣߊߖߏߣߊ߫߹ ߡߍ߲ ߞߊ߬ ߞߐߜߍ߫ ߞߙߍߞߙߍߣߍ߲ ߡߊߦߟߍ߬ߡߊ߲߫.", "action-import": "ߞߐߜߍ ߟߎ߬ ߟߊߛߣߍ߫ ߞߊ߬ ߓߐ߫ ߥߞߌ ߕߐ߭ ߟߎ߬ ߘߐ߫", "action-importupload": "ߞߐߜߍ ߟߎ߬ ߟߊߛߣߍ߫ ߞߊ߬ ߓߐ߫ ߞߐߕߐ߯ ߟߊߦߟߍ߬ߣߍ߲ ߠߎ߬ ߘߐ߫", "action-patrol": "ߟߊ߬ߓߊ߰ߙߊ߬ߟߊ ߘߏ ߟߎ߬ ߟߊ߫ ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲ ߠߎ߬ ߣߐ߬ߣߐ߬ ߓߍ߬ߙߍ߲߬ߓߍ߬ߙߍ߲߬ߣߍ߲ ߘߌ߫", @@ -1110,6 +1110,13 @@ "action-managechangetags": "ߘߎ߲ߛߓߍ ߟߎ߬ ߛߌ߲ߘߟߌ ߣߴߊ߬ߟߎ߬ ߓߐߒߠߊߟߌ", "action-applychangetags": "ߘߎ߲ߛߓߍ ߟߎ߬ ߟߊߓߊ߯ߙߊ߫ ߌ ߟߊ߫ ߡߝߊ߬ߟߋ߲߬ߠߌ߲ ߠߎ߬ ߞߊ߲߬", "action-deletechangetags": "ߘߎ߲ߛߓߍ ߟߎ߬ ߖߏ߬ߛߌ߬ ߞߊ߬ ߓߐ߫ ߓߟߏߡߟߊ ߝߊ߲ ߞߊ߲߬", + "action-purge": "ߞߐߜߍ ߣߌ߲߬ ߛߊߣߌ߲ߧߊ߫", + "action-apihighlimits": "API ߡߊߢߌߣߌ߲ߣߍ߲ ߛߊ߲ߘߐߕߊ ߟߊߓߊ߯ߙߊ߫", + "action-bigdelete": "ߞߐߜߍ߫ ߘߝߐ߬ ߓߟߋ߬ߓߟߋ߬ߡߊ ߟߎ߬ ߖߏ߰ߛߌ߬", + "action-blockemail": "ߟߊ߬ߓߊ߰ߙߊ߬ߟߊ ߓߊ߬ߟߌ߬ ߢߎߡߍߙߋ߲ ߗߋߟߌ ߡߊ߬", + "action-editprotected": "ߞߐߜߍ ߟߎ߬ ߡߊߦߟߍ߬ߡߊ߲߫ ߡߍ߲ ߠߎ߬ ߟߊߞߊ߲ߘߊߣߍ߲߫ ߦߋ߫ \"{{int:protect-level-sysop}}\" ߓߟߏ߫.", + "action-editsemiprotected": "ߞߐߜߍ ߟߎ߬ ߡߊߦߟߍ߬ߡߊ߲߫ ߡߍ߲ ߠߎ߬ ߟߊߞߊ߲ߘߊߣߍ߲߫ ߦߋ߫ \"{{int:protect-level-autoconfirmed}}\"", + "action-editinterface": "ߟߊ߬ߓߊ߰ߙߊ߬ߟߊ ߟߊ߫ ߢߐ߲߯ߕߍߞߣߍ ߡߊߦߟߍ߬ߡߊ߲߫", "action-editusercss": "ߟߊ߬ߓߊ߰ߙߊ߬ߟߊ ߘߏ ߟߎ߬ CSS ߟߊ߬ߓߊ߰ߙߊ߬ߟߌ߬ ߞߐߕߐ߮ ߡߊߦߟߍ߬ߡߊ߲߫", "action-edituserjson": "ߟߊ߬ߓߊ߰ߙߊ߬ߟߊ ߘߏ ߟߎ߬ ߟߊ߫ JSON ߞߐߕߐ߮ ߟߎ߬ ߡߊߦߟߍ߬ߡߊ߲߫", "action-edituserjs": "ߟߊ߬ߓߊ߰ߙߊ߬ߟߊ ߘߏ ߟߎ߬ ߟߊ߫ JavaScript ߞߐߕߐ߮ ߟߎ߬ ߡߊߦߟߍ߬ߡߊ߲߫", @@ -1119,8 +1126,16 @@ "action-editmyusercss": "ߌ ߖߘߍ߬ߞߊ߬ߣߌ߲߬ CSS ߟߊ߬ߓߊ߰ߙߊ߬ߟߌ߬ ߞߐߕߐ߮ ߡߊߦߟߍ߬ߡߊ߲߫", "action-editmyuserjson": "ߌ ߖߘߍ߬ߞߊ߬ߣߌ߲߬ JSON ߞߐߕߐ߮ ߟߎ߬ ߡߊߦߟߍ߬ߡߊ߲߫", "action-editmyuserjs": "ߌ ߖߘߍ߬ߞߊ߬ߣߌ߲߬ JavaScript ߞߐߕߐ߮ ߟߎ߬ ߡߊߦߟߍ߬ߡߊ߲߫", + "action-editmyuserjsredirect": "ߌ ߖߘߍ߬ߞߊ߬ߣߌ߲߬ JavaScript ߞߐߕߐ߮ ߟߎ߬ ߡߊߦߟߍ߬ߡߊ߲߫ ߡߍ߲ ߠߎ߬ ߓߘߊ߫ ߟߊߞߎ߲߬ߛߌ߲߫.", "action-viewsuppressed": "ߟߊ߬ߓߊ߰ߙߊ߬ߟߊ ߘߏ ߟߎ߬ ߟߊ߫ ߟߢߊ߬ߟߌ߬ ߢߡߊߘߏ߲߰ߣߍ߲ ߠߎ߬ ߦߋ߫", + "action-hideuser": "ߟߊ߬ߓߊ߰ߙߊ߬ߟߊ߫ ߟߎ߫ ߓߊ߬ߟߌ߬߸ ߡߍ߲ ߠߎ߬ ߢߡߊߘߏ߲߰ߣߍ߲߬ ߦߋ߫ ߖߊ߬ߡߊ ߟߊ߫ ߦߋߟߌ ߡߊ߬.", "action-unblockself": "ߌ ߖߍ߬ߘߍ ߓߊ߬ߟߌ߬ߣߍ߲ ߓߐ߫", + "action-reupload-own": "ߌ ߖߘߍ߬ߞߊߣߌ߲ ߠߊ߫ ߞߐߕߐ߯ ߟߊߦߟߍ߬ߣߍ߲ ߠߎ߬ ߖߏ߰ߛߌ߬", + "action-nominornewtalk": "ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲߬ ߘߋ߬ߣߍ߲߬ ߞߏ ߕߍ߫ ߘߊߘߐߖߊߥߏ ߞߐߜߍ ߟߎ߬ ߘߐ߫߸ ߗߋߛߓߍ߫ ߞߎߘߊ߫ ߘߊߡߌ߬ߣߊ߬ ߞߊߟߌߦߊ߫ ߘߐ߫.", + "action-markbotedits": "ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲߬ ߟߊߞߐߛߊ߬ߦߌ߬ߣߍ߲ ߠߎ߬ ߣߐ߬ߣߐ߬ ߓߏߕ ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲߬ߣߐ ߘߌ߫.", + "action-patrolmarks": "ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲߬ ߞߎߘߊ ߟߎ߬ ߦߌ߬ߘߊ߬ ߓߍ߬ߙߍ߲߬ߓߍ߬ߙߍ߲߬ߠߌ߲߫ ߣߐ߬ߣߐ߬ߣߍ߲ ߘߌ߫", + "action-override-export-depth": "ߞߐߜߍ ߟߎ߬ ߟߊߝߏ߬ߦߌ߬߸ ߤߊߟߌ߬ ߞߐߜߍ߫ ߜߋ߲߭ߞߘߎ߬ߣߍ߲ߢߐ߲߰ߠߊ ߡߍ߲ ߠߎ߬ ߦߋ߫ ߅ ߘߎ߲߰ߧߊ ߛߊ߲ߘߐ߫.", + "action-suppressredirect": "ߟߊ߬ߞߎ߲߬ߛߌ߲߬ߠߌ߲ ߞߊߣߊ߬ ߟߊߘߊ߲߫ ߓߐߛߎ߲ ߞߐߜߍ ߟߎ߬ ߟߊ߫ ߞߐߜߍ ߟߎ߬ ߓߐ߫ ߕߎߡߊ ߟߴߊ߬ߟߎ߫ ߣߐ߭ ߘߐ߫.", "nchanges": "$1 {{PLURAL:$1|ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲|ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲ ߠߎ߬}}", "enhancedrc-since-last-visit": "$1 {{PLURAL:$1|ߞߊ߬ߦߌ߯ ߓߐߒߡߊߟߌ ߟߊߓߊ߲}}", "enhancedrc-history": "ߘߐ߬ߝߐ", @@ -1131,6 +1146,7 @@ "recentchanges-timeout": "ߢߌߣߌ߲ߣߌ߲ ߣߌ߲߬ ߕߎ߬ߡߊ ߓߘߊ߫ ߕߊ߬ߡߌ߲߬. ߌ ߞߊߞߊ߲߫ ߞߊ߬ ߢߊߢߌߣߌ߲߫ ߜߘߍ߫ ߟߊ߬ߓߍ߲߬ߢߐ߲߰ߡߊ ߞߍ߫.", "recentchanges-network": "ߞߊ߬ ߓߍ߲߬ ߛߋߒߞߏߟߦߊ ߝߎ߬ߕߎ߲߬ߕߌ ߡߊ߬߸ ߞߐߝߟߌ߫ ߛߌ߫ ߕߍ߫ ߣߊ߬ ߛߋ߫ ߟߊ߫ ߟߊߢߎ߲߫ ߠߊ߫. ߌ ߞߊߘߊ߲߫ ߞߊ߬ ߞߐߜߍ ߣߌ߲߬ ߠߊߛߎߡߦߊ߫ ߖߊ߰ߣߌ߲߫.", "recentchanges-notargetpage": "ߞߐߜߍ ߕߐ߮ ߟߊߘߏ߲߬ ߛߊ߲ߝߍ߬߸ ߦߟߍ߬ߡߊ߲ ߡߍ߲ ߦߋ߫ ߞߐߜߍ ߘߐ߫߸ ߞߵߏ߬ ߦߋ߫.", + "recentchanges-feed-description": "ߥߞߌ ߣߌ߲߬ ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲߬ ߞߐ߯ߟߕߊ ߟߎ߬ ߣߐ߬ߣߐ߬ ߓߊߟߏ ߣߌ߲߬ ߘߐ߫.", "recentchanges-label-newpage": "ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲ ߣߌ߲߬ ߓߘߊ߫ ߘߐߜߍ߫ ߞߎߘߊ ߟߊߘߊ߲߫", "recentchanges-label-minor": "ߢߟߊߞߎߘߦߊ߫ ߝߕߌߣߍ߲ ߠߋ߬", "recentchanges-label-bot": "ߡߐ߰ߡߐ߮ ߟߋ߫ ߣߐ߬ ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ ߣߌ߲߬ ߞߍ߫ ߟߊ߫", @@ -1327,6 +1343,7 @@ "illegalfilename": "ߞߟߏ ߘߏ߫ ߦߋ߫ ߞߐߕߐ߮ ߕߐ߮ \"$1\" ߘߐ߫ ߡߍ߲ ߠߊߘߤߊ߬ߣߍ߲߬ ߕߍ߫ ߞߐߜߍ ߞߎ߲߬ߕߐ߰ ߞߏ ߘߐ߫. \nߕߐ߯ ߜߘߍ߫ ߟߊ߫ ߞߐߕߐ߮ ߟߊ߫ ߖߊ߰ߣߌ߲߬ ߞߣߊ߬ ߕߴߊ߬ ߟߊߦߟߍ߬ߟߌ ߡߊߝߍߣߍ߲߫ ߠߊ߫ ߕߎ߲߯.", "filename-toolong": "ߞߐߕߐ߮ ߕߐ߮ ߡߊ߲ߞߊ߲߫ ߞߊ߬ ߕߊ߬ߡߌ߲߬ ߝߙߐ߬ߢߐ ߂߀߀ ߞߊ߲߬.", "badfilename": "ߞߐߕߐ߮ ߕߐ߮ ߓߘߊ߫ ߦߟߍ߬ߡߊ߲߫ ߞߵߊ߬ ߞߍ߫ \"$1\" ߘߌ߫", + "filetype-missing": "ߘߐ߬ߝߎ߬ߟߋ߲߬ߠߌ߲߬ߢ ߛߌ߫ߢ ߕߍ߫ ߞߐߜߍ ߣߌ߲߬ ߠߊ߫ (ߦߏ߫ \".jpg\")", "empty-file": "ߌ ߣߊ߬ ߞߐߕߐ߮ ߡߍ߲ ߞߙߊߓߊ߫ ߟߊ߫߸ ߊ߬ ߘߐߞߏߟߏ߲ ߠߋ߬ ߕߘߍ߬.", "file-too-large": "ߌ ߟߊ߫ ߞߐߕߐ߮ ߞߙߊߓߊߣߍ߲ ߓߏ߲߬ߓߊ߫ ߕߘߍ߬ ߞߏߖߎ߰߹", "filename-tooshort": "ߞߐߕߐ߮ ߕߐ߮ ߛߘߎ߬ߡߊ߲߬ ߞߏߖߎ߰.", @@ -1334,8 +1351,14 @@ "verification-error": "ߞߐߕߐ߮ ߣߌ߲߬ ߡߊ߫ ߕߊ߬ߡߌ߲߬ ߞߐߕߐ߮ ߝߛߍ߬ߝߛߍ߬ ߦߌߟߊ.", "hookaborted": "ߌ ߕߘߍ߬ ߦߋ߫ ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲ ߡߍ߲ ߞߍ߫ ߞߏ ߘߐ߫߸ ߊ߬ ߘߐߛߊ߬ߣߍ߲߬ ߦߋ߫ ߘߐ߬ߥߙߊ߬ߟߌ ߟߋ߬ ߓߟߏ߫.", "illegal-filename": "ߞߐߕߐ߮ ߕߐ߮ ߟߊߘߌ߬ߢߍ߬ߣߍ߲߬ ߕߍ߫.", + "overwrite": "ߕߋ߲߭ߕߋ߲߭ ߞߐߕߐ߮ ߖߏ߬ߛߌ߬ߟߌ ߟߊߘߌ߬ߢߍ߬ߣߍ߲߬ ߕߍ߫.", "unknown-error": "ߝߎ߬ߕߎ߲߬ߕߌ߬ ߡߊߟߐ߲ߓߊߟߌ ߘߏ߫ ߓߘߊ߫ ߓߌ߬ߟߵߊ߬ ߘߐ߫.", "tmp-create-error": "ߊ߬ ߕߍ߫ ߣߊ߬ ߥߊ߯ߕߌ߫ ߟߊߕߊߡߌ߲߫ ߞߐߕߐ߮ ߛߌ߲ߘߌ߫ ߟߊ߫.", + "tmp-write-error": "ߥߊ߯ߕߌߟߊߕߊߡߌ߲߫ ߞߐߕߐ߮ ߛߓߍߟߌ ߝߎ߬ߕߎ߲߬ߕߌ.", + "large-file": "ߊ߬ ߞߊ߬ߣߌ߲߬ߣߍ߲߬ ߦߋ߫ ߟߋ߬ ߞߏ߫ ߞߐߕߐ߮ ߞߊߣߊ߬ ߥߙߊ߬ $1 ߘߌ: ߞߐߕߐ߮ ߣߌ߲߬ ߘߏ߲߬ ߦߋ߫ $2.", + "largefileserver": "ߞߐߕߐ߮ ߓߏ߲߬ߓߊ߫ ߞߊ߬ ߕߊ߬ߡߌ߲߬ ߡߊ߬ߛߐ߬ߟߊ ߘߊߘߐߓߍ߲߬ߣߍ߲߫ ߡߍ߲ ߠߊߘߌ߬ߢߍ߬ ߞߊ߲ߡߊ߬.", + "windows-nonascii-filename": "ߥߞߌ ߣߌ߲߬ ߡߊ߫ ߛߕߍߘߋ߲߫ ߞߙߍߞߙߍߣߍ߲ ߞߐߡߊߓߌ߲ߓߌ߲߫ ߞߐߕߐ߮ ߕߐ߮ ߞߏ ߘߐ߫.", + "fileexists": "ߞߐߕߐ߮ ߡߍ߲ ߟߕߐ߬ ߦߋ߫ ߕߐ߮ ߣߌ߲߬ ߡߊ߬߸ ߏ߬ ߦߋ߫ ߦߋ߲߬ ߞߘߐ߬ߡߊ߲߫߸ ߖߊ߰ߣߌ߲߬ ߌ ߦߋ߫ <strong>[[:$1]]</strong> ߝߛߍ߬ߝߛߍ߬ ߣߌ߫ {{GENDER:|ߌ}} ߘߏ߲߬ ߟߊߣߍ߲߫ ߡߊ߫ ߞߴߊ߬ ߟߊ߫߸ ߣߴߌ ߦߴߊ߬ ߡߊߝߊ߬ߟߋ߲߬ߞߏ ߘߐ߫ [[$1|ߞߝߊ߬ߟߋ߲ߛߋ߲]]", "uploadwarning": "ߟߊ߬ߦߟߍ߬ߟߌ ߖߊ߬ߛߙߋ߬ߡߊ߬ߟߊ", "uploadwarning-text": "ߞߐߕߐ߮ ߘߎ߰ߟߊ߬ߘߐ߫ ߞߊ߲ߛߓߍߟߌ ߡߊ߬ߦߟߍ߬ߡߊ߲߫ ߖߊ߰ߣߌ߲߬߸ ߞߵߊ߬ ߡߊߝߍߣߍ߲߫ ߕߎ߲߯.", "savefile": "ߞߐߕߐ߮ ߟߊߞߎ߲߬ߘߎ߬", @@ -1394,6 +1417,7 @@ "lockmanager-notlocked": "ߊ߬ ߕߍ߫ ߣߊ߬ ߛߐ߲߬ ߠߊ߫ \"$1\" ߟߊߞߊ߬ ߟߊ߫߸ ߊ߬ ߛߐ߰ߣߍ߲߬ ߕߍ߫.", "lockmanager-fail-closelock": "ߊ߬ ߕߍ߫ ߣߊ߬ ߛߋ߫ ߟߊ߫ \"$1\" ߞߐߕߐ߮ ߛߐ߰ߣߍ߲ ߘߊߕߎ߲߯ ߠߊ߫.", "lockmanager-fail-deletelock": "ߊ߬ ߕߍ߫ ߣߊ߬ ߛߋ߫ ߟߊ߫ \"$1\" ߞߐߕߐ߯ ߛߐ߰ߣߍ߲ ߖߏ߰ߛߌ߬ ߟߊ߫.", + "lockmanager-fail-acquirelock": "ߌ ߕߍ߫ ߣߊ߬ ߛߋ߫ ߟߊ߫ ߛߐ߰ߟߌ ߛߐ߬ߘߐ߲߬ ߠߊ߫ \"$1\" ߞߊ߲߬.", "lockmanager-fail-releaselock": "ߌ ߕߍ߫ ߣߊ߬ ߛߋ߫ ߟߊ߫ ߛߐ߰ߟߌ ߓߐ߫ ߟߊ߫ \"$1\" ߞߊ߲߬.", "lockmanager-fail-db-release": "ߌ ߕߍ߫ ߣߊ߬ ߛߋ߫ ߟߊ߫ ߛߐ߰ߟߌ ߓߐ߫ ߟߊ߫ ߓߟߏߡߟߊߝߊ߲ $1 ߞߊ߲߬.", "lockmanager-fail-svr-release": "ߌ ߕߍ߫ ߣߊ߬ ߛߋ߫ ߟߊ߫ ߛߐ߰ߟߌ ߓߐ߫ ߟߊ߫ ߡߊ߬ߛߐ߬ߟߊ $1 ߞߊ߲߬.", @@ -1440,6 +1464,7 @@ "license-header": "ߟߊ߬ߘߌ߬ߢߍ߬ߟߌ ߦߴߌ ߘߐ߫", "nolicense": "ߊ߬ ߡߊ߫ ߓߊߕߐ߬ߡߐ߲߬", "licenses-edit": "ߕߌ߰ߦߊ ߢߣߊߕߊߟߌ ߡߊߦߟߍ߬ߡߊ߲߫", + "license-nopreview": "(ߟߊ߬ߕߎ߲߰ߠߊ߫ ߕߴߦߋ߲߬)", "upload_source_file": "(ߌ ߟߊ߫ ߞߐߕߐ߯ ߛߎߥߊ߲ߘߌߣߍ߲ ߠߎ߬ ߞߊ߬ ߝߘߊ߫ ߌ ߟߊ߫ ߕߟߋ߬ߓߊ߮ ߟߊ߫)", "listfiles-delete": "ߊ߬ ߖߏ߬ߛߌ߬", "listfiles-summary": "ߞߐߜߍ߫ ߓߟߏߡߊߞߊ߬ߣߍ߲ ߣߌ߲߬ ߦߴߌ ߟߊ߫ ߞߐߕߐ߯ ߟߊߦߟߍ߬ߣߍ߲ ߠߎ߬ ߓߍ߯ ߟߋ߬ ߦߌ߬ߘߊ߬ ߟߊ߫", @@ -1447,6 +1472,7 @@ "listfiles-userdoesnotexist": "ߟߊ߬ߓߊ߰ߙߊ߬ ߖߊߕߋߘߊ \"$1\" ߟߊߞߎ߲߬ߘߎ߬ߣߍ߲߫ ߕߍ߫.", "imgfile": "ߞߐߕߐ߮", "listfiles": "ߞߐߕߐ߮ ߛߙߍߘߍ", + "listfiles_subpage": "ߊ߬ ߟߊߦߟߍ߬ߣߍ߲߬ ߦߋ߫ $1 ߟߋ߬ ߓߟߏ߫", "listfiles_thumb": "ߞߝߊ߬ߟߋ߲ߛߋ߲", "listfiles_date": "ߕߎ߬ߡߊ߬ߘߊ", "listfiles_name": "ߕߐ߮", @@ -1483,9 +1509,13 @@ "sharedupload": "ߞߐߕߐ߮ ߣߌ߲߬ ߝߘߊߣߍ߲߫ ߦߋ߫ $1 ߊ߬ ߣߴߊ߬ ߘߌ߫ ߛߋ߫ ߟߊߓߊ߯ߙߊ߫ ߟߊ߫ ߖߊ߬ߕߋ߬ߘߐ߬ߛߌ߰ ߜߘߍ߫ ߟߎ߫ ߘߐ߫.", "sharedupload-desc-there": "ߞߐߕߐ߮ ߣߌ߲߬ ߝߘߊߣߍ߲߫ ߦߋ߫ $1 ߟߋ߬ ߟߊ߫߸ ߊ߬ ߣߴߊ߬ ߟߊߓߊ߯ߙߊߣߍ߲߫ ߘߌ߫ ߞߍ߫ ߖߊ߬ߕߋ߬ߘߐ߬ߛߌ߰ ߜߘߍ߫ ߟߎ߫ ߘߐ߫. ߖߊ߰ߣߌ߲߬ ߌ ߦߋ߫ [$2 ߞߐߕߐ߮ ߞߊ߲߬ߛߓߍߟߌ ߞߐߜߍ ߘߐߜߍ߫|ߞߌ߬ߓߊ߬ߙߏ߬ߦߊ߬ ߡߞߊ߬ߝߏ߬ߟߌ߬ ߞߏ ߘߐ߫]", "sharedupload-desc-here": "ߘߐ߬ߛߙߋ ߣߌ߲߬ ߦߋ߫ ߦߊ߲߬ ߠߋ߫ $1 ߖߊ߬ߕߋ߬ߘߐ߬ߛߌ߮ ߕߐ߭ ߟߎ߬ ߞߏ߬ߣߌ߲ ߘߌ߫ ߛߴߊ߬ ߟߊߓߊ߯ߙߊ߫ ߟߊ߫. ߊ߬ ߕߐ߯ ߛߓߍߟߌ ߦߙߐ [$2 ߞߐߕߐ߮ ߞߊ߲߬ߛߓߍߟߌ ߞߐߜߍ] ߟߋ߬ ߦߋ߫ ߘߎ߰ߟߊ ߘߐ߫ ߣߌ߲߬.", + "sharedupload-desc-edit": "ߞߐߕߐ߮ ߣߌ߲߬ ߝߘߊߣߍ߲߫ ߦߋ߫ $1 ߟߋ߬ ߟߊ߫߸ ߊ߬ ߘߏ߲߬ ߠߊߓߊ߯ߙߊߣߍ߲߫ ߘߌ߫ ߞߍ߫ ߖߊ߬ߕߋ߬ߘߐ߬ߛߌ߰ ߜߘߍ߫ ߟߎ߫ ߘߐ߫.\nߕߎ߬ߡߊ߬ߘߐ߫ ߌ ߘߌ߫ ߞߴߊ߬ ߝߍ߬ ߞߴߊ߬ ߞߊ߲߬ߛߓߍߟߌ ߡߊߦߟߍ߬ߡߊ߲߫ ߊ߬ [$2 ߞߐߜߍ ߞߊ߲߬ߛߓߍ߬ߟߌ߬ ߞߐߜߍ] ߘߐ߫.", + "sharedupload-desc-create": "ߞߐߕߐ߮ ߣߌ߲߬ ߝߘߊߣߍ߲߫ ߦߋ߫ $1 ߟߋ߬ ߟߊ߫߸ ߊ߬ ߘߏ߲߬ ߠߊߓߊ߯ߙߊߣߍ߲߫ ߘߌ߫ ߞߍ߫ ߖߊ߬ߕߋ߬ߘߐ߬ߛߌ߰ ߜߘߍ߫ ߟߎ߫ ߘߐ߫.\nߕߎ߬ߡߊ߬ߘߐ߫ ߌ ߘߌ߫ ߞߴߊ߬ ߝߍ߫ ߞߴߊ߬ ߞߊ߲߬ߛߓߍߟߌ ߡߊߦߟߍ߬ߡߊ߲߫ ߊ߬ [$2 ߞߐߕߐ߮ ߞߊ߲߬ߛߓߍ߬ߟߌ߬ ߞߐߜߍ] ߘߐ߫", "filepage-nofile": "ߕߐ߮ ߣߌ߲߬ ߞߐߕߐ߯ ߛߎ߯ ߕߍ߫ ߦߋ߲߬", + "filepage-nofile-link": "ߞߐߕߐ߯ ߛߌ߫ ߕߍ߫ ߕߐ߮ ߣߌ߲߬ ߠߊ߫߸ ߞߏ߬ߣߌ߲߬ ߌ ߘߌ߫ ߛߋ߫ [ߊ߬ $1 ߟߊߦߟߍ߬ ߟߊ߫]", "uploadnewversion-linktext": "ߞߐߕߐ߮ ߣߌ߲߬ ߛߎ߯ߦߊ߫ ߞߎߘߊ߫ ߟߊߦߟߍ߬", "shared-repo-from": "ߞߊ߬ ߝߘߊ߫: $1", + "shared-repo": "ߟߊ߬ߖߍ߲߬ߛߍ߲߬ߣߍ߲ ߠߎ߬ ߝߊ߲", "upload-disallowed-here": "ߌ ߕߍߣߊ߬ ߞߐߜߍ ߣߌ߲߬ ߞߊ߲߬ߛߓߍ߫ ߟߊ߫.", "filerevert": "ߌ ߞߐߛߊ߬ߦߌ߬ $1", "filerevert-legend": "ߞߐߕߐ߯ ߟߊߛߊ߬ߦߌ߲߬ߣߍ߲", @@ -1572,6 +1602,7 @@ "wantedpages": "ߞߐߜߍ߫ ߜߋ߬ߟߎ߲߬ߣߍ߲ ߠߎ߬", "wantedpages-badtitle": "ߞߎ߲߬ߕߐ߮ ߓߍ߲߬ߣߍ߲߬ ߕߍ߫ ߞߐߝߟߌ߫ ߦߌ߬ߘߊ߬ߣߍ߲: $1 ߘߐ߫", "wantedfiles": "ߞߐߜߍ߫ ߜߋ߬ߟߎ߲߬ߣߍ߲ ߠߎ߬", + "wantedfiletext-nocat-noforeign": "ߞߐߕߐ߮ ߢߌ߲߬ ߠߎ߬ ߓߘߊ߫ ߟߊߓߊ߯ߙߊ߫ ߞߏ߬ߣߵߊ߬ߟߎ߬ ߕߴߦߋ߲߬.", "wantedtemplates": "ߞߙߊߞߏ ߞߊ߬ߣߌ߲߬ߣߍ߲ ߠߎ߬", "mostlinked": "ߛߘߌ߬ߜߋ߲߬ ߦߙߌߞߊ߫ ߦߋ߫ ߞߐߜߍ ߡߍ߲ ߠߎ߬ ߘߐ߫", "mostlinkedcategories": "ߛߘߌ߬ߜߋ߲߬ ߦߙߌߞߊ߫ ߦߋ߫ ߦߌߟߡߊ ߡߍ߲ ߠߎ߬ ߘߐ߫", @@ -1590,6 +1621,7 @@ "protectedpages": "ߞߐߜߍ߫ ߟߊߞߊ߲ߘߊߣߍ߲ ߠߎ߬", "protectedpages-filters": "ߛߍ߲ߛߍ߲ߟߊ߲ ߠߎ߬:", "protectedpages-indef": "ߟߊ߬ߞߊ߲߬ߘߊ߬ߟߌ ߘߊ߲߬ߠߊߕߍ߰ߓߊߟߌ ߘߐߙߐ߲߫", + "protectedpages-summary": "ߞߐߜߍ ߛߙߍߘߍ ߢߌ߲߬ ߠߎ߬ ߦߋ߫ ߦߋ߫ ߞߐߜߍ߫ ߟߎ߫ ߟߋ߬ ߘߐ߫ ߡߍ߲ ߠߎ߬ ߟߊߞߊ߲ߘߊߣߍ߲߫ ߦߋ߫ ߕߊ߲߫. ߣߵߌ ߦߋ߫ ߞߎ߲߬ߕߐ߮ ߛߙߍߘߍ߫ ߟߎ߫ ߟߋ߬ ߞߐ߫ ߡߍ߲ ߠߎ߬ ߟߊߞߊ߲ߘߊߣߍ߲߫ ߦߋ߫ ߛߌ߲ߘߟߌ ߡߊ߬߸ ߣߌ߲߬ ߘߐߜߍ߫ [[{{#special:ProtectedTitles}}|{{int:protectedtitles}}]].", "protectedpages-noredirect": "ߟߊ߬ߞߎ߲߬ߛߌ߲߬ߠߌ߲ ߢߡߊߘߏ߲߰", "protectedpages-timestamp": "ߕߎ߬ߡߊ ߓߊ߬ߘߌ߬ߟߊ߲", "protectedpages-page": "ߞߐߜߍ", @@ -1852,6 +1884,8 @@ "protect-title": "ߟߊ߬ߞߊ߲߬ߘߊ߬ߟߌ ߞߊߓߋ ߡߊߦߟߍ߬ߡߊ߲߬ \"$1\" ߞߊ߲߬", "protect-title-notallowed": "\"$1\" ߟߊ߬ߞߊ߲߬ߘߊ߬ߟߌ ߞߊߓߋ ߦߋ߫", "prot_1movedto2": "\"[[$1]]\" ߓߘߊ߫ ߟߥߊ߫ ߦߊ߲߬ [[$2]]", + "protect-badnamespace-title": "ߕߐ߯ߛߓߍ ߞߣߍ ߟߊߞߊ߲ߘߊߓߊߟߌ", + "protect-badnamespace-text": "ߞߐߜߍ ߡߍ߲ ߠߎ߬ ߦߋ߫ ߕߐ߯ߛߓߍ ߞߣߍ ߘߐ߫ ߏ߬ ߕߍ߫ ߛߋ߫ ߟߊߞߊ߲ߘߊ߫ ߟߊ߫", "protect-legend": "ߟߊ߬ߞߊ߲߬ߘߊ߬ߟߌ ߟߊߛߙߋߦߊ߫", "protectcomment": "ߊ߬ ߛߊߓߎ:", "protectexpiry": "ߊ߬ ߛߕߊ ߓߘߊ߫ ߝߊ߫:", @@ -2483,6 +2517,8 @@ "version-hook-name": "ߛߏ߲߭ߓߊ߬ߟߌ ߕߐ߮", "version-hook-subscribedby": "ߕߐ߮ ߛߓߍߣߍ߲߫ ߦߋ߫", "version-no-ext-name": "[ߕߐ߯ ߕߴߊ߬ ߟߊ߫]", + "version-ext-license": "ߕߌ߰ߦߊ", + "version-ext-colheader-name": "ߞߐߕߊ߲ߠߌ߲", "version-skin-colheader-name": "ߝߊ߬ߘߌ", "version-ext-colheader-version": "ߦߌߟߡߊ", "version-ext-colheader-license": "ߕߌ߰ߦߊ", @@ -2535,10 +2571,70 @@ "specialpages-group-developer": "ߟߊ߬ߥߙߌ߬ߞߌ߬ߟߌ ߖߐ߯ߙߊ߲ ߠߎ߬", "blankpage": "ߞߐߜߍ߫ ߘߐߞߏߟߏ߲", "tag-filter": "[[Special:Tags|ߞߊ߲ߠߊߛߓߍ]] ߢߡߊߘߏ߲߰ߣߍ߲", + "tag-filter-submit": "ߥߊ߬ߣߊߙߌ", "tag-list-wrapper": "[[Special:Tags|{{PLURAL:$1|ߡߊ߬ߛߙߋ |ߡߊ߬ߛߙߋ ߟߎ߬ }}]]: $2", + "tag-mw-contentmodelchange": "ߞߣߐߘߐ ߛߎ߯ߦߊ ߡߊߝߊ߬ߟߋ߲߬ߠߌ߲", + "tag-mw-contentmodelchange-description": "ߣߌ߲߬ ߡߊߦߟߍ߬ߡߊ߲߫\n[https://www.mediawiki.org/wiki/Special:MyLanguage/Help:ߞߣߐߘߐߛߎ߯ߦߊߡߊߝߊ߬ߟߋ߲߬ ߞߣߐߘߐ ߛߎ߯ߦߊ ߡߊߝߊ߬ߟߋ߲߬] ߞߐߜߍ ߘߐ߫", + "tag-mw-new-redirect": "ߟߊ߬ߞߎ߲߬ߛߌ߲߬ߠߌ߲߬ ߞߎߘߊ", + "tag-mw-new-redirect-description": "ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲ ߡߍ߲ ߠߎ߬ ߞߊ߬ ߟߊ߬ߞߎ߲߬ߛߌ߲߬ߠߌ߲ ߠߊߘߊ߲߫ ߥߟߊ߫ ߞߊ߬ ߞߐߜߍ ߦߟߍ߬ߡߊ߲߫ ߞߊ߬ ߞߍ߫ ߟߊ߬ߞߎ߲߬ߛߌ߲߬ߠߌ߲ ߘߌ߫", + "tag-mw-removed-redirect": "ߟߊ߬ߞߎ߲߬ߛߌ߲߬ߠߌ߲ ߛߋ߲߬ߓߐ߫", + "tag-mw-removed-redirect-description": "ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲ ߡߍ߲ ߠߎ߬ ߞߊ߬ ߕߋ߲߭ߕߋ߲߭ ߟߊ߬ߞߎ߲߬ߛߌ߲߬ߠߌ߲ ߡߊߦߟߍ߬ߡߊ߲߫ ߞߵߊ߬ ߞߍ߫ ߟߊ߬ߞߎ߲߬ߛߌ߲߬ߓߊߟߌ ߘߌ߫", + "tag-mw-changed-redirect-target": "ߟߊ߬ߞߎ߲߬ߛߌ߲߬ߠߌ߲ ߞߏ߲߭ ߓߘߊ߫ ߡߊߝߊ߬ߟߋ߲߬", + "tag-mw-changed-redirect-target-description": "ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲ ߡߍ߲ ߠߎ߬ ߞߊ߬ ߟߊ߬ߞߎ߲߬ߛߌ߲߬ߠߌ߲ ߞߏ߲߭ ߡߊߝߊ߬ߟߋ߲߬", + "tag-mw-blank": "ߖߏ߰ߛߌ߬ߟߌ ߦߵߌ ߘߐ߫", + "tag-mw-blank-description": "ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲ ߡߍ߲ ߠߎ߬ ߞߊ߬ ߞߐߜߍ ߖߏ߰ߛߌ߬", + "tag-mw-replace": "ߊ߬ ߓߘߊ߫ ߓߐ߫ ߊ߬ ߣߐ߭ ߘߐ߫", + "tag-mw-replace-description": "ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲ ߡߍ߲ ߠߎ߬ ߞߊ߬ ߞߣߐߘߐ %߉߀ ߛߋ߲߬ߓߐ߫ ߞߐߜߍ ߘߐ߫", + "tag-mw-rollback": "ߟߊߞߐߛߊ߬ߦߌ߬", + "tag-mw-undo": "ߊ߬ ߘߐߛߊ߬", + "tag-mw-undo-description": "ߡߊߦߟߍ߬ߡߊ߲߬ߠߌ߲ ߡߍ߲ ߠߎ߬ ߞߊ߬ ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲߬ ߟߐ߯ߟߊߣߍ߲ ߠߎ߬ ߘߐߛߊ߬ ߞߊ߬ ߘߐ߬ߛߊ߬ߟߌ ߛߘߌ߬ߜߋ߲ ߠߊߓߊ߯ߙߊ߫.", + "tags-title": "ߘߎ߲ߛߓߍ ߟߎ߬", + "tags-tag": "ߘߎ߲ߛߓߍ ߕߐ߮", + "tags-display-header": "ߟߊ߲ߞߣߍߡߊߟߌ ߡߊ߬ߦߟߍ߬ߡߊ߲߬ߠߌ߲߬ ߛߙߍߘߍ ߘߐ߫", + "tags-description-header": "ߞߘߐߝߐߟߌ ߞߊ߲߬ߛߓߍ߬ߟߌ߬ ߘߝߊߣߍ߲", + "tags-source-header": "ߛߎ߲", + "tags-active-header": "ߊ߬ ߟߊߞߎߣߎ߲߫ ߣߍ߲߫؟", + "tags-hitcount-header": "ߞߏ߲߭ ߓߘߊ߫ ߡߊߝߊ߬ߟߋ߲߬", + "tags-actions-header": "ߞߍߟߌ ߟߎ߬", "tags-active-yes": "ߐ߲߬ߐ߲߬ߐ߲߫", "tags-active-no": "ߍ߲߬ߍ߲ߍ߲߬", + "tags-source-extension": "ߡߊ߬ߕߍ߰ߣߍ߲ ߠߎ߬ ߛߎ߲ߝߘߍ ߓߟߏ߫", + "tags-source-manual": "ߟߊ߬ߓߊ߰ߙߊ߬ߟߊ ߣߌ߫ ߓߏߕ ߟߎ߬ ߟߊ߫ ߓߟߏߟߊ߫ ߞߍߟߌ", + "tags-source-none": "ߊ߬ ߕߍߣߊ߬ ߥߊ߯ߕߌߖߊ߲߫ ߞߍ߫ ߟߊ߫ ߓߊ߯ߙߊ ߘߐ߫ ߡߎ߬ߕߎ߲߬", + "tags-edit": "ߊ߬ ߡߊߦߟߍ߬ߡߊ߲߬", + "tags-delete": "ߊ߬ ߖߏ߰ߛߌ߬", + "tags-activate": "ߊ߬ ߟߊߞߎߣߎ߲߫", + "tags-deactivate": "ߊ߬ ߟߊߛߎ߬ߣߐ߬", "tags-hitcount": "{{PLURAL:$1|ߦߟߍ߬ߡߊ߲߬ߠߌ|$1 ߦߟߍ߬ߡߊ߲߬ߠߌ ߠߎ߬}}", + "tags-manage-no-permission": "ߌ ߟߊߘߌ߬ߢߍ߬ߣߍ߲߬ ߕߍ߫ ߞߊ߬ ߘߎ߲ߛߓߍ ߡߊߦߟߍ߬ߡߊ߲߬ߠߌ߲ ߡߊߞߍ߲߰.", + "tags-manage-blocked": "ߌ ߕߍ߫ ߣߊ߬ ߛߋ߫ ߟߊ߫ ߘߎ߲ߛߓߍ ߡߊߦߟߍ߬ߡߊ߲߬ߠߌ߲ ߡߊߞߍ߲߰ ߠߊ߫ ߞߊ߬ {{GENDER:$1|ߌ}} ߓߊ߬ߟߌ߬ߣߍ߲ ߕߏ߫.", + "tags-create-heading": "ߘߎ߲ߛߓߍ߫ ߞߎߘߊ߫ ߛߌ߲ߘߌ", + "tags-create-explanation": "ߘߊ߲ߛߎ߲ ߞߏߛߐ߲߬߸ ߘߎ߲ߛߓߍ ߟߊߘߊ߲ߣߍ߲߫ ߞߎߘߊ ߟߎ߬ ߘߌ߫ ߣߊ߬ ߛߌ߲ߘߌ߫߸ ߊ߬ ߣߌ߫ ߞߊ߬ ߞߍ߫ ߦߋ߲߬ ߟߊ߬ߓߊ߰ߙߊ߬ߟߊ ߣߌ߫ ߓߏߕ ߟߊ߫ ߟߊ߬ߓߊ߰ߙߊ߬ߟߌ ߞߊ߲ߡߊ߬.", + "tags-create-tag-name": "ߘߎ߲ߛߓߍ ߕߐ߮:", + "tags-create-reason": "ߊ߬ ߛߊߓߎ:", + "tags-create-submit": "ߟߊ߬ߘߊ߲߬ߠߌ߲", + "tags-create-no-name": "ߌ ߞߊߞߊ߲߫ ߞߊ߬ ߘߎ߲ߛߓߍ ߕߐ߮ ߘߏ߫ ߞߙߍߞߙߍ߫.", + "tags-delete-reason": "ߊ߬ ߛߊߓߎ:", + "tags-activate-reason": "ߊ߬ ߛߊߓߎ:", + "tags-deactivate-reason": "ߊ߬ ߛߊߓߎ:", + "compare-page1": "ߞߐߜߍ ߁߭", + "compare-page2": "ߞߐߜߍ ߂߲", + "compare-rev1": "ߟߢߊ߬ߟߌ ߁߭", + "compare-rev2": "ߟߢߊ߬ߟߌ ߂߲", + "compare-submit": "ߊ߬ ߟߊߢߐ߲߮ߡߊ߬", + "compare-invalid-title": "ߌ ߣߊ߬ ߞߎ߲߬ߕߐ߮ ߡߍ߲ ߞߙߍߞߙߍ߫ ߟߊ߫ ߏ߬ ߓߍ߲߬ߣߍ߲߬ ߕߍ߫.", + "compare-title-not-exists": "ߌ ߣߊ߬ ߞߎ߲߬ߕߐ߮ ߡߍ߲ ߞߙߍߞߙߍ߫ ߟߊ߫ ߏ߬ ߕߴߦߋ߲߬.", + "compare-revision-not-exists": "ߌ ߣߊ߬ ߟߢߊ߬ߟߌ ߡߍ߲ ߞߙߍߞߙߍ߫ ߟߊ߫ ߏ߬ ߕߴߦߋ߲߬.", + "diff-form": "ߓߐߣߍ߲ߢߐ߲߰ߡߊ ߟߎ߬", + "diff-form-oldid": "ߟߢߊ߬ߟߌ߬ ߞߘߐ ID (ߢߣߊߕߊߟߌ)", + "diff-form-revid": "ߓߐߣߍ߲ߢߐ߲߰ߡߊ ߟߎ߬ ߟߢߊ߬ߟߌ ID", + "diff-form-submit": "ߓߐߣߍ߲ߢߐ߲߰ߡߊ ߟߎ߬ ߦߌ߬ߘߊ߬", + "permanentlink": "ߛߘߌ߬ߜߋ߲߬ ߓߟߏߕߍ߰ߓߊߟߌ", + "permanentlink-revid": "ߟߢߊ߬ߟߌ ID", + "permanentlink-submit": "ߕߊ߯ ߟߢߊ߬ߟߌ ߘߐ߫", + "newsection": "ߕߍߕߍ߯ ߞߎߘߊ", + "newsection-page": "ߞߏ߲߭ ߞߐߜߍ", + "newsection-submit": "ߕߊ߯ ߞߐߜߍ ߞߊ߲߬", "logentry-delete-delete": "$1 {{GENDER:$2|deleted}} ߞߐߜߍ $3", "logentry-delete-restore": "$1 $3($4) ߞߐߜߍ {{GENDER:$2|ߓߘߊ߫ ߟߊߛߊ߬ߦߌ߬ ߞߐ߫}}", "logentry-delete-revision": "$1 {{GENDER:$2|ߓߘߊ߫ ߦߟߍ߬ߡߊ߲߬ߠߌ߲ ߞߍ߫}} ߣߌ߲߬ ߦߋߗߏ߮ ߟߊ߫ {{PLURAL:$5|a revision|$5 revisions}} ߞߐߜߍ ߣߌ߲߬ $3: $4 ߘߐ߫", diff --git a/languages/i18n/nso.json b/languages/i18n/nso.json index b218a40987..0b3d7ab2f1 100644 --- a/languages/i18n/nso.json +++ b/languages/i18n/nso.json @@ -283,24 +283,6 @@ "resetpass_submit": "Lokela ditlhaka-tÅ¡a-siphiri o tsene", "changepassword-success": "Ditlhaka tÅ¡a siphiri di fetotÅ¡we!", "passwordreset-username": "Leina la moÅ¡omiÅ¡i:", - "bold_sample": "Mongwalo wa '''Bold'''", - "bold_tip": "Ditlhaka tÅ¡e Bold", - "italic_sample": "Ditlhaka tÅ¡e Italic", - "italic_tip": "Mongwala wa Italic", - "link_sample": "Thaetlele ya hlomaganyo", - "link_tip": "Hlomaganyo ya kagare", - "extlink_sample": "http://www.example.com hlomaganyo thaetlele", - "extlink_tip": "Hlomaganyo ya ka ntle (gopola go thoma ka http://)", - "headline_sample": "Tlhaka ya hlogotaba", - "headline_tip": "Hlogotaba ya boemo ba 2", - "nowiki_sample": "Tsenya ditlhaka tÅ¡a go sebe le ''format'' mo", - "nowiki_tip": "Hlokomologa tselangwalo (''formatting'') ya wiki", - "image_sample": "Mohlala.jpg", - "image_tip": "SeswantÅ¡ho/Faele yago dikanelwa (''embedded'')", - "media_sample": "Mohlala.ogg", - "media_tip": "Hlomaganyo ya Faele", - "sig_tip": "Tshaeno ya gago le nako ya phetogo", - "hr_tip": "Mothalo wago ya faase/papamela (Å¡omiÅ¡a ka hloko)", "summary": "KakaretÅ¡o:", "subject": "Tabataba/Hlogo ya taba:", "minoredit": "Ye ke phetogo ye nnyenyane", diff --git a/languages/i18n/nys.json b/languages/i18n/nys.json index 9475ca49ba..d2e589bda2 100644 --- a/languages/i18n/nys.json +++ b/languages/i18n/nys.json @@ -186,22 +186,6 @@ "pt-userlogout": "woort koorl", "passwordreset": "Wallakiny ban-a-warryn", "passwordreset-username": "Niall kwel-le", - "bold_sample": "Moorn text", - "bold_tip": "Moorn text", - "italic_sample": "Italic text", - "italic_tip": "Italic text", - "link_sample": "Beda katta wir-iny", - "link_tip": "Bura beda", - "extlink_sample": "http://www.example.com beda kat-ta-biddi", - "extlink_tip": "Ban-dak beda (katta-rah http:// prefix)", - "headline_sample": "Kat-ta-biddi text", - "headline_tip": "Katta-wiring 2", - "nowiki_sample": "Ijow boko non-formatted text nidjak", - "nowiki_tip": "Meeyal-boort wiki formatting", - "image_tip": "Bal-ya-ta file", - "media_tip": "File beda", - "sig_tip": "Noonook ban-a with timestamp", - "hr_tip": "Yambor (use sparingly)", "summary": "Koorada waangkininy:", "minoredit": "neyp-nopb wallak", "watchthis": "djinang nidja bibol", diff --git a/languages/i18n/oc.json b/languages/i18n/oc.json index e7ad902fcb..ee53dfe789 100644 --- a/languages/i18n/oc.json +++ b/languages/i18n/oc.json @@ -591,24 +591,6 @@ "resettokens-watchlist-token": "Geton pel flux (Atom/RSS) web de [[Special:Watchlist|modificacions de paginas de vòstra lista de seguiment]]", "resettokens-done": "Getons reïnicializats.", "resettokens-resetbutton": "Reïnicializar los getons seleccionats", - "bold_sample": "Tèxte en gras", - "bold_tip": "Tèxte en gras", - "italic_sample": "Tèxte en italica", - "italic_tip": "Tèxte en italica", - "link_sample": "Títol del ligam", - "link_tip": "Ligam intèrne", - "extlink_sample": "http://www.example.com títol del ligam", - "extlink_tip": "Ligam extèrne (doblidetz pas lo prefixe http://)", - "headline_sample": "Tèxte de sostítol", - "headline_tip": "Sostítol nivèl 2", - "nowiki_sample": "Picatz lo tèxte pas formatat aicí", - "nowiki_tip": "Ignorar la sintaxi wiki", - "image_sample": "Exemple.jpg", - "image_tip": "Imatge inserit", - "media_sample": "Exemple.ogg", - "media_tip": "Ligam cap a un fichièr mèdia", - "sig_tip": "Vòstra signatura amb la data", - "hr_tip": "Linha orizontala (n'abusetz pas)", "summary": "Resumit :", "subject": "Subjècte :", "minoredit": "Aquò es un cambiament menor", diff --git a/languages/i18n/olo.json b/languages/i18n/olo.json index 6dd890c050..25a8e47c99 100644 --- a/languages/i18n/olo.json +++ b/languages/i18n/olo.json @@ -421,22 +421,6 @@ "changeemail-submit": "Vaihta sähköpoÅ¡tu", "changeemail-throttled": "Olet oppinuh kirjuttuakseh liijan moni kerdua. Ole hyvä, vuota $1 enne ku opit uvvessah.", "resettokens-tokens": "Avaimet:", - "bold_sample": "Lihavoitu tekstu", - "bold_tip": "Lihavoitu tekstu", - "italic_sample": "Kursivoitu tekstu", - "italic_tip": "Kursivoitu tekstu", - "link_sample": "Linkan nimi", - "link_tip": "Sižähine linku", - "extlink_sample": "http://www.example.com linkan nimi", - "extlink_tip": "Ulgohine linku (musta http:// alguh)", - "headline_sample": "Rubriekkutekstu", - "headline_tip": "Tazon 2 rubriekku", - "nowiki_sample": "Ližiä täh tekstu, kudamua ei pie korjata", - "nowiki_tip": "Älä puutu wiki-korjavuksih", - "image_tip": "Upotettu failu", - "media_tip": "Linki failah", - "sig_tip": "Teijän allekirjutus da aigu", - "hr_tip": "Horizontualine viivu (älä käytä liijakse)", "summary": "Yhtehvedo:", "subject": "Tiemu/rubriekku:", "minoredit": "Tämä on pieni kohendus", diff --git a/languages/i18n/or.json b/languages/i18n/or.json index 2e58b33766..6c7ac8356d 100644 --- a/languages/i18n/or.json +++ b/languages/i18n/or.json @@ -559,22 +559,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|ନିଜର ଦେଖଣାତାଲିକରେ ହେଉଥିବା ବଦଳ]]ର ୱେବ ଫିଡ଼ ପାଇଁ ଟୋକନ (ଆଟମ/RSS)", "resettokens-done": "ଟୋକନ ରିସେଟ ହେଲା ।", "resettokens-resetbutton": "ବଛାଯାଇଥିବା ଟୋକନ ରିସେଟ କରନ୍ତୁ", - "bold_sample": "ମୋଟା ଲେଖା", - "bold_tip": "ମୋଟା ଲେଖା", - "italic_sample": "ତେରେଛା ଲେଖା", - "italic_tip": "ତେରେଛା ଲେଖା", - "link_sample": "ଲିଙ୍କ ଶିରୋନାମା", - "link_tip": "ଭିତର ଲିଙ୍କ", - "extlink_sample": "http://www.example.com ଲିଙ୍କ ଶିରୋନାମା", - "extlink_tip": "ବାହାର ଲିଙ୍କ (ଆରମ୍ଭରେ http:// ଲେଖିବାକୁ ମନେରଖିଥିବେ)", - "headline_sample": "ଶିରୋନାମା ଲେଖା", - "headline_tip": "୨କ ଆକାରର ମୂଳଧାଡ଼ି", - "nowiki_sample": "ଅସଜଡ଼ା ଲେଖା ଏଠାରେ ଭରିବେ", - "nowiki_tip": "ଉଇକି ସଜାଣି ବିନା", - "image_tip": "ଏମ୍ବେଡ଼ ହୋଇ ଥିବା ଫାଇଲ", - "media_tip": "ଫାଇଲର ଲିଙ୍କ", - "sig_tip": "ସମୟ ସହ ଆପଣଙ୍କ ସନ୍ତକ", - "hr_tip": "ସମାନ୍ତରାଳ ରେଖା (ବେଳେବେଳେ ବ୍ୟବହାର କରିବେ)", "summary": "ସାରକଥା:", "subject": "ବିଷୟ:", "minoredit": "ଏହା ଏକ ସାମାନ୍ୟ ସମ୍ପାଦନା", diff --git a/languages/i18n/os.json b/languages/i18n/os.json index 5a89dc7373..188dec6757 100644 --- a/languages/i18n/os.json +++ b/languages/i18n/os.json @@ -493,22 +493,6 @@ "resettokens-token-label": "$1 (ныры мидис: $2)", "resettokens-done": "Токентæ æппæрст æрцыдысты.", "resettokens-resetbutton": "Амынд токентæ æппар", - "bold_sample": "Бæзджын текст", - "bold_tip": "Бæзджын текст", - "italic_sample": "Курсив", - "italic_tip": "Курсив", - "link_sample": "Æрвитæны текст", - "link_tip": "Мидæггаг æрвитæн", - "extlink_sample": "http://www.example.com æрвитæны текст", - "extlink_tip": "Æддаг æрвитæн (префикс http:// ма рох кæн)", - "headline_sample": "Сæргонд текст", - "headline_tip": "Бæрц 2 сæргонд", - "nowiki_sample": "Батысс нæформатгонд текст ардæм", - "nowiki_tip": "Ницæмæ дарын вики формат", - "image_tip": "Æфтыд файл", - "media_tip": "Файлмæ æрвитæн", - "sig_tip": "Дæ къухæрфыст, рæстæгимæ", - "hr_tip": "Горизонталон хахх (арæх дзы ма пайда кæн)", "summary": "Бындур:", "subject": "Темæ/сæр:", "minoredit": "Ай чысыл ивд у.", diff --git a/languages/i18n/pa.json b/languages/i18n/pa.json index 3a4961b635..e5c10c4f44 100644 --- a/languages/i18n/pa.json +++ b/languages/i18n/pa.json @@ -527,22 +527,6 @@ "resettokens-token-label": "$1 (ਚਾਲੂ ਮੁੱਲ: $2)", "resettokens-done": "ਨਿਸ਼ਾਨੀਆਂ ਮੁੜ ਬਣਾਈਆਂ ਗਈਆਂ।", "resettokens-resetbutton": "ਚੁਣੇ ਹੋਏ ਟੋਕਨ ਮੁੜ ਸੈੱਟ ਕਰੋ", - "bold_sample": "ਗੂੜੀ ਲਿਖਤ", - "bold_tip": "ਗੂੜੇ ਅੱਖਰ", - "italic_sample": "ਟੇਢੇ ਅੱਖਰ", - "italic_tip": "ਟੇਢੇ ਅੱਖਰ", - "link_sample": "ਲਿੰਕ ਸਿਰਲੇਖ", - "link_tip": "ਅੰਦਰੂਨੀ ਲਿੰਕ", - "extlink_sample": "http://www.example.com ਲਿੰਕ ਸਿਰਲੇਖ", - "extlink_tip": "ਬਾਹਰੀ ਲਿੰਕ (http:// ਅਗੇਤਰ ਯਾਦ ਰੱਖੋ)", - "headline_sample": "ਸੁਰਖੀ ਅੱਖਰ", - "headline_tip": "ਪੱਧਰ 2 ਸੁਰਖੀ", - "nowiki_sample": "ਅਸੰਗਠਿਤ ਪਾਠ (NON -FORMATTED) ਇੱਥੇ ਰਖੋ।", - "nowiki_tip": "ਵਿਕੀ ਫਾਰਮੈਟਿੰਗ ਨਜ਼ਰਅੰਦਾਜ਼ ਕਰੋ", - "image_tip": "ਇੰਬੈੱਡ ਫ਼ਾਈਲ", - "media_tip": "ਫਾਇਲ ਲਿੰਕ", - "sig_tip": "ਤੁਹਾਡੇ ਦਸਤਖ਼ਤ, ਸਮੇਂ ਸਮੇਤ", - "hr_tip": "ਲੇਟਵੀਂ ਰੇਖਾ (ਟਾਵੀਂ-ਟਾਵੀਂ ਵਰਤੋਂ ਕਰੋ)", "summary": "ਸਾਰ:", "subject": "ਵਿਸ਼ਾ/ਹੈੱਡਲਾਈਨ:", "minoredit": "ਇਹ ਇੱਕ ਛੋਟੀ ਸੋਧ ਹੈ", diff --git a/languages/i18n/pag.json b/languages/i18n/pag.json index f0abee9d58..3607128357 100644 --- a/languages/i18n/pag.json +++ b/languages/i18n/pag.json @@ -193,7 +193,6 @@ "botpasswords-label-delete": "Buralen", "resetpass-submit-cancel": "I-tonda", "changeemail-none": "(anggapo)", - "link_tip": "Gawing ed loob", "summary": "Sumaryo:", "subject": "Suheto:", "minoredit": "Melag yan dinuma", diff --git a/languages/i18n/pam.json b/languages/i18n/pam.json index 9e1da98743..7d11470640 100644 --- a/languages/i18n/pam.json +++ b/languages/i18n/pam.json @@ -348,22 +348,6 @@ "changepassword-success": "Melaus ing pamanalili mung password! Ngeni mila-login naka...", "resetpass_forbidden": "E la malyaring alilan deng password keng wiking ini", "passwordreset": "Alilan udyat (reset password)", - "bold_sample": "Makapasalang kulitan", - "bold_tip": "Makapal pangasulat", - "italic_sample": "Makakiling pangasulat", - "italic_tip": "Makakiling a kulitan (italic)", - "link_sample": "Bansag ning suglung", - "link_tip": "Suglung a pangkilub", - "extlink_sample": "http://www.example.com bansag ning suglung", - "extlink_tip": "Suglung a palwal (tandanan me ing http:// prefix)", - "headline_sample": "Letra ning pamagat (headline text)", - "headline_tip": "Pamagat a level 2", - "nowiki_sample": "Keti mu isingit ing sulat a e makaayus (non-formatted text)", - "nowiki_tip": "E papansinan ing pamanayus a pang-wiki (wiki formatting)", - "image_tip": "Simpan a makalangkap (Embedded file)", - "media_tip": "Suglung king simpan (File link)", - "sig_tip": "Ing kekang pirmang maki tatak ning oras (timestamp)", - "hr_tip": "Gulis a pakera (e dapat paneng gagamitan)", "summary": "Sampulung (Summary):", "subject": "Paksa/pamagat (headline):", "minoredit": "Malati yang edit ini", diff --git a/languages/i18n/pcd.json b/languages/i18n/pcd.json index a17c7d33bf..38cdca56d3 100644 --- a/languages/i18n/pcd.json +++ b/languages/i18n/pcd.json @@ -349,22 +349,6 @@ "resetpass-submit-loggedin": "Canger ch'mot d'passe", "passwordreset": "Ortreuver ch'mot d'passe", "changeemail": "Canger l'adrèche du imèle", - "bold_sample": "Cros teske", - "bold_tip": "Cros teske", - "italic_sample": "Teske italique", - "italic_tip": "Teske italique", - "link_sample": "Tite dech loïen", - "link_tip": "Loïen intérne", - "extlink_sample": "http://www.example.com tite dech loïen", - "extlink_tip": "Éstérne loïen ( n'obliez mie ech préfix http:// )", - "headline_sample": "Teske dechl in-téte", - "headline_tip": "In-téte nivieu 2", - "nowiki_sample": "Placher ch'teske non-formaté ichi", - "nowiki_tip": "Poin d'format wiki", - "image_tip": "fichié incorporé", - "media_tip": "Loïen dech fichié", - "sig_tip": "Vo pataraf aveuc l'date", - "hr_tip": "line orizontale (imploéïer aveuc modérachon)", "summary": "Résumè:", "subject": "Sujet/in-téte:", "minoredit": "Ch'est eune tiote édition", diff --git a/languages/i18n/pdc.json b/languages/i18n/pdc.json index 0221ab83a8..7817d90251 100644 --- a/languages/i18n/pdc.json +++ b/languages/i18n/pdc.json @@ -226,17 +226,6 @@ "passwordreset-emailelement": "Yuusernaame: \n$1\n\nPaesswatt fer nau: \n$2", "changeemail-none": "(ken)", "changeemail-submit": "E-Poschd ennere", - "bold_sample": "Wadde fett gmarrickt", - "bold_tip": "Wadde fett gmarrickt", - "link_sample": "Gleecher-Titel", - "link_tip": "Gleecher", - "extlink_sample": "http://www.example.com Gleecher-Text", - "extlink_tip": "Gewebbgleecher (acht uff http://)", - "headline_sample": "Iwwerschrift", - "headline_tip": "Iwwerschrift Level 2", - "image_sample": "Beeschpiel.jpg", - "media_sample": "Beeschpiel.ogg", - "media_tip": "Gleecher fer Feil", "minoredit": "Nur gleene Enneringe gemacht", "watchthis": "Watsch des Blatt", "savearticle": "Blatt beilege", diff --git a/languages/i18n/pfl.json b/languages/i18n/pfl.json index 921cf9dd1a..3ae1ab2789 100644 --- a/languages/i18n/pfl.json +++ b/languages/i18n/pfl.json @@ -323,22 +323,6 @@ "changeemail-none": "(käni)", "changeemail-submit": "E-Mail-Adress ännare", "resettokens-token-label": "$1 (jedzischa Wead: $2)", - "bold_sample": "Feddi Schrifd", - "bold_tip": "Feddi Schrifd", - "italic_sample": "Schebbi Schrifd", - "italic_tip": "Schebbi Schrifd", - "link_sample": "Schdischwoad", - "link_tip": "Inderna Ling'g", - "extlink_sample": "http://www.example.com Ling'gtegschd", - "extlink_tip": "Exderna Ling'g (uff http:// uffbasse)", - "headline_sample": "Schlaachzail", - "headline_tip": "Iwwaschrifd Ewene 2", - "nowiki_sample": "Gebb do'n Tegschd oi, wu nedd uffb'raid wead", - "nowiki_tip": "Wiki-Formatierunge nedd beachde", - "image_tip": "Bildvawais", - "media_tip": "Dadailing'g", - "sig_tip": "Doi Unnaschrifd midd ena Zaidoagawb", - "hr_tip": "Waagreschdi Linje (schbaasoam vawende)", "summary": "Iwwabligg:", "subject": "Bedreff:", "minoredit": "Des ischä glänni Beawaidung", diff --git a/languages/i18n/pl.json b/languages/i18n/pl.json index 04fec53574..d235fecb21 100644 --- a/languages/i18n/pl.json +++ b/languages/i18n/pl.json @@ -102,7 +102,8 @@ "Vlad5250", "CiaPan", "BadDog", - "Rail" + "Rail", + "Maro21" ] }, "tog-underline": "Podkreślenie linków:", @@ -149,6 +150,7 @@ "tog-useeditwarning": "Ostrzegaj mnie, gdy opuszczam stronę edycji bez zapisania zmian", "tog-prefershttps": "Zawsze używaj bezpiecznego połączenia po zalogowaniu", "tog-showrollbackconfirmation": "Wyświetl komunikat potwierdzający kliknięcie linku wycofującego edycje", + "tog-requireemail": "Wymagaj adresu e-mail przy resetowaniu hasła", "underline-always": "Zawsze", "underline-never": "Nigdy", "underline-default": "według ustawień skórki lub przeglądarki", @@ -514,7 +516,7 @@ "userlogin-resetpassword-link": "Nie pamiętasz hasła?", "userlogin-helplink2": "Pomoc przy logowaniu", "userlogin-loggedin": "Zalogowano jako {{GENDER:$1|$1}}.\nUżyj poniższego formularza, aby zalogować się jako inny użytkownik.", - "userlogin-reauth": "Musisz się ponownie zalogować, aby potwierdzić, że jesteś {{GENDER:$1|$1}}.", + "userlogin-reauth": "Musisz się ponownie zalogować, aby potwierdzić, że {{GENDER:$1|użytkownik|użytkowniczka}} $1 to Ty.", "userlogin-createanother": "Załóż nowe konto", "createacct-emailrequired": "Adres e‐mail", "createacct-emailoptional": "Adres e-mail (opcjonalnie)", @@ -523,7 +525,7 @@ "createaccountmail": "Użyj tymczasowego hasła wygenerowanego losowo i wyślij je na podany adres e-mail", "createaccountmail-help": "Pozwala utworzyć konto dla innej osoby, nie znając jej hasła.", "createacct-realname": "Prawdziwe imię i nazwisko (opcjonalnie)", - "createacct-reason": "Powód", + "createacct-reason": "Powód (podawany publicznie)", "createacct-reason-ph": "Dlaczego zakładasz kolejne konto", "createacct-reason-help": "Komunikat wyświetlany w rejestrze tworzenia kont", "createacct-submit": "Utwórz konto", @@ -691,24 +693,6 @@ "resettokens-watchlist-token": "Token kanału internetowego (Atom/RSS) zmian w [[Special:Watchlist|obserwowanych stronach]]", "resettokens-done": "Tokeny zresetowane.", "resettokens-resetbutton": "Zresetuj wybrane tokeny", - "bold_sample": "Tekst tłustą czcionką", - "bold_tip": "Tekst tłustą czcionką", - "italic_sample": "Tekst pochyłą czcionką", - "italic_tip": "Tekst pochyłą czcionką", - "link_sample": "Tytuł linku", - "link_tip": "Link wewnętrzny", - "extlink_sample": "http://www.example.com nazwa linku", - "extlink_tip": "Link zewnętrzny (pamiętaj o przedrostku http:// )", - "headline_sample": "Tekst nagłówka", - "headline_tip": "Nagłówek 2. poziomu", - "nowiki_sample": "Tutaj wstaw niesformatowany tekst", - "nowiki_tip": "Zignoruj formatowanie wiki", - "image_sample": "Przykład.jpg", - "image_tip": "Obraz lub inny plik osadzony na stronie", - "media_sample": "Przykład.ogg", - "media_tip": "Link do pliku", - "sig_tip": "Twój podpis wraz z datą i czasem", - "hr_tip": "Linia pozioma (nie nadużywaj)", "summary": "Opis zmian:", "subject": "Temat:", "minoredit": "To jest drobna zmiana", @@ -1078,7 +1062,7 @@ "searchall": "wszystkie", "showingresults": "Poniżej znajduje się lista {{PLURAL:$1|z '''1''' wynikiem|'''$1''' wyników}}, rozpoczynając od wyniku numer '''$2'''.", "showingresultsinrange": "Poniżej wyświetlono co najwyżej {{PLURAL:$1|<strong>1</strong> wynik|<strong>$1</strong> wyniki|<strong>$1</strong> wyników}} w zakresie od <strong>$2</strong> do <strong>$3</strong>.", - "search-showingresults": "{{PLURAL:$4|Wynik <strong>$1</strong> z <strong>$3</strong>|Wyniki <strong>$1 - $2</strong> z <strong>$3</strong>}}", + "search-showingresults": "{{PLURAL:$4|Wynik <strong>$1</strong> z <strong>$3</strong>|Wyniki <strong>$1 – $2</strong> z <strong>$3</strong>}}", "search-nonefound": "Brak wyników spełniających kryteria podane w zapytaniu.", "search-nonefound-thiswiki": "Brak wyników spełniających kryteria podane w zapytaniu.", "powersearch-legend": "Wyszukiwanie zaawansowane", @@ -1188,6 +1172,7 @@ "prefs-help-email": "Podanie adresu e‐mail nie jest obowiązkowe, lecz jest konieczne do zresetowania zapomnianego hasła.", "prefs-help-email-others": "Możesz również umożliwić innym użytkownikom wysłanie do Ciebie e‐maila poprzez Twoją stronę użytkownika lub stronę dyskusji (bez ujawniania Twojego adresu).", "prefs-help-email-required": "Wymagany jest adres e‐mail.", + "prefs-help-requireemail": "Po zaznaczeniu wiadomości e-mail z linkiem do resetu hasła będą wysyłane dopiero gdy resetujący użytkownik wprowadzi zarówno nazwę użytkownika jak i adres e-mail przypisane do tego konta.", "prefs-info": "Podstawowe informacje", "prefs-i18n": "Ustawienia językowe", "prefs-signature": "Podpis", @@ -1906,6 +1891,7 @@ "listfiles-userdoesnotexist": "Konto użytkownika „$1” nie jest zarejestrowane.", "imgfile": "plik", "listfiles": "Lista plików", + "listfiles_subpage": "Przesłane przez $1", "listfiles_thumb": "Miniatura", "listfiles_date": "Data", "listfiles_name": "Nazwa", @@ -2640,6 +2626,7 @@ "ipblocklist-legend": "Znajdź zablokowanego użytkownika", "blocklist-userblocks": "Ukryj blokady konta", "blocklist-tempblocks": "Ukryj tymczasowe blokady", + "blocklist-indefblocks": "Ukryj blokady nałołożone na zawsze", "blocklist-addressblocks": "Ukryj blokady pojedynczych adresów IP", "blocklist-type": "Typ:", "blocklist-type-opt-all": "Wszystkie", @@ -2929,7 +2916,7 @@ "tooltip-p-logo": "Strona główna", "tooltip-n-mainpage": "Zobacz stronę główną", "tooltip-n-mainpage-description": "Przejdź na stronę główną", - "tooltip-n-portal": "O projekcie - co możesz zrobić, gdzie możesz znaleźć informacje", + "tooltip-n-portal": "O projekcie – co możesz zrobić, gdzie możesz znaleźć informacje", "tooltip-n-currentevents": "Informacje o aktualnych wydarzeniach", "tooltip-n-recentchanges": "Lista ostatnich zmian w {{GRAMMAR:MS.lp|{{SITENAME}}}}.", "tooltip-n-randompage": "Załaduj losową stronę", diff --git a/languages/i18n/pms.json b/languages/i18n/pms.json index ecc86bb6a2..fd463e8f03 100644 --- a/languages/i18n/pms.json +++ b/languages/i18n/pms.json @@ -536,24 +536,6 @@ "resettokens-watchlist-token": "Geton për ël fluss an sl'aragnà (Atom/RSS) ëd [[Special:Watchlist|modìfiche a le pàgine che as ten sot-euj]]", "resettokens-done": "Geton riampostà.", "resettokens-resetbutton": "Riamposté ij geton selessionà", - "bold_sample": "Test an grassèt", - "bold_tip": "Test an grassèt", - "italic_sample": "Test an corsiv", - "italic_tip": "Test an corsiv", - "link_sample": "Tìtol dl'anliura", - "link_tip": "Anliura interna", - "extlink_sample": "http://www.example.com tìtol dl'anliura", - "extlink_tip": "Anliura esterna (che as visa dë buté ël prefiss http://)", - "headline_sample": "Test dël tìtol", - "headline_tip": "Antestassion dë scond livel", - "nowiki_sample": "Che a buta ël test brut ambelessì", - "nowiki_tip": "Lassé un tòch ëd test fòra dla sintassi dla wiki", - "image_sample": "Esempi.jpg", - "image_tip": "Archivi anglobà", - "media_sample": "Esempi.ogg", - "media_tip": "Anliura a n'archivi multimedial", - "sig_tip": "Soa signadura con la data e l'ora", - "hr_tip": "Riga orisontal (da dovresse nen tròp soèns)", "summary": "Resumé:", "subject": "Sogèt:", "minoredit": "Costa a l'é na modìfica cita", diff --git a/languages/i18n/pnb.json b/languages/i18n/pnb.json index d4aaf9e3e7..e9cee8a468 100644 --- a/languages/i18n/pnb.json +++ b/languages/i18n/pnb.json @@ -461,24 +461,6 @@ "changeemail-newemail": "نواں ای-میل پتہ:", "changeemail-none": "(کوئی نئیں)", "changeemail-submit": "ای-میل بدلو", - "bold_sample": "موٹی لکھائی", - "bold_tip": "موٹی لکھائی", - "italic_sample": "ٹیڈی لکھائی", - "italic_tip": "ٹیڈی لکھائی", - "link_sample": "جوڑ", - "link_tip": "اندرونی جوڑ", - "extlink_sample": "http://www.example.com جوڑ دا ناں", - "extlink_tip": "بارلے جوڑ (remember http:// prefix)", - "headline_sample": "شہ سرخی", - "headline_tip": "دوسرے درجے دی سرخی", - "nowiki_sample": "فارمیٹ نہ ہوئی لکھائی ایتھے پاؤ", - "nowiki_tip": "وکی فارمیٹ رہن دیؤ۔", - "image_sample": "Example.jpg", - "image_tip": "وچ مورت لگاؤ", - "media_sample": "Example.ogg", - "media_tip": "فائل دا جوڑ", - "sig_tip": "تواڈے دستخط ویلے دے نال", - "hr_tip": "سدھی لکیر", "summary": "ویروا:", "subject": "موضوع:", "minoredit": "اے نکا جیا کم اے", diff --git a/languages/i18n/pnt.json b/languages/i18n/pnt.json index 85652ec689..3d9fec478f 100644 --- a/languages/i18n/pnt.json +++ b/languages/i18n/pnt.json @@ -275,22 +275,6 @@ "resetpass-submit-cancel": "Χάσονα", "resetpass-wrong-oldpass": "'Κ εγράφτεν τογρία το προσωρνόν ή κανονικόν σημάδιν.\nΓιαμ' εποίκατε καινούρεον σημάδιν ή εποίκατε ψαλαφίον για καινούρεον προσωρνόν σημάδιν;", "resetpass-temp-password": "Προσωρινόν σημάδ':", - "bold_sample": "Χοντρόν κείμενον", - "bold_tip": "Χοντρόν κείμενον", - "italic_sample": "Ψιλόν κείμενον", - "italic_tip": "Ψιλόν κείμενον", - "link_sample": "Τίτλον σύνδεσμονος", - "link_tip": "Εσωτερικόν σύνδεσμον", - "extlink_sample": "http://www.example.com τίτλον σύνδεσμονος", - "extlink_tip": "Εξωτερικόν σύνδεσμον (να μην ανασπάλλετε το πρόθεμαν http:// )", - "headline_sample": "Κείμενον τίτλονος", - "headline_tip": "Δεύτερον τίτλος (επίπεδον 2)", - "nowiki_sample": "Αδακά πα να εισάγετε το μη μορφοποιημένον κείμενον.", - "nowiki_tip": "Ξάι 'κ να τερείται η μορφοποίηση Wiki.", - "image_tip": "Ενσωματωμένον εικόνα", - "media_tip": "Σύνδεσμον αρχείατι πολυμεσίων", - "sig_tip": "Η υπογραφήν εσούν με ώραν κι ημερομηνίαν", - "hr_tip": "Οριζόντιον γραμμή (μη θέκ'ς ατέν πολλά)", "summary": "Σύνοψη:", "subject": "Θέμα/επικεφαλίδα:", "minoredit": "Μικρόν αλλαγήν", diff --git a/languages/i18n/prg.json b/languages/i18n/prg.json index 7f7415472d..237a61d9ca 100644 --- a/languages/i18n/prg.json +++ b/languages/i18n/prg.json @@ -331,22 +331,6 @@ "resetpass-submit-loggedin": "KitawÄ«dinais kliptaswÄ«rdan", "resetpass-wrong-oldpass": "Nitikrōmiskas kÄ«smingiskas anga aktuāls kliptaswÄ«rds.\nMazzingi tÅ« assei ka tēr kitawÄ«dinuns swajjan kliptaswÄ«rdan anga assei madlÄ«wuns per nāunan kÄ«smingiskan kliptaswÄ«rdan.", "resetpass-temp-password": "KÄ«smingiskas kliptaswÄ«rds:", - "bold_sample": "PastarÄ«nts teksts", - "bold_tip": "PastarÄ«nts teksts", - "italic_sample": "Itālikis", - "italic_tip": "Itālikis", - "link_sample": "AutengÄ«nsenes tÄ«tels", - "link_tip": "Ēntrewingis autengÄ«nsenis", - "extlink_sample": "http://www.example.com autengÄ«nsenes tÄ«tels", - "extlink_tip": "IzwinaÄ«nas autengÄ«nsenis (pamēnais ezze prefiksan http:// )", - "headline_sample": "GalwasrÄ«ndas teksts", - "headline_tip": "Āntras lÄ«gmenes galwasrÄ«nda", - "nowiki_sample": "Stwi enpeisāis nifōrmatitan tekstan", - "nowiki_tip": "Ignōris wiki fōrmatisnan", - "image_tip": "Grāfiki anga kits endÄ«ts en pāusu zÅ«rbrukis", - "media_tip": "AutengÄ«nsenis prei zÅ«rbrukin", - "sig_tip": "Twājs papeisāsenis sen dātan be kērdan", - "hr_tip": "Uricōntali (tērpaus taupÄ«ngi)", "summary": "KitawÄ«dinsnan ebpeisāsenis:", "subject": "TÄ«tels:", "minoredit": "Sta ast malkā tikrinsnā.", diff --git a/languages/i18n/ps.json b/languages/i18n/ps.json index d0f097c79f..7b7467d39d 100644 --- a/languages/i18n/ps.json +++ b/languages/i18n/ps.json @@ -588,24 +588,6 @@ "resettokens-watchlist-token": "د ویب فیډ (د اتوم / آر ایس ایس) لپاره ډک کړئ [[Special:Watchlist| د خپل د کتار لیست په پاڼو کې بدلونونه]]", "resettokens-done": "د رایو بیا راګرځول.", "resettokens-resetbutton": "د ټاکل شوي ټوکنونو بیا راګرځول", - "bold_sample": "زغرد متن", - "bold_tip": "زغرد متن", - "italic_sample": "رېوند متن", - "italic_tip": "رېوند متن", - "link_sample": "د تړن سرليک", - "link_tip": "کورنۍ تړنه", - "extlink_sample": "http://www.example.com د تړنې سرليک", - "extlink_tip": "باندنۍ تړنې (د http:// مختاړی مه هېروی)", - "headline_sample": "د سرليک متن", - "headline_tip": "د Û² کچې سرليک", - "nowiki_sample": "دلته دې بې بڼې متن ځای پر ځای شي", - "nowiki_tip": "د ويکي بڼه نيونه بابېزه گڼل", - "image_sample": "Example.jpg", - "image_tip": "خښه شوې دوتنه", - "media_sample": "Example.ogg", - "media_tip": "د دوتنې تړنه", - "sig_tip": "ستاسې لاسليک د وخت د ټاپې سره", - "hr_tip": "څنډيزه ليکه (ددې په کارولو کې سپما وکړۍ)", "summary": "لنډيز:", "subject": "سکالو:", "minoredit": "دا يو وړوکی سمون دی", diff --git a/languages/i18n/pt-br.json b/languages/i18n/pt-br.json index 1106f5f309..55ab67baff 100644 --- a/languages/i18n/pt-br.json +++ b/languages/i18n/pt-br.json @@ -167,6 +167,7 @@ "tog-useeditwarning": "Avisar-me quando eu deixar uma janela de edição sem ter salvo as alterações", "tog-prefershttps": "Usar sempre uma conexão segura enquanto estiver conectado", "tog-showrollbackconfirmation": "Mostrar um aviso de confirmação ao clicar em um link de reversão", + "tog-requireemail": "Exigir e-mail para redefinições de senha", "underline-always": "Sempre", "underline-never": "Nunca", "underline-default": "Padrão do navegador/tema", @@ -546,7 +547,7 @@ "createaccountmail": "Usar uma senha aleatória e temporária que será enviada ao endereço de e-mail especificado a seguir", "createaccountmail-help": "Pode ser utilizado para criar uma conta para outra pessoa sem saber a senha.", "createacct-realname": "Nome real (opcional)", - "createacct-reason": "Motivo", + "createacct-reason": "Motivo (entrado publicamente)", "createacct-reason-ph": "Por que você está criando outra conta", "createacct-reason-help": "Mensagem mostrada no registro de criação de conta", "createacct-submit": "Crie sua conta", @@ -715,24 +716,6 @@ "resettokens-watchlist-token": "Tokens para o feed da web (Atom/RSS) das [[Special:Watchlist|mudanças de páginas em sua lista de páginas vigiadas]]", "resettokens-done": "Tokens reiniciados.", "resettokens-resetbutton": "Reiniciar tokens selecionados", - "bold_sample": "Texto em negrito", - "bold_tip": "Texto em negrito", - "italic_sample": "Texto em itálico", - "italic_tip": "Texto em itálico", - "link_sample": "Título do link", - "link_tip": "Link interno", - "extlink_sample": "http://www.example.com título do link", - "extlink_tip": "Link externo (lembre-se do prefixo http://)", - "headline_sample": "Conteúdo do cabeçalho", - "headline_tip": "Seção de nível 2", - "nowiki_sample": "Inserir texto não formatado aqui", - "nowiki_tip": "Ignorar a formatação wiki", - "image_sample": "Exemplo.jpg", - "image_tip": "Arquivo embutido", - "media_sample": "Exemplo.ogg", - "media_tip": "Link para o arquivo", - "sig_tip": "Sua assinatura, com hora e data", - "hr_tip": "Linha horizontal (use de forma moderada)", "summary": "Resumo da edição:", "subject": "Assunto:", "minoredit": "Marcar como edição menor", @@ -1217,6 +1200,7 @@ "prefs-help-email": "O endereço de e-mail é opcional, mas será necessário para recriar sua senha caso esqueça a antiga.", "prefs-help-email-others": "Você também pode optar por permitir que outros entrem em contato com você através de sua página de usuário ou de discussão sem ter de revelar seus dados pessoais.", "prefs-help-email-required": "O endereço de e-mail é requerido.", + "prefs-help-requireemail": "Se marcado, só enviará emails de redefinição de senha se a pessoa que redefiniu tiver fornecido o nome de usuário e o e-mail para esta conta.", "prefs-info": "Informações básicas", "prefs-i18n": "Internacionalização", "prefs-signature": "Assinatura", @@ -1941,6 +1925,7 @@ "listfiles-userdoesnotexist": "A conta de usuário \"$1\" não está registrada.", "imgfile": "arquivo", "listfiles": "Lista de arquivos", + "listfiles_subpage": "Enviado por $1", "listfiles_thumb": "Miniatura", "listfiles_date": "Data", "listfiles_name": "Nome", @@ -2684,6 +2669,7 @@ "ipblocklist-legend": "Procurar por um usuário bloqueado", "blocklist-userblocks": "Esconder bloqueios de contas", "blocklist-tempblocks": "Esconder bloqueios temporários", + "blocklist-indefblocks": "Ocultar bloqueios indefinidos", "blocklist-addressblocks": "Esconder bloqueios de IP único", "blocklist-type": "Tipo:", "blocklist-type-opt-all": "Todos", @@ -4022,5 +4008,8 @@ "mycustomjsredirectprotected": "Você não tem permissão para editar esta página JavaScript porque é um redirecionamento e não aponta dentro do seu espaço do usuário.", "easydeflate-invaliddeflate": "O conteúdo fornecido não está devidamente comprimido", "unprotected-js": "Por razões de segurança o JavaScript não pode ser carregado de páginas desprotegidas. Por favor, crie apenas javascript no MediaWiki: namespace ou como uma subpágina do usuário", - "userlogout-continue": "Você quer sair?" + "userlogout-continue": "Você quer sair?", + "rest-prefix-mismatch": "O caminho pedido ($1) não estava no interior do caminho raiz da API REST ($2)", + "rest-wrong-method": "O método pedido ($1) não era {{PLURAL:$3|o método permitido para este caminho|um dos métodos permitidos para este caminho}} ($2)", + "rest-no-match": "O caminho relativo pedido ($1) não corresponde a nenhuma rotina de tratamento conhecida" } diff --git a/languages/i18n/pt.json b/languages/i18n/pt.json index c72842199a..5f844fdf4a 100644 --- a/languages/i18n/pt.json +++ b/languages/i18n/pt.json @@ -80,7 +80,8 @@ "Fitoschido", "Ldacosta", "CaiusSPQR", - "Waldyrious" + "Waldyrious", + "Mansil alfalb" ] }, "tog-underline": "Sublinhar hiperligações:", @@ -127,6 +128,7 @@ "tog-useeditwarning": "Avisar-me ao abandonar uma página editada sem gravar as alterações", "tog-prefershttps": "Usar sempre uma ligação segura enquanto tiver sessão iniciada", "tog-showrollbackconfirmation": "Mostrar um pedido de confirmação ao clicar numa hiperligação de reversão", + "tog-requireemail": "Exigir correio eletrónico para reinícios da palavra-passe", "underline-always": "Sempre", "underline-never": "Nunca", "underline-default": "Usar opção padrão do tema ou do navegador", @@ -506,7 +508,7 @@ "createaccountmail": "Usar uma palavra-passe aleatória e temporária e enviá-la para o endereço de correio eletrónico especificado", "createaccountmail-help": "Pode ser utilizado para criar uma conta para outra pessoa sem saber a palavra-passe.", "createacct-realname": "Nome verdadeiro (opcional)", - "createacct-reason": "Motivo", + "createacct-reason": "Motivo (registado publicamente)", "createacct-reason-ph": "Porque está a criar outra conta", "createacct-reason-help": "Mensagem mostrada no registo de criação de contas", "createacct-submit": "Crie a sua conta", @@ -675,24 +677,6 @@ "resettokens-watchlist-token": "Chave para o ''feed'' Atom/RSS de [[Special:Watchlist|mudanças às páginas vigiadas]]", "resettokens-done": "As chaves foram redefinidas.", "resettokens-resetbutton": "Redefinir chaves selecionadas", - "bold_sample": "Texto a negrito", - "bold_tip": "Texto a negrito", - "italic_sample": "Texto em itálico", - "italic_tip": "Texto em itálico", - "link_sample": "Título da hiperligação", - "link_tip": "Hiperligação interna", - "extlink_sample": "http://www.example.com título da hiperligação", - "extlink_tip": "Hiperligação externa (lembre-se do prefixo http://)", - "headline_sample": "Texto do cabeçalho", - "headline_tip": "Secção de nível 2", - "nowiki_sample": "Inserir texto não-formatado aqui", - "nowiki_tip": "Ignorar formatação wiki", - "image_sample": "Exemplo.jpg", - "image_tip": "Ficheiro incorporado", - "media_sample": "Exemplo.ogg", - "media_tip": "Hiperligação para ficheiro", - "sig_tip": "A sua assinatura, com hora e data", - "hr_tip": "Linha horizontal (utilize moderadamente)", "summary": "Resumo:", "subject": "Assunto:", "minoredit": "Marcar como edição menor", @@ -876,6 +860,7 @@ "undo-norev": "Não foi possível desfazer a edição porque não existe ou foi apagada.", "undo-nochange": "A edição parece já ter sido desfeita.", "undo-summary": "Desfez a edição $1 de [[Special:Contributions/$2|$2]] ([[User talk:$2|discussão]])", + "undo-summary-anon": "Desfazer a revisão $1 de [[Special:Contributions/$2|$2]]", "undo-summary-username-hidden": "Desfez a edição $1 de um utilizador oculto", "cantcreateaccount-text": "A criação de contas a partir deste endereço IP (<strong>$1</strong>) foi bloqueada por [[User:$3|$3]].\n\nO motivo apresentado por $3 foi <em>$2</em>", "cantcreateaccount-range-text": "A criação de conta a partir dos endereços IP no intervalo <strong>$1</strong>, que inclui o seu endereço IP (<strong>$4</strong>), foi bloqueada por [[User:$3|$3]].\n\nO motivo apresentado por $3 foi <em>$2</em>", @@ -1176,6 +1161,7 @@ "prefs-help-email": "Opcional: o endereço de correio eletrónico é opcional, mas será necessário para redefinir a palavra-passe caso esqueça a antiga.", "prefs-help-email-others": "Também pode optar por permitir que outros entrem em contacto consigo por correio eletrónico, através de uma hiperligação nas suas páginas de utilizador ou de discussão, sem revelar o seu endereço de correio eletrónico.", "prefs-help-email-required": "É necessário o endereço de correio eletrónico.", + "prefs-help-requireemail": "Se marcado, só serão enviados correios de reinício da palavra-passe se a pessoa que está a reiniciar tiver fornecido o nome de utilizador e o correio eletrónico desta conta.", "prefs-info": "Informações básicas", "prefs-i18n": "Internacionalização", "prefs-signature": "Assinatura", @@ -1896,6 +1882,7 @@ "listfiles-userdoesnotexist": "A conta de utilizador \"$1\" não está registada.", "imgfile": "ficheiro", "listfiles": "Ficheiros", + "listfiles_subpage": "Carregamentos de $1", "listfiles_thumb": "Miniatura", "listfiles_date": "Data", "listfiles_name": "Nome", @@ -2393,6 +2380,7 @@ "alreadyrolled": "Não foi possível reverter as edições de [[:$1]] por [[User:$2|$2]] ([[User talk:$2|discussão]]{{int:pipe-separator}}[[Special:Contributions/$2|{{int:contribslink}}]]);\nalguém editou ou já reverteu a página.\n\nA última edição foi de [[User:$3|$3]] ([[User talk:$3|discussão]]{{int:pipe-separator}}[[Special:Contributions/$3|{{int:contribslink}}]]).", "editcomment": "O resumo da edição era: <em$1</em>.", "revertpage": "Foram revertidas as edições de [[Special:Contributions/$2|$2]] ([[User talk:$2|disc]]) para a última revisão de [[User:$1|$1]]", + "revertpage-anon": "Foram revertidas as edições de [[Special:Contributions/$2|$2]] para a última revisão de [[User:$1|$1]]", "revertpage-nouser": "Foram revertidas as edições de um utilizador oculto para a última revisão de {{GENDER:$1|[[User:$1|$1]]}}", "rollback-success": "Foram revertidas as edições de {{GENDER:$3|$1}}; reposta a última edição de {{GENDER:$4|$2}}.", "sessionfailure-title": "Erro de sessão", @@ -2629,6 +2617,7 @@ "ipblocklist-legend": "Procurar um utilizador bloqueado", "blocklist-userblocks": "Ocultar bloqueios de contas", "blocklist-tempblocks": "Ocultar bloqueios temporários", + "blocklist-indefblocks": "Ocultar bloqueios sem fim definido", "blocklist-addressblocks": "Ocultar bloqueios de um IP individual", "blocklist-type": "Tipo:", "blocklist-type-opt-all": "Todos", @@ -3914,5 +3903,8 @@ "mycustomjsredirectprotected": "Não tem autorização para editar esta página de JavaScript porque ela é um redirecionamento e não aponta para o interior do seu espaço do utilizador.", "easydeflate-invaliddeflate": "O conteúdo fornecido não está devidamente comprimido", "unprotected-js": "Por motivos de segurança o JavaScript de páginas desprotegidas não pode ser carregado. Crie javascript só no espaço nominal/domínio MediaWiki: ou numa subpágina do utilizador", - "userlogout-continue": "Quer sair?" + "userlogout-continue": "Quer sair?", + "rest-prefix-mismatch": "O caminho pedido ($1) não estava no interior do caminho raiz da API REST ($2)", + "rest-wrong-method": "O método pedido ($1) não era {{PLURAL:$3|o método permitido para este caminho|um dos métodos permitidos para este caminho}} ($2)", + "rest-no-match": "O caminho relativo pedido ($1) não corresponde a nenhuma rotina de tratamento conhecida" } diff --git a/languages/i18n/qqq.json b/languages/i18n/qqq.json index a33608f5fb..afbfd94bab 100644 --- a/languages/i18n/qqq.json +++ b/languages/i18n/qqq.json @@ -838,25 +838,7 @@ "resettokens-watchlist-token": "Label for watchlist token checkbox on [[Special:ResetTokens]] (see {{msg-mw|prefs-watchlist-token}} at [[Special:Preferences#mw-prefsection-watchlist]]).", "resettokens-done": "Message shown on [[Special:ResetTokens]] after the tokens have been reset successfully.", "resettokens-resetbutton": "Form submit button on [[Special:ResetTokens]].", - "bold_sample": "This is the sample text that you get when you press the first button on the left on the edit toolbar.\n\n{{Identical|Bold text}}", - "bold_tip": "This is the text that appears when you hover the mouse over the first button on the left of the edit toolbar.\n\n{{Identical|Bold text}}", - "italic_sample": "The sample text that you get when you press the second button from the left on the edit toolbar.\n\n{{Identical|Italic text}}", - "italic_tip": "This is the tooltip that appears when the user points to the \"Italic\" button in the edit toolbar.\n\n{{Identical|Italic text}}", - "link_sample": "This is the default text in the internal link that is created when you press the third button from the left on the edit toolbar (the \"Ab\" icon).", - "link_tip": "Tip for internal links.\n{{Identical|Internal link}}", - "extlink_sample": "This message appears when clicking on the fourth button of the edit toolbar. You can translate \"link title\". Because many of the localisations had urls that went to domains reserved for advertising, it is recommended that the link is left as-is. All customised links were replaced with the standard one, that is reserved in the standard and will never have ads or something.", - "extlink_tip": "This is the tip that appears when you hover the mouse over the fourth button from the left on the edit toolbar.\n\n{{Identical|External link (remember http:// prefix)}}", - "headline_sample": "Sample of headline text.", - "headline_tip": "This is the text that appears when you hover the mouse over the fifth button from the left on the edit toolbar.", - "nowiki_sample": "Text inserted between nowiki tags", - "nowiki_tip": "This is the text that appears when you hover the mouse over the third button from the right on the edit toolbar.", - "image_sample": "{{optional}}\nUsed in text generated by Picture button in toolbar.\n{{Identical|Example}}", - "image_tip": "This is the text that appears when you hover the mouse over the sixth (middle) button on the edit toolbar.\n\n{{Identical|Embedded file}}", - "media_sample": "{{optional}}\n{{Identical|Example}}", - "media_tip": "This is the text that appears when you hover the mouse over the fifth button from the right in the edit toolbar.\n{{Identical|File link}}", "sig-text": "{{notranslate}} This is the text that appears when you click on the signature button (second button from the right) on the edit toolbar. $1 will be replaced with four tildes (which cannot be included directly in the message for technical reasons).", - "sig_tip": "This is the text that appears when you hover the mouse over the second key from the right on the edit toolbar.\n{{Identical|Signature with timestamp}}", - "hr_tip": "This is the text that appears when you hover the mouse over the first button on the right on the edit toolbar.", "summary": "The Summary text beside the edit summary field\n\nSee also:\n* {{msg-mw|Subject}}\nSee also:\n* {{msg-mw|Accesskey-summary}}\n* {{msg-mw|Tooltip-summary}}\n{{Identical|Summary}}", "subject": "Used as label for the section title input box when adding a new section on a talk page.\n\nSee also:\n* {{msg-mw|Summary}}\n{{Identical|Subject}}", "minoredit": "Text above Save page button in editor\n\nSee also:\n* {{msg-mw|Minoredit}}\n* {{msg-mw|Accesskey-minoredit}}\n* {{msg-mw|Tooltip-minoredit}}", @@ -2103,6 +2085,7 @@ "listfiles-userdoesnotexist": "This message is displayed on [[Special:ListFiles]] when a invalid username is entered.", "imgfile": "{{Identical|File}}", "listfiles": "Page title and grouping label for the form displayed on [[Special:ListFiles]].\n{{Identical|List}}", + "listfiles_subpage": "Page title and grouping label for the form displayed on [[Special:ListFiles]].\n\nParameters:\n* $1 - username\n\n{{Identical|List}} when a username is selected.", "listfiles_thumb": "{{Identical|Thumbnail}}", "listfiles_date": "Column header for the result table displayed on [[Special:ListFiles]].\n{{Identical|Date}}", "listfiles_name": "Column header for the result table displayed on [[Special:ListFiles]].\n{{Identical|Name}}", @@ -4472,5 +4455,8 @@ "mycustomjsredirectprotected": "Error message shown when user tries to edit their own JS page that is a foreign redirect without the 'mycustomjsredirectprotected' right. See also {{msg-mw|mycustomjsprotected}}.", "easydeflate-invaliddeflate": "Error message if the content passed to easydeflate was not deflated (compressed) properly", "unprotected-js": "Error message shown when trying to load javascript via action=raw that is not protected", - "userlogout-continue": "Shown if user attempted to log out without a token specified. Probably the user clicked on an old link that hasn't been updated to use the new system. $1 - url that user should click on in order to log out." + "userlogout-continue": "Shown if user attempted to log out without a token specified. Probably the user clicked on an old link that hasn't been updated to use the new system. $1 - url that user should click on in order to log out.", + "rest-prefix-mismatch": "Error message for REST API debugging, shown if $wgRestPath is incorrect or otherwise not matched. Parameters:\n* $1: The requested path.\n* $2: The configured root path ($wgRestPath).", + "rest-wrong-method": "Error message for REST API debugging, shown if the HTTP method is incorrect. Parameters:\n* $1: The received request method.\n* $2: A comma-separated list of allowed methods for this path.\n* $3: The number of items in the list $2", + "rest-no-match": "Error message for REST API debugging, shown if the path has the correct prefix but did not match any registered handler. Parameters:\n* $1: The received request path, relative to $wgRestPath." } diff --git a/languages/i18n/qu.json b/languages/i18n/qu.json index fd9c55be77..087c28a58d 100644 --- a/languages/i18n/qu.json +++ b/languages/i18n/qu.json @@ -491,23 +491,6 @@ "resettokens-token-label": "$1 (kunan chani: $2)", "resettokens-done": "Llawikunaqa kutichimusqañam.", "resettokens-resetbutton": "Akllasqa llawikunata kutichimuy", - "bold_sample": "Yanasapa qillqa", - "bold_tip": "Yanasapa qillqa", - "italic_sample": "Wiksu qillqa", - "italic_tip": "Wiksu qillqa", - "link_sample": "T'inkip sutin", - "link_tip": "Ukhu t'inki", - "extlink_sample": "http://www.example.com t'inkip umallin", - "extlink_tip": "Hawa t'inki (ñawpaqta http:// nisqata yapariy)", - "headline_sample": "Uma siq'i qillqa", - "headline_tip": "Iskay ñiqi hanaq siq'i qillqa", - "nowiki_sample": "Kayman mana wiki rikch'akuyniyuq qillqata yapamuy", - "nowiki_tip": "Wiki rikch'akuy ama kachunchu", - "image_sample": "Qhawarichiy.jpg", - "image_tip": "Ch'aqtasqa rikcha", - "media_tip": "Multimidya willañiqiman t'inki", - "sig_tip": "Sutiykita, p'unchawta, pachatapas silq'umuy", - "hr_tip": "Siriq siq'i (ama nisyutachu llamk'apuy)", "summary": "Pisichay:", "subject": "Yachaywa/umalli:", "minoredit": "Kayqa uchuylla hukchaymi", diff --git a/languages/i18n/qug.json b/languages/i18n/qug.json index c66fb49c77..d1306cc879 100644 --- a/languages/i18n/qug.json +++ b/languages/i18n/qug.json @@ -260,22 +260,6 @@ "createaccount": "Shuk rurak shutita akllana", "mailmypassword": "Musuq yaykunkapak rimayta e-chaskiwan kachawapay", "loginlanguagelabel": "Shimi: $1", - "bold_sample": "Yanayashka killka", - "bold_tip": "Yanayashka killka", - "italic_sample": "Wiksu killka", - "italic_tip": "Wiksu qillqa", - "link_sample": "Tinkipak uma rimay", - "link_tip": "Ukuman tinki", - "extlink_sample": "http://www.example.com tinkipa uma rimay", - "extlink_tip": "Hawaman tinki (http:// llikakunawan kallarinami kan)", - "headline_sample": "Uma rimaypa killka", - "headline_tip": "Ishkay-niki hatun uma rimay", - "nowiki_sample": "Kaypi wiki-shimi illak (''sin formato'') killkaykunata churapay", - "nowiki_tip": "wiki-shimi ama hapinchu", - "image_tip": "Ukupi tiyak rikcha", - "media_tip": "Archivuman tinkikuna", - "sig_tip": "Kikinpa aspiyta, punchawan pachawanpash killkan", - "hr_tip": "sirik aspi (paykunata ama ashtawan churapay)", "summary": "Uchilla rimay", "subject": "Imamanta/Uma rimay", "minoredit": "Kay killkayka uchillami kan", diff --git a/languages/i18n/rif.json b/languages/i18n/rif.json index 5d8a729d89..d86faec1de 100644 --- a/languages/i18n/rif.json +++ b/languages/i18n/rif.json @@ -190,22 +190,6 @@ "pt-userlogout": "ⴼⴼⵖ", "retypenew": "Ɛawd arri Taguri n wadaf tamaynut:", "botpasswords-label-delete": "ⴽⴽⵙ", - "bold_sample": "ⵜⵉⵔⵔⴰ ⵜⵉⵣⵓⵔⴰⵔⵉⵏ", - "bold_tip": "ⵜⵉⵔⵔⴰ ⵜⵉⵣⵓⵔⴰⵔⵉⵏ", - "italic_sample": "Tirra titalyanin", - "italic_tip": "Tira ifrghn.", - "link_sample": "isem n tzedayt", - "link_tip": "Tazdayt n dixl", - "extlink_sample": "http://www.example.com isem n tezdayt", - "extlink_tip": "Tazdayt n baṛṛa (qa tettud http:// prefix)", - "headline_sample": "Aḍris n ixf-isem", - "headline_tip": "Aswir 2 n ixf-isem", - "nowiki_sample": "Sideff da tirra bla taseddast(formatting) n wiki", - "nowiki_tip": "Ur tawi x taseddast(formatting) n wiki", - "image_tip": "Afaylu war-itmesebḍi", - "media_tip": "Tazdayt ufaylu", - "sig_tip": "Azewl(signature) inec ag ukud(time) .", - "hr_tip": "Acariḍ aglawan", "summary": "ⵜⵓⴳⵣⵉⵍⵜ:", "subject": "ⴰⵙⵏⵜⵍ:", "minoredit": "ⵡⴰ â´· ⴰⵙⵏⴼⵍ ⵓⵎⵥⵉⵢ", diff --git a/languages/i18n/rm.json b/languages/i18n/rm.json index 3f846d0bae..930de34ddb 100644 --- a/languages/i18n/rm.json +++ b/languages/i18n/rm.json @@ -445,23 +445,6 @@ "changeemail-none": "(nagina)", "changeemail-password": "Tes pled-clav da {{SITENAME}}:", "changeemail-submit": "Midar l'adressa dad e-mail", - "bold_sample": "Text grass", - "bold_tip": "Text grass", - "italic_sample": "Text cursiv", - "italic_tip": "Text cursiv", - "link_sample": "Titel da la colliaziun", - "link_tip": "Colliaziun interna", - "extlink_sample": "http://www.example.com link title", - "extlink_tip": "Link extern (betg emblidar il prefix http:// )", - "headline_sample": "Titel", - "headline_tip": "Titel da segund livel", - "nowiki_sample": "Scriva qua text che na duai betg vegnir formatà", - "nowiki_tip": "Ignorar las formataziuns vichi", - "image_sample": "Exempel.jpg", - "image_tip": "Integrar ina datoteca", - "media_tip": "Colliaziun ad ina datoteca", - "sig_tip": "Tia suttascripziun cun data e temp", - "hr_tip": "Lingia orizontala (betg utilisar savens!)", "summary": "Resumaziun:", "subject": "Object:", "minoredit": "Midà be bagatellas", diff --git a/languages/i18n/ro.json b/languages/i18n/ro.json index d08a6bcd79..6cc866dd80 100644 --- a/languages/i18n/ro.json +++ b/languages/i18n/ro.json @@ -39,7 +39,8 @@ "WebSourceContentRO", "MSClaudiu", "Lucdrei", - "Moyogo" + "Moyogo", + "GabiBil" ] }, "tog-underline": "Sublinierea legăturilor:", @@ -626,24 +627,6 @@ "resettokens-watchlist-token": "Jeton pentru fluxul web (Atom/RSS) al [[Special:Watchlist|modificărilor aduse paginilor pe care le urmăriți]]", "resettokens-done": "Jetoane resetate.", "resettokens-resetbutton": "Resetează jetoanele selectate", - "bold_sample": "Text aldin", - "bold_tip": "Text aldin", - "italic_sample": "Text cursiv", - "italic_tip": "Text cursiv", - "link_sample": "Titlul legăturii", - "link_tip": "Legătură internă", - "extlink_sample": "http://www.example.com titlul legăturii", - "extlink_tip": "Legătură externă (nu uitați prefixul http://)", - "headline_sample": "Text de titlu", - "headline_tip": "Titlu de nivel 2", - "nowiki_sample": "Introduceți text neformatat aici", - "nowiki_tip": "Ignoră formatarea wiki", - "image_sample": "Exemplu.jpg", - "image_tip": "Fișier inserat", - "media_sample": "Exemplu.ogg", - "media_tip": "Legătură la fișier", - "sig_tip": "Semnătura dumneavoastră datată", - "hr_tip": "Linie orizontală (folosiți-o cumpătat)", "summary": "Rezumat:", "subject": "Subiect / titlu:", "minoredit": "Aceasta este o modificare minoră", @@ -710,7 +693,7 @@ "userinvalidconfigtitle": "<strong>Avertizare:</strong> 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!", + "previewnote": "<strong>Țineți cont că aceasta este doar o previzualizare.</strong>\nModificările dumneavoastră nu au fost încă salvate!", "continue-editing": "Mergi la zona de editare", "previewconflict": "Această pre-vizualizare reflectă textul din caseta de sus, respectiv felul în care va arăta articolul dacă alegeți să-l salvați acum.", "session_fail_preview": "Ne pare rău! Nu am putut procesa modificarea dumneavoastră din cauza pierderii datelor sesiunii.\n\nEste posibil să vă fi deconectat. <strong>Vă rugăm să verificați dacă sunteți încă conectat și să încercați din nou</strong>.\nDacă tot nu funcționează, încercați să [[Special:UserLogout|închideți sesiunea]] și să vă autentificați din nou. Verificați și dacă navigatorul dumneavoastră permite module cookie de la acest site.", @@ -1539,6 +1522,8 @@ "rcfilters-filter-showlinkedto-label": "Arată schimbările din paginile ce trimit la", "rcfilters-filter-showlinkedto-option-label": "<strong>Pages ce trimit la</strong> pagina selectată", "rcfilters-target-page-placeholder": "Introduceți numele unei pagini (sau categorii)", + "rcfilters-allcontents-label": "Tot conținutul", + "rcfilters-alldiscussions-label": "Toate discuțiile", "rcnotefrom": "Dedesubt {{PLURAL:$5|se află o modificare|sunt modificările}} începând cu <b>$3, $4</b> (maximum <b>$1</b> afișate).", "rclistfromreset": "Resetați selectarea datei", "rclistfrom": "Afișează modificările începând cu $3, ora $2", @@ -2337,9 +2322,9 @@ "sessionfailure": "Se pare că este o problemă cu sesiunea de autentificare; această acțiune a fost oprită ca o precauție împotriva furtului sesiunii. Vă rugăm să trimiteți formularul din nou.", "changecontentmodel": "Modificare model de conținut al unei pagini", "changecontentmodel-legend": "Modifică modelul de conținut", - "changecontentmodel-title-label": "Titlul paginii", + "changecontentmodel-title-label": "Titul paginii:", "changecontentmodel-current-label": "Modelul de conținut curent:", - "changecontentmodel-model-label": "Model de conținut nou", + "changecontentmodel-model-label": "Model de conținut nou:", "changecontentmodel-reason-label": "Motiv:", "changecontentmodel-submit": "Schimbă", "changecontentmodel-success-title": "Modelul de conținut a fost modificat", diff --git a/languages/i18n/roa-tara.json b/languages/i18n/roa-tara.json index a55c17d97c..b846a3fed7 100644 --- a/languages/i18n/roa-tara.json +++ b/languages/i18n/roa-tara.json @@ -60,6 +60,7 @@ "tog-useeditwarning": "Avvisave quanne jie lasse 'na pàgene cangiate senze ca agghie sarvate le cangiaminde", "tog-prefershttps": "Ause sembre 'na connessione secure quanne trase", "tog-showrollbackconfirmation": "Fà 'ndrucà 'na richieste de conferme quanne ste cazze sus a 'nu collegamende de annullamende", + "tog-requireemail": "Richeiste email pe l'azzeramende d'a passuord", "underline-always": "Sembre", "underline-never": "Maje", "underline-default": "Valore de default d'u browser o scheme", @@ -182,7 +183,7 @@ "printableversion": "Versione ca se stambe", "permalink": "Collegamende ca remane pe sembre", "print": "Stambe", - "view": "Vide", + "view": "'Ndruche", "view-foreign": "'Ndruche sus a $1", "edit": "Cange", "edit-local": "Cange 'a descrizione locale", @@ -190,7 +191,7 @@ "create-local": "Aggiunge 'a descrizione locale", "delete": "Scangìlle", "undelete_short": "Annulle {{PLURAL:$1|'nu camgiamende|$1 cangiaminde}}", - "viewdeleted_short": "Vide {{PLURAL:$1|'nu cangiamende scangellate|$1 cangiaminde scangellate}}", + "viewdeleted_short": "'Ndruche {{PLURAL:$1|'nu cangiamende scangellate|$1 cangiaminde scangellate}}", "protect": "Prutette", "protect_change": "cange", "unprotect": "Cange 'a protezione", @@ -204,12 +205,12 @@ "tool-link-userrights": "Cange le gruppe {{GENDER:$1|utinde}}", "tool-link-userrights-readonly": "'Ndruche le gruppe {{GENDER:$1|utinde}}", "tool-link-emailuser": "Manne 'na mail a stu {{GENDER:$1|utende}}", - "imagepage": "Vide a pàgene de le file", - "mediawikipage": "Vide a pàgene de le messàgge", - "templatepage": "Vide a pàgene de le template", - "viewhelppage": "Vide a pàgene de l'ajute", - "categorypage": "Vide a pàgene de le categorije", - "viewtalkpage": "Vide le 'ngazzaminde", + "imagepage": "'Ndruche 'a pàgene de le file", + "mediawikipage": "'Ndruche 'a pàgene de le messàgge", + "templatepage": "'Ndruche 'a pàgene de le template", + "viewhelppage": "'Ndruche 'a pàgene de l'ajute", + "categorypage": "'Ndruche 'a pàgene de le categorije", + "viewtalkpage": "'Ndruche le 'ngazzaminde", "otherlanguages": "Jndr'à l'otre lènghe", "redirectedfrom": "(Riderette da $1)", "redirectpagesub": "Pàgene de redirezione", @@ -438,7 +439,7 @@ "createaccountmail": "Ause 'na passuord temboranèe a uecchije e mannale a l'indirizze email specificate", "createaccountmail-help": "Pò essere ausate pe ccrejà 'n'utende pe 'n'otre crestiane senze ca adda canoscere 'a passuord.", "createacct-realname": "Nome vere (opzionale)", - "createacct-reason": "Mutive", + "createacct-reason": "Mutive (archiviate pubblecamende)", "createacct-reason-ph": "Purcé tu ste ccreje 'n'otre cunde utende?", "createacct-reason-help": "Messàgge 'ndrucate jndr'à l'archivije d'a ccrejazzione de le utinde", "createacct-submit": "Ccreje 'u cunde utende tune", @@ -604,24 +605,6 @@ "resettokens-watchlist-token": "Gettone pu feed web (Atom/RSS) de [[Special:Watchlist|le cangiaminde de le pàggene condrollate]]", "resettokens-done": "Gettone azzerate.", "resettokens-resetbutton": "Azzere le gettone scacchiate", - "bold_sample": "Teste grascette", - "bold_tip": "Teste grascette", - "italic_sample": "Teste corsive", - "italic_tip": "Scritte in corsivo", - "link_sample": "Titele d'u collegamende", - "link_tip": "Collegamende 'nderne", - "extlink_sample": "http://www.example.com Nome d'u collegamende", - "extlink_tip": "Collegamende de fore a Uicchipedie (arrecuerdete 'u prefisse http://)", - "headline_sample": "Teste d'a Testete", - "headline_tip": "Levèlle 2 tèstete", - "nowiki_sample": "Mitte 'u teste non formattate aqquà", - "nowiki_tip": "No scè penzanne 'a formattazione de Uicchi", - "image_sample": "Esembie.jpg", - "image_tip": "File ingapsulete", - "media_sample": "Esembie.ogg", - "media_tip": "File de collegamende", - "sig_tip": "'A firma toje cu l'orarie e 'a sciurnete", - "hr_tip": "Linee orizzondele (ausele picche)", "summary": "Riepileghe:", "subject": "Oggette:", "minoredit": "Cangiaminde stuèdeche", @@ -724,6 +707,8 @@ "nocreate-loggedin": "Non ge tine le permesse pe ccreja pàggene nuève.", "sectioneditnotsupported-title": "Sezione de le cangiaminde none supportate", "sectioneditnotsupported-text": "Sezione de le cangiaminde non g'è supportate sus a sta pàgene de cangiaminde.", + "modeleditnotsupported-title": "'U cangiamende non g'è supportate", + "modeleditnotsupported-text": "'U cangiamende non g'è supportate pu modelle de condenute $1.", "permissionserrors": "Errore de permesse", "permissionserrorstext": "Tu non ge tine 'u permesse pe fà ste cose, pe {{PLURAL:$1|stu mutive|ste mutive}}:", "permissionserrorstext-withaction": "Tu non ge tine 'u permesse pe $2, pe {{PLURAL:$1|stu mutive|ste mutive}}:", @@ -758,6 +743,9 @@ "content-model-css": "CSS", "content-json-empty-object": "Oggette vacande", "content-json-empty-array": "Matrice vacande", + "unsupported-content-model": "<strong>Attenziò:</strong> 'u modelle de condenute $1 non g'è supportate jndr'à sta uicchi.", + "unsupported-content-diff": "Le differenze non ge sò supportate pu modelle de condenute $1.", + "unsupported-content-diff2": "Le differenze 'mbrà le modelle de condenute $1 e $2 non ge sò supportate sus a sta uicchi.", "deprecated-self-close-category": "Lè pàggene ca ausane le tag HTML auto-achiuse invalide", "duplicate-args-warning": "<strong>Attenziò:</strong> [[:$1]] ste chiame [[:$2]] cu cchiù de 'nu valore pu parametre \"$3\". Sulamende l'urteme valore date avène ausate.", "duplicate-args-category": "Pàggene ca ausane le argumende a doppie jndr'à le chiamate d'u template", @@ -1454,6 +1442,9 @@ "rcfilters-exclude-button-off": "Scitte le scacchiate", "rcfilters-exclude-button-on": "Scettanne le scacchiate", "rcfilters-view-tags": "Cangiaminde taggate", + "rcfilters-view-namespaces-tooltip": "Filtre le resultate pe namespace", + "rcfilters-view-tags-tooltip": "Filtre le resultate ausanne le tag de cangiamende", + "rcfilters-view-return-to-default-tooltip": "Tuèrne a 'u menu de le filtre prengepàle", "rcfilters-liveupdates-button": "Aggiornaminde in tiembe reale", "rcfilters-liveupdates-button-title-on": "Stute le aggiornaminde automatece", "rcfilters-watchlist-markseen-button": "Signe tutte le cangiaminde cumme 'ndrucate", @@ -1716,6 +1707,7 @@ "listfiles-userdoesnotexist": "Nome utende \"$1\" non g'è reggistrate.", "imgfile": "file", "listfiles": "Liste de le fail", + "listfiles_subpage": "Carecaminde da $1", "listfiles_thumb": "Miniature", "listfiles_date": "Sciurne", "listfiles_name": "Nome", @@ -2400,6 +2392,7 @@ "ipblocklist-legend": "Iacchije 'n'utende blocchete", "blocklist-userblocks": "Scunne le blocche sus a le cunde de l'utinde", "blocklist-tempblocks": "Scunne le blocche temboranèe", + "blocklist-indefblocks": "Scunne le blocche indefinite", "blocklist-addressblocks": "Scunne le blocche de le IP singole", "blocklist-type": "Tipe:", "blocklist-type-opt-all": "Tutte", diff --git a/languages/i18n/ru.json b/languages/i18n/ru.json index d6094cd56e..d3475a505b 100644 --- a/languages/i18n/ru.json +++ b/languages/i18n/ru.json @@ -146,7 +146,8 @@ "ЛингвоЧел", "OlegVeliky", "Saimongoltinio", - "Wikisaurus" + "Wikisaurus", + "Katunchik" ] }, "tog-underline": "Подчёркивание ссылок:", @@ -193,6 +194,7 @@ "tog-useeditwarning": "Предупреждать, когда я покидаю страницу с несохранёнными изменениями", "tog-prefershttps": "Всегда использовать защищённое соединение после представления системе", "tog-showrollbackconfirmation": "Запрашивать подтверждение при нажатии ссылки для отката", + "tog-requireemail": "Требовать адрес электронной почты для сброса пароля", "underline-always": "Всегда", "underline-never": "Никогда", "underline-default": "Использовать настройки браузера", @@ -570,7 +572,7 @@ "createaccountmail": "Использовать сгенерированный случайным образом временный пароль и выслать его на указанный адрес электронной почты", "createaccountmail-help": "Может использоваться, чтобы создать учётную запись для другого лица, не узнавая пароль.", "createacct-realname": "Настоящее имя (необязательно)", - "createacct-reason": "Причина", + "createacct-reason": "Причина (публично видимая)", "createacct-reason-ph": "Зачем вы создаёте другую учётную запись", "createacct-reason-help": "Сообщение, отображаемое в журнале создания учётных записей", "createacct-submit": "Создать учётную запись", @@ -738,24 +740,6 @@ "resettokens-watchlist-token": "Токен для веб-канала (Atom/RSS) [[Special:Watchlist|изменений страниц в вашем списке наблюдения]]", "resettokens-done": "Токены сброшены.", "resettokens-resetbutton": "Сбросить выбранные токены", - "bold_sample": "Полужирное начертание", - "bold_tip": "Полужирное начертание", - "italic_sample": "Курсивное начертание", - "italic_tip": "Курсивное начертание", - "link_sample": "Заголовок ссылки", - "link_tip": "Внутренняя ссылка", - "extlink_sample": "http://www.example.com заголовок ссылки", - "extlink_tip": "Внешняя ссылка (помните о префиксе http:// )", - "headline_sample": "Текст заголовка", - "headline_tip": "Заголовок 2-го уровня", - "nowiki_sample": "Вставьте сюда текст, который не нужно форматировать", - "nowiki_tip": "Игнорировать вики-форматирование", - "image_sample": "Пример.jpg", - "image_tip": "Встроенный файл", - "media_sample": "Пример.ogg", - "media_tip": "Ссылка на файл", - "sig_tip": "Ваша подпись и момент времени", - "hr_tip": "Горизонтальная линия (не используйте слишком часто)", "summary": "Описание изменений:", "subject": "Тема/заголовок:", "minoredit": "Малое изменение", @@ -939,6 +923,7 @@ "undo-norev": "Правка не может быть отменена, так как её не существует или она была удалена.", "undo-nochange": "Правка, похоже, уже была отменена.", "undo-summary": "Отмена правки $1, сделанной [[Special:Contributions/$2|$2]] ([[User talk:$2|обсуждение]])", + "undo-summary-anon": "Отмена версии $1 от [[Special:Contributions/$2|$2]]", "undo-summary-username-hidden": "Отмена правки $1, сделанной участником, чьё имя скрыто", "cantcreateaccount-text": "Создание учётных записей с этого IP-адреса (<strong>$1</strong>) было заблокировано {{GENDER:$3|участником|участницей|}} [[User:$3|$3]].\n\n$3 {{GENDER:$3|указал|указала}} следующую причину: <em>$2</em>.", "cantcreateaccount-range-text": "{{GENDER:$3|Участник|Участница}} [[User:$3|$3]] {{GENDER:$3|установил|установила}} запрет на создание учётных записей для диапазона IP-адресов <strong>$1</strong>, включающего ваш IP-адрес (<strong>$4</strong>). \n\nБыла указана следующая причина: <em>$2</em>.", @@ -1236,6 +1221,7 @@ "prefs-help-email": "Адрес почты не обязателен, но это единственный способ восстановить забытый пароль.", "prefs-help-email-others": "Он также позволит другим участникам связаться с вами по электронной почте с помощью ссылки на вашей персональной странице или на вашей странице обсуждения. При этом ваш адрес электронной почты не будет никому раскрыт.", "prefs-help-email-required": "Необходимо указать адрес электронной почты.", + "prefs-help-requireemail": "Если этот флажок установлен, электронные письма для сброса пароля будут отправляться только в том случае, если лицо, осуществляющее сброс, указало для этой учётной записи и имя пользователя, и адрес электронной почты.", "prefs-info": "Основные сведения", "prefs-i18n": "Интернационализация", "prefs-signature": "Подпись", @@ -1955,6 +1941,7 @@ "listfiles-userdoesnotexist": "Учётная запись «$1» не зарегистрирована.", "imgfile": "файл", "listfiles": "Список файлов", + "listfiles_subpage": "Загрузки $1", "listfiles_thumb": "Миниатюра", "listfiles_date": "Дата", "listfiles_name": "Имя файла", @@ -2456,6 +2443,7 @@ "alreadyrolled": "Невозможно откатить последние изменения страницы «[[:$1]]», совершённые [[User:$2|$2]] ([[User talk:$2|обсуждение]]{{int:pipe-separator}}[[Special:Contributions/$2|{{int:contribslink}}]]),\nпоскольку кто-то другой уже успел откатить эти правки или отредактировать страницу.\n\nПоследние изменения {{GENDER:$3|внёс|внесла}} [[User:$3|$3]] ([[User talk:$3|обсуждение]]{{int:pipe-separator}}[[Special:Contributions/$3|{{int:contribslink}}]]).", "editcomment": "Было дано описание изменения: <em>$1</em>.", "revertpage": "Откат правок [[Special:Contributions/$2|$2]] ([[User talk:$2|обсуждение]]) к версии [[User:$1|$1]]", + "revertpage-anon": "Откат правок [[Special:Contributions/$2|$2]] к последней версии от [[User:$1|$1]]", "revertpage-nouser": "Откат правок (имя участника скрыто) к версии {{GENDER:$1|[[User:$1|$1]]}}", "rollback-success": "Откачены правки {{GENDER:$3|$1}}; возвращена последняя версия {{GENDER:$4|$2}}.", "sessionfailure-title": "Ошибка сеанса", @@ -2692,6 +2680,7 @@ "ipblocklist-legend": "Поиск заблокированного участника", "blocklist-userblocks": "Скрыть блокировки учётных записей", "blocklist-tempblocks": "Скрыть временные блокировки", + "blocklist-indefblocks": "Скрыть бессрочные блокировки", "blocklist-addressblocks": "Скрыть блокировки отдельных IP", "blocklist-type": "Тип:", "blocklist-type-opt-all": "Все", @@ -4068,5 +4057,8 @@ "mycustomjsredirectprotected": "У вас нет прав на редактирование этой JavaScript-страницы, так как она является перенаправлением и не указывает внутрь вашего пространства участника.", "easydeflate-invaliddeflate": "Предоставленное содержимое не спущено надлежащим образом", "unprotected-js": "По соображениям безопасности JavaScript нельзя загружать с незащищённых страниц. Пожалуйста, создавайте скрипты только в пространстве имён MediaWiki: или как подстраницы участника.", - "userlogout-continue": "Вы хотите выйти?" + "userlogout-continue": "Вы хотите выйти?", + "rest-prefix-mismatch": "Запрашиваемый путь ($1) не найден внутри корневого пути REST API ($2)", + "rest-wrong-method": "Метод запроса ($1) не был {{{{PLURAL:$3|}}|разрешенным методом для этого пути|одним из разрешенных методов для этого пути}} ($2)", + "rest-no-match": "Запрошенный относительный путь ($1) не соответствует ни одному известному обработчику" } diff --git a/languages/i18n/rue.json b/languages/i18n/rue.json index 443cbffa11..a1a1d842e4 100644 --- a/languages/i18n/rue.json +++ b/languages/i18n/rue.json @@ -504,22 +504,6 @@ "resettokens-watchlist-token": "Кліч до вебового канала (Atom/RSS) [[Special:Watchlist|змін слїдованых сторінок]]", "resettokens-done": "Клічі были реініціалізованы.", "resettokens-resetbutton": "Реініціалізовати зволены клічі", - "bold_sample": "Товстый текст", - "bold_tip": "Шырокый текст", - "italic_sample": "Курсива", - "italic_tip": "Курсива", - "link_sample": "Назва одказу", - "link_tip": "Інтерный одказ", - "extlink_sample": "http://www.example.com назва одказу", - "extlink_tip": "Екстерный одказ (не забудьте http:// prefix)", - "headline_sample": "Текст надпису", - "headline_tip": "Надпис 2-го рівня", - "nowiki_sample": "Вложте ту неформатованый текст", - "nowiki_tip": "Іґноровати вікі-форматованя", - "image_tip": "Файл", - "media_tip": "Одказ на медіа-файл", - "sig_tip": "Ваш підпис з датумом і часом", - "hr_tip": "Горізонтална лінія (хоснуйте єй скупо)", "summary": "Куртый опис змін:", "subject": "Тема:", "minoredit": "Незначна зміна", diff --git a/languages/i18n/sa.json b/languages/i18n/sa.json index 893d23dbbb..a5f6c7c999 100644 --- a/languages/i18n/sa.json +++ b/languages/i18n/sa.json @@ -536,24 +536,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|भवतः/भवत्याः ध्यानसूच्याः परिवर्तनस्य]] जालपूर्तेः (Atom/RSS) चिह्नं", "resettokens-done": "चिह्नं परिवर्त्यताम्", "resettokens-resetbutton": "अङ्कितं चिह्नं परिवर्त्यताम्", - "bold_sample": "स्थूलाक्षराणि", - "bold_tip": "स्थूलाक्षराणि", - "italic_sample": "तिर्यक् अक्षरम्", - "italic_tip": "तिर्यक् अक्षरम्", - "link_sample": "परिसन्धेः शीर्षकम्", - "link_tip": "आन्तरिकसम्पर्कतन्तुः", - "extlink_sample": "http://www.example.com परिसन्धेः शीर्षकम्", - "extlink_tip": "बाह्यानुबन्धः (http:// पूर्वन्यासस्य अग्रे योजनीयम् इति स्मरतु)", - "headline_sample": "शीर्षकम्", - "headline_tip": "द्वितीयस्तरीयं शीर्षकम्", - "nowiki_sample": "अप्रारूपितं पाठम् अत्र निवेश्यताम्", - "nowiki_tip": "विकि-प्रारूपम् उपेक्ष्यताम्", - "image_sample": "उदाहरणम्.jpg", - "image_tip": "अन्तर्निहिता सञ्चिका", - "media_sample": "उदाहरणम्.ogg", - "media_tip": "सञ्चिकासम्बन्धः", - "sig_tip": "समयोल्लेखेन सह भवतः/भवत्याः हस्ताक्षरम्", - "hr_tip": "तिर्यक्-रेखा (भिन्नतया प्रयोक्तव्या)", "summary": "सारांशः :", "subject": "विषयः/शीर्षकम् :", "minoredit": "इदं लघु सम्पादनम्", diff --git a/languages/i18n/sah.json b/languages/i18n/sah.json index 011a9e38f0..c52e670174 100644 --- a/languages/i18n/sah.json +++ b/languages/i18n/sah.json @@ -601,24 +601,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|Кэтиир сирэйдэриҥ уларыйыыларын]] ситим-ханаалын (Atom/RSS) токена", "resettokens-done": "Токен сотулунна.", "resettokens-resetbutton": "Талыллыбыты сот", - "bold_sample": "Модьу бичик", - "bold_tip": "Модьу бичик", - "italic_sample": "Иҥнэри бичик", - "italic_tip": "Иҥнэри бичик", - "link_sample": "Ыйынньык баһа", - "link_tip": "Ис ыйынньык", - "extlink_sample": "http://www.example.com ыйынньык баһа", - "extlink_tip": "Тас ыйынньык (http:// префиксы умнума)", - "headline_sample": "Бас тыл", - "headline_tip": "2-с таһым бас тыла", - "nowiki_sample": "Манна форматтамматах суругу киллэриҥ", - "nowiki_tip": "Биики формаатын билинимэ", - "image_sample": "Холобур.jpg", - "image_tip": "Ойууну олордуу", - "media_sample": "Холобур.ogg", - "media_tip": "Медиа билэҕэ сигэнии", - "sig_tip": "Илии баттааһыныҥ уонна хаһан илии баттаабытыҥ", - "hr_tip": "Туора сурааһын (наһаа элбэхтик туттума)", "summary": "Уларытыыҥ ис хоһооно:", "subject": "Тиэмэтэ:", "minoredit": "Бу суолтата суох уларытыы", diff --git a/languages/i18n/sat.json b/languages/i18n/sat.json index d48829e663..61af209a61 100644 --- a/languages/i18n/sat.json +++ b/languages/i18n/sat.json @@ -493,22 +493,6 @@ "changeemail-none": "(ᱪᱮᱫ ᱦᱚᱸ ᱵᱟᱹᱱᱩᱜ-ᱟ)", "changeemail-password": "ᱟᱢᱟᱜ {{SITENAME}} ᱫᱟᱱᱟᱝ ᱥᱟᱵᱟᱽ:", "changeemail-submit": "ᱤ-ᱢᱮᱞ ᱵᱚᱫᱚᱞᱢᱮ", - "bold_sample": "ᱢᱚᱴᱟ ᱚᱞ", - "bold_tip": "ᱢᱚᱴᱟ ᱚᱞ", - "italic_sample": "ᱜᱷᱟᱸᱡᱮᱲ ᱚᱞ", - "italic_tip": "ᱜᱷᱟᱸᱡᱮᱲ ᱚᱞ", - "link_sample": "ᱡᱚᱱᱚᱲ ᱴᱟᱭᱴᱮᱞ", - "link_tip": "ᱵᱷᱤᱛᱨᱤ ᱡᱚᱱᱚᱲ", - "extlink_sample": "http://www.example.com ᱡᱚᱱᱚᱲ ᱴᱟᱭᱴᱮᱞ", - "extlink_tip": "ᱵᱟᱨᱦᱮ ᱡᱚᱱᱚᱲ (ᱫᱤᱥᱟᱹᱭᱢᱮ http:// prefix)", - "headline_sample": "ᱵᱚᱦᱚᱜ ᱨᱮᱱᱟᱜ ᱚᱞ", - "headline_tip": "ᱞᱮᱵᱷᱮᱞ ᱒ ᱦᱮᱰᱞᱟᱭᱤᱱ", - "nowiki_sample": "ᱵᱮᱜᱚᱨ ᱯᱷᱚᱨᱢᱮᱴ ᱚᱞᱠᱩ ᱵᱷᱚᱨᱟᱣᱢᱮ", - "nowiki_tip": "ᱣᱤᱠᱤ ᱯᱷᱚᱨᱢᱟᱴᱤᱝ ᱵᱟᱹᱜᱤᱭᱢᱮ", - "image_tip": "ᱛᱚᱞᱟᱠᱟᱱ ᱨᱮᱫ", - "media_tip": "ᱨᱮᱫ ᱡᱚᱱᱚᱲ", - "sig_tip": "ᱟᱢᱟᱜ ᱥᱩᱦᱤ ᱥᱟᱶᱛᱮ ᱚᱠᱛᱚ ᱪᱷᱟᱯ", - "hr_tip": "ᱵᱟᱨᱟᱵᱟᱹᱨᱤ ᱫᱟᱜᱽ", "summary": "ᱢᱩᱬᱩᱛ ᱠᱟᱛᱦᱟ:", "subject": "ᱥᱟᱛᱟᱢ:", "minoredit": "ᱱᱚᱣᱟ ᱫᱚ ᱦᱩᱰᱤᱧ ᱥᱟᱯᱲᱟᱣ ᱠᱟᱱᱟ", @@ -545,7 +529,7 @@ "noarticletext": "ᱱᱮᱛᱚᱜ ᱱᱚᱣᱟ ᱥᱟᱦᱴᱟᱨᱮ ᱪᱮᱫᱜᱮ ᱵᱟᱹᱱᱩᱜ-ᱟ᱾\nᱮᱴᱟᱜ ᱥᱟᱦᱴᱟᱨᱮᱢ [[Special:Search/{{PAGENAME}}|ᱱᱚᱶᱟ ᱥᱟᱦᱴᱟ ᱧᱩᱛᱩᱢ ᱥᱮᱸᱫᱽᱨᱟᱭ ᱢᱮ]],\n<span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} ᱡᱚᱲᱟᱣᱟᱱ ᱞᱚᱜᱽ ᱠᱚ ᱥᱮᱸᱫᱽᱨᱟᱭ ᱢᱮ],\nor [{{fullurl:{{FULLPAGENAME}}|action=edit}} ᱱᱚᱶᱟ ᱥᱟᱦᱴᱟ ᱥᱟᱯᱲᱟᱣ ᱢᱮ]</span>.", "noarticletext-nopermission": "ᱱᱚᱣᱟ ᱥᱟᱦᱴᱟᱨᱮ ᱱᱤᱛᱚᱜ ᱪᱮᱫᱜᱮ ᱚᱞ ᱵᱟᱹᱱᱩᱜ-ᱟ᱾\n\nᱟᱢ [[Special:Search/{{PAGENAME}}|ᱱᱚᱭᱟ ᱥᱟᱦᱴᱟᱨᱮᱱᱟᱜ ᱧᱤᱛᱩᱢᱮᱢ ᱥᱮᱸᱫᱽᱨᱟ ᱫᱟᱲᱮᱭᱟᱜ-ᱟ]] ᱮᱴᱟᱜ ᱥᱟᱦᱴᱟ ᱠᱚᱨᱮᱦᱚᱸ,\nᱟᱨᱵᱟᱝ <span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} search the related logs]</span>.", "userpage-userdoesnotexist": "\"<nowiki>$1</nowiki>\" ᱧᱩᱛᱩᱢᱟᱱ ᱡᱟᱸᱦᱟᱸᱭ ᱵᱮᱵᱷᱟᱨᱤᱭᱟᱜ ᱦᱤᱥᱟᱹᱵ ᱠᱷᱟᱛᱷᱟ ᱫᱚ ᱵᱟᱝ ᱨᱮᱥᱴᱨᱤ ᱦᱩᱭ ᱟᱠᱟᱱᱟ᱾\nᱫᱟᱭᱟᱠᱟᱛᱮ ᱵᱤᱰᱟᱹᱣ ᱠᱟᱛᱮᱛ ᱧᱮᱞᱢᱮ ᱱᱚᱣᱟ ᱥᱟᱦᱴᱟ ᱫᱚ ᱵᱮᱱᱟᱣ/ᱥᱟᱯᱲᱟᱣ ᱢᱮᱱᱮᱫ ᱠᱟᱱᱟ ᱥᱮ ᱵᱟᱝ᱾", - "userpage-userdoesnotexist-view": "ᱵᱮᱵᱦᱟᱨᱤᱭᱟᱜ \"$1\" ᱮᱠᱟᱣᱱᱴ ᱫᱚ ᱵᱟᱝ ᱨᱮᱥᱴᱨᱤ ᱟᱠᱟᱱᱟ᱾", + "userpage-userdoesnotexist-view": "ᱵᱮᱵᱦᱟᱨᱤᱭᱟᱹ \"$1\" ᱮᱠᱟᱶᱩᱴ ᱫᱚ ᱵᱟᱝ ᱨᱮᱥᱴᱨᱤ ᱟᱠᱟᱱᱟ᱾", "blocked-notice-logextract": "ᱱᱩᱭ ᱵᱮᱵᱦᱟᱨᱤᱡ ᱫᱚ ᱱᱮᱛᱚᱜ á±® ᱥᱮᱥᱫᱜᱮᱭᱟ᱾\nᱨᱮᱯᱷᱟᱨᱮᱱᱥ ᱞᱟᱹᱜᱤᱛᱛᱮ ᱱᱟᱣᱟᱱᱟᱜ ᱵᱚᱞᱚᱜ ᱠᱩᱨᱩᱢᱩᱴᱩ ᱞᱟᱛᱟᱨᱨᱮ ᱮᱢ ᱦᱩᱭᱱᱟ:", "clearyourcache": "<strong>ᱧᱮᱛᱮᱞ:</strong> ᱨᱩᱠᱷᱤᱭᱟᱹ ᱦᱩᱭ ᱠᱟᱛᱮ, ᱟᱢᱟᱜ ᱵᱨᱟᱣᱡᱚᱨ ᱠᱮᱪ ᱵᱟᱭᱯᱟᱥ ᱦᱩᱭᱩᱜ ᱛᱟᱢᱟ ᱚᱫᱚᱞ ᱠᱚ ᱧᱮᱞ ᱞᱟᱹᱜᱤᱫ á±¾\n* <strong>ᱯᱷᱟᱭᱟᱨᱯᱷᱚᱠᱥ / ᱥᱟᱯᱷᱟᱨᱤ:</strong> Hold <em>Shift</em> while clicking <em>Reload</em>, or press either <em>Ctrl-F5</em> or <em>Ctrl-R</em> (<em>⌘-R</em> on a Mac)\n* <strong>Google Chrome:</strong> Press <em>Ctrl-Shift-R</em> (<em>⌘-Shift-R</em> on a Mac)\n* <strong>Internet Explorer:</strong> Hold <em>Ctrl</em> while clicking <em>Refresh</em>, or press <em>Ctrl-F5</em>\n* <strong>Opera:</strong> Go to <em>Menu → Settings</em> (<em>Opera → Preferences</em> on a Mac) and then to <em>Privacy & security → Clear browsing data → Cached images and files</em>.", "updated": "(ᱩᱛᱷᱱᱟᱣ ᱜᱮᱭᱟ)", @@ -698,7 +682,7 @@ "prefs-skin": "ᱦᱟᱨᱛᱟ", "skin-preview": "ᱧᱮᱞ ᱵᱤᱰᱟᱹᱣ", "datedefault": "ᱠᱩᱥᱤ ᱵᱟᱹᱱᱩᱜ-ᱟ", - "prefs-user-pages": "ᱵᱮᱵᱦᱟᱨᱤᱭᱟᱜ ᱥᱟᱦᱴᱟᱠᱚ", + "prefs-user-pages": "ᱵᱮᱵᱷᱟᱨᱤᱭᱟᱹ ᱥᱟᱦᱴᱟᱠᱚ", "prefs-rc": "ᱨᱚᱠᱟ ᱵᱚᱫᱚᱞᱠᱚ", "prefs-watchlist": "ᱧᱮᱞᱟᱜ ᱞᱤᱥᱴᱤ", "prefs-editwatchlist": "ᱧᱮᱞᱟᱜ ᱞᱤᱥᱴᱤ ᱥᱟᱯᱲᱟᱣ", @@ -743,9 +727,9 @@ "prefs-editor": "ᱥᱟᱯᱲᱮᱛ", "prefs-preview": "ᱧᱮᱞ ᱵᱤᱰᱟᱹᱣ", "prefs-diffs": "ᱵᱷᱮᱯᱮᱫ", - "userrights": "ᱵᱮᱵᱦᱟᱨᱤᱭᱟᱜ ᱟᱹᱭᱫᱟᱹᱨᱤ ᱠᱩ", + "userrights": "ᱵᱮᱵᱷᱟᱨᱤᱭᱟᱜ ᱟᱹᱭᱫᱟᱹᱨᱤ ᱠᱩ", "userrights-lookup-user": "ᱢᱤᱫᱴᱮᱱ ᱵᱮᱵᱦᱟᱨᱤ ᱴᱷᱤᱠᱤ ᱢᱮ", - "userrights-user-editname": "ᱵᱮᱵᱦᱟᱨᱤᱭᱟᱜ ᱧᱤᱛᱩᱢ ᱵᱚᱞᱚᱭ ᱢᱮ:", + "userrights-user-editname": "ᱵᱮᱵᱷᱟᱨᱤᱭᱟᱜ ᱧᱤᱛᱩᱢ ᱟᱫᱮᱨ ᱢᱮ:", "editusergroup": "ᱵᱮᱵᱦᱟᱨᱤ ᱜᱟᱶᱛᱟᱠᱩ ᱩᱰᱩᱜᱽ ᱢᱮ", "userrights-editusergroup": "ᱥᱟᱯᱲᱟᱣ {{GENDER:$1|ᱵᱮᱵᱦᱟᱨᱤ}} ᱜᱟᱶᱛᱟᱠᱩ", "saveusergroups": "ᱨᱩᱠᱷᱤᱭᱟᱹ {{GENDER:$1|ᱵᱮᱵᱦᱟᱨᱤ}} ᱜᱟᱶᱛᱟᱠᱩ", @@ -1022,7 +1006,7 @@ "tooltip-namespace_association": "ᱱᱚᱶᱟ ᱵᱟᱠᱥᱟ ᱴᱤᱠ ᱢᱮ ᱨᱚᱯᱚᱲ ᱵᱟᱝᱠᱷᱟᱱ ᱥᱟᱛᱟᱢ ᱨᱟᱠᱷᱟ ᱧᱩᱛᱩᱢ ᱵᱟᱪᱷᱚᱱ ᱟᱠᱟᱱ ᱨᱟᱠᱷᱟ ᱧᱩᱛᱩᱢ ᱥᱟᱶ ᱡᱚᱯᱚᱲᱟᱣ ᱟᱠᱟᱱᱟᱜ", "blanknamespace": "(ᱢᱩᱬᱩᱛ)", "contributions": "{{GENDER:$1|ᱵᱮᱵᱦᱟᱨᱤᱭᱟᱹ}} ᱮᱱᱮᱢᱠᱩ", - "contributions-title": "$1 ᱵᱮᱵᱦᱟᱨᱤᱭᱟᱜ ᱮᱱᱮᱢᱠᱩ", + "contributions-title": "$1 ᱵᱮᱵᱷᱟᱨᱤᱭᱟᱜ ᱮᱱᱮᱢᱠᱩ", "mycontris": "ᱮᱱᱮᱢᱠᱩ", "anoncontribs": "ᱮᱱᱮᱢᱠᱩ", "contribsub2": "{{GENDER:$3|$1}} ($2) ᱞᱟᱹᱜᱤᱫ ᱛᱮ", @@ -1035,7 +1019,7 @@ "sp-contributions-logs": "ᱛᱟᱞᱟᱠᱩ", "sp-contributions-talk": "ᱨᱚᱲ", "sp-contributions-search": "ᱮᱱᱮᱢᱠᱩ ᱞᱟᱹᱜᱤᱛ ᱥᱮᱸᱫᱨᱟ", - "sp-contributions-username": "IP ᱴᱷᱤᱠᱟᱹᱱᱟ ᱥᱮ ᱵᱮᱵᱦᱟᱨᱤᱭᱟᱜ ᱧᱩᱛᱩᱢ", + "sp-contributions-username": "IP ᱴᱷᱤᱠᱟᱹᱱᱟ ᱥᱮ ᱵᱮᱵᱷᱟᱨᱤᱭᱟᱹ ᱧᱩᱛᱩᱢ", "sp-contributions-toponly": "ᱱᱮᱛᱟᱨ ᱥᱩᱫᱷᱨᱟᱹᱣ ᱠᱚᱨᱮᱭᱟᱜ ᱥᱟᱯᱲᱟᱣ ᱠᱟᱹᱢᱤᱠᱚ ᱩᱫᱩᱜᱽ ᱢᱮ", "sp-contributions-newonly": "ᱥᱩᱢᱩᱝ ᱟᱹᱨᱩᱠᱚ ᱥᱚᱫᱚᱨᱢᱮ ᱡᱟᱦᱟᱸ ᱥᱟᱦᱟᱴᱟ ᱫᱚ ᱥᱤᱨᱡᱟᱹᱣᱟᱜ ᱠᱟᱱᱟ", "sp-contributions-submit": "ᱥᱮᱸᱫᱽᱨᱟ", @@ -1073,7 +1057,7 @@ "reblock-logentry": "ᱵᱚᱫᱚᱞᱮᱱᱟ ᱵᱚᱸᱫ ᱥᱟᱡᱟᱣᱠᱚ [[$1]] ᱞᱟᱹᱜᱤᱫ ᱪᱟᱵᱟᱜ ᱚᱠᱛᱚ $2 $3 ᱥᱟᱶ", "block-log-flags-nocreate": "ᱮᱠᱟᱶᱩᱴ ᱵᱮᱱᱟᱣ ᱵᱚᱸᱫᱽ ᱜᱮᱭᱟ", "block-log-flags-noemail": "ᱤᱢᱮᱞ ᱵᱚᱸᱫᱷ ᱜᱮᱭᱟ", - "block-log-flags-hiddenname": "ᱵᱮᱵᱦᱟᱨᱤᱭᱟᱜ ᱧᱩᱛᱩᱢ ᱩᱠᱩ ᱜᱮᱭᱟ", + "block-log-flags-hiddenname": "ᱵᱮᱵᱷᱟᱨᱤᱭᱟᱹ ᱧᱩᱛᱩᱢ ᱩᱠᱩ ᱜᱮᱭᱟ", "proxyblocker": "ᱯᱨᱚᱠᱥᱤ ᱮᱥᱮᱫᱤᱡ", "movepagebtn": "ᱥᱟᱦᱴᱟ ᱩᱪᱟᱹᱲᱢᱮ", "pagemovedsub": "ᱚᱪᱟᱜ ᱫᱚ ᱦᱩᱭᱱᱟ", @@ -1252,7 +1236,7 @@ "logentry-move-move-noredirect": "$1 {{GENDER:$2|ᱩᱪᱟᱹᱲᱠᱮᱜ-ᱟᱭ}} ᱥᱟᱦᱴᱟ $3 to $4 ᱢᱚᱦᱰᱟ ᱵᱤᱱ ᱵᱟᱹᱜᱤ ᱠᱟᱛᱮ", "logentry-move-move_redir": "ᱥᱟᱦᱴᱟ $3 ᱠᱷᱚᱱ $4 ᱛᱮ $1 {{GENDER:$2|ᱩᱪᱟᱹᱲ ᱠᱮᱫᱼᱟᱭ}} ᱢᱚᱸᱦᱰᱟ ᱥᱟᱶᱛᱮ", "logentry-patrol-patrol-auto": "$1 ᱟᱡᱛᱮᱜᱮ {{GENDER:$2|ᱪᱤᱱᱦᱟᱹᱭᱮᱱᱟ}} $4 ᱧᱮᱞᱟᱹᱨᱩ $3 ᱥᱟᱦᱴᱟ ᱨᱮᱱᱟᱜ á±¾", - "logentry-newusers-create": "ᱵᱮᱵᱦᱟᱨᱤᱭᱟᱜ ᱦᱤᱥᱟᱹᱵ $1 ᱫᱚ {{GENDER:$2|ᱛᱮᱭᱟᱨᱱᱟ}}", + "logentry-newusers-create": "ᱵᱮᱵᱷᱟᱨᱤᱭᱟᱹ ᱮᱠᱟᱶᱩᱴ $1 ᱫᱚ {{GENDER:$2|ᱛᱮᱭᱟᱨᱮᱱᱟ}}", "logentry-newusers-autocreate": "ᱵᱮᱵᱷᱟᱨᱤᱭᱟᱹ ᱠᱷᱟᱛᱟ $1 ᱫᱚ {{GENDER:$2|ᱛᱮᱭᱟᱨᱮᱱᱟ}} ᱟᱡᱛᱮᱜᱮ", "logentry-upload-upload": "$1 {{GENDER:$2|ᱞᱟᱫᱮᱭᱮᱱᱟ}} $3", "logentry-upload-overwrite": "$1 {{GENDER:$2|ᱞᱟᱫᱮᱭᱮᱱᱟ}} ᱢᱤᱫ ᱱᱟᱶᱟ ᱵᱷᱟᱨᱥᱚᱱ $3 ᱨᱮᱱᱟᱜ", diff --git a/languages/i18n/sc.json b/languages/i18n/sc.json index 94acced2b7..1b97f70ee0 100644 --- a/languages/i18n/sc.json +++ b/languages/i18n/sc.json @@ -487,24 +487,6 @@ "changeemail-submit": "Càmbia email", "resettokens": "Reseta tokens", "resettokens-token-label": "$1 (valore atuale: $2)", - "bold_sample": "Testu grassu", - "bold_tip": "Testu grassu", - "italic_sample": "Testu cursivu", - "italic_tip": "Testu cursivu", - "link_sample": "Tìtulu ligòngiu", - "link_tip": "Ligòngiu internu", - "extlink_sample": "http://www.example.com tìtulu de su ligòngiu", - "extlink_tip": "Ligòngiu a foras (regorda su prefissu http://)", - "headline_sample": "Testu de su tìtulu", - "headline_tip": "Tìtulu de su de duos livellu", - "nowiki_sample": "Inserta su testu non-formatadu inoghe", - "nowiki_tip": "Ignora sa formatatzione wiki", - "image_sample": "Esèmpiu.jpg", - "image_tip": "Incòrpora una pintura", - "media_sample": "Esèmpiu.ogg", - "media_tip": "Ligòngiu a unu file multimediale", - "sig_tip": "Firma·ti cun data e ora", - "hr_tip": "Lìnia orizontale (de impreare cun critèriu)", "summary": "Ogetu:", "subject": "Sugetu:", "minoredit": "Custu est unu càmbiu minore", diff --git a/languages/i18n/scn.json b/languages/i18n/scn.json index 2f9216e299..f0a007eaa0 100644 --- a/languages/i18n/scn.json +++ b/languages/i18n/scn.json @@ -521,24 +521,6 @@ "resettokens-watchlist-token": "Token pû feed web (Atom/RSS) dî [[Special:Watchlist|canciamenti ê pàggini ntâ tò lista taliata]]", "resettokens-done": "Li token foru azzirati.", "resettokens-resetbutton": "Azzera li token scigghiuti", - "bold_sample": "Grassettu", - "bold_tip": "Grassettu", - "italic_sample": "Cursivu", - "italic_tip": "Cursivu", - "link_sample": "Tìtulu dû lijami", - "link_tip": "Lijami di dintra", - "extlink_sample": "http://www.example.com tìtulu dâ lijami", - "extlink_tip": "Lijami di fora (arricurdàrisi lu prifissu http://)", - "headline_sample": "Ntistazzioni", - "headline_tip": "Suttantistazzioni", - "nowiki_sample": "Nzirisci ccà lu testu nun furmattatu", - "nowiki_tip": "Gnora la furmattazzioni wiki", - "image_sample": "Asempiu.jpg", - "image_tip": "File ncurpuratu", - "media_sample": "Asempiu.ogg", - "media_tip": "Lijami a file", - "sig_tip": "La tò firma cu data e ura", - "hr_tip": "Lìnia urizzuntali (usari cu giudizziu)", "summary": "Riassuntu:", "subject": "Oggettu:", "minoredit": "Chistu è nu canciamentu nicu", diff --git a/languages/i18n/sco.json b/languages/i18n/sco.json index ea5a0786d3..8e949a81fc 100644 --- a/languages/i18n/sco.json +++ b/languages/i18n/sco.json @@ -597,24 +597,6 @@ "resettokens-watchlist-token": "Token fer the wab feed (Atom/RSS) o [[Special:Watchlist|chynges til pages oan yer watchleet]]", "resettokens-done": "Tokens' reset.", "resettokens-resetbutton": "Reset selected tokens.", - "bold_sample": "Baud tex", - "bold_tip": "Baud tex", - "italic_sample": "Italic tex", - "italic_tip": "Italic tex", - "link_sample": "Airtin teetle", - "link_tip": "Internal airtin", - "extlink_sample": "http://www.example.com airtin teetle", - "extlink_tip": "External link (mynd the http:// prefix)", - "headline_sample": "Heidline tex", - "headline_tip": "Level 2 heidline", - "nowiki_sample": "Insert non-formattit tex here", - "nowiki_tip": "Ignore wiki formattin", - "image_sample": "Exemplar.jpg", - "image_tip": "Embeddit eemage", - "media_sample": "Exemplar.ogg", - "media_tip": "File airtin", - "sig_tip": "Yer seignatur wi timestamp", - "hr_tip": "Horizontal line (dinna ower uise)", "summary": "Ootline:", "subject": "Subject:", "minoredit": "This is ae smaa eedit", diff --git a/languages/i18n/sd.json b/languages/i18n/sd.json index 332a02e8c0..2a0cb8bdc4 100644 --- a/languages/i18n/sd.json +++ b/languages/i18n/sd.json @@ -380,7 +380,7 @@ "createacct-another-email-ph": "برقٽپال پتو ڄاڻايو", "createaccountmail": "ڪو بہ عارضي ڳجھولفظ استعمال ڪريو Û½ ڄاڻايل برقٽپال پتي تي اماڻيو", "createacct-realname": "اصل نالو (مرضيءَ موجب)", - "createacct-reason": "سبب", + "createacct-reason": "سبب (عوامي-طور داخل-ٿيل)", "createacct-reason-ph": "توهان ٻيو کاتو ڇو کولي رهيا آهيو", "createacct-reason-help": "کاتو سرجڻ لاگ Û¾ ڏيکاريل پيغام", "createacct-submit": "پنھنجو کاتو کوليو", @@ -500,24 +500,6 @@ "resettokens-tokens": "ٽوڪنس:", "resettokens-token-label": "$1 (حاليہ قدر: $2)", "resettokens-resetbutton": "چونڊيل ٽوڪن ٻيھر ترتيب ڪريو", - "bold_sample": "گھري لکت", - "bold_tip": "گھري لکت", - "italic_sample": "ترڇي لکت", - "italic_tip": "ٽيڏي لکت", - "link_sample": "ڳنڍڻي جو عنوان", - "link_tip": "داخلي ڳنڍڻو", - "extlink_sample": "http://www.example.com ڳنڍڻي جو عنوان", - "extlink_tip": "خارجي ڳنڍڻو (اڳياڙي http:// نہ وساريندا)", - "headline_sample": "سرخي جي لکت", - "headline_tip": "سطح 2 جي سرخي", - "nowiki_sample": "غير-فارميٽڊ لکت شامل ڪريو", - "nowiki_tip": "وڪي فارميٽڱ کي نظرانداز ڪريو", - "image_sample": "مثال.jpg", - "image_tip": "جَڙيل فائيل", - "media_sample": "مثال.ogg", - "media_tip": "فائيل جو ڳنڍڻو", - "sig_tip": "توھان جي صحيح بمع اوقاتي مھر", - "hr_tip": "افقي لڪير (ڪفايت سان استعمال ڪريو)", "summary": "تَتُ:", "subject": "موضوع:", "minoredit": "ھيءَ Ú¾Úª معمولي سنوار آھي", diff --git a/languages/i18n/sdc.json b/languages/i18n/sdc.json index 515274afe5..5ccb7075c4 100644 --- a/languages/i18n/sdc.json +++ b/languages/i18n/sdc.json @@ -397,24 +397,6 @@ "changeemail-newemail": "Nobu indirizzu di postha erettrònica:", "changeemail-none": "(nisciunu)", "resettokens-tokens": "Token:", - "bold_sample": "Grassetu", - "bold_tip": "Grassetu", - "italic_sample": "Cursibu", - "italic_tip": "Cursibu", - "link_sample": "Tìturu di lu cullegamentu", - "link_tip": "Cullegamentu internu", - "extlink_sample": "http://www.example.com tìturu di lu cullegamentu", - "extlink_tip": "Cullegamentu esthernu (nota lu prefissu http:// )", - "headline_sample": "Intisthazioni", - "headline_tip": "Sottu-intisthazioni", - "nowiki_sample": "Insirì lu testhu nò fuimmaddaddu inogghi", - "nowiki_tip": "Ignora la fuimmaddazioni wiki", - "image_sample": "Esempiu.jpg", - "image_tip": "File incoipuraddu", - "media_sample": "Esempiu.ogg", - "media_tip": "Cullegamentu a file mùrthimediari", - "sig_tip": "Fimma cun data e ora", - "hr_tip": "Lìnia orizontari (usà cun moderazioni)", "summary": "Oggettu:", "subject": "Oggettu:", "minoredit": "Chistha è una mudìfigga minori", diff --git a/languages/i18n/sdh.json b/languages/i18n/sdh.json index 8aa237bac8..e89807470b 100644 --- a/languages/i18n/sdh.json +++ b/languages/i18n/sdh.json @@ -212,22 +212,6 @@ "retypenew": "تێپەڕوشەێ نوو دوبارە بنۊسەو:", "passwordreset-username": "ناو ئەوکاربەری:", "changeemail-none": "(هۊچ)", - "bold_sample": "دەق پڕرەنگ", - "bold_tip": "دەق پڕرەنگ", - "italic_sample": "دەق کەژ", - "italic_tip": "دەق کەژ", - "link_sample": "سەردێڕ بەسیار", - "link_tip": "بەسیار ناوخوەێ", - "extlink_sample": "http://www.example.com سەردێڕ بەسیار", - "extlink_tip": "بەسیار دەرەکی (لەھۊرت بوود نۊسین پێشگر http:// )", - "headline_sample": "دەق سەردێڕ", - "headline_tip": "سەردێڕ ئاست Û²", - "nowiki_sample": "لە ئیرە دەق نەڕازانیاێ تێ‌بخە", - "nowiki_tip": "لەوەرچاو نەگرتن داڕشانەگان ویکی", - "image_tip": "وێنەێ ناو دەق", - "media_tip": "بەسیار پەڕگە", - "sig_tip": "ئیمزاگەت وەرد مۆر ڕێکەفت", - "hr_tip": "هێڵ ئاسوویی (کەم ئەوکاری بوەین)", "summary": "کورتەێ وێراشتە:", "minoredit": "ئیە وێراشتەێگ بۊچگە", "watchthis": "ئەی پەڕە بخە ژێر چاودێری", diff --git a/languages/i18n/se.json b/languages/i18n/se.json index 4cb1966125..b1befb6cdd 100644 --- a/languages/i18n/se.json +++ b/languages/i18n/se.json @@ -293,24 +293,6 @@ "resetpass_forbidden": "Suollemassániid rievdan ii lihkosmuva dán wikis.", "resetpass-submit-loggedin": "Molsso suollemassáni", "passwordreset-email": "Å leađgaboastačujuhus:", - "bold_sample": "Buoiddes teaksta", - "bold_tip": "Buoiddes teaksta", - "italic_sample": "Vitnju teaksta", - "italic_tip": "Vitnju teaksta", - "link_sample": "liŋka", - "link_tip": "Siskkaldas liŋka", - "extlink_sample": "http://www.example.com liŋkka bájilčála", - "extlink_tip": "Wiki olggobeal liŋka (muite http:// ovddas)", - "headline_sample": "Bájilčálateaksta", - "headline_tip": "Bajilčála", - "nowiki_sample": "Lasit rievdatkeahtes teavstta dasa", - "nowiki_tip": "Teaksta, man wiki ii rievdda", - "image_sample": "Ovdamearka.jpg", - "image_tip": "Vurkejuvvon govva", - "media_sample": "Ovdamearka.ogg", - "media_tip": "Mediafiilaliŋka", - "sig_tip": "Vuolláičálus áiggiin", - "hr_tip": "Láskkosárggis", "summary": "Čoahkkáigeassu:", "subject": "Fáddá:", "minoredit": "Dát lea unna rievdadus", diff --git a/languages/i18n/sei.json b/languages/i18n/sei.json index 562ce6dc68..3afbeaf222 100644 --- a/languages/i18n/sei.json +++ b/languages/i18n/sei.json @@ -288,24 +288,6 @@ "resetpass_submit": "Vanquimx canj ö caápo", "changepassword-success": "Me quimx canj coccebj quiixde success! Caápo cmaa...", "resetpass_forbidden": "Quimx cánj nereset jan wiki iti", - "bold_sample": "Text ccomca", - "bold_tip": "Text ccomca", - "italic_sample": "Text canj", - "italic_tip": "Text canj", - "link_sample": "Titelde link", - "link_tip": "Link intern", - "extlink_sample": "http://www.example.com Titelde link", - "extlink_tip": "Link extern (¡hajbazxo http:// ö!)", - "headline_sample": "Text corridor", - "headline_tip": "Text corridor 2", - "nowiki_sample": "Neformattám cuerte damir", - "nowiki_tip": "Neformatöxde wiki", - "image_sample": "Cuáxiit.jpg", - "image_tip": "Plusöx ciúchan zo", - "media_sample": "Cuáxiit.ogg", - "media_tip": "Link MediaCiúchan", - "sig_tip": "Hesignura xeperat epa", - "hr_tip": "I horizont (seperatman)", "summary": "Abvuatl:", "subject": "Subject/ccanzam:", "minoredit": "Jan coccebj editám z bajlöxám", diff --git a/languages/i18n/ses.json b/languages/i18n/ses.json index 72d6e66911..acc654f7aa 100644 --- a/languages/i18n/ses.json +++ b/languages/i18n/ses.json @@ -540,24 +540,6 @@ "resettokens-watchlist-token": "Tammaasa interneti toonandiyanoo se (Atom/RSS) [[Special:Hawgayhayey|barmawey war hawgayhayey maaÅ¡eedaa ga]]", "resettokens-done": "Tammaasawey yeeti:", "resettokens-resetbutton": "Tammaasa suubantey yeeti", - "bold_sample": "Hantum warga", - "bold_tip": "Hantum warga", - "italic_sample": "Hantum Å¡iirante", - "italic_tip": "Hantum Å¡iirante", - "link_sample": "Dobu maa", - "link_tip": "Kunahere dobu", - "extlink_sample": "http://www.example.com dobu maa", - "extlink_tip": "Tarayhere dobu (honga http:// jinekanji)", - "headline_sample": "Boŋžeeri hantum", - "headline_tip": "Adadu 2 boŋžeeri", - "nowiki_sample": "Hantum bila nda fasal-takari dam ne", - "nowiki_tip": "Wiki fasal-takaroo muray", - "image_sample": "Example.jpg", - "image_tip": "Tuku damgamante", - "media_sample": "Example.ogg", - "media_tip": "Tuku dobu", - "sig_tip": "War kanbežeeroo nda waati Å¡ilbay", - "hr_tip": "Žeeri kanante (w'a tee cee fooyaŋ de)", "summary": "Duurandi:", "subject": "Furari:", "minoredit": "Barmay kayna ti woo:", diff --git a/languages/i18n/sgs.json b/languages/i18n/sgs.json index 0edb66d785..7861a609ad 100644 --- a/languages/i18n/sgs.json +++ b/languages/i18n/sgs.json @@ -455,24 +455,6 @@ "changeemail-submit": "Keistė el. paÅ¡ta", "changeemail-throttled": "Tamsta nuognē daug sÄ«kiu miegėnat prėsėjongtė.\nPalaukat $1 prÄ«Å¡ miegėnont apent.", "changeemail-nochange": "IraÅ¡Ä«kat kėtuoki nauja al. paÅ¡ta adresa.", - "bold_sample": "Pastuorints raÅ¡tos", - "bold_tip": "Pastuorints raÅ¡tos", - "italic_sample": "Pasviris raÅ¡tos", - "italic_tip": "Pasviris raÅ¡tos", - "link_sample": "NÅ«ruodas pavadėnėms", - "link_tip": "Vėduojė nÅ«ruoda", - "extlink_sample": "http://www.example.com nÅ«ruodas pavadėnėms", - "extlink_tip": "Laukėnė nÅ«ruoda (neožmėrÅ¡kat http:// prÄ«raÅ¡a)", - "headline_sample": "Skėrsnė pavadėnėms", - "headline_tip": "Ontra lÄ«gė skėrsnė pavadėnėms", - "nowiki_sample": "Diekat čiuonās teksta, katruo nerēk formatoutė", - "nowiki_tip": "Neprėveizietė wiki teksta skvarma", - "image_sample": "PavÄ«zdÄ«s.jpg", - "image_tip": "Oždietė abruozdieli", - "media_sample": "PavÄ«zdÄ«s.ogg", - "media_tip": "NÅ«ruoda abruozdielin", - "sig_tip": "Tamstas paraÅ¡os ė čiesos", - "hr_tip": "Golos briežis (nenauduokat ba rēkala)", "summary": "Keitėma paāškėnėms:", "subject": "Tema/ontraÅ¡tė:", "minoredit": "Mažos pakeitėms", diff --git a/languages/i18n/sh.json b/languages/i18n/sh.json index a4c30f82bd..756ee8a72d 100644 --- a/languages/i18n/sh.json +++ b/languages/i18n/sh.json @@ -67,6 +67,7 @@ "tog-useeditwarning": "Upozori me kad napuÅ¡tam stranicu za uređivanje bez snimanja izmjena", "tog-prefershttps": "Uvijek koristi sigurnu vezu dok sam prijavljen", "tog-showrollbackconfirmation": "Prikaži potvrdnicu kada kliknete vezu za opoziv", + "tog-requireemail": "Zahtijevaj e-poÅ¡tu za stavljanje novu lozinku", "underline-always": "Uvijek", "underline-never": "Nikad", "underline-default": "prema skinu ili postavkama preglednika", @@ -443,7 +444,7 @@ "createaccountmail": "Daj privremenu nasumičnu lozinku i poÅ¡alji na navedenu adresu", "createaccountmail-help": "Može se koristiti za stvaranje računa u tuđem imenu bez da se sazna lozinka.", "createacct-realname": "Stvarno ime (opcionalno)", - "createacct-reason": "Razlog", + "createacct-reason": "Razlog (javno zaveden)", "createacct-reason-ph": "ZaÅ¡to stvarate novi račun", "createacct-reason-help": "Poruka koja se prikazuje u zapisniku stvaranja korisničkih računa", "createacct-submit": "Stvorite svoj račun", @@ -610,22 +611,6 @@ "resettokens-watchlist-token": "Token za web feed (Atom/RSS) [[Special:Watchlist|promjena za vaÅ¡em spisku praćenja]]", "resettokens-done": "Tokeni resetirani.", "resettokens-resetbutton": "Resetiraj odabrane tokene", - "bold_sample": "Podebljan tekst", - "bold_tip": "Podebljan tekst", - "italic_sample": "Kurzivan tekst", - "italic_tip": "Kurzivan tekst", - "link_sample": "Naslov linka", - "link_tip": "Interni link", - "extlink_sample": "http://www.example.com naslov linka", - "extlink_tip": "Eksterni link (zapamti prefiks http:// )", - "headline_sample": "Tekst naslova", - "headline_tip": "Podnaslov", - "nowiki_sample": "Dodaj neformatirani tekst ovdje", - "nowiki_tip": "Ignoriraj wiki formatiranje", - "image_tip": "Uklopljena datoteka/fajl", - "media_tip": "Veza do datoteke/fajla", - "sig_tip": "VaÅ¡ potpis sa trenutnim vremenom", - "hr_tip": "Horizontalna linija (koristite rijetko)", "summary": "Sažetak:", "subject": "Tema:", "minoredit": "Ovo je manje uređenje", @@ -801,6 +786,7 @@ "undo-norev": "Izmjena se ne može vratiti jer ne postoji ranija ili je obrisana.", "undo-nochange": "Ovo je uređivanje izgleda već bilo poniÅ¡teno.", "undo-summary": "PoniÅ¡tena izmjena $1 [[Special:Contribs/$2|korisnika $2]] ([[User talk:$2|razgovor]])", + "undo-summary-anon": "PoniÅ¡ti izmjenu $1 {{GENDER:$2|korisnika|korisnice}} [[Special:Contributions/$2|$2]]", "undo-summary-username-hidden": "PoniÅ¡ti izmjenu $1 od skrivenog korisnika", "cantcreateaccount-text": "Pravljenje korisničkog računa sa ove IP adrese ('''$1''') je blokirano od strane [[User:$3|$3]].\n\nRazlog koji je naveo $3 je ''$2''", "cantcreateaccount-range-text": "Stvaranje računa od IP adresa iz pojasa<strong>$1</strong>, koji uključuje vaÅ¡u IP adresu (<strong>$4</strong>), je blokirao/la [[User:$3|$3]].\n\nRazlog koji je dao/la $3 je <em>$2</em>", @@ -1098,6 +1084,7 @@ "prefs-help-email": "E-mail adresa je opcionalna, ali je potrebna jer omogućava da Vam se poÅ¡alje nova Å¡ifra u slučaju da je izgubite ili zaboravite.", "prefs-help-email-others": "Također možete da odaberete da vas drugi kontaktiraju putem vaÅ¡e korisničke stranice ili stranice za razgovor bez otkrivanja vaÅ¡eg identiteta.", "prefs-help-email-required": "Neophodno je navesti e-mail adresu.", + "prefs-help-requireemail": "Ako je Å¡tiklirano, mogućnost za novu lozinku će imaju samo korisnici koji naveli su korisničko ime i e-poÅ¡tu.", "prefs-info": "Osnovne informacije", "prefs-i18n": "Internacionalizacija", "prefs-signature": "Potpis", @@ -1814,6 +1801,7 @@ "listfiles-userdoesnotexist": "Korisnički račun \"$1\" nije registrovan.", "imgfile": "datoteka", "listfiles": "Spisak slika", + "listfiles_subpage": "Postavljene datoteke $1", "listfiles_thumb": "Smanjeni pregled", "listfiles_date": "Datum", "listfiles_name": "Naziv", @@ -2310,6 +2298,7 @@ "alreadyrolled": "Ne može se vratiti posljednja izmjena [[:$1]] od korisnika [[User:$2|$2]] ([[User talk:$2|razgovor]]{{int:pipe-separator}}[[Special:Contributions/$2|{{int:contribslink}}]]); neko drugi je već izmjenio ili vratio članak.\n\nPosljednja izmjena je bila od korisnika [[User:$3|$3]] ([[User talk:$3|razgovor]]{{int:pipe-separator}}[[Special:Contributions/$3|{{int:contribslink}}]]).", "editcomment": "Sažetak izmjene je bio: <em>$1</em>.", "revertpage": "Vraćene izmjene [[Special:Contributions/$2|$2]] ([[User talk:$2|razgovor]]) na posljednju izmjenu korisnika [[User:$1|$1]]", + "revertpage-anon": "Vraćene izmjene [[Special:Contributions/$2|$2]] na posljednju izmjenu korisnika [[User:$1|$1]]", "revertpage-nouser": "Vraćene izmjene skrivenog korisnika na posljednju reviziju, koju je {{GENDER:$1|napravio|napravila}} [[User:$1|$1]]", "rollback-success": "Vraćene su izmjene korisnika {{GENDER:$3|$1}};\nvraćeno na posljednju verziju koju je snimio {{GENDER:$4|$2}}.", "sessionfailure-title": "GreÅ¡ka u sesiji", @@ -2546,6 +2535,7 @@ "ipblocklist-legend": "Traži blokiranog korisnika", "blocklist-userblocks": "Sakrij blokade računa", "blocklist-tempblocks": "Sakrij privremene blokade", + "blocklist-indefblocks": "Sakrij beskonačne blokade", "blocklist-addressblocks": "Sakrij pojedinačne IP blokade", "blocklist-type": "Vrsta:", "blocklist-type-opt-all": "Sve", diff --git a/languages/i18n/shi.json b/languages/i18n/shi.json index 35d47fda99..ffe3b3358e 100644 --- a/languages/i18n/shi.json +++ b/languages/i18n/shi.json @@ -335,22 +335,6 @@ "resetpass-submit-cancel": "ⵙⵎⵎⵜ", "resetpass-wrong-oldpass": "Awal n uzri yad niÉ£t walli yak ittkfan i yatwalt ur gis iffuÉ£ umya.\nHan irwas is yad tsbadlt awal n uzri niÉ£d is ḍalbt yan yaḍn n yat tklit.", "resetpass-temp-password": "Awal ad n uzri iga É£ir win yat tklit:", - "bold_sample": "ⴰⴹⵔⵉⵙ ⵉⵣⵓⵔⵏ", - "bold_tip": "ⴰⴹⵔⵉⵙ ⵉⵣⵓⵔⵏ", - "italic_sample": "ⴰⴹⵔⵉⵙ ⵉⴽⵯⵏⴰⵏ", - "italic_tip": "ⴰⴹⵔⵉⵙ ⵉⴽⵯⵏⴰⵏ", - "link_sample": "ⴰⵣⵡⵍ ⵏ ⵓⵍⵉⵏⴽ", - "link_tip": "ⴰⵍⵉⵏⴽ ⴰⴳⵯⵏⵙⴰⵏ", - "extlink_sample": "http://www.example.com ⴰⵣⵡⵓⵍ ⵏ ⵓⵍⵉⵏⴽ", - "extlink_tip": "ⴰⵍⵉⵏⴽ ⴰⴱⵔⵔⴰⵏⵉⵢ (â´°â´· ⵓⵔ ⵜⴻⵜⵜⵓⵜ ⵓⵣⵡⵉⵔ http://)", - "headline_sample": "ⴰⴹⵔⵉⵙ ⵏ ⵓⵣⵡⵓⵍ", - "headline_tip": "Ddu-uzwl taskfalt 2", - "nowiki_sample": "Kcm aḍṛiá¹£ li ur imzln É£id", - "nowiki_tip": "Zri Taseddast n wiki", - "image_tip": "ⴰⴼⴰⵢⵍⵓ ⵉⵜⵜⵡⴰⵙⵉⴷⴼⵏ", - "media_tip": "ⴰⵍⵉⵏⴽ ⵏ ⵓⴼⴰⵢⵍⵓ", - "sig_tip": "ⴰⵙⴳⵎⴹ ⵏⵏⴽ/ⵎ ⵙ ⵜⵉⵣⵉ", - "hr_tip": "izriri iÉ£zzifn (â´°â´· ⵜ ⵓⵔ ⵜⵙⵙⵓⴳⵜⵜ)", "summary": "ⴰⵣⴳⵣⵍ :", "subject": "ⵉⵎⵔⵙⵉ :", "minoredit": "ⴰⵙⵏⴼⵍ ⵎⵥⵥⵉⵏ", diff --git a/languages/i18n/shn.json b/languages/i18n/shn.json index 01c892bdb1..19a2d26857 100644 --- a/languages/i18n/shn.json +++ b/languages/i18n/shn.json @@ -538,22 +538,6 @@ "resettokens-token-label": "$1 (ၵႃႈၶၼ် ယၢမ်းလဵဝ်: $2)", "resettokens-done": "ၶိုၼ်းတင်ႈ မၢႆၶပ်ႉ", "resettokens-resetbutton": "ၶိုၼ်းတင်ႈ မၢႆၶပ်ႉ ဢၼ်လိူၵ်ႈဝႆႉၼႆႉ", - "bold_sample": "တူဝ်လိၵ်ႈၼႃ", - "bold_tip": "တူဝ်လိၵ်ႈၼႃ", - "italic_sample": "တူဝ်လိၵ်ႈၵိူင်း", - "italic_tip": "တူဝ်လိၵ်ႈၵိူင်း", - "link_sample": "ႁူဝ်ၶေႃႈႁဵင်းၵွင်ႉ", - "link_tip": "ႁဵင်းၵွင်ႉတၢင်းၼႂ်း", - "extlink_sample": "http://www.example.com ႁူဝ်ၶေႃႈႁဵင်းၵွင်ႉ", - "extlink_tip": "ႁဵင်းၵွင်ႉၵႂႃႇတၢင်ႇတီႈ (ယႃႇလိုမ်းသႂ်ႇ http:// ပႃႈၼႃႈသုတ်း)", - "headline_sample": "လိၵ်ႈ​ႁူဝ်ၶေႃႈ", - "headline_tip": "ႁူဝ်ၶေႃႈ ထၢၼ်ႈ ႒", - "nowiki_sample": "ဢဝ်လိၵ်ႈဢၼ်ဢမ်ႇမီးပိူင် သႂ်ႇပၼ်တီႈၼႆႈ", - "nowiki_tip": "ၶၢမ်ႈပႅတ်ႈပိူင် wiki", - "image_tip": "ၾၢႆႇၽင်ဝႆႉ", - "media_tip": "ႁဵင်းၵွင်ႉၾၢႆႇ", - "sig_tip": "လၢႆးမိုဝ်းၸဝ်ႈၵဝ်ႇ ၸွမ်း ၸုမ်ႈၶၢဝ်းယၢမ်း", - "hr_tip": "သၢႆၼႃႈသုင် - ၸႂ်ႉဢၼ်ၵႅမ်", "summary": "ႁူဝ်ႁုပ်ႈ :", "subject": "ႁူဝ်ၶေႃႈ :", "minoredit": "ပဵၼ်လွင်ႈမူၼ်ႉမႄးဢိတ်းဢီႈ", diff --git a/languages/i18n/shy-latn.json b/languages/i18n/shy-latn.json index daa8c99d2b..5c997d7721 100644 --- a/languages/i18n/shy-latn.json +++ b/languages/i18n/shy-latn.json @@ -541,22 +541,6 @@ "resettokens-watchlist-token": "Tiddest i usuddem (Atom/RSS) web n [[Special:Watchlist|ibeddilen n isebtar n umuÉ£ inek/inem n uḍfar]]", "resettokens-done": "Tiddas i wennezen.", "resettokens-resetbutton": "Wennez tiddas i fernen", - "bold_sample": "Aḍris aberbuz", - "bold_tip": "Aḍris aberbuz", - "italic_sample": "Aḍris aá¹­alyani", - "italic_tip": "Aḍris aá¹­alyani", - "link_sample": "Azwel n uzday", - "link_tip": "Azday zdaxel", - "extlink_sample": "http://www.example.com azwel n uzday", - "extlink_tip": "Azday aberrani (cfu belli yessefk at tebduḍ s http://)", - "headline_sample": "Aḍris n uzwel azellum", - "headline_tip": "Aswir 2 n uzwel azellum", - "nowiki_sample": "Sideff da tirra bla taseddast(formatting) n wiki", - "nowiki_tip": "Ttu taseddast n wiki", - "image_tip": "Tugna yettussekcmen", - "media_tip": "Azday n ufaylu media", - "sig_tip": "Azmul inek s uzemz", - "hr_tip": "Ajerriḍ aglawan (ur teččerɛiḍ ara)", "summary": "Agzul:", "subject": "Asentel:", "minoredit": "Wagi d abeddel afessas", diff --git a/languages/i18n/si.json b/languages/i18n/si.json index 05d63523d8..b38194924c 100644 --- a/languages/i18n/si.json +++ b/languages/i18n/si.json @@ -555,24 +555,6 @@ "resettokens-watchlist-token": "වෙබ් සංග්රහය (Atom/RSS) සඳහා සංකේත [[Special:Watchlist|ඔබගේ මුර-ලැයිස්තුවෙහි පිටු වෙනස්කම්]]", "resettokens-done": "ටෝකන් පත් යළි පිහිටුවන්න.", "resettokens-resetbutton": "තෝරාගත් ටෝකන් පත් යළි පිහිටුවන්න", - "bold_sample": "තදකුරු", - "bold_tip": "තදකුරු", - "italic_sample": "ඇලකුරු", - "italic_tip": "ඇලකුරු", - "link_sample": "සබැඳි ශීර්ෂය", - "link_tip": "අභ්‍යන්තර සබැඳිය", - "extlink_sample": "http://www.example.com සබැඳුම් මාතෘකාව", - "extlink_tip": "බාහිර සබැඳිය (http:// උපසර්ගය සිහි තබාගන්න)", - "headline_sample": "සිරස්තල පෙළ", - "headline_tip": "2වන මට්ටමේ සිරස්තලය", - "nowiki_sample": "ආකෘතිකරණය-නොකල පෙළ මෙහි ඇතුළුකරන්න", - "nowiki_tip": "විකි ආකෘතිකරණය නොසලකාහරින්න", - "image_sample": "නිදසුන.jpg", - "image_tip": "කාවැද්දූ ගොනුව", - "media_sample": "නිදසුන.ogg", - "media_tip": "ගොනු සබැඳිය", - "sig_tip": "වේලා මුද්‍රාව හා සමග ඔබගේ විද්‍යුත් අත්සන", - "hr_tip": "තිරස් පේළිය (අවම වශයෙන් භාවිතා කරන්න)", "summary": "සාරාංශය:", "subject": "විෂයය:", "minoredit": "මෙය සුළු සංස්කරණයකි", diff --git a/languages/i18n/sk.json b/languages/i18n/sk.json index 10882ad98d..78d9ce78e0 100644 --- a/languages/i18n/sk.json +++ b/languages/i18n/sk.json @@ -88,6 +88,7 @@ "tog-norollbackdiff": "VynechaÅ¥ rozdiel po vykonaní rollbacku", "tog-useeditwarning": "UpozorniÅ¥ ma, keď opúšťam upravovaciu stránku s neuloženými zmenami", "tog-prefershttps": "Po prihlásení používaÅ¥ vždy zabezpečené pripojenie", + "tog-requireemail": "Pre obnovu hesla vyžadovaÅ¥ e-mail", "underline-always": "Vždy", "underline-never": "Nikdy", "underline-default": "Podľa nastavení prehliadača alebo témy vzhľadu", @@ -194,6 +195,7 @@ "returnto": "Späť na $1.", "tagline": "Z {{GRAMMAR:genitív|{{SITENAME}}}}", "help": "Pomoc", + "help-mediawiki": "Nápoveda k MediaWiki", "search": "HľadaÅ¥", "search-ignored-headings": " #<!-- tento riadok je nutné nechaÅ¥ bez zmeny --> <pre>\n# Nadpisy, ktoré bude vyhľadávanie ignorovaÅ¥.\n# Tieto zmenu sa prejavia akonáhle bude stránka s nadpisom zaindexovaná.\n# Reindexovanie stránky môžete vynútiÅ¥ uložením prázdnej úpravy.\n# Syntax je nasledovná:\n# * VÅ¡etko počínajúc znakom „#“ do konca riadka je komentár.\n# * Každý neprázdny riadok je presný názov, ktorý má byÅ¥ ignorovaný, presne ako je napísaný, pričom na veľkosti písmen záleží.\nReferencie\nExterné odkazy\nPozri aj\n #</pre> <!-- tento riadok je nutné nechaÅ¥ bez zmeny -->", "searchbutton": "HľadaÅ¥", @@ -355,6 +357,7 @@ "badarticleerror": "Na tejto stránke túto činnosÅ¥ nemožno vykonaÅ¥.", "cannotdelete": "Nebolo možné zmazaÅ¥ stránku alebo súbor „$1“.\nMožno ju už zmazal nieto iný.", "cannotdelete-title": "Nemôžete zmazaÅ¥ stránku „$1“", + "delete-scheduled": "Zmazanie stránky „$1“ bolo naplánované.\nBuďte, prosím, trpezliví.", "delete-hook-aborted": "Zmazanie zruÅ¡ila prídavná funkcia (prípojný bod syntaktického analyzátora).\nNeudala vysvetlenie.", "no-null-revision": "Nepodarilo sa vytvoriÅ¥ novú prázdnu revíziu stránky „$1“", "badtitle": "Neplatný nadpis", @@ -386,6 +389,7 @@ "customcssprotected": "Nemáte právo upravovaÅ¥ túto CSS stránku, pretože obsahuje osobné nastavenie iného používateľa.", "customjsonprotected": "Nemáte právo upravovaÅ¥ túto JSON stránku, pretože obsahuje osobné nastavenie iného používateľa.", "customjsprotected": "Nemáte právo upravovaÅ¥ túto JavaScript stránku, pretože obsahuje osobné nastavenie iného používateľa.", + "sitecssprotected": "Nemáte oprávnenie editovaÅ¥ túto stránku s CSS, pretože to môže maÅ¥ dopad na vÅ¡etkých návÅ¡tevníkov.", "mycustomcssprotected": "Nemáte povolenie na úpravu tejto CSS stránky.", "mycustomjsonprotected": "Nemáte povolenie na úpravu tejto JSON stránky.", "mycustomjsprotected": "Nemáte povolenie na úpravu tejto JavaScriptovej stránky.", @@ -453,7 +457,7 @@ "createaccountmail": "PoužiÅ¥ dočasné náhodné heslo a poslaÅ¥ ho na uvedenú e-mailovú adresu", "createaccountmail-help": "Môže byÅ¥ použité na vytvorenie účtu pre inú osobu bez prezradenia hesla.", "createacct-realname": "Skutočné meno (nepovinné)", - "createacct-reason": "Dôvod", + "createacct-reason": "Dôvod (verejne zaznamenaný)", "createacct-reason-ph": "Prečo si vytvárate ďalší účet", "createacct-reason-help": "Správa zobrazená v knihe nových používateľov", "createacct-submit": "VytvoriÅ¥ si účet", @@ -467,6 +471,7 @@ "badretype": "Zadané heslá nie sú rovnaké.", "usernameinprogress": "Vytváranie účtu s týmto menom už prebieha. Prosím, počkajte.", "userexists": "Zadané používateľské meno sa už používa.\nProsím, zvoľte si iné meno.", + "createacct-normalization": "VaÅ¡e používateľské meno bude z technických dôvodov upravené na „$2“.", "loginerror": "Chyba pri prihlasovaní", "createacct-error": "Chyba pri vytváraní účtu", "createaccounterror": "Nepodarilo sa vytvoriÅ¥ účet: $1", @@ -481,11 +486,12 @@ "nosuchusershort": "V súčasnosti neexistuje používateľ s menom „$1“. Skontrolujte preklepy.", "nouserspecified": "Musíte uviesÅ¥ meno používateľa.", "login-userblocked": "Tento používateľ je zablokovaný. Nie je mu dovolené prihlásiÅ¥ sa.", - "wrongpassword": "Zadané heslo je nesprávne. Prosím, skúste to znova.", + "wrongpassword": "Zadané používateľské meno alebo heslo je nesprávne. Prosím, skúste to znova.", "wrongpasswordempty": "Zadané heslo bolo prázdne. Prosím, skúste to znova.", "passwordtooshort": "Heslo musí maÅ¥ dĺžku aspoň $1 {{PLURAL:$1|znak|znaky|znakov}}.", "passwordtoolong": "Heslá nemôžu byÅ¥ dlhÅ¡ie než {{PLURAL:$1|1 znak|$1 znaky|$1 znakov}}.", - "passwordtoopopular": "Nie je možné použiÅ¥ priveľmi frekventované heslá. Zvoľte si prosím iné, menej frekventované heslo.", + "passwordtoopopular": "Nie je možné použiÅ¥ priveľmi frekventované heslá. Zvoľte si, prosím, iné heslo, ktoré je zložitejÅ¡ie uhádnuÅ¥.", + "passwordinlargeblacklist": "Zadané heslo je uvedené na zozname veľmi často používaných hesiel. Zvoľte si, prosím, unikátnejÅ¡ie heslo.", "password-name-match": "VaÅ¡e heslo musí byÅ¥ iné ako vaÅ¡e používateľské meno.", "password-login-forbidden": "Použitie tohto používateľského mena a hesla bolo zakázané.", "mailmypassword": "ObnoviÅ¥ heslo", @@ -571,7 +577,7 @@ "resetpass-submit-loggedin": "ZmeniÅ¥ heslo", "resetpass-submit-cancel": "ZruÅ¡iÅ¥", "resetpass-wrong-oldpass": "Neplatné, dočasné alebo aktuálne heslo.\nJe možné, že sa vám už podarilo úspeÅ¡ne zmeniÅ¥ svoje heslo alebo ste si vyžiadali nové dočasné heslo.", - "resetpass-recycled": "Ako nové heslo si prosím nastavte niečo iné než súčasné heslo.", + "resetpass-recycled": "Ako nové heslo si, prosím, nastavte niečo iné ako súčasné heslo.", "resetpass-temp-emailed": "Prihlasujete sa dočasným heslom, zaslaným e-mailom. Aby ste dokončili prihlásenie, nastavte si tu nové heslo:", "resetpass-temp-password": "Dočasné heslo:", "resetpass-abort-generic": "Zmena hesla bola zablokovaná rozšírením.", @@ -616,24 +622,6 @@ "resettokens-watchlist-token": "Token pre webový kanál (Atom/RSS) [[Special:Watchlist|zmien na stránkach, ktoré sledujete]]", "resettokens-done": "Tokeny boli obnovené.", "resettokens-resetbutton": "ObnoviÅ¥ zvolené tokeny.", - "bold_sample": "Tučný text", - "bold_tip": "Tučný text", - "italic_sample": "Kurzíva", - "italic_tip": "Kurzíva", - "link_sample": "Názov odkazu", - "link_tip": "Interný odkaz", - "extlink_sample": "http://www.example.com názov odkazu", - "extlink_tip": "Externý odkaz (nezabudnite na predponu http://)", - "headline_sample": "Text nadpisu", - "headline_tip": "Text nadpisu úrovne 2", - "nowiki_sample": "Sem vložte neformátovaný text", - "nowiki_tip": "Ignoruj wiki formátovanie", - "image_sample": "Príklad.jpg", - "image_tip": "Vložený obrázok", - "media_sample": "Príklad.ogg", - "media_tip": "Odkaz na media súbor", - "sig_tip": "Váš podpis s dátumom a časom", - "hr_tip": "Vodorovná čiara (radÅ¡ej ju nepoužívajte)", "summary": "Zhrnutie úprav:", "subject": "Predmet:", "minoredit": "Toto je drobná úprava", @@ -664,6 +652,8 @@ "autoblockedtext": "VaÅ¡a IP adresa bola automaticky zablokovaná, pretože ju používa iný používateľ, ktorého zablokoval $1.\nUdaný dôvod zablokovania:\n\n:''$2''\n\n* Blokovanie začalo: $8\n* Blokovanie vyprší: $6\n* Blokovanie sa týka: $7\n\nAk potrebujete informácie o blokovaní, môžete kontaktovaÅ¥ $1 alebo niektorého iného\n[[{{MediaWiki:Grouppage-sysop}}|správcu]].\n\nPozn.: Nemôžete použiÅ¥ funkciu „{{int:emailuser}}“, ak ste si vo svojich\n[[Special:Preferences|používateľských nastaveniach]] nezaregistrovali platnú e-mailovú adresu.\n\nVaÅ¡a aktuálna IP adresa je $3. ID vášho blokovania je $5.\nProsím, uveďte tieto podrobnosti v akýchkoľvek otázkach, ktoré sa opýtate.", "systemblockedtext": "VaÅ¡a IP adresa bola automaticky zablokovaná.\nUdaný dôvod zablokovania:\n\n:<em>$2</em>\n\n* Blokovanie začalo: $8\n* Blokovanie vyprší: $6\n* Blokovanie sa týka: $7\n\nVaÅ¡a aktuálna IP adresa je $3.\nProsím, uveďte tieto podrobnosti v akýchkoľvek otázkach, ktoré sa opýtate.", "blockednoreason": "nebol uvedený dôvod", + "blockedtext-composite-no-ids": "VaÅ¡a IP adresa sa objavuje na niekoľkých čiernych listinách", + "blockedtext-composite-reason": "Na váš účet a/alebo vaÅ¡u IP adresu sa vzÅ¥ahuje viac blokovaní.", "whitelistedittext": "Aby ste mohli upravovaÅ¥ stránky, musíte sa $1", "confirmedittext": "Pred úpravami stránok musíte potvrdiÅ¥ vaÅ¡u e-mailovú adresu. Prosím, nastavte a overte svoju e-mailovú adresu v [[Special:Preferences|používateľských nastaveniach]].", "nosuchsectiontitle": "Sekcia nebola nájdená", @@ -728,6 +718,7 @@ "nocreate-loggedin": "Nemáte povolenie vytváraÅ¥ nové stránky.", "sectioneditnotsupported-title": "Úprava sekcie nie je podporovaná", "sectioneditnotsupported-text": "Táto stránka úprav nepodporuje úpravu sekcie.", + "modeleditnotsupported-title": "Editácia nie je podporovaná", "permissionserrors": "Chyba oprávnenia", "permissionserrorstext": "Na to nemáte povolenie z {{PLURAL:$1|nasledujúceho dôvodu|nasledujúcich dôvodov}}:", "permissionserrorstext-withaction": "Nemáte oprávnenie $2 z {{PLURAL:$1|nasledovného dôvodu|nasledovných dôvodov}}:", @@ -742,6 +733,7 @@ "postedit-confirmation-created": "Stránka bola vytvorená.", "postedit-confirmation-restored": "Stránka bola obnovená.", "postedit-confirmation-saved": "VaÅ¡a úprava bola uložená.", + "postedit-confirmation-published": "VaÅ¡a úprava bola zverejnená.", "edit-already-exists": "Nebolo možné vytvoriÅ¥ novú stránku.\nUž existuje.", "defaultmessagetext": "Predvolený text správy", "content-failed-to-parse": "Nepodarilo sa spracovaÅ¥ obsah $2 pre model $1: $3", @@ -955,7 +947,7 @@ "search-file-match": "(výskyt v obsahu súboru)", "search-suggest": "Mali ste na mysli „$1“?", "search-rewritten": "Zobrazujú sa výsledky pre $1. VyhľadaÅ¥ namiesto toho $2.", - "search-interwiki-caption": "Sesterské projekty", + "search-interwiki-caption": "Výsledky zo sesterských projektov", "search-interwiki-default": "Výsledky z $1:", "search-interwiki-more": "(viac)", "search-interwiki-more-results": "ďalÅ¡ie výsledky", @@ -1087,6 +1079,7 @@ "prefs-advancedwatchlist": "Rozšírené možnosti", "prefs-displayrc": "Možnosti zobrazenia", "prefs-displaywatchlist": "Možnosti zobrazenia", + "prefs-changesrc": "Zobrazené zmeny", "prefs-changeswatchlist": "Zobrazené zmeny", "prefs-pageswatchlist": "Sledované stránky", "prefs-tokenwatchlist": "Kľúč", @@ -1094,10 +1087,10 @@ "prefs-help-prefershttps": "Táto voľba sa prejaví pri vaÅ¡om ďalÅ¡om prihlásení.", "prefswarning-warning": "Vykonali ste zmeny v nastaveniach, ktoré zatiaľ nie sú uložené. Ak túto stránku opustíte bez kliknutia na „$1“, vaÅ¡e nastavenia sa neaktualizujú.", "prefs-tabs-navigation-hint": "Tip: prepínaÅ¥ medzi záložkami môžete aj pomocou šípok vľavo a vpravo.", - "userrights": "Spravovanie používateľských práv", - "userrights-lookup-user": "SpravovaÅ¥ členstvo používateľa v skupinách", + "userrights": "Používateľské práva", + "userrights-lookup-user": "VybraÅ¥ používateľa", "userrights-user-editname": "Zadajte meno používateľa:", - "editusergroup": "UpraviÅ¥ skupiny {{GENDER:$1|používateľa|používateľky}}", + "editusergroup": "NačítaÅ¥ skupiny používateľov", "editinguser": "Zmena práv používateľa '''[[User:$1|$1]]''' $2", "viewinguserrights": "Prehliadanie práv {{GENDER:$1|používateľa|používateľky}} <strong>[[User:$1|$1]]</strong> $2", "userrights-editusergroup": "UpraviÅ¥ skupiny používateľa", @@ -1111,6 +1104,7 @@ "userrights-nodatabase": "Databáza $1 neexistuje alebo nie je lokálna.", "userrights-changeable-col": "Skupiny, ktoré môžete zmeniÅ¥", "userrights-unchangeable-col": "Skupiny, ktoré nemôžete zmeniÅ¥", + "userrights-expiry-othertime": "Iný čas:", "userrights-conflict": "Konflikt zmien práv používateľov! Prosím, skontrolujte ho a potvrďte svoje zmeny.", "group": "Skupina:", "group-user": "Používatelia", @@ -1228,7 +1222,7 @@ "grant-createeditmovepage": "VytváraÅ¥, upravovaÅ¥ a presúvaÅ¥ stránky", "grant-delete": "OdstraňovaÅ¥ stránky, revízie a položky záznamu", "grant-editinterface": "UpravovaÅ¥ menný priestor MediaWiki a projektový/používateľský JSON", - "grant-editmycssjs": "UpravovaÅ¥ váš používateľský CSS/JavaScript", + "grant-editmycssjs": "UpravovaÅ¥ váš používateľský CSS/JSON/JavaScript", "grant-editmyoptions": "UpravovaÅ¥ nastavenia vášho používateľského účtu", "grant-editmywatchlist": "UpravovaÅ¥ váš zoznam sledovaných stránok", "grant-editsiteconfig": "UpravovaÅ¥ projektové a používateľské CSS/JS súbory", @@ -1270,7 +1264,7 @@ "action-upload_by_url": "nahraÅ¥ tento súbor z URL adresy", "action-writeapi": "použiÅ¥ API na zápis", "action-delete": "zmazaÅ¥ túto stránku", - "action-deleterevision": "zmazaÅ¥ túto revíziu", + "action-deleterevision": "zmazaÅ¥ revízie", "action-deletelogentry": "mazaÅ¥ záznamy", "action-deletedhistory": "zobraziÅ¥ históriu zmazaných revízií tejto stránky", "action-deletedtext": "zobraziÅ¥ si zmazané texty revízií", @@ -1350,8 +1344,9 @@ "rcfilters-savedqueries-already-saved": "Tieto filtre sú už uložené. Zmeňte niektoré nastavenia, ak chcete vytvoriÅ¥ nový uložený filter.", "rcfilters-restore-default-filters": "ObnoviÅ¥ predvolené filtre", "rcfilters-clear-all-filters": "ZruÅ¡iÅ¥ vÅ¡etky filtre", - "rcfilters-show-new-changes": "ZobraziÅ¥ najnovÅ¡ie zmeny", - "rcfilters-search-placeholder": "FiltrovaÅ¥ posledné úpravy (vyhľadávajte alebo začnite písaÅ¥)", + "rcfilters-show-new-changes": "ZobraziÅ¥ zmeny od $1", + "rcfilters-search-placeholder": "FiltrovaÅ¥ posledné úpravy (použite menu alebo vyhľadajte názov filtra)", + "rcfilters-search-placeholder-mobile": "Filtre", "rcfilters-invalid-filter": "Neplatný filter", "rcfilters-empty-filter": "Žiadne aktívne filtre. VÅ¡etky príspevky sú zobrazené.", "rcfilters-filterlist-title": "Filtre", @@ -1435,7 +1430,7 @@ "rcfilters-watchlist-markseen-button": "OznačiÅ¥ vÅ¡etky úpravy ako zobrazené", "rcfilters-watchlist-edit-watchlist-button": "UpraviÅ¥ zoznam sledovaných stránok", "rcfilters-watchlist-showupdated": "Zmeny stránok, ktoré ste od ich zmeny nenavÅ¡tívili, sú zobrazené <strong>hrubo</strong> s vyplneným krúžkom.", - "rcfilters-preference-label": "SkryÅ¥ vylepÅ¡enú verziu posledných úprav", + "rcfilters-preference-label": "PoužiÅ¥ rozhranie bez JavaScriptu", "rcfilters-preference-help": "Zruší novú podobu rozhrania z roku 2017 a vÅ¡etky nástroje odvtedy pridané.", "rcfilters-watchlist-preference-label": "SkryÅ¥ vylepÅ¡enú verziu sledovaných stránok", "rcfilters-watchlist-preference-help": "Zruší novú podobu rozhrania z roku 2017 a vÅ¡etky nástroje odvtedy pridané.", @@ -1634,6 +1629,7 @@ "backend-fail-contenttype": "Nebolo možné určiÅ¥ typ obsahu súboru, ktorý sa má uložiÅ¥ na „$1“.", "backend-fail-batchsize": "Do úložiska bola zaslaná dávka s $1 {{PLURAL:$1|operáciou|operáciami}}; limit je $2 {{PLURAL:$2|operácia|operácie|operácií}}.", "backend-fail-usable": "Nie je možné čítaÅ¥ alebo zapísaÅ¥ súbor $1 kvôli nedostatočným povoleniam alebo chýbajúcim adresárom/kontajnerom.", + "backend-fail-stat": "Nepodarilo sa načítaÅ¥ stav súboru „$1“.", "filejournal-fail-dbconnect": "Nepodarilo sa pripojiÅ¥ k žurnálovej databáze úložiska „$1“.", "filejournal-fail-dbquery": "Nepodarilo sa aktualizovaÅ¥ žurnálovú databázu úložiska „$1“.", "lockmanager-notlocked": "Nepodarilo sa odomknúť zámok „$1“; nie je zamknutý.", @@ -1659,6 +1655,11 @@ "uploadstash-refresh": "ObnoviÅ¥ zoznam súborov", "uploadstash-thumbnail": "zobraziÅ¥ náhľad", "uploadstash-exception": "Načítaný súbor sa nepodarilo uložiÅ¥ do skrýše ($1): „$2“.", + "uploadstash-bad-path": "Cesta neexistuje.", + "uploadstash-bad-path-invalid": "Cesta nie je platná.", + "uploadstash-bad-path-unknown-type": "Neznámy typ „$1“.", + "uploadstash-bad-path-unrecognized-thumb-name": "Nerozpoznaný názov náhľadu.", + "uploadstash-file-not-found-no-thumb": "Nepodarilo sa získaÅ¥ náhľad.", "invalid-chunk-offset": "Neplatný posun bloku", "img-auth-accessdenied": "Prístup zamietnutý", "img-auth-nopathinfo": "Váš server nie je nastavený tak, aby poskytoval tieto informácie.\nMôže byÅ¥ založený na CGI a nedokáže podporovaÅ¥ img_auth.\nPozri https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:Image_Authorization.", @@ -1676,6 +1677,7 @@ "http-timed-out": "Vyhradený čas požiadavky HTTP vyprÅ¡al.", "http-curl-error": "Chyba pri sÅ¥ahovaní URL: $1", "http-bad-status": "Počas požiadavky HTTP nastal problém: $1 $2", + "http-internal-error": "Interná chyba HTTP.", "upload-curl-error6": "Nedostupný URL", "upload-curl-error6-text": "Poskytnutý URL nebol dostupný. Prosím, skontrolujte znova, že URL je správny a lokalita je dostupná.", "upload-curl-error28": "VyprÅ¡al čas vyhradený pre nahrávanie", @@ -1693,6 +1695,7 @@ "listfiles-userdoesnotexist": "Používateľské konto „$1“ nie je zaregistrované.", "imgfile": "súbor", "listfiles": "Zoznam obrázkov", + "listfiles_subpage": "Súbory {{GENDER:$1|používateľa|používateľky}} $1", "listfiles_thumb": "Náhľad", "listfiles_date": "Dátum", "listfiles_name": "Názov", @@ -1700,7 +1703,7 @@ "listfiles_size": "VeľkosÅ¥ (v bajtoch)", "listfiles_description": "Popis", "listfiles_count": "Verzie", - "listfiles-show-all": "Vrátane starších verzií obrázkov", + "listfiles-show-all": "Zahrnúť staré verzie súborov", "listfiles-latestversion": "Aktuálna verzia", "listfiles-latestversion-yes": "Áno", "listfiles-latestversion-no": "Nie", @@ -1802,6 +1805,8 @@ "pageswithprop-legend": "Stránky s vlastnosÅ¥ou stránky", "pageswithprop-text": "Táto stránka obsahuje stránky, ktoré používajú konkrétnu vlastnosÅ¥ stránky.", "pageswithprop-prop": "Názov vlastnosti:", + "pageswithprop-reverse": "ZoradiÅ¥ v opačnom poradí", + "pageswithprop-sortbyvalue": "ZoradiÅ¥ podľa hodnoty vlastnosti", "pageswithprop-submit": "VykonaÅ¥", "pageswithprop-prophidden-long": "dlhá hodnota textovej vlastnosti bola skrytá ($1)", "pageswithprop-prophidden-binary": "hodnota binárnej vlastnosti bola skrytá ($1)", @@ -1863,6 +1868,7 @@ "deadendpages": "Slepé stránky", "deadendpagestext": "Nasledujúce stránky neodkazujú na žiadne iné stránky na {{GRAMMAR:lokál|{{SITENAME}}}}.", "protectedpages": "Zamknuté stránky", + "protectedpages-filters": "Filtre:", "protectedpages-indef": "Zamknutia iba na neurčito", "protectedpages-summary": "Táto stránka obsahuje zoznam existujúcich stránok, ktoré sú momentálne zamknuté. Zoznam názvov zamknutých proti vytvoreniu nájdete na stránke [[{{#special:ProtectedTitles}}|{{int:protectedtitles}}]].", "protectedpages-cascade": "Iba kaskádové zamykanie", @@ -1911,9 +1917,20 @@ "apisandbox-submit": "OdoslaÅ¥ dopyt", "apisandbox-reset": "VyčistiÅ¥", "apisandbox-retry": "SkúsiÅ¥ znova", + "apisandbox-helpurls": "Odkazy na nápovedu", "apisandbox-examples": "Príklady", + "apisandbox-dynamic-parameters": "Doplnkové parametre", + "apisandbox-dynamic-parameters-add-label": "PridaÅ¥ parameter:", + "apisandbox-dynamic-parameters-add-placeholder": "Meno parametra", + "apisandbox-add-multi": "PridaÅ¥", + "apisandbox-submit-invalid-fields-title": "Niektoré polia sú neplatné", + "apisandbox-submit-invalid-fields-message": "Opravte označené polia a skúste to znova.", "apisandbox-results": "Výsledky", "apisandbox-request-url-label": "URL požiadavky:", + "apisandbox-continue": "PokračovaÅ¥", + "apisandbox-continue-clear": "VymazaÅ¥", + "apisandbox-multivalue-all-namespaces": "$1 (VÅ¡etky menné priestory)", + "apisandbox-multivalue-all-values": "$1 (VÅ¡etky hodnoty)", "booksources": "Knižné zdroje", "booksources-search-legend": "VyhľadávaÅ¥ knižné zdroje", "booksources-search": "HľadaÅ¥", @@ -1926,6 +1943,7 @@ "speciallogtitlelabel": "Cieľ (názov alebo {{ns:user}}:Používateľské meno):", "log": "Záznamy", "logeventslist-submit": "ZobraziÅ¥", + "logeventslist-more-filters": "ZobraziÅ¥ ďalÅ¡ie záznamy:", "logeventslist-patrol-log": "Kniha preverených úprav", "logeventslist-tag-log": "Kniha značiek", "all-logs-page": "VÅ¡etky verejné záznamy", @@ -2144,8 +2162,8 @@ "sessionfailure": "Zdá sa, že je problém s vaÅ¡ou prihlasovacou reláciou;\ntáto akcia bola zruÅ¡ená ako prevencia proti zneužitiu relácie (session).\nProsím, stlačte \"naspäť\", obnovte stránku, z ktorej ste sa sem dostali, a skúste to znova.", "changecontentmodel": "ZmeniÅ¥ model obsahu stránky", "changecontentmodel-legend": "ZmeniÅ¥ model obsahu", - "changecontentmodel-title-label": "Názov stránky", - "changecontentmodel-model-label": "Nový model obsahu", + "changecontentmodel-title-label": "Názov stránky:", + "changecontentmodel-model-label": "Nový model obsahu:", "changecontentmodel-reason-label": "Dôvod:", "changecontentmodel-submit": "ZmeniÅ¥", "changecontentmodel-success-title": "Model obsahu bol zmenený", @@ -2314,15 +2332,15 @@ "ipbreason": "Dôvod:", "ipbreason-dropdown": "* Bežné dôvody blokovania\n** Zámerné vkladanie chybných informácií\n** Mazanie obsahu stránok\n** Spam odkazy na externé stránky\n** Vkladanie nezmyslov do stránok\n** ZastraÅ¡ujúce správanie/obÅ¥ažovanie\n** Zneužívanie viacerých účtov\n** Neprípustné používateľské meno", "ipb-hardblock": "ZabrániÅ¥ prihláseným používateľom upravovaÅ¥ z tejto IP adresy", - "ipbcreateaccount": "ZabrániÅ¥ vytváraniu účtov", - "ipbemailban": "ZabrániÅ¥ používateľovi posielaÅ¥ e-maily", + "ipbcreateaccount": "Vytváranie účtov", + "ipbemailban": "Posielanie e-mailov", "ipbenableautoblock": "Automaticky blokovaÅ¥ poslednú IP adresu, ktorú tento používateľ použil, a vÅ¡etky ďalÅ¡ie adresy, z ktorých sa pokúsi upravovaÅ¥.", "ipbsubmit": "ZablokovaÅ¥ tohto používateľa", "ipbother": "Iný čas", "ipboptions": "2 hodiny:2 hours,1 deň:1 day,3 dni:3 days,1 týždeň:1 week,2 týždne:2 weeks,1 mesiac:1 month,3 mesiace:3 months,6 mesiacov:6 months,1 rok:1 year,na neurčito:infinite", "ipbhidename": "SkryÅ¥ meno používateľa z úprav a zoznamov", "ipbwatchuser": "SledovaÅ¥ používateľskú a diskusnú stránku tohto používateľa", - "ipb-disableusertalk": "ZabrániÅ¥ tomuto používateľovi upravovaÅ¥ vlastnú diskusnú stránku, kým je zablokovaný", + "ipb-disableusertalk": "Upravovanie vlastnej diskusnej stránky", "ipb-change-block": "Znovu zablokovaÅ¥ používateľa s týmito voľbami", "ipb-confirm": "PotvrdiÅ¥ blokovanie", "badipaddress": "IP adresa má nesprávny formát.", @@ -2375,11 +2393,14 @@ "createaccountblock": "tvorba účtov bola zablokovaná", "emailblock": "e-mail blokovaný", "blocklist-nousertalk": "nemôže upravovaÅ¥ svoju diskusnú stránku", + "blocklist-editing-page": "stránky", + "blocklist-editing-ns": "menné priestory", "ipblocklist-empty": "Zoznam blokovaní je prázdny.", - "ipblocklist-no-results": "Požadovaná IP adresa alebo používateľské meno nie je blokovaná.", + "ipblocklist-no-results": "Nebolo nájdené žiadne zablokovanie danej IP adresy alebo používateľa.", "blocklink": "zablokovaÅ¥", "unblocklink": "odblokovaÅ¥", "change-blocklink": "zmeniÅ¥ blokovanie", + "empty-username": "(používateľské meno nie je dostupné)", "contribslink": "príspevky", "emaillink": "poslaÅ¥ e-mail", "autoblocker": "Boli ste automaticky zablokovaný, pretože vaÅ¡u IP adresu nedávno použil „[[User:$1|$1]]“.\nDôvodom zablokovania redaktora $1 bolo „$2“", @@ -2798,8 +2819,10 @@ "newimages-summary": "Táto Å¡peciálna stránka zobrazuje posledné nahrané súbory.", "newimages-legend": "Filter", "newimages-label": "Názov súboru (alebo jeho časÅ¥):", + "newimages-user": "IP adresa alebo používateľské meno", "newimages-showbots": "ZobraziÅ¥ súbory nahrané botmi", "newimages-hidepatrolled": "SkryÅ¥ preverené nahratia súborov", + "newimages-mediatype": "Typ multimédia:", "noimages": "Niet čo zobraziÅ¥.", "gallery-slideshow-toggle": "Prepnúť náhľady", "ilsubmit": "HľadaÅ¥", @@ -2872,6 +2895,8 @@ "confirm-unwatch-top": "OdstrániÅ¥ túto stránku z vášho zoznamu sledovaných?", "confirm-rollback-button": "OK", "confirm-rollback-top": "VrátiÅ¥ úpravy na tejto stránke?", + "confirm-mcrundo-title": "VrátiÅ¥ späť zmenu", + "mcrundofailed": "Vrátenie úpravy sa nepodarilo", "quotation-marks": "„$1“", "imgmultipageprev": "← predoÅ¡lá stránka", "imgmultipagenext": "ďalÅ¡ia stránka →", @@ -3078,8 +3103,8 @@ "diff-form": "Rozdiely", "dberr-problems": "Prepáčte! Táto stránka má práve technické problémy.", "dberr-again": "Skúste niekoľko minút počkaÅ¥ a potom opäť načítaÅ¥ stránku.", - "dberr-info": "(Spojenie s databázovým serverom neúspeÅ¡né: $1)", - "dberr-info-hidden": "(Nie je možné kontaktovaÅ¥ databázový server)", + "dberr-info": "(Nie je možné pripojiÅ¥ sa k databáze: $1)", + "dberr-info-hidden": "(Nie je možné pripojiÅ¥ sa k databáze)", "htmlform-invalid-input": "Niekotrý z údajov, ktoré ste zadali je problematický", "htmlform-select-badoption": "Hodnota, ktorú ste uviedli nie je platná.", "htmlform-int-invalid": "Hodnota, ktorú ste uviedli nie je celé číslo.", @@ -3141,7 +3166,7 @@ "logentry-protect-protect-cascade": "$1 {{GENDER:$2|zamkol|zamkla}} stránku $3 $4 [kaskádovým zámkom]", "logentry-protect-modify": "$1 {{GENDER:$2|zmenil|zmenila}} úroveň zámku stránky $3 $4", "logentry-protect-modify-cascade": "$1 {{GENDER:$2|zmenil|zmenila}} úroveň zámku stránky $3 $4 [kaskádový zámok]", - "logentry-rights-rights": "$1 zmenil členstvo $3 v skupinách z $4 na $5", + "logentry-rights-rights": "$1 {{GENDER:$2|zmenil|zmenila}} členstvo {{GENDER:$6|používateľa|používateľky}} $3 v skupinách z $4 na $5", "logentry-rights-rights-legacy": "$1 zmenil členstvo $3 v skupinách", "logentry-rights-autopromote": "$1 bol automaticky povýšený z $4 na $5", "logentry-upload-upload": "$1 {{GENDER:$2|pridal|pridala}} $3", @@ -3208,7 +3233,7 @@ "expandtemplates": "SubstituovaÅ¥ Å¡ablóny", "expand_templates_intro": "Táto Å¡peciálna stránka prijme na\nvstup text a rekurzívne substituuje vÅ¡etky Å¡ablóny,\nktoré sú v ňom použité. Tiež expanduje funkcie\nsyntaktického analyzátora ako <nowiki>{{</nowiki>#language:...}}\na premenné ako <nowiki>{{</nowiki>CURRENTDAY}}—v podstate\ntakmer vÅ¡etko v zložených zátvorkách. Robí to pomocou\nvolania relevantnej fázy syntaktického analyzátora\nsamotného MediaWiki.", "expand_templates_title": "Názov kontextu pre {{FULLPAGENAME}} atď.:", - "expand_templates_input": "Vstupný text:", + "expand_templates_input": "Vstupný wikitext:", "expand_templates_output": "Výsledok", "expand_templates_xml_output": "XML výstup", "expand_templates_html_output": "Surový HTML výstup", @@ -3298,8 +3323,12 @@ "date-range-from": "Od dátumu:", "date-range-to": "Po dátum:", "randomrootpage": "Náhodná koreňová stránka", + "authmanager-provider-password": "Autentifikácia pomocou hesla", "changecredentials": "Zmena prihlasovacích údajov", + "changecredentials-submit": "ZmeniÅ¥ prihlasovacie údaje", "removecredentials": "Odstránenie prihlasovacích údajov", + "credentialsform-provider": "Typ prihlasovacích údajov:", + "credentialsform-account": "Názov účtu:", "userjsispublic": "Uvedomte si prosím, že podstránky s JavaScriptom by nemali obsahovaÅ¥ tajné údaje, pretože sú viditeľné ostatným používateľom.", "usercssispublic": "Uvedomte si prosím, že podstránky s CSS by nemali obsahovaÅ¥ tajné údaje, pretože sú viditeľné ostatným používateľom.", "passwordpolicies": "Pravidlá pre heslá" diff --git a/languages/i18n/skr-arab.json b/languages/i18n/skr-arab.json index ac72c32623..26fb69ee84 100644 --- a/languages/i18n/skr-arab.json +++ b/languages/i18n/skr-arab.json @@ -356,22 +356,6 @@ "resettokens": "ٹوکناں دی نویں ترتیب", "resettokens-tokens": "ٹوکن", "resettokens-token-label": "$1 (موجودہ قدر: $2)", - "bold_sample": "موٹی لکھائی", - "bold_tip": "موٹی لکھائی", - "italic_sample": "ترچھا متن", - "italic_tip": "ترچھی لکھائی", - "link_sample": "جوڑ", - "link_tip": "اندرونی جوڑ", - "extlink_sample": "http://www.example.com جوڑ دا ناں", - "extlink_tip": "باہرلے جوڑ (remember http:// prefix)", - "headline_sample": "شہ سرخی", - "headline_tip": "ݙوجھے درجے دی سرخی", - "nowiki_sample": "فارمیٹ نہ تھئی ہوئی لکھائی اتھ درج کرو", - "nowiki_tip": "ویکی فارمیٹ کوں نظرانداز کرو", - "image_tip": "پیوستہ فائل", - "media_tip": "فائل دا جوڑ", - "sig_tip": "تہاݙے دستخط ویلے دے نال", - "hr_tip": "اُفقی لکیر (زیادہ استعمال نہ کریں)", "summary": "خلاصہ", "subject": "عنوان:", "minoredit": "ایہ ہک چھوٹی تبدیلی ہے", diff --git a/languages/i18n/sl.json b/languages/i18n/sl.json index 7cd6220cbd..d9be5c25d0 100644 --- a/languages/i18n/sl.json +++ b/languages/i18n/sl.json @@ -64,6 +64,7 @@ "tog-useeditwarning": "Opozori me, ko skuÅ¡am zapreti urejevalno polje z neshranjenimi spremembami", "tog-prefershttps": "Med prijavo vedno uporabljaj varno povezavo", "tog-showrollbackconfirmation": "Pokaži potrditveno okno ob kliku na povezavo za vrnitev", + "tog-requireemail": "Zahtevaj e-poÅ¡tni naslov za ponastavitev gesla", "underline-always": "Vedno", "underline-never": "Nikoli", "underline-default": "Koža ali privzeto v brskalniku", @@ -437,7 +438,7 @@ "createaccountmail": "Ustvari začasno naključno geslo in ga poÅ¡lji na spodaj navedeni e-poÅ¡tni naslov", "createaccountmail-help": "Se lahko uporablja za ustvarjanje računa za drugo osebo brez da bi vedeli geslo.", "createacct-realname": "Pravo ime (izbirno)", - "createacct-reason": "Razlog", + "createacct-reason": "Razlog (javno zabeležen)", "createacct-reason-ph": "Zakaj ustvarjate drug račun", "createacct-reason-help": "Sporočilo, prikazano v dnevniku ustvarjanja računov", "createacct-submit": "Ustvarite svoj račun", @@ -605,24 +606,6 @@ "resettokens-watchlist-token": "Žeton spletnega vira (Atom/RSS) [[Special:Watchlist|sprememb strani na vaÅ¡em spisku nadzorov]]", "resettokens-done": "Žetone sem ponastavil.", "resettokens-resetbutton": "Ponastavi izbrane žetone", - "bold_sample": "Krepko besedilo", - "bold_tip": "Krepko besedilo", - "italic_sample": "Ležeče besedilo", - "italic_tip": "Ležeče besedilo", - "link_sample": "Naslov povezave", - "link_tip": "Notranja povezava", - "extlink_sample": "http://www.example.com naslov povezave", - "extlink_tip": "Zunanja povezava (ne pozabite na predpono http://)", - "headline_sample": "Besedilo naslovne vrstice", - "headline_tip": "Naslovna vrstica druge ravni", - "nowiki_sample": "Tu vnesite neoblikovano besedilo", - "nowiki_tip": "Prezri wikioblikovanje", - "image_sample": "Zgled.jpg", - "image_tip": "Povezava na sliko", - "media_sample": "Zgled.ogg", - "media_tip": "Povezava na predstavnostno datoteko", - "sig_tip": "VaÅ¡ podpis z datumom", - "hr_tip": "Vodoravna črta (uporabljajte zmerno)", "summary": "Povzetek urejanja:", "subject": "Zadeva:", "minoredit": "manjÅ¡e urejanje", @@ -804,6 +787,7 @@ "undo-norev": "Urejanja ni mogoče razveljaviti, ker ne obstaja ali je bilo izbrisano.", "undo-nochange": "Zdi se, da je urejanje nekdo že razveljavil.", "undo-summary": "Redakcija $1 uporabnika [[Special:Contributions/$2|$2]] ([[User talk:$2|pogovor]]) razveljavljena", + "undo-summary-anon": "Razveljavitev redakcije $1 uporabnika [[Special:Contributions/$2|$2]]", "undo-summary-username-hidden": "Razveljavi redakcijo $1 skritega uporabnika", "cantcreateaccount-text": "Registracije z IP-naslova ('''$1''') je administrator(ka) [[User:$3|$3]] blokiral(a).\n\nRazlog, ki ga je $3 podal(a), je ''$2''.", "cantcreateaccount-range-text": "Ustvarjanje računov z IP-naslovov v območju <strong>$1</strong>, ki vključuje vaÅ¡ IP-naslov (<strong>$4</strong>), je blokiral(-a) [[User:$3|$3]].\n\nRazlog, ki ga je podal(-a) $3, je <em>$2</em>.", @@ -1102,6 +1086,7 @@ "prefs-help-email": "E-poÅ¡tni naslov ni obvezen, vendar omogoča, da vam v primeru pozabljenega gesla poÅ¡ljemo novo.", "prefs-help-email-others": "Omogočite lahko tudi možnost, da vam lahko ostali uporabniki poÅ¡iljajo e-poÅ¡to prek vaÅ¡e uporabniÅ¡ke ali pogovorne strani.\nKo vas drugi uporabniki kontaktirajo, jim vaÅ¡ega e-poÅ¡tnega naslova ne bomo razkrili.", "prefs-help-email-required": "E-poÅ¡tni naslov je obvezen.", + "prefs-help-requireemail": "Če je označeno, bo e-poÅ¡ta za ponastavitev gesla poslana samo, če je oseba, ki je sprožila ponastavitev, vnesla tako uporabniÅ¡ko ime kot e-poÅ¡tni naslov tega računa.", "prefs-info": "Osnovni podatki", "prefs-i18n": "Internacionalizacija", "prefs-signature": "Podpis", @@ -1819,6 +1804,7 @@ "listfiles-userdoesnotexist": "UporabniÅ¡ki račun »$1« ni registriran.", "imgfile": "dat.", "listfiles": "Seznam datotek", + "listfiles_subpage": "Nalaganja $1", "listfiles_thumb": "Sličica", "listfiles_date": "Datum", "listfiles_name": "Ime", @@ -2316,6 +2302,7 @@ "alreadyrolled": "Zadnje spremembe [[:$1]] uporabnika [[User:$2|$2]] ([[User talk:$2|pogovor]]{{int:pipe-separator}}[[Special:Contributions/$2|{{int:contribslink}}]]) ne morem vrniti;\nstran je spremenil ali vrnil že nekdo drug.\n\nZadnji je stran urejal uporabnik [[User:$3|$3]] ([[User talk:$3|pogovor]]{{int:pipe-separator}}[[Special:Contributions/$3|{{int:contribslink}}]]).", "editcomment": "Povzetek urejanja je bil: <em>$1</em>.", "revertpage": "vrnitev sprememb uporabnika [[Special:Contributions/$2|$2]] ([[User talk:$2|pogovor]]) na zadnje urejanje uporabnika [[User:$1|$1]]", + "revertpage-anon": "Vrnjena urejanja uporabnika [[Special:Contributions/$2|$2]] na zadnjo redakcijo uporabnika [[User:$1|$1]]", "revertpage-nouser": "vrnitev sprememb skritega uporabnika na zadnjo redakcijo {{GENDER:$1|[[User:$1|$1]]}}", "rollback-success": "Razveljavljene spremembe {{GENDER:$3|uporabnika|uporabnice}} $1;\nvrnjeno na urejanje {{GENDER:$4|uporabnika|uporabnice}} $2.", "sessionfailure-title": "Neuspeh seje", @@ -2552,6 +2539,7 @@ "ipblocklist-legend": "Poišči blokiranega uporabnika", "blocklist-userblocks": "skrij blokade računov", "blocklist-tempblocks": "skrij začasne blokade", + "blocklist-indefblocks": "Skrij neomejene blokade", "blocklist-addressblocks": "skrij blokade posameznih IP-naslovov", "blocklist-type": "Vrsta:", "blocklist-type-opt-all": "Vse", @@ -3825,5 +3813,8 @@ "mycustomjsredirectprotected": "Nimate pravic za urejanje te strani z JavaScriptom, ker je preusmeritev in ne kaže v vaÅ¡ uporabniÅ¡ki prostor.", "easydeflate-invaliddeflate": "Dana vsebina ni pravilno stisnjena", "unprotected-js": "Iz varnostnih razlogov JavaScripta ni možno naložiti z nezaščitenih strani. Prosimo, da JavaScript ustvarite samo v imenskem prostoru MediaWiki ali kot uporabniÅ¡ko podstran.", - "userlogout-continue": "Se želite odjaviti?" + "userlogout-continue": "Se želite odjaviti?", + "rest-prefix-mismatch": "Zahtevana pot ($1) ni bila znotraj korenske poti REST API ($2)", + "rest-wrong-method": "Zahtevana metoda ($1) ni {{PLURAL:$3|veljavna metoda|ena od veljavnih metod}} za to pot ($2)", + "rest-no-match": "Zahtevana relativna pot ($1) se ne ujema z nobenim znanim krmilnikom" } diff --git a/languages/i18n/sli.json b/languages/i18n/sli.json index 673be97d2b..84824231f2 100644 --- a/languages/i18n/sli.json +++ b/languages/i18n/sli.json @@ -326,22 +326,6 @@ "resetpass-submit-loggedin": "Poaßwurt ändern", "resetpass-wrong-oldpass": "Ungiltiges temporäres oder aktuelles Poaßwurt.\nMeeglicherweise host du dei Poaßwurt bereits erfolgreich geändert oder a neues temporäres Poaßwurt beantragt.", "resetpass-temp-password": "Temporäres Poaßwurt:", - "bold_sample": "Fetter Text", - "bold_tip": "Fetter Text", - "italic_sample": "Kursiver Text", - "italic_tip": "Kursiver Text", - "link_sample": "Verknipfungstext", - "link_tip": "Interne Verknipfung", - "extlink_sample": "http://www.example.com Verknipfungstittel", - "extlink_tip": "Externe Verknipfung (http:// beoachta)", - "headline_sample": "Ieberschreft (Ebene 2)", - "headline_tip": "Ebene 2 Ieberschreft", - "nowiki_sample": "unformatierta Text hier eifiega", - "nowiki_tip": "unformatierter Text (nowiki)", - "image_tip": "Verknipfung miet Datei", - "media_tip": "Verknipfung miet Mediadatei", - "sig_tip": "Denne Underschrift miet Zeetstempel", - "hr_tip": "Hurizuntale Linie (sporsam verwenda)", "summary": "Zusammafoassung:", "minoredit": "Ocke Kleenigkeeta wurda verändert", "watchthis": "Diese Seite beoboachta", diff --git a/languages/i18n/so.json b/languages/i18n/so.json index d46a9d2b53..c9f7e17b2e 100644 --- a/languages/i18n/so.json +++ b/languages/i18n/so.json @@ -394,20 +394,6 @@ "changeemail-newemail": "Ciwaan e-mail oo cusub:", "changeemail-none": "(waxna)", "changeemail-submit": "Bedel e-mailka", - "bold_sample": "Far butac ah", - "bold_tip": "Far butac ah", - "italic_sample": "Farta caatada ah", - "italic_tip": "Farta caatada ah", - "link_sample": "Qoraalka linkiga", - "extlink_sample": "http://www.example.com qoraalka linkiga", - "extlink_tip": "Xiriirka tixraaca (xasuuso http:// prefix)", - "headline_sample": "Qoraalka madaxa hore", - "headline_tip": "Qeybta 2aad ee ciwaanka kore", - "nowiki_sample": "Ku dar meeshaan qoraal aan la format-gareen", - "nowiki_tip": "Iska dhagooleey formatka wiki", - "image_tip": "Fayl la soo galiyay", - "media_tip": "Linkiga file-ka", - "sig_tip": "Saxiixaaga oo waqti ku dhufsan", "summary": "Qoraal kooban:", "minoredit": "Kan waa wax ka bedel yar", "watchthis": "Boggaan waardiyey", diff --git a/languages/i18n/sq.json b/languages/i18n/sq.json index bf5827839b..f6b5d56205 100644 --- a/languages/i18n/sq.json +++ b/languages/i18n/sq.json @@ -611,24 +611,6 @@ "resettokens-token-label": "$1 (vlera aktuale: $2)", "resettokens-done": "Tokenët u resetuan.", "resettokens-resetbutton": "Reseto tokenët e zgjedhur", - "bold_sample": "Stil i theksuar i tekstit", - "bold_tip": "Stil i theksuar i tekstit", - "italic_sample": "Tekst i pjerrët", - "italic_tip": "Tekst i pjerrët", - "link_sample": "Titulli i lidhjes", - "link_tip": "Lidhje e brendshme", - "extlink_sample": "http://www.example.com titulli i lidhjes", - "extlink_tip": "Lidhje e jashtme (most harro prefiksin http://)", - "headline_sample": "Titulli", - "headline_tip": "Titull i nivelit 2", - "nowiki_sample": "Vendos tekst që nuk duhet të formatohet", - "nowiki_tip": "Mos përdor format wiki", - "image_sample": "Shembull.jpg", - "image_tip": "Vendos një figurë", - "media_sample": "Shembull.ogg", - "media_tip": "Lidhje media-skedash", - "sig_tip": "Firma juaj me gjithë kohë", - "hr_tip": "vijë horizontale (përdoreni rallë)", "summary": "Përmbledhje:", "subject": "Subjekt:", "minoredit": "Ky është një redaktim i vogël", diff --git a/languages/i18n/sr-ec.json b/languages/i18n/sr-ec.json index 6f159775f9..9c65b81737 100644 --- a/languages/i18n/sr-ec.json +++ b/languages/i18n/sr-ec.json @@ -630,24 +630,6 @@ "resettokens-watchlist-token": "Токен за веб-фид (Atom/RSS) [[Special:Watchlist|промена на страницама у вашем списку надгледања]]", "resettokens-done": "Токени су ресетовани.", "resettokens-resetbutton": "Ресетуј изабране токене", - "bold_sample": "Подебљан текст", - "bold_tip": "Подебљан текст", - "italic_sample": "Искошен текст", - "italic_tip": "Искошен текст", - "link_sample": "Наслов везе", - "link_tip": "Унутрашња веза", - "extlink_sample": "http://www.example.com/ наслов везе", - "extlink_tip": "Спољашња веза (са префиксом http://)", - "headline_sample": "Текст наслова", - "headline_tip": "Поднаслов (ниво 2)", - "nowiki_sample": "Овде уметните необликован текст", - "nowiki_tip": "Занемари вики обликовање", - "image_sample": "Пример.jpg", - "image_tip": "Уграђивање датотеке", - "media_sample": "Пример.ogg", - "media_tip": "Веза до датотеке", - "sig_tip": "Ваш потпис са временском ознаком", - "hr_tip": "Водоравна линија (користите ретко)", "summary": "Опис измене:", "subject": "Тема:", "minoredit": "Ово је мања измена", diff --git a/languages/i18n/sr-el.json b/languages/i18n/sr-el.json index d9e64491ba..e06d84d14a 100644 --- a/languages/i18n/sr-el.json +++ b/languages/i18n/sr-el.json @@ -618,24 +618,6 @@ "resettokens-watchlist-token": "Token za veb-fid (Atom/RSS) [[Special:Watchlist|promena na stranicama u vaÅ¡em spisku nadgledanja]]", "resettokens-done": "Tokeni su resetovani.", "resettokens-resetbutton": "Resetuj izabrane tokene", - "bold_sample": "Podebljan tekst", - "bold_tip": "Podebljan tekst", - "italic_sample": "IskoÅ¡en tekst", - "italic_tip": "IskoÅ¡en tekst", - "link_sample": "Naslov veze", - "link_tip": "UnutraÅ¡nja veza", - "extlink_sample": "http://www.example.com/ naslov veze", - "extlink_tip": "SpoljaÅ¡nja veza (sa prefiksom http://)", - "headline_sample": "Tekst naslova", - "headline_tip": "Podnaslov (nivo 2)", - "nowiki_sample": "Ovde umetnite neoblikovan tekst", - "nowiki_tip": "Zanemari viki oblikovanje", - "image_sample": "Primer.jpg", - "image_tip": "Ugrađivanje datoteke", - "media_sample": "Primer.ogg", - "media_tip": "Veza do datoteke", - "sig_tip": "VaÅ¡ potpis sa vremenskom oznakom", - "hr_tip": "Vodoravna linija (koristite retko)", "summary": "Opis izmene:", "subject": "Tema:", "minoredit": "Ovo je manja izmena", diff --git a/languages/i18n/srn.json b/languages/i18n/srn.json index 9de7eafd6c..579cd76f24 100644 --- a/languages/i18n/srn.json +++ b/languages/i18n/srn.json @@ -280,22 +280,6 @@ "newpassword": "Nyun waktiwortu:", "retypenew": "Nyun psa wortu ete wan tron:", "resetpass_submit": "Kenki yu waktiwortu nanga kon", - "bold_sample": "Fatu skrifi", - "bold_tip": "Fatu", - "italic_sample": "Skoinsi skrifi", - "italic_tip": "Skoinsi", - "link_sample": "Miti nen", - "link_tip": "Miti go na insey", - "extlink_sample": "http://www.example.com miti nen", - "extlink_tip": "Miti go na dorosey (no fergiti fu poti http:// fosi)", - "headline_sample": "Pisi ede nen", - "headline_tip": "Pisi ede nen", - "nowiki_sample": "Skrifi sondro wiki skrifi-fasi dyaso", - "nowiki_tip": "Skotu a wiki skrifi-fasi", - "image_tip": "Media file", - "media_tip": "Miti go na file", - "sig_tip": "Yu ondroskrifi nanga a dei nanga a yuru", - "hr_tip": "Didon lini (no kebroiki furu)", "summary": "In' syatu:", "subject": "Abra san/ede:", "minoredit": "Disi na wan pikin kenki", diff --git a/languages/i18n/stq.json b/languages/i18n/stq.json index 330dcb8e4a..c3eb89cecd 100644 --- a/languages/i18n/stq.json +++ b/languages/i18n/stq.json @@ -381,24 +381,6 @@ "passwordreset-emailtitle": "Benutserkontoinformatione ap {{SITENAME}}", "passwordreset-emailelement": "↓Benutsernoome: \n$1\n\nTemporär Paaswoud: \n$2", "passwordreset-emailsentemail": "↓Ne Ärinnerenge wuud uur E-Mail fersoand.", - "bold_sample": "Fatten Text", - "bold_tip": "Fatten Text", - "italic_sample": "Kursiven Text", - "italic_tip": "Kursive Text", - "link_sample": "Link-Text", - "link_tip": "Internen Link", - "extlink_sample": "http://www.example.com Link-Text", - "extlink_tip": "Externen Link (http:// beoachtje)", - "headline_sample": "Ieuwene 2 Uurskrift", - "headline_tip": "Ieuwene 2 Uurskrift", - "nowiki_sample": "Uunformattierden Text hier ienföigje", - "nowiki_tip": "Uunformattierden Text", - "image_sample": "Biespil.jpg", - "image_tip": "Doatäi-Ferbiendenge", - "media_sample": "Biespil.ogg", - "media_tip": "Mediendoatäi-Ferwies", - "sig_tip": "Dien Signatur mäd Tiedstämpel", - "hr_tip": "Horizontoale Lienje (spoarsoam ferweende)", "summary": "Touhoopefoatenge:", "subject": "Themoa:", "minoredit": "Bloot litje Seeken wuuden ferannerd", diff --git a/languages/i18n/sty.json b/languages/i18n/sty.json index 456d31c4ff..270e65130c 100644 --- a/languages/i18n/sty.json +++ b/languages/i18n/sty.json @@ -182,22 +182,6 @@ "pt-createaccount": "Йаңа аккаунт пултырғалы", "pt-userlogout": "Цыҡҡалы", "passwordreset": "Парольны пөтөрөү", - "bold_sample": "Ҡалын пелән йасыу", - "bold_tip": "Ҡалын пелән йасыу", - "italic_sample": "Курсив пелән йасыу", - "italic_tip": "Курсив пелән йасыу", - "link_sample": "Ссылканыңҡы төп исеме", - "link_tip": "Эцке ссылка", - "extlink_sample": "http://www.example.com ссылканың төп исеме", - "extlink_tip": "Тышҡы ссылка (http:// префиксны онотмаң)", - "headline_sample": "Төп исем", - "headline_tip": "2-нце ҡат төп исем", - "nowiki_sample": "Мынта форматлау кәрәкмәйтеген текстны өстәң", - "nowiki_tip": "Вики-форматлауға ҡолаҡ салмау", - "image_tip": "Кергеселгән файл", - "media_tip": "Файлға ссылка", - "sig_tip": "Ҡул ҡуйыуығыс пелән уаҡыт", - "hr_tip": "Горизонталь цыйыҡ (әлтән ошланмаң)", "summary": "Пашҡартыуларны аңнатыу:", "minoredit": "Кецкенә пашҡартыу", "watchthis": "Пы питне көсәткәле", diff --git a/languages/i18n/su.json b/languages/i18n/su.json index ce0d0685c3..a0e57b7cc2 100644 --- a/languages/i18n/su.json +++ b/languages/i18n/su.json @@ -580,24 +580,6 @@ "resettokens-watchlist-token": "Token pikeun asupan raramat (Atom/RSS) [[Special:Watchlist|parobahan kana kaca-kaca anu diponcorong]]", "resettokens-done": "Reset token.", "resettokens-resetbutton": "Setél token anu dipilih", - "bold_sample": "Téks kandel", - "bold_tip": "Téks kandel", - "italic_sample": "Tulisan déngdék", - "italic_tip": "Tulisan déngdék", - "link_sample": "Judul tutumbu", - "link_tip": "Tutumbu internal", - "extlink_sample": "http://www.example.com Judul tutumbu", - "extlink_tip": "Tutumbu kaluar (inget awalan http://)", - "headline_sample": "Téks judul", - "headline_tip": "Judul tingkat 2", - "nowiki_sample": "Asupkeun téks nu teu diformat di dieu", - "nowiki_tip": "Format wiki tong diwaro", - "image_sample": "Conto.jpg", - "image_tip": "Ngasupkeun gambar", - "media_sample": "Conto.ogg", - "media_tip": "Tutumbu berkas", - "sig_tip": "Paraf anjeun katut cap titimangsa", - "hr_tip": "Garis horisontal", "summary": "Ringkesan:", "subject": "Subyék:", "minoredit": "Ieu éditan minor", diff --git a/languages/i18n/sv.json b/languages/i18n/sv.json index dcc686b910..e1f585cb7e 100644 --- a/languages/i18n/sv.json +++ b/languages/i18n/sv.json @@ -130,6 +130,7 @@ "tog-useeditwarning": "Varna mig om jag lämnar en redigeringssida med osparade ändringar", "tog-prefershttps": "Använd alltid en säker anslutning medan jag är inloggad", "tog-showrollbackconfirmation": "Visa en bekräftelsedialog när man klickar pÃ¥ en tillbakarullningslänk", + "tog-requireemail": "Kräv e-postadress för att Ã¥terställa lösenord", "underline-always": "Alltid", "underline-never": "Aldrig", "underline-default": "Webbläsarens eller utseendets standardinställning", @@ -670,24 +671,6 @@ "resettokens-watchlist-token": "Nyckel för webbflöde (Atom/RSS) av [[Special:Watchlist|ändringar i sidor pÃ¥ din bevakningslista]]", "resettokens-done": "Nycklarna är Ã¥terställda.", "resettokens-resetbutton": "Återställ valda nycklar", - "bold_sample": "Fetstil", - "bold_tip": "Fetstil", - "italic_sample": "Kursiv stil", - "italic_tip": "Kursiv stil", - "link_sample": "Länktitel", - "link_tip": "Intern länk", - "extlink_sample": "http://www.exempel.com länktitel", - "extlink_tip": "Extern länk (kom ihÃ¥g prefixet http://)", - "headline_sample": "Rubriktext", - "headline_tip": "Rubrik i nivÃ¥ 2", - "nowiki_sample": "Skriv in oformaterad text här", - "nowiki_tip": "Ignorera wikiformatering", - "image_sample": "Exempel.jpg", - "image_tip": "Inbäddad fil", - "media_sample": "Exempel.ogg", - "media_tip": "Länk till fil", - "sig_tip": "Din signatur med tidsstämpel", - "hr_tip": "Horisontell linje (använd sparsamt)", "summary": "Sammanfattning:", "subject": "Ämne:", "minoredit": "Detta är en mindre ändring", @@ -1168,6 +1151,7 @@ "prefs-help-email": "Att ange e-postadress är valfritt, men gör det möjligt att fÃ¥ ditt lösenord mejlat till dig om du glömmer det.", "prefs-help-email-others": "Du kan ocksÃ¥ välja att lÃ¥ta andra kontakta dig via e-post genom en länk pÃ¥ din användar- eller diskussionssida. \nDin e-postadress avslöjas inte när andra användare kontaktar dig.", "prefs-help-email-required": "E-postadress mÃ¥ste anges.", + "prefs-help-requireemail": "Om detta markeras kommer lösenordsÃ¥terställningar endast skickas via e-post om Ã¥terställaren har angivit bÃ¥de användarnamn och e-postadress för detta konto.", "prefs-info": "Grundläggande information", "prefs-i18n": "Internationalisering", "prefs-signature": "Signatur", @@ -2621,6 +2605,7 @@ "ipblocklist-legend": "Sök efter en blockerad användare", "blocklist-userblocks": "Dölj kontoblockeringar", "blocklist-tempblocks": "Dölj tillfälliga blockeringar", + "blocklist-indefblocks": "Dölj otydliga blockeringar", "blocklist-addressblocks": "Dölj enskilda IP-blockeringar", "blocklist-type": "Typ:", "blocklist-type-opt-all": "Alla", diff --git a/languages/i18n/sw.json b/languages/i18n/sw.json index 6004a1a633..cc29e0b537 100644 --- a/languages/i18n/sw.json +++ b/languages/i18n/sw.json @@ -523,22 +523,6 @@ "resettokens-token-label": "$1 (current value: $2)", "resettokens-done": "Seti vibazi upya.", "resettokens-resetbutton": "Seti vibazi ulivyochagua upya", - "bold_sample": "Maandishi ya kooze", - "bold_tip": "Kukoozesha maandishi", - "italic_sample": "Matini ya italiki", - "italic_tip": "Matini ya italiki", - "link_sample": "Jina la kiungo", - "link_tip": "Kiungo cha ndani", - "extlink_sample": "http://www.example.com jina la kiungo", - "extlink_tip": "Kiungo cha nje (kumbuka kuanza na http:// )", - "headline_sample": "Matini ya kichwa cha habari", - "headline_tip": "Kichwa cha habari, saizi 2", - "nowiki_sample": "Weka matini bila fomati hapa", - "nowiki_tip": "Puuza fomati ya Wiki", - "image_tip": "Faili lililotiwa", - "media_tip": "Kiungo cha faili la picha, video, au sauti", - "sig_tip": "Sahihi yako na saa ya kusahihisha", - "hr_tip": "Mstari wa mlalo (usitumie ovyo)", "summary": "Muhtasari:", "subject": "Kuhusu/kichwa cha habari:", "minoredit": "Haya ni mabadiliko madogo", diff --git a/languages/i18n/szl.json b/languages/i18n/szl.json index 8446ebd584..14aba572af 100644 --- a/languages/i18n/szl.json +++ b/languages/i18n/szl.json @@ -66,9 +66,9 @@ "underline-never": "Ńigdy", "underline-default": "Podug sztalowańo uoglůndarki", "editfont-style": "Styl czćůnki we placu sprowjyń:", - "editfont-monospace": "Monotypowe krojło", - "editfont-sansserif": "Bezszeryfowe krojło", - "editfont-serif": "Szeryfowe krojło", + "editfont-monospace": "Monotypowe pismo", + "editfont-sansserif": "Bezszeryfowe pismo", + "editfont-serif": "Szeryfowe pismo", "sunday": "Niydziela", "monday": "Pyńdziałek", "tuesday": "Wtorek", @@ -252,8 +252,8 @@ "viewsourcelink": "pokŏż zdrzōdło", "editsectionhint": "Edytuj sekcyjõ: $1", "toc": "Wykŏz treści", - "showtoc": "uobejrzij", - "hidetoc": "schrůń", + "showtoc": "pokŏż", + "hidetoc": "skryj", "collapsible-collapse": "Skryj", "collapsible-expand": "Pokŏż", "thisisdeleted": "Pokŏzać abo stworzić zaś $1?", @@ -271,7 +271,7 @@ "sort-ascending": "Sortuj rosnůnco", "nstab-main": "Strōna", "nstab-user": "{{GENDER:{{BASEPAGENAME}}|Strōna ôd używŏcza|Strōna ôd używŏczki}}", - "nstab-media": "Pliki", + "nstab-media": "Zbiōr", "nstab-special": "Specjalnŏ strōna", "nstab-project": "Strōna projektu", "nstab-image": "Zbiōr", @@ -315,9 +315,9 @@ "no-null-revision": "Ńy je mogebne stworzyńe zerowyj wersyji zajty \"$1\"", "badtitle": "Niynŏleżny tytuł", "badtitletext": "Podany tytuł strōny to je niynŏleżny, prōzny, abo źle zalinkowany tytuł metajynzykowy abo interwiki.\nMoże w nim być jedyn abo wiyncyj znakōw, co niy mogōm być używane we tytułach.", - "perfcached": "To co sam je naszkryflane, to ino kopja ze pamjyńći podryncznyj a może ńy być aktualne. Nojwjyncyj {{PLURAL:$1|jydyn wynik je|$1 wyniki sům}} we tyj pamjyńći.", - "perfcachedts": "To co sam je naszkryflane, to ino kopja s pamjyńći podryncznyj a bůło uaktualńůne $1. Nojwjyncyj {{PLURAL:$4|jeden wynik je|$4 wyniki sům}} dostympne.", - "querypage-no-updates": "Uaktualńyńo lo tyj zajty sům terozki zawarte. Dane, kere sam sům, ńy zostouy uodśwjyżůne.", + "perfcached": "Dane niżyj sōm ze cache i mogōm niy być aktualne. Maksymalnie {{PLURAL:$1|jedyn wynik je|$1 wyniki sōm|$1 wynikōw je}} we tyj pamiyńci.", + "perfcachedts": "Dane niżyj sōm ze cache i ôstatni rŏz były uaktualniōne $1. Maksymalnie {{PLURAL:$4|jedyn wynik je|$4 wyniki sōm|$4 wynikōw je}} we pamiyńci cache.", + "querypage-no-updates": "Aktualizacyje tyj strōny sōm terŏz zastawiōne.\nDane tukej niy bydōm ôdświyżane.", "viewsource": "Zdrzōdłowy tekst", "viewsource-title": "Pokŏż zdrzōdło $1", "actionthrottled": "Akcyjo wstrzimano", @@ -347,7 +347,7 @@ "virus-badscanner": "Felerno konfiguracyjo – ńyznany skaner antywirusowy ''$1''", "virus-scanfailed": "skanowańy ńyudone (feler $1)", "virus-unknownscanner": "ńyznajůmy průgram antywirusowy", - "logouttext": "'''Terozki jeżeś wylůgowany'''.\n\nDej pozůr, co na ńykerych zajtach przeglůndarka może dali pokozywać co jeżeś zalůgowany, a bydźe tak aże uodśwjyżysz jeij cache.", + "logouttext": "<strong>Używŏcz je wylogowany.</strong>\n\nDej pozōr, że podwiela niy ôdświyżysz cache przeglōndarki, niykere strōny mogōm sie durch pokazować choćby trwało zalogowanie.", "welcomeuser": "Witej, $1", "welcomecreation-msg": "Uotwarli my sam lo Ćebje kůnto.\nPamjyntej coby posztalować [[Special:Preferences|preferencyji]]", "yourname": "Miano ôd używŏcza:", @@ -369,7 +369,7 @@ "login": "Wloguj sie", "nav-login-createaccount": "Logowańy / Tworzyńy kůnta", "logout": "Wyloguj", - "userlogout": "Uodloguj śe", + "userlogout": "Ôdlogowanie", "notloggedin": "Niy je żeś wlogowany(ŏ)", "userlogin-noaccount": "Niy mŏsz kōnta?", "userlogin-joinproject": "Dołōncz do {{GRAMMAR:D.lp|{{SITENAME}}}}", @@ -407,7 +407,7 @@ "nosuchusershort": "Ńy mo sam użytkowńika uo mjańe \"$1\".", "nouserspecified": "Musisz podać miano ôd używŏcza.", "login-userblocked": "Tyn sprowjorz mo zawarte sprowjyńa. Ńy idźe śe zalogować.", - "wrongpassword": "Hasło kere żeś naszkryfloł je felerne. Poprůbůj naszkryflać je jeszcze roz.", + "wrongpassword": "Wkludzōny login abo hasło sōm felerne.\nSprōbuj zaś.", "wrongpasswordempty": "Hasło kere żeś podou je uostawjůne blank. Naszkryflej je jeszcze roz.", "passwordtooshort": "Hasło kere żeś podoł je felerne abo za krůtke.\nHasło muśi mjeć przinojmńij {{PLURAL:$1|1 buchsztaba|$1 buchsztabůw}} a być inksze uod mjana użytkowńika.", "password-name-match": "Hasło mo być inksze atoli mjano używocza.", @@ -448,7 +448,7 @@ "user-mail-no-body": "Bůła průba posłańo e-brifa uo blank abo krůtkim tekśće.", "changepassword": "Zmiana hasła", "resetpass_announce": "Zalůgowołżeś śe ze tymczasowym kodym uotrzimanym bez e-brif. Coby zakůńczyć proces logůwańo muśisz nasztalować nowe hasło:", - "resetpass_header": "Zmjyń hasło lů swojygo kůnta", + "resetpass_header": "Zmiyń hasło kōnta", "oldpassword": "Stare hasło", "newpassword": "Nowe hasło", "retypenew": "Naszkryflej jeszcze roz nowe hasło:", @@ -457,7 +457,7 @@ "botpasswords": "Hasła bota", "resetpass_forbidden": "Ńy idźe sam půmjyńyć hasłůw.", "resetpass-no-info": "Å»eby mieć bezpostrzedni dostymp do tyj strōny, trzeba sie zalogować.", - "resetpass-submit-loggedin": "Zmjyń hasło", + "resetpass-submit-loggedin": "Zmiyń hasło", "resetpass-submit-cancel": "Uodćepej", "resetpass-wrong-oldpass": "Felerne tymczasowe abo aktualne hasło.\nMożliwe co właśńy zmjyńiłżeś swoje hasło abo poprosiłżeś uo nowe tymczasowe hasło.", "resetpass-temp-password": "Tymczasowe hasło:", @@ -478,29 +478,14 @@ "changeemail-newemail": "Nowŏ e-mailowŏ adresa:", "changeemail-none": "podstawowo", "changeemail-submit": "Spamjyntej nowy", - "resettokens": "Resetuj tokeny", - "bold_sample": "Ruby tekst", - "bold_tip": "Ruby tekst", - "italic_sample": "Kursywa", - "italic_tip": "Kursywa", - "link_sample": "Tytuł linku", - "link_tip": "Wewnytrzny link", - "extlink_sample": "http://www.example.com tytuł linku", - "extlink_tip": "Zewnyntrzny link (pamiyntej ô prefiksie http:// )", - "headline_sample": "Tekst nŏgōwka", - "headline_tip": "Nŏgōwek 2. poziōmu", - "nowiki_sample": "Wraź sam niysformatowany tekst", - "nowiki_tip": "Ignoruj formatowanie wiki", - "image_tip": "Wrażōny zbiōr", - "media_tip": "Link do zbioru", - "sig_tip": "Twōj podpis ze datōm i czasym", - "hr_tip": "Poziōmŏ linijŏ (niy nadużywej)", + "resettokens": "Resetuj tokyny", "summary": "Ôpis zmian:", "subject": "Tyjma/iberszryft:", "minoredit": "To je małŏ zmiana", "watchthis": "Ôbserwuj tã strōnã", "savearticle": "Spamiyntej", "publishpage": "Ôpublikuj strōnã", + "publishchanges": "Ôpublikuj zmiany", "publishpage-start": "Ôpublikuj strōnã...", "preview": "Podglōnd", "showpreview": "Pokŏż podglōnd", @@ -560,7 +545,7 @@ "editingold": "'''Dej pozůr: Sprowjosz inkszo wersyjo zajty kej bjeżůnco. Jeli jům naszkryflosz, wszyjske půźńyjsze pomjyńańa bydům wyćepane.'''", "yourdiff": "Rōżnice", "copyrightwarning": "Pamjyntej uo tym, aże cołki wkłod do {{SITENAME}} udostympńůmy wedle zasad $2 (dokładńij we $1). Jak ńy chcesz, coby kożdy můg go půmjyńać a dalij rozpowszychńoć, ńy wćepuj uůnygo sam. Szkryflajůnc sam tukej pośwjadczosz tyż, co te pisańy je twoje własne, abo żeś go wźůn(a) ze materjołůw kere sům na ''public domain'', abo kůmpatybilne.<br />\n'''PROSZA ŃY WĆEPYWAĆ SAM MATYRJOŁŮW KERE SÅ®M CHRŮŃONE AUTORSKIM PRAWYM BEZ DOZWOLEŃO WŁAŚĆIĆELA!'''", - "copyrightwarning2": "Pamjyntej uo tym, aże cołki wkłod do {{GRAMMAR:MS.lp|{{SITENAME}}}} może być sprowjany, pomjyńany abo wyćepany bez inkszych użytkownikůw. Jak ńy chcysz, coby kożdy můg uůnygo zmjyńać a dalij rozpowszychńoć bez uograniczyń, ńy wćepuj go sam.<br />\nSzkryflajůnc sam tukej pośwjadczosz tyż, co te pisańy je twoje własne, abo żeś go wźůn(a) ze matyrjołůw kere sům na public domain, abo kůmpatybilne (kuknij tyż: $1).\n'''PROSZA ŃY WĆEPYWAĆ SAM MATYRJOŁŮW KERE SÅ®M CHRŮŃONE PRAWYM AUTORSKIM BEZ DOZWOLEŃO WŁAŚĆIĆELA!'''", + "copyrightwarning2": "Dej pozōr, iże cołki wkłŏd na {{SITENAME}} może być edytowany, zmiyniany abo kasowany ôd inkszych używŏczōw. Jeźli niy chcesz, żeby twōj tekst bōł niymiyłosiernie edytowany, to niy wkludzej go sam.<br />\nPrzirzekŏsz tyż nōm, iże wszyjsko je napisane ôd ciebie abo skopiowane ze dōmyny publicznyj abo podobnego wolnego zdrzōdła (po wiyncyj informacyji patrz $1).\n<strong>Niy wkludzej dzieł chrōniōnych autorskimi prawami bez przizwolyniŏ!</strong>", "longpageerror": "''Feler: Tekst kery żeś sam wćepywoł mo {{PLURAL:$1|jedyn kilobajt|$1 kilobajtůw}}. Maksymalno dugość tekstu ńy może być srogszo kej {{PLURAL:$2|jedyn kilobajt|$2 kilobajtůw}}. Twůj tekst ńy bydźe sam naszkryflany.'''", "readonlywarning": "'''Dej pozůr: Baza danych zostoua filowo zawarto skuli potřeb admińistracyjnych. Bestůž ńy do śe terozki naÅ¡kryflać Twojich pomjyńań. Radzymy přećepać nowy tekst kajś do plika tekstowego (wytnij/wklej) a wćepać sam zaś po uodymkńyńću bazy.'''\n\nAdmińistrator kery zawar baza dou take wyjaśńyńe: $1", "protectedpagewarning": "'''Dej pozůr: Sprowjańe tyj zajty zostoło zawarte. Mogům jům sprowjać ino użytkowńicy ze uprawńyńami admińistratora.'''\nUostatńy wpis w rejerze je poniżej.", @@ -568,15 +553,15 @@ "cascadeprotectedwarning": "'''Dej pozůr:''' Ta zajta zostoła zawarto a ino użytkowńicy ze uprawńyńami admińistratora mogům jům sprowjać. Zajta ta je podpjynto pod {{PLURAL:$1|nastympujůnco zajta, kero zostoła zawarto|nastympujůncych zajtach, kere zostouy zawarte}} ze załůnczonům uopcjům dźedźiczyńo:", "titleprotectedwarning": "'''Dej pozůr: Zajta uo tym titlu zostoła zawarto a ino [[Special:ListGroupRights|ńykerzi użytkowńicy]] mogům jům wćepać.'''\nUostatńy wpis z rejera je ńyżej.", "templatesused": "{{PLURAL:$1|Muster użyty|Mustry użyte}} na tyj strōnie:", - "templatesusedpreview": "{{PLURAL:$1|Muster użyty|Mustry użyte}} na tyj podglōńdzie:", + "templatesusedpreview": "{{PLURAL:$1|Muster użyty|Mustry użyte}} na tym podglōńdzie:", "templatesusedsection": "{{PLURAL:$1|Szablon|Szablůny}} użyte we tyj tajli:", "template-protected": "(chrōniōny)", "template-semiprotected": "(pōłzawarte)", "hiddencategories": "Ta strōna je we {{PLURAL:$1|jednyj skrytyj kategoryji|$1 skrytych kategoryjach}}:", "nocreatetext": "Na {{GRAMMAR:MS.lp|{{SITENAME}}}} tworzyńy nowych zajtůw uograńiczůno.\nMoges sprowjać te co już sům, abo [[Special:UserLogin|zalogować śe, abo śa zaregisztrować]].", "nocreate-loggedin": "Ńy mosz uprowńyń do tworzyńo nowych zajtůw.", - "sectioneditnotsupported-title": "Sprowjańy tajli ńymogebne", - "sectioneditnotsupported-text": "Sprowjańy tajli ńymogebne na tyj zajće.", + "sectioneditnotsupported-title": "Edycyjŏ sekcyje niyma spiyranŏ", + "sectioneditnotsupported-text": "Edycyjŏ sekcyji niyma spiyranŏ na tyj strōnie.", "permissionserrors": "Feler uprawniyń", "permissionserrorstext": "Ńy mosz uprowńyń do takij akcyje {{PLURAL:$1|skuli tego, co:|bestůż, co:}}", "permissionserrorstext-withaction": "Niy mŏsz przizwolyniŏ na $2, skuli {{PLURAL:$1|takigo powodu|takich powodōw}}:", @@ -589,7 +574,7 @@ "edit-no-change": "Twoje sprowjyńe uostoło zignorowane pů takymu, aże ńic żeś we tekśće ńy zmjyńůł.", "postedit-confirmation-saved": "Spamjyntano twoje sprowjyńe.", "edit-already-exists": "Ńy idźe utworzić nowyj zajty.\nTako zajta już sam je.", - "defaultmessagetext": "Tekst důmyślny", + "defaultmessagetext": "Wychodny tekst wiadōmości", "content-model-wikitext": "wikitekst", "expensive-parserfunction-warning": "Dej pozůr: ta zajta mo za dużo uodwouań do funkcyji parsera, kere mocno uobćůnżajům systym.\n\nPowinno być myńi jak $2 {{PLURAL:$2|wywołańy|wywołańo|wywołań}}, a terozki {{PLURAL:$1|je $1 wywołańy|sům $1 wywołańo|je $1 wywołań}}.", "expensive-parserfunction-category": "Zajty kere majům za dużo uodwołań do funkcyji parsera, kere mocno uobćůnżajům systym.", @@ -750,7 +735,7 @@ "search-showingresults": "{{PLURAL:$4|Rezultat <strong>$1</strong> ze <strong>$3</strong>|Rezultaty <strong>$1 – $2</strong> ze <strong>$3</strong>}}", "search-nonefound": "Żŏdne wyniki niy ôdpowiadajōm tymu zapytaniu.", "powersearch-legend": "Sznupańy zaawansowane", - "powersearch-ns": "Sznupej we przestrzyńach mjan:", + "powersearch-ns": "Szukej we przestrzyniach mian:", "powersearch-togglelabel": "Ôznŏcz:", "powersearch-toggleall": "Wszyjsko", "powersearch-togglenone": "Nic", @@ -762,34 +747,34 @@ "prefs-edits": "Liczba edycyji:", "prefs-skin": "Skůrka", "skin-preview": "podglůnd", - "datedefault": "Důmyślny", + "datedefault": "Wychodny", "prefs-labs": "Funkcyje \"labs\"", "prefs-user-pages": "Zajty ôd używŏczōw", "prefs-personal": "Dane używocza", "prefs-rc": "Ôstatnie zmiany", - "prefs-watchlist": "Pozůrlista", + "prefs-watchlist": "Ôbserwowane", "prefs-watchlist-days": "Liczba dńůw widocznych na liśće artikli, na kere dowosz pozůr:", "prefs-watchlist-days-max": "Max $1 {{PLURAL:$1|dźyń|dńi}}", "prefs-watchlist-edits": "Liczba půmjyńań pokozywanych we rozszyrzůnyj liśće artiklůw, na kere dowosz pozůr:", "prefs-watchlist-edits-max": "Maksymalno liczba: 1000", "prefs-watchlist-token": "ID pozůrlisty:", "prefs-misc": "Roztůmajte", - "prefs-resetpass": "Zmjyń hasło", + "prefs-resetpass": "Zmiyń hasło", "prefs-changeemail": "Zmiyń abo skasuj adresã e-mail", "prefs-setemail": "Nasztaluj adresã e-mail", "prefs-email": "Ôpcyje e-maila", "prefs-rendering": "Wyglōnd", "saveprefs": "Spamjyntej", "restoreprefs": "Prziwrōć wszyjske wychodne preferyncyje (we wszyjskich sekcyjach)", - "prefs-editing": "Sprowjańy", + "prefs-editing": "Edycyjŏ", "searchresultshead": "Sznupańy", "stub-threshold": "Maksymalny rozmjar artikla uoznaczanygo kej <a href=\"#\" class=\"stub\">stub (kůnsek)</a>", "stub-threshold-disabled": "Uodymkńynte", "recentchangesdays": "Liczba dńůw do pokazańo we půmjyńanych na uostatku:", "recentchangesdays-max": "(maksymalńy $1 {{PLURAL:$1|dźyń|dńi}})", "recentchangescount": "Liczba pozycyji na liśće půmjyńanych na uostatku, we historyje zajtůw a zajtach rejerůw:", - "prefs-help-recentchangescount": "Ze listům ńydawnych pomjyńan, gyszichta zajt a rejer.", - "savedprefs": "Twoje sztalowańo we preferyncyjach zostoły naszkryflane.", + "prefs-help-recentchangescount": "Maksymalnŏ wielość: 1000", + "savedprefs": "Twoje sztelōnki były spamiyntane.", "timezonelegend": "Czasowo sztrefa", "localtime": "Lokalny czas:", "timezoneuseserverdefault": "Użyj domyślnygo czasu serwera ($1)", @@ -807,12 +792,12 @@ "timezoneregion-indian": "Ocean Indyjski", "timezoneregion-pacific": "Uocean Spokojny", "allowemail": "Inksze użytkowńiki můgům posyłać mje e-brify", - "prefs-searchoptions": "Sznupańe", + "prefs-searchoptions": "Wyszukowanie", "prefs-namespaces": "Raumy mjan", "default": "důmyślńy", - "prefs-files": "Pliki", + "prefs-files": "Zbiory", "youremail": "E-mail:", - "username": "{{GENDER:$1|Mjano używocza}}:", + "username": "{{GENDER:$1|Miano ôd używŏcza|Miano ôd używŏczki}}:", "prefs-memberingroups": "Należy do {{PLURAL:$1|grupy|grup:}}", "prefs-registration": "Data registracyje:", "yourrealname": "Prawdźiwe mjano", @@ -890,7 +875,7 @@ "right-bigdelete": "Wyćep zajty s dugům historyjům půmjyńań", "right-deleterevision": "Wyćepywańy a wćepywańy nazod wskazanych sprowjyń zajtůw", "right-deletedhistory": "Pokazuj historyjo usuńyntych sprowjyń, bez tekstu uopisu", - "right-browsearchive": "Sznupej za wyćepanymi zajtůma", + "right-browsearchive": "Szukej we skasowanych strōnach", "right-undelete": "Prziwrŏcanie skasowanych strōn", "right-suppressrevision": "Přyglůndańy i uodtwařańy sprowjyń schrůńůnych před admińistratorami", "right-suppressionlog": "Pokoż prywatne lůgi", @@ -918,9 +903,9 @@ "right-userrights-interwiki": "Edytuj uprawniynia używŏczōw na inkszych wiki", "right-siteadmin": "Zawjerańy i uodmykańy bazy danych", "newuserlogpage": "Ksiōnżka nowych używŏczōw", - "newuserlogpagetext": "To je rejer uostatńo utworzůnych kůnt użytkowńikůw", + "newuserlogpagetext": "To je regest tworzōnych używŏczōw.", "rightslog": "Regest uprawniyń używŏczōw", - "rightslogtext": "Rejer půmjyńań uprawńyń užytkowńikůw.", + "rightslogtext": "To je regest zmian uprawniyń używŏczōw.", "action-read": "přeglůndańo tyj zajty", "action-edit": "edycyje tyj strōny", "action-createpage": "tworzyńo zajtůw", @@ -970,7 +955,13 @@ "recentchanges-legend-newpage": "{{int:recentchanges-label-newpage}} (ôbejzdrzij tyż [[Special:NewPages|listã nowych strōn]])", "rcfilters-legend-heading": "<strong>Wykŏz skrōtōw:</strong>", "rcfilters-other-review-tools": "Inksze nŏrzyńdzia kōntrole", + "rcfilters-savedqueries-cancel-label": "Pociep", + "rcfilters-search-placeholder": "Filtruj zmiany (użyj myni abo wyszukej podle filtra)", + "rcfilters-filter-user-experience-level-unregistered-description": "Edytorzi, co niy sōm zalogowani.", "rcfilters-filter-humans-label": "Czowiek (niy bot)", + "rcfilters-filter-pageedits-label": "Edycyje strōny", + "rcfilters-filter-newpages-label": "Tworzynie strōn", + "rcfilters-filter-logactions-label": "Registrowane czyności", "rcfilters-liveupdates-button": "Aktualizacyje na żywo", "rcfilters-liveupdates-button-title-on": "Zastŏw aktualizacyje na żywo", "rcnotefrom": "Niżyj {{PLURAL:$5|je zmiana|sōm zmiany}} ôd <strong>$3, $4</strong> ({{PLURAL:$5|je pokŏzanŏ|sōm pokŏzane}} nojwyżyj <strong>$1</strong>).", @@ -996,7 +987,7 @@ "hist": "hist.", "hide": "Skryj", "show": "Pokŏż", - "minoreditletter": "d", + "minoreditletter": "m", "newpageletter": "N", "boteditletter": "b", "rc-change-size-new": "$1 {{PLURAL:$1|bajt|bajty|bajtōw}} po zmianie", @@ -1013,13 +1004,13 @@ "recentchangeslinked-to": "Pokŏż zmiany na strōnach, co linkujōm do podanyj strōny", "upload": "Zaladuj zbiōr", "uploadbtn": "Prziślij zbiōr", - "reuploaddesc": "Nazod do formulařa uod wćepywańo.", + "reuploaddesc": "Pociep przesyłanie i wrōć do formulara.", "uploadnologin": "Niy je żeś wlogowany(ŏ)", "uploadnologintext": "MuśyÅ¡ śe [[Special:UserLogin|zalůgować]] ńim wćepńeÅ¡ pliki.", "upload_directory_missing": "Katalog lo wćepywanych plikůw ($1) ńy istńeje a serwer WWW ńy poradźi go utwořić.", "upload_directory_read_only": "Serwer ńy može Å¡kryflać do katalůgu ($1) kery je přeznačůny na wćepywane pliki.", "uploaderror": "Feler při wćepywańu", - "uploadtext": "Ůžyj formulařa půńižej do wćepywańo plikůw.\nJak chceÅ¡ přejřeć dotychčas wćepane pliki, abo w ńich Å¡nupać, přeńdź do [[Special:FileList|listy douůnčůnych plikůw]]. WÅ¡yjstke wćepańo uodnotowane sům we [[Special:Log/upload|rejeře přesůuanych plikůw]], a jygo wyćepańy we [[Special:Log/delete|rejeře wyćepanych]].\n\nPlik pojawi śe na zajće, jak užyjeÅ¡ linka wedle jydnygo s nastympujůncych wzorůw:\n* '''<code><nowiki>[[</nowiki>{{ns:file}}<nowiki>:Plik.jpg]]</nowiki></code>''' pokože plik we pounyj postaći\n* '''<code><nowiki>[[</nowiki>{{ns:file}}<nowiki>:Plik.png|200px|thumb|left|tekst uopisu]]</nowiki></code>''' pokože Å¡yroko na 200 pikseli mińjaturka umjyščůno při lewym margineśe, uotočůno bez ramka, s podpisym „podpis grafiki”\n* '''<code><nowiki>[[</nowiki>{{ns:media}}<nowiki>:Plik.ogg]]</nowiki></code>''' dowo bezpostředńi link do plika ńy pokozujůnc go", + "uploadtext": "Użyj formulara niżyj, żeby przisłać zbiory.\nÅ»eby przejzdrzeć abo szukać zaladowane zbiory, idź do [[Special:FileList|listy zaladowanych zbiorōw]], przisłania sōm tyż listowane we [[Special:Log/upload|regeście przisłań]], skasowania sōm we [[Special:Log/delete|regeście skasowań]].\n\nÅ»eby wrazić zbiōr na strōnã, użyj linka we jednyj ze formōw niżyj:\n* <strong><code><nowiki>[[</nowiki>{{ns:file}}<nowiki>:Zbiōr.jpg]]</nowiki></code></strong>, żeby użyć połnyj wersyje zbioru\n* <strong><code><nowiki>[[</nowiki>{{ns:file}}<nowiki>:Zbiōr.png|200px|thumb|left|alt text]]</nowiki></code></strong>, żeby użyć 200 pikselōw szyrokõ miniaturã we rōmce przi lewym marginesie ze „alt text” za ôpis\n* <strong><code><nowiki>[[</nowiki>{{ns:media}}<nowiki>:Zbiōr.ogg]]</nowiki></code></strong>, żeby bezpostrzednio linkować zbiōr bez jego pokazowaniŏ", "upload-permitted": "Dopuščalne formaty plikůw: $1.", "upload-preferred": "Zalecane formaty plikůw: $1.", "upload-prohibited": "Zakozane formaty plikůw: $1.", @@ -1142,12 +1133,13 @@ "filedelete-reason-otherlist": "Inkszy powůd", "filedelete-reason-dropdown": "* Nojczynstsze powody wyćepańa\n** Naruszyńy praw autorskych\n** Kopja plika kery już sam jest", "filedelete-edit-reasonlist": "Sprowjańe powodůw wyćepańo zajty", - "mimesearch": "Sznupej MIME", + "mimesearch": "Szukanie podle typu MIME", "mimesearch-summary": "Ta zajta ůmožliwjo Å¡nupańe za plikůma wedle jeich typu MIME. Užyće: typtreśći/podtyp, np. <code>image/jpeg</code>.", "mimetype": "Typ MIME:", "download": "pobier", "unwatchedpages": "Zajty na kere ńy je dowany pozůr", "listredirects": "Lista przekerowań", + "listduplicatedfiles": "Lista zbiorōw ze tuplikatami", "unusedtemplates": "Niyużywane mustry", "unusedtemplatestext": "Půńižej znojdowo śe lista wÅ¡yjstkich zajtůw s přestřyńi mjan {{ns:template}}, kere ńy sům užywane bez inkÅ¡e zajty. Sprowdź inkÅ¡e adresowańa ku Å¡ablůnům, ńim wyćepńeÅ¡ ta zajta.", "unusedtemplateswlh": "ku adresatu", @@ -1161,9 +1153,9 @@ "statistics-header-users": "Statystyka užytkowńikůw", "statistics-articles": "Zajty", "statistics-pages": "Zajty", - "statistics-pages-desc": "Wszyjstke zajty na wiki, wroz ze zajtami godki, przekerowańami a t.p.", - "statistics-files": "Wćepane pliki", - "statistics-edits": "Sprowjyńa wykůnane uod powstańo {{grammar:D.lp|{{SITENAME}}}}", + "statistics-pages-desc": "Wszyjske strōny na wiki, społym ze dyskusyjami, pōnkniyńciami itp.", + "statistics-files": "Zaladowane zbiory", + "statistics-edits": "Edycyje strōn ôd powstaniŏ {{grammar:D.lp|{{SITENAME}}}}", "statistics-edits-average": "Strzedńo liczba sprowjyń na zajta", "statistics-users": "Zarejerowanych użytkowńikůw", "statistics-users-active": "Aktywnych użytkowńikůw", @@ -1190,7 +1182,7 @@ "nrevisions": "$1 {{PLURAL:$1|wersja|wersje|wersjůw}}", "specialpage-empty": "Ta zajta je pusto.", "lonelypages": "Sierocie strōny", - "lonelypagestext": "Do zajtůw půńiżyj ńy adresuje żodno inkszo zajta we {{SITENAME}}.", + "lonelypagestext": "Do tych strōn niy linkuje żŏdnŏ inkszŏ strōna we {{GRAMMAR:MS.lp|{{SITENAME}}}}.", "uncategorizedpages": "Niyskategoryzowane strōny", "uncategorizedcategories": "Kategoryje bez kategoryji", "uncategorizedimages": "Niyskategoryzowane zbiory", @@ -1201,12 +1193,13 @@ "wantedpages": "Potrzebne strōny", "wantedfiles": "Potrzebne zbiory", "wantedtemplates": "Potrzebne mustry", - "mostlinked": "Nojczyńśćij adresowane", - "mostlinkedcategories": "Kategoryje we kerych je nojwjyncyj artikli", + "mostlinked": "Nojczyńścij linkowane", + "mostlinkedcategories": "Nojwiyncyj używane kategoryje", "mostlinkedtemplates": "Nojczyńśćij adresowane mustry", - "mostcategories": "Zajty kere majům nojwiyncyj kategoryjůw", - "mostimages": "Nojczyńśćij adresowane pliki", - "mostrevisions": "Nojczyńśćij sprowjane artikle", + "mostcategories": "Strōny, co majōm nojwiyncyj kategoryji", + "mostimages": "Nojczyńścij używane zbiory", + "mostinterwikis": "Strōny, co majōm nojwiyncyj linkōw interwiki", + "mostrevisions": "Nojwiyncyj edytowane strōny", "prefixindex": "Wszyjske strōny ze prefiksym", "shortpages": "Nojkrōtsze strōny", "longpages": "Duge strōny", @@ -1217,7 +1210,7 @@ "protectedpages-cascade": "Yno zajty zabezpjeczůne rekursywńy", "protectedpagesempty": "Å»odno zajta ńy je terozki zawarto ze podanymi parametrami.", "protectedtitles": "Zastawiōne tytuły", - "protectedtitlesempty": "Do tych Å¡talowań utwořyńy artikla uo dowolnym mjańy ńy je zawarte", + "protectedtitlesempty": "Żŏdne strōny niy sōm terŏz zawarte ze tymi parametrami.", "listusers": "Lista używŏczōw", "listusers-editsonly": "Pokoż yno użytkowńikůw kere majům sprowjyńa", "usereditcount": "$1 {{PLURAL:$1|sprowjyńe|sprowjyńa|sprowjyń}}", @@ -1228,7 +1221,7 @@ "move": "Przeniyś", "movethispage": "Přećepej ta zajta", "unusedimagestext": "Pamjyntej, proÅ¡a, aže inkÅ¡e witryny, np. projekty Wikimedja w inkÅ¡ych godkach, můgům adresować do tych plikůw užywajůnc bezpośredńo URL. Bez tůž ńykere ze plikůw můgům sam być na tej liśće pokozane mimo, aže žodna zajta ńy adresuje do ńich.", - "unusedcategoriestext": "Katygorje pokazane půńižej istńejům, choć ńy kořisto s ńich žadyn artikel ańi katygorja.", + "unusedcategoriestext": "Te strōny kategoryji istniyjōm, chociŏż żŏdnŏ inkszŏ strōna ani kategoryjŏ ich niy używŏ.", "notargettitle": "Wskazywano zajta ńy istńeje", "notargettext": "Ńy podano zajty abo užytkowńika, do kerych ta uoperacyjo mo być wykůnano.", "nopagetitle": "Ńy ma sam zajty docelowyj", @@ -1239,12 +1232,12 @@ "booksources": "Zdrzōdła ksiōnżek", "booksources-search-legend": "Szukej informacyji ô ksiōnżkach", "booksources-search": "Szukej", - "booksources-text": "Půńiżyj je lista uodnośńikůw do inkszych witryn, kere pośredńiczům we sprzedaży nowych a używanych buchůw, a tyż můgům mjeć dolsze informacyje uo poszukiwanym bez ćebje buchu.", + "booksources-text": "Niżyj je wykŏz linkōw do inkszych strōn, co przedŏwajōm nowe i używane ksiōnżki, i mogōm mieć dalsze informacyje ô ksiōnżkach, co ich szukŏsz:", "booksources-invalid-isbn": "Podany numer ISBN zostoł rozpoznany kej felerny. Sprowdź aże podany numer je zgodny s numerym kery je we zdrzůdle.", "specialloguserlabel": "Fto:", "speciallogtitlelabel": "Cyl (nazwa abo {{ns:user}}:miano ôd używŏcza):", "log": "Regest ôperacyji", - "all-logs-page": "Wszyjske óperacyje", + "all-logs-page": "Wszyjske ôperacyje", "alllogstext": "Spōlne pokŏzanie wszyjskich dostympnych regestōw {{SITENAME}}.\nMożesz uakuratnić widok bez ôbranie zorty regestu, miana ôd używŏcza, abo tykanyj strōny (dŏwŏ pozōr na małe i sroge litery).", "logempty": "Niy ma we regeście zgodliwych elymyntōw.", "log-title-wildcard": "Szukej tytułōw, co sie zaczynajōm ôd tego tekstu", @@ -1263,10 +1256,10 @@ "categories": "Kategoryje", "categoriespagetext": "Zajta przedstowjo lista katygoryji s zajtůma a plikůma.\n[[Special:UnusedCategories|Ńyużywane kategoryj]] ńy zostoły tukej pokozane.\nKukńij tyż [[Special:WantedCategories|ńyistńyjůnce kategoryje]].", "categoriesfrom": "Pokož kategoryje začynajůnc uod:", - "deletedcontributions": "Wyćepane sprowjyńa użytkowńika", - "deletedcontributions-title": "Wyćepane sprowjyńa użytkowńika", + "deletedcontributions": "Skasowany wkłŏd ôd używŏcza", + "deletedcontributions-title": "Skasowany wkłŏd ôd używŏcza", "sp-deletedcontributions-contribs": "wkłŏd", - "linksearch": "Necowe uodwołańa", + "linksearch": "Szukanie zewnyntrznych linkōw", "linksearch-pat": "Wzorzec sznupańo", "linksearch-ns": "Przestrzyń mjan", "linksearch-ok": "Å nupej", @@ -1313,8 +1306,8 @@ "emailsend": "Wyślij", "emailccme": "Wyślij mi kopja moiy wjadomości.", "emailccsubject": "Kopja Twojej wjadůmośći do $1: $2", - "emailsent": "Wjadůmość zostoua wysuano", - "emailsenttext": "Twoja wjadůmość zostoua wysuano.", + "emailsent": "E-mail wysłany", + "emailsenttext": "Twoja wiadōmość e-mail je wysłanŏ.", "emailuserfooter": "Wjadůmość e-brif zostoła wysłano s {{GRAMMAR:D.lp|{{SITENAME}}}} ku $2 bez $1 s użyćym „Wyślij e-brif ku tym użytkowńikowi”.", "usermessage-editor": "Nadŏwca systymowych kōmunikatōw", "watchlist": "Ôbserwowane", @@ -1330,7 +1323,7 @@ "unwatch": "Niy ôbserwuj", "unwatchthispage": "Přestoń dować pozůr", "notanarticle": "To ńy je artikel", - "notvisiblerev": "Wersyja zostoua wyćepano", + "notvisiblerev": "Ôstatniŏ wersyjŏ ôd inkszego używŏcza była skasowanŏ", "watchlist-details": "Na Twojij liście ôbserwowanych {{PLURAL:$1|je $1 strōna|sōm $1 strōny|je $1 strōn}} (plus strōny dyskusyje).", "wlheader-enotif": "Wysůuańy powjadůmjyń na adres e-brif je zouůnčůne", "wlheader-showupdated": "Zajty, co były zmiyniane ôd twojij ôstatnij nŏwiydzki na nich ôstały ukŏzane <strong>na rubo</strong>.", @@ -1357,10 +1350,10 @@ "confirmdeletetext": "Zarŏz wyciepniesz artikel i cołkõ ôd niygo historyjõ. Przitupluj, iże na isto chcesz to zrobić, miarkujesz kōnsekwyncyje, i co robisz to podle [[{{MediaWiki:Policy-url}}|prawideł]].", "actioncomplete": "Fertig", "actionfailed": "Ńy udało śe.", - "deletedtext": "Wyćepano \"$1\". Rejer uostatnio zrobiůnych wyćepań možeÅ¡ uobejžyć tukej: $2.", + "deletedtext": "Strōna „$1” była skasowanŏ.\nWejzdrzij na $2 po regest ôstatnich skasowań.", "dellogpage": "Regest kasowań", "dellogpagetext": "To je lista uostatńo wykůnanych wyćepań.", - "deletionlog": "rejer wyćepań", + "deletionlog": "regest skasowań", "reverted": "Prziwrōcōnŏ poprzedniõ wersyjõ", "deletecomment": "Čymu:", "deleteotherreason": "InkÅ¡y powůd:", @@ -1373,7 +1366,7 @@ "rollbacklink": "cŏfej", "rollbacklinkcount": "cŏfnij $1 {{PLURAL:$1|edycyjõ|edycyje|edycyji}}", "rollbackfailed": "Niy szło wycŏfać zmiany", - "cantrollback": "Ńy idże cofnůńć pomjyńyńo, sam je ino jedna wersyja tyi zajty.", + "cantrollback": "Niy idzie cŏfnōńć edycyje;\nôstatni edytōr to je jedyny autōr tyj strōny.", "alreadyrolled": "Ńy idźe lů zajty [[:$1|$1]] cofnůńć uostatńygo pomjyńeńa, kere wykonoł [[User:$2|$2]] ([[User talk:$2|godka]]{{int:pipe-separator}}[[Special:Contributions/$2|{{int:contribslink}}]]).\nKto inkszy zdůnżůł już to zrobić abo wprowadźił własne poprowki do treśći zajty.\n\nAutorym ostatńygo pomjyńyńo je terozki [[User:$3|$3]] ([[User talk:$3|godka]]{{int:pipe-separator}}[[Special:Contributions/$3|{{int:contribslink}}]]).", "editcomment": "Sprowjyńe uopisano: <em>$1</em>.", "revertpage": "Wycofano sprowjyńe użytkowńika [[Special:Contributions/$2|$2]] ([[User talk:$2|godka]]). Autor prziwrůcůnej wersyji to [[User:$1|$1]].", @@ -1385,14 +1378,14 @@ "modifiedarticleprotection": "zmiyniōł(yła) poziōm zawarciŏ „[[$1]]”", "unprotectedarticle": "uodymknyu [[$1]]", "movedarticleprotection": "przekludzůno sztalowańa zabezpjeczyńo s „[[$2]]” ku „[[$1]]”", - "protect-title": "Pomjyńeńe poźomu zawarćo „$1”", + "protect-title": "Zmiana poziōmu zawarciŏ „$1”", "prot_1movedto2": "[[$1]] přećepano do [[$2]]", "protect-legend": "Potwjyrdź zawarće", "protectcomment": "Čymu:", - "protectexpiry": "Wygaso:", + "protectexpiry": "Wygasŏ:", "protect_expiry_invalid": "Čas wygaśńjyńćo je zuy.", "protect_expiry_old": "Čas wygaśńjyńćo je w downiej ńiž terozki.", - "protect-text": "Sam tukej možyÅ¡ uobejžeć i pomjyńyć poźům zawarcia zajty '''$1'''.", + "protect-text": "Sam możesz ôbejzdrzeć i zmiynić poziōmy zawarciŏ strōny <strong>$1</strong>.", "protect-locked-blocked": "Ńy možeÅ¡ půmjyńać poźůmůw zawarćo kej žeś sům je zawarty uod sprowjyń. Terozki Å¡talowańa dla zajty '''$1''' to:", "protect-locked-dblock": "Ńy idźe půmjyńić poźůmu zawarća s kuli tygo co baza danych tyž je zawarto. Uobecne Å¡talowańa dla zajty '''$1''' to:", "protect-locked-access": "Ńy moÅ¡ uprowńyń coby pomjyńyć poziům zawarcia zajty. Uobecne ustawjyńo dlo zajty '''$1''' to:", @@ -1404,18 +1397,19 @@ "protect-summary-cascade": "dźedźičyńy", "protect-expiring": "wygaso $1 (UTC)", "protect-expiry-indefinite": "na zowdy", - "protect-cascade": "Dźedźyčyńe zawarćo - zawřij wÅ¡yskie zajty kere sům na tyi zajće.", + "protect-cascade": "Zawrzij strōny, co sōm wrażōne do tyj strōny (erbowanie zawarciŏ)", "protect-cantedit": "Ńy možeÅ¡ pomjyńyć poziůmu zawarća tyi zajty, po takiymu, co uona je dlo Ćebje zawarto uod pomjyńańa.", "protect-othertime": "Inkszy uokres:", "protect-othertime-op": "inkszy uokres", "protect-existing-expiry": "Czas wygaśńyńćo nasztalowany terozki: $2 uo $3", + "protect-existing-expiry-infinity": "Czas wygaśniyńciŏ: niyskōńczōny", "protect-otherreason": "Inkszy/dodatkowy powůd:", "protect-otherreason-op": "inkszy/dodatkowy powůd", "protect-dropdown": "*Nojczynstsze powody zawarćo uod sprowjyń\n** Czynste wandalizmy\n** Czynste spamowańy\n** Wojna edycyjno\n** Wygupy", - "protect-edit-reasonlist": "Sprowjej powody zawarćo uod sprowjyń", + "protect-edit-reasonlist": "Edytuj powody zawarciŏ", "protect-expiry-options": "2 godźiny:2 hours,1 dźyń:1 day,3 dńi:3 days,1 tydźyń:1 week,2 tygodńy:2 weeks,1 mjeśůnc:1 month,3 mjeśůnce:3 months,6 mjeśency:6 months,1 rok:1 year,ńyskůńčůny:infińite", "restriction-type": "Pozwolyńy:", - "restriction-level": "Poźům:", + "restriction-level": "Poziōm:", "minimum-size": "Minimalnŏ srogość", "maximum-size": "Maksymalnŏ srogość:", "pagesize": "(bajtōw)", @@ -1446,8 +1440,8 @@ "undeleteinvert": "Zaznocz na uopy", "undeletecomment": "Powůd wćepańo nazod:", "cannotundelete": "Wćepańy nazod ńy powjodo śe.\nKto inkÅ¡y můgu wćepać nazod zajta pjyrwÅ¡y.", - "undeletedpage": "'''Wćepano nazod zajta $1.'''\n\nUobejřij [[Special:Log/delete|rejer wyćepań]], kejbyś chćou přeglůndnůnć uostatnie uoperacyje wyćepywańo i wćepywańo nazod zajtůw.", - "undelete-header": "Uobejřij [[Special:Log/delete|rejer wyćepań]] coby sprawdźić uostatńo wyćepane zajty.", + "undeletedpage": "<strong>Strōna „$1” była prziwrōcōnŏ</strong>\n\nWejzdrzij do [[Special:Log/delete|regestu skasowań]] po lista ôstatnich skasowań i prziwrōcyń.", + "undelete-header": "Wejzdrzij na [[Special:Log/delete|regest skasowań]] po ôstatnio skasowane strōny.", "undelete-search-box": "Å nupej za wyćepńjyntymi zajtami", "undelete-search-prefix": "Strōny, co sie zaczynajōm ôd:", "undelete-search-submit": "Å nupej", @@ -1516,7 +1510,7 @@ "ipboptions": "2 godziny:2 hours,1 dziyń:1 day,3 dni:3 days,1 tydziyń:1 week,2 tydnie:2 weeks,1 miesiōnc:1 month,3 miesiōnce:3 months,6 miesiyncy:6 months,1 rok:1 year,na dycki:infinite", "ipbhidename": "Schrůń mjano użytkowńika/adres IP w rejerze zawarć, na liśće aktywnych zawarć i liśće użytkowńikůw", "ipbwatchuser": "Ôbserwuj włŏsnõ strōnã i strōnã dyskusyje ôd tego używŏcza", - "ipb-change-block": "Zmjyń sztalowańa zawarća uod sprowjyń", + "ipb-change-block": "Zablokuj zaś tego używŏcza z tymi sztelōnkami", "badipaddress": "Felerny adres IP", "blockipsuccesssub": "Zawarće uod sprowjyń udane", "blockipsuccesstext": "Užytkowńik [[Special:Contributions/$1|$1]] zostou zawarty uod sprowjyń.<br />\nPřyńdź do [[Special:BlockList|listy zawartych adresůw IP]] coby přejřeć zawarća.", @@ -1561,7 +1555,7 @@ "block-log-flags-noemail": "e-mail zablokowany", "block-log-flags-nousertalk": "ńy może sprowjać włosnyj zajty godki", "block-log-flags-angry-autoblock": "rozszerzůne automatyczne zawjyrańe załůnczůne", - "range_block_disabled": "Možliwość zawjerańo zakresu adresůw IP zostoua wůuůnčůno.", + "range_block_disabled": "Blokowanie zŏkresu adres IP je zakŏzane.", "ipb_expiry_invalid": "Felerny čas wygaśńjyńćo zawarća.", "ipb_expiry_temp": "Schrůńůne mjano użytkowńika noleży zawrzić trwale.", "ipb_already_blocked": "\"$1\" je już zawarty uod sprowjyń", @@ -1582,10 +1576,10 @@ "lockbtn": "Zawřij baza danych", "unlockbtn": "Uodymkńij baza danych", "locknoconfirm": "Ńy zaznačůužeś potwjerdzyńo.", - "lockdbsuccesssub": "Baza danych zostoua půmyślńy zawarto", - "unlockdbsuccesssub": "Baza danych zostoua půmyślńy uodymkńynto", - "lockdbsuccesstext": "Baza danych zostoua zawarto.<br />\nPamjyntej coby [[Special:UnlockDB|jům uodymknůńć]] po zakůńčyńu dźouań admińistracyjnych.", - "unlockdbsuccesstext": "Baza danych zostoua uodymkńynto.", + "lockdbsuccesssub": "Zablokowanie bazy danych sie podarziło", + "unlockdbsuccesssub": "Blokada bazy danych symniyntŏ", + "lockdbsuccesstext": "Baza danych je zablokowanŏ.<br />\nPamiyntej, żeby [[Special:UnlockDB|jōm ôtworzić]] jak robota bydzie skōńczōnŏ.", + "unlockdbsuccesstext": "Baza danych je ôdblokowanŏ.", "lockfilenotwritable": "Ńy idźe naÅ¡kreflać plika zawarća bazy danych.\nZawjerańy i uodmykańy bazy danych wymogo coby plik můgu być naÅ¡kreflany bez web serwer.", "databasenotlocked": "Baza danych ńy je zawarto.", "move-page": "Przećep $1", @@ -1639,7 +1633,7 @@ "export-templates": "Douůnč Å¡ablůny", "allmessages": "Komunikaty", "allmessagesname": "Mjano", - "allmessagesdefault": "Tekst důmyślny", + "allmessagesdefault": "Wychodny tekst wiadōmości", "allmessagescurrent": "Tekst uobecny", "allmessagestext": "Uoto lista wÅ¡yjstkych kůmůńikatůw systymowych dostympnych w přestřyńi mjan MedjaWiki.\nUodwjydź [https://www.mediawiki.org/wiki/Special:MyLanguage/Localisation Tuůmačyńy MediaWiki] a tyž [https://translatewiki.net translatewiki.net] kejbyś chćou učestńičyć w tuůmačyńu uoprůgramowańo MediaWiki.", "allmessages-not-supported-database": "Ta zajta ńy može być užyta, bez tůž co zmjynna '''$wgUseDatabaseMessages''' je wůuůnčůno.", @@ -1679,7 +1673,7 @@ "import-token-mismatch": "Straćiły śe dane ze sesyje. Prosza spróbować zaś.", "import-invalid-interwiki": "Ńy idźe importować s podanyj wiki.", "importlogpage": "Regest importōw", - "importlogpagetext": "Rejer přeprowadzůnych importůw zajtůw s inkÅ¡ych serwisůw wiki.", + "importlogpagetext": "Regest importōw strōn społym ze jejich historyjami ze inkszych wiki.", "import-logentry-upload-detail": "$1 {{PLURAL:$1|wersyja|wersyje|wersyji}}", "import-logentry-interwiki-detail": "$1 {{PLURAL:$1|wersyja|wersyje|wersyji}} ze $2", "tooltip-pt-userpage": "{{GENDER:|Moja}} strōna", @@ -1826,7 +1820,7 @@ "show-big-image-preview": "Srogość tego podglōndu: $1.", "show-big-image-other": "{{PLURAL:$2|Inkszŏ rozdzielczość|Inksze rozdzielczości}}: $1.", "show-big-image-size": "$1 x $2 pikselōw", - "newimages": "Galerjo nowych uobrozkůw", + "newimages": "Galeryjŏ nowych ôbrŏzkōw", "imagelisttext": "Půnižyj na {{PLURAL:$1||posortowanyj $2}} liśće {{PLURAL:$1|znojdowo|znojdujům|znojdowo}} śe '''$1''' {{PLURAL:$1|plik|pliki|plikůw}}.", "newimages-summary": "Na tyj ekstra zajće prezyntowane sům uostatńo wćepńynte pliki.", "newimages-legend": "Filtruj", @@ -1848,7 +1842,7 @@ "confirmemail_text": "Projekt {{SITENAME}} wymago weryfikacyji adresa e-brif před užyćym fůnkcyji kořistajůncych s počty.\nWćiś knefel půńižy coby wysúać na swůj adres list s linkym do zajty WWW.\nList bydźe zawjeroú link do zajty, w kerym zakodowany bydźe idyntyfikator.\nUodymkńij tyn link we přyglůndarce, čym potwjerdźiÅ¡, co ježeś užytkowńikym tygo adresa e-brif.", "confirmemail_pending": "Kod potwierdzyniŏ bōł prawie do Ciebie wysłany. Jak Twoje kōnto było niydŏwno zaregistrowane, to poczekej pŏrã minut na jego dotarcie, podwiela wyślesz prośbã ô nowy.", "confirmemail_send": "Wyślij kod potwjerdzyńo", - "confirmemail_sent": "Wjadůmość e-brif s kodym uwjeřitelńajůncym zostoua wysuano.", + "confirmemail_sent": "E-mail ze potwiyrdzyniym wysłany.", "confirmemail_oncreate": "Link s kodym potwjerdzyńo zostou wysuany na Twůj adres e-brif.\nKod tyn ńy je wymagany coby śe sam lůgować, ale bydźeÅ¡ muśou go aktywować uodmykajůnc uotřimany link we přyglůndarce ńim zouůnčyÅ¡ ńykere uopcyje e-brif na wiki.", "confirmemail_sendfailed": "{{SITENAME}} ńy poradźiła wysłać potwjerdzajůncyj wjadůmośći e-brif.\nSprowdź aże we adreśe ńy ma felernyj buchsztaby.\n\nSystym pocztowy zwrůćił kůmůńikat: $1", "confirmemail_invalid": "Felerny kod potwjerdzyńo.\nKod može być předawńůny", @@ -1874,13 +1868,13 @@ "imgmultigoto": "Idź do strōny $1", "table_pager_next": "Nastympnŏ strōna", "table_pager_prev": "Poprzedniŏ strōna", - "table_pager_first": "PjyrwÅ¡o zajta", - "table_pager_last": "Uostatńo zajta", + "table_pager_first": "Piyrszŏ strōna", + "table_pager_last": "Ôstatniŏ strōna", "table_pager_limit": "Pokož $1 pozycyji na zajće", "table_pager_limit_submit": "Pokož", "table_pager_empty": "Brak wynikůw", "autosumm-blank": "POZÅ®R! Usůńjyńće treśći (zajta pozostoła pusto)!", - "autosumm-replace": "POZÅ®R! Zastůmpjyńy treśći hasua bardzo krůtkym tekstym: „$1”", + "autosumm-replace": "Zastōmpiynie zawartości tekstym „$1”", "autoredircomment": "Przekerowanie do [[$1]]", "autosumm-new": "Stworzōnŏ nowõ strōnã: \"$1\"", "lag-warn-normal": "Na tyj liśće zmjany nowsze jak {{PLURAL:$1|sekůnda|sekůnd}} můgům ńy być widoczne.", @@ -1889,13 +1883,13 @@ "watchlistedit-normal-legend": "Wyćep zajty s listy artikli na kere dowoÅ¡ pozůr", "watchlistedit-normal-explain": "Půńiżyj mosz lista artikli na kere dowosz pozůr.\nCoby wyćepać z ńij jako zajta, zaznocz pole przi ńij i naćiś knefel „{{int:Watchlistedit-normal-submit}}”.\nMożesz tyż skorzistać ze [[Special:EditWatchlist/raw|tekstowygo sprowjorza listy artikli na kere dowosz pozůr]].", "watchlistedit-normal-submit": "Wyćep s listy", - "watchlistedit-normal-done": "Z Twoi listy artikli na kere dowoÅ¡ pozůr {{PLURAL:$1|zostoua wyćepano 1 zajta|zostouy wyćepane $1 zajty|zostouo wyćepanych $1 zajtůw}}:", + "watchlistedit-normal-done": "{{PLURAL:$1|Była skasowanŏ jedna strōna|Były skasowane $1 strōny|Było skasowanych $1 strōn}} ze twojij listy ôbserwowanych:", "watchlistedit-raw-title": "Tekstowy edytor listy artikli na kere dowosz pozůr", "watchlistedit-raw-legend": "Tekstowy edytor listy artikli na kere dowoÅ¡ pozůr", "watchlistedit-raw-explain": "Půńižy moÅ¡ lista artikli na kere dowoÅ¡ pozůr. W koždej lińii znojdowo śe titel jydnygo artikla. Lista možeÅ¡ sprowjać dodajůnc nowe zajty i wyćepujůnc te kere na ńij sům. Jak skůńčyÅ¡, naćiś knefel „Uaktualńij lista zajtůw na kere dowům pozůr”.\nMožeÅ¡ tyž [[Special:EditWatchlist|užyć standardowygo edytora]].", "watchlistedit-raw-titles": "Title:", "watchlistedit-raw-submit": "Uaktualńij lista", - "watchlistedit-raw-done": "Lista zajtůw na kere dowoÅ¡ pozůr zostoua uaktualńůna", + "watchlistedit-raw-done": "Lista twojich ôbserwowanych była zaktualizowanŏ.", "watchlistedit-raw-added": "Dodano {{PLURAL:$1|1 pozycyja|$1 pozycyje|$1 pozycyji}} do listy artikli na kere dowoÅ¡ pozůr:", "watchlistedit-raw-removed": "Wyćepano {{PLURAL:$1|1 pozycyja|$1 pozycyje|$1 pozycyji}} z listy zajtůw na kere dowoÅ¡ pozůr:", "watchlisttools-clear": "Wysnŏż ôbserwowane", @@ -1930,7 +1924,7 @@ "redirect-page": "Idyntyfikatōr strōny", "redirect-revision": "Wersyjŏ strōny", "redirect-file": "Miano zbioru", - "fileduplicatesearch": "Å nupej za duplikatym plika", + "fileduplicatesearch": "Szukej tuplikatōw zbioru", "fileduplicatesearch-summary": "Å nupej za duplikatůma plika na podstawje wartośći fůnkcyji skrůtu.", "fileduplicatesearch-filename": "Mjano pliku:", "fileduplicatesearch-submit": "Å nupej", @@ -1940,16 +1934,16 @@ "specialpages": "Ekstra strōny", "specialpages-note-restricted": "* Ekstra zajty uogůlńy dostympne.\n* <strong class=\"mw-specialpagerestricted\">Ekstra zajty do kerych dostymp je uograńiczůny.</strong>", "specialpages-group-maintenance": "Reporty kōnserwacyjne", - "specialpages-group-other": "InkÅ¡e ekstra zajty", + "specialpages-group-other": "Inksze ekstra strōny", "specialpages-group-login": "Logowanie / registracyjŏ", - "specialpages-group-changes": "Pomjyńane na uostatku a rejery", - "specialpages-group-media": "Pliki", + "specialpages-group-changes": "Ôstatnie zmiany i regesty", + "specialpages-group-media": "Zbiory", "specialpages-group-users": "Używŏcze i uprawniynia", - "specialpages-group-highuse": "Zajty čynsto užywane", + "specialpages-group-highuse": "Czynsto używane strōny", "specialpages-group-pages": "Listy strōn", - "specialpages-group-pagetools": "Nořyńdźa zajtůw", - "specialpages-group-wiki": "Informacyje a werkcojgi wiki", - "specialpages-group-redirects": "Ekstra zajty, kere kerujům", + "specialpages-group-pagetools": "Norzyńdzia strōn", + "specialpages-group-wiki": "Norzyńdzia i dane", + "specialpages-group-redirects": "Ekstra zajty przekerowaniŏ", "specialpages-group-spam": "Nořyńdźa do wyćepywanio spamu", "blankpage": "Pusto zajta", "intentionallyblankpage": "Ta zajta nauůmyślńy uostoua śe pusto", @@ -1978,7 +1972,9 @@ "searchsuggest-search": "Szukej we {{SITENAME}}", "duration-days": "$1 {{PLURAL:$1|dziyń|dni}}", "expand_templates_ok": "OK", + "mediastatistics": "Statystyki mediōw", "randomrootpage": "Losowŏ strōna (bez podstrōn)", "changecredentials": "Zmiyń poświadczynia", - "changecredentials-submit": "Zmiyń poświadczynia" + "changecredentials-submit": "Zmiyń poświadczynia", + "removecredentials": "Kasowanie poświadczyń" } diff --git a/languages/i18n/ta.json b/languages/i18n/ta.json index 337b5031c0..a0e5ae83f5 100644 --- a/languages/i18n/ta.json +++ b/languages/i18n/ta.json @@ -613,22 +613,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|உங்கள் கவனிப்புப் பட்டியல் பக்களின் மாற்றத்திற்கான]] வலை ஓடைச் (Atom/RSS) சீட்டுகள்", "resettokens-done": "சீட்டுகள் புதுப்பிப்பு.", "resettokens-resetbutton": "தேர்தெடுத்த வில்லைகளை மறுஅமை", - "bold_sample": "தடித்த எழுத்துக்கள்", - "bold_tip": "தடித்த எழுத்து", - "italic_sample": "சாய்வெழுத்து", - "italic_tip": "சாய்வெழுத்து", - "link_sample": "இணைப்புத் தலைப்பு", - "link_tip": "உள்ளக இணைப்பு", - "extlink_sample": "http://www.example.com இணைப்புத் தலைப்பு", - "extlink_tip": "வெளியிணைப்பு (http:// முன்னிணைப்பை மறக்காதீர்)", - "headline_sample": "தலைப்பு", - "headline_tip": "இரண்டாம் படித் தலைப்பு", - "nowiki_sample": "விக்கி நிரலாக்கத்தால் புறக்கணிக்கப்படவேண்டிய உரையை இங்கே இடவும்", - "nowiki_tip": "விக்கி நிரலாக்கத்தைப் புறக்கணி", - "image_tip": "பொதிந்துள்ள படிமம்", - "media_tip": "கோப்பு இணைப்பு", - "sig_tip": "நேர முத்திரையுடன் உங்கள் கையொப்பம்", - "hr_tip": "கிடைக் கோடு (அரிதாகவே பயன்படுத்துங்கள்)", "summary": "சுருக்கம்:", "subject": "விடயம்:", "minoredit": "இது ஒரு சிறு தொகுப்பு", diff --git a/languages/i18n/tay.json b/languages/i18n/tay.json index 2f5089862b..d297dbff57 100644 --- a/languages/i18n/tay.json +++ b/languages/i18n/tay.json @@ -289,22 +289,6 @@ "resettokens": "T’ringun kbalay lawziy niwan sawsu’", "resettokens-tokens": "Niwan sawsu’:", "resettokens-done": "Wal t’aring kbalay lawziy niwan sawsu’ na mima’.", - "bold_sample": "Qthuy na biru’", - "bold_tip": "Qthuy na biru’", - "italic_sample": "Mtkkiy na biru’", - "italic_tip": "Mtkkiy na biru’", - "link_sample": "Spzyang lalu’ na ’ubuy sqaniy", - "link_tip": "’nubuy sa qsahuy", - "extlink_sample": "http://www.example.com qaniy quw lalu’ na ’ubuy", - "extlink_tip": "’ubuy tay bzinah(zngyay su’ yaquw http://quw tqsu’ miru’)", - "headline_sample": "Biru’ spzyang lalu’ tay msinqutux", - "headline_tip": "Biru’ na spzyang lalu’ na binrwan tay msinsazing", - "nowiki_sample": "Si’ quw biru’ na iyat minKs’ xwa’", - "nowiki_tip": "Ini’ si’ inlung quw minKs’xwa’ kkayal kay’ na Wiki’", - "image_tip": "Pinraw niya’ biru’ na zayzyuwaw", - "media_tip": "’ubuy sa biru’ na kwara’ zayzyuwaw", - "sig_tip": "Cyux pglgan bnrwan zikang ru ryax nquw binrwan lalu’", - "hr_tip": "Swe ping syen (laxiy brwaniy iyal)", "summary": "Lalu’ na spzyang bbiru’ su’:", "subject": "Spzyang na ptzyuwaw:", "minoredit": "Iyat spzyang balay ssr’tun miru’ balay qaniy hya’", diff --git a/languages/i18n/tcy.json b/languages/i18n/tcy.json index 63a7abfa81..ced033dfc7 100644 --- a/languages/i18n/tcy.json +++ b/languages/i18n/tcy.json @@ -597,22 +597,6 @@ "resettokens-watchlist-token": "ಜಾಲ ಆಹಾರದ ಸಂಕೇತಬಿಲ್ಲೆ (ಆಟಂ/ಆರ್.ಎಸ್.ಎಸ್) \n ವೀಕ್ಷಣಪಟ್ಟಿದ ಪುಟ ಬದಲಾವಣೆಲು\n[[Special:Watchlist|changes to pages on your watchlist]]", "resettokens-done": "ಸಂಕೇತಬಿಲ್ಲೆಲು ಪಿರತಾಪನೆ ಆತಾ.", "resettokens-resetbutton": "ಜತ್ತಿನ ಸಂಕೇತಬಿಲ್ಲೆಲೆನ್ ಪಿರತಾಪನೆ ಮಲ್ಪುಲೆ", - "bold_sample": "ದಪ್ಪೊ ಅಕ್ಷರೊ", - "bold_tip": "ದಪ್ಪೊ ಅಕ್ಷರೊ", - "italic_sample": "ಓರೆ ಅಕ್ಷರೊಲು", - "italic_tip": "ಓರೆ ಅಕ್ಷರೊಲು", - "link_sample": "ಕೊಂಡಿದ ಸೀರ್ಸಿಕೆ", - "link_tip": "ಉಲಯಿದ ಕೊಂಡಿ", - "extlink_sample": "http://www.example.com ಕೊಂಡಿದ ಸೀರ್ಸಿಕೆ", - "extlink_tip": "ಪಿದಯಿದ ಕೊಂಡಿ(http:// ರ್ದ್ ಸುರು ಮಲ್ಪೆರೆ ಮರಪೊಡ್ಚಿ)", - "headline_sample": "ತರೆಬರವುದ ಪಟ್ಯೊ", - "headline_tip": "2ನೇ ಮಟ್ಟೊದ ತರೆಬರವು", - "nowiki_sample": "ಮುಲ್ಪ ಫಾರ್ಮೇಟ್ ಆವಂದಿನಂಚಿನ ಪಟ್ಯೊನು ಸೇರಲೆ", - "nowiki_tip": "ವಿಕಿ ಫಾರ್ಮ್ಯಾಟಿಂಗ್‍ನ್ ಗೆನ್ಪೊಡ್ಚಿ", - "image_tip": "ಸೇರ್ಪಾಯಿನ ಫೈಲ್", - "media_tip": "ಫೈಲ್‍ದ ಕೊಂಡಿ", - "sig_tip": "ಪೊರ್ತುಮುದ್ರೆದೊಟ್ಟುಗು ಇರೆನ ದಸ್ಕತ್", - "hr_tip": "ಅಡ್ಡೊ ಗೆರೆ(ಆಯಿನಾತ್ ಕಮ್ಮಿ ಗಲಸ್‌ಲೆ)", "summary": "ಸಾರಾಂಸೊ:", "subject": "ವಿಷಯ/ಮುಖ್ಯಾ೦ಶ:", "minoredit": "ಉಂದು ಎಲ್ಯ ಬದಲಾವಣೆ", diff --git a/languages/i18n/te.json b/languages/i18n/te.json index f9c80aa077..d3e4af9ab1 100644 --- a/languages/i18n/te.json +++ b/languages/i18n/te.json @@ -612,24 +612,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|changes to pages on your watchlist]] యొక్క జాల వడ్డన (Atom/RSS) కు టోకెన్", "resettokens-done": "టోకెన్లను రీసెట్ చేసాం.", "resettokens-resetbutton": "ఎంచుకున్న టోకెన్లను రీసెట్ చెయ్యి", - "bold_sample": "బొద్దు అక్షరాలు", - "bold_tip": "బొద్దు అక్షరాలు", - "italic_sample": "వాలు పాఠ్యం", - "italic_tip": "వాలు పాఠ్యం", - "link_sample": "లంకె పేరు", - "link_tip": "అంతర్గత లంకె", - "extlink_sample": "http://www.example.com లింకు పేరు", - "extlink_tip": "బయటి లింకు (దీనికి ముందు http:// ఇవ్వటం మరువకండి)", - "headline_sample": "శీర్షిక పాఠ్యం", - "headline_tip": "2à°µ స్థాయి శీర్షిక", - "nowiki_sample": "ఫార్మాటు చేయని పాఠ్యాన్ని ఇక్కడ చేర్చండి", - "nowiki_tip": "వికీ ఫార్మాటును పట్టించుకోవద్దు", - "image_sample": "Example.jpg", - "image_tip": "ఇమిడ్చిన ఫైలు", - "media_sample": "Example.ogg", - "media_tip": "దస్త్రపు లంకె", - "sig_tip": "సమయంతో సహా మీ సంతకం", - "hr_tip": "అడ్డగీత (అరుదుగా వాడండి)", "summary": "సారాంశం:", "subject": "విషయం:", "minoredit": "ఇది ఒక చిన్న మార్పు", diff --git a/languages/i18n/tet.json b/languages/i18n/tet.json index d6e0181525..6e5ecfc050 100644 --- a/languages/i18n/tet.json +++ b/languages/i18n/tet.json @@ -220,12 +220,6 @@ "resetpass_text": "<!-- Hakerek testu iha ne'e -->", "passwordreset-username": "Naran uza-na'in:", "passwordreset-email": "Diresaun korreiu eletróniku:", - "link_tip": "Ligasaun ba laran", - "extlink_sample": "http://www.example.com ligasaun ba li'ur", - "extlink_tip": "Ligasaun ba li'ur (tau tan http://)", - "image_sample": "Ezemplu.jpg", - "media_sample": "Ezemplu.ogg", - "sig_tip": "Ita-nia asinatura ho data/oras", "summary": "Rezumu:", "minoredit": "Ne'e muda ki'ik", "watchthis": "Hateke pájina ne'e", diff --git a/languages/i18n/tg-cyrl.json b/languages/i18n/tg-cyrl.json index 5989777f2d..02478caf42 100644 --- a/languages/i18n/tg-cyrl.json +++ b/languages/i18n/tg-cyrl.json @@ -486,24 +486,6 @@ "resettokens-tokens": "Нишонаҳо:", "resettokens-done": "Нишонаҳо тазим шуданд.", "resettokens-resetbutton": "Нишонаҳои интихобшуда танзим шаванд", - "bold_sample": "Матни пурранг", - "bold_tip": "Матни пурранг", - "italic_sample": "Матни хобида", - "italic_tip": "Матни хобида", - "link_sample": "Унвони пайванд", - "link_tip": "Пайванди дохилӣ", - "extlink_sample": "http://www.example.com унвони пайванд", - "extlink_tip": "Пайванди беруна (пешванди http:// фаромӯш накунед)", - "headline_sample": "Матни унвон", - "headline_tip": "Унвони сатҳи 2", - "nowiki_sample": "Инҷо матни қолаббанди-нашударо дохил кунед", - "nowiki_tip": "Рад кардани қолаббандии вики", - "image_sample": "Намуна.jpg", - "image_tip": "Тасвири дохили матн", - "media_sample": "Намуна.ogg", - "media_tip": "Пайванди парвандаи расона", - "sig_tip": "Имзои Шумо бо мӯҳри сана", - "hr_tip": "Хати уфуқӣ (сарфакорона истифода кунед)", "summary": "Хулоса:", "subject": "Мавзӯъ:", "minoredit": "Ин вироиши хурд аст", diff --git a/languages/i18n/tg-latn.json b/languages/i18n/tg-latn.json index 8ad66c4c1d..1dcbcc3974 100644 --- a/languages/i18n/tg-latn.json +++ b/languages/i18n/tg-latn.json @@ -333,22 +333,6 @@ "resetpass-submit-loggedin": "TaÆ£jiri guzarvoƶa", "resetpass-wrong-oldpass": "Guzarvoƶai muvaqat jo oxir nomÅ«'tabar.\nMumkin ast, ki şumo allakaj guzarvoƶaatonro bo muvaffaqijat taÆ£jir doda boşed jo darxosti jak guzarvoƶai muvaqatÄ« karda boşed.", "resetpass-temp-password": "Guzarvoƶai muvaqqatÄ«:", - "bold_sample": "Matni purrang", - "bold_tip": "Matni purrang", - "italic_sample": "Matni xobida", - "italic_tip": "Matni xobida", - "link_sample": "Unvoni pajvand", - "link_tip": "Pajvandi doxilÄ«", - "extlink_sample": "http://www.example.com unvoni pajvand", - "extlink_tip": "Pajvandi beruna (peşvandi http:// faromūş nakuned)", - "headline_sample": "Matni unvon", - "headline_tip": "Unvoni sathi 2", - "nowiki_sample": "Inço matni qolabbandi-naşudaro doxil kuned", - "nowiki_tip": "Rad kardani qolabbandiji viki", - "image_tip": "Tasviri doxili matn", - "media_tip": "Pajvandi parvandai rasona", - "sig_tip": "Imzoi Şumo bo mÅ«hri sana", - "hr_tip": "Xati ufuqÄ« (sarfakorona istifoda kuned)", "summary": "Xulosa:", "subject": "MavzÅ«'/sarlavha:", "minoredit": "In viroişi xurd ast", diff --git a/languages/i18n/th.json b/languages/i18n/th.json index 8f363c8a7b..007435eb3c 100644 --- a/languages/i18n/th.json +++ b/languages/i18n/th.json @@ -627,24 +627,6 @@ "resettokens-watchlist-token": "โทเค็นสำหรับเว็บฟีด (Atom/RSS) ของ[[Special:Watchlist|การเปลี่ยนแปลงแก่หน้าในรายการเฝ้าดูของคุณ]]", "resettokens-done": "ตั้งค่าโทเค็นใหม่แล้ว", "resettokens-resetbutton": "ตั้งโทเค็นที่เลือกใหม่", - "bold_sample": "ข้อความตัวหนา", - "bold_tip": "ทำตัวหนา", - "italic_sample": "ข้อความตัวเอน", - "italic_tip": "ทำตัวเอน", - "link_sample": "เชื่อมโยงหัวเรื่อง", - "link_tip": "ลิงก์ภายใน", - "extlink_sample": "http://www.example.com ชื่อเรื่องเชื่อมโยง", - "extlink_tip": "ลิงก์ภายนอก (อย่าลืมใส่ http:// นำหน้าเสมอ)", - "headline_sample": "ข้อความพาดหัว", - "headline_tip": "พาดหัวระดับ 2", - "nowiki_sample": "แทรกข้อความที่ไม่จัดรูปแบบที่นี่", - "nowiki_tip": "ไม่สนใจการจัดรูปแบบวิกิ", - "image_sample": "ตัวอย่าง.jpg", - "image_tip": "ใส่ไฟล์", - "media_sample": "ตัวอย่าง.ogg", - "media_tip": "เชื่อมโยงไฟล์", - "sig_tip": "ลายเซ็นของคุณพร้อมตราเวลา", - "hr_tip": "เส้นนอน (ใช้อย่างจำกัด)", "summary": "ความย่อ:", "subject": "เรื่อง:", "minoredit": "เป็นการแก้ไขเล็กน้อย", diff --git a/languages/i18n/tk.json b/languages/i18n/tk.json index b247d3d185..8ec343b926 100644 --- a/languages/i18n/tk.json +++ b/languages/i18n/tk.json @@ -365,22 +365,6 @@ "changeemail-newemail": "Täze e-poçta adresi:", "changeemail-none": "(hiç biri)", "changeemail-submit": "E-poçtany üýtget", - "bold_sample": "Goýy tekst", - "bold_tip": "Goýy tekst", - "italic_sample": "Kursiw tekst", - "italic_tip": "Kursiw tekst", - "link_sample": "Çykgydyň ady", - "link_tip": "Içerki çykgyt", - "extlink_sample": "http://www.example.com çykgyt düşündirişi", - "extlink_tip": "Daşarky çykgyt (Adresiň öňüne http:// ýazmagy unutmaň)", - "headline_sample": "Adyň teksti", - "headline_tip": "2-nji derejeli at", - "nowiki_sample": "Formatirlenmedik teksti şu ýere salyň", - "nowiki_tip": "Wiki formatirlemesini hasap etme", - "image_tip": "Salnan faýl", - "media_tip": "Multimediýa faýlyna çykgyt", - "sig_tip": "Wagt belgili goluňyz", - "hr_tip": "Gorizontal liniýa (ýygy-ýygydan ulanmaň)", "summary": "Gysgaça düşündiriş:", "subject": "Tema/at:", "minoredit": "Ujypsyzja özgerdiş", diff --git a/languages/i18n/tl.json b/languages/i18n/tl.json index 0f5287c436..3dc685ccbd 100644 --- a/languages/i18n/tl.json +++ b/languages/i18n/tl.json @@ -567,24 +567,6 @@ "changeemail-throttled": "Masyadong madami ang kamakailan lamang mong pagsubok sa pag-login.\nMaghintay po muna ng $1 bago subukan uli.", "resettokens": "I-reset ang mga token o susi", "resettokens-token-label": "$1 (kasalukuyang halaga: $2)", - "bold_sample": "Makapal na panitik", - "bold_tip": "Makapal na panitik", - "italic_sample": "Nakahilig na panitik", - "italic_tip": "Nakahilig na panitik", - "link_sample": "Pamagat ng kawing", - "link_tip": "Panloob na kawing", - "extlink_sample": "http://www.example.com na link ng pamagat", - "extlink_tip": "Panlabas na link (tandaan ang unlaping http://)", - "headline_sample": "Teksto ng ulong pambungad", - "headline_tip": "Antas 2 na ulong pambungad", - "nowiki_sample": "Isingit ang hindi nakapormat na teksto dito", - "nowiki_tip": "Balewalain ang pormat na pangwiki", - "image_sample": "Halimbawa.jpg", - "image_tip": "File na naka-embed", - "media_sample": "Halimbawa.ogg", - "media_tip": "Link ng file", - "sig_tip": "Lagda mo na may tatak ng oras", - "hr_tip": "Pahalagang na guhit (gamitin nang madalang)", "summary": "Buod:", "subject": "Paksa:", "minoredit": "Ito ay isang munting pagbabago", diff --git a/languages/i18n/tly.json b/languages/i18n/tly.json index 7c7812132c..4259731af8 100644 --- a/languages/i18n/tly.json +++ b/languages/i18n/tly.json @@ -267,22 +267,6 @@ "changeemail-newemail": "Е-номә тожә унвон:", "changeemail-none": "(ни)", "changeemail-submit": "Е-номә дәгиш кардеј", - "bold_sample": "Нимәтындә шрифт", - "bold_tip": "Нимәтындә шрифт", - "italic_sample": "Курсивә мәтн", - "italic_tip": "Курсивә мәтн", - "link_sample": "Сәбони сәрловһә", - "link_tip": "Дыләтонә сәбон", - "extlink_sample": "http://www.example.com сәбони сәрловһә", - "extlink_tip": "Хариҹә сәбон (сыханәсә http:// јодәдә огәтән)", - "headline_sample": "Сәрловһә мәтн", - "headline_tip": "2-нә сәвијјә сәрловһә", - "nowiki_sample": "Формат кардә ныбә мәтн дәғандән ијо", - "nowiki_tip": "Вики формат кардеј бә нәзә ныстәнеј", - "image_tip": "Дахыл кардә быә фајл", - "media_tip": "Сәбон бә медијә-фајл", - "sig_tip": "Шымә ғол ијән вахт", - "hr_tip": "Уфуғијә ријә (рә-рә истифодә мәкән)", "summary": "Дәгишон тәсвир:", "subject": "Мıvzu:", "minoredit": "Ым гадә дәгишије", diff --git a/languages/i18n/to.json b/languages/i18n/to.json index 8bf2af4bc1..2fc7671c61 100644 --- a/languages/i18n/to.json +++ b/languages/i18n/to.json @@ -252,19 +252,6 @@ "oldpassword": "Ko e leatapu motuÊ»a:", "newpassword": "Ko e leatapu foÊ»ou:", "retypenew": "Toe Ê»ai leatapu foÊ»ou:", - "bold_sample": "Tohi sinolahi", - "bold_tip": "Tohi sinolahi", - "italic_sample": "MataÊ»itohi mahei", - "italic_tip": "MataÊ»itohi mahei", - "link_sample": "Hingoa Ê»o e fehokotaki", - "link_tip": "Fehokotaki fakalotovā", - "extlink_sample": "http://www.example.com Hingoa fakafehokotaki", - "extlink_tip": "Fehokotaki ki tuÊ»a (manatuÊ»i ko e fakapipikimuÊ»a — http://)", - "headline_sample": "MataÊ»itohi tuÊ»umuÊ»a", - "headline_tip": "TuÊ»umuÊ»a fakatuÊ»unga hono 2", - "nowiki_sample": "Hulumaki Ê»a e ʻū mataÊ»itohi taÊ»engaohi Ê»i heni", - "nowiki_tip": "taÊ»etokaÊ»i ngaohi ''wiki''", - "sig_tip": "Ko e fakamoÊ»oniÊ»i Ê»aÊ»au mo hono taimi", "summary": "Fakanounou:", "subject": "TuÊ»unga lea:", "minoredit": "Ko e fatu siÊ»i pē ia", diff --git a/languages/i18n/tpi.json b/languages/i18n/tpi.json index 8ed63738e7..dbf76f6f94 100644 --- a/languages/i18n/tpi.json +++ b/languages/i18n/tpi.json @@ -207,9 +207,6 @@ "mailmypassword": "E-mel nupela paswot", "loginlanguagelabel": "Tokples: $1", "changepassword": "Senis paswot", - "link_sample": "Link taitel", - "extlink_sample": "http://www.example.com link taitel", - "media_tip": "Link bilong fail", "summary": "Liklik toksave bilong senis:", "subject": "Nem bilong pes (o hap bilong pes):", "minoredit": "Dispela emi liklik senis", diff --git a/languages/i18n/tr.json b/languages/i18n/tr.json index 821ce9d738..ec025df723 100644 --- a/languages/i18n/tr.json +++ b/languages/i18n/tr.json @@ -696,24 +696,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|Ä°zleme listenizdeki sayfa değişiklikleri]] için web beslemeleri (Atom/RSS) anahtarı", "resettokens-done": "Belirteçler sıfırlandı.", "resettokens-resetbutton": "Seçili anahtarları sıfırla", - "bold_sample": "Kalın yazı", - "bold_tip": "Kalın yazı", - "italic_sample": "Eğik yazı", - "italic_tip": "Eğik yazı", - "link_sample": "Bağlantı başlığı", - "link_tip": "İç bağlantı", - "extlink_sample": "http://www.example.com bağlantı başlığı", - "extlink_tip": "Dış bağlantı (Adresin önüne http:// koymayı unutmayın)", - "headline_sample": "Başlık metni", - "headline_tip": "2. seviye başlık", - "nowiki_sample": "Biçimlendirilmeyecek metni buraya girin", - "nowiki_tip": "viki formatlamasını devre dışı bırak", - "image_sample": "Örnek.jpg", - "image_tip": "Gömülü dosya", - "media_sample": "Örnek.ogg", - "media_tip": "Dosya bağlantısı", - "sig_tip": "Ä°mzanız ve zaman", - "hr_tip": "Yatay çizgi (çok sık kullanmayın)", "summary": "Özet:", "subject": "Konu:", "minoredit": "Bu bir küçük değişiklik", diff --git a/languages/i18n/tru.json b/languages/i18n/tru.json index 04c7c524eb..40abaa88c4 100644 --- a/languages/i18n/tru.json +++ b/languages/i18n/tru.json @@ -193,22 +193,6 @@ "resetpass-submit-loggedin": "Mşaḥlaf uQliḍo", "passwordreset-username": "Işme duHadomo:", "changeemail-newemail": "Email-adres ḥaá¹­o:", - "bold_sample": "Ḥarfe ḥlime", - "bold_tip": "Ḥarfe ḥlime", - "italic_sample": "Ḥarfe 3wije", - "italic_tip": "Ḥarfe 3wije", - "link_sample": "Link title", - "link_tip": "Internal link", - "extlink_sample": "http://www.example.com link title", - "extlink_tip": "External link (remember http:// prefix)", - "headline_sample": "Headline text", - "headline_tip": "Level 2 headline", - "nowiki_sample": "Insert non-formatted text here", - "nowiki_tip": "uSyomano latyo buFormat", - "image_tip": "Embedded file", - "media_tip": "File link", - "sig_tip": "Mḍay herke u ká¹­aw iSa³aye muqa yo.", - "hr_tip": "Horizontal line (use sparingly)", "summary": "Summary:", "minoredit": "This is a minor edit", "watchthis": "Watch this page", diff --git a/languages/i18n/trv.json b/languages/i18n/trv.json index eeffb2d7d7..a385cf78f0 100644 --- a/languages/i18n/trv.json +++ b/languages/i18n/trv.json @@ -202,22 +202,6 @@ "resetpass-submit-cancel": "Pkungat", "passwordreset": "Psbgurah powsa sspgan lniing", "passwordreset-username": "seejiq mduuy hangan:", - "bold_sample": "Patas qthur", - "bold_tip": "Patas qthur", - "italic_sample": "Atas gmisil", - "italic_tip": "Atas gmisil", - "link_sample": "Mggaluk pusu kari", - "link_tip": "Mggaluk ruwan", - "extlink_sample": "http://www.example.com/ mggaluk pusu kari", - "extlink_tip": "Lipax mggaluk (saw peeniq qsahur http:// pnrjingan)", - "headline_sample": "Tg1 tntunan patas pusu kari", - "headline_tip": "Tg2 tntunan patas pusu kari", - "nowiki_sample": "Maat kska aji smmalu iyax ptasan patas", - "nowiki_tip": "Brkagan Wiki smmalu iyax ptasan elug kari", - "image_tip": "Numal pusu patas", - "media_tip": "Mggaluk pusu patas", - "sig_tip": "Patas hangan su ni jiyax", - "hr_tip": "Qtaan ayus msbalay (bilaq bi dmuuy)", "summary": "Ramas kari:", "minoredit": "Asaw nii snsul smmalu patas", "watchthis": "Gmraka qmita ruwahan patas nii", diff --git a/languages/i18n/ts.json b/languages/i18n/ts.json index 99d8e5ca0e..e8f2153dcf 100644 --- a/languages/i18n/ts.json +++ b/languages/i18n/ts.json @@ -278,22 +278,6 @@ "loginsuccess": "'''Ule ndzeni ka {{SITENAME}} tani hi \"$1\".'''", "mailmypassword": "Rhumela vito-mpfungulo lerintwsa", "loginlanguagelabel": "Ririmi: $1", - "bold_sample": "Marito yo bumbula", - "bold_tip": "Marito yo bumbula", - "italic_sample": "Tsalawa ra xitaliki", - "italic_tip": "Tsalawa ra xitaliki", - "link_sample": "Khwekerisa nhlokomhaka", - "link_tip": "Xikhwekerisi xala ndzeni ka wiki leyi", - "extlink_sample": "http://www.example.com khwekerisa nhlokomhaka", - "extlink_tip": "Xikhwekerisi xa tluka ralehandle ka wiki leyi (tsundzuka xi rhangi xa http:// )", - "headline_sample": "tsala ra nhlokomhaka", - "headline_tip": "Nhloko mhaka ya xiyenge xa 2", - "nowiki_sample": "Hoxa xivulwa lexi nga sasekisiwangiki mavonele laha", - "nowiki_tip": "bakanya kuxongisa marito ka wiki", - "image_tip": "Fayili leyi angarhiweke", - "media_tip": "Xikhwekerisi xa fayili", - "sig_tip": "Nsayino wawena wurina mfungo wa nkarhi", - "hr_tip": "Ntila wo khwatiheta (wu tirhise hivukheta)", "summary": "Nkomiso:", "minoredit": "Lowu i ndzulamiso wu tsongo", "watchthis": "Langutisa tluka leri", diff --git a/languages/i18n/tt-cyrl.json b/languages/i18n/tt-cyrl.json index bda0a4f001..1369401fe7 100644 --- a/languages/i18n/tt-cyrl.json +++ b/languages/i18n/tt-cyrl.json @@ -547,24 +547,6 @@ "resettokens-token-label": "$1 (агымдагы мәгънә: $2)", "resettokens-done": "Токеннар ташланды.", "resettokens-resetbutton": "Сайланган токеннарны ташлау", - "bold_sample": "Калын язылыш", - "bold_tip": "Калын язылыш", - "italic_sample": "Курсив язылыш", - "italic_tip": "Курсив язылыш", - "link_sample": "Сылтама исеме", - "link_tip": "Эчке сылтама", - "extlink_sample": "http://www.example.com сылтама исеме", - "extlink_tip": "Тышкы сылтама (http:// алкушымчасы турында онытмагыз)", - "headline_sample": "Башисем", - "headline_tip": "2 нче дәрәҗәле исем", - "nowiki_sample": "Форматланмаган текстны монда өстәгез", - "nowiki_tip": "Вики-форматлауны исәпкә алмау", - "image_sample": "Мисал.jpg", - "image_tip": "Куелган файл", - "media_sample": "Мисал.ogg", - "media_tip": "Файлга сылтама", - "sig_tip": "Имзагыз вакыт белән", - "hr_tip": "Горизонталь сызык (еш кулланмагыз)", "summary": "Кыскача аңлатма:", "subject": "Тема:", "minoredit": "Бу кече төзәтмә", @@ -1108,7 +1090,7 @@ "rcfilters-restore-default-filters": "Гадәттәге сөзгечләрне торгызу", "rcfilters-clear-all-filters": "Барлык сөзгечләрне бушату", "rcfilters-show-new-changes": "$1 башлап яңа үзгәрешләрне карау", - "rcfilters-search-placeholder": "Үзгәрешләрне сөзү (меню кулланыгыз яки сөзгеч аты буенча эзлигез)", + "rcfilters-search-placeholder": "Үзгәрешләрне сөзү (меню кулланыгыз яки сөзгеч исеме буенча эзләгез)", "rcfilters-search-placeholder-mobile": "Сөзгечләр", "rcfilters-invalid-filter": "Яраксыз сөзгеч", "rcfilters-filterlist-title": "Сөзгечләр", @@ -1458,19 +1440,30 @@ "notargettitle": "Максатсыз", "nopagetitle": "Мондый бит юк", "nopagetext": "Күрсәтелгән бит юк.", - "pager-newer-n": "{{PLURAL:$1|$1 яңарак}}", - "pager-older-n": "$1 {{PLURAL:$1|искерәк}}", + "pager-newer-n": "{{PLURAL:$1|1 яңарак|$1 яңарак}}", + "pager-older-n": "{{PLURAL:$1|1 искерәк|$1 искерәк}}", "suppress": "Яшерү", "apihelp": "API ярдәм", "apihelp-no-such-module": "«$1» модуле табылмады.", "apisandbox": "API комлыгы", - "apisandbox-reset": "Чистарту", + "apisandbox-submit": "Сорату ясарга", + "apisandbox-reset": "Бушату", "apisandbox-retry": "Кабатлау", + "apisandbox-helpurls": "Белешмәгә сылтамалар", "apisandbox-examples": "Мисаллар", "apisandbox-dynamic-parameters": "Өстәмә параметрлар", + "apisandbox-dynamic-parameters-add-label": "Параметр өстәргә:", + "apisandbox-dynamic-parameters-add-placeholder": "Параметр исеме", + "apisandbox-dynamic-error-exists": "«$1» исемле параметр бар инде.", + "apisandbox-templated-parameter-reason": "Бу [[Special:ApiHelp/main#main/templatedparams|калып параметры]] $2 исемлегенең {{PLURAL:$1|мәгънә}} нигезендә тәкъдим ителә.", + "apisandbox-deprecated-parameters": "Искергән параметрлар", + "apisandbox-fetch-token": "Торенны автотутыру", + "apisandbox-add-multi": "Өстәү", + "apisandbox-submit-invalid-fields-title": "Кайбер кырлар дөрес түгел", + "apisandbox-submit-invalid-fields-message": "Билгеләнгән кырларны төзәтегез һәм яңадан тырышып карагыз.", "apisandbox-results": "Нәтиҗәләр", "apisandbox-continue": "Дәвам итү", - "apisandbox-continue-clear": "Чистарту", + "apisandbox-continue-clear": "Бушату", "apisandbox-multivalue-all-namespaces": "$1 (Барлык исемнәр киңлекләре)", "apisandbox-multivalue-all-values": "$1 (Барлык мәгънәләр)", "booksources": "Китап чыганаклары", @@ -1523,7 +1516,7 @@ "activeusers": "Актив кулланучылар исемлеге", "activeusers-noresult": "Кулланучылар табылмады.", "listgrouprights": "Кулланучы төркемнәренең хокуклары", - "listgrouprights-key": "Легенда:\n* <span class=\"listgrouprights-granted\">Бирелгән хокуклар</span>\n* <span class=\"listgrouprights-revoked\">Алынган хокуклар</span>", + "listgrouprights-key": "Аңлатма:\n* <span class=\"listgrouprights-granted\">Бирелгән хокуклар</span>\n* <span class=\"listgrouprights-revoked\">Алынган хокуклар</span>", "listgrouprights-group": "Төркем", "listgrouprights-rights": "Хокуклар", "listgrouprights-helppage": "Help:Төркемнәрнең хокуклары", @@ -1599,7 +1592,7 @@ "confirm": "Раслау", "excontent": "эчтәлек: «$1»", "excontentauthor": "эчтәлеге: «$1», бердәнбер авторы [[Special:Contributions/$2|$2]] ([[User talk:$2|бәхәс]])", - "exbeforeblank": "чистартуга кадәр булган эчтәлек: «$1»", + "exbeforeblank": "бушатуга кадәр булган эчтәлек: «$1»", "delete-confirm": "«$1» бетерү", "delete-legend": "Бетерү", "historywarning": "<strong>Игътибар:</strong> Сез бетерергә теләгән биттә үзгәртү тарихы бар, ул $1 {{PLURAL:$1|юрамадан тора}}:", @@ -1829,7 +1822,7 @@ "delete_and_move_confirm": "Әйе, битне бетерү", "delete_and_move_reason": "Күчерүне мөмкин итәр өчен бетерелде «[[$1]]»", "move-leave-redirect": "Юнәлтү калдырылсын", - "export": "Битләрне чыгаруы", + "export": "Битләрне чыгару", "export-submit": "Экспортлау", "export-addcattext": "Бу төркемнән битләр өстәү:", "export-addcat": "Өстәү", @@ -2049,8 +2042,8 @@ "recreate": "Яңадан төзү", "unit-pixel": "нкт", "confirm_purge_button": "Ярар", - "confirm-purge-top": "Бу битнең кэшы чистартылсынмы?", - "confirm-purge-bottom": "Кэшны чистартудан соң аның соңгы юрамасы күрсәтеләчәк.", + "confirm-purge-top": "Бу битнең кэшын бушатыргамы?", + "confirm-purge-bottom": "Кэшны бушатудан соң аның соңгы юрамасы күрсәтеләчәк.", "confirm-watch-button": "Ярар", "confirm-unwatch-button": "Ярар", "confirm-rollback-button": "Ярар", @@ -2160,6 +2153,7 @@ "version-software": "Урнаштырылган программа белән тәэмин ителешне", "version-software-product": "Продукт", "version-software-version": "Версия", + "version-entrypoints-header-entrypoint": "Керү урыны", "version-entrypoints-header-url": "URL", "version-libraries-library": "Китапханә", "version-libraries-version": "Версия", @@ -2175,11 +2169,16 @@ "redirect-page": "Бит идентификаторы", "redirect-revision": "Бит юрамасы", "redirect-file": "Файл исеме", - "fileduplicatesearch": "Бер үк файлларны эзләү", + "redirect-logid": "Көндәлек ID", + "redirect-not-exists": "Мәгънәсе табылмады", + "redirect-not-numeric": "Мәгънәсе сан зурлыгы түгел", + "fileduplicatesearch": "Бердәй файлларны эзләү", + "fileduplicatesearch-summary": "Бердәй файлларны хэш-код буенча эзләү.", "fileduplicatesearch-filename": "Файл исеме:", "fileduplicatesearch-submit": "Эзләү", "fileduplicatesearch-info": "$1 × $2 нокта<br />Файл зурлыгы: $3<br />MIME төре: $4", "specialpages": "Махсус битләр", + "specialpages-note-top": "Аңлатма", "specialpages-note-restricted": "* Гади махсус битләр.\n* <span class=\"mw-specialpagerestricted\">Чикләнелгән махсус битләр.</span>", "specialpages-group-maintenance": "Техник карау хисапнамәсе", "specialpages-group-other": "Башка махсус битләр", diff --git a/languages/i18n/tt-latn.json b/languages/i18n/tt-latn.json index 2e842e0514..4c78486e93 100644 --- a/languages/i18n/tt-latn.json +++ b/languages/i18n/tt-latn.json @@ -394,24 +394,6 @@ "resetpass-submit-cancel": "Kire qağu", "resetpass-wrong-oldpass": "Yalğış sersüz.\nSez sersüzegezne üzgärtkän yäisä yaña waqıtlı sersüz soratqan bulırğa mömkinsez.", "resetpass-temp-password": "Waqıtlı sersüz:", - "bold_sample": "Qalın yazılış", - "bold_tip": "Qalın yazılış", - "italic_sample": "Kursiv yazılış", - "italic_tip": "Kursiv yazılış", - "link_sample": "Sıltama iseme", - "link_tip": "Eçke sıltama", - "extlink_sample": "http://www.example.com sıltama iseme", - "extlink_tip": "Tışqı sıltama (http:// alquşımçası turında onıtmağız)", - "headline_sample": "Başisem", - "headline_tip": "2 nçe däräcäle isem", - "nowiki_sample": "Formatlanmağan tekstnı monda östägez", - "nowiki_tip": "Wiki-formatlawnı isäpkä almaw", - "image_sample": "Misal.jpg", - "image_tip": "Quyılğan fayl", - "media_sample": "Mísal.ogg", - "media_tip": "Media-faylğa sıltama", - "sig_tip": "Ä°mza häm waqıt", - "hr_tip": "Gorizontal sızıq (yış qullanmağız)", "summary": "Üzgärtülär taswirlaması:", "subject": "Tema/başisem:", "minoredit": "Bu keçe üzgärtü", diff --git a/languages/i18n/tyv.json b/languages/i18n/tyv.json index bffe59297b..b4acae0f2a 100644 --- a/languages/i18n/tyv.json +++ b/languages/i18n/tyv.json @@ -281,24 +281,6 @@ "changeemail-newemail": "Чаа э-чагааның адреси:", "changeemail-none": "(чок)", "changeemail-submit": "Э-чагааны өскертири", - "bold_sample": "семис үжүк", - "bold_tip": "семис үжүк", - "italic_sample": "курсив хевир", - "italic_tip": "Курсив хевир", - "link_sample": "Шөлүлгениң ады", - "link_tip": "Иштики арынче айтыг", - "extlink_sample": "http://www.example.com холбааның ады", - "extlink_tip": "Даштыкы арынче айтыг (\"http://\" префикс дугайында утпаңар)", - "headline_sample": "Эге аттың сөзүглели", - "headline_tip": "2-ги деңнелдиң эге ады", - "nowiki_sample": "Форматтавас сөзүглелди бээр салыңар", - "nowiki_tip": "Вики-форматтаашкын кылбас", - "image_sample": "Чижек.jpg", - "image_tip": "Киирген файл", - "media_sample": "Чижек.ogg", - "media_tip": "Файлче айтыг", - "sig_tip": "Холуңар үжүү, үе-шагы", - "hr_tip": "Доора шугум (көвей ажыглаваңар)", "summary": "Түңнел:", "subject": "Кол сөс:", "minoredit": "Бо эдилге бичии-дир", diff --git a/languages/i18n/tzm.json b/languages/i18n/tzm.json index c3b206e9fd..6d917e36ea 100644 --- a/languages/i18n/tzm.json +++ b/languages/i18n/tzm.json @@ -204,16 +204,6 @@ "changeemail-submit": "ⴱⴷⴷⴻⵍ ⴰⵎⵢⴰⵣⴰⵍ ⴰⵍⵉⴽⵜⵔⵓⵏⵉ", "resettokens-tokens": "ⵜⵉⵙⵓⵔⴰ:", "resettokens-done": "ⴱⴷⴷⴻⵍ ⵜⵉⵙⵓⵔⴰ", - "bold_sample": "Bold text", - "bold_tip": "Bold text", - "italic_sample": "Italic text", - "italic_tip": "Italic text", - "link_sample": "ⴰⵣⵡⵉⵍ ⵏ ⵓⵣⴷⴰⵢ", - "link_tip": "ⴰⵣⴷⴰⵢ ⵏ ⵓⴳⵏⵙⵓ", - "extlink_sample": "http://www.example.com ⴰⵣⵡⵉⵍ ⵓⵣⴷⴰⵢ", - "image_sample": "Example.jpg", - "media_sample": "Example.ogg", - "media_tip": "ⴰⵣⴷⴰⵢ ⵓⵙⴷⴰⵡ", "savearticle": "ⵣⵎⵎⴻⵎ ⵜⴰⵙⵏⴰ", "preview": "ⴰⵥⵕⵉ ⴰⵎⵣⵡⴰⵔⵓ", "showpreview": "ⵥⵕ", diff --git a/languages/i18n/udm.json b/languages/i18n/udm.json index aa79090832..87d541ed29 100644 --- a/languages/i18n/udm.json +++ b/languages/i18n/udm.json @@ -324,22 +324,6 @@ "botpasswords-deleted-title": "Пароль палэнтыны боты", "passwordreset": "Пароль куштыны", "passwordreset-username": "Пырон ним:", - "bold_sample": "Зӧк шрифт", - "bold_tip": "Зӧк шрифт", - "italic_sample": "Бекырес текст", - "italic_tip": "Бекырес текст", - "link_sample": "Чӧлсконлэн йыръянэз", - "link_tip": "Пуш чӧлскон", - "extlink_sample": "http://www.example.com чӧлсконлэн йыръянэз", - "extlink_tip": "Педпала чӧлскон (http:// префиксэз эн вунэтэ)", - "headline_sample": "Йыръян текст", - "headline_tip": "2-тӥ уровеньем йыръян", - "nowiki_sample": "Вики-пусъёсыз санэ басьтытэк кельтоно текстэз пуктэ татчы", - "nowiki_tip": "Вики-пусъёсыз лыдэ басьтоно ӧвӧл", - "image_tip": "Пыӵатэм файл", - "media_tip": "Файл чӧлскон", - "sig_tip": "Тӥляд гожтӥськонды но дыр пусъён", - "hr_tip": "Горизонтальной гож (эн пыртэ ӵем)", "summary": "Мар но малы тупатэмын? (вакчияк):", "minoredit": "Ичи воштон", "watchthis": "Та бамез чаклан списоке пыртыны", diff --git a/languages/i18n/ug-arab.json b/languages/i18n/ug-arab.json index 0c47afc462..7dbbecaebc 100644 --- a/languages/i18n/ug-arab.json +++ b/languages/i18n/ug-arab.json @@ -568,24 +568,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|كۆزىتىش تىزىملىكىڭىزدىكى بەتلەر ئۆزگىرىشى]] (Atom/RSS) تور مەنبەسىنىڭ ئاچقۇچلۇق بەلگىسى", "resettokens-done": "ئاچقۇچلۇق بەلگىلەر قايتا بېكىتىلدى.", "resettokens-resetbutton": "تاللانغان ئاچقۇچلۇق بەلگىلەرنى قايتا بېكىت", - "bold_sample": "توم خەت", - "bold_tip": "توم خەت", - "italic_sample": "يانتۇ خەت", - "italic_tip": "يانتۇ خەت", - "link_sample": "ئۇلانما ماۋزۇ", - "link_tip": "ئىچكى ئۇلانما", - "extlink_sample": "http://www.example.com ئۇلانما ماۋزۇسى", - "extlink_tip": "سىرتقى ئۇلانما (http:// ئالدى قوشۇلغۇچى قوشۇڭ)", - "headline_sample": "ماۋزۇ تېكستى", - "headline_tip": "2- دەرىجىلىك ماۋزۇ", - "nowiki_sample": "فورماتى يوق تېكست قىستۇر", - "nowiki_tip": "wiki فورماتىغا پەرۋا قىلما", - "image_sample": "Example.jpg", - "image_tip": "سىڭدۈرمە ھۆججەت", - "media_sample": "Example.ogg", - "media_tip": "ھۆججەت ئۇلىنىشى", - "sig_tip": "ۋاقىت تامغىلىق ئىمزايىڭىز", - "hr_tip": "توغرىسىغا سىزىق (ئېھتىيات بىلەن ئىشلىتىڭ)", "summary": "ئۈزۈندە", "subject": "ماۋزۇ:", "minoredit": "بۇ ئازراقلا تەھرىرلەش", diff --git a/languages/i18n/uk.json b/languages/i18n/uk.json index 519a35581f..583ef080fc 100644 --- a/languages/i18n/uk.json +++ b/languages/i18n/uk.json @@ -97,7 +97,7 @@ "tog-watchdefault": "Додавати змінені мною сторінки та файли до мого списку спостереження", "tog-watchmoves": "Додавати перейменовані мною сторінки та файли до мого списку спостереження", "tog-watchdeletion": "Додавати вилучені мною сторінки та файли до мого списку спостереження", - "tog-watchuploads": "Додавати до мого списку спостереження нові файли, завантажені мною", + "tog-watchuploads": "Додавати файли, завантажені мною до списку спостереження", "tog-watchrollback": "Додавати відкочені мною сторінки до мого списку спостереження", "tog-minordefault": "Позначати всі зміни як незначні за замовчуванням", "tog-previewontop": "Показувати попередній перегляд перед вікном редагування, а не після", @@ -127,6 +127,7 @@ "tog-useeditwarning": "Попереджати мене, якщо я залишаю сторінку редагування з незбереженими змінами", "tog-prefershttps": "Завжди використовувати безпечне з'єднання при вході в систему", "tog-showrollbackconfirmation": "Показати підтверджувальне вікно при натисканні на посилання відкоту", + "tog-requireemail": "Вимагає вказання електронної пошти для скидання пароля", "underline-always": "Завжди", "underline-never": "Ніколи", "underline-default": "Використовувати налаштування браузера", @@ -205,7 +206,7 @@ "category-empty": "''Ця категорія зараз порожня.''", "hidden-categories": "{{PLURAL:$1|1=Прихована категорія|Приховані категорії}}", "hidden-category-category": "Приховані категорії", - "category-subcat-count": "{{PLURAL:$2|Показано $1 {{PLURAL:$1|підкатегорію з|підкатегорії з|підкатегорій із}} $2.|1=Ця категорія має тільки таку підкатегорію.}}", + "category-subcat-count": "{{PLURAL:$2|1=Ця категорія має тільки таку підкатегорію.|Показано $1 {{PLURAL:$1|підкатегорію з|підкатегорії з|підкатегорій із}} $2.}}", "category-subcat-count-limited": "У цій категорії {{PLURAL:$1|$1 підкатегорія|$1 підкатегорії|$1 підкатегорій}}.", "category-article-count": "Показано $1 {{PLURAL:$1|сторінку|сторінки|сторінок}} цієї категорії (із $2).", "category-article-count-limited": "У цій категорії {{PLURAL:$1|$1 сторінка|$1 сторінки|$1 сторінок}}.", @@ -504,7 +505,7 @@ "createaccountmail": "Використати тимчасовий випадковий пароль і надіслати його на вказану адресу електронної пошти", "createaccountmail-help": "Може використовуватися, щоб створити обліковий запис для іншої особи, не дізнаючись пароль.", "createacct-realname": "Справжнє ім'я (не обов'язково)", - "createacct-reason": "Причина", + "createacct-reason": "Причина (публічно видима)", "createacct-reason-ph": "Чому ви створюєте інший обліковий запис", "createacct-reason-help": "Повідомлення, що показується в журналі створення облікових записів", "createacct-submit": "Створіть ваш обліковий запис", @@ -667,30 +668,12 @@ "changeemail-nochange": "Будь ласка, введіть адресу електронної пошти, відмінну від попередньої.", "resettokens": "Скидання токенів", "resettokens-text": "Ви можете скинути токени, що забезпечують доступ до певних особистих даних, пов'язаних тут із вашим обліковим записом.\nВам слід це зробити, якщо ви випадково поділились токенами з кимось, або якщо ваш обліковий запис було зламано.", - "resettokens-no-tokens": "Немає жетонів до скидання.", + "resettokens-no-tokens": "Немає токенів до скидання.", "resettokens-tokens": "Токени:", "resettokens-token-label": "$1 (поточне значення: $2)", "resettokens-watchlist-token": "Маркер стрічки новин (Atom/RSS) щодо [[Special:Watchlist|зміни на сторінці з вашого списку спостереження]]", "resettokens-done": "Токени скинуто.", "resettokens-resetbutton": "Скинути обрані токени", - "bold_sample": "Жирний текст", - "bold_tip": "Жирний текст", - "italic_sample": "Курсив", - "italic_tip": "Курсив", - "link_sample": "Назва посилання", - "link_tip": "Внутрішнє посилання", - "extlink_sample": "http://www.example.com назва посилання", - "extlink_tip": "Зовнішнє посилання (не забудьте про префікс http://)", - "headline_sample": "Текст заголовка", - "headline_tip": "Заголовок 2-го рівня", - "nowiki_sample": "Додайте сюди неформатований текст.", - "nowiki_tip": "Ігнорувати вікі-форматування", - "image_sample": "Example.jpg", - "image_tip": "Файл", - "media_sample": "Example.ogg", - "media_tip": "Посилання на медіа-файл", - "sig_tip": "Ваш підпис з часовою міткою", - "hr_tip": "Горизонтальна лінія (використовуйте скупо)", "summary": "Короткий опис змін:", "subject": "Тема:", "minoredit": "Незначна зміна", @@ -873,6 +856,7 @@ "undo-norev": "Редагування не може бути скасоване, бо його не існує або було вилучено.", "undo-nochange": "Схоже, редагування вже було скасовано.", "undo-summary": "Скасування редагування № $1 користувача [[Special:Contribs/$2|$2]] ([[User talk:$2|обговорення]])", + "undo-summary-anon": "Скасування версії $1 від [[Special:Contributions/$2|$2]]", "undo-summary-username-hidden": "Скасувати версію $1, виконану прихованим користувачем", "cantcreateaccount-text": "Створення облікових записів із цієї IP-адреси ('''$1''') було заблоковане [[User:$3|користувачем $3]].\n\n$3 зазначив таку причину: ''$2''", "cantcreateaccount-range-text": "Створення облікового запису із IP-адрес у діапазоні <strong>$1</strong>, який включає вашу IP-адресу (<strong>$4</strong>), було заблоковано користувачем [[User:$3|$3]].\n\nКористувач $3 вказав як причину <em>$2</em>", @@ -1172,6 +1156,7 @@ "prefs-help-email": "Адреса електронної пошти не є обов'язковою, але необхідна для скидання пароля, якщо Ви його забудете.", "prefs-help-email-others": "Також вона дозволить іншим користувачам зв'язатися з Вами через посилання на Вашій сторінці користувача чи на сторінці обговорення. При цьому Ваша електронна адреса залишиться нерозкритою.", "prefs-help-email-required": "Потрібно зазначити адресу електронної пошти.", + "prefs-help-requireemail": "Якщо вибране, то надішле електронного листа із скинутим паролем за умови, що в обліковому записі було вказано ім'я користувача та електронна пошта.", "prefs-info": "Основні відомості", "prefs-i18n": "Інтернаціоналізація", "prefs-signature": "Підпис", @@ -2395,6 +2380,7 @@ "alreadyrolled": "Неможливо відкинути останні редагування [[:$1]], зроблені [[User:$2|$2]] ([[User talk:$2|обговорення]]{{int:pipe-separator}}[[Special:Contributions/$2|{{int:contribslink}}]]), оскільки хтось інший уже змінив чи відкинув редагування цієї статті.\n\nОстанні редагування зроблено [[User:$3|$3]] ([[User talk:$3|обговорення]]{{int:pipe-separator}}[[Special:Contributions/$3|{{int:contribslink}}]]).", "editcomment": "Пояснення редагування було: «<em>$1</em>.».", "revertpage": "Відкинуто редагування [[Special:Contributions/$2|$2]] ([[User talk:$2|обговорення]]) до зробленого [[User:$1|$1]]", + "revertpage-anon": "Відкинуто правки [[Special:Contributions/$2|$2]] до останньої версії [[User:$1|$1]]", "revertpage-nouser": "Відкинуто редагування прихованого користувача до останньої версії, зробленої {{GENDER:$1|[[User:$1|$1]]}}", "rollback-success": "Відкинуті редагування {{GENDER:$3|користувача|користувачки}} $1; повернення до версії {{GENDER:$4|користувача|користувачки}} $2.", "sessionfailure-title": "Помилка сеансу", @@ -2631,6 +2617,7 @@ "ipblocklist-legend": "Пошук заблокованого користувача", "blocklist-userblocks": "Сховати блокування облікових записів", "blocklist-tempblocks": "Сховати тимчасові блокування", + "blocklist-indefblocks": "Сховати безстрокові блокування", "blocklist-addressblocks": "Приховати блокування окремих IP-адрес", "blocklist-type": "Тип:", "blocklist-type-opt-all": "Всі", diff --git a/languages/i18n/ur.json b/languages/i18n/ur.json index fa0c3094a5..164552fae4 100644 --- a/languages/i18n/ur.json +++ b/languages/i18n/ur.json @@ -623,22 +623,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|آپ کی زیرنظر فہرست میں موجود صفحات کی تبدیلیوں]] کی ویب فیڈ (آٹوم/آر ایس ایس) کا ٹوکن", "resettokens-done": "ٹوکنوں کی ترتیب نو مکمل۔", "resettokens-resetbutton": "منتخب ٹوکنوں کو دوبارہ مرتب کریں", - "bold_sample": "دبیز متن", - "bold_tip": "دبیز متن", - "italic_sample": "ترچھا متن", - "italic_tip": "ترچھی لکھائی", - "link_sample": "ربط کا عنوان", - "link_tip": "اندرونی ربط", - "extlink_sample": "http://www.example.com ربط کا عنوان", - "extlink_tip": "بیرونی ربط (http:// کا سابقہ نہ بھولیں)", - "headline_sample": "شہ سرخی", - "headline_tip": "شہ سرخی درجہ دوم", - "nowiki_sample": "غیرشکلبندشدہ متن یہاں درج کریں", - "nowiki_tip": "ویکی فارمیٹ کو نظرانداز کریں", - "image_tip": "پیوستہ فائل", - "media_tip": "فائل کا ربط", - "sig_tip": "آپکا دستخط بمع مہرِوقت", - "hr_tip": "اُفقی لکیر (زیادہ استعمال نہ کریں)", "summary": "خلاصہ:", "subject": "عنوان:", "minoredit": "معمولی ترمیم", diff --git a/languages/i18n/uz.json b/languages/i18n/uz.json index b54cc10365..8bdb26cef9 100644 --- a/languages/i18n/uz.json +++ b/languages/i18n/uz.json @@ -433,22 +433,6 @@ "resettokens-token-label": "$1 (joriy koÊ»rsatkich: $2)", "resettokens-done": "Kalitlar yangilandi.", "resettokens-resetbutton": "Belgilangan kalitlarni yangilash", - "bold_sample": "Qalin matn", - "bold_tip": "Qalin matn", - "italic_sample": "Yotiq matn", - "italic_tip": "Yotiq matn", - "link_sample": "Ishorat nomi", - "link_tip": "Ichki ishorat", - "extlink_sample": "http://www.example.com ishorat nomi", - "extlink_tip": "Tashqi ishorat (http:// prefiksini unutmang)", - "headline_sample": "Sarlavha", - "headline_tip": "2-darajadagi sarlavha", - "nowiki_sample": "Bu yerga formatlash zarur boÊ»lmagan matnni qoÊ»ying", - "nowiki_tip": "Viki-formatlashga eʼtibor berilmasin", - "image_tip": "Fayl oÊ»rnatish", - "media_tip": "Faylga havola", - "sig_tip": "Imzoingiz va sana", - "hr_tip": "Yotiq (gorizontal) chiziq (ko'p ishlatmang)", "summary": "Qisqa izoh:", "subject": "Mavzu/sarlavha", "minoredit": "Bu kichik tahrir", diff --git a/languages/i18n/vec.json b/languages/i18n/vec.json index 37649c8e7d..bc20ee6d09 100644 --- a/languages/i18n/vec.json +++ b/languages/i18n/vec.json @@ -514,24 +514,6 @@ "changeemail-password": "Ła password so {{SITENAME}}:", "changeemail-submit": "Canbia indiriso de posta ełetronega", "resettokens-token-label": "$1 (valor atuale: $2)", - "bold_sample": "Testo in grosso", - "bold_tip": "Testo in grosso", - "italic_sample": "Corsivo", - "italic_tip": "Corsivo", - "link_sample": "Titolo del colegamento", - "link_tip": "Colegamento interno", - "extlink_sample": "http://www.example.com titolo del colegamento", - "extlink_tip": "Colegamento foresto (tiente in mente el prefiso http:// )", - "headline_sample": "Intestassion", - "headline_tip": "Intestassion de 2° livèl", - "nowiki_sample": "Inserire qua el testo no formatà", - "nowiki_tip": "Ignora ła formatasion wiki", - "image_sample": "Esenpio.jpg", - "image_tip": "File incorporà", - "media_sample": "Esenpio.ogg", - "media_tip": "Cołegamento al file multimediałe", - "sig_tip": "Firma co data e ora", - "hr_tip": "Łinea orizontałe (usare con giudisio)", "summary": "Comento:", "subject": "Argomento (intestassion):", "minoredit": "Segna come canbiamento picenin", diff --git a/languages/i18n/vep.json b/languages/i18n/vep.json index d07840cc5a..7ca9bc6cef 100644 --- a/languages/i18n/vep.json +++ b/languages/i18n/vep.json @@ -426,24 +426,6 @@ "changeemail-none": "(ei ole)", "changeemail-submit": "Toižetada e-počtan adres", "resettokens-tokens": "Tokenad:", - "bold_sample": "Lihavoitud tekst", - "bold_tip": "Lihavoitud tekst", - "italic_sample": "Kursivtekst", - "italic_tip": "Kursivtekst", - "link_sample": "Kosketusen pälkirjutez", - "link_tip": "Südäikosketuz", - "extlink_sample": "http://www.example.com kosketusen pälkirjutez", - "extlink_tip": "Irdkosketuz (muÅ¡tkat prefiksas http://)", - "headline_sample": "Pälkirjutesen tekst", - "headline_tip": "Toižen pindan pälkirjutez", - "nowiki_sample": "Pangat formatiruimatoman tekstan nakhu", - "nowiki_tip": "Ignoriruida wiki-formatiruind", - "image_sample": "Ozutez.jpg", - "image_tip": "Mülütadud fail", - "media_sample": "Ozutez.ogg", - "media_tip": "Kosketuz mediafailale", - "sig_tip": "Teiden allekirjutez da tarkoiktan aigan vestatez", - "hr_tip": "Gorizontaline pird (algat kävutagoi paksus)", "summary": "Toižetusiden ümbrikacund:", "subject": "Tem/pälkirjutez:", "minoredit": "Nece om pen' redakcii", diff --git a/languages/i18n/vi.json b/languages/i18n/vi.json index c5933052bc..a613ae4134 100644 --- a/languages/i18n/vi.json +++ b/languages/i18n/vi.json @@ -634,24 +634,6 @@ "resettokens-watchlist-token": "Dấu hiệu cho nguồn cấp [[Special:Watchlist|thay đổi trong danh sách theo dõi]] (dạng Atom/RSS)", "resettokens-done": "Đã đặt lại các dấu hiệu.", "resettokens-resetbutton": "Đặt lại các dấu hiệu được chọn", - "bold_sample": "Chữ đậm", - "bold_tip": "Chữ đậm", - "italic_sample": "Chữ xiên", - "italic_tip": "Chữ xiên", - "link_sample": "Liên kết", - "link_tip": "Liên kết", - "extlink_sample": "http://www.example.com liên kết ngoài", - "extlink_tip": "Liên kết ngoài (nhớ ghi http://)", - "headline_sample": "Đề mục", - "headline_tip": "Đề mục cấp 2", - "nowiki_sample": "Nhập dòng chữ không theo định dạng wiki vào đây", - "nowiki_tip": "Không theo định dạng wiki", - "image_sample": "Ví dụ.jpg", - "image_tip": "Chèn hình", - "media_sample": "Ví dụ.ogg", - "media_tip": "Liên kết phÆ°Æ¡ng tiện", - "sig_tip": "Chữ ký có ngày", - "hr_tip": "Dòng kẻ ngang (không nên lạm dụng)", "summary": "Tóm lược:", "subject": "Đề mục:", "minoredit": "Sá»­a đổi nhỏ", diff --git a/languages/i18n/vmf.json b/languages/i18n/vmf.json index 34169e17dd..e6f6de5beb 100644 --- a/languages/i18n/vmf.json +++ b/languages/i18n/vmf.json @@ -230,22 +230,6 @@ "mailmypassword": " najs passwôrd iwâr iimejl dsuschign lasn", "loginlanguagelabel": "Sproch: $1", "changepassword": "S'bhaswôrd ändârn", - "bold_sample": "Dägsd in fäd", - "bold_tip": "Fädâr dhägschd", - "italic_sample": "Ghursiif-dhägsd", - "italic_tip": "Ghursiif-dhägsd", - "link_sample": "Lingg-dhägsd", - "link_tip": "Lingg inârhalb fom Wighi", - "extlink_sample": "http://www.example.com Lingg-dhägsde", - "extlink_tip": "Lingg nach ausârhalb (achdung, „http://“ ghäärd fôrnewäch dâdsu)", - "headline_sample": "Iiwârschrifd 2. ôrdnung", - "headline_tip": "Iiwârschrifd 2. ôrdnung", - "nowiki_sample": "Dô än uunfôrmadiirdn dhägsd nâjschrajm", - "nowiki_tip": "Uufôrmadiirdâr dhägsd", - "image_tip": "Âjbedâde dadaj", - "media_tip": "Lingh af â meedjâ-dadaj", - "sig_tip": "Dâj signadhuur dsamm mid'm dadum", - "hr_tip": "Horidsondaalâr schdrich (bide schbôôrsam âjsedsâ)", "summary": "Dsamfasung:", "subject": "Bedräf:", "minoredit": "Blos a weng wôs is gändârd wôrn", diff --git a/languages/i18n/vo.json b/languages/i18n/vo.json index 8a356ceb0d..b594755333 100644 --- a/languages/i18n/vo.json +++ b/languages/i18n/vo.json @@ -407,22 +407,6 @@ "changeemail-none": "(nonik)", "changeemail-password": "Letavöd olik su {{SITENAME}}:", "changeemail-submit": "Votükön ladeti leäktronik", - "bold_sample": "Vödem bigik", - "bold_tip": "Vödem bigik", - "italic_sample": "Korsiv", - "italic_tip": "Korsiv", - "link_sample": "Yümatiäd", - "link_tip": "Yüm ninik", - "extlink_sample": "http://www.example.com yümatiäd", - "extlink_tip": "Yüm plödik (memolös foyümoti: http://)", - "headline_sample": "Tiädavödem", - "headline_tip": "Tiäd nivoda 2id", - "nowiki_sample": "Pladolös isio vödemi no pefomätöli", - "nowiki_tip": "Nedemön vükifomätami", - "image_tip": "Magod penüpladöl", - "media_tip": "Yüm lü ragiv mediatik", - "sig_tip": "Dispenäd olik kobü dät e tim", - "hr_tip": "Lien horitätik (no gebolös tu suvo)", "summary": "Plän brefik:", "subject": "Subyet/tiäd:", "minoredit": "Votükam pülik", diff --git a/languages/i18n/vot.json b/languages/i18n/vot.json index ac77d85604..016b48de69 100644 --- a/languages/i18n/vot.json +++ b/languages/i18n/vot.json @@ -179,22 +179,6 @@ "resetpass-submit-cancel": "Otmeńoit", "passwordreset-username": "Cäüttijänimi:", "changeemail-newemail": "Vassõn e-mail:", - "bold_sample": "Pimmiä teksti", - "bold_tip": "Pimmiä teksti", - "italic_sample": "Kursiivoi teksti", - "italic_tip": "Kursiivi", - "link_sample": "Linkki", - "link_tip": "Sisipooliin linkki", - "extlink_sample": "http://www.example.com linki nimi", - "extlink_tip": "Eräpooliin linkki (mäleht http:// prefiksi)", - "headline_sample": "Zagolofkka-teksti", - "headline_tip": "Zagolofkka", - "nowiki_sample": "Lissä formattimatoo teksti tänne", - "nowiki_tip": "Ignoriiroit viki formatti", - "image_tip": "Kuva", - "media_tip": "Faililinkki", - "sig_tip": "Alacirjutuz aikamerkikaa", - "hr_tip": "Gorizontalnoi viiru", "summary": "Turvotuz:", "subject": "Teema:", "minoredit": "Kase on peeni muutuz", diff --git a/languages/i18n/vro.json b/languages/i18n/vro.json index 7bf5967c8f..5aba430aaf 100644 --- a/languages/i18n/vro.json +++ b/languages/i18n/vro.json @@ -452,24 +452,6 @@ "resetpass-recycled": "Olõq hää, valiq umas salasõnas midägi muud, ku parhillanõ salasõna.", "resetpass-temp-password": "Aotlinõ salasõna:", "passwordreset": "Salasõna vahtsõndaminõ", - "bold_sample": "Paks kiri", - "bold_tip": "Paks kiri", - "italic_sample": "Liuhkakiri", - "italic_tip": "Liuhkakiri", - "link_sample": "Lingi päälkiri", - "link_tip": "Siselink", - "extlink_sample": "http://www.example.com Lingi nimi", - "extlink_tip": "Välislink (unõhtagu-i ette pandaq http://)", - "headline_sample": "Päälkiri", - "headline_tip": "Tõõsõ tasõmõ päälkiri", - "nowiki_sample": "Kirodaq kujondamalda tekst", - "nowiki_tip": "Tunnistagu-i viki kujondust", - "image_sample": "Näüdüs.jpg", - "image_tip": "Pästet pilt", - "media_sample": "Näüdüs.ogg", - "media_tip": "Meediäteedüstü", - "sig_tip": "Suq allkiri üten aotempliga", - "hr_tip": "Horisontaaljuun", "summary": "Kokkovõtõq:", "subject": "Päälkiri:", "minoredit": "Taa om väiku parandus", diff --git a/languages/i18n/wa.json b/languages/i18n/wa.json index efebbb0274..16887074dd 100644 --- a/languages/i18n/wa.json +++ b/languages/i18n/wa.json @@ -414,24 +414,6 @@ "changeemail-newemail": "Novele adresse emile:", "changeemail-none": "(nole)", "changeemail-submit": "Candjî l' emile", - "bold_sample": "CrÃ¥ssès letes", - "bold_tip": "Tecse e crÃ¥ssès letes", - "italic_sample": "Clintcheyès letes", - "italic_tip": "Tecse e clintcheyès letes", - "link_sample": "Tecse pol loyén", - "link_tip": "Divintrin loyén", - "extlink_sample": "http://www.example.com tecse pol hÃ¥rdêye", - "extlink_tip": "Difoûtrinne hÃ¥rdêye (èn rovyîz nén di mete «http://» pa dvant)", - "headline_sample": "Tecse di tite", - "headline_tip": "Tite di 2inme livea", - "nowiki_sample": "Tapez l' tecse nén wiki chal", - "nowiki_tip": "Èn nén analijhî des côdes wiki, eyet purade les hÃ¥yner sins fôrmater", - "image_sample": "Egzimpe.jpg", - "image_tip": "Ravalêye imÃ¥dje", - "media_sample": "Egzimpe.ogg", - "media_tip": "Loyén viè on fitchî multimedia (come do son evnd)", - "sig_tip": "Li sinateure da vosse, avou l' date et l' eure", - "hr_tip": "Roye di coûtchî (a n' nén eployî d' trop)", "summary": "Rascourti:", "subject": "Sudjet:", "minoredit": "Ci n' est k' ene tchitcheye", diff --git a/languages/i18n/war.json b/languages/i18n/war.json index d54ed0540d..eb70fa4b24 100644 --- a/languages/i18n/war.json +++ b/languages/i18n/war.json @@ -552,22 +552,6 @@ "resettokens-watchlist-token": "Token para han web feed (Atom/RSS) han[[Special:Watchlist|mga pagbag-o ha imo pakli han talaan-barantayon]]", "resettokens-done": "Narest an mga token.", "resettokens-resetbutton": "Igreset an pinili nga mga token", - "bold_sample": "dakmola an agi", - "bold_tip": "Dakmola an agi", - "italic_sample": "Pakiling nga agi", - "italic_tip": "Pakiling nga agi", - "link_sample": "Titulo han sumpay", - "link_tip": "Sumpay ha sulod", - "extlink_sample": "http://www.example.com sumpay nga titulo", - "extlink_tip": "Sumpay ha gawas (hinumdomi http:// pahiuna-nga-panumpay)", - "headline_sample": "teksto han katukiban", - "headline_tip": "Katupngan 2 nga katukiban", - "nowiki_sample": "Igsuksok an diri-nakaayos nga mga teksto dinhi", - "nowiki_tip": "Pabay-i la an pagfoformat nga wiki", - "image_tip": "Nakatampo nga paypay", - "media_tip": "sumpay han paypay", - "sig_tip": "Imo pirma nga may-ada marka hin oras", - "hr_tip": "Patumba nga bagis (hinay-hinay la it paggamit)", "summary": "Halipotay nga masisiring:", "subject": "Himangrawan:", "minoredit": "Gutiay ini nga pagliwat", diff --git a/languages/i18n/wo.json b/languages/i18n/wo.json index 703314d895..1480e97ae4 100644 --- a/languages/i18n/wo.json +++ b/languages/i18n/wo.json @@ -372,24 +372,6 @@ "resetpass-wrong-oldpass": "Baatujall bu diiru walla bi teew baaxul.\nXèj-na baatujàll bi soppi nga ko ba noppi, walla xéj-na it dangaa laaj beneen baatujàll bu diiru.", "resetpass-temp-password": "Baatujàll bu diiru :", "passwordreset": "Neenal baatujàll bi", - "bold_sample": "Duufal mbind mi", - "bold_tip": "Duufal mbind mi", - "italic_sample": "Wengal mbind mi", - "italic_tip": "Wengal mbind mi", - "link_sample": "Koju lëkkalekaay bi", - "link_tip": "Lëkkalekaay yu biir", - "extlink_sample": "http://www.example.com koju lëkkalekaay bi", - "extlink_tip": "Lëkkalekaay yu biti (bul fattee jiital http://)", - "headline_sample": "Ron-koj", - "headline_tip": "Ron-koj 2 tolluwaay", - "nowiki_sample": "Dugalal fii mbind mi ñu joxul melokaan", - "nowiki_tip": "Jéllaleel mbindinu wiki", - "image_sample": "Misaal.jpg", - "image_tip": "Roof ab nataal", - "media_sample": "Misaal.ogg", - "media_tip": "Lëkkalekaay buy jëme ciw ŋara", - "sig_tip": "Xaatimee waxtu wi", - "hr_tip": "Rëdd wu tëdd (bul ci ëppal)", "summary": "Tënk :", "subject": "Tëriit/koj:", "minoredit": "Coppite yu néewal", diff --git a/languages/i18n/wuu.json b/languages/i18n/wuu.json index 38131aa726..5c250c7a15 100644 --- a/languages/i18n/wuu.json +++ b/languages/i18n/wuu.json @@ -519,22 +519,6 @@ "resettokens-token-label": "$1(当前值:$2)", "resettokens-done": "密钥已重置。", "resettokens-resetbutton": "重置选中个密钥", - "bold_sample": "粗体文字", - "bold_tip": "粗体文字", - "italic_sample": "斜体文字", - "italic_tip": "斜体文字", - "link_sample": "链接标题", - "link_tip": "内部链接", - "extlink_sample": "http://www.example.com 链接标题", - "extlink_tip": "外部链接(前头记牢加 http://)", - "headline_sample": "标题文本", - "headline_tip": "2级标题文字", - "nowiki_sample": "来箇里插入非格式文本", - "nowiki_tip": "弗管wiki格式", - "image_tip": "嵌入文件", - "media_tip": "文件链接", - "sig_tip": "签名搭辰光戳", - "hr_tip": "水平线 (小心用)", "summary": "摘要:", "subject": "主题:", "minoredit": "箇是小变化", diff --git a/languages/i18n/xal.json b/languages/i18n/xal.json index 2abbe5e593..8d9092cda0 100644 --- a/languages/i18n/xal.json +++ b/languages/i18n/xal.json @@ -293,22 +293,6 @@ "changepassword-success": "Тана нууц үгиг йовудта сольв! Та ода орнат...", "resetpass-submit-loggedin": "Нууц үг сольх", "resetpass-submit-cancel": "Буцх", - "bold_sample": "Тарһн бичг", - "bold_tip": "Тарһн бичг", - "italic_sample": "Өкәсн бичг", - "italic_tip": "Өкәсн бичг", - "link_sample": "Заалһин нерн", - "link_tip": "Дотрк заалһ", - "extlink_sample": "http://www.example.com заалһин һарцг", - "extlink_tip": "Һазак заалһ (http:// эклвр бичә мартн)", - "headline_sample": "Һарцгин бичәсн", - "headline_tip": "Дү һарцг", - "nowiki_sample": "Энд кевлүлх кергго бичәсн орултн", - "nowiki_tip": "Вики кевлүллт басх", - "image_tip": "Углсн боомг", - "media_tip": "Боомгур заалһ", - "sig_tip": "Тана тәвсн һар цаг хойр", - "hr_tip": "Кевтә татасн (нигтәр биш керглтн)", "summary": "Үндсн:", "subject": "Төр/һарцг:", "minoredit": "Баһ ясвр", diff --git a/languages/i18n/xmf.json b/languages/i18n/xmf.json index cc010c2370..e7a5cc0810 100644 --- a/languages/i18n/xmf.json +++ b/languages/i18n/xmf.json @@ -517,22 +517,6 @@ "resettokens-watchlist-token": "ტოკენი ვებ-არხისთვის (Atom/RSS) [[Special:Watchlist|გვერდების ცვლილებები თქვენი კონტროლის სიაში]]", "resettokens-done": "ჟეტონების ჩამოყრა.", "resettokens-resetbutton": "არჩეული ჟეტონების ჩამოყრა", - "bold_sample": "რუმე ტექსტი", - "bold_tip": "რუმე ტექსტი", - "italic_sample": "ელართელი ტექსტი", - "italic_tip": "ელართელი ტექსტი", - "link_sample": "რცხუშ ჯოხო", - "link_tip": "დინოხოლენი რცხუ", - "extlink_sample": "http://www.example.com რცხუშ ჯოხო", - "extlink_tip": "გალენი რცხუ (ქორშუდანი http:// პრეფიქსი)", - "headline_sample": "დუდლანდარიშ ტექსტი", - "headline_tip": "მაჟირა დონეშ დუდლანდარი", - "nowiki_sample": "ქინახუნეთ უგუფორმატაფუ ტექსტი თაქ", - "nowiki_tip": "ვიკიშ ფორმატირაფაშ იგნორირაფა", - "image_tip": "დინოხუნაფილი ფაილი", - "media_tip": "ფაილიშ რცხუ", - "sig_tip": "თქვან ხეშმოჭარა დო ბორჯი", - "hr_tip": "ჰორიზონტალური ღოზი (ვაგიმირინუათ შხირას)", "summary": "რეზიუმე:", "subject": "თემა/დუდლანდარი:", "minoredit": "თენა რე ჭიჭე რედაქტირაფა", diff --git a/languages/i18n/xsy.json b/languages/i18n/xsy.json index 33ff1ad707..073dff9e84 100644 --- a/languages/i18n/xsy.json +++ b/languages/i18n/xsy.json @@ -198,22 +198,6 @@ "resetpass-submit-cancel": "kayni’", "passwordreset": " ’in’alay naehan paskayzaeh ka mima:", "passwordreset-username": " kamamatawaw raro:o’:", - "bold_sample": " pinakrarahoe’ ka kina:at", - "bold_tip": " pinakrarahoe’ ka kina:at", - "italic_sample": " kina:at pinay’iring", - "italic_tip": " kina:at pinay’iring", - "link_sample": " kalotoran raro:o’", - "link_tip": "izo’ kalotoran", - "extlink_sample": "http://www.example.com kalotoran raro:o’", - "extlink_tip": " ’oehaez kalotoran ( hoehoero: ’anoka http:// ’on’alay)", - "headline_sample": "minayhal ka raro:o’ kina:at", - "headline_tip": "minaypoSal ka raro:o’ kina:at", - "nowiki_sample": "paksilaeh ’inoki ke:Se’hwa’ ka kina:at", - "nowiki_tip": "’itayso: ka wiki pinke:Se’hwa’", - "image_tip": "tang’an rinpa:", - "media_tip": " tang’an kalotoran", - "sig_tip": "’inSo’a kina:at raro:o’ ki hahila: jikang", - "hr_tip": "hinoba:ang ’imatatihingha’ (’okik rengreng)", "summary": "zhayaw:", "minoredit": "hini ’aehae’ ka pinaybiil kaponrowa’en", "watchthis": "kitkita’ ka hini ye:myen", diff --git a/languages/i18n/yi.json b/languages/i18n/yi.json index 46c9688005..aaae6479f7 100644 --- a/languages/i18n/yi.json +++ b/languages/i18n/yi.json @@ -587,24 +587,6 @@ "resettokens-watchlist-token": "טאקן פארן וועב־פֿיד (Atom/RSS) פון [[Special:Watchlist|ענדערונגען צו בלעטער אויף אייער אויפֿפאסונג ליסטע]]", "resettokens-done": "טאקנס צוריקגעזעצט.", "resettokens-resetbutton": "צוריקזעצן אויסגעקליבענע טאקנס", - "bold_sample": "דיקער טעקסט", - "bold_tip": "דיקער טעקסט", - "italic_sample": "דאס וועט מאכן ''שיף'' די אויסגעוועלט ווארט.", - "italic_tip": "דאס וועט מאכן ''שיף'' די אויסגעוועלט פאנט.", - "link_sample": "שרײַבט דאָ אַרײַן די װערטער װאָס װעט זײַן אַ לינק צו {{SITENAME}} אַרטיקל אין דעם נושא", - "link_tip": "מאך דאס א '''לינק''' צו א וויקיפעדיע ארטיקל", - "extlink_sample": "http://www.example.com לינק טיטל", - "extlink_tip": "דערויסענדיגע לינק (געדענק http:// פרעפיקס)", - "headline_sample": "קעפּל", - "headline_tip": "קעפּל -2טער שטאפל", - "nowiki_sample": "נישט פֿארמאַטירטער טעקסט", - "nowiki_tip": "נישט פֿאָרמאַטירטער טעקסט", - "image_sample": "PictureFileName.jpg|קליין|250px|לייגט דא א קעפל פֿארן בילד", - "image_tip": "טעקע געוויזן אין בלאט", - "media_sample": "ביישפיל.ogg", - "media_tip": "פארבינדונג צו א מעדיע טעקע", - "sig_tip": "אייער אינטערשריפט, מיט א צייט סטעמפּל ווען איר האט אונטערגעשריבן.", - "hr_tip": "א שטרייך אין די ברייט, (נישט נוצן אפט)", "summary": "קורץ וואָרט:", "subject": "טעמע:", "minoredit": "דאס איז א מינערדיגע ענדערונג", diff --git a/languages/i18n/yo.json b/languages/i18n/yo.json index 03552cf19e..871febd3e7 100644 --- a/languages/i18n/yo.json +++ b/languages/i18n/yo.json @@ -501,22 +501,6 @@ "changeemail-none": "(kòsí)", "changeemail-password": "Ọ̀rọ̀ìpamọ́ {{SITENAME}} yín:", "changeemail-submit": "Ìyípadà E-mail", - "bold_sample": "Ìkọ kedere", - "bold_tip": "Ìkọ kedere", - "italic_sample": "Ìkọ italiki", - "italic_tip": "Ìkọ̀wé italiki", - "link_sample": "Àkọlé ìjápọ̀", - "link_tip": "Ìjápọ̀ inú", - "extlink_sample": "http://www.example.com àkọlé ìjápọ̀", - "extlink_tip": "Ìjápọ̀ lóde (ẹ mọ́ gbàgbé àlẹ̀mọ́wájú http://)", - "headline_sample": "Ìkọ àkọlé", - "headline_tip": "Àkọlé onípele 2", - "nowiki_sample": "Ìkìbọ̀ ìkọ àìjẹ́ síṣèdá síbí", - "nowiki_tip": "Kí á fojú fo bí wiki á¹£e rí", - "image_tip": "Fáìlì tí a kìbọ̀", - "media_tip": "Ìjápọ̀ fáìlì", - "sig_tip": "Ìtọwọ́bọ̀wé yín pẹ̀lú àsìkò àti déètì", - "hr_tip": "Ìlà gbọlọjọ (ẹ lọ̀ọ́ pẹ̀lú àkíyèsì)", "summary": "Àkótán:", "subject": "Ìdálé-ọ̀rọ̀:", "minoredit": "Àtúná¹£e kékeré nìyí", diff --git a/languages/i18n/yue.json b/languages/i18n/yue.json index 143b9a79e6..6709950810 100644 --- a/languages/i18n/yue.json +++ b/languages/i18n/yue.json @@ -609,22 +609,6 @@ "resettokens-watchlist-token": "訂[[Special:Watchlist|監視清單]] Atom/RSS 嘅密匙", "resettokens-done": "密匙已經重設。", "resettokens-resetbutton": "重設指定密匙", - "bold_sample": "粗體字", - "bold_tip": "粗體字", - "italic_sample": "斜體字", - "italic_tip": "斜體字", - "link_sample": "連結標題", - "link_tip": "內部連結", - "extlink_sample": "http://www.example.com 連結標題", - "extlink_tip": "連出去(記住加 http:// 開頭)", - "headline_sample": "標題文字", - "headline_tip": "二級標題", - "nowiki_sample": "喺呢度插入非格式代文字", - "nowiki_tip": "唔理 wiki 格式", - "image_tip": "嵌入檔案", - "media_tip": "檔案連結", - "sig_tip": "你嘅簽名同埋時間戳", - "hr_tip": "橫線(請小心用)", "summary": "摘要:", "subject": "主題:", "minoredit": "呢個係細修改", diff --git a/languages/i18n/zea.json b/languages/i18n/zea.json index 64c64edc1e..5b00d8637f 100644 --- a/languages/i18n/zea.json +++ b/languages/i18n/zea.json @@ -337,22 +337,6 @@ "resetpass_submit": "Wachtwoôrd instell'n en anmelden", "changepassword-success": "Je wachtwoord is ewiezigd. Bezig mie anmelden ...", "resetpass_forbidden": "Wachtwoôrden kunn'n op {{SITENAME}} nie ewiezigd worn", - "bold_sample": "Vette tekst", - "bold_tip": "Vet", - "italic_sample": "Schuunhedrukte tekst", - "italic_tip": "Schuun", - "link_sample": "Onderwerp", - "link_tip": "Interne lienk", - "extlink_sample": "http://www.example.com lienktekst", - "extlink_tip": "Externe lienk (verheet http:// nie)", - "headline_sample": "Deêlonderwerp", - "headline_tip": "Tussenkopje (oôgste niveau)", - "nowiki_sample": "Voer ier de nie op te maeken tekst in", - "nowiki_tip": "Wiki-opmaek neheren", - "image_tip": "Mediabestand", - "media_tip": "Lienk ni bestand", - "sig_tip": "Jen 'andteêkenienge mie datum en tied", - "hr_tip": "Horizontaele lien (gebruuk spaerzaem)", "summary": "Saemenvatting:", "subject": "Onderwerp/kop:", "minoredit": "Dit is een kleine wieziging", diff --git a/languages/i18n/zgh.json b/languages/i18n/zgh.json index d0d4c8a8c5..b2944ca331 100644 --- a/languages/i18n/zgh.json +++ b/languages/i18n/zgh.json @@ -170,7 +170,7 @@ "history": "ⴰⵎⵣⵔⴰⵢ ⵏ ⵜⴰⵙⵏⴰ", "history_short": "ⴰⵎⵣⵔⵓⵢ", "history_small": "ⴰⵎⵣⵔⵓⵢ", - "updatedmarker": "ⵜⵡⴰⵙⵙⵏⴼⵍ ⵜⵉⴳⵉⵔⴰ ⵏ ⵓⵔⵣⴰⴼ ⵉⵏⵓ", + "updatedmarker": "ⵜⵡⴰⵙⵙⵏⴼⵍ ⵜⵉⴳⵉⵔⴰ ⵏ ⵓⵔⵣⴰⴼ ⵏⴽ:", "printableversion": "ⵜⵓⵏⵖⵉⵍⵜ ⵉⵜⵜⵡⴰⵙⵉⴳⴳⵣⵏ", "permalink": "ⴰⵙⵖⵏ ⴰⵎⵖⵍⴰⵍ", "print": "ⵙⵉⴳⴳⵣ", @@ -482,22 +482,6 @@ "changeemail-newemail-help": "ⴰⵊⵊ ⵉⴳⵔ â´°â´· ⵢⵓⵔⴰⵏ ⵉⵖ ⵜⵔⵉⴷ â´°â´· ⵜⴽⴽⵙⴷ ⴰⵏⵙⴰ ⴰⵍⵉⴽⵟⵕⵓⵏⵉ ⵏⴽ. ⵓⵔ ⵔⴰ ⵙⵓⵍ ⵜⵉⵥⴹⵓⵔⴷ â´°â´· ⵜⵔⴰⵔⴷ ⵜⴰⴳⵓⵔⵉ ⵏ ⵓⵣⵔⴰⵢ ⵉⵖ ⵜⵜ ⵜⵜⵓⴷ â´· ⵓⵔ ⵔⴰ ⴽⵉⵏ ⵙⵓⵍ ⵍⴽⴽⵎⵏⵜ ⵜⵓⵣⵉⵏⵉⵏ ⵜⴰⵍⵉⵟⵕⵓⵏⵉⵜⵉⵏ ⵙⴳ ⵓⵡⵉⴽⵉ â´°â´· ⵉⵖ ⵜⴽⴽⵙⴷ ⴰⵏⵙⴰ ⴰⵍⵉⴽⵟⵕⵓⵏⵉ ⵏⴽ.", "changeemail-none": "(ⵓⵍⴰ ⵢⴰⵏ)", "changeemail-password": "ⴰⵜⴳⵓⵔⵉ ⵏ ⵓⵣⵔⴰⵢ ⵏⴽ â´³ {{SITENAME}}:", - "bold_sample": "ⴰⴹⵔⵉⵙ ⴰⵣⵓⵔⴰⵔ", - "bold_tip": "ⴰⴹⵔⵉⵙ ⴰⵣⵓⵔⴰⵔ", - "italic_sample": "ⴰⴹⵔⵉⵙ ⵓⵣⵍⵉⴳ", - "italic_tip": "ⴰⴹⵔⵉⵙ ⵓⵣⵍⵉⴳ", - "link_sample": "ⴰⵣⵡⵍ ⵏ ⵓⵙⵖⵓⵏ", - "link_tip": "ⴰⵙⵖⵓⵏ ⴰⴳⵯⵏⵙⴰⵏ", - "extlink_sample": "http://www.example.com ⴰⵣⵡⵍ ⵏ ⵓⵙⵖⵓⵏ", - "extlink_tip": "ⴰⵙⵖⵓⵏ ⴰⴱⵕⵕⴰⵏⵉ (ⴽⵜⵢ ⴰⵣⵡⵉⵔ http://)", - "headline_sample": "ⴰⴹⵕⵉⵚ ⵏ ⵓⵣⵡⵍ", - "headline_tip": "ⴰⵣⵡⵍ ⵏ ⵓⵙⵡⵉⵔ 2", - "nowiki_sample": "ⵙⵙⴽⵛⵎ ⴰⴹⵕⵉⵚ ⵡⴰⵔⴰⵙⵎⵓⵜⵜⴳ ⴷⴳⵉ", - "nowiki_tip": "â´°â´· ⵓⵔ ⵜⴰⵡⵉⵜ ⵅⴼ ⵜⵙⵏⴰⵢⵜ ⵏ ⵓⵡⵉⴽⵉ", - "image_tip": "ⴰⴼⴰⵢⵍⵓ ⵉⵜⵜⵓⵙⵉⴷⴼⵏ", - "media_tip": "ⴰⵙⵖⵓⵏ ⵏ ⵓⴼⴰⵢⵍⵓ", - "sig_tip": "ⴰⴷⵔⵉⵣ ⵏⴽ â´· ⵓⵙⴰⴽⵓⴷ", - "hr_tip": "ⵉⵣⵔⵉⵔⵉ ⴰⴳⵍⴰⵡⴰⵏ (ⵓⵔ ⵜⵄⵢⵢⵇ)", "summary": "ⴰⵙⴳⵣⵍ:", "minoredit": "ⵡⴰ â´· ⴰⵙⵏⴼⵍ ⵓⵎⵥⵉⵢ", "watchthis": "ⵎⵎⴰⵜⵔ ⵜⴰⵙⵏⴰ â´°â´·", @@ -517,7 +501,7 @@ "accmailtitle": "ⵜⴰⴳⵓⵔⵉ ⵓⵣⵔⴰⵢ ⵜⴻⵜⵜⵡⴰⵣⵏ", "newarticle": "(ⴰⵎⴰⵢⵏⵓ)", "newarticletext": "ⵜⴹⴼⴰⵔⴷ ⵢⴰⵏ ⵓⵙⵖⵏ ⵖⵔ ⵢⴰⵜ ⵜⴰⵙⵏⴰ ⵏⵏⴰ ⵓⵔ ⵜⴰ ⵉⵍⵍⵉⵏ. \nⴰⴼⴰⴷ â´°â´· ⵜⵙⵏⵓⵍⴼⵓⴷ ⵜⴰⵙⵏⴰ, ⵙⵙⵏⵜⵉ ⵜⵉⵔⵔⴰ â´³ ⵓⴼⵏⵉⵇ â´³ ⵉⵣⴷⴷⴰⵔ (ⵥⵔ [$1 ⵜⴰⵙⵏⴰ ⵏ ⵜⵡⵉⵙⵉ] ⵉ ⵡⵓⴳⴳⴰⵔ ⵏ ⵉⵏⵖⵎⵉⵙⵏ). \nⵎⴽ ⵜⵍⵍⵉⴷ â´·â´° ⵙ ⵓⵣⴳⴰⵍ, ⴰⴽⵍ ⵖⴼ <strong>ⴰⵖⵓⵍ</strong> â´³ ⵓⵙⴰⵔⴰ ⵏⵏⴽ.", - "anontalkpagetext": "----\n<em>ⵜⵍⵍⵉⴷ â´³ ⵜⴰⵙⵏ ⵏ ⵓⵎⵙⴰⵡⴰⵍ ⵏ ⵢⴰⵏ ⵓⵏⵙⵙⵎⵔⵙ ⵡⴰⵔⵉⵙⵎ ⵏⵏⴰ ⵜⴰ ⵓⵔ ⵉⵙⴽⵉⵔⵏ ⴰⵎⵉⴹⴰⵏ ⵏⵖ ⵏⵏⴰ ⵜ ⵓⵔ ⵉⵙⵙⵎⵔⵉⵙⵏ</em>.\nⴰⵢⴰ â´° ⵖⴼ ⵉⴼⵓⴽⴽ â´°â´· ⵏⵙⵙⵎⵔⵙ ⵜⴰⵏⵙⴰ ⵏⵏⵙ IP ⴼⴰⴷ â´°â´· ⵜ ⵏⵙⵎⴰⴳⵉ.\nⵢⴰⵜ ⵜⴰⵏⵙⴰ IP ⵥⴹⴰⵔⵏ â´°â´· ⵜⵜ ⵙⵙⵓⵔⵏ ⵎⵏⵏⴰⵡ ⵏ ⵉⵏⵙⵙⵎⵔⵙⵏ.\nⵎⴽ ⵜⴳⵉⴷ ⵢⴰⵏ ⵓⵏⵙⵙⵎⵔⵙ ⵡⴰⵔⵉⵙⵎ â´· â´½ ⵜⵖⴹⴼⴷ ⵎⴰⵙ â´½ ⵡⴰⵜⵙⵏ ⴽⵔⴰ ⵏ ⵉⵅⴼⴰⵡⴰⵍⵏ ⵓⵔ ⵙⵉⴽ ⵉⵥⵍⵉⵏ, ⵜⵓⴼⵉⴷ â´°â´· [[Special:CreateAccount|ⵙⴽⵔ ⵢⴰⵏ ⵓⵎⵉⴹⴰⵏ]] ⵏⵖ â´· [[Special:UserLogin|ⴽⵛⵎ]] ⴱⴰⵔ â´°â´· ⵜⴰⵏⴼⴷ ⵉ ⴽⵔⴰⵢⴳⴰⵜ ⴰⵎⵔⴽⵙ â´· ⵉⵎⴷⵔⴰⵡⵏ ⵢⴰⴹⵏ.", + "anontalkpagetext": "----\n<em>ⵜⵍⵍⵉⴷ â´³ ⵜⴰⵙⵏ ⵏ ⵓⵎⵙⴰⵡⴰⵍ ⵏ ⵢⴰⵏ ⵓⵏⵙⵙⵎⵔⵙ ⵡⴰⵔⵉⵙⵎ ⵏⵏⴰ ⵜⴰ ⵓⵔ ⵉⵙⴽⵉⵔⵏ ⴰⵎⵉⴹⴰⵏ ⵏⵖ ⵏⵏⴰ ⵜ ⵓⵔ ⵉⵙⵙⵎⵔⵉⵙⵏ</em>.\nⴰⵢⴰ â´° ⵖⴼ ⵉⴼⵓⴽⴽ â´°â´· ⵏⵙⵙⵎⵔⵙ ⵜⴰⵏⵙⴰ ⵏⵏⵙ IP ⴼⴰⴷ â´°â´· ⵜⵏ ⵏⵙⵎⴰⴳⵉ.\nⵢⴰⵜ ⵜⴰⵏⵙⴰ IP ⵥⴹⴰⵔⵏ â´°â´· ⵜⵜ ⵙⵙⵓⵔⵏ ⵎⵏⵏⴰⵡ ⵏ ⵉⵏⵙⵙⵎⵔⵙⵏ.\nⵎⴽ ⵜⴳⵉⴷ ⵢⴰⵏ ⵓⵏⵙⵙⵎⵔⵙ ⵡⴰⵔⵉⵙⵎ â´· â´½ ⵜⵖⴹⴼⴷ ⵎⴰⵙ â´½ ⵡⴰⵜⵙⵏ ⴽⵔⴰ ⵏ ⵉⵅⴼⴰⵡⴰⵍⵏ ⵓⵔ ⵙⵉⴽ ⵉⵥⵍⵉⵏ, ⵜⵓⴼⵉⴷ â´°â´· [[Special:CreateAccount|ⵙⴽⵔ ⵢⴰⵏ ⵓⵎⵉⴹⴰⵏ]] ⵏⵖ â´· [[Special:UserLogin|ⴽⵛⵎ]] ⴱⴰⵔ â´°â´· ⵜⴰⵏⴼⴷ ⵉ ⴽⵔⴰⵢⴳⴰⵜ ⴰⵎⵔⴽⵙ â´· ⵉⵎⴷⵔⴰⵡⵏ ⵢⴰⴹⵏ.", "noarticletext": "ⵓⵔ ⵉⵍⵍⵉ ⴽⵔⴰ ⵏ ⵓⴹⵔⵉⵙ â´³ ⵜⴰⵙⵏⴰ â´°â´· ⵖⵉⵍⴰ. \nⵜⵣⵎⵔⴷ â´°â´· [[Special:Search/{{PAGENAME}}|ⵜⵔⵣⵓⴷ ⵖⴼ ⵓⵣⵡⵍ ⵏⵏⵙ]] â´³ ⵜⴰⵙⵏⵉⵡⵉⵏ ⵢⴰⴹⵏ, <span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} ⵔⵣⵓ ⵖⴼ logs ⵖⵔⵙ ⵉⵇⵇⵏⴻⵏ],\nⵏⵖ [{{fullurl:{{FULLPAGENAME}}|action=edit}} ⵙⵏⵓⵍⴼⵓ ⵜⴰⵙⵏⴰ]</span>.", "noarticletext-nopermission": "ⴷⵖⵉ ⵓⵔ ⵉⵍⵍⵉ ⴰⵡⴷ ⴽⵔⴰ ⵏ ⵓⴹⵔⵉⵚ â´³ ⵜⴰⵙⵏⴰ â´°.\nⵜⵣⵎⵔⴷ â´°â´· [[Special:Search/{{PAGENAME}}|ⵜⵔⵣⵓⴷ ⵖⴼ ⵓⵣⵡⵍ ⵏⵏⵙ]] â´³ ⵜⴰⵙⵏⵉⵡⵉⵏ ⵢⴰⴹⵏⵉⵏ, ⵏⵖ <span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} ⵔⵣⵓ ⵖⴼ ⵉⵣⵎⵎⴻⵎⵏ ⵉⵣⴷⵉⵏ]</span>, ⵎⴰⵛⴰ ⵓⵔ ⴷⴰⵔⴽ ⵜⵓⵔⴰⴳⵜ â´°â´· ⵜⵙⵏⵓⵍⴼⵓⴷ ⵜⴰⵙⵏⴰ â´°.", "userpage-userdoesnotexist-view": "ⴰⵎⵉⴹⴰⵏ ⵏ ⵓⵎⵙⵙⵎⵔⵙ $1 ⵓⵔ ⵉⵜⵜⵓⵣⵎⵎⴻⵎ.", @@ -551,7 +535,7 @@ "last": "ⵓⵣⵡⵔ", "page_last": "ⴰⵎⴳⴳⴰⵔⵓ", "histlegend": "ⴰⵙⵜⴰⵢ ⵏ ⵓⵎⵣⴰⵔⴰⵢ : ⵔⵛⵎ ⵜⴰⵏⴽⵓⵍⵉⵏ ⵏ ⵜⵓⵏⵖⵉⵍⵉⵏ ⵏⵏⴰ ⵜⵔⵉⴷ â´°â´· ⵜⵙⵎⵣⴰⵣⴰⵍⴷ ⵜⴰⴷⵔⴷ ⵉ ⴰⴽⵎ ⵏⵖ ⵉ ⵜⵙⴰⵔⵓⵜ ⵏ ⵢⵉⵣⴷⴰⵔ.<br />\nⵜⴰⴱⴰⴷⵓⵜ : <strong>({{int:cur}})</strong> = ⴰⵎⵣⴰⵔⴰⵢ ⴰⴽⴷ ⵜⵓⵏⵖⵉⵍⵜ ⵜⴰⵎⴳⴳⴰⵔⵓⵜ, <strong>({{int:last}})</strong> = ⴰⵎⵣⴰⵔⴰⵢ ⴰⴽⴷ ⵜⵓⵏⵖⵉⵍⵜ ⵉⵣⵔⵉⵏ, <strong>{{int:minoreditletter}}</strong> = ⵉⵙⵏⵉⴼⵉⵍⵏ ⵉⵎⵥⵥⵉⵢⵏ.", - "history-fieldset-title": "ⵔⵣⵓ ⵖⴼ ⵉⵣⵣⵔⴰⵢⵏ", + "history-fieldset-title": "ⵙⵜⵉ ⵉⵣⵣⵔⴰⵢⵏ", "histfirst": "ⴰⵇⴱⵓⵔ", "histlast": "ⴰⵎⴰⵢⵏⵓ", "history-feed-title": "ⴰⵎⵣⵔⵓⵢ ⵏ ⵓⵣⵣⵔⴰⵢ", @@ -769,7 +753,7 @@ "rcfilters-savedqueries-already-saved": "ⵜⵉⵎⵣⵉⵣⴷⴳⵉⵜⵉⵏ â´°â´· ⵜⵜⵡⴰⵃⴹⴰⵏⵜ ⵢⴰⴷ. ⵙⵏⴼⵍ ⵜⵉⵙⵖⴰⵍ ⵏⴽ ⵃⵎⴰ â´°â´· ⵜⵙⵏⴼⵍⴷ ⵜⵉⵎⵣⵉⵣⴷⴳⵜ ⵜⴰⵎⴰⵢⵏⵓⵜ ⵉⵜⵜⵡⴰⵃⴹⴰⵏ.", "rcfilters-restore-default-filters": "ⵔⴰⵔ â´· ⵜⵉⵎⵣⵉⵣⴷⴳⵉⵜⵉⵏ ⵙ ⵓⵎⵕⴰⴹ", "rcfilters-clear-all-filters": "ⵚⵚⴼⴹ ⴰⴽⴽⵯ ⵜⵉⵎⵣⵉⵣⴷⴳⵉⵜⵉⵏ", - "rcfilters-show-new-changes": "ⵙⴽⵏ ⵉⵙⵏⴼⵍⵏ ⵉⵎⴰⵢⵏⵓⵜⵏ", + "rcfilters-show-new-changes": "ⵙⴽⵏ ⵉⵙⵏⴼⵍⵏ ⵉⵎⴰⵢⵏⵓⵜⵏ ⵣⴳ $1", "rcfilters-search-placeholder": "ⵣⵉⵣⴷⵉⴳ ⵉⵙⵏⴼⵍⵏ (ⵙⵎⵔⵙ ⵓⵎⵓⵖ ⵏⵖ ⵔⵣⵓ ⵖⴼ ⵉⵙⵎ ⵏ ⵜⵎⵣⵉⵣⴷⴳⵜ)", "rcfilters-invalid-filter": "ⵜⵉⵎⵣⵉⵣⴷⴳⵜ ⵓⵔ ⵉⵖⵥⴰⵏⵏ", "rcfilters-empty-filter": "ⵃⵜⵜⴰ ⴽⵔⴰ ⵏ ⵜⵉⵎⵣⵉⵣⴷⴳⵜ ⵉⵙⵡⵓⵔⵉⵏ. ⴰⴽⴽⵯ ⵉⵙⵏⵍⵏ ⵜⵜⵡⴰⵙⴽⵏⵏ.", diff --git a/languages/i18n/zh-hans.json b/languages/i18n/zh-hans.json index a65b321f30..9c00f4f3b0 100644 --- a/languages/i18n/zh-hans.json +++ b/languages/i18n/zh-hans.json @@ -708,24 +708,6 @@ "resettokens-watchlist-token": "[[Special:Watchlist|对你的监视列表中的页面的更改]]的网页feed(Atom/RSS)的密钥", "resettokens-done": "密钥已重置。", "resettokens-resetbutton": "重置选择的密钥", - "bold_sample": "粗体文字", - "bold_tip": "粗体文字", - "italic_sample": "斜体文字", - "italic_tip": "斜体文字", - "link_sample": "链接标题", - "link_tip": "内部链接", - "extlink_sample": "http://www.example.com 链接标题", - "extlink_tip": "外部链接(加前缀 http://)", - "headline_sample": "大标题文字", - "headline_tip": "2级标题", - "nowiki_sample": "在此插入非格式文本", - "nowiki_tip": "插入非格式文本", - "image_sample": "范例.jpg", - "image_tip": "插入文件", - "media_sample": "范例.ogg", - "media_tip": "文件链接", - "sig_tip": "带时间戳的签名", - "hr_tip": "水平线(请小心使用)", "summary": "摘要:", "subject": "主题:", "minoredit": "标记为小编辑", @@ -2653,6 +2635,7 @@ "ipblocklist-legend": "查找被封禁用户", "blocklist-userblocks": "隐藏账户封禁", "blocklist-tempblocks": "隐藏临时封禁", + "blocklist-indefblocks": "隐藏无限期封禁", "blocklist-addressblocks": "隐藏单个IP封禁", "blocklist-type": "类型:", "blocklist-type-opt-all": "全部", diff --git a/languages/i18n/zh-hant.json b/languages/i18n/zh-hant.json index c2cd05bedd..2bce867f9b 100644 --- a/languages/i18n/zh-hant.json +++ b/languages/i18n/zh-hant.json @@ -153,6 +153,7 @@ "tog-useeditwarning": "在我離開未儲存的編輯頁面時警告我", "tog-prefershttps": "登入時永遠使用安全連線", "tog-showrollbackconfirmation": "當點擊回退連結時顯示確認提示", + "tog-requireemail": "需要電子郵件用來重設密碼", "underline-always": "永遠使用", "underline-never": "永不使用", "underline-default": "佈景主題或瀏覽器預設", @@ -525,7 +526,7 @@ "createaccountmail": "使用臨時的隨機密碼,並將它寄至指定的電子郵件地址", "createaccountmail-help": "可用來建立其他人的帳號 (不需要知道密碼)。", "createacct-realname": "真實姓名 (選填)", - "createacct-reason": "原因", + "createacct-reason": "原因(公開記錄)", "createacct-reason-ph": "您為什麼要建立另一個帳號", "createacct-reason-help": "顯示於帳號建立日誌的訊息", "createacct-submit": "建立您的帳號", @@ -581,7 +582,7 @@ "cannotchangeemail": "æ­¤ wiki 無法變更帳號的電子郵件地址。", "emaildisabled": "此網站不能傳送電子郵件。", "accountcreated": "已建立帳號", - "accountcreatedtext": "使用者帳號 [[{{ns:User}}:$1|$1]] ([[{{ns:User talk}}:$1|討論]]) 已建立。", + "accountcreatedtext": "使用者帳號[[{{ns:User}}:$1|$1]]([[{{ns:User talk}}:$1|討論]])已建立。", "createaccount-title": "{{SITENAME}} 的帳號建立", "createaccount-text": "不明人士使用您的電子郵件地址在 {{SITENAME}} ($4) 建立了一個帳號名稱為 \"$2\",密碼為 \"$3\"。\n您應該立即登入並更改密碼。\n\n如果該帳號是建立錯誤的話,您可以忽略此訊息。", "login-throttled": "您已經嘗試太多次的登入動作。\n請稍等 $1 後再試。", @@ -680,7 +681,7 @@ "changeemail-oldemail": "目前的電子郵件地址:", "changeemail-newemail": "新的電子郵件地址:", "changeemail-newemail-help": "若您想移除您的電子郵件地址,此欄位應留空。若移除電子郵件地址您將無法重設忘記的密碼並且將不會再收到來自此 wiki 的電子郵件。", - "changeemail-none": "(無)", + "changeemail-none": "(無)", "changeemail-password": "您於 {{SITENAME}} 的密碼:", "changeemail-submit": "變更電子郵件", "changeemail-throttled": "您最近嘗試了太多次登入。\n請等待 $1 後再試。", @@ -693,24 +694,6 @@ "resettokens-watchlist-token": "用來訂閱 [[Special:Watchlist|監視清單]] Atom/RSS 的密鑰", "resettokens-done": "已重設金鑰。", "resettokens-resetbutton": "重設已選擇的金鑰", - "bold_sample": "粗體文字", - "bold_tip": "粗體文字", - "italic_sample": "斜體文字", - "italic_tip": "斜體文字", - "link_sample": "連結標題", - "link_tip": "內部連結", - "extlink_sample": "http://www.example.com 連結標題", - "extlink_tip": "外部連結(記得以 http:// 開頭)", - "headline_sample": "標題文字", - "headline_tip": "2級標題", - "nowiki_sample": "插入非格式化文字", - "nowiki_tip": "忽略 Wiki 格式化語法", - "image_sample": "範例.jpg", - "image_tip": "附加檔案", - "media_sample": "範例.ogg", - "media_tip": "檔案連結", - "sig_tip": "您的簽名與日期時間", - "hr_tip": "水平線(謹慎使用)", "summary": "摘要:", "subject": "主旨:", "minoredit": "這是一個次要修訂", @@ -891,7 +874,8 @@ "undo-main-slot-only": "編輯無法還原,因為有包含到在主分配之外的內容。", "undo-norev": "此編輯不存在或已被刪除,無法還原。", "undo-nochange": "此編輯已被還原。", - "undo-summary": "取消由 [[Special:Contributions/$2|$2]] ([[User talk:$2|討論]]) 所作出的修訂 $1", + "undo-summary": "取消由[[Special:Contributions/$2|$2]]([[User talk:$2|討論]])所作出的修訂$1", + "undo-summary-anon": "取消由[[Special:Contributions/$2|$2]]所作出的修訂$1", "undo-summary-username-hidden": "還原隱藏使用者的修訂 $1", "cantcreateaccount-text": "自這個 IP 位址 (<strong>$1</strong>) 建立帳號已經被 [[User:$3|$3]] 封鎖。\n\n$3 封鎖的原因是$2", "cantcreateaccount-range-text": "來自 IP 位址範圍 <strong>$1</strong>,包含您的 IP 位址 (<strong>$4</strong>) 所建立的帳號已經被 [[User:$3|$3]] 封鎖。\n\n$3 封鎖的原因是 <em>$2</em>", @@ -1101,7 +1085,7 @@ "datedefault": "預設值", "prefs-labs": "實驗中的功能", "prefs-user-pages": "使用者頁面", - "prefs-personal": "使用者基本資料", + "prefs-personal": "用戶資料", "prefs-rc": "近期變更", "prefs-watchlist": "監視清單", "prefs-editwatchlist": "編輯監視清單", @@ -1186,9 +1170,10 @@ "prefs-help-gender": "此偏好設定為選填欄位。\n系統會使用您選擇的方式稱呼您,對他人提及您時也會使用適當語法稱呼。\n此項資訊會被公開。", "email": "Email", "prefs-help-realname": "真實姓名為選填欄位。\n若提供,真實姓名可能會用來作為您的作品的署名。", - "prefs-help-email": "電子郵件地址為選填欄位。\n但在重設密碼時會使用,而您很有可能會忘記密碼。", + "prefs-help-email": "電子郵件地址為選填欄位,但是當您忘記密碼而要重設時需要此資訊。", "prefs-help-email-others": "您亦可以選擇讓其他使用者透過您的電子郵件、使用者頁面或討論頁面的連結與您聯絡。\n您的電子郵件地址不會洩漏給其他要聯絡您的使用者。", "prefs-help-email-required": "電子郵件地址是必填項目。", + "prefs-help-requireemail": "如果選取,則只有在重設密碼的人同時提供此帳戶的使用者名稱和電子郵件時,才會發送重設密碼的電子郵件。", "prefs-info": "基本資訊", "prefs-i18n": "國際化", "prefs-signature": "簽名", @@ -1682,7 +1667,7 @@ "upload-preferred": "建議的檔案類型:$1。", "upload-prohibited": "禁止的檔案類型:$1。", "uploadlogpage": "上傳日誌", - "uploadlogpagetext": "以下清單為最近上傳的檔案。\n請檢視 [[Special:NewFiles|最新檔案圖庫]] 以視覺化的方式檢視。", + "uploadlogpagetext": "以下清單為最近上傳的檔案。以視覺化的方式檢視請見[[Special:NewFiles|最新檔案圖庫]]。", "filename": "檔案名稱", "filedesc": "摘要", "fileuploadsummary": "摘要:", @@ -1906,6 +1891,7 @@ "listfiles-userdoesnotexist": "使用者帳號 \"$1\" 尚未註冊。", "imgfile": "檔案", "listfiles": "檔案清單", + "listfiles_subpage": "由 $1 上傳", "listfiles_thumb": "縮圖", "listfiles_date": "日期", "listfiles_name": "名稱", @@ -2242,7 +2228,7 @@ "listgrouprights-group": "群組", "listgrouprights-rights": "權限", "listgrouprights-helppage": "Help:使用者群組權限", - "listgrouprights-members": "(成員清單)", + "listgrouprights-members": "(成員清單)", "listgrouprights-addgroup": "加入{{PLURAL:$2|群組}}:$1", "listgrouprights-removegroup": "移除{{PLURAL:$2|群組|群組}}:$1", "listgrouprights-addgroup-all": "加入所有群組", @@ -2404,6 +2390,7 @@ "alreadyrolled": "無法回退由[[User:$2|$2]]([[User talk:$2|討論]]{{int:pipe-separator}}[[Special:Contributions/$2|{{int:contribslink}}]])所作的最後一次編輯[[:$1]],已有其他人編輯或回退了該頁面。\n\n最後一次編輯該頁面的使用者是[[User:$3|$3]]([[User talk:$3|討論]]{{int:pipe-separator}}[[Special:Contributions/$3|{{int:contribslink}}]])。", "editcomment": "編輯摘要為:<em>$1</em>。", "revertpage": "已還原[[Special:Contributions/$2|$2]]([[User talk:$2|討論]])的編輯至最後由[[User:$1|$1]]所修訂的版本", + "revertpage-anon": "已還原[[Special:Contributions/$2|$2]]的編輯至最後由[[User:$1|$1]]所修訂的版本", "revertpage-nouser": "已還原隱藏使用者的編輯為最後 {{GENDER:$1|[[User:$1|$1]]}} 修訂的版本", "rollback-success": "已還原{{GENDER:$3|$1}}所做的編輯;變更回由{{GENDER:$4|$2}}修訂的最後一個版本。", "sessionfailure-title": "連線階段失敗", @@ -2641,6 +2628,7 @@ "ipblocklist-legend": "搜尋已封鎖的使用者", "blocklist-userblocks": "隱藏帳號封鎖", "blocklist-tempblocks": "隱藏暫時封鎖", + "blocklist-indefblocks": "隱藏無限期封鎖", "blocklist-addressblocks": "隱藏單一 IP 封鎖", "blocklist-type": "類型:", "blocklist-type-opt-all": "所有", @@ -3560,7 +3548,7 @@ "logentry-import-upload": "$1 已由檔案上傳{{GENDER:$2|匯入}} $3", "logentry-import-upload-details": "$1 已使用檔案上傳{{GENDER:$2|匯入}} $3 ($4 {{PLURAL:$4|修訂|修訂}})", "logentry-import-interwiki": "$1 已由其他 wiki {{GENDER:$2|匯入}} $3", - "logentry-import-interwiki-details": "$1 已自 $5 {{GENDER:$2|匯入}} $3 ($4 {{PLURAL:$4|修訂|修訂}})", + "logentry-import-interwiki-details": "$1已自$5{{GENDER:$2|匯入}}$3($4{{PLURAL:$4|修訂|修訂}})", "logentry-merge-merge": "$1 將 $3 {{GENDER:$2|合併}}至 $4 (修訂版本至 $5)", "logentry-move-move": "$1 {{GENDER:$2|已移動}}頁面 $3 至 $4", "logentry-move-move-noredirect": "$1 {{GENDER:$2|已移動}}頁面 $3 至 $4,不留重新導向", @@ -3939,5 +3927,8 @@ "mycustomjsredirectprotected": "您無權編輯此JavaScript頁面,因為它是重新導向,且不是重新導向到您的用戶空間。", "easydeflate-invaliddeflate": "提供的內容未被正常的壓縮", "unprotected-js": "基於安全因素,JavaScript 不能從未保護的頁面來載入。請僅在 MediaWiki:命名空間或使用者子頁面中建立 JavaScript。", - "userlogout-continue": "您想要登出嗎?" + "userlogout-continue": "您想要登出嗎?", + "rest-prefix-mismatch": "請求的路徑($1)不在REST API的根路徑($2)內", + "rest-wrong-method": "請求的方法($1)不是{{PLURAL:$3|此路徑允許的方法|此路徑允許的方法之一}}($2)", + "rest-no-match": "請求的相對路徑($1)不符合任何已知的處理器" } diff --git a/languages/i18n/zh-hk.json b/languages/i18n/zh-hk.json index 68a0380a63..2334a83098 100644 --- a/languages/i18n/zh-hk.json +++ b/languages/i18n/zh-hk.json @@ -18,7 +18,8 @@ "Wxyveronica", "和平至上", "A2093064", - "WQL" + "WQL", + "Sunny00217" ] }, "tog-watchlisthidebots": "隱藏監視清單中機械人的編輯", @@ -114,6 +115,7 @@ "revdelete-suppress-text": "壓制'''只'''應用於以下的情況:\n* 不合適的個人資料\n*: ''地址、電話號碼、身份證號碼等。''", "editundo": "復原", "prefs-user-pages": "用戶頁面", + "prefs-personal": "用戶資料", "username": "{{GENDER:$1|用戶名稱}}:", "prefs-help-gender": "可選:用於軟件中的性別指定。此項資料將會被公開。", "group-user": "用戶", diff --git a/maintenance/Doxyfile b/maintenance/Doxyfile index 1a5daca4e1..0d1579d33f 100644 --- a/maintenance/Doxyfile +++ b/maintenance/Doxyfile @@ -59,11 +59,6 @@ ALIASES = "type{1}=<b> \1 </b>:" \ "codeCoverageIgnore=" \ "codingStandardsIgnoreEnd=" \ "codingStandardsIgnoreStart=" \ - "covers=" \ - "dataProvider=" \ - "expectedException=" \ - "expectedExceptionMessage=" \ - "group=" \ "phan=" \ "suppress=" TCL_SUBST = @@ -112,8 +107,8 @@ SORT_GROUP_NAMES = NO SORT_BY_SCOPE_NAME = NO STRICT_PROTO_MATCHING = NO GENERATE_TODOLIST = YES -GENERATE_TESTLIST = YES -GENERATE_BUGLIST = YES +GENERATE_TESTLIST = NO +GENERATE_BUGLIST = NO GENERATE_DEPRECATEDLIST= YES ENABLED_SECTIONS = MAX_INITIALIZER_LINES = 30 @@ -148,6 +143,7 @@ EXCLUDE_PATTERNS = LocalSettings.php \ AdminSettings.php \ .svn \ */.git/* \ + */README.md \ {{EXCLUDE_PATTERNS}} EXCLUDE_SYMBOLS = EXAMPLE_PATH = diff --git a/maintenance/addChangeTag.php b/maintenance/addChangeTag.php index b63a2e2b82..c1a1b079f3 100644 --- a/maintenance/addChangeTag.php +++ b/maintenance/addChangeTag.php @@ -52,7 +52,7 @@ class AddChangeTag extends Maintenance { ); if ( !$status->isGood() ) { - $this->fatalError( $status->getWikiText( null, null, 'en' ) ); + $this->fatalError( $status->getMessage( false, false, 'en' )->text() ); } $this->output( "$tag was created.\n" ); diff --git a/maintenance/archives/upgradeLogging.php b/maintenance/archives/upgradeLogging.php index 6faeee832b..98a2b59e00 100644 --- a/maintenance/archives/upgradeLogging.php +++ b/maintenance/archives/upgradeLogging.php @@ -23,6 +23,8 @@ require __DIR__ . '/../commandLine.inc'; +use Wikimedia\Rdbms\Database; + /** * Maintenance script that upgrade for log_id/log_deleted fields in a * replication-safe way. diff --git a/maintenance/changePassword.php b/maintenance/changePassword.php index e7df448f7a..aa45154ddd 100644 --- a/maintenance/changePassword.php +++ b/maintenance/changePassword.php @@ -60,7 +60,7 @@ class ChangePassword extends Maintenance { if ( $status->isGood() ) { $this->output( "Password set for " . $user->getName() . "\n" ); } else { - $this->fatalError( $status->getWikiText( null, null, 'en' ) ); + $this->fatalError( $status->getMessage( false, false, 'en' )->text() ); } } } diff --git a/maintenance/cleanupCaps.php b/maintenance/cleanupCaps.php index da241e5337..2c81adf070 100644 --- a/maintenance/cleanupCaps.php +++ b/maintenance/cleanupCaps.php @@ -163,7 +163,7 @@ class CleanupCaps extends TableCleanup { $mp = MediaWikiServices::getInstance()->getMovePageFactory() ->newMovePage( $current, $target ); $status = $mp->move( $this->user, $reason, $createRedirect ); - $ok = $status->isOK() ? 'OK' : $status->getWikiText( false, false, 'en' ); + $ok = $status->isOK() ? 'OK' : $status->getMessage( false, false, 'en' )->text(); $this->output( "\"$display\" -> \"$targetDisplay\": $ok\n" ); } diff --git a/maintenance/cleanupRevActorPage.php b/maintenance/cleanupRevActorPage.php new file mode 100644 index 0000000000..ac655fc93b --- /dev/null +++ b/maintenance/cleanupRevActorPage.php @@ -0,0 +1,77 @@ +<?php + +require_once __DIR__ . '/Maintenance.php'; + +/** + * Maintenance script that cleans up cases where rev_page and revactor_page + * became desynced, e.g. from T232464. + * + * @ingroup Maintenance + * @since 1.34 + */ +class CleanupRevActorPage extends LoggedUpdateMaintenance { + + public function __construct() { + parent::__construct(); + $this->addDescription( + 'Resyncs revactor_page with rev_page when they differ, e.g. from T232464.' + ); + $this->setBatchSize( 1000 ); + } + + protected function getUpdateKey() { + return __CLASS__; + } + + protected function doDBUpdates() { + $dbw = $this->getDB( DB_MASTER ); + $max = $dbw->selectField( 'revision', 'MAX(rev_id)', '', __METHOD__ ); + $batchSize = $this->mBatchSize; + + $this->output( "Resyncing revactor_page with rev_page...\n" ); + + $count = 0; + for ( $start = 1; $start <= $max; $start += $batchSize ) { + $end = $start + $batchSize - 1; + $this->output( "... rev_id $start - $end, $count changed\n" ); + + // Fetch the rows needing update + $res = $dbw->select( + [ 'revision', 'revision_actor_temp' ], + [ 'rev_id', 'rev_page' ], + [ + 'rev_page != revactor_page', + "rev_id >= $start", + "rev_id <= $end", + ], + __METHOD__, + [], + [ 'revision_actor_temp' => [ 'JOIN', 'rev_id = revactor_rev' ] ] + ); + + if ( !$res->numRows() ) { + continue; + } + + // Update the existing rows + foreach ( $res as $row ) { + $dbw->update( + 'revision_actor_temp', + [ 'revactor_page' => $row->rev_page ], + [ 'revactor_rev' => $row->rev_id ], + __METHOD__ + ); + $count += $dbw->affectedRows(); + } + + wfWaitForSlaves(); + } + + $this->output( "Completed resync, $count row(s) updated\n" ); + + return true; + } +} + +$maintClass = CleanupRevActorPage::class; +require_once RUN_MAINTENANCE_IF_MAIN; diff --git a/maintenance/cleanupSpam.php b/maintenance/cleanupSpam.php index 4cc52a4034..60f3884419 100644 --- a/maintenance/cleanupSpam.php +++ b/maintenance/cleanupSpam.php @@ -21,7 +21,7 @@ * @ingroup Maintenance */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; require_once __DIR__ . '/Maintenance.php'; diff --git a/maintenance/copyFileBackend.php b/maintenance/copyFileBackend.php index ce4063842c..9e36742726 100644 --- a/maintenance/copyFileBackend.php +++ b/maintenance/copyFileBackend.php @@ -260,7 +260,7 @@ class CopyFileBackend extends Maintenance { // Note: prepare() is usually fast for key/value backends $status = $dst->prepare( [ 'dir' => dirname( $dstPath ), 'bypassReadOnly' => 1 ] ); if ( !$status->isOK() ) { - $this->error( print_r( Status::wrap( $status )->getWikiText(), true ) ); + $this->error( Status::wrap( $status )->getMessage( false, false, 'en' )->text() ); $this->fatalError( "$domainId: Could not copy $srcPath to $dstPath." ); } $ops[] = [ 'op' => 'store', @@ -277,7 +277,7 @@ class CopyFileBackend extends Maintenance { } $elapsed_ms = floor( ( microtime( true ) - $t_start ) * 1000 ); if ( !$status->isOK() ) { - $this->error( print_r( Status::wrap( $status )->getWikiText(), true ) ); + $this->error( Status::wrap( $status )->getMessage( false, false, 'en' )->text() ); $this->fatalError( "$domainId: Could not copy file batch." ); } elseif ( count( $copiedRel ) ) { $this->output( "\n\tCopied these file(s) [{$elapsed_ms}ms]:\n\t" . @@ -314,7 +314,7 @@ class CopyFileBackend extends Maintenance { } $elapsed_ms = floor( ( microtime( true ) - $t_start ) * 1000 ); if ( !$status->isOK() ) { - $this->error( print_r( Status::wrap( $status )->getWikiText(), true ) ); + $this->error( Status::wrap( $status )->getMessage( false, false, 'en' )->text() ); $this->fatalError( "$domainId: Could not delete file batch." ); } elseif ( count( $deletedRel ) ) { $this->output( "\n\tDeleted these file(s) [{$elapsed_ms}ms]:\n\t" . diff --git a/maintenance/createAndPromote.php b/maintenance/createAndPromote.php index 505168e84b..b92735b1a5 100644 --- a/maintenance/createAndPromote.php +++ b/maintenance/createAndPromote.php @@ -121,7 +121,7 @@ class CreateAndPromote extends Maintenance { false ); if ( !$status->isGood() ) { - $this->fatalError( $status->getWikiText( null, null, 'en' ) ); + $this->fatalError( $status->getMessage( false, false, 'en' )->text() ); } } @@ -134,7 +134,7 @@ class CreateAndPromote extends Maintenance { 'retype' => $password, ] ); if ( !$status->isGood() ) { - throw new PasswordError( $status->getWikiText( null, null, 'en' ) ); + throw new PasswordError( $status->getMessage( false, false, 'en' )->text() ); } if ( $exists ) { $this->output( "Password set.\n" ); diff --git a/maintenance/edit.php b/maintenance/edit.php index 3609cf2249..825e9caf21 100644 --- a/maintenance/edit.php +++ b/maintenance/edit.php @@ -122,7 +122,7 @@ class EditCLI extends Maintenance { $exit = 1; } if ( !$status->isGood() ) { - $this->output( $status->getWikiText( false, false, 'en' ) . "\n" ); + $this->output( $status->getMessage( false, false, 'en' )->text() . "\n" ); } exit( $exit ); } diff --git a/maintenance/findDeprecated.php b/maintenance/findDeprecated.php index d4f9c2d0c7..03035f756a 100644 --- a/maintenance/findDeprecated.php +++ b/maintenance/findDeprecated.php @@ -20,6 +20,7 @@ * * @file * @ingroup Maintenance + * @phan-file-suppress PhanUndeclaredProperty Lots of custom properties */ require_once __DIR__ . '/Maintenance.php'; diff --git a/maintenance/getText.php b/maintenance/getText.php index ca67c833df..3b7ba634b5 100644 --- a/maintenance/getText.php +++ b/maintenance/getText.php @@ -23,7 +23,7 @@ * @ingroup Maintenance */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; require_once __DIR__ . '/Maintenance.php'; diff --git a/maintenance/importDump.php b/maintenance/importDump.php index d5f94ad8ab..6640148a28 100644 --- a/maintenance/importDump.php +++ b/maintenance/importDump.php @@ -326,7 +326,7 @@ TEXT $statusRootPage = $importer->setTargetRootPage( $this->getOption( 'rootpage' ) ); if ( !$statusRootPage->isGood() ) { // Die here so that it doesn't print "Done!" - $this->fatalError( $statusRootPage->getMessage()->text() ); + $this->fatalError( $statusRootPage->getMessage( false, false, 'en' )->text() ); return false; } } diff --git a/maintenance/importImages.php b/maintenance/importImages.php index 954f36d3a2..0c4ff0af50 100644 --- a/maintenance/importImages.php +++ b/maintenance/importImages.php @@ -326,7 +326,7 @@ class ImportImages extends Maintenance { $archive = $image->publish( $file, $flags, $publishOptions ); if ( !$archive->isGood() ) { $this->output( "failed. (" . - $archive->getWikiText( false, false, 'en' ) . + $archive->getMessage( false, false, 'en' )->text() . ")\n" ); $failed++; continue; diff --git a/maintenance/install.php b/maintenance/install.php index 16b8ccf837..20254b0c05 100644 --- a/maintenance/install.php +++ b/maintenance/install.php @@ -118,7 +118,7 @@ class CommandLineInstaller extends Maintenance { try { $installer = InstallerOverrides::getCliInstaller( $siteName, $adminName, $this->mOptions ); } catch ( \MediaWiki\Installer\InstallException $e ) { - $this->output( $e->getStatus()->getMessage()->text() . "\n" ); + $this->output( $e->getStatus()->getMessage( false, false, 'en' )->text() . "\n" ); return false; } diff --git a/maintenance/language/zhtable/simp2trad.manual b/maintenance/language/zhtable/simp2trad.manual index 7a5e93eb76..75767812cb 100644 --- a/maintenance/language/zhtable/simp2trad.manual +++ b/maintenance/language/zhtable/simp2trad.manual @@ -267,7 +267,7 @@ U+2B127𫄧|U+07D96綖| U+2B128𫄨|U+07D7A絺| U+2B137𫄷|U+07E76繶| U+2B138𫄸|U+07E81纁| -U+2B1ED𫇭|U+0853F蔿| +U+2B1ED𫇭|U+0848D蒍|U+0853F蔿| U+2B300𫌀|U+08940襀| U+2B363𫍣|U+08A77è©·| U+2B36F𫍯|U+08AF4è«´| diff --git a/maintenance/language/zhtable/simp2trad_noconvert.manual b/maintenance/language/zhtable/simp2trad_noconvert.manual index 77ad24341c..407f42a737 100644 --- a/maintenance/language/zhtable/simp2trad_noconvert.manual +++ b/maintenance/language/zhtable/simp2trad_noconvert.manual @@ -6,11 +6,11 @@ 疴 æ¡¿ 錶 -蘋 詑 堖 嶴 灡 +蘋 薳 虯 凈 diff --git a/maintenance/language/zhtable/toCN.manual b/maintenance/language/zhtable/toCN.manual index e1016dce11..43c7e61976 100644 --- a/maintenance/language/zhtable/toCN.manual +++ b/maintenance/language/zhtable/toCN.manual @@ -2316,6 +2316,7 @@ 聖吉斯納域斯 圣基茨和尼维斯 聖克里斯多福及尼維斯 圣基茨和尼维斯 聖文森及格瑞那丁 圣文森特和格林纳丁斯 +聖文森國 圣文森特和格林纳丁斯 聖馬利諾 圣马力诺 蓋亞那 圭亚那 坦尚尼亞 坦桑尼亚 @@ -2441,6 +2442,7 @@ 提比里西 第比利斯 巴斯拉 巴士拉 杜拜 迪拜 +喬治亞字母 格鲁吉亚字母 坚杜拜 坚杜拜 堅杜拜 坚杜拜 賽普勒斯 塞浦路斯 @@ -2728,3 +2730,7 @@ A型肝炎 甲型肝炎 普立茲獎 普利策奖 富比士 福布斯 聖多美普林西比 圣多美和普林西比 +札格瑞布 萨格勒布 +溫荷克 温得和克 +普利托利亞 比勒陀利亚 +阿迪斯阿貝巴 亚的斯亚贝巴 \ No newline at end of file diff --git a/maintenance/language/zhtable/toHK.manual b/maintenance/language/zhtable/toHK.manual index 915050b82e..1eaa387951 100644 --- a/maintenance/language/zhtable/toHK.manual +++ b/maintenance/language/zhtable/toHK.manual @@ -616,6 +616,7 @@ 镇里 鎮裏 》里 》裏 空里 空裏 +牢里 牢裏 版本里 版本裏 苑裡 苑裡 霄裡 霄裡 @@ -2662,6 +2663,9 @@ 軟體動物 軟體動物 軟體家具 軟體家具 網路 網絡 +全角 全形 +全角度 全角度 +全角色 全角色 人工智慧 人工智能 航天飞机 穿梭機 太空梭 穿梭機 @@ -2710,6 +2714,7 @@ 圣基茨和尼维斯 聖吉斯納域斯 聖克里斯多福及尼維斯 聖吉斯納域斯 聖文森及格瑞那丁 聖文森特和格林納丁斯 +聖文森國 聖文森特和格林納丁斯 聖馬利諾 聖馬力諾 蓋亞那 圭亞那 坦尚尼亞 坦桑尼亞 @@ -2801,7 +2806,7 @@ 西臺人 赫梯人 阿联酋 阿聯酋 迪拜 杜拜 -格鲁吉亚 格魯吉亞 +喬治亞字母 格魯吉亞字母 提比里西 第比利斯 諾鲁 瑙魯 玻里尼西亞 波利尼西亞 @@ -3092,3 +3097,7 @@ IP地址 IP位址 普利策奖 普立茲獎 聖多美普林西比 聖多美和普林西比 塔希提 大溪地 +札格瑞布 薩格勒布 +溫荷克 溫得和克 +普利托利亞 比勒陀利亞 +阿迪斯阿貝巴 亞的斯亞貝巴 \ No newline at end of file diff --git a/maintenance/language/zhtable/toSimp.manual b/maintenance/language/zhtable/toSimp.manual index 6329133c90..45fef1dacd 100644 --- a/maintenance/language/zhtable/toSimp.manual +++ b/maintenance/language/zhtable/toSimp.manual @@ -252,6 +252,7 @@ 高陞 高升 晉陞 晋升 歷陞 历升 +尋陞 寻升 官陞 官升 榮陞 荣升 又陞 又升 diff --git a/maintenance/language/zhtable/toTW.manual b/maintenance/language/zhtable/toTW.manual index 6b5ecdd719..39fd1f3a60 100644 --- a/maintenance/language/zhtable/toTW.manual +++ b/maintenance/language/zhtable/toTW.manual @@ -229,6 +229,9 @@ 三極管 三極體 软件 軟體 軟件 軟體 +全角 全形 +全角度 全角度 +全角色 全角色 人工智能 人工智慧 航天飞机 太空梭 穿梭機 太空梭 @@ -315,6 +318,7 @@ 布隆迪 蒲隆地 帕劳 帛琉 意大利 義大利 +意大利面 義大利麵 所罗门群岛 索羅門群島 所羅門群島 索羅門群島 文莱 汶萊 @@ -808,6 +812,7 @@ IP地址 IP位址 残奥会 帕運會 殘奧會 帕運會 残疾人奥林匹克 帕拉林匹克 +殘疾人奧林匹克 帕拉林匹克 不列颠哥伦比亚省 卑詩省 登巴萨 丹帕沙 登巴薩 丹帕沙 @@ -824,6 +829,12 @@ IP地址 IP位址 格林納丁斯 格瑞那丁 空中客车 空中巴士 普利策奖 普立茲獎 -圣多美和普林西比 聖多美普林西比 -聖多美和普林西比 聖多美普林西比 +多美和普林西比 多美普林西比 #聖多美普林西比 塔希提 大溪地 +萨格勒布 札格瑞布 +薩格勒布 札格瑞布 +温得和克 溫荷克 +溫得和克 溫荷克 +比勒陀利 普利托利 #普利托利亚 +亚的斯亚贝巴 阿迪斯阿貝巴 +亞的斯亞貝巴 阿迪斯阿貝巴 diff --git a/maintenance/language/zhtable/toTrad.manual b/maintenance/language/zhtable/toTrad.manual index 78b5a7384f..8bd266534b 100644 --- a/maintenance/language/zhtable/toTrad.manual +++ b/maintenance/language/zhtable/toTrad.manual @@ -6,6 +6,7 @@ ’m ’m ’t ’t ’re ’re +𬞟 蘋 手塚治虫 手塚治虫 寇仇 寇讎 往日无仇 往日無讎 @@ -78,6 +79,7 @@ 乾象曆 乾象曆 乾象历 乾象曆 不好干預 不好干預 +可能干預 可能干預 范文瀾 范文瀾 機械系 機械系 頂多 頂多 @@ -97,6 +99,7 @@ 于帥 于帥 于濤 于濤 于贈 于贈 +于闐 于闐 于會泳 于會泳 于偉國 于偉國 于光遠 于光遠 @@ -107,6 +110,7 @@ 于學忠 于學忠 于小偉 于小偉 于山國 于山國 +于山島 于山島 于幼軍 于幼軍 于廣洲 于廣洲 于從濂 于從濂 @@ -579,3 +583,4 @@ 更钟情 更鍾情 更钟爱 更鍾愛 更钟意 更鍾意 +温嵐 温嵐 diff --git a/maintenance/language/zhtable/trad2simp.manual b/maintenance/language/zhtable/trad2simp.manual index 74064bbe52..5c30eb8f90 100644 --- a/maintenance/language/zhtable/trad2simp.manual +++ b/maintenance/language/zhtable/trad2simp.manual @@ -586,6 +586,7 @@ U+08432萲|U+08431萱| U+08457著|U+08457著|U+07740着| U+08460葠|U+053C2参| U+0846F葯|U+0836F药| +U+0848D蒍|U+2B1ED𫇭| U+08493蒓|U+083BC莼| U+084C6蓆|U+05E2D席| U+084E1蓡|U+053C2参| diff --git a/maintenance/language/zhtable/tradphrases.manual b/maintenance/language/zhtable/tradphrases.manual index 2cf35ba6ee..522ae311ea 100644 --- a/maintenance/language/zhtable/tradphrases.manual +++ b/maintenance/language/zhtable/tradphrases.manual @@ -369,6 +369,7 @@ 併為一家 併吞 並吞下 +入侵並 #分詞用 提摩太後書 裏海 不採 @@ -811,6 +812,7 @@ 捲葉蛾 捲尾猴 捲積雲 +被捲回 夸父 夸克 夸特 @@ -988,6 +990,7 @@ 伊府麵 藥麵兒 意大利麵 +意大利面臨 湯下麵 茶麵 麵團 @@ -1210,6 +1213,7 @@ 鹹豬 甜鹹 鹹甜 +鹹吃 甜、鹹 鹹、甜 錦綉花園 @@ -1408,6 +1412,7 @@ 幹仗 包幹 幹過 +大幹一 李連杰 周杰 杰倫 @@ -2281,6 +2286,7 @@ 不占算 不好干涉 不好干預 +可能干預 不斗膽 不每只 不采聲 @@ -2972,6 +2978,7 @@ 詞裡 》裡 空裡 +牢裡 版本裡 裏白 #植物常用名 烏蘇里 #分詞用 @@ -3020,9 +3027,11 @@ 于衡 于贈 于越 +於越南 于靖 于勒 于格 +於格林 鳳凰于飛 于仁泰 于會泳 @@ -3046,6 +3055,7 @@ 于小偉 于小彤 于山國 +于山島 于幼軍 于廣洲 于康震 @@ -3737,3 +3747,4 @@ 關系科 銹病 嚐糞 +温嵐 diff --git a/maintenance/language/zhtable/tradphrases_exclude.manual b/maintenance/language/zhtable/tradphrases_exclude.manual index 5c153b8da0..1524e5f1f7 100644 --- a/maintenance/language/zhtable/tradphrases_exclude.manual +++ b/maintenance/language/zhtable/tradphrases_exclude.manual @@ -794,3 +794,6 @@ 換籤 后座 託兒 +大幹 +穀人 +于思 diff --git a/maintenance/mediawiki.Title/generatePhpCharToUpperMappings.php b/maintenance/mediawiki.Title/generatePhpCharToUpperMappings.php index 5dd9432862..9fc5513e37 100755 --- a/maintenance/mediawiki.Title/generatePhpCharToUpperMappings.php +++ b/maintenance/mediawiki.Title/generatePhpCharToUpperMappings.php @@ -67,7 +67,13 @@ class GeneratePhpCharToUpperMappings extends Maintenance { $phpUpper = $wgContLang->ucfirst( $char ); $jsUpper = $jsUpperChars[$i]; if ( $jsUpper !== $phpUpper ) { - $data[$char] = $phpUpper; + if ( $char === $phpUpper ) { + // Optimisation: Use the empty string to signal "leave character unchanged". + // Reduces the transfer size by ~50%. Reduces browser memory cost as well. + $data[$char] = ''; + } else { + $data[$char] = $phpUpper; + } } } @@ -76,6 +82,9 @@ class GeneratePhpCharToUpperMappings extends Maintenance { ) . "\n"; $outputPath = '/resources/src/mediawiki.Title/phpCharToUpper.json'; $file = fopen( $IP . $outputPath, 'w' ); + if ( !$file ) { + $this->fatalError( "Unable to write file \"$IP$outputPath\"" ); + } fwrite( $file, $mappingJson ); $this->output( count( $data ) . " differences found.\n" ); diff --git a/maintenance/moveBatch.php b/maintenance/moveBatch.php index 09f3120a97..b54ed4566b 100644 --- a/maintenance/moveBatch.php +++ b/maintenance/moveBatch.php @@ -111,7 +111,7 @@ class MoveBatch extends Maintenance { ->newMovePage( $source, $dest ); $status = $mp->move( $wgUser, $reason, !$noredirects ); if ( !$status->isOK() ) { - $this->output( "\nFAILED: " . $status->getWikiText( false, false, 'en' ) ); + $this->output( "\nFAILED: " . $status->getMessage( false, false, 'en' )->text() ); } $this->commitTransaction( $dbw, __METHOD__ ); $this->output( "\n" ); diff --git a/maintenance/mwdocgen.php b/maintenance/mwdocgen.php index f600f13869..6b22097d2e 100644 --- a/maintenance/mwdocgen.php +++ b/maintenance/mwdocgen.php @@ -83,8 +83,10 @@ class MWDocGen extends Maintenance { $this->addOption( 'output', 'Path to write doc to', false, true ); - $this->addOption( 'no-extensions', - 'Ignore extensions' ); + $this->addOption( 'extensions', + 'Process the extensions/ directory as well (ignored if --file is used)' ); + $this->addOption( 'skins', + 'Process the skins/ directory as well (ignored if --file is used)' ); } public function getDbType() { @@ -115,15 +117,23 @@ class MWDocGen extends Maintenance { $this->template = $IP . '/maintenance/Doxyfile'; $this->excludes = [ - 'vendor', - 'node_modules', - 'resources/lib', 'images', + 'node_modules', + 'resources', 'static', + 'tests', + 'vendor', ]; $this->excludePatterns = []; - if ( $this->hasOption( 'no-extensions' ) ) { - $this->excludePatterns[] = 'extensions'; + if ( $this->input === '' ) { + // If no explicit --file filter is set, we're indexing all of $IP, + // but any extension or skin submodules should be excluded by default. + if ( !$this->hasOption( 'extensions' ) ) { + $this->excludePatterns[] = 'extensions'; + } + if ( !$this->hasOption( 'skins' ) ) { + $this->excludePatterns[] = 'skins'; + } } $this->doDot = shell_exec( 'which dot' ); diff --git a/maintenance/populateRevisionLength.php b/maintenance/populateRevisionLength.php index e48b6ab0a7..1e73540f42 100644 --- a/maintenance/populateRevisionLength.php +++ b/maintenance/populateRevisionLength.php @@ -21,7 +21,7 @@ * @ingroup Maintenance */ -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; use Wikimedia\Rdbms\IDatabase; require_once __DIR__ . '/Maintenance.php'; diff --git a/maintenance/preprocessDump.php b/maintenance/preprocessDump.php index fddac8a0e4..ec759dae33 100644 --- a/maintenance/preprocessDump.php +++ b/maintenance/preprocessDump.php @@ -26,7 +26,7 @@ */ use MediaWiki\MediaWikiServices; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; require_once __DIR__ . '/dumpIterator.php'; diff --git a/maintenance/purgeList.php b/maintenance/purgeList.php index d558c478e8..540d2750ec 100644 --- a/maintenance/purgeList.php +++ b/maintenance/purgeList.php @@ -65,9 +65,14 @@ class PurgeList extends Maintenance { } elseif ( $page !== '' ) { $title = Title::newFromText( $page ); if ( $title ) { - $url = $title->getInternalURL(); - $this->output( "$url\n" ); - $urls[] = $url; + $newUrls = $title->getCdnUrls(); + + foreach ( $newUrls as $url ) { + $this->output( "$url\n" ); + } + + $urls = array_merge( $urls, $newUrls ); + if ( $this->getOption( 'purge' ) ) { $title->invalidateCache(); } @@ -110,8 +115,7 @@ class PurgeList extends Maintenance { $urls = []; foreach ( $res as $row ) { $title = Title::makeTitle( $row->page_namespace, $row->page_title ); - $url = $title->getInternalURL(); - $urls[] = $url; + $urls = array_merge( $urls, $title->getCdnUrls() ); $startId = $row->page_id; } $this->sendPurgeRequest( $urls ); diff --git a/maintenance/refreshFileHeaders.php b/maintenance/refreshFileHeaders.php index db8a19a115..264ba57a29 100644 --- a/maintenance/refreshFileHeaders.php +++ b/maintenance/refreshFileHeaders.php @@ -143,6 +143,10 @@ class RefreshFileHeaders extends Maintenance { $this->output( "Done. Updated headers for $count file(s).\n" ); } + /** + * @param LocalRepo $repo + * @param array $backendOperations + */ protected function updateFileHeaders( $repo, $backendOperations ) { $status = $repo->getBackend()->doQuickOperations( $backendOperations ); diff --git a/maintenance/refreshLinks.php b/maintenance/refreshLinks.php index 3f48abbb8e..c1170fc026 100644 --- a/maintenance/refreshLinks.php +++ b/maintenance/refreshLinks.php @@ -22,7 +22,7 @@ */ use MediaWiki\MediaWikiServices; -use MediaWiki\Storage\RevisionRecord; +use MediaWiki\Revision\RevisionRecord; use Wikimedia\Rdbms\IDatabase; require_once __DIR__ . '/Maintenance.php'; diff --git a/maintenance/userDupes.inc b/maintenance/userDupes.inc index 038ef23928..5f7f9d5e43 100644 --- a/maintenance/userDupes.inc +++ b/maintenance/userDupes.inc @@ -36,7 +36,7 @@ use Wikimedia\Rdbms\IMaintainableDatabase; */ class UserDupes { /** - * @var Database + * @var IMaintainableDatabase */ private $db; private $reassigned; diff --git a/mw-config/config.css b/mw-config/config.css index 6084c84a93..72fe286a21 100644 --- a/mw-config/config.css +++ b/mw-config/config.css @@ -142,10 +142,6 @@ color: #008000; } -.success-box { - font-size: 130%; -} - .config-cc-wrapper { clear: left; /* If you change this height, also change it in WebInstallerOptions::submitCC() */ diff --git a/resources/Resources.php b/resources/Resources.php index 1388128fc0..c8eae03120 100644 --- a/resources/Resources.php +++ b/resources/Resources.php @@ -155,17 +155,6 @@ return [ /* jQuery Plugins */ - 'jquery.accessKeyLabel' => [ - 'deprecated' => 'Please use "mediawiki.util" instead.', - 'dependencies' => [ - 'mediawiki.util', - ], - 'targets' => [ 'mobile', 'desktop' ], - ], - 'jquery.checkboxShiftClick' => [ - 'scripts' => 'resources/src/jquery/jquery.checkboxShiftClick.js', - 'targets' => [ 'desktop', 'mobile' ], - ], 'jquery.chosen' => [ 'scripts' => 'resources/lib/jquery.chosen/chosen.jquery.js', 'styles' => 'resources/lib/jquery.chosen/chosen.css', @@ -175,11 +164,10 @@ return [ 'targets' => [ 'desktop', 'mobile' ], ], 'jquery.color' => [ - 'scripts' => 'resources/src/jquery/jquery.color.js', - 'dependencies' => 'jquery.colorUtil', - ], - 'jquery.colorUtil' => [ - 'scripts' => 'resources/src/jquery/jquery.colorUtil.js', + 'scripts' => [ + 'resources/src/jquery.color/jquery.colorUtil.js', + 'resources/src/jquery.color/jquery.color.js', + ], ], 'jquery.confirmable' => [ 'scripts' => [ @@ -895,6 +883,7 @@ return [ 'dependencies' => [ 'mediawiki.api', 'oojs', + 'mediawiki.Uri', ], 'targets' => [ 'desktop', 'mobile' ], ], @@ -940,6 +929,9 @@ return [ 'scripts' => [ 'resources/src/mediawiki.htmlform.checker.js', ], + 'dependencies' => [ + 'mediawiki.util', + ], 'targets' => [ 'desktop', 'mobile' ], ], 'mediawiki.htmlform.ooui' => [ @@ -1252,8 +1244,8 @@ return [ ] ], 'mediawiki.util' => [ - 'localBasePath' => "$IP/resources/src/mediawiki.util/", - 'remoteBasePath' => "$wgResourceBasePath/resources/src/mediawiki.util/", + 'localBasePath' => "$IP/resources/src/mediawiki.util", + 'remoteBasePath' => "$wgResourceBasePath/resources/src/mediawiki.util", 'packageFiles' => [ 'util.js', 'jquery.accessKeyLabel.js', @@ -1660,9 +1652,13 @@ return [ ] ], 'mediawiki.page.ready' => [ - 'scripts' => 'resources/src/mediawiki.page.ready.js', + 'localBasePath' => "$IP/resources/src/mediawiki.page.ready", + 'remoteBasePath' => "$wgResourceBasePath/resources/src/mediawiki.page.ready", + 'packageFiles' => [ + 'ready.js', + 'checkboxShift.js', + ], 'dependencies' => [ - 'jquery.checkboxShiftClick', 'mediawiki.util', 'mediawiki.notify', 'mediawiki.api' @@ -1995,6 +1991,7 @@ return [ 'resources/src/mediawiki.special/userrights.css', 'resources/src/mediawiki.special/watchlist.css', 'resources/src/mediawiki.special/block.less', + 'resources/src/mediawiki.special/listFiles.less', 'resources/src/mediawiki.special/blocklist.less', ], 'targets' => [ 'desktop', 'mobile' ], @@ -2313,7 +2310,6 @@ return [ 'dependencies' => [ 'mediawiki.api', 'mediawiki.jqueryMsg', - 'jquery.throttle-debounce', 'mediawiki.htmlform.checker', ], ], diff --git a/resources/lib/foreign-resources.yaml b/resources/lib/foreign-resources.yaml index 9ab1b496ab..5db52a419d 100644 --- a/resources/lib/foreign-resources.yaml +++ b/resources/lib/foreign-resources.yaml @@ -253,8 +253,8 @@ oojs-router: ooui: type: tar - src: https://registry.npmjs.org/oojs-ui/-/oojs-ui-0.34.0.tgz - integrity: sha384-DVG3XayKF02r0rqXSJUEWJImcK8XJeiIVC/Ii5R20cINYpTaAs+x4rdCU52VaKKw + src: https://registry.npmjs.org/oojs-ui/-/oojs-ui-0.34.1.tgz + integrity: sha384-QXYp5vK60xpu4nkv/JStszI6U4TYGCNe7uXb5rYb7FYURLTR41mtNO74gl7HXgpz dest: # Main stuff diff --git a/resources/lib/ooui/History.md b/resources/lib/ooui/History.md index 9408e9bc4e..501b7688ec 100644 --- a/resources/lib/ooui/History.md +++ b/resources/lib/ooui/History.md @@ -1,4 +1,16 @@ # OOUI Release History +## v0.34.1 / 2019-09-10 +### Deprecating changes +* [DEPRECATING CHANGE] icons: Rename 'beaker' to 'labFlask' (Volker E.) + +### Styles +* icons: Add 'userGroup' (Volker E.) + +### Code +* Wrap long strings in popups (Sam Wilson) +* demos: Add missing file to PHP demo to fix infusion (Bartosz Dziewoński) + + ## v0.34.0 / 2019-09-04 ### Breaking changes * [BREAKING CHANGE] Use OOjs v3.0.0, up from v2.2.2 (James D. Forrester) diff --git a/resources/lib/ooui/i18n/fr.json b/resources/lib/ooui/i18n/fr.json index 6bfe4d6228..8595f6173d 100644 --- a/resources/lib/ooui/i18n/fr.json +++ b/resources/lib/ooui/i18n/fr.json @@ -42,11 +42,11 @@ "ooui-item-remove": "Supprimer", "ooui-dialog-message-accept": "OK", "ooui-dialog-message-reject": "Annuler", - "ooui-dialog-process-error": "Quelque chose s'est mal passé", + "ooui-dialog-process-error": "Quelque chose s’est mal passé", "ooui-dialog-process-dismiss": "Fermer", "ooui-dialog-process-retry": "Réessayer", "ooui-dialog-process-continue": "Continuer", - "ooui-combobox-button-label": "Liste déroulante de combobox", + "ooui-combobox-button-label": "Liste déroulante pour boîte de saisie", "ooui-selectfile-button-select": "Sélectionner un fichier", "ooui-selectfile-not-supported": "La sélection de fichier n’est pas prise en charge", "ooui-selectfile-placeholder": "Aucun fichier sélectionné", diff --git a/resources/lib/ooui/i18n/pl.json b/resources/lib/ooui/i18n/pl.json index affc066a66..d13cb451ae 100644 --- a/resources/lib/ooui/i18n/pl.json +++ b/resources/lib/ooui/i18n/pl.json @@ -18,7 +18,8 @@ "Gloria sah", "Andrzej aa", "The Polish", - "Railfail536" + "Railfail536", + "Rail" ] }, "ooui-outline-control-move-down": "Przesuń w dół", diff --git a/resources/lib/ooui/oojs-ui-apex.js b/resources/lib/ooui/oojs-ui-apex.js index d48a492eed..667f11e5a0 100644 --- a/resources/lib/ooui/oojs-ui-apex.js +++ b/resources/lib/ooui/oojs-ui-apex.js @@ -1,12 +1,12 @@ /*! - * OOUI v0.34.0-pre (d5e74518ab) + * OOUI v0.34.1-pre (3913589098) * https://www.mediawiki.org/wiki/OOUI * * Copyright 2011–2019 OOUI Team and other contributors. * Released under the MIT license * http://oojs.mit-license.org * - * Date: 2019-09-04T18:28:52Z + * Date: 2019-09-10T23:46:03Z */ ( function ( OO ) { diff --git a/resources/lib/ooui/oojs-ui-core-apex.css b/resources/lib/ooui/oojs-ui-core-apex.css index bb5819025f..e06ece006a 100644 --- a/resources/lib/ooui/oojs-ui-core-apex.css +++ b/resources/lib/ooui/oojs-ui-core-apex.css @@ -1,12 +1,12 @@ /*! - * OOUI v0.34.0-pre (d5e74518ab) + * OOUI v0.34.1-pre (3913589098) * https://www.mediawiki.org/wiki/OOUI * * Copyright 2011–2019 OOUI Team and other contributors. * Released under the MIT license * http://oojs.mit-license.org * - * Date: 2019-09-04T18:28:59Z + * Date: 2019-09-10T23:46:11Z */ .oo-ui-element-hidden { display: none !important; @@ -917,6 +917,8 @@ body:not( :-moz-handler-blocked ) .oo-ui-fieldsetLayout { .oo-ui-popupWidget-popup { position: relative; overflow: hidden; + word-wrap: break-word; + overflow-wrap: break-word; } .oo-ui-popupWidget-anchor { display: none; diff --git a/resources/lib/ooui/oojs-ui-core-wikimediaui.css b/resources/lib/ooui/oojs-ui-core-wikimediaui.css index cfbf7d6134..d4eaea52e5 100644 --- a/resources/lib/ooui/oojs-ui-core-wikimediaui.css +++ b/resources/lib/ooui/oojs-ui-core-wikimediaui.css @@ -1,12 +1,12 @@ /*! - * OOUI v0.34.0-pre (d5e74518ab) + * OOUI v0.34.1-pre (3913589098) * https://www.mediawiki.org/wiki/OOUI * * Copyright 2011–2019 OOUI Team and other contributors. * Released under the MIT license * http://oojs.mit-license.org * - * Date: 2019-09-04T18:28:59Z + * Date: 2019-09-10T23:46:11Z */ .oo-ui-element-hidden { display: none !important; @@ -1059,6 +1059,8 @@ body:not( :-moz-handler-blocked ) .oo-ui-fieldsetLayout { .oo-ui-popupWidget-popup { position: relative; overflow: hidden; + word-wrap: break-word; + overflow-wrap: break-word; } .oo-ui-popupWidget-anchor { display: none; diff --git a/resources/lib/ooui/oojs-ui-core.js b/resources/lib/ooui/oojs-ui-core.js index 11e132ea12..9754fb8b93 100644 --- a/resources/lib/ooui/oojs-ui-core.js +++ b/resources/lib/ooui/oojs-ui-core.js @@ -1,12 +1,12 @@ /*! - * OOUI v0.34.0-pre (d5e74518ab) + * OOUI v0.34.1-pre (3913589098) * https://www.mediawiki.org/wiki/OOUI * * Copyright 2011–2019 OOUI Team and other contributors. * Released under the MIT license * http://oojs.mit-license.org * - * Date: 2019-09-04T18:28:52Z + * Date: 2019-09-10T23:46:03Z */ ( function ( OO ) { diff --git a/resources/lib/ooui/oojs-ui-toolbars-apex.css b/resources/lib/ooui/oojs-ui-toolbars-apex.css index fda6a81e21..768d107a36 100644 --- a/resources/lib/ooui/oojs-ui-toolbars-apex.css +++ b/resources/lib/ooui/oojs-ui-toolbars-apex.css @@ -1,12 +1,12 @@ /*! - * OOUI v0.34.0-pre (d5e74518ab) + * OOUI v0.34.1-pre (3913589098) * https://www.mediawiki.org/wiki/OOUI * * Copyright 2011–2019 OOUI Team and other contributors. * Released under the MIT license * http://oojs.mit-license.org * - * Date: 2019-09-04T18:28:59Z + * Date: 2019-09-10T23:46:11Z */ .oo-ui-tool > .oo-ui-tool-link > .oo-ui-tool-checkIcon { display: none; diff --git a/resources/lib/ooui/oojs-ui-toolbars-wikimediaui.css b/resources/lib/ooui/oojs-ui-toolbars-wikimediaui.css index c0119427ea..5e8b9c9893 100644 --- a/resources/lib/ooui/oojs-ui-toolbars-wikimediaui.css +++ b/resources/lib/ooui/oojs-ui-toolbars-wikimediaui.css @@ -1,12 +1,12 @@ /*! - * OOUI v0.34.0-pre (d5e74518ab) + * OOUI v0.34.1-pre (3913589098) * https://www.mediawiki.org/wiki/OOUI * * Copyright 2011–2019 OOUI Team and other contributors. * Released under the MIT license * http://oojs.mit-license.org * - * Date: 2019-09-04T18:28:59Z + * Date: 2019-09-10T23:46:11Z */ .oo-ui-tool { -webkit-box-sizing: border-box; diff --git a/resources/lib/ooui/oojs-ui-toolbars.js b/resources/lib/ooui/oojs-ui-toolbars.js index 000b9eb73e..e8a571e27a 100644 --- a/resources/lib/ooui/oojs-ui-toolbars.js +++ b/resources/lib/ooui/oojs-ui-toolbars.js @@ -1,12 +1,12 @@ /*! - * OOUI v0.34.0-pre (d5e74518ab) + * OOUI v0.34.1-pre (3913589098) * https://www.mediawiki.org/wiki/OOUI * * Copyright 2011–2019 OOUI Team and other contributors. * Released under the MIT license * http://oojs.mit-license.org * - * Date: 2019-09-04T18:28:52Z + * Date: 2019-09-10T23:46:03Z */ ( function ( OO ) { diff --git a/resources/lib/ooui/oojs-ui-widgets-apex.css b/resources/lib/ooui/oojs-ui-widgets-apex.css index 854d8e36be..f94e98b1a1 100644 --- a/resources/lib/ooui/oojs-ui-widgets-apex.css +++ b/resources/lib/ooui/oojs-ui-widgets-apex.css @@ -1,12 +1,12 @@ /*! - * OOUI v0.34.0-pre (d5e74518ab) + * OOUI v0.34.1-pre (3913589098) * https://www.mediawiki.org/wiki/OOUI * * Copyright 2011–2019 OOUI Team and other contributors. * Released under the MIT license * http://oojs.mit-license.org * - * Date: 2019-09-04T18:28:59Z + * Date: 2019-09-10T23:46:11Z */ .oo-ui-draggableElement-handle:not( .oo-ui-draggableElement-undraggable ).oo-ui-widget { cursor: move; diff --git a/resources/lib/ooui/oojs-ui-widgets-wikimediaui.css b/resources/lib/ooui/oojs-ui-widgets-wikimediaui.css index 73da6f8383..8bc82a87e9 100644 --- a/resources/lib/ooui/oojs-ui-widgets-wikimediaui.css +++ b/resources/lib/ooui/oojs-ui-widgets-wikimediaui.css @@ -1,12 +1,12 @@ /*! - * OOUI v0.34.0-pre (d5e74518ab) + * OOUI v0.34.1-pre (3913589098) * https://www.mediawiki.org/wiki/OOUI * * Copyright 2011–2019 OOUI Team and other contributors. * Released under the MIT license * http://oojs.mit-license.org * - * Date: 2019-09-04T18:28:59Z + * Date: 2019-09-10T23:46:11Z */ .oo-ui-draggableElement-handle:not( .oo-ui-draggableElement-undraggable ).oo-ui-widget { cursor: move; diff --git a/resources/lib/ooui/oojs-ui-widgets.js b/resources/lib/ooui/oojs-ui-widgets.js index bdf0d2f24f..7afac69be9 100644 --- a/resources/lib/ooui/oojs-ui-widgets.js +++ b/resources/lib/ooui/oojs-ui-widgets.js @@ -1,12 +1,12 @@ /*! - * OOUI v0.34.0-pre (d5e74518ab) + * OOUI v0.34.1-pre (3913589098) * https://www.mediawiki.org/wiki/OOUI * * Copyright 2011–2019 OOUI Team and other contributors. * Released under the MIT license * http://oojs.mit-license.org * - * Date: 2019-09-04T18:28:52Z + * Date: 2019-09-10T23:46:03Z */ ( function ( OO ) { diff --git a/resources/lib/ooui/oojs-ui-wikimediaui.js b/resources/lib/ooui/oojs-ui-wikimediaui.js index 75f1acdfd4..5355835d1f 100644 --- a/resources/lib/ooui/oojs-ui-wikimediaui.js +++ b/resources/lib/ooui/oojs-ui-wikimediaui.js @@ -1,12 +1,12 @@ /*! - * OOUI v0.34.0-pre (d5e74518ab) + * OOUI v0.34.1-pre (3913589098) * https://www.mediawiki.org/wiki/OOUI * * Copyright 2011–2019 OOUI Team and other contributors. * Released under the MIT license * http://oojs.mit-license.org * - * Date: 2019-09-04T18:28:52Z + * Date: 2019-09-10T23:46:03Z */ ( function ( OO ) { diff --git a/resources/lib/ooui/oojs-ui-windows-apex.css b/resources/lib/ooui/oojs-ui-windows-apex.css index 8ac442f48c..5a11914b7c 100644 --- a/resources/lib/ooui/oojs-ui-windows-apex.css +++ b/resources/lib/ooui/oojs-ui-windows-apex.css @@ -1,12 +1,12 @@ /*! - * OOUI v0.34.0-pre (d5e74518ab) + * OOUI v0.34.1-pre (3913589098) * https://www.mediawiki.org/wiki/OOUI * * Copyright 2011–2019 OOUI Team and other contributors. * Released under the MIT license * http://oojs.mit-license.org * - * Date: 2019-09-04T18:28:59Z + * Date: 2019-09-10T23:46:11Z */ .oo-ui-window { diff --git a/resources/lib/ooui/oojs-ui-windows-wikimediaui.css b/resources/lib/ooui/oojs-ui-windows-wikimediaui.css index e406188090..b1a067bce6 100644 --- a/resources/lib/ooui/oojs-ui-windows-wikimediaui.css +++ b/resources/lib/ooui/oojs-ui-windows-wikimediaui.css @@ -1,12 +1,12 @@ /*! - * OOUI v0.34.0-pre (d5e74518ab) + * OOUI v0.34.1-pre (3913589098) * https://www.mediawiki.org/wiki/OOUI * * Copyright 2011–2019 OOUI Team and other contributors. * Released under the MIT license * http://oojs.mit-license.org * - * Date: 2019-09-04T18:28:59Z + * Date: 2019-09-10T23:46:11Z */ .oo-ui-window { diff --git a/resources/lib/ooui/oojs-ui-windows.js b/resources/lib/ooui/oojs-ui-windows.js index 8885525f1f..d8db8d1a34 100644 --- a/resources/lib/ooui/oojs-ui-windows.js +++ b/resources/lib/ooui/oojs-ui-windows.js @@ -1,12 +1,12 @@ /*! - * OOUI v0.34.0-pre (d5e74518ab) + * OOUI v0.34.1-pre (3913589098) * https://www.mediawiki.org/wiki/OOUI * * Copyright 2011–2019 OOUI Team and other contributors. * Released under the MIT license * http://oojs.mit-license.org * - * Date: 2019-09-04T18:28:52Z + * Date: 2019-09-10T23:46:03Z */ ( function ( OO ) { diff --git a/resources/lib/ooui/themes/apex/icons-editing-advanced.json b/resources/lib/ooui/themes/apex/icons-editing-advanced.json index 732d70ffbc..516dc08d57 100644 --- a/resources/lib/ooui/themes/apex/icons-editing-advanced.json +++ b/resources/lib/ooui/themes/apex/icons-editing-advanced.json @@ -15,7 +15,8 @@ "file": "../wikimediaui/images/icons/attachment.svg" }, "beaker": { - "file": "../wikimediaui/images/icons/beaker.svg" + "file": "../wikimediaui/images/icons/labFlask.svg", + "deprecated": "Renamed since v0.34.1, use 'labFlask' instead." }, "calendar": { "file": "../wikimediaui/images/icons/calendar.svg" @@ -38,6 +39,9 @@ "imageLayoutThumbnail": { "file": "../wikimediaui/images/icons/imageLayoutThumbnail.svg" }, + "labFlask": { + "file": "../wikimediaui/images/icons/labFlask.svg" + }, "language": { "file": "../wikimediaui/images/icons/language.svg" }, diff --git a/resources/lib/ooui/themes/apex/icons-user.json b/resources/lib/ooui/themes/apex/icons-user.json index e13bb1db62..de7a1183db 100644 --- a/resources/lib/ooui/themes/apex/icons-user.json +++ b/resources/lib/ooui/themes/apex/icons-user.json @@ -11,6 +11,12 @@ "userAvatarOutline": { "file": "../wikimediaui/images/icons/userAvatarOutline.svg" }, + "userGroup": { + "file": { + "ltr": "../wikimediaui/images/icons/userGroup-ltr.svg", + "rtl": "../wikimediaui/images/icons/userGroup-rtl.svg" + } + }, "userTalk": { "file": { "ltr": "../wikimediaui/images/icons/userTalk-ltr.svg", diff --git a/resources/lib/ooui/themes/wikimediaui/icons-editing-advanced.json b/resources/lib/ooui/themes/wikimediaui/icons-editing-advanced.json index 4f4fd4e062..23dd607da9 100644 --- a/resources/lib/ooui/themes/wikimediaui/icons-editing-advanced.json +++ b/resources/lib/ooui/themes/wikimediaui/icons-editing-advanced.json @@ -38,7 +38,8 @@ "file": "images/icons/attachment.svg" }, "beaker": { - "file": "images/icons/beaker.svg" + "file": "images/icons/labFlask.svg", + "deprecated": "Renamed since v0.34.1, use 'labFlask' instead." }, "calendar": { "file": "images/icons/calendar.svg" @@ -61,6 +62,9 @@ "imageLayoutThumbnail": { "file": "images/icons/imageLayoutThumbnail.svg" }, + "labFlask": { + "file": "images/icons/labFlask.svg" + }, "language": { "file": "images/icons/language.svg" }, diff --git a/resources/lib/ooui/themes/wikimediaui/icons-user.json b/resources/lib/ooui/themes/wikimediaui/icons-user.json index 7266d3426f..5a382ce75a 100644 --- a/resources/lib/ooui/themes/wikimediaui/icons-user.json +++ b/resources/lib/ooui/themes/wikimediaui/icons-user.json @@ -34,6 +34,12 @@ "userAvatarOutline": { "file": "images/icons/userAvatarOutline.svg" }, + "userGroup": { + "file": { + "ltr": "images/icons/userGroup-ltr.svg", + "rtl": "images/icons/userGroup-rtl.svg" + } + }, "userTalk": { "file": { "ltr": "images/icons/userTalk-ltr.svg", diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/beaker-invert.png b/resources/lib/ooui/themes/wikimediaui/images/icons/beaker-invert.png deleted file mode 100644 index 89d2d3db79..0000000000 Binary files a/resources/lib/ooui/themes/wikimediaui/images/icons/beaker-invert.png and /dev/null differ diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/beaker-invert.svg b/resources/lib/ooui/themes/wikimediaui/images/icons/beaker-invert.svg deleted file mode 100644 index c031dafabd..0000000000 --- a/resources/lib/ooui/themes/wikimediaui/images/icons/beaker-invert.svg +++ /dev/null @@ -1,7 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 20 20"> - <title> - beaker - - - diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/beaker-progressive.png b/resources/lib/ooui/themes/wikimediaui/images/icons/beaker-progressive.png deleted file mode 100644 index 78736aca78..0000000000 Binary files a/resources/lib/ooui/themes/wikimediaui/images/icons/beaker-progressive.png and /dev/null differ diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/beaker-progressive.svg b/resources/lib/ooui/themes/wikimediaui/images/icons/beaker-progressive.svg deleted file mode 100644 index 1f8efbdee7..0000000000 --- a/resources/lib/ooui/themes/wikimediaui/images/icons/beaker-progressive.svg +++ /dev/null @@ -1,7 +0,0 @@ - - - - beaker - - - diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/beaker.png b/resources/lib/ooui/themes/wikimediaui/images/icons/beaker.png deleted file mode 100644 index 63a1a80b27..0000000000 Binary files a/resources/lib/ooui/themes/wikimediaui/images/icons/beaker.png and /dev/null differ diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/beaker.svg b/resources/lib/ooui/themes/wikimediaui/images/icons/beaker.svg deleted file mode 100644 index 7a37c5a7ad..0000000000 --- a/resources/lib/ooui/themes/wikimediaui/images/icons/beaker.svg +++ /dev/null @@ -1,7 +0,0 @@ - - - - beaker - - - diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/labFlask-invert.png b/resources/lib/ooui/themes/wikimediaui/images/icons/labFlask-invert.png new file mode 100644 index 0000000000..89d2d3db79 Binary files /dev/null and b/resources/lib/ooui/themes/wikimediaui/images/icons/labFlask-invert.png differ diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/labFlask-invert.svg b/resources/lib/ooui/themes/wikimediaui/images/icons/labFlask-invert.svg new file mode 100644 index 0000000000..bfb66da0d0 --- /dev/null +++ b/resources/lib/ooui/themes/wikimediaui/images/icons/labFlask-invert.svg @@ -0,0 +1,7 @@ + + + + laboratory flask + + + diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/labFlask-progressive.png b/resources/lib/ooui/themes/wikimediaui/images/icons/labFlask-progressive.png new file mode 100644 index 0000000000..78736aca78 Binary files /dev/null and b/resources/lib/ooui/themes/wikimediaui/images/icons/labFlask-progressive.png differ diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/labFlask-progressive.svg b/resources/lib/ooui/themes/wikimediaui/images/icons/labFlask-progressive.svg new file mode 100644 index 0000000000..1db0d6bd11 --- /dev/null +++ b/resources/lib/ooui/themes/wikimediaui/images/icons/labFlask-progressive.svg @@ -0,0 +1,7 @@ + + + + laboratory flask + + + diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/labFlask.png b/resources/lib/ooui/themes/wikimediaui/images/icons/labFlask.png new file mode 100644 index 0000000000..63a1a80b27 Binary files /dev/null and b/resources/lib/ooui/themes/wikimediaui/images/icons/labFlask.png differ diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/labFlask.svg b/resources/lib/ooui/themes/wikimediaui/images/icons/labFlask.svg new file mode 100644 index 0000000000..c95a51a8bd --- /dev/null +++ b/resources/lib/ooui/themes/wikimediaui/images/icons/labFlask.svg @@ -0,0 +1,7 @@ + + + + laboratory flask + + + diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/userAvatarOutline-invert.svg b/resources/lib/ooui/themes/wikimediaui/images/icons/userAvatarOutline-invert.svg index 3b5187ded1..268dc3046d 100644 --- a/resources/lib/ooui/themes/wikimediaui/images/icons/userAvatarOutline-invert.svg +++ b/resources/lib/ooui/themes/wikimediaui/images/icons/userAvatarOutline-invert.svg @@ -1,4 +1,4 @@ - + user avatar diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/userAvatarOutline-progressive.svg b/resources/lib/ooui/themes/wikimediaui/images/icons/userAvatarOutline-progressive.svg index 047a18c79f..681a46815c 100644 --- a/resources/lib/ooui/themes/wikimediaui/images/icons/userAvatarOutline-progressive.svg +++ b/resources/lib/ooui/themes/wikimediaui/images/icons/userAvatarOutline-progressive.svg @@ -1,4 +1,4 @@ - + user avatar diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/userAvatarOutline.svg b/resources/lib/ooui/themes/wikimediaui/images/icons/userAvatarOutline.svg index 7608cd2eaf..82362357c2 100644 --- a/resources/lib/ooui/themes/wikimediaui/images/icons/userAvatarOutline.svg +++ b/resources/lib/ooui/themes/wikimediaui/images/icons/userAvatarOutline.svg @@ -1,4 +1,4 @@ - + user avatar diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-ltr-invert.png b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-ltr-invert.png new file mode 100644 index 0000000000..bc9c1114e3 Binary files /dev/null and b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-ltr-invert.png differ diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-ltr-invert.svg b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-ltr-invert.svg new file mode 100644 index 0000000000..d05ad381a5 --- /dev/null +++ b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-ltr-invert.svg @@ -0,0 +1,7 @@ + + + + user group + + + diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-ltr-progressive.png b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-ltr-progressive.png new file mode 100644 index 0000000000..5cd3d1c7b0 Binary files /dev/null and b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-ltr-progressive.png differ diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-ltr-progressive.svg b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-ltr-progressive.svg new file mode 100644 index 0000000000..71d354a78d --- /dev/null +++ b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-ltr-progressive.svg @@ -0,0 +1,7 @@ + + + + user group + + + diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-ltr.png b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-ltr.png new file mode 100644 index 0000000000..43c0be222d Binary files /dev/null and b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-ltr.png differ diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-ltr.svg b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-ltr.svg new file mode 100644 index 0000000000..248d0560f1 --- /dev/null +++ b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-ltr.svg @@ -0,0 +1,7 @@ + + + + user group + + + diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-rtl-invert.png b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-rtl-invert.png new file mode 100644 index 0000000000..2147e81d8c Binary files /dev/null and b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-rtl-invert.png differ diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-rtl-invert.svg b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-rtl-invert.svg new file mode 100644 index 0000000000..5604358123 --- /dev/null +++ b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-rtl-invert.svg @@ -0,0 +1,7 @@ + + + + user group + + + diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-rtl-progressive.png b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-rtl-progressive.png new file mode 100644 index 0000000000..d9082d388c Binary files /dev/null and b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-rtl-progressive.png differ diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-rtl-progressive.svg b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-rtl-progressive.svg new file mode 100644 index 0000000000..75436e9d19 --- /dev/null +++ b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-rtl-progressive.svg @@ -0,0 +1,7 @@ + + + + user group + + + diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-rtl.png b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-rtl.png new file mode 100644 index 0000000000..4eedd2e7ab Binary files /dev/null and b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-rtl.png differ diff --git a/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-rtl.svg b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-rtl.svg new file mode 100644 index 0000000000..5bd5bf5969 --- /dev/null +++ b/resources/lib/ooui/themes/wikimediaui/images/icons/userGroup-rtl.svg @@ -0,0 +1,7 @@ + + + + user group + + + diff --git a/resources/src/jquery.color/jquery.color.js b/resources/src/jquery.color/jquery.color.js new file mode 100644 index 0000000000..6df02adf5b --- /dev/null +++ b/resources/src/jquery.color/jquery.color.js @@ -0,0 +1,55 @@ +/** + * jQuery Color Animations + * + * @author John Resig, 2007 + * @author Krinkle, 2011 + * Released under the MIT and GPL licenses. + * + * - 2011-01-05: Forked for MediaWiki. See also jQuery.colorUtil plugin + */ +( function () { + + function getColor( elem, attr ) { + var color; + + do { + color = $.css( elem, attr ); + + // Keep going until we find an element that has color, or we hit the body + if ( color !== '' && color !== 'transparent' || elem.nodeName.toLowerCase() === 'body' ) { + break; + } + + attr = 'backgroundColor'; + // eslint-disable-next-line no-cond-assign + } while ( elem = elem.parentNode ); + + return $.colorUtil.getRGB( color ); + } + + // We override the animation for all of these color styles + [ + 'backgroundColor', + 'borderBottomColor', + 'borderLeftColor', + 'borderRightColor', + 'borderTopColor', + 'color', + 'outlineColor' + ].forEach( function ( attr ) { + $.fx.step[ attr ] = function ( fx ) { + if ( !fx.colorInit ) { + fx.start = getColor( fx.elem, attr ); + fx.end = $.colorUtil.getRGB( fx.end ); + fx.colorInit = true; + } + + fx.elem.style[ attr ] = 'rgb(' + [ + Math.max( Math.min( parseInt( ( fx.pos * ( fx.end[ 0 ] - fx.start[ 0 ] ) ) + fx.start[ 0 ], 10 ), 255 ), 0 ), + Math.max( Math.min( parseInt( ( fx.pos * ( fx.end[ 1 ] - fx.start[ 1 ] ) ) + fx.start[ 1 ], 10 ), 255 ), 0 ), + Math.max( Math.min( parseInt( ( fx.pos * ( fx.end[ 2 ] - fx.start[ 2 ] ) ) + fx.start[ 2 ], 10 ), 255 ), 0 ) + ].join( ',' ) + ')'; + }; + } ); + +}() ); diff --git a/resources/src/jquery.color/jquery.colorUtil.js b/resources/src/jquery.color/jquery.colorUtil.js new file mode 100644 index 0000000000..009be1aa73 --- /dev/null +++ b/resources/src/jquery.color/jquery.colorUtil.js @@ -0,0 +1,268 @@ +/*! + * jQuery Color Utilities + * + * Released under the MIT and GPL licenses. + * + * Mostly based on other plugins and functions (linted and optimized a little). + * Sources cited inline. + */ +( function () { + /** + * @class jQuery.colorUtil + * @singleton + */ + $.colorUtil = { + + /** + * Parse CSS color strings looking for color tuples + * + * Based on highlightFade by Blair Mitchelmore + * + * + * @param {Array|string} color + * @return {Array} + */ + getRGB: function ( color ) { + var result; + + // Check if we're already dealing with an array of colors + if ( color && Array.isArray( color ) && color.length === 3 ) { + return color; + } + if ( typeof color !== 'string' ) { + return undefined; + } + + // Look for rgb(num,num,num) + // eslint-disable-next-line no-cond-assign + if ( result = /rgb\(\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*\)/.exec( color ) ) { + return [ + parseInt( result[ 1 ], 10 ), + parseInt( result[ 2 ], 10 ), + parseInt( result[ 3 ], 10 ) + ]; + } + + // Look for rgb(num%,num%,num%) + // eslint-disable-next-line no-cond-assign + if ( result = /rgb\(\s*([0-9]+(?:\.[0-9]+)?)%\s*,\s*([0-9]+(?:\.[0-9]+)?)%\s*,\s*([0-9]+(?:\.[0-9]+)?)%\s*\)/.exec( color ) ) { + return [ + parseFloat( result[ 1 ] ) * 2.55, + parseFloat( result[ 2 ] ) * 2.55, + parseFloat( result[ 3 ] ) * 2.55 + ]; + } + + // Look for #a0b1c2 + // eslint-disable-next-line no-cond-assign + if ( result = /#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})/.exec( color ) ) { + return [ + parseInt( result[ 1 ], 16 ), + parseInt( result[ 2 ], 16 ), + parseInt( result[ 3 ], 16 ) + ]; + } + + // Look for #fff + // eslint-disable-next-line no-cond-assign + if ( result = /#([a-fA-F0-9])([a-fA-F0-9])([a-fA-F0-9])/.exec( color ) ) { + return [ + parseInt( result[ 1 ] + result[ 1 ], 16 ), + parseInt( result[ 2 ] + result[ 2 ], 16 ), + parseInt( result[ 3 ] + result[ 3 ], 16 ) + ]; + } + + // Look for rgba(0, 0, 0, 0) == transparent in Safari 3 + // eslint-disable-next-line no-cond-assign + if ( result = /rgba\(0, 0, 0, 0\)/.exec( color ) ) { + return $.colorUtil.colors.transparent; + } + + // Otherwise, we're most likely dealing with a named color + return $.colorUtil.colors[ color.trim().toLowerCase() ]; + }, + + /** + * Named color map + * + * Based on Interface by Stefan Petre + * + * + * @property {Object} + */ + colors: { + aqua: [ 0, 255, 255 ], + azure: [ 240, 255, 255 ], + beige: [ 245, 245, 220 ], + black: [ 0, 0, 0 ], + blue: [ 0, 0, 255 ], + brown: [ 165, 42, 42 ], + cyan: [ 0, 255, 255 ], + darkblue: [ 0, 0, 139 ], + darkcyan: [ 0, 139, 139 ], + darkgrey: [ 169, 169, 169 ], + darkgreen: [ 0, 100, 0 ], + darkkhaki: [ 189, 183, 107 ], + darkmagenta: [ 139, 0, 139 ], + darkolivegreen: [ 85, 107, 47 ], + darkorange: [ 255, 140, 0 ], + darkorchid: [ 153, 50, 204 ], + darkred: [ 139, 0, 0 ], + darksalmon: [ 233, 150, 122 ], + darkviolet: [ 148, 0, 211 ], + fuchsia: [ 255, 0, 255 ], + gold: [ 255, 215, 0 ], + green: [ 0, 128, 0 ], + indigo: [ 75, 0, 130 ], + khaki: [ 240, 230, 140 ], + lightblue: [ 173, 216, 230 ], + lightcyan: [ 224, 255, 255 ], + lightgreen: [ 144, 238, 144 ], + lightgrey: [ 211, 211, 211 ], + lightpink: [ 255, 182, 193 ], + lightyellow: [ 255, 255, 224 ], + lime: [ 0, 255, 0 ], + magenta: [ 255, 0, 255 ], + maroon: [ 128, 0, 0 ], + navy: [ 0, 0, 128 ], + olive: [ 128, 128, 0 ], + orange: [ 255, 165, 0 ], + pink: [ 255, 192, 203 ], + purple: [ 128, 0, 128 ], + violet: [ 128, 0, 128 ], + red: [ 255, 0, 0 ], + silver: [ 192, 192, 192 ], + white: [ 255, 255, 255 ], + yellow: [ 255, 255, 0 ], + transparent: [ 255, 255, 255 ] + }, + + /** + * Convert an RGB color value to HSL. + * + * Conversion formula based on + * + * + * Adapted from . + * + * Assumes `r`, `g`, and `b` are contained in the set `[0, 255]` and + * returns `h`, `s`, and `l` in the set `[0, 1]`. + * + * @param {number} r The red color value + * @param {number} g The green color value + * @param {number} b The blue color value + * @return {number[]} The HSL representation + */ + rgbToHsl: function ( r, g, b ) { + var d, h, s, l, min, max; + + r = r / 255; + g = g / 255; + b = b / 255; + + max = Math.max( r, g, b ); + min = Math.min( r, g, b ); + l = ( max + min ) / 2; + + if ( max === min ) { + // achromatic + h = s = 0; + } else { + d = max - min; + s = l > 0.5 ? d / ( 2 - max - min ) : d / ( max + min ); + switch ( max ) { + case r: + h = ( g - b ) / d + ( g < b ? 6 : 0 ); + break; + case g: + h = ( b - r ) / d + 2; + break; + case b: + h = ( r - g ) / d + 4; + break; + } + h /= 6; + } + + return [ h, s, l ]; + }, + + /** + * Convert an HSL color value to RGB. + * + * Conversion formula based on + * + * + * Adapted from . + * + * Assumes `h`, `s`, and `l` are contained in the set `[0, 1]` and + * returns `r`, `g`, and `b` in the set `[0, 255]`. + * + * @param {number} h The hue + * @param {number} s The saturation + * @param {number} l The lightness + * @return {number[]} The RGB representation + */ + hslToRgb: function ( h, s, l ) { + var r, g, b, hue2rgb, q, p; + + if ( s === 0 ) { + r = g = b = l; // achromatic + } else { + hue2rgb = function ( p, q, t ) { + if ( t < 0 ) { + t += 1; + } + if ( t > 1 ) { + t -= 1; + } + if ( t < 1 / 6 ) { + return p + ( q - p ) * 6 * t; + } + if ( t < 1 / 2 ) { + return q; + } + if ( t < 2 / 3 ) { + return p + ( q - p ) * ( 2 / 3 - t ) * 6; + } + return p; + }; + + q = l < 0.5 ? l * ( 1 + s ) : l + s - l * s; + p = 2 * l - q; + r = hue2rgb( p, q, h + 1 / 3 ); + g = hue2rgb( p, q, h ); + b = hue2rgb( p, q, h - 1 / 3 ); + } + + return [ r * 255, g * 255, b * 255 ]; + }, + + /** + * Get a brighter or darker rgb() value string. + * + * Usage: + * + * $.colorUtil.getColorBrightness( 'red', +0.1 ); + * // > "rgb(255,50,50)" + * $.colorUtil.getColorBrightness( 'rgb(200,50,50)', -0.2 ); + * // > "rgb(118,29,29)" + * + * @param {Mixed} currentColor Current value in css + * @param {number} mod Wanted brightness modification between -1 and 1 + * @return {string} Like `'rgb(r,g,b)'` + */ + getColorBrightness: function ( currentColor, mod ) { + var rgbArr = $.colorUtil.getRGB( currentColor ), + hslArr = $.colorUtil.rgbToHsl( rgbArr[ 0 ], rgbArr[ 1 ], rgbArr[ 2 ] ); + rgbArr = $.colorUtil.hslToRgb( hslArr[ 0 ], hslArr[ 1 ], hslArr[ 2 ] + mod ); + + return 'rgb(' + + [ parseInt( rgbArr[ 0 ], 10 ), parseInt( rgbArr[ 1 ], 10 ), parseInt( rgbArr[ 2 ], 10 ) ].join( ',' ) + + ')'; + } + + }; + +}() ); diff --git a/resources/src/jquery/jquery.checkboxShiftClick.js b/resources/src/jquery/jquery.checkboxShiftClick.js deleted file mode 100644 index 435e23f55e..0000000000 --- a/resources/src/jquery/jquery.checkboxShiftClick.js +++ /dev/null @@ -1,43 +0,0 @@ -/** - * @class jQuery.plugin.checkboxShiftClick - */ -( function () { - - /** - * Enable checkboxes to be checked or unchecked in a row by clicking one, - * holding shift and clicking another one. - * - * @return {jQuery} - * @chainable - */ - $.fn.checkboxShiftClick = function () { - var prevCheckbox = null, - $box = this; - // When our boxes are clicked.. - $box.on( 'click', function ( e ) { - // And one has been clicked before... - if ( prevCheckbox !== null && e.shiftKey ) { - // Check or uncheck this one and all in-between checkboxes, - // except for disabled ones - $box - .slice( - Math.min( $box.index( prevCheckbox ), $box.index( e.target ) ), - Math.max( $box.index( prevCheckbox ), $box.index( e.target ) ) + 1 - ) - .filter( function () { - return !this.disabled; - } ) - .prop( 'checked', !!e.target.checked ); - } - // Either way, update the prevCheckbox variable to the one clicked now - prevCheckbox = e.target; - } ); - return $box; - }; - - /** - * @class jQuery - * @mixins jQuery.plugin.checkboxShiftClick - */ - -}() ); diff --git a/resources/src/jquery/jquery.color.js b/resources/src/jquery/jquery.color.js deleted file mode 100644 index 6df02adf5b..0000000000 --- a/resources/src/jquery/jquery.color.js +++ /dev/null @@ -1,55 +0,0 @@ -/** - * jQuery Color Animations - * - * @author John Resig, 2007 - * @author Krinkle, 2011 - * Released under the MIT and GPL licenses. - * - * - 2011-01-05: Forked for MediaWiki. See also jQuery.colorUtil plugin - */ -( function () { - - function getColor( elem, attr ) { - var color; - - do { - color = $.css( elem, attr ); - - // Keep going until we find an element that has color, or we hit the body - if ( color !== '' && color !== 'transparent' || elem.nodeName.toLowerCase() === 'body' ) { - break; - } - - attr = 'backgroundColor'; - // eslint-disable-next-line no-cond-assign - } while ( elem = elem.parentNode ); - - return $.colorUtil.getRGB( color ); - } - - // We override the animation for all of these color styles - [ - 'backgroundColor', - 'borderBottomColor', - 'borderLeftColor', - 'borderRightColor', - 'borderTopColor', - 'color', - 'outlineColor' - ].forEach( function ( attr ) { - $.fx.step[ attr ] = function ( fx ) { - if ( !fx.colorInit ) { - fx.start = getColor( fx.elem, attr ); - fx.end = $.colorUtil.getRGB( fx.end ); - fx.colorInit = true; - } - - fx.elem.style[ attr ] = 'rgb(' + [ - Math.max( Math.min( parseInt( ( fx.pos * ( fx.end[ 0 ] - fx.start[ 0 ] ) ) + fx.start[ 0 ], 10 ), 255 ), 0 ), - Math.max( Math.min( parseInt( ( fx.pos * ( fx.end[ 1 ] - fx.start[ 1 ] ) ) + fx.start[ 1 ], 10 ), 255 ), 0 ), - Math.max( Math.min( parseInt( ( fx.pos * ( fx.end[ 2 ] - fx.start[ 2 ] ) ) + fx.start[ 2 ], 10 ), 255 ), 0 ) - ].join( ',' ) + ')'; - }; - } ); - -}() ); diff --git a/resources/src/jquery/jquery.colorUtil.js b/resources/src/jquery/jquery.colorUtil.js deleted file mode 100644 index 009be1aa73..0000000000 --- a/resources/src/jquery/jquery.colorUtil.js +++ /dev/null @@ -1,268 +0,0 @@ -/*! - * jQuery Color Utilities - * - * Released under the MIT and GPL licenses. - * - * Mostly based on other plugins and functions (linted and optimized a little). - * Sources cited inline. - */ -( function () { - /** - * @class jQuery.colorUtil - * @singleton - */ - $.colorUtil = { - - /** - * Parse CSS color strings looking for color tuples - * - * Based on highlightFade by Blair Mitchelmore - * - * - * @param {Array|string} color - * @return {Array} - */ - getRGB: function ( color ) { - var result; - - // Check if we're already dealing with an array of colors - if ( color && Array.isArray( color ) && color.length === 3 ) { - return color; - } - if ( typeof color !== 'string' ) { - return undefined; - } - - // Look for rgb(num,num,num) - // eslint-disable-next-line no-cond-assign - if ( result = /rgb\(\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*\)/.exec( color ) ) { - return [ - parseInt( result[ 1 ], 10 ), - parseInt( result[ 2 ], 10 ), - parseInt( result[ 3 ], 10 ) - ]; - } - - // Look for rgb(num%,num%,num%) - // eslint-disable-next-line no-cond-assign - if ( result = /rgb\(\s*([0-9]+(?:\.[0-9]+)?)%\s*,\s*([0-9]+(?:\.[0-9]+)?)%\s*,\s*([0-9]+(?:\.[0-9]+)?)%\s*\)/.exec( color ) ) { - return [ - parseFloat( result[ 1 ] ) * 2.55, - parseFloat( result[ 2 ] ) * 2.55, - parseFloat( result[ 3 ] ) * 2.55 - ]; - } - - // Look for #a0b1c2 - // eslint-disable-next-line no-cond-assign - if ( result = /#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})/.exec( color ) ) { - return [ - parseInt( result[ 1 ], 16 ), - parseInt( result[ 2 ], 16 ), - parseInt( result[ 3 ], 16 ) - ]; - } - - // Look for #fff - // eslint-disable-next-line no-cond-assign - if ( result = /#([a-fA-F0-9])([a-fA-F0-9])([a-fA-F0-9])/.exec( color ) ) { - return [ - parseInt( result[ 1 ] + result[ 1 ], 16 ), - parseInt( result[ 2 ] + result[ 2 ], 16 ), - parseInt( result[ 3 ] + result[ 3 ], 16 ) - ]; - } - - // Look for rgba(0, 0, 0, 0) == transparent in Safari 3 - // eslint-disable-next-line no-cond-assign - if ( result = /rgba\(0, 0, 0, 0\)/.exec( color ) ) { - return $.colorUtil.colors.transparent; - } - - // Otherwise, we're most likely dealing with a named color - return $.colorUtil.colors[ color.trim().toLowerCase() ]; - }, - - /** - * Named color map - * - * Based on Interface by Stefan Petre - * - * - * @property {Object} - */ - colors: { - aqua: [ 0, 255, 255 ], - azure: [ 240, 255, 255 ], - beige: [ 245, 245, 220 ], - black: [ 0, 0, 0 ], - blue: [ 0, 0, 255 ], - brown: [ 165, 42, 42 ], - cyan: [ 0, 255, 255 ], - darkblue: [ 0, 0, 139 ], - darkcyan: [ 0, 139, 139 ], - darkgrey: [ 169, 169, 169 ], - darkgreen: [ 0, 100, 0 ], - darkkhaki: [ 189, 183, 107 ], - darkmagenta: [ 139, 0, 139 ], - darkolivegreen: [ 85, 107, 47 ], - darkorange: [ 255, 140, 0 ], - darkorchid: [ 153, 50, 204 ], - darkred: [ 139, 0, 0 ], - darksalmon: [ 233, 150, 122 ], - darkviolet: [ 148, 0, 211 ], - fuchsia: [ 255, 0, 255 ], - gold: [ 255, 215, 0 ], - green: [ 0, 128, 0 ], - indigo: [ 75, 0, 130 ], - khaki: [ 240, 230, 140 ], - lightblue: [ 173, 216, 230 ], - lightcyan: [ 224, 255, 255 ], - lightgreen: [ 144, 238, 144 ], - lightgrey: [ 211, 211, 211 ], - lightpink: [ 255, 182, 193 ], - lightyellow: [ 255, 255, 224 ], - lime: [ 0, 255, 0 ], - magenta: [ 255, 0, 255 ], - maroon: [ 128, 0, 0 ], - navy: [ 0, 0, 128 ], - olive: [ 128, 128, 0 ], - orange: [ 255, 165, 0 ], - pink: [ 255, 192, 203 ], - purple: [ 128, 0, 128 ], - violet: [ 128, 0, 128 ], - red: [ 255, 0, 0 ], - silver: [ 192, 192, 192 ], - white: [ 255, 255, 255 ], - yellow: [ 255, 255, 0 ], - transparent: [ 255, 255, 255 ] - }, - - /** - * Convert an RGB color value to HSL. - * - * Conversion formula based on - * - * - * Adapted from . - * - * Assumes `r`, `g`, and `b` are contained in the set `[0, 255]` and - * returns `h`, `s`, and `l` in the set `[0, 1]`. - * - * @param {number} r The red color value - * @param {number} g The green color value - * @param {number} b The blue color value - * @return {number[]} The HSL representation - */ - rgbToHsl: function ( r, g, b ) { - var d, h, s, l, min, max; - - r = r / 255; - g = g / 255; - b = b / 255; - - max = Math.max( r, g, b ); - min = Math.min( r, g, b ); - l = ( max + min ) / 2; - - if ( max === min ) { - // achromatic - h = s = 0; - } else { - d = max - min; - s = l > 0.5 ? d / ( 2 - max - min ) : d / ( max + min ); - switch ( max ) { - case r: - h = ( g - b ) / d + ( g < b ? 6 : 0 ); - break; - case g: - h = ( b - r ) / d + 2; - break; - case b: - h = ( r - g ) / d + 4; - break; - } - h /= 6; - } - - return [ h, s, l ]; - }, - - /** - * Convert an HSL color value to RGB. - * - * Conversion formula based on - * - * - * Adapted from . - * - * Assumes `h`, `s`, and `l` are contained in the set `[0, 1]` and - * returns `r`, `g`, and `b` in the set `[0, 255]`. - * - * @param {number} h The hue - * @param {number} s The saturation - * @param {number} l The lightness - * @return {number[]} The RGB representation - */ - hslToRgb: function ( h, s, l ) { - var r, g, b, hue2rgb, q, p; - - if ( s === 0 ) { - r = g = b = l; // achromatic - } else { - hue2rgb = function ( p, q, t ) { - if ( t < 0 ) { - t += 1; - } - if ( t > 1 ) { - t -= 1; - } - if ( t < 1 / 6 ) { - return p + ( q - p ) * 6 * t; - } - if ( t < 1 / 2 ) { - return q; - } - if ( t < 2 / 3 ) { - return p + ( q - p ) * ( 2 / 3 - t ) * 6; - } - return p; - }; - - q = l < 0.5 ? l * ( 1 + s ) : l + s - l * s; - p = 2 * l - q; - r = hue2rgb( p, q, h + 1 / 3 ); - g = hue2rgb( p, q, h ); - b = hue2rgb( p, q, h - 1 / 3 ); - } - - return [ r * 255, g * 255, b * 255 ]; - }, - - /** - * Get a brighter or darker rgb() value string. - * - * Usage: - * - * $.colorUtil.getColorBrightness( 'red', +0.1 ); - * // > "rgb(255,50,50)" - * $.colorUtil.getColorBrightness( 'rgb(200,50,50)', -0.2 ); - * // > "rgb(118,29,29)" - * - * @param {Mixed} currentColor Current value in css - * @param {number} mod Wanted brightness modification between -1 and 1 - * @return {string} Like `'rgb(r,g,b)'` - */ - getColorBrightness: function ( currentColor, mod ) { - var rgbArr = $.colorUtil.getRGB( currentColor ), - hslArr = $.colorUtil.rgbToHsl( rgbArr[ 0 ], rgbArr[ 1 ], rgbArr[ 2 ] ); - rgbArr = $.colorUtil.hslToRgb( hslArr[ 0 ], hslArr[ 1 ], hslArr[ 2 ] + mod ); - - return 'rgb(' + - [ parseInt( rgbArr[ 0 ], 10 ), parseInt( rgbArr[ 1 ], 10 ), parseInt( rgbArr[ 2 ], 10 ) ].join( ',' ) + - ')'; - } - - }; - -}() ); diff --git a/resources/src/jquery/jquery.makeCollapsible.js b/resources/src/jquery/jquery.makeCollapsible.js index 20bd405038..de307a69d9 100644 --- a/resources/src/jquery/jquery.makeCollapsible.js +++ b/resources/src/jquery/jquery.makeCollapsible.js @@ -136,6 +136,11 @@ .toggleClass( 'mw-collapsible-toggle-expanded', wasCollapsed ); } + // Toggle `aria-expanded` attribute, if requested (for default and premade togglers by default). + if ( options.toggleARIA ) { + $toggle.attr( 'aria-expanded', wasCollapsed ? 'true' : 'false' ); + } + // Toggle the text ("Show"/"Hide") within elements tagged with mw-collapsible-text if ( options.toggleText ) { collapseText = options.toggleText.collapseText; @@ -211,6 +216,7 @@ actionHandler = function ( e, opts ) { var defaultOpts = { toggleClasses: true, + toggleARIA: true, toggleText: { collapseText: collapseText, expandText: expandText } }; opts = $.extend( defaultOpts, options, opts ); @@ -324,6 +330,7 @@ // Attach event handlers to togglelink $toggle.on( 'click.mw-collapsible keypress.mw-collapsible', actionHandler ) + .attr( 'aria-expanded', 'true' ) .prop( 'tabIndex', 0 ); $( this ).data( 'mw-collapsible', { diff --git a/resources/src/mediawiki.ForeignApi.core.js b/resources/src/mediawiki.ForeignApi.core.js index 4b6313b93c..83ea0ce003 100644 --- a/resources/src/mediawiki.ForeignApi.core.js +++ b/resources/src/mediawiki.ForeignApi.core.js @@ -59,7 +59,6 @@ } }, parameters: { - // Add 'origin' query parameter to all requests. origin: this.getOrigin() } }, @@ -77,17 +76,26 @@ * any). * * @protected - * @return {string} + * @return {string|undefined} */ CoreForeignApi.prototype.getOrigin = function () { - var origin; + var origin, apiUri, apiOrigin; if ( this.anonymous ) { return '*'; } + origin = location.protocol + '//' + location.hostname; if ( location.port ) { origin += ':' + location.port; } + + apiUri = new mw.Uri( this.apiUrl ); + apiOrigin = apiUri.protocol + '://' + apiUri.getAuthority(); + if ( origin === apiOrigin ) { + // requests are not cross-origin, omit parameter + return undefined; + } + return origin; }; @@ -101,10 +109,12 @@ if ( ajaxOptions.type === 'POST' ) { url = ( ajaxOptions && ajaxOptions.url ) || this.defaults.ajax.url; origin = ( parameters && parameters.origin ) || this.defaults.parameters.origin; - url += ( url.indexOf( '?' ) !== -1 ? '&' : '?' ) + - // Depending on server configuration, MediaWiki may forbid periods in URLs, due to an IE 6 - // XSS bug. So let's escape them here. See WebRequest::checkUrlExtension() and T30235. - 'origin=' + encodeURIComponent( origin ).replace( /\./g, '%2E' ); + if ( origin !== undefined ) { + url += ( url.indexOf( '?' ) !== -1 ? '&' : '?' ) + + // Depending on server configuration, MediaWiki may forbid periods in URLs, due to an IE 6 + // XSS bug. So let's escape them here. See WebRequest::checkUrlExtension() and T30235. + 'origin=' + encodeURIComponent( origin ).replace( /\./g, '%2E' ); + } newAjaxOptions = $.extend( {}, ajaxOptions, { url: url } ); } else { newAjaxOptions = ajaxOptions; diff --git a/resources/src/mediawiki.Title/Title.js b/resources/src/mediawiki.Title/Title.js index 3f39fd16e6..843f00f744 100644 --- a/resources/src/mediawiki.Title/Title.js +++ b/resources/src/mediawiki.Title/Title.js @@ -29,11 +29,9 @@ /* Private members */ -var +var toUpperMap, mwString = require( 'mediawiki.String' ), - toUpperMapping = require( './phpCharToUpper.json' ), - namespaceIds = mw.config.get( 'wgNamespaceIds' ), /** @@ -765,8 +763,15 @@ Title.normalizeExtension = function ( extension ) { * @return {string} Unicode character, in upper case, according to the same rules as in PHP */ Title.phpCharToUpper = function ( chr ) { - var mapped = toUpperMapping[ chr ]; - return mapped || chr.toUpperCase(); + if ( !toUpperMap ) { + toUpperMap = require( './phpCharToUpper.json' ); + } + if ( toUpperMap[ chr ] === '' ) { + // Optimisation: When the override is to keep the character unchanged, + // we use an empty string in JSON. This reduces the data by 50%. + return chr; + } + return toUpperMap[ chr ] || chr.toUpperCase(); }; /* Public members */ diff --git a/resources/src/mediawiki.Title/phpCharToUpper.json b/resources/src/mediawiki.Title/phpCharToUpper.json index 2ba08cfbf0..0334039510 100644 --- a/resources/src/mediawiki.Title/phpCharToUpper.json +++ b/resources/src/mediawiki.Title/phpCharToUpper.json @@ -1,156 +1,156 @@ { - "ß": "ß", - "ʼn": "ʼn", - "ƀ": "ƀ", - "ƚ": "ƚ", - "Dž": "Dž", + "ß": "", + "ʼn": "", + "ƀ": "", + "ƚ": "", + "Dž": "", "dž": "Dž", - "Lj": "Lj", + "Lj": "", "lj": "Lj", - "Nj": "Nj", + "Nj": "", "nj": "Nj", - "Ç°": "Ç°", - "Dz": "Dz", + "Ç°": "", + "Dz": "", "dz": "Dz", - "ȼ": "ȼ", - "È¿": "È¿", - "ɀ": "ɀ", - "ɂ": "ɂ", - "ɇ": "ɇ", - "ɉ": "ɉ", - "ɋ": "ɋ", - "ɍ": "ɍ", - "ɏ": "ɏ", - "ɐ": "ɐ", - "ɑ": "ɑ", - "ɒ": "ɒ", - "ɜ": "ɜ", - "É¡": "É¡", - "É¥": "É¥", - "ɦ": "ɦ", - "ɪ": "ɪ", - "É«": "É«", - "ɬ": "ɬ", - "ɱ": "ɱ", - "ɽ": "ɽ", - "ʂ": "ʂ", - "ʇ": "ʇ", - "ʉ": "ʉ", - "ʌ": "ʌ", - "ʝ": "ʝ", - "ʞ": "ʞ", - "ͅ": "ͅ", - "ͱ": "ͱ", - "ͳ": "ͳ", - "Í·": "Í·", - "Í»": "Í»", - "ͼ": "ͼ", - "ͽ": "ͽ", - "ΐ": "ΐ", - "ΰ": "ΰ", - "ϗ": "ϗ", + "ȼ": "", + "È¿": "", + "ɀ": "", + "ɂ": "", + "ɇ": "", + "ɉ": "", + "ɋ": "", + "ɍ": "", + "ɏ": "", + "ɐ": "", + "ɑ": "", + "ɒ": "", + "ɜ": "", + "É¡": "", + "É¥": "", + "ɦ": "", + "ɪ": "", + "É«": "", + "ɬ": "", + "ɱ": "", + "ɽ": "", + "ʂ": "", + "ʇ": "", + "ʉ": "", + "ʌ": "", + "ʝ": "", + "ʞ": "", + "ͅ": "", + "ͱ": "", + "ͳ": "", + "Í·": "", + "Í»": "", + "ͼ": "", + "ͽ": "", + "ΐ": "", + "ΰ": "", + "ϗ": "", "ϲ": "Σ", - "ϳ": "ϳ", - "ϸ": "ϸ", - "Ï»": "Ï»", - "ӏ": "ӏ", - "Ó·": "Ó·", - "Ó»": "Ó»", - "Ó½": "Ó½", - "Ó¿": "Ó¿", - "ԑ": "ԑ", - "ԓ": "ԓ", - "ԕ": "ԕ", - "ԗ": "ԗ", - "ԙ": "ԙ", - "ԛ": "ԛ", - "ԝ": "ԝ", - "ԟ": "ԟ", - "Ô¡": "Ô¡", - "Ô£": "Ô£", - "Ô¥": "Ô¥", - "Ô§": "Ô§", - "Ô©": "Ô©", - "Ô«": "Ô«", - "Ô­": "Ô­", - "Ô¯": "Ô¯", - "և": "և", - "ა": "ა", - "ბ": "ბ", - "გ": "გ", - "დ": "დ", - "ე": "ე", - "ვ": "ვ", - "ზ": "ზ", - "თ": "თ", - "ი": "ი", - "კ": "კ", - "ლ": "ლ", - "მ": "მ", - "ნ": "ნ", - "ო": "ო", - "პ": "პ", - "ჟ": "ჟ", - "რ": "რ", - "ს": "ს", - "ტ": "ტ", - "უ": "უ", - "ფ": "ფ", - "ქ": "ქ", - "ღ": "ღ", - "ყ": "ყ", - "შ": "შ", - "ჩ": "ჩ", - "ც": "ც", - "ძ": "ძ", - "წ": "წ", - "ჭ": "ჭ", - "ხ": "ხ", - "ჯ": "ჯ", - "ჰ": "ჰ", - "ჱ": "ჱ", - "ჲ": "ჲ", - "ჳ": "ჳ", - "ჴ": "ჴ", - "ჵ": "ჵ", - "ჶ": "ჶ", - "ჷ": "ჷ", - "ჸ": "ჸ", - "ჹ": "ჹ", - "ჺ": "ჺ", - "ჽ": "ჽ", - "ჾ": "ჾ", - "ჿ": "ჿ", - "ᏸ": "ᏸ", - "ᏹ": "ᏹ", - "ᏺ": "ᏺ", - "ᏻ": "ᏻ", - "ᏼ": "ᏼ", - "ᏽ": "ᏽ", - "ᲀ": "ᲀ", - "ᲁ": "ᲁ", - "ᲂ": "ᲂ", - "ᲃ": "ᲃ", - "ᲄ": "ᲄ", - "ᲅ": "ᲅ", - "ᲆ": "ᲆ", - "ᲇ": "ᲇ", - "ᲈ": "ᲈ", - "áµ¹": "áµ¹", - "áµ½": "áµ½", - "ᶎ": "ᶎ", - "ẖ": "ẖ", - "ẗ": "ẗ", - "ẘ": "ẘ", - "ẙ": "ẙ", - "ẚ": "ẚ", - "á»»": "á»»", - "ỽ": "ỽ", - "ỿ": "ỿ", - "ὐ": "ὐ", - "ὒ": "ὒ", - "ὔ": "ὔ", - "ὖ": "ὖ", + "ϳ": "", + "ϸ": "", + "Ï»": "", + "ӏ": "", + "Ó·": "", + "Ó»": "", + "Ó½": "", + "Ó¿": "", + "ԑ": "", + "ԓ": "", + "ԕ": "", + "ԗ": "", + "ԙ": "", + "ԛ": "", + "ԝ": "", + "ԟ": "", + "Ô¡": "", + "Ô£": "", + "Ô¥": "", + "Ô§": "", + "Ô©": "", + "Ô«": "", + "Ô­": "", + "Ô¯": "", + "և": "", + "ა": "", + "ბ": "", + "გ": "", + "დ": "", + "ე": "", + "ვ": "", + "ზ": "", + "თ": "", + "ი": "", + "კ": "", + "ლ": "", + "მ": "", + "ნ": "", + "ო": "", + "პ": "", + "ჟ": "", + "რ": "", + "ს": "", + "ტ": "", + "უ": "", + "ფ": "", + "ქ": "", + "ღ": "", + "ყ": "", + "შ": "", + "ჩ": "", + "ც": "", + "ძ": "", + "წ": "", + "ჭ": "", + "ხ": "", + "ჯ": "", + "ჰ": "", + "ჱ": "", + "ჲ": "", + "ჳ": "", + "ჴ": "", + "ჵ": "", + "ჶ": "", + "ჷ": "", + "ჸ": "", + "ჹ": "", + "ჺ": "", + "ჽ": "", + "ჾ": "", + "ჿ": "", + "ᏸ": "", + "ᏹ": "", + "ᏺ": "", + "ᏻ": "", + "ᏼ": "", + "ᏽ": "", + "ᲀ": "", + "ᲁ": "", + "ᲂ": "", + "ᲃ": "", + "ᲄ": "", + "ᲅ": "", + "ᲆ": "", + "ᲇ": "", + "ᲈ": "", + "áµ¹": "", + "áµ½": "", + "ᶎ": "", + "ẖ": "", + "ẗ": "", + "ẘ": "", + "ẙ": "", + "ẚ": "", + "á»»": "", + "ỽ": "", + "ỿ": "", + "ὐ": "", + "ὒ": "", + "ὔ": "", + "ὖ": "", "ᾀ": "ᾈ", "ᾁ": "ᾉ", "ᾂ": "ᾊ", @@ -159,14 +159,14 @@ "ᾅ": "ᾍ", "ᾆ": "ᾎ", "ᾇ": "ᾏ", - "ᾈ": "ᾈ", - "ᾉ": "ᾉ", - "ᾊ": "ᾊ", - "ᾋ": "ᾋ", - "ᾌ": "ᾌ", - "ᾍ": "ᾍ", - "ᾎ": "ᾎ", - "ᾏ": "ᾏ", + "ᾈ": "", + "ᾉ": "", + "ᾊ": "", + "ᾋ": "", + "ᾌ": "", + "ᾍ": "", + "ᾎ": "", + "ᾏ": "", "ᾐ": "ᾘ", "ᾑ": "ᾙ", "ᾒ": "ᾚ", @@ -175,14 +175,14 @@ "ᾕ": "ᾝ", "ᾖ": "ᾞ", "ᾗ": "ᾟ", - "ᾘ": "ᾘ", - "ᾙ": "ᾙ", - "ᾚ": "ᾚ", - "ᾛ": "ᾛ", - "ᾜ": "ᾜ", - "ᾝ": "ᾝ", - "ᾞ": "ᾞ", - "ᾟ": "ᾟ", + "ᾘ": "", + "ᾙ": "", + "ᾚ": "", + "ᾛ": "", + "ᾜ": "", + "ᾝ": "", + "ᾞ": "", + "ᾟ": "", "á¾ ": "ᾨ", "ᾡ": "ᾩ", "á¾¢": "ᾪ", @@ -191,614 +191,614 @@ "á¾¥": "á¾­", "ᾦ": "á¾®", "ᾧ": "ᾯ", - "ᾨ": "ᾨ", - "ᾩ": "ᾩ", - "ᾪ": "ᾪ", - "ᾫ": "ᾫ", - "ᾬ": "ᾬ", - "á¾­": "á¾­", - "á¾®": "á¾®", - "ᾯ": "ᾯ", - "á¾²": "á¾²", + "ᾨ": "", + "ᾩ": "", + "ᾪ": "", + "ᾫ": "", + "ᾬ": "", + "á¾­": "", + "á¾®": "", + "ᾯ": "", + "á¾²": "", "á¾³": "á¾¼", - "á¾´": "á¾´", - "ᾶ": "ᾶ", - "á¾·": "á¾·", - "á¾¼": "á¾¼", - "ῂ": "ῂ", + "á¾´": "", + "ᾶ": "", + "á¾·": "", + "á¾¼": "", + "ῂ": "", "ῃ": "ῌ", - "ῄ": "ῄ", - "ῆ": "ῆ", - "ῇ": "ῇ", - "ῌ": "ῌ", - "ῒ": "ῒ", - "ΐ": "ΐ", - "ῖ": "ῖ", - "ῗ": "ῗ", - "á¿¢": "á¿¢", - "á¿£": "á¿£", - "ῤ": "ῤ", - "ῦ": "ῦ", - "ῧ": "ῧ", - "ῲ": "ῲ", + "ῄ": "", + "ῆ": "", + "ῇ": "", + "ῌ": "", + "ῒ": "", + "ΐ": "", + "ῖ": "", + "ῗ": "", + "á¿¢": "", + "á¿£": "", + "ῤ": "", + "ῦ": "", + "ῧ": "", + "ῲ": "", "ῳ": "ῼ", - "á¿´": "á¿´", - "ῶ": "ῶ", - "á¿·": "á¿·", - "ῼ": "ῼ", - "ⅎ": "ⅎ", - "ⅰ": "ⅰ", - "ⅱ": "ⅱ", - "ⅲ": "ⅲ", - "ⅳ": "ⅳ", - "ⅴ": "ⅴ", - "ⅵ": "ⅵ", - "ⅶ": "ⅶ", - "ⅷ": "ⅷ", - "ⅸ": "ⅸ", - "ⅹ": "ⅹ", - "ⅺ": "ⅺ", - "ⅻ": "ⅻ", - "ⅼ": "ⅼ", - "ⅽ": "ⅽ", - "ⅾ": "ⅾ", - "ⅿ": "ⅿ", - "ↄ": "ↄ", - "ⓐ": "ⓐ", - "ⓑ": "ⓑ", - "ⓒ": "ⓒ", - "ⓓ": "ⓓ", - "ⓔ": "ⓔ", - "ⓕ": "ⓕ", - "ⓖ": "ⓖ", - "ⓗ": "ⓗ", - "ⓘ": "ⓘ", - "ⓙ": "ⓙ", - "ⓚ": "ⓚ", - "ⓛ": "ⓛ", - "ⓜ": "ⓜ", - "ⓝ": "ⓝ", - "ⓞ": "ⓞ", - "ⓟ": "ⓟ", - "ⓠ": "ⓠ", - "ⓡ": "ⓡ", - "ⓢ": "ⓢ", - "ⓣ": "ⓣ", - "ⓤ": "ⓤ", - "ⓥ": "ⓥ", - "ⓦ": "ⓦ", - "ⓧ": "ⓧ", - "ⓨ": "ⓨ", - "ⓩ": "ⓩ", - "â°°": "â°°", - "â°±": "â°±", - "â°²": "â°²", - "â°³": "â°³", - "â°´": "â°´", - "â°µ": "â°µ", - "â°¶": "â°¶", - "â°·": "â°·", - "â°¸": "â°¸", - "â°¹": "â°¹", - "â°º": "â°º", - "â°»": "â°»", - "â°¼": "â°¼", - "â°½": "â°½", - "â°¾": "â°¾", - "â°¿": "â°¿", - "ⱀ": "ⱀ", - "ⱁ": "ⱁ", - "ⱂ": "ⱂ", - "ⱃ": "ⱃ", - "ⱄ": "ⱄ", - "ⱅ": "ⱅ", - "ⱆ": "ⱆ", - "ⱇ": "ⱇ", - "ⱈ": "ⱈ", - "ⱉ": "ⱉ", - "ⱊ": "ⱊ", - "ⱋ": "ⱋ", - "ⱌ": "ⱌ", - "ⱍ": "ⱍ", - "ⱎ": "ⱎ", - "ⱏ": "ⱏ", - "ⱐ": "ⱐ", - "ⱑ": "ⱑ", - "ⱒ": "ⱒ", - "ⱓ": "ⱓ", - "ⱔ": "ⱔ", - "ⱕ": "ⱕ", - "ⱖ": "ⱖ", - "ⱗ": "ⱗ", - "ⱘ": "ⱘ", - "ⱙ": "ⱙ", - "ⱚ": "ⱚ", - "ⱛ": "ⱛ", - "ⱜ": "ⱜ", - "ⱝ": "ⱝ", - "ⱞ": "ⱞ", - "ⱡ": "ⱡ", - "â±¥": "â±¥", - "ⱦ": "ⱦ", - "ⱨ": "ⱨ", - "ⱪ": "ⱪ", - "ⱬ": "ⱬ", - "â±³": "â±³", - "ⱶ": "ⱶ", - "ⲁ": "ⲁ", - "ⲃ": "ⲃ", - "ⲅ": "ⲅ", - "ⲇ": "ⲇ", - "ⲉ": "ⲉ", - "ⲋ": "ⲋ", - "ⲍ": "ⲍ", - "ⲏ": "ⲏ", - "ⲑ": "ⲑ", - "ⲓ": "ⲓ", - "ⲕ": "ⲕ", - "ⲗ": "ⲗ", - "ⲙ": "ⲙ", - "ⲛ": "ⲛ", - "ⲝ": "ⲝ", - "ⲟ": "ⲟ", - "ⲡ": "ⲡ", - "â²£": "â²£", - "â²¥": "â²¥", - "ⲧ": "ⲧ", - "ⲩ": "ⲩ", - "ⲫ": "ⲫ", - "â²­": "â²­", - "ⲯ": "ⲯ", - "â²±": "â²±", - "â²³": "â²³", - "â²µ": "â²µ", - "â²·": "â²·", - "â²¹": "â²¹", - "â²»": "â²»", - "â²½": "â²½", - "ⲿ": "ⲿ", - "ⳁ": "ⳁ", - "ⳃ": "ⳃ", - "ⳅ": "ⳅ", - "ⳇ": "ⳇ", - "ⳉ": "ⳉ", - "ⳋ": "ⳋ", - "ⳍ": "ⳍ", - "ⳏ": "ⳏ", - "ⳑ": "ⳑ", - "ⳓ": "ⳓ", - "ⳕ": "ⳕ", - "ⳗ": "ⳗ", - "ⳙ": "ⳙ", - "ⳛ": "ⳛ", - "ⳝ": "ⳝ", - "ⳟ": "ⳟ", - "ⳡ": "ⳡ", - "â³£": "â³£", - "ⳬ": "ⳬ", - "â³®": "â³®", - "â³³": "â³³", - "ⴀ": "ⴀ", - "ⴁ": "ⴁ", - "ⴂ": "ⴂ", - "ⴃ": "ⴃ", - "ⴄ": "ⴄ", - "ⴅ": "ⴅ", - "ⴆ": "ⴆ", - "ⴇ": "ⴇ", - "ⴈ": "ⴈ", - "ⴉ": "ⴉ", - "ⴊ": "ⴊ", - "ⴋ": "ⴋ", - "ⴌ": "ⴌ", - "ⴍ": "ⴍ", - "ⴎ": "ⴎ", - "ⴏ": "ⴏ", - "ⴐ": "ⴐ", - "ⴑ": "ⴑ", - "ⴒ": "ⴒ", - "ⴓ": "ⴓ", - "ⴔ": "ⴔ", - "ⴕ": "ⴕ", - "ⴖ": "ⴖ", - "ⴗ": "ⴗ", - "ⴘ": "ⴘ", - "ⴙ": "ⴙ", - "ⴚ": "ⴚ", - "ⴛ": "ⴛ", - "ⴜ": "ⴜ", - "ⴝ": "ⴝ", - "ⴞ": "ⴞ", - "ⴟ": "ⴟ", - "â´ ": "â´ ", - "â´¡": "â´¡", - "â´¢": "â´¢", - "â´£": "â´£", - "â´¤": "â´¤", - "â´¥": "â´¥", - "â´§": "â´§", - "â´­": "â´­", - "ꙁ": "ꙁ", - "ꙃ": "ꙃ", - "ꙅ": "ꙅ", - "ꙇ": "ꙇ", - "ꙉ": "ꙉ", - "ꙋ": "ꙋ", - "ꙍ": "ꙍ", - "ꙏ": "ꙏ", - "ꙑ": "ꙑ", - "ꙓ": "ꙓ", - "ꙕ": "ꙕ", - "ꙗ": "ꙗ", - "ꙙ": "ꙙ", - "ꙛ": "ꙛ", - "ꙝ": "ꙝ", - "ꙟ": "ꙟ", - "ꙡ": "ꙡ", - "ꙣ": "ꙣ", - "ꙥ": "ꙥ", - "ꙧ": "ꙧ", - "ꙩ": "ꙩ", - "ꙫ": "ꙫ", - "ꙭ": "ꙭ", - "ꚁ": "ꚁ", - "ꚃ": "ꚃ", - "ꚅ": "ꚅ", - "ꚇ": "ꚇ", - "ꚉ": "ꚉ", - "ꚋ": "ꚋ", - "ꚍ": "ꚍ", - "ꚏ": "ꚏ", - "ꚑ": "ꚑ", - "ꚓ": "ꚓ", - "ꚕ": "ꚕ", - "ꚗ": "ꚗ", - "ꚙ": "ꚙ", - "ꚛ": "ꚛ", - "ꜣ": "ꜣ", - "ꜥ": "ꜥ", - "ꜧ": "ꜧ", - "ꜩ": "ꜩ", - "ꜫ": "ꜫ", - "ꜭ": "ꜭ", - "ꜯ": "ꜯ", - "ꜳ": "ꜳ", - "ꜵ": "ꜵ", - "ꜷ": "ꜷ", - "ꜹ": "ꜹ", - "ꜻ": "ꜻ", - "ꜽ": "ꜽ", - "ꜿ": "ꜿ", - "ꝁ": "ꝁ", - "ꝃ": "ꝃ", - "ꝅ": "ꝅ", - "ꝇ": "ꝇ", - "ꝉ": "ꝉ", - "ꝋ": "ꝋ", - "ꝍ": "ꝍ", - "ꝏ": "ꝏ", - "ꝑ": "ꝑ", - "ꝓ": "ꝓ", - "ꝕ": "ꝕ", - "ꝗ": "ꝗ", - "ꝙ": "ꝙ", - "ꝛ": "ꝛ", - "ꝝ": "ꝝ", - "ꝟ": "ꝟ", - "ꝡ": "ꝡ", - "ꝣ": "ꝣ", - "ꝥ": "ꝥ", - "ꝧ": "ꝧ", - "ꝩ": "ꝩ", - "ꝫ": "ꝫ", - "ꝭ": "ꝭ", - "ꝯ": "ꝯ", - "ꝺ": "ꝺ", - "ꝼ": "ꝼ", - "ꝿ": "ꝿ", - "ꞁ": "ꞁ", - "ꞃ": "ꞃ", - "ꞅ": "ꞅ", - "ꞇ": "ꞇ", - "ꞌ": "ꞌ", - "ꞑ": "ꞑ", - "ꞓ": "ꞓ", - "ꞔ": "ꞔ", - "ꞗ": "ꞗ", - "ꞙ": "ꞙ", - "ꞛ": "ꞛ", - "ꞝ": "ꞝ", - "ꞟ": "ꞟ", - "ꞡ": "ꞡ", - "ꞣ": "ꞣ", - "ꞥ": "ꞥ", - "ꞧ": "ꞧ", - "ꞩ": "ꞩ", - "ꞵ": "ꞵ", - "ꞷ": "ꞷ", - "ꞹ": "ꞹ", - "ꞻ": "ꞻ", - "ꞽ": "ꞽ", - "ꞿ": "ꞿ", - "ꟃ": "ꟃ", - "ꭓ": "ꭓ", - "ê­°": "ê­°", - "ê­±": "ê­±", - "ê­²": "ê­²", - "ê­³": "ê­³", - "ê­´": "ê­´", - "ê­µ": "ê­µ", - "ê­¶": "ê­¶", - "ê­·": "ê­·", - "ê­¸": "ê­¸", - "ê­¹": "ê­¹", - "ê­º": "ê­º", - "ê­»": "ê­»", - "ê­¼": "ê­¼", - "ê­½": "ê­½", - "ê­¾": "ê­¾", - "ê­¿": "ê­¿", - "ꮀ": "ꮀ", - "ꮁ": "ꮁ", - "ꮂ": "ꮂ", - "ꮃ": "ꮃ", - "ꮄ": "ꮄ", - "ꮅ": "ꮅ", - "ꮆ": "ꮆ", - "ꮇ": "ꮇ", - "ꮈ": "ꮈ", - "ꮉ": "ꮉ", - "ꮊ": "ꮊ", - "ꮋ": "ꮋ", - "ꮌ": "ꮌ", - "ꮍ": "ꮍ", - "ꮎ": "ꮎ", - "ꮏ": "ꮏ", - "ꮐ": "ꮐ", - "ꮑ": "ꮑ", - "ꮒ": "ꮒ", - "ꮓ": "ꮓ", - "ꮔ": "ꮔ", - "ꮕ": "ꮕ", - "ꮖ": "ꮖ", - "ꮗ": "ꮗ", - "ꮘ": "ꮘ", - "ꮙ": "ꮙ", - "ꮚ": "ꮚ", - "ꮛ": "ꮛ", - "ꮜ": "ꮜ", - "ꮝ": "ꮝ", - "ꮞ": "ꮞ", - "ꮟ": "ꮟ", - "ê® ": "ê® ", - "ꮡ": "ꮡ", - "ꮢ": "ꮢ", - "ꮣ": "ꮣ", - "ꮤ": "ꮤ", - "ꮥ": "ꮥ", - "ꮦ": "ꮦ", - "ꮧ": "ꮧ", - "ꮨ": "ꮨ", - "ꮩ": "ꮩ", - "ꮪ": "ꮪ", - "ꮫ": "ꮫ", - "ꮬ": "ꮬ", - "ê®­": "ê®­", - "ê®®": "ê®®", - "ꮯ": "ꮯ", - "ê®°": "ê®°", - "ê®±": "ê®±", - "ꮲ": "ꮲ", - "ꮳ": "ꮳ", - "ê®´": "ê®´", - "ꮵ": "ꮵ", - "ꮶ": "ꮶ", - "ê®·": "ê®·", - "ꮸ": "ꮸ", - "ꮹ": "ꮹ", - "ꮺ": "ꮺ", - "ê®»": "ê®»", - "ꮼ": "ꮼ", - "ꮽ": "ꮽ", - "ꮾ": "ꮾ", - "ꮿ": "ꮿ", - "ff": "ff", - "fi": "fi", - "fl": "fl", - "ffi": "ffi", - "ffl": "ffl", - "ſt": "ſt", - "st": "st", - "ﬓ": "ﬓ", - "ﬔ": "ﬔ", - "ﬕ": "ﬕ", - "ﬖ": "ﬖ", - "ﬗ": "ﬗ", - "𐑎": "𐑎", - "𐑏": "𐑏", - "𐓘": "𐓘", - "𐓙": "𐓙", - "𐓚": "𐓚", - "𐓛": "𐓛", - "𐓜": "𐓜", - "𐓝": "𐓝", - "𐓞": "𐓞", - "𐓟": "𐓟", - "𐓠": "𐓠", - "𐓡": "𐓡", - "𐓢": "𐓢", - "𐓣": "𐓣", - "𐓤": "𐓤", - "𐓥": "𐓥", - "𐓦": "𐓦", - "𐓧": "𐓧", - "𐓨": "𐓨", - "𐓩": "𐓩", - "𐓪": "𐓪", - "𐓫": "𐓫", - "𐓬": "𐓬", - "𐓭": "𐓭", - "𐓮": "𐓮", - "𐓯": "𐓯", - "𐓰": "𐓰", - "𐓱": "𐓱", - "𐓲": "𐓲", - "𐓳": "𐓳", - "𐓴": "𐓴", - "𐓵": "𐓵", - "𐓶": "𐓶", - "𐓷": "𐓷", - "𐓸": "𐓸", - "𐓹": "𐓹", - "𐓺": "𐓺", - "𐓻": "𐓻", - "𐳀": "𐳀", - "𐳁": "𐳁", - "𐳂": "𐳂", - "𐳃": "𐳃", - "𐳄": "𐳄", - "𐳅": "𐳅", - "𐳆": "𐳆", - "𐳇": "𐳇", - "𐳈": "𐳈", - "𐳉": "𐳉", - "𐳊": "𐳊", - "𐳋": "𐳋", - "𐳌": "𐳌", - "𐳍": "𐳍", - "𐳎": "𐳎", - "𐳏": "𐳏", - "𐳐": "𐳐", - "𐳑": "𐳑", - "𐳒": "𐳒", - "𐳓": "𐳓", - "𐳔": "𐳔", - "𐳕": "𐳕", - "𐳖": "𐳖", - "𐳗": "𐳗", - "𐳘": "𐳘", - "𐳙": "𐳙", - "𐳚": "𐳚", - "𐳛": "𐳛", - "𐳜": "𐳜", - "𐳝": "𐳝", - "𐳞": "𐳞", - "𐳟": "𐳟", - "𐳠": "𐳠", - "𐳡": "𐳡", - "𐳢": "𐳢", - "𐳣": "𐳣", - "𐳤": "𐳤", - "𐳥": "𐳥", - "𐳦": "𐳦", - "𐳧": "𐳧", - "𐳨": "𐳨", - "𐳩": "𐳩", - "𐳪": "𐳪", - "𐳫": "𐳫", - "𐳬": "𐳬", - "𐳭": "𐳭", - "𐳮": "𐳮", - "𐳯": "𐳯", - "𐳰": "𐳰", - "𐳱": "𐳱", - "𐳲": "𐳲", - "𑣀": "𑣀", - "𑣁": "𑣁", - "𑣂": "𑣂", - "𑣃": "𑣃", - "𑣄": "𑣄", - "𑣅": "𑣅", - "𑣆": "𑣆", - "𑣇": "𑣇", - "𑣈": "𑣈", - "𑣉": "𑣉", - "𑣊": "𑣊", - "𑣋": "𑣋", - "𑣌": "𑣌", - "𑣍": "𑣍", - "𑣎": "𑣎", - "𑣏": "𑣏", - "𑣐": "𑣐", - "𑣑": "𑣑", - "𑣒": "𑣒", - "𑣓": "𑣓", - "𑣔": "𑣔", - "𑣕": "𑣕", - "𑣖": "𑣖", - "𑣗": "𑣗", - "𑣘": "𑣘", - "𑣙": "𑣙", - "𑣚": "𑣚", - "𑣛": "𑣛", - "𑣜": "𑣜", - "𑣝": "𑣝", - "𑣞": "𑣞", - "𑣟": "𑣟", - "𖹠": "𖹠", - "𖹡": "𖹡", - "𖹢": "𖹢", - "𖹣": "𖹣", - "𖹤": "𖹤", - "𖹥": "𖹥", - "𖹦": "𖹦", - "𖹧": "𖹧", - "𖹨": "𖹨", - "𖹩": "𖹩", - "𖹪": "𖹪", - "𖹫": "𖹫", - "𖹬": "𖹬", - "𖹭": "𖹭", - "𖹮": "𖹮", - "𖹯": "𖹯", - "𖹰": "𖹰", - "𖹱": "𖹱", - "𖹲": "𖹲", - "𖹳": "𖹳", - "𖹴": "𖹴", - "𖹵": "𖹵", - "𖹶": "𖹶", - "𖹷": "𖹷", - "𖹸": "𖹸", - "𖹹": "𖹹", - "𖹺": "𖹺", - "𖹻": "𖹻", - "𖹼": "𖹼", - "𖹽": "𖹽", - "𖹾": "𖹾", - "𖹿": "𖹿", - "𞤢": "𞤢", - "𞤣": "𞤣", - "𞤤": "𞤤", - "𞤥": "𞤥", - "𞤦": "𞤦", - "𞤧": "𞤧", - "𞤨": "𞤨", - "𞤩": "𞤩", - "𞤪": "𞤪", - "𞤫": "𞤫", - "𞤬": "𞤬", - "𞤭": "𞤭", - "𞤮": "𞤮", - "𞤯": "𞤯", - "𞤰": "𞤰", - "𞤱": "𞤱", - "𞤲": "𞤲", - "𞤳": "𞤳", - "𞤴": "𞤴", - "𞤵": "𞤵", - "𞤶": "𞤶", - "𞤷": "𞤷", - "𞤸": "𞤸", - "𞤹": "𞤹", - "𞤺": "𞤺", - "𞤻": "𞤻", - "𞤼": "𞤼", - "𞤽": "𞤽", - "𞤾": "𞤾", - "𞤿": "𞤿", - "𞥀": "𞥀", - "𞥁": "𞥁", - "𞥂": "𞥂", - "𞥃": "𞥃" + "á¿´": "", + "ῶ": "", + "á¿·": "", + "ῼ": "", + "ⅎ": "", + "ⅰ": "", + "ⅱ": "", + "ⅲ": "", + "ⅳ": "", + "ⅴ": "", + "ⅵ": "", + "ⅶ": "", + "ⅷ": "", + "ⅸ": "", + "ⅹ": "", + "ⅺ": "", + "ⅻ": "", + "ⅼ": "", + "ⅽ": "", + "ⅾ": "", + "ⅿ": "", + "ↄ": "", + "ⓐ": "", + "ⓑ": "", + "ⓒ": "", + "ⓓ": "", + "ⓔ": "", + "ⓕ": "", + "ⓖ": "", + "ⓗ": "", + "ⓘ": "", + "ⓙ": "", + "ⓚ": "", + "ⓛ": "", + "ⓜ": "", + "ⓝ": "", + "ⓞ": "", + "ⓟ": "", + "ⓠ": "", + "ⓡ": "", + "ⓢ": "", + "ⓣ": "", + "ⓤ": "", + "ⓥ": "", + "ⓦ": "", + "ⓧ": "", + "ⓨ": "", + "ⓩ": "", + "â°°": "", + "â°±": "", + "â°²": "", + "â°³": "", + "â°´": "", + "â°µ": "", + "â°¶": "", + "â°·": "", + "â°¸": "", + "â°¹": "", + "â°º": "", + "â°»": "", + "â°¼": "", + "â°½": "", + "â°¾": "", + "â°¿": "", + "ⱀ": "", + "ⱁ": "", + "ⱂ": "", + "ⱃ": "", + "ⱄ": "", + "ⱅ": "", + "ⱆ": "", + "ⱇ": "", + "ⱈ": "", + "ⱉ": "", + "ⱊ": "", + "ⱋ": "", + "ⱌ": "", + "ⱍ": "", + "ⱎ": "", + "ⱏ": "", + "ⱐ": "", + "ⱑ": "", + "ⱒ": "", + "ⱓ": "", + "ⱔ": "", + "ⱕ": "", + "ⱖ": "", + "ⱗ": "", + "ⱘ": "", + "ⱙ": "", + "ⱚ": "", + "ⱛ": "", + "ⱜ": "", + "ⱝ": "", + "ⱞ": "", + "ⱡ": "", + "â±¥": "", + "ⱦ": "", + "ⱨ": "", + "ⱪ": "", + "ⱬ": "", + "â±³": "", + "ⱶ": "", + "ⲁ": "", + "ⲃ": "", + "ⲅ": "", + "ⲇ": "", + "ⲉ": "", + "ⲋ": "", + "ⲍ": "", + "ⲏ": "", + "ⲑ": "", + "ⲓ": "", + "ⲕ": "", + "ⲗ": "", + "ⲙ": "", + "ⲛ": "", + "ⲝ": "", + "ⲟ": "", + "ⲡ": "", + "â²£": "", + "â²¥": "", + "ⲧ": "", + "ⲩ": "", + "ⲫ": "", + "â²­": "", + "ⲯ": "", + "â²±": "", + "â²³": "", + "â²µ": "", + "â²·": "", + "â²¹": "", + "â²»": "", + "â²½": "", + "ⲿ": "", + "ⳁ": "", + "ⳃ": "", + "ⳅ": "", + "ⳇ": "", + "ⳉ": "", + "ⳋ": "", + "ⳍ": "", + "ⳏ": "", + "ⳑ": "", + "ⳓ": "", + "ⳕ": "", + "ⳗ": "", + "ⳙ": "", + "ⳛ": "", + "ⳝ": "", + "ⳟ": "", + "ⳡ": "", + "â³£": "", + "ⳬ": "", + "â³®": "", + "â³³": "", + "ⴀ": "", + "ⴁ": "", + "ⴂ": "", + "ⴃ": "", + "ⴄ": "", + "ⴅ": "", + "ⴆ": "", + "ⴇ": "", + "ⴈ": "", + "ⴉ": "", + "ⴊ": "", + "ⴋ": "", + "ⴌ": "", + "ⴍ": "", + "ⴎ": "", + "ⴏ": "", + "ⴐ": "", + "ⴑ": "", + "ⴒ": "", + "ⴓ": "", + "ⴔ": "", + "ⴕ": "", + "ⴖ": "", + "ⴗ": "", + "ⴘ": "", + "ⴙ": "", + "ⴚ": "", + "ⴛ": "", + "ⴜ": "", + "ⴝ": "", + "ⴞ": "", + "ⴟ": "", + "â´ ": "", + "â´¡": "", + "â´¢": "", + "â´£": "", + "â´¤": "", + "â´¥": "", + "â´§": "", + "â´­": "", + "ꙁ": "", + "ꙃ": "", + "ꙅ": "", + "ꙇ": "", + "ꙉ": "", + "ꙋ": "", + "ꙍ": "", + "ꙏ": "", + "ꙑ": "", + "ꙓ": "", + "ꙕ": "", + "ꙗ": "", + "ꙙ": "", + "ꙛ": "", + "ꙝ": "", + "ꙟ": "", + "ꙡ": "", + "ꙣ": "", + "ꙥ": "", + "ꙧ": "", + "ꙩ": "", + "ꙫ": "", + "ꙭ": "", + "ꚁ": "", + "ꚃ": "", + "ꚅ": "", + "ꚇ": "", + "ꚉ": "", + "ꚋ": "", + "ꚍ": "", + "ꚏ": "", + "ꚑ": "", + "ꚓ": "", + "ꚕ": "", + "ꚗ": "", + "ꚙ": "", + "ꚛ": "", + "ꜣ": "", + "ꜥ": "", + "ꜧ": "", + "ꜩ": "", + "ꜫ": "", + "ꜭ": "", + "ꜯ": "", + "ꜳ": "", + "ꜵ": "", + "ꜷ": "", + "ꜹ": "", + "ꜻ": "", + "ꜽ": "", + "ꜿ": "", + "ꝁ": "", + "ꝃ": "", + "ꝅ": "", + "ꝇ": "", + "ꝉ": "", + "ꝋ": "", + "ꝍ": "", + "ꝏ": "", + "ꝑ": "", + "ꝓ": "", + "ꝕ": "", + "ꝗ": "", + "ꝙ": "", + "ꝛ": "", + "ꝝ": "", + "ꝟ": "", + "ꝡ": "", + "ꝣ": "", + "ꝥ": "", + "ꝧ": "", + "ꝩ": "", + "ꝫ": "", + "ꝭ": "", + "ꝯ": "", + "ꝺ": "", + "ꝼ": "", + "ꝿ": "", + "ꞁ": "", + "ꞃ": "", + "ꞅ": "", + "ꞇ": "", + "ꞌ": "", + "ꞑ": "", + "ꞓ": "", + "ꞔ": "", + "ꞗ": "", + "ꞙ": "", + "ꞛ": "", + "ꞝ": "", + "ꞟ": "", + "ꞡ": "", + "ꞣ": "", + "ꞥ": "", + "ꞧ": "", + "ꞩ": "", + "ꞵ": "", + "ꞷ": "", + "ꞹ": "", + "ꞻ": "", + "ꞽ": "", + "ꞿ": "", + "ꟃ": "", + "ꭓ": "", + "ê­°": "", + "ê­±": "", + "ê­²": "", + "ê­³": "", + "ê­´": "", + "ê­µ": "", + "ê­¶": "", + "ê­·": "", + "ê­¸": "", + "ê­¹": "", + "ê­º": "", + "ê­»": "", + "ê­¼": "", + "ê­½": "", + "ê­¾": "", + "ê­¿": "", + "ꮀ": "", + "ꮁ": "", + "ꮂ": "", + "ꮃ": "", + "ꮄ": "", + "ꮅ": "", + "ꮆ": "", + "ꮇ": "", + "ꮈ": "", + "ꮉ": "", + "ꮊ": "", + "ꮋ": "", + "ꮌ": "", + "ꮍ": "", + "ꮎ": "", + "ꮏ": "", + "ꮐ": "", + "ꮑ": "", + "ꮒ": "", + "ꮓ": "", + "ꮔ": "", + "ꮕ": "", + "ꮖ": "", + "ꮗ": "", + "ꮘ": "", + "ꮙ": "", + "ꮚ": "", + "ꮛ": "", + "ꮜ": "", + "ꮝ": "", + "ꮞ": "", + "ꮟ": "", + "ê® ": "", + "ꮡ": "", + "ꮢ": "", + "ꮣ": "", + "ꮤ": "", + "ꮥ": "", + "ꮦ": "", + "ꮧ": "", + "ꮨ": "", + "ꮩ": "", + "ꮪ": "", + "ꮫ": "", + "ꮬ": "", + "ê®­": "", + "ê®®": "", + "ꮯ": "", + "ê®°": "", + "ê®±": "", + "ꮲ": "", + "ꮳ": "", + "ê®´": "", + "ꮵ": "", + "ꮶ": "", + "ê®·": "", + "ꮸ": "", + "ꮹ": "", + "ꮺ": "", + "ê®»": "", + "ꮼ": "", + "ꮽ": "", + "ꮾ": "", + "ꮿ": "", + "ff": "", + "fi": "", + "fl": "", + "ffi": "", + "ffl": "", + "ſt": "", + "st": "", + "ﬓ": "", + "ﬔ": "", + "ﬕ": "", + "ﬖ": "", + "ﬗ": "", + "𐑎": "", + "𐑏": "", + "𐓘": "", + "𐓙": "", + "𐓚": "", + "𐓛": "", + "𐓜": "", + "𐓝": "", + "𐓞": "", + "𐓟": "", + "𐓠": "", + "𐓡": "", + "𐓢": "", + "𐓣": "", + "𐓤": "", + "𐓥": "", + "𐓦": "", + "𐓧": "", + "𐓨": "", + "𐓩": "", + "𐓪": "", + "𐓫": "", + "𐓬": "", + "𐓭": "", + "𐓮": "", + "𐓯": "", + "𐓰": "", + "𐓱": "", + "𐓲": "", + "𐓳": "", + "𐓴": "", + "𐓵": "", + "𐓶": "", + "𐓷": "", + "𐓸": "", + "𐓹": "", + "𐓺": "", + "𐓻": "", + "𐳀": "", + "𐳁": "", + "𐳂": "", + "𐳃": "", + "𐳄": "", + "𐳅": "", + "𐳆": "", + "𐳇": "", + "𐳈": "", + "𐳉": "", + "𐳊": "", + "𐳋": "", + "𐳌": "", + "𐳍": "", + "𐳎": "", + "𐳏": "", + "𐳐": "", + "𐳑": "", + "𐳒": "", + "𐳓": "", + "𐳔": "", + "𐳕": "", + "𐳖": "", + "𐳗": "", + "𐳘": "", + "𐳙": "", + "𐳚": "", + "𐳛": "", + "𐳜": "", + "𐳝": "", + "𐳞": "", + "𐳟": "", + "𐳠": "", + "𐳡": "", + "𐳢": "", + "𐳣": "", + "𐳤": "", + "𐳥": "", + "𐳦": "", + "𐳧": "", + "𐳨": "", + "𐳩": "", + "𐳪": "", + "𐳫": "", + "𐳬": "", + "𐳭": "", + "𐳮": "", + "𐳯": "", + "𐳰": "", + "𐳱": "", + "𐳲": "", + "𑣀": "", + "𑣁": "", + "𑣂": "", + "𑣃": "", + "𑣄": "", + "𑣅": "", + "𑣆": "", + "𑣇": "", + "𑣈": "", + "𑣉": "", + "𑣊": "", + "𑣋": "", + "𑣌": "", + "𑣍": "", + "𑣎": "", + "𑣏": "", + "𑣐": "", + "𑣑": "", + "𑣒": "", + "𑣓": "", + "𑣔": "", + "𑣕": "", + "𑣖": "", + "𑣗": "", + "𑣘": "", + "𑣙": "", + "𑣚": "", + "𑣛": "", + "𑣜": "", + "𑣝": "", + "𑣞": "", + "𑣟": "", + "𖹠": "", + "𖹡": "", + "𖹢": "", + "𖹣": "", + "𖹤": "", + "𖹥": "", + "𖹦": "", + "𖹧": "", + "𖹨": "", + "𖹩": "", + "𖹪": "", + "𖹫": "", + "𖹬": "", + "𖹭": "", + "𖹮": "", + "𖹯": "", + "𖹰": "", + "𖹱": "", + "𖹲": "", + "𖹳": "", + "𖹴": "", + "𖹵": "", + "𖹶": "", + "𖹷": "", + "𖹸": "", + "𖹹": "", + "𖹺": "", + "𖹻": "", + "𖹼": "", + "𖹽": "", + "𖹾": "", + "𖹿": "", + "𞤢": "", + "𞤣": "", + "𞤤": "", + "𞤥": "", + "𞤦": "", + "𞤧": "", + "𞤨": "", + "𞤩": "", + "𞤪": "", + "𞤫": "", + "𞤬": "", + "𞤭": "", + "𞤮": "", + "𞤯": "", + "𞤰": "", + "𞤱": "", + "𞤲": "", + "𞤳": "", + "𞤴": "", + "𞤵": "", + "𞤶": "", + "𞤷": "", + "𞤸": "", + "𞤹": "", + "𞤺": "", + "𞤻": "", + "𞤼": "", + "𞤽": "", + "𞤾": "", + "𞤿": "", + "𞥀": "", + "𞥁": "", + "𞥂": "", + "𞥃": "" } diff --git a/resources/src/mediawiki.htmlform.checker.js b/resources/src/mediawiki.htmlform.checker.js index 33207d49a7..473635a53e 100644 --- a/resources/src/mediawiki.htmlform.checker.js +++ b/resources/src/mediawiki.htmlform.checker.js @@ -3,14 +3,6 @@ // FIXME: mw.htmlform.Element also sets this to empty object mw.htmlform = {}; - function debounce( delay, callback ) { - var timeout; - return function () { - clearTimeout( timeout ); - timeout = setTimeout( Function.prototype.apply.bind( callback, this, arguments ), delay ); - }; - } - /** * @class mw.htmlform.Checker */ @@ -60,7 +52,7 @@ if ( $extraElements ) { $e = $e.add( $extraElements ); } - $e.on( events, debounce( 1000, this.validate.bind( this ) ) ); + $e.on( events, mw.util.debounce( 1000, this.validate.bind( this ) ) ); return this; }; diff --git a/resources/src/mediawiki.legacy/shared.css b/resources/src/mediawiki.legacy/shared.css index 3b99696e9f..13ef390c25 100644 --- a/resources/src/mediawiki.legacy/shared.css +++ b/resources/src/mediawiki.legacy/shared.css @@ -354,7 +354,7 @@ a.new { font-weight: bold; } -/* Error, warning and success messages */ +/* Error, warning, success and neutral messages */ .error, .warning, .success { @@ -373,41 +373,45 @@ a.new { color: #14866d; } +.messagebox, .errorbox, .warningbox, .successbox { + color: #000; + margin-bottom: 1em; border: 1px solid; padding: 0.5em 1em; - margin-bottom: 1em; - display: inline-block; } +.messagebox h2, .errorbox h2, .warningbox h2, .successbox h2 { color: inherit; - font-size: 1em; - font-weight: bold; display: inline; margin: 0 0.5em 0 0; border: 0; + font-size: 1em; + font-weight: bold; +} + +.messagebox { + background-color: #eaecf0; + border-color: #a2a9b1; } .errorbox { background-color: #fee7e6; - color: #000; border-color: #d33; } .warningbox { background-color: #fef6e7; - color: #000; border-color: #fc3; } .successbox { background-color: #d5fdf4; - color: #000; border-color: #14866d; } @@ -431,15 +435,9 @@ a.new { /* Note on preview page */ .previewnote { - color: #d33; margin-bottom: 1em; } -.previewnote p { - text-indent: 3em; - margin: 0.8em 0; -} - .visualClear { clear: both; } diff --git a/resources/src/mediawiki.page.gallery.slideshow.js b/resources/src/mediawiki.page.gallery.slideshow.js index 667c2ba21b..a36e409aa5 100644 --- a/resources/src/mediawiki.page.gallery.slideshow.js +++ b/resources/src/mediawiki.page.gallery.slideshow.js @@ -24,7 +24,7 @@ this.drawCarousel(); this.setSizeRequirement(); this.toggleThumbnails( !!this.$gallery.attr( 'data-showthumbnails' ) ); - this.showCurrentImage(); + this.showCurrentImage( true ); // Events $( window ).on( @@ -229,8 +229,10 @@ /** * Displays the image set as {@link #$currentImage} in the carousel. + * + * @param {boolean} init Image being show during gallery init (i.e. first image) */ - mw.GallerySlideshow.prototype.showCurrentImage = function () { + mw.GallerySlideshow.prototype.showCurrentImage = function ( init ) { var $thumbnail, $imgLink, $imageLi = this.getCurrentImage(), $caption = $imageLi.find( '.gallerytext' ); @@ -279,7 +281,10 @@ if ( this.$thumbnail.attr( 'src' ) === $thumbnail.attr( 'src' ) ) { this.$img.attr( 'src', info.thumburl ); this.setImageSize(); - mw.hook( 'wikipage.content' ).fire( this.$imgContainer ); + // Don't fire hook twice during init + if ( !init ) { + mw.hook( 'wikipage.content' ).fire( this.$imgContainer ); + } // Pre-fetch the next image this.loadImage( this.getNextImage().find( 'img' ) ); diff --git a/resources/src/mediawiki.page.image.pagination.js b/resources/src/mediawiki.page.image.pagination.js index 4541c582ad..a0ac0ca84a 100644 --- a/resources/src/mediawiki.page.image.pagination.js +++ b/resources/src/mediawiki.page.image.pagination.js @@ -105,7 +105,7 @@ // Generate the same URL on client side as the one generated in ImagePage::openShowImage. // We avoid using the URL in the link directly since it could have been manipulated (T68608) page = Number( mw.util.getParamValue( 'page', this.href ) ); - url = mw.util.getUrl( mw.config.get( 'wgPageName' ), { page: page } ); + url = mw.util.getUrl( null, { page: page } ); switchPage( url ); e.preventDefault(); diff --git a/resources/src/mediawiki.page.ready.js b/resources/src/mediawiki.page.ready.js deleted file mode 100644 index 0e59da624b..0000000000 --- a/resources/src/mediawiki.page.ready.js +++ /dev/null @@ -1,82 +0,0 @@ -( function () { - mw.hook( 'wikipage.content' ).add( function ( $content ) { - var $sortable, $collapsible; - - $collapsible = $content.find( '.mw-collapsible' ); - if ( $collapsible.length ) { - // Preloaded by Skin::getDefaultModules() - mw.loader.using( 'jquery.makeCollapsible', function () { - $collapsible.makeCollapsible(); - } ); - } - - $sortable = $content.find( 'table.sortable' ); - if ( $sortable.length ) { - // Preloaded by Skin::getDefaultModules() - mw.loader.using( 'jquery.tablesorter', function () { - $sortable.tablesorter(); - } ); - } - - // Run jquery.checkboxShiftClick - $content.find( 'input[type="checkbox"]:not(.noshiftselect)' ).checkboxShiftClick(); - } ); - - // Things outside the wikipage content - $( function () { - var $nodes; - - // Add accesskey hints to the tooltips - $( '[accesskey]' ).updateTooltipAccessKeys(); - - $nodes = $( '.catlinks[data-mw="interface"]' ); - if ( $nodes.length ) { - /** - * Fired when categories are being added to the DOM - * - * It is encouraged to fire it before the main DOM is changed (when $content - * is still detached). However, this order is not defined either way, so you - * should only rely on $content itself. - * - * This includes the ready event on a page load (including post-edit loads) - * and when content has been previewed with LivePreview. - * - * @event wikipage_categories - * @member mw.hook - * @param {jQuery} $content The most appropriate element containing the content, - * such as .catlinks - */ - mw.hook( 'wikipage.categories' ).fire( $nodes ); - } - - $( '#t-print a' ).on( 'click', function ( e ) { - window.print(); - e.preventDefault(); - } ); - - // Turn logout to a POST action - $( '#pt-logout a' ).on( 'click', function ( e ) { - var api = new mw.Api(), - returnUrl = $( '#pt-logout a' ).attr( 'href' ); - mw.notify( - mw.message( 'logging-out-notify' ), - { tag: 'logout', autoHide: false } - ); - api.postWithToken( 'csrf', { - action: 'logout' - } ).then( - function () { - location.href = returnUrl; - }, - function ( e ) { - mw.notify( - mw.message( 'logout-failed', e ), - { type: 'error', tag: 'logout', autoHide: false } - ); - } - ); - e.preventDefault(); - } ); - } ); - -}() ); diff --git a/resources/src/mediawiki.page.ready/.eslintrc.json b/resources/src/mediawiki.page.ready/.eslintrc.json new file mode 100644 index 0000000000..ad8dbb3e85 --- /dev/null +++ b/resources/src/mediawiki.page.ready/.eslintrc.json @@ -0,0 +1,5 @@ +{ + "parserOptions": { + "sourceType": "module" + } +} diff --git a/resources/src/mediawiki.page.ready/checkboxShift.js b/resources/src/mediawiki.page.ready/checkboxShift.js new file mode 100644 index 0000000000..86e0ec2360 --- /dev/null +++ b/resources/src/mediawiki.page.ready/checkboxShift.js @@ -0,0 +1,33 @@ +/** + * @private + * @class mw.plugin.pageready + */ +/** + * Enable checkboxes to be checked or unchecked in a row by clicking one, + * holding shift and clicking another one. + * + * @method checkboxShift + * @param {jQuery} $box + */ +module.exports = function ( $box ) { + var prev; + // When our boxes are clicked.. + $box.on( 'click', function ( e ) { + // And one has been clicked before... + if ( prev && e.shiftKey ) { + // Check or uncheck this one and all in-between checkboxes, + // except for disabled ones + $box + .slice( + Math.min( $box.index( prev ), $box.index( e.target ) ), + Math.max( $box.index( prev ), $box.index( e.target ) ) + 1 + ) + .filter( function () { + return !this.disabled; + } ) + .prop( 'checked', e.target.checked ); + } + // Either way, remember this as the last clicked one + prev = e.target; + } ); +}; diff --git a/resources/src/mediawiki.page.ready/ready.js b/resources/src/mediawiki.page.ready/ready.js new file mode 100644 index 0000000000..48d605d455 --- /dev/null +++ b/resources/src/mediawiki.page.ready/ready.js @@ -0,0 +1,79 @@ +var checkboxShift = require( './checkboxShift.js' ); +mw.hook( 'wikipage.content' ).add( function ( $content ) { + var $sortable, $collapsible; + + $collapsible = $content.find( '.mw-collapsible' ); + if ( $collapsible.length ) { + // Preloaded by Skin::getDefaultModules() + mw.loader.using( 'jquery.makeCollapsible', function () { + $collapsible.makeCollapsible(); + } ); + } + + $sortable = $content.find( 'table.sortable' ); + if ( $sortable.length ) { + // Preloaded by Skin::getDefaultModules() + mw.loader.using( 'jquery.tablesorter', function () { + $sortable.tablesorter(); + } ); + } + + checkboxShift( $content.find( 'input[type="checkbox"]:not(.noshiftselect)' ) ); +} ); + +// Handle elements outside the wikipage content +$( function () { + var $nodes; + + // Add accesskey hints to the tooltips + $( '[accesskey]' ).updateTooltipAccessKeys(); + + $nodes = $( '.catlinks[data-mw="interface"]' ); + if ( $nodes.length ) { + /** + * Fired when categories are being added to the DOM + * + * It is encouraged to fire it before the main DOM is changed (when $content + * is still detached). However, this order is not defined either way, so you + * should only rely on $content itself. + * + * This includes the ready event on a page load (including post-edit loads) + * and when content has been previewed with LivePreview. + * + * @event wikipage_categories + * @member mw.hook + * @param {jQuery} $content The most appropriate element containing the content, + * such as .catlinks + */ + mw.hook( 'wikipage.categories' ).fire( $nodes ); + } + + $( '#t-print a' ).on( 'click', function ( e ) { + window.print(); + e.preventDefault(); + } ); + + // Turn logout to a POST action + $( '#pt-logout a' ).on( 'click', function ( e ) { + var api = new mw.Api(), + url = this.href; + mw.notify( + mw.message( 'logging-out-notify' ), + { tag: 'logout', autoHide: false } + ); + api.postWithToken( 'csrf', { + action: 'logout' + } ).then( + function () { + location.href = url; + }, + function ( err ) { + mw.notify( + mw.message( 'logout-failed', err ), + { type: 'error', tag: 'logout', autoHide: false } + ); + } + ); + e.preventDefault(); + } ); +} ); diff --git a/resources/src/mediawiki.special/listFiles.less b/resources/src/mediawiki.special/listFiles.less new file mode 100644 index 0000000000..c54eb0902e --- /dev/null +++ b/resources/src/mediawiki.special/listFiles.less @@ -0,0 +1,43 @@ +@import 'mediawiki.ui/variables'; + +// On mobile devices the table layout is collapsed. +@media all and ( max-width: @width-breakpoint-tablet ) { + .mw-special-Listfiles { + // stylelint-disable selector-class-pattern + thead, + .TablePager_col_count, + .TablePager_col_img_size, + .TablePager_col_img_name, + .TablePager_col_img_timestamp { + display: none; + } + + tbody, + tr, + td, + .mw-datatable, + .TablePager_col_img_description, + .TablePager_col_thumb { + display: block; + } + + .mw-datatable, + .mw-datatable th, + .mw-datatable td { + border: 0; + } + + .TablePager_col_img_user_text, + .TablePager_col_img_description { + color: @colorGray5; + margin: 0.5em 0 0; + padding-bottom: 40px; + line-height: 1.5; + } + + .TablePager_col_img_user_text { + padding: 0; + } + // stylelint-enable selector-class-pattern + } +} diff --git a/resources/src/mediawiki.ui/components/forms.less b/resources/src/mediawiki.ui/components/forms.less index 01318c936d..1d364ce04e 100644 --- a/resources/src/mediawiki.ui/components/forms.less +++ b/resources/src/mediawiki.ui/components/forms.less @@ -84,13 +84,11 @@ // // Markup: //
- //
An error occurred
+ //
+ //
  • An error occurred. There are problems with some of your input.
+ //
//
A warning to be noted
//
Action successful!
- //
A different kind of error
- //
- //
  • There are problems with some of your input.
- //
//
// //
@@ -107,8 +105,6 @@ //
// // Styleguide 5.2. - .error, - .warning, .errorbox, .warningbox, .successbox { @@ -119,27 +115,12 @@ word-wrap: break-word; } - // Colours taken from those for .errorbox in shared.css - .error { - background-color: @backgroundColorError; - color: @colorTextEmphasized; - border: 1px solid @borderColorError; - } - - // Colours taken from those for .warningbox in shared.css - .warning { - background-color: @backgroundColorWarning; - color: @colorTextEmphasized; - border: 1px solid @borderColorWarning; - } - // This specifies styling for individual field validation error messages. // Show them below the fields to prevent line break glitches, and leave // some space between the field and the error message box. .mw-ui-vform-field { - .error, - .warning { - display: block; + .errorbox, + .warningbox { margin-top: 5px; } } diff --git a/resources/src/mediawiki.util/util.js b/resources/src/mediawiki.util/util.js index e8823e1249..85216649e0 100644 --- a/resources/src/mediawiki.util/util.js +++ b/resources/src/mediawiki.util/util.js @@ -13,8 +13,7 @@ require( './jquery.accessKeyLabel.js' ); * @return {string} Encoded string */ function rawurlencode( str ) { - str = String( str ); - return encodeURIComponent( str ) + return encodeURIComponent( String( str ) ) .replace( /!/g, '%21' ).replace( /'/g, '%27' ).replace( /\(/g, '%28' ) .replace( /\)/g, '%29' ).replace( /\*/g, '%2A' ).replace( /~/g, '%7E' ); } @@ -59,33 +58,50 @@ util = { rawurlencode: rawurlencode, /** - * Encode string into HTML id compatible form suitable for use in HTML - * Analog to PHP Sanitizer::escapeIdForAttribute() + * Encode a string as CSS id, for use as HTML id attribute value. * - * @since 1.30 + * Analog to `Sanitizer::escapeIdForAttribute()` in PHP. * + * @since 1.30 * @param {string} str String to encode * @return {string} Encoded string */ escapeIdForAttribute: function ( str ) { - var mode = config.FragmentMode[ 0 ]; - - return escapeIdInternal( str, mode ); + return escapeIdInternal( str, config.FragmentMode[ 0 ] ); }, /** - * Encode string into HTML id compatible form suitable for use in links - * Analog to PHP Sanitizer::escapeIdForLink() + * Encode a string as URL fragment, for use as HTML anchor link. * - * @since 1.30 + * Analog to `Sanitizer::escapeIdForLink()` in PHP. * + * @since 1.30 * @param {string} str String to encode * @return {string} Encoded string */ escapeIdForLink: function ( str ) { - var mode = config.FragmentMode[ 0 ]; + return escapeIdInternal( str, config.FragmentMode[ 0 ] ); + }, - return escapeIdInternal( str, mode ); + /** + * Return a wrapper function that is debounced for the given duration. + * + * When it is first called, a timeout is scheduled. If before the timer + * is reached the wrapper is called again, it gets rescheduled for the + * same duration from now until it stops being called. The original function + * is called from the "tail" of such chain, with the last set of arguments. + * + * @since 1.34 + * @param {number} delay Time in milliseconds + * @param {Function} callback + * @return {Function} + */ + debounce: function ( delay, callback ) { + var timeout; + return function () { + clearTimeout( timeout ); + timeout = setTimeout( Function.prototype.apply.bind( callback, this, arguments ), delay ); + }; }, /** @@ -126,16 +142,15 @@ util = { * @return {string} Url of the page with name of `pageName` */ getUrl: function ( pageName, params ) { - var titleFragmentStart, url, query, - fragment = '', + var fragmentIdx, url, query, fragment, title = typeof pageName === 'string' ? pageName : mw.config.get( 'wgPageName' ); // Find any fragment - titleFragmentStart = title.indexOf( '#' ); - if ( titleFragmentStart !== -1 ) { - fragment = title.slice( titleFragmentStart + 1 ); + fragmentIdx = title.indexOf( '#' ); + if ( fragmentIdx !== -1 ) { + fragment = title.slice( fragmentIdx + 1 ); // Exclude the fragment from the page name - title = title.slice( 0, titleFragmentStart ); + title = title.slice( 0, fragmentIdx ); } // Produce query string @@ -152,7 +167,7 @@ util = { } // Append the encoded fragment - if ( fragment.length ) { + if ( fragment && fragment.length ) { url += '#' + util.escapeIdForLink( fragment ); } @@ -160,16 +175,14 @@ util = { }, /** - * Get address to a script in the wiki root. - * For index.php use `mw.config.get( 'wgScript' )`. + * Get URL to a MediaWiki entry point. * * @since 1.18 - * @param {string} str Name of script (e.g. 'api'), defaults to 'index' - * @return {string} Address to script (e.g. '/w/api.php' ) + * @param {string} [str="index"] Name of MW entry point (e.g. 'index' or 'api') + * @return {string} URL to the script file (e.g. '/w/api.php' ) */ wikiScript: function ( str ) { - str = str || 'index'; - if ( str === 'index' ) { + if ( !str || str === 'index' ) { return mw.config.get( 'wgScript' ); } else if ( str === 'load' ) { return config.LoadScript; @@ -195,7 +208,7 @@ util = { */ addCSS: function ( text ) { var s = mw.loader.addStyleTag( text ); - return s.sheet || s.styleSheet || s; + return s.sheet; }, /** @@ -440,15 +453,15 @@ util = { * @return {boolean} */ isIPv4Address: function ( address, allowBlock ) { - var block, RE_IP_BYTE, RE_IP_ADD; + var block, + RE_IP_BYTE = '(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|0?[0-9]?[0-9])', + RE_IP_ADD = '(?:' + RE_IP_BYTE + '\\.){3}' + RE_IP_BYTE; if ( typeof address !== 'string' ) { return false; } block = allowBlock ? '(?:\\/(?:3[0-2]|[12]?\\d))?' : ''; - RE_IP_BYTE = '(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|0?[0-9]?[0-9])'; - RE_IP_ADD = '(?:' + RE_IP_BYTE + '\\.){3}' + RE_IP_BYTE; return ( new RegExp( '^' + RE_IP_ADD + block + '$' ).test( address ) ); }, diff --git a/tests/parser/parserTests.txt b/tests/parser/parserTests.txt index d563235cc0..4f78be4a9a 100644 --- a/tests/parser/parserTests.txt +++ b/tests/parser/parserTests.txt @@ -9251,7 +9251,7 @@ Template parameter named "constructor" !! wikitext {{echo| constructor = |hi}} !! html/parsoid -

hi

+

hi

!! end !! article @@ -25601,7 +25601,7 @@ __TOC__ !! article MediaWiki:T34057 !! text -== {{int:headline_sample}} == +== {{int:ok}} == !! endarticle !! test @@ -25611,7 +25611,7 @@ title=[[Main Page]] !! wikitext {{int:T34057}} !! html -

Headline text[edit]

+

OK[edit]

!! end !! test diff --git a/tests/phpunit/MediaWikiCoversValidator.php b/tests/phpunit/MediaWikiCoversValidator.php index ce3f2e281d..ca400bf8aa 100644 --- a/tests/phpunit/MediaWikiCoversValidator.php +++ b/tests/phpunit/MediaWikiCoversValidator.php @@ -45,6 +45,6 @@ trait MediaWikiCoversValidator { } } - $this->assertEquals( '', $bad ); + $this->assertSame( '', $bad ); } } diff --git a/tests/phpunit/MediaWikiIntegrationTestCase.php b/tests/phpunit/MediaWikiIntegrationTestCase.php index b738312725..27cbed593b 100644 --- a/tests/phpunit/MediaWikiIntegrationTestCase.php +++ b/tests/phpunit/MediaWikiIntegrationTestCase.php @@ -1821,22 +1821,30 @@ abstract class MediaWikiIntegrationTestCase extends PHPUnit\Framework\TestCase { /** * Empty all tables so they can be repopulated for tests * - * @param Database $db|null Database to reset - * @param array $tablesUsed Tables to reset + * @param IDatabase $db|null Database to reset + * @param string[] $tablesUsed Tables to reset */ - private function resetDB( $db, $tablesUsed ) { + private function resetDB( IDatabase $db = null, array $tablesUsed ) { if ( $db ) { - $userTables = [ 'user', 'user_groups', 'user_properties', 'actor' ]; - $pageTables = [ - 'page', 'revision', 'ip_changes', 'revision_comment_temp', 'comment', 'archive', - 'revision_actor_temp', 'slots', 'content', 'content_models', 'slot_roles', - 'change_tag', + // some groups of tables are connected such that if any is used, all should be cleared + $extraTables = [ + 'user' => [ 'user', 'user_groups', 'user_properties', 'actor' ], + 'page' => [ 'page', 'revision', 'ip_changes', 'revision_comment_temp', 'comment', 'archive', + 'revision_actor_temp', 'slots', 'content', 'content_models', 'slot_roles', + 'change_tag' ], + 'logging' => [ 'logging', 'log_search', 'change_tag' ], ]; - $coreDBDataTables = array_merge( $userTables, $pageTables ); + $coreDBDataTables = array_merge( $extraTables['user'], $extraTables['page'] ); - // If any of the user or page tables were marked as used, we should clear all of them. - if ( array_intersect( $tablesUsed, $userTables ) ) { - $tablesUsed = array_unique( array_merge( $tablesUsed, $userTables ) ); + foreach ( $extraTables as $i => $group ) { + if ( !array_intersect( $tablesUsed, $group ) ) { + unset( $extraTables[$i] ); + } + } + $extraTables = array_values( $extraTables ); + $tablesUsed = array_unique( array_merge( $tablesUsed, ...$extraTables ) ); + + if ( in_array( 'user', $tablesUsed ) ) { TestUserRegistry::clear(); // Reset $wgUser, which is probably 127.0.0.1, as its loaded data is probably not valid @@ -1845,9 +1853,6 @@ abstract class MediaWikiIntegrationTestCase extends PHPUnit\Framework\TestCase { global $wgUser; $wgUser->clearInstanceCache( $wgUser->mFrom ); } - if ( array_intersect( $tablesUsed, $pageTables ) ) { - $tablesUsed = array_unique( array_merge( $tablesUsed, $pageTables ) ); - } // Postgres uses mwuser/pagecontent // instead of user/text. But Postgres does not remap the @@ -2382,32 +2387,6 @@ abstract class MediaWikiIntegrationTestCase extends PHPUnit\Framework\TestCase { $this->mergeMwGlobalArrayValue( 'wgHooks', [ $hookName => [ $handler ] ] ); } - /** - * Check whether file contains given data. - * @param string $fileName - * @param string $actualData - * @param bool $createIfMissing If true, and file does not exist, create it with given data - * and skip the test. - * @param string $msg - * @since 1.30 - */ - protected function assertFileContains( - $fileName, - $actualData, - $createIfMissing = false, - $msg = '' - ) { - if ( $createIfMissing ) { - if ( !file_exists( $fileName ) ) { - file_put_contents( $fileName, $actualData ); - $this->markTestSkipped( "Data file $fileName does not exist" ); - } - } else { - self::assertFileExists( $fileName ); - } - self::assertEquals( file_get_contents( $fileName ), $actualData, $msg ); - } - /** * Edits or creates a page/revision * @param string $pageName Page title diff --git a/tests/phpunit/MediaWikiTestCaseTrait.php b/tests/phpunit/MediaWikiTestCaseTrait.php index 4ccfe39491..918b51b7c9 100644 --- a/tests/phpunit/MediaWikiTestCaseTrait.php +++ b/tests/phpunit/MediaWikiTestCaseTrait.php @@ -29,4 +29,30 @@ trait MediaWikiTestCaseTrait { $mock->expects( $this->never() )->method( $this->anythingBut( '__destruct' ) ); return $mock; } + + /** + * Check whether file contains given data. + * @param string $fileName + * @param string $actualData + * @param bool $createIfMissing If true, and file does not exist, create it with given data + * and skip the test. + * @param string $msg + * @since 1.30 + */ + protected function assertFileContains( + $fileName, + $actualData, + $createIfMissing = false, + $msg = '' + ) { + if ( $createIfMissing ) { + if ( !file_exists( $fileName ) ) { + file_put_contents( $fileName, $actualData ); + $this->markTestSkipped( "Data file $fileName does not exist" ); + } + } else { + self::assertFileExists( $fileName ); + } + self::assertEquals( file_get_contents( $fileName ), $actualData, $msg ); + } } diff --git a/tests/phpunit/data/media/jpeg-xmp-nullchar.jpg b/tests/phpunit/data/media/jpeg-xmp-nullchar.jpg new file mode 100644 index 0000000000..76ae2b486c Binary files /dev/null and b/tests/phpunit/data/media/jpeg-xmp-nullchar.jpg differ diff --git a/tests/phpunit/includes/EditPageTest.php b/tests/phpunit/includes/EditPageTest.php index d2540f6f4d..1f9465dee3 100644 --- a/tests/phpunit/includes/EditPageTest.php +++ b/tests/phpunit/includes/EditPageTest.php @@ -351,7 +351,7 @@ class EditPageTest extends MediaWikiLangTestCase { wfGetDB( DB_MASTER )->commit( __METHOD__ ); - $this->assertEquals( 0, DeferredUpdates::pendingUpdatesCount(), 'No deferred updates' ); + $this->assertSame( 0, DeferredUpdates::pendingUpdatesCount(), 'No deferred updates' ); if ( $expectedCode != EditPage::AS_BLANK_ARTICLE ) { $latest = $page->getLatest(); diff --git a/tests/phpunit/includes/FauxRequestTest.php b/tests/phpunit/includes/FauxRequestTest.php index c054caa06f..7b7f6b9d43 100644 --- a/tests/phpunit/includes/FauxRequestTest.php +++ b/tests/phpunit/includes/FauxRequestTest.php @@ -50,7 +50,7 @@ class FauxRequestTest extends PHPUnit\Framework\TestCase { public function testGetText() { $req = new FauxRequest( [ 'x' => 'Value' ] ); $this->assertEquals( 'Value', $req->getText( 'x' ) ); - $this->assertEquals( '', $req->getText( 'z' ) ); + $this->assertSame( '', $req->getText( 'z' ) ); } /** @@ -287,8 +287,8 @@ class FauxRequestTest extends PHPUnit\Framework\TestCase { */ public function testDummies() { $req = new FauxRequest(); - $this->assertEquals( '', $req->getRawQueryString() ); - $this->assertEquals( '', $req->getRawPostString() ); - $this->assertEquals( '', $req->getRawInput() ); + $this->assertSame( '', $req->getRawQueryString() ); + $this->assertSame( '', $req->getRawPostString() ); + $this->assertSame( '', $req->getRawInput() ); } } diff --git a/tests/phpunit/includes/HtmlTest.php b/tests/phpunit/includes/HtmlTest.php index 5d83b7eb5b..4401410ef3 100644 --- a/tests/phpunit/includes/HtmlTest.php +++ b/tests/phpunit/includes/HtmlTest.php @@ -161,12 +161,12 @@ class HtmlTest extends MediaWikiTestCase { * @covers Html::expandAttributes */ public function testExpandAttributesForBooleans() { - $this->assertEquals( + $this->assertSame( '', Html::expandAttributes( [ 'selected' => false ] ), 'Boolean attributes do not generates output when value is false' ); - $this->assertEquals( + $this->assertSame( '', Html::expandAttributes( [ 'selected' => null ] ), 'Boolean attributes do not generates output when value is null' diff --git a/tests/phpunit/includes/LinkerTest.php b/tests/phpunit/includes/LinkerTest.php index fe325075d5..dcac47146c 100644 --- a/tests/phpunit/includes/LinkerTest.php +++ b/tests/phpunit/includes/LinkerTest.php @@ -453,7 +453,7 @@ class LinkerTest extends MediaWikiLangTestCase { $user = $context->getUser(); $user->setOption( 'showrollbackconfirmation', $rollbackEnabled ); - $this->assertEquals( 0, Title::newFromText( $title )->getArticleID() ); + $this->assertSame( 0, Title::newFromText( $title )->getArticleID() ); $pageData = $this->insertPage( $title ); $page = WikiPage::factory( $pageData['title'] ); diff --git a/tests/phpunit/includes/MediaWikiServicesTest.php b/tests/phpunit/includes/MediaWikiServicesTest.php index 8fa0cd60ec..e4c068fbd7 100644 --- a/tests/phpunit/includes/MediaWikiServicesTest.php +++ b/tests/phpunit/includes/MediaWikiServicesTest.php @@ -227,7 +227,7 @@ class MediaWikiServicesTest extends MediaWikiTestCase { // This should do nothing. In particular, it should not create a service instance. $services->resetServiceForTesting( 'Test' ); - $this->assertEquals( 0, $serviceCounter, 'No service instance should be created yet.' ); + $this->assertSame( 0, $serviceCounter, 'No service instance should be created yet.' ); $oldInstance = $services->getService( 'Test' ); $this->assertEquals( 1, $serviceCounter, 'A service instance should exit now.' ); @@ -308,7 +308,16 @@ class MediaWikiServicesTest extends MediaWikiTestCase { throw new MWException( 'All service callbacks must have a return type defined, ' . "none found for $name" ); } - $ret[$name] = [ $name, $fun->getReturnType()->__toString() ]; + + $returnType = $fun->getReturnType(); + + // ReflectionType::__toString() generates deprecation notices in PHP 7.4 and above + // TODO: T228342 - remove this check after MediaWiki only supports PHP 7.1+ + if ( is_callable( [ $returnType, 'getName' ] ) ) { + $ret[$name] = [ $name, $returnType->getName() ]; + } else { + $ret[$name] = [ $name, $fun->getReturnType()->__toString() ]; + } } return $ret; } diff --git a/tests/phpunit/includes/OutputPageTest.php b/tests/phpunit/includes/OutputPageTest.php index aa6e49479a..6ab56eb10a 100644 --- a/tests/phpunit/includes/OutputPageTest.php +++ b/tests/phpunit/includes/OutputPageTest.php @@ -93,7 +93,7 @@ class OutputPageTest extends MediaWikiTestCase { 'Some syndication links should be there' ); } else { $this->assertFalse( $outputPage->isSyndicated(), 'No syndication should be offered' ); - $this->assertEquals( 0, count( $outputPage->getSyndicationLinks() ), + $this->assertSame( 0, count( $outputPage->getSyndicationLinks() ), 'No syndication links should be there' ); } } diff --git a/tests/phpunit/includes/Rest/BasicAccess/MWBasicRequestAuthorizerTest.php b/tests/phpunit/includes/Rest/BasicAccess/MWBasicRequestAuthorizerTest.php index 2d1fd986cc..d5bbb11d78 100644 --- a/tests/phpunit/includes/Rest/BasicAccess/MWBasicRequestAuthorizerTest.php +++ b/tests/phpunit/includes/Rest/BasicAccess/MWBasicRequestAuthorizerTest.php @@ -3,7 +3,7 @@ namespace MediaWiki\Tests\Rest\BasicAccess; use GuzzleHttp\Psr7\Uri; -use MediaWiki\MediaWikiServices; +use MediaWiki\Permissions\PermissionManager; use MediaWiki\Rest\BasicAccess\MWBasicAuthorizer; use MediaWiki\Rest\Handler; use MediaWiki\Rest\RequestData; @@ -26,30 +26,28 @@ use Wikimedia\ObjectFactory; class MWBasicRequestAuthorizerTest extends MediaWikiTestCase { private function createRouter( $userRights, $request ) { $user = User::newFromName( 'Test user' ); - // Don't allow the rights to everybody so that user rights kick in. - $this->mergeMwGlobalArrayValue( 'wgGroupPermissions', [ '*' => $userRights ] ); - $this->overrideUserPermissions( - $user, - array_keys( array_filter( $userRights ), function ( $value ) { - return $value === true; - } ) - ); - - global $IP; - $objectFactory = new ObjectFactory( $this->getMockForAbstractClass( ContainerInterface::class ) ); + $permissionManager = $this->createMock( PermissionManager::class ); + // Don't allow the rights to everybody so that user rights kick in. + $permissionManager->method( 'isEveryoneAllowed' )->willReturn( false ); + $permissionManager->method( 'userHasRight' ) + ->will( $this->returnCallback( function ( $user, $action ) use ( $userRights ) { + return isset( $userRights[$action] ) && $userRights[$action]; + } ) ); + + global $IP; return new Router( [ "$IP/tests/phpunit/unit/includes/Rest/testRoutes.json" ], [], '/rest', new \EmptyBagOStuff(), - new ResponseFactory(), - new MWBasicAuthorizer( $user, MediaWikiServices::getInstance()->getPermissionManager() ), + new ResponseFactory( [] ), + new MWBasicAuthorizer( $user, $permissionManager ), $objectFactory, - new Validator( $objectFactory, $request, $user ) + new Validator( $objectFactory, $permissionManager, $request, $user ) ); } diff --git a/tests/phpunit/includes/Rest/EntryPointTest.php b/tests/phpunit/includes/Rest/EntryPointTest.php index b984895281..d05c7973c2 100644 --- a/tests/phpunit/includes/Rest/EntryPointTest.php +++ b/tests/phpunit/includes/Rest/EntryPointTest.php @@ -5,6 +5,7 @@ namespace MediaWiki\Tests\Rest; use EmptyBagOStuff; use GuzzleHttp\Psr7\Uri; use GuzzleHttp\Psr7\Stream; +use MediaWiki\Permissions\PermissionManager; use MediaWiki\Rest\BasicAccess\StaticBasicAuthorizer; use MediaWiki\Rest\Handler; use MediaWiki\Rest\EntryPoint; @@ -32,16 +33,17 @@ class EntryPointTest extends \MediaWikiTestCase { $objectFactory = new ObjectFactory( $this->getMockForAbstractClass( ContainerInterface::class ) ); + $permissionManager = $this->createMock( PermissionManager::class ); return new Router( [ "$IP/tests/phpunit/unit/includes/Rest/testRoutes.json" ], [], '/rest', new EmptyBagOStuff(), - new ResponseFactory(), + new ResponseFactory( [] ), new StaticBasicAuthorizer(), $objectFactory, - new Validator( $objectFactory, $request, new User ) + new Validator( $objectFactory, $permissionManager, $request, new User ) ); } diff --git a/tests/phpunit/includes/Revision/McrRevisionStoreDbTest.php b/tests/phpunit/includes/Revision/McrRevisionStoreDbTest.php index c0ff44b0b8..e4d6b54105 100644 --- a/tests/phpunit/includes/Revision/McrRevisionStoreDbTest.php +++ b/tests/phpunit/includes/Revision/McrRevisionStoreDbTest.php @@ -3,12 +3,17 @@ namespace MediaWiki\Tests\Revision; use CommentStoreComment; +use ContentHandler; use MediaWiki\MediaWikiServices; use MediaWiki\Revision\MutableRevisionRecord; use MediaWiki\Revision\RevisionRecord; use MediaWiki\Revision\SlotRecord; +use MediaWiki\Storage\SqlBlobStore; +use Revision; +use StatusValue; use TextContent; use Title; +use Wikimedia\TestingAccessWrapper; use WikitextContent; /** @@ -239,4 +244,49 @@ class McrRevisionStoreDbTest extends RevisionStoreDbTestBase { ] ] ], $result->getErrors() ); } + + /** + * @covers \MediaWiki\Revision\RevisionStore::newRevisionsFromBatch + */ + public function testNewRevisionFromBatchUsesGetBlobBatch() { + $page1 = $this->getTestPage(); + $text = __METHOD__ . 'b-ä'; + $editStatus = $this->editPage( $page1->getTitle()->getPrefixedDBkey(), $text . '1' ); + $this->assertTrue( $editStatus->isGood(), 'Sanity: must create revision 1' ); + /** @var Revision $rev1 */ + $rev1 = $editStatus->getValue()['revision']; + + $contentAddress = $rev1->getRevisionRecord()->getSlot( SlotRecord::MAIN )->getAddress(); + $mockBlobStore = $this->getMockBuilder( SqlBlobStore::class ) + ->disableOriginalConstructor() + ->getMock(); + $mockBlobStore + ->expects( $this->once() ) + ->method( 'getBlobBatch' ) + ->with( [ $contentAddress ], $this->anything() ) + ->willReturn( StatusValue::newGood( [ + $contentAddress => 'Content_From_Mock' + ] ) ); + $mockBlobStore + ->expects( $this->never() ) + ->method( 'getBlob' ); + + $revStore = MediaWikiServices::getInstance() + ->getRevisionStoreFactory() + ->getRevisionStore(); + $wrappedRevStore = TestingAccessWrapper::newFromObject( $revStore ); + $wrappedRevStore->blobStore = $mockBlobStore; + + $result = $revStore->newRevisionsFromBatch( + [ $this->revisionToRow( $rev1 ) ], + [ + 'slots' => [ SlotRecord::MAIN ], + 'content' => true + ] + ); + $this->assertTrue( $result->isGood() ); + $this->assertSame( 'Content_From_Mock', + ContentHandler::getContentText( $result->getValue()[$rev1->getId()] + ->getContent( SlotRecord::MAIN ) ) ); + } } diff --git a/tests/phpunit/includes/Revision/RenderedRevisionTest.php b/tests/phpunit/includes/Revision/RenderedRevisionTest.php index 96658678ba..7115515e8a 100644 --- a/tests/phpunit/includes/Revision/RenderedRevisionTest.php +++ b/tests/phpunit/includes/Revision/RenderedRevisionTest.php @@ -4,6 +4,7 @@ namespace MediaWiki\Tests\Revision; use Content; use Language; +use MediaWiki\MediaWikiServices; use MediaWiki\Revision\MutableRevisionRecord; use MediaWiki\Revision\MutableRevisionSlots; use MediaWiki\Revision\RenderedRevision; @@ -122,7 +123,9 @@ class RenderedRevisionTest extends MediaWikiTestCase { $mock->expects( $this->any() ) ->method( 'userCan' ) ->willReturnCallback( function ( $perm, User $user ) use ( $mock ) { - return $user->isAllowed( $perm ); + return MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, $perm ); } ); return $mock; diff --git a/tests/phpunit/includes/Revision/RevisionStoreDbTestBase.php b/tests/phpunit/includes/Revision/RevisionStoreDbTestBase.php index 76190e0a9b..4040ffc76e 100644 --- a/tests/phpunit/includes/Revision/RevisionStoreDbTestBase.php +++ b/tests/phpunit/includes/Revision/RevisionStoreDbTestBase.php @@ -4,8 +4,10 @@ namespace MediaWiki\Tests\Revision; use CommentStoreComment; use Content; +use ContentHandler; use Exception; use HashBagOStuff; +use IDBAccessObject; use InvalidArgumentException; use Language; use MediaWiki\Linker\LinkTarget; @@ -105,7 +107,7 @@ abstract class RevisionStoreDbTestBase extends MediaWikiTestCase { * @return WikiPage */ protected function getTestPage( $pageTitle = null ) { - if ( !is_null( $pageTitle ) && $this->testPage ) { + if ( is_null( $pageTitle ) && $this->testPage ) { return $this->testPage; } @@ -1992,23 +1994,17 @@ abstract class RevisionStoreDbTestBase extends MediaWikiTestCase { ) { $page1 = $this->getTestPage(); $text = __METHOD__ . 'b-ä'; + $editStatus = $this->editPage( $page1->getTitle()->getPrefixedDBkey(), $text . '1' ); + $this->assertTrue( $editStatus->isGood(), 'Sanity: must create revision 1' ); /** @var Revision $rev1 */ - $rev1 = $page1->doEditContent( - new WikitextContent( $text . '1' ), - __METHOD__ . 'b', - 0, - false, - $this->getTestUser()->getUser() - )->value['revision']; + $rev1 = $editStatus->getValue()['revision']; + $page2 = $this->getTestPage( $otherPageTitle ); + $editStatus = $this->editPage( $page2->getTitle()->getPrefixedDBkey(), $text . '2' ); + $this->assertTrue( $editStatus->isGood(), 'Sanity: must create revision 2' ); /** @var Revision $rev2 */ - $rev2 = $page2->doEditContent( - new WikitextContent( $text . '2' ), - __METHOD__ . 'b', - 0, - false, - $this->getTestUser()->getUser() - )->value['revision']; + $rev2 = $editStatus->getValue()['revision']; + $store = MediaWikiServices::getInstance()->getRevisionStore(); $result = $store->newRevisionsFromBatch( [ $this->revisionToRow( $rev1 ), $this->revisionToRow( $rev2 ) ], @@ -2016,14 +2012,15 @@ abstract class RevisionStoreDbTestBase extends MediaWikiTestCase { ); $this->assertTrue( $result->isGood() ); $this->assertEmpty( $result->getErrors() ); + /** @var RevisionRecord[] $records */ $records = $result->getValue(); $this->assertRevisionRecordMatchesRevision( $rev1, $records[$rev1->getId()] ); $this->assertRevisionRecordMatchesRevision( $rev2, $records[$rev2->getId()] ); $this->assertSame( $text . '1', - $records[$rev1->getId()]->getContent( SlotRecord::MAIN )->serialize() ); + ContentHandler::getContentText( $records[$rev1->getId()]->getContent( SlotRecord::MAIN ) ) ); $this->assertSame( $text . '2', - $records[$rev2->getId()]->getContent( SlotRecord::MAIN )->serialize() ); + ContentHandler::getContentText( $records[$rev2->getId()]->getContent( SlotRecord::MAIN ) ) ); $this->assertEquals( $page1->getTitle()->getDBkey(), $records[$rev1->getId()]->getPageAsLinkTarget()->getDBkey() ); $this->assertEquals( $page2->getTitle()->getDBkey(), @@ -2046,4 +2043,41 @@ abstract class RevisionStoreDbTestBase extends MediaWikiTestCase { $this->assertEmpty( $result->getValue() ); $this->assertEmpty( $result->getErrors() ); } + + /** + * @covers \MediaWiki\Revision\RevisionStore::newRevisionsFromBatch + */ + public function testNewRevisionsFromBatch_wrongTitle() { + $page1 = $this->getTestPage(); + $text = __METHOD__ . 'b-ä'; + $editStatus = $this->editPage( $page1->getTitle()->getPrefixedDBkey(), $text . '1' ); + $this->assertTrue( $editStatus->isGood(), 'Sanity: must create revision 1' ); + /** @var Revision $rev1 */ + $rev1 = $editStatus->getValue()['revision']; + + $this->setExpectedException( InvalidArgumentException::class ); + MediaWikiServices::getInstance()->getRevisionStore() + ->newRevisionsFromBatch( + [ $this->revisionToRow( $rev1 ) ], + [], + IDBAccessObject::READ_NORMAL, + $this->getTestPage( 'Title_Other_Then_The_One_Revision_Belongs_To' )->getTitle() + ); + } + + /** + * @covers \MediaWiki\Revision\RevisionStore::newRevisionsFromBatch + */ + public function testNewRevisionsFromBatch_DuplicateRows() { + $page1 = $this->getTestPage(); + $text = __METHOD__ . 'b-ä'; + $editStatus = $this->editPage( $page1->getTitle()->getPrefixedDBkey(), $text . '1' ); + $this->assertTrue( $editStatus->isGood(), 'Sanity: must create revision 1' ); + /** @var Revision $rev1 */ + $rev1 = $editStatus->getValue()['revision']; + + $this->setExpectedException( InvalidArgumentException::class ); + MediaWikiServices::getInstance()->getRevisionStore() + ->newRevisionsFromBatch( [ $this->revisionToRow( $rev1 ), $this->revisionToRow( $rev1 ) ] ); + } } diff --git a/tests/phpunit/includes/Revision/RevisionStoreFactoryTest.php b/tests/phpunit/includes/Revision/RevisionStoreFactoryTest.php index f4d324dde7..99332d2488 100644 --- a/tests/phpunit/includes/Revision/RevisionStoreFactoryTest.php +++ b/tests/phpunit/includes/Revision/RevisionStoreFactoryTest.php @@ -4,7 +4,6 @@ namespace MediaWiki\Tests\Revision; use ActorMigration; use CommentStore; -use MediaWiki\Logger\Spi as LoggerSpi; use MediaWiki\Revision\RevisionStore; use MediaWiki\Revision\RevisionStoreFactory; use MediaWiki\Revision\SlotRoleRegistry; @@ -35,7 +34,7 @@ class RevisionStoreFactoryTest extends \MediaWikiIntegrationTestCase { $this->getMockCommentStore(), ActorMigration::newMigration(), MIGRATION_OLD, - $this->getMockLoggerSpi(), + new NullLogger(), true ); $this->assertTrue( true ); @@ -65,7 +64,7 @@ class RevisionStoreFactoryTest extends \MediaWikiIntegrationTestCase { $cache = $this->getHashWANObjectCache(); $commentStore = $this->getMockCommentStore(); $actorMigration = ActorMigration::newMigration(); - $loggerProvider = $this->getMockLoggerSpi(); + $logger = new NullLogger(); $factory = new RevisionStoreFactory( $lbFactory, @@ -76,7 +75,7 @@ class RevisionStoreFactoryTest extends \MediaWikiIntegrationTestCase { $commentStore, $actorMigration, $mcrMigrationStage, - $loggerProvider, + $logger, $contentHandlerUseDb ); @@ -178,16 +177,4 @@ class RevisionStoreFactoryTest extends \MediaWikiIntegrationTestCase { return new WANObjectCache( [ 'cache' => new \HashBagOStuff() ] ); } - /** - * @return \PHPUnit_Framework_MockObject_MockObject|LoggerSpi - */ - private function getMockLoggerSpi() { - $mock = $this->getMock( LoggerSpi::class ); - - $mock->method( 'getLogger' ) - ->willReturn( new NullLogger() ); - - return $mock; - } - } diff --git a/tests/phpunit/includes/RevisionTest.php b/tests/phpunit/includes/RevisionTest.php index ed4a27f42a..249fa78dab 100644 --- a/tests/phpunit/includes/RevisionTest.php +++ b/tests/phpunit/includes/RevisionTest.php @@ -850,8 +850,7 @@ class RevisionTest extends MediaWikiTestCase { ); $cacheKey = $cache->makeGlobalKey( - 'BlobStore', - 'address', + 'SqlBlobStore-blob', $lb->getLocalDomainID(), 'tt:7777' ); diff --git a/tests/phpunit/includes/SiteStatsTest.php b/tests/phpunit/includes/SiteStatsTest.php index b0d89a6ae5..ff9fa7b34a 100644 --- a/tests/phpunit/includes/SiteStatsTest.php +++ b/tests/phpunit/includes/SiteStatsTest.php @@ -21,7 +21,7 @@ class SiteStatsTest extends MediaWikiTestCase { ); $jobq->get( 'null' )->delete(); // clear jobqueue - $this->assertEquals( 0, $jobq->get( 'null' )->getSize(), + $this->assertSame( 0, $jobq->get( 'null' )->getSize(), 'Job queue for NullJob has been cleaned' ); $cache->delete( $cache->makeKey( 'SiteStats', 'jobscount' ) ); @@ -29,7 +29,7 @@ class SiteStatsTest extends MediaWikiTestCase { 'jobs count is kept in process cache' ); $cache->clearProcessCache(); - $this->assertEquals( 0, SiteStats::jobs() ); + $this->assertSame( 0, SiteStats::jobs() ); } } diff --git a/tests/phpunit/includes/Storage/DerivedPageDataUpdaterTest.php b/tests/phpunit/includes/Storage/DerivedPageDataUpdaterTest.php index 2148411cbf..c64169fd8c 100644 --- a/tests/phpunit/includes/Storage/DerivedPageDataUpdaterTest.php +++ b/tests/phpunit/includes/Storage/DerivedPageDataUpdaterTest.php @@ -1062,7 +1062,7 @@ class DerivedPageDataUpdaterTest extends MediaWikiTestCase { $this->db->endAtomic( __METHOD__ ); // run deferred updates - $this->assertEquals( 0, DeferredUpdates::pendingUpdatesCount(), 'No pending updates' ); + $this->assertSame( 0, DeferredUpdates::pendingUpdatesCount(), 'No pending updates' ); } /** @@ -1095,7 +1095,7 @@ class DerivedPageDataUpdaterTest extends MediaWikiTestCase { $this->db->endAtomic( __METHOD__ ); // run deferred updates - $this->assertEquals( 0, DeferredUpdates::pendingUpdatesCount(), 'No pending updates' ); + $this->assertSame( 0, DeferredUpdates::pendingUpdatesCount(), 'No pending updates' ); $this->assertNotFalse( $pcache->get( $page, $updater->getCanonicalParserOptions() ) ); } diff --git a/tests/phpunit/includes/TitleMethodsTest.php b/tests/phpunit/includes/TitleMethodsTest.php index 77d6f59d21..ec002e0aec 100644 --- a/tests/phpunit/includes/TitleMethodsTest.php +++ b/tests/phpunit/includes/TitleMethodsTest.php @@ -327,7 +327,7 @@ class TitleMethodsTest extends MediaWikiLangTestCase { $title2 = Title::newFromText( 'Foo' ); $this->assertNotSame( $title1, $title2, 'title cache should be empty' ); - $this->assertEquals( 0, $linkCache->getGoodLinkID( 'Foo' ), 'link cache should be empty' ); + $this->assertSame( 0, $linkCache->getGoodLinkID( 'Foo' ), 'link cache should be empty' ); } public function provideGetLinkURL() { diff --git a/tests/phpunit/includes/TitleTest.php b/tests/phpunit/includes/TitleTest.php index 82ccb9ae32..608d59078e 100644 --- a/tests/phpunit/includes/TitleTest.php +++ b/tests/phpunit/includes/TitleTest.php @@ -834,8 +834,23 @@ class TitleTest extends MediaWikiTestCase { return [ [ Title::makeTitle( NS_SPECIAL, 'Test' ) ], [ Title::makeTitle( NS_MEDIA, 'Test' ) ], - [ Title::makeTitle( NS_MAIN, '', 'Kittens' ) ], - [ Title::makeTitle( NS_MAIN, 'Kittens', '', 'acme' ) ], + ]; + } + + public static function provideGetTalkPage_broken() { + // These cases *should* be bad, but are not treated as bad, for backwards compatibility. + // See discussion on T227817. + return [ + [ + Title::makeTitle( NS_MAIN, '', 'Kittens' ), + Title::makeTitle( NS_TALK, '' ), // Section is lost! + false, + ], + [ + Title::makeTitle( NS_MAIN, 'Kittens', '', 'acme' ), + Title::makeTitle( NS_TALK, 'Kittens', '' ), // Interwiki prefix is lost! + true, + ], ]; } @@ -895,6 +910,23 @@ class TitleTest extends MediaWikiTestCase { $title->getTalkPage(); } + /** + * @dataProvider provideGetTalkPage_broken + * @covers Title::getTalkPageIfDefined + */ + public function testGetTalkPage_broken( Title $title, Title $expected, $valid ) { + $errorLevel = error_reporting( E_ERROR ); + + // NOTE: Eventually we want to throw in this case. But while there is still code that + // calls this method without checking, we want to avoid fatal errors. + // See discussion on T227817. + $result = $title->getTalkPage(); + $this->assertTrue( $expected->equals( $result ) ); + $this->assertSame( $valid, $result->isValid() ); + + error_reporting( $errorLevel ); + } + /** * @dataProvider provideGetTalkPage_good * @covers Title::getTalkPageIfDefined diff --git a/tests/phpunit/includes/XmlTest.php b/tests/phpunit/includes/XmlTest.php index ab9abbb429..f95505bcbc 100644 --- a/tests/phpunit/includes/XmlTest.php +++ b/tests/phpunit/includes/XmlTest.php @@ -46,7 +46,7 @@ class XmlTest extends MediaWikiTestCase { $this->assertNull( Xml::expandAttributes( null ), 'Converting a null list of attributes' ); - $this->assertEquals( '', Xml::expandAttributes( [] ), + $this->assertSame( '', Xml::expandAttributes( [] ), 'Converting an empty list of attributes' ); } diff --git a/tests/phpunit/includes/api/ApiBlockTest.php b/tests/phpunit/includes/api/ApiBlockTest.php index 2d19d3817b..fe6fcfcca8 100644 --- a/tests/phpunit/includes/api/ApiBlockTest.php +++ b/tests/phpunit/includes/api/ApiBlockTest.php @@ -182,7 +182,6 @@ class ApiBlockTest extends ApiTestCase { $this->setMwGlobals( [ 'wgEnableEmail' => true, 'wgEnableUserEmail' => true, - 'wgSysopEmailBans' => true, ] ); $res = $this->doBlock( [ 'noemail' => '' ] ); @@ -200,7 +199,6 @@ class ApiBlockTest extends ApiTestCase { $this->setMwGlobals( [ 'wgEnableEmail' => true, 'wgEnableUserEmail' => true, - 'wgSysopEmailBans' => true, ] ); $this->setExpectedException( ApiUsageException::class, diff --git a/tests/phpunit/includes/api/ApiPageSetTest.php b/tests/phpunit/includes/api/ApiPageSetTest.php index fdc9c1b2b3..b1b8a42523 100644 --- a/tests/phpunit/includes/api/ApiPageSetTest.php +++ b/tests/phpunit/includes/api/ApiPageSetTest.php @@ -214,7 +214,7 @@ class ApiPageSetTest extends ApiTestCase { 'titles' => 'User:' . implode( '|User:', $userNames ), ] ); - $this->assertEquals( 0, $genderCache->misses, + $this->assertSame( 0, $genderCache->misses, 'ApiPageSet does not prefill the gender cache correctly' ); $this->assertEquals( $userNames, array_keys( $genderCache->cache ), 'ApiPageSet does not prefill all users into the gender cache' ); diff --git a/tests/phpunit/includes/api/ApiQueryBlockInfoTraitTest.php b/tests/phpunit/includes/api/ApiQueryBlockInfoTraitTest.php new file mode 100644 index 0000000000..cded9dd942 --- /dev/null +++ b/tests/phpunit/includes/api/ApiQueryBlockInfoTraitTest.php @@ -0,0 +1,77 @@ +assertTrue( method_exists( ApiQueryBlockInfoTrait::class, 'getBlockDetails' ), + 'ApiQueryBlockInfoTrait::getBlockDetails exists' ); + } + + /** + * @dataProvider provideAddBlockInfoToQuery + */ + public function testAddBlockInfoToQuery( $args, $expect ) { + // Fake timestamp to show up in the queries + $reset = ConvertibleTimestamp::setFakeTime( '20190101000000' ); + + $data = []; + + $mock = $this->getMockForTrait( ApiQueryBlockInfoTrait::class ); + $mock->method( 'getDB' )->willReturn( wfGetDB( DB_REPLICA ) ); + $mock->method( 'getPermissionManager' ) + ->willReturn( MediaWikiServices::getInstance()->getPermissionManager() ); + $mock->method( 'getUser' ) + ->willReturn( $this->getMutableTestUser()->getUser() ); + $mock->method( 'addTables' )->willReturnCallback( function ( $v ) use ( &$data ) { + $data['tables'] = array_merge( $data['tables'] ?? [], (array)$v ); + } ); + $mock->method( 'addFields' )->willReturnCallback( function ( $v ) use ( &$data ) { + $data['fields'] = array_merge( $data['fields'] ?? [], (array)$v ); + } ); + $mock->method( 'addWhere' )->willReturnCallback( function ( $v ) use ( &$data ) { + $data['where'] = array_merge( $data['where'] ?? [], (array)$v ); + } ); + $mock->method( 'addJoinConds' )->willReturnCallback( function ( $v ) use ( &$data ) { + $data['joins'] = array_merge( $data['joins'] ?? [], (array)$v ); + } ); + + TestingAccessWrapper::newFromObject( $mock )->addBlockInfoToQuery( ...$args ); + $this->assertEquals( $expect, $data ); + } + + public function provideAddBlockInfoToQuery() { + $queryInfo = DatabaseBlock::getQueryInfo(); + + $db = wfGetDB( DB_REPLICA ); + $ts = $db->addQuotes( $db->timestamp( '20190101000000' ) ); + + return [ + [ [ false ], [ + 'tables' => [ 'blk' => [ 'ipblocks' ] ], + 'fields' => [ 'ipb_deleted' ], + 'where' => [ 'ipb_deleted = 0 OR ipb_deleted IS NULL' ], + 'joins' => [ + 'blk' => [ 'LEFT JOIN', [ 'ipb_user=user_id', "ipb_expiry > $ts" ] ] + ], + ] ], + + [ [ true ], [ + 'tables' => [ 'blk' => $queryInfo['tables'] ], + 'fields' => $queryInfo['fields'], + 'where' => [ 'ipb_deleted = 0 OR ipb_deleted IS NULL' ], + 'joins' => $queryInfo['joins'] + [ + 'blk' => [ 'LEFT JOIN', [ 'ipb_user=user_id', "ipb_expiry > $ts" ] ] + ], + ] ], + ]; + } + +} diff --git a/tests/phpunit/includes/api/ApiQuerySiteinfoTest.php b/tests/phpunit/includes/api/ApiQuerySiteinfoTest.php index 0a2558a227..dce1a5feef 100644 --- a/tests/phpunit/includes/api/ApiQuerySiteinfoTest.php +++ b/tests/phpunit/includes/api/ApiQuerySiteinfoTest.php @@ -79,15 +79,46 @@ class ApiQuerySiteinfoTest extends ApiTestCase { $this->assertSame( 'Need more donations', $data['readonlyreason'] ); } - public function testNamespaces() { - $this->setMwGlobals( 'wgExtraNamespaces', [ '138' => 'Testing' ] ); + public function testNamespacesBasic() { + $this->assertSame( + array_keys( MediaWikiServices::getInstance()->getContentLanguage()->getFormattedNamespaces() ), + array_keys( $this->doQuery( 'namespaces' ) ) + ); + } + public function testNamespacesExtraNS() { + $this->setMwGlobals( 'wgExtraNamespaces', [ '138' => 'Testing' ] ); $this->assertSame( array_keys( MediaWikiServices::getInstance()->getContentLanguage()->getFormattedNamespaces() ), array_keys( $this->doQuery( 'namespaces' ) ) ); } + public function testNamespacesProtection() { + $this->setMwGlobals( + 'wgNamespaceProtection', + [ + '0' => '', + '2' => [ '' ], + '4' => 'editsemiprotected', + '8' => [ + 'editinterface', + 'noratelimit' + ], + '14' => [ + 'move-categorypages', + '' + ] + ] + ); + $data = $this->doQuery( 'namespaces' ); + $this->assertArrayNotHasKey( 'namespaceprotection', $data['0'] ); + $this->assertArrayNotHasKey( 'namespaceprotection', $data['2'] ); + $this->assertSame( 'editsemiprotected', $data['4']['namespaceprotection'] ); + $this->assertSame( 'editinterface|noratelimit', $data['8']['namespaceprotection'] ); + $this->assertSame( 'move-categorypages', $data['14']['namespaceprotection'] ); + } + public function testNamespaceAliases() { global $wgNamespaceAliases; diff --git a/tests/phpunit/includes/api/ApiQueryWatchlistIntegrationTest.php b/tests/phpunit/includes/api/ApiQueryWatchlistIntegrationTest.php index 2b08a81c2e..26fedba1b3 100644 --- a/tests/phpunit/includes/api/ApiQueryWatchlistIntegrationTest.php +++ b/tests/phpunit/includes/api/ApiQueryWatchlistIntegrationTest.php @@ -1575,7 +1575,7 @@ class ApiQueryWatchlistIntegrationTest extends ApiTestCase { $pages = array_values( $result[0]['query']['pages'] ); $this->assertCount( 1, $pages ); - $this->assertEquals( 0, $pages[0]['ns'] ); + $this->assertSame( 0, $pages[0]['ns'] ); $this->assertEquals( $this->getPrefixedText( $target ), $pages[0]['title'] ); $this->assertArraySubsetsEqual( $pages[0]['revisions'], diff --git a/tests/phpunit/includes/api/ApiQueryWatchlistRawIntegrationTest.php b/tests/phpunit/includes/api/ApiQueryWatchlistRawIntegrationTest.php index c554fb3f49..b41c3e5b2f 100644 --- a/tests/phpunit/includes/api/ApiQueryWatchlistRawIntegrationTest.php +++ b/tests/phpunit/includes/api/ApiQueryWatchlistRawIntegrationTest.php @@ -535,7 +535,7 @@ class ApiQueryWatchlistRawIntegrationTest extends ApiTestCase { // $result[0]['query']['pages'] uses page ids as keys $item = array_values( $result[0]['query']['pages'] )[0]; - $this->assertEquals( 0, $item['ns'] ); + $this->assertSame( 0, $item['ns'] ); $this->assertEquals( 'ApiQueryWatchlistRawIntegrationTestPage', $item['title'] ); } diff --git a/tests/phpunit/includes/api/ApiWatchTest.php b/tests/phpunit/includes/api/ApiWatchTest.php index 6d64a178df..24d016e697 100644 --- a/tests/phpunit/includes/api/ApiWatchTest.php +++ b/tests/phpunit/includes/api/ApiWatchTest.php @@ -64,7 +64,7 @@ class ApiWatchTest extends ApiTestCase { unset( $data[0]['query']['watchlist'][$index] ); } } - $this->assertEquals( 0, count( $data[0]['query']['watchlist'] ) ); + $this->assertSame( 0, count( $data[0]['query']['watchlist'] ) ); return $data; } diff --git a/tests/phpunit/includes/auth/AuthManagerTest.php b/tests/phpunit/includes/auth/AuthManagerTest.php index f8be1d437f..55d4e10ab9 100644 --- a/tests/phpunit/includes/auth/AuthManagerTest.php +++ b/tests/phpunit/includes/auth/AuthManagerTest.php @@ -2120,9 +2120,9 @@ class AuthManagerTest extends \MediaWikiTestCase { } if ( $created ) { - $this->assertNotEquals( 0, \User::idFromName( $username ) ); + $this->assertNotNull( \User::idFromName( $username ) ); } else { - $this->assertEquals( 0, \User::idFromName( $username ) ); + $this->assertNull( \User::idFromName( $username ) ); } $first = false; @@ -2474,7 +2474,7 @@ class AuthManagerTest extends \MediaWikiTestCase { $this->assertEquals( $expect, $ret ); $this->assertNotEquals( 0, $user->getId() ); $this->assertSame( 'UTSysop', $user->getName() ); - $this->assertEquals( 0, $session->getUser()->getId() ); + $this->assertSame( 0, $session->getUser()->getId() ); $this->assertSame( [ [ LogLevel::DEBUG, '{username} already exists locally' ], ], $logger->getBuffer() ); @@ -2489,9 +2489,9 @@ class AuthManagerTest extends \MediaWikiTestCase { $ret = $this->manager->autoCreateUser( $user, AuthManager::AUTOCREATE_SOURCE_SESSION, true ); $this->unhook( 'LocalUserCreated' ); $this->assertEquals( \Status::newFatal( wfMessage( 'readonlytext', 'Because' ) ), $ret ); - $this->assertEquals( 0, $user->getId() ); + $this->assertSame( 0, $user->getId() ); $this->assertNotEquals( $username, $user->getName() ); - $this->assertEquals( 0, $session->getUser()->getId() ); + $this->assertSame( 0, $session->getUser()->getId() ); $this->assertSame( [ [ LogLevel::DEBUG, 'denied by wfReadOnly(): {reason}' ], ], $logger->getBuffer() ); @@ -2506,9 +2506,9 @@ class AuthManagerTest extends \MediaWikiTestCase { $ret = $this->manager->autoCreateUser( $user, AuthManager::AUTOCREATE_SOURCE_SESSION, true ); $this->unhook( 'LocalUserCreated' ); $this->assertEquals( \Status::newFatal( 'test' ), $ret ); - $this->assertEquals( 0, $user->getId() ); + $this->assertSame( 0, $user->getId() ); $this->assertNotEquals( $username, $user->getName() ); - $this->assertEquals( 0, $session->getUser()->getId() ); + $this->assertSame( 0, $session->getUser()->getId() ); $this->assertSame( [ [ LogLevel::DEBUG, 'blacklisted in session {sessionid}' ], ], $logger->getBuffer() ); @@ -2521,9 +2521,9 @@ class AuthManagerTest extends \MediaWikiTestCase { $ret = $this->manager->autoCreateUser( $user, AuthManager::AUTOCREATE_SOURCE_SESSION, true ); $this->unhook( 'LocalUserCreated' ); $this->assertEquals( \Status::newFatal( 'test2' ), $ret ); - $this->assertEquals( 0, $user->getId() ); + $this->assertSame( 0, $user->getId() ); $this->assertNotEquals( $username, $user->getName() ); - $this->assertEquals( 0, $session->getUser()->getId() ); + $this->assertSame( 0, $session->getUser()->getId() ); $this->assertSame( [ [ LogLevel::DEBUG, 'blacklisted in session {sessionid}' ], ], $logger->getBuffer() ); @@ -2536,9 +2536,9 @@ class AuthManagerTest extends \MediaWikiTestCase { $ret = $this->manager->autoCreateUser( $user, AuthManager::AUTOCREATE_SOURCE_SESSION, true ); $this->unhook( 'LocalUserCreated' ); $this->assertEquals( \Status::newFatal( 'noname' ), $ret ); - $this->assertEquals( 0, $user->getId() ); + $this->assertSame( 0, $user->getId() ); $this->assertNotEquals( $username . '@', $user->getId() ); - $this->assertEquals( 0, $session->getUser()->getId() ); + $this->assertSame( 0, $session->getUser()->getId() ); $this->assertSame( [ [ LogLevel::DEBUG, 'name "{username}" is not creatable' ], ], $logger->getBuffer() ); @@ -2554,9 +2554,9 @@ class AuthManagerTest extends \MediaWikiTestCase { $ret = $this->manager->autoCreateUser( $user, AuthManager::AUTOCREATE_SOURCE_SESSION, true ); $this->unhook( 'LocalUserCreated' ); $this->assertEquals( \Status::newFatal( 'authmanager-autocreate-noperm' ), $ret ); - $this->assertEquals( 0, $user->getId() ); + $this->assertSame( 0, $user->getId() ); $this->assertNotEquals( $username, $user->getName() ); - $this->assertEquals( 0, $session->getUser()->getId() ); + $this->assertSame( 0, $session->getUser()->getId() ); $this->assertSame( [ [ LogLevel::DEBUG, 'IP lacks the ability to create or autocreate accounts' ], ], $logger->getBuffer() ); @@ -2608,9 +2608,9 @@ class AuthManagerTest extends \MediaWikiTestCase { unset( $lock ); $this->unhook( 'LocalUserCreated' ); $this->assertEquals( \Status::newFatal( 'usernameinprogress' ), $ret ); - $this->assertEquals( 0, $user->getId() ); + $this->assertSame( 0, $user->getId() ); $this->assertNotEquals( $username, $user->getName() ); - $this->assertEquals( 0, $session->getUser()->getId() ); + $this->assertSame( 0, $session->getUser()->getId() ); $this->assertSame( [ [ LogLevel::DEBUG, 'Could not acquire account creation lock' ], ], $logger->getBuffer() ); @@ -2623,9 +2623,9 @@ class AuthManagerTest extends \MediaWikiTestCase { $ret = $this->manager->autoCreateUser( $user, AuthManager::AUTOCREATE_SOURCE_SESSION, true ); $this->unhook( 'LocalUserCreated' ); $this->assertEquals( \Status::newFatal( 'fail-in-pre' ), $ret ); - $this->assertEquals( 0, $user->getId() ); + $this->assertSame( 0, $user->getId() ); $this->assertNotEquals( $username, $user->getName() ); - $this->assertEquals( 0, $session->getUser()->getId() ); + $this->assertSame( 0, $session->getUser()->getId() ); $this->assertSame( [ [ LogLevel::DEBUG, 'Provider denied creation of {username}: {reason}' ], ], $logger->getBuffer() ); @@ -2640,9 +2640,9 @@ class AuthManagerTest extends \MediaWikiTestCase { $ret = $this->manager->autoCreateUser( $user, AuthManager::AUTOCREATE_SOURCE_SESSION, true ); $this->unhook( 'LocalUserCreated' ); $this->assertEquals( \Status::newFatal( 'fail-in-primary' ), $ret ); - $this->assertEquals( 0, $user->getId() ); + $this->assertSame( 0, $user->getId() ); $this->assertNotEquals( $username, $user->getName() ); - $this->assertEquals( 0, $session->getUser()->getId() ); + $this->assertSame( 0, $session->getUser()->getId() ); $this->assertSame( [ [ LogLevel::DEBUG, 'Provider denied creation of {username}: {reason}' ], ], $logger->getBuffer() ); @@ -2657,9 +2657,9 @@ class AuthManagerTest extends \MediaWikiTestCase { $ret = $this->manager->autoCreateUser( $user, AuthManager::AUTOCREATE_SOURCE_SESSION, true ); $this->unhook( 'LocalUserCreated' ); $this->assertEquals( \Status::newFatal( 'fail-in-secondary' ), $ret ); - $this->assertEquals( 0, $user->getId() ); + $this->assertSame( 0, $user->getId() ); $this->assertNotEquals( $username, $user->getName() ); - $this->assertEquals( 0, $session->getUser()->getId() ); + $this->assertSame( 0, $session->getUser()->getId() ); $this->assertSame( [ [ LogLevel::DEBUG, 'Provider denied creation of {username}: {reason}' ], ], $logger->getBuffer() ); @@ -2678,9 +2678,9 @@ class AuthManagerTest extends \MediaWikiTestCase { $ret = $this->manager->autoCreateUser( $user, AuthManager::AUTOCREATE_SOURCE_SESSION, true ); $this->unhook( 'LocalUserCreated' ); $this->assertEquals( \Status::newFatal( 'authmanager-autocreate-exception' ), $ret ); - $this->assertEquals( 0, $user->getId() ); + $this->assertSame( 0, $user->getId() ); $this->assertNotEquals( $username, $user->getName() ); - $this->assertEquals( 0, $session->getUser()->getId() ); + $this->assertSame( 0, $session->getUser()->getId() ); $this->assertSame( [ [ LogLevel::DEBUG, '{username} denied by prior creation attempt failures' ], ], $logger->getBuffer() ); @@ -2697,9 +2697,9 @@ class AuthManagerTest extends \MediaWikiTestCase { $user->setName( $username ); $ret = $this->manager->autoCreateUser( $user, AuthManager::AUTOCREATE_SOURCE_SESSION, true ); $this->assertEquals( \Status::newFatal( 'because' ), $ret ); - $this->assertEquals( 0, $user->getId() ); + $this->assertSame( 0, $user->getId() ); $this->assertNotEquals( $username, $user->getName() ); - $this->assertEquals( 0, $session->getUser()->getId() ); + $this->assertSame( 0, $session->getUser()->getId() ); $this->assertSame( [ [ LogLevel::INFO, 'creating new user ({username}) - from: {from}' ], [ LogLevel::ERROR, '{username} failed with message {msg}' ], @@ -2723,8 +2723,8 @@ class AuthManagerTest extends \MediaWikiTestCase { } catch ( \Exception $ex ) { $this->assertSame( 'Excepted', $ex->getMessage() ); } - $this->assertEquals( 0, $user->getId() ); - $this->assertEquals( 0, $session->getUser()->getId() ); + $this->assertSame( 0, $user->getId() ); + $this->assertSame( 0, $session->getUser()->getId() ); $this->assertSame( [ [ LogLevel::INFO, 'creating new user ({username}) - from: {from}' ], [ LogLevel::ERROR, '{username} failed with exception {exception}' ], @@ -2790,7 +2790,7 @@ class AuthManagerTest extends \MediaWikiTestCase { $this->assertEquals( \Status::newGood(), $ret ); $this->assertNotEquals( 0, $user->getId() ); $this->assertEquals( $username, $user->getName() ); - $this->assertEquals( 0, $session->getUser()->getId() ); + $this->assertSame( 0, $session->getUser()->getId() ); $this->assertSame( [ [ LogLevel::INFO, 'creating new user ({username}) - from: {from}' ], ], $logger->getBuffer() ); diff --git a/tests/phpunit/includes/block/BlockManagerTest.php b/tests/phpunit/includes/block/BlockManagerTest.php index d4133b7f93..230d36a31d 100644 --- a/tests/phpunit/includes/block/BlockManagerTest.php +++ b/tests/phpunit/includes/block/BlockManagerTest.php @@ -6,6 +6,7 @@ use MediaWiki\Block\CompositeBlock; use MediaWiki\Block\SystemBlock; use MediaWiki\MediaWikiServices; use Wikimedia\TestingAccessWrapper; +use Psr\Log\LoggerInterface; /** * @group Blocking @@ -48,15 +49,15 @@ class BlockManagerTest extends MediaWikiTestCase { private function getBlockManagerConstructorArgs( $overrideConfig ) { $blockManagerConfig = array_merge( $this->blockManagerConfig, $overrideConfig ); $this->setMwGlobals( $blockManagerConfig ); + $logger = $this->getMockBuilder( LoggerInterface::class )->getMock(); return [ new LoggedServiceOptions( self::$serviceOptionsAccessLog, BlockManager::$constructorOptions, MediaWikiServices::getInstance()->getMainConfig() ), - $this->user, - $this->user->getRequest(), - MediaWikiServices::getInstance()->getPermissionManager() + MediaWikiServices::getInstance()->getPermissionManager(), + $logger ]; } diff --git a/tests/phpunit/includes/block/BlockRestrictionStoreTest.php b/tests/phpunit/includes/block/BlockRestrictionStoreTest.php index ebbfde27c0..b1e23baabf 100644 --- a/tests/phpunit/includes/block/BlockRestrictionStoreTest.php +++ b/tests/phpunit/includes/block/BlockRestrictionStoreTest.php @@ -282,7 +282,7 @@ class BlockRestrictionStoreTest extends \MediaWikiLangTestCase { [ 'ir_ipb_id' => $block->getId() ] ); - $this->assertEquals( 0, $result->numRows() ); + $this->assertSame( 0, $result->numRows() ); } /** diff --git a/tests/phpunit/includes/block/DatabaseBlockTest.php b/tests/phpunit/includes/block/DatabaseBlockTest.php index 0ef571db73..9182609ff7 100644 --- a/tests/phpunit/includes/block/DatabaseBlockTest.php +++ b/tests/phpunit/includes/block/DatabaseBlockTest.php @@ -314,7 +314,7 @@ class DatabaseBlockTest extends MediaWikiLangTestCase { $this->assertEquals( 'Meta>MetaWikiUser', $block->getBlocker()->getName(), 'Correct blocker name' ); $this->assertEquals( 'Meta>MetaWikiUser', $block->getByName(), 'Correct blocker name' ); - $this->assertEquals( 0, $block->getBy(), 'Correct blocker id' ); + $this->assertSame( 0, $block->getBy(), 'Correct blocker id' ); } protected function addXffBlocks() { diff --git a/tests/phpunit/includes/cache/MessageCacheTest.php b/tests/phpunit/includes/cache/MessageCacheTest.php index 7abddd44ad..869236b43f 100644 --- a/tests/phpunit/includes/cache/MessageCacheTest.php +++ b/tests/phpunit/includes/cache/MessageCacheTest.php @@ -124,7 +124,7 @@ class MessageCacheTest extends MediaWikiLangTestCase { $this->makePage( 'Go', 'de', 'Race!' ); $dbw->endAtomic( __METHOD__ ); - $this->assertEquals( 0, + $this->assertSame( 0, DeferredUpdates::pendingUpdatesCount(), 'Post-commit deferred update triggers a run of all updates' ); @@ -155,7 +155,7 @@ class MessageCacheTest extends MediaWikiLangTestCase { // Populate one key $this->makePage( 'Key1', 'de', 'Value1' ); - $this->assertEquals( 0, + $this->assertSame( 0, DeferredUpdates::pendingUpdatesCount(), 'Post-commit deferred update triggers a run of all updates' ); $this->assertEquals( 'Value1', $messageCache->get( 'Key1' ), 'Key1 was successfully edited' ); @@ -168,7 +168,7 @@ class MessageCacheTest extends MediaWikiLangTestCase { // Populate the second key $this->makePage( 'Key2', 'de', 'Value2' ); - $this->assertEquals( 0, + $this->assertSame( 0, DeferredUpdates::pendingUpdatesCount(), 'Post-commit deferred update triggers a run of all updates' ); $this->assertEquals( 'Value2', $messageCache->get( 'Key2' ), 'Key2 was successfully edited' ); @@ -208,14 +208,14 @@ class MessageCacheTest extends MediaWikiLangTestCase { MessageCache::singleton()->getMsgFromNamespace( 'allpages', $wgContLanguageCode ); - $this->assertEquals( 0, $dbr->trxLevel() ); + $this->assertSame( 0, $dbr->trxLevel() ); $dbr->setFlag( DBO_TRX, $dbr::REMEMBER_PRIOR ); // make queries trigger TRX MessageCache::singleton()->getMsgFromNamespace( 'go', $wgContLanguageCode ); $dbr->restoreFlags(); - $this->assertEquals( 0, $dbr->trxLevel(), "No DB read queries (content language)" ); + $this->assertSame( 0, $dbr->trxLevel(), "No DB read queries (content language)" ); } public function testNoDBAccessNonContentLanguage() { @@ -223,14 +223,14 @@ class MessageCacheTest extends MediaWikiLangTestCase { MessageCache::singleton()->getMsgFromNamespace( 'allpages/nl', 'nl' ); - $this->assertEquals( 0, $dbr->trxLevel() ); + $this->assertSame( 0, $dbr->trxLevel() ); $dbr->setFlag( DBO_TRX, $dbr::REMEMBER_PRIOR ); // make queries trigger TRX MessageCache::singleton()->getMsgFromNamespace( 'go/nl', 'nl' ); $dbr->restoreFlags(); - $this->assertEquals( 0, $dbr->trxLevel(), "No DB read queries (non-content language)" ); + $this->assertSame( 0, $dbr->trxLevel(), "No DB read queries (non-content language)" ); } /** diff --git a/tests/phpunit/includes/changes/CategoryMembershipChangeTest.php b/tests/phpunit/includes/changes/CategoryMembershipChangeTest.php index 7ad654136d..31929d386a 100644 --- a/tests/phpunit/includes/changes/CategoryMembershipChangeTest.php +++ b/tests/phpunit/includes/changes/CategoryMembershipChangeTest.php @@ -83,12 +83,12 @@ class CategoryMembershipChangeTest extends MediaWikiLangTestCase { $this->assertEquals( '(recentchanges-page-added-to-category: ' . self::$pageName . ')', self::$lastNotifyArgs[3] ); $this->assertEquals( self::$pageName, self::$lastNotifyArgs[4]->getPrefixedText() ); - $this->assertEquals( 0, self::$lastNotifyArgs[5] ); - $this->assertEquals( 0, self::$lastNotifyArgs[6] ); + $this->assertSame( 0, self::$lastNotifyArgs[5] ); + $this->assertSame( 0, self::$lastNotifyArgs[6] ); $this->assertEquals( null, self::$lastNotifyArgs[7] ); $this->assertEquals( 1, self::$lastNotifyArgs[8] ); $this->assertEquals( null, self::$lastNotifyArgs[9] ); - $this->assertEquals( 0, self::$lastNotifyArgs[10] ); + $this->assertSame( 0, self::$lastNotifyArgs[10] ); } public function testChangeRemovedNoRev() { @@ -103,12 +103,12 @@ class CategoryMembershipChangeTest extends MediaWikiLangTestCase { $this->assertEquals( '(recentchanges-page-removed-from-category: ' . self::$pageName . ')', self::$lastNotifyArgs[3] ); $this->assertEquals( self::$pageName, self::$lastNotifyArgs[4]->getPrefixedText() ); - $this->assertEquals( 0, self::$lastNotifyArgs[5] ); - $this->assertEquals( 0, self::$lastNotifyArgs[6] ); + $this->assertSame( 0, self::$lastNotifyArgs[5] ); + $this->assertSame( 0, self::$lastNotifyArgs[6] ); $this->assertEquals( null, self::$lastNotifyArgs[7] ); $this->assertEquals( 1, self::$lastNotifyArgs[8] ); $this->assertEquals( null, self::$lastNotifyArgs[9] ); - $this->assertEquals( 0, self::$lastNotifyArgs[10] ); + $this->assertSame( 0, self::$lastNotifyArgs[10] ); } public function testChangeAddedWithRev() { @@ -127,9 +127,9 @@ class CategoryMembershipChangeTest extends MediaWikiLangTestCase { $this->assertEquals( self::$pageRev->getParentId(), self::$lastNotifyArgs[5] ); $this->assertEquals( $revision->getId(), self::$lastNotifyArgs[6] ); $this->assertEquals( null, self::$lastNotifyArgs[7] ); - $this->assertEquals( 0, self::$lastNotifyArgs[8] ); + $this->assertSame( 0, self::$lastNotifyArgs[8] ); $this->assertEquals( '127.0.0.1', self::$lastNotifyArgs[9] ); - $this->assertEquals( 0, self::$lastNotifyArgs[10] ); + $this->assertSame( 0, self::$lastNotifyArgs[10] ); } public function testChangeRemovedWithRev() { @@ -148,9 +148,9 @@ class CategoryMembershipChangeTest extends MediaWikiLangTestCase { $this->assertEquals( self::$pageRev->getParentId(), self::$lastNotifyArgs[5] ); $this->assertEquals( $revision->getId(), self::$lastNotifyArgs[6] ); $this->assertEquals( null, self::$lastNotifyArgs[7] ); - $this->assertEquals( 0, self::$lastNotifyArgs[8] ); + $this->assertSame( 0, self::$lastNotifyArgs[8] ); $this->assertEquals( '127.0.0.1', self::$lastNotifyArgs[9] ); - $this->assertEquals( 0, self::$lastNotifyArgs[10] ); + $this->assertSame( 0, self::$lastNotifyArgs[10] ); } } diff --git a/tests/phpunit/includes/changes/EnhancedChangesListTest.php b/tests/phpunit/includes/changes/EnhancedChangesListTest.php index 1511d46c5c..895a3cbdaa 100644 --- a/tests/phpunit/includes/changes/EnhancedChangesListTest.php +++ b/tests/phpunit/includes/changes/EnhancedChangesListTest.php @@ -76,7 +76,7 @@ class EnhancedChangesListTest extends MediaWikiLangTestCase { $recentChange2 = $this->getEditChange( '20131103092253' ); $html = $enhancedChangesList->recentChangesLine( $recentChange2, false ); - $this->assertEquals( '', $html ); + $this->assertSame( '', $html ); } public function testRecentChangesPrefix() { diff --git a/tests/phpunit/includes/changes/RCCacheEntryFactoryTest.php b/tests/phpunit/includes/changes/RCCacheEntryFactoryTest.php index 8f914b714a..a59ba7dcff 100644 --- a/tests/phpunit/includes/changes/RCCacheEntryFactoryTest.php +++ b/tests/phpunit/includes/changes/RCCacheEntryFactoryTest.php @@ -61,7 +61,7 @@ class RCCacheEntryFactoryTest extends MediaWikiLangTestCase { $this->assertEquals( false, $cacheEntry->watched, 'watched' ); $this->assertEquals( '21:21', $cacheEntry->timestamp, 'timestamp' ); - $this->assertEquals( 0, $cacheEntry->numberofWatchingusers, 'watching users' ); + $this->assertSame( 0, $cacheEntry->numberofWatchingusers, 'watching users' ); $this->assertEquals( false, $cacheEntry->unpatrolled, 'unpatrolled' ); $this->assertUserLinks( $user->getName(), $cacheEntry ); @@ -96,7 +96,7 @@ class RCCacheEntryFactoryTest extends MediaWikiLangTestCase { $this->assertEquals( false, $cacheEntry->watched, 'watched' ); $this->assertEquals( '21:21', $cacheEntry->timestamp, 'timestamp' ); - $this->assertEquals( 0, $cacheEntry->numberofWatchingusers, 'watching users' ); + $this->assertSame( 0, $cacheEntry->numberofWatchingusers, 'watching users' ); $this->assertEquals( false, $cacheEntry->unpatrolled, 'unpatrolled' ); $this->assertDeleteLogLink( $cacheEntry ); @@ -130,7 +130,7 @@ class RCCacheEntryFactoryTest extends MediaWikiLangTestCase { $this->assertEquals( false, $cacheEntry->watched, 'watched' ); $this->assertEquals( '21:21', $cacheEntry->timestamp, 'timestamp' ); - $this->assertEquals( 0, $cacheEntry->numberofWatchingusers, 'watching users' ); + $this->assertSame( 0, $cacheEntry->numberofWatchingusers, 'watching users' ); $this->assertEquals( false, $cacheEntry->unpatrolled, 'unpatrolled' ); $this->assertRevDel( $cacheEntry ); diff --git a/tests/phpunit/includes/content/ContentHandlerTest.php b/tests/phpunit/includes/content/ContentHandlerTest.php index e73b554561..39b538025d 100644 --- a/tests/phpunit/includes/content/ContentHandlerTest.php +++ b/tests/phpunit/includes/content/ContentHandlerTest.php @@ -181,7 +181,7 @@ class ContentHandlerTest extends MediaWikiTestCase { $content = null; $text = ContentHandler::getContentText( $content ); - $this->assertEquals( '', $text ); + $this->assertSame( '', $text ); } public static function dataGetContentText_TextContent() { diff --git a/tests/phpunit/includes/content/UnknownContentHandlerTest.php b/tests/phpunit/includes/content/UnknownContentHandlerTest.php index bc1d3c6405..057228975d 100644 --- a/tests/phpunit/includes/content/UnknownContentHandlerTest.php +++ b/tests/phpunit/includes/content/UnknownContentHandlerTest.php @@ -49,7 +49,7 @@ class UnknownContentHandlerTest extends MediaWikiLangTestCase { $content = $handler->makeEmptyContent(); $this->assertTrue( $content->isEmpty() ); - $this->assertEquals( '', $content->getData() ); + $this->assertSame( '', $content->getData() ); } public static function dataIsSupportedFormat() { diff --git a/tests/phpunit/includes/content/UnknownContentTest.php b/tests/phpunit/includes/content/UnknownContentTest.php index fd8e3ba585..2b6f3f1ff2 100644 --- a/tests/phpunit/includes/content/UnknownContentTest.php +++ b/tests/phpunit/includes/content/UnknownContentTest.php @@ -139,7 +139,7 @@ class UnknownContentTest extends MediaWikiLangTestCase { public function testGetWikitextForTransclusion() { $content = $this->newContent( 'hello world.' ); - $this->assertEquals( '', $content->getWikitextForTransclusion() ); + $this->assertFalse( $content->getWikitextForTransclusion() ); } /** diff --git a/tests/phpunit/includes/content/WikitextContentHandlerTest.php b/tests/phpunit/includes/content/WikitextContentHandlerTest.php index b372e37c9f..e18cecb402 100644 --- a/tests/phpunit/includes/content/WikitextContentHandlerTest.php +++ b/tests/phpunit/includes/content/WikitextContentHandlerTest.php @@ -64,7 +64,7 @@ class WikitextContentHandlerTest extends MediaWikiLangTestCase { $content = $this->handler->makeEmptyContent(); $this->assertTrue( $content->isEmpty() ); - $this->assertEquals( '', $content->getText() ); + $this->assertSame( '', $content->getText() ); } public static function dataIsSupportedFormat() { diff --git a/tests/phpunit/includes/context/RequestContextTest.php b/tests/phpunit/includes/context/RequestContextTest.php index 32e71e055c..3bb79e4a0f 100644 --- a/tests/phpunit/includes/context/RequestContextTest.php +++ b/tests/phpunit/includes/context/RequestContextTest.php @@ -49,7 +49,7 @@ class RequestContextTest extends MediaWikiTestCase { $oInfo = $context->exportSession(); $this->assertEquals( '127.0.0.1', $oInfo['ip'], "Correct initial IP address." ); - $this->assertEquals( 0, $oInfo['userId'], "Correct initial user ID." ); + $this->assertSame( 0, $oInfo['userId'], "Correct initial user ID." ); $this->assertFalse( MediaWiki\Session\SessionManager::getGlobalSession()->isPersistent(), 'Global session isn\'t persistent to start' ); diff --git a/tests/phpunit/includes/db/LBFactoryTest.php b/tests/phpunit/includes/db/LBFactoryTest.php index c789e83082..f00499f35d 100644 --- a/tests/phpunit/includes/db/LBFactoryTest.php +++ b/tests/phpunit/includes/db/LBFactoryTest.php @@ -187,7 +187,7 @@ class LBFactoryTest extends MediaWikiTestCase { }; $factory = $this->newLBFactoryMultiLBs(); - $this->assertEquals( 0, $countLBsFunc( $factory ) ); + $this->assertSame( 0, $countLBsFunc( $factory ) ); $dbw = $factory->getMainLB()->getConnection( DB_MASTER ); $this->assertEquals( 1, $countLBsFunc( $factory ) ); // Test that LoadBalancer instances made during pre-commit callbacks in do not @@ -208,7 +208,7 @@ class LBFactoryTest extends MediaWikiTestCase { $called = 0; $factory = $this->newLBFactoryMultiLBs(); - $this->assertEquals( 0, $countLBsFunc( $factory ) ); + $this->assertSame( 0, $countLBsFunc( $factory ) ); $dbw = $factory->getMainLB()->getConnection( DB_MASTER ); $this->assertEquals( 1, $countLBsFunc( $factory ) ); // Test that LoadBalancer instances made during pre-commit callbacks in do not @@ -475,17 +475,16 @@ class LBFactoryTest extends MediaWikiTestCase { /** @var IMaintainableDatabase $db */ $db = $lb->getConnection( DB_MASTER, [], '' ); - $this->assertEquals( + $this->assertSame( '', $db->getDomainId(), 'Null domain ID handle used' ); - $this->assertEquals( - '', + $this->assertNull( $db->getDBname(), 'Null domain ID handle used' ); - $this->assertEquals( + $this->assertSame( '', $db->tablePrefix(), 'Main domain ID handle used; prefix is empty though' @@ -555,7 +554,7 @@ class LBFactoryTest extends MediaWikiTestCase { /** @var IMaintainableDatabase $db */ $db = $lb->getConnection( DB_MASTER, [], '' ); - $this->assertEquals( '', $db->getDomainID(), "Null domain used" ); + $this->assertSame( '', $db->getDomainID(), "Null domain used" ); $this->assertEquals( $this->quoteTable( $db, 'page' ), @@ -717,7 +716,7 @@ class LBFactoryTest extends MediaWikiTestCase { $lb->forEachOpenConnection( function () use ( &$n ) { ++$n; } ); - $this->assertEquals( 0, $n, "Connections closed" ); + $this->assertSame( 0, $n, "Connections closed" ); $conn2 = $lb->getConnectionRef( DB_MASTER ); $this->assertEquals( diff --git a/tests/phpunit/includes/deferred/LinksUpdateTest.php b/tests/phpunit/includes/deferred/LinksUpdateTest.php index cd3ddfa8e8..1f9d29e26c 100644 --- a/tests/phpunit/includes/deferred/LinksUpdateTest.php +++ b/tests/phpunit/includes/deferred/LinksUpdateTest.php @@ -430,4 +430,18 @@ class LinksUpdateTest extends MediaWikiLangTestCase { $queueGroup->ack( $job ); } } + + public function testIsRecursive() { + list( $title, $po ) = $this->makeTitleAndParserOutput( 'Test', 1 ); + $linksUpdate = new LinksUpdate( $title, $po ); + $this->assertTrue( $linksUpdate->isRecursive(), 'LinksUpdate is recursive by default' ); + + $linksUpdate = new LinksUpdate( $title, $po, true ); + $this->assertTrue( $linksUpdate->isRecursive(), + 'LinksUpdate is recursive when asked to be recursive' ); + + $linksUpdate = new LinksUpdate( $title, $po, false ); + $this->assertFalse( $linksUpdate->isRecursive(), + 'LinksUpdate is not recursive when asked to be not recursive' ); + } } diff --git a/tests/phpunit/includes/deferred/SiteStatsUpdateTest.php b/tests/phpunit/includes/deferred/SiteStatsUpdateTest.php index ccfcc181ee..f820f60346 100644 --- a/tests/phpunit/includes/deferred/SiteStatsUpdateTest.php +++ b/tests/phpunit/includes/deferred/SiteStatsUpdateTest.php @@ -20,8 +20,8 @@ class SiteStatsUpdateTest extends MediaWikiTestCase { $this->assertEquals( 1, $wrapped->pages ); $this->assertEquals( 3, $wrapped->users ); $this->assertEquals( 1, $wrapped->images ); - $this->assertEquals( 0, $wrapped->edits ); - $this->assertEquals( 0, $wrapped->articles ); + $this->assertSame( 0, $wrapped->edits ); + $this->assertSame( 0, $wrapped->articles ); } /** @@ -42,7 +42,7 @@ class SiteStatsUpdateTest extends MediaWikiTestCase { $fi = SiteStats::images(); $ai = SiteStats::articles(); - $this->assertEquals( 0, DeferredUpdates::pendingUpdatesCount() ); + $this->assertSame( 0, DeferredUpdates::pendingUpdatesCount() ); $dbw->begin( __METHOD__ ); // block opportunistic updates @@ -64,7 +64,7 @@ class SiteStatsUpdateTest extends MediaWikiTestCase { $this->assertEquals( 1, DeferredUpdates::pendingUpdatesCount() ); DeferredUpdates::doUpdates(); - $this->assertEquals( 0, DeferredUpdates::pendingUpdatesCount() ); + $this->assertSame( 0, DeferredUpdates::pendingUpdatesCount() ); SiteStats::unload(); $this->assertEquals( $pi + 2, SiteStats::pages(), 'page count' ); diff --git a/tests/phpunit/includes/filebackend/FileBackendTest.php b/tests/phpunit/includes/filebackend/FileBackendTest.php index 3b30d7ef71..7bc7918776 100644 --- a/tests/phpunit/includes/filebackend/FileBackendTest.php +++ b/tests/phpunit/includes/filebackend/FileBackendTest.php @@ -2422,7 +2422,7 @@ class FileBackendTest extends MediaWikiTestCase { "$base/subdir2/subdir/sub/120-px-file.txt", ]; - for ( $i = 0; $i < 25; $i++ ) { + for ( $i = 0; $i < 2; $i++ ) { $status = $this->backend->lockFiles( $paths, LockManager::LOCK_EX ); $this->assertEquals( print_r( [], true ), print_r( $status->getErrors(), true ), "Locking of files succeeded ($backendName) ($i)." ); @@ -2554,7 +2554,7 @@ class FileBackendTest extends MediaWikiTestCase { $be->getReadIndexFromParams( [ 'latest' => 1 ] ), 'Reads with "latest" flag use backend 1' ); - $this->assertEquals( + $this->assertSame( 0, $be->getReadIndexFromParams( [ 'latest' => 0 ] ), 'Reads without "latest" flag use backend 0' diff --git a/tests/phpunit/includes/filebackend/SwiftFileBackendTest.php b/tests/phpunit/includes/filebackend/SwiftFileBackendTest.php index 35eca28f7e..13f2b17578 100644 --- a/tests/phpunit/includes/filebackend/SwiftFileBackendTest.php +++ b/tests/phpunit/includes/filebackend/SwiftFileBackendTest.php @@ -13,7 +13,7 @@ use Wikimedia\TestingAccessWrapper; * @covers SwiftFileBackendList */ class SwiftFileBackendTest extends MediaWikiTestCase { - /** @var TestingAccessWrapper Proxy to SwiftFileBackend */ + /** @var TestingAccessWrapper|SwiftFileBackend */ private $backend; protected function setUp() { @@ -34,26 +34,28 @@ class SwiftFileBackendTest extends MediaWikiTestCase { } /** - * @dataProvider provider_testSanitizeHdrsStrict + * @covers SwiftFileBackend::extractMutableContentHeaders + * @dataProvider provider_testExtractPostableContentHeaders */ - public function testSanitizeHdrsStrict( $raw, $sanitized ) { - $hdrs = $this->backend->sanitizeHdrsStrict( [ 'headers' => $raw ] ); + public function testExtractPostableContentHeaders( $raw, $sanitized ) { + $hdrs = $this->backend->extractMutableContentHeaders( $raw ); - $this->assertEquals( $hdrs, $sanitized, 'sanitizeHdrsStrict() has expected result' ); + $this->assertEquals( $hdrs, $sanitized, 'Correct extractPostableContentHeaders() result' ); } - public static function provider_testSanitizeHdrsStrict() { + public static function provider_testExtractPostableContentHeaders() { return [ [ [ 'content-length' => 345, - 'content-type' => 'image+bitmap/jpeg', + 'content-type' => 'image+bitmap/jpeg', 'content-disposition' => 'inline', 'content-duration' => 35.6363, 'content-Custom' => 'hello', 'x-content-custom' => 'hello' ], [ + 'content-type' => 'image+bitmap/jpeg', 'content-disposition' => 'inline', 'content-duration' => 35.6363, 'content-custom' => 'hello', @@ -63,13 +65,14 @@ class SwiftFileBackendTest extends MediaWikiTestCase { [ [ 'content-length' => 345, - 'content-type' => 'image+bitmap/jpeg', + 'content-type' => 'image+bitmap/jpeg', 'content-Disposition' => 'inline; filename=xxx; ' . str_repeat( 'o', 1024 ), 'content-duration' => 35.6363, 'content-custom' => 'hello', 'x-content-custom' => 'hello' ], [ + 'content-type' => 'image+bitmap/jpeg', 'content-disposition' => 'inline;filename=xxx', 'content-duration' => 35.6363, 'content-custom' => 'hello', @@ -79,13 +82,14 @@ class SwiftFileBackendTest extends MediaWikiTestCase { [ [ 'content-length' => 345, - 'content-type' => 'image+bitmap/jpeg', + 'content-type' => 'image+bitmap/jpeg', 'content-disposition' => 'filename=' . str_repeat( 'o', 1024 ) . ';inline', 'content-duration' => 35.6363, 'content-custom' => 'hello', 'x-content-custom' => 'hello' ], [ + 'content-type' => 'image+bitmap/jpeg', 'content-disposition' => '', 'content-duration' => 35.6363, 'content-custom' => 'hello', @@ -96,75 +100,11 @@ class SwiftFileBackendTest extends MediaWikiTestCase { } /** - * @dataProvider provider_testSanitizeHdrs - */ - public function testSanitizeHdrs( $raw, $sanitized ) { - $hdrs = $this->backend->sanitizeHdrs( [ 'headers' => $raw ] ); - - $this->assertEquals( $hdrs, $sanitized, 'sanitizeHdrs() has expected result' ); - } - - public static function provider_testSanitizeHdrs() { - return [ - [ - [ - 'content-length' => 345, - 'content-type' => 'image+bitmap/jpeg', - 'content-disposition' => 'inline', - 'content-duration' => 35.6363, - 'content-Custom' => 'hello', - 'x-content-custom' => 'hello' - ], - [ - 'content-type' => 'image+bitmap/jpeg', - 'content-disposition' => 'inline', - 'content-duration' => 35.6363, - 'content-custom' => 'hello', - 'x-content-custom' => 'hello' - ] - ], - [ - [ - 'content-length' => 345, - 'content-type' => 'image+bitmap/jpeg', - 'content-Disposition' => 'inline; filename=xxx; ' . str_repeat( 'o', 1024 ), - 'content-duration' => 35.6363, - 'content-custom' => 'hello', - 'x-content-custom' => 'hello' - ], - [ - 'content-type' => 'image+bitmap/jpeg', - 'content-disposition' => 'inline;filename=xxx', - 'content-duration' => 35.6363, - 'content-custom' => 'hello', - 'x-content-custom' => 'hello' - ] - ], - [ - [ - 'content-length' => 345, - 'content-type' => 'image+bitmap/jpeg', - 'content-disposition' => 'filename=' . str_repeat( 'o', 1024 ) . ';inline', - 'content-duration' => 35.6363, - 'content-custom' => 'hello', - 'x-content-custom' => 'hello' - ], - [ - 'content-type' => 'image+bitmap/jpeg', - 'content-disposition' => '', - 'content-duration' => 35.6363, - 'content-custom' => 'hello', - 'x-content-custom' => 'hello' - ] - ] - ]; - } - - /** + * @covers SwiftFileBackend::extractMetadataHeaders * @dataProvider provider_testGetMetadataHeaders */ public function testGetMetadataHeaders( $raw, $sanitized ) { - $hdrs = $this->backend->getMetadataHeaders( $raw ); + $hdrs = $this->backend->extractMetadataHeaders( $raw ); $this->assertEquals( $hdrs, $sanitized, 'getMetadataHeaders() has expected result' ); } @@ -188,10 +128,11 @@ class SwiftFileBackendTest extends MediaWikiTestCase { } /** + * @covers SwiftFileBackend::getMetadataFromHeaders * @dataProvider provider_testGetMetadata */ public function testGetMetadata( $raw, $sanitized ) { - $hdrs = $this->backend->getMetadata( $raw ); + $hdrs = $this->backend->getMetadataFromHeaders( $raw ); $this->assertEquals( $hdrs, $sanitized, 'getMetadata() has expected result' ); } diff --git a/tests/phpunit/includes/filerepo/file/LocalFileTest.php b/tests/phpunit/includes/filerepo/file/LocalFileTest.php index 7acd237203..fe5dba1beb 100644 --- a/tests/phpunit/includes/filerepo/file/LocalFileTest.php +++ b/tests/phpunit/includes/filerepo/file/LocalFileTest.php @@ -52,7 +52,7 @@ class LocalFileTest extends MediaWikiTestCase { * @covers File::getHashPath */ public function testGetHashPath() { - $this->assertEquals( '', $this->file_hl0->getHashPath() ); + $this->assertSame( '', $this->file_hl0->getHashPath() ); $this->assertEquals( 'a/a2/', $this->file_hl2->getHashPath() ); $this->assertEquals( 'c/c4/', $this->file_lc->getHashPath() ); } @@ -193,4 +193,26 @@ class LocalFileTest extends MediaWikiTestCase { 'wfLocalFile() returns LocalFile for valid Titles' ); } + + /** + * @covers File::getUser + */ + public function testGetUserForNonExistingFile() { + $this->assertSame( 'Unknown user', $this->file_hl0->getUser() ); + $this->assertSame( 0, $this->file_hl0->getUser( 'id' ) ); + } + + /** + * @covers File::getUser + */ + public function testDescriptionShortUrlForNonExistingFile() { + $this->assertNull( $this->file_hl0->getDescriptionShortUrl() ); + } + + /** + * @covers File::getUser + */ + public function testDescriptionTextForNonExistingFile() { + $this->assertFalse( $this->file_hl0->getDescriptionText() ); + } } diff --git a/tests/phpunit/includes/http/GuzzleHttpRequestTest.php b/tests/phpunit/includes/http/GuzzleHttpRequestTest.php index c9356b6b10..ff0a9eb0bc 100644 --- a/tests/phpunit/includes/http/GuzzleHttpRequestTest.php +++ b/tests/phpunit/includes/http/GuzzleHttpRequestTest.php @@ -109,7 +109,7 @@ class GuzzleHttpRequestTest extends MediaWikiTestCase { $s = $r->execute(); $errorMsg = $s->getErrorsByType( 'error' )[0]['message']; - $this->assertEquals( 0, $r->getStatus() ); + $this->assertSame( 0, $r->getStatus() ); $this->assertEquals( 'http-invalid-url', $errorMsg ); } @@ -121,7 +121,7 @@ class GuzzleHttpRequestTest extends MediaWikiTestCase { $s = $r->execute(); $errorMsg = $s->getErrorsByType( 'error' )[0]['message']; - $this->assertEquals( 0, $r->getStatus() ); + $this->assertSame( 0, $r->getStatus() ); $this->assertEquals( 'http-request-error', $errorMsg ); } @@ -133,7 +133,7 @@ class GuzzleHttpRequestTest extends MediaWikiTestCase { $s = $r->execute(); $errorMsg = $s->getErrorsByType( 'error' )[0]['message']; - $this->assertEquals( 0, $r->getStatus() ); + $this->assertSame( 0, $r->getStatus() ); $this->assertEquals( 'http-timed-out', $errorMsg ); } diff --git a/tests/phpunit/includes/http/HttpTest.php b/tests/phpunit/includes/http/HttpTest.php index ef499a1ee7..94b8c91b4e 100644 --- a/tests/phpunit/includes/http/HttpTest.php +++ b/tests/phpunit/includes/http/HttpTest.php @@ -14,7 +14,7 @@ class HttpTest extends MediaWikiTestCase { $this->hideDeprecated( 'Http::getProxy' ); $this->setMwGlobals( 'wgHTTPProxy', false ); - $this->assertEquals( + $this->assertSame( '', Http::getProxy(), 'default setting' diff --git a/tests/phpunit/includes/jobqueue/JobQueueTest.php b/tests/phpunit/includes/jobqueue/JobQueueTest.php index 8f8dde5559..1db708540f 100644 --- a/tests/phpunit/includes/jobqueue/JobQueueTest.php +++ b/tests/phpunit/includes/jobqueue/JobQueueTest.php @@ -108,8 +108,8 @@ class JobQueueTest extends MediaWikiTestCase { $this->assertTrue( $queue->isEmpty(), "Queue is empty ($desc)" ); $queue->flushCaches(); - $this->assertEquals( 0, $queue->getSize(), "Queue is empty ($desc)" ); - $this->assertEquals( 0, $queue->getAcquiredCount(), "Queue is empty ($desc)" ); + $this->assertSame( 0, $queue->getSize(), "Queue is empty ($desc)" ); + $this->assertSame( 0, $queue->getAcquiredCount(), "Queue is empty ($desc)" ); $this->assertNull( $queue->push( $this->newJob() ), "Push worked ($desc)" ); $this->assertNull( $queue->batchPush( [ $this->newJob() ] ), "Push worked ($desc)" ); @@ -118,7 +118,7 @@ class JobQueueTest extends MediaWikiTestCase { $queue->flushCaches(); $this->assertEquals( 2, $queue->getSize(), "Queue size is correct ($desc)" ); - $this->assertEquals( 0, $queue->getAcquiredCount(), "No jobs active ($desc)" ); + $this->assertSame( 0, $queue->getAcquiredCount(), "No jobs active ($desc)" ); $jobs = iterator_to_array( $queue->getAllQueuedJobs() ); $this->assertEquals( 2, count( $jobs ), "Queue iterator size is correct ($desc)" ); @@ -135,7 +135,7 @@ class JobQueueTest extends MediaWikiTestCase { $job2 = $queue->pop(); $this->assertTrue( $queue->isEmpty(), "Queue is empty ($desc)" ); - $this->assertEquals( 0, $queue->getSize(), "Queue is empty ($desc)" ); + $this->assertSame( 0, $queue->getSize(), "Queue is empty ($desc)" ); $queue->flushCaches(); if ( $recycles ) { @@ -152,7 +152,7 @@ class JobQueueTest extends MediaWikiTestCase { $queue->ack( $job2 ); $queue->flushCaches(); - $this->assertEquals( 0, $queue->getAcquiredCount(), "Active job count ($desc)" ); + $this->assertSame( 0, $queue->getAcquiredCount(), "Active job count ($desc)" ); $this->assertNull( $queue->batchPush( [ $this->newJob(), $this->newJob() ] ), "Push worked ($desc)" ); @@ -161,7 +161,7 @@ class JobQueueTest extends MediaWikiTestCase { $queue->delete(); $queue->flushCaches(); $this->assertTrue( $queue->isEmpty(), "Queue is empty ($desc)" ); - $this->assertEquals( 0, $queue->getSize(), "Queue is empty ($desc)" ); + $this->assertSame( 0, $queue->getSize(), "Queue is empty ($desc)" ); } /** @@ -177,8 +177,8 @@ class JobQueueTest extends MediaWikiTestCase { $this->assertTrue( $queue->isEmpty(), "Queue is empty ($desc)" ); $queue->flushCaches(); - $this->assertEquals( 0, $queue->getSize(), "Queue is empty ($desc)" ); - $this->assertEquals( 0, $queue->getAcquiredCount(), "Queue is empty ($desc)" ); + $this->assertSame( 0, $queue->getSize(), "Queue is empty ($desc)" ); + $this->assertSame( 0, $queue->getAcquiredCount(), "Queue is empty ($desc)" ); $this->assertNull( $queue->batchPush( @@ -190,7 +190,7 @@ class JobQueueTest extends MediaWikiTestCase { $queue->flushCaches(); $this->assertEquals( 1, $queue->getSize(), "Queue size is correct ($desc)" ); - $this->assertEquals( 0, $queue->getAcquiredCount(), "No jobs active ($desc)" ); + $this->assertSame( 0, $queue->getAcquiredCount(), "No jobs active ($desc)" ); $this->assertNull( $queue->batchPush( @@ -203,13 +203,13 @@ class JobQueueTest extends MediaWikiTestCase { $queue->flushCaches(); $this->assertEquals( 1, $queue->getSize(), "Queue size is correct ($desc)" ); - $this->assertEquals( 0, $queue->getAcquiredCount(), "No jobs active ($desc)" ); + $this->assertSame( 0, $queue->getAcquiredCount(), "No jobs active ($desc)" ); $job1 = $queue->pop(); $this->assertTrue( $queue->isEmpty(), "Queue is empty ($desc)" ); $queue->flushCaches(); - $this->assertEquals( 0, $queue->getSize(), "Queue is empty ($desc)" ); + $this->assertSame( 0, $queue->getSize(), "Queue is empty ($desc)" ); if ( $recycles ) { $this->assertEquals( 1, $queue->getAcquiredCount(), "Active job count ($desc)" ); } @@ -217,7 +217,7 @@ class JobQueueTest extends MediaWikiTestCase { $queue->ack( $job1 ); $queue->flushCaches(); - $this->assertEquals( 0, $queue->getAcquiredCount(), "Active job count ($desc)" ); + $this->assertSame( 0, $queue->getAcquiredCount(), "Active job count ($desc)" ); } /** @@ -256,8 +256,8 @@ class JobQueueTest extends MediaWikiTestCase { $this->assertTrue( $queue->isEmpty(), "Queue is empty ($desc)" ); $queue->flushCaches(); - $this->assertEquals( 0, $queue->getSize(), "Queue is empty ($desc)" ); - $this->assertEquals( 0, $queue->getAcquiredCount(), "Queue is empty ($desc)" ); + $this->assertSame( 0, $queue->getSize(), "Queue is empty ($desc)" ); + $this->assertSame( 0, $queue->getAcquiredCount(), "Queue is empty ($desc)" ); $root1 = Job::newRootJobParams( "nulljobspam:testId" ); // task ID/timestamp for ( $i = 0; $i < 5; ++$i ) { @@ -282,7 +282,7 @@ class JobQueueTest extends MediaWikiTestCase { $queue->flushCaches(); $this->assertEquals( 10, $queue->getSize(), "Queue size is correct ($desc)" ); - $this->assertEquals( 0, $queue->getAcquiredCount(), "No jobs active ($desc)" ); + $this->assertSame( 0, $queue->getAcquiredCount(), "No jobs active ($desc)" ); $dupcount = 0; $jobs = []; @@ -314,8 +314,8 @@ class JobQueueTest extends MediaWikiTestCase { $this->assertTrue( $queue->isEmpty(), "Queue is empty ($desc)" ); $queue->flushCaches(); - $this->assertEquals( 0, $queue->getSize(), "Queue is empty ($desc)" ); - $this->assertEquals( 0, $queue->getAcquiredCount(), "Queue is empty ($desc)" ); + $this->assertSame( 0, $queue->getSize(), "Queue is empty ($desc)" ); + $this->assertSame( 0, $queue->getAcquiredCount(), "Queue is empty ($desc)" ); for ( $i = 0; $i < 10; ++$i ) { $this->assertNull( $queue->push( $this->newJob( $i ) ), "Push worked ($desc)" ); @@ -332,8 +332,8 @@ class JobQueueTest extends MediaWikiTestCase { $this->assertFalse( $queue->pop(), "Queue is not empty ($desc)" ); $queue->flushCaches(); - $this->assertEquals( 0, $queue->getSize(), "Queue is empty ($desc)" ); - $this->assertEquals( 0, $queue->getAcquiredCount(), "No jobs active ($desc)" ); + $this->assertSame( 0, $queue->getSize(), "Queue is empty ($desc)" ); + $this->assertSame( 0, $queue->getAcquiredCount(), "No jobs active ($desc)" ); } /** diff --git a/tests/phpunit/includes/jobqueue/jobs/ClearUserWatchlistJobTest.php b/tests/phpunit/includes/jobqueue/jobs/ClearUserWatchlistJobTest.php index 90b57f2aff..c7596bf46f 100644 --- a/tests/phpunit/includes/jobqueue/jobs/ClearUserWatchlistJobTest.php +++ b/tests/phpunit/includes/jobqueue/jobs/ClearUserWatchlistJobTest.php @@ -66,7 +66,7 @@ class ClearUserWatchlistJobTest extends MediaWikiTestCase { $this->assertEquals( 1, JobQueueGroup::singleton()->getQueueSizes()['clearUserWatchlist'] ); $this->assertEquals( 2, $watchedItemStore->countWatchedItems( $user ) ); $this->runJobs( 1 ); - $this->assertEquals( 0, JobQueueGroup::singleton()->getQueueSizes()['clearUserWatchlist'] ); + $this->assertSame( 0, JobQueueGroup::singleton()->getQueueSizes()['clearUserWatchlist'] ); $this->assertEquals( 2, $watchedItemStore->countWatchedItems( $user ) ); $this->assertTrue( $watchedItemStore->isWatched( $user, new TitleValue( 0, 'C' ) ) ); diff --git a/tests/phpunit/includes/libs/ProcessCacheLRUTest.php b/tests/phpunit/includes/libs/ProcessCacheLRUTest.php index 8e91e70cb0..78af366e6b 100644 --- a/tests/phpunit/includes/libs/ProcessCacheLRUTest.php +++ b/tests/phpunit/includes/libs/ProcessCacheLRUTest.php @@ -16,7 +16,7 @@ class ProcessCacheLRUTest extends PHPUnit\Framework\TestCase { * Compare against an array so we get the cache content difference. */ protected function assertCacheEmpty( $cache, $msg = 'Cache should be empty' ) { - $this->assertEquals( 0, $cache->getEntriesCount(), $msg ); + $this->assertSame( 0, $cache->getEntriesCount(), $msg ); } /** diff --git a/tests/phpunit/includes/libs/StringUtilsTest.php b/tests/phpunit/includes/libs/StringUtilsTest.php index fcfa53e22d..79d5788fa2 100644 --- a/tests/phpunit/includes/libs/StringUtilsTest.php +++ b/tests/phpunit/includes/libs/StringUtilsTest.php @@ -125,4 +125,28 @@ class StringUtilsTest extends PHPUnit\Framework\TestCase { 'noncharacters 2' => [ $PASS, "\xef\xbf\xbf" ], ]; } + + /** + * @param strin $input + * @param bool $expected + * @dataProvider provideRegexps + * @covers StringUtils::isValidRegex + */ + public function testIsValidRegex( $input, $expected ) { + $this->assertSame( $expected, StringUtils::isValidRegex( $input ) ); + } + + /** + * Data provider for testValidRegex + */ + public static function provideRegexps() { + return [ + [ 'foo', false ], + [ '/foo/', true ], + [ '//', true ], + [ '/(foo/', false ], + [ '!(f[o]{2})!', true ], + [ '/foo\/', false ] + ]; + } } diff --git a/tests/phpunit/includes/libs/TimingTest.php b/tests/phpunit/includes/libs/TimingTest.php index 581a518626..90abd8cf7d 100644 --- a/tests/phpunit/includes/libs/TimingTest.php +++ b/tests/phpunit/includes/libs/TimingTest.php @@ -55,7 +55,7 @@ class TimingTest extends PHPUnit\Framework\TestCase { $this->assertEquals( 'a', $entry['name'] ); $this->assertEquals( 'mark', $entry['entryType'] ); $this->assertArrayHasKey( 'startTime', $entry ); - $this->assertEquals( 0, $entry['duration'] ); + $this->assertSame( 0, $entry['duration'] ); usleep( 100 ); $timing->mark( 'a' ); diff --git a/tests/phpunit/includes/libs/objectcache/HashBagOStuffTest.php b/tests/phpunit/includes/libs/objectcache/HashBagOStuffTest.php index 332e23b25b..3e082503c1 100644 --- a/tests/phpunit/includes/libs/objectcache/HashBagOStuffTest.php +++ b/tests/phpunit/includes/libs/objectcache/HashBagOStuffTest.php @@ -82,7 +82,7 @@ class HashBagOStuffTest extends PHPUnit\Framework\TestCase { $cache->set( 'bar', 1, 10 ); $cache->set( 'baz', 1, -10 ); - $this->assertEquals( 0, $cacheInternal->bag['foo'][$cache::KEY_EXP], 'Indefinite' ); + $this->assertSame( 0, $cacheInternal->bag['foo'][$cache::KEY_EXP], 'Indefinite' ); // 2 seconds tolerance $this->assertEquals( time() + 10, $cacheInternal->bag['bar'][$cache::KEY_EXP], 'Future', 2 ); $this->assertEquals( time() - 10, $cacheInternal->bag['baz'][$cache::KEY_EXP], 'Past', 2 ); diff --git a/tests/phpunit/includes/libs/objectcache/WANObjectCacheTest.php b/tests/phpunit/includes/libs/objectcache/WANObjectCacheTest.php index ac988e6467..7c4c9bf944 100644 --- a/tests/phpunit/includes/libs/objectcache/WANObjectCacheTest.php +++ b/tests/phpunit/includes/libs/objectcache/WANObjectCacheTest.php @@ -318,7 +318,7 @@ class WANObjectCacheTest extends PHPUnit\Framework\TestCase { $v = $cache->getWithSetCallback( $key, 30, $func, [ 'lowTTL' => 0, 'lockTSE' => 5 ] + $extOpts ); $this->assertEquals( $value, $v, "Value returned" ); - $this->assertEquals( 0, $wasSet, "Value not regenerated" ); + $this->assertSame( 0, $wasSet, "Value not regenerated" ); $mockWallClock += 1; @@ -584,7 +584,7 @@ class WANObjectCacheTest extends PHPUnit\Framework\TestCase { $asycList[0](); // run the refresh callback $asycList = []; $this->assertEquals( 2, $wasSet, "Value calculated at later time" ); - $this->assertEquals( 0, count( $asycList ), "No deferred refreshes added." ); + $this->assertSame( 0, count( $asycList ), "No deferred refreshes added." ); $v = $cache->getWithSetCallback( $key, 300, $func, $opts ); $this->assertEquals( $value, $v, "New value stored" ); @@ -678,13 +678,13 @@ class WANObjectCacheTest extends PHPUnit\Framework\TestCase { $keyedIds, 30, $genFunc, [ 'lowTTL' => 0, 'lockTSE' => 5 ] + $extOpts ); $this->assertEquals( $value, $v[$keyB], "Value returned" ); $this->assertEquals( 1, $wasSet, "Value regenerated" ); - $this->assertEquals( 0, $cache->getWarmupKeyMisses(), "Keys warmed in warmup cache" ); + $this->assertSame( 0, $cache->getWarmupKeyMisses(), "Keys warmed in warmup cache" ); $v = $cache->getMultiWithSetCallback( $keyedIds, 30, $genFunc, [ 'lowTTL' => 0, 'lockTSE' => 5 ] + $extOpts ); $this->assertEquals( $value, $v[$keyB], "Value returned" ); $this->assertEquals( 1, $wasSet, "Value not regenerated" ); - $this->assertEquals( 0, $cache->getWarmupKeyMisses(), "Keys warmed in warmup cache" ); + $this->assertSame( 0, $cache->getWarmupKeyMisses(), "Keys warmed in warmup cache" ); $mockWallClock += 1; @@ -846,13 +846,13 @@ class WANObjectCacheTest extends PHPUnit\Framework\TestCase { $keyedIds, 30, $genFunc, [ 'lowTTL' => 0 ] + $extOpts ); $this->assertEquals( $value, $v[$keyB], "Value returned" ); $this->assertEquals( 1, $wasSet, "Value regenerated" ); - $this->assertEquals( 0, $cache->getWarmupKeyMisses(), "Keys warmed in warmup cache" ); + $this->assertSame( 0, $cache->getWarmupKeyMisses(), "Keys warmed in warmup cache" ); $v = $cache->getMultiWithUnionSetCallback( $keyedIds, 30, $genFunc, [ 'lowTTL' => 0 ] + $extOpts ); $this->assertEquals( $value, $v[$keyB], "Value returned" ); $this->assertEquals( 1, $wasSet, "Value not regenerated" ); - $this->assertEquals( 0, $cache->getWarmupKeyMisses(), "Keys warmed in warmup cache" ); + $this->assertSame( 0, $cache->getWarmupKeyMisses(), "Keys warmed in warmup cache" ); $mockWallClock += 1; @@ -1478,7 +1478,7 @@ class WANObjectCacheTest extends PHPUnit\Framework\TestCase { $wasSet = 0; $v = $cache->getWithSetCallback( $key, 30, $funcV2, $verOpts + $extOpts ); $this->assertEquals( $valueV2, $v, "Value not regenerated (secondary key)" ); - $this->assertEquals( 0, $wasSet, "Value not regenerated (secondary key)" ); + $this->assertSame( 0, $wasSet, "Value not regenerated (secondary key)" ); // Clear out the older or unversioned key $cache->delete( $key, 0 ); @@ -1981,6 +1981,8 @@ class WANObjectCacheTest extends PHPUnit\Framework\TestCase { [ 'domain:page:5', 'page' ], [ 'domain:main-key', 'main-key' ], [ 'domain:page:history', 'page' ], + // Regression test for T232907 + [ 'domain:foo-bar-1.2:abc:v2', 'foo-bar-1_2' ], [ 'missingdomainkey', 'missingdomainkey' ] ]; } diff --git a/tests/phpunit/includes/libs/rdbms/database/DatabaseSQLTest.php b/tests/phpunit/includes/libs/rdbms/database/DatabaseSQLTest.php index 4419533fed..16f6a6c053 100644 --- a/tests/phpunit/includes/libs/rdbms/database/DatabaseSQLTest.php +++ b/tests/phpunit/includes/libs/rdbms/database/DatabaseSQLTest.php @@ -2014,7 +2014,7 @@ class DatabaseSQLTest extends PHPUnit\Framework\TestCase { $this->database->startAtomic( __METHOD__ ); $wrapper->trxStatus = Database::STATUS_TRX_ERROR; $this->database->rollback( __METHOD__ ); - $this->assertEquals( 0, $this->database->trxLevel() ); + $this->assertSame( 0, $this->database->trxLevel() ); $this->assertEquals( Database::STATUS_TRX_NONE, $wrapper->trxStatus() ); $this->assertLastSql( 'BEGIN; ROLLBACK' ); @@ -2024,7 +2024,7 @@ class DatabaseSQLTest extends PHPUnit\Framework\TestCase { $this->database->endAtomic( __METHOD__ ); $this->assertEquals( Database::STATUS_TRX_NONE, $wrapper->trxStatus() ); $this->assertLastSql( 'BEGIN; DELETE FROM x WHERE field = \'1\'; COMMIT' ); - $this->assertEquals( 0, $this->database->trxLevel(), 'Use after rollback()' ); + $this->assertSame( 0, $this->database->trxLevel(), 'Use after rollback()' ); $this->database->begin( __METHOD__ ); $this->database->startAtomic( __METHOD__, Database::ATOMIC_CANCELABLE ); @@ -2038,7 +2038,7 @@ class DatabaseSQLTest extends PHPUnit\Framework\TestCase { $this->database->commit( __METHOD__ ); // phpcs:ignore Generic.Files.LineLength $this->assertLastSql( 'BEGIN; SAVEPOINT wikimedia_rdbms_atomic1; UPDATE y SET a = \'1\' WHERE field = \'1\'; ROLLBACK TO SAVEPOINT wikimedia_rdbms_atomic1; DELETE FROM y WHERE field = \'1\'; COMMIT' ); - $this->assertEquals( 0, $this->database->trxLevel(), 'Use after rollback()' ); + $this->assertSame( 0, $this->database->trxLevel(), 'Use after rollback()' ); // Next transaction $this->database->startAtomic( __METHOD__ ); @@ -2047,7 +2047,7 @@ class DatabaseSQLTest extends PHPUnit\Framework\TestCase { $this->database->endAtomic( __METHOD__ ); $this->assertEquals( Database::STATUS_TRX_NONE, $wrapper->trxStatus() ); $this->assertLastSql( 'BEGIN; DELETE FROM x WHERE field = \'3\'; COMMIT' ); - $this->assertEquals( 0, $this->database->trxLevel() ); + $this->assertSame( 0, $this->database->trxLevel() ); } /** @@ -2194,7 +2194,7 @@ class DatabaseSQLTest extends PHPUnit\Framework\TestCase { $this->assertFalse( $this->database->isOpen() ); $this->assertLastSql( 'BEGIN; DELETE FROM x WHERE field = \'3\'; ROLLBACK; SELECT 2' ); - $this->assertEquals( 0, $this->database->trxLevel() ); + $this->assertSame( 0, $this->database->trxLevel() ); } /** @@ -2223,7 +2223,7 @@ class DatabaseSQLTest extends PHPUnit\Framework\TestCase { $this->assertFalse( $this->database->isOpen() ); $this->assertLastSql( 'BEGIN; DELETE FROM x WHERE field = \'3\'; ROLLBACK; SELECT 2' ); - $this->assertEquals( 0, $this->database->trxLevel() ); + $this->assertSame( 0, $this->database->trxLevel() ); } /** @@ -2246,7 +2246,7 @@ class DatabaseSQLTest extends PHPUnit\Framework\TestCase { $this->assertFalse( $this->database->isOpen() ); $this->assertLastSql( 'BEGIN; DELETE FROM x WHERE field = \'3\'; ROLLBACK' ); - $this->assertEquals( 0, $this->database->trxLevel() ); + $this->assertSame( 0, $this->database->trxLevel() ); } /** @@ -2261,7 +2261,7 @@ class DatabaseSQLTest extends PHPUnit\Framework\TestCase { $this->assertFalse( $this->database->isOpen() ); $this->assertLastSql( 'BEGIN; SELECT 1; ROLLBACK' ); - $this->assertEquals( 0, $this->database->trxLevel() ); + $this->assertSame( 0, $this->database->trxLevel() ); } /** diff --git a/tests/phpunit/includes/libs/rdbms/database/DatabaseTest.php b/tests/phpunit/includes/libs/rdbms/database/DatabaseTest.php index 93b1bf82ba..fddbab2b37 100644 --- a/tests/phpunit/includes/libs/rdbms/database/DatabaseTest.php +++ b/tests/phpunit/includes/libs/rdbms/database/DatabaseTest.php @@ -490,13 +490,13 @@ class DatabaseTest extends PHPUnit\Framework\TestCase { $db->method( 'isOpen' )->willReturn( true ); $db->method( 'getDBname' )->willReturn( 'unittest' ); - $this->assertEquals( 0, $db->trxLevel() ); + $this->assertSame( 0, $db->trxLevel() ); $this->assertEquals( true, $db->lockIsFree( 'x', __METHOD__ ) ); $this->assertEquals( true, $db->lock( 'x', __METHOD__ ) ); $this->assertEquals( false, $db->lockIsFree( 'x', __METHOD__ ) ); $this->assertEquals( true, $db->unlock( 'x', __METHOD__ ) ); $this->assertEquals( true, $db->lockIsFree( 'x', __METHOD__ ) ); - $this->assertEquals( 0, $db->trxLevel() ); + $this->assertSame( 0, $db->trxLevel() ); $db->setFlag( DBO_TRX ); $this->assertEquals( true, $db->lockIsFree( 'x', __METHOD__ ) ); @@ -507,7 +507,7 @@ class DatabaseTest extends PHPUnit\Framework\TestCase { $db->clearFlag( DBO_TRX ); // Pending writes with DBO_TRX - $this->assertEquals( 0, $db->trxLevel() ); + $this->assertSame( 0, $db->trxLevel() ); $this->assertTrue( $db->lockIsFree( 'meow', __METHOD__ ) ); $db->setFlag( DBO_TRX ); $db->query( "DELETE FROM test WHERE t = 1" ); // trigger DBO_TRX transaction before lock @@ -521,7 +521,7 @@ class DatabaseTest extends PHPUnit\Framework\TestCase { $db->rollback( __METHOD__, IDatabase::FLUSHING_ALL_PEERS ); // Pending writes without DBO_TRX $db->clearFlag( DBO_TRX ); - $this->assertEquals( 0, $db->trxLevel() ); + $this->assertSame( 0, $db->trxLevel() ); $this->assertTrue( $db->lockIsFree( 'meow2', __METHOD__ ) ); $db->begin( __METHOD__ ); $db->query( "DELETE FROM test WHERE t = 1" ); // trigger DBO_TRX transaction before lock @@ -535,17 +535,17 @@ class DatabaseTest extends PHPUnit\Framework\TestCase { $db->rollback( __METHOD__ ); // No pending writes, with DBO_TRX $db->setFlag( DBO_TRX ); - $this->assertEquals( 0, $db->trxLevel() ); + $this->assertSame( 0, $db->trxLevel() ); $this->assertTrue( $db->lockIsFree( 'wuff', __METHOD__ ) ); $db->query( "SELECT 1", __METHOD__ ); $this->assertEquals( 1, $db->trxLevel() ); $lock = $db->getScopedLockAndFlush( 'wuff', __METHOD__, 1 ); - $this->assertEquals( 0, $db->trxLevel() ); + $this->assertSame( 0, $db->trxLevel() ); $this->assertFalse( $db->lockIsFree( 'wuff', __METHOD__ ), 'Lock already acquired' ); $db->rollback( __METHOD__, IDatabase::FLUSHING_ALL_PEERS ); // No pending writes, without DBO_TRX $db->clearFlag( DBO_TRX ); - $this->assertEquals( 0, $db->trxLevel() ); + $this->assertSame( 0, $db->trxLevel() ); $this->assertTrue( $db->lockIsFree( 'wuff2', __METHOD__ ) ); $db->begin( __METHOD__ ); try { diff --git a/tests/phpunit/includes/linker/LinkRendererTest.php b/tests/phpunit/includes/linker/LinkRendererTest.php index b26a247c80..d176e39145 100644 --- a/tests/phpunit/includes/linker/LinkRendererTest.php +++ b/tests/phpunit/includes/linker/LinkRendererTest.php @@ -168,7 +168,7 @@ class LinkRendererTest extends MediaWikiLangTestCase { $linkRenderer = new LinkRenderer( $titleFormatter, $linkCache, $nsInfo ); $linkRenderer->setStubThreshold( 0 ); - $this->assertEquals( + $this->assertSame( '', $linkRenderer->getLinkClasses( $foobarTitle ) ); @@ -186,7 +186,7 @@ class LinkRendererTest extends MediaWikiLangTestCase { ); $linkRenderer->setStubThreshold( 20 ); - $this->assertEquals( + $this->assertSame( '', $linkRenderer->getLinkClasses( $userTitle ) ); diff --git a/tests/phpunit/includes/media/JpegMetadataExtractorTest.php b/tests/phpunit/includes/media/JpegMetadataExtractorTest.php index 6c56510170..4a0a6d0cad 100644 --- a/tests/phpunit/includes/media/JpegMetadataExtractorTest.php +++ b/tests/phpunit/includes/media/JpegMetadataExtractorTest.php @@ -1,7 +1,7 @@ assertEquals( $expected, bin2hex( $res['PSIR'][0] ) ); } + public function testXMPExtractionNullChar() { + $res = JpegMetadataExtractor::segmentSplitter( $this->filePath . 'jpeg-xmp-nullchar.jpg' ); + $expected = file_get_contents( $this->filePath . 'jpeg-xmp-psir.xmp' ); + $this->assertEquals( $expected, $res['XMP'] ); + } + public function testXMPExtractionAltAppId() { $res = JpegMetadataExtractor::segmentSplitter( $this->filePath . 'jpeg-xmp-alt.jpg' ); $expected = file_get_contents( $this->filePath . 'jpeg-xmp-psir.xmp' ); diff --git a/tests/phpunit/includes/media/JpegPixelFormatTest.php b/tests/phpunit/includes/media/JpegPixelFormatTest.php index 630df54335..8d0ddf8df4 100644 --- a/tests/phpunit/includes/media/JpegPixelFormatTest.php +++ b/tests/phpunit/includes/media/JpegPixelFormatTest.php @@ -54,7 +54,7 @@ class JpegPixelFormatTest extends MediaWikiMediaTestCase { '%[jpeg:sampling-factor]', $path )->execute(); - $this->assertEquals( 0, + $this->assertSame( 0, $result->getExitCode(), "ImageMagick's identify command should return success" ); diff --git a/tests/phpunit/includes/media/PNGMetadataExtractorTest.php b/tests/phpunit/includes/media/PNGMetadataExtractorTest.php index 22de935793..4d7ff48bbc 100644 --- a/tests/phpunit/includes/media/PNGMetadataExtractorTest.php +++ b/tests/phpunit/includes/media/PNGMetadataExtractorTest.php @@ -72,9 +72,9 @@ class PNGMetadataExtractorTest extends MediaWikiTestCase { $meta = PNGMetadataExtractor::getMetadata( $this->filePath . 'Png-native-test.png' ); - $this->assertEquals( 0, $meta['frameCount'] ); + $this->assertSame( 0, $meta['frameCount'] ); $this->assertEquals( 1, $meta['loopCount'] ); - $this->assertEquals( 0, $meta['duration'] ); + $this->assertSame( 0.0, $meta['duration'] ); } /** @@ -87,7 +87,7 @@ class PNGMetadataExtractorTest extends MediaWikiTestCase { $this->assertEquals( 20, $meta['frameCount'] ); // Note loop count of 0 = infinity - $this->assertEquals( 0, $meta['loopCount'] ); + $this->assertSame( 0, $meta['loopCount'] ); $this->assertEquals( 1.5, $meta['duration'], '', 0.00001 ); } diff --git a/tests/phpunit/includes/page/WikiPageDbTestBase.php b/tests/phpunit/includes/page/WikiPageDbTestBase.php index f071e4b198..f0d895ee9e 100644 --- a/tests/phpunit/includes/page/WikiPageDbTestBase.php +++ b/tests/phpunit/includes/page/WikiPageDbTestBase.php @@ -439,7 +439,7 @@ abstract class WikiPageDbTestBase extends MediaWikiLangTestCase { $n = $res->numRows(); $res->free(); - $this->assertEquals( 0, $n, 'pagelinks should contain no more links from the page' ); + $this->assertSame( 0, $n, 'pagelinks should contain no more links from the page' ); } /** @@ -637,7 +637,7 @@ abstract class WikiPageDbTestBase extends MediaWikiLangTestCase { $n = $res->numRows(); $res->free(); - $this->assertEquals( 0, $n, 'pagelinks should contain no more links from the page' ); + $this->assertSame( 0, $n, 'pagelinks should contain no more links from the page' ); } /** @@ -1577,20 +1577,20 @@ more stuff $page->updateCategoryCounts( [ 'A' ], [], 0 ); $this->assertEquals( 1, Category::newFromName( 'A' )->getPageCount() ); - $this->assertEquals( 0, Category::newFromName( 'B' )->getPageCount() ); - $this->assertEquals( 0, Category::newFromName( 'C' )->getPageCount() ); + $this->assertSame( 0, Category::newFromName( 'B' )->getPageCount() ); + $this->assertSame( 0, Category::newFromName( 'C' )->getPageCount() ); // Add a new category $page->updateCategoryCounts( [ 'B' ], [], 0 ); $this->assertEquals( 1, Category::newFromName( 'A' )->getPageCount() ); $this->assertEquals( 1, Category::newFromName( 'B' )->getPageCount() ); - $this->assertEquals( 0, Category::newFromName( 'C' )->getPageCount() ); + $this->assertSame( 0, Category::newFromName( 'C' )->getPageCount() ); // Add and remove a category $page->updateCategoryCounts( [ 'C' ], [ 'A' ], 0 ); - $this->assertEquals( 0, Category::newFromName( 'A' )->getPageCount() ); + $this->assertSame( 0, Category::newFromName( 'A' )->getPageCount() ); $this->assertEquals( 1, Category::newFromName( 'B' )->getPageCount() ); $this->assertEquals( 1, Category::newFromName( 'C' )->getPageCount() ); } diff --git a/tests/phpunit/includes/preferences/DefaultPreferencesFactoryTest.php b/tests/phpunit/includes/preferences/DefaultPreferencesFactoryTest.php index e7f7067adb..c7a3fe6045 100644 --- a/tests/phpunit/includes/preferences/DefaultPreferencesFactoryTest.php +++ b/tests/phpunit/includes/preferences/DefaultPreferencesFactoryTest.php @@ -2,6 +2,7 @@ use MediaWiki\Auth\AuthManager; use MediaWiki\MediaWikiServices; +use MediaWiki\Permissions\PermissionManager; use MediaWiki\Preferences\DefaultPreferencesFactory; use Wikimedia\TestingAccessWrapper; @@ -49,9 +50,10 @@ class DefaultPreferencesFactoryTest extends \MediaWikiTestCase { /** * Get a basic PreferencesFactory for testing with. + * @param PermissionManager $mockPM * @return DefaultPreferencesFactory */ - protected function getPreferencesFactory() { + protected function getPreferencesFactory( PermissionManager $mockPM ) { $mockNsInfo = $this->createMock( NamespaceInfo::class ); $mockNsInfo->method( 'getValidNamespaces' )->willReturn( [ NS_MAIN, NS_TALK, NS_USER, NS_USER_TALK @@ -65,7 +67,8 @@ class DefaultPreferencesFactoryTest extends \MediaWikiTestCase { new Language(), AuthManager::singleton(), MediaWikiServices::getInstance()->getLinkRenderer(), - $mockNsInfo + $mockNsInfo, + $mockPM ); } @@ -76,7 +79,9 @@ class DefaultPreferencesFactoryTest extends \MediaWikiTestCase { $this->setTemporaryHook( 'GetPreferences', null ); $testUser = $this->getTestUser(); - $form = $this->getPreferencesFactory()->getForm( $testUser->getUser(), $this->context ); + $pm = $this->createMock( PermissionManager::class ); + $pm->method( 'userHasRight' )->willReturn( true ); + $form = $this->getPreferencesFactory( $pm )->getForm( $testUser->getUser(), $this->context ); $this->assertInstanceOf( PreferencesFormOOUI::class, $form ); $this->assertCount( 5, $form->getPreferenceSections() ); } @@ -88,7 +93,9 @@ class DefaultPreferencesFactoryTest extends \MediaWikiTestCase { * @dataProvider emailAuthenticationProvider */ public function testEmailAuthentication( $user, $cssClass ) { - $prefs = $this->getPreferencesFactory()->getFormDescriptor( $user, $this->context ); + $pm = $this->createMock( PermissionManager::class ); + $pm->method( 'userHasRight' )->willReturn( true ); + $prefs = $this->getPreferencesFactory( $pm )->getFormDescriptor( $user, $this->context ); $this->assertArrayHasKey( 'cssclass', $prefs['emailauthentication'] ); $this->assertEquals( $cssClass, $prefs['emailauthentication']['cssclass'] ); } @@ -100,16 +107,18 @@ class DefaultPreferencesFactoryTest extends \MediaWikiTestCase { $userMock = $this->getMockBuilder( User::class ) ->disableOriginalConstructor() ->getMock(); - $userMock->method( 'isAllowed' ) - ->willReturn( false ); $userMock->method( 'getEffectiveGroups' ) ->willReturn( [] ); $userMock->method( 'getGroupMemberships' ) ->willReturn( [] ); $userMock->method( 'getOptions' ) ->willReturn( [ 'test' => 'yes' ] ); - - $prefs = $this->getPreferencesFactory()->getFormDescriptor( $userMock, $this->context ); + $pm = $this->createMock( PermissionManager::class ); + $pm->method( 'userHasRight' ) + ->will( $this->returnValueMap( [ + [ $userMock, 'editmyoptions', true ] + ] ) ); + $prefs = $this->getPreferencesFactory( $pm )->getFormDescriptor( $userMock, $this->context ); $this->assertArrayNotHasKey( 'showrollbackconfirmation', $prefs ); } @@ -120,16 +129,19 @@ class DefaultPreferencesFactoryTest extends \MediaWikiTestCase { $userMock = $this->getMockBuilder( User::class ) ->disableOriginalConstructor() ->getMock(); - $userMock->method( 'isAllowed' ) - ->willReturn( true ); $userMock->method( 'getEffectiveGroups' ) ->willReturn( [] ); $userMock->method( 'getGroupMemberships' ) ->willReturn( [] ); $userMock->method( 'getOptions' ) ->willReturn( [ 'test' => 'yes' ] ); - - $prefs = $this->getPreferencesFactory()->getFormDescriptor( $userMock, $this->context ); + $pm = $this->createMock( PermissionManager::class ); + $pm->method( 'userHasRight' ) + ->will( $this->returnValueMap( [ + [ $userMock, 'editmyoptions', true ], + [ $userMock, 'rollback', true ] + ] ) ); + $prefs = $this->getPreferencesFactory( $pm )->getFormDescriptor( $userMock, $this->context ); $this->assertArrayHasKey( 'showrollbackconfirmation', $prefs ); $this->assertEquals( 'rendering/advancedrendering', @@ -181,10 +193,6 @@ class DefaultPreferencesFactoryTest extends \MediaWikiTestCase { ->getMock(); $userMock->method( 'getOptions' ) ->willReturn( $oldOptions ); - $userMock->method( 'isAllowedAny' ) - ->willReturn( true ); - $userMock->method( 'isAllowed' ) - ->willReturn( true ); $userMock->expects( $this->exactly( 2 ) ) ->method( 'setOption' ) @@ -193,18 +201,25 @@ class DefaultPreferencesFactoryTest extends \MediaWikiTestCase { [ $this->equalTo( 'option' ), $this->equalTo( $newOptions[ 'option' ] ) ] ); - $form->expects( $this->any() ) - ->method( 'getModifiedUser' ) + $form->method( 'getModifiedUser' ) ->willReturn( $userMock ); - $form->expects( $this->any() ) - ->method( 'getContext' ) + $form->method( 'getContext' ) ->willReturn( $this->context ); - $form->expects( $this->any() ) - ->method( 'getConfig' ) + $form->method( 'getConfig' ) ->willReturn( $configMock ); + $pm = $this->createMock( PermissionManager::class ); + $pm->method( 'userHasAnyRight' ) + ->will( $this->returnValueMap( [ + [ $userMock, 'editmyprivateinfo', 'editmyoptions', true ] + ] ) ); + $pm->method( 'userHasRight' ) + ->will( $this->returnValueMap( [ + [ $userMock, 'editmyoptions', true ] + ] ) ); + $this->setTemporaryHook( 'PreferencesFormPreSave', function ( $formData, $form, $user, &$result, $oldUserOptions ) use ( $newOptions, $oldOptions, $userMock ) { @@ -220,7 +235,7 @@ class DefaultPreferencesFactoryTest extends \MediaWikiTestCase { ); /** @var DefaultPreferencesFactory $factory */ - $factory = TestingAccessWrapper::newFromObject( $this->getPreferencesFactory() ); + $factory = TestingAccessWrapper::newFromObject( $this->getPreferencesFactory( $pm ) ); $factory->saveFormData( $newOptions, $form, [] ); } @@ -233,7 +248,14 @@ class DefaultPreferencesFactoryTest extends \MediaWikiTestCase { // Test a string with leading zeros (i.e. not octal) and spaces. $this->context->getRequest()->setVal( 'wprclimit', ' 0012 ' ); $user = new User; - $form = $this->getPreferencesFactory()->getForm( $user, $this->context ); + $pm = $this->createMock( PermissionManager::class ); + $pm->method( 'userHasAnyRight' ) + ->willReturn( true ); + $pm->method( 'userHasRight' ) + ->will( $this->returnValueMap( [ + [ $user, 'editmyoptions', true ] + ] ) ); + $form = $this->getPreferencesFactory( $pm )->getForm( $user, $this->context ); $form->show(); $form->trySubmit(); $this->assertEquals( 12, $user->getOption( 'rclimit' ) ); diff --git a/tests/phpunit/includes/resourceloader/ResourceLoaderTest.php b/tests/phpunit/includes/resourceloader/ResourceLoaderTest.php index 94e346139a..be11d538a5 100644 --- a/tests/phpunit/includes/resourceloader/ResourceLoaderTest.php +++ b/tests/phpunit/includes/resourceloader/ResourceLoaderTest.php @@ -718,7 +718,7 @@ END ] ); $context = $this->getResourceLoaderContext( [], $rl ); - $this->assertEquals( + $this->assertSame( '', $rl->getCombinedVersion( $context, [] ), 'empty list' diff --git a/tests/phpunit/includes/search/SearchNearMatchResultSetTest.php b/tests/phpunit/includes/search/SearchNearMatchResultSetTest.php index 67493c4243..8135d573f1 100644 --- a/tests/phpunit/includes/search/SearchNearMatchResultSetTest.php +++ b/tests/phpunit/includes/search/SearchNearMatchResultSetTest.php @@ -7,7 +7,7 @@ class SearchNearMatchResultSetTest extends PHPUnit\Framework\TestCase { */ public function testNumRows() { $resultSet = new SearchNearMatchResultSet( null ); - $this->assertEquals( 0, $resultSet->numRows() ); + $this->assertSame( 0, $resultSet->numRows() ); $resultSet = new SearchNearMatchResultSet( Title::newMainPage() ); $this->assertEquals( 1, $resultSet->numRows() ); diff --git a/tests/phpunit/includes/shell/ShellTest.php b/tests/phpunit/includes/shell/ShellTest.php index 5fb3ac0f5f..0dd88bb868 100644 --- a/tests/phpunit/includes/shell/ShellTest.php +++ b/tests/phpunit/includes/shell/ShellTest.php @@ -65,7 +65,7 @@ class ShellTest extends MediaWikiTestCase { $wrapper = TestingAccessWrapper::newFromObject( $command ); $this->assertEquals( $expected, $wrapper->command ); - $this->assertEquals( 0, $wrapper->restrictions & Shell::NO_LOCALSETTINGS ); + $this->assertSame( 0, $wrapper->restrictions & Shell::NO_LOCALSETTINGS ); } public function provideMakeScriptCommand() { diff --git a/tests/phpunit/includes/site/CachingSiteStoreTest.php b/tests/phpunit/includes/site/CachingSiteStoreTest.php index df12eba765..fc04fb7066 100644 --- a/tests/phpunit/includes/site/CachingSiteStoreTest.php +++ b/tests/phpunit/includes/site/CachingSiteStoreTest.php @@ -149,7 +149,7 @@ class CachingSiteStoreTest extends \MediaWikiIntegrationTestCase { $this->assertNull( $site ); $sites = $store->getSites(); - $this->assertEquals( 0, $sites->count() ); + $this->assertSame( 0, $sites->count() ); } /** diff --git a/tests/phpunit/includes/site/DBSiteStoreTest.php b/tests/phpunit/includes/site/DBSiteStoreTest.php index 14ee15b635..e125d71741 100644 --- a/tests/phpunit/includes/site/DBSiteStoreTest.php +++ b/tests/phpunit/includes/site/DBSiteStoreTest.php @@ -138,7 +138,7 @@ class DBSiteStoreTest extends MediaWikiTestCase { $this->assertNull( $site ); $sites = $store->getSites(); - $this->assertEquals( 0, $sites->count() ); + $this->assertSame( 0, $sites->count() ); } /** diff --git a/tests/phpunit/includes/site/SiteTest.php b/tests/phpunit/includes/site/SiteTest.php index 9ad61b2359..2119d31064 100644 --- a/tests/phpunit/includes/site/SiteTest.php +++ b/tests/phpunit/includes/site/SiteTest.php @@ -222,7 +222,7 @@ class SiteTest extends MediaWikiTestCase { $path = '//acme.com/'; // protocol-relative URL $site->setPath( $type, $path ); - $this->assertEquals( '', $site->getProtocol() ); + $this->assertSame( '', $site->getProtocol() ); } public static function provideGetPageUrl() { diff --git a/tests/phpunit/includes/specials/SpecialBlankPageTest.php b/tests/phpunit/includes/specials/SpecialBlankPageTest.php index 879acfece1..5435afa36e 100644 --- a/tests/phpunit/includes/specials/SpecialBlankPageTest.php +++ b/tests/phpunit/includes/specials/SpecialBlankPageTest.php @@ -8,6 +8,11 @@ */ class SpecialBlankPageTest extends SpecialPageTestBase { + protected function setUp() { + parent::setUp(); + $this->setUserLang( 'qqx' ); + } + /** * Returns a new instance of the special page under test. * @@ -19,7 +24,7 @@ class SpecialBlankPageTest extends SpecialPageTestBase { public function testHasWikiMsg() { list( $html, ) = $this->executeSpecialPage(); - $this->assertContains( wfMessage( 'intentionallyblankpage' )->text(), $html ); + $this->assertContains( '(intentionallyblankpage)', $html ); } } diff --git a/tests/phpunit/includes/specials/SpecialPageDataTest.php b/tests/phpunit/includes/specials/SpecialPageDataTest.php index 4075406357..b11973c9cd 100644 --- a/tests/phpunit/includes/specials/SpecialPageDataTest.php +++ b/tests/phpunit/includes/specials/SpecialPageDataTest.php @@ -9,6 +9,12 @@ */ class SpecialPageDataTest extends SpecialPageTestBase { + protected function setUp() { + parent::setUp(); + + $this->setContentLang( 'qqx' ); + } + protected function newSpecialPage() { $page = new SpecialPageData(); @@ -130,17 +136,12 @@ class SpecialPageDataTest extends SpecialPageTestBase { } public function testSpecialPageWithoutParameters() { - $this->setContentLang( Language::factory( 'en' ) ); $request = new FauxRequest(); $request->response()->header( 'Status: 200 OK', true, 200 ); // init/reset list( $output, ) = $this->executeSpecialPage( '', $request ); - $this->assertContains( - "Content negotiation applies based on your client's Accept header.", - $output, - "output" - ); + $this->assertContains( '(pagedata-text)', $output ); } } diff --git a/tests/phpunit/includes/user/LocalIdLookupTest.php b/tests/phpunit/includes/user/LocalIdLookupTest.php index e38d77b72b..0e4674455c 100644 --- a/tests/phpunit/includes/user/LocalIdLookupTest.php +++ b/tests/phpunit/includes/user/LocalIdLookupTest.php @@ -1,6 +1,7 @@ getPermissionManager(); $user1 = $this->getLookupUser(); $user2 = User::newFromName( 'UTLocalIdLookup2' ); - $this->assertTrue( $user1->isAllowed( 'hideuser' ), 'sanity check' ); - $this->assertFalse( $user2->isAllowed( 'hideuser' ), 'sanity check' ); + $this->assertTrue( $permissionManager->userHasRight( $user1, 'hideuser' ), 'sanity check' ); + $this->assertFalse( $permissionManager->userHasRight( $user2, 'hideuser' ), 'sanity check' ); $this->assertSame( [], $lookup->lookupCentralIds( [] ) ); @@ -76,11 +77,12 @@ class LocalIdLookupTest extends MediaWikiTestCase { public function testLookupUserNames() { $lookup = new LocalIdLookup(); + $permissionManager = MediaWikiServices::getInstance()->getPermissionManager(); $user1 = $this->getLookupUser(); $user2 = User::newFromName( 'UTLocalIdLookup2' ); - $this->assertTrue( $user1->isAllowed( 'hideuser' ), 'sanity check' ); - $this->assertFalse( $user2->isAllowed( 'hideuser' ), 'sanity check' ); + $this->assertTrue( $permissionManager->userHasRight( $user1, 'hideuser' ), 'sanity check' ); + $this->assertFalse( $permissionManager->userHasRight( $user2, 'hideuser' ), 'sanity check' ); $this->assertSame( [], $lookup->lookupUserNames( [] ) ); diff --git a/tests/phpunit/includes/user/PasswordResetTest.php b/tests/phpunit/includes/user/PasswordResetTest.php index b0c0fec6b2..4a7aa05b14 100644 --- a/tests/phpunit/includes/user/PasswordResetTest.php +++ b/tests/phpunit/includes/user/PasswordResetTest.php @@ -4,6 +4,7 @@ use MediaWiki\Auth\AuthManager; use MediaWiki\Block\DatabaseBlock; use MediaWiki\Block\CompositeBlock; use MediaWiki\Block\SystemBlock; +use MediaWiki\Permissions\PermissionManager; /** * @covers PasswordReset @@ -30,16 +31,19 @@ class PasswordResetTest extends MediaWikiTestCase { $user->expects( $this->any() )->method( 'getName' )->willReturn( 'Foo' ); $user->expects( $this->any() )->method( 'getBlock' )->willReturn( $block ); $user->expects( $this->any() )->method( 'getGlobalBlock' )->willReturn( $globalBlock ); - $user->expects( $this->any() )->method( 'isAllowed' ) - ->will( $this->returnCallback( function ( $perm ) use ( $canEditPrivate ) { - if ( $perm === 'editmyprivateinfo' ) { - return $canEditPrivate; - } else { - $this->fail( 'Unexpected permission check' ); - } - } ) ); - $passwordReset = new PasswordReset( $config, $authManager ); + $permissionManager = $this->getMockBuilder( PermissionManager::class ) + ->disableOriginalConstructor() + ->getMock(); + $permissionManager->method( 'userHasRight' ) + ->with( $user, 'editmyprivateinfo' ) + ->willReturn( $canEditPrivate ); + + $passwordReset = new PasswordReset( + $config, + $authManager, + $permissionManager + ); $this->assertSame( $isAllowed, $passwordReset->isAllowed( $user )->isGood() ); } @@ -204,9 +208,16 @@ class PasswordResetTest extends MediaWikiTestCase { $request->setIP( '1.2.3.4' ); $performingUser = $this->getMockBuilder( User::class )->getMock(); $performingUser->expects( $this->any() )->method( 'getRequest' )->willReturn( $request ); - $performingUser->expects( $this->any() )->method( 'isAllowed' )->willReturn( true ); $performingUser->expects( $this->any() )->method( 'getName' )->willReturn( 'Performer' ); + $permissionManager = $this->getMockBuilder( PermissionManager::class ) + ->disableOriginalConstructor() + ->getMock(); + $permissionManager->expects( $this->once() ) + ->method( 'userHasRight' ) + ->with( $performingUser, 'editmyprivateinfo' ) + ->willReturn( true ); + $targetUser1 = $this->getMockBuilder( User::class )->getMock(); $targetUser2 = $this->getMockBuilder( User::class )->getMock(); $targetUser1->expects( $this->any() )->method( 'getName' )->willReturn( 'User1' ); @@ -217,7 +228,8 @@ class PasswordResetTest extends MediaWikiTestCase { $targetUser2->expects( $this->any() )->method( 'getEmail' )->willReturn( 'foo@bar.baz' ); $passwordReset = $this->getMockBuilder( PasswordReset::class ) - ->setMethods( [ 'getUsersByEmail' ] )->setConstructorArgs( [ $config, $authManager ] ) + ->setConstructorArgs( [ $config, $authManager, $permissionManager ] ) + ->setMethods( [ 'getUsersByEmail' ] ) ->getMock(); $passwordReset->expects( $this->any() )->method( 'getUsersByEmail' )->with( 'foo@bar.baz' ) ->willReturn( [ $targetUser1, $targetUser2 ] ); diff --git a/tests/phpunit/includes/user/UserGroupMembershipTest.php b/tests/phpunit/includes/user/UserGroupMembershipTest.php index 4862747b4f..6f575789f5 100644 --- a/tests/phpunit/includes/user/UserGroupMembershipTest.php +++ b/tests/phpunit/includes/user/UserGroupMembershipTest.php @@ -1,5 +1,7 @@ clearInstanceCache(); $this->assertContains( 'unittesters', $user->getGroups() ); $this->assertArrayHasKey( 'unittesters', $user->getGroupMemberships() ); - $this->assertTrue( $user->isAllowed( 'runtest' ) ); + $this->assertTrue( MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'runtest' ) ); // try updating without allowUpdate. Should fail $ugm = new UserGroupMembership( $user->getId(), 'unittesters', $this->expiryTime ); @@ -72,7 +76,9 @@ class UserGroupMembershipTest extends MediaWikiTestCase { $user->clearInstanceCache(); $this->assertContains( 'unittesters', $user->getGroups() ); $this->assertArrayHasKey( 'unittesters', $user->getGroupMemberships() ); - $this->assertTrue( $user->isAllowed( 'runtest' ) ); + $this->assertTrue( MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'runtest' ) ); // try removing the group $ugm->delete(); @@ -81,7 +87,9 @@ class UserGroupMembershipTest extends MediaWikiTestCase { $this->logicalNot( $this->contains( 'unittesters' ) ) ); $this->assertThat( $user->getGroupMemberships(), $this->logicalNot( $this->arrayHasKey( 'unittesters' ) ) ); - $this->assertFalse( $user->isAllowed( 'runtest' ) ); + $this->assertFalse( MediaWikiServices::getInstance() + ->getPermissionManager() + ->userHasRight( $user, 'runtest' ) ); // check that the user group is now in user_former_groups $this->assertContains( 'unittesters', $user->getFormerGroups() ); diff --git a/tests/phpunit/includes/user/UserTest.php b/tests/phpunit/includes/user/UserTest.php index 3005ae9b2e..f24255b8da 100644 --- a/tests/phpunit/includes/user/UserTest.php +++ b/tests/phpunit/includes/user/UserTest.php @@ -559,10 +559,10 @@ class UserTest extends MediaWikiTestCase { $this->markTestSkippedIfDbType( 'postgres' ); $users = User::findUsersByGroup( [] ); - $this->assertEquals( 0, iterator_count( $users ) ); + $this->assertSame( 0, iterator_count( $users ) ); $users = User::findUsersByGroup( 'foo' ); - $this->assertEquals( 0, iterator_count( $users ) ); + $this->assertSame( 0, iterator_count( $users ) ); $user = $this->getMutableTestUser( [ 'foo' ] )->getUser(); $users = User::findUsersByGroup( 'foo' ); @@ -1488,10 +1488,6 @@ class UserTest extends MediaWikiTestCase { // logged in users should be inmune to cookie block of type ip/range $this->assertNull( $user->getBlock() ); - // cookie is being cleared - $cookies = $request->response()->getCookies(); - $this->assertEquals( '', $cookies['wikiBlockID']['value'] ); - // clean up $block->delete(); } diff --git a/tests/phpunit/includes/watcheditem/WatchedItemQueryServiceUnitTest.php b/tests/phpunit/includes/watcheditem/WatchedItemQueryServiceUnitTest.php index 0b1d0132fb..45fa1430d7 100644 --- a/tests/phpunit/includes/watcheditem/WatchedItemQueryServiceUnitTest.php +++ b/tests/phpunit/includes/watcheditem/WatchedItemQueryServiceUnitTest.php @@ -1,5 +1,6 @@ getMockLoadBalancer( $mockDb ), $this->getMockCommentStore(), $this->getMockActorMigration(), - $this->getMockWatchedItemStore() + $this->getMockWatchedItemStore(), + $mockPM ?: $this->getMockPermissionManager() ); } @@ -153,6 +156,25 @@ class WatchedItemQueryServiceUnitTest extends MediaWikiTestCase { return $mock; } + /** + * @param string $notAllowedAction + * @return PHPUnit_Framework_MockObject_MockObject|PermissionManager + */ + private function getMockPermissionManager( $notAllowedAction = null ) { + $mock = $this->getMockBuilder( PermissionManager::class ) + ->disableOriginalConstructor() + ->getMock(); + $mock->method( 'userHasRight' ) + ->will( $this->returnCallback( function ( $user, $action ) use ( $notAllowedAction ) { + return $action !== $notAllowedAction; + } ) ); + $mock->method( 'userHasAnyRight' ) + ->will( $this->returnCallback( function ( $user, ...$actions ) use ( $notAllowedAction ) { + return !in_array( $notAllowedAction, $actions ); + } ) ); + return $mock; + } + /** * @param int $id * @param string[] $extraMethods Extra methods that are expected might be called @@ -177,9 +199,7 @@ class WatchedItemQueryServiceUnitTest extends MediaWikiTestCase { */ private function getMockUnrestrictedNonAnonUserWithId( $id, array $extraMethods = [] ) { $mock = $this->getMockNonAnonUserWithId( $id, - array_merge( [ 'isAllowed', 'isAllowedAny', 'useRCPatrol' ], $extraMethods ) ); - $mock->method( 'isAllowed' )->willReturn( true ); - $mock->method( 'isAllowedAny' )->willReturn( true ); + array_merge( [ 'useRCPatrol' ], $extraMethods ) ); $mock->method( 'useRCPatrol' )->willReturn( true ); return $mock; } @@ -189,18 +209,9 @@ class WatchedItemQueryServiceUnitTest extends MediaWikiTestCase { * @param string $notAllowedAction * @return PHPUnit_Framework_MockObject_MockObject|User */ - private function getMockNonAnonUserWithIdAndRestrictedPermissions( $id, $notAllowedAction ) { + private function getMockNonAnonUserWithIdAndRestrictedPermissions( $id ) { $mock = $this->getMockNonAnonUserWithId( $id, - [ 'isAllowed', 'isAllowedAny', 'useRCPatrol', 'useNPPatrol' ] ); - - $mock->method( 'isAllowed' ) - ->will( $this->returnCallback( function ( $action ) use ( $notAllowedAction ) { - return $action !== $notAllowedAction; - } ) ); - $mock->method( 'isAllowedAny' ) - ->will( $this->returnCallback( function ( ...$actions ) use ( $notAllowedAction ) { - return !in_array( $notAllowedAction, $actions ); - } ) ); + [ 'useRCPatrol', 'useNPPatrol' ] ); $mock->method( 'useRCPatrol' )->willReturn( false ); $mock->method( 'useNPPatrol' )->willReturn( false ); @@ -213,15 +224,7 @@ class WatchedItemQueryServiceUnitTest extends MediaWikiTestCase { */ private function getMockNonAnonUserWithIdAndNoPatrolRights( $id ) { $mock = $this->getMockNonAnonUserWithId( $id, - [ 'isAllowed', 'isAllowedAny', 'useRCPatrol', 'useNPPatrol' ] ); - - $mock->expects( $this->any() ) - ->method( 'isAllowed' ) - ->will( $this->returnValue( true ) ); - $mock->expects( $this->any() ) - ->method( 'isAllowedAny' ) - ->will( $this->returnValue( true ) ); - + [ 'useRCPatrol', 'useNPPatrol' ] ); $mock->expects( $this->any() ) ->method( 'useRCPatrol' ) ->will( $this->returnValue( false ) ); @@ -1132,9 +1135,10 @@ class WatchedItemQueryServiceUnitTest extends MediaWikiTestCase { ) ->will( $this->returnValue( [] ) ); - $user = $this->getMockNonAnonUserWithIdAndRestrictedPermissions( 1, $notAllowedAction ); + $permissionManager = $this->getMockPermissionManager( $notAllowedAction ); + $user = $this->getMockNonAnonUserWithIdAndRestrictedPermissions( 1 ); - $queryService = $this->newService( $mockDb ); + $queryService = $this->newService( $mockDb, $permissionManager ); $items = $queryService->getWatchedItemsWithRecentChangeInfo( $user, $options ); $this->assertEmpty( $items ); diff --git a/tests/phpunit/includes/watcheditem/WatchedItemStoreUnitTest.php b/tests/phpunit/includes/watcheditem/WatchedItemStoreUnitTest.php index fbb893e204..e40417c63c 100644 --- a/tests/phpunit/includes/watcheditem/WatchedItemStoreUnitTest.php +++ b/tests/phpunit/includes/watcheditem/WatchedItemStoreUnitTest.php @@ -1180,7 +1180,7 @@ class WatchedItemStoreUnitTest extends MediaWikiTestCase { $this->assertInstanceOf( WatchedItem::class, $watchedItem ); $this->assertEquals( 1, $watchedItem->getUser()->getId() ); $this->assertEquals( 'SomeDbKey', $watchedItem->getLinkTarget()->getDBkey() ); - $this->assertEquals( 0, $watchedItem->getLinkTarget()->getNamespace() ); + $this->assertSame( 0, $watchedItem->getLinkTarget()->getNamespace() ); } public function testLoadWatchedItem_noItem() { @@ -1382,7 +1382,7 @@ class WatchedItemStoreUnitTest extends MediaWikiTestCase { $this->assertInstanceOf( WatchedItem::class, $watchedItem ); $this->assertEquals( 1, $watchedItem->getUser()->getId() ); $this->assertEquals( 'SomeDbKey', $watchedItem->getLinkTarget()->getDBkey() ); - $this->assertEquals( 0, $watchedItem->getLinkTarget()->getNamespace() ); + $this->assertSame( 0, $watchedItem->getLinkTarget()->getNamespace() ); } public function testGetWatchedItem_cachedItem() { diff --git a/tests/phpunit/integration/includes/db/DatabaseSqliteTest.php b/tests/phpunit/integration/includes/db/DatabaseSqliteTest.php index 53edbf2688..77fcff27f3 100644 --- a/tests/phpunit/integration/includes/db/DatabaseSqliteTest.php +++ b/tests/phpunit/integration/includes/db/DatabaseSqliteTest.php @@ -233,7 +233,7 @@ class DatabaseSqliteTest extends \MediaWikiIntegrationTestCase { $index = $indexList->next(); $this->assertEquals( 'baz_index2', $index->name ); $this->assertEquals( '1', $index->unique ); - $this->assertEquals( 0, + $this->assertSame( 0, $db->selectField( 'sqlite_master', 'COUNT(*)', [ 'name' => 'baz' ] ), 'Create a temporary duplicate only' ); @@ -524,7 +524,7 @@ class DatabaseSqliteTest extends \MediaWikiIntegrationTestCase { $databaseCreation = $db->query( 'CREATE TABLE a ( a_1 )', __METHOD__ ); $this->assertInstanceOf( ResultWrapper::class, $databaseCreation, "Failed to create table a" ); $res = $db->select( 'a', '*' ); - $this->assertEquals( 0, $db->numFields( $res ), "expects to get 0 fields for an empty table" ); + $this->assertSame( 0, $db->numFields( $res ), "expects to get 0 fields for an empty table" ); $insertion = $db->insert( 'a', [ 'a_1' => 10 ], __METHOD__ ); $this->assertTrue( $insertion, "Insertion failed" ); $res = $db->select( 'a', '*' ); diff --git a/tests/phpunit/languages/LanguageTest.php b/tests/phpunit/languages/LanguageTest.php index 2f6fa39b36..628d248938 100644 --- a/tests/phpunit/languages/LanguageTest.php +++ b/tests/phpunit/languages/LanguageTest.php @@ -1799,7 +1799,7 @@ class LanguageTest extends LanguageClassesTestCase { $s = $lang->getMessageFromDB( 'word-separator' ); $c = $lang->getMessageFromDB( 'comma-separator' ); - $this->assertEquals( '', $lang->listToText( [] ) ); + $this->assertSame( '', $lang->listToText( [] ) ); $this->assertEquals( 'a', $lang->listToText( [ 'a' ] ) ); $this->assertEquals( "a{$and}{$s}b", $lang->listToText( [ 'a', 'b' ] ) ); $this->assertEquals( "a{$c}b{$and}{$s}c", $lang->listToText( [ 'a', 'b', 'c' ] ) ); diff --git a/tests/phpunit/maintenance/DumpTestCase.php b/tests/phpunit/maintenance/DumpTestCase.php index 7647915ab9..03875351fb 100644 --- a/tests/phpunit/maintenance/DumpTestCase.php +++ b/tests/phpunit/maintenance/DumpTestCase.php @@ -185,7 +185,7 @@ abstract class DumpTestCase extends MediaWikiLangTestCase { // 2. Do the real output checking on our own. $lines = explode( "\n", $this->getActualOutput() ); $this->assertGreaterThan( 1, count( $lines ), "Minimal lines of produced output" ); - $this->assertEquals( '', array_pop( $lines ), "Output ends in LF" ); + $this->assertSame( '', array_pop( $lines ), "Output ends in LF" ); $timestamp_re = "[0-9]{4}-[01][0-9]-[0-3][0-9] [0-2][0-9]:[0-5][0-9]:[0-6][0-9]"; foreach ( $lines as $line ) { $this->assertRegExp( diff --git a/tests/phpunit/maintenance/MWDoxygenFilterTest.php b/tests/phpunit/maintenance/MWDoxygenFilterTest.php index 22b5938daa..edb7618ea3 100644 --- a/tests/phpunit/maintenance/MWDoxygenFilterTest.php +++ b/tests/phpunit/maintenance/MWDoxygenFilterTest.php @@ -1,7 +1,7 @@ getMockForAbstractClass( ContainerInterface::class ) ); - + $permissionManager = $this->createMock( PermissionManager::class ); $request = new RequestData( $requestInfo ); $router = new Router( [ __DIR__ . '/../testRoutes.json' ], [], '/rest', new EmptyBagOStuff(), - new ResponseFactory(), + new ResponseFactory( [] ), new StaticBasicAuthorizer(), $objectFactory, - new Validator( $objectFactory, $request, new User ) + new Validator( $objectFactory, $permissionManager, $request, new User ) ); $response = $router->execute( $request ); if ( isset( $responseInfo['statusCode'] ) ) { diff --git a/tests/phpunit/unit/includes/Rest/ResponseFactoryTest.php b/tests/phpunit/unit/includes/Rest/ResponseFactoryTest.php index 04d54de899..0a98686f0a 100644 --- a/tests/phpunit/unit/includes/Rest/ResponseFactoryTest.php +++ b/tests/phpunit/unit/includes/Rest/ResponseFactoryTest.php @@ -6,6 +6,8 @@ use ArrayIterator; use MediaWiki\Rest\HttpException; use MediaWiki\Rest\ResponseFactory; use MediaWikiUnitTestCase; +use Wikimedia\Message\ITextFormatter; +use Wikimedia\Message\MessageValue; /** @covers \MediaWiki\Rest\ResponseFactory */ class ResponseFactoryTest extends MediaWikiUnitTestCase { @@ -18,14 +20,27 @@ class ResponseFactoryTest extends MediaWikiUnitTestCase { ]; } + private function createResponseFactory() { + $fakeTextFormatter = new class implements ITextFormatter { + function getLangCode() { + return 'qqx'; + } + + function format( MessageValue $message ) { + return $message->getKey(); + } + }; + return new ResponseFactory( [ $fakeTextFormatter ] ); + } + /** @dataProvider provideEncodeJson */ public function testEncodeJson( $input, $expected ) { - $rf = new ResponseFactory; + $rf = $this->createResponseFactory(); $this->assertSame( $expected, $rf->encodeJson( $input ) ); } public function testCreateJson() { - $rf = new ResponseFactory; + $rf = $this->createResponseFactory(); $response = $rf->createJson( [] ); $response->getBody()->rewind(); $this->assertSame( 'application/json', $response->getHeaderLine( 'Content-Type' ) ); @@ -35,7 +50,7 @@ class ResponseFactoryTest extends MediaWikiUnitTestCase { } public function testCreateNoContent() { - $rf = new ResponseFactory; + $rf = $this->createResponseFactory(); $response = $rf->createNoContent(); $this->assertSame( [], $response->getHeader( 'Content-Type' ) ); $this->assertSame( 0, $response->getBody()->getSize() ); @@ -43,35 +58,35 @@ class ResponseFactoryTest extends MediaWikiUnitTestCase { } public function testCreatePermanentRedirect() { - $rf = new ResponseFactory; + $rf = $this->createResponseFactory(); $response = $rf->createPermanentRedirect( 'http://www.example.com/' ); $this->assertSame( [ 'http://www.example.com/' ], $response->getHeader( 'Location' ) ); $this->assertSame( 301, $response->getStatusCode() ); } public function testCreateLegacyTemporaryRedirect() { - $rf = new ResponseFactory; + $rf = $this->createResponseFactory(); $response = $rf->createLegacyTemporaryRedirect( 'http://www.example.com/' ); $this->assertSame( [ 'http://www.example.com/' ], $response->getHeader( 'Location' ) ); $this->assertSame( 302, $response->getStatusCode() ); } public function testCreateTemporaryRedirect() { - $rf = new ResponseFactory; + $rf = $this->createResponseFactory(); $response = $rf->createTemporaryRedirect( 'http://www.example.com/' ); $this->assertSame( [ 'http://www.example.com/' ], $response->getHeader( 'Location' ) ); $this->assertSame( 307, $response->getStatusCode() ); } public function testCreateSeeOther() { - $rf = new ResponseFactory; + $rf = $this->createResponseFactory(); $response = $rf->createSeeOther( 'http://www.example.com/' ); $this->assertSame( [ 'http://www.example.com/' ], $response->getHeader( 'Location' ) ); $this->assertSame( 303, $response->getStatusCode() ); } public function testCreateNotModified() { - $rf = new ResponseFactory; + $rf = $this->createResponseFactory(); $response = $rf->createNotModified(); $this->assertSame( 0, $response->getBody()->getSize() ); $this->assertSame( 304, $response->getStatusCode() ); @@ -79,12 +94,12 @@ class ResponseFactoryTest extends MediaWikiUnitTestCase { /** @expectedException \InvalidArgumentException */ public function testCreateHttpErrorInvalid() { - $rf = new ResponseFactory; + $rf = $this->createResponseFactory(); $rf->createHttpError( 200 ); } public function testCreateHttpError() { - $rf = new ResponseFactory; + $rf = $this->createResponseFactory(); $response = $rf->createHttpError( 415, [ 'message' => '...' ] ); $this->assertSame( 415, $response->getStatusCode() ); $body = $response->getBody(); @@ -95,7 +110,7 @@ class ResponseFactoryTest extends MediaWikiUnitTestCase { } public function testCreateFromExceptionUnlogged() { - $rf = new ResponseFactory; + $rf = $this->createResponseFactory(); $response = $rf->createFromException( new HttpException( 'hello', 415 ) ); $this->assertSame( 415, $response->getStatusCode() ); $body = $response->getBody(); @@ -106,7 +121,7 @@ class ResponseFactoryTest extends MediaWikiUnitTestCase { } public function testCreateFromExceptionLogged() { - $rf = new ResponseFactory; + $rf = $this->createResponseFactory(); $response = $rf->createFromException( new \Exception( "hello", 415 ) ); $this->assertSame( 500, $response->getStatusCode() ); $body = $response->getBody(); @@ -131,7 +146,7 @@ class ResponseFactoryTest extends MediaWikiUnitTestCase { /** @dataProvider provideCreateFromReturnValue */ public function testCreateFromReturnValue( $input, $expected ) { - $rf = new ResponseFactory; + $rf = $this->createResponseFactory(); $response = $rf->createFromReturnValue( $input ); $body = $response->getBody(); $body->rewind(); @@ -140,7 +155,17 @@ class ResponseFactoryTest extends MediaWikiUnitTestCase { /** @expectedException \InvalidArgumentException */ public function testCreateFromReturnValueInvalid() { - $rf = new ResponseFactory; + $rf = $this->createResponseFactory(); $rf->createFromReturnValue( new ArrayIterator ); } + + public function testCreateLocalizedHttpError() { + $rf = $this->createResponseFactory(); + $response = $rf->createLocalizedHttpError( 404, new MessageValue( 'rftest' ) ); + $body = $response->getBody(); + $body->rewind(); + $this->assertSame( + '{"messageTranslations":{"qqx":"rftest"},"httpCode":404,"httpReason":"Not Found"}', + $body->getContents() ); + } } diff --git a/tests/phpunit/unit/includes/Rest/RouterTest.php b/tests/phpunit/unit/includes/Rest/RouterTest.php index e16ea25c9a..270bcfc483 100644 --- a/tests/phpunit/unit/includes/Rest/RouterTest.php +++ b/tests/phpunit/unit/includes/Rest/RouterTest.php @@ -3,6 +3,7 @@ namespace MediaWiki\Tests\Rest; use GuzzleHttp\Psr7\Uri; +use MediaWiki\Permissions\PermissionManager; use MediaWiki\Rest\BasicAccess\StaticBasicAuthorizer; use MediaWiki\Rest\Handler; use MediaWiki\Rest\HttpException; @@ -24,15 +25,16 @@ class RouterTest extends \MediaWikiUnitTestCase { $objectFactory = new ObjectFactory( $this->getMockForAbstractClass( ContainerInterface::class ) ); + $permissionManager = $this->createMock( PermissionManager::class ); return new Router( [ __DIR__ . '/testRoutes.json' ], [], '/rest', new \EmptyBagOStuff(), - new ResponseFactory(), + new ResponseFactory( [] ), new StaticBasicAuthorizer( $authError ), $objectFactory, - new Validator( $objectFactory, $request, new User ) + new Validator( $objectFactory, $permissionManager, $request, new User ) ); } @@ -55,6 +57,16 @@ class RouterTest extends \MediaWikiUnitTestCase { $this->assertSame( 'GET', $response->getHeaderLine( 'Allow' ) ); } + public function testHeadToGet() { + $request = new RequestData( [ + 'uri' => new Uri( '/rest/user/joe/hello' ), + 'method' => 'HEAD' + ] ); + $router = $this->createRouter( $request ); + $response = $router->execute( $request ); + $this->assertSame( 200, $response->getStatusCode() ); + } + public function testNoMatch() { $request = new RequestData( [ 'uri' => new Uri( '/rest/bogus' ) ] ); $router = $this->createRouter( $request ); diff --git a/tests/phpunit/unit/includes/diff/DiffOpTest.php b/tests/phpunit/unit/includes/diff/DiffOpTest.php index 4e1aced7a6..17487acbca 100644 --- a/tests/phpunit/unit/includes/diff/DiffOpTest.php +++ b/tests/phpunit/unit/includes/diff/DiffOpTest.php @@ -50,7 +50,7 @@ class DiffOpTest extends \MediaWikiUnitTestCase { */ public function testNorig() { $obj = new FakeDiffOp(); - $this->assertEquals( 0, $obj->norig() ); + $this->assertSame( 0, $obj->norig() ); $obj->orig = [ 'foo' ]; $this->assertEquals( 1, $obj->norig() ); } @@ -60,7 +60,7 @@ class DiffOpTest extends \MediaWikiUnitTestCase { */ public function testNclosing() { $obj = new FakeDiffOp(); - $this->assertEquals( 0, $obj->nclosing() ); + $this->assertSame( 0, $obj->nclosing() ); $obj->closing = [ 'foo' ]; $this->assertEquals( 1, $obj->nclosing() ); } diff --git a/tests/phpunit/unit/includes/password/PasswordFactoryTest.php b/tests/phpunit/unit/includes/password/PasswordFactoryTest.php index cbfddd4d72..2c852e0c75 100644 --- a/tests/phpunit/unit/includes/password/PasswordFactoryTest.php +++ b/tests/phpunit/unit/includes/password/PasswordFactoryTest.php @@ -7,7 +7,7 @@ class PasswordFactoryTest extends MediaWikiUnitTestCase { public function testConstruct() { $pf = new PasswordFactory(); $this->assertEquals( [ '' ], array_keys( $pf->getTypes() ) ); - $this->assertEquals( '', $pf->getDefaultType() ); + $this->assertSame( '', $pf->getDefaultType() ); $pf = new PasswordFactory( [ 'foo' => [ 'class' => 'FooPassword' ], diff --git a/tests/phpunit/unit/includes/search/SearchSuggestionSetTest.php b/tests/phpunit/unit/includes/search/SearchSuggestionSetTest.php index fb0309def5..fce21f7638 100644 --- a/tests/phpunit/unit/includes/search/SearchSuggestionSetTest.php +++ b/tests/phpunit/unit/includes/search/SearchSuggestionSetTest.php @@ -27,7 +27,7 @@ class SearchSuggestionSetTest extends \MediaWikiUnitTestCase { */ public function testAppend() { $set = SearchSuggestionSet::emptySuggestionSet(); - $this->assertEquals( 0, $set->getSize() ); + $this->assertSame( 0, $set->getSize() ); $set->append( new SearchSuggestion( 3 ) ); $this->assertEquals( 3, $set->getWorstScore() ); $this->assertEquals( 3, $set->getBestScore() ); @@ -61,7 +61,7 @@ class SearchSuggestionSetTest extends \MediaWikiUnitTestCase { */ public function testInsertBest() { $set = SearchSuggestionSet::emptySuggestionSet(); - $this->assertEquals( 0, $set->getSize() ); + $this->assertSame( 0, $set->getSize() ); $set->prepend( new SearchSuggestion( 3 ) ); $this->assertEquals( 3, $set->getWorstScore() ); $this->assertEquals( 3, $set->getBestScore() ); @@ -104,7 +104,7 @@ class SearchSuggestionSetTest extends \MediaWikiUnitTestCase { $this->assertEquals( 10, $set->getSize() ); $set->shrink( 0 ); - $this->assertEquals( 0, $set->getSize() ); + $this->assertSame( 0, $set->getSize() ); } // TODO: test for fromTitles diff --git a/tests/qunit/QUnitTestResources.php b/tests/qunit/QUnitTestResources.php index cab6c3bf99..a3a165f0a2 100644 --- a/tests/qunit/QUnitTestResources.php +++ b/tests/qunit/QUnitTestResources.php @@ -102,7 +102,6 @@ return [ ], 'dependencies' => [ 'jquery.color', - 'jquery.colorUtil', 'jquery.getAttrs', 'jquery.highlightText', 'jquery.lengthLimit', diff --git a/tests/qunit/suites/resources/mediawiki.api/mediawiki.ForeignApi.test.js b/tests/qunit/suites/resources/mediawiki.api/mediawiki.ForeignApi.test.js index 541c61072d..22a3a4b436 100644 --- a/tests/qunit/suites/resources/mediawiki.api/mediawiki.ForeignApi.test.js +++ b/tests/qunit/suites/resources/mediawiki.api/mediawiki.ForeignApi.test.js @@ -29,4 +29,29 @@ return api.post( {} ); } ); + QUnit.test( 'origin is not included in same-origin GET requests', function ( assert ) { + var apiUrl = location.protocol + '//' + location.host + '/w/api.php', + api = new mw.ForeignApi( apiUrl ); + + this.server.respond( function ( request ) { + assert.strictEqual( request.url.match( /origin=.*?(?:&|$)/ ), null, 'origin is not included in GET requests' ); + request.respond( 200, { 'Content-Type': 'application/json' }, '[]' ); + } ); + + return api.get( {} ); + } ); + + QUnit.test( 'origin is not included in same-origin POST requests', function ( assert ) { + var apiUrl = location.protocol + '//' + location.host + '/w/api.php', + api = new mw.ForeignApi( apiUrl ); + + this.server.respond( function ( request ) { + assert.strictEqual( request.requestBody.match( /origin=.*?(?:&|$)/ ), null, 'origin is not included in POST request body' ); + assert.strictEqual( request.url.match( /origin=.*?(?:&|$)/ ), null, 'origin is not included in POST request URL, either' ); + request.respond( 200, { 'Content-Type': 'application/json' }, '[]' ); + } ); + + return api.post( {} ); + } ); + }() ); diff --git a/tests/qunit/suites/resources/mediawiki/mediawiki.util.test.js b/tests/qunit/suites/resources/mediawiki/mediawiki.util.test.js index 4f61abd186..a05b50b462 100644 --- a/tests/qunit/suites/resources/mediawiki/mediawiki.util.test.js +++ b/tests/qunit/suites/resources/mediawiki/mediawiki.util.test.js @@ -474,4 +474,27 @@ assert.strictEqual( mw.util.escapeRegExp( normal ), normal, 'Alphanumerals are left alone' ); } ); + + QUnit.test( 'debounce', function ( assert ) { + var fn, + q = [], + done = assert.async(); + + fn = mw.util.debounce( 0, function ( data ) { + q.push( data ); + } ); + + fn( 1 ); + fn( 2 ); + fn( 3 ); + + setTimeout( function () { + assert.deepEqual( + q, + [ 3 ], + 'Last one ran' + ); + done(); + } ); + } ); }() ); diff --git a/tests/selenium/wdio-mediawiki/Api.js b/tests/selenium/wdio-mediawiki/Api.js index 6b674b99f9..8a28e4d84d 100644 --- a/tests/selenium/wdio-mediawiki/Api.js +++ b/tests/selenium/wdio-mediawiki/Api.js @@ -3,11 +3,37 @@ const MWBot = require( 'mwbot' ); // TODO: Once we require Node 7 or later, we can use async-await. module.exports = { + /** + * Get a logged-in instance of `MWBot` with edit token already set up. + * Default username, password and base URL is used unless specified. + * + * @since 0.5.0 + * @param {string} username - Optional + * @param {string} password - Optional + * @param {string} baseUrl - Optional + * @return {Promise} + */ + bot( + username = browser.options.username, + password = browser.options.password, + baseUrl = browser.options.baseUrl + ) { + const bot = new MWBot(); + + return bot.loginGetEditToken( { + apiUrl: `${baseUrl}/api.php`, + username: username, + password: password + } ).then( function () { + return bot; + } ); + }, + /** * Shortcut for `MWBot#edit( .. )`. * Default username, password and base URL is used unless specified * - * @since 1.0.0 + * @since 0.1.0 * @see * @param {string} title * @param {string} content @@ -22,42 +48,32 @@ module.exports = { password = browser.options.password, baseUrl = browser.options.baseUrl ) { - const bot = new MWBot(); - - return bot.loginGetEditToken( { - apiUrl: `${baseUrl}/api.php`, - username: username, - password: password - } ).then( function () { - return bot.edit( title, content, `Created or updated page with "${content}"` ); - } ); + return this.bot( username, password, baseUrl ) + .then( function ( bot ) { + return bot.edit( title, content, `Created or updated page with "${content}"` ); + } ); }, /** * Shortcut for `MWBot#delete( .. )`. * - * @since 1.0.0 + * @since 0.1.0 * @see * @param {string} title * @param {string} reason * @return {Object} Promise for API action=delete response data. */ delete( title, reason ) { - const bot = new MWBot(); - - return bot.loginGetEditToken( { - apiUrl: `${browser.options.baseUrl}/api.php`, - username: browser.options.username, - password: browser.options.password - } ).then( function () { - return bot.delete( title, reason ); - } ); + return this.bot() + .then( function ( bot ) { + return bot.delete( title, reason ); + } ); }, /** * Shortcut for `MWBot#request( { acount: 'createaccount', .. } )`. * - * @since 1.0.0 + * @since 0.1.0 * @see * @param {string} username * @param {string} password @@ -94,23 +110,17 @@ module.exports = { * @return {Object} Promise for API action=block response data. */ blockUser( username, expiry ) { - const bot = new MWBot(); - - // Log in as admin - return bot.loginGetEditToken( { - apiUrl: `${browser.options.baseUrl}/api.php`, - username: browser.options.username, - password: browser.options.password - } ).then( () => { - // block user. default = admin - return bot.request( { - action: 'block', - user: username || browser.options.username, - reason: 'browser test', - token: bot.editToken, - expiry + return this.bot() + .then( function ( bot ) { + // block user. default = admin + return bot.request( { + action: 'block', + user: username || browser.options.username, + reason: 'browser test', + token: bot.editToken, + expiry + } ); } ); - } ); }, /** @@ -122,21 +132,15 @@ module.exports = { * @return {Object} Promise for API action=unblock response data. */ unblockUser( username ) { - const bot = new MWBot(); - - // Log in as admin - return bot.loginGetEditToken( { - apiUrl: `${browser.options.baseUrl}/api.php`, - username: browser.options.username, - password: browser.options.password - } ).then( () => { - // unblock user. default = admin - return bot.request( { - action: 'unblock', - user: username || browser.options.username, - reason: 'browser test done', - token: bot.editToken + return this.bot() + .then( function ( bot ) { + // unblock user. default = admin + return bot.request( { + action: 'unblock', + user: username || browser.options.username, + reason: 'browser test done', + token: bot.editToken + } ); } ); - } ); } }; diff --git a/tests/selenium/wdio-mediawiki/CHANGELOG.md b/tests/selenium/wdio-mediawiki/CHANGELOG.md index ed6c78a722..79356a2209 100644 --- a/tests/selenium/wdio-mediawiki/CHANGELOG.md +++ b/tests/selenium/wdio-mediawiki/CHANGELOG.md @@ -1,3 +1,7 @@ +## 0.5.0 / 2019-09-18 + +* Api: Added `bot()` method. + ## 0.4.0 / 2019-07-18 * Util: Added a `waitForModuleState()` method. diff --git a/tests/selenium/wdio-mediawiki/README.md b/tests/selenium/wdio-mediawiki/README.md index dc16e816d2..d2698f7cf5 100644 --- a/tests/selenium/wdio-mediawiki/README.md +++ b/tests/selenium/wdio-mediawiki/README.md @@ -22,11 +22,12 @@ Utilities to interact with the MediaWiki API. Uses the [mwbot](https://github.co Actions are performed logged-in using `browser.options.username` and `browser.options.password`, which typically come from `MEDIAWIKI_USER` and `MEDIAWIKI_PASSWORD` environment variables. -* `edit(title, content [, string username [, string password [, string baseUrl ] ] ])` -* `delete(title, reason)` -* `createAccount(username, password)` -* `blockUser(username, expiry)` -* `unblockUser(username)` +* `edit(string title, string content [, string username [, string password [, string baseUrl ] ] ])` +* `delete(string title, string reason)` +* `createAccount(string username, string password)` +* `blockUser([ string username [, string expiry ] ])` +* `unblockUser([ string username ])` +* `bot([string username [, string password [, string baseUrl ] ] ])` ### RunJobs diff --git a/tests/selenium/wdio-mediawiki/package.json b/tests/selenium/wdio-mediawiki/package.json index 423487f4d2..58a5390de9 100644 --- a/tests/selenium/wdio-mediawiki/package.json +++ b/tests/selenium/wdio-mediawiki/package.json @@ -1,6 +1,6 @@ { "name": "wdio-mediawiki", - "version": "0.4.0", + "version": "0.5.0", "description": "WebdriverIO plugin for testing a MediaWiki site.", "homepage": "https://gerrit.wikimedia.org/g/mediawiki/core/+/master/tests/selenium/wdio-mediawiki/", "license": "MIT", diff --git a/tests/selenium/wdio.conf.js b/tests/selenium/wdio.conf.js index 6512e7db87..72a89dd606 100644 --- a/tests/selenium/wdio.conf.js +++ b/tests/selenium/wdio.conf.js @@ -39,16 +39,8 @@ exports.config = { // Sauce Labs // ====== // See http://webdriver.io/guide/services/sauce.html - // and https://docs.saucelabs.com/reference/platforms-configurator - services: [ 'sauce' ], - user: process.env.SAUCE_USERNAME, - key: process.env.SAUCE_ACCESS_KEY, - - // Default timeout in milliseconds for Selenium Grid requests - connectionRetryTimeout: 90 * 1000, - - // Default request retries count - connectionRetryCount: 3, + // and https://github.com/bermi/sauce-connect-launcher#advanced-usage + services: process.env.SAUCE_ACCESS_KEY ? [ 'sauce' ] : [], // ================== // Test Files diff --git a/thumb.php b/thumb.php index 5be1ed07ab..bedf171510 100644 --- a/thumb.php +++ b/thumb.php @@ -524,7 +524,7 @@ function wfGenerateThumbnail( File $file, array $params, $thumbName, $thumbPath * /w/images/thumb/a/ab/Foo.png/120px-Foo.png. The $thumbRel parameter * of this function would be set to "a/ab/Foo.png/120px-Foo.png". * This method is responsible for turning that into an array - * with the folowing keys: + * with the following keys: * * f => the filename (Foo.png) * * rel404 => the whole thing (a/ab/Foo.png/120px-Foo.png) * * archived => 1 (If the request is for an archived thumb)