regularly. Below only new and removed languages are listed, as well as
changes to languages because of Bugzilla reports.
+* Languages added:
+** awa (अवधी / Awadhi), thanks to translator 1AnuraagPandey;
+** bgn (بلوچی رخشانی / Western Balochi), thanks to translators
+ Baloch Afghanistan, Ibrahim khashrowdi and Rachitrali;
+** ses (Koyraboro Senni), thanks to translator Songhay.
* (T66440) Kazakh (kk) wikis should no longer forcefully reset the user's
interface language to kk where unexpected.
* The Chinese conversion table was substantially updated to fix a lot of
regularly. Below only new and removed languages are listed, as well as
changes to languages because of Bugzilla reports.
+* BREAKING CHANGE (T91240): Language code "bh" is not valid in ISO 639 and
+ was removed, so it will no longer alias to "bho". If you used "bh" as your
+ wiki's $wgLanguageCode, you must update your configuration.
=== Other changes in 1.26 ===
* ChangeTags::tagDescription() will return false if the interface message
*/
$wgEnotifUseJobQ = false;
+/**
+ * Use the job queue for user activity updates like updating "last visited"
+ * fields for email notifications of page changes. This should only be enabled
+ * if the jobs have a dedicated runner to avoid update lag.
+ *
+ * @since 1.26
+ */
+$wgActivityUpdatesUseJobQueue = false;
+
/**
* Use real name instead of username in e-mail "from" field.
*/
'ThumbnailRender' => 'ThumbnailRenderJob',
'recentChangesUpdate' => 'RecentChangesUpdateJob',
'refreshLinksPrioritized' => 'RefreshLinksJob', // for cascading protection
+ 'activityUpdateJob' => 'ActivityUpdateJob',
'enqueue' => 'EnqueueJob', // local queue for multi-DC setups
'null' => 'NullJob'
);
/**
* Parse the request to get the Title object
*
+ * @throws MalformedTitleException If a title has been provided by the user, but is invalid.
* @return Title Title object to be $wgTitle
*/
private function parseTitle() {
}
if ( $ret === null || ( $ret->getDBkey() == '' && !$ret->isExternal() ) ) {
- $ret = SpecialPage::getTitleFor( 'Badtitle' );
+ // If we get here, we definitely don't have a valid title; throw an exception.
+ // Try to get detailed invalid title exception first, fall back to MalformedTitleException.
+ Title::newFromTextThrow( $title );
+ throw new MalformedTitleException( null, $title );
}
return $ret;
*/
public function getTitle() {
if ( !$this->context->hasTitle() ) {
- $this->context->setTitle( $this->parseTitle() );
+ try {
+ $this->context->setTitle( $this->parseTitle() );
+ } catch ( MalformedTitleException $ex ) {
+ $this->context->setTitle( SpecialPage::getTitleFor( 'Badtitle' ) );
+ }
}
return $this->context->getTitle();
}
|| $title->isSpecial( 'Badtitle' )
) {
$this->context->setTitle( SpecialPage::getTitleFor( 'Badtitle' ) );
+ try {
+ $this->parseTitle();
+ } catch ( MalformedTitleException $ex ) {
+ throw new BadTitleError( $ex );
+ }
throw new BadTitleError();
}
$output->redirect( $url, 301 );
} else {
$this->context->setTitle( SpecialPage::getTitleFor( 'Badtitle' ) );
+ try {
+ $this->parseTitle();
+ } catch ( MalformedTitleException $ex ) {
+ throw new BadTitleError( $ex );
+ }
throw new BadTitleError();
}
// Redirect loops, no title in URL, $wgUsePathInfo URLs, and URLs with a variant
public static function newFromDBkey( $key ) {
$t = new Title();
$t->mDbkeyform = $key;
- if ( $t->secureAndSplit() ) {
+
+ try {
+ $t->secureAndSplit();
return $t;
- } else {
+ } catch ( MalformedTitleException $ex ) {
return null;
}
}
wfWarn( __METHOD__ . ': $text must be a string. This will throw an InvalidArgumentException in future.', 2 );
}
+ try {
+ return Title::newFromTextThrow( $text, $defaultNamespace );
+ } catch ( MalformedTitleException $ex ) {
+ return null;
+ }
+ }
+
+ /**
+ * Like Title::newFromText(), but throws MalformedTitleException when the title is invalid,
+ * rather than returning null.
+ *
+ * The exception subclasses encode detailed information about why the title is invalid.
+ *
+ * @see Title::newFromText
+ *
+ * @since 1.25
+ * @param string $text Title text to check
+ * @param int $defaultNamespace
+ * @throws MalformedTitleException If the title is invalid
+ * @return Title
+ */
+ public static function newFromTextThrow( $text, $defaultNamespace = NS_MAIN ) {
+ if ( is_object( $text ) ) {
+ throw new MWException( 'Title::newFromTextThrow given an object' );
+ }
+
$cache = self::getTitleCache();
/**
$t->mDbkeyform = str_replace( ' ', '_', $filteredText );
$t->mDefaultNamespace = intval( $defaultNamespace );
- if ( $t->secureAndSplit() ) {
- if ( $defaultNamespace == NS_MAIN ) {
- $cache->set( $text, $t );
- }
- return $t;
- } else {
- return null;
+ $t->secureAndSplit();
+ if ( $defaultNamespace == NS_MAIN ) {
+ $cache->set( $text, $t );
}
+ return $t;
}
/**
}
$t->mDbkeyform = str_replace( ' ', '_', $url );
- if ( $t->secureAndSplit() ) {
+
+ try {
+ $t->secureAndSplit();
return $t;
- } else {
+ } catch ( MalformedTitleException $ex ) {
return null;
}
}
$t = new Title();
$t->mDbkeyform = Title::makeName( $ns, $title, $fragment, $interwiki, true );
- if ( $t->secureAndSplit() ) {
+
+ try {
+ $t->secureAndSplit();
return $t;
- } else {
+ } catch ( MalformedTitleException $ex ) {
return null;
}
}
* namespace prefixes, sets the other forms, and canonicalizes
* everything.
*
+ * @throws MalformedTitleException On invalid titles
* @return bool True on success
*/
private function secureAndSplit() {
$dbkey = $this->mDbkeyform;
- try {
- // @note: splitTitleString() is a temporary hack to allow MediaWikiTitleCodec to share
- // the parsing code with Title, while avoiding massive refactoring.
- // @todo: get rid of secureAndSplit, refactor parsing code.
- $titleParser = self::getTitleParser();
- $parts = $titleParser->splitTitleString( $dbkey, $this->getDefaultNamespace() );
- } catch ( MalformedTitleException $ex ) {
- return false;
- }
+ // @note: splitTitleString() is a temporary hack to allow MediaWikiTitleCodec to share
+ // the parsing code with Title, while avoiding massive refactoring.
+ // @todo: get rid of secureAndSplit, refactor parsing code.
+ $titleParser = self::getTitleParser();
+ // MalformedTitleException can be thrown here
+ $parts = $titleParser->splitTitleString( $dbkey, $this->getDefaultNamespace() );
# Fill fields
$this->setFragment( '#' . $parts['fragment'] );
$force = 'force';
}
- $this->getWatchedItem( $title )->resetNotificationTimestamp( $force, $oldid );
+ $this->getWatchedItem( $title )->resetNotificationTimestamp(
+ $force, $oldid, WatchedItem::DEFERRED
+ );
}
/**
* @ingroup Watchlist
*/
class WatchedItem {
- /**
- * Constant to specify that user rights 'editmywatchlist' and
- * 'viewmywatchlist' should not be checked.
- * @since 1.22
- */
- const IGNORE_USER_RIGHTS = 0;
-
- /**
- * Constant to specify that user rights 'editmywatchlist' and
- * 'viewmywatchlist' should be checked.
- * @since 1.22
- */
- const CHECK_USER_RIGHTS = 1;
-
/** @var Title */
public $mTitle;
/** @var string */
private $timestamp;
+ /**
+ * Constant to specify that user rights 'editmywatchlist' and
+ * 'viewmywatchlist' should not be checked.
+ * @since 1.22
+ */
+ const IGNORE_USER_RIGHTS = 0;
+
+ /**
+ * Constant to specify that user rights 'editmywatchlist' and
+ * 'viewmywatchlist' should be checked.
+ * @since 1.22
+ */
+ const CHECK_USER_RIGHTS = 1;
+
+ /**
+ * Do DB master updates right now
+ * @since 1.26
+ */
+ const IMMEDIATE = 0;
+ /**
+ * Do DB master updates via the job queue
+ * @since 1.26
+ */
+ const DEFERRED = 1;
+
/**
* Create a WatchedItem object with the given user and title
* @since 1.22 $checkRights parameter added
* @param bool $force Whether to force the write query to be executed even if the
* page is not watched or the notification timestamp is already NULL.
* @param int $oldid The revision id being viewed. If not given or 0, latest revision is assumed.
+ * @mode int $mode WatchedItem::DEFERRED/IMMEDIATE
*/
- public function resetNotificationTimestamp( $force = '', $oldid = 0 ) {
+ public function resetNotificationTimestamp(
+ $force = '', $oldid = 0, $mode = self::IMMEDIATE
+ ) {
+ global $wgActivityUpdatesUseJobQueue;
+
// Only loggedin user can have a watchlist
if ( wfReadOnly() || $this->mUser->isAnon() || !$this->isAllowed( 'editmywatchlist' ) ) {
return;
}
}
- // If the page is watched by the user (or may be watched), update the timestamp on any
- // any matching rows
- $dbw = wfGetDB( DB_MASTER );
- $dbw->update( 'watchlist', array( 'wl_notificationtimestamp' => $notificationTimestamp ),
- $this->dbCond(), __METHOD__ );
+ // If the page is watched by the user (or may be watched), update the timestamp
+ if ( $mode === self::DEFERRED && $wgActivityUpdatesUseJobQueue ) {
+ JobQueueGroup::singleton()->push(
+ EnqueueJob::newFromLocalJobs( new JobSpecification(
+ 'activityUpdateJob',
+ array(
+ 'type' => 'updateWatchlistNotification',
+ 'userid' => $this->getUserId(),
+ 'notifTime' => $notificationTimestamp,
+ 'curTime' => time()
+ ),
+ array( 'removeDuplicates' => true ),
+ $title
+ ) )
+ );
+ } else {
+ $dbw = wfGetDB( DB_MASTER );
+ $dbw->update( 'watchlist',
+ array( 'wl_notificationtimestamp' => $notificationTimestamp ),
+ $this->dbCond(),
+ __METHOD__
+ );
+ }
+
$this->timestamp = null;
}
}
public function getHelpUrls() {
- return 'https://www.mediawiki.org/wiki/API:Meta#allmessages_.2F_am';
+ return 'https://www.mediawiki.org/wiki/API:Allmessages';
}
}
}
public function getHelpUrls() {
- $name = $this->getModuleName();
- $prefix = $this->getModulePrefix();
- return "https://www.mediawiki.org/wiki/API:Properties#{$name}_.2F_{$prefix}";
+ $name = ucfirst( $this->getModuleName() );
+ return "https://www.mediawiki.org/wiki/API:{$name}";
}
}
}
public function getHelpUrls() {
- return 'https://www.mediawiki.org/wiki/API:Properties#categories_.2F_cl';
+ return 'https://www.mediawiki.org/wiki/API:Categories';
}
}
}
public function getHelpUrls() {
- return 'https://www.mediawiki.org/wiki/API:Properties#categoryinfo_.2F_ci';
+ return 'https://www.mediawiki.org/wiki/API:Categoryinfo';
}
}
}
public function getHelpUrls() {
- return 'https://www.mediawiki.org/wiki/API:Properties#contributors_.2F_pc';
+ return 'https://www.mediawiki.org/wiki/API:Contributors';
}
}
}
public function getHelpUrls() {
- return 'https://www.mediawiki.org/wiki/API:Properties#deletedrevisions_.2F_drv';
+ return 'https://www.mediawiki.org/wiki/API:Deletedrevisions';
}
}
}
public function getHelpUrls() {
- return 'https://www.mediawiki.org/wiki/API:Properties#duplicatefiles_.2F_df';
+ return 'https://www.mediawiki.org/wiki/API:Duplicatefiles';
}
}
}
public function getHelpUrls() {
- return 'https://www.mediawiki.org/wiki/API:Properties#extlinks_.2F_el';
+ return 'https://www.mediawiki.org/wiki/API:Extlinks';
}
}
=> 'apihelp-query+filerepoinfo-example-simple',
);
}
+
+ public function getHelpUrls() {
+ return 'https://www.mediawiki.org/wiki/API:Filerepoinfo';
+ }
}
}
public function getHelpUrls() {
- return 'https://www.mediawiki.org/wiki/API:Properties#imageinfo_.2F_ii';
+ return 'https://www.mediawiki.org/wiki/API:Imageinfo';
}
}
}
public function getHelpUrls() {
- return 'https://www.mediawiki.org/wiki/API:Properties#images_.2F_im';
+ return 'https://www.mediawiki.org/wiki/API:Images';
}
}
}
public function getHelpUrls() {
- return 'https://www.mediawiki.org/wiki/API:Properties#info_.2F_in';
+ return 'https://www.mediawiki.org/wiki/API:Info';
}
}
}
public function getHelpUrls() {
- return 'https://www.mediawiki.org/wiki/API:Properties#langlinks_.2F_ll';
+ return 'https://www.mediawiki.org/wiki/API:Langlinks';
}
}
$this->table = 'pagelinks';
$this->prefix = 'pl';
$this->titlesParam = 'titles';
- $this->helpUrl = 'https://www.mediawiki.org/wiki/API:Properties#links_.2F_pl';
+ $this->helpUrl = 'https://www.mediawiki.org/wiki/API:Links';
break;
case self::TEMPLATES:
$this->table = 'templatelinks';
$this->prefix = 'tl';
$this->titlesParam = 'templates';
- $this->helpUrl = 'https://www.mediawiki.org/wiki/API:Properties#templates_.2F_tl';
+ $this->helpUrl = 'https://www.mediawiki.org/wiki/API:Templates';
break;
default:
ApiBase::dieDebug( __METHOD__, 'Unknown module name' );
}
public function getHelpUrls() {
- return 'https://www.mediawiki.org/wiki/API:Properties#pageprops_.2F_pp';
+ return 'https://www.mediawiki.org/wiki/API:Pageprops';
}
}
}
public function getHelpUrls() {
- return 'https://www.mediawiki.org/wiki/API:Properties#revisions_.2F_rv';
+ return 'https://www.mediawiki.org/wiki/API:Revisions';
}
}
}
public function getHelpUrls() {
- return 'https://www.mediawiki.org/wiki/API:Meta#siteinfo_.2F_si';
+ return 'https://www.mediawiki.org/wiki/API:Siteinfo';
}
}
=> 'apihelp-query+stashimageinfo-example-params',
);
}
+
+ public function getHelpUrls() {
+ return 'https://www.mediawiki.org/wiki/API:Stashimageinfo';
+ }
}
public function getCacheMode( $params ) {
return 'private';
}
+
+ public function getHelpUrls() {
+ return 'https://www.mediawiki.org/wiki/API:Tokens';
+ }
}
}
public function getHelpUrls() {
- return 'https://www.mediawiki.org/wiki/API:Meta#userinfo_.2F_ui';
+ return 'https://www.mediawiki.org/wiki/API:Userinfo';
}
}
"apihelp-imagerotate-example-generator": "Otočit všechny obrázky v <kbd>Category:Flip</kbd> o <kbd>180</kbd> stupňů.",
"apihelp-import-param-summary": "Import shrnutí.",
"apihelp-import-param-xml": "Nahraný XML soubor.",
- "apihelp-import-param-rootpage": "Importovat jako podstránku k této stránce.",
+ "apihelp-import-param-namespace": "Importovat do tohoto jmenného prostoru. Přepíše parametr <kbd>$1rootpage</kbd>.",
+ "apihelp-import-param-rootpage": "Importovat jako podstránku k této stránce. Ignoruje se, pokud je k dispozici parametr <kbd>$1namespace</kbd>.",
"apihelp-login-param-name": "Uživatelské jméno.",
"apihelp-login-param-password": "Heslo.",
"apihelp-login-param-domain": "Doména (volitelná)",
"apihelp-imagerotate-example-generator": "Rotar todas las imágenes en la <kbd>Categoría:Girar</kbd> <kbd>180</kbd> grados.",
"apihelp-import-param-summary": "Resumen de importación.",
"apihelp-import-param-xml": "Se cargó el archivo XML.",
- "apihelp-import-param-rootpage": "Importar como subpágina de esta página.",
+ "apihelp-import-param-rootpage": "Importar como subpágina de esta página. Se ignora si se proporciona el parámetro <kbd>$1namespace</kbd>.",
"apihelp-login-param-name": "Nombre de usuario.",
"apihelp-login-param-password": "Contraseña.",
"apihelp-login-param-domain": "Dominio (opcional).",
"apihelp-tag-param-reason": "Dä Jrond för di Änderong.",
"apihelp-tag-example-rev": "Donn de Makkehrong „<kbd lang=\"en\" xml:lang=\"en\" dir=\"ltr\">vandalism</kbd>“ vun dä Väsjohn met dä Kännong „<kbd>123</kbd>“ fott nämme, der ohne ene Jrond ze nänne.",
"apihelp-tag-example-log": "Donn de Makkehrong „<kbd lang=\"en\" xml:lang=\"en\" dir=\"ltr\">spam</kbd>“ vun dämm Enndrahch met dä Kännong „<kbd>123</kbd>“ em Logbohch fott nämme un als Jrond draaach „<kbd lang=\"en\" xml:lang=\"en\" dir=\"ltr\">Wrongly applied</kbd>“ enn.",
+ "apihelp-upload-description": "Donn en Dattei huh lahde, udder holl der Zohschtand vun de onfähdesch huhjelahde Datteije .\n\nEt jitt ongerscheidlejje Metohde:\n* Donn de Ennhallde vun de Datteije tiräk huhlahde, övver der Parramehter „<var lang=\"en\" xml:lang=\"en\" dir=\"ltr\">$1file</var>“.\n* Donn de Datteije en en Aanzahl Rötsche huhlahde, övver de Parramehter „<var lang=\"en\" xml:lang=\"en\" dir=\"ltr\">$1filesize</var>“, „<var lang=\"en\" xml:lang=\"en\" dir=\"ltr\">$1chunk</var>“, un „<var lang=\"en\" xml:lang=\"en\" dir=\"ltr\">$1offset</var>“.\n* Lohß der ẞööver vum Wikki en Dattei vun enem <i lang=\"en\" xml:lang=\"en\" dir=\"ltr\" title=\"Uniform Ressource Locator\">URL</i> holle, övver de Parramehter „<var lang=\"en\" xml:lang=\"en\" dir=\"ltr\">$1url</var>“.\n* Lohß en Dattei fähdesch huhlahde, di zeläz nit fähdesch wohd, un met Warnonge schtonn jeblevve es övver de Parramehter „<var lang=\"en\" xml:lang=\"en\" dir=\"ltr\">$1filekey</var>“.\nOpjepaß: dä „<code lang=\"en\" xml:lang=\"en\" dir=\"ltr\">POST</code>“-Befähl vum <i lang=\"en\" xml:lang=\"en\" dir=\"ltr\" title=\"HyperText Transfer Protocol\">HTTP</i> moß als e Dattei-Huhlahde aanjeschtüßße wähde, allsu met „<code lang=\"en\" xml:lang=\"en\" dir=\"ltr\">multipart/form-data</code>“, wam_mer dä Parramehter „<var lang=\"en\" xml:lang=\"en\" dir=\"ltr\">$1file</var>“ scheck.",
"api-help-source": "Quäll: $1",
"api-help-source-unknown": "Quäll: <span class=\"apihelp-unknown\">onbikannt</span>",
"api-help-license": "Lezänz: [[$1|$2]]",
"apihelp-main-param-requestid": "Тука внесената вредност ќе биде вклучена во извештајот. Може да се користи за разликување на барањата.",
"apihelp-main-param-servedby": "Вклучи го домаќинското име што го услужило барањето во резултатите.",
"apihelp-main-param-curtimestamp": "Бклучи тековно време и време и датум во резултатот.",
- "apihelp-main-param-origin": "Кога му пристапувате на Пирлогот користејќи повеќедоменско AJAX-барање (CORS), задајте му го на ова изворниот домен. Ова мора да се вклучи во секое подготвително барање и затоа мора да биде дел од URI на барањето (не главната содржина во POST). Ова мора точно да се совпаѓа со еден од изворниците на заглавието Origin:, така што мора да е зададен на нешто како http://en.wikipedia.org or https://meta.wikimedia.org. Ако овој параметар не се совпаѓа со заглавието Origin:, ќе се појави одговор 403. Ако се совпаѓа, а изворникот е на бел список (на допуштени), тогаш ќе се зададе ззаглавието Контрола на пристап-Изворник.",
- "apihelp-main-param-uselang": "Јазик за преведување на пораките. Список на јазични кодови ќе најдете на [[Special:ApiHelp/query+siteinfo|action=query&meta=siteinfo]] со siprop=languages или укажете „user“ за да го користите тековно зададениот јазик корисникот, или пак укажете „content“ за да го користите јазикот на содржината на ова вики.",
+ "apihelp-main-param-origin": "Кога му пристапувате на Пирлогот користејќи повеќедоменско AJAX-барање (CORS), задајте му го на ова изворниот домен. Ова мора да се вклучи во секое подготвително барање и затоа мора да биде дел од URI на барањето (не главната содржина во POST). Ова мора точно да се совпаѓа со еден од изворниците на заглавието Origin:, така што мора да е зададен на нешто како <kbd>https://mk.wikipedia.org</kbd> or <kbd>https://meta.wikimedia.org</kbd>. Ако овој параметар не се совпаѓа со заглавието <code>Origin</code>:, ќе се појави одговор 403. Ако се совпаѓа, а изворникот е на бел список (на допуштени), тогаш ќе се зададе заглавието <code>Access-Control-Allow-Origin</code>.",
+ "apihelp-main-param-uselang": "Јазик за преведување на пораките. Список на јазични кодови ќе најдете на <kbd>[[Special:ApiHelp/query+siteinfo|action=query&meta=siteinfo]]</kbd> со <kbd>siprop=languages</kbd> или укажете <kbd>user</kbd> за да го користите тековно зададениот јазик корисникот, или пак укажете <kbd>content</kbd> за да го користите јазикот на содржината на ова вики.",
"apihelp-block-description": "Блокирај корисник.",
"apihelp-block-param-user": "Корисничко име, IP-адреса или IP-опсег ако сакате да блокирате.",
- "apihelp-block-param-expiry": "Време на истек. Може да биде релативно (на пр. „5 месеци“ или „2 недели“) или пак апсолутно (на пр. „2014-09-18T12:34:56Z“). Ако го зададете „бесконечно“, „неодредено“ или „никогаш“, блокот ќе трае засекогаш.",
+ "apihelp-block-param-expiry": "Време на истек. Може да биде релативно (на пр. <kbd>5 months</kbd> или „2 недели“) или пак апсолутно (на пр. <kbd>2014-09-18T12:34:56Z</kbd>). Ако го зададете <kbd>infinite</kbd>, <kbd>indefinite</kbd> или <kbd>never</kbd>, блокот ќе трае засекогаш.",
"apihelp-block-param-reason": "Причина за блокирање.",
"apihelp-block-param-anononly": "Блокирај само анонимни корисници (т.е. оневозможи анонимно уредување од оваа IP-адреса).",
"apihelp-block-param-nocreate": "Оневозможи создавање кориснички сметки.",
"apihelp-block-param-autoblock": "Автоматски блокирај ја последно употребената IP-адреса и сите понатамошни IP-адреси од кои лицето ќе се обиде да се најави.",
- "apihelp-block-param-noemail": "Оневозможи му на корисникот да испаќа е-пошта преку викито. (Го бара правото „блокирање е-пошта“).",
+ "apihelp-block-param-noemail": "Оневозможи му на корисникот да испаќа е-пошта преку викито. (Го бара правото code>blockemail</code>).",
"apihelp-block-param-hidename": "Скриј го корисничкото име од дневникот на блокирања. (Го бара правото <code>hideuser</code>)",
"apihelp-block-param-allowusertalk": "Овозможи му на корисникот да си ја уредува сопствената страница за разговор (зависи од <var>[[mw:Manual:$wgBlockAllowsUTEdit|$wgBlockAllowsUTEdit]]</var>).",
"apihelp-block-param-reblock": "Ако корисникот е веќе блокиран, наметни врз постоечкиот блок.",
"apihelp-block-param-watchuser": "Набљудувај ја корисничката страница и страницата за разговор на овој корисник или IP-адреса",
"apihelp-block-example-ip-simple": "Блокирај ја IP-адресата <kbd>192.0.2.5</kbd> три дена со причината <kbd>Прва опомена</kbd>.",
- "apihelp-block-example-user-complex": "Блокирај го корисникот Вандал (Vandal) бесконечно со причината „Вандализам“ и оневозможи создавање на нови сметки и праќање е-пошта",
+ "apihelp-block-example-user-complex": "Блокирај го корисникот <kbd>Vandal</kbd> (Вандал) бесконечно со причината <kbd>Vandal</kbd> (Вандализам) и оневозможи создавање на нови сметки и праќање е-пошта.",
+ "apihelp-checktoken-description": "Проверка на полноважноста на шифрата од <kbd>[[Special:ApiHelp/query+tokens|action=query&meta=tokens]]</kbd>.",
+ "apihelp-checktoken-param-type": "Тип на шифра што се испробува.",
+ "apihelp-checktoken-param-token": "Шифра што се испробува.",
"apihelp-clearhasmsg-description": "Ја отстранува ознаката „<code>hasmsg</code>“ од тековниот корисник.",
"apihelp-clearhasmsg-example-1": "Отстрани ја ознаката „<code>hasmsg</code>“ од тековниот корисник",
- "apihelp-compare-description": "Ð\94обиваÑ\9aе на Ñ\80азлика помеÑ\93Ñ\83 две Ñ\81Ñ\82Ñ\80аниÑ\86и.\n\nÐ\9cоÑ\80а да Ñ\81е добие бÑ\80оÑ\98 на пÑ\80еÑ\80абоÑ\82каÑ\82а, наÑ\81лов на Ñ\81Ñ\82Ñ\80аниваÑ\82а или пак неÑ\98зина назнака. Ð\92ажи и за „од“ и за „на“.",
+ "apihelp-compare-description": "Ð\94обиваÑ\9aе на Ñ\80азлика помеÑ\93Ñ\83 две Ñ\81Ñ\82Ñ\80аниÑ\86и.\n\nÐ\9cоÑ\80а да Ñ\81е даде бÑ\80оÑ\98оÑ\82 на пÑ\80еÑ\80абоÑ\82каÑ\82а, наÑ\81ловоÑ\82 на Ñ\81Ñ\82Ñ\80аниÑ\86аÑ\82а или пак неÑ\98зина назнака за „од“ и за „на“.",
"apihelp-compare-param-fromtitle": "Прв наслов за споредба.",
"apihelp-compare-param-fromid": "Прва назнака на страница за споредба.",
"apihelp-compare-param-fromrev": "Прва преработка за споредба.",
"apihelp-createaccount-param-mailpassword": "Ако му се зададе било каква вредност, тогаш на корисникот ќе му биде испратена случајна лозинка.",
"apihelp-createaccount-param-reason": "Незадолжителна прочина за создавање на сметката која ќе стои во дневниците.",
"apihelp-createaccount-param-language": "Јазичен код кој ќе биде стандарден за корисникот (незадолжително, по основно: јазикот на самото вики).",
- "apihelp-createaccount-example-pass": "Создај го корисникот „testuser“ со лозинката „test123“",
- "apihelp-createaccount-example-mail": "Создај го корисникот „testmailuser“ и испрати случајно-создадена лозинка по е-пошта",
+ "apihelp-createaccount-example-pass": "Создај го корисникот <kbd>testuser</kbd> со лозинката <kbd>test123</kbd>.",
+ "apihelp-createaccount-example-mail": "Создај го корисникот <kbd>testmailuser</kbd> и испрати случајно-создадена лозинка по е-пошта.",
"apihelp-delete-description": "Избриши страница.",
- "apihelp-delete-param-title": "Наслов на страницата што сакате да ја избришете. Не може да се користи заедно со $1pageid.",
- "apihelp-delete-param-pageid": "Назнака на страницата што сакате да ја избришете. Не може да се користи заедно со $1title.",
+ "apihelp-delete-param-title": "Наслов на страницата што сакате да ја избришете. Не може да се користи заедно со <var>$1pageid</var>.",
+ "apihelp-delete-param-pageid": "Назнака на страницата што сакате да ја избришете. Не може да се користи заедно со <var>$1title</var>.",
"apihelp-delete-param-reason": "Причина за бришење. Ако не се зададе, ќе се наведе автоматска причина.",
- "apihelp-delete-param-watch": "Додај ја страницата во набљудуваните.",
- "apihelp-delete-param-watchlist": "Безусловно додај или отстрани ја страницата од набљудуваните, користете ги нагодувањата или не ги менувајте набљудуваните.",
- "apihelp-delete-param-unwatch": "Отстрани ја страницата од набљудуваните.",
+ "apihelp-delete-param-watch": "Додај ја страницата во набљудуваните на тековниот корисник.",
+ "apihelp-delete-param-watchlist": "Безусловно додај или отстрани ја страницата од набљудуваните на тековниот корисник, користете ги нагодувањата или не ги менувајте набљудуваните.",
+ "apihelp-delete-param-unwatch": "Отстрани ја страницата од набљудуваните на тековниот корисник.",
"apihelp-delete-param-oldimage": "Името на страта слика за бришење според добиеното од [[Special:ApiHelp/query+imageinfo|action=query&prop=imageinfo&iiprop=archivename]].",
- "apihelp-delete-example-simple": "Избриши ја Главната страница",
- "apihelp-delete-example-reason": "Избриши ја Главната страница со причината „Подготовка за преместување“",
+ "apihelp-delete-example-simple": "Избриши ја <kbd>Главна страница</kbd>.",
+ "apihelp-delete-example-reason": "Избриши ја <kbd>Главна страница</kbd> со причината <kbd>Подготовка за преместување</kbd>.",
"apihelp-disabled-description": "Модулот е деактивиран.",
"apihelp-edit-description": "Создај или уреди страници.",
- "apihelp-edit-param-title": "Наслов на страницата што сакате да ја уредите. Не може да се користи заедно со $1pageid.",
- "apihelp-edit-param-pageid": "Назнака на страницата што сакате да ја уредите. Не може да се користи заедно со $1title.",
- "apihelp-edit-param-section": "Број на поднасловот. 0 за првиот, „new“ за нов.",
+ "apihelp-edit-param-title": "Наслов на страницата што сакате да ја уредите. Не може да се користи заедно со <var>$1pageid</var>.",
+ "apihelp-edit-param-pageid": "Назнака на страницата што сакате да ја уредите. Не може да се користи заедно со <var>$1title</var>.",
+ "apihelp-edit-param-section": "Број на поднасловот. <kbd>0</kbd> за првиот, <kbd>new</kbd> за нов.",
"apihelp-edit-param-sectiontitle": "Назив на новиот поднаслов",
"apihelp-edit-param-text": "Содржина на страницата.",
"apihelp-edit-param-summary": "Опис на уредувањето. Ова е и назив на поднасловот кога не се зададени $1section=new и $1sectiontitle.",
"apihelp-edit-param-notminor": "Неситно уредување.",
"apihelp-edit-param-bot": "Означи го уредувањево како ботско.",
"apihelp-edit-param-basetimestamp": "Датум и време на преработката на базата, кои се користат за утврдување на спротиставености во уредувањето. Може да се добие преку [[Special:ApiHelp/query+revisions|action=query&prop=revisions&rvprop=timestamp]].",
- "apihelp-edit-param-starttimestamp": "Ð\94аÑ\82Ñ\83м и вÑ\80еме кога Ñ\81Ñ\82е го поÑ\87нале Ñ\83Ñ\80едÑ\83ваÑ\9aеÑ\82о, кои Ñ\81е коÑ\80иÑ\81Ñ\82аÑ\82 за Ñ\83Ñ\82вÑ\80дÑ\83ваÑ\9aе на Ñ\81пÑ\80оÑ\82иÑ\81Ñ\82авеноÑ\81Ñ\82и во Ñ\83Ñ\80едÑ\83ваÑ\9aаÑ\82а. СоодвеÑ\82наÑ\82а вÑ\80едноÑ\81Ñ\82 Ñ\81е добива коÑ\80иÑ\81Ñ\82еÑ\98Ñ\9cи [[Special:ApiHelp/main|curtimestamp]] кога ќе почнете со уредување (на пр. кога ќе се вчита содржината што ќе ја уредувате).",
- "apihelp-edit-param-recreate": "Занемари ги грешките што се појавуваат во врска со статијата што е избришана во меѓувреме.",
+ "apihelp-edit-param-starttimestamp": "Ð\94аÑ\82Ñ\83м и вÑ\80еме кога Ñ\81Ñ\82е поÑ\87нало Ñ\83Ñ\80едÑ\83ваÑ\9aеÑ\82о, кои Ñ\81е коÑ\80иÑ\81Ñ\82аÑ\82 за Ñ\83Ñ\82вÑ\80дÑ\83ваÑ\9aе на Ñ\81пÑ\80оÑ\82иÑ\81Ñ\82авеноÑ\81Ñ\82и во Ñ\83Ñ\80едÑ\83ваÑ\9aаÑ\82а. СоодвеÑ\82наÑ\82а вÑ\80едноÑ\81Ñ\82 Ñ\81е добива коÑ\80иÑ\81Ñ\82еÑ\98Ñ\9cи <var>[[Special:ApiHelp/main|curtimestamp]]</var> кога ќе почнете со уредување (на пр. кога ќе се вчита содржината што ќе ја уредувате).",
+ "apihelp-edit-param-recreate": "Занемари ги грешките што се појавуваат во врска со страницата што е избришана во меѓувреме.",
"apihelp-edit-param-createonly": "Не ја уредувај страницата ако веќе постои.",
"apihelp-edit-param-nocreate": "Дај грешка ако страницата не постои.",
- "apihelp-edit-param-watch": "Додај ја страницата во набљудуваните.",
- "apihelp-edit-param-unwatch": "Отстрани ја страницата од набљудуваните.",
- "apihelp-edit-param-watchlist": "Безусловно додај или отстрани ја страницата од набљудуваните, користете ги нагодувањата или не ги менувајте набљудуваните.",
+ "apihelp-edit-param-watch": "Додај ја страницата во набљудуваните на тековниот корисник.",
+ "apihelp-edit-param-unwatch": "Отстрани ја страницата од набљудуваните на тековниот корисник.",
+ "apihelp-edit-param-watchlist": "Безусловно додај или отстрани ја страницата од набљудуваните на тековниот корисник, користете ги нагодувањата или не ги менувајте набљудуваните.",
"apihelp-edit-param-md5": "MD5-тарабата на параметарот $1text, или параметрите $1prependtext и $1appendtext поврзани. Ако е зададено, уредувањето нема да се изврши без тарабата да биде исправна.",
"apihelp-edit-param-prependtext": "Ставете го текстов на почетокот од страницата. Го заменува $1text.",
"apihelp-edit-param-appendtext": "Ставете го текстов на крајот од страницата. Го заменува $1text.\n\nКористете $1section=new наместо овој параметар за да приложите кон новиот поднаслов.",
"apihelp-emailuser-param-subject": "Наслов.",
"apihelp-emailuser-param-text": "Содржина.",
"apihelp-emailuser-param-ccme": "Прати ми примерок и мене.",
- "apihelp-emailuser-example-email": "Испрати е-пошта на корисникот „WikiSysop“ со текстот „Содржина“",
+ "apihelp-emailuser-example-email": "Испрати е-пошта на корисникот <kbd>WikiSysop</kbd> со текстот <kbd>Содржина</kbd>.",
"apihelp-expandtemplates-description": "Ги проширува сите шаблони во викитекст.",
"apihelp-expandtemplates-param-title": "Наслов на страница.",
"apihelp-expandtemplates-param-text": "Викитекст за претворање.",
"apihelp-expandtemplates-param-revid": "Назнака на преработката, за <nowiki>{{REVISIONID}}</nowiki> и слични променливи.",
- "apihelp-expandtemplates-param-prop": "Кои информации треба да ги добиете:\n;wikitext:The expanded wikitext.\n;categories: Категориите присутно во вносот кои не се претставени во викитекстуалниот извод.\n;volatile: Дали изводот е месно врзан и не треба да се преупотребува на други места во страницата.\n;ttl: Максималното време по кое треба да се поништи меѓускладираниот резултат.\n;parsetree: XML-дрвото на расчленување за изводот.\nИмајте на ум дека ако не изберете никаква вредност, резултатот ќе го содржи викитекстот, но изводот ќе биде во застарен формат.",
+ "apihelp-expandtemplates-param-prop": "Кои информации треба да ги добиете:\n;wikitext:The expanded wikitext.\n;categories: Категориите присутно во вносот кои не се претставени во викитекстуалниот извод.\n;properties: Својства на страницата определени од проширени волшебни зборови во викитекстот.\n;volatile: Дали изводот е месно врзан и не треба да се преупотребува на други места во страницата.\n;ttl: Максималното време по кое треба да се поништи меѓускладираниот резултат.\n;parsetree: XML-дрвото на расчленување за изводот.\nИмајте на ум дека ако не изберете никаква вредност, резултатот ќе го содржи викитекстот, но изводот ќе биде во застарен формат.",
"apihelp-expandtemplates-param-includecomments": "Дали во изводот да се вклучени HTML-коментари.",
"apihelp-expandtemplates-param-generatexml": "Создај XML-дрво на расчленување (заменето со $1prop=parsetree).",
- "apihelp-expandtemplates-example-simple": "Прошири го викитекстот „<nowiki>{{Project:Sandbox}}</nowiki>“",
+ "apihelp-expandtemplates-example-simple": "Прошири го викитекстот <kbd><nowiki>{{Project:Sandbox}}</nowiki></kbd>.",
"apihelp-feedcontributions-description": "Дава канал со придонеси на корисник.",
"apihelp-feedcontributions-param-feedformat": "Формат на каналот.",
"apihelp-feedcontributions-param-user": "За кои корисници да се прикажуваат придонесите.",
"apihelp-feedcontributions-param-toponly": "Прикажувај само последни преработки.",
"apihelp-feedcontributions-param-newonly": "Прикажувај само новосоздадени страници",
"apihelp-feedcontributions-param-showsizediff": "Покажувај ја големинската разлика меѓу преработките.",
- "apihelp-feedcontributions-example-simple": "Покажувај придонеси на [[Корисник:Пример]]",
+ "apihelp-feedcontributions-example-simple": "Покажувај придонеси на <kbd>Пример</kbd>.",
"apihelp-feedrecentchanges-description": "Дава канал со скорешни промени.",
"apihelp-feedrecentchanges-param-feedformat": "Форматот на каналот.",
"apihelp-feedrecentchanges-param-namespace": "На кој именски простор да се ограничат резултатите.",
"apihelp-feedrecentchanges-param-hideanons": "Скриј ги промените направени од анонимни корисници.",
"apihelp-feedrecentchanges-param-hideliu": "Скриј ги промените направени од регистрирани корисници.",
"apihelp-feedrecentchanges-param-hidepatrolled": "Скриј ги испатролираните промени.",
- "apihelp-feedrecentchanges-param-hidemyself": "СкÑ\80иÑ\98 ги моиÑ\82е пÑ\80омени.",
+ "apihelp-feedrecentchanges-param-hidemyself": "СкÑ\80иÑ\98 ги пÑ\80омениÑ\82е на Ñ\82ековниоÑ\82 коÑ\80иÑ\81ник.",
"apihelp-feedrecentchanges-param-tagfilter": "Филтрирање по ознака.",
"apihelp-feedrecentchanges-param-target": "Прикажи само промени на страници што водат од оваа.",
"apihelp-feedrecentchanges-param-showlinkedto": "Наместо тоа, прикажи ги промените на страниците поврзани со избраната страница.",
"apihelp-filerevert-param-archivename": "Архивски назив на преработката што ја повраќате.",
"apihelp-filerevert-example-revert": "Врати ја <kbd>Wiki.png</kbd> на верзијата од <kbd>2011-03-05T15:27:40Z</kbd>",
"apihelp-help-description": "Прикажувај помош за укажаните модули.",
- "apihelp-help-param-modules": "Модули за приказ на помош за (вредности на параметрите action= и format=, или пак „main“). Може да се укажат подмодули со „+“.",
+ "apihelp-help-param-modules": "Модули за приказ на помош за (вредности на параметрите <var>action</var> и <var>format</var>, или пак <kbd>main</kbd>). Може да се укажат подмодули со <kbd>+</kbd>.",
"apihelp-help-param-submodules": "Прикажувај и помош за подмодули на именуваниот модул.",
"apihelp-help-param-recursivesubmodules": "Прикажувај и помош за подмодули рекурзивно.",
"apihelp-help-param-helpformat": "Формат на изводот на помошта.",
"apihelp-help-example-query": "Помош за два подмодула за барања",
"apihelp-imagerotate-description": "Сврти една или повеќе слики.",
"apihelp-imagerotate-param-rotation": "За колку степени да се сврти надесно.",
- "apihelp-imagerotate-example-simple": "Сврти ја [[:Податотека:Пример.png]] за 90 степени",
- "apihelp-imagerotate-example-generator": "Сврти ги сите слики во [[:Категорија:Некоја]] за 180 степени",
- "apihelp-import-description": "Увези страница од друго вики или XML-податотека.\n\nИмајте на ум дека POST на HTTP мора да се изведе како подигање на податотеката (т.е. користејќи повеќеделни податоци/податоци од образец) кога ја испраќате податотеката за параметарот „xml“.",
+ "apihelp-imagerotate-example-simple": "Сврти ја <kbd>Податотека:Пример.png</kbd> за <kbd>90</kbd> степени.",
+ "apihelp-imagerotate-example-generator": "Сврти ги сите слики во <kbd>Категорија:Некоја</kbd> за <kbd>180</kbd> степени.",
+ "apihelp-import-description": "Увези страница од друго вики или XML-податотека.\n\nИмајте на ум дека POST на HTTP мора да се изведе како подигање на податотеката (т.е. користејќи повеќеделни податоци/податоци од образец) кога ја испраќате податотеката за параметарот <var>xml</var>.",
"apihelp-import-param-summary": "Увези опис.",
"apihelp-import-param-xml": "Подигната XML-податотека.",
"apihelp-import-param-interwikisource": "За меѓујазични увози: од кое вики да се увезе.",
"apihelp-import-param-interwikipage": "За меѓујазични увози: страница за увоз.",
"apihelp-import-param-fullhistory": "За меѓујазични увози:: увези ја целата историја, а не само тековната верзија.",
"apihelp-import-param-templates": "За меѓујазични увози: увези ги и сите вклучени шаблони.",
- "apihelp-import-param-namespace": "Ð\97а меÑ\93Ñ\83Ñ\98азиÑ\87ни Ñ\83вози: Ñ\83вези во овоÑ\98 именÑ\81ки пÑ\80оÑ\81Ñ\82оÑ\80.",
- "apihelp-import-param-rootpage": "Увези како потстраница на страницава.",
+ "apihelp-import-param-namespace": "Увези во овоÑ\98 именÑ\81ки пÑ\80оÑ\81Ñ\82оÑ\80. Се намеÑ\82нÑ\83ва вÑ\80з паÑ\80амеÑ\82аÑ\80оÑ\82 <kbd>$1rootpage</kbd>.",
+ "apihelp-import-param-rootpage": "Увези како потстраница на страницава. Се занемарува ако е укажан параметарот <kbd>$1namespace</kbd>.",
"apihelp-import-example-import": "Увези [[meta:Help:Parserfunctions]] во именскиот простор 100 со целата историја.",
"apihelp-login-description": "Најавете се и добијте колачиња за заверка.\n\nВо случај кога ќе се најавите успешно, потребните колачиња ќе се придодадат кон заглавијата на HTTP-одѕивот. Во случај да не успеете да се најавите, понатамошните обиди може да се ограничат за да се ограничат нападите со автоматизирано погодување на лозинката.",
"apihelp-login-param-name": "Корисничко име.",
"apihelp-logout-description": "Одјави се и исчисти ги податоците на седницата.",
"apihelp-logout-example-logout": "Одјави го тековниот корисник",
"apihelp-move-description": "Премести страница.",
- "apihelp-move-param-from": "Ð\9dаÑ\81лов на Ñ\81Ñ\82Ñ\80аниÑ\86аÑ\82а Ñ\88Ñ\82о Ñ\81акаÑ\82е да Ñ\98а пÑ\80емеÑ\81Ñ\82иÑ\82е. Ð\9dе може да Ñ\81е коÑ\80иÑ\81Ñ\82и заедно Ñ\81о $1fromid.",
- "apihelp-move-param-fromid": "Ð\9dазнака на Ñ\81Ñ\82Ñ\80аниÑ\86аÑ\82а Ñ\88Ñ\82о Ñ\81акаÑ\82е да Ñ\98а пÑ\80емеÑ\81Ñ\82иÑ\82е. Ð\9dе може да Ñ\81е коÑ\80иÑ\81Ñ\82и заедно Ñ\81о $1from.",
- "apihelp-move-param-to": "Како сакате да гласи новиот наслов на страницата.",
- "apihelp-move-param-reason": "Ð\9fÑ\80иÑ\87ина за пÑ\80емеÑ\81Ñ\82увањето.",
- "apihelp-move-param-movetalk": "Ð\9fÑ\80емеÑ\81Ñ\82и ја и страницата за разговор, ако ја има.",
- "apihelp-move-param-movesubpages": "Ð\9fÑ\80емеÑ\81Ñ\82и поÑ\82Ñ\81Ñ\82Ñ\80аниÑ\86и, ако има",
+ "apihelp-move-param-from": "Ð\9dаÑ\81лов на Ñ\81Ñ\82Ñ\80аниÑ\86аÑ\82а Ñ\88Ñ\82о Ñ\82Ñ\80еба да Ñ\81е пÑ\80емеÑ\81Ñ\82и. Ð\9dе може да Ñ\81е коÑ\80иÑ\81Ñ\82и заедно Ñ\81о <var>$1fromid</var>.",
+ "apihelp-move-param-fromid": "Ð\9dазнака на Ñ\81Ñ\82Ñ\80аниÑ\86аÑ\82а Ñ\88Ñ\82о Ñ\82Ñ\80еба да Ñ\81е пÑ\80емеÑ\81Ñ\82и. Ð\9dе може да Ñ\81е коÑ\80иÑ\81Ñ\82и заедно Ñ\81о <var>$1from</var>.",
+ "apihelp-move-param-to": "Како да гласи новата страница.",
+ "apihelp-move-param-reason": "Ð\9fÑ\80иÑ\87ина за пÑ\80еименувањето.",
+ "apihelp-move-param-movetalk": "Ð\9fÑ\80еименÑ\83ваÑ\98 ја и страницата за разговор, ако ја има.",
+ "apihelp-move-param-movesubpages": "Ð\9fÑ\80еименÑ\83ваÑ\98 поÑ\82Ñ\81Ñ\82Ñ\80аниÑ\86и, ако има.",
"apihelp-move-param-noredirect": "Не прави пренасочување.",
- "apihelp-move-param-watch": "Додај ги страницата и пренасочувањето во набљудуваните.",
- "apihelp-move-param-unwatch": "Отстрани ги страницата и пренасочувањето од набљудуваните.",
- "apihelp-move-param-watchlist": "Безусловно додај или отстрани ја страницата од набљудуваните, користете ги нагодувањата или не ги менувајте набљудуваните.",
+ "apihelp-move-param-watch": "Додај ги страницата и пренасочувањето во набљудуваните на тековниот корисник.",
+ "apihelp-move-param-unwatch": "Отстрани ги страницата и пренасочувањето од набљудуваните на тековниот корисник.",
+ "apihelp-move-param-watchlist": "Безусловно додај или отстрани ја страницата од набљудуваните на тековниот корисник, користете ги нагодувањата или не ги менувајте набљудуваните.",
"apihelp-move-param-ignorewarnings": "Занемари предупредувања.",
- "apihelp-move-example-move": "Премести го „Лош наслов“ на „Добар наслов“, неоставајќи пренасочување",
+ "apihelp-move-example-move": "Премести го <kbd>Лош наслов</kbd> на <kbd>Добар наслов</kbd>, неоставајќи пренасочување",
"apihelp-opensearch-description": "Пребарување на викито со протоколот OpenSearch.",
"apihelp-opensearch-param-search": "Низа за пребарување.",
"apihelp-opensearch-param-limit": "Максималниот број на резултати за прикажување.",
"apihelp-opensearch-param-namespace": "Именски простори за пребарување.",
- "apihelp-opensearch-param-suggest": "Не прави ништо ако [https://www.mediawiki.org/wiki/Manual:$wgEnableOpenSearchSuggest $wgEnableOpenSearchSuggest] е неточно.",
+ "apihelp-opensearch-param-suggest": "Не прави ништо ако <var>[[mw:Manual:$wgEnableOpenSearchSuggest|$wgEnableOpenSearchSuggest]]</var> е неточно.",
"apihelp-opensearch-param-redirects": "Како да се работи со пренасочувања:\n;return: Дај го самото пренасочување.\n;resolve: Дај ја целната страница. Може да даде помалку од $1limit резултати.\nОд историски причини, по основно е „return“ за $1format=json и „resolve“ за други формати.",
"apihelp-opensearch-param-format": "Формат на изводот.",
- "apihelp-opensearch-example-te": "Најди страници што почнуваат со „Те“",
+ "apihelp-opensearch-example-te": "Најди страници што почнуваат со <kbd>Те</kbd>.",
"apihelp-options-description": "Смени ги нагодувањата на тековниот корисник.\n\nМожат да се зададат само можностите заведени во јадрото или во едно од воспоставените додатоци, или пак можности со клуч кој ја има претставката „userjs-“ (предвиден за употреба од кориснички скрипти).",
"apihelp-options-param-reset": "Ги враќа поставките по основно.",
- "apihelp-options-param-resetkinds": "Писок на типови можности за повраток кога е зададена можноста „$1reset“.",
+ "apihelp-options-param-resetkinds": "Писок на типови можности за повраток кога е зададена можноста <var>$1reset</var>.",
"apihelp-options-param-change": "Список на промени во форматот name=value (на пр. skin=vector). Вредностите не треба да содржат исправени црти. Ако не зададете вредност (дури ни знак за равенство), на пр., можност|другаможност|..., ќе биде зададена вредноста на можноста по основно.",
- "apihelp-options-param-optionname": "Назив на можноста што треба да ѝ се зададе на вредноста дадена од „$1optionvalue“.",
- "apihelp-options-param-optionvalue": "Вредноста на можноста укажана од „$1optionnam“. Може да содржи исправени црти.",
+ "apihelp-options-param-optionname": "Назив на можноста што треба да ѝ се зададе на вредноста дадена од <var>$1optionvalue</var>.",
+ "apihelp-options-param-optionvalue": "Вредноста на можноста укажана од <var>$1optionname</var>. Може да содржи исправени црти.",
"apihelp-options-example-reset": "Врати ги сите поставки по основно",
- "apihelp-options-example-change": "Смени ги поставките „skinЗ“ и „hideminor“",
- "apihelp-options-example-complex": "Врати ги сите нагодувања по основно, а потоа задај ги „skin“ и „nickname“",
+ "apihelp-options-example-change": "Смени ги поставките <kbd>skin</kbd и <kbd>hideminor</kbd>.",
+ "apihelp-options-example-complex": "Врати ги сите нагодувања по основно, а потоа задај ги <kbd>skin</kbd> и <kbd>nickname</kbd>.",
"apihelp-paraminfo-description": "Набави информации за извршнички (API) модули.",
- "apihelp-paraminfo-param-modules": "Список на називи на модули (вредности на параметрите action= и format=, или пак „main“). Може да се укажат подмодули со „+“.",
+ "apihelp-paraminfo-param-modules": "Список на називи на модули (вредности на параметрите <var>action</var> и <var>format</var>, или пак <kbd>main</kbd>). Може да се укажат подмодули со <kbd>+</kbd>.",
"apihelp-paraminfo-param-helpformat": "Формат на помошните низи.",
- "apihelp-paraminfo-param-querymodules": "Список на називи на модули за барања (вредност на параметарот prop=, meta= или list=). Користете го „$1modules=query+foo“ наместо „$1querymodules=foo“.",
- "apihelp-paraminfo-param-mainmodule": "Добави информации и за главниот (врховен) модул. Користете го „$1modules=main“ наместо тоа.",
+ "apihelp-paraminfo-param-querymodules": "Список на називи на модули за барања (вредност на параметарот <var>prop</var>, <var>meta</var> или <var>list</var>). Користете го <kbd>$1modules=query+foo</kbd> наместо <kbd>$1querymodules=foo</kbd>.",
+ "apihelp-paraminfo-param-mainmodule": "Добави информации и за главниот (врховен) модул. Користете го <kbd>$1modules=main</kbd> наместо тоа.",
"apihelp-paraminfo-param-pagesetmodule": "Дај ги сите информации и за модулот на збирот страници (укажувајќи titles= и сродни).",
- "apihelp-paraminfo-param-formatmodules": "Список на називи на форматни модули (вредностза параметарот format=). Наместо тоа, користете го „$1modules“.",
+ "apihelp-paraminfo-param-formatmodules": "Список на називи на форматни модули (вредностза параметарот <var>format</var>). Наместо тоа, користете го <var>$1modules</var>.",
"apihelp-parse-param-summary": "Опис за расчленување.",
"apihelp-parse-param-preview": "Расчлени во прегледен режим.",
"apihelp-parse-param-sectionpreview": "Расчлени во прегледен режим на поднасловот (го овозможува и прегледниот режим).",
"apihelp-protect-param-reason": "Причиина за (од)заштитување",
"apihelp-protect-example-protect": "Заштити страница",
"apihelp-purge-param-forcelinkupdate": "Поднови ги табелите со врски.",
- "apihelp-purge-example-simple": "Превчитај ги „Главна страница“ и „Извршник“",
+ "apihelp-purge-example-simple": "Превчитај ги <kbd>Главна страница</kbd> и <kbd>Извршник</kbd>.",
"apihelp-query-param-list": "Кои списоци да се набават.",
"apihelp-query-param-meta": "Кои метаподатоци да се набават.",
"apihelp-query+allcategories-description": "Наброј ги сите категории.",
"apihelp-query+allcategories-param-dir": "Насока на подредувањето.",
"apihelp-query+alldeletedrevisions-param-from": "Почни го исписот од овој наслов.",
"apihelp-query+alldeletedrevisions-param-to": "Запри го исписот на овој наслов.",
- "apihelp-query+alldeletedrevisions-example-user": "СпиÑ\81ок на поÑ\81ледниÑ\82е 50 избÑ\80иÑ\88ани пÑ\80идонеÑ\81и на Ð\9aоÑ\80иÑ\81ник:Ð\9fÑ\80имеÑ\80",
- "apihelp-query+alldeletedrevisions-example-ns-main": "Список на последните 50 избришани преработки во главниот именски простор",
- "apihelp-query+allimages-example-B": "Прикажи список на податотеки што почнуваат со буквата „Б“",
+ "apihelp-query+alldeletedrevisions-example-user": "СпиÑ\81ок на поÑ\81ледниÑ\82е 50 избÑ\80иÑ\88ани пÑ\80идонеÑ\81и на коÑ\80иÑ\81никоÑ\82 <kbd>Ð\9fÑ\80имеÑ\80<kbd>.",
+ "apihelp-query+alldeletedrevisions-example-ns-main": "Список на последните 50 избришани преработки во главниот именски простор.",
+ "apihelp-query+allimages-example-B": "Прикажи список на податотеки што почнуваат со буквата <kbd>Б</kbd>.",
"apihelp-query+allimages-example-recent": "Прикажи список на неодамна подигнати податотеки сличен на [[Special:NewFiles]]",
- "apihelp-query+allimages-example-generator": "Прикажи информации за околу 4 податотеки што почнуваат со буквата „Т“",
+ "apihelp-query+allimages-example-generator": "Прикажи информации за околу 4 податотеки што почнуваат со буквата <kbd>Т</kbd>.",
"apihelp-query+alllinks-description": "Наброј ги сите врски што водат кон даден именски простор.",
"apihelp-query+alllinks-param-from": "Наслов на врската од која ќе почне набројувањето.",
"apihelp-query+alllinks-param-to": "Наслов на врската на која ќе запре набројувањето.",
"apihelp-query+alllinks-param-prefix": "Пребарај ги сите сврзани наслови што почнуваат со оваа вредност.",
- "apihelp-query+alllinks-param-unique": "Прикажувај само различни поврзани наслови. Не може да се користи со $1prop=ids.\nКога се користи како создавач, дава целни страници наместо изворни.",
+ "apihelp-query+alllinks-param-unique": "Прикажувај само различни поврзани наслови. Не може да се користи со <kbd>$1prop=ids</kbd>.\nКога се користи како создавач, дава целни страници наместо изворни.",
+ "apihelp-query+alllinks-param-prop": "Кои информации да се вклучат:\n;ids:Ја додава назнаката на страницата на која е врската (не може да се користи со <var>$1unique</var>).\n;title:Го додава насловот на врската.",
"apihelp-query+alllinks-param-namespace": "Именскиот простор што се набројува.",
"apihelp-query+alllinks-param-limit": "Колку вкупно ставки да се дадат.",
"apihelp-query+alllinks-param-dir": "Насока на исписот.",
- "apihelp-query+alllinks-example-B": "Списока на наслови со врски, вклучувајќи ги отсутните, со назнаки на нивните страници, почнувајќи од Б",
+ "apihelp-query+alllinks-example-B": "Списока на наслови со врски, вклучувајќи ги отсутните, со назнаки на нивните страници, почнувајќи од <kbd>Б</kbd>.",
"apihelp-query+alllinks-example-unique": "Испиши единствени наслови со врски",
"apihelp-query+alllinks-example-unique-generator": "Ги дава сите наслови со врски, означувајќи ги отсутните",
"apihelp-query+alllinks-example-generator": "Дава страници што ги содржат врските",
"apihelp-query+allmessages-param-to": "Дај пораки што завршуваат со оваа порака.",
"apihelp-query+allmessages-param-title": "Назив на страницата што ќе се користи во контекст кога се расчленува порака (за можноста $1enableparser).",
"apihelp-query+allmessages-param-prefix": "Дај пораки со оваа претставка.",
- "apihelp-query+allmessages-example-ipb": "Прикажи ги пораките што започнуваат со „ipb-“",
- "apihelp-query+allmessages-example-de": "Прикажи ги пораките „август“ и „главна страница“ на германски",
+ "apihelp-query+allmessages-example-ipb": "Прикажи ги пораките што започнуваат со <kbd>ipb-</kbd>.",
+ "apihelp-query+allmessages-example-de": "Прикажи ги пораките <kbd>august</kbd> and <kbd>mainpage</kbd> на германски.",
"apihelp-query+allpages-description": "Наброј ги сите страници последователно во даден именски простор.",
"apihelp-query+allpages-param-from": "Наслов на страницата од која ќе почне набројувањето.",
"apihelp-query+allpages-param-to": "Наслов на страницата на која ќе запре набројувањето.",
"apihelp-block-param-nocreate": "Zapobiegnij utworzeniu konta.",
"apihelp-block-param-watchuser": "Obserwuj stronę użytkownika i jego IP oraz ich strony dyskusji.",
"apihelp-block-example-ip-simple": "Zablokuj IP <kbd>192.0.2.5</kbd> na 3 dni za <kbd>Pierwszy atak</kbd>.",
+ "apihelp-block-example-user-complex": "Zablokuj użytkownika <kbd>Vandal</kbd> na zawsze za <kbd>Vandalism</kbd> i uniemożliwij utworzenie nowego konta oraz wysyłanie emaili.",
+ "apihelp-checktoken-param-type": "Typ tokenu do przetestowania.",
"apihelp-checktoken-param-token": "Token do przetestowania.",
+ "apihelp-checktoken-param-maxtokenage": "Maksymalny wiek tokenu, w sekundach.",
"apihelp-compare-param-totitle": "Drugi tytuł do porównania.",
"apihelp-compare-param-toid": "Numer drugiej strony do porównania.",
"apihelp-createaccount-description": "Utwórz nowe konto.",
"apihelp-createaccount-param-name": "Nazwa użytkownika",
+ "apihelp-createaccount-param-token": "Token tworzenia konta uzyskany w pierwszym zapytaniu.",
"apihelp-createaccount-param-email": "Adres email użytkownika (opcjonalne).",
"apihelp-createaccount-param-realname": "Prawdziwe imię i nazwisko użytkownika (opcjonalne).",
"apihelp-createaccount-param-reason": "Opcjionalny powód tworzenia konta (aby został umieszczony w logu).",
"apihelp-emailuser-description": "Wyślij e‐mail do użytkownika.",
"apihelp-emailuser-param-text": "Treść emaila.",
"apihelp-expandtemplates-param-title": "Tytuł strony.",
+ "apihelp-expandtemplates-param-text": "Wikitext do przekonwertowania.",
+ "apihelp-feedrecentchanges-param-hideminor": "Ukryj drobne zmiany.",
+ "apihelp-feedrecentchanges-param-hidebots": "Ukryj zmiany zrobione przez boty.",
+ "apihelp-feedrecentchanges-param-hideanons": "Ukryj zmiany zrobione przez anonimowych użytkowników.",
+ "apihelp-feedrecentchanges-param-hideliu": "Ukryj zmiany zrobione przez zarejestrowanych użytkowników.",
+ "apihelp-feedrecentchanges-param-hidepatrolled": "Ukryj sprawdzone zmiany.",
+ "apihelp-feedrecentchanges-param-hidemyself": "Ukryj zmiany zrobione przez obecnego użytkownika.",
+ "apihelp-feedrecentchanges-param-tagfilter": "Filtruj po tagach.",
"apihelp-feedrecentchanges-example-simple": "Pokaż ostatnie zmiany.",
+ "apihelp-filerevert-param-comment": "Prześlij komentarz.",
"apihelp-help-description": "Wyświetl pomoc dla określonych modułów.",
"apihelp-help-param-modules": "Moduły do wyświetlenia pomocy dla (wartości <var>action</var> i <var>format</var> parametry, lub <kbd>main</kbd>). Może określić podmoduły z <kbd>+</kbd>.",
"apihelp-help-param-recursivesubmodules": "Zawiera pomoc dla podmodułów rekursywnie.",
"apihelp-help-example-main": "Pomoc dla modułu głównego",
"apihelp-help-example-recursive": "Cała pomoc na jednej stronie.",
"apihelp-help-example-help": "Pomoc dla modułu pomocy",
+ "apihelp-imagerotate-description": "Obróć jeden lub wiecej obrazków.",
"apihelp-login-param-name": "Nazwa użytkownika.",
"apihelp-login-param-password": "Hasło.",
+ "apihelp-login-param-domain": "Domena (opcjonalnie).",
+ "apihelp-login-param-token": "Token logowania zdobyty w pierwszym zapytaniu.",
+ "apihelp-login-example-gettoken": "Zdobądź token logowania.",
"apihelp-login-example-login": "Zaloguj się",
+ "apihelp-logout-description": "Wyloguj i wyczyść dane sesji.",
+ "apihelp-logout-example-logout": "Wyloguj obecnego użytkownika.",
"apihelp-managetags-param-ignorewarnings": "Czy zignorować ostrzeżenia, które pojawiają się w trakcie operacji.",
"apihelp-move-description": "Przenieś stronę.",
"apihelp-move-param-reason": "Powód zmiany nazwy.",
+ "apihelp-move-param-noredirect": "Nie twórz przekierowania.",
"apihelp-move-param-ignorewarnings": "Ignoruj wszystkie ostrzeżenia.",
+ "apihelp-opensearch-param-search": "Wyszukaj tekst.",
+ "apihelp-opensearch-param-limit": "Maksymalna liczba zwracanych wyników.",
+ "apihelp-opensearch-param-namespace": "Przestrzenie nazw do przeszukania.",
+ "apihelp-options-example-reset": "Resetuj wszystkie preferencje.",
+ "apihelp-paraminfo-description": "Zdobądź informacje o modułach API.",
+ "apihelp-patrol-description": "Sprawdź stronę lub edycję.",
+ "apihelp-patrol-param-revid": "Numer edycji do sprawdzenia.",
+ "apihelp-patrol-example-rcid": "Sprawdź ostatnią zmianę.",
+ "apihelp-patrol-example-revid": "Sprawdź edycje.",
+ "apihelp-protect-param-reason": "Powód zabezpieczania/odbezpieczania.",
+ "apihelp-protect-param-cascade": "Włacz ochronę kaskadową (chronione są wszystkie strony zawarte w tej stronie). Ignorowane jeśli wszystkie poziomy ochrony nie wspierają kaskadowania.",
"apihelp-protect-example-protect": "Zabezpiecz stronę",
"apihelp-query+allpages-example-B": "Pokaż listę stron rozpoczynających się na literę <kbd>B</kbd>.",
"apihelp-query+filearchive-example-simple": "Pokaż listę wszystkich usuniętych plików.",
"apihelp-opensearch-param-limit": "回傳的結果數量上限。",
"apihelp-opensearch-param-namespace": "搜尋的命名空間。",
"apihelp-opensearch-param-format": "輸出的格式。",
+ "apihelp-options-param-reset": "重設偏好設定為網站預設值。",
"apihelp-options-example-reset": "重設所有偏好設定",
+ "apihelp-parse-example-page": "解析一個頁面。",
+ "apihelp-parse-example-text": "解析 wikitext。",
+ "apihelp-parse-example-texttitle": "解析 wikitext,指定頁面標題。",
+ "apihelp-parse-example-summary": "解析一個摘要。",
+ "apihelp-patrol-description": "巡查一個頁面或修訂。",
+ "apihelp-patrol-param-rcid": "要巡查的近期變更 ID。",
+ "apihelp-patrol-param-revid": "要巡查的修訂 ID。",
+ "apihelp-patrol-example-rcid": "巡查一個近期變更。",
+ "apihelp-patrol-example-revid": "巡查一個修訂。",
+ "apihelp-protect-description": "變更頁面的保護層級。",
+ "apihelp-protect-param-title": "要(解除)保護頁面的標題。 不能與 $1pageid 一起使用。",
+ "apihelp-protect-param-pageid": "要(解除)保護頁面的 ID。 不能與 $1title 一起使用。",
+ "apihelp-protect-param-protections": "保護層級清單,格式為 <kbd>action=level</kbd> (例如 <kbd>edit=sysop</kbd>)。\n\n<strong>注意:</strong> 任何未列入清單項目的限制將會被移除。",
+ "apihelp-protect-param-expiry": "期限時間戳記,若只設定一個時間戳記,該時間戳記將會套用至所有的保護層級。 使用 <kbd>infinite</kbd>、<kbd>indefinite</kbd>、<kbd>infinity</kbd> 或 <kbd>never</kbd> 來設定保護層級期限為永遠。",
+ "apihelp-protect-param-reason": "(解除)保護的原因。",
"apihelp-query+allcategories-param-limit": "要回傳的分類數量。",
"apihelp-query+allfileusages-param-limit": "要回傳的項目總數。",
"apihelp-query+allimages-param-limit": "要回傳的圖片總數。",
if ( $rev_id ) {
$rev = Revision::newFromId( $rev_id );
if ( $rev ) {
- $title = $rev->getTitle();
$logEntry->setTarget( $rev->getTitle() );
}
} elseif ( $log_id ) {
* @param User $user Who to attribute the action to
* @param int $tagCount For deletion only, how many usages the tag had before
* it was deleted.
+ * @return int ID of the inserted log entry
* @since 1.25
*/
protected static function logTagManagementAction( $action, $tag, $reason,
*/
class BadTitleError extends ErrorPageError {
/**
- * @param string|Message $msg A message key (default: 'badtitletext')
+ * @param string|Message|MalformedTitleException $msg A message key (default: 'badtitletext'), or
+ * a MalformedTitleException to figure out things from
* @param array $params Parameter to wfMessage()
*/
public function __construct( $msg = 'badtitletext', $params = array() ) {
- parent::__construct( 'badtitle', $msg, $params );
+ if ( $msg instanceof MalformedTitleException ) {
+ $errorMessage = $msg->getErrorMessage();
+ if ( !$errorMessage ) {
+ parent::__construct( 'badtitle', 'badtitletext', array() );
+ } else {
+ $errorMessageParams = $msg->getErrorMessageParameters();
+ $titleText = $msg->getTitleText();
+ if ( $titleText ) {
+ $errorMessageParams[] = $titleText;
+ }
+ parent::__construct( 'badtitle', $errorMessage, $errorMessageParams );
+ }
+ } else {
+ parent::__construct( 'badtitle', $msg, $params );
+ }
}
/**
$wgOut->setStatusCode( 400 );
parent::report();
}
-
}
--- /dev/null
+<?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
+ * @author Aaron Schulz
+ * @ingroup JobQueue
+ */
+
+/**
+ * Job for updating user activity like "last viewed" timestamps
+ *
+ * @ingroup JobQueue
+ * @since 1.26
+ */
+class ActivityUpdateJob extends Job {
+ function __construct( $title, $params ) {
+ parent::__construct( 'activityUpdateJob', $title, $params );
+
+ if ( !isset( $params['type'] ) ) {
+ throw new InvalidArgumentException( "Missing 'type' parameter." );
+ }
+
+ $this->removeDuplicates = true;
+ }
+
+ public function run() {
+ if ( $this->params['type'] === 'updateWatchlistNotification' ) {
+ $this->updateWatchlistNotification();
+ } else {
+ throw new Exception( "Invalid 'type' parameter '{$this->params['type']}'." );
+ }
+
+ return true;
+ }
+
+ protected function updateWatchlistNotification() {
+ $casTimestamp = ( $this->params['notifTime'] !== null )
+ ? $this->params['notifTime']
+ : $this->params['curTime'];
+
+ $dbw = wfGetDB( DB_MASTER );
+ $dbw->update( 'watchlist',
+ array(
+ 'wl_notificationtimestamp' => $dbw->timestampOrNull( $this->params['notifTime'] )
+ ),
+ array(
+ 'wl_user' => $this->params['userid'],
+ 'wl_namespace' => $this->title->getNamespace(),
+ 'wl_title' => $this->title->getDBkey(),
+ // Add a "check and set" style comparison to handle conflicts.
+ // The inequality always avoids updates when the current value
+ // is already NULL per ANSI SQL. This is desired since NULL means
+ // that the user is "caught up" on edits already. When the field
+ // is non-NULL, make sure not to set it back in time or set it to
+ // NULL when newer revisions were in fact added to the page.
+ 'wl_notificationtimestamp < ' . $dbw->addQuotes( $dbw->timestamp( $casTimestamp ) )
+ ),
+ __METHOD__
+ );
+ }
+}
# Show error message
$oldid = $this->getOldID();
- if ( $oldid ) {
- $text = wfMessage( 'missing-revision', $oldid )->plain();
- } elseif ( $title->getNamespace() === NS_MEDIAWIKI ) {
- // Use the default message text
- $text = $title->getDefaultMessageText();
- } elseif ( $title->quickUserCan( 'create', $this->getContext()->getUser() )
- && $title->quickUserCan( 'edit', $this->getContext()->getUser() )
- ) {
- $message = $this->getContext()->getUser()->isLoggedIn() ? 'noarticletext' : 'noarticletextanon';
- $text = wfMessage( $message )->plain();
+ if ( !$oldid && $title->getNamespace() === NS_MEDIAWIKI ) {
+ $outputPage->addParserOutput( $this->getContentObject()->getParserOutput( $title ) );
} else {
- $text = wfMessage( 'noarticletext-nopermission' )->plain();
- }
- $text = "<div class='noarticletext'>\n$text\n</div>";
+ if ( $oldid ) {
+ $text = wfMessage( 'missing-revision', $oldid )->plain();
+ } elseif ( $title->quickUserCan( 'create', $this->getContext()->getUser() )
+ && $title->quickUserCan( 'edit', $this->getContext()->getUser() )
+ ) {
+ $message = $this->getContext()->getUser()->isLoggedIn() ? 'noarticletext' : 'noarticletextanon';
+ $text = wfMessage( $message )->plain();
+ } else {
+ $text = wfMessage( 'noarticletext-nopermission' )->plain();
+ }
- $outputPage->addWikiText( $text );
+ $outputPage->addWikiText( "<div class='noarticletext'>\n$text\n</div>" );
+ }
}
/**
$autoloadClasses = array();
foreach ( $queue as $path => $mtime ) {
$json = file_get_contents( $path );
+ if ( $json === false ) {
+ throw new Exception( "Unable to read $path, does it exist?" );
+ }
$info = json_decode( $json, /* $assoc = */ true );
if ( !is_array( $info ) ) {
throw new Exception( "$path is not a valid JSON file." );
<?php
/**
- * Representation of a page title within %MediaWiki.
- *
* 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
* http://www.gnu.org/copyleft/gpl.html
*
* @file
- * @license GPL 2+
- * @author Daniel Kinzler
*/
/**
* MalformedTitleException is thrown when a TitleParser is unable to parse a title string.
- *
- * @license GPL 2+
- * @author Daniel Kinzler
* @since 1.23
*/
class MalformedTitleException extends Exception {
+ private $titleText = null;
+ private $errorMessage = null;
+ private $errorMessageParameters = array();
+
+ /**
+ * @param string $errorMessage Localisation message describing the error (since MW 1.26)
+ * @param string $titleText The invalid title text (since MW 1.26)
+ * @param string[] $errorMessageParameters Additional parameters for the error message (since MW 1.26)
+ */
+ public function __construct( $errorMessage = null, $titleText = null, $errorMessageParameters = array() ) {
+ $this->errorMessage = $errorMessage;
+ $this->titleText = $titleText;
+ $this->errorMessageParameters = $errorMessageParameters;
+ }
+
+ /**
+ * @since 1.26
+ * @return string|null
+ */
+ public function getTitleText() {
+ return $this->titleText;
+ }
+
+ /**
+ * @since 1.26
+ * @return string|null
+ */
+ public function getErrorMessage() {
+ return $this->errorMessage;
+ }
+
+ /**
+ * @since 1.26
+ * @return string[]
+ */
+ public function getErrorMessageParameters() {
+ return $this->errorMessageParameters;
+ }
}
// Interwiki links are not supported by TitleValue
if ( $parts['interwiki'] !== '' ) {
- throw new MalformedTitleException( 'Title must not contain an interwiki prefix: ' . $text );
+ throw new MalformedTitleException( 'title-invalid-interwiki', $text );
}
// Relative fragment links are not supported by TitleValue
if ( $parts['dbkey'] === '' ) {
- throw new MalformedTitleException( 'Title must not be empty: ' . $text );
+ throw new MalformedTitleException( 'title-invalid-empty', $text );
}
return new TitleValue( $parts['namespace'], $parts['dbkey'], $parts['fragment'] );
if ( strpos( $dbkey, UtfNormal\Constants::UTF8_REPLACEMENT ) !== false ) {
# Contained illegal UTF-8 sequences or forbidden Unicode chars.
- throw new MalformedTitleException( 'Bad UTF-8 sequences found in title: ' . $text );
+ throw new MalformedTitleException( 'title-invalid-utf8', $text );
}
$parts['dbkey'] = $dbkey;
}
if ( $dbkey == '' ) {
- throw new MalformedTitleException( 'Empty title: ' . $text );
+ throw new MalformedTitleException( 'title-invalid-empty', $text );
}
# Namespace or interwiki prefix
if ( $ns == NS_TALK && preg_match( $prefixRegexp, $dbkey, $x ) ) {
if ( $this->language->getNsIndex( $x[1] ) ) {
# Disallow Talk:File:x type titles...
- throw new MalformedTitleException( 'Bad namespace prefix: ' . $text );
+ throw new MalformedTitleException( 'title-invalid-talk-namespace', $text );
} elseif ( Interwiki::isValidInterwiki( $x[1] ) ) {
//TODO: get rid of global state!
# Disallow Talk:Interwiki:x type titles...
- throw new MalformedTitleException( 'Interwiki prefix found in title: ' . $text );
+ throw new MalformedTitleException( 'title-invalid-talk-namespace', $text );
}
}
} elseif ( Interwiki::isValidInterwiki( $p ) ) {
# Reject illegal characters.
$rxTc = self::getTitleInvalidRegex();
- if ( preg_match( $rxTc, $dbkey ) ) {
- throw new MalformedTitleException( 'Illegal characters found in title: ' . $text );
+ $matches = array();
+ if ( preg_match( $rxTc, $dbkey, $matches ) ) {
+ throw new MalformedTitleException( 'title-invalid-characters', $text, array( $matches[0] ) );
}
# Pages with "/./" or "/../" appearing in the URLs will often be un-
substr( $dbkey, -3 ) == '/..'
)
) {
- throw new MalformedTitleException( 'Bad title: ' . $text );
+ throw new MalformedTitleException( 'title-invalid-relative', $text );
}
# Magic tilde sequences? Nu-uh!
if ( strpos( $dbkey, '~~~' ) !== false ) {
- throw new MalformedTitleException( 'Bad title: ' . $text );
+ throw new MalformedTitleException( 'title-invalid-magic-tilde', $text );
}
# Limit the size of titles to 255 bytes. This is typically the size of the
# underlying database field. We make an exception for special pages, which
# don't need to be stored in the database, and may edge over 255 bytes due
# to subpage syntax for long titles, e.g. [[Special:Block/Long name]]
- if (
- ( $parts['namespace'] != NS_SPECIAL && strlen( $dbkey ) > 255 )
- || strlen( $dbkey ) > 512
- ) {
- throw new MalformedTitleException( 'Title too long: ' . substr( $dbkey, 0, 255 ) . '...' );
+ $maxLength = ( $parts['namespace'] != NS_SPECIAL ) ? 255 : 512;
+ if ( strlen( $dbkey ) > $maxLength ) {
+ throw new MalformedTitleException( 'title-invalid-too-long', $text, array( $maxLength ) );
}
# Normally, all wiki links are forced to have an initial capital letter so [[foo]]
# self-links with a fragment identifier.
if ( $dbkey == '' && $parts['interwiki'] === '' ) {
if ( $parts['namespace'] != NS_MAIN ) {
- throw new MalformedTitleException( 'Empty title: ' . $text );
+ throw new MalformedTitleException( 'title-invalid-empty', $text );
}
}
// Any remaining initial :s are illegal.
if ( $dbkey !== '' && ':' == $dbkey[0] ) {
- throw new MalformedTitleException( 'Title must not start with a colon: ' . $text );
+ throw new MalformedTitleException( 'title-invalid-leading-colon', $text );
}
# Fill fields
'aa' => 'Qafár af', # Afar
'ab' => 'Аҧсшәа', # Abkhaz
'ace' => 'Acèh', # Aceh
- 'aeb' => 'تونسي/Tûnsi', # Tunisian Arabic (multiple scripts - defaults to Arabic)
+ 'aeb' => 'تونسي/Tûnsî', # Tunisian Arabic (multiple scripts - defaults to Arabic)
'aeb-arab' => 'تونسي', # Tunisian Arabic (Arabic Script)
- 'aeb-latn' => 'Tûnsi', # Tunisian Arabic (Latin Script)
+ 'aeb-latn' => 'Tûnsî', # Tunisian Arabic (Latin Script)
'af' => 'Afrikaans', # Afrikaans
'ak' => 'Akan', # Akan
'aln' => 'Gegë', # Gheg Albanian
'ast' => 'asturianu', # Asturian
'av' => 'авар', # Avar
'avk' => 'Kotava', # Kotava
+ 'awa' => 'अवधी', # Awadhi
'ay' => 'Aymar aru', # Aymara
'az' => 'azərbaycanca', # Azerbaijani
'azb' => 'تورکجه', # South Azerbaijani
'be-x-old' => "беларуская (тарашкевіца)\xE2\x80\x8E", # (be-tarask compat)
'bg' => 'български', # Bulgarian
'bgn' => 'بلوچی رخشانی', # Western Balochi
- 'bh' => 'भोजपुरी', # Bihari macro language. Falls back to Bhojpuri (bho)
'bho' => 'भोजपुरी', # Bhojpuri
'bi' => 'Bislama', # Bislama
'bjn' => 'Bahasa Banjar', # Banjarese
"tog-extendwatchlist": "Expandir a lista de seguimiento t'amostrar totz os cambeos, no nomás os más recients.",
"tog-usenewrc": "Zaguers cambeos con presentación amillorada (cal JavaScript)",
"tog-numberheadings": "Numerar automaticament os encabezaus",
- "tog-showtoolbar": "Amostrar a barra de ferramientas d'edición (cal JavaScript)",
- "tog-editondblclick": "Activar edición de pachinas fendo-ie doble click (cal JavaScript)",
- "tog-editsectiononrightclick": "Activar a edición de seccions punchando con o botón dreito d'o ratet <br /> en os títols de seccions (cal JavaScript)",
+ "tog-showtoolbar": "Amostrar a barra d'edición",
+ "tog-editondblclick": "Editar pachinas fendo-ie doble click",
+ "tog-editsectiononrightclick": "Activar a edición de seccions punchando con o botón dreito d'o ratet en os títols de seccions",
"tog-watchcreations": "Cosirar as pachinas que creye",
"tog-watchdefault": "Cosirar as pachinas que edite",
"tog-watchmoves": "Cosirar as pachinas que treslade",
"oct": "oct",
"nov": "nov",
"dec": "avi",
+ "january-date": "$1 de chinero",
+ "february-date": "$1 de febrero",
+ "march-date": "Marzo $1",
+ "april-date": "$1 de abril",
+ "may-date": "$1 de mayo",
+ "june-date": "$1 de chunio",
+ "july-date": "$1 de chulio",
+ "august-date": "$1 de agosto",
+ "september-date": "$1 de setiembre",
+ "october-date": "$1 de octubre",
+ "november-date": "$1 de noviembre",
+ "december-date": "$1 de aviento",
"pagecategories": "{{PLURAL:$1|Categoría|Categorías}}",
"category_header": "Articlos en a categoría \"$1\"",
"subcategories": "Subcategorías",
"newwindow": "(s'ubre en una nueva finestra)",
"cancel": "Cancelar",
"moredotdotdot": "Más...",
- "mypage": "A mía pachina",
+ "mypage": "Pachina",
"mytalk": "Pachina de discusión",
"anontalk": "Pachina de descusión d'ista IP",
"navigation": "Navego",
"disclaimers": "Alvertencias chenerals",
"disclaimerpage": "Project:Alvertencias chenerals",
"edithelp": "Aduya ta editar pachinas",
+ "helppage-top-gethelp": "Aduya",
"mainpage": "Portalada",
"mainpage-description": "Portalada",
"policy-url": "Project:Politicas y normas",
"hidetoc": "amagar",
"collapsible-collapse": "Replegar",
"collapsible-expand": "Ixamplar",
+ "confirmable-yes": "Si",
+ "confirmable-no": "No",
"thisisdeleted": "Quiere amostrar u restaurar $1?",
"viewdeleted": "Quiere amostrar $1?",
"restorelink": "{{PLURAL:$1|una edición borrata|$1 edicions borratas}}",
"nospecialpagetext": "<strong>A pachina especial que ha demandato no existe.</strong>\n\nPuede trobar una lista de pachinas especials en [[Special:SpecialPages|{{int:specialpages}}]].",
"error": "Error",
"databaseerror": "Error d'a base de datos",
+ "databaseerror-error": "Error: $1",
"laggedslavemode": "Pare cuenta: podrían faltar as zagueras edicions d'ista pachina.",
"readonly": "Base de datos bloqueyata",
"enterlockreason": "Esplique a causa d'o bloqueyo, incluyendo una estimación de quán se producirá o desbloqueyo",
"createaccountmail": "por correu electronico",
"createaccountreason": "Razón:",
"createacct-imgcaptcha-ph": "Escribe o texto d'alto",
+ "createacct-submit": "Creya a tuya cuenta",
+ "createacct-another-submit": "Creya unatra cuenta",
"createacct-benefit-body3": "{{PLURAL:$1|colaborador recient|colaboradors recients}}",
"badretype": "As claus que ha escrito no son iguals.",
"userexists": "O nombre d'usuario que ha escrito ya ye en uso.\nPor favor, trigue-ne uno de diferent.",
"loginlanguagelabel": "Idioma: $1",
"suspicious-userlogout": "S'ha denegau a suya demanda de zarrar a sesión ya que pareix que la ninvió un navegador defectuoso u bell proxy amagau.",
"pt-login": "Dentrar-ie",
+ "pt-createaccount": "Creyar cuenta",
"php-mail-error-unknown": "Error desconoixito en a función mail() de PHP",
"user-mail-no-addy": "Ha mirau de ninviar un mensache de correu sin una adreza de correu electronico.",
"changepassword": "Cambiar a clau",
"errorpagetitle": "خطا",
"returnto": "$1-ه قاییت.",
"tagline": "{{SITENAME}} سایتیندان",
- "help": "کؤمک",
+ "help": "یاردیم",
"search": "آختار",
"searchbutton": "آختار",
"go": "گئت",
"talkpage": "بۇ صحیفهنی دانیش",
"talkpagelinktext": "دانیشیق",
"specialpage": "اؤزل صفحه",
- "personaltools": "شخصی آراجلار",
+ "personaltools": "شخصی آراجلار",
"articlepage": "ایچریلی صحیفهیه باخ",
"talk": "دانیشیق",
- "views": "گؤرونوشلر",
- "toolbox": "آراجلار",
+ "views": "گؤرونوشلر",
+ "toolbox": "آراجلار",
"userpage": "ایستیفادهچی صحیفهسینه باخ",
"projectpage": "پروژه صحیفهسینه باخ",
"imagepage": "فایل صحیفهسینه باخ",
"pool-errorunknown": "بیلینمهین خطا",
"pool-servererror": "پول سنتر سئرویسی الده دئییل ( $1 ).",
"poolcounter-usage-error": "$1:ایشلتمک خطاسی",
- "aboutsite": "{{SITENAME}} گؤره",
+ "aboutsite": "{{SITENAME}}-ه گؤره",
"aboutpage": "Project:گؤره",
"copyright": "ایچیندهکیلر $1 لیسانسی احاطهسیندهدیلر.",
"copyrightpage": "{{ns:project}}:کوْپی حاقلاری",
- "currentevents": "ایندیکی اولایلار",
- "currentevents-url": "Project:ایندیکی اولایلار",
+ "currentevents": "ایندیکی اولایلار",
+ "currentevents-url": "Project:ایندیکی اولایلار",
"disclaimers": "یالانلامالار",
"disclaimerpage": "Project:گنل یالانلاما",
"edithelp": "ديَیشتیرمک یاردیمی",
"diff-multi-otherusers": "({{PLURAL:$1|۱ میانی نوسخه لر|$1 میانی نوسخه لر}} دَییک اولونموش {{PLURAL:$2|۱ ایشلدچی|$2 ایشلدچی}}طرفیندن گوستریلمیر)",
"diff-multi-manyusers": "{{PLURAL:$2|بیر|$2}}-دن چوخ ایستیفادهچی یارادان {{PLURAL:$1|بیر|$1}} نوسخه، گؤستریلمهییبدیر",
"difference-missing-revision": "بو فرقین ($1) {{PLURAL:$2|بیر|$2}} نوسخهسی تاپیلانمادی.\n\nعموماً بو خطا، سیلینن بیر صحیفهیه واختی گئچمیش بیر فرق باغلانتیسیلا گلمک ایله آرا گلر.\n[{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}}سیلمک سیاهیسی]ندا باشقا بیلگیلر اولا بیلر.",
- "searchresults": "آختاریش سونوجلاری",
- "searchresults-title": "«$1» اوچون آختاریش سونوجلاری",
+ "searchresults": "آختاریش سونوجلاری",
+ "searchresults-title": "«$1» اوچون آختاریش سونوجلاری",
"titlematches": "صحیفه آدی عینیدیر",
"textmatches": "یازی عینیدیر",
"notextmatches": "هئچ بیر بنزر صحیفه یازیسی تاپیلمادی",
"nchanges": "$1 {{PLURAL:$1|دَییشیکلیک}}",
"enhancedrc-since-last-visit": "$1 {{PLURAL:$1|سون گوروش دن}}",
"enhancedrc-history": "گئچمیش",
- "recentchanges": "سون دَییشیکلیکلر",
+ "recentchanges": "سون دَییشیکلیکلر",
"recentchanges-legend": "سون دَییشیکلیکلر سئچمهلری",
"recentchanges-summary": "بو صحیفهده، بو ویکیده وئریلن ان سون دَییشیکلیکلری ایزلهیین.",
"recentchanges-noresult": "وئریلمیش دؤنمده، بو معیارلارا تطبیق اولان دَییشدیرمه یوخدور.",
"rc-old-title": "ایلکجه «$1» آدیله یارانمیشدیر",
"recentchangeslinked": "ایلگیلی دَییشیکلیکلر",
"recentchangeslinked-feed": "ایلگیلی دَییشیکلیکلر",
- "recentchangeslinked-toolbox": "ایلگیلی دَییشیکلیکلر",
+ "recentchangeslinked-toolbox": "ایلگیلی دَییشیکلیکلر",
"recentchangeslinked-title": "''$1'' ایله ایلگیلی دییشیکلر",
"recentchangeslinked-summary": "آشاغیداکی سیياهی، قئيد اوْلونان صحیفهيه (و يا قئيد اوْلونان کاتئقوْرياداکی صحیفهلره) داخیلی کئچید وئرن صحیفهلرده ائدیلمیش سوْن ديَیشیکلیکلرین سیياهیسیدیر. \n[[Special:Watchlist|ایزلهمه سیياهینیزداکی]] صحیفهلر '''قالین''' شریفتله گؤستریلمیشدیر.",
"recentchangeslinked-page": "صفحه آدی:",
"listusers-desc": "آزالان سیرادا سیرالا",
"usereditcount": "$1 {{PLURAL:$1|دَییشدیرمه}}",
"usercreated": "$1 تاریخینده، ساعات $2-ده {{GENDER:$3|یارانیبدیر}}",
- "newpages": "يئنی صفحهلر",
+ "newpages": "يئنی صفحهلر",
"newpages-username": "ایستیفادهچی آدی:",
"ancientpages": "ان اسکی صحیفهلر",
"move": "آدینی دَییشدیر",
"invert": "سئچیلنی دؤندر",
"tooltip-invert": "بو قوتونی علامتله یین تا انتخاب اولان آد فضا سینین ایچری صحیفه لری دییشیک لیک لری(و اوبیری علامتلنمیش فضالار) گیزله نه آدی",
"tooltip-whatlinkshere-invert": "سئچیلمیش آدفضاسیندان اولان باغلانتیلاری گیزلتمک اوچون بو قوتویا نیشان قویون.",
- "namespace_association": "عÙ\84اÙ\82Ù\87â\80\8cÙ\84Û\8c آد ساØÙ\87â\80\8cسی",
+ "namespace_association": "اÛ\8cÙ\84Ú¯Û\8cÙ\84Û\8c آدÙ\81ضاسی",
"tooltip-namespace_association": "بو قوتونو علامت له ین یالنیز آد بحث فضاسی یا مرتبط اولان آد فضاسی ایله انتخاب اولا",
"blanknamespace": "(آنا)",
"contributions": "{{GENDER:$1|ایستیفادهچی}} چالیشمالاری",
"sp-contributions-toponly": "تکجه سون نوسخه اولان دییشیکلری گؤستر",
"sp-contributions-newonly": "یالنیز صفحه یاراتماق دَییشیکلیکلرینی گؤستر",
"sp-contributions-submit": "آختار",
- "whatlinkshere": "بو صفحهیه باغلانتیلار",
+ "whatlinkshere": "بو صفحهیه باغلانتیلار",
"whatlinkshere-title": "«$1»-ه باغلانان صحیفهلر",
"whatlinkshere-page": "صفحه:",
"linkshere": "آشاغیداکی صحیفهلر '''[[:$1]]'''-ه باغلانیب:",
"import-interwiki-history": "صحیفهنین دییشمه تاریخچهلرینین هامیسینی کؤچور",
"import-interwiki-templates": "بوتون شابلونلارلا بیرلیکده",
"import-interwiki-submit": "ایچری توکمه اولسون",
- "import-interwiki-namespace": "هدف آد ساحهسی:",
- "import-interwiki-rootpage": "هدفلنن قایناق صحیفهسی (ایستهیه باغلی):",
"import-upload-filename": "فایل آدی",
"import-comment": "آچیخلا:",
"importtext": "خاهیش ائدیریک فایلی [[Special:Export| خاریجه کؤچورمه کؤمک پروقرامییلا]] قایناق ویکی خاریجه کؤچورون.\nکومپوتئرینیزه یازین و بورا یوکلیین.",
"tooltip-pt-mycontris": "سیزین چالیشمالارینیزین لیستی",
"tooltip-pt-login": "گیریش ائتمهیینیز توصیه اولونور؛ اما گرکلی دئییل",
"tooltip-pt-logout": "چیخیش",
- "tooltip-pt-createaccount": "سیزدن دعوت اولونور ایشلدن حسابی آچیب و گیریش ائده سیز،آنجاق حساب یارتماق اختیاری دیر.",
+ "tooltip-pt-createaccount": "سیزدن دعوت اولونور ایشلدن حسابی آچیب و گیریش ائدهسیز؛ آنجاق حساب یاراتماق ایستگه باغلیدیر",
"tooltip-ca-talk": "ایچیندهکیلره گؤره دانیشیق",
"tooltip-ca-edit": "سیز بو صفحهنی دَییشدیره بیلرسینیز. لطفاً قئید ائتمهدن قاباق اؤنگؤستریش دوگمهسینی ایشلدین",
"tooltip-ca-addsection": "یئنی بؤلوم یارات",
"tooltip-ca-viewsource": "بو صحیفه قورونوبدور.\nاونون قایناغینا باخا بیلرسیز",
- "tooltip-ca-history": "بو صفحهنین گئچمیش سۆروملری",
+ "tooltip-ca-history": "بو صفحهنین گئچمیش سۆروملری",
"tooltip-ca-protect": "بو صحیفهنی قورو",
"tooltip-ca-unprotect": "بو صحیفهنین قوروماسینی دَییشدیر",
"tooltip-ca-delete": "بو صحیفهنی سیل",
"svg-long-error": "اعتبارسیز سوگ فایل: $1",
"show-big-image": "فایلین اصلی",
"show-big-image-preview": "سیناق گؤستریشی اؤلچوسو: $1.",
- "show-big-image-other": "دÛ\8cگر {{PLURAL:$2|Ù\86تÛ\8cج|Ù\86تÛ\8cجÙ\87â\80\8cلر}}: $1.",
+ "show-big-image-other": "Ø¢Û\8cرÛ\8c {{PLURAL:$2|Ú©Û\8cÙ\81Û\8cت|Ú©Û\8cÙ\81Û\8cتلر}}: $1.",
"show-big-image-size": "$1 × $2 پیکسئل",
"file-info-gif-looped": "ایلملنیب",
"file-info-gif-frames": "$1 {{PLURAL:$1|فرامئ|چرچیوه}}",
"tags-delete": "سیل",
"tags-hitcount": "$1 {{PLURAL:$1|دییشیکلیک|دییشیکلیک}}",
"tags-create-submit": "یارات",
+ "tags-edit-title": "اِتیکِتلری دَییشدیر",
+ "tags-edit-manage-link": "اِتیکِتلری ایداره ائت",
+ "tags-edit-revision-selected": "[[:$2]]-نین سئچیلمیش {{PLURAL:$1|نوسخهسی|نوسخهلری}}:",
+ "tags-edit-logentry-selected": "سئچیلمیش {{PLURAL:$1|قئید|قئیدلر}}:",
+ "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-new-tags": "یئتی اِتیکِتلر:",
+ "tags-edit-add": "بو اِتیکِتلری اکله:",
+ "tags-edit-remove": "بو اِتیکِتلری قالدیر:",
+ "tags-edit-remove-all-tags": "(بوتون اِتیکِتلری قالدیر)",
+ "tags-edit-chosen-placeholder": "بعضی اِتیکِتلری سئچ",
+ "tags-edit-chosen-no-results": "تای اولان اِتیکِت تاپیلمادی",
+ "tags-edit-reason": "ندن:",
+ "tags-edit-nooldid-title": "گئچرسیز هدف نوسخه",
"comparepages": "صحیفهلری قارشیلاشدیر",
"compare-page1": "صحیفه 1",
"compare-page2": "صحیفه 2",
"htmlform-chosen-placeholder": "بیر سئچمه سئچین",
"htmlform-cloner-create": "چوْخراق آرتیر",
"htmlform-cloner-delete": "سیل",
+ "htmlform-cloner-required": "ان آزی بیر دیَر گرکلیدیر.",
"sqlite-has-fts": "$1 بوتون یازی آختارما دستگیله",
"sqlite-no-fts": "$1 بوتون یازی آختارماماقلا",
"logentry-delete-delete": "$1، $3 صحیفهسینی {{GENDER:$2|سیلدی}}",
"revdelete-uname-unhid": "ایستیفادهچی آدی گیزلیلیکدن چیخدی",
"revdelete-restricted": "ایدارهچیلره محدودیت قویدو",
"revdelete-unrestricted": "ایدارهچیلرین محدودیتلرینی گؤتوردو",
+ "logentry-block-block": "$1 {{GENDER:$4|$3}}-نی {{GENDER:$2|بلوکلادی}}. قورتارماق تاریخی: $5 $6",
+ "logentry-block-unblock": "$1 {{GENDER:$4|$3}}-نین {{GENDER:$2|بلوکلاماغینی قالدیردی}}",
"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": "$1، $3 صحیفهسینین $4 نوسخهسینی، نظارتلنمیش {{GENDER:$2|نیشانلادی}}",
"logentry-patrol-patrol-auto": "$1، $3 صحیفهسینین $4 نوسخهسینی، اوتوماتیک اولاراق نظارتلنمیش {{GENDER:$2|نیشانلادی}}",
"logentry-newusers-newusers": " بیر ایستیفادهچی حسابی $1 {{GENDER:$2|یاراتدی}}",
- "logentry-newusers-create": "بیر ایشلدن حسابی $1 {{GENDER:$2|یاراتدی}}",
+ "logentry-newusers-create": "$1 ایشلدن حسابی {{GENDER:$2|یارادیلدی}}",
"logentry-newusers-create2": "$1 ایستیفادهچی، $3 حسابی {{GENDER:$2|یاراتدی}}",
"logentry-newusers-byemail": "$3 ایستیفادهچی حسابی، $1 ایله {{GENDER:$2|یارادیلیب}} و رمز، ایمیل ایله گؤندریلیبدیر",
"logentry-newusers-autocreate": "$1 ایستیفادهچی حسابی اوتوماتیک {{GENDER:$2|یارادیلدی}}",
"logentry-rights-autopromote": "$1-ین مقامی اوتوماتیک $4-دن $5-ه {{GENDER:$2|آرتیریلدی}}",
"logentry-upload-upload": "$1 $3 را {{GENDER:$2|یوکلندیردی}}",
"rightsnone": "(هئچ)",
+ "revdelete-summary": "دَییشدیرمه قیساسی",
"feedback-adding": "صحیفهیه گئری-بیلدیریم آرتیریلیر...",
+ "feedback-back": "دالی",
"feedback-bugcheck": "گؤزل! فقط لوطفاً باخین او [$1 تانینمیش خطالار]دان اولماسین.",
"feedback-bugnew": "یوخلادیم. یئنی بیر خطا گؤندر",
"feedback-bugornote": "بیر تکنیکی خطانی شرح وئرمگه آماده اولساز، لوطفاً [$1 بیر باگ بیلدیرین].\nاو اولماسا، بو آشاغیداکی ساده فورمدان ایستیفاده ائده بیلرسینیز. سیزین باخیشینیز، ایستیفادهچی آدینیزلا، «[$3 $2]» صحیفهسینه آرتیریلاجاقدیر.",
"feedback-cancel": "لغو ائت",
"feedback-close": "اولدو",
+ "feedback-error-title": "خطا",
"feedback-error1": "خطا: API-دان تانینمامیش نتیجه",
"feedback-error2": "خطا: دَییشدیرمه باشاریسیز اولدو",
"feedback-error3": "خطا: API-دان جاواب گلمهدی",
"feedback-subject": "قونو:",
"feedback-submit": "گؤندر",
"feedback-thanks": "تشکورلر! سیزین گئری-بیلدیریمینیز «[$2 $1]» صحیفهسینه گؤندریلدی.",
+ "feedback-thanks-title": "تشکورلر!",
"searchsuggest-search": "آختار",
"searchsuggest-containing": "ساخلانیلیر...",
"api-error-badaccess-groups": "سیزین بو ویکییه فایل یوکلهمک ایجازهنیز یوخدور.",
"mediastatistics-header-audio": "سس",
"mediastatistics-header-video": "ویدیولار",
"mediastatistics-header-office": "دفتر",
+ "headline-anchor-title": "بو بؤلومه باغلانتی",
"special-characters-group-latin": "لاتین",
"special-characters-group-latinextended": "لاتین گئنیشلندیریلمیش",
"special-characters-group-ipa": "IPA",
"import-interwiki-submit": "Імпартаваць",
"import-mapping-default": "Імпарт у месца па змоўчаньні",
"import-mapping-namespace": "Імпарт у прастору назваў:",
+ "import-mapping-subpage": "Імпарт у якасьці падстаронак наступнай старонкі:",
"import-upload-filename": "Назва файла:",
"import-comment": "Камэнтар:",
"importtext": "Калі ласка, экспартуйце файл з крынічнай вікі з дапамогай [[Special:Export|прылады экспарту]].\nЗахавайце яго на свой кампутар, а потым загрузіце сюды.",
"pageinfo-protect-cascading-yes": "Так",
"pageinfo-protect-cascading-from": "Каскадная абароная пачынаецца з",
"pageinfo-category-info": "Інфармацыя пра катэгорыю",
+ "pageinfo-category-total": "Агульная колькасьць чальцоў",
"pageinfo-category-pages": "Колькасьць старонак",
"pageinfo-category-subcats": "Колькасьць падкатэгорыяў",
"pageinfo-category-files": "Колькасьць файлаў",
"notloggedin": "Не ўвайшоў",
"userlogin-noaccount": "Не маеце ўліковага запісу?",
"userlogin-joinproject": "Далучайцеся да {{GRAMMAR:родны|{{SITENAME}}}}",
- "nologin": "Не маеце рахунку? $1.",
+ "nologin": "Не маеце рахунка? $1.",
"nologinlink": "Завесці рахунак",
"createaccount": "Стварыць рахунак",
"gotaccount": "Ужо маеце рахунак? '''$1'''.",
"accountcreated": "Створаны рахунак",
"accountcreatedtext": "Створаны ўліковы запіс удзельніка [[{{ns:User}}:$1|$1]] ([[{{ns:User talk}}:$1|размовы]]).",
"createaccount-title": "Стварэнне рахунка на {{SITENAME}}",
- "createaccount-text": "На пляцоўцы {{SITENAME}} ($4) быў створаны рахунак удзельніка з гэтым адрасам эл.пошты. Назва рахунку \"$2\", пароль \"$3\". Варта адразу ўвайсці ў сістэму і змяніць пароль.\n\nКалі стварэнне рахунку было памылковым, то на гэтае паведамленне можна не звяртаць увагі.",
+ "createaccount-text": "На пляцоўцы {{SITENAME}} ($4) быў створаны рахунак удзельніка з гэтым адрасам эл.пошты. Назва рахунка \"$2\", пароль \"$3\". Варта адразу ўвайсці ў сістэму і змяніць пароль.\n\nКалі рахунак быў створаны памылкова, то на гэтае паведамленне можна не звяртаць увагі.",
"login-throttled": "Занадта многа нядаўніх спробаў увайсці пад гэтым уліковым запісам. \nПачакайце $1 перад тым, як спрабаваць ізноў.",
"login-abort-generic": "Няўдалая спроба ўвайсці ў сістэму",
"loginlanguagelabel": "Мова: $1",
"user-mail-no-body": "Спроба даслаць ліст эл.пошты з пустым або неабгрунтавана кароткім зместам.",
"changepassword": "Пароль",
"resetpass_announce": "Каб завяршыць уваход у сістэму, Вы павінны ўстанавіць новы пароль.",
- "resetpass_header": "Змяніць пароль рахунку",
+ "resetpass_header": "Змяніць пароль рахунка",
"oldpassword": "Стары пароль:",
"newpassword": "Новы пароль:",
"retypenew": "Новы пароль паўторна:",
"accmailtext": "На адрас $2 быў дасланы згенераваны пароль для [[User talk:$1|$1]]. Ён можа быць зменены на <em>[[Special:ChangePassword|старонцы змены пароля]]</em> пасля ўваходу ў сістэму.",
"newarticle": "(Новы)",
"newarticletext": "Вы перайшлі да старонкі, якой яшчэ няма, і таму трапілі сюды. \nКаб пачаць новую старонку, пішыце яе тэкст у ніжэйпаказаным акне рэдагавання (падрабязнасці бач у [$1 даведцы]). \nКалі вы тут выпадкова, проста націсніце <strong>назад</strong> у браўзеры.",
- "anontalkpagetext": "----''Гэта старонка размовы з ананімным удзельнікам, які або не мае свайго рахунку, або ім не карыстаўся. Таму дзеля яго ці яе ідэнтыфікацыі мы мусім выкарыстаць лічбавы Адрас IP. Такі адрас IP могуць дзяліць між сабою некалькі асоб. Калі вы ананімны ўдзельнік, і лічыце, што атрымліваеце няслушныя заўвагі,[[Special:UserLogin/signup|стварыце рахунак]] або [[Special:UserLogin|акажыцеся]], каб вас больш не блыталі з іншымі ананімнымі ўдзельнікамі.''",
+ "anontalkpagetext": "----''Гэта старонка размовы з ананімным удзельнікам, які або не мае свайго рахунка, або ім не карыстаўся. Таму дзеля яго ці яе ідэнтыфікацыі мы мусім выкарыстаць лічбавы IP-адрас. Такі адрас IP могуць дзяліць між сабою некалькі асоб. Калі вы ананімны ўдзельнік, і лічыце, што атрымліваеце няслушныя заўвагі,[[Special:UserLogin/signup|стварыце рахунак]] або [[Special:UserLogin|зайдзіце ў сістэму]], каб вас больш не блыталі з іншымі ананімнымі ўдзельнікамі.''",
"noarticletext": "Старонка не ўтрымлівае тэксту. Вы можаце [[Special:Search/{{PAGENAME}}|пашукаць гэткую назву]] ў іншых старонках ці <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}}|page={{FULLPAGENAMEE}}}} ў журналах]</span>, але вы не маеце дазволу на стварэнне гэтай старонкі.",
"missing-revision": "Няма версіі #$1 у старонкі з назвай \"{{FULLPAGENAME}}\".\n\nЗвычайна такое здараецца, калі прайсці па састарэлай спасылцы з гісторыі на старонку, якая была сцёрта.\nПадрабязнасці можна пабачыць у [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} журнале сціранняў].",
"expiringblock": "канчаецца $1 $2",
"anononlyblock": "толькі ананімы",
"noautoblockblock": "аўтаблок не дазволены",
- "createaccountblock": "стварэнне рахунку заблакавана",
+ "createaccountblock": "стварэнне рахунка заблакавана",
"emailblock": "эл.пошта заблакавана",
"blocklist-nousertalk": "не мае дазволу правіць уласную старонку размоў",
"ipblocklist-empty": "Спіс блокаў зараз пусты.",
"blocklogtext": "Журнал пастаноўкі і зняцця блокаў. Аўтаматычна блакаваныя адрасы IP тут не паказваюцца. Спіс актуальных забарон і блокаў бач у [[Special:BlockList|спісе блокаў]].",
"unblocklogentry": "зняты блок з $1",
"block-log-flags-anononly": "толькі ананімныя ўдзельнікі",
- "block-log-flags-nocreate": "стварэнне рахунку не дазволена",
+ "block-log-flags-nocreate": "стварэнне рахунка не дазволена",
"block-log-flags-noautoblock": "аўта-блок не дазволены",
"block-log-flags-noemail": "пастаўлены блок на эл.пошту",
"block-log-flags-nousertalk": "нельга правіць уласную размову",
"confirmemail_loggedin": "Зараз ваш адрас эл.пошты стаўся пацверджаным.",
"confirmemail_subject": "Пацверджанне адрасу эл.пошты для {{SITENAME}}",
"confirmemail_body": "Нехта (магчыма, што і вы — з адрасу IP $1) завёў рахунак \"$2\" на пляцоўцы {{SITENAME}}, паказваючы гэты адрас эл.пошты як свой.\n\nДзеля таго, каб пацвердзіць, што рахунак сапраўды ваш, і каб актываваць магчымасці эл.пошты для {{SITENAME}}, адкрыйце ў браўзеры гэтую спасылку:\n\n$3\n\nКалі гэта *былі не вы*, не адкрывайце той спасылкі, а адкрыйце гэтую, каб згасіць пацверджанне адрасу эл.пошты:\n\n$5\n\nГэты пацвярджальны код згасне $4.",
- "confirmemail_body_changed": "Нехта з IP-адрасу \"$1\" (магчыма, што Вы) змяніў адрас эл.пошты для рахунку \"$2\" на пляцоўцы {{SITENAME}}.\n\nКаб пацвердзіць, што рахунак сапраўды належыць вам, і каб ізноў уключыць працу з эл.поштай для рахунку на пляцоўцы {{SITENAME}}, адкрыйце гэтую спасылку ў браўзеры:\n\n$3\n\nКалі рахунак вам *не належыць*, адкрыйце ніжэй паказаную спасылку, каб адмовіцца ад пацверджання адрасу эл.пошты:\n\n$5\n\nГэты квіток на пацверджанне будзе дзейсны не далей за $4.",
+ "confirmemail_body_changed": "Нехта з IP-адраса \"$1\" (магчыма, што Вы) змяніў адрас эл.пошты для рахунка \"$2\" на пляцоўцы {{SITENAME}}.\n\nКаб пацвердзіць, што рахунак сапраўды належыць вам, і каб ізноў уключыць працу з эл.поштай для рахунка на пляцоўцы {{SITENAME}}, адкрыйце гэтую спасылку ў браўзеры:\n\n$3\n\nКалі рахунак вам *не належыць*, адкрыйце ніжэй паказаную спасылку, каб адмовіцца ад пацвярджэння адраса эл.пошты:\n\n$5\n\nГэты код пацвярджэння сапраўдны да $4.",
"confirmemail_body_set": "Нехта (магчыма, вы) з IP-адрасам $1\nпаказаў дадзены адрас электроннай пошты для ўліковага запісу «$2» у праекце {{SITENAME}}.\n\nКаб пацвердзіць, што акаўнт сапраўды належыць вам, і ўключыць магчымасць адпраўкі лістоў з сайта {{SITENAME}}, адкрыйце гэтую спасылку ў браўзеры:\n\n$3\n\nКалі рахунак вам *не належыць*, адкрыйце ніжэй паказаную спасылку, каб адмовіцца ад пацверджання адрасу эл.пошты:\n\n$5\n\nКод пацверджання дзейсны да $4.",
"confirmemail_invalidated": "Пацверджанне эл.пошты скасаванае",
"invalidateemail": "Адмовіцца ад пацверджання эл.пошты",
"revdelete-uname-unhid": "імя ўдзельніка адкрыта",
"revdelete-restricted": "пастаўленыя абмежаванні на адміністратараў",
"revdelete-unrestricted": "знятыя абмежаванні з адміністратараў",
+ "logentry-block-block": "$1 заблакірава{{GENDER:$2|ў|ла}} {{GENDER:$4|$3}} на перыяд $5 $6",
+ "logentry-block-reblock": "$1 {{GENDER:$2|памяняў|памяняла}} настройкі блакіроўкі {{GENDER:$4|$3}} на перыяд $5 $6",
+ "logentry-suppress-reblock": "$1 {{GENDER:$2|памяняў|памяняла}} параметры блакіроўкі {{GENDER:$4|$3}} на перыяд $5 $6",
"logentry-move-move": "$1 {{GENDER:$2|перанёс|перанесла}} старонку $3 у $4",
"logentry-move-move-noredirect": "$1 {{GENDER:$2|перанёс|перанесла}} старонку $3 у $4, не пакінуўшы перасылкі",
"logentry-move-move_redir": "$1 {{GENDER:$2|перанёс|перанесла}} старонку $3 у $4 па-над перасылкаю",
"import-interwiki-submit": "আমদানি",
"import-upload-filename": "ফাইলনাম:",
"import-comment": "মন্তব্য:",
- "importtext": "à¦\85নà§\81à¦\97à§\8dরহ à¦\95রà§\87 ফাà¦\87লà¦\9fি à¦\89à§\8eস à¦\89à¦\87à¦\95ি থà§\87à¦\95à§\87 [[Special:Export|à¦\8fà¦\95à§\8dসপà§\8bরà§\8dà¦\9f à¦\87à¦\89à¦\9fিলিà¦\9fি]] বà§\8dযবহার à¦\95রà§\87 à¦\8fà¦\95à§\8dসপà§\8bরà§\8dà¦\9f করুন।\nফাইলটি আপনার কম্পিউটারে সংরক্ষণ করুন এবং এখানে আপলোড করুন।",
+ "importtext": "à¦\85নà§\81à¦\97à§\8dরহ à¦\95রà§\87 ফাà¦\87লà¦\9fি à¦\89à§\8eস à¦\89à¦\87à¦\95ি থà§\87à¦\95à§\87 [[Special:Export|রপà§\8dতানি à¦\87à¦\89à¦\9fিলিà¦\9fি]] বà§\8dযবহার à¦\95রà§\87 রপà§\8dতানি করুন।\nফাইলটি আপনার কম্পিউটারে সংরক্ষণ করুন এবং এখানে আপলোড করুন।",
"importstart": "পাতা আমদানি করা হচ্ছে...",
"import-revision-count": "$1 {{PLURAL:$1|টি সংশোধন|টি সংশোধন}}",
"importnopages": "আমদানি করার মত কোন পাতা নেই।",
"importunknownsource": "আমদানি উৎসের ধরন অজানা",
"importcantopen": "আমদানি ফাইল খোলা যায়নি",
"importbadinterwiki": "খারাপ আন্তঃউইকি সংযোগ",
- "importsuccess": "à¦\87মà§\8dপà§\8bরà§\8dà¦\9f সফল!",
+ "importsuccess": "à¦\86মদানি সফল!",
"importnosources": "কোন আন্তঃউইকি আমদানি উৎস সংজ্ঞায়িত করা হয়নি এবং সরাসরি ইতিহাস আপলোডের ক্ষমতা নিষ্ক্রিয় করা হয়েছে।",
"importnofile": "কোন আমদানি ফাইল আপলোড করা হয়নি।",
"importuploaderrorsize": "আমদানি ফাইল আপলোড ব্যর্থ। ফাইলটির আকার অনুমোদিত আপলোডের আকারের চেয়ে বড়।",
"importuploaderrorpartial": "আমদানি ফাইল আপলোড ব্যর্থ। ফাইলটি কেবল আংশিকভাবে আপলোড করা হয়েছে।",
"importuploaderrortemp": "আমদানি ফাইলের আপলোড ব্যর্থ। একটি সাময়িক ফোল্ডার হারানো গেছে।",
"import-parse-failure": "XML পার্স করা যায়নি",
- "import-noarticle": "à¦\87মà§\8dপà§\8bরà§\8dà¦\9f করার মত কোন পাতা নেই!",
+ "import-noarticle": "à¦\86মদানি করার মত কোন পাতা নেই!",
"import-nonewrevisions": "কোনো সংস্করণ আমদানী করা হয়নি।",
"xml-error-string": "$1 যে লাইনে $2, কলামে $3 (বাইট $4): $5",
"import-upload": "XML ডাটা আপলোড",
"import-token-mismatch": "সেশন ডাটা হারিয়ে গিয়েছে।\nঅনুগ্রহ করে পুনরায় চেষ্টা করুন।",
"import-invalid-interwiki": "নির্ধারিত উইকি থেকে আমদানী করা যাবে না।",
"import-error-edit": "\"$1\" পাতাটি আমদানি করা যায়নি কারণ আপনার এটি সম্পাদনা করার অনুমতি নেই।",
- "import-error-create": "\"$1\" পাতাà¦\9fি à¦\87মà§\8dপà§\8bরà§\8dà¦\9f করা যায়নি কারণ আপনার এটি তৈরী করার অনুমতি নেই।",
- "import-error-interwiki": "\"$1\" পাতাà¦\9fি à¦\87মà§\8dপà§\8bরà§\8dà¦\9f à¦\95রা যায়নি à¦\95ারণ à¦\8fà¦\87 নামà¦\9fি বহিà¦\83সà¦\82যà§\8bà¦\97র à¦\9cনà§\8dয নিরà§\8dধারিত (à¦\87নà§\8dà¦\9fারউইকি)।",
+ "import-error-create": "\"$1\" পাতাà¦\9fি à¦\86মদানি করা যায়নি কারণ আপনার এটি তৈরী করার অনুমতি নেই।",
+ "import-error-interwiki": "\"$1\" পাতাà¦\9fি à¦\86মদানি à¦\95রা যায়নি à¦\95ারণ à¦\8fà¦\87 নামà¦\9fি বহিà¦\83সà¦\82যà§\8bà¦\97র à¦\9cনà§\8dয নিরà§\8dধারিত (à¦\86নà§\8dতà¦\83উইকি)।",
"import-error-special": "\"$1\" পাতাটি আমদানি করা যায়নি কারণ এটি একটি বিশেষ নামস্থানকে নির্দেশ করে যেটি সম্পাদনার জন্য অনুমোদিত নয়।",
- "import-error-invalid": "\"$1\" পাতাà¦\9fি à¦\87মà§\8dপà§\8bরà§\8dà¦\9f করা যায়নি কারণ নামটি সঠিক নয়।",
+ "import-error-invalid": "\"$1\" পাতাà¦\9fি à¦\86মদানি করা যায়নি কারণ নামটি সঠিক নয়।",
"import-error-unserialize": "$1 পাতার $2 সংস্করণটি সিরিয়ালাইজ করা যাচ্ছে না। এই রিভিশনে $4 হিসাবে $3 কন্টেন্ট মডেলে সিরিয়ালাইজ করা আছে।",
"import-options-wrong": "ভুল {{PLURAL:$2|অপশন|অপশনসমূহ}}: <nowiki>$1</nowiki>",
"import-rootpage-invalid": "মূল পাতার ভুল শিরনাম দেয়া হয়েছে।",
"revdelete-no-file": "Иштта файл яц.",
"revdelete-show-file-confirm": "Бакъалла лаьий хьуна дӀаяьккхина файлан версега хьажа «<nowiki>$1</nowiki>» $2 тӀера, $3?",
"revdelete-show-file-submit": "ХӀаъ",
- "revdelete-selected-text": "{{PLURAL:$1|Файлан Ñ\85аÑ\8cÑ\80жина веÑ\80Ñ\81и|Файлан Ñ\85аьржина версеш}} [[:$2]]:",
+ "revdelete-selected-text": "{{PLURAL:$1|ХаÑ\8cÑ\80жина веÑ\80Ñ\81и|Ð¥аьржина версеш}} [[:$2]]:",
"revdelete-selected-file": "{{PLURAL:$1|Файлан хаьржина верси|Файлан хаьржина версеш}} [[:$2]]:",
"logdelete-selected": "Тептар чура {{PLURAL:$1|хаьржина дӀаяздар|хаьржина дӀаяздарш}}:",
"revdelete-text-text": "ДӀаяьхна версеш агӀонан истори чохь хьалха санна гуш хира ю, амма чулацаман цхьадолу дакъош декъашхошна тӀекхочехь хира дац.",
"difference-multipage": "(АгӀонийн башхалла)",
"lineno": "МогӀа $1:",
"compareselectedversions": "Хаьржина версешка хьажар",
- "showhideselectedversions": "Ð\93айÑ\82а/кÑ\8aайлаÑ\8fÑ\85а Ñ\85аÑ\8cÑ\80жина баÑ\88Ñ\85онаш",
+ "showhideselectedversions": "Ð\93айÑ\82а/кÑ\8aайлаÑ\8fÑ\85а Ñ\85аÑ\8cÑ\80жина веÑ\80Ñ\81еш",
"editundo": "цаоьшу",
"diff-empty": "(башхалла яц)",
"diff-multi-sameuser": "(ца {{PLURAL:$1|гайтина юккъера цхьа верси|гайтина юккъера цхьа версеш}} оьцу декъашхочун)",
"specialloguserlabel": "Декъашхо:",
"speciallogtitlelabel": "Ӏалашо (цӀе я декъашхо):",
"log": "Тéптарш",
- "all-logs-page": "Деригге тléкхочучéхь долу тéптарш",
+ "all-logs-page": "Дерриге тӀекхочучехь долу тептарш",
"alllogstext": "Массо тéптар могӀам. {{SITENAME}}.\nШуьга харжалур бу хилам оцу тептаре хьаьжжина, декъашхочун цӀе (дӀаяздар диц а цадеш) я цо хьейина агӀонаш (ишта дӀаяздар а диц цадеш).",
"logempty": "Тептарш чохь хӀокху агӀона дӀаяздарш дац.",
"log-title-wildcard": "ХӀокху символашца болалуш болу кортанаш карабе",
"unlockdbsuccesssub": "Хаамийн базан тӀера блокдӀаяьккхина",
"lockedbyandtime": "($1 $2 $3)",
"move-page": "$1 — цӀе хийцар",
- "move-page-legend": "ЦӀe хийца яр",
+ "move-page-legend": "ЦӀе хийцар",
"movepagetext": "Бухахь йолу форманца агӀон цӀе хийцало. Цул совнах цуьна хийцаман тептар кхоьчу метте доккха. Хьалхалера цӀарахь хиръю керла кхоьллина агӀонан хьажорг.\n\nХьовсалаш [[Special:DoubleRedirects|шалха]] а [[Special:BrokenRedirects|йохна хьажоргаш]] юй техь аьлла.\n\nШу жоьпехь ду хьажоргаш нийса некъ гойтуш хиларан.\n\nТидам бе хьалхалера агӀон цӀе ‘’’хийцалур яц’’’ иштта цӀе йолу агӀо йолуш елахь. Юкъардаккхар: йолуш йолу агӀо кхоьчухьа хьажорг елахь, я еса елахь а, цуьна хийцаме истори яцахь а.\n\nИ бохург ду шун агӀонан цӀе юха а хьалха хиллачун тӀе хийца йиш ю, амма йолуш йолу агӀо дӀаяккха йиш яц.\n\n'''ДӀАХЬЕДАР!'''\n\nЦӀе хийцар бахьнехь гӀаръяьлла агӀонашна дукха дагахь боцу хийцамаш хила тарло. Цундела цӀе хийцале шеш хила тарлучу тӀехьонашах кхета аьлла тешна хила.",
"movepagetext-noredirectfixer": "Бухахь йолу форманца агӀон цӀе хийцало. Цул совнах цуьна хийцаман тептар кхоьчу метте доккха. Хьалхалера цӀарахь хиръю керла кхоьллина агӀонан хьажорг.\n\nХьовсалаш [[Special:DoubleRedirects|шалха]] а [[Special:BrokenRedirects|йохна хьажоргаш]] юй техь аьлла.\n\nШу жоьпехь ду хьажоргаш нийса некъ гойтуш хиларан.\n\nТидам бе хьалхалера агӀон цӀе ‘’’хийцалур яц’’’ иштта цӀе йолу агӀо йолуш елахь. Юкъардаккхар: йолуш йолу агӀо кхоьчухьа хьажорг елахь, я еса елахь а, цуьна хийцаме истори яцахь а.\n\nИ бохург ду шун агӀонан цӀе юха а хьалха хиллачун тӀе хийца йиш ю, амма йолуш йолу агӀо дӀаяккха йиш яц.\n\n'''ДӀАХЬЕДАР!'''\n\nЦӀе хийцар бахьнехь гӀаръяьлла агӀонашна дукха дагахь боцу хийцамаш хила тарло. Цундела цӀе хийцале шеш хила тарлучу тӀехьонашах кхета аьлла тешна хила.",
"movepagetalktext": "ТӀе хӀоьттина йолу дийцаре агӀо ишта цӀе хийцина хира ю, '''цхьа йолу ханчохь, маца:'''\n\n*Йаьсса йоцу дийцаре агӀо йолуш ю оцу цӀарца йа\n*Ахьа къастаман харжам цабиняхь а къастам хӀотточехь.\n\nИшта чу ханчохь, ахьа дехьа яккха йезар ю йа куьйга хӀоттайар, нагахь иза хьашт йалахь.",
"nonfile-cannot-move-to-file": "АгӀонийн цӀераш хийца йиш яц",
"imagetypemismatch": "Файлан керла шоръелла оцунна тайпанца йогӀуш яц",
"imageinvalidfilename": "Файлан цӀе гӀалате ю",
+ "fix-double-redirects": "Хьалхара цӀе йолу дӀасахьажорг нисъян",
"move-leave-redirect": "Ӏадйита дӀасахьажораг",
"protectedpagemovewarning": "'''ДӀахьедар.''' ХӀара агӀо гӀаролла йина ю; цӀе хийца я нисйа а бакъо йолуш куьйгалхой бе бац.\nЛахахьа тептаро балийна тӀаьхьаралера дӀаязбина хаам:",
"semiprotectedpagemovewarning": "'''ДӀахьедо.''' ХӀара агӀо гӀаролла йина ю; дӀабазбиначу декъашхошка бе цӀе хийцалуш яц.\nЛахахьа тептаро балийна тӀаьхьаралера дӀаязбина хаам:",
"tags-deactivate-reason": "Бахьна:",
"tags-deactivate-submit": "ДӀаяйа",
"tags-edit-title": "Тегаш таян",
+ "tags-edit-manage-link": "Тегашна урхалладар",
+ "tags-edit-revision-selected": "{{PLURAL:$1|Хаьржина верси|Хаьржина версеш}} [[:$2]]:",
+ "tags-edit-revision-legend": "ТӀетоха я дӀаяха тегаш {{PLURAL:$1|this revision|all $1 revisions}} чура",
+ "tags-edit-logentry-legend": "ТӀетоха я дӀаяха тегаш {{PLURAL:$1|this log entry|all $1 log entries}} чура",
"tags-edit-existing-tags": "Йолуш йолу билгалонаш:",
"tags-edit-existing-tags-none": "''ХӀахӀа''",
"tags-edit-new-tags": "Керла билгалонаш:",
+ "tags-edit-add": "ТӀетоха хӀара билгалонаш:",
+ "tags-edit-remove": "ДӀаяха хӀара билгалонаш:",
+ "tags-edit-remove-all-tags": "(дӀаяха массо билгалонаш)",
+ "tags-edit-chosen-placeholder": "Харжа цхьаъ я массийта тег",
"tags-edit-reason": "Бахьна:",
"tags-edit-nooldid-title": "Ӏалашонан верси билгалйина яц",
"comparepages": "АгӀонаш юстар",
"logentry-upload-revert": "$1 {{GENDER:$2|чуяьккхина}} $3",
"log-name-managetags": "Билгалонашан урхалладаран тептар",
"logentry-managetags-create": "$1 {{GENDER:$2|Кхоьллина}} билгало «$4»",
+ "log-name-tag": "Билгалонийн тептар",
"rightsnone": "(яц)",
"revdelete-summary": "хийцамах лаьцна",
"feedback-adding": "АгӀона хетарг тӀетохар...",
"myprivateinfoprotected": "Nemáte oprávnění měnit své soukromé údaje.",
"mypreferencesprotected": "Nemáte oprávnění změnit svá nastavení.",
"ns-specialprotected": "Stránky ve jmenném prostoru {{ns:special}} nelze editovat.",
- "titleprotected": "Stránku s tímto názvem nelze založit, protože název zamknul uživatel [[User:$1|$1]] s odůvodněním <em>$2</em>.",
+ "titleprotected": "Stránku s tímto názvem nelze založit, protože název {{GENDER:$1|zamkl|zamkla|zamkl uživatel}} [[User:$1|$1]].\nUdaným důvodem bylo „<em>$2</em>“.",
"filereadonlyerror": "Nelze změnit soubor „$1“, protože úložiště souborů „$2“ je pouze pro čtení.\n\nSprávce serveru, který úložiště zamkl, poskytl toto zdůvodnění: „$3“.",
"invalidtitle-knownnamespace": "Neplatný název se jmenným prostorem „$2“ a textem „$3“",
"invalidtitle-unknownnamespace": "Neplatný název s neznámým číslem jmenného prostoru $1 a textem „$2“",
"no-null-revision": "Could not create new null revision for page \"$1\"",
"badtitle": "Bad title",
"badtitletext": "The requested page title was invalid, empty, or an incorrectly linked inter-language or inter-wiki title.\nIt may contain one or more characters that cannot be used in titles.",
+ "title-invalid-empty": "The requested page title is empty or contains only the name of a namespace.",
+ "title-invalid-utf8": "The requested page title contains an invalid UTF-8 sequence.",
+ "title-invalid-interwiki": "Title contains an interwiki link",
+ "title-invalid-talk-namespace": "The requested page title refers to a talk page that can not exist.",
+ "title-invalid-characters": "The requested page title contains invalid characters: \"$1\".",
+ "title-invalid-relative": "Title has relative path. Relative page titles (./, ../) are invalid, because they will often be unreachable when handled by user\"s browser.",
+ "title-invalid-magic-tilde": "The requested page title contains invalid magic tilde sequence (<nowiki>~~~</nowiki>).",
+ "title-invalid-too-long": "The requested page title is too long. It must be no longer than $1 bytes in UTF-8 encoding.",
+ "title-invalid-leading-colon": "The requested page title contains an invalid colon at the beginning.",
"perfcached": "The following data is cached and may not be up to date. A maximum of {{PLURAL:$1|one result is|$1 results are}} available in the cache.",
"perfcachedts": "The following data is cached, and was last updated $1. A maximum of {{PLURAL:$4|one result is|$4 results are}} available in the cache.",
"querypage-no-updates": "Updates for this page are currently disabled.\nData here will not presently be refreshed.",
"logentry-managetags-activate": "$1 {{GENDER:$2|aktivoi}} merkkauksen \"$4\" käyttäjien ja bottien käytettäväksi",
"logentry-managetags-deactivate": "$1 {{GENDER:$2|otti pois käytöstä}} merkkauksen \"$4\" käyttäjiltä ja boteilta",
"log-name-tag": "Merkkausloki",
+ "log-description-tag": "Tällä sivulla näytetään käyttäjien lisäämät tai poistamat [[Special:Tags|merkkaukset]] yksittäisissä sivuversioissa tai lokimerkinnöissä. Lokiin eivät kirjaudu merkkaukset silloin, kun ne tulevat muokkaamisen, poistamisen tai muun vastaavan toimenpiteen yhteydessä.",
"logentry-tag-update-add-revision": "$1 {{GENDER:$2|lisäsi}} {{PLURAL:$7|merkkauksen|merkkaukset}} $6 kohdeversioon $4 sivulla $3",
"logentry-tag-update-add-logentry": "$1 {{GENDER:$2|lisäsi}} {{PLURAL:$7|merkkauksen|merkkaukset}} $6 lokimerkintään $5 sivulla $3",
"logentry-tag-update-remove-revision": "$1 {{GENDER:$2|poisti}} {{PLURAL:$9|merkkauksen|merkkaukset}} $8 kohdeversiosta $4 sivulla $3",
"viewsourcetext": "આપ આ પાનાનો મૂળ સ્રોત નિહાળી શકો છો અને તેની નકલ (copy) પણ કરી શકો છો:",
"viewyourtext": "આપ આ પાનાનાં '''આપનાં સંપાદનો'''નો મૂળ સ્રોત નિહાળી શકો છો અને તેની નકલ (copy) પણ કરી શકો છો:",
"protectedinterface": "આ પાનું સોફ્ટવેર માટે ઇન્ટરફેઇસ ટેક્સટ આપે છે, અને તેને દુરુપયોગ રોકવા માટે સ્થગિત કર્યું છે.\nબધાંજ વિકિ માટે ભાષાંતર ઉમેરવા કે બદલવા માટે, કૃપા કરી [//translatewiki.net/ translatewiki.net], મિડિયાવિકિ સ્થાનિયકરણ પ્રકલ્પ, વાપરો.",
- "editinginterface": "'''ચેતવણી:''' તમે જે પાનામાં ફેરફાર કરી રહ્યા છો તે પાનું સોફ્ટવેર માટે ઇન્ટરફેસ ટેક્સટ પુરી પાડે છે.\nઅહીંનો બદલાવ આ વિકિ પર ઉપસ્થિત અન્ય સભ્યોના ઇન્ટરફેસનાં દેખાવ ઉપર અસરકર્તા બનશે.\nબધાંજ વિકિ માટે ભાષાંતર ઉમેરવા કે બદલવા માટે કૃપા કરી [//translatewiki.net/ translatewiki.net], મિડિયાવિકી સ્થાનિયકરણ પ્રકલ્પ, વાપરો.",
+ "editinginterface": "<strong>ચેતવણી:</strong> તમે જે પાનામાં ફેરફાર કરી રહ્યા છો તે પાનું સોફ્ટવેર માટે ઇન્ટરફેસ ટેક્સટ પુરી પાડે છે.\nઅહીંનો બદલાવ આ વિકિ પર ઉપસ્થિત અન્ય સભ્યોના ઇન્ટરફેસનાં દેખાવ ઉપર અસરકર્તા બનશે.",
"cascadeprotected": "આ પાના પર ફેરફાર પ્રતિબંધિત છે કેમ કે આ પાનું {{PLURAL:$1|એવું પાનું|એવા પાના}} માં શામિલ છે જેમાં અનુવર્તી (પગથિયામય)સંરક્ષણ સક્રીય છે :\n$2",
"namespaceprotected": "તમને '''$1''' નામાવકાશનાં પાનાંમાં ફેરફાર કરવાની પરવાનગી નથી.",
"customcssprotected": "તમને આ પાનું બદલવાની પરવાનગી નથી કારણકે આ પાનામાં બીજા સભ્યની પસંદગીના સેટીંગ્સ છે.",
"invalidtitle-knownnamespace": "નામસ્થળ \"$2\" અને લખાણ \"$3\" સાથે અમાન્ય મથાળું",
"invalidtitle-unknownnamespace": "અજ્ઞાત નામસ્થળ ક્રમાંક $1 અને નામ \"$2\" વાળું અમાન્ય મથાળું",
"exception-nologin": "પ્રવેશ કરેલ નથી",
- "exception-nologin-text": "આ પાનું કે પ્રક્રિયા પ્રાપ્તી માટે કૃપયા [[Special:Userlogin|લોગઈન]] કરો.",
+ "exception-nologin-text": "આ પાનું કે પ્રક્રિયા પ્રાપ્તી માટે કૃપયા લોગઈન કરો.",
"exception-nologin-text-manual": "આ પાનું કે પ્રક્રિયા મેળવવા માટે કૃપયા $1.",
"virus-badscanner": "ખરાબ રૂપરેખા: અજાણ્યું વાઇરસ સ્કેનર: ''$1''",
"virus-scanfailed": "સ્કેન અસફળ (code $1)",
"history-feed-empty": "આ પાનું અસ્તિત્વમાં નથી.\nશક્ય છે કે આ પાનું વિકિમાંથી દૂર કરવામાં આવ્યું હોય કે તેનું નામ બદલવામાં આવ્યું હોય.\nસંલગ્ન નવા પાનાઓ માટે [[Special:Search|વિકિમાં શોધી જુઓ]].",
"rev-deleted-comment": "(ફેરફારોનો સારાંશ હટાવ્યો)",
"rev-deleted-user": "(સભ્યનામ હટાવાયું)",
- "rev-deleted-event": "(લà«\8bàª\97 àª\95à«\8dરિયા હટાવાઈ)",
+ "rev-deleted-event": "(લà«\8bàª\97 વિàª\97તà«\8b હટાવાઈ)",
"rev-deleted-user-contribs": "[સભ્યનામ કે IP સરનામું હટાવી દેવાયું છે - યોગદાનામાં આ ફેરફાર અદ્રશ્ય છે]",
"rev-deleted-text-permission": "આ પુનરાવર્તન હટાવી દેવાયું છે\nઆની વિસ્તરીત માહિતી અહીં મળશે [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} deletion log].",
"rev-suppressed-text-permission": "આ પાનાં પરનું પુનરાવર્તન <strong>છુપાવવામાં</strong> આવ્યું છે. તેની વધુ વિગત [{{fullurl:{{#Special:Log}}/suppress|page={{FULLPAGENAMEE}}}} છુપાવાયેલના લોગ] પરથી મળશે.",
"rev-showdeleted": "બતાવો",
"revisiondelete": "પુનરાવર્તન રદ કરો/પુનર્જીવીત કરો",
"revdelete-nooldid-title": "અવૈધ લક્ષ્ય ફેરફાર",
- "revdelete-nooldid-text": "આ ક્રિયા જેના પર કરવાની છે તે લક્ષ્ય ફેરફાર તમે જણાવ્યો નથી અથવા એવો કોઇ ફેરફાર અસ્તિત્વમાં નથી અથવા તમે હાલનો ફેરફાર સંતાડવાનો પ્રયત્ન કરી રહ્યાં છો.",
+ "revdelete-nooldid-text": "આ ક્રિયા જેના પર કરવાની છે તે લક્ષ્ય ફેરફાર તમે જણાવ્યો નથી. અથવા એવો કોઇ ફેરફાર અસ્તિત્વમાં નથી. અથવા તમે હાલનો ફેરફાર સંતાડવાનો પ્રયત્ન કરી રહ્યાં છો.",
"revdelete-no-file": "વર્ણવેલી ફાઈલ અસ્તિત્વમાં નથી",
"revdelete-show-file-confirm": "શું તમને ખાત્રી છે કેતમે $2 તારીખ $3 વાગ્યા સુધીના \"<nowiki>$1</nowiki>\" ફાઇલ ના ફેરફાર જોવા માંગો છો?",
"revdelete-show-file-submit": "હા",
"revdelete-selected-text": "[[:$2]]: નું {{PLURAL:$1|Selected revision|પસંદ કરાયેલ પુનરાવર્તન}}",
"logdelete-selected": "{{PLURAL:$1|પસંદગી કરેલ લોગ ઘટના | પસંદગી કરેલ લોગ ઘટનાઓ }}:",
- "revdelete-confirm": "કૃપયા પુષ્ટિ કરો કે તમે શું કરી રહ્યા છો તેની અને તેના પરિણામોની તમને જાણ છે અને તમે આ બધું [[{{MediaWiki:Policy-url}}|the policy]] અ6તર્ગત કરી રહ્યાં છો.",
+ "revdelete-confirm": "કૃપયા પુષ્ટિ કરો કે તમે શું કરી રહ્યા છો તેની અને તેના પરિણામોની તમને જાણ છે અને તમે આ બધું [[{{MediaWiki:Policy-url}}|નીતિ]] અંતર્ગત કરી રહ્યાં છો.",
"revdelete-suppress-text": "બળ પૂર્વક છુપાવવું \"માત્ર\" આજ સંજોગોમાં કરી શકાશે:\n* સંભવતઃ ભયાજનક માહિતી \n* અયોગ્ય નિજી માહિતી \n*: ''ઘરનું સરનામું અને ટેલિફોન નંબર, રાષ્ટ્રીય ઓળખ ક્રમાંકો વગેરે.''",
"revdelete-legend": "દ્રશ્યતા સંબંધી પ્રતિબંધોને ગોઠવો",
"revdelete-hide-text": "પુનરાવર્તન લખાણ",
"revdelete-hide-image": "ફાઇલની માહિતી છુપાવો",
- "revdelete-hide-name": "àª\95à«\8dરિયા àª\85નà«\87 લàª\95à«\8dષà«\8dય સંતાડો",
+ "revdelete-hide-name": "લàª\95à«\8dષà«\8dય àª\85નà«\87 પરિમાણà«\8b સંતાડો",
"revdelete-hide-comment": "ફેરફાર સારાંશ",
"revdelete-hide-user": "સંપાદકનું નામ /આઈ પી એડ્રેસ",
"revdelete-hide-restricted": "પ્રબંધક કે અન્યો સૌની માહિતી છુપાવો",
"right-deletedtext": "રદ્દ કરાયેલ લેખ અને રદ્દીકરણ વચ્ચેના ફેરફારો વાંચો",
"right-browsearchive": "હટાવેલા પાનાની શોધ",
"right-undelete": "હટાવેલ પાનું પુનર્જીવીત કરો",
- "right-suppressrevision": "પà«\8dરબàª\82ધàª\95à«\8bથà«\80 સàª\82તાડાયà«\87લ ફà«\87રફારà«\8bનà«\81àª\82 àª\85વલà«\8bàª\95ન àª\85નà«\87 પà«\81નàª\83સà«\8dથાપન àª\95રà«\8b.",
+ "right-suppressrevision": "àª\95à«\8bàª\88પણ સàªà«\8dયàª\8f પાનાàª\93 પર àª\95રà«\87લાàª\82 àª\9aà«\8bàª\95à«\8dàª\95સ ફà«\87રફારà«\8b àª\9cà«\81àª\93, સàª\82તાડà«\8b àª\95à«\87 દà«\87àª\96ાતા àª\95રà«\8b",
"right-suppressionlog": "નિજી લોગ જુઓ",
"right-block": "આ સભ્ય દ્વારા થનાર ફેરફાર પ્રતિબંધીત કરો",
"right-blockemail": "સભ્યના ઇ-મેલ મોકલવા પર પ્રતિબંધ મૂકો",
"emailccsubject": "$1ને તમે મોકલેલા સંદેશાની પ્રત: $2",
"emailsent": "ઈ-મેલ મોકલી દેવાયો",
"emailsenttext": "તમારો ઈ-મેલ મોકલી દેવાયો છે",
- "emailuserfooter": "આ પત્ર $1 દ્વારા $2ને {{SITENAME}} પરની \"સભ્યને ઇ-મેલ કરો\" કડી મારફતે મોકલવામાં આવ્યો છે.",
+ "emailuserfooter": "આ પત્ર $1 દ્વારા $2ને {{SITENAME}} પરની \"{{int:emailpage}} (સભ્યને ઇ-મેલ કરો)\" કડી મારફતે મોકલવામાં આવ્યો છે.",
"usermessage-summary": "તંત્ર સંદેશ મૂક્યો",
"usermessage-editor": "તંત્ર સંદેશાઓ",
"watchlist": "ધ્યાનસૂચી",
"contribsub2": "($2) માટે {{GENDER:$3|$1}}",
"nocontribs": "આ પરિમાણને મળતી પરિણામ નથી મળ્યાં",
"uctop": "(વર્તમાન)",
- "month": ":મહિનાથી (અને પહેલાનાં)",
- "year": ":વર્ષથી (અને પહેલાનાં)",
+ "month": "આ મહિનાથી (અને તેના પહેલાનાં) →",
+ "year": "આ વર્ષથી (અને તેના પહેલાનાં) →",
"sp-contributions-newbies": "માત્ર નવા ખુલેલાં ખાતાઓનું યોગદાન બતાવો",
"sp-contributions-newbies-sub": "નવા ખાતાઓ માટે",
"sp-contributions-newbies-title": "નવા ખાતાના સભ્યોનું યોગદાન",
"logentry-delete-delete": "$1 દ્વારા પાનું $3 {{GENDER:$2|દૂર કરવામાં આવ્યું}}",
"logentry-delete-restore": "$1 {{GENDER:$2|પુનઃસંગ્રહ}} પાનું $3",
"logentry-delete-event": "$1 એ {{PLURAL:$5|લૉગ ઘટના|$5 લૉગ ઘટનાઓ}} ની દ્રશ્યતા $3 પર {{GENDER:$2|બદલેલ}} છે: $4",
- "logentry-delete-revision": "$1 {{GENDER:$2|બદલà«\87લ}} બદલાàª\88 ના દà«\83શà«\8dયતા {{PLURAL:$5 | સà«\81ધારણા | $5 àª\86વà«\83તà«\8dતિàª\93}} $3 પાનાàª\82 પર: $4",
+ "logentry-delete-revision": "$1 {{GENDER:$2|àª\8f}} પà«\83ષà«\8dઠ$3 પરના {{PLURAL:$5|àª\8fàª\95 પà«\81નરાવરà«\8dતન|$5 પà«\81નરાવરà«\8dતનà«\8b}}નà«\80 દà«\83ષà«\8dયતા બદલà«\80: $4",
"logentry-delete-event-legacy": "$1 એ $3 પર ફેરફારની દૃશ્યતા બદલી",
"logentry-delete-revision-legacy": "પૃષ્ઠ $3 પરના પુનરાવર્તનોની દૃશ્યતા $1 {{GENDER:$2|એ બદલી}}",
"logentry-suppress-delete": "$1 એ $3 પાનું {{GENDER:$2|દબાવ્યું}}",
"logentry-suppress-event": "$1 ખાનગી રીતે {{GENDER:$2|દ્વારા માહિતીની દૃશ્યતા}} $3 : $4 પર બદલાઈ {{PLURAL:$5 | લોગ ઘટના | $5 લોગ}}",
- "logentry-suppress-revision": "$1 છાની માહિતી {{GENDER:$2|બદલેલ}} બદલાઈ ના દૃશ્યતા {{PLURAL:$5 | આવૃત્તિ એ | $5 આવૃત્તિઓ}}: $4 $3 પાનાં પર",
+ "logentry-suppress-revision": "$1 {{GENDER:$2|એ છાનામાના}} પૃષ્ઠ $3 પરના {{PLURAL:$5|એક પુનરાવર્તન|$5 પુનરાવર્તનો}}ની દૃષ્યતા બદલી: $4",
"logentry-suppress-event-legacy": "$1એ ગુપ્ત રીતે $3 પર લોગ ઘટનાઓની દૃશ્યતા બદલી",
"logentry-suppress-revision-legacy": "$1 ગુપ્ત {{GENDER:$2|બદલેલ}} બદલાઈ પાનાં પર આવૃત્તિઓની દૃશ્યતા $3",
"revdelete-content-hid": "માહિતી છુપાવી",
"protectedinterface": "Ez a lap a szoftver felületéhez szolgáltat szöveget, és a visszaélések elkerülése miatt le van zárva.",
"editinginterface": "<strong>Vigyázat:</strong> egy olyan lapot szerkesztesz, ami a MediaWiki szoftver felületéhez tartozik. A lap megváltoztatása hatással lesz a kinézetre, ahogy más szerkesztők látják a lapot.",
"translateinterface": "Minden wikire kiterjedő fordítások hozzáadásához vagy szerkesztésére használd a [//translatewiki.net/ translatewiki.net]-et, a MédiaWiki lokalizációs projektjét.",
- "cascadeprotected": "Ez a lap szerkesztés elleni védelemmel lett ellátva, mert a következő {{PLURAL:$1|lapon|lapokon}} be van kapcsolva a „kaszkádolt” védelem:\n$2",
+ "cascadeprotected": "Ez a lap szerkesztés elleni védelemmel lett ellátva, mert be van illesztve a következő {{PLURAL:$1|lapon|lapokon}}, ahol be van kapcsolva a „kaszkádolt” védelem:\n$2",
"namespaceprotected": "Nincs jogosultságod a(z) '''$1''' névtérben található lapok szerkesztésére.",
"customcssprotected": "Nem szerkesztheted ezt a CSS-lapot, mert egy másik felhasználó személyes beállításait tartalmazza.",
"customjsprotected": "Nem szerkesztheted ezt a JavaScript-lapot, mert egy másik felhasználó személyes beállításait tartalmazza.",
"history-feed-description": "Riwayat revisi halaman ini di wiki",
"history-feed-item-nocomment": "$1 pada $2",
"history-feed-empty": "Halaman yang diminta tak ditemukan.\nKemungkinan telah dihapus dari wiki, atau diberi nama baru.\nCoba [[Special:Search|lakukan pencarian di wiki]] untuk halaman baru yang relevan.",
+ "history-edit-tags": "Sunting tag dari revisi yang terpilih",
"rev-deleted-comment": "(ringkasan suntingan dihapus)",
"rev-deleted-user": "(nama pengguna dihapus)",
"rev-deleted-event": "(rincian log dihapus)",
"listfiles-delete": "hapus",
"listfiles-summary": "Halaman istimewa ini menampilkan semua berkas yang telah diunggah.\nKetika disaring oleh pengguna, hanya versi berkas terbaru dari berkas yang diunggah oleh pengguna tersebut yang ditampilkan.",
"listfiles_search_for": "Cari nama berkas:",
+ "listfiles-userdoesnotexist": "Akun pengguna \"$1\" tidak terdaftar.",
"imgfile": "berkas",
"listfiles": "Daftar berkas",
"listfiles_thumb": "Miniatur",
"logempty": "Tidak ditemukan entri log yang sesuai.",
"log-title-wildcard": "Cari judul yang diawali dengan teks tersebut",
"showhideselectedlogentries": "Tampilkan/sembunyikan entri log terpilih",
+ "log-edit-tags": "Sunting tag dari entri log yang terpilih",
"allpages": "Semua halaman",
"nextpage": "Halaman selanjutnya ($1)",
"prevpage": "Halaman sebelumnya ($1)",
"protect-othertime": "Waktu lain:",
"protect-othertime-op": "waktu lain",
"protect-existing-expiry": "Waktu kedaluwarsa saat ini: $2 $3",
+ "protect-existing-expiry-infinity": "Waktu kedaluwarsa yang ada: tidak terdefinisi",
"protect-otherreason": "Alasan lain/tambahan:",
"protect-otherreason-op": "Alasan lain",
"protect-dropdown": "*Alasan umum pelindungan\n** Vandalisme berulang\n** Spam berulang\n** Perang suntingan\n** Halaman dengan lalu-lintas tinggi",
"namespace": "Ruang nama:",
"invert": "Balikkan pilihan",
"tooltip-invert": "Centang kotak ini untuk menyembunyikan perubahan halaman dalam ruang nama yang dipilih (dan ruang nama terkait jika dicentang)",
+ "tooltip-whatlinkshere-invert": "Centang kotak ini untuk menyembunyikan pranala dalam ruang nama yang dipilih.",
"namespace_association": "Ruangnama terkait",
"tooltip-namespace_association": "Centang halaman ini untuk menyertakan ruang nama pembicaraan atau subjek yang terkait dengan ruang nama terpilih",
"blanknamespace": "(Utama)",
"unblocked": "Blokir terhadap [[User:$1|$1]] telah dicabut",
"unblocked-range": "$1 telah diblokir",
"unblocked-id": "Blokir $1 telah dicabut",
+ "unblocked-ip": "[[Special:Contributions/$1|$1]] telah dibuka blokirnya.",
"blocklist": "Pengguna terblokir",
"ipblocklist": "Pengguna terblokir",
"ipblocklist-legend": "Cari pengguna yang diblokir",
"thumbnail-temp-create": "Tidak dapat membuat berkas kecil temporer",
"thumbnail-dest-create": "Tidak dapat menyimpan berkas kecil ke tujuan",
"thumbnail_invalid_params": "Kesalahan parameter miniatur",
+ "thumbnail_toobigimagearea": "Berkas dengan dimensi lebih besar dari $1",
"thumbnail_dest_directory": "Direktori tujuan tak dapat dibuat",
"thumbnail_image-type": "Tipe gambar tidak didukung",
"thumbnail_gd-library": "Konfigurasi pustaka GD tak lengkap: tak ada fungsi $1",
"thumbnail_image-missing": "Berkas yang tampaknya hilang: $1",
"thumbnail_image-failure-limit": "Ada terlalu banyak upaya yang gagal baru-baru ini ($1 atau lebih) untuk membuat miniatur ini. Silakan coba lagi nanti.",
"import": "Impor halaman",
- "importinterwiki": "Impor transwiki",
- "import-interwiki-text": "Pilih suatu wiki dan judul halaman yang akan di impor.\nTanggal revisi dan nama penyunting akan dipertahankan.\nSemua aktivitas impor transwiki akan dicatat di [[Special:Log/import|log impor]].",
+ "importinterwiki": "Impor dari wiki yang lainnya",
+ "import-interwiki-text": "Pilih suatu wiki dan judul halaman yang akan di impor.\nTanggal revisi dan nama penyunting akan dipertahankan.\nSemua aktivitas impor dari wiki lainnya akan dicatat di [[Special:Log/import|log impor]].",
+ "import-interwiki-sourcewiki": "Wiki sumber:",
+ "import-interwiki-sourcepage": "Sumber halaman:",
"import-interwiki-history": "Salin semua versi terdahulu dari halaman ini",
"import-interwiki-templates": "Sertakan semua templat",
"import-interwiki-submit": "Impor",
+ "import-mapping-default": "Impor ke lokasi standar",
+ "import-mapping-namespace": "Impor ke ruang nama:",
+ "import-mapping-subpage": "Impor sebagai subhalaman dari halaman berikut:",
"import-upload-filename": "Nama berkas:",
"import-comment": "Komentar:",
"importtext": "Silakan ekspor berkas dari wiki sumber dengan menggunakan [[Special:Export|fasilitas ekspor]].\nSimpan ke komputer Anda dan unggah ke sini.",
"importcantopen": "Berkas impor tidak dapat dibuka",
"importbadinterwiki": "Pranala interwiki rusak",
"importsuccess": "Impor sukses!",
- "importnosources": "Tidak ada sumber impor transwiki yang telah dibuat dan pemuatan riwayat secara langsung telah di non-aktifkan.",
+ "importnosources": "Tidak ada wiki dari yang diimpor yang telah dibuat dan pemuatan riwayat secara langsung telah di non-aktifkan.",
"importnofile": "Tidak ada berkas sumber impor yang telah dimuat.",
"importuploaderrorsize": "Pemuatan berkas impor gagal. Ukuran berkas melebihi ukuran yang diperbolehkan.",
"importuploaderrorpartial": "Pemuatan berkas impor gagal. Hanya sebagian berkas yang berhasil dimuat.",
"logentry-newusers-create2": "$1 사용자가 $3 사용자 계정을 {{GENDER:$2|만들었습니다}}",
"logentry-newusers-byemail": "$3 사용자 계정을 $1님이 {{GENDER:$2|만들었고}} 비밀번호는 이메일로 보냈습니다",
"logentry-newusers-autocreate": "$1 사용자 계정을 자동으로 {{GENDER:$2|만들었습니다}}",
- "logentry-rights-rights": "$1 사용자가 $3 사용자의 권한을 $4에서 $5으로 {{GENDER:$2|바꾸었습니다}}",
+ "logentry-rights-rights": "$1 사용자가 $3 사용자의 권한을 $4에서 $5(으)로 {{GENDER:$2|바꾸었습니다}}",
"logentry-rights-rights-legacy": "$1 사용자가 $3 사용자의 권한을 {{GENDER:$2|바꾸었습니다}}",
"logentry-rights-autopromote": "$1 사용자의 권한을 자동적으로 $4에서 $5으로 {{GENDER:$2|바꾸었습니다}}",
"logentry-upload-upload": "$1 사용자가 $3 파일을 {{GENDER:$2|올렸습니다}}",
"metadata-help": "Hic fasciculus alias res continet, saepius a machina originatore additas, et (si fasciculus postea recensus sit) fortasse corrigendas.",
"metadata-expand": "Plura ostende",
"metadata-collapse": "Partim celare",
+ "metadata-fields": "Campi metadatorum imaginis in hoc nuntio enumerati in pagina imaginis includentur cum tabula metadatorum occludatur.\nAlii abscondentur nisi actio contraria faciatur.\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",
"exif-imagewidth": "Amplitudo",
"exif-imagelength": "Altitudo",
"exif-bitspersample": "Biti per componentem",
"editfont-sansserif": "Bezserifa fonts",
"editfont-serif": "Serifa fonts",
"sunday": "svētdiena",
- "monday": "Pirmdiena",
+ "monday": "pirmdiena",
"tuesday": "otrdiena",
"wednesday": "trešdiena",
"thursday": "ceturtdiena",
"disclaimers": "Saistību atrunas",
"disclaimerpage": "Project:Saistību atrunas",
"edithelp": "Labošanas palīdzība",
+ "helppage-top-gethelp": "Palīdzība",
"mainpage": "Sākumlapa",
"mainpage-description": "Sākumlapa",
"policy-url": "Project:Politika",
"history-feed-description": "Revisjonshistorikk for denne siden",
"history-feed-item-nocomment": "$1 på $2",
"history-feed-empty": "Den etterspurte siden finnes ikke.\nDen kan ha blitt slettet fra wikien, eller fått et nytt navn.\nPrøv å [[Special:Search|søke]] etter beslektede sider.",
+ "history-edit-tags": "Rediger merkene til de valgte revisjonene",
"rev-deleted-comment": "(redigeringskommentar fjernet)",
"rev-deleted-user": "(brukernavn fjernet)",
"rev-deleted-event": "(loggoppføring fjernet)",
"listfiles-delete": "slett",
"listfiles-summary": "Denne spesialsiden viser alle opplastede filer.",
"listfiles_search_for": "Søk etter filnavn:",
+ "listfiles-userdoesnotexist": "Brukerkontoen «$1» er ikke registrert.",
"imgfile": "fil",
"listfiles": "Filliste",
"listfiles_thumb": "Miniatyrbilde",
"patrol-log-page": "Patruljeringslogg",
"patrol-log-header": "Dette er en logg over patruljerte sideversjoner.",
"log-show-hide-patrol": "$1 patruljeringslogg",
+ "log-show-hide-tag": "$1 merkelogg",
"deletedrevision": "Slettet gammel revisjon $1.",
"filedeleteerror-short": "Feil under filsletting: $1",
"filedeleteerror-long": "Feil oppsto under filsletting:\n\n$1",
"rcshowhidemine-show": "Bekiek",
"rcshowhidemine-hide": "Verbarg",
"rclinks": "Bekiek de leste $1 wiezigingen van de aofgeleupen $2 dagen<br />$3",
- "diff": "wiezig",
+ "diff": "wiez",
"hist": "gesch",
"hide": "verbarg",
"show": "bekiek",
"markedaspatrollederrornotify": "Markeren als gecontroleerd mislukt.",
"patrol-log-page": "Markeerlogboek",
"patrol-log-header": "Dit logboek bevat versies die gemarkeerd zijn als gecontroleerd.",
- "log-show-hide-patrol": "Markeerlogboek $1",
- "log-show-hide-tag": "Label-logboekregel $1",
+ "log-show-hide-patrol": "markeerlogboek $1",
+ "log-show-hide-tag": "labellogboek $1",
"deletedrevision": "De oude versie $1 is verwijderd",
"filedeleteerror-short": "Fout bij het verwijderen van bestand: $1",
"filedeleteerror-long": "Er zijn fouten opgetreden bij het verwijderen van het bestand:\n\n$1",
"hours-abbrev": "$1 گ",
"seconds": "{{PLURAL:$1|$1 ثانيه|$1 ثانيې}}",
"minutes": "{{PLURAL:$1|$1 دقيقه|$1 دقيقې}}",
- "hours": "{{PLURAL:$1|$1 ساعت|$1 ساعتونه}}",
+ "hours": "{{PLURAL:$1|$1 گړۍ|$1 گړۍ}}",
"days": "{{PLURAL:$1|$1 ورځ|$1 ورځې}}",
"weeks": "{{PLURAL:$1|$1 اونۍ|$1 اونۍ}}",
"months": "{{PLURAL:$1|$1 مياشت|$1 مياشتې}}",
"api-error-unknownerror": "ناڅرګنده تېروتنه: \"$1\".",
"duration-seconds": "$1 {{PLURAL:$1|ثانيه|ثانيې}}",
"duration-minutes": "$1 {{PLURAL:$1|دقيقه|دقيقې}}",
- "duration-hours": "$1 {{PLURAL:$1|ساعت|ساعتونه}}",
+ "duration-hours": "$1 {{PLURAL:$1|گړۍ|گړۍ}}",
"duration-days": "$1 {{PLURAL:$1|ورځ|ورځې}}",
"duration-weeks": "$1 {{PLURAL:$1|اونۍ|اونۍ}}",
"duration-years": "$1 {{PLURAL:$1|کال|کالونه}}",
"delete-hook-aborted": "Error message shown when an extension hook prevents a page deletion, but does not provide an error message.",
"no-null-revision": "Error message shown when no null revision could be created to reflect a protection level change.\n\nAbout \"null revision\":\n* Create a new null-revision for insertion into a page's history. This will not re-save the text, but simply refer to the text from the previous version.\n* Such revisions can for instance identify page rename operations and other such meta-modifications.\n\nParameters:\n* $1 - page title",
"badtitle": "The page title when a user requested a page with invalid page name. The content will be {{msg-mw|badtitletext}}.",
+ "title-invalid-empty": "Used as text of error message: empty title",
+ "title-invalid-utf8": "Used as text of error message: invalid UTF8 sequence",
+ "title-invalid-interwiki": "Used as text of error message: invalid interwiki link",
+ "title-invalid-talk-namespace": "Used as text of error message: invalid talk page",
+ "title-invalid-characters": "Used as text of error message: invalid characters in title ($1 is the character)",
+ "title-invalid-relative": "Used as text of error message: relative titles are invalid",
+ "title-invalid-magic-tilde": "Used as text of error message: magic tilde sequence is invalid in page title",
+ "title-invalid-too-long": "Used as text of error message: too long title ($1 is maximum length)",
+ "title-invalid-leading-colon": "Used as text of error message: colon at the beginning of title is invalid",
"badtitletext": "The message shown when a user requested a page with invalid page name. The page title will be {{msg-mw|badtitle}}.\n\nSee also:\n* {{msg-mw|selfmove}}\n* {{msg-mw|immobile-source-namespace}}\n* {{msg-mw|immobile-target-namespace-iw}}\n* {{msg-mw|immobile-target-namespace}}",
"perfcached": "Like {{msg-mw|perfcachedts}} but used when we do not know how long ago page was cached (unlikely to happen).\n\nParameters:\n* $1 - the max result cut off ($wgQueryCacheLimit)",
"perfcachedts": "Used on pages that list page lists for which the displayed data is cached. Parameters:\n* $1 - a time stamp (date and time combined)\n* $2 - a date (optional)\n* $3 - a time (optional)\n* $4 - the cut off limit for cached results ($wgQueryCacheLimit). If there are more then this many results for the query, only the first $4 of those will be listed on the page. Usually $4 is about 1000.",
"searchrelated": "ආශ්රිත",
"searchall": "සියල්ල",
"showingresults": "#'''$2''' ගෙන් ආරම්භ කොට, {{PLURAL:$1|ප්රතිඵල '''1''' ක් |ප්රතිඵල '''$1''' ක්}} දක්වා පහත පෙන්වා ඇත.",
+ "search-showingresults": "{{PLURAL:$4|ප්රතිඵල <strong>$3</strong> කින් <strong>$1</strong> ක්|ප්රතිඵල <strong>$3</strong> කින් <strong>$1 සිට $2</strong> දක්වා}}",
"search-nonefound": "විමසුම හා ගැලපෙන ප්රතිඵල කිසිවක් නොමැත.",
"powersearch-legend": "වැඩිමනත් ගවේෂණය",
"powersearch-ns": "නාමඅවකාශයන්හි ගවේෂණය කරන්න:",
"recentchanges-label-minor": "මෙය සුළු සංස්කරණයකි",
"recentchanges-label-bot": "මෙය රොබෝවක් විසින් කරන ලද සංස්කරණයකි",
"recentchanges-label-unpatrolled": "මෙම සංස්කරණය තවම විමර්ශනය කර නොමැත",
+ "recentchanges-label-plusminus": "පිටුවේ බයිට ගණන මෙපමණකින් වෙනස් වී ඇත",
"recentchanges-legend-heading": "'''Legend:'''",
"recentchanges-legend-newpage": "{{int:recentchanges-label-newpage}} ([[Special:NewPages|නව පිටු ලැයිස්තුව]] ද බලන්න)",
"rcnotefrom": "'''$2''' න් පසු සිදුවී ඇති වෙනස්කම් මෙහි පහත දැක්වේ ('''$1''' ක ප්රමාණයක උපරිමයක් පෙන්වා ඇත).",
"undelete-show-file-submit": "ඔව්",
"namespace": "නාමඅවකාශය:",
"invert": "තෝරාගැනුම ප්රතිලෝම කරන්න",
+ "tooltip-invert": "තෝරාගත් නාම අවකාශය තුළ ඇති පිටුවල වෙනස්කම් සැඟවීමට මෙම කොටුව ලකුණු කරන්න (ලකුණු කර ඇත්නම් සම්බන්ධ නාම අවකාශයත්)",
"namespace_association": "ආශ්රිත නාම අවකාශය",
+ "tooltip-namespace_association": "තෝරාගත් නාම අවකාශය හා සම්බන්ධ සාකච්ඡා හෝ විෂයය නාම අවකාශය ඇතුළත් කිරීමට මෙම කොටුව ලකුණු කරන්න",
"blanknamespace": "(ප්රධාන)",
"contributions": "{{GENDER:$1|පරිශීලකගේ}} දායකත්වයන්",
"contributions-title": " $1 සඳහා පරිශීලක දායකත්වයන්",
"toc": "Obsah",
"showtoc": "zobraziť",
"hidetoc": "skryť",
- "collapsible-collapse": "zbaliť",
- "collapsible-expand": "rozbaliť",
+ "collapsible-collapse": "skry",
+ "collapsible-expand": "rozbaľ",
"confirmable-confirm": "Ste si {{GENDER:$1|istý|istá|istí}}?",
"confirmable-yes": "Áno",
"confirmable-no": "Nie",
"nov": "Nof",
"dec": "Dis",
"pagecategories": "{{PLURAL:$1|Qeybta|Qeybaha}}",
- "category_header": "Maqaalada ku jirta qeybta \"$1\"",
+ "category_header": "Bogagga ku jira qeybta \"$1\"",
"subcategories": "Qeybaha hoose",
"category-media-header": "Wararka ku jiro qeybta\"$1\"",
"category-empty": "''Qeybtaan hadda wax maqaal ah kuma jirto''",
"watchlistedit-raw-done": "Ваш списак надгледања је ажуриран.",
"watchlistedit-raw-added": "{{PLURAL:$1|1=Додат је један наслов|Додата су $1 наслова|Додато је $1 наслова}}:",
"watchlistedit-raw-removed": "{{PLURAL:$1|1 наслов је уклоњен|Уклоњена су $1 наслова|Уклоњено је $1 наслова}}:",
- "watchlistedit-clear-title": "СпиÑ\81ак надгледаÑ\9aа иÑ\81пÑ\80ажÑ\9aен",
+ "watchlistedit-clear-title": "Ð\9fÑ\80ажÑ\9aеÑ\9aе Ñ\81пиÑ\81ак надгледаÑ\9aа",
"watchlistedit-clear-legend": "Испразни списак надгледања",
"watchlistedit-clear-explain": "Сви наслови ће бити уклоњени из вашег списка надгледања.",
"watchlistedit-clear-titles": "Наслови:",
"import-interwiki-history": "Kopiraj sve verzije istorije za ovu stranicu",
"import-interwiki-templates": "Uključi sve šablone",
"import-interwiki-submit": "Uvezi",
- "import-interwiki-namespace": "Odredišni imenski prostor:",
- "import-interwiki-rootpage": "Odredišna osnovna stranica (neobavezno):",
"import-upload-filename": "Naziv datoteke:",
"import-comment": "Komentar:",
"importtext": "Izvezite datoteku s izvornog vikija koristeći [[Special:Export|izvoz]].\nSačuvajte je na računar i pošaljite ovde.",
"watchlistedit-raw-done": "Vaš spisak nadgledanja je ažuriran.",
"watchlistedit-raw-added": "{{PLURAL:$1|1=Dodat je jedan naslov|Dodata su $1 naslova|Dodato je $1 naslova}}:",
"watchlistedit-raw-removed": "{{PLURAL:$1|1 naslov je uklonjen|Uklonjena su $1 naslova|Uklonjeno je $1 naslova}}:",
- "watchlistedit-clear-title": "Spisak nadgledanja ispražnjen",
+ "watchlistedit-clear-title": "Pražnjenje spisak nadgledanja",
"watchlistedit-clear-legend": "Isprazni spisak nadgledanja",
"watchlistedit-clear-explain": "Svi naslovi će biti uklonjeni iz vašeg spiska nadgledanja.",
"watchlistedit-clear-titles": "Naslovi:",
"history": "Арынның төөгүзү",
"history_short": "Төөгү",
"printableversion": "Саазынга үндүрерин көөрү",
- "permalink": "Турум холбаа",
+ "permalink": "Турум айтыг",
"print": "Саазынга үндүрер",
"view": "Көөрү",
"edit": "Эдер",
"mainpage": "Кол Арын",
"mainpage-description": "Кол Арын",
"policy-url": "Project:Чурум",
- "portal": "Ниитилелдиң хаалгазы",
- "portal-url": "Project:Ниитилелдиң хаалгазы",
+ "portal": "Ниитилел хаалгазы",
+ "portal-url": "Project:Ниитилел хаалгазы",
"privacy": "Актыг бүзүрел дугуржулгазы",
"privacypage": "Project:Актыг бүзүрел дугуржулгазы",
"badaccess": "Алдаг:Эргеңер чок.",
"nstab-user": "Ажыглакчының арыны",
"nstab-media": "Медиа арыны",
"nstab-special": "Тускай арын",
- "nstab-project": "Төлевилелдиң арыны",
+ "nstab-project": "Төлевилел дугайында",
"nstab-image": "Файл",
"nstab-mediawiki": "Чагаа",
"nstab-template": "Майык",
"createaccountreason": "Чылдагаан:",
"badretype": "Силерниң парлаан чажыт сөзүңер таарышпас.",
"userexists": "Силерниң парлаан адыңар амгы үеде ажыглаттынып турар.\nӨске аттан шилип алыңар.",
- "loginerror": "Ð\91агай киÑ\80еÑ\80и",
+ "loginerror": "Ð\9aиÑ\80им алдаа (ЧазÑ\8bглÑ\8bг киÑ\80им)",
"loginsuccesstitle": "Чедимчелиг кирери",
"login-userblocked": "Бо ажыглакчы blocked. Кирери хоржок.",
"password-login-forbidden": "Бо ажыглакчының ады болгаш чажыт сөс хоржок.",
"subject": "Кол сөс:",
"minoredit": "Бо эдилге бичии-дир",
"watchthis": "Бо арынны хайгаараары",
- "savearticle": "Арынны шыгжаары",
+ "savearticle": "Арын шыгжаар",
"preview": "Чижеглей көөрү",
"showpreview": "Чижеглей көөрү",
"showdiff": "Өскерлиишкиннерни көргүзери",
- "anoneditwarning": "'''Кичээңгейлиг!''' Силер сайтче авторжуттунмаан силер.\nБо арынның өскертилге төөгүзүнче Силерниң IP-адрезиңер бижитинип каар.",
+ "anoneditwarning": "<strong>Кичээңгейлиг!</strong> Силер сайтче кирип албаан силер. Чаартылгалар киирер болзуңарза, Силерниң IP-адрезиңер чүүлдүң төөгүзүнге көстүп кээр. Кажан сайтче <strong>[$1 шолаңар-биле кире бээриңерге]</strong> азы <strong>[$2 чаа шола чаяап алырыңарга]</strong>, эдилгеңерни шолаңар-биле холбаап каар база Силерге ажыктыг тускай херекселдер тыптып келир.",
"missingcommenttext": "Тайылбырни адаанда чогаадыңар.",
"summary-preview": "Түңнелдү чижеглей көөрү:",
"subject-preview": "Кол сөс чижеглей көөрү:",
"post-expand-template-inclusion-category": "Кожар майыктарга чөшпээрээн хемчээлин ашкан арыннар",
"post-expand-template-argument-warning": "'''Кичээнгейлиг:''' бо арында тоң дора дээрге (по крайней мере) чаңгыс майыктыг, а ооң аргументизи эмин эрттир улуг калбаяр хемчээлдиг.\nЫндыг чергелиг аргументилерни эрттирип каан.",
"post-expand-template-argument-category": "Аргументилери салдынмаан майыктарлыг '''арыннар'''",
+ "undo-success": "Ук эдилгени ойталап болур. Адаанда янзыларын (версияларын) хынавышаан, тааржыр өскертилгелерни көжүрүп алгаш, оларны арынга шыгжаарда, «Арынны бижидер» деп тананы базыптыңар.",
"viewpagelogs": "Бо арынның журналын көргүзери",
"nohistory": "Бо арынның өскерлиишкин төөгүзү чок.",
"currentrev": "Амгы үе үндүрери",
"email": "Э-чагаа",
"prefs-help-email": "Э-шуудаң адрезин айтыры албан эвес, ынчалза-даа, уруңуңар (парольуңар) чиде бээрге, ол херек апаар.",
"prefs-help-email-others": "Ол харылзаа медээлели база өске киржикчилерге хуу азы чугаалажылга арныңарга э-шуудаңыңар (e-mail) таварыштыр Силерниң-биле харылзажырынга ажыктыг. Ооң кадында Силерниң э-шуудаң адрезиңер кымга-даа көзүлбес.",
- "prefs-info": "Кол медээлер",
+ "prefs-info": "Кол медээлел",
"prefs-signature": "Хол үжүү",
"prefs-diffs": "Ылгалдар",
"editusergroup": "Ажыглакчының бөлгүмнерни өскертири",
"newsectionsummary": "/* $1 */ чаа салбыр",
"rc-enhanced-expand": "Тодаларны көргүзери (JavaScript херек)",
"rc-enhanced-hide": "Тодаларны чажырары",
- "recentchangeslinked": "Хамааржыр өскерлиишкиннер",
- "recentchangeslinked-toolbox": "Хамааржыр өскерлиишкиннер",
+ "recentchangeslinked": "Хамаарышкан өскерилгелер",
+ "recentchangeslinked-toolbox": "Хамаарышкан өскерилгелер",
"recentchangeslinked-title": "«$1» деп арынга хамаарыштырган өскерлиишкиннер",
"recentchangeslinked-summary": "Айыткан арынның (азы айыткан аңгылалга хамаарышкан) шөлүлүглериниң чедер арыннарнының чаа өскерилгер даңзызы.\n[[Special:Watchlist|Силерниң хайгаарал даңзызынче]] кирип турар арыннарны '''ылгап каан'''.",
"recentchangeslinked-page": "Арынның ады:",
"tooltip-pt-login": "Маңаа системаже киир бүрүткенип болур, ынчалза-даа ол албан эвес.",
"tooltip-pt-logout": "Үнери",
"tooltip-ca-talk": "Бо арын дугайында чыгаалажыры",
- "tooltip-ca-edit": "СилеÑ\80 бо аÑ\80Ñ\8bннÑ\8b Ñ\8dдип болÑ\83Ñ\80. ШÑ\8bгжааÑ\80 мÑ\83Ñ\80Ñ\83нда Ñ\87ижеглеп көÑ\80ем.",
+ "tooltip-ca-edit": "Ук аÑ\80Ñ\8bннÑ\8b Ñ\8dдип болÑ\83Ñ\80 Ñ\81илеÑ\80. ÐдилгеңеÑ\80 бижидеÑ\80ин беÑ\80Ñ\82инде Ñ\87ижеглей көөÑ\80үн Ñ\83Ñ\82паңаÑ\80.",
"tooltip-ca-addsection": "Чаа салбыр чаяар",
"tooltip-ca-viewsource": "Бо арын камгалаттырган.\nДөзү кодун көрүп болур силер.",
"tooltip-ca-history": "Арынның мурнуку өскерлиишкиннери",
"tooltip-t-upload": "Файлдарны киирери",
"tooltip-t-specialpages": "Шупту тускай арыннар даңзызы",
"tooltip-t-print": "Бо арынның парлаттынар хевири",
- "tooltip-t-permalink": "Ð\90Ñ\80Ñ\8bннÑ\8bÒ£ бо Ñ\8fнзÑ\8b-Ñ\85евиÑ\80иниң Ñ\82Ñ\83Ñ\80Ñ\83м Ñ\88өлүлгези",
+ "tooltip-t-permalink": "Ук аÑ\80Ñ\8bннÑ\8bÒ£ амгÑ\8b Ñ\8fнзÑ\8bзÑ\8bнÑ\8bÒ£ Ñ\82Ñ\83Ñ\80Ñ\83м айÑ\82Ñ\8bÑ\8b",
"tooltip-ca-nstab-main": "Допчы арынын көөрү",
"tooltip-ca-nstab-user": "Ажыглакчының арынын көөрү",
"tooltip-ca-nstab-media": "Медиа арынын көөрү",
"tooltip-undo": "Киирген эдигни казааш, ойталалдың чылдагаанын айтыр аргалыг мурнай көргүзүүн көргүзер.",
"tooltip-summary": "Кысказы-биле бижиңер",
"anonymous": "{{grammar:genitive|{{SITENAME}}}} адыжок {{PLURAL:$1|киржикчизи}}",
- "pageinfo-toolboxlink": "Арын дугайында медээлел",
+ "pageinfo-title": "«$1» дугайында",
+ "pageinfo-header-basic": "Кол медээлел",
+ "pageinfo-toolboxlink": "Арын дугайында",
"filedelete-missing": "«$1» деп файл чок, ынчангаш ол ап калдынмас.",
"previousdiff": "← Артык эрги үндүрери",
"nextdiff": "Артык чаа үндүрери →",
"history-feed-description": "本 Wiki 上此頁面的修訂歷史",
"history-feed-item-nocomment": "$1 於 $2",
"history-feed-empty": "請求的頁面不存在,\n可能已被刪除或重新命名。\n請嘗試 [[Special:Search|搜尋本站]] 取得其他相關的新頁面。",
+ "history-edit-tags": "編輯已選擇修訂的標籤",
"rev-deleted-comment": "(已移除編輯摘要)",
"rev-deleted-user": " (已移除使用者名稱)",
"rev-deleted-event": "(已移除日誌明細)",
"rev-showdeleted": "顯示",
"revisiondelete": "刪除/取消刪除修訂",
"revdelete-nooldid-title": "無效的目標修訂",
- "revdelete-nooldid-text": "您尚未指定目標修訂執行此動作、指定的修訂不存在,或您嘗試隱藏目前的修訂。",
+ "revdelete-nooldid-text": "您沒有指定任何要執行此功能的目標修訂、或指定的修訂並不存在、或您嘗試隱藏目前的修訂。",
"revdelete-no-file": "指定的檔案不存在。",
"revdelete-show-file-confirm": "您是否要檢視檔案 \"<nowiki>$1</nowiki>\" 已刪除的修訂於 $2 $3?",
"revdelete-show-file-submit": "是",
"right-sendemail": "傳送電子郵件聯絡其他使用者",
"right-passwordreset": "檢視重設密碼電子郵件",
"right-managechangetags": "建立並自資料庫移除[[Special:Tags|標籤]]",
+ "right-applychangetags": "連同某個人的變更一起套用[[Special:Tags|標籤]]",
+ "right-changetags": "加入與移除任何於各別修訂與日誌項目的[[Special:Tags|標籤]]",
"newuserlogpage": "建立使用者日誌",
"newuserlogpagetext": "此為建立使用者的日誌。",
"rightslog": "使用者權限日誌",
"action-editmyprivateinfo": "編輯您的個人資訊",
"action-editcontentmodel": "編輯頁面的內容模型",
"action-managechangetags": "建立並自資料庫移除標籤",
+ "action-applychangetags": "連同您的變更一起套用標籤",
+ "action-changetags": "加入與移除任何於各別修訂與日誌項目的標籤",
"nchanges": "$1 次變更",
"enhancedrc-since-last-visit": "{{PLURAL:$1|自上次拜訪}}已有 $1",
"enhancedrc-history": "歷史",
"listfiles-delete": "刪除",
"listfiles-summary": "此特殊頁面顯示所有已上傳的檔案。",
"listfiles_search_for": "搜尋媒體名稱:",
+ "listfiles-userdoesnotexist": "使用者帳號 \"$1\" 尚未被註冊。",
"imgfile": "檔案",
"listfiles": "檔案清單",
"listfiles_thumb": "縮圖",
"logempty": "無符合條件的日誌。",
"log-title-wildcard": "搜尋以此欄位文字為字首的標題",
"showhideselectedlogentries": "顯示/隱藏已選擇的日誌項目",
+ "log-edit-tags": "編輯已選擇日誌項目的標籤",
"allpages": "所有頁面",
"nextpage": "下一頁 ($1)",
"prevpage": "上一頁 ($1)",
"emailuser": "Email 聯絡此使用者",
"emailuser-title-target": "E-mail 聯絡此{{GENDER:$1|使用者}}",
"emailuser-title-notarget": "E-mail 聯絡使用者",
- "emailpage": "E-mail 給使用者",
+ "emailpage": "E-mail 聯絡使用者",
"emailpagetext": "您可以使用以下表格傳送電子郵件給這位 {{Gender:$1|使用者}}。\n您在 [[Special:Preferences|偏好設定]] 中所輸入的電子郵件位址將會作為郵件的 \"寄件人\",因此該使用者可直接回覆您。",
"defemailsubject": "{{SITENAME}} 使用者 \"$1\" 寄來的電子郵件",
"usermaildisabled": "使用者電子郵件已停用",
"emailccsubject": "您寄給 $1 的訊息副本:$2",
"emailsent": "已寄出電子郵件",
"emailsenttext": "已寄出您的電子郵件訊息。",
- "emailuserfooter": "這封電子郵件是由 $1 透過 {{SITENAME}} 的 \"Email 聯絡此使用者\" 功能寄給 $2。",
+ "emailuserfooter": "這封電子郵件是由 $1 透過 {{SITENAME}} 的 \"{{int:emailpage}}\" 功能寄給 $2。",
"usermessage-summary": "留訊息至系統。",
"usermessage-editor": "系統訊息",
"watchlist": "監視清單",
"import-interwiki-history": "複製此頁的所有歷史修訂",
"import-interwiki-templates": "包含所有模板",
"import-interwiki-submit": "匯入",
+ "import-mapping-default": "匯入至預設位置",
+ "import-mapping-namespace": "匯入至命名空間:",
+ "import-mapping-subpage": "匯入做為以下頁面的子頁面:",
"import-upload-filename": "檔案名稱:",
"import-comment": "評論:",
"importtext": "請使用 [[Special:Export|匯出工具]] 從來源 Wiki 匯出檔案,\n儲存至您的電腦後再上傳到這裡。",
"pageinfo-protect-cascading-yes": "是",
"pageinfo-protect-cascading-from": "連鎖保護來自",
"pageinfo-category-info": "分類資訊",
+ "pageinfo-category-total": "成員總數",
"pageinfo-category-pages": "頁面數量",
"pageinfo-category-subcats": "子分類數量",
"pageinfo-category-files": "檔案數量",
"patrol-log-page": "巡查日誌",
"patrol-log-header": "這是已巡查的修訂版本的日誌。",
"log-show-hide-patrol": "$1 巡查日誌",
+ "log-show-hide-tag": "$1 標籤日誌",
"deletedrevision": "已刪除舊修訂 $1",
"filedeleteerror-short": "刪除檔案發生錯誤:$1",
"filedeleteerror-long": "刪除檔案時發生錯誤:\n\n$1",
"tags-deactivate-reason": "原因:",
"tags-deactivate-not-allowed": "無法停用標籤 \"$1\"。",
"tags-deactivate-submit": "停用",
+ "tags-apply-no-permission": "您沒有權限連同您的變更一起套用標籤。",
+ "tags-apply-not-allowed-one": "不允許手動套用標籤 \"$1\"。",
+ "tags-apply-not-allowed-multi": "不允許手動套用以下{{PLURAL:$2|標籤|標籤}}:$1",
+ "tags-update-no-permission": "您沒有權限加入與移除任何於各別修訂與日誌項目的標籤",
+ "tags-update-add-not-allowed-one": "不允許手動加入標籤 \"$1\"。",
+ "tags-update-add-not-allowed-multi": "不允許手動加入以下{{PLURAL:$2|標籤|標籤}}:$1",
+ "tags-update-remove-not-allowed-one": "不允許手動移除標籤 \"$1\"。",
+ "tags-update-remove-not-allowed-multi": "不允許手動移除以下{{PLURAL:$2|標籤|標籤}}:$1",
+ "tags-edit-title": "編輯標籤",
+ "tags-edit-manage-link": "管理標籤",
+ "tags-edit-revision-selected": "已選擇 [[:$2]] 中{{PLURAL:$1|的修訂|的多筆修訂}}:",
+ "tags-edit-logentry-selected": "{{PLURAL:$1|已選擇日誌項目|已選擇日誌項目}}:",
+ "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-new-tags": "新標籤:",
+ "tags-edit-add": "加入這些標籤:",
+ "tags-edit-remove": "移除這些標籤:",
+ "tags-edit-remove-all-tags": "(移除所有標籤)",
+ "tags-edit-chosen-placeholder": "選擇一些標籤",
+ "tags-edit-chosen-no-results": "沒有符合條件的標籤",
+ "tags-edit-reason": "原因:",
+ "tags-edit-revision-submit": "套用變更至{{PLURAL:$1|此修訂|$1 筆修訂}}",
+ "tags-edit-logentry-submit": "套用變更至{{PLURAL:$1|此日誌項目|$1 筆日誌項目}}",
+ "tags-edit-success": "已成功套用變更。",
+ "tags-edit-failure": "變更被無法套用:\n$1",
+ "tags-edit-nooldid-title": "無效的目標修訂",
+ "tags-edit-nooldid-text": "您沒有指定任何要執行此功能的目標修訂或指定的修訂並不存在。",
+ "tags-edit-none-selected": "請至少選擇一個要加入或移除的標籤。",
"comparepages": "比較頁面",
"compare-page1": "第 1 頁",
"compare-page2": "第 2 頁",
"logentry-managetags-delete": "$1 {{GENDER:$2|已刪除}}標籤 \"$4\" (已自 $5 個{{PLURAL:$5|修訂或日誌|修訂或日誌}}中移除)",
"logentry-managetags-activate": "$1 {{GENDER:$2|已啟用}}標籤 \"$4\" 供使用者與機器人使用",
"logentry-managetags-deactivate": "$1 {{GENDER:$2|已停用}}標籤 \"$4\" 供使用者與機器人使用",
+ "log-name-tag": "標籤日誌",
+ "log-description-tag": "當使用者自各別修訂或日誌項目加入或移除[[Special:Tags|標籤]]時會顯示於此頁面。 此日誌並不會列出當時對標籤所做的編輯、刪除或類似的動作。",
+ "logentry-tag-update-add-revision": "$1 {{GENDER:$2|已加入}}{{PLURAL:$7|標籤|標籤}} $6 至頁面 $3 的修訂 $4。",
+ "logentry-tag-update-add-logentry": "$1 {{GENDER:$2|已加入}}{{PLURAL:$7|標籤|標籤}} $6 至頁面 $3 的日誌項目 $5。",
+ "logentry-tag-update-remove-revision": "$1 {{GENDER:$2|已移除}}{{PLURAL:$9|標籤|標籤}} $8 自頁面 $3 的修訂 $4。",
+ "logentry-tag-update-remove-logentry": "$1 {{GENDER:$2|已移除}}{{PLURAL:$9|標籤|標籤}} $8 自日誌項目 $3 的修訂 $5。",
+ "logentry-tag-update-revision": "$1 {{GENDER:$2|已更新}}標籤於頁面 $3 的修訂 $4 ({{PLURAL:$7|加入}} $6; {{PLURAL:$9|移除}} $8)。",
+ "logentry-tag-update-logentry": "$1 {{GENDER:$2|已更新}}標籤於頁面 $3 的日誌項目 $5 ({{PLURAL:$7|加入}} $6; {{PLURAL:$9|移除}} $8)。",
"rightsnone": "(無)",
"revdelete-summary": "編輯摘要",
"feedback-adding": "正在新增意見回饋至頁面...",
"feedback-error1": "錯誤:無法識別 API 回傳的結果",
"feedback-error2": "錯誤:編輯失敗",
"feedback-error3": "錯誤:API 沒有回應",
+ "feedback-error4": "錯誤:無法發佈至指定的意見回饋標題",
"feedback-message": "訊息:",
"feedback-subject": "主旨:",
"feedback-submit": "送出",
"log-name-pagelang": "更改語言日誌",
"log-description-pagelang": "此頁為頁面語言的變更日誌。",
"logentry-pagelang-pagelang": "$1 {{GENDER:$2|已更改}}頁面 $3 的語言從 $4 到 $5。",
- "default-skin-not-found": "哎呀!您於 <code dir=\"ltr\">$wgDefaultSkin</code> 設定的 Wiki 預設外觀 <code>$1</code> 無法使用。\n\n您的安裝程序應包含以下{{PLURAL:$4|外觀}}。請參考 [https://www.mediawiki.org/wiki/Manual:Skin_configuration 操作手冊:外觀設定] 以取得如何{{PLURAL:$4|開啟外觀並設為預設值}}的資訊。\n\n$2\n\n; 若您才剛安裝完 MediaWiki:\n: 您大概是使用 git 或直接透過原始碼使用其他方法安裝,這種情況是正常的。請嘗試安裝 [https://www.mediawiki.org/wiki/Category:All_skins mediawiki.org 的外觀目錄] 中的部份外觀使用以下方式:\n:* 下載 [https://www.mediawiki.org/wiki/Special:MyLanguage/Download tarball 安裝程式],該程式包含數個外觀與擴充套件。您可以複製並貼上至 <code>skins/</code> 目錄。\n:* 自 [https://www.mediawiki.org/wiki/Special:SkinDistributor mediawiki.org] 下載個別外觀 tarball。\n:* 透過 git 複製 <code>mediawiki/skins/*</code> 儲存庫中其中一個外觀到您安裝的 MediaWiki <code dir=\"ltr\">skins/</code> 目錄中。\n: 若您是 MediaWiki 的開發人員,這麼做應該不會影響到您的 git 儲存庫。\n\n; 若您才剛升級 MediaWiki:\n: MediaWiki 1.24 與較新的版本不再自動開啟已安裝的外觀 (請參考 [https://www.mediawiki.org/wiki/Manual:Skin_autodiscovery 操作手冊:外觀自動搜尋])。您可以將下{{PLURAL:$5|列行}}貼上至 <code>LocalSettings.php</code> 來開啟{{PLURAL:$5|所有}}目前已經安裝的{{PLURAL:$5|外觀}}:\n\n<pre dir=\"ltr\">$3</pre>\n\n; 若您才剛修改 <code>LocalSettings.php</code>:\n: 請再次確認您輸入的外觀名稱是否有誤。",
+ "default-skin-not-found": "哎呀!您於 <code dir=\"ltr\">$wgDefaultSkin</code> 設定的 Wiki 預設外觀 <code>$1</code> 無法使用。\n\n您的安裝程序應包含以下{{PLURAL:$4|外觀}}。請參考 [https://www.mediawiki.org/wiki/Manual:Skin_configuration 操作手冊:外觀設定] 以取得如何{{PLURAL:$4|開啟外觀並設為預設值}}的資訊。\n\n$2\n\n; 若您才剛安裝完 MediaWiki:\n: 您大概是使用 git 或直接透過原始碼使用其他方法安裝,這種情況是正常的。請嘗試安裝 [https://www.mediawiki.org/wiki/Category:All_skins mediawiki.org 的外觀目錄] 中的部份外觀使用以下方式:\n:* 下載 [https://www.mediawiki.org/wiki/Special:MyLanguage/Download tarball 安裝程式],該程式包含數個外觀與擴充套件。您可以複製並貼上至 <code>skins/</code> 目錄。\n:* 自 [https://www.mediawiki.org/wiki/Special:SkinDistributor mediawiki.org] 下載個別外觀 tarball。\n:* 透過 git 複製 <code>mediawiki/skins/*</code> 儲存庫中其中一個外觀到您安裝的 MediaWiki <code dir=\"ltr\">skins/</code> 目錄中。\n: 若您是 MediaWiki 的開發人員,這麼做應該不會影響到您的 git 儲存庫。\n\n; 若您才剛升級 MediaWiki:\n: MediaWiki 1.24 與較新的版本不再自動開啟已安裝的外觀 (請參考 [https://www.mediawiki.org/wiki/Manual:Skin_autodiscovery 操作手冊:外觀自動搜尋])。您可以將下列{{PLURAL:$5|行}}貼上至 <code>LocalSettings.php</code> 來開啟{{PLURAL:$5|所有}}目前已經安裝的{{PLURAL:$5|外觀}}:\n\n<pre dir=\"ltr\">$3</pre>\n\n; 若您才剛修改 <code>LocalSettings.php</code>:\n: 請再次確認您輸入的外觀名稱是否有誤。",
"default-skin-not-found-no-skins": "哎呀!您於 <code>$wgDefaultSkin</code> 設定的 Wiki 預設外觀 <code>$1</code> 無法使用。\n\n您未安裝任何的外觀。\n\n; 若您才剛安裝完或升級完 MediaWiki:\n: 您大概是使用 git 或直接透過原始碼使用其他方法安裝,這種情況是正常的。 MediaWiki 1.24 或較新的版本在主要儲存庫中不再包含任何的外觀。 請嘗試安裝 [https://www.mediawiki.org/wiki/Category:All_skins mediawiki.org 的外觀目錄] 中的部份外觀使用以下方式:\n:* 下載 [https://www.mediawiki.org/wiki/Special:MyLanguage/Download tarball 安裝程式],該程式包含數個外觀與擴充套件。 您可以複製並貼上至 <code>skins/</code> 目錄。\n:* 自 [https://www.mediawiki.org/wiki/Special:SkinDistributor mediawiki.org] 下載個別外觀 tarball。\n:* 透過 git 複製 <code>mediawiki/skins/*</code> 儲存庫中其中一個外觀到您安裝的 MediaWiki <code dir=\"ltr\">skins/</code> 目錄中。\n: 若您是 MediaWiki 的開發人員,這麼做應該不會影響到您的 git 儲存庫。 請參考 [https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:Skin_configuration 操作手冊:外觀設定] 以取得如何開啟外觀並設為預設值的資訊。",
"default-skin-not-found-row-enabled": "* <code>$1</code> / $2 (已開啟)",
"default-skin-not-found-row-disabled": "* <code>$1</code> / $2 ('''已停用''')",
+++ /dev/null
-<?php
-/** Bihari (भोजपुरी)
- *
- * To improve a translation please visit https://translatewiki.net
- *
- * @ingroup Language
- * @file
- *
- */
-
-$fallback = 'bho';
-
hasOwn = Object.prototype.hasOwnProperty,
slice = Array.prototype.slice,
trackCallbacks = $.Callbacks( 'memory' ),
+ trackHandlers = [],
trackQueue = [];
/**
*/
trackSubscribe: function ( topic, callback ) {
var seen = 0;
-
- trackCallbacks.add( function ( trackQueue ) {
+ function handler( trackQueue ) {
var event;
for ( ; seen < trackQueue.length; seen++ ) {
event = trackQueue[ seen ];
callback.call( event, event.topic, event.data );
}
}
+ }
+
+ trackHandlers.push( [ handler, callback ] );
+
+ trackCallbacks.add( handler );
+ },
+
+ /**
+ * Stop handling events for a particular handler
+ *
+ * @param {Function} callback
+ */
+ trackUnsubscribe: function ( callback ) {
+ trackHandlers = $.grep( trackHandlers, function ( fns ) {
+ if ( fns[1] === callback ) {
+ trackCallbacks.remove( fns[0] );
+ // Ensure the tuple is removed to avoid holding on to closures
+ return false;
+ }
+ return true;
} );
},
# tests/phpunit/includes/diff
'FakeDiffOp' => "$testDir/phpunit/includes/diff/FakeDiffOp.php",
+ # tests/phpunit/includes/logging
+ 'LogFormatterTestCase' => "$testDir/phpunit/includes/logging/LogFormatterTestCase.php",
+
# tests/phpunit/includes/password
'PasswordTestCase' => "$testDir/phpunit/includes/password/PasswordTestCase.php",
public static function provideInvalidSecureAndSplit() {
return array(
- array( '' ),
- array( ':' ),
- array( '__ __' ),
- array( ' __ ' ),
+ array( '', 'title-invalid-empty' ),
+ array( ':', 'title-invalid-empty' ),
+ array( '__ __', 'title-invalid-empty' ),
+ array( ' __ ', 'title-invalid-empty' ),
// Bad characters forbidden regardless of wgLegalTitleChars
- array( 'A [ B' ),
- array( 'A ] B' ),
- array( 'A { B' ),
- array( 'A } B' ),
- array( 'A < B' ),
- array( 'A > B' ),
- array( 'A | B' ),
+ array( 'A [ B', 'title-invalid-characters' ),
+ array( 'A ] B', 'title-invalid-characters' ),
+ array( 'A { B', 'title-invalid-characters' ),
+ array( 'A } B', 'title-invalid-characters' ),
+ array( 'A < B', 'title-invalid-characters' ),
+ array( 'A > B', 'title-invalid-characters' ),
+ array( 'A | B', 'title-invalid-characters' ),
// URL encoding
- array( 'A%20B' ),
- array( 'A%23B' ),
- array( 'A%2523B' ),
+ array( 'A%20B', 'title-invalid-characters' ),
+ array( 'A%23B', 'title-invalid-characters' ),
+ array( 'A%2523B', 'title-invalid-characters' ),
// XML/HTML character entity references
// Note: Commented out because they are not marked invalid by the PHP test as
// Title::newFromText runs Sanitizer::decodeCharReferencesAndNormalize first.
//'A é B',
//'A é B',
// Subject of NS_TALK does not roundtrip to NS_MAIN
- array( 'Talk:File:Example.svg' ),
+ array( 'Talk:File:Example.svg', 'title-invalid-talk-namespace' ),
// Directory navigation
- array( '.' ),
- array( '..' ),
- array( './Sandbox' ),
- array( '../Sandbox' ),
- array( 'Foo/./Sandbox' ),
- array( 'Foo/../Sandbox' ),
- array( 'Sandbox/.' ),
- array( 'Sandbox/..' ),
+ array( '.', 'title-invalid-relative' ),
+ array( '..', 'title-invalid-relative' ),
+ array( './Sandbox', 'title-invalid-relative' ),
+ array( '../Sandbox', 'title-invalid-relative' ),
+ array( 'Foo/./Sandbox', 'title-invalid-relative' ),
+ array( 'Foo/../Sandbox', 'title-invalid-relative' ),
+ array( 'Sandbox/.', 'title-invalid-relative' ),
+ array( 'Sandbox/..', 'title-invalid-relative' ),
// Tilde
- array( 'A ~~~ Name' ),
- array( 'A ~~~~ Signature' ),
- array( 'A ~~~~~ Timestamp' ),
- array( str_repeat( 'x', 256 ) ),
+ array( 'A ~~~ Name', 'title-invalid-magic-tilde' ),
+ array( 'A ~~~~ Signature', 'title-invalid-magic-tilde' ),
+ array( 'A ~~~~~ Timestamp', 'title-invalid-magic-tilde' ),
+ // Length
+ array( str_repeat( 'x', 256 ), 'title-invalid-too-long' ),
// Namespace prefix without actual title
- array( 'Talk:' ),
- array( 'Talk:#' ),
- array( 'Category: ' ),
- array( 'Category: #bar' ),
+ array( 'Talk:', 'title-invalid-empty' ),
+ array( 'Talk:#', 'title-invalid-empty' ),
+ array( 'Category: ', 'title-invalid-empty' ),
+ array( 'Category: #bar', 'title-invalid-empty' ),
// interwiki prefix
- array( 'localtestiw: Talk: # anchor' ),
- array( 'localtestiw: Talk:' )
+ array( 'localtestiw: Talk: # anchor', 'title-invalid-empty' ),
+ array( 'localtestiw: Talk:', 'title-invalid-empty' )
);
}
* @dataProvider provideInvalidSecureAndSplit
* @note This mainly tests MediaWikiTitleCodec::parseTitle().
*/
- public function testSecureAndSplitInvalid( $text ) {
+ public function testSecureAndSplitInvalid( $text, $expectedErrorMessage ) {
$this->secureAndSplitGlobals();
- $this->assertNull( Title::newFromText( $text ), "Invalid: $text" );
+ try {
+ Title::newFromTextThrow( $text ); // should throw
+ $this->assertTrue( false, "Invalid: $text" );
+ } catch ( MalformedTitleException $ex ) {
+ $this->assertEquals( $expectedErrorMessage, $ex->getErrorMessage(), "Invalid: $text" );
+ }
}
public static function provideConvertByteClassToUnicodeClass() {
),
$this->user_comment
);
+ # block/block - legacy
+ $this->assertIRCComment(
+ $this->context->msg( 'blocklogentry', 'SomeTitle', 'duration', '(flags)' )->plain()
+ . $sep . $this->user_comment,
+ 'block', 'block',
+ array(
+ 'duration',
+ 'flags',
+ ),
+ $this->user_comment,
+ '',
+ true
+ );
# block/unblock
$this->assertIRCComment(
$this->context->msg( 'unblocklogentry', 'SomeTitle' )->plain() . $sep . $this->user_comment,
* @param string $msg (optional) A message for PHPUnit :-)
*/
protected function assertIRCComment( $expected, $type, $action, $params,
- $comment = null, $msg = ''
+ $comment = null, $msg = '', $legacy = false
) {
$logEntry = new ManualLogEntry( $type, $action );
$logEntry->setPerformer( $this->user );
$logEntry->setComment( $comment );
}
$logEntry->setParameters( $params );
+ $logEntry->setLegacy( $legacy );
$formatter = LogFormatter::newFromEntry( $logEntry );
$formatter->setContext( $this->context );
--- /dev/null
+<?php
+
+class BlockLogFormatterTest extends LogFormatterTestCase {
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideBlockLogDatabaseRows() {
+ return array(
+ // Current log format
+ array(
+ array(
+ 'type' => 'block',
+ 'action' => 'block',
+ 'comment' => 'Block comment',
+ 'user' => 0,
+ 'user_text' => 'Sysop',
+ 'namespace' => NS_USER,
+ 'title' => 'Logtestuser',
+ 'params' => array(
+ '5::duration' => 'infinite',
+ '6::flags' => 'anononly',
+ ),
+ ),
+ array(
+ 'text' => 'Sysop blocked Logtestuser with an expiry time of indefinite (anonymous users only)',
+ 'api' => array(
+ 'duration' => 'infinite',
+ 'flags' => array( 'anononly' ),
+ ),
+ ),
+ ),
+
+ // Old legacy log
+ array(
+ array(
+ 'type' => 'block',
+ 'action' => 'block',
+ 'comment' => 'Block comment',
+ 'user' => 0,
+ 'user_text' => 'Sysop',
+ 'namespace' => NS_USER,
+ 'title' => 'Logtestuser',
+ 'params' => array(
+ 'infinite',
+ 'anononly',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'Sysop blocked Logtestuser with an expiry time of indefinite (anonymous users only)',
+ 'api' => array(
+ 'duration' => 'infinite',
+ 'flags' => array( 'anononly' ),
+ ),
+ ),
+ ),
+
+ // Old legacy log without flag
+ array(
+ array(
+ 'type' => 'block',
+ 'action' => 'block',
+ 'comment' => 'Block comment',
+ 'user' => 0,
+ 'user_text' => 'Sysop',
+ 'namespace' => NS_USER,
+ 'title' => 'Logtestuser',
+ 'params' => array(
+ 'infinite',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'Sysop blocked Logtestuser with an expiry time of indefinite',
+ 'api' => array(
+ 'duration' => 'infinite',
+ 'flags' => array(),
+ ),
+ ),
+ ),
+
+ // Very old legacy log without duration
+ array(
+ array(
+ 'type' => 'block',
+ 'action' => 'block',
+ 'comment' => 'Block comment',
+ 'user' => 0,
+ 'user_text' => 'Sysop',
+ 'namespace' => NS_USER,
+ 'title' => 'Logtestuser',
+ 'params' => array(),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'Sysop blocked Logtestuser with an expiry time of indefinite',
+ 'api' => array(
+ 'duration' => 'infinite',
+ 'flags' => array(),
+ ),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideBlockLogDatabaseRows
+ */
+ public function testBlockLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideReblockLogDatabaseRows() {
+ return array(
+ // Current log format
+ array(
+ array(
+ 'type' => 'block',
+ 'action' => 'reblock',
+ 'comment' => 'Block comment',
+ 'user' => 0,
+ 'user_text' => 'Sysop',
+ 'namespace' => NS_USER,
+ 'title' => 'Logtestuser',
+ 'params' => array(
+ '5::duration' => 'infinite',
+ '6::flags' => 'anononly',
+ ),
+ ),
+ array(
+ 'text' => 'Sysop changed block settings for Logtestuser with an expiry time of'
+ . ' indefinite (anonymous users only)',
+ 'api' => array(
+ 'duration' => 'infinite',
+ 'flags' => array( 'anononly' ),
+ ),
+ ),
+ ),
+
+ // Old log
+ array(
+ array(
+ 'type' => 'block',
+ 'action' => 'reblock',
+ 'comment' => 'Block comment',
+ 'user' => 0,
+ 'user_text' => 'Sysop',
+ 'namespace' => NS_USER,
+ 'title' => 'Logtestuser',
+ 'params' => array(
+ 'infinite',
+ 'anononly',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'Sysop changed block settings for Logtestuser with an expiry time of'
+ . ' indefinite (anonymous users only)',
+ 'api' => array(
+ 'duration' => 'infinite',
+ 'flags' => array( 'anononly' ),
+ ),
+ ),
+ ),
+
+ // Older log without flag
+ array(
+ array(
+ 'type' => 'block',
+ 'action' => 'reblock',
+ 'comment' => 'Block comment',
+ 'user' => 0,
+ 'user_text' => 'Sysop',
+ 'namespace' => NS_USER,
+ 'title' => 'Logtestuser',
+ 'params' => array(
+ 'infinite',
+ )
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'Sysop changed block settings for Logtestuser with an expiry time of indefinite',
+ 'api' => array(
+ 'duration' => 'infinite',
+ 'flags' => array(),
+ ),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideReblockLogDatabaseRows
+ */
+ public function testReblockLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideUnblockLogDatabaseRows() {
+ return array(
+ // Current log format
+ array(
+ array(
+ 'type' => 'block',
+ 'action' => 'unblock',
+ 'comment' => 'Block comment',
+ 'user' => 0,
+ 'user_text' => 'Sysop',
+ 'namespace' => NS_USER,
+ 'title' => 'Logtestuser',
+ 'params' => array(),
+ ),
+ array(
+ 'text' => 'Sysop unblocked Logtestuser',
+ 'api' => array(),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideUnblockLogDatabaseRows
+ */
+ public function testUnblockLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideSuppressBlockLogDatabaseRows() {
+ return array(
+ // Current log format
+ array(
+ array(
+ 'type' => 'suppress',
+ 'action' => 'block',
+ 'comment' => 'Block comment',
+ 'user' => 0,
+ 'user_text' => 'Sysop',
+ 'namespace' => NS_USER,
+ 'title' => 'Logtestuser',
+ 'params' => array(
+ '5::duration' => 'infinite',
+ '6::flags' => 'anononly',
+ ),
+ ),
+ array(
+ 'text' => 'Sysop blocked Logtestuser with an expiry time of indefinite (anonymous users only)',
+ 'api' => array(
+ 'duration' => 'infinite',
+ 'flags' => array( 'anononly' ),
+ ),
+ ),
+ ),
+
+ // legacy log
+ array(
+ array(
+ 'type' => 'suppress',
+ 'action' => 'block',
+ 'comment' => 'Block comment',
+ 'user' => 0,
+ 'user_text' => 'Sysop',
+ 'namespace' => NS_USER,
+ 'title' => 'Logtestuser',
+ 'params' => array(
+ 'infinite',
+ 'anononly',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'Sysop blocked Logtestuser with an expiry time of indefinite (anonymous users only)',
+ 'api' => array(
+ 'duration' => 'infinite',
+ 'flags' => array( 'anononly' ),
+ ),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideSuppressBlockLogDatabaseRows
+ */
+ public function testSuppressBlockLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideSuppressReblockLogDatabaseRows() {
+ return array(
+ // Current log format
+ array(
+ array(
+ 'type' => 'suppress',
+ 'action' => 'reblock',
+ 'comment' => 'Block comment',
+ 'user' => 0,
+ 'user_text' => 'Sysop',
+ 'namespace' => NS_USER,
+ 'title' => 'Logtestuser',
+ 'params' => array(
+ '5::duration' => 'infinite',
+ '6::flags' => 'anononly',
+ ),
+ ),
+ array(
+ 'text' => 'Sysop changed block settings for Logtestuser with an expiry time of'
+ . ' indefinite (anonymous users only)',
+ 'api' => array(
+ 'duration' => 'infinite',
+ 'flags' => array( 'anononly' ),
+ ),
+ ),
+ ),
+
+ // Legacy format
+ array(
+ array(
+ 'type' => 'suppress',
+ 'action' => 'reblock',
+ 'comment' => 'Block comment',
+ 'user' => 0,
+ 'user_text' => 'Sysop',
+ 'namespace' => NS_USER,
+ 'title' => 'Logtestuser',
+ 'params' => array(
+ 'infinite',
+ 'anononly',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'Sysop changed block settings for Logtestuser with an expiry time of'
+ . ' indefinite (anonymous users only)',
+ 'api' => array(
+ 'duration' => 'infinite',
+ 'flags' => array( 'anononly' ),
+ ),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideSuppressReblockLogDatabaseRows
+ */
+ public function testSuppressReblockLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+}
--- /dev/null
+<?php
+
+class DeleteLogFormatterTest extends LogFormatterTestCase {
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideDeleteLogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'delete',
+ 'action' => 'delete',
+ 'comment' => 'delete comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(),
+ ),
+ array(
+ 'text' => 'User deleted page Page',
+ 'api' => array(),
+ ),
+ ),
+
+ // Legacy format
+ array(
+ array(
+ 'type' => 'delete',
+ 'action' => 'delete',
+ 'comment' => 'delete comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'User deleted page Page',
+ 'api' => array(),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideDeleteLogDatabaseRows
+ */
+ public function testDeleteLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideRestoreLogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'delete',
+ 'action' => 'restore',
+ 'comment' => 'delete comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(),
+ ),
+ array(
+ 'text' => 'User restored page Page',
+ 'api' => array(),
+ ),
+ ),
+
+ // Legacy format
+ array(
+ array(
+ 'type' => 'delete',
+ 'action' => 'restore',
+ 'comment' => 'delete comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'User restored page Page',
+ 'api' => array(),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideRestoreLogDatabaseRows
+ */
+ public function testRestoreLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideRevisionLogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'delete',
+ 'action' => 'revision',
+ 'comment' => 'delete comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(
+ '4::type' => 'archive',
+ '5::ids' => array( '1', '3', '4' ),
+ '6::ofield' => '1',
+ '7::nfield' => '2',
+ ),
+ ),
+ array(
+ 'text' => 'User changed visibility of 3 revisions on page Page: edit summary '
+ . 'hidden and content unhidden',
+ 'api' => array(
+ 'type' => 'archive',
+ 'ids' => array( '1', '3', '4' ),
+ 'old' => array(
+ 'bitmask' => 1,
+ 'content' => true,
+ 'comment' => false,
+ 'user' => false,
+ 'restricted' => false,
+ ),
+ 'new' => array(
+ 'bitmask' => 2,
+ 'content' => false,
+ 'comment' => true,
+ 'user' => false,
+ 'restricted' => false,
+ ),
+ ),
+ ),
+ ),
+
+ // Legacy format
+ array(
+ array(
+ 'type' => 'delete',
+ 'action' => 'revision',
+ 'comment' => 'delete comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(
+ 'archive',
+ '1,3,4',
+ 'ofield=1',
+ 'nfield=2',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'User changed visibility of 3 revisions on page Page: edit summary '
+ . 'hidden and content unhidden',
+ 'api' => array(
+ 'type' => 'archive',
+ 'ids' => array( '1', '3', '4' ),
+ 'old' => array(
+ 'bitmask' => 1,
+ 'content' => true,
+ 'comment' => false,
+ 'user' => false,
+ 'restricted' => false,
+ ),
+ 'new' => array(
+ 'bitmask' => 2,
+ 'content' => false,
+ 'comment' => true,
+ 'user' => false,
+ 'restricted' => false,
+ ),
+ ),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideRevisionLogDatabaseRows
+ */
+ public function testRevisionLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideEventLogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'delete',
+ 'action' => 'event',
+ 'comment' => 'delete comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(
+ '4::ids' => array( '1', '3', '4' ),
+ '5::ofield' => '1',
+ '6::nfield' => '2',
+ ),
+ ),
+ array(
+ 'text' => 'User changed visibility of 3 log events on Page: edit summary hidden '
+ . 'and content unhidden',
+ 'api' => array(
+ 'type' => 'logging',
+ 'ids' => array( '1', '3', '4' ),
+ 'old' => array(
+ 'bitmask' => 1,
+ 'content' => true,
+ 'comment' => false,
+ 'user' => false,
+ 'restricted' => false,
+ ),
+ 'new' => array(
+ 'bitmask' => 2,
+ 'content' => false,
+ 'comment' => true,
+ 'user' => false,
+ 'restricted' => false,
+ ),
+ ),
+ ),
+ ),
+
+ // Legacy format
+ array(
+ array(
+ 'type' => 'delete',
+ 'action' => 'event',
+ 'comment' => 'delete comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(
+ '1,3,4',
+ 'ofield=1',
+ 'nfield=2',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'User changed visibility of 3 log events on Page: edit summary hidden '
+ . 'and content unhidden',
+ 'api' => array(
+ 'type' => 'logging',
+ 'ids' => array( '1', '3', '4' ),
+ 'old' => array(
+ 'bitmask' => 1,
+ 'content' => true,
+ 'comment' => false,
+ 'user' => false,
+ 'restricted' => false,
+ ),
+ 'new' => array(
+ 'bitmask' => 2,
+ 'content' => false,
+ 'comment' => true,
+ 'user' => false,
+ 'restricted' => false,
+ ),
+ ),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideEventLogDatabaseRows
+ */
+ public function testEventLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideSuppressRevisionLogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'suppress',
+ 'action' => 'revision',
+ 'comment' => 'Suppress comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(
+ '4::type' => 'archive',
+ '5::ids' => array( '1', '3', '4' ),
+ '6::ofield' => '1',
+ '7::nfield' => '10',
+ ),
+ ),
+ array(
+ 'text' => 'User secretly changed visibility of 3 revisions on page Page: edit '
+ . 'summary hidden, content unhidden and applied restrictions to administrators',
+ 'api' => array(
+ 'type' => 'archive',
+ 'ids' => array( '1', '3', '4' ),
+ 'old' => array(
+ 'bitmask' => 1,
+ 'content' => true,
+ 'comment' => false,
+ 'user' => false,
+ 'restricted' => false,
+ ),
+ 'new' => array(
+ 'bitmask' => 10,
+ 'content' => false,
+ 'comment' => true,
+ 'user' => false,
+ 'restricted' => true,
+ ),
+ ),
+ ),
+ ),
+
+ // Legacy format
+ array(
+ array(
+ 'type' => 'suppress',
+ 'action' => 'revision',
+ 'comment' => 'Suppress comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(
+ 'archive',
+ '1,3,4',
+ 'ofield=1',
+ 'nfield=10',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'User secretly changed visibility of 3 revisions on page Page: edit '
+ . 'summary hidden, content unhidden and applied restrictions to administrators',
+ 'api' => array(
+ 'type' => 'archive',
+ 'ids' => array( '1', '3', '4' ),
+ 'old' => array(
+ 'bitmask' => 1,
+ 'content' => true,
+ 'comment' => false,
+ 'user' => false,
+ 'restricted' => false,
+ ),
+ 'new' => array(
+ 'bitmask' => 10,
+ 'content' => false,
+ 'comment' => true,
+ 'user' => false,
+ 'restricted' => true,
+ ),
+ ),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideSuppressRevisionLogDatabaseRows
+ */
+ public function testSuppressRevisionLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideSuppressEventLogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'suppress',
+ 'action' => 'event',
+ 'comment' => 'Suppress comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(
+ '4::ids' => array( '1', '3', '4' ),
+ '5::ofield' => '1',
+ '6::nfield' => '10',
+ ),
+ ),
+ array(
+ 'text' => 'User secretly changed visibility of 3 log events on Page: edit '
+ . 'summary hidden, content unhidden and applied restrictions to administrators',
+ 'api' => array(
+ 'type' => 'logging',
+ 'ids' => array( '1', '3', '4' ),
+ 'old' => array(
+ 'bitmask' => 1,
+ 'content' => true,
+ 'comment' => false,
+ 'user' => false,
+ 'restricted' => false,
+ ),
+ 'new' => array(
+ 'bitmask' => 10,
+ 'content' => false,
+ 'comment' => true,
+ 'user' => false,
+ 'restricted' => true,
+ ),
+ ),
+ ),
+ ),
+
+ // Legacy format
+ array(
+ array(
+ 'type' => 'suppress',
+ 'action' => 'event',
+ 'comment' => 'Suppress comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(
+ '1,3,4',
+ 'ofield=1',
+ 'nfield=10',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'User secretly changed visibility of 3 log events on Page: edit '
+ . 'summary hidden, content unhidden and applied restrictions to administrators',
+ 'api' => array(
+ 'type' => 'logging',
+ 'ids' => array( '1', '3', '4' ),
+ 'old' => array(
+ 'bitmask' => 1,
+ 'content' => true,
+ 'comment' => false,
+ 'user' => false,
+ 'restricted' => false,
+ ),
+ 'new' => array(
+ 'bitmask' => 10,
+ 'content' => false,
+ 'comment' => true,
+ 'user' => false,
+ 'restricted' => true,
+ ),
+ ),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideSuppressEventLogDatabaseRows
+ */
+ public function testSuppressEventLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideSuppressDeleteLogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'suppress',
+ 'action' => 'delete',
+ 'comment' => 'delete comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(),
+ ),
+ array(
+ 'text' => 'User suppressed page Page',
+ 'api' => array(),
+ ),
+ ),
+
+ // Legacy format
+ array(
+ array(
+ 'type' => 'suppress',
+ 'action' => 'delete',
+ 'comment' => 'delete comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'User suppressed page Page',
+ 'api' => array(),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideSuppressDeleteLogDatabaseRows
+ */
+ public function testSuppressDeleteLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+}
--- /dev/null
+<?php
+
+/**
+ * @since 1.26
+ */
+abstract class LogFormatterTestCase extends MediaWikiLangTestCase {
+
+ public function doTestLogFormatter( $row, $extra ) {
+ RequestContext::resetMain();
+ $row = $this->expandDatabaseRow( $row, $this->isLegacy( $extra ) );
+
+ $formatter = LogFormatter::newFromRow( $row );
+
+ $this->assertEquals(
+ $extra['text'],
+ self::removeSomeHtml( $formatter->getActionText() ),
+ 'Action text is equal to expected text'
+ );
+
+ $this->assertEquals(
+ $extra['api'],
+ self::removeApiMetaData( $formatter->formatParametersForApi() ),
+ 'Api log params is equal to expected array'
+ );
+ }
+
+ protected function isLegacy( $extra ) {
+ return isset( $extra['legacy'] ) && $extra['legacy'];
+ }
+
+ protected function expandDatabaseRow( $data, $legacy ) {
+ return array(
+ // no log_id because no insert in database
+ 'log_type' => $data['type'],
+ 'log_action' => $data['action'],
+ 'log_timestamp' => isset( $data['timestamp'] ) ? $data['timestamp'] : wfTimestampNow(),
+ 'log_user' => isset( $data['user'] ) ? $data['user'] : 0,
+ 'log_user_text' => isset( $data['user_text'] ) ? $data['user_text'] : 'User',
+ 'log_namespace' => isset( $data['namespace'] ) ? $data['namespace'] : NS_MAIN,
+ 'log_title' => isset( $data['title'] ) ? $data['title'] : 'Main_Page',
+ 'log_page' => isset( $data['page'] ) ? $data['page'] : 0,
+ 'log_comment' => isset( $data['comment'] ) ? $data['comment'] : '',
+ 'log_params' => $legacy
+ ? LogPage::makeParamBlob( $data['params'] )
+ : LogEntryBase::makeParamBlob( $data['params'] ),
+ 'log_deleted' => isset( $data['deleted'] ) ? $data['deleted'] : 0,
+ );
+ }
+
+ private static function removeSomeHtml( $html ) {
+ return trim( preg_replace( '/<(a|span)[^>]*>([^<]*)<\/\1>/', '$2', $html ) );
+ }
+
+ private static function removeApiMetaData( $val ) {
+ if ( is_array( $val ) ) {
+ unset( $val['_element'] );
+ unset( $val['_type'] );
+ foreach ( $val as $key => $value ) {
+ $val[$key] = self::removeApiMetaData( $value );
+ }
+ }
+ return $val;
+ }
+}
--- /dev/null
+<?php
+
+class MergeLogFormatterTest extends LogFormatterTestCase {
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideMergeLogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'merge',
+ 'action' => 'merge',
+ 'comment' => 'Merge comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'OldPage',
+ 'params' => array(
+ '4::dest' => 'NewPage',
+ '5::mergepoint' => '20140804160710',
+ ),
+ ),
+ array(
+ 'text' => 'User merged OldPage into NewPage (revisions up to 16:07, 4 August 2014)',
+ 'api' => array(
+ 'mergepoint' => '2014-08-04T16:07:10Z',
+ 'dest_ns' => 0,
+ 'dest_title' => 'NewPage',
+ ),
+ ),
+ ),
+
+ // Legacy format
+ array(
+ array(
+ 'type' => 'merge',
+ 'action' => 'merge',
+ 'comment' => 'merge comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'OldPage',
+ 'params' => array(
+ 'NewPage',
+ '20140804160710',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'User merged OldPage into NewPage (revisions up to 16:07, 4 August 2014)',
+ 'api' => array(
+ 'mergepoint' => '2014-08-04T16:07:10Z',
+ 'dest_ns' => 0,
+ 'dest_title' => 'NewPage',
+ ),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideMergeLogDatabaseRows
+ */
+ public function testMergeLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+}
--- /dev/null
+<?php
+
+class MoveLogFormatterTest extends LogFormatterTestCase {
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideMoveLogDatabaseRows() {
+ return array(
+ // Current format - with redirect
+ array(
+ array(
+ 'type' => 'move',
+ 'action' => 'move',
+ 'comment' => 'move comment with redirect',
+ 'namespace' => NS_MAIN,
+ 'title' => 'OldPage',
+ 'params' => array(
+ '4::target' => 'NewPage',
+ '5::noredir' => '0',
+ ),
+ ),
+ array(
+ 'text' => 'User moved page OldPage to NewPage',
+ 'api' => array(
+ 'target_ns' => 0,
+ 'target_title' => 'NewPage',
+ 'suppressredirect' => false,
+ ),
+ ),
+ ),
+
+ // Current format - without redirect
+ array(
+ array(
+ 'type' => 'move',
+ 'action' => 'move',
+ 'comment' => 'move comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'OldPage',
+ 'params' => array(
+ '4::target' => 'NewPage',
+ '5::noredir' => '1',
+ ),
+ ),
+ array(
+ 'text' => 'User moved page OldPage to NewPage without leaving a redirect',
+ 'api' => array(
+ 'target_ns' => 0,
+ 'target_title' => 'NewPage',
+ 'suppressredirect' => true,
+ ),
+ ),
+ ),
+
+ // legacy format - with redirect
+ array(
+ array(
+ 'type' => 'move',
+ 'action' => 'move',
+ 'comment' => 'move comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'OldPage',
+ 'params' => array(
+ 'NewPage',
+ '',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'User moved page OldPage to NewPage',
+ 'api' => array(
+ 'target_ns' => 0,
+ 'target_title' => 'NewPage',
+ 'suppressredirect' => false,
+ ),
+ ),
+ ),
+
+ // legacy format - without redirect
+ array(
+ array(
+ 'type' => 'move',
+ 'action' => 'move',
+ 'comment' => 'move comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'OldPage',
+ 'params' => array(
+ 'NewPage',
+ '1',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'User moved page OldPage to NewPage without leaving a redirect',
+ 'api' => array(
+ 'target_ns' => 0,
+ 'target_title' => 'NewPage',
+ 'suppressredirect' => true,
+ ),
+ ),
+ ),
+
+ // old format without flag for redirect suppression
+ array(
+ array(
+ 'type' => 'move',
+ 'action' => 'move',
+ 'comment' => 'move comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'OldPage',
+ 'params' => array(
+ 'NewPage',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'User moved page OldPage to NewPage',
+ 'api' => array(
+ 'target_ns' => 0,
+ 'target_title' => 'NewPage',
+ 'suppressredirect' => false,
+ ),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideMoveLogDatabaseRows
+ */
+ public function testMoveLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideMoveRedirLogDatabaseRows() {
+ return array(
+ // Current format - with redirect
+ array(
+ array(
+ 'type' => 'move',
+ 'action' => 'move_redir',
+ 'comment' => 'move comment with redirect',
+ 'namespace' => NS_MAIN,
+ 'title' => 'OldPage',
+ 'params' => array(
+ '4::target' => 'NewPage',
+ '5::noredir' => '0',
+ ),
+ ),
+ array(
+ 'text' => 'User moved page OldPage to NewPage over redirect',
+ 'api' => array(
+ 'target_ns' => 0,
+ 'target_title' => 'NewPage',
+ 'suppressredirect' => false,
+ ),
+ ),
+ ),
+
+ // Current format - without redirect
+ array(
+ array(
+ 'type' => 'move',
+ 'action' => 'move_redir',
+ 'comment' => 'move comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'OldPage',
+ 'params' => array(
+ '4::target' => 'NewPage',
+ '5::noredir' => '1',
+ ),
+ ),
+ array(
+ 'text' => 'User moved page OldPage to NewPage over a redirect without leaving a redirect',
+ 'api' => array(
+ 'target_ns' => 0,
+ 'target_title' => 'NewPage',
+ 'suppressredirect' => true,
+ ),
+ ),
+ ),
+
+ // legacy format - with redirect
+ array(
+ array(
+ 'type' => 'move',
+ 'action' => 'move_redir',
+ 'comment' => 'move comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'OldPage',
+ 'params' => array(
+ 'NewPage',
+ '',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'User moved page OldPage to NewPage over redirect',
+ 'api' => array(
+ 'target_ns' => 0,
+ 'target_title' => 'NewPage',
+ 'suppressredirect' => false,
+ ),
+ ),
+ ),
+
+ // legacy format - without redirect
+ array(
+ array(
+ 'type' => 'move',
+ 'action' => 'move_redir',
+ 'comment' => 'move comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'OldPage',
+ 'params' => array(
+ 'NewPage',
+ '1',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'User moved page OldPage to NewPage over a redirect without leaving a redirect',
+ 'api' => array(
+ 'target_ns' => 0,
+ 'target_title' => 'NewPage',
+ 'suppressredirect' => true,
+ ),
+ ),
+ ),
+
+ // old format without flag for redirect suppression
+ array(
+ array(
+ 'type' => 'move',
+ 'action' => 'move_redir',
+ 'comment' => 'move comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'OldPage',
+ 'params' => array(
+ 'NewPage',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'User moved page OldPage to NewPage over redirect',
+ 'api' => array(
+ 'target_ns' => 0,
+ 'target_title' => 'NewPage',
+ 'suppressredirect' => false,
+ ),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideMoveRedirLogDatabaseRows
+ */
+ public function testMoveRedirLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+}
--- /dev/null
+<?php
+
+/**
+ * @group Database
+ */
+class NewUsersLogFormatterTest extends LogFormatterTestCase {
+
+ protected function setUp() {
+ parent::setUp();
+
+ // Register LogHandler, see $wgNewUserLog in Setup.php
+ $this->mergeMwGlobalArrayValue( 'wgLogActionsHandlers', array(
+ 'newusers/newusers' => 'NewUsersLogFormatter',
+ 'newusers/create' => 'NewUsersLogFormatter',
+ 'newusers/create2' => 'NewUsersLogFormatter',
+ 'newusers/byemail' => 'NewUsersLogFormatter',
+ 'newusers/autocreate' => 'NewUsersLogFormatter',
+ ) );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideNewUsersLogDatabaseRows() {
+ return array(
+ // Only old logs
+ array(
+ array(
+ 'type' => 'newusers',
+ 'action' => 'newusers',
+ 'comment' => 'newusers comment',
+ 'user' => 0,
+ 'user_text' => 'New user',
+ 'namespace' => NS_USER,
+ 'title' => 'New user',
+ 'params' => array(),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'User account New user was created',
+ 'api' => array(),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideNewUsersLogDatabaseRows
+ */
+ public function testNewUsersLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideCreateLogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'newusers',
+ 'action' => 'create',
+ 'comment' => 'newusers comment',
+ 'user' => 0,
+ 'user_text' => 'New user',
+ 'namespace' => NS_USER,
+ 'title' => 'New user',
+ 'params' => array(
+ '4::userid' => '1',
+ ),
+ ),
+ array(
+ 'text' => 'User account New user was created',
+ 'api' => array(
+ 'userid' => 1,
+ ),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideCreateLogDatabaseRows
+ */
+ public function testCreateLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideCreate2LogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'newusers',
+ 'action' => 'create2',
+ 'comment' => 'newusers comment',
+ 'user' => 0,
+ 'user_text' => 'User',
+ 'namespace' => NS_USER,
+ 'title' => 'UTSysop',
+ 'params' => array(
+ '4::userid' => '1',
+ ),
+ ),
+ array(
+ 'text' => 'User account UTSysop was created by User',
+ 'api' => array(
+ 'userid' => 1,
+ ),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideCreate2LogDatabaseRows
+ */
+ public function testCreate2LogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideByemailLogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'newusers',
+ 'action' => 'byemail',
+ 'comment' => 'newusers comment',
+ 'user' => 0,
+ 'user_text' => 'Sysop',
+ 'namespace' => NS_USER,
+ 'title' => 'UTSysop',
+ 'params' => array(
+ '4::userid' => '1',
+ ),
+ ),
+ array(
+ 'text' => 'User account UTSysop was created by Sysop and password was sent by email',
+ 'api' => array(
+ 'userid' => 1,
+ ),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideByemailLogDatabaseRows
+ */
+ public function testByemailLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideAutocreateLogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'newusers',
+ 'action' => 'autocreate',
+ 'comment' => 'newusers comment',
+ 'user' => 0,
+ 'user_text' => 'New user',
+ 'namespace' => NS_USER,
+ 'title' => 'New user',
+ 'params' => array(
+ '4::userid' => '1',
+ ),
+ ),
+ array(
+ 'text' => 'User account New user was created automatically',
+ 'api' => array(
+ 'userid' => 1,
+ ),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideAutocreateLogDatabaseRows
+ */
+ public function testAutocreateLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+}
--- /dev/null
+<?php
+
+class PageLangLogFormatterTest extends LogFormatterTestCase {
+
+ protected function setUp() {
+ parent::setUp();
+
+ // Disable cldr extension
+ $this->setMwGlobals( 'wgHooks', array() );
+ // Register LogHandler, see $wgPageLanguageUseDB in Setup.php
+ $this->mergeMwGlobalArrayValue( 'wgLogActionsHandlers', array(
+ 'pagelang/pagelang' => 'PageLangLogFormatter',
+ ) );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function providePageLangLogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'pagelang',
+ 'action' => 'pagelang',
+ 'comment' => 'page lang comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(
+ '4::oldlanguage' => 'en',
+ '5::newlanguage' => 'de[def]',
+ ),
+ ),
+ array(
+ 'text' => 'User changed page language for Page from English (en) to Deutsch (de) [default].',
+ 'api' => array(
+ 'oldlanguage' => 'en',
+ 'newlanguage' => 'de[def]'
+ ),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider providePageLangLogDatabaseRows
+ */
+ public function testPageLangLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+}
--- /dev/null
+<?php
+
+class PatrolLogFormatterTest extends LogFormatterTestCase {
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function providePatrolLogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'patrol',
+ 'action' => 'patrol',
+ 'comment' => 'patrol comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(
+ '4::curid' => 2,
+ '5::previd' => 1,
+ '6::auto' => 0,
+ ),
+ ),
+ array(
+ 'text' => 'User marked revision 2 of page Page patrolled',
+ 'api' => array(
+ 'curid' => 2,
+ 'previd' => 1,
+ 'auto' => false,
+ ),
+ ),
+ ),
+
+ // Current format - autopatrol
+ array(
+ array(
+ 'type' => 'patrol',
+ 'action' => 'patrol',
+ 'comment' => 'patrol comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(
+ '4::curid' => 2,
+ '5::previd' => 1,
+ '6::auto' => 1,
+ ),
+ ),
+ array(
+ 'text' => 'User automatically marked revision 2 of page Page patrolled',
+ 'api' => array(
+ 'curid' => 2,
+ 'previd' => 1,
+ 'auto' => true,
+ ),
+ ),
+ ),
+
+ // Legacy format
+ array(
+ array(
+ 'type' => 'patrol',
+ 'action' => 'patrol',
+ 'comment' => 'patrol comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(
+ '2',
+ '1',
+ '0',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'User marked revision 2 of page Page patrolled',
+ 'api' => array(
+ 'curid' => 2,
+ 'previd' => 1,
+ 'auto' => false,
+ ),
+ ),
+ ),
+
+ // Legacy format - autopatrol
+ array(
+ array(
+ 'type' => 'patrol',
+ 'action' => 'patrol',
+ 'comment' => 'patrol comment',
+ 'namespace' => NS_MAIN,
+ 'title' => 'Page',
+ 'params' => array(
+ '2',
+ '1',
+ '1',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'User automatically marked revision 2 of page Page patrolled',
+ 'api' => array(
+ 'curid' => 2,
+ 'previd' => 1,
+ 'auto' => true,
+ ),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider providePatrolLogDatabaseRows
+ */
+ public function testPatrolLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+}
--- /dev/null
+<?php
+
+class RightsLogFormatterTest extends LogFormatterTestCase {
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideRightsLogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'rights',
+ 'action' => 'rights',
+ 'comment' => 'rights comment',
+ 'user' => 0,
+ 'user_text' => 'Sysop',
+ 'namespace' => NS_USER,
+ 'title' => 'User',
+ 'params' => array(
+ '4::oldgroups' => array(),
+ '5::newgroups' => array( 'sysop', 'bureaucrat' ),
+ ),
+ ),
+ array(
+ 'text' => 'Sysop changed group membership for User:User from (none) to '
+ . 'administrator and bureaucrat',
+ 'api' => array(
+ 'oldgroups' => array(),
+ 'newgroups' => array( 'sysop', 'bureaucrat' ),
+ ),
+ ),
+ ),
+
+ // Legacy format
+ array(
+ array(
+ 'type' => 'rights',
+ 'action' => 'rights',
+ 'comment' => 'rights comment',
+ 'user' => 0,
+ 'user_text' => 'Sysop',
+ 'namespace' => NS_USER,
+ 'title' => 'User',
+ 'params' => array(
+ '',
+ 'sysop, bureaucrat',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'Sysop changed group membership for User:User from (none) to '
+ . 'administrator and bureaucrat',
+ 'api' => array(
+ 'oldgroups' => array(),
+ 'newgroups' => array( 'sysop', 'bureaucrat' ),
+ ),
+ ),
+ ),
+
+ // Really old entry
+ array(
+ array(
+ 'type' => 'rights',
+ 'action' => 'rights',
+ 'comment' => 'rights comment',
+ 'user' => 0,
+ 'user_text' => 'Sysop',
+ 'namespace' => NS_USER,
+ 'title' => 'User',
+ 'params' => array(),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'Sysop changed group membership for User:User',
+ 'api' => array(),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideRightsLogDatabaseRows
+ */
+ public function testRightsLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideAutopromoteLogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'rights',
+ 'action' => 'autopromote',
+ 'comment' => 'rights comment',
+ 'user' => 0,
+ 'user_text' => 'Sysop',
+ 'namespace' => NS_USER,
+ 'title' => 'Sysop',
+ 'params' => array(
+ '4::oldgroups' => array( 'sysop' ),
+ '5::newgroups' => array( 'sysop', 'bureaucrat' ),
+ ),
+ ),
+ array(
+ 'text' => 'Sysop was automatically promoted from administrator to '
+ . 'administrator and bureaucrat',
+ 'api' => array(
+ 'oldgroups' => array( 'sysop' ),
+ 'newgroups' => array( 'sysop', 'bureaucrat' ),
+ ),
+ ),
+ ),
+
+ // Legacy format
+ array(
+ array(
+ 'type' => 'rights',
+ 'action' => 'autopromote',
+ 'comment' => 'rights comment',
+ 'user' => 0,
+ 'user_text' => 'Sysop',
+ 'namespace' => NS_USER,
+ 'title' => 'Sysop',
+ 'params' => array(
+ 'sysop',
+ 'sysop, bureaucrat',
+ ),
+ ),
+ array(
+ 'legacy' => true,
+ 'text' => 'Sysop was automatically promoted from administrator to '
+ . 'administrator and bureaucrat',
+ 'api' => array(
+ 'oldgroups' => array( 'sysop' ),
+ 'newgroups' => array( 'sysop', 'bureaucrat' ),
+ ),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideAutopromoteLogDatabaseRows
+ */
+ public function testAutopromoteLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+}
--- /dev/null
+<?php
+
+class UploadLogFormatterTest extends LogFormatterTestCase {
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideUploadLogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'upload',
+ 'action' => 'upload',
+ 'comment' => 'upload comment',
+ 'namespace' => NS_FILE,
+ 'title' => 'File.png',
+ 'params' => array(
+ 'img_sha1' => 'hash',
+ 'img_timestamp' => '20150101000000',
+ ),
+ ),
+ array(
+ 'text' => 'User uploaded File:File.png',
+ 'api' => array(
+ 'img_sha1' => 'hash',
+ 'img_timestamp' => '2015-01-01T00:00:00Z',
+ ),
+ ),
+ ),
+
+ // Old format without params
+ array(
+ array(
+ 'type' => 'upload',
+ 'action' => 'upload',
+ 'comment' => 'upload comment',
+ 'namespace' => NS_FILE,
+ 'title' => 'File.png',
+ 'params' => array(),
+ ),
+ array(
+ 'text' => 'User uploaded File:File.png',
+ 'api' => array(),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideUploadLogDatabaseRows
+ */
+ public function testUploadLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideOverwriteLogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'upload',
+ 'action' => 'overwrite',
+ 'comment' => 'upload comment',
+ 'namespace' => NS_FILE,
+ 'title' => 'File.png',
+ 'params' => array(
+ 'img_sha1' => 'hash',
+ 'img_timestamp' => '20150101000000',
+ ),
+ ),
+ array(
+ 'text' => 'User uploaded a new version of File:File.png',
+ 'api' => array(
+ 'img_sha1' => 'hash',
+ 'img_timestamp' => '2015-01-01T00:00:00Z',
+ ),
+ ),
+ ),
+
+ // Old format without params
+ array(
+ array(
+ 'type' => 'upload',
+ 'action' => 'overwrite',
+ 'comment' => 'upload comment',
+ 'namespace' => NS_FILE,
+ 'title' => 'File.png',
+ 'params' => array(),
+ ),
+ array(
+ 'text' => 'User uploaded a new version of File:File.png',
+ 'api' => array(),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideOverwriteLogDatabaseRows
+ */
+ public function testOverwriteLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+
+ /**
+ * Provide different rows from the logging table to test
+ * for backward compatibility.
+ * Do not change the existing data, just add a new database row
+ */
+ public static function provideRevertLogDatabaseRows() {
+ return array(
+ // Current format
+ array(
+ array(
+ 'type' => 'upload',
+ 'action' => 'revert',
+ 'comment' => 'upload comment',
+ 'namespace' => NS_FILE,
+ 'title' => 'File.png',
+ 'params' => array(
+ 'img_sha1' => 'hash',
+ 'img_timestamp' => '20150101000000',
+ ),
+ ),
+ array(
+ 'text' => 'User uploaded File:File.png',
+ 'api' => array(
+ 'img_sha1' => 'hash',
+ 'img_timestamp' => '2015-01-01T00:00:00Z',
+ ),
+ ),
+ ),
+
+ // Old format without params
+ array(
+ array(
+ 'type' => 'upload',
+ 'action' => 'revert',
+ 'comment' => 'upload comment',
+ 'namespace' => NS_FILE,
+ 'title' => 'File.png',
+ 'params' => array(),
+ ),
+ array(
+ 'text' => 'User uploaded File:File.png',
+ 'api' => array(),
+ ),
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider provideRevertLogDatabaseRows
+ */
+ public function testRevertLogDatabaseRows( $row, $extra ) {
+ $this->doTestLogFormatter( $row, $extra );
+ }
+}
assert.assertTrue( this.timeStamp >= now, 'thisValue has sane timestamp' );
} );
} );
+
+ QUnit.test( 'trackUnsubscribe', 1, function ( assert ) {
+ var sequence = [];
+ function unsubber( topic, data ) {
+ sequence.push( [ topic, data ] );
+ }
+
+ mw.track( 'unsub', { key: 1 } );
+ mw.trackSubscribe( 'unsub', unsubber );
+ mw.track( 'unsub', { key: 2 } );
+ mw.trackUnsubscribe( unsubber );
+ mw.track( 'unsub', { key: 3 } );
+
+ assert.deepEqual( sequence, [
+ [ 'unsub', { key: 1 } ],
+ [ 'unsub', { key: 2 } ]
+ ], 'Stop when unsubscribing' );
+ } );
}( mediaWiki ) );