we will send rel=alternate.
=== New features in 1.24 ===
+* Added new hook WatchlistEditorBeforeFormRender, allowing subscribers to
+ manipulate the list of pages and/or preload lots of data at once.
+* Added new argument &$link in hook WatchlistEditorBuildRemoveLine, allowing the
+ link to the title to be changed.
* Added a new hook, "WhatLinksHereProps", to allow extensions to annotate
WhatLinksHere entries.
* Added a new hook, "ContentGetParserOutput", to customize parser output for
* (bugs 57238, 65206) Blank pages can now be directly created.
* (bug 69789) Title::getContentModel() now loads from the database when
necessary instead of incorrectly returning the default content model.
+* (bug 69249) wfBaseConvert() now works around PHP Bug #50175 when using GMP.
=== Action API changes in 1.24 ===
* action=parse API now supports prop=modules, which provides the list of
$user: user that watched
$page: WikiPage object watched
+'WatchlistEditorBeforeFormRender': Before building the Special:EditWatchlist
+form, used to manipulate the list of pages or preload data based on that list.
+&$watchlistInfo: array of watchlisted pages in
+ [namespaceId => ['title1' => 1, 'title2' => 1]] format
+
'WatchlistEditorBuildRemoveLine': when building remove lines in
Special:Watchlist/edit.
&$tools: array of extra links
$title: Title object
$redirect: whether the page is a redirect
$skin: Skin object
+&$link: HTML link to title
'WebRequestPathInfoRouter': While building the PathRouter to parse the
REQUEST_URI.
'AuthPluginUser' => 'includes/AuthPlugin.php',
'Autopromote' => 'includes/Autopromote.php',
'Block' => 'includes/Block.php',
+ 'BloomCache' => 'includes/cache/bloom/BloomCache.php',
+ 'BloomCacheRedis' => 'includes/cache/bloom/BloomCacheRedis.php',
+ 'BloomFilterTitleHasLogs' => 'includes/cache/bloom/BloomFilters.php',
+ 'CacheHelper' => 'includes/CacheHelper.php',
'Category' => 'includes/Category.php',
- 'Categoryfinder' => 'includes/Categoryfinder.php',
+ 'CategoryFinder' => 'includes/CategoryFinder.php',
'CategoryViewer' => 'includes/CategoryViewer.php',
'ChangeTags' => 'includes/ChangeTags.php',
'ChannelFeed' => 'includes/Feed.php',
'DumpPipeOutput' => 'includes/Export.php',
'EditPage' => 'includes/EditPage.php',
'EmailNotification' => 'includes/UserMailer.php',
+ 'EmptyBloomCache' => 'includes/cache/bloom/BloomCache.php',
'Fallback' => 'includes/Fallback.php',
'FauxRequest' => 'includes/WebRequest.php',
'FauxResponse' => 'includes/WebResponse.php',
--- /dev/null
+<?php
+/**
+ * Recent changes filtering by category.
+ *
+ * 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
+ */
+
+/**
+ * The "CategoryFinder" class takes a list of articles, creates an internal
+ * representation of all their parent categories (as well as parents of
+ * parents etc.). From this representation, it determines which of these
+ * articles are in one or all of a given subset of categories.
+ *
+ * Example use :
+ * <code>
+ * # Determines whether the article with the page_id 12345 is in both
+ * # "Category 1" and "Category 2" or their subcategories, respectively
+ *
+ * $cf = new CategoryFinder;
+ * $cf->seed(
+ * array( 12345 ),
+ * array( 'Category 1', 'Category 2' ),
+ * 'AND'
+ * );
+ * $a = $cf->run();
+ * print implode( ',' , $a );
+ * </code>
+ *
+ */
+class CategoryFinder {
+ /** @var int[] The original article IDs passed to the seed function */
+ protected $articles = array();
+
+ /** @var array Array of DBKEY category names for categories that don't have a page */
+ protected $deadend = array();
+
+ /** @var array Array of [ID => array()] */
+ protected $parents = array();
+
+ /** @var array Array of article/category IDs */
+ protected $next = array();
+
+ /** @var array Array of DBKEY category names */
+ protected $targets = array();
+
+ /** @var array */
+ protected $name2id = array();
+
+ /** @var string "AND" or "OR" */
+ protected $mode;
+
+ /** @var DatabaseBase Read-DB slave */
+ protected $dbr;
+
+ /**
+ * Initializes the instance. Do this prior to calling run().
+ * @param array $articleIds Array of article IDs
+ * @param array $categories FIXME
+ * @param string $mode FIXME, default 'AND'.
+ * @todo FIXME: $categories/$mode
+ */
+ public function seed( $articleIds, $categories, $mode = 'AND' ) {
+ $this->articles = $articleIds;
+ $this->next = $articleIds;
+ $this->mode = $mode;
+
+ # Set the list of target categories; convert them to DBKEY form first
+ $this->targets = array();
+ foreach ( $categories as $c ) {
+ $ct = Title::makeTitleSafe( NS_CATEGORY, $c );
+ if ( $ct ) {
+ $c = $ct->getDBkey();
+ $this->targets[$c] = $c;
+ }
+ }
+ }
+
+ /**
+ * Iterates through the parent tree starting with the seed values,
+ * then checks the articles if they match the conditions
+ * @return array Array of page_ids (those given to seed() that match the conditions)
+ */
+ public function run() {
+ $this->dbr = wfGetDB( DB_SLAVE );
+ while ( count( $this->next ) > 0 ) {
+ $this->scanNextLayer();
+ }
+
+ # Now check if this applies to the individual articles
+ $ret = array();
+
+ foreach ( $this->articles as $article ) {
+ $conds = $this->targets;
+ if ( $this->check( $article, $conds ) ) {
+ # Matches the conditions
+ $ret[] = $article;
+ }
+ }
+ return $ret;
+ }
+
+ /**
+ * This functions recurses through the parent representation, trying to match the conditions
+ * @param int $id The article/category to check
+ * @param array $conds The array of categories to match
+ * @param array $path Used to check for recursion loops
+ * @return bool Does this match the conditions?
+ */
+ private function check( $id, &$conds, $path = array() ) {
+ // Check for loops and stop!
+ if ( in_array( $id, $path ) ) {
+ return false;
+ }
+
+ $path[] = $id;
+
+ # Shortcut (runtime paranoia): No conditions=all matched
+ if ( count( $conds ) == 0 ) {
+ return true;
+ }
+
+ if ( !isset( $this->parents[$id] ) ) {
+ return false;
+ }
+
+ # iterate through the parents
+ foreach ( $this->parents[$id] as $p ) {
+ $pname = $p->cl_to;
+
+ # Is this a condition?
+ if ( isset( $conds[$pname] ) ) {
+ # This key is in the category list!
+ if ( $this->mode == 'OR' ) {
+ # One found, that's enough!
+ $conds = array();
+ return true;
+ } else {
+ # Assuming "AND" as default
+ unset( $conds[$pname] );
+ if ( count( $conds ) == 0 ) {
+ # All conditions met, done
+ return true;
+ }
+ }
+ }
+
+ # Not done yet, try sub-parents
+ if ( !isset( $this->name2id[$pname] ) ) {
+ # No sub-parent
+ continue;
+ }
+ $done = $this->check( $this->name2id[$pname], $conds, $path );
+ if ( $done || count( $conds ) == 0 ) {
+ # Subparents have done it!
+ return true;
+ }
+ }
+ return false;
+ }
+
+ /**
+ * Scans a "parent layer" of the articles/categories in $this->next
+ */
+ private function scanNextLayer() {
+ $profiler = new ProfileSection( __METHOD__ );
+
+ # Find all parents of the article currently in $this->next
+ $layer = array();
+ $res = $this->dbr->select(
+ /* FROM */ 'categorylinks',
+ /* SELECT */ '*',
+ /* WHERE */ array( 'cl_from' => $this->next ),
+ __METHOD__ . '-1'
+ );
+ foreach ( $res as $o ) {
+ $k = $o->cl_to;
+
+ # Update parent tree
+ if ( !isset( $this->parents[$o->cl_from] ) ) {
+ $this->parents[$o->cl_from] = array();
+ }
+ $this->parents[$o->cl_from][$k] = $o;
+
+ # Ignore those we already have
+ if ( in_array( $k, $this->deadend ) ) {
+ continue;
+ }
+
+ if ( isset( $this->name2id[$k] ) ) {
+ continue;
+ }
+
+ # Hey, new category!
+ $layer[$k] = $k;
+ }
+
+ $this->next = array();
+
+ # Find the IDs of all category pages in $layer, if they exist
+ if ( count( $layer ) > 0 ) {
+ $res = $this->dbr->select(
+ /* FROM */ 'page',
+ /* SELECT */ array( 'page_id', 'page_title' ),
+ /* WHERE */ array( 'page_namespace' => NS_CATEGORY, 'page_title' => $layer ),
+ __METHOD__ . '-2'
+ );
+ foreach ( $res as $o ) {
+ $id = $o->page_id;
+ $name = $o->page_title;
+ $this->name2id[$name] = $id;
+ $this->next[] = $id;
+ unset( $layer[$name] );
+ }
+ }
+
+ # Mark dead ends
+ foreach ( $layer as $v ) {
+ $this->deadend[$v] = $v;
+ }
+ }
+}
+++ /dev/null
-<?php
-/**
- * Recent changes filtering by category.
- *
- * 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
- */
-
-/**
- * The "Categoryfinder" class takes a list of articles, creates an internal
- * representation of all their parent categories (as well as parents of
- * parents etc.). From this representation, it determines which of these
- * articles are in one or all of a given subset of categories.
- *
- * Example use :
- * <code>
- * # Determines whether the article with the page_id 12345 is in both
- * # "Category 1" and "Category 2" or their subcategories, respectively
- *
- * $cf = new Categoryfinder;
- * $cf->seed(
- * array( 12345 ),
- * array( 'Category 1', 'Category 2' ),
- * 'AND'
- * );
- * $a = $cf->run();
- * print implode( ',' , $a );
- * </code>
- *
- */
-class Categoryfinder {
- /** @var int[] The original article IDs passed to the seed function */
- protected $articles = array();
-
- /** @var array Array of DBKEY category names for categories that don't have a page */
- protected $deadend = array();
-
- /** @var array Array of [ID => array()] */
- protected $parents = array();
-
- /** @var array Array of article/category IDs */
- protected $next = array();
-
- /** @var array Array of DBKEY category names */
- protected $targets = array();
-
- /** @var array */
- protected $name2id = array();
-
- /** @var string "AND" or "OR" */
- protected $mode;
-
- /** @var DatabaseBase Read-DB slave */
- protected $dbr;
-
- function __construct() {
- }
-
- /**
- * Initializes the instance. Do this prior to calling run().
- * @param array $article_ids Array of article IDs
- * @param array $categories FIXME
- * @param string $mode FIXME, default 'AND'.
- * @todo FIXME: $categories/$mode
- */
- function seed( $article_ids, $categories, $mode = 'AND' ) {
- $this->articles = $article_ids;
- $this->next = $article_ids;
- $this->mode = $mode;
-
- # Set the list of target categories; convert them to DBKEY form first
- $this->targets = array();
- foreach ( $categories as $c ) {
- $ct = Title::makeTitleSafe( NS_CATEGORY, $c );
- if ( $ct ) {
- $c = $ct->getDBkey();
- $this->targets[$c] = $c;
- }
- }
- }
-
- /**
- * Iterates through the parent tree starting with the seed values,
- * then checks the articles if they match the conditions
- * @return array Array of page_ids (those given to seed() that match the conditions)
- */
- function run() {
- $this->dbr = wfGetDB( DB_SLAVE );
- while ( count( $this->next ) > 0 ) {
- $this->scan_next_layer();
- }
-
- # Now check if this applies to the individual articles
- $ret = array();
-
- foreach ( $this->articles as $article ) {
- $conds = $this->targets;
- if ( $this->check( $article, $conds ) ) {
- # Matches the conditions
- $ret[] = $article;
- }
- }
- return $ret;
- }
-
- /**
- * This functions recurses through the parent representation, trying to match the conditions
- * @param int $id The article/category to check
- * @param array $conds The array of categories to match
- * @param array $path Used to check for recursion loops
- * @return bool Does this match the conditions?
- */
- function check( $id, &$conds, $path = array() ) {
- // Check for loops and stop!
- if ( in_array( $id, $path ) ) {
- return false;
- }
-
- $path[] = $id;
-
- # Shortcut (runtime paranoia): No conditions=all matched
- if ( count( $conds ) == 0 ) {
- return true;
- }
-
- if ( !isset( $this->parents[$id] ) ) {
- return false;
- }
-
- # iterate through the parents
- foreach ( $this->parents[$id] as $p ) {
- $pname = $p->cl_to;
-
- # Is this a condition?
- if ( isset( $conds[$pname] ) ) {
- # This key is in the category list!
- if ( $this->mode == 'OR' ) {
- # One found, that's enough!
- $conds = array();
- return true;
- } else {
- # Assuming "AND" as default
- unset( $conds[$pname] );
- if ( count( $conds ) == 0 ) {
- # All conditions met, done
- return true;
- }
- }
- }
-
- # Not done yet, try sub-parents
- if ( !isset( $this->name2id[$pname] ) ) {
- # No sub-parent
- continue;
- }
- $done = $this->check( $this->name2id[$pname], $conds, $path );
- if ( $done || count( $conds ) == 0 ) {
- # Subparents have done it!
- return true;
- }
- }
- return false;
- }
-
- /**
- * Scans a "parent layer" of the articles/categories in $this->next
- */
- function scan_next_layer() {
- wfProfileIn( __METHOD__ );
-
- # Find all parents of the article currently in $this->next
- $layer = array();
- $res = $this->dbr->select(
- /* FROM */ 'categorylinks',
- /* SELECT */ '*',
- /* WHERE */ array( 'cl_from' => $this->next ),
- __METHOD__ . '-1'
- );
- foreach ( $res as $o ) {
- $k = $o->cl_to;
-
- # Update parent tree
- if ( !isset( $this->parents[$o->cl_from] ) ) {
- $this->parents[$o->cl_from] = array();
- }
- $this->parents[$o->cl_from][$k] = $o;
-
- # Ignore those we already have
- if ( in_array( $k, $this->deadend ) ) {
- continue;
- }
-
- if ( isset( $this->name2id[$k] ) ) {
- continue;
- }
-
- # Hey, new category!
- $layer[$k] = $k;
- }
-
- $this->next = array();
-
- # Find the IDs of all category pages in $layer, if they exist
- if ( count( $layer ) > 0 ) {
- $res = $this->dbr->select(
- /* FROM */ 'page',
- /* SELECT */ array( 'page_id', 'page_title' ),
- /* WHERE */ array( 'page_namespace' => NS_CATEGORY, 'page_title' => $layer ),
- __METHOD__ . '-2'
- );
- foreach ( $res as $o ) {
- $id = $o->page_id;
- $name = $o->page_title;
- $this->name2id[$name] = $id;
- $this->next[] = $id;
- unset( $layer[$name] );
- }
- }
-
- # Mark dead ends
- foreach ( $layer as $v ) {
- $this->deadend[$v] = $v;
- }
-
- wfProfileOut( __METHOD__ );
- }
-}
'hash' => array( 'class' => 'HashBagOStuff' ),
);
+/**
+ * Map of bloom filter store names to configuration arrays.
+ *
+ * Example:
+ * $wgBloomFilterStores['main'] = array(
+ * 'cacheId' => 'main-v1',
+ * 'class' => 'BloomCacheRedis',
+ * 'redisServers' => array( '127.0.0.1:6379' ),
+ * 'redisConfig' => array( 'connectTimeout' => 2 )
+ * );
+ *
+ * A primary bloom filter must be created manually.
+ * Example in eval.php:
+ * <code>
+ * BloomCache::get( 'main' )->init( 'shared', 1000000000, .001 );
+ * </code>
+ * The size should be as large as practical given wiki size and resources.
+ *
+ * @since 1.24
+ */
+$wgBloomFilterStores = array();
+
/**
* The expiry time for the parser cache, in seconds.
* The default is 86400 (one day).
$wgOut->addHTML( $this->editFormTextBeforeContent );
- if ( $this->contentModel === CONTENT_MODEL_WIKITEXT &&
- $showToolbar && $wgUser->getOption( 'showtoolbar' ) )
- {
+ if ( !$this->isCssJsSubpage && $showToolbar && $wgUser->getOption( 'showtoolbar' ) ) {
$wgOut->addHTML( EditPage::getEditToolbar() );
}
);
if ( extension_loaded( 'gmp' ) && ( $engine == 'auto' || $engine == 'gmp' ) ) {
- $result = gmp_strval( gmp_init( $input, $sourceBase ), $destBase );
+ // Removing leading zeros works around broken base detection code in
+ // some PHP versions (see <https://bugs.php.net/bug.php?id=50175> and
+ // <https://bugs.php.net/bug.php?id=55398>).
+ $result = gmp_strval( gmp_init( ltrim( $input, '0' ), $sourceBase ), $destBase );
} elseif ( extension_loaded( 'bcmath' ) && ( $engine == 'auto' || $engine == 'bcmath' ) ) {
$decimal = '0';
foreach ( str_split( strtolower( $input ) ) as $char ) {
*/
class MediaWiki {
/**
- * @todo Fold $output, etc, into this
* @var IContextSource
*/
private $context;
*/
private $config;
- /**
- * @param null|WebRequest $x
- * @return WebRequest
- */
- public function request( WebRequest $x = null ) {
- $old = $this->context->getRequest();
- if ( $x ) {
- $this->context->setRequest( $x );
- }
- return $old;
- }
-
- /**
- * @param null|OutputPage $x
- * @return OutputPage
- */
- public function output( OutputPage $x = null ) {
- $old = $this->context->getOutput();
- if ( $x ) {
- $this->context->setOutput( $x );
- }
- return $old;
- }
-
/**
* @param IContextSource|null $context
*/
);
} else {
$links['html'] .= Html::inlineScript(
- $resourceLoader->makeModuleResponse( $context, $grpModules )
+ ResourceLoader::makeLoaderConditionalScript(
+ $resourceLoader->makeModuleResponse( $context, $grpModules )
+ )
);
}
$links['html'] .= "\n";
continue;
}
$host = $parts[0];
- if ( $parts[1] === false ) {
+ if ( isset( $_SERVER['HTTP_X_FORWARDED_PROTO'] ) ) {
+ // Bug 70021: Assume that upstream proxy is running on the default
+ // port based on the protocol. We have no reliable way to determine
+ // the actual port in use upstream.
+ $port = $stdPort;
+ } elseif ( $parts[1] === false ) {
if ( isset( $_SERVER['SERVER_PORT'] ) ) {
$port = $_SERVER['SERVER_PORT'];
} // else leave it as $stdPort
' fileextensions - Returns list of file extensions allowed to be uploaded',
' rightsinfo - Returns wiki rights (license) information if available',
' restrictions - Returns information on available restriction (protection) types',
- ' languages - Returns a list of languages MediaWiki supports' .
+ ' languages - Returns a list of languages MediaWiki supports ' .
"(optionally localised by using {$p}inlanguagecode)",
' skins - Returns a list of all enabled skins',
' extensiontags - Returns a list of parser extension tags',
--- /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
+ */
+
+/**
+ * Persistent bloom filter used to avoid expensive lookups
+ *
+ * @since 1.24
+ */
+abstract class BloomCache {
+ /** @var string Unique ID for key namespacing */
+ protected $cacheID;
+
+ /** @var array Map of (id => BloomCache) */
+ protected static $instances = array();
+
+ /**
+ * @param string $id
+ * @return BloomCache
+ */
+ final public static function get( $id ) {
+ global $wgBloomFilterStores;
+
+ if ( !isset( self::$instances[$id] ) ) {
+ if ( isset( $wgBloomFilterStores[$id] ) ) {
+ $class = $wgBloomFilterStores[$id]['class'];
+ self::$instances[$id] = new $class( $wgBloomFilterStores[$id] );
+ } else {
+ wfDebug( "No bloom filter store '$id'; using EmptyBloomCache." );
+ return new EmptyBloomCache( array() );
+ }
+ }
+
+ return self::$instances[$id];
+ }
+
+ /**
+ * Create a new bloom cache instance from configuration.
+ * This should only be called from within BloomCache.
+ *
+ * @param array $config Parameters include:
+ * - cacheID : Prefix to all bloom filter names that is unique to this cache.
+ * It should only consist of alphanumberic, '-', and '_' characters.
+ * This ID is what avoids collisions if multiple logical caches
+ * use the same storage system, so this should be set carefully.
+ */
+ public function __construct( array $config ) {
+ $this->cacheID = $config['cacheId'];
+ if ( !preg_match( '!^[a-zA-Z0-9-_]{1,32}$!', $this->cacheID ) ) {
+ throw new MWException( "Cache ID '{$this->cacheID}' is invalid." );
+ }
+ }
+
+ /**
+ * Check if a member is set in the bloom filter
+ *
+ * A member being set means that it *might* have been added.
+ * A member not being set means it *could not* have been added.
+ *
+ * This abstracts over isHit() to deal with filter updates and readiness.
+ * A class must exist with the name BloomFilter<type> and a static public
+ * mergeAndCheck() method. The later takes the following arguments:
+ * (BloomCache $bcache, $domain, $virtualKey, array $status)
+ * The method should return a bool indicating whether to use the filter.
+ *
+ * The 'shared' bloom key must be used for any updates and will be used
+ * for the membership check if the method returns true. Since the key is shared,
+ * the method should never use delete(). The filter cannot be used in cases where
+ * membership in the filter needs to be taken away. In such cases, code *cannot*
+ * use this method - instead, it can directly use the other BloomCache methods
+ * to manage custom filters with their own keys (e.g. not 'shared').
+ *
+ * @param string $domain
+ * @param string $type
+ * @param string $member
+ * @return bool True if set, false if not (also returns true on error)
+ */
+ final public function check( $domain, $type, $member ) {
+ $section = new ProfileSection( get_class( $this ) . '::' . __FUNCTION__ );
+
+ if ( method_exists( "BloomFilter{$type}", 'mergeAndCheck' ) ) {
+ try {
+ $virtualKey = "$domain:$type";
+
+ $status = $this->getStatus( $virtualKey );
+ if ( $status == false ) {
+ wfDebug( "Could not query virtual bloom filter '$virtualKey'." );
+ return null;
+ }
+
+ $useFilter = call_user_func_array(
+ array( "BloomFilter{$type}", 'mergeAndCheck' ),
+ array( $this, $domain, $virtualKey, $status )
+ );
+
+ if ( $useFilter ) {
+ return ( $this->isHit( 'shared', "$virtualKey:$member" ) !== false );
+ }
+ } catch ( MWException $e ) {
+ MWExceptionHandler::logException( $e );
+ return true;
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * Inform the bloom filter of a new member in order to keep it up to date
+ *
+ * @param string $domain
+ * @param string $type
+ * @param string|array $members
+ * @return bool Success
+ */
+ final public function insert( $domain, $type, $members ) {
+ $section = new ProfileSection( get_class( $this ) . '::' . __FUNCTION__ );
+
+ if ( method_exists( "BloomFilter{$type}", 'mergeAndCheck' ) ) {
+ try {
+ $virtualKey = "$domain:$type";
+ $prefixedMembers = array();
+ foreach ( (array)$members as $member ) {
+ $prefixedMembers[] = "$virtualKey:$member";
+ }
+
+ return $this->add( 'shared', $prefixedMembers );
+ } catch ( MWException $e ) {
+ MWExceptionHandler::logException( $e );
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * Create a new bloom filter at $key (if one does not exist yet)
+ *
+ * @param string $key
+ * @param integer $size Bit length [default: 1000000]
+ * @param float $precision [default: .001]
+ * @return bool Success
+ */
+ final public function init( $key, $size = 1000000, $precision = .001 ) {
+ $section = new ProfileSection( get_class( $this ) . '::' . __FUNCTION__ );
+
+ return $this->doInit( "{$this->cacheID}:$key", $size, min( .1, $precision ) );
+ }
+
+ /**
+ * Add a member to the bloom filter at $key
+ *
+ * @param string $key
+ * @param string|array $members
+ * @return bool Success
+ */
+ final public function add( $key, $members ) {
+ $section = new ProfileSection( get_class( $this ) . '::' . __FUNCTION__ );
+
+ return $this->doAdd( "{$this->cacheID}:$key", (array)$members );
+ }
+
+ /**
+ * Check if a member is set in the bloom filter.
+ *
+ * A member being set means that it *might* have been added.
+ * A member not being set means it *could not* have been added.
+ *
+ * If this returns true, then the caller usually should do the
+ * expensive check (whatever that may be). It can be avoided otherwise.
+ *
+ * @param string $key
+ * @param string $member
+ * @return bool|null True if set, false if not, null on error
+ */
+ final public function isHit( $key, $member ) {
+ $section = new ProfileSection( get_class( $this ) . '::' . __FUNCTION__ );
+
+ return $this->doIsHit( "{$this->cacheID}:$key", $member );
+ }
+
+ /**
+ * Destroy a bloom filter at $key
+ *
+ * @param string $key
+ * @return bool Success
+ */
+ final public function delete( $key ) {
+ $section = new ProfileSection( get_class( $this ) . '::' . __FUNCTION__ );
+
+ return $this->doDelete( "{$this->cacheID}:$key" );
+ }
+
+ /**
+ * Set the status map of the virtual bloom filter at $key
+ *
+ * @param string $virtualKey
+ * @param array $values Map including some of (lastID, asOfTime, epoch)
+ * @return bool Success
+ */
+ final public function setStatus( $virtualKey, array $values ) {
+ $section = new ProfileSection( get_class( $this ) . '::' . __FUNCTION__ );
+
+ return $this->doSetStatus( "{$this->cacheID}:$virtualKey", $values );
+ }
+
+ /**
+ * Get the status map of the virtual bloom filter at $key
+ *
+ * The map includes:
+ * - lastID : the highest ID of the items merged in
+ * - asOfTime : UNIX timestamp that the filter is up-to-date as of
+ * - epoch : UNIX timestamp that filter started being populated
+ * Unset fields will have a null value.
+ *
+ * @param string $virtualKey
+ * @return array|bool False on failure
+ */
+ final public function getStatus( $virtualKey ) {
+ $section = new ProfileSection( get_class( $this ) . '::' . __FUNCTION__ );
+
+ return $this->doGetStatus( "{$this->cacheID}:$virtualKey" );
+ }
+
+ /**
+ * Get an exclusive lock on a filter for updates
+ *
+ * @param string $virtualKey
+ * @return ScopedCallback|ScopedLock|null Returns null if acquisition failed
+ */
+ public function getScopedLock( $virtualKey ) {
+ return null;
+ }
+
+ /**
+ * @param string $key
+ * @param integer $size Bit length
+ * @param float $precision
+ * @return bool Success
+ */
+ abstract protected function doInit( $key, $size, $precision );
+
+ /**
+ * @param string $key
+ * @param array $members
+ * @return bool Success
+ */
+ abstract protected function doAdd( $key, array $members );
+
+ /**
+ * @param string $key
+ * @param string $member
+ * @return bool|null
+ */
+ abstract protected function doIsHit( $key, $member );
+
+ /**
+ * @param string $key
+ * @return bool Success
+ */
+ abstract protected function doDelete( $key );
+
+ /**
+ * @param string $virtualKey
+ * @param array $values
+ * @return bool Success
+ */
+ abstract protected function doSetStatus( $virtualKey, array $values );
+
+ /**
+ * @param string $key
+ * @return array|bool
+ */
+ abstract protected function doGetStatus( $key );
+}
+
+class EmptyBloomCache extends BloomCache {
+ public function __construct( array $config ) {
+ parent::__construct( array( 'cacheId' => 'none' ) );
+ }
+
+ protected function doInit( $key, $size, $precision ) {
+ return true;
+ }
+
+ protected function doAdd( $key, array $members ) {
+ return true;
+ }
+
+ protected function doIsHit( $key, $member ) {
+ return true;
+ }
+
+ protected function doDelete( $key ) {
+ return true;
+ }
+
+ protected function doSetStatus( $virtualKey, array $values ) {
+ return true;
+ }
+
+ protected function doGetStatus( $virtualKey ) {
+ return array( 'lastID' => null, 'asOfTime' => null, 'epoch' => null ) ;
+ }
+}
--- /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
+ */
+
+/**
+ * Bloom filter implented using Redis
+ *
+ * The Redis server must be >= 2.6 and should have volatile-lru or volatile-ttl
+ * if there is any eviction policy. It should not be allkeys-* in any case. Also,
+ * this can be used in a simple master/slave setup or with Redis Sentinal preferably.
+ *
+ * Some bits are based on https://github.com/ErikDubbelboer/redis-lua-scaling-bloom-filter
+ * but are simplified to use a single filter instead of up to 32 filters.
+ *
+ * @since 1.24
+ */
+class BloomCacheRedis extends BloomCache {
+ /** @var RedisConnectionPool */
+ protected $redisPool;
+ /** @var RedisLockManager */
+ protected $lockMgr;
+ /** @var array */
+ protected $servers;
+ /** @var integer Federate each filter into this many redis bitfield objects */
+ protected $segments = 128;
+
+ /**
+ * @params include:
+ * - redisServers : list of servers (address:<port>) (the first is the master)
+ * - redisConf : additional redis configuration
+ *
+ * @param array $config
+ */
+ public function __construct( array $config ) {
+ parent::__construct( $config );
+
+ $redisConf = $config['redisConfig'];
+ $redisConf['serializer'] = 'none'; // manage that in this class
+ $this->redisPool = RedisConnectionPool::singleton( $redisConf );
+ $this->servers = $config['redisServers'];
+ $this->lockMgr = new RedisLockManager( array(
+ 'lockServers' => array( 'srv1' => $this->servers[0] ),
+ 'srvsByBucket' => array( 0 => array( 'srv1' ) ),
+ 'redisConfig' => $config['redisConfig']
+ ) );
+ }
+
+ protected function doInit( $key, $size, $precision ) {
+ $conn = $this->getConnection( 'master' );
+ if ( !$conn ) {
+ return false;
+ }
+
+ // 80000000 items at p = .001 take up 500MB and fit into one value.
+ // Do not hit the 512MB redis value limit by reducing the demands.
+ $size = min( $size, 80000000 * $this->segments );
+ $precision = max( round( $precision, 3 ), .001 );
+ $epoch = microtime( true );
+
+ static $script =
+<<<LUA
+ local kMetadata, kData = unpack(KEYS)
+ local aEntries, aPrec, aEpoch = unpack(ARGV)
+ if redis.call('EXISTS',kMetadata) == 0 or redis.call('EXISTS',kData) == 0 then
+ redis.call('DEL',kMetadata)
+ redis.call('HSET',kMetadata,'entries',aEntries)
+ redis.call('HSET',kMetadata,'precision',aPrec)
+ redis.call('HSET',kMetadata,'epoch',aEpoch)
+ redis.call('SET',kData,'')
+ return 1
+ end
+ return 0
+LUA;
+
+ $res = false;
+ try {
+ $conn->script( 'load', $script );
+ $conn->multi( Redis::MULTI );
+ for ( $i = 0; $i < $this->segments; ++$i ) {
+ $res = $conn->luaEval( $script,
+ array(
+ "$key:$i:bloom-metadata", # KEYS[1]
+ "$key:$i:bloom-data", # KEYS[2]
+ ceil( $size / $this->segments ), # ARGV[1]
+ $precision, # ARGV[2]
+ $epoch # ARGV[3]
+ ),
+ 2 # number of first argument(s) that are keys
+ );
+ }
+ $results = $conn->exec();
+ $res = $results && !in_array( false, $results, true );
+ } catch ( RedisException $e ) {
+ $this->handleException( $conn, $e );
+ }
+
+ return ( $res !== false );
+ }
+
+ protected function doAdd( $key, array $members ) {
+ $conn = $this->getConnection( 'master' );
+ if ( !$conn ) {
+ return false;
+ }
+
+ static $script =
+<<<LUA
+ local kMetadata, kData = unpack(KEYS)
+ local aMember = unpack(ARGV)
+
+ -- Check if the filter was initialized
+ if redis.call('EXISTS',kMetadata) == 0 or redis.call('EXISTS',kData) == 0 then
+ return false
+ end
+
+ -- Initial expected entries and desired precision
+ local entries = 1*redis.call('HGET',kMetadata,'entries')
+ local precision = 1*redis.call('HGET',kMetadata,'precision')
+ local hash = redis.sha1hex(aMember)
+
+ -- Based on the math from: http://en.wikipedia.org/wiki/Bloom_filter#Probability_of_false_positives
+ -- 0.480453013 = ln(2)^2
+ local bits = math.ceil((entries * math.log(precision)) / -0.480453013)
+
+ -- 0.693147180 = ln(2)
+ local k = math.floor(0.693147180 * bits / entries)
+
+ -- This uses a variation on:
+ -- 'Less Hashing, Same Performance: Building a Better Bloom Filter'
+ -- http://www.eecs.harvard.edu/~kirsch/pubs/bbbf/esa06.pdf
+ local h = { }
+ h[0] = tonumber(string.sub(hash, 1, 8 ), 16)
+ h[1] = tonumber(string.sub(hash, 9, 16), 16)
+ h[2] = tonumber(string.sub(hash, 17, 24), 16)
+ h[3] = tonumber(string.sub(hash, 25, 32), 16)
+
+ for i=1, k do
+ local pos = (h[i % 2] + i * h[2 + (((i + (i % 2)) % 4) / 2)]) % bits
+ redis.call('SETBIT', kData, pos, 1)
+ end
+
+ return 1
+LUA;
+
+ $res = false;
+ try {
+ $conn->script( 'load', $script );
+ $conn->multi( Redis::PIPELINE );
+ foreach ( $members as $member ) {
+ $i = $this->getSegment( $member );
+ $conn->luaEval( $script,
+ array(
+ "$key:$i:bloom-metadata", # KEYS[1],
+ "$key:$i:bloom-data", # KEYS[2]
+ $member # ARGV[1]
+ ),
+ 2 # number of first argument(s) that are keys
+ );
+ }
+ $results = $conn->exec();
+ $res = $results && !in_array( false, $results, true );
+ } catch ( RedisException $e ) {
+ $this->handleException( $conn, $e );
+ }
+
+ if ( $res === false ) {
+ wfDebug( "Could not add to the '$key' bloom filter; it may be missing." );
+ }
+
+ return ( $res !== false );
+ }
+
+ protected function doSetStatus( $virtualKey, array $values ) {
+ $conn = $this->getConnection( 'master' );
+ if ( !$conn ) {
+ return null;
+ }
+
+ $res = false;
+ try {
+ $res = $conn->hMSet( "$virtualKey:filter-metadata", $values );
+ } catch ( RedisException $e ) {
+ $this->handleException( $conn, $e );
+ }
+
+ return ( $res !== false );
+ }
+
+ protected function doGetStatus( $virtualKey ) {
+ $conn = $this->getConnection( 'slave' );
+ if ( !$conn ) {
+ return false;
+ }
+
+ $res = false;
+ try {
+ $res = $conn->hGetAll( "$virtualKey:filter-metadata" );
+ } catch ( RedisException $e ) {
+ $this->handleException( $conn, $e );
+ }
+
+ if ( is_array( $res ) ) {
+ $res['lastID'] = isset( $res['lastID'] ) ? $res['lastID'] : null;
+ $res['asOfTime'] = isset( $res['asOfTime'] ) ? $res['asOfTime'] : null;
+ $res['epoch'] = isset( $res['epoch'] ) ? $res['epoch'] : null;
+ }
+
+ return $res;
+ }
+
+ protected function doIsHit( $key, $member ) {
+ $conn = $this->getConnection( 'slave' );
+ if ( !$conn ) {
+ return null;
+ }
+
+ static $script =
+<<<LUA
+ local kMetadata, kData = unpack(KEYS)
+ local aMember = unpack(ARGV)
+
+ -- Check if the filter was initialized
+ if redis.call('EXISTS',kMetadata) == 0 or redis.call('EXISTS',kData) == 0 then
+ return false
+ end
+
+ -- Initial expected entries and desired precision.
+ -- This determines the size of the first and subsequent filters.
+ local entries = redis.call('HGET',kMetadata,'entries')
+ local precision = redis.call('HGET',kMetadata,'precision')
+ local hash = redis.sha1hex(aMember)
+
+ -- This uses a variation on:
+ -- 'Less Hashing, Same Performance: Building a Better Bloom Filter'
+ -- http://www.eecs.harvard.edu/~kirsch/pubs/bbbf/esa06.pdf
+ local h = { }
+ h[0] = tonumber(string.sub(hash, 1, 8 ), 16)
+ h[1] = tonumber(string.sub(hash, 9, 16), 16)
+ h[2] = tonumber(string.sub(hash, 17, 24), 16)
+ h[3] = tonumber(string.sub(hash, 25, 32), 16)
+
+ -- 0.480453013 = ln(2)^2
+ local bits = math.ceil((entries * math.log(precision)) / -0.480453013)
+
+ -- 0.693147180 = ln(2)
+ local k = math.floor(0.693147180 * bits / entries)
+
+ local found = 1
+ for i=1, k do
+ local pos = (h[i % 2] + i * h[2 + (((i + (i % 2)) % 4) / 2)]) % bits
+ if redis.call('GETBIT', kData, pos) == 0 then
+ found = 0
+ break
+ end
+ end
+
+ return found
+LUA;
+
+ $res = null;
+ try {
+ $i = $this->getSegment( $member );
+ $res = $conn->luaEval( $script,
+ array(
+ "$key:$i:bloom-metadata", # KEYS[1],
+ "$key:$i:bloom-data", # KEYS[2]
+ $member # ARGV[1]
+ ),
+ 2 # number of first argument(s) that are keys
+ );
+ } catch ( RedisException $e ) {
+ $this->handleException( $conn, $e );
+ }
+
+ return is_int( $res ) ? (bool)$res : null;
+ }
+
+ protected function doDelete( $key ) {
+ $conn = $this->getConnection( 'master' );
+ if ( !$conn ) {
+ return false;
+ }
+
+ $res = false;
+ try {
+ $keys = array();
+ for ( $i = 0; $i < $this->segments; ++$i ) {
+ $keys[] = "$key:$i:bloom-metadata";
+ $keys[] = "$key:$i:bloom-data";
+ }
+ $res = $conn->delete( $keys );
+ } catch ( RedisException $e ) {
+ $this->handleException( $conn, $e );
+ }
+
+ return ( $res !== false );
+ }
+
+ public function getScopedLock( $virtualKey ) {
+ $status = Status::newGood();
+ return ScopedLock::factory( $this->lockMgr,
+ array( $virtualKey ), LockManager::LOCK_EX, $status );
+ }
+
+ /**
+ * @param string $member
+ * @return integer
+ */
+ protected function getSegment( $member ) {
+ return hexdec( substr( md5( $member ), 0, 2 ) ) % $this->segments;
+ }
+
+ /**
+ * $param string $to (master/slave)
+ * @return RedisConnRef|bool Returns false on failure
+ */
+ protected function getConnection( $to ) {
+ if ( $to === 'master' ) {
+ $conn = $this->redisPool->getConnection( $this->servers[0] );
+ } else {
+ static $lastServer = null;
+
+ $conn = false;
+ if ( $lastServer ) {
+ $conn = $this->redisPool->getConnection( $lastServer );
+ if ( $conn ) {
+ return $conn; // reuse connection
+ }
+ }
+ $servers = $this->servers;
+ $attempts = min( 3, count( $servers ) );
+ for ( $i = 1; $i <= $attempts; ++$i ) {
+ $index = mt_rand( 0, count( $servers ) - 1 );
+ $conn = $this->redisPool->getConnection( $servers[$index] );
+ if ( $conn ) {
+ $lastServer = $servers[$index];
+ return $conn;
+ }
+ unset( $servers[$index] ); // skip next time
+ }
+ }
+
+ return $conn;
+ }
+
+ /**
+ * @param RedisConnRef $conn
+ * @param Exception $e
+ */
+ protected function handleException( RedisConnRef $conn, $e ) {
+ $this->redisPool->handleError( $conn, $e );
+ }
+}
--- /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
+ */
+
+/**
+ * @since 1.24
+ */
+class BloomFilterTitleHasLogs {
+ public static function mergeAndCheck(
+ BloomCache $bcache, $domain, $virtualKey, array $status
+ ) {
+ $age = microtime( true ) - $status['asOfTime']; // seconds
+ $scopedLock = ( mt_rand( 1, (int)pow( 3, max( 0, 5 - $age ) ) ) == 1 )
+ ? $bcache->getScopedLock( $virtualKey )
+ : false;
+
+ if ( $scopedLock ) {
+ $updates = self::merge( $bcache, $domain, $virtualKey, $status );
+ if ( isset( $updates['asOfTime'] ) ) {
+ $age = ( microtime( true ) - $updates['asOfTime'] );
+ }
+ }
+
+ return ( $age < 30 );
+ }
+
+ public static function merge(
+ BloomCache $bcache, $domain, $virtualKey, array $status
+ ) {
+ $limit = 1000;
+ $dbr = wfGetDB( DB_SLAVE, array(), $domain );
+ $res = $dbr->select( 'logging',
+ array( 'log_namespace', 'log_title', 'log_id', 'log_timestamp' ),
+ array( 'log_id > ' . $dbr->addQuotes( (int)$status['lastID'] ) ),
+ __METHOD__,
+ array( 'ORDER BY' => 'log_id', 'LIMIT' => $limit )
+ );
+
+ $updates = array();
+ if ( $res->numRows() > 0 ) {
+ $members = array();
+ foreach ( $res as $row ) {
+ $members[] = "$virtualKey:{$row->log_namespace}:{$row->log_title}";
+ }
+ $lastID = $row->log_id;
+ $lastTime = $row->log_timestamp;
+ if ( !$bcache->add( 'shared', $members ) ) {
+ return false;
+ }
+ $updates['lastID'] = $lastID;
+ $updates['asOfTime'] = wfTimestamp( TS_UNIX, $lastTime );
+ } else {
+ $updates['asOfTime'] = microtime( true );
+ }
+
+ $updates['epoch'] = $status['epoch'] ?: microtime( true );
+
+ $bcache->setStatus( $virtualKey, $updates );
+
+ return $updates;
+ }
+}
*/
class OldChangesList extends ChangesList {
+
/**
* Format a line using the old system (aka without any javascript).
*
public function recentChangesLine( &$rc, $watched = false, $linenumber = null ) {
wfProfileIn( __METHOD__ );
- # Should patrol-related stuff be shown?
- $unpatrolled = $this->showAsUnpatrolled( $rc );
-
- $s = '';
$classes = array();
// use mw-line-even/mw-line-odd class only if linenumber is given (feature from bug 14468)
if ( $linenumber ) {
$classes[] = $watched && $rc->mAttribs['rc_timestamp'] >= $watched
? 'mw-changeslist-line-watched' : 'mw-changeslist-line-not-watched';
+ $html = $this->formatChangeLine( $rc, $watched );
+
+ if ( $this->watchlist ) {
+ $classes[] = Sanitizer::escapeClass( 'watchlist-' .
+ $rc->mAttribs['rc_namespace'] . '-' . $rc->mAttribs['rc_title'] );
+ }
+
+ if ( !wfRunHooks( 'OldChangesListRecentChangesLine', array( &$this, &$html, $rc, &$classes ) ) ) {
+ wfProfileOut( __METHOD__ );
+
+ return false;
+ }
+
+ wfProfileOut( __METHOD__ );
+
+ $dateheader = ''; // $html now contains only <li>...</li>, for hooks' convenience.
+ $this->insertDateHeader( $dateheader, $rc->mAttribs['rc_timestamp'] );
+
+ return "$dateheader<li class=\"" . implode( ' ', $classes ) . "\">" . $html . "</li>\n";
+ }
+
+ /**
+ * @param RecentChange $rc
+ * @param boolean $watched
+ *
+ * @return string
+ */
+ private function formatChangeLine( RecentChange $rc, $watched ) {
+ $html = '';
+
if ( $rc->mAttribs['rc_log_type'] ) {
$logtitle = SpecialPage::getTitleFor( 'Log', $rc->mAttribs['rc_log_type'] );
- $this->insertLog( $s, $logtitle, $rc->mAttribs['rc_log_type'] );
+ $this->insertLog( $html, $logtitle, $rc->mAttribs['rc_log_type'] );
// Log entries (old format) or log targets, and special pages
} elseif ( $rc->mAttribs['rc_namespace'] == NS_SPECIAL ) {
- list( $name, $subpage ) = SpecialPageFactory::resolveAlias( $rc->mAttribs['rc_title'] );
+ list( $name, $htmlubpage ) = SpecialPageFactory::resolveAlias( $rc->mAttribs['rc_title'] );
if ( $name == 'Log' ) {
- $this->insertLog( $s, $rc->getTitle(), $subpage );
+ $this->insertLog( $html, $rc->getTitle(), $htmlubpage );
}
// Regular entries
} else {
- $this->insertDiffHist( $s, $rc, $unpatrolled );
+ $unpatrolled = $this->showAsUnpatrolled( $rc );
+
+ $this->insertDiffHist( $html, $rc, $unpatrolled );
# M, N, b and ! (minor, new, bot and unpatrolled)
- $s .= $this->recentChangesFlags(
+ $html .= $this->recentChangesFlags(
array(
'newpage' => $rc->mAttribs['rc_type'] == RC_NEW,
'minor' => $rc->mAttribs['rc_minor'],
),
''
);
- $this->insertArticleLink( $s, $rc, $unpatrolled, $watched );
+ $this->insertArticleLink( $html, $rc, $unpatrolled, $watched );
}
# Edit/log timestamp
- $this->insertTimestamp( $s, $rc );
+ $this->insertTimestamp( $html, $rc );
# Bytes added or removed
if ( $this->getConfig()->get( 'RCShowChangedSize' ) ) {
$cd = $this->formatCharacterDifference( $rc );
if ( $cd !== '' ) {
- $s .= $cd . ' <span class="mw-changeslist-separator">. .</span> ';
+ $html .= $cd . ' <span class="mw-changeslist-separator">. .</span> ';
}
}
if ( $rc->mAttribs['rc_type'] == RC_LOG ) {
- $s .= $this->insertLogEntry( $rc );
+ $html .= $this->insertLogEntry( $rc );
} else {
# User tool links
- $this->insertUserRelatedLinks( $s, $rc );
+ $this->insertUserRelatedLinks( $html, $rc );
# LTR/RTL direction mark
- $s .= $this->getLanguage()->getDirMark();
- $s .= $this->insertComment( $rc );
+ $html .= $this->getLanguage()->getDirMark();
+ $html .= $this->insertComment( $rc );
}
# Tags
- $this->insertTags( $s, $rc, $classes );
+ $this->insertTags( $html, $rc, $classes );
# Rollback
- $this->insertRollback( $s, $rc );
+ $this->insertRollback( $html, $rc );
# For subclasses
- $this->insertExtra( $s, $rc, $classes );
+ $this->insertExtra( $html, $rc, $classes );
# How many users watch this page
if ( $rc->numberofWatchingusers > 0 ) {
- $s .= ' ' . $this->numberofWatchingusers( $rc->numberofWatchingusers );
- }
-
- if ( $this->watchlist ) {
- $classes[] = Sanitizer::escapeClass( 'watchlist-' .
- $rc->mAttribs['rc_namespace'] . '-' . $rc->mAttribs['rc_title'] );
+ $html .= ' ' . $this->numberofWatchingusers( $rc->numberofWatchingusers );
}
- if ( !wfRunHooks( 'OldChangesListRecentChangesLine', array( &$this, &$s, $rc, &$classes ) ) ) {
- wfProfileOut( __METHOD__ );
-
- return false;
- }
-
- wfProfileOut( __METHOD__ );
-
- $dateheader = ''; // $s now contains only <li>...</li>, for hooks' convenience.
- $this->insertDateHeader( $dateheader, $rc->mAttribs['rc_timestamp'] );
-
- return "$dateheader<li class=\"" . implode( ' ', $classes ) . "\">" . $s . "</li>\n";
+ return $html;
}
}
'undoafter' => $this->mOldid,
'undo' => $this->mNewid
) ),
- 'title' => Linker::titleAttrib( 'undo' )
+ 'title' => Linker::titleAttrib( 'undo' ),
),
$this->msg( 'editundo' )->text()
);
- $revisionTools[] = $undoLink;
+ $revisionTools['mw-diff-undo'] = $undoLink;
}
}
wfRunHooks( 'DiffRevisionTools', array( $this->mNewRev, &$revisionTools, $this->mOldRev ) );
$formattedRevisionTools = array();
// Put each one in parentheses (poor man's button)
- foreach ( $revisionTools as $tool ) {
- $formattedRevisionTools[] = $this->msg( 'parentheses' )->rawParams( $tool )->escaped();
+ foreach ( $revisionTools as $key => $tool ) {
+ $toolClass = is_string( $key ) ? $key : 'mw-diff-tool';
+ $element = Html::rawElement(
+ 'span',
+ array( 'class' => $toolClass ),
+ $this->msg( 'parentheses' )->rawParams( $tool )->escaped()
+ );
+ $formattedRevisionTools[] = $element;
}
$newRevisionHeader = $this->getRevisionHeader( $this->mNewRev, 'complete' ) .
' ' . implode( ' ', $formattedRevisionTools );
$key = $title->quickUserCan( 'edit', $user ) ? 'editold' : 'viewsourceold';
$msg = $this->msg( $key )->escaped();
- $header .= ' ' . $this->msg( 'parentheses' )->rawParams(
- Linker::linkKnown( $title, $msg, array(), $editQuery ) )->plain();
+ $editLink = $this->msg( 'parentheses' )->rawParams(
+ Linker::linkKnown( $title, $msg, array( ), $editQuery ) )->plain();
+ $header .= ' ' . Html::rawElement(
+ 'span',
+ array( 'class' => 'mw-diff-edit' ),
+ $editLink
+ );
if ( $rev->isDeleted( Revision::DELETED_TEXT ) ) {
$header = Html::rawElement(
'span',
"config-db-web-help": "Diuzañ an anv implijer hag ar ger-tremen a vo implijet gant ar servijer web evit kevreañ ouzh ar servijer diaz roadennoù pa vez ar wiki o vont en-dro war ar pemdez.",
"config-db-web-account-same": "Ober gant an hevelep kont hag an hini implijet evit ar staliañ",
"config-db-web-create": "Krouiñ ar gont ma n'eus ket anezhi c'hoazh",
+ "config-db-web-no-create-privs": "Ar gont ho peus diferet evit ar staliañ n'he deus ket gwirioù a-walc'h evit krouiñ ur gont.\nRet eo d'ar gont diferet amañ bezañ anezhi dija.",
"config-mysql-engine": "Lusker stokañ :",
"config-mysql-innodb": "InnoDB",
"config-mysql-myisam": "MyISAM",
"config-session-expired": "Tus datos de sesión parecen haber expirado.\nLas sesiones están configuradas por una duración de $1.\nPuedes incrementar esto configurando <code>session.gc_maxlifetime</code> en php.ini.\nReiniciar el proceso de instalación.",
"config-no-session": "Se han perdido los datos de sesión.\nVerifica tu php.ini y comprueba que <code>session.save_path</code> está establecido en un directorio apropiado.",
"config-your-language": "Tu idioma:",
- "config-your-language-help": "Seleccionar un idioma a usar durante el proceso de instalación.",
+ "config-your-language-help": "Selecciona un idioma para usar durante el proceso de instalación.",
"config-wiki-language": "Idioma del wiki:",
- "config-wiki-language-help": "Seleccionar el idioma en el que el wiki será escrito predominantemente.",
+ "config-wiki-language-help": "Selecciona el idioma en el que se escribirá predominantemente el wiki.",
"config-back": "← Atrás",
"config-continue": "Continuar →",
"config-page-language": "Idioma",
"config-no-cache": "'''Advertencia:''' No pudo encontrarse [http://www.php.net/apc APC], [http://xcache.lighttpd.net/ XCache] o [http://www.iis.net/download/WinCacheForPhp WinCache].\nEl caché de objetos no está habilitado.",
"config-mod-security": "''' Advertencia ''': Su servidor web tiene [http://modsecurity.org/ mod_security] habilitado. Si la configuración es incorrecta, puede causar problemas a MediaWiki u otro software que permita a los usuarios publicar contenido arbitrarios.\nConsulte la [http://modsecurity.org/documentation/ documentación de mod_security] o contacte con el soporte de su servidor (''host'') si encuentra errores aleatorios.",
"config-diff3-bad": "GNU diff3 no se encuentra.",
- "config-git": "Se encontró el ''software'' de control de versiones Git: <code>$1</code>.",
+ "config-git": "Se encontró el software de control de versiones Git: <code>$1</code>.",
"config-git-bad": "No se encontró el software de control de versiones Git.",
"config-imagemagick": "ImageMagick encontrado: <code>$1</code>.\nLa miniaturización de imágenes se habilitará si habilitas las cargas.",
"config-gd": "Se ha encontrado una biblioteca de gráficos GD integrada.\nLa miniaturización de imágenes se habilitará si habilitas las subidas.",
"config-no-scaling": "No se ha encontrado ninguma biblioteca GD o ImageMagik.\nSe inhabilitará la miniaturización de imágenes.",
- "config-no-uri": "'''Error:''' No se pudo determinar el URI actual.\nSe interrumpió la instalación.",
+ "config-no-uri": "<strong>Error:</strong> no se pudo determinar el URI actual.\nSe interrumpió la instalación.",
"config-no-cli-uri": "<strong>Aviso:</strong> No se especificó <code>--scriptpath</code>; se usa el valor predeterminado: <code>$1</code>.",
"config-using-server": "Utilizando el nombre de servidor \"<nowiki>$1</nowiki>\".",
- "config-using-uri": "Utilizando la dirección URL del servidor \"<nowiki>$1$2</nowiki>\".",
+ "config-using-uri": "Utilizando la URL del servidor \"<nowiki>$1$2</nowiki>\".",
"config-uploads-not-safe": "'''Atención:''' Su directorio por defecto para las cargas, <code>$1</code>, es vulnerable a la ejecución de scripts arbitrarios.\nAunque MediaWiki comprueba todos los archivos cargados por si hubiese amenazas de seguridad, es altamente recomendable [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:Security#Upload_security cerrar esta vulnerabilidad de seguridad] antes de activar las cargas.",
"config-no-cli-uploads-check": "'''Atención:''' Su directorio predeterminado para cargas (<code>$1</code>) no está comprobado para la vulnerabilidad\n de ejecución arbitraria de comandos script durante la instalación de CLI.",
"config-brokenlibxml": "El sistema tiene una combinación de versiones de PHP y de libxml2 que es poco confiable y puede provocar corrupción oculta en los datos de MediaWiki y otras aplicaciones web.\nActualizar a PHP 5.2.9 o posterior y a libxml2 2.7.3 o posterior ([//bugs.php.net/bug.php?id=45996 bug reportado con PHP]).\nInstalación abortada.",
"config-suhosin-max-value-length": "Suhosin está instalado y limita el parámetro <code>length</code> GET a $1 bytes.\nEl componente ResourceLoader (gestor de recursos) de MediaWiki trabajará en este límite, pero eso perjudicará el rendimiento.\nSi es posible, deberías establecer <code>suhosin.get.max_value_length</code> en el valor 1024 o superior en <code>php.ini</code> y establecer <code>$wgResourceLoaderMaxQueryLength</code> en el mismo valor en <code>php.ini</code>.",
- "config-db-type": "Tipo de base de datos",
+ "config-db-type": "Tipo de base de datos:",
"config-db-host": "Servidor de la base de datos:",
"config-db-host-help": "Si su servidor de base de datos está en otro servidor, escriba el nombre del host o su dirección IP aquí.\nSi está utilizando alojamiento web compartido, su proveedor de alojamiento debería darle el nombre correcto del servidor de alojamiento (host) en su documentación.\nSi va a instalarlo en un servidor Windows y utiliza MySQL, el uso de \"localhost\" como nombre del servidor puede no funcionar. Si no es así, intente poner \"127.0.0.1\" como dirección IP local.\nSi utiliza PostgreSQL, deje este campo en blanco para conectarse a través de un socket de Unix.",
"config-db-host-oracle": "TNS de la base de datos:",
"config-db-host-oracle-help": "Introduzca un [http://download.oracle.com/docs/cd/B28359_01/network.111/b28317/tnsnames.htm nombre de conexión local] válido; un archivo tnsnames.ora debe ser visible para esta instalación.<br />Si está utilizando bibliotecas de cliente 10g o más recientes también puede utilizar el método de asignación de nombres [http://download.oracle.com/docs/cd/E11882_01/network.112/e10836/naming.htm Easy Connect].",
- "config-db-wiki-settings": "Identifique este wiki",
- "config-db-name": "Nombre de base de datos:",
+ "config-db-wiki-settings": "Identifica este wiki",
+ "config-db-name": "Nombre de la base de datos:",
"config-db-name-help": "Elija un nombre que identifique su wiki.\nNo debe contener espacios.\n\nSi está utilizando alojamiento web compartido, su proveedor de alojamiento le dará un nombre específico de base de datos para que lo utilice, o bien le permitirá crear bases de datos a través de un panel de control.",
- "config-db-name-oracle": "Esquema de base de datos:",
+ "config-db-name-oracle": "Esquema de la base de datos:",
"config-db-account-oracle-warn": "Hay tres escenarios compatibles para la instalación de Oracle como base de datos back-end:\n\nSi desea crear una cuenta de base de datos como parte del proceso de instalación, por favor suministre una cuenta con función SYSDBA como cuenta de base de datos para la instalación y especifique las credenciales deseadas de la cuenta de acceso al web, de lo contrario puede crear manualmente la cuenta de acceso al web y suministrar sólo esa cuenta (si tiene los permisos necesarios para crear los objetos de esquema) o suministrar dos cuentas diferentes, una con privilegios de creación y otra con acceso restringido a la web\n\nLa secuencia de comandos (script) para crear una cuenta con los privilegios necesarios puede encontrarse en el directorio \"maintenance/oracle/\" de esta instalación. Tenga en cuenta que utilizando una cuenta restringida desactivará todas las capacidades de mantenimiento con la cuenta predeterminada.",
"config-db-install-account": "Cuenta de usuario para instalación",
- "config-db-username": "Nombre de usuario de base de datos:",
- "config-db-password": "contraseña de base de datos:",
+ "config-db-username": "Nombre de usuario de la base de datos:",
+ "config-db-password": "Contraseña de la base de datos:",
"config-db-password-empty": "Introduzca una contraseña para el nuevo usuario de base de datos: $1.\nAunque es posible crear usuarios sin contraseña, esto no es seguro.",
"config-db-username-empty": "Debe introducir un valor para \"{{int:config-db-username}}\"",
"config-db-install-username": "Introduzca el nombre de usuario que se utilizará para conectarse a la base de datos durante el proceso de instalación.\nEste no es el nombre de usuario de la cuenta de MediaWiki; Este es el nombre de usuario para la base de datos.",
"config-db-install-password": "Introduzca la contraseña que se utilizará para conectarse a la base de datos durante el proceso de instalación.\nEsta no es la contraseña para la cuenta de MediaWiki; esta es la contraseña para la base de datos.",
"config-db-install-help": "Ingresar el nombre de usuario y la contraseña que será usada para conectar a la base de datos durante el proceso de instalación.",
"config-db-account-lock": "Usar el mismo nombre de usuario y contraseña durante operación normal",
- "config-db-wiki-account": "Usar cuenta para operación normal",
+ "config-db-wiki-account": "Cuenta de usuario para operación normal",
"config-db-wiki-help": "Introduce el nombre de usuario y la contraseña que serán usados para acceder a la base de datos durante la operación normal del wiki.\nSi esta cuenta no existe y la cuenta de instalación tiene suficientes privilegios, se creará esta cuenta de usuario con los privilegios mínimos necesarios para la operación normal del wiki.",
- "config-db-prefix": "Prefijo de tablas de base de datos:",
+ "config-db-prefix": "Prefijo de tablas de la base de datos:",
"config-db-prefix-help": "Si necesita compartir una base de datos entre múltiples wikis, o entre MediaWiki y otra aplicación web, puede optar por agregar un prefijo a todos los nombres de tabla para evitar conflictos.\nNo utilice espacios.\n\nNormalmente se deja este campo vacío.",
"config-db-charset": "Conjunto de caracteres de la base de datos",
"config-charset-mysql5-binary": "MySQL 4.1/5.0 binario",
"config-charset-mysql5": "MySQL 4.1/5.0 UTF-8",
"config-charset-mysql4": "MySQL 4.0 retrocompatible UTF-8",
"config-charset-help": "'''Atención:''' Si emplea '''backwards-compatible UTF-8''' en MySQL 4.1+ y posteriormente hace copia de seguridad de la base de datos con <code>mysqldump</code> , puede destruir todos los caracteres no-ASCII, ¡dañando irreversiblemente sus copias de seguridad!\n\nEn '''modo binario''', MediaWiki almacena texto UTF-8 en la base de datos en campos binarios.\nEsto es más eficiente que el modo UTF-8 de MySQL, y le permite utilizar la gama completa de caracteres Unicode.\nEn ''' modo UTF-8'' ', MySQL sabrá el juego de caracteres de sus datos y puede presentarlos y convertirlos apropiadamente,\npero no le permitirá almacenar caracteres por encima del [//en.wikipedia.org/wiki/Mapping_of_Unicode_character_planes plano multilingüe básico].",
- "config-mysql-old": "Se necesita MySQL $1 o una versión más reciente. Tienes la versión $2.",
+ "config-mysql-old": "Se necesita MySQL $1 o posterior. Tienes $2.",
"config-db-port": "Puerto de la base de datos:",
"config-db-schema": "Esquema para MediaWiki",
"config-db-schema-help": "Estos esquemas usualmente estarán bien.\nAltéralos sólo si tienes la seguridad de que necesitas hacerlo.",
"config-upgrade-done": "Actualización completa.\n\nUsted puede ahora [ $1 empezar a usar su wiki].\n\nSi desea regenerar su archivo <code>LocalSettings.php</code> de archivo, haga clic en el botón de abajo.\nEsto '''no se recomienda''' a menos que esté teniendo problemas con su wiki.",
"config-upgrade-done-no-regenerate": "Actualización completa.\n\nUsted puede ahora [$1 empezar a usar su wiki].",
"config-regenerate": "Regenerar LocalSettings.php →",
- "config-show-table-status": "<code>SHOW TABLE STATUS</code> ha fallado!",
+ "config-show-table-status": "¡Falló la consulta <code>SHOW TABLE STATUS</code>!",
"config-unknown-collation": "'''Advertencia:''' La base de datos está utilizando una intercalación no reconocida.",
- "config-db-web-account": "Cuenta de base de datos para acceso Web",
+ "config-db-web-account": "Cuenta de la base de datos para acceso web",
"config-db-web-help": "Elige el usuario y contraseña que el servidor Web usará para conectarse al servidor de la base de datos durante el fincionamiento normal del wiki.",
"config-db-web-account-same": "Utilizar la misma cuenta que en la instalación",
"config-db-web-create": "Crear la cuenta si no existe",
"config-mysql-binary": "Binario",
"config-mysql-utf8": "UTF-8",
"config-mysql-charset-help": "En '''modo binario''', MediaWiki almacena texto UTF-8 para la base de datos en campos binarios.\nEsto es más eficiente que el modo UTF-8 de MySQL y le permite utilizar la gama completa de caracteres Unicode.\n\nEn '''modo UTF-8''', MySQL sabrá qué conjunto de caracteres emplean sus datos y puede presentarlos y convertirlos adecuadamente, pero no le permitirá almacenar caracteres por encima del [//en.wikipedia.org/wiki/Mapping_of_Unicode_character_planes plano multilingüe básico].",
- "config-mssql-auth": "Tipo de autentificación:",
+ "config-mssql-auth": "Tipo de autenticación:",
"config-mssql-install-auth": "Seleccione el tipo de autenticación que se utilizará para conectarse a la base de datos durante el proceso de instalación.\nSi selecciona \"{{int:config-mssql-windowsauth}}\", las credenciales de cualquier usuario de el servidor web que se está ejecutando van a ser utilizadas.",
"config-mssql-web-auth": "Seleccione el tipo de autenticación que utilizará el servidor web para conectarse al servidor de base de datos, durante el funcionamiento normal de la wiki.\nSi selecciona \"{{int:config-mssql-windowsauth}}\", las credenciales del usuario que sea cual sea el servidor Web se ejecuta como será utilizado.",
"config-mssql-sqlauth": "Autenticación de SQL Server",
"config-site-name-blank": "Ingresar un nombre de sitio.",
"config-project-namespace": "Espacio de nombre de proyecto:",
"config-ns-generic": "Proyecto",
- "config-ns-site-name": "Igual como el nombre del wiki: $1",
+ "config-ns-site-name": "Igual al nombre del wiki: $1",
"config-ns-other": "Otro (especificar)",
"config-ns-other-default": "MiWiki",
"config-project-namespace-help": "Siguiendo el ejemplo de Wikipedia, muchos wikis mantienen sus páginas de políticas separadas de sus páginas de contenido, en un \"'''espacio de nombres del proyecto'''\".\n\nTodos los títulos de página en este espacio de nombres comienzan con un determinado prefijo, que usted puede especificar aquí.\nTradicionalmente, este prefijo se deriva del nombre del wiki, pero no puede contener caracteres de puntuación como \"#\" o \":\".",
"config-admin-box": "Cuenta de administrador",
"config-admin-name": "Tu nombre de usuario:",
"config-admin-password": "Contraseña:",
- "config-admin-password-confirm": "Repita la contraseña:",
+ "config-admin-password-confirm": "Repite la contraseña:",
"config-admin-help": "Escribe aquí el nombre de usuario que desees, como por ejemplo \"Pedro Bloggs\".\nEste es el nombre que usarás para entrar al wiki.",
"config-admin-name-blank": "Introduce un nombre de usuario de administrador.",
"config-admin-name-invalid": "El nombre de usuario especificado \"<nowiki>$1</nowiki>\" no es válido.\nEspecifique un nombre de usuario diferente.",
"config-profile-fishbowl": "Sólo editores autorizados",
"config-profile-private": "Wiki privado",
"config-profile-help": "Los wikis funcionan mejor cuando dejas que los edite tanta gente como sea posible.\nEn MediaWiki, es fácil revisar los cambios recientes y revertir los daños realizados por usuarios malintencionados o novatos.\nSin embargo, muchos han encontrado que MediaWiki es útil para una amplia variedad de funciones, y a veces no es fácil convencer a todos de los beneficios de la forma wiki.\nPor lo tanto tienes la elección.\n\nEl modelo '''{{int:config-profile-wiki}}''' permite que cualquiera pueda editar, sin siquiera iniciar sesión.\nUn wiki con '''{{int:config-profile-no-anon}}''' ofrece rendición de cuentas adicional, pero puede disuadir a colaboradores.\n\nEl modelo '''{{int:config-profile-fishbowl}}''' permite editar a los usuarios autorizados, pero el público puede ver las páginas, incluyendo el historial.\nUn '''{{int:config-profile-private}}''' sólo permite ver páginas a los usuarios autorizados, el mismo grupo al que le está permitido editar.\n\nConfiguraciones más complejas de derechos de usuario están disponibles después de la instalación, consulte [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:User_rights esta entrada en el manual].",
- "config-license": "Copyright and licencia:",
+ "config-license": "Derechos de autor y licencia:",
"config-license-none": "Pie sin licencia",
- "config-license-cc-by-sa": "Creative Commons Reconocimiento Compartir Igual",
- "config-license-cc-by": "Creative Commons Reconocimiento",
- "config-license-cc-by-nc-sa": "Creative Commons Reconocimiento Compartir Igual no comercial",
+ "config-license-cc-by-sa": "Creative Commons Atribución-CompartirIgual",
+ "config-license-cc-by": "Creative Commons Atribución",
+ "config-license-cc-by-nc-sa": "Creative Commons Atribución-NoComercial-CompartirIgual",
"config-license-cc-0": "Creative Commons Zero (dominio público)",
"config-license-gfdl": "Licencia de documentación libre de GNU 1.3 o posterior",
- "config-license-pd": "Dominio Público",
+ "config-license-pd": "Dominio público",
"config-license-cc-choose": "Selecciona una licencia personalizada de Creative Commons",
"config-license-help": "Muchos wikis públicos ponen todas las contribuciones bajo una [http://freedomdefined.org/Definition licencia libre].\nEsto ayuda a crear un sentido de propiedad comunitaria y alienta la contribución a largo plazo.\nEsto no es generalmente necesario para un wiki privado o corporativo.\n\nSi deseas poder utilizar texto de Wikipedia, y deseas que Wikipedia pueda aceptar el texto copiado de tu wiki, debes elegir <strong>{{int:config-license-cc-by-sa}}</strong>.\n\nWikipedia utilizaba anteriormente la licencia de documentación libre de GNU (GFDL).\nLa GFDL es una licencia válida, pero es difícil de entender.\nTambién es difícil reutilizar el contenido licenciado bajo la GFDL.",
"config-email-settings": "Configuración de correo electrónico",
"config-enable-email": "Activar el envío de correos electrónicos",
"config-enable-email-help": "Si quieres que el correo electrónico funcione, la [http://www.php.net/manual/en/mail.configuration.php configuración PHP de correo electrónico] debe ser la correcta.\nSi no quieres la funcionalidad de correo electrónico, puedes desactivarla aquí.",
- "config-email-user": "Habilitar correo electrónico de usuario a usuario",
+ "config-email-user": "Habilitar correo electrónico entre usuarios",
"config-email-user-help": "Permitir que todos los usuarios intercambien correos electrónicos si lo han activado en sus preferencias.",
"config-email-usertalk": "Activar notificaciones de páginas de discusión de usuarios",
"config-email-usertalk-help": "Permitir a los usuarios recibir notificaciones de cambios en la página de discusión de usuario, si lo han activado en sus preferencias.",
"config-install-user": "Creando el usuario de la base de datos",
"config-install-user-alreadyexists": "El usuario \"$1\" ya existe",
"config-install-user-create-failed": "La creación del usuario \"$1\" falló: $2",
- "config-install-user-grant-failed": "La concesión de permisos para el usuario \"$1\" ha fallado: $2",
+ "config-install-user-grant-failed": "La concesión de permisos al usuario \"$1\" falló: $2",
"config-install-user-missing": "El usuario especificado \"$1\" no existe.",
"config-install-user-missing-create": "El usuario especificado \"$1\" no existe.\nPor favor, haga clic en la casilla \"Crear cuenta\" que aparece a continuación si desea crearlo.",
"config-install-tables": "Creando tablas",
"config-install-interwiki-list": "No se pudo encontrar el archivo <code>interwiki.list</code>.",
"config-install-interwiki-exists": "'''Advertencia''': La tabla de interwikis parece ya contener entradas.\nSe omitirá la lista predeterminada.",
"config-install-stats": "Iniciando las estadísticas",
- "config-install-keys": "Generación de claves secretas",
+ "config-install-keys": "Generando claves secretas",
"config-insecure-keys": "''' Atención:'' ' {{PLURAL:$2|Una clave de seguridad generada|Las claves de seguridad generadas}} ($1) durante la instalación no {{PLURAL:$2|es totalmente segura|son totalmente seguras}}. Considere {{PLURAL:$2| cambiarla|cambiarlas}} manualmente.",
- "config-install-sysop": "Creando cuenta de usuario del administrador",
+ "config-install-sysop": "Creando la cuenta de usuario del administrador",
"config-install-subscribe-fail": "No se ha podido suscribir a mediawiki-announce: $1",
"config-install-subscribe-notpossible": "cURL no está instalado y <code>allow_url_fopen</code> no está disponible.",
"config-install-mainpage": "Creando página principal con contenido predeterminado",
"config-install-mainpage-failed": "No se pudo insertar la página principal: $1",
"config-install-done": "<strong>¡Felicidades!</strong>\nHas instalado MediaWiki correctamente.\n\nEl instalador ha generado un archivo <code>LocalSettings.php</code>.\nEste contiene toda su configuración.\n\nDeberás descargarlo y ponerlo en la base de la instalación de wiki (el mismo directorio que index.php). La descarga debería haber comenzado automáticamente.\n\nSi no comenzó la descarga, o si se ha cancelado, puedes reiniciar la descarga haciendo clic en el siguiente enlace:\n\n$3\n\n<strong>Nota</strong>: Si no haces esto ahora, este archivo de configuración generado no estará disponible más tarde si sales de la instalación sin descargarlo.\n\nCuando lo hayas hecho, podrás <strong>[$2 entrar en tu wiki]</strong>.",
"config-download-localsettings": "Descargar archivo <code>LocalSettings.php</code>",
- "config-help": "Ayuda",
- "config-help-tooltip": "Haz clic para ampliar",
+ "config-help": "ayuda",
+ "config-help-tooltip": "haz clic para ampliar",
"config-nofile": "El archivo \"$1\" no se pudo encontrar. ¿Se ha eliminado?",
"config-extension-link": "¿Sabías que tu wiki admite [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:Extensions extensiones]?\n\nPuedes navegar por las [//www.mediawiki.org/wiki/Special:MyLanguage/Category:Extensions_by_category categorías] o visitar el [//www.mediawiki.org/wiki/Extension_Matrix centro de extensiones] para ver una lista completa.",
- "mainpagetext": "'''MediaWiki ha sido instalado con éxito.'''",
+ "mainpagetext": "<strong>MediaWiki se ha instalado con éxito.<strong>",
"mainpagedocfooter": "Consulta la [//meta.wikimedia.org/wiki/Help:Contents/es guía del usuario] para obtener información sobre el uso del software wiki.\n\n== Primeros pasos ==\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:Configuration_settings Lista de ajustes de configuración]\n* [//www.mediawiki.org/wiki/Manual:FAQ/es Preguntas frecuentes sobre MediaWiki]\n* [https://lists.wikimedia.org/mailman/listinfo/mediawiki-announce Lista de correo de anuncios de publicación de MediaWiki]\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Localisation#Translation_resources Traducir MediaWiki en tu idioma]"
}
"config-upgrade-key-missing": "نصب موجود مدیاویکی شناسایی شدهاست.\nبرای بروزرسانی این نصب، لطفاً خط زیر را در آخر کد \nقرار دادن به نصب ارتقاء داده شده، به خط زیر لطفاً در پایین خود را <code>LocalSettings.php</code> قرار دهید:\n\n$1",
"config-localsettings-incomplete": "وجود <code>LocalSettings.php</code> به نظر ناقص میرسد.\nمتغیر $1 تنظیم نشدهاست.\nبرای اینکه این متغیر تنظیم شود لطفاً <code>LocalSettings.php</code> را تغییر دهید، و \"{{int:Config-continue}}\" را کلیک کنید.",
"config-localsettings-connection-error": "هنگام اتصال به پایگاه اطلاعاتی که ازتنظیمات مشخص شده در<code>LocalSettings.php</code> استفاده میکند، خطایی رخ داد. لطفاً این تنظیمات را نصب کنید و دوباره تلاش کنید.\n$1",
- "config-session-error": "خطا در شروع جلسه $1",
+ "config-session-error": "خطا در شروع جلسه: $1",
"config-session-expired": "به نظر میرسد اطلاعات جلسهٔ شما منقضی شدهاست.\nجلسات برای مادام العمر $1 پیکربندی شدهاند.\nشما میتوانید این پیکربندی را با تنظیم <code>session.gc_maxlifetime</code> در php.ini افزایش دهید.\nروند نصب را دوباره شروع کنید.",
"config-no-session": "اطلاعات دورهٔ شما از دست رفته است!\nphp.ini خود را بررسی کنید و مطمئن شوید <code>session.save_path</code> برای یک فهرست مناسب تنظیم شدهاست.",
"config-your-language": "زبان شما:",
"config-page-language": "زبان",
"config-page-welcome": "به مدیاویکی خوش آمدید!",
"config-page-dbconnect": "اتصال به پایگاه داده",
- "config-page-upgrade": "نصب موجود را ارتقاء دهید.",
- "config-page-dbsettings": "تÙ\86ظÛ\8cÙ\85ات پاÛ\8cگاÙ\87 اطÙ\84اعاتÛ\8c",
+ "config-page-upgrade": "ارتقای نصب موجود",
+ "config-page-dbsettings": "تÙ\86ظÛ\8cÙ\85ات پاÛ\8cگاÙ\87 دادÙ\87",
"config-page-name": "نام",
"config-page-options": "گزینهها",
"config-page-install": "نصب",
"config-page-complete": "کامل!",
- "config-page-restart": "نصب را دوباره شروع کنید",
+ "config-page-restart": "راهاندازی دوباره نصب",
"config-page-readme": "مرا بخوان",
"config-page-releasenotes": "یادداشتهای انتشار",
"config-page-copying": "تکثیر",
- "config-page-upgradedoc": "ارتقا",
+ "config-page-upgradedoc": "ارتقاء",
"config-page-existingwiki": "ویکی موجود",
"config-help-restart": "آیا میخواهید همهٔ اطلاعات ذخیره شدهای که وارد کردهاید را پاک کنید و دوباره روند نصب را شروع کنید؟",
- "config-restart": "بله ، آن دوباره راه اندازی کن",
+ "config-restart": "بله، دوباره راهاندازی کن",
"config-welcome": "===بررسیهای محیطی===\nبرای فهمیدن اینکه این محیط برای نصب مدیاویکی مناسب است، اکنون بررسیهای اساسی انجام خواهدشد.\nاگر به دنبال پشتیبانی در چگونگی تکمیل نصب هستید،به یاد داشته باشید این اطلاعات را بگنجانید.",
"config-copyright": "===حق چاپ و شرایط===\n$1\nاین برنامه،نرمافزاری آزاد است;شما میتوانید این برنامه را دوباره توزیع کنید و/یا تحت شرایط مجوز عمومی کلی جیانیو که توسط بنیاد نرمافزار آزاد منتشر شده،اصلاح کنید;یا نسخهٔ 2 مجوز، یا (به انتخاب خود) هر نسخهٔ پس از این.\nاین برنامه به امید اینکه مفید واقع شود توزیع شدهاست،اما '''بدون هیچ ضمانتی'''; حتی بدون اشارهٔ ضمانتی از '''قابلیت عرضه''' یا ''' صلاحیت برای یک هدف خاص'''.\nبرای جزئیات بیشتر مجوز عمومی کلی جیانیو را مشاهده کنید.\nشما باید <doclink href=Copying> یک چاپ ازمجوز عمومی کلی </doclink> همراه این برنامه دریافت کنید; اگر دریافت نکردید،به بنیاد نرمافزار آزاد بنویسید،Inc.،خیابان فرانکلین۵۱،طبقه پنجم،بوستون، MA۰۲۱۱۰-۱۳۰،آمریکا،یا [http://www.gnu.org/copyleft/gpl.html read it online].",
"config-sidebar": "* [//www.mediawiki.org صفحهٔ اصلی مدیاویکی]\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Help:Contents راهنمای کاربر]\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:Contents راهنمای مدیر]\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:FAQ پرسشهای رایج]\n----\n* <doclink href=Readme>مرا بخوان</doclink>\n* <doclink href=ReleaseNotes>یادداشتهای انتشار</doclink>\n* <doclink href=Copying>نسخه برداری</doclink>\n* <doclink href=UpgradeDoc>ارتقا</doclink>",
"config-no-cache": "'''هشدار:''' [http://www.php.net/apc APC],[http://xcache.lighttpd.net/ XCache] یا [http://www.iis.net/download/WinCacheForPhp WinCache] را نتوانست پیدا کند.\nذخیره شی فعال نیست.",
"config-mod-security": "'''هشدار:''' وب سرور شما [http://modsecurity.org/ mod_security] فعال است.اگر اشتباه پیکربندی شده باشد،می تواند باعث ایجاد مشکلاتی برای مدیاویکی یا دیگر نرمافزاری شود که به کاربران اجازه میدهد پیام دلخواه ارسال کنند.\nبه [http://modsecurity.org/documentation/ mod_security documentation] مراجعه کنید یا اگر با خطاهای اتفاقی مواجه شدید با پشتیبانی میزبان خود در تماس باشید.",
"config-diff3-bad": "جیانیو دیف۳ پیدا نشد.",
- "config-git": "نسخهٔ کنترل نرمافزار جیت پیدا شد:<code>$1</code>.",
- "config-git-bad": "نسخه نرمافزار کنترل جیت پیدا نشد.",
+ "config-git": "کنترل نسخهٔ نرمافزار گیت پیدا شد: <code>$1</code>.",
+ "config-git-bad": "کنترل نسخهٔ نرمافزار گیت پیدا نشد.",
"config-imagemagick": "ایمیجمجیک پیدا شد: <code>$1</code>.\nاگر ارسالها را فعال کنید،تصویر کوچک فعال خواهدشد.",
"config-gd": "گرافیکهای جیدی ساخته شده در کتابخانه پیدا شد.\nاگر ارسالها را فعال کنید تصویر کوچک فعال خواهدشد.",
"config-no-scaling": "کتابخانهٔ جیدی یا ایمیجمجیک نتوانست پیدا شود.\nتصویر کوچک غیرفعال خواهدشد.",
"config-db-install-account": "حساب کاربری برای نصب",
"config-db-username": "نام کاربری پایگاه اطلاعات:",
"config-db-password": "گذرواژه پایگاه دادهها:",
- "config-db-password-empty": "Ù\84Ø·Ù\81اÙ\8b Û\8cÚ© رÙ\85ز عبÙ\88ر براÛ\8c کاربر جدÛ\8cد پایگاه اطلاعاتی وارد کنید: $1\nدر صورتی که ممکن است کاربران بدون رمز عبور به وجود آیند،امن نیست.",
+ "config-db-password-empty": "Ù\84Ø·Ù\81اÙ\8b Û\8cÚ© رÙ\85ز عبÙ\88ر براÛ\8c کاربر تازÙ\87 پایگاه اطلاعاتی وارد کنید: $1\nدر صورتی که ممکن است کاربران بدون رمز عبور به وجود آیند،امن نیست.",
"config-db-username-empty": "شما باید یک مقدار برای \"نام کاربری {{int:config-db-username}}\" وارد کنید",
"config-db-install-username": "نام کاربری را وارد کنید که برای اتصال به پایگاه اطلاعاتی در طول روند نصب استفاده خواهدشد.\nاین نام کاربری حساب مدیاویکی نیست; نام کاربری برای پایگاه اطلاعاتی شما است.",
"config-db-install-password": "رمز عبوری را وارد کنید که برای اتصال به پایگاه اطلاعاتی در طول روند نصب استفاده خواهدشد.\nاین رمز عبور برای حساب مدیاویکی نیست;رمز عبور برای پایگاه اطلاعاتی شما است.",
"config-env-good": "L'ambiente è stato controllato.\nÈ possibile installare MediaWiki.",
"config-env-bad": "L'ambiente è stato controllato.\nNon è possibile installare MediaWiki.",
"config-env-php": "PHP $1 è installato.",
+ "config-env-hhvm": "HHVM $1 è installato.",
"config-unicode-using-utf8": "Usa Brion Vibber's utf8_normalize.so per la normalizzazione Unicode.",
"config-unicode-using-intl": "Usa [http://pecl.php.net/intl l'estensione PECL intl] per la normalizzazione Unicode.",
"config-unicode-pure-php-warning": "'''Attenzione:''' [http://pecl.php.net/intl l'estensione PECL intl] non è disponibile per gestire la normalizzazione Unicode, così si usa la lenta implementazione in puro PHP.\nSe esegui un sito ad alto traffico, dovresti leggere alcune considerazioni sulla [//www.mediawiki.org/wiki/Special:MyLanguage/Unicode_normalization_considerations normalizzazione Unicode].",
"config-admin-name-invalid": "Il nome utente specificato \"<nowiki>$1</nowiki>\" non è valido.\nSpecificare un nome utente diverso.",
"config-admin-password-blank": "Inserisci una password per l'account di amministratore.",
"config-admin-password-mismatch": "Le password inserite non coincidono tra loro.",
- "config-admin-email": "Indirizzo e-mail:",
+ "config-admin-email": "Indirizzo email:",
"config-admin-email-help": "Inserisci qui un indirizzo email per poter ricevere email dagli altri utenti del wiki, reimpostare la tua password, ed essere informato delle modifiche apportate alle pagine tuoi osservati speciali. Se non ti interessa, puoi lasciare vuoto questo campo.",
"config-admin-error-user": "Errore interno durante la creazione di un amministratore con il nome \"<nowiki>$1</nowiki>\".",
"config-admin-error-password": "Errore interno durante l'impostazione di una password per amministratore \"<nowiki>$1</nowiki>\": <pre>$2</pre>",
"config-env-good": "環境を確認しました。\nMediaWiki をインストールできます。",
"config-env-bad": "環境を確認しました。\nMediaWiki のインストールはできません。",
"config-env-php": "PHP $1がインストールされています。",
+ "config-env-hhvm": "HHVM $1 がインストールされています。",
"config-unicode-using-utf8": "Unicode正規化に、Brion Vibberのutf8_normalize.soを使用。",
"config-unicode-using-intl": "Unicode正規化に[http://pecl.php.net/intl intl PECL 拡張機能]を使用。",
"config-unicode-pure-php-warning": "<strong>警告:</strong> Unicode 正規化の処理に [http://pecl.php.net/intl intl PECL 拡張機能]を利用できないため、処理が遅いピュア PHP の実装を代わりに使用しています。\n高トラフィックのサイトを運営する場合は、[//www.mediawiki.org/wiki/Special:MyLanguage/Unicode_normalization_considerations Unicode 正規化]をお読みください。",
"config-site-name": "Isem tal-wiki:",
"config-site-name-help": "Dan se jidher fil-barra tat-titlu tal-browżer u f'diversi postijiet oħra.",
"config-site-name-blank": "Daħħal isem tas-sit.",
- "config-project-namespace": "Spazju tal-isem tal-proġett:",
+ "config-project-namespace": "Spazju tal-ismijiet tal-proġett:",
"config-ns-generic": "Proġett",
"config-ns-site-name": "L-istess bħall-isem tal-wiki: $1",
"config-ns-other": "Oħrajn (speċifika)",
"config-ns-other-default": "MyWiki",
- "config-ns-invalid": "L-ispazju speċifikat \"<nowiki>$1</nowiki>\" huwa ħażin.\nSpeċifika spazju tal-isem tal-proġett differenti.",
- "config-ns-conflict": "L-ispazju speċifikat \"<nowiki>$1</nowiki>\" joħloq kunflitt ma' spazju tal-isem ieħor tal-MediaWiki.\nSpeċifika spazju tal-isem tal-proġett differenti.",
+ "config-ns-invalid": "L-ispazju speċifikat \"<nowiki>$1</nowiki>\" huwa ħażin.\nSpeċifika spazju tal-ismijiet ta' proġett differenti.",
+ "config-ns-conflict": "L-ispazju speċifikat \"<nowiki>$1</nowiki>\" joħloq kunflitt ma' spazju tal-ismijiet tal-MediaWiki predeterminat.\nSpeċifika spazju tal-ismijiet ta' proġett differenti.",
"config-admin-box": "Kont tal-amministratur",
"config-admin-name": "Ismek:",
"config-admin-password": "Password:",
"config-env-good": "L’environament es estat verificat.\nPodètz installar MediaWiki.",
"config-env-bad": "L’environament es estat verificat.\nPodètz pas installar MediaWiki.",
"config-env-php": "PHP $1 es installat.",
- "config-env-php-toolow": "PHP $1 es installat.\nPasmens, MediaWiki requerís PHP $2 o superior.",
+ "config-env-hhvm": "HHVM $1 es installat.",
"config-unicode-using-utf8": "Utilizacion de utf8_normalize.so per Brion Vibber per la normalizacion Unicode.",
"config-unicode-using-intl": "Utilizacion de [http://pecl.php.net/intl l'extension PECL intl] per la normalizacion Unicode.",
"config-memory-raised": "Lo paramètre <code>memory_limit</code> de PHP èra a $1, portat a $2.",
"config-cache-options": "Paramètres per la mesa en escondedor dels objèctes :",
"config-memcached-servers": "servidors per Memcached :",
"config-extensions": "Extensions",
+ "config-skins": "Abilhatges",
+ "config-skins-use-as-default": "Utilizar aqueste abilhatge per defaut",
"config-install-step-done": "fach",
"config-install-step-failed": "fracàs",
"config-install-extensions": "Inclusion de las extensions",
"config-install-database": "Creacion de la banca de donadas",
"config-install-schema": "Creacion d'esquèma",
+ "config-install-pg-schema-not-exist": "L'esquèma PostgreSQL existís pas",
"config-install-pg-commit": "Validacion de las modificacions",
"config-install-pg-plpgsql": "Verificacion del lengatge PL/pgSQL",
"config-install-user": "Creacion d'un utilizaire de la banca de donadas",
+ "config-install-user-alreadyexists": "L'utilizaire « $1 » existís ja.",
+ "config-install-user-create-failed": "Fracàs al moment de la creacion de l'utilizaire « $1 » : $2",
+ "config-install-user-missing": "L'utilizaire «$1» existís pas.",
"config-install-tables": "Creacion de las taulas",
"config-install-stats": "Inicializacion de las estatisticas",
+ "config-install-keys": "Generacion de la clau secreta",
+ "config-install-updates": "Empachar l’execucion de las mesas a jorn inutilas",
"config-install-sysop": "Creacion del compte administrator",
"config-install-mainpage-failed": "Impossible d’inserir la pagina principala : $1",
"config-download-localsettings": "Telecargar <code>LocalSettings.php</code>",
"config-help": "ajuda",
+ "config-help-tooltip": "clicar per agrandir",
"mainpagetext": "'''MediaWiki es estat installat amb succès.'''",
"mainpagedocfooter": "Consultatz lo [//meta.wikimedia.org/wiki/Help:Contents/fr Guida de l'utilizaire] per mai d'entresenhas sus l'utilizacion d'aqueste logicial de wiki.\n\n== Per començar ==\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:Configuration_settings Lista dels paramètres de configuracion]\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:FAQ/oc FAQ MediaWiki]\n* [https://lists.wikimedia.org/mailman/listinfo/mediawiki-announce Lista de discussions de las distribucions de MediaWiki]\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Localisation#Translation_resources Adaptatz MediaWiki dins vòstra lenga]"
}
$dbw->insert( 'log_search', $rows, __METHOD__, 'IGNORE' );
}
+ // Update any bloom filter cache
+ $member = $this->getTarget()->getNamespace() . ':' . $this->getTarget()->getDBkey();
+ BloomCache::get( 'main' )->insert( wfWikiId(), 'TitleHasLogs', $member );
+
return $this->id;
}
*/
public function showMissingArticle() {
global $wgSend404Code;
+
$outputPage = $this->getContext()->getOutput();
// Whether the page is a root user page of an existing user (but not a subpage)
$validUserPage = false;
+ $title = $this->getTitle();
+
# Show info in user (talk) namespace. Does the user exist? Is he blocked?
- if ( $this->getTitle()->getNamespace() == NS_USER
- || $this->getTitle()->getNamespace() == NS_USER_TALK
+ if ( $title->getNamespace() == NS_USER
+ || $title->getNamespace() == NS_USER_TALK
) {
- $parts = explode( '/', $this->getTitle()->getText() );
+ $parts = explode( '/', $title->getText() );
$rootPart = $parts[0];
$user = User::newFromName( $rootPart, false /* allow IP users*/ );
$ip = User::isIP( $rootPart );
)
)
);
- $validUserPage = !$this->getTitle()->isSubpage();
+ $validUserPage = !$title->isSubpage();
} else {
- $validUserPage = !$this->getTitle()->isSubpage();
+ $validUserPage = !$title->isSubpage();
}
}
wfRunHooks( 'Article::MissingArticleConditions', array( &$conds, $logTypes ) );
# Show delete and move logs
- LogEventsList::showLogExtract( $outputPage, $logTypes, $this->getTitle(), '',
- array( 'lim' => 10,
- 'conds' => $conds,
- 'showIfEmpty' => false,
- 'msgKey' => array( 'moveddeleted-notice' ) )
- );
+ $member = $title->getNamespace() . ':' . $title->getDBkey();
+ // @todo: move optimization to showLogExtract()?
+ if ( BloomCache::get( 'main' )->check( wfWikiId(), 'TitleHasLogs', $member ) ) {
+ LogEventsList::showLogExtract( $outputPage, $logTypes, $title, '',
+ array( 'lim' => 10,
+ 'conds' => $conds,
+ 'showIfEmpty' => false,
+ 'msgKey' => array( 'moveddeleted-notice' ) )
+ );
+ }
if ( !$this->mPage->hasViewableContent() && $wgSend404Code && !$validUserPage ) {
// If there's no backing content, send a 404 Not Found
$oldid = $this->getOldID();
if ( $oldid ) {
$text = wfMessage( 'missing-revision', $oldid )->plain();
- } elseif ( $this->getTitle()->getNamespace() === NS_MEDIAWIKI ) {
+ } elseif ( $title->getNamespace() === NS_MEDIAWIKI ) {
// Use the default message text
- $text = $this->getTitle()->getDefaultMessageText();
- } elseif ( $this->getTitle()->quickUserCan( 'create', $this->getContext()->getUser() )
- && $this->getTitle()->quickUserCan( 'edit', $this->getContext()->getUser() )
+ $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();
# @todo FIXME: Why is this using escapeId for a class?!
$class = Sanitizer::escapeId( $v['id'] );
if ( $type == 'collapsed' ) {
- // Handled by mediawiki.action.view.metadata module and shared.css.
+ // Handled by mediawiki.action.view.metadata module.
$class .= ' collapsable';
}
$r .= "<tr class=\"$class\">\n";
$fields = array();
$count = 0;
- foreach ( $this->getWatchlistInfo() as $namespace => $pages ) {
+ // Allow subscribers to manipulate the list of watched pages (or use it
+ // to preload lots of details at once)
+ $watchlistInfo = $this->getWatchlistInfo();
+ wfRunHooks(
+ 'WatchlistEditorBeforeFormRender',
+ array( &$watchlistInfo )
+ );
+
+ foreach ( $watchlistInfo as $namespace => $pages ) {
$options = array();
foreach ( array_keys( $pages ) as $dbkey ) {
private function buildRemoveLine( $title ) {
$link = Linker::link( $title );
- if ( $title->isRedirect() ) {
- // Linker already makes class mw-redirect, so this is redundant
- $link = '<span class="watchlistredir">' . $link . '</span>';
- }
-
- $tools[] = Linker::link( $title->getTalkPage(), $this->msg( 'talkpagelinktext' )->escaped() );
+ $tools['talk'] = Linker::link( $title->getTalkPage(), $this->msg( 'talkpagelinktext' )->escaped() );
if ( $title->exists() ) {
- $tools[] = Linker::linkKnown(
+ $tools['history'] = Linker::linkKnown(
$title,
$this->msg( 'history_short' )->escaped(),
array(),
}
if ( $title->getNamespace() == NS_USER && !$title->isSubpage() ) {
- $tools[] = Linker::linkKnown(
+ $tools['contributions'] = Linker::linkKnown(
SpecialPage::getTitleFor( 'Contributions', $title->getText() ),
$this->msg( 'contributions' )->escaped()
);
wfRunHooks(
'WatchlistEditorBuildRemoveLine',
- array( &$tools, $title, $title->isRedirect(), $this->getSkin() )
+ array( &$tools, $title, $title->isRedirect(), $this->getSkin(), &$link )
);
+ if ( $title->isRedirect() ) {
+ // Linker already makes class mw-redirect, so this is redundant
+ $link = '<span class="watchlistredir">' . $link . '</span>';
+ }
+
return $link . " (" . $this->getLanguage()->pipeList( $tools ) . ")";
}
$form = new HTMLForm( $fields, $this->getContext() );
$form->setMethod( 'get' );
+ $form->setTitle( $this->getTitle() );
$form->setId( 'mw-listfiles-form' );
$form->setWrapperLegendMsg( 'listfiles' );
$form->setSubmitTextMsg( 'table_pager_limit_submit' );
}
# Look up
- $c = new Categoryfinder;
- $c->seed( $articles, $cats, $opts['categories_any'] ? 'OR' : 'AND' );
- $match = $c->run();
+ $catFind = new CategoryFinder;
+ $catFind->seed( $articles, $cats, $opts['categories_any'] ? 'OR' : 'AND' );
+ $match = $catFind->run();
# Filter
$newrows = array();
"recentchanges": "በቅርብ ጊዜ የተለወጡ",
"recentchanges-legend": "የቅርብ ለውጥ አማራጮች፦",
"recentchanges-summary": "በዚሁ ገጽ ላይ በቅርብ ጊዜ የወጡ አዳዲስ ለውጦች ለመከታተል ይችላሉ።",
+ "recentchanges-noresult": "ለዚሁ ጥያቄ በተሰጠው ወቅት ውስጥ አንዳችም ለውጥ አልነበረም።",
"recentchanges-feed-description": "በዚህ ዊኪ ላይ በቅርብ ግዜ የተለወጠውን በዚሁ feed መከታተል ይችላሉ",
"recentchanges-label-newpage": "ይኸው ለውጥ አዲስ ገጽ ፈጠረ።",
"recentchanges-label-minor": "ይህ ለውጥ ጥቃቅን ነው።",
"thumbnail_invalid_params": "ትክክለኛ ያልሆነ የናሙና ግቤት",
"import": "ገጾች ከሌላ ዊኪ ለማስገባት",
"importinterwiki": "ከሌላ ዊኪ ማስገባት",
- "import-interwiki-source": "መነሻ ዊኪ/ገጽ:",
"import-interwiki-history": "ለዚህ ገጽ የታሪክ ዕትሞች ሁሉ ለመቅዳት",
"import-interwiki-submit": "ለማስገባት",
"import-interwiki-namespace": "መድረሻ ክፍለ-ዊኪ:",
"contribsub2": "ل{{GENDER:$3|$1}} ($2)",
"contributions-userdoesnotexist": "حساب المستخدم \"$1\" غير مسجل.",
"nocontribs": "لم يتم العثور على تغييرات تطابق هذه المحددات.",
- "uctop": "حالي",
+ "uctop": "(حالية)",
"month": "من شهر (وأقدم):",
"year": "من سنة (وأقدم):",
"sp-contributions-newbies": "اعرض مساهمات الحسابات الجديدة فقط",
"parser-template-recursion-depth-warning": "Tizhet bevenn donder galvoù ar patromoù ($1)",
"language-converter-depth-warning": "Aet eur en tu all d'ar vevenn amdreiñ yezhoù ($1)",
"node-count-exceeded-category": "Pajennoù m'eur aet en tu all d'an niver a skoulmoù",
+ "node-count-exceeded-category-desc": "Mont a ra ar bajenn-mañ en tu all da gont uhelañ ar skoulmoù.",
"node-count-exceeded-warning": "Pajenn hag a ya en tu all d'an niver a skoulmoù",
"expansion-depth-exceeded-category": "Pajennoù m'eur aet dreist d'an donder astenn",
"expansion-depth-exceeded-warning": "Pajenn a ya dreist d'an donder astenn",
"shown-title": "Diskouez $1 {{PLURAL:$1|disoc'h|disoc'h}} dre bajenn",
"viewprevnext": "Gwelet ($1 {{int:pipe-separator}} $2) ($3).",
"searchmenu-exists": "'''Ur bajenn anvet\"[[:$1]]\" zo war ar wiki-mañ'''",
- "searchmenu-new": "'''Krouiñ ar bajenn \"[[:$1]]\" war ar wiki-mañ !'''",
+ "searchmenu-new": "<strong>Krouiñ ar bajenn \"[[:$1]]\" war ar wiki-mañ !</strong> {{PLURAL:$2|0=|Gwelet ivez ar bajenn kavet gant ho klask.|Gwelet ivez disoc'hoù ar c'hlask.}}",
"searchprofile-articles": "Pajennoù gant boued",
"searchprofile-images": "Liesmedia",
"searchprofile-everything": "Pep tra",
"licenses-edit": "Aozañ dibarzhioù an aotre-implijout",
"license-nopreview": "(Dibosupl rakwelet)",
"upload_source_url": " (Un URL reizh a c'hall bezañ tizhet gant an holl)",
- "upload_source_file": " (ur restr war hoc'h urzhiataer)",
+ "upload_source_file": " (ar restr ho peus dibabet en hoc'h urzhiataer)",
"listfiles-delete": "dilemel",
"listfiles-summary": "Diskouez a ra ar bajenn dibar-mañ an holl restroù bet ezporzhiet.",
"listfiles_search_for": "Klask anv ar skeudenn :",
"listgrouprights-addgroup-self-all": "Gallout a ra ouzhpennañ an holl strolladoù da gont an-unan",
"listgrouprights-removegroup-self-all": "Gallout a ra tennañ kuit an holl strolladoù eus kont an-unan.",
"listgrouprights-namespaceprotection-namespace": "Esaouenn anv",
+ "listgrouprights-namespaceprotection-restrictedto": "Gwir(ioù) hag a aotre an implijer da aozañ",
+ "trackingcategories": "Rummadoù evezhiañ",
+ "trackingcategories-msg": "Rummad evezhiañ",
"trackingcategories-name": "Anv ar gemennadenn",
"broken-file-category-desc": "Er bajenn-mañ ez eus ul liamm restr torr (ul liamm da enframmañ ur restr pa n'eus ket eus ar restr-se).",
"trackingcategories-nodesc": "N'eus deskrivadur ebet.",
"unwatchthispage": "Paouez da evezhiañ",
"notanarticle": "Pennad ebet",
"notvisiblerev": "Stumm diverket",
- "watchlist-details": "Lakaet hoc'h eus {{PLURAL:$1|$1 bajenn|$1 pajenn}} dindan evezh, anez kontañ ar pajennoù kaozeal.",
+ "watchlist-details": "Lakaet hoc'h eus {{PLURAL:$1|$1 bajenn|$1 a bajennoù}} war ho roll evezhiañ, anez kontañ ar pajennoù kaozeal.",
"wlheader-enotif": "Gweredekaet eo ar c'has posteloù.",
"wlheader-showupdated": "E '''tev''' emañ merket ar pajennoù bet kemmet abaoe ar wezh ziwezhañ hoc'h eus sellet outo",
- "wlnote": "Setu aze {{PLURAL:$1|ar c'hemm diwezhañ|ar '''$1''' kemm diwezhañ}} c'hoarvezet e-kerzh an {{PLURAL:$2|eurvezh|'''$2''' eurvezh}} ziwezhañ, evit an $3 da $4.",
+ "wlnote": "Setu aze {{PLURAL:$1|ar c'hemm diwezhañ|ar '''$1''' kemm diwezhañ}} c'hoarvezet e-kerzh an {{PLURAL:$2|eurvezh|'''$2''' eurvezh}} diwezhañ, d'an $3 da $4.",
"wlshowlast": "Diskouez an $1 eurvezh $2 devezh diwezhañ $3",
"watchlist-options": "Dibarzhioù ar roll evezhiañ",
"watching": "Heuliet...",
"exbeforeblank": "A-raok diverkañ e oa an endalc'had : '$1'",
"delete-confirm": "Diverkañ \"$1\"",
"delete-legend": "Diverkañ",
- "historywarning": "'''Diwallit :''' Emaoc'h war-nes diverkañ ur bajenn dezhi un istor gant e-tro {{PLURAL:$1|adweladenn|adweladenn}} :",
+ "historywarning": "<strong>Diwallit :</strong> Emaoc'h war-nes diverkañ ur bajenn dezhi un istor gant {{PLURAL:$1|adweladenn}} :",
"confirmdeletetext": "War-nes diverkañ da viken ur bajenn pe ur skeudenn eus ar bank roadennoù emaoc'h. Diverket e vo ivez an holl stummoù kozh stag outi.\nKadarnait, mar plij, eo mat an dra-se hoc'h eus c'hoant da ober, e komprenit mat an heuliadoù, hag e rit se diouzh ar [[{{MediaWiki:Policy-url}}]].",
"actioncomplete": "Diverkadenn kaset da benn",
"actionfailed": "Ober c'hwitet",
"alreadyrolled": "Dibosupl eo disteuler ar c'hemm diwezhañ graet d'ar bajenn [[:$1]] gant [[User:$2|$2]] ([[User talk:$2|Kaozeal]]{{int:pipe-separator}}[[Special:Contributions/$2|{{int:contribslink}}]]);\nkemmet pe distaolet eo bet c'hoazh gant unan bennak all.\n\nAr c'hemm diwezhañ d'ar bajenn-mañ a oa bet graet gant [[User:$3|$3]] ([[User talk:$3|Kaozeal]]{{int:pipe-separator}}[[Special:Contributions/$3|{{int:contribslink}}]]).",
"editcomment": "Diverradenn ar c'hemm a oa : \"''$1''\".",
"revertpage": "Kemmoù distaolet gant [[Special:Contributions/$2|$2]] ([[User talk:$2|Kaozeal]]); adlakaet d'ar stumm diwezhañ a-gent gant [[User:$1|$1]]",
- "revertpage-nouser": "Disteuler kemmoù un implijer kuzhet ha distreiñ d'ar stumm diwezhañ gant [[User:$1|$1]]",
+ "revertpage-nouser": "Disteuler kemmoù un implijer kuzhet ha distreiñ d'ar stumm diwezhañ gant an {{GENDER:$1|[[implijer :$1|$1]]}}",
"rollback-success": "Disteuler kemmoù $1; distreiñ da stumm diwezhañ $2.",
"sessionfailure-title": "Fazi dalc'h",
"sessionfailure": "Evit doare ez eus ur gudenn gant ho talc'h;\nNullet eo bet an ober-mañ a-benn en em wareziñ diouzh an tagadennoù preizhañ.\nKlikit war \"kent\" hag adkargit ar bajenn oc'h deuet drezi; goude klaskit en-dro.",
"cant-move-user-page": "Noc'h ket aotreet da adenvel pajennoù pennañ an implijerien (er-maez eus o ispajennoù).",
"cant-move-to-user-page": "Noc'h ket aotreet da adenvel ur bajenn gant anv hini un implijer all (nemet un ispajenn e vefe).",
"cant-move-category-page": "N'oc'h ket aotreet da zilec'hiañ pajennoù rummad.",
+ "cant-move-to-category-page": "N'oc'h ket aotreet da zilec'hiañ ur bajenn d'ur bajenn rummad.",
"newtitle": "anv nevez",
"move-watch": "Evezhiañ ar bajenn-mañ",
"movepagebtn": "Adenvel ar pennad",
"import-error-create": "N'eo ket bet enporzhiet ar bajenn \"$1\" peogwir n'oc'h ket aotreet da grouiñ anezhi.",
"import-error-interwiki": "Ne vez ket enporzhiet ar bajenn \"$1\" rak miret eo an anv evit liammoù diavaez (etrewiki).",
"import-error-special": "Ne vez ket enporzhiet ar bajenn \"$1\" rak stag eo ouzh un esaouenn anv dibar na aotre ket pajennoù.",
- "import-error-invalid": "Ne vez ket enporzhiet ar bajenn \"$1\" rak direizh eo hec'h anv.",
+ "import-error-invalid": "N'eo ket bet enporzhiet ar bajenn \"$1\" rak direizh e vefe hec'h anv er wiki-mañ.",
"import-options-wrong": "{{PLURAL:$2|Dibab fall|Dibaboù fall}}: <nowiki>$1</nowiki>",
"import-rootpage-invalid": "Pourchas a ra ar bennbajenn un titl n'eo ket reizh.",
"import-rootpage-nosubpage": "Esaouenn anvioù \"$1\" eus ar bennpajenn ne aotre ket an ispajennoù.",
"importlogpage": "Log an enporzhiadennoù",
"importlogpagetext": "Enporzhiadennoù melestradurel eus pajennoù adal wikioù all gant istor ar c'hemmadennoù degaset enno.",
"import-logentry-upload": "en/he deus enporzhiet (pellgarget) [[$1]]",
- "import-logentry-upload-detail": "$1 {{PLURAL:$1|stumm|stumm}}",
+ "import-logentry-upload-detail": "$1 {{PLURAL:$1|adweladenn}} enporzhiet",
"import-logentry-interwiki": "treuzwikiet $1",
- "import-logentry-interwiki-detail": "$1 {{PLURAL:$1|c'hemm|kemm}} abaoe $2",
+ "import-logentry-interwiki-detail": "$1 {{PLURAL:$1|adweladenn}} enporzhiet eus $2",
"javascripttest": "Amprouadenn JavaScript",
"javascripttest-title": "Emeur o seveniñ $1 amprouadenn",
"javascripttest-pagetext-noframework": "Miret eo ar bajenn-mañ evit amprouiñ JavaScript.",
"fileduplicatesearch-noresults": "N'eus bet kavet restr ebet anvet \"$1\".",
"specialpages": "Pajennoù dibar",
"specialpages-note-top": "Alc'hwez",
- "specialpages-note": "* Pajennoù dibar boutin.\n* <span class=\"mw-specialpagerestricted\">Pajennoù dibar miret strizh.</span>\n* <span class=\"mw-specialpagecached\">Pajennoù dibar krubuilhet hepken (a c'hellfe bezañ re gozh).</span>",
+ "specialpages-note": "* Pajennoù dibar ordinal.\n* <span class=\"mw-specialpagerestricted\">Pajennoù dibar miret strizh.</span>",
"specialpages-group-maintenance": "Rentaoù-kont trezalc'h",
"specialpages-group-other": "Pajennoù dibar all",
"specialpages-group-login": "Kevreañ / krouiñ ur gont",
"logentry-newusers-byemail": "Krouet eo bet ar gont implijer $3 gant $1 ha kaset eo bet ar ger-tremen dre bostel",
"logentry-newusers-autocreate": "{{GENDER:$2|Krouet}} eo bet kont $1 ent emgefre",
"logentry-rights-autopromote": "$1 zo bet {{GENDER:$2|anvet}} ent emgefre a $4 da $5",
+ "logentry-upload-upload": "$1 {{GENDER:$2|en deus|he deus}} ezporzhiet $3",
+ "logentry-upload-overwrite": "$1 {{GENDER:$2|en deus|he deus}} ezporzhiet ur stumm nevez eus $3",
+ "logentry-upload-revert": "$1 {{GENDER:$2|en deus|he deus}} ezporzhiet $3",
"rightsnone": "(netra)",
"feedback-bugornote": "Ma'z oc'h prest da zeskrivañ ur gudenn deknikel dre ar munud e c'hallit [$1 kemenn un draen].\nA-hend-all e c'hallit ober gant ar furmskrid eeunaet dindan. Ouzhpennet e vo hoc'h evezhiadenn d'ar bajenn \"[$3 $2]\", a-gevret gant hoc'h anv implijer hag anv ar merdeer a rit gantañ.",
"feedback-subject": "Danvez :",
"pagelang-select-lang": "Dibab ar yezh",
"right-pagelang": "Cheñch yezh ar bajenn",
"action-pagelang": "cheñch yezh ar bajenn",
+ "log-name-pagelang": "Cheñch yezh",
"log-description-pagelang": "Hemañ zo ur marilh eus ar c'hemmoù e pajenn ar yezhoù.",
+ "logentry-pagelang-pagelang": "$1 {{GENDER:$2|en deus|he deus}} cheñchet yezh ar bajenn evit $3 eus $4 da $5.",
"default-skin-not-found-row-enabled": "* <code>$1</code> / $2 (gweredekaet)",
"default-skin-not-found-row-disabled": "* <code>$1</code> / $2 ('''diweredekaet''')"
}
"gotaccount": "Ja teniu un compte? $1.",
"gotaccountlink": "Inicia una sessió",
"userlogin-resetlink": "Heu oblidat les vostres dades d'accés?",
- "userlogin-resetpassword-link": "Has oblidat la teva contrasenya?",
+ "userlogin-resetpassword-link": "Heu oblidat la contrasenya?",
"userlogin-helplink2": "Ajuda amb el registre",
"createacct-emailrequired": "Adreça de correu electrònic",
"createacct-emailoptional": "Adreça de correu electrònic (opcional)",
"showpreview": "Ukázat náhled",
"showdiff": "Ukázat změny",
"blankarticle": "<strong>Upozornění:</strong> Stránka, kterou se chystáte založit, je prázdná. Pokud ještě jednou kliknete na „{{int:savearticle}}“, bude založena zcela bez obsahu.",
- "anoneditwarning": "'''Varování:''' Nejste přihlášen(a). Vaše IP adresa bude zveřejněna v historii této stránky.",
+ "anoneditwarning": "'''Varování:''' Nejste přihlášen(a). Pokud uložíte jakoukoli editaci, bude vaše IP adresa zveřejněna v historii této stránky. Pokud se <strong>[$1 přihlásíte]</strong> nebo si <strong>[$2 vytvoříte účet]</strong>, budou vaše editace připsány vašemu uživatelskému jménu a získáte i další výhody.",
"anonpreviewwarning": "''Nejste přihlášen(a). Uložením zveřejníte svou IP adresu v historii této stránky.''",
"missingsummary": "'''Připomenutí:''' Nezadali jste shrnutí editace. Pokud ještě jednou kliknete na Uložit změny, bude vaše editace zapsána bez shrnutí.",
"missingcommenttext": "Zadejte komentář",
"listgrouprights-namespaceprotection-header": "Navnerumsbegrænsninger",
"listgrouprights-namespaceprotection-namespace": "Navnerum",
"listgrouprights-namespaceprotection-restrictedto": "Rettighed(er) der giver brugeren mulighed for at redigere",
- "trackingcategories-desc": "Kategori optagelse kriterier",
- "noindex-category-desc": "Siden ikke indekseres af robotter, fordi det er det magiske ord <code><nowiki>__NOINDEX__</nowiki></code> på det og er i et navneområde, hvor dette flag er tilladt.",
- "index-category-desc": "Siden har en <code><nowiki>__INDEX__</nowiki></code> på det (og er i et navneområde, hvor dette flag er tilladt), og dermed er indekseret af robotter, hvor det normalt ikke ville være.",
+ "trackingcategories-desc": "Optagelseskriterier for kategori",
+ "noindex-category-desc": "Siden indekseres ikke af robotter, fordi den indeholder det magiske ord <code><nowiki>__NOINDEX__</nowiki></code> og er i et navnerum, hvor dette flag er tilladt.",
+ "index-category-desc": "Siden indeholder <code><nowiki>__INDEX__</nowiki></code> (og er i et navnerum, hvor dette flag er tilladt), og bliver derfor indekseret af robotter, hvor den normalt ikke ville blive det.",
"mailnologin": "Du er ikke logget på",
"mailnologintext": "Du skal være [[Special:UserLogin|logget på]] og have en gyldig e-mailadresse sat i dine [[Special:Preferences|indstillinger]] for at sende e-mail til andre brugere.",
"emailuser": "E-mail til denne bruger",
"showpreview": "Vorschau zeigen",
"showdiff": "Änderungen zeigen",
"blankarticle": "<strong>Warnung:</strong> Die Seite, die du erstellst, ist leer.\nWenn du erneut auf „{{int:savearticle}}“ klickst, wird die Seite ohne Inhalt erstellt.",
- "anoneditwarning": "Du bearbeitest diese Seite unangemeldet. Wenn du sie abspeicherst, wird deine aktuelle IP-Adresse in der Versionsgeschichte aufgezeichnet und ist damit unwiderruflich '''öffentlich''' einsehbar.",
+ "anoneditwarning": "<strong>Warnung:</strong> Du bist nicht angemeldet. Deine IP-Adresse wird öffentlich sichtbar, falls du Bearbeitungen durchführst. Wenn du dich <strong>[$1 anmeldest]</strong> oder <strong>[$2 ein Benutzerkonto erstellst]</strong>, werden deine Bearbeitungen zusammen mit anderen Beiträgen deinem Benutzernamen zugeordnet.",
"anonpreviewwarning": "''Du bist nicht angemeldet. Beim Speichern wird deine IP-Adresse in der Versionsgeschichte aufgezeichnet.''",
"missingsummary": "'''Hinweis:''' Du hast keine Zusammenfassung angegeben. Wenn du erneut auf „{{int:savearticle}}“ klickst, wird deine Änderung ohne Zusammenfassung übernommen.",
"missingcommenttext": "Dein Abschnitt enthält keinen Text.",
"showpreview": "Εμφάνιση προεπισκόπησης",
"showdiff": "Εμφάνιση αλλαγών",
"blankarticle": "<strong>Προειδοποίηση:</strong> Η σελίδα που δημιουργείτε είναι κενή.\nΕάν κάνετε κλικ στο κουμπί \"{{int:savearticle}}\" και πάλι, η σελίδα θα δημιουργηθεί χωρίς κανένα περιεχόμενο.",
- "anoneditwarning": "'''Προειδοποίηση:''' Δεν έχετε συνδεθεί. Η διεύθυνση IP σας θα καταγραφεί στο ιστορικό επεξεργασίας αυτής της σελίδας.",
+ "anoneditwarning": "<strong>Προειδοποίηση:</strong> Δεν έχετε συνδεθεί. Η διεύθυνση IP σας θα είναι ορατή δημόσια αν κάνετε κάποια επεξεργασία. Αν <strong>[$1 συνδεθείτε]</strong> ή <strong>[$2 δημιουργήσετε λογαριασμό]</strong>, οι επεξεργασίες σας θα αποδοθούν στο όνομά χρήστη σας, μαζί με άλλα οφέλη.",
"anonpreviewwarning": "''Δεν έχετε συνδεθεί. Η αποθήκευση θα καταγράψει την διεύθυνσή IP σας στο ιστορικό επεξεργασίας αυτής της σελίδας.''",
"missingsummary": "'''Υπενθύμιση:''' Δεν έχετε συμπληρώσει τη σύνοψη επεξεργασίας. Αν κάνετε κλικ στο κουμπί Αποθήκευση πάλι, η επεξεργασία σας θα αποθηκευτεί χωρίς σύνοψη.",
"missingcommenttext": "Παρακαλώ εισάγετε ένα σχόλιο παρακάτω.",
"search-relatedarticle": "Σχετικά",
"searchrelated": "σχετικά",
"searchall": "όλα",
- "showingresults": "Δείτε παρακάτω μέχρι τα {{PLURAL:$1|'''1'''αποτέλεσμα|'''$1''' αποτελέσματα}} ξεκινώντας με #'''$2'''.",
+ "showingresults": "Παρακάτω {{PLURAL:$1|εμφανίζεται μέχρι <strong>1</strong> αποτέλεσμα|εμφανίζονται μέχρι <strong>$1</strong> αποτελέσματα}} ξεκινώντας από το Νο <strong>$2</strong>.",
+ "showingresultsinrange": "Παρακάτω {{PLURAL:$1|εμφανίζεται μέχρι <strong>1</strong> αποτέλεσμα|εμφανίζονται μέχρι <strong>$1</strong> αποτελέσματα}} σε εύρος από το Νο <strong>$2</strong> μέχρι το Νο <strong>$3</strong>.",
"showingresultsheader": "{{PLURAL:$5|Αποτέλεσμα '''$1''' από '''$3'''|Αποτελέσματα '''$1 - $2''' από '''$3'''}} για '''$4'''",
"search-nonefound": "Δεν υπάρχουν αποτελέσματα που να ικανοποιούν το ερώτημα.",
"powersearch-legend": "Αναλυτική αναζήτηση",
"right-browsearchive": "Αναζήτηση στις διαγραμμένες σελίδες",
"right-undelete": "Ανάκληση διαγραφής μίας σελίδας",
"right-suppressrevision": "Επιθεώρηση και αποκατάσταση αναθεωρήσεων κρυμμένων από τους διαχειριστές",
- "right-viewsuppressed": "Προβολή αναθεωρήσεων κρυμμέτων από κάθε χρήστη",
+ "right-viewsuppressed": "Προβολή αναθεωρήσεων κρυμμένων από κάθε χρήστη",
"right-suppressionlog": "Προβολή ιδιωτικών καταγραφών",
"right-block": "Φραγή άλλων χρηστών από την επεξεργασία",
"right-blockemail": "Φραγή ενός χρήστη από την αποστολή ηλεκτρονικών μηνυμάτων",
"recentchanges-legend-heading": "'''Υπόμνημα:'''",
"recentchanges-legend-newpage": "{{int:recentchanges-label-newpage}} (δείτε [[Special:NewPages|κατάλογος νέων σελίδων]])",
"rcnotefrom": "Παρακάτω είναι οι αλλαγές από τις <strong>$2</strong> (εμφανίζονται μέχρι <strong>$1</strong> ).",
- "rclistfrom": "Εμφάνιση νέων αλλαγών αρχίζοντας από $3 $2",
+ "rclistfrom": "Εμφάνιση νέων αλλαγών αρχίζοντας από τις $3 στις $2",
"rcshowhideminor": "$1 μικροεπεξεργασιών",
"rcshowhideminor-show": "Εμφάνιση",
"rcshowhideminor-hide": "Απόκρυψη",
"windows-nonascii-filename": "Αυτό το wiki δεν υποστηρίζει ονόματα αρχείων με ειδικούς χαρακτήρες.",
"fileexists": "Υπάρχει ήδη αρχείο με αυτό το όνομα, παρακαλούμε ελέγξτε το <strong>[[:$1]]</strong> εάν δεν είστε {{GENDER:|σίγουρος|σίγουρη}} αν θέλετε να το αλλάξετε.\n[[$1|thumb]]",
"filepageexists": "Η σελίδα περιγραφής για αυτό το αρχείο δημιουργήθηκε ήδη στο <strong>[[:$1]]</strong>, αλλά κανένα αρχείο με αυτό το όνομα δεν υπάρχει αυτή τη στιγμή.\nΗ περιγραφἠ που θα εισάγετε δεν θα εμφανιστεί στη σελίδα περιγραφής.\nΓια να εμφανιστεί η περιγραφή σας εκεί, θα πρέπει να την επεξεργαστείτε χειροκίνητα.\n[[$1|thumb]]",
- "fileexists-extension": "Î\88να αÏ\81Ï\87είο με Ï\80αÏ\81Ï\8cμοιο Ï\8cνομα Ï\85Ï\80άÏ\81Ï\87ει: [[$2|thumb]]\n* Î\8cνομα Ï\84οÏ\85 Ï\80Ï\81οÏ\82 εÏ\80ιÏ\86Ï\8cÏ\81Ï\84Ï\89Ï\83η αÏ\81Ï\87είοÏ\85: <strong>[[:$1]]</strong>\n* Î\8cνομα Ï\85Ï\80άÏ\81Ï\87ονÏ\84οÏ\82 αÏ\81Ï\87είοÏ\85: <strong>[[:$2]]</strong>\nΠαÏ\81ακαλÏ\8e διαλÎξÏ\84ε Îνα διαÏ\86οÏ\81εÏ\84ικÏ\8c Ï\8cνομα.",
+ "fileexists-extension": "Î¥Ï\80άÏ\81Ï\87ει Îνα αÏ\81Ï\87είο με Ï\80αÏ\81Ï\8cμοιο Ï\8cνομα: [[$2|thumb]]\n* Î\8cνομα Ï\84οÏ\85 Ï\80Ï\81οÏ\82 ανÎβαÏ\83μα αÏ\81Ï\87είοÏ\85: <strong>[[:$1]]</strong>\n* Î\8cνομα Ï\85Ï\80άÏ\81Ï\87ονÏ\84οÏ\82 αÏ\81Ï\87είοÏ\85: <strong>[[:$2]]</strong>\nÎ\9cήÏ\80Ï\89Ï\82 θα θÎλαÏ\84ε να Ï\87Ï\81ηÏ\83ιμοÏ\80οιήÏ\83εÏ\84ε κάÏ\80οιο Ï\8cνομα Ï\80οÏ\85 να ξεÏ\87Ï\89Ï\81ίζει Ï\80εÏ\81ιÏ\83Ï\83Ï\8cÏ\84εÏ\81ο;",
"fileexists-thumbnail-yes": "Το αρχείο φαίνεται ότι είναι μια εικόνα μειωμένου μεγέθους ''(μικρογραφία)''. [[$1|thumb]]\nΠαρακαλώ ελέγξτε το αρχείο <strong>[[:$1]]</strong>.\nΑν το ελεγμένο αρχείο είναι η ίδια εικόνα στο αρχικό μέγεθος δεν είναι απαραίτητο να επιφορτώσετε μια επιπλέον μικρογραφία.",
"file-thumbnail-no": "Το όνομα αρχείου αρχίζει με <strong>$1</strong>.\nΦαίνεται πως είναι μια εικόνα μειωμένου μεγέθους ''(μικρογραφία)''.\nΑν έχετε αυτή την εικόνα σε πλήρη ανάλυση, επιφορτώστε τη, αλλιώς αλλάξτε παρακαλώ το όνομα του αρχείου.",
"fileexists-forbidden": "Ένα αρχείο με αυτό το όνομα υπάρχει ήδη˙ εάν ακόμη θέλετε να επιφορτώσωτε αυτό το αρχείο παρακαλώ πηγαίνετε πίσω και επιφορτώστε το υπό ένα νέο όνομα. [[File:$1|thumb|center|$1]]",
"license-header": "Αδειοδότηση",
"nolicense": "Καμία επιλεγμένη",
"license-nopreview": "(Μη διαθέσιμη προεπισκόπηση)",
- "upload_source_url": " (ένα έγκυρο, δημόσια προσβάσιμο URL)",
+ "upload_source_url": "(το επιλεγμένο σας αρχείο από μια έγκυρη, δημόσια προσβάσιμη διεύθυνση URL)",
"upload_source_file": "(το επιλεγμένο αρχείο από τον υπολογιστή σας)",
"listfiles-delete": "διαγραφή",
"listfiles-summary": "Αυτή η ειδική σελίδα δείχνει όλα τα επιφορτωμένα αρχεία.",
"statistics": "Στατιστικά",
"statistics-header-pages": "Στατιστικά σελίδων",
"statistics-header-edits": "Στατιστικά επεξεργασιών",
- "statistics-header-views": "Î\95μÏ\86άνιÏ\83η στατιστικών",
+ "statistics-header-views": "Î Ï\81οβολή στατιστικών",
"statistics-header-users": "Στατιστικά χρηστών",
"statistics-header-hooks": "Άλλα στατιστικά",
"statistics-articles": "Σελίδες περιεχομένου",
"pageswithprop-submit": "Μετάβαση",
"doubleredirects": "Διπλές ανακατευθύνσεις",
"doubleredirectstext": "Αυτή η σελίδα συγκαταλέγει σελίδες οι οποίες ανακατευθύνουν σε άλλες σελίδες ανακατεύθυνσης. Κάθε σειρά περιέχει συνδέσμους προς την πρώτη και τη δεύτερη σελίδα ανακατεύθυνσης, όπως επίσης και την πρώτη αράδα του κειμένου στη δεύτερη σελίδα ανακατεύθυνσης η οποία και είναι, κανονικά, ο πραγματικός προορισμός της ανακατεύθυνσης -εκεί δηλαδή όπου θα έπρεπε να είχατε οδηγηθεί από την αρχή. Τα <del>διεγραμμένα</del> λήμματα έχουν επιλυθεί.",
- "double-redirect-fixed-move": "Η [[$1]] έχει μετακινηθεί, τώρα είναι ανακατεύθυνση στην [[$2]]",
- "double-redirect-fixed-maintenance": "Î\94ιÏ\8cÏ\81θÏ\89Ï\83η διÏ\80λήÏ\82 ανακαÏ\84εÏ\8dθÏ\85νÏ\83ηÏ\82 αÏ\80Ï\8c Ï\84ο [[$1]] Ï\83Ï\84ο [[$2]].",
+ "double-redirect-fixed-move": "Η [[$1]] έχει μετακινηθεί.\nΕνημερώθηκε αυτόματα και τώρα είναι ανακατεύθυνση στην [[$2]].",
+ "double-redirect-fixed-maintenance": "Î\91Ï\85Ï\84Ï\8cμαÏ\84η διÏ\8cÏ\81θÏ\89Ï\83η διÏ\80λήÏ\82 ανακαÏ\84εÏ\8dθÏ\85νÏ\83ηÏ\82 αÏ\80Ï\8c [[$1]] Ï\83ε [[$2]] Ï\83ε εÏ\81γαÏ\83ία Ï\83Ï\85νÏ\84ήÏ\81ηÏ\83ηÏ\82.",
"double-redirect-fixer": "Διορθωτής ανακατευθύνσεων",
"brokenredirects": "Λανθασμένες ανακατευθύνσεις",
"brokenredirectstext": "Οι παρακάτω ανακατευθύνσεις οδηγούν σε σελίδες που δεν υπάρχουν:",
"activeusers-noresult": "Δεν βρέθηκε χρήστης.",
"listgrouprights": "Δικαιώματα ομάδων χρηστών",
"listgrouprights-summary": "Ακόλουθεί μία λίστα με τις ομάδες χρηστών σε αυτό το wiki καθώς και με τα δικαιώματα πρόσβασης αυτών.\nΕνδέχεται να περιέχει [[{{MediaWiki:Listgrouprights-helppage}}|πρόσθετες πληροφορίες]] σχετικά με ατομικά δικαιώματα.",
- "listgrouprights-key": "* <span class=\"listgrouprights-granted\">Δόθηκε δικαίωμα</span>\n* <span class=\"listgrouprights-revoked\">Ανακλήθηκε δικαίωμα</span>",
+ "listgrouprights-key": "Υπόμνημα:\n* <span class=\"listgrouprights-granted\">Χορηγηθέν δικαίωμα</span>\n* <span class=\"listgrouprights-revoked\">Ανακληθέν δικαίωμα</span>",
"listgrouprights-group": "Ομάδα",
"listgrouprights-rights": "Δικαιώματα",
"listgrouprights-helppage": "Help:Δικαιώματα ομάδων",
"listgrouprights-removegroup-self": "Μπορεί να αφαιρέσει {{PLURAL:$2|ομάδα|ομάδες}} από το δικό σας λογαριασμό: $1",
"listgrouprights-addgroup-self-all": "Μπορεί να προσθέσει όλες τις ομάδες στο δικό σας λογαριασμό",
"listgrouprights-removegroup-self-all": "Μπορεί να αφαιρέσει όλες τις ομάδες από το δικό σας λογαριασμό",
+ "listgrouprights-namespaceprotection-header": "Περιορισμοί ονοματοχώρων",
"listgrouprights-namespaceprotection-namespace": "Ονοματοχώρος",
+ "listgrouprights-namespaceprotection-restrictedto": "Δικαίωμα(τα) που επιτρέπει(ουν) σε χρήστη να επεξεργαστεί",
+ "trackingcategories": "Παρακολούθηση κατηγοριών",
"trackingcategories-name": "Όνομα μηνύματος",
"trackingcategories-desc": "Κριτήρια συμπερίληψης κατηγορίας",
"post-expand-template-inclusion-category-desc": "Το μέγεθος της σελίδας είναι μεγαλύτερο από <code>$wgMaxArticleSize</code> μετά την επέκταση όλων των προτύπων, έτσι ώστε ορισμένα πρότυπα δεν έχουν αναπτυχθεί.",
+ "hidden-category-category-desc": "Η κατηγορία περιέχει <code><nowiki>__HIDDENCAT__</nowiki></code> στο περιεχόμενο της σελίδας της, που την εμποδίζει εκ προεπιλογής να εμφανίζεται στο πλαίσιο συνδέσμων κατηγοριών των σελίδων.",
"trackingcategories-nodesc": "Καμία διαθέσιμη περιγραφή.",
+ "trackingcategories-disabled": "Η κατηγορία είναι απενεργοποιημένη",
"mailnologin": "Δεν υπάρχει διεύθυνση παραλήπτη.",
"mailnologintext": "Πρέπει να έχετε [[Special:UserLogin|συνδεθεί]] και να έχετε δηλώσει\nμια έγκυρη ηλεκτρονική διεύθυνση στις [[Special:Preferences|Προτιμήσεις]]\nγια να στείλετε e-mail σε άλλους χρήστες.",
"emailuser": "Αποστολή μηνύματος ηλεκτρονικού ταχυδρομείου σε αυτόν τον χρήστη",
"watchnologin": "Δεν έχετε συνδεθεί.",
"addwatch": "Προσθήκη στη λίστα παρακολούθησης",
"addedwatchtext": "Η σελίδα «[[:$1]]» έχει προστεθεί στη [[Special:Watchlist|λίστα παρακολούθησής σας]].\nΜελλοντικές αλλαγές σε αυτή τη σελίδα και στη συσχετισμένη σελίδα συζήτησής της θα εμφανίζονται εδώ.",
+ "addedwatchtext-short": "Η σελίδα «$1» έχει προστεθεί στην λίστα παρακολούθησής σας.",
"removewatch": "Αφαίρεση από τη λίστα παρακολούθησης",
"removedwatchtext": "Η σελίδα \"[[:$1]]\" έχει αφαιρεθεί από [[Special:Watchlist|τη λίστα παρακολούθησής σας]].",
+ "removedwatchtext-short": "Η σελίδα «$1» έχει αφαιρεθεί από τη λίστα παρακολούθησής σας.",
"watch": "Παρακολούθηση",
"watchthispage": "Παρακολούθηση αυτής της σελίδας",
"unwatch": "Παύση παρακολούθησης",
"unwatchthispage": "Παύση παρακολούθησης αυτής της σελίδας",
"notanarticle": "Η σελίδα αυτή δεν είναι σελίδα περιεχομένου.",
"notvisiblerev": "Η έκδοση έχει διαγραφεί",
- "watchlist-details": "{{PLURAL:$1|$1 σελίδα|$1 σελίδες}} στη λίστα παρακολούθησης σας, χωρίς να προσμετρούνται οι σελίδες συζήτησης.",
+ "watchlist-details": "{{PLURAL:$1|$1 Ï\83ελίδα|$1 Ï\83ελίδεÏ\82}} Ï\83Ï\84η λίÏ\83Ï\84α Ï\80αÏ\81ακολοÏ\8dθηÏ\83ηÏ\82 Ï\83αÏ\82, Ï\87Ï\89Ï\81ίÏ\82 να Ï\80Ï\81οÏ\83μεÏ\84Ï\81οÏ\8dνÏ\84αι ξεÏ\87Ï\89Ï\81ιÏ\83Ï\84ά οι Ï\83ελίδεÏ\82 Ï\83Ï\85ζήÏ\84ηÏ\83ηÏ\82.",
"wlheader-enotif": "Η ειδοποίηση ηλεκτρονικού ταχυδρομείου ενεργοποιήθηκε.",
"wlheader-showupdated": "Σελίδες που έχουν υποστεί αλλαγές από την τελευταία φορά που τις επισκεφθήκατε εμφανίζονται με '''έντονους χαρακτήρες'''.",
- "wlnote": "Παρακάτω είναι {{PLURAL:$1|η πιο πρόσφατη αλλαγή|οι '''$1''' πιο πρόσφατες αλλαγές}} κατά τη διάρκεια {{PLURAL:$2|της τελευταίας ώρας|των '''$2''' τελευταίων ωρών}} ως προς την $3, $4.",
+ "wlnote": "Παρακάτω είναι {{PLURAL:$1|η πιο πρόσφατη αλλαγή|οι <strong>$1</strong> πιο πρόσφατες αλλαγές}} κατά τη διάρκεια {{PLURAL:$2|της τελευταίας ώρας|των <strong>$2</strong> τελευταίων ωρών}} ως προς τις $3 στις $4.",
"wlshowlast": "Εμφάνιση των τελευταίων $1 ωρών $2 ημερών $3",
"watchlist-options": "Επιλογές λίστας παρακολούθησης",
"watching": "Παρακολούθηση...",
"enotif_lastvisited": "Δείτε το $1 για όλες τις αλλαγές που έγιναν από την τελευταία σας επίσκεψη.",
"enotif_lastdiff": "Δείτε το $1 για να εμφανίσετε αυτή την αλλαγή.",
"enotif_anon_editor": "ανώνυμος χρήστης $1",
- "enotif_body": "{{GENDER:$WATCHINGUSERNAME|Î\91γαÏ\80ηÏ\84Î|Î\91γαÏ\80ηÏ\84ή}} $WATCHINGUSERNAME,\n\n$PAGEINTRO $NEWPAGE\n\nΠεÏ\81ιγÏ\81αÏ\86ή εÏ\80εξεÏ\81γαÏ\83ίαÏ\82: $PAGESUMMARY $PAGEMINOREDIT\n\nÎ\95Ï\80ικοινÏ\89νία με Ï\84ο Ï\87Ï\81ήÏ\83Ï\84η Ï\80οÏ\85 Îκανε Ï\84ην εÏ\80εξεÏ\81γαÏ\83ία:\nηλεκÏ\84Ï\81ονική διεÏ\8dθÏ\85νÏ\83η: $PAGEEDITOR_EMAIL\nwiki: $PAGEEDITOR_WIKI\n\nÎ\94εν θα Ï\85Ï\80άÏ\81ξοÏ\85ν άλλεÏ\82 ειδοÏ\80οιήÏ\83ειÏ\82 Ï\83ε Ï\80εÏ\81ίÏ\80Ï\84Ï\89Ï\83η Ï\80εÏ\81αιÏ\84ÎÏ\81Ï\89 δÏ\81αÏ\83Ï\84ηÏ\81ιÏ\8cÏ\84ηÏ\84αÏ\82 αν δεν εÏ\80ιÏ\83κεÏ\86θείÏ\84ε Ï\84η Ï\83ελίδα. Î\9cÏ\80οÏ\81είÏ\84ε εÏ\80ίÏ\83ηÏ\82 να εÏ\80αναÏ\86ÎÏ\81εÏ\84ε Ï\84ην εÏ\80ιλογή ειδοÏ\80οίηÏ\83ηÏ\82 για Ï\8cλεÏ\82 Ï\84ιÏ\82 Ï\80αÏ\81ακολοÏ\85θοÏ\8dμενεÏ\82 Ï\83ελίδεÏ\82 Ï\83Ï\84η λίÏ\83Ï\84α Ï\80αÏ\81ακολοÏ\8dθηÏ\83ήÏ\82 Ï\83αÏ\82.\n\n Φιλικά,\n Tο σύστημα ειδοποίησης του ιστοχώρου {{SITENAME}}\n\n--\nΓια να αλλάξετε τις προτιμήσεις των ειδοποιήσεων ηλεκτρονικού ταχυδρομείου, επισκεφτείτε το\n{{canonicalurl:{{#special:Preferences}}}}\n\nΓια να αλλάξετε τις προτιμήσεις της λίστας παρακολούθησής σας, επισκεφτείτε το\n{{canonicalurl:{{#special:EditWatchlist}}}}\n\nΓια να διαγράψετε την σελίδα από την λίστα παρακολούθησής σας, επισκεφτείτε το\n$UNWATCHURL\n\nΠαρατηρήσεις και περισσότερη βοήθεια:\n$HELPPAGE",
+ "enotif_body": "{{GENDER:$WATCHINGUSERNAME|Î\91γαÏ\80ηÏ\84Î|Î\91γαÏ\80ηÏ\84ή}} $WATCHINGUSERNAME,\n\n$PAGEINTRO $NEWPAGE\n\nΠεÏ\81ιγÏ\81αÏ\86ή εÏ\80εξεÏ\81γαÏ\83ίαÏ\82: $PAGESUMMARY $PAGEMINOREDIT\n\nÎ\95Ï\80ικοινÏ\89νία με Ï\84ο Ï\87Ï\81ήÏ\83Ï\84η Ï\80οÏ\85 Îκανε Ï\84ην εÏ\80εξεÏ\81γαÏ\83ία:\nδιεÏ\8dθÏ\85νÏ\83η ηλεκÏ\84Ï\81ονικήÏ\82 αλληλογÏ\81αÏ\86ίαÏ\82: $PAGEEDITOR_EMAIL\nwiki: $PAGEEDITOR_WIKI\n\nÎ\94εν θα Ï\85Ï\80άÏ\81ξοÏ\85ν άλλεÏ\82 ειδοÏ\80οιήÏ\83ειÏ\82 Ï\83ε Ï\80εÏ\81ίÏ\80Ï\84Ï\89Ï\83η Ï\80εÏ\81αιÏ\84ÎÏ\81Ï\89 δÏ\81αÏ\83Ï\84ηÏ\81ιÏ\8cÏ\84ηÏ\84αÏ\82 αν δεν εÏ\80ιÏ\83κεÏ\86θείÏ\84ε Ï\84η Ï\83ελίδα ÎÏ\87ονÏ\84αÏ\82 κάνει Ï\83Ï\8dνδεÏ\83η. Î\9cÏ\80οÏ\81είÏ\84ε εÏ\80ίÏ\83ηÏ\82 να εÏ\80αναÏ\86ÎÏ\81εÏ\84ε Ï\84ην εÏ\80ιλογή ειδοÏ\80οίηÏ\83ηÏ\82 για Ï\8cλεÏ\82 Ï\84ιÏ\82 Ï\80αÏ\81ακολοÏ\85θοÏ\8dμενεÏ\82 Ï\83ελίδεÏ\82 Ï\83Ï\84η λίÏ\83Ï\84α Ï\80αÏ\81ακολοÏ\8dθηÏ\83ήÏ\82 Ï\83αÏ\82.\n\nΦιλικά, \nÏ\84ο σύστημα ειδοποίησης του ιστοχώρου {{SITENAME}}\n\n--\nΓια να αλλάξετε τις προτιμήσεις των ειδοποιήσεων ηλεκτρονικού ταχυδρομείου, επισκεφτείτε το\n{{canonicalurl:{{#special:Preferences}}}}\n\nΓια να αλλάξετε τις προτιμήσεις της λίστας παρακολούθησής σας, επισκεφτείτε το\n{{canonicalurl:{{#special:EditWatchlist}}}}\n\nΓια να διαγράψετε την σελίδα από την λίστα παρακολούθησής σας, επισκεφτείτε το\n$UNWATCHURL\n\nΠαρατηρήσεις και περισσότερη βοήθεια:\n$HELPPAGE",
"created": "δημιουργήθηκε",
"changed": "έχει αλλάξει",
"deletepage": "Διαγραφή σελίδας",
"deletecomment": "Λόγος:",
"deleteotherreason": "Άλλος/πρόσθετος λόγος:",
"deletereasonotherlist": "Άλλος λόγος",
- "deletereason-dropdown": "*Συνηθισμένοι λόγοι διαγραφής\n** Αίτηση του δημιουργού της\n** Παραβίαση των πνευματικών δικαιωμάτων\n** Βανδαλισμός",
+ "deletereason-dropdown": "* Συνηθισμένοι λόγοι διαγραφής\n** Σπαμ\n** Βανδαλισμός\n** Παραβίαση πνευματικών δικαιωμάτων\n** Αίτηση του δημιουργού της\n** Κατεστραμμένη ανακατεύθυνση",
"delete-edit-reasonlist": "Επεξεργασία λόγων διαγραφής",
"delete-toobig": "Αυτή η σελίδα έχει μεγάλο ιστορικό τροποποιήσεων, πάνω από $1 {{PLURAL:$1|τροποποίηση|τροποποιήσεις}}.\nΗ διαγραφή τέτοιων σελίδων έχει περιοριστεί για την αποφυγή τυχαίας αναστάτωσης του {{SITENAME}}.",
"delete-warning-toobig": "Αυτή η σελίδα έχει μεγάλο ιστορικό τροποποιήσεων, πάνω από $1 {{PLURAL:$1|τροποποίηση|τροποποιήσεις}}.\nΗ διαγραφή της μπορεί να αναστατώσει τη λειτουργία της βάσης δεδομένων του {{SITENAME}}. Συνιστούμε μεγάλη προσοχή.",
"protect-locked-blocked": "Δεν μπορείτε να αλλάξετε επίπεδα προστασίας ενώ είστε σε φραγή.\nΕδώ είναι οι τρέχουσες ρυθμίσεις για τη σελίδα '''$1''':",
"protect-locked-dblock": "Τα επίπεδα προστασίας δεν μπορούν να αλλαχθούν λόγω ενός ενεργού κλεδώματος της βάσης δεδομένων.\nΕδώ είναι οι τρέχουσες ρυθμίσεις για τη σελίδα '''$1''':",
"protect-locked-access": "Ο λογαριασμός σας δεν έχει δικαίωμα να αλλάξει τα επίπεδα προστασίας σελίδας.\nΕδώ είναι οι τρέχουσες ρυθμίσεις για τη σελίδα '''$1''':",
- "protect-cascadeon": "Î\91Ï\85Ï\84ή η Ï\83ελίδα είναι Ï\80Ï\81οÏ\82 Ï\84ο Ï\80αÏ\81Ï\8cν Ï\80Ï\81οÏ\83Ï\84αÏ\84εÏ\85μÎνη εÏ\80ειδή Ï\80εÏ\81ιλαμβάνεÏ\84αι {{PLURAL:$1|Ï\83Ï\84ην ακÏ\8cλοÏ\85θη Ï\83ελίδα, η οÏ\80οία ÎÏ\87ει|Ï\83Ï\84ιÏ\82 ακÏ\8cλοÏ\85θεÏ\82 Ï\83ελίδεÏ\82, οι οÏ\80οίεÏ\82 ÎÏ\87οÏ\85ν}} Ï\84η διαδοÏ\87ική Ï\80Ï\81οÏ\83Ï\84αÏ\83ία ενεÏ\81γοÏ\80οιημÎνη. Î\9cÏ\80οÏ\81είÏ\84ε να αλλάξεÏ\84ε Ï\84ο εÏ\80ίÏ\80εδο Ï\80Ï\81οÏ\83Ï\84αÏ\83ίαÏ\82 αÏ\85Ï\84ήÏ\82 Ï\84ηÏ\82 Ï\83ελίδαÏ\82, αλλά δεν θα εÏ\80ηÏ\81εάÏ\83ει τη διαδοχική προστασία.",
+ "protect-cascadeon": "Î\91Ï\85Ï\84ή η Ï\83ελίδα είναι Ï\80Ï\81οÏ\82 Ï\84ο Ï\80αÏ\81Ï\8cν Ï\80Ï\81οÏ\83Ï\84αÏ\84εÏ\85μÎνη εÏ\80ειδή Ï\80εÏ\81ιλαμβάνεÏ\84αι {{PLURAL:$1|Ï\83Ï\84ην ακÏ\8cλοÏ\85θη Ï\83ελίδα, η οÏ\80οία ÎÏ\87ει|Ï\83Ï\84ιÏ\82 ακÏ\8cλοÏ\85θεÏ\82 Ï\83ελίδεÏ\82, οι οÏ\80οίεÏ\82 ÎÏ\87οÏ\85ν}} Ï\84η διαδοÏ\87ική Ï\80Ï\81οÏ\83Ï\84αÏ\83ία ενεÏ\81γοÏ\80οιημÎνη. Î\91λλαγÎÏ\82 Ï\83Ï\84ο εÏ\80ίÏ\80εδο Ï\80Ï\81οÏ\83Ï\84αÏ\83ίαÏ\82 αÏ\85Ï\84ήÏ\82 Ï\84ηÏ\82 Ï\83ελίδαÏ\82 δεν θα εÏ\80ηÏ\81εάÏ\83οÏ\85ν τη διαδοχική προστασία.",
"protect-default": "Να επιτρέπονται όλοι οι χρήστες",
"protect-fallback": "Να επιτρέπεται μόνο σε χρήστες με δικαιώματα «$1»",
"protect-level-autoconfirmed": "Να επιτρέπονται μόνο αυτοεπιβεβαιωμένοι χρήστες",
"contributions-title": "Συνεισφορές χρήστη για {{GENDER:$1|τον|την}} $1",
"mycontris": "Συνεισφορές",
"contribsub2": "Για {{GENDER:$3|$1}} ($2)",
+ "contributions-userdoesnotexist": "Ο λογαριασμός χρήστη «$1» δεν είναι εγγεγραμμένος.",
"nocontribs": "Δεν βρέθηκαν αλλαγές με αυτά τα κριτήρια.",
"uctop": "(τρέχουσα)",
"month": "Από το μήνα (και νωρίτερα):",
"sp-contributions-newbies-sub": "Για νέους λογαριασμούς",
"sp-contributions-newbies-title": "Συνεισφορές χρηστών για νέους λογαριασμούς",
"sp-contributions-blocklog": "αρχείο καταγραφών φραγών",
+ "sp-contributions-suppresslog": "διαγεγραμμένες συνεισφορές χρήστη",
"sp-contributions-deleted": "διαγραμμένες συνεισφορές χρήστη",
"sp-contributions-uploads": "ανεβάσματα αρχείων",
"sp-contributions-logs": "καταγραφές",
"sp-contributions-search": "Αναζήτηση για συνεισφορές",
"sp-contributions-username": "Διεύθυνση IP ή όνομα χρήστη:",
"sp-contributions-toponly": "Εμφάνιση μόνο των επεξεργασιών που είναι πρόσφατες αναθεωρήσεις",
+ "sp-contributions-newonly": "Εμφάνιση μόνο των επεξεργασιών που είναι δημιουργία σελίδας",
"sp-contributions-submit": "Αναζήτηση",
"whatlinkshere": "Τι συνδέει εδώ",
"whatlinkshere-title": "Σελίδες που συνδέουν στη σελίδα «$1»",
"blockipsuccesstext": "{{GENDER:$1|Ο|Η}} [[Special:Contributions/$1|$1]] έχει υποστεί φραγή.<br />\nΔείτε τον [[Special:BlockList|κατάλογο φραγών]] για να εποπτεύσετε τις φραγές.",
"ipb-blockingself": "Είστε έτοιμος να επιβάλετε φραγή στον ευατό σας! Είστε σίγουροι ότι θέλετε να το κάνετε αυτό;",
"ipb-confirmhideuser": "Είστε {{GENDER:|έτοιμος|έτοιμη}} να μπλοκάρετε ένα χρήστη με ενεργοποιημένη την \"απόκρυψη χρήστη\" . Αυτό θα καταστείλει το όνομα του χρήστη σε όλες τις λίστες και τις καταχωρήσεις ημερολογίου. Είστε {{GENDER:|σίγουρος|σίγουρη}} ότι θέλετε να το κάνετε αυτό;",
+ "ipb-confirmaction": "Εάν είστε σίγουροι ότι θέλετε πραγματικά να το κάνετε αυτό, παρακαλούμε τσεκάρετε το πεδίο «{{int:ipb-confirm}}» στο κάτω μέρος.",
"ipb-edit-dropdown": "Επεξεργασία λόγων φραγής",
"ipb-unblock-addr": "Τερμάτισε τη φραγή του/της $1",
"ipb-unblock": "Τερμάτισε τη φραγή για ένα όνομα χρήστη ή μια διεύθυνση IP",
"movepagetalktext": "Η σελίδα συζήτησης που αντιστοιχεί, εάν υπάρχει, θα μετακινηθεί αυτόματα μαζί με αυτήν '''έκτός αν:'''\n*Μετακινείτε τη σελίδα σε διαφορετική περιοχή (namespace),\n*Υπάρχει κάτω από το νέο όνομα μια σελίδα συζήτησης που δεν είναι κενή, ή\n*Έχετε αφαιρέσει τη σημείωση (check) από το κουτάκι που υπάρχει παρακάτω.\n\nΣε αυτές τις περιπτώσεις, θα πρέπει να μετακινήσετε (ή να ενσωματώσετε αν το θέλετε) τη σελίδα με αντιγραφή-και-επικόλληση.",
"movearticle": "Μετακίνηση σελίδας",
"moveuserpage-warning": "'''Προσοχή:''' Ετοιμάζεστε να μετακινήσετε μια σελίδα χρήστη. Σημειώστε παρακαλώ ότι θα μετακινηθεί μόνο η σελίδα και ο χρήστης '''δεν''' θα μετονομαστεί.",
+ "movecategorypage-warning": "<strong>Προειδοποίηση:</strong>Πάτε να μετακινήσετε μια σελίδα κατηγορίας. Παρακαλούμε να σημειωθεί ότι μόνο η σελίδα θα μετακινηθεί και τυχόν σελίδες στην παλιά κατηγορία <em>δεν</em> θα επανακατηγοριοποιηθούν στη νέα κατηγορία.",
"movenologintext": "Για να μετακινήσετε μια σελίδα πρέπει να είστε εγγεγραμένος χρήστης και [[Special:UserLogin|να έχετε συνδεθεί]] στο Wiκi.",
"movenotallowed": "Δεν έχετε άδεια να μετακινείτε σελίδες.",
"movenotallowedfile": "Δεν έχετε άδεια να μετακινείτε αρχεία.",
"cant-move-user-page": "Δεν έχετε άδεια για να μετακινήσετε σελίδες χρηστών (παρά μόνο υποσελίδες).",
"cant-move-to-user-page": "Δεν έχετε άδεια για να μετακινήσετε μια σελίδα σε σελίδα χρήστη (παρά μόνο σε υποσελίδα χρήστη).",
+ "cant-move-category-page": "Δεν έχετε άδεια να μετακινείτε σελίδες κατηγοριών.",
+ "cant-move-to-category-page": "Δεν έχετε άδεια να μετακινήσετε μια σελίδα σε σελίδα της κατηγορίας.",
"newtitle": "νέος τίτλος",
"move-watch": "Παρακολούθησε αυτή τη σελίδα",
"movepagebtn": "Μετακίνηση σελίδας",
"import": "Εισαγωγή σελίδων",
"importinterwiki": "Εισαγωγή από άλλο Wiki",
"import-interwiki-text": "Επιλέξτε ένα wiki και τίτλο σελίδας για την εισαγωγή.\nΟι ημερομηνίες των αναθεωρήσεων και τα ονόματα των συντακτών θα διατηρηθούν.\nΌλες οι ενέργειες εισαγωγής μεταξύ wiki καταγράφονται στο [[Special:Log/import|αρχείο καταγραφής εισαγωγών]].",
+ "import-interwiki-sourcewiki": "Πηγαίο wiki:",
+ "import-interwiki-sourcepage": "Πηγαία σελίδα:",
"import-interwiki-history": "Αντιγραφή όλων των εκδόσεων του ιστορικού για αυτή τη σελίδα",
"import-interwiki-templates": "Συμπερίληψη όλων των προτύπων",
"import-interwiki-submit": "Εισαγωγή",
"import-upload": "Επιφόρτωση δεδομένων XML",
"import-token-mismatch": "Απώλεια των στοιχείων της συνόδου. Παρακαλούμε προσπαθήστε ξανά.",
"import-invalid-interwiki": "Δεν είναι δυνατή η εισαγωγή από το καθορισμένο wiki.",
- "import-error-edit": "Η σελίδα \"$1\" δεν εισήχθηκε επειδή δεν επιτρέπεται να το επεξεργαστείτε.",
- "import-error-create": "Η σελίδα \"$1\" δεν εισήχθηκε επειδή δεν επιτρέπεται να τη δημιουργήσετε.",
- "import-error-interwiki": "Η σελίδα \" $1 \" δεν έχει εισαχθεί, επειδή το όνομα της δεσμευμένο για εξωτερική σύνδεση (interwiki).",
- "import-error-special": "Η σελίδα \"$1\" δεν εισήχθη επειδή ανήκει σε έναν ειδικό χώρο ονομάτων που δεν επιτρέπει σελίδες.",
- "import-error-invalid": "Η σελίδα \"$1\" δεν εισήχθη επειδή το όνομά της δεν είναι έγκυρο.",
+ "import-error-edit": "Η σελίδα «$1» δεν εισήχθη επειδή δεν σας επιτρέπεται να την επεξεργαστείτε.",
+ "import-error-create": "Η σελίδα «$1» δεν εισήχθη επειδή δεν σας επιτρέπεται να την δημιουργήσετε.",
+ "import-error-interwiki": "Η σελίδα «$1» δεν εισήχθη επειδή το όνομα της είναι δεσμευμένο για εξωτερική σύνδεση (interwiki).",
+ "import-error-special": "Η σελίδα «$1» δεν εισήχθη επειδή ανήκει σε έναν ειδικό ονοματοχώρο που δεν επιτρέπει σελίδες.",
+ "import-error-invalid": "Η σελίδα «$1» δεν εισήχθη επειδή το όνομά με το οποίο επρόκειτο να εισαχθεί δεν είναι έγκυρο σε αυτό το wiki.",
"import-options-wrong": "Λάθος {{PLURAL:$2|επιλογή|επιλογές}}: <nowiki>$1</nowiki>",
"import-rootpage-invalid": "Η δεδομένη ριζική σελίδα είναι μη έγκυρος τίτλος",
"importlogpage": "Αρχείο καταγραφής εισαγωγών",
"importlogpagetext": "Διαχειριστικές εισαγωγές σελίδων με ιστορικό επεξεργασίας από άλλα wiki.",
"import-logentry-upload": "εισάχθηκε η σελίδα [[$1]] με επιφόρτωση αρχείου",
- "import-logentry-upload-detail": "$1 {{PLURAL:$1|αναθεώρηση|αναθεωρήσεις}}",
+ "import-logentry-upload-detail": "{{PLURAL:$1|Εισήχθη $1 αναθεώρηση|Εισήχθησαν $1 αναθεωρήσεις}}",
"import-logentry-interwiki": "η σελίδα $1 εισάχθηκε μεταξύ wiki",
- "import-logentry-interwiki-detail": "$1 {{PLURAL:$1|αναθεώρηση|αναθεωρήσεις}} από $2",
+ "import-logentry-interwiki-detail": "{{PLURAL:$1|Εισήχθη $1 αναθεώρηση|Εισήχθησαν $1 αναθεωρήσεις}} από $2",
"javascripttest": "Δοκιμή JavaScript",
"javascripttest-title": "Εκτελούνται $1 δοκιμές",
"javascripttest-pagetext-noframework": "Αυτή η σελίδα είναι δεσμευμένη για την εκτέλεση δοκιμών σε JavaScript.",
"newimages-summary": "Αυτή η ειδική σελίδα δείχνει τα πιο πρόσφατα φορτωμένα αρχεία.",
"newimages-legend": "Φίλτρο",
"newimages-label": "Όνομα αρχείου (ή μέρος αυτού):",
+ "newimages-showbots": "Εμφάνιση αρχείων ανεβασμένων από ρομπότ",
"noimages": "Δεν υπάρχουν εικόνες.",
"ilsubmit": "Αναζήτηση",
"bydate": "ημερομηνίας",
"confirm-watch-top": "Προσθήκη αυτής της σελίδας στη λίστα παρακολούθησης σας;",
"confirm-unwatch-button": "Εντάξει",
"confirm-unwatch-top": "Κατάργηση αυτής της σελίδας από τη λίστα παρακολούθησης σας;",
- "quotation-marks": "\"$1\"",
+ "quotation-marks": "«$1»",
"imgmultipageprev": "← προηγούμενη σελίδα",
"imgmultipagenext": "επόμενη σελίδα →",
"imgmultigo": "Πήγαινε!",
"watchlistedit-raw-done": "Η λίστα παρακολούθησής σας ενημερώθηκε.",
"watchlistedit-raw-added": "{{PLURAL:$1|1 σελίδα|$1 σελίδες}} προστέθηκαν:",
"watchlistedit-raw-removed": "{{PLURAL:$1|1 σελίδα|$1 σελίδες}} αφαιρέθηκαν:",
+ "watchlistedit-clear-explain": "Όλοι οι τίτλοι θα αφαιρεθούν από τη λίστα παρακολούθησής σας",
"watchlistedit-clear-titles": "Τίτλοι:",
"watchlistedit-clear-submit": "Καθαρίστε τη λίστα παρακολούθησης (αυτό είναι μόνιμο!)",
+ "watchlistedit-clear-done": "Η λίστα παρακολούθησής σας έχει καθαριστεί.",
+ "watchlistedit-clear-removed": "{{PLURAL:$1|1 τίτλος αφαιρέθηκε|$1 τίτλοι αφαιρέθηκαν}}:",
"watchlistedit-too-many": "Υπάρχουν υπερβολικά πολλές σελίδες και δεν μπορούν να εμφανιστούν εδώ.",
"watchlisttools-view": "Προβολή σχετικών αλλαγών",
"watchlisttools-edit": "Προβολή και επεξεργασία λίστας παρακολούθησης",
"logentry-rights-rights": "{{GENDER:$2|Ο|Η}} $1 άλλαξε την ιδιότητα μέλους ομάδας για {{GENDER:$3|τον|την}} $3 από $4 σε $5",
"logentry-rights-rights-legacy": "{{GENDER:$2|Ο|Η}} $1 άλλαξε την ιδιότητα μέλους ομάδας {{GENDER:$1|του|της}} $3",
"logentry-rights-autopromote": "$1 {{GENDER:$2|προωθήθηκε}} αυτόματα από το $4 στο $5",
+ "logentry-upload-upload": "{{GENDER:$2|Ο|Η}} $1 ανέβασε το $3",
+ "logentry-upload-overwrite": "{{GENDER:$2|Ο|Η}} $1 ανέβασε μια νέα έκδοση του $3",
+ "logentry-upload-revert": "{{GENDER:$2|Ο|Η}} $1 ανέβασε το $3",
"rightsnone": "(κανένα)",
"feedback-bugornote": "Εάν είστε έτοιμοι να περιγράψετε ένα τεχνικό πρόβλημα λεπτομερώς παρακαλούμε [$1 κάντε μια αναφορά σφάλματος].\nΔιαφορετικά, μπορείτε να χρησιμοποιήσετε την παρακάτω απλή φόρμα. Το σχόλιό σας θα προστεθεί στη σελίδα \"[$3 $2]\", μαζί με το όνομα χρήστη σας.",
"feedback-subject": "Θέμα:",
"api-error-overwrite": "Αντικατάσταση ενός υπάρχοντος αρχείου δεν επιτρέπεται.",
"api-error-stashfailed": "Εσωτερικό σφάλμα: ο διακομιστής απέτυχε να αποθηκεύσει το προσωρινό αρχείο.",
"api-error-publishfailed": "Εσωτερικό σφάλμα: ο διακομιστής απέτυχε να αποθηκεύσει το προσωρινό αρχείο.",
+ "api-error-stasherror": "Παρουσιάστηκε ένα σφάλμα κατά το ανέβασμα του αρχείου στην κρύπτη.",
"api-error-timeout": "Ο διακομιστής δεν αποκρίθηκε εντός του αναμενόμενου χρόνου.",
"api-error-unclassified": "Προέκυψε ένα άγνωστο σφάλμα.",
"api-error-unknown-code": "Άγνωστο σφάλμα: \"$1\"",
"limitreport-ppvisitednodes": "Καταμέτρηση κόμβων επισκεφθέντων από τον προεπεξεργαστή",
"limitreport-ppgeneratednodes": "Καταμέτρηση κόμβων παραχθέντων από τον προεπεξεργαστή",
"limitreport-postexpandincludesize": "Μέγεθος συμπερίληψης πριν την ανάπτυξη",
+ "limitreport-postexpandincludesize-value": "$1 από $2 {{PLURAL:$2|byte|bytes}}",
"limitreport-templateargumentsize": "Μέγεθος ορισμάτων προτύπων",
+ "limitreport-templateargumentsize-value": "$1 από $2 {{PLURAL:$2|byte|bytes}}",
"limitreport-expansiondepth": "Μεγαλύτερο βάθος ανάπτυξης",
"limitreport-expensivefunctioncount": "Πλήθος ακριβών συναρτήσεων συντακτικού αναλυτή",
"expandtemplates": "Επέκτεινε τα πρότυπα",
"expand_templates_generate_xml": "Εμφάνιση δέντρου συντακτικής ανάλυσης XML",
"expand_templates_generate_rawhtml": "Εμφάνιση ανεπεξέργαστης HTML",
"expand_templates_preview": "Προεπισκόπηση",
+ "pagelanguage": "Επιλογέας γλώσσας σελίδας",
"pagelang-name": "Σελίδα",
"pagelang-language": "Γλώσσα",
"pagelang-use-default": "Χρήση προεπιλεγμένης γλώσσας",
"pagelang-select-lang": "Επιλογή γλώσσας",
+ "right-pagelang": "Αλλαγή γλώσσας σελίδας",
+ "action-pagelang": "αλλαγή της γλώσσας σελίδας",
"default-skin-not-found-row-enabled": "* <code>$1</code> /$2 (ενεργοποιημένο)",
"default-skin-not-found-row-disabled": "* <code>$1</code> / $2 ('''απενεργοποιημένο''')"
}
"showpreview": "Näita eelvaadet",
"showdiff": "Näita muudatusi",
"blankarticle": "<strong>Hoiatus:</strong> Lehekülg, mida alustad, on tühi.\nKui klõpsad uuesti \"{{int:savearticle}}\", luuakse lehekülg ilma sisuta.",
- "anoneditwarning": "'''Hoiatus:''' Sa pole sisse logitud.\nSelle lehe redigeerimislogisse salvestatakse su IP-aadress.",
+ "anoneditwarning": "<strong>Hoiatus:</strong> Sa pole sisse logitud. Sinu IP-aadress on kõigile nähtav, kui muudatusi teed. Kui <strong>[$1 logid sisse]</strong> või <strong>[$2 lood konto]</strong>, siis teiste eeliste seas omistatakse sinu muudatused sulle kasutajanime järgi.",
"anonpreviewwarning": "''Sa pole sisse logitud. Selle lehe redigeerimislogisse salvestatakse su IP-aadress.''",
"missingsummary": "'''Meeldetuletus:''' Sa ei ole lisanud muudatuse resümeed.\nKui vajutad uuesti salvestamise nupule, salvestatakse muudatus ilma resümeeta.",
"missingcommenttext": "Palun sisesta siit allapoole kommentaar.",
"tog-usenewrc": "گروهبندی تغییرات بر پایهٔ صفحات تغییرات اخیر و فهرست پیگیریها",
"tog-numberheadings": "شمارهگذاری خودکار عنوانها",
"tog-showtoolbar": "نوار ابزار ویرایش نمایش یابد",
- "tog-editondblclick": "ویرایش صفحهها با دو کلیک",
+ "tog-editondblclick": "ویرایش صفحات با دو کلیک",
"tog-editsectiononrightclick": "فعالکردن ویرایش بخشها با کلیک راست روی عنوان بخشها",
"tog-watchcreations": "صفحههایی که میسازم و پروندههایی که بارگذاری میکنم به فهرست پیگیریهایم افزوده شود",
"tog-watchdefault": "صفحهها و پروندههایی که ویرایش میکنم به فهرست پیگیریهایم افزوده شود",
"tog-watchmoves": "صفحهها و پروندههایی که منتقل میکنم به فهرست پیگیریهایم افزوده شود",
- "tog-watchdeletion": "صفحهها و پروندههایی که حذف میکنم به فهرست پیگیریهایم افزوده شود",
+ "tog-watchdeletion": "صفحات و پروندههایی که حذف میکنم به فهرست پیگیریهایم افزوده شود",
"tog-watchrollback": "افزودن صفحاتی که واگردانی کردم برای فهرست پیگیریهایم",
"tog-minordefault": "همهٔ ویرایشها به طور پیشفرض به عنوان «جزئی» علامت بخورد",
"tog-previewontop": "پیشنمایش قبل از جعبهٔ ویرایش نمایش یابد",
"category-file-count": "{{PLURAL:$2|این رده تنها حاوی پروندهٔ زیر است.|{{PLURAL:$1|این پرونده|این $1 پرونده}} در این رده قرار {{PLURAL:$1|دارد|دارند}}؛ این رده در کل حاوی $2 پرونده است.}}",
"category-file-count-limited": "{{PLURAL:$1|پروندهٔ|$1 پروندهٔ}} زیر در ردهٔ فعلی قرار دارند.",
"listingcontinuesabbrev": "(ادامه)",
- "index-category": "صفحههای نمایهشده",
- "noindex-category": "صفحههای نمایهنشده",
- "broken-file-category": "صفحههای دارای پیوند خراب به پرونده",
+ "index-category": "صفحات فهرستشده",
+ "noindex-category": "صفحات فهرستنشده",
+ "broken-file-category": "صفحات دارای پیوند خراب به پرونده",
"about": "درباره",
"article": "صفحهٔ محتوایی",
- "newwindow": "(در Ù¾Ù\86جرÙ\87Ù\94 جدÛ\8cد باز میشود)",
+ "newwindow": "(در Ù¾Ù\86جرÙ\87Ù\94 تازÙ\87 باز میشود)",
"cancel": "لغو",
"moredotdotdot": "بیشتر...",
"morenotlisted": "این فهرست کامل نیست.",
"mypage": "صفحه",
"mytalk": "بحث",
- "anontalk": "بØØ« براÛ\8c اÛ\8cÙ\86 آیپی",
- "navigation": "گشتن",
+ "anontalk": "بØØ« دربارÙ\87 اÛ\8cÙ\86 Ù\86شاÙ\86Û\8c آیپی",
+ "navigation": "ناوبری",
"and": " و",
"qbfind": "یافتن",
"qbbrowse": "مرور",
"qbedit": "ویرایش",
"qbpageoptions": "این صفحه",
- "qbmyoptions": "صفحههای من",
+ "qbmyoptions": "صفحات من",
"faq": "پرسشهای متداول",
"faqpage": "Project:پرسشهای متداول",
"actions": "عملکردها",
"create-this-page": "ایجاد این صفحه",
"delete": "حذف",
"deletethispage": "حذف این صفحه",
- "undeletethispage": "اØÛ\8cای این صفحه",
+ "undeletethispage": "بازگرداÙ\86ی این صفحه",
"undelete_short": "احیای {{PLURAL:$1|یک ویرایش|$1 ویرایش}}",
"viewdeleted_short": "نمایش {{PLURAL:$1|یک ویرایش حذفشده|$1 ویرایش حذفشده}}",
"protect": "محافظت",
"protect_change": "تغییر",
"protectthispage": "محافظت از این صفحه",
- "unprotect": "تغییر سطح محافظت",
- "unprotectthispage": "تغییر سطح محافظت این صفحه",
+ "unprotect": "تغییر محافظت",
+ "unprotectthispage": "تغییر محافظت این صفحه",
"newpage": "صفحهٔ تازه",
"talkpage": "بحث دربارهٔ این صفحه",
"talkpagelinktext": "بحث",
"laggedslavemode": "'''هشدار:''' صفحه ممکن است بهروزرسانیهای اخیر را شامل نشود.",
"readonly": "پایگاه داده قفل شد",
"enterlockreason": "دلیلی برای قفل کردن ذکر کنید، که حاوی تقریبی از زمانی باشد که قفل برداشته خواهد شد",
- "readonlytext": "پایگاه داده در حال حاضر در برابر تغییرات و ایجاد صفحهها قفل شدهاست؛ این وضعیت احتمالاً به خاطر بهینهسازی و رسیدگیهای معمول است که پس از آن وضع به حالت عادی بازخواهد گشت.\n\nمدیری که آن را قفل کرده این توضیح را ارائه کردهاست: $1",
+ "readonlytext": "پایگاه داده در حال حاضر در برابر تغییرات و ایجاد صفحات قفل شدهاست؛ این وضعیت احتمالاً به خاطر بهینهسازی و رسیدگیهای معمول است که پس از آن وضع به حالت عادی بازخواهد گشت.\n\nمدیری که آن را قفل کرده این توضیح را ارائه کردهاست: $1",
"missing-article": "پایگاه داده متن صفحهٔ با نام «$1» $2 را که باید پیدا میکرد نیافت.\n\nاین مشکل معمولاً به علت دنبالکردن یک پیوند تفاوت تاریخگذشته یا تاریخچهٔ صفحهای که حذف شدهاست، رخ میدهد.\n\nدر غیر این صورت ممکن است اشکالی در نرمافزار پیدا کرده باشد.\nلطفاً این مشکل را با ذکر نشانی اینترنتی به یکی از [[Special:ListUsers/sysop|مدیران]] گزارش دهید.",
"missingarticle-rev": "(شمارهٔ نسخه: $1)",
"missingarticle-diff": "(تفاوت: $1، $2)",
"userlogin-noaccount": "حساب کاربری ندارید؟",
"userlogin-joinproject": "در {{SITENAME}} نامنویسی کنید!",
"nologin": "حساب کاربری ندارید؟ $1.",
- "nologinlink": "Û\8cÚ© Øساب کاربرÛ\8c جدÛ\8cد بسازید",
+ "nologinlink": "Û\8cÚ© Øساب کاربرÛ\8c تازÙ\87 بسازید",
"createaccount": "ایجاد حساب کاربری",
"gotaccount": "حساب کاربری دارید؟ $1.",
"gotaccountlink": "به سامانه وارد شوید",
"noname": "شما نام کاربری معتبری مشخص نکردهاید.",
"loginsuccesstitle": "ورود موفقیتآمیز به سامانه",
"loginsuccess": "'''شما اکنون با نام «$1» به {{SITENAME}} وارد شدهاید.'''",
- "nosuchuser": "کاربرÛ\8c با Ù\86اÙ\85 «$1» Ù\88جÙ\88د Ù\86دارد.\nÙ\86اÙ\85 کاربرÛ\8c بÙ\87 بزرگÛ\8c Ù\88 Ú©Ù\88Ú\86Ú©Û\8c ØرÙ\88Ù\81 Øساس است.\nاÙ\85Ù\84اÛ\8c Ù\86اÙ\85 را بررسÛ\8c Ú©Ù\86Û\8cدØ\8c Û\8cا [[Special:UserLogin/signup|Û\8cÚ© Øساب کاربرÛ\8c جدÛ\8cد بسازید]].",
+ "nosuchuser": "کاربرÛ\8c با Ù\86اÙ\85 «$1» Ù\88جÙ\88د Ù\86دارد.\nÙ\86اÙ\85 کاربرÛ\8c بÙ\87 بزرگÛ\8c Ù\88 Ú©Ù\88Ú\86Ú©Û\8c ØرÙ\88Ù\81 Øساس است.\nاÙ\85Ù\84اÛ\8c Ù\86اÙ\85 را بررسÛ\8c Ú©Ù\86Û\8cدØ\8c Û\8cا [[Special:UserLogin/signup|Û\8cÚ© Øساب کاربرÛ\8c تازÙ\87 بسازید]].",
"nosuchusershort": "هیچ کاربری با نام ''$1'' وجود ندارد.\nاملایتان را وارسی کنید.",
"nouserspecified": "باید یک نام کاربری مشخص کنید.",
"login-userblocked": "این کاربر بسته شدهاست. ورود به سامانه مجاز نیست.",
"resetpass_header": "تغییر گذرواژهٔ حساب کاربری",
"oldpassword": "گذرواژهٔ پیشین:",
"newpassword": "گذرواژهٔ تازه:",
- "retypenew": "گذرÙ\88اÚ\98Ù\87Ù\94 جدÛ\8cد را دوباره وارد کنید",
+ "retypenew": "گذرÙ\88اÚ\98Ù\87Ù\94 تازÙ\87 را دوباره وارد کنید",
"resetpass_submit": "تنظیم گذرواژه و ورود به سامانه",
"changepassword-success": "گذرواژهٔ شما با موفقیت تغییر داده شد!",
"changepassword-throttled": "شما به تازگی چندینبار برای ثبت ورود تلاش کردهاید.\nلطفاً پیش از آنکه دوباره تلاش کنید $1 صبر کنید.",
"resetpass-no-info": "برای دسترسی مستقیم به این صفحه شما باید به سامانه وارد شده باشید.",
"resetpass-submit-loggedin": "تغییر گذرواژه",
"resetpass-submit-cancel": "لغو",
- "resetpass-wrong-oldpass": "گذرÙ\88اÚ\98Ù\87Ù\94 Ù\85Ù\88Ù\82ت Û\8cا اخÛ\8cر Ù\86اÙ\85عتبر.\nÙ\85Ù\85Ú©Ù\86 است Ú©Ù\87 Ø´Ù\85ا Ù\87Ù\85Û\8cÙ\86Ú© گذرÙ\88اÚ\98Ù\87â\80\8cتاÙ\86 را با Ù\85Ù\88Ù\81Ù\82Û\8cت تغÛ\8cÛ\8cر دادÙ\87 باشÛ\8cد Û\8cا درخÙ\88است Û\8cÚ© گذرÙ\88اÚ\98Ù\87Ù\94 Ù\85Ù\88Ù\82ت جدÛ\8cد کرده باشید.",
+ "resetpass-wrong-oldpass": "گذرÙ\88اÚ\98Ù\87Ù\94 Ù\85Ù\88Ù\82ت Û\8cا اخÛ\8cر Ù\86اÙ\85عتبر.\nÙ\85Ù\85Ú©Ù\86 است Ú©Ù\87 Ø´Ù\85ا Ù\87Ù\85Û\8cÙ\86Ú© گذرÙ\88اÚ\98Ù\87â\80\8cتاÙ\86 را با Ù\85Ù\88Ù\81Ù\82Û\8cت تغÛ\8cÛ\8cر دادÙ\87 باشÛ\8cد Û\8cا درخÙ\88است Û\8cÚ© گذرÙ\88اÚ\98Ù\87Ù\94 Ù\85Ù\88Ù\82ت تازÙ\87 کرده باشید.",
"resetpass-recycled": "لطفاً رمز عبور خود را به چیز دیگری غیر از رمز عبور فعلی تنظیم کنید.",
"resetpass-temp-emailed": "شما با یک کد رایانامه شدهٔ موقت وارد شدهاید.\nبرای پایان ورود، شما باید رمز عبور جدیدی اینجا وارد کنید:",
"resetpass-temp-password": "گذرواژهٔ موقت:",
"resetpass-abort-generic": "تغییر گذرواژه به دست یکی از افزونهها لغو شده است.",
"resetpass-expired": "رمز عبور شما منقضی شدهاست. لطفاً برای ورود رمز عبور جدیدی را تنظیم کنید.",
"resetpass-expired-soft": "رمز عبور شما منقضی شدهاست، و نیاز به تنظیم مجدد دارد. لطفاً اکنون رمز عبور جدیدی را انتخاب کنید، یا برای تنظیم مجدد آن بعدآً، دکمه \"{{int:resetpass-submit-cancel}}\" را کلیک کنید.",
- "resetpass-validity-soft": "گذرÙ\88اÙ\87Ù\94 Ø´Ù\85ا صØÛ\8cØ Ù\86Û\8cست: $1\n\nÙ\84Ø·Ù\81اÙ\8b Û\8cÚ© گذرÙ\88اÚ\98Ù\87Ù\94 جدÛ\8cد الآن انتخاب کنید یا بر «{{int:resetpass-submit-cancel}}» کلیک کنید که دوباره آن را بعداً انتخاب کنید.",
+ "resetpass-validity-soft": "گذرÙ\88اÙ\87Ù\94 Ø´Ù\85ا صØÛ\8cØ Ù\86Û\8cست: $1\n\nÙ\84Ø·Ù\81اÙ\8b Û\8cÚ© گذرÙ\88اÚ\98Ù\87Ù\94 تازÙ\87 الآن انتخاب کنید یا بر «{{int:resetpass-submit-cancel}}» کلیک کنید که دوباره آن را بعداً انتخاب کنید.",
"passwordreset": "بازنشانی گذرواژه",
"passwordreset-text-one": "برای بازنشانی گذرواژهتان این فرم را کامل کنید.",
"passwordreset-text-many": "{{PLURAL:$1|برای دریافت یک گذرواژهٔ موقت از راه رایانامه، یکی از زمینهها را پر کنید.}}",
"showpreview": "پیشنمایش",
"showdiff": "نمایش تغییرات",
"blankarticle": "<strong>هشدار:</strong> شما در حال ایجاد صفحه خالی هستید.\nاگر \"{{int:savearticle}}\" را دوباره کلیک کنید، صفحه بدون محتوا ایجاد میشود.",
- "anoneditwarning": "'''هشدار:''' شما به سامانه وارد نشدهاید.\nنشانی آیپی شما در تاریخچهٔ ویرایش این صفحه ثبت خواهد شد.",
+ "anoneditwarning": "<strong>هشدار:</strong> شما وارد نشدهاید. نشانی آیپی شما برای عموم قابل مشاهده خواهد بود اگر هر تغییری ایجاد کنید. اگر <strong>[$1 وارد شوید]</strong> یا <strong>[$2 یک حساب کاربری بسازید]</strong>، ویرایشهایتان به نام کاربریتان نسبت داده خواهد شد، همراه با مزایای دیگر.",
"anonpreviewwarning": "''شما به سامانه وارد نشدهاید. ذخیره کردن باعث میشود که نشانی آیپی شما در تاریخچهٔ این صفحه ثبت گردد.''",
"missingsummary": "'''یادآوری:''' شما خلاصهٔ ویرایش ننوشتهاید.\nاگر دوباره دکمهٔ «{{int:savearticle}}» را فشار دهید ویرایش شما بدون آن ذخیره خواهد شد.",
"missingcommenttext": "لطفاً توضیحی در زیر بیفزایید.",
"autoblockedtext": "دسترسی نشانی آیپی شما قطع شدهاست، زیرا این نشانی آیپی توسط کاربر دیگری استفاده شده که دسترسی او توسط $1 قطع شدهاست.\nدلیل ارائهشده چنین است:\n\n:''$2''\n\n* شروع قطع دسترسی: $8\n* پایان قطع دسترسی: $6\n* کاربری هدف قطع دسترسی: $7\n\nشما میتوانید با $1 یا [[{{MediaWiki:Grouppage-sysop}}|مدیری]] دیگر تماس بگیرید و در این باره صحبت کنید.\nتوجه کنید که شما نمیتوانید از ویژگی «فرستادن رایانامه به این کاربر» استفاده کنید مگر آنکه نشانی رایانامه معتبری در [[Special:Preferences|ترجیحات کاربری]] خودتان ثبت کرده باشید و نیز باید امکان استفاده از این ویژگی برای شما قطع نشده باشد.\nنشانی آیپی فعلی شما $3 و شمارهٔ قطع دسترسی شما $5 است.\nلطفاً تمامی جزئیات فوق را در کلیهٔ درخواستهایی که در این باره مطرح میکنید ذکر کنید.",
"blockednoreason": "دلیلی مشخص نشدهاست",
"whitelistedittext": "برای ویرایش مقالهها باید $1.",
- "confirmedittext": "شما باید، پیش از ویرایش صفحهها، نشانی رایانامهٔ خود را مشخص و تأیید کنید. لطفاً از طریق [[Special:Preferences|ترجیحات کاربر]] این کار را صورت دهید.",
+ "confirmedittext": "شما باید، پیش از ویرایش صفحات، نشانی رایانامهٔ خود را مشخص و تأیید کنید. لطفاً از طریق [[Special:Preferences|ترجیحات کاربر]] این کار را صورت دهید.",
"nosuchsectiontitle": "چنین بخشی پیدا نشد",
"nosuchsectiontext": "شما تلاش کردهاید یک بخش در صفحه را ویرایش کنید که وجود ندارد.\nممکن است در مدتی که شما صفحه را مشاهده میکردید این بخش جا به جا یا حذف شده باشد.",
"loginreqtitle": "ورود به سامانه لازم است",
"newarticletext": "شما پیوندی را دنبال کردهاید و به صفحهای رسیدهاید که هنوز وجود ندارد.\nبرای ایجاد صفحه، در مستطیل زیر شروع به نوشتن کنید (برای اطلاعات بیشتر به [$1 صفحهٔ راهنما] مراجعه کنید).\nاگر به اشتباه اینجا آمدهاید، دکمهٔ «بازگشت» مرورگرتان را بزنید.",
"anontalkpagetext": "----''این صفحهٔ بحث برای کاربر گمنامی است که هنوز حسابی درست نکرده است یا از آن استفاده نمیکند.\nبنا بر این برای شناساییاش مجبوریم از نشانی آیپی عددی استفاده کنیم.\nچنین نشانیهای آیپی ممکن است توسط چندین کاربر به شکل مشترک استفاده شود.\nاگر شما کاربر گمنامی هستید و تصور میکنید اظهار نظرات نامربوط به شما صورت گرفته است، لطفاً برای پیشگیری از اشتباه گرفته شدن با کاربران گمنام دیگر در آینده [[Special:UserLogin/signup|حسابی ایجاد کنید]] یا [[Special:UserLogin|به سامانه وارد شوید]].''",
"noarticletext": "این صفحه هماکنون دارای هیچ متنی نیست.\nشما میتوانید در صفحههای دیگر [[Special:Search/{{PAGENAME}}|عنوان این صفحه را جستجو کنید]]،\n<span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} سیاهههای مرتبط را جستجو کنید]،\nیا [{{fullurl:{{FULLPAGENAME}}|action=edit}} این صفحه را ویرایش کنید]</span>.",
- "noarticletext-nopermission": "این صفحه هماکنون متنی ندارد.\nشما میتوانید در دیگر صفحهها [[Special:Search/{{PAGENAME}}|این عنوان را جستجو کنید]]،\nیا <span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} سیاهههای مرتبط را بگردید]</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}}}} سیاههٔ حذف] بیابید.",
"userpage-userdoesnotexist": "حساب کاربر «<nowiki>$1</nowiki>» ثبت نشدهاست.\nلطفاً مطمئن شوید که میخواهید این صفحه را ایجاد یا ویرایش کنید.",
"userpage-userdoesnotexist-view": "حساب کاربری «$1» ثبت نشدهاست.",
"editing": "در حال ویرایش $1",
"creating": "ایجاد $1",
"editingsection": "در حال ویرایش $1 (بخش)",
- "editingcomment": "در ØاÙ\84 Ù\88Û\8cراÛ\8cØ´ $1 (بخش جدÛ\8cد)",
+ "editingcomment": "در ØاÙ\84 Ù\88Û\8cراÛ\8cØ´ $1 (بخش تازÙ\87)",
"editconflict": "تعارض ویرایشی: $1",
"explainconflict": "از وقتی ویرایش این صفحه را آغاز کردهاید شخص دیگری آن را تغییر دادهاست.\nناحیهٔ متنی بالایی شامل متن صفحه به شکل کنونی آن است.\nتغییرات شما در ناحیهٔ متنی پایینی نشان داده شدهاست.\nشما باید تغییراتتان را با متن کنونی ترکیب کنید.\nبا فشردن دکمهٔ «{{int:savearticle}}» '''فقط''' متن ناحیهٔ متنی بالایی ذخیره خواهد شد.",
"yourtext": "متن شما",
"storedversion": "نسخهٔ ذخیره شده",
- "nonunicodebrowser": "'''هشدار: مرورگر شما با استانداردهای یونیکد سازگار نیست.'''\nراه حلی به کار گرفته شده تا شما بتوانید صفحهها را با امنیت ویرایش کنید: کاراکترهای غیر ASCII به صورت کدهایی در مبنای شانزده به شما نشان داده میشوند.",
+ "nonunicodebrowser": "'''هشدار: مرورگر شما با استانداردهای یونیکد سازگار نیست.'''\nراه حلی به کار گرفته شده تا شما بتوانید صفحات را با امنیت ویرایش کنید: کاراکترهای غیر ASCII به صورت کدهایی در مبنای شانزده به شما نشان داده میشوند.",
"editingold": "'''هشدار: شما در حال ویرایش نسخهای قدیمی از این صفحه هستید.'''\nاگر ذخیرهاش کنید، هر تغییری که پس از این نسخه انجام شدهاست از بین خواهد رفت.",
"yourdiff": "تفاوتها",
"copyrightwarning": "لطفاً توجه داشته باشید که فرض میشود کلیهٔ مشارکتهای شما با {{SITENAME}} تحت «$2» منتشر میشوند (برای جزئیات بیشتر به $1 مراجعه کنید).\nاگر نمیخواهید نوشتههایتان بیرحمانه ویرایش شده و به دلخواه توزیع شود، اینجا نفرستیدشان.<br />\nهمچنین شما دارید به ما قول میدهید که خودتان این را نوشتهاید، یا آن را از یک منبع آزاد با مالکیت عمومی یا مشابه آن برداشتهاید.\n'''کارهای دارای حق تکثیر (copyright) را بیاجازه نفرستید!'''",
"template-semiprotected": "(نیمهحفاظتشده)",
"hiddencategories": "این صفحه در {{PLURAL:$1|یک ردهٔ پنهان|$1 ردهٔ پنهان}} قرار دارد:",
"edittools": "<!-- متن این قسمت زیر صفحههای ویرایش و بارگذاری نشان داده میشود -->",
- "nocreatetext": "{{SITENAME}} Ù\82ابÙ\84Û\8cت اÛ\8cجاد صÙ\81ØÙ\87â\80\8cÙ\87اÛ\8c جدÛ\8cد را محدود کردهاست.\nمیتوانید بازگردید و صفحهای موجود را ویرایش کنید یا اینکه [[Special:UserLogin|به سامانه وارد شوید یا حساب کاربری ایجاد کنید]].",
- "nocreate-loggedin": "Ø´Ù\85ا اجازÙ\87Ù\94 اÛ\8cجاد صÙ\81ØÙ\87â\80\8cÙ\87اÛ\8c جدÛ\8cد را ندارید.",
+ "nocreatetext": "{{SITENAME}} Ù\82ابÙ\84Û\8cت اÛ\8cجاد صÙ\81ØÙ\87â\80\8cÙ\87اÛ\8c تازÙ\87 را محدود کردهاست.\nمیتوانید بازگردید و صفحهای موجود را ویرایش کنید یا اینکه [[Special:UserLogin|به سامانه وارد شوید یا حساب کاربری ایجاد کنید]].",
+ "nocreate-loggedin": "Ø´Ù\85ا اجازÙ\87Ù\94 اÛ\8cجاد صÙ\81ØÙ\87â\80\8cÙ\87اÛ\8c تازÙ\87 را ندارید.",
"sectioneditnotsupported-title": "ویرایش بخشها پشتیبانی نمیشود",
"sectioneditnotsupported-text": "این صفحه از ویرایش بخشها پشتیبانی نمیکند.",
"permissionserrors": "خطای سطح دسترسی",
"postedit-confirmation-created": "صفحه ایجاد شده است.",
"postedit-confirmation-restored": "صفحه بازیابی شده است.",
"postedit-confirmation-saved": "ویرایش شما ذخیره شد.",
- "edit-already-exists": "اÙ\85کاÙ\86 ساختÙ\86 صÙ\81ØÙ\87Ù\94 جدÛ\8cد وجود ندارد.\nاین صفحه از قبل وجود داشتهاست.",
+ "edit-already-exists": "اÙ\85کاÙ\86 ساختÙ\86 صÙ\81ØÙ\87Ù\94 تازÙ\87 وجود ندارد.\nاین صفحه از قبل وجود داشتهاست.",
"defaultmessagetext": "متن پیشفرض پیغام",
"content-failed-to-parse": "عدم موفقیت در تجزیه محتوای $2 برای مدل $1: $3",
"invalid-content-data": "داده محتوای نامعتبر",
"history-feed-title": "تاریخچهٔ ویرایشها",
"history-feed-description": "تاریخچهٔ ویرایشهای این صفحه در ویکی",
"history-feed-item-nocomment": "$1 در $2",
- "history-feed-empty": "صفحهٔ درخواست شده وجود ندارد.\nممکن است که از ویکی حذف یا اینکه نامش تغییر داده شده باشد.\nصفحههای جدید را برای موارد مرتبط در این ویکی [[Special:Search|جستجو کنید]].",
+ "history-feed-empty": "صفحهٔ درخواست شده وجود ندارد.\nممکن است که از ویکی حذف یا اینکه نامش تغییر داده شده باشد.\nصفحات تازه را برای موارد مرتبط در این ویکی [[Special:Search|جستجو کنید]].",
"rev-deleted-comment": "(خلاصه ویرایش حذف شد)",
"rev-deleted-user": "(نام کاربری حذف شد)",
"rev-deleted-event": "(مورد از سیاهه پاک شده)",
"revdelete-offender": "نویسنده نسخه:",
"suppressionlog": "سیاههٔ فرونشانی",
"suppressionlogtext": "در زیر فهرستی از آخرین حذفها و قطع دسترسیهایی که حاوی محتوایی هستند که از مدیران پنهان شدهاند را میبینید.\nبرای مشاهدهٔ فهرستی از قطع دسترسیهای فعال [[Special:BlockList|فهرست بستهشدهها]] را ببینید.",
- "mergehistory": "ادغام تاریخچه صفحهها",
+ "mergehistory": "ادغام تاریخچه صفحات",
"mergehistory-header": "این صفحه به شما این امکان را میدهد که نسخههای تاریخچهٔ یک مقاله را با یک مقاله دیگر ادغام کنید.\nاطمینان حاصل کنید که این تغییر به توالی زمانی ویرایشها لطمه نخواهد زد.",
"mergehistory-box": "ادغام نسخههای دو صفحه:",
"mergehistory-from": "صفحهٔ مبدأ:",
"mergelogpagetext": "در زیر سیاههٔ آخرین موارد ادغام تاریخچهٔ یک صفحه در صفحهای دیگر را میبینید.",
"history-title": "$1: تاریخچهٔ ویرایشها",
"difference-title": "$1: تفاوت بین نسخهها",
- "difference-title-multipage": "$1 و $2: تفاوت بین صفحهها",
- "difference-multipage": "(تفاوت بین صفحهها)",
+ "difference-title-multipage": "$1 و $2: تفاوت بین صفحات",
+ "difference-multipage": "(تفاوت بین صفحات)",
"lineno": "سطر $1:",
"compareselectedversions": "مقایسهٔ نسخههای انتخابشده",
"showhideselectedversions": "تغییر پدیداری بازبینیهای انتخابشده",
"right-createaccount": "ایجاد حسابهای کاربری",
"right-minoredit": "علامتزدن ویرایشها بهعنوان جزئی",
"right-move": "انتقال صفحه",
- "right-move-subpages": "انتقال صفحÙ\87â\80\8cÙ\87ا بÙ\87 Ù\87Ù\85راÙ\87 زÛ\8cرâ\80\8cصÙ\81ØÙ\87â\80\8cÙ\87اÛ\8cشاÙ\86",
+ "right-move-subpages": "انتقال صفحات بÙ\87 Ù\87Ù\85راÙ\87 زÛ\8cرâ\80\8cصÙ\81Øاتâ\80\8cشاÙ\86",
"right-move-rootuserpages": "انتقال صفحههای کاربری سرشاخه",
"right-move-categorypages": "انتقال صفحهٔ رده",
"right-movefile": "انتقال پروندهها",
"right-purge": "پاککردن میانگیر صفحه بدون مشاهدهٔ صفحهٔ تأیید",
"right-autoconfirmed": "از محدودیتهای سرعت آیپی-محور تاثیر نمیگیرد",
"right-bot": "تلقیشده به عنوان یک فرآیند خودکار",
- "right-nominornewtalk": "Ù\88Û\8cراÛ\8cØ´ جزئÛ\8c صÙ\81ØÙ\87â\80\8cÙ\87اÛ\8c بØØ« بÙ\87 Ø´Ú©Ù\84Û\8c Ú©Ù\87 باعث اعÙ\84اÙ\86 Ù¾Û\8cغاÙ\85 جدÛ\8cد نشود",
+ "right-nominornewtalk": "Ù\88Û\8cراÛ\8cØ´ جزئÛ\8c صÙ\81ØÙ\87â\80\8cÙ\87اÛ\8c بØØ« بÙ\87 Ø´Ú©Ù\84Û\8c Ú©Ù\87 باعث اعÙ\84اÙ\86 Ù¾Û\8cغاÙ\85 تازÙ\87 نشود",
"right-apihighlimits": "سقف بالاتر استفاده از API",
"right-writeapi": "استفاده از API مربوط به نوشتن",
- "right-delete": "حذف صفحهها",
+ "right-delete": "حذف صفحات",
"right-bigdelete": "حذف صفحههای دارای تاریخچهٔ بزرگ",
"right-deletelogentry": "حذف و احیای مدخلهای خاصی از سیاهه",
"right-deleterevision": "حذف و احیای نسخههای خاصی از صفحه",
"right-deletedhistory": "مشاهدهٔ موارد حذفشده از تاریخچه، بدون دیدن متن آنها",
"right-deletedtext": "مشاهدهٔ متن حذفشده و تغییرات بین نسخههای حذفشده",
"right-browsearchive": "جستجوی صفحههای حذفشده",
- "right-undelete": "احیای صفحهها",
+ "right-undelete": "احیای صفحات",
"right-suppressrevision": "مشاهده و احیای ویرایشهایی که از کاربران پنهان شدهاند",
"right-viewsuppressed": "مشاهده نسخههایی که از کاربران مخفی شدهاند",
"right-suppressionlog": "مشاهدهٔ سیاهههای خصوصی",
"right-ipblock-exempt": "تاثیر نپذیرفتن از قطع دسترسیهای آیپی، خودکار یا فاصلهای",
"right-proxyunbannable": "تاثیر نپذیرفتن از قطع دسترسی خودکار پروکسیها",
"right-unblockself": "بازکردن دسترسی خود",
- "right-protect": "تغییر میزان محافظت صفحهها و ویرایش صفحههای محافظتشده آبشاری",
+ "right-protect": "تغییر میزان محافظت صفحات و ویرایش صفحات محافظتشده آبشاری",
"right-editprotected": "ویرایش صفحههای محافظتشده بهعنوان «{{int:protect-level-sysop}}»",
"right-editsemiprotected": "ویرایش صفحه حفاظتشده به عنوان \"{{int:protect-level-autoconfirmed}}\"",
"right-editinterface": "ویرایش واسط کاربری",
"right-editmyusercss": "پروندههای سیاساس کاربری خود را ویرایش کنید",
"right-editmyuserjs": "پروندههای جاوااسکریپت کاربری خود را ویرایش کنید",
"right-viewmywatchlist": "فهرست پیگیریهای خود را ببینید",
- "right-editmywatchlist": "فهرست پیگیریهای خود را ویرایش کنید. توجه داشته باشید برخی از اقدامات حتی بدون این دسترسی هم صفحهها را اضافه میکنند.",
+ "right-editmywatchlist": "فهرست پیگیریهای خود را ویرایش کنید. توجه داشته باشید برخی از اقدامات حتی بدون این دسترسی هم صفحات را اضافه میکنند.",
"right-viewmyprivateinfo": "دادههای خصوصی خود را ببینید (مانند رایانشانی و نام واقعی)",
"right-editmyprivateinfo": "دادههای خصوصی خود را ویرایش کنید (مانند رایانشانی و نام واقعی)",
"right-editmyoptions": "ترجیحات خود را ویرایش",
"right-autopatrol": "گشت زدن خودکار ویرایشهای خودش",
"right-patrolmarks": "مشاهدهٔ برچسب گشت تغییرات اخیر",
"right-unwatchedpages": "مشاهدهٔ فهرست صفحههایی که پیگیری نمیشوند",
- "right-mergehistory": "ادغام تاریخچهٔ صفحهها",
+ "right-mergehistory": "ادغام تاریخچهٔ صفحات",
"right-userrights": "ویرایش تمام اختیارات کاربرها",
"right-userrights-interwiki": "ویرایش اختیارات کاربرهای ویکیهای دیگر",
"right-siteadmin": "قفلکردن و بازکردن پایگاه دادهها",
"recentchanges-summary": "آخرین تغییرات ویکی را در این صفحه پیگیری کنید.",
"recentchanges-noresult": "هیچ تغییری در طول دورهٔ تعیینشده با این معیارها همخوانی نداشت.",
"recentchanges-feed-description": "آخرین تغییرات ویکی را در این خوراک پیگیری کنید.",
- "recentchanges-label-newpage": "اÛ\8cÙ\86 Ù\88Û\8cراÛ\8cØ´ صÙ\81ØÙ\87â\80\8cاÛ\8c جدÛ\8cد ایجاد کرد",
+ "recentchanges-label-newpage": "اÛ\8cÙ\86 Ù\88Û\8cراÛ\8cØ´ صÙ\81ØÙ\87â\80\8cاÛ\8c تازÙ\87 ایجاد کرد",
"recentchanges-label-minor": "این یک ویرایش جزئیاست",
"recentchanges-label-bot": "این ویرایش را یک ربات انجام دادهاست",
"recentchanges-label-unpatrolled": "این ویرایش هنوز گشتزنی نشدهاست",
"recentchanges-label-plusminus": "حجم صفحه به اندازه این بایتها تغییر یافتهاست",
"recentchanges-legend-heading": "'''اختصارها:'''",
- "recentchanges-legend-newpage": "{{int:recentchanges-label-newpage}} (Ù\87Ù\85Ú\86Ù\86Û\8cÙ\86 بÙ\87 [[Special:NewPages|Ù\81Ù\87رست صÙ\81Øات جدÛ\8cد]] نگاه کنید)",
+ "recentchanges-legend-newpage": "{{int:recentchanges-label-newpage}} (Ù\87Ù\85Ú\86Ù\86Û\8cÙ\86 بÙ\87 [[Special:NewPages|Ù\81Ù\87رست صÙ\81Øات تازÙ\87]] نگاه کنید)",
"recentchanges-legend-plusminus": "(<em>±۱۲۳</em>)",
"rcnotefrom": "در زیر تغییرات از <strong>$3, $4</strong> (تا <strong>$1</strong> {{PLURAL:$5|نشان داده شدهاست|نشان داده شدهاند}}).",
- "rclistfrom": "Ù\86Ù\85اÛ\8cØ´ تغÛ\8cÛ\8cرات جدÛ\8cد با شروع از $3 $2",
+ "rclistfrom": "Ù\86Ù\85اÛ\8cØ´ تغÛ\8cÛ\8cرات تازÙ\87 با شروع از $3 $2",
"rcshowhideminor": "$1 ویرایشهای جزئی",
"rcshowhideminor-show": "نمایش",
"rcshowhideminor-hide": "پنهانکردن",
"upload_directory_read_only": "شاخهٔ بارگذاری ($1) از طرف سرور وب قابل نوشتن نیست.",
"uploaderror": "خطای بارگذاری",
"upload-recreate-warning": "'''هشدار: پروندهای با این نام حذف یا منتقل شده است.'''\n\nبرای راحتی، سیاههٔ حذف و انتقال برای این صفحه در زیر آمده است:",
- "uploadtext": "از فرم زیر برای بارگذاری کردن پروندههای جدید استفاده کنید.\nبرای دیدن پروندههایی که قبلاً بارگذاری شدهاند به [[Special:FileList|فهرست پروندهها]] بروید. بارگذاری نیز مجدد در [[Special:Log/upload|سیاههٔ بارگذاریها]] و حذف پروندهها در [[Special:Log/delete|deletion log]] ثبت میشود.\n\nبعد از این که پروندهای را بارگذاری کردید، به این سه شکل میتوانید آن را در صفحهها استفاده کنید:\n*'''<code><nowiki>[[</nowiki>{{ns:file}}<nowiki>:File.jpg]]</nowiki></code>''' برای استفاده از نسخه کامل پرونده\n*'''<code><nowiki>[[</nowiki>{{ns:file}}<nowiki>:File.png|200px|thumb|left|alt text]]</nowiki></code>''' برای استفاده از یک نسخه ۲۰۰ پیکسلی از پرونده درون یک جعبه در سمت چپ متن که عبارت alt text در آن به عنوان توضیح استفاده شده\n*'''<code><nowiki>[[</nowiki>{{ns:media}}<nowiki>:File.ogg]]</nowiki></code>''' برای ایجاد یک پیونده مستقیم به پرونده بدون نمایش پرونده",
+ "uploadtext": "از فرم زیر برای بارگذاری کردن پروندههای جدید استفاده کنید.\nبرای دیدن پروندههایی که قبلاً بارگذاری شدهاند به [[Special:FileList|فهرست پروندهها]] بروید. بارگذاری نیز مجدد در [[Special:Log/upload|سیاههٔ بارگذاریها]] و حذف پروندهها در [[Special:Log/delete|deletion log]] ثبت میشود.\n\nبعد از این که پروندهای را بارگذاری کردید، به این سه شکل میتوانید آن را در صفحات استفاده کنید:\n*'''<code><nowiki>[[</nowiki>{{ns:file}}<nowiki>:File.jpg]]</nowiki></code>''' برای استفاده از نسخه کامل پرونده\n*'''<code><nowiki>[[</nowiki>{{ns:file}}<nowiki>:File.png|200px|thumb|left|alt text]]</nowiki></code>''' برای استفاده از یک نسخه ۲۰۰ پیکسلی از پرونده درون یک جعبه در سمت چپ متن که عبارت alt text در آن به عنوان توضیح استفاده شده\n*'''<code><nowiki>[[</nowiki>{{ns:media}}<nowiki>:File.ogg]]</nowiki></code>''' برای ایجاد یک پیونده مستقیم به پرونده بدون نمایش پرونده",
"upload-permitted": "انواع مجاز پروندهها: $1.",
"upload-preferred": "انواع ترجیحداده شده پروندهها: $1.",
"upload-prohibited": "انواع نامجاز پروندهها: $1.",
"ignorewarning": "چشمپوشی از هشدار و ذخیرهٔ پرونده.",
"ignorewarnings": "چشمپوشی از همهٔ هشدارها",
"minlength1": "نام پرونده دست کم باید یک حرف باشد.",
- "illegalfilename": "نام پرونده «$1» نویسههایی را شامل میشود که در نام صفحهها مجاز نیستند.\nلطفاً نام پرونده را تغییر دهید و آن را دوباره بارگذاری کنید.",
+ "illegalfilename": "نام پرونده «$1» نویسههایی را شامل میشود که در نام صفحات مجاز نیستند.\nلطفاً نام پرونده را تغییر دهید و آن را دوباره بارگذاری کنید.",
"filename-toolong": "نام پرونده نباید از ۲۴۰ بایت طولانیتر باشد.",
"badfilename": "نام پرونده به «$1» تغییر کرد.",
"filetype-mime-mismatch": "پسوند پرونده «$1.» با نوع MIME آن ($2) مطابقت ندارد.",
"listduplicatedfiles-summary": "این فهرست پروندههایی با نسخههای اخیر این پرونده تکراری است که نسخههای اخبر سایر پروندهها است. فقط پروندههای محلی در نظر گرفته شدهاند.",
"listduplicatedfiles-entry": "[[:File:$1|$1]][[$3|{{PLURAL:$2|یک تکرار|$2 تکرار}}]] دارد.",
"unusedtemplates": "الگوهای استفادهنشده",
- "unusedtemplatestext": "این صفحه همهٔ صفحههایی در فضای نام {{ns:template}} را که در هیچ صفحهای به کار نرفتهاند، فهرست میکند.\nبه یاد داشته باشید که پیش از پاککردن این صفحهها پیوندهای دیگر به آنها را هم وارسی کنید.",
+ "unusedtemplatestext": "این صفحه همهٔ صفحاتی در فضای نام {{ns:template}} را که در هیچ صفحهای به کار نرفتهاند، فهرست میکند.\nبه یاد داشته باشید که پیش از پاککردن این صفحات پیوندهای دیگر به آنها را هم وارسی کنید.",
"unusedtemplateswlh": "پیوندهای دیگر",
"randompage": "مقالهٔ تصادفی",
"randompage-nopages": "هیچ صفحهای در این {{PLURAL:$2|فضای نام|فضاهای نام}} موجود نیست: $1.",
"randomredirect": "تغییرمسیر تصادفی",
"randomredirect-nopages": "هیج صفحهٔ تغییرمسیری در فضای نام «$1» موجود نیست.",
"statistics": "آمار",
- "statistics-header-pages": "آمار صفحهها",
+ "statistics-header-pages": "آمار صفحه",
"statistics-header-edits": "آمار ویرایشها",
"statistics-header-views": "آمار بازدیدها",
"statistics-header-users": "آمار کاربران",
"statistics-header-hooks": "آمارهای دیگر",
"statistics-articles": "صفحههای محتوایی",
- "statistics-pages": "صفحهها",
+ "statistics-pages": "صفحات",
"statistics-pages-desc": "تمام صفحههای این ویکی، از جمله صفحههای بحث، تغییرمسیر و غیره",
"statistics-files": "پروندههای بارگذاریشده",
"statistics-edits": "ویرایش صفحهها از هنگامی که {{SITENAME}} راهاندازی شده",
"brokenredirects-edit": "ویرایش",
"brokenredirects-delete": "حذف",
"withoutinterwiki": "صفحههای بدون پیوند میانویکی",
- "withoutinterwiki-summary": "این صفحهها پیوندی به صفحهای به زبان دیگر نمیدارند:",
+ "withoutinterwiki-summary": "این صفحات پیوندی به صفحهای به زبان دیگر نمیدارند:",
"withoutinterwiki-legend": "پیشوند",
"withoutinterwiki-submit": "نمایش",
"fewestrevisions": "مقالههای دارای کمترین شمار ویرایش",
"mostimages": "پروندههایی که بیشتر از همه به آنها پیوند داده شدهاست",
"mostinterwikis": "صفحههای دارای بیشترین میانویکی",
"mostrevisions": "صفحههای دارای بیشترین نسخه",
- "prefixindex": "تمام صفحهها با پیشوند",
+ "prefixindex": "تمام صفحات با پیشوند",
"prefixindex-namespace": "همهٔ صفحههای دارای پیشوند (فضاینام $1)",
"prefixindex-strip": "حذف پیشوند در فهرست",
"shortpages": "صفحههای کوتاه",
"usercreated": "{{GENDER:$3|ایجادشده}} در تاریخ $1 در ساعت $2",
"newpages": "صفحههای تازه",
"newpages-username": "نام کاربری:",
- "ancientpages": "قدیمیترین صفحهها",
+ "ancientpages": "قدیمیترین صفحات",
"move": "انتقال",
"movethispage": "انتقال این صفحه",
"unusedimagestext": "پروندههای زیر موجودند اما در هیچ صفحهای به کار نرفتهاند.\nلطفاً توجه داشته باشید که دیگر وبگاهها ممکن است با یک نشانی اینترنتی مستقیم به یک پرونده پیوند دهند، و با وجود این که در استفادهٔ فعال هستند در این جا فهرست شوند.",
"logempty": "مورد منطبق با منظور شما در سیاهه یافت نشد.",
"log-title-wildcard": "صفحههایی را جستجو کن که عنوانشان با این عبارت آغاز میشود",
"showhideselectedlogentries": "تغییر پدیداری موارد انتخابشده سیاهه",
- "allpages": "همهٔ صفحهها",
+ "allpages": "همهٔ صفحات",
"nextpage": "صفحهٔ بعد ($1)",
"prevpage": "صفحهٔ قبلی ($1)",
- "allpagesfrom": "نمایش صفحهها با شروع از:",
- "allpagesto": "نمایش صفحهها با پایان در:",
- "allarticles": "همهٔ صفحهها",
- "allinnamespace": "همهٔ صفحهها (فضای نام $1)",
+ "allpagesfrom": "نمایش صفحات با شروع از:",
+ "allpagesto": "نمایش صفحات با پایان در:",
+ "allarticles": "همهٔ صفحات",
+ "allinnamespace": "همهٔ صفحات (فضای نام $1)",
"allpagessubmit": "برو",
"allpagesprefix": "نمایش صفحههای دارای پیشوند:",
- "allpagesbadtitle": "عنوان صفحهٔ دادهشده نامعتبر است یا اینکه دارای پیشوندی بینزبانی یا بینویکیای است. ممکن است نویسههایی بدارد که نمیتوان از آنها در عنوان صفحهها استفاده کرد.",
+ "allpagesbadtitle": "عنوان صفحهٔ دادهشده نامعتبر است یا اینکه دارای پیشوندی بینزبانی یا بینویکیای است. ممکن است نویسههایی بدارد که نمیتوان از آنها در عنوان صفحات استفاده کرد.",
"allpages-bad-ns": "{{SITENAME}} دارای فضای نام «$1» نیست.",
"allpages-hide-redirects": "پنهانکردن تغییرمسیرها",
"cachedspecial-viewing-cached-ttl": "شما در حال مشاهدهٔ نسخهای از این صفحه که در میانگیر قرار دارد هستید که ممکن است برای $1 قبل باشد.",
"cachedspecial-viewing-cached-ts": "شما در حال مشاهدهٔ نسخهای از این صفحه که در میانگیر قرار دارد هستید، و این نسخه ممکن است کاملاً واقعی نباشد.",
"cachedspecial-refresh-now": "مشاهده آخرین.",
"categories": "ردهها",
- "categoriespagetext": "{{PLURAL:$1|ردهٔ|ردههای}} زیر دارای صفحهها یا پروندههایی {{PLURAL:$1|است|هستند}}.\n[[Special:UnusedCategories|ردههای استفادهنشده]] در اینجا نمایش داده نشدهاند.\nهمچنین [[Special:WantedCategories|ردههای مورد نیاز]] را ببینید.",
+ "categoriespagetext": "{{PLURAL:$1|ردهٔ|ردههای}} زیر دارای صفحات یا پروندههایی {{PLURAL:$1|است|هستند}}.\n[[Special:UnusedCategories|ردههای استفادهنشده]] در اینجا نمایش داده نشدهاند.\nهمچنین [[Special:WantedCategories|ردههای مورد نیاز]] را ببینید.",
"categoriesfrom": "نمایش ردهها با شروع از:",
"special-categories-sort-count": "مرتب کردن بر اساس تعداد",
"special-categories-sort-abc": "مرتب کردن الفبایی",
"watching": "پیگیری...",
"unwatching": "توقف پیگیری...",
"watcherrortext": "ایرادی در هنگام عوض کردن تنظیمات فهرست پیگیرتان برای «$1» رخ داد.",
- "enotif_reset": "نشانگذاری همهٔ صفحهها بهعنوان بازدیدشده",
+ "enotif_reset": "نشانگذاری همهٔ صفحات بهعنوان بازدیدشده",
"enotif_impersonal_salutation": "کاربر {{SITENAME}}",
"enotif_subject_deleted": "{{SITENAME}} صفحهٔ $1 توسط {{gender:$2|$2}} حذف شد.",
"enotif_subject_created": "{{SITENAME}} صفحهٔ $1 توسط {{gender:$2|$2}} ایجاد شده.",
"deletereasonotherlist": "دلیل دیگر",
"deletereason-dropdown": "*دلایل متداول حذف\n** هرزنگار\n** خرابکاری\n** نقض حق تکثیر\n** درخواست کاربر\n** تغییرمسیر شکسته",
"delete-edit-reasonlist": "ویرایش دلایل حذف",
- "delete-toobig": "این صفحه تاریخچهٔ ویرایشی بزرگی دارد، که شامل بیش از $1 {{PLURAL:$1|نسخه|نسخه}} است.\nبه منظور جلوگیری از اختلال ناخواسته در {{SITENAME}} حذف این گونه صفحهها محدود شدهاست.",
+ "delete-toobig": "این صفحه تاریخچهٔ ویرایشی بزرگی دارد، که شامل بیش از $1 {{PLURAL:$1|نسخه|نسخه}} است.\nبه منظور جلوگیری از اختلال ناخواسته در {{SITENAME}} حذف این گونه صفحات محدود شدهاست.",
"delete-warning-toobig": "این صفحه تاریخچهٔ ویرایشی بزرگی دارد، که شامل بیش از $1 {{PLURAL:$1|نسخه|نسخه}} است.\nحذف آن ممکن است که عملکرد پایگاه دادهٔ {{SITENAME}} را مختل کند;\nبا احتیاط ادامه دهید.",
"deleteprotected": "شما نمیتوانید این صفحه را پاک کنید چون که از آن محافظت شدهاست.",
"deleting-backlinks-warning": "''' هشدار:''' [[Special:WhatLinksHere/{{FULLPAGENAME}}|صفحههای دیگری]] هستند که به صفحهای که شما در حال حذف آن هستید پیوند دارند یا آن را تراگنجانیدهاند.",
"protect_expiry_old": "زمان سرآمدن در گذشتهاست.",
"protect-unchain-permissions": "باز کردن سایر گزینههای محافظت",
"protect-text": "شما میتوانید سطح محافظت صفحهٔ '''$1''' را ببینید و از اینجا آن را تغییر دهید.",
- "protect-locked-blocked": "شما در مدتی که دسترسیتان قطع است نمیتوانید سطح محافظت صفحهها را تغییر دهید.\nتنظیمات فعلی صفحهٔ '''$1''' از این قرار است:",
+ "protect-locked-blocked": "شما در مدتی که دسترسیتان قطع است نمیتوانید سطح محافظت صفحات را تغییر دهید.\nتنظیمات فعلی صفحهٔ '''$1''' از این قرار است:",
"protect-locked-dblock": "به دلیل قفل شدن پایگاه داده، امکان تغییر سطح محافظت صفحه وجود ندارد.\nتنظیمات فعلی صفحهٔ '''$1''' به این قرار است:",
"protect-locked-access": "حساب کاربری شما اجازهٔ تغییر سطح محافظت صفحه را ندارد.\nتنظیمات فعلی صفحهٔ '''$1''' به این قرار است:",
"protect-cascadeon": "این صفحه در حال حاضر محافظت شدهاست زیرا در {{PLURAL:$1|صفحهٔ|صفحههای}} زیر که گزینهٔ محافظت آبشاری {{PLURAL:$1|آن|آنها}} فعال است، گنجانده شده است.\nتغییراتی به سطح محافظت این صفحه به محافظت ابشاری تأثیر نخواهد گذاشت.",
"undelete-header": "برای دیدن صفحههای حذفشدهٔ اخیر [[Special:Log/delete|سیاههٔ حذف]] را ببینید.",
"undelete-search-title": "جستجوی صفحههای حذفشده",
"undelete-search-box": "جستجوی صفحههای حذفشده.",
- "undelete-search-prefix": "نمایش صفحهها با شروع از:",
+ "undelete-search-prefix": "نمایش صفحات با شروع از:",
"undelete-search-submit": "برو",
"undelete-no-results": "هیچ صفحهٔ منطبقی در بایگانی حذفشدهها یافت نشد.",
"undelete-filename-mismatch": "امکان احیای نسخهٔ $1 وجود ندارد: نام پرونده مطابقت نمیکند.",
"ipaddressorusername": "نشانی آیپی یا نام کاربری:",
"ipbexpiry": "زمان سرآمدن:",
"ipbreason": "دلیل:",
- "ipbreason-dropdown": "*دلایل متداول قطع دسترسی\n**واردکردن اطلاعات نادرست\n**پاککردن اطلاعات مفید از صفحهها\n**هرزنگاری از طریق درج مکرر پیوند به وبگاهها\n**درج چرندیات یا نوشتههای بیمعنا در صفحهها\n**تهدید یا ارعاب دیگر کاربران\n**سوء استفاده از چند حساب کاربری\n**نام کاربری نامناسب",
+ "ipbreason-dropdown": "*دلایل متداول قطع دسترسی\n**واردکردن اطلاعات نادرست\n**پاککردن اطلاعات مفید از صفحات\n**هرزنگاری از طریق درج مکرر پیوند به وبگاهها\n**درج چرندیات یا نوشتههای بیمعنا در صفحات\n**تهدید یا ارعاب دیگر کاربران\n**سوء استفاده از چند حساب کاربری\n**نام کاربری نامناسب",
"ipb-hardblock": "جلوگیری از ویرایش کردن کاربران ثبت نام کرده از طریق این نشانی آیپی",
"ipbcreateaccount": "جلوگیری از ایجاد حساب",
"ipbemailban": "جلوگیری از ارسال رایانامه",
"ipbnounblockself": "شما مجاز به باز کردن دسترسی خود نیستید.",
"lockdb": "قفل کردن پایگاه داده",
"unlockdb": "از قفل در آوردن پایگاه داده",
- "lockdbtext": "قفل کردن پایگاه داده امکان ویرایش صفحهها، تغییر تنظیمات، ویرایش پیگیریها، و سایر تغییراتی را که نیازمند تغییری در پایگاه داده است، از همهٔ کاربران سلب میکند.\nلطفاً تأیید کنید که همین کار را میخواهید انجام دهید، و در اولین فرصت پایگاه داده را از حالت قفل شده خارج خواهید کرد.",
- "unlockdbtext": "از قفل در آوردن پایگاه داده به تمامی کاربران اجازه میدهد که توانایی ویرایش صفحهها، تغییر تنظیمات، تغییر پیگیریها و هر تغییر دیگری که نیازمند تغییر در پایگاه داده باشد را دوباره به دست بیاورند.\nلطفاً تأیید کنید که همین کار را میخواهید انجام دهید.",
+ "lockdbtext": "قفل کردن پایگاه داده امکان ویرایش صفحات، تغییر تنظیمات، ویرایش پیگیریها، و سایر تغییراتی را که نیازمند تغییری در پایگاه داده است، از همهٔ کاربران سلب میکند.\nلطفاً تأیید کنید که همین کار را میخواهید انجام دهید، و در اولین فرصت پایگاه داده را از حالت قفل شده خارج خواهید کرد.",
+ "unlockdbtext": "از قفل در آوردن پایگاه داده به تمامی کاربران اجازه میدهد که توانایی ویرایش صفحات، تغییر تنظیمات، تغییر پیگیریها و هر تغییر دیگری که نیازمند تغییر در پایگاه داده باشد را دوباره به دست بیاورند.\nلطفاً تأیید کنید که همین کار را میخواهید انجام دهید.",
"lockconfirm": "بله، من جداً میخواهم پایگاه داده را قفل کنم.",
"unlockconfirm": "بله، من جداً میخواهم پایگاه داده را از قفل در آورم.",
"lockbtn": "قفل کردن پایگاه داده",
"lockedbyandtime": "(به وسیلهٔ $1 در $2 ساعت $3)",
"move-page": "انتقال $1",
"move-page-legend": "انتقال صفحه",
- "movepagetext": "با استفاده از فرم زیر نام صفحه تغییر خواهد کرد، و تمام تاریخچهاش به نام جدید منتقل خواهد شد.\nعنوان قدیمی تبدیل به یک صفحهٔ تغییرمسیر به عنوان جدید خواهد شد.\nشما میتوانید تغییرمسیرهایی که به عنوان اصلی اشاره دارند را به صورت خودکار بهروزرسانی کنید.\nپیوندهای که به عنوان صفحهٔ قدیمی وجود دارند، تغییر نخواهند کرد؛ حتماً تغییرمسیرهای [[Special:DoubleRedirects|دوتایی]] یا [[Special:BrokenRedirects|خراب]] را بررسی کنید.\n'''شما''' مسئول اطمینان از این هستید که پیوندها هنوز به همانجایی که قرار است بروند.\n\nتوجه کنید که اگر از قبل صفحهای در عنوان جدید وجود داشته باشد صفحه منتقل '''نخواهد شد'''،\nمگر این آخرین ویرایش تغییرمسیر باشد و در تاریخچهٔ ویرایشی نداشته باشد.\nاین یعنی اگر اشتباه کردید میتوانید صفحه را به همان جایی که از آن منتقل شده بود برگردانید، و این که نمیتوانید روی صفحهها موجود بنویسید.\n\n'''هشدار!'''\nانتقال صفحهها به نام جدید ممکن است تغییر اساسی و غیرمنتظرهای برای صفحههای محبوب باشد؛\nلطفاً مطمئن شوید که قبل از انتقال دادن صفحه، عواقب این کار را درک میکنید.",
+ "movepagetext": "با استفاده از فرم زیر نام صفحه تغییر خواهد کرد، و تمام تاریخچهاش به نام جدید منتقل خواهد شد.\nعنوان قدیمی تبدیل به یک صفحهٔ تغییرمسیر به عنوان جدید خواهد شد.\nشما میتوانید تغییرمسیرهایی که به عنوان اصلی اشاره دارند را به صورت خودکار بهروزرسانی کنید.\nپیوندهای که به عنوان صفحهٔ قدیمی وجود دارند، تغییر نخواهند کرد؛ حتماً تغییرمسیرهای [[Special:DoubleRedirects|دوتایی]] یا [[Special:BrokenRedirects|خراب]] را بررسی کنید.\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لطفاً پیش از انتقال مطمئن شوید از نتیجهٔ کار آگاهید.",
"movepagetalktext": "صفحهٔ بحث مربوط، اگر وجود داشته باشد، بطور خودکار همراه با مقالهٔ اصلی منتقل خواهد شد '''مگر اینکه''' :\n* در حال انتقال صفحه از این فضای نام به فضای نام دیگری باشید،\n* یک صفحهٔ بحث غیرخالی تحت این نام جدید وجود داشته باشد، یا\n* جعبهٔ زیر را تیک نزده باشید.\n\nدر این حالات، باید صفحه را بطور دستی انتقال داده و یا محتویات دو صفحه را با ویرایش ادغام کنید.",
"movearticle": "انتقال صفحه:",
"moveuserpage-warning": "'''هشدار:''' شما در حال انتقال دادن یک صفحهٔ کاربر هستید. توجه داشته باشید که تنها صفحه منتقل میشود و نام کاربر تغییر '''نمییابد'''.",
"movecategorypage-warning": "<strong>هشدار:</strong> شما در حال انتقال صفحه رده هستید. لطفاً توجه داشته باشید که فقط صفحه منتقل خواهد شد و صفحات در رده قدیمی میمانند و به رده جدید <em>نمیروند</em>.",
- "movenologintext": "برای انتقال صفحهها باید کاربر ثبتشده بوده و [[Special:UserLogin|به سامانه وارد شوید]].",
- "movenotallowed": "شما اجازهٔ انتقال دادن صفحهها را ندارید.",
+ "movenologintext": "برای انتقال صفحات باید کاربر ثبتشده بوده و [[Special:UserLogin|به سامانه وارد شوید]].",
+ "movenotallowed": "شما اجازهٔ انتقال دادن صفحات را ندارید.",
"movenotallowedfile": "شما اجازهٔ انتقال پروندهها را ندارید.",
"cant-move-user-page": "شما اجازه ندارید صفحههای کاربری سرشاخه را انتقال دهید.",
"cant-move-to-user-page": "شما اجازه ندارید که یک صفحه را به یک صفحهٔ کاربر انتقال دهید (به استثنای زیر صفحههای کاربری).",
"cant-move-category-page": "شما اجازهٔ انتقال دادن صفحهٔ ردهها را ندارید.",
"cant-move-to-category-page": "شما مجوز برای انتقال صفحه به صفحه رده ندارید.",
- "newtitle": "بهعنوان جدید",
+ "newtitle": "به عنوان تازه:",
"move-watch": "پیگیری صفحههای مبدأ و مقصد",
"movepagebtn": "صفحه منتقل شود",
"pagemovedsub": "انتقال با موفقیت انجام شد",
"movepage-page-unmoved": "صفحهٔ $1 را نمیتوان به $2 انتقال داد.",
"movepage-max-pages": "حداکثر تعداد صفحههای ممکن ($1 {{PLURAL:$1|صفحه|صفحه}}) که میتوان انتقال داد منتقل شدند و صفحههای دیگر را نمیتوان به طور خودکار منتقل کرد.",
"movelogpage": "سیاههٔ انتقال",
- "movelogpagetext": "در زیر فهرستی از انتقال صفحهها آمده است.",
+ "movelogpagetext": "در زیر فهرستی از انتقال صفحات آمدهاست.",
"movesubpage": "{{PLURAL:$1|زیرصفحه|زیرصفحهها}}",
"movesubpagetext": "این صفحه $1 زیرصفحه دارد که در زیر نمایش {{PLURAL:$1|یافتهاست|یافتهاند}}.",
"movenosubpage": "این صفحه هیچ زیرصفحهای ندارد.",
"bad-target-model": "مقصد مورد نظر از مدل محتوایی متفاوتی استفاده میکند. تبدیل $1 به $2 ممکن نیست.",
"imagenocrossnamespace": "امکان انتقال تصویر به فضای نام غیر پرونده وجود ندارد",
"nonfile-cannot-move-to-file": "امکان انتقال محتوای غیر پرونده به فضای نام پرونده وجود ندارد",
- "imagetypemismatch": "پسÙ\88Ù\86د پرÙ\88Ù\86دÙ\87 جدÛ\8cد با نوع آن سازگار نیست",
+ "imagetypemismatch": "پسÙ\88Ù\86د پرÙ\88Ù\86دÙ\87 تازÙ\87 با نوع آن سازگار نیست",
"imageinvalidfilename": "نام پروندهٔ هدف نامجاز است",
"fix-double-redirects": "به روز کردن تمامی تغییرمسیرهایی که به مقالهٔ اصلی اشاره میکنند",
"move-leave-redirect": "بر جا گذاشتن یک تغییرمسیر",
"semiprotectedpagemovewarning": "'''تذکر:''' این صفحه قفل شدهاست به طوری که تنها کاربران ثبت نام کرده میتوانند آن را انتقال دهند.\nآخرین موارد سیاهه در زیر آمده است:",
"move-over-sharedrepo": "== پرونده موجود است ==\n[[:$1]] در یک مخزن مشترک وجود دارد. انتقال یک پرونده به این نام باعث باطل شدن پرونده مشترک خواهد شد.",
"file-exists-sharedrepo": "نام پرونده انتخاب شده از قبل در یک مخزن مشترک استفاده شدهاست.\nلطفاً یک نام دیگر برگزینید.",
- "export": "برونبری صفحهها",
- "exporttext": "شما میتوانید متن و تاریخچهٔ ویرایش یک صفحهٔ مشخص یا مجموعهای از صفحهها را به شکل پوشیده در اکسامال برونبری کنید.\nاین اطلاعات را میتوان در ویکی دیگری که نرمافزار «مدیاویکی» را اجرا میکند از طریق [[Special:Import|صفحهٔ درونریزی]] وارد کرد.\n\nبرای برونبری صفحهها، عنوان آنها را در جعبهٔ زیر وارد کنید (در هر سطر فقط یک عنوان) و مشخص کنید که آیا نسخهٔ اخیر صفحه را به همراه نسخههای قدیمیتر و تاریخچهٔ صفحه میخواهید، یا تنها نسخهٔ اخیر صفحه و اطلاعات آخرین ویرایش را میخواهید.\n\nدر حالت دوم، شما میتوانید از یک پیوند استفاده کنید، مثلاً [[{{#Special:Export}}/{{MediaWiki:Mainpage}}]] برای صفحهٔ «[[{{MediaWiki:Mainpage}}]]».",
- "exportall": "برونبری همهٔ صفحهها",
+ "export": "برونبری صفحات",
+ "exporttext": "شما میتوانید متن و تاریخچهٔ ویرایش یک صفحهٔ مشخص یا مجموعهای از صفحات را به شکل پوشیده در اکسامال برونبری کنید.\nاین اطلاعات را میتوان در ویکی دیگری که نرمافزار «مدیاویکی» را اجرا میکند از طریق [[Special:Import|صفحهٔ درونریزی]] وارد کرد.\n\nبرای برونبری صفحات، عنوان آنها را در جعبهٔ زیر وارد کنید (در هر سطر فقط یک عنوان) و مشخص کنید که آیا نسخهٔ اخیر صفحه را به همراه نسخههای قدیمیتر و تاریخچهٔ صفحه میخواهید، یا تنها نسخهٔ اخیر صفحه و اطلاعات آخرین ویرایش را میخواهید.\n\nدر حالت دوم، شما میتوانید از یک پیوند استفاده کنید، مثلاً [[{{#Special:Export}}/{{MediaWiki:Mainpage}}]] برای صفحهٔ «[[{{MediaWiki:Mainpage}}]]».",
+ "exportall": "برونبری همهٔ صفحات",
"exportcuronly": "فقط نسخهٔ فعلی شامل شود، نه کل تاریخچه",
- "exportnohistory": "----\n'''توجه:''' امکان برونبری تاریخچهٔ کامل صفحهها از طریق این صفحه به دلایل اجرایی از کار انداخته شدهاست.",
+ "exportnohistory": "----\n'''توجه:''' امکان برونبری تاریخچهٔ کامل صفحات از طریق این صفحه به دلایل اجرایی از کار انداخته شدهاست.",
"exportlistauthors": "شامل فهرست کامل مشارکتکنندگان هر صفحه",
"export-submit": "برونبری",
- "export-addcattext": "افزودن صفحهها از رده:",
+ "export-addcattext": "افزودن صفحات از رده:",
"export-addcat": "افزودن",
- "export-addnstext": "افزودن صفحهها از فضای نام:",
+ "export-addnstext": "افزودن صفحات از فضای نام:",
"export-addns": "افزودن",
"export-download": "ذخیره به صورت پرونده",
"export-templates": "شامل شدن الگوها",
"thumbnail_gd-library": "تنظیمات ناقص کتابخانهٔ GD: عملکرد $1 وجود ندارد",
"thumbnail_image-missing": "پرونده به نظر گم شدهاست: $1",
"thumbnail_image-failure-limit": "تلاشهای ناموفق اخیر بسیاری ($1 یا بیشتر) برای ارائهٔ این تصویر کوچک وجود داشته است. لطفأ بعداً دوباره تلاش کنید.",
- "import": "درونریزی صفحهها",
+ "import": "درونریزی صفحات",
"importinterwiki": "درونریزی تراویکی",
- "import-interwiki-text": "یک ویکی و یک نام صفحه را انتخاب کنید تا اطلاعات از آن درونریزی شود.\nتاریخ نسخهها و نام ویرایشکنندگان ثابت خواهد ماند.\nاطلاعات مربوط به درونریزی صفحهها در [[Special:Log/import|سیاههٔ درونریزیها]] درج خواهد شد.",
+ "import-interwiki-text": "یک ویکی و یک نام صفحه را انتخاب کنید تا اطلاعات از آن درونریزی شود.\nتاریخ نسخهها و نام ویرایشکنندگان ثابت خواهد ماند.\nاطلاعات مربوط به درونریزی صفحات در [[Special:Log/import|سیاههٔ درونریزیها]] درج خواهد شد.",
"import-interwiki-sourcewiki": "ویکی منبع:",
"import-interwiki-sourcepage": "صفحهٔ مبدأ:",
"import-interwiki-history": "تمام نسخههای تاریخچهٔ این صفحه انتقال داده شود",
"import-upload-filename": "نام پرونده:",
"import-comment": "توضیح:",
"importtext": "لطفاً پرونده را از ویکی منبع با کمک [[Special:Export|ابزار برونبری]] دریافت کنید.\nسپس آن را روی دستگاهتان ذخیره کنید و اینجا بارگذاری نمایید.",
- "importstart": "در حال درونریزی صفحهها...",
+ "importstart": "در حال درونریزی صفحات...",
"import-revision-count": "$1 {{PLURAL:$1|ویرایش|ویرایش}}",
"importnopages": "صفحهای برای درونریزی نیست.",
"imported-log-entries": "$1 {{PLURAL:$1|مورد سیاهه|مورد سیاهه}} درون ریزی شد.",
- "importfailed": "درونریزی صفحهها شکست خورد: <nowiki>$1</nowiki>",
+ "importfailed": "درونریزی صفحات شکست خورد: <nowiki>$1</nowiki>",
"importunknownsource": "نوع مأخذ درونریزی معلوم نیست",
- "importcantopen": "پروندهٔ درونریزی صفحهها باز نشد",
+ "importcantopen": "پروندهٔ درونریزی صفحات باز نشد",
"importbadinterwiki": "پیوند میانویکی نادرست",
"importsuccess": "درونریزی با موفقیت انجام شد!",
"importnosources": "هیچ منبعی برای درونریزی اطلاعات از ویکی دیگر تعریف نشدهاست.",
"import-rootpage-invalid": "با توجه به ریشه صفحه عنوان نامعتبر است.",
"import-rootpage-nosubpage": "فضای نام \"$1\" صفحهٔ مبنا اجازهٔ زیرصفحه نمیدهد.",
"importlogpage": "سیاههٔ درونریزیها",
- "importlogpagetext": "درونریزی صفحهها به همراه تاریخچهٔ ویرایش آنها از ویکیهای دیگر.",
+ "importlogpagetext": "درونریزی صفحات به همراه تاریخچهٔ ویرایش آنها از ویکیهای دیگر.",
"import-logentry-upload": "[[$1]] را از طریق بارگذاری پرونده درونریزی کرد",
"import-logentry-upload-detail": "$1 {{PLURAL:$1|نسخه|نسخه}} واردشده",
"import-logentry-interwiki": "$1 را تراویکی کرد",
"tooltip-ca-unwatch": "حذف این صفحه از فهرست پیگیریهایتان",
"tooltip-search": "جستجو در {{SITENAME}}",
"tooltip-search-go": "در صورت امکان به صفحهای با همین نام برو",
- "tooltip-search-fulltext": "جستجوی این عبارت در صفحهها",
+ "tooltip-search-fulltext": "جستجوی این عبارت در صفحات",
"tooltip-p-logo": "مشاهدهٔ صفحهٔ اصلی",
"tooltip-n-mainpage": "مشاهدهٔ صفحهٔ اصلی",
"tooltip-n-mainpage-description": "مشاهدهٔ صفحهٔ اصلی",
"creditspage": "اعتبارات این صفحه",
"nocredits": "اطلاعات سازندگان این صفحه موجود نیست.",
"spamprotectiontitle": "پالایهٔ هرزنگاریها",
- "spamprotectiontext": "از ذخÛ\8cرÙ\87 کردÙ\86 صÙ\81ØÙ\87 تÙ\88سط پاÙ\84اÛ\8cÙ\87Ù\94 Ù\87رزÙ\86گارÛ\8câ\80\8cÙ\87ا جÙ\84Ù\88Ú¯Û\8cرÛ\8c شد.\nÙ\85عÙ\85Ù\88Ù\84اÙ\8b اÛ\8cÙ\86 اتÙ\81اÙ\82 زÙ\85اÙ\86Û\8c Ù\85Û\8câ\80\8cاÙ\81تد Ú©Ù\87 Ù\85تÙ\86 جدÛ\8cد صفحه، حاوی پیوندی به یک نشانی وب باشد که در فهرست سیاه قرار دارد.",
+ "spamprotectiontext": "از ذخÛ\8cرÙ\87 کردÙ\86 صÙ\81ØÙ\87 تÙ\88سط پاÙ\84اÛ\8cÙ\87Ù\94 Ù\87رزÙ\86گارÛ\8câ\80\8cÙ\87ا جÙ\84Ù\88Ú¯Û\8cرÛ\8c شد.\nÙ\85عÙ\85Ù\88Ù\84اÙ\8b اÛ\8cÙ\86 اتÙ\81اÙ\82 زÙ\85اÙ\86Û\8c Ù\85Û\8câ\80\8cاÙ\81تد Ú©Ù\87 Ù\85تÙ\86 تازÙ\87 صفحه، حاوی پیوندی به یک نشانی وب باشد که در فهرست سیاه قرار دارد.",
"spamprotectionmatch": "متن زیر چیزیاست که پالایهٔ هرزهنگاری ما را به کارانداخت: $1",
"spambot_username": "هرزهتمیزکارِ مدیاویکی",
"spam_reverting": "واگردانی به آخرین نسخهای که پیوندی به $1 ندارد.",
"pageinfo-protect-cascading-yes": "بله",
"pageinfo-protect-cascading-from": "محافظت آبشاری از",
"pageinfo-category-info": "اطلاعات رده",
- "pageinfo-category-pages": "تعداد صفحهها",
+ "pageinfo-category-pages": "تعداد صفحات",
"pageinfo-category-subcats": "تعداد زیرردهها",
"pageinfo-category-files": "تعداد پروندهها",
"markaspatrolleddiff": "برچسب گشت بزن",
"autosumm-blank": "صفحه را خالی کرد",
"autosumm-replace": "جایگزینی صفحه با '$1'",
"autoredircomment": "تغییرمسیر به [[$1]]",
- "autosumm-new": "صÙ\81ØÙ\87â\80\8cاÛ\8c جدÛ\8cد حاوی «$1» ایجاد کرد",
+ "autosumm-new": "صÙ\81ØÙ\87â\80\8cاÛ\8c تازÙ\87 حاوی «$1» ایجاد کرد",
"autosumm-newblank": "ایجاد صفحه خالی",
"size-bytes": "$1 بایت",
"size-kilobytes": "$1 کیلوبایت",
"specialpages-group-media": "گزارش بارگذاری رسانهها",
"specialpages-group-users": "کاربرها و دسترسیها",
"specialpages-group-highuse": "صفحههای پربازدید",
- "specialpages-group-pages": "فهرستهای صفحهها",
- "specialpages-group-pagetools": "ابزارهای صفحهها",
+ "specialpages-group-pages": "فهرستهای صفحات",
+ "specialpages-group-pagetools": "ابزارهای صفحات",
"specialpages-group-wiki": "داده و ابزارها",
"specialpages-group-redirects": "صفحههای ویژهٔ تغییرمسیر دهنده",
"specialpages-group-spam": "ابزارهای هرزنگاری",
"tags-active-no": "خیر",
"tags-edit": "ویرایش",
"tags-hitcount": "$1 {{PLURAL:$1|تغییر|تغییر}}",
- "comparepages": "مقایسهٔ صفحهها",
+ "comparepages": "مقایسهٔ صفحات",
"compare-page1": "صفحهٔ ۱",
"compare-page2": "صفحهٔ ۲",
"compare-rev1": "نسخهٔ ۱",
"logentry-rights-rights-legacy": "$1 گروه عضویت $3 را {{GENDER:$2|تغییر داد}}",
"logentry-rights-autopromote": "$1 به طور خودکار از $4 به $5 {{GENDER:$2|ارتقاء داد}}",
"logentry-upload-upload": "$1 {{GENDER:$2|بارگذاری کرد}} $3",
- "logentry-upload-overwrite": "$1 Û\8cÚ© Ù\86سخÙ\87Ù\94 جدÛ\8cد {{GENDER:$2|بارگذاریکرد}} $3",
+ "logentry-upload-overwrite": "$1 Û\8cÚ© Ù\86سخÙ\87Ù\94 تازÙ\87 {{GENDER:$2|بارگذاریکرد}} $3",
"logentry-upload-revert": "$1 {{GENDER:$2|بارگذاری کرد}} $3",
"rightsnone": "(هیچ)",
"feedback-bugornote": "اگر آمادهاید تا مشکلی فنی را با جزئیاتش شرح دهید لطفاً [$1 یک ایراد گزارش دهید]. در غیر این صورت میتوانید از فرم سادهٔ زیر استفاده کنید. نظر شما به همراه نام کاربری و مرورگرتان به صفحهٔ «[$3 $2]» افزوده خواهد شد.",
"feedback-thanks": "سپاس! بازخورد شما در صفحهٔ «[$1 $2]» ثبت شد.",
"feedback-close": "انجام شد",
"feedback-bugcheck": "عالیاست! فقط بررسی کنید که از [$1 ایرادهای شناختهشده] نباشد.",
- "feedback-bugnew": "بررسÛ\8c کردÙ\85. اÛ\8cرادÛ\8c جدÛ\8cد را گزارش بده",
+ "feedback-bugnew": "بررسÛ\8c کردÙ\85. اÛ\8cرادÛ\8c تازÙ\87 را گزارش بده",
"searchsuggest-search": "جستجو",
"searchsuggest-containing": "صفحههای دربردارنده...",
"api-error-badaccess-groups": "شما اجازهٔ بارگذاری پروندهها را در این ویکی ندارید.",
"showpreview": "Prévisualiser",
"showdiff": "Voir les modifications",
"blankarticle": "<strong>Attention :</strong> La page que vous créez est vide.\nSi vous cliquez de nouveau sur « {{int:savearticle}} », la page sera créée sans aucun contenu.",
- "anoneditwarning": "<strong>Attention :</strong> Vous n’êtes pas identifié(e). Votre adresse IP sera enregistrée dans l’historique de cette page.",
+ "anoneditwarning": "<strong>Attention :</strong> Vous n’êtes pas connecté. Votre adresse IP sera visible de tout le monde si vous faites des modifications. Si vous <strong>[$1 vous connectez]</strong> ou <strong>[$2 créez un compte]</strong>, vos modifications seront attribuées à votre nom d’utilisateur, entre autres avantages.",
"anonpreviewwarning": "''Vous n’êtes pas identifié(e). Sauvegarder enregistrera votre adresse IP dans l’historique des modifications de la page.''",
"missingsummary": "'''Rappel :''' vous n'avez pas encore fourni le résumé de votre modification.\nSi vous cliquez de nouveau sur le bouton « {{int:savearticle}} », la publication sera faite sans nouvel avertissement.",
"missingcommenttext": "Veuillez entrer un commentaire ci-dessous.",
"emailuser-title-notarget": "Envoyer un courriel à l'utilisateur",
"emailpage": "Envoyer un courriel à l'utilisateur",
"emailpagetext": "Vous pouvez utiliser le formulaire ci-dessous pour envoyer un courriel à {{GENDER:$1|cet utilisateur|cette utilisatrice}}.\nL'adresse électronique que vous avez indiquée dans [[Special:Preferences|vos préférences]] apparaîtra dans le champ « Expéditeur » de votre message ; ainsi, le destinataire pourra vous répondre directement.",
- "defemailsubject": "{{SITENAME}} Courriel de l'utilisateur « $1 »",
+ "defemailsubject": "Courriel de {{SITENAME}} de l'utilisateur « $1 »",
"usermaildisabled": "L'envoi de courriels entre utilisateurs est désactivé",
"usermaildisabledtext": "Vous ne pouvez pas envoyer de courriels à d'autres utilisateurs sur ce wiki",
"noemailtitle": "Aucune adresse de courriel",
"showpreview": "תצוגה מקדימה",
"showdiff": "הצגת שינויים",
"blankarticle": "<strong>אזהרה:</strong> הדף שאתם יוצרים הוא ריק.\nאם תלחצו שוב על \"{{int:savearticle}}\", הדף ייווצר ללא תוכן.",
- "anoneditwarning": "'''אזהרה:''' אינכם מחוברים לחשבון. כתובת ה־IP שלכם תירשם בהיסטוריית העריכות של הדף.",
+ "anoneditwarning": "<strong>אזהרה:</strong> אינכם מחוברים לחשבון. כתובת ה־IP שלכם תוצג בפומבי אם תבצעו עריכות כלשהן. אם <strong>[$1 תיכנסו לחשבון]</strong> או <strong>[$2 תיצרו חשבון]</strong>, העריכות שלכם תיוחסנה לשם המשתמש שלכם ותקבלו גם יתרונות אחרים.",
"anonpreviewwarning": "''אינכם מחוברים לחשבון. שמירה תגרום לכתובת ה־IP שלכם להירשם בהיסטוריית העריכות של הדף.''",
"missingsummary": "'''תזכורת:''' לא הזנתם תקציר עריכה.\nאם תלחצו שוב על הכפתור \"{{int:savearticle}}\", עריכתכם תישמר בלעדיו.",
"missingcommenttext": "אנא הקלידו את ההודעה למטה.",
"hidetoc": "छुपाएँ",
"collapsible-collapse": "छोटा करें",
"collapsible-expand": "विस्तार करें",
+ "confirmable-confirm": "क्या {{GENDER:$1|आप}} निश्चित हो?",
+ "confirmable-yes": "हाँ",
+ "confirmable-no": "नहीं",
"thisisdeleted": "$1 देखें या वापिस लाएँ?",
"viewdeleted": "$1 दिखायें?",
"restorelink": "{{PLURAL:$1|एक हटाया हुआ|$1 हटाये हुए}} बदलाव",
"confirmemail_invalid": "Pogrešna potvrda. Kôd je možda istekao.",
"confirmemail_needlogin": "Molimo $1 kako biste potvrdili Vašu e-mail adresu.",
"confirmemail_success": "Vaša je e-mail adresa potvrđena. Možete se prijaviti i uživati u wikiju.",
- "confirmemail_loggedin": "Vaša je e-mail adresa potvrđena.",
+ "confirmemail_loggedin": "Vaša je adresa e-pošte potvrđena.",
"confirmemail_subject": "{{SITENAME}}: potvrda e-mail adrese",
"confirmemail_body": "Netko, vjerojatno Vi, s IP adrese $1 otvorio je\nsuradnički račun pod imenom \"$2\" s ovom adresom e-pošte na {{SITENAME}}.\n\nKako biste potvrdili da je ovaj suradnički račun uistinu Vaš i\nomogućili funkcije e-pošte na {{SITENAME}}, otvorite u Vašem\npregledniku sljedeću poveznicu:\n\n$3\n\nAko to *niste* Vi, slijedite ovu poveznicu za poništavanje potvrde:\n\n$5\n\nValjanost ovog potvrdnog kȏda istječe na $4.",
"confirmemail_body_changed": "Netko, vjerojatno Vi, s IP adrese $1,\npromijenio je adresu e-pošte suradničkog računa \"$2\" u ovu adresu na {{SITENAME}}.\n\nKako biste potvrdili da je ovaj suradnički račun uistinu Vaš te uključili\nmogućnosti e-pošte na {{SITENAME}}, otvorite u Vašem pregledniku sljedeću poveznicu:\n\n$3\n\nUkoliko suradnički račun *ne* pripada Vama, slijedite ovu poveznicu\nza poništavanje potvrde adrese e-pošte:\n\n$5\n\nValjanost ovog potvrdnog koda istječe $4.",
"userlogin-resetlink": "Elfelejtetted a bejelentkezési adataidat?",
"userlogin-resetpassword-link": "Elfelejtetted a jelszavad?",
"userlogin-helplink2": "Segítség a bejelentkezéshez",
- "userlogin-loggedin": "Már be vagy jelentkezve mint {{GENDER:$1|$1}}. Ha más néven akarsz belépni, alább megteheted.",
- "userlogin-createanother": "Felhasználói fiók létrehozása",
"createacct-emailrequired": "E-mail cím",
"createacct-emailoptional": "E-mail cím (opcionális)",
"createacct-email-ph": "Add meg e-mail címed",
"preferences": "Beállítások",
"mypreferences": "Beállítások",
"prefs-edits": "Szerkesztéseid száma:",
- "prefsnologintext2": "Kérjük jelentkezzen be a beállítások módosításához.",
+ "prefsnologintext2": "Kérjük, jelentkezz be a beállítások módosításához.",
"prefs-skin": "Felület",
"skin-preview": "előnézet",
"datedefault": "Nincs beállítás",
"right-editmyusercss": "A saját szerkesztői CSS-fájlok szerkesztése",
"right-editmyuserjs": "Saját szerkesztői JavaScript-fájlok szerkesztése",
"right-viewmywatchlist": "Saját figyelőlista megtekintése",
+ "right-editmywatchlist": "Saját figyelőlista szerkesztése. Bizonyos műveletek képesek lapok figyelőlistához adására ezen jog nélkül is.",
+ "right-viewmyprivateinfo": "Saját személyes adatok megtekintése (pl. e-mailcím, valódi név)",
+ "right-editmyprivateinfo": "Saját személyes adatok szerkesztése (pl. e-mailcím, valódi név)",
"right-editmyoptions": "Saját beállítások szerkesztése",
"right-rollback": "a lap utolsó szerkesztésének gyors visszaállítása",
"right-markbotedits": "visszaállított szerkesztések botként való jelölése",
"passwordreset-domain": "Dominio:",
"passwordreset-capture": "Visualizzare il contenuto del messaggio e-mail?",
"passwordreset-capture-help": "Se si seleziona questa casella, l'indirizzo e-mail (con la password temporanea), verrà mostrato a voi, oltre ad essere inviato all'utente.",
- "passwordreset-email": "Indirizzo e-mail:",
+ "passwordreset-email": "Indirizzo email:",
"passwordreset-emailtitle": "Dettagli dell'utente su {{SITENAME}}",
"passwordreset-emailtext-ip": "Qualcuno (probabilmente tu, con indirizzo IP $1) ha richiesto l'invio di una nuova password per l'accesso a {{SITENAME}} ($4). {{PLURAL:$3|L'utente associato|Gli utenti associati}} a questo indirizzo email sono:\n\n$2\n\n{{PLURAL:$3|Questa password temporanea scadrà|Queste password temporanee scadranno}} dopo {{PLURAL:$5|un giorno|$5 giorni}}.\nDovresti accedere e scegliere una nuova password ora. \n\nSe non sei stato tu a fare la richiesta, o se ti sei ricordato la password originale e non vuoi più cambiarla, puoi ignorare questo messaggio e continuare al utilizzare la tua vecchia password.",
"passwordreset-emailtext-user": "L'utente $1 di {{SITENAME}} ha richiesto l'invio di una nuova password per l'accesso a {{SITENAME}} ($4). {{PLURAL:$3|L'utente associato|Gli utenti associati}} a questo indirizzo email sono:\n\n$2\n\n{{PLURAL:$3|Questa password temporanea scadrà|Queste password temporanee scadranno}} dopo {{PLURAL:$5|un giorno|$5 giorni}}.\nDovresti accedere e scegliere una nuova password ora. \n\nSe non sei stato tu a fare la richiesta, o se ti sei ricordato la password originale e non vuoi più cambiarla, puoi ignorare questo messaggio e continuare al utilizzare la tua vecchia password.",
"showpreview": "Visualizza anteprima",
"showdiff": "Mostra modifiche",
"blankarticle": "<strong>Attenzione:</strong> la pagina che stai creando è vuota.\nCliccando nuovamente su \"{{int:savearticle}}\", la pagina sarà creata senza alcun contenuto.",
- "anoneditwarning": "'''Attenzione:''' Accesso non effettuato. Nella cronologia della pagina verrà registrato il tuo indirizzo IP.",
+ "anoneditwarning": "<strong>Attenzione:</strong> Accesso non effettuato. Se effettuerai delle modifiche il tuo indirizzo IP sarà visibile pubblicamente. Se <strong>[$1 accedi]</strong> o <strong>[$2 crei un'utenza]</strong>, le tue modifiche saranno attribuite al tuo nome utente, insieme ad altri benefici.",
"anonpreviewwarning": "''Non è stato eseguito il login. Salvando la pagina, il proprio indirizzo IP sarà registrato nella cronologia.''",
"missingsummary": "'''Attenzione:''' non è stato specificato l'oggetto di questa modifica. Premendo di nuovo \"{{int:savearticle}}\" la modifica verrà salvata con l'oggetto vuoto.",
"missingcommenttext": "Inserire un commento qui sotto.",
"mergehistory-empty": "Nessuna versione da unire.",
"mergehistory-success": "{{PLURAL:$3|Una versione di [[:$1]] è stata unita|$3 versioni di [[:$1]] sono state unite}} alla cronologia di [[:$2]].",
"mergehistory-fail": "Impossibile unire le cronologie. Verificare la pagina e i parametri temporali.",
- "mergehistory-fail-toobig": "Impossibile eseguire l'unione della cronologia con oltre $1 {{PLURAL:$1|revisione|revisioni}} da spostare.",
+ "mergehistory-fail-toobig": "Impossibile eseguire l'unione della cronologia essendoci oltre $1 {{PLURAL:$1|versione|versioni}} da spostare.",
"mergehistory-no-source": "La pagina di origine $1 non esiste.",
"mergehistory-no-destination": "La pagina di destinazione $1 non esiste.",
"mergehistory-invalid-source": "La pagina di origine deve avere un titolo corretto.",
"userlogin-resetlink": "ავტორიზაციის მონაცემები დაგავიწყდათ?",
"userlogin-resetpassword-link": "დაგავიწყდათ პაროლი?",
"userlogin-helplink2": "დახმარება:შესვლა",
- "userlogin-createanother": "სხვა ანგარიშის შექმნა",
"createacct-emailrequired": "ელ. ფოსტის მისამართი",
"createacct-emailoptional": "ელ. ფოსტის მისამართი (არასავალდებულო)",
"createacct-email-ph": "შეიყვანეთ თქვენი ელ. ფოსტის მისამართი",
"userlogin-resetlink": "Си ги заборавивте податоците за најава?",
"userlogin-resetpassword-link": "Ја заборавивте лозинката?",
"userlogin-helplink2": "Помош за најава",
- "userlogin-loggedin": "Веќе сте најавени како {{GENDER:$1|$1}}.\nСо образецот подолу можете да се најавите како друг корисник.",
- "userlogin-createanother": "Направи нова сметка",
"createacct-emailrequired": "Е-пошта",
"createacct-emailoptional": "Е-пошта (незадолжително)",
"createacct-email-ph": "Внесете е-пошта",
"showpreview": "Преглед",
"showdiff": "Прикажи промени",
"blankarticle": "<strong>Предупредување:</strong> Страницата што ја создавате е празна.\nАко повторно стиснете на „{{int:savearticle}}“, страницата ќе биде создадена без никаква содржина во неа.",
- "anoneditwarning": "'''Предупредување:''' Не сте најавени.\nВашата IP-адреса ќе биде заведена во историјата на уредување на страницата.",
+ "anoneditwarning": "<strong>Предупредување:</strong> Не сте најавени. Вашата IP-адреса ќе биде јавно видлива ако уредувате. Ако <strong>[$1 се најавите]</strong> или <strong>[$2 направите сметка]</strong>, тогаш уредувањата ќе се припишуваат на вашето корисничко име, покрај другите погодности.",
"anonpreviewwarning": "''Не сте најавени. Ако ја зачувате, Вашата IP-адреса ќе биде заведена во историјата на уредување на страницата.''",
"missingsummary": "'''Потсетник:''' Не внесовте опис на измените. Ако притиснете Зачувај повторно, вашите измени ќе се зачуваат без опис.",
"missingcommenttext": "Ве молиме внесете коментар подолу.",
"powersearch-togglelabel": "Одбери:",
"powersearch-toggleall": "Сè",
"powersearch-togglenone": "Ништо",
- "powersearch-remember": "Запамти го изборот за идни пребарувања",
+ "powersearch-remember": "Запoмни го изборот за идни пребарувања",
"search-external": "Надворешно пребарување",
"searchdisabled": "{{SITENAME}} пребарувањето е оневозможено.\nВо меѓувреме, можете да пребарувате преку Google.\nДа напоменеме дека нивното индексирање на {{SITENAME}} содржините може да биде застарено.",
"search-error": "Се појави грешка при пребарувањето: $1",
"showpreview": "എങ്ങനെയുണ്ടെന്നു കാണുക",
"showdiff": "മാറ്റങ്ങൾ കാണിക്കുക",
"blankarticle": "<strong>മുന്നറിയിപ്പ്:</strong> താങ്കൾ സൃഷ്ടിക്കുന്ന താൾ ശൂന്യമാണ്.\n\"{{int:savearticle}}\" ഒന്നുകൂടി അമർത്തിയാൽ, ഉള്ളടക്കമൊന്നുമില്ലാതെ താൾ സൃഷ്ടിക്കപ്പെടും.",
- "anoneditwarning": "'''മുന്നറിയിപ്പ്:''' താങ്കൾ ലോഗിൻ ചെയ്തിട്ടില്ല. താങ്കളുടെ ഐ.പി. വിലാസം താളിന്റെ തിരുത്തൽ ചരിത്രത്തിൽ ചേർക്കുന്നതാണ്.",
+ "anoneditwarning": "<strong>മുന്നറിയിപ്പ്:</strong> താങ്കൾ ലോഗിൻ ചെയ്തിട്ടില്ല. താങ്കൾ തിരുത്തുകളെന്തെങ്കിലും ചെയ്യുകയാണെങ്കിൽ താങ്കളുടെ ഐ.പി. വിലാസം എല്ലാവർക്കും ലഭ്യമായിരിക്കും. താങ്കൾ <strong>[$1 ലോഗിൻ ചെയ്യുകയോ]</strong> <strong>[$2 അംഗത്വമെടുക്കുകയോ]</strong> ചെയ്യുന്നതുവഴി മറ്റ് ഗുണങ്ങളോടൊപ്പം താങ്കളുടെ തിരുത്തുകൾ ഉപയോക്തൃനാമത്തിലാവും അറിയപ്പെടുക.",
"anonpreviewwarning": "''താങ്കൾ ലോഗിൻ ചെയ്തിട്ടില്ല. സേവ് ചെയ്യുമ്പോൾ താളിന്റെ തിരുത്തൽ ചരിത്രത്തിൽ താങ്കളുടെ ഐ.പി. വിലാസം ചേർത്തു സൂക്ഷിക്കപ്പെടും.''",
"missingsummary": "'''ഓർമ്മക്കുറിപ്പ്:''' താങ്കൾ തിരുത്തലിന്റെ ചുരുക്കരൂപം നൽകിയിട്ടില്ല. ''സേവ് ചെയ്യുക'' ബട്ടൺ ഒരുവട്ടം കൂടി അമർത്തിയാൽ താങ്കൾ വരുത്തിയ മാറ്റം കാത്തുസൂക്ഷിക്കുന്നതാണ്.",
"missingcommenttext": "താങ്കളുടെ അഭിപ്രായം ദയവായി താഴെ രേഖപ്പെടുത്തുക.",
"version-parser-function-hooks": "പാഴ്സർ ഫങ്ഷൻ കൊളുത്തുകൾ",
"version-hook-name": "കൊളുത്തിന്റെ പേര്",
"version-hook-subscribedby": "വരിക്കാരനായത്",
- "version-version": "(പതിപ്പ് $1)",
+ "version-version": "($1)",
"version-no-ext-name": "[[പേര് നൽകിയിട്ടില്ല]",
"version-license": "മീഡിയവിക്കി ഉപയോഗാനുമതി",
"version-ext-license": "അനുമതി",
"userlogin-resetlink": "Insejt kif tidħol fil-kont tiegħek?",
"userlogin-resetpassword-link": "Insejt il-kelma tad-dħul (password)?",
"userlogin-helplink2": "Għajnuna biex tidħol fil-kont",
- "userlogin-loggedin": "Diġà dħalt fil-kont bħala {{GENDER:$1|$1}}.\nUża l-formola t'hawn taħt biex tidħol bħala utent ieħor",
- "userlogin-createanother": "Oħloq kont ieħor",
"createacct-emailrequired": "Indirizz elettroniku",
"createacct-emailoptional": "Indirizz elettroniku (mhux obbligatorju)",
"createacct-email-ph": "Daħħal l-indirizz elettroniku tiegħek",
"preview": "Dehra proviżorja",
"showpreview": "Dehra proviżorja",
"showdiff": "Uri t-tibdiliet",
- "anoneditwarning": "'''Twissija:''' Ma rnexxilekx tidħol.\nL-indirizz tal-IP tiegħek se jiġi reġistrat fil-kronoloġija tal-modifikar ta' din il-paġna.",
+ "anoneditwarning": "'''Attenzjoni:''' Ma dħaltx f'kontok.\nL-indirizz tal-IP tiegħek se jkun jidher pubblikament meta tagħmel xi modifika. Jekk <strong>[$1 tidħol f'kontok]</strong> jew <strong>[$2 toħloq kont]</strong>, il-modifiki li tagħmel jiġu attribwiti lill-ismek ta' utent, flimkien ma benefiċċji oħra.",
"anonpreviewwarning": "''Bħalissa mintix fil-kont tiegħek. Jekk issalva xi modifiki tiegħek, fil-kronoloġija tal-paġna se jiġi reġistrat l-indirizz IP tiegħek.''",
"missingsummary": "'''Twissija:''' Ma pprovdejt l-ebda taqsira dwar il-modifika.\nJekk terġa' tagħfas Modifika, l-modifika se tiġi salvata mingħajr waħda.",
"missingcommenttext": "Jekk jogħġbok ħalli kumment hawn taħt.",
"sp-deletedcontributions-contribs": "kontribuzzjonijiet",
"linksearch": "Fittex ħoloq esterni",
"linksearch-pat": "Mudell ta' tfittxija:",
- "linksearch-ns": "Spazju tal-isem:",
+ "linksearch-ns": "Spazju tal-ismijiet:",
"linksearch-ok": "Fittex",
"linksearch-text": "Tista' tagħmel użu minn metakarattri, per eżempju \"*.wikipedia.org\".<br />\nHuwa neċessarju minn tal-inqas dominju tal-ewwel livell, per eżempju \"*.org\".<br />\nProtokolli aċċettati: <code>$1</code> (jekk ma jiġi speċifikat l-ebda protokol, dan jiġi awtomatikament definit bħala http://).",
"linksearch-line": "$1 hija marbuta mill-paġna $2",
"undelete-error-long": "Kien hemm problemi waqt il-fajl kien qiegħed jiġi rkuprat:\n\n$1",
"undelete-show-file-confirm": "Inti ċert li trid tara reviżjoni imħassra tal-fajl \"<nowiki>$1</nowiki>\" ta' nhar $2, fil-ħin ta' $3?",
"undelete-show-file-submit": "Iva",
- "namespace": "Spazju tal-isem:",
+ "namespace": "Spazju tal-ismijiet:",
"invert": "Aqleb l-għażla",
"tooltip-invert": "Agħżel din il-kaxxa biex taħbi l-modifiki lejn paġni li jinsabu fl-ispazji tal-isem magħżula (u l-ispazju tal-isem assoċjat jekk hu magħżul)",
- "namespace_association": "Spazju tal-isem assoċjat",
+ "namespace_association": "Spazju tal-ismijiet assoċjat",
"tooltip-namespace_association": "Agħżel din il-kaxxa sabiex tinkludi l-paġna ta' diskussjoni jew l-oġġett tal-ispazju tal-isem assoċjat mal-ispazju tal-isem magħżul",
"blanknamespace": "(Prinċipali)",
"contributions": "Kontributi tal-{{GENDER:$1|utent}}",
"import": "Importa paġni",
"importinterwiki": "Importazzjoni transwiki",
"import-interwiki-text": "Agħżel wiki u titlu ta' paġna li se timporta.\nDati ta' reviżjonijiet u ismijiet tal-modifikaturi jiġu preservati.\nKull azzjonijiet ta' importazzjoni tal-transwiki jiġu reġistrati fil-[[Special:Log/import|log ta' importazzjoni]].",
- "import-interwiki-source": "Sors tal-wiki/paġna:",
"import-interwiki-history": "Kopja l-verżjonijiet tal-kronoloġija kollha għal din il-paġna",
"import-interwiki-templates": "Inkludi l-mudelli kollha",
"import-interwiki-submit": "Importa",
"exif-copyright": "Informazzjoni dwar il-propjetá letterarja",
"exif-exifversion": "Verżjoni tal-format Exif",
"exif-flashpixversion": "Verżjoni sapportata ta' Flashpix",
- "exif-colorspace": "Spazju tal-kulur",
+ "exif-colorspace": "Spazju tal-kuluri",
"exif-componentsconfiguration": "Tfissira dwar kull komponent",
"exif-compressedbitsperpixel": "Għamla tal-kompressjoni tal-istampa",
"exif-pixelydimension": "Wisa' tal-istampa",
"exif-lightsource": "Sorġent tad-dawl",
"exif-flash": "Flash",
"exif-focallength": "Distanza fokali objettiva",
- "exif-subjectarea": "Spazju tas-suġġett",
+ "exif-subjectarea": "Spazju tas-suġġetti",
"exif-flashenergy": "Saħħa tal-flash",
"exif-focalplanexresolution": "Riżoluzzjoni X fuq il-witja fokali",
"exif-focalplaneyresolution": "Riżoluzzjoni Y fuq il-witja fokali",
"Parthava (on mzn.wikipedia.org)",
"Spacebirdy",
"محک",
- "아라"
+ "아라",
+ "Alirezaaa"
]
},
"tog-underline": "پیوندون زیر خط دکشی بواشه",
"june": "ژوئن",
"july": "ژوئیه",
"august": "آگوست",
- "september": "سÙ\80Ù\87â\80\8cÙ¾Ù\80تÙ\80Ù\87â\80\8cÙ\85Ù\80بÙ\80ر",
+ "september": "سپتاÙ\85بر",
"october": "اکتبر",
"november": "نـووهمـبـر",
"december": "دسامبر",
"june-gen": "جـون",
"july-gen": "ژوئیه",
"august-gen": "آگوست",
- "september-gen": "سÙ\80Ù\87â\80\8cÙ¾Ù\80تÙ\80Ù\87â\80\8cÙ\85Ù\80بÙ\80ر",
+ "september-gen": "سپتاÙ\85بر",
"october-gen": "اکتبر",
"november-gen": "نـووهمـبـر",
"december-gen": "دسامبر",
"revertmove": "واچـیـهن",
"delete_and_move_confirm": "أره، پاک هاکهن وه ره",
"export": "دأیابأبهردهن ولـگئون",
- "exporttext": "شما بتونّی متن و تاریخچهٔ دچییه بیّن اتا صفحهٔ مشخص یا یتـّا مجموعه از صفحهها ره به شکل دپوشنییه اکسامال دله بریم دربَورین.\n\nاین اطلاعات ره بنشنه اتا ویکی دیگه دله که نرمافزار «مدیاویکی» ره اجرا کانده از طریق [[Special:Import|صفحهٔ دلهدشنیین]] وارد هاکردن.\n\nبریمدربَوردن صفحهها وسّه، وشون عنوان ره این جعبه دله دشنین (هر سطر فقط اتا عنوان) و معلوم هاکنین که تازه دگاردستهئون صفحه ره همراه نسخهئون قدیمیتر و تاریخچهٔ صفحه خوندنّی، یا تازه دگاردستهئون صفحه و اطلاعات آخرین دچییه ره، تیناری اشنّی.\n\nدومین حالت سَره، شما بتونّی اتا لینک جه استفاده هاکنین، مثلاً [[{{#Special:Export}}/{{MediaWiki:Mainpage}}]] صفحهٔ «[[{{MediaWiki:Mainpage}}]]» وسّه.",
+ "exporttext": "شما بتونّی متن و تاریخچهٔ دچییه بیّن اتا صفحهٔ مشخص یا یتـّا مجموعه از صفحات ره به شکل دپوشنییه اکسامال دله بریم دربَورین.\n\nاین اطلاعات ره بنشنه اتا ویکی دیگه دله که نرمافزار «مدیاویکی» ره اجرا کانده از طریق [[Special:Import|صفحهٔ دلهدشنیین]] وارد هاکردن.\n\nبریمدربَوردن صفحات وسّه، وشون عنوان ره این جعبه دله دشنین (هر سطر فقط اتا عنوان) و معلوم هاکنین که تازه دگاردستهئون صفحه ره همراه نسخهئون قدیمیتر و تاریخچهٔ صفحه خوندنّی، یا تازه دگاردستهئون صفحه و اطلاعات آخرین دچییه ره، تیناری اشنّی.\n\nدومین حالت سَره، شما بتونّی اتا لینک جه استفاده هاکنین، مثلاً [[{{#Special:Export}}/{{MediaWiki:Mainpage}}]] صفحهٔ «[[{{MediaWiki:Mainpage}}]]» وسّه.",
"allmessages-filter-all": "همه",
"thumbnail-more": "گت بوو",
"import-interwiki-submit": "بیاردن",
"virus-unknownscanner": "antivirus scanusciuto:",
"logouttext": "'''Site asciùte.'''\n\nNota ca arcune paggene potrebbero cuntinuà ad apparire comme se 'o logout nun fosse avvenuto finché nun venne pulita 'a cache d\"o proprio browser.",
"welcomeuser": "Bemmenuto, $1!",
- "welcomecreation-msg": "'O cunto tuo è stato criato.\nMo' può cagnà 'e [[Special:Preferences|preferenze 'e {{SITENAME}}]].",
+ "welcomecreation-msg": "'O cunto vuosto è stato criato.\nMo' putite cagnà 'e [[Special:Preferences|preferenze 'e {{SITENAME}}]].",
"yourname": "Nomme utente",
"userlogin-yourname": "Nomme utente",
"userlogin-yourname-ph": "'Nserisce 'o tujo nomme utente",
"createacct-benefit-body2": "{{PLURAL:$1|paggena|paggene}}",
"createacct-benefit-body3": "{{PLURAL:$1|contribbutòre ricente|contribbutture ricente}}",
"badretype": "'E passwords ch'è mis nun songe eguale.",
- "userexists": "'O nomme utente ch'è mis è già ausàto.\nPe' piacere scigliete n'atu nomme.",
+ "userexists": "'O nomme utente ch'è mis è già ausàto.\nPe' piacere sciglite n'atu nomme.",
"loginerror": "Probblema 'e accièsso",
"createacct-error": "Errore 'e criazione 'e cunto",
"createaccounterror": "Nun se può crià nu cunto: $1",
"login-abort-generic": "'O login tujo nun ha avuto succiesso - Annullato",
"loginlanguagelabel": "Lengua: $1",
"suspicious-userlogout": "'A richiesta 'e disconnessione d' 'a toja è stata negate pecché pare ca fosse mannata 'a nu navigatóre rutto o nu proxy 'e \"caching\".",
- "createacct-another-realname-tip": "'O nomme overo vuosto è ozzionale.\nSi scigliete 'e nzertà 'o nomme overo, chesto s'ausarrà pe' dà l'utente l'attribuzione d' 'a fatica fatta.",
+ "createacct-another-realname-tip": "'O nomme overo vuosto è ozzionale.\nSi sciglite 'e nzertà 'o nomme overo, chesto s'ausarrà pe' dà l'utente l'attribuzione d' 'a fatica fatta.",
"pt-login": "Tràse",
"pt-login-button": "Tràse",
"pt-createaccount": "Cria nu cunto nuovo",
"passwordreset-emailerror-capture": "Na mmasciata e-mail pe' riabbià 'a password è stata mannata, 'a putite vedé ccà abbascio, ma aita sapé ca nun s'è mannata a {{GENDER:$2|l'utente}} pecché c'è stato cocch'errore: $1",
"changeemail": "Cagna l'indirizzo e-mail",
"changeemail-header": "Cagna l'indirizzo e-mail d' 'o cunto",
- "changeemail-text": "Ghienche stu modulo pe' cangà l'indirizzo mail d' 'o tuojo. Sarrà necessario nzertà 'a password tuja pe' puté cunfermà stu cagnamiento.",
+ "changeemail-text": "Ghienchete stu modulo pe' cangà l'indirizzo mail d' 'o vuosto. Sarrà necessario nzertà 'a password vosta pe' puté cunfermà stu cagnamiento.",
"changeemail-no-info": "Hè 'a trasì ('o login) pe ffà l'acciesso a sta paggena direttamente.",
"changeemail-oldemail": "Indirizzo email 'e mmò:",
"changeemail-newemail": "Indirizzo e-mail nuovo:",
"changeemail-none": "(nisciuno)",
- "changeemail-password": "'A password tuja pe' {{SITENAME}}:",
+ "changeemail-password": "'A password vosta pe' {{SITENAME}}:",
"changeemail-submit": "Cagna e-mail",
"changeemail-cancel": "Canciella",
"changeemail-throttled": "Hè fatto troppe tentative 'a trasì.\nAspetta nu $1 apprimma 'e pruvà n'ata vota.",
"resettokens": "Riabbìa 'e token",
- "resettokens-text": "Ccà se ponno riabbià 'e chiave ca permetessero l'acciesso a determinate date private associate a 'o cunto tuojo.\n\nL'avisse 'e ffà quanno l'hè spartuto pe' sbaglio cu cocche perzona o pure quanno 'o cunto d' 'o tuojo è stato compromesso.",
+ "resettokens-text": "Ccà se ponno riabbià 'e chiave ca permetessero l'acciesso a determinate date private associate a 'o cunto vuosto.\n\nL'aviste 'e ffà quanno l'avete spartuto pe' sbaglio cu cocche perzona o pure quanno 'o cunto d' 'o vuosto è stato compromesso.",
"resettokens-no-tokens": "Nun ce stanno token 'a riabbià.",
"resettokens-legend": "Riabbìa 'e token",
"resettokens-tokens": "Token:",
"showpreview": "Vere anteprimma",
"showdiff": "Fa veré 'e cagnamiente",
"blankarticle": "<strong>Attenziò:</strong> 'a paggena ca staje crianno è abbacante.\nFà click ncopp'a \"{{int:savearticle}}\" n'ata vota, 'a paggena sarrà criata senza cuntenute.",
- "anoneditwarning": "'''Attenziò:''' Nun hè fatto l'acciesso.\nDint'a cronologgia d' 'a paggena sarrà riggistrato l'indirizzo IP d' 'o tuojo.",
- "anonpreviewwarning": "''Nun hè fatto 'o login. Sarvann' 'a paggena, l'indirizzo IP d' 'o tuojo sarrà riggistrato dint'a cronologgia.''",
+ "anoneditwarning": "'''Attenziò:''' Nun avete fatto l'acciesso. 'A cronologgia d' 'a vosta sarrà visibbele pubbrecamente si facite cocche cagnamiento. Si <strong>[$1 tràse]</strong> o <strong>[$2 crìe nu cunto]</strong>, 'e cagnamiente vuoste ve sarranno attribbuite a vvuje, nzieme a n'ati migliuramente.",
+ "anonpreviewwarning": "''Nun avite fatto 'o login. Sarvann' 'a paggena, l'indirizzo IP d' 'o vuosto sarrà riggistrato dint'a cronologgia.''",
"missingsummary": "'''Attenziò:''' nun s'è specificato l'oggetto 'e stu cagnamiento. Clicann' 'a \"{{int:savearticle}}\" n'ata vota 'o cagnamiento sarrà sarvato cu l'oggetto abbacante.",
"missingcommenttext": "Pe' piacere scrivete nu commento ccà abbascio.",
"missingcommentheader": "'''Attenziò:''' nun s'è specificato l'oggetto/titolo 'e stu commento. Clicann' 'a \"{{int:savearticle}}\" n'ata vota 'o cagnamiento sarrà sarvato c' 'o titolo abbacante.",
"summary-preview": "Anteprimma'e l'oggetto:",
"subject-preview": "Anteprima 'e l'oggetto/intestazione:",
"blockedtitle": "Utente bloccato.",
- "blockedtext": "<strong>'O nomme utente o ll'IP tuojo è stato bloccato.</strong>\n\n'O blocco è stato imposlocco è stato mpustato 'a $1. 'O mutivo d' 'o blocco è chesto: ''$2''\n\n* Abbiàta d' 'o blocco: $8\n* Ammaturità d' 'o blocco: $6\n* Tiempo 'e blocco: $7\n\nPuò cuntattà $1 o n'atu [[{{MediaWiki:Grouppage-sysop}}|ammenistratore]] pe' discutere 'o blocco.\n\nVide c' 'a funzione 'Scrive a ll'utente' nun è attiva si nun s'è riggistrato 'o ndirizzo e-mail buono dint' 'e [[Special:Preferences|preferenze]] o pùre si ll'uso 'e tale funzione è stato bloccato.\n\n'O ndirizzo IP attuale è $3, 'o nummero ID d' 'o blocco è #$5.\nPe' piacere avite 'e specificà tutte sti dettaglie ccà ncoppa quanno facite cocche dumanna.",
- "autoblockedtext": "Ll'IP tuojo è stato bloccato pecché 'o steva piglianno n'atu utente, ch'è stato bloccato pe' $1.\n\n'O mutivo d' 'o blocco è chesto:\n\n:''$2''\n\n* Abbiàta d' 'o blocco: $8\n* Ammaturità d' 'o blocco: $6\n* Tiempo 'e blocco: $7\n\nPuò cuntattà $1 o n'atu [[{{MediaWiki:Grouppage-sysop}}|ammenistratore]] pe' discutere 'o blocco.\n\nVide c' 'a funzione 'Scrive a ll'utente' nun è attiva si nun s'è riggistrato 'o ndirizzo e-mail buono dint' 'e [[Special:Preferences|preferenze]] o pùre si ll'uso 'e tale funzione è stato bloccato.\n\n'O ndirizzo IP attuale è $3, 'o nummero ID d' 'o blocco è #$5.\nPe' piacere avite 'e specificà tutte sti dettaglie ccà ncoppa quanno facite cocche dumanna.",
+ "blockedtext": "<strong>'O nomme utente o ll'IP vuosto è stato bloccato.</strong>\n\n'O blocco è stato mpustato 'a $1. 'O mutivo d' 'o blocco è chesto: ''$2''\n\n* Abbiàta d' 'o blocco: $8\n* Ammaturità d' 'o blocco: $6\n* Tiempo 'e blocco: $7\n\nPutite cuntattà $1 o n'atu [[{{MediaWiki:Grouppage-sysop}}|ammenistratore]] pe' discutere 'o blocco.\n\nVedite c' 'a funzione 'Scrivete a ll'utente' nun è attiva si nun s'è riggistrato 'o ndirizzo e-mail buono dint' 'e [[Special:Preferences|preferenze]] o pùre si ll'uso 'e tale funzione è stato bloccato.\n\n'O ndirizzo IP attuale è $3, 'o nummero ID d' 'o blocco è #$5.\nPe' piacere avite 'e specificà tutte sti dettaglie ccà ncoppa quanno facite cocche dumanna.",
+ "autoblockedtext": "Ll'IP vuosto è stato bloccato pecché 'o steva piglianno n'atu utente, ch'è stato bloccato pe' $1.\n\n'O mutivo d' 'o blocco è chesto:\n\n:''$2''\n\n* Abbiàta d' 'o blocco: $8\n* Ammaturità d' 'o blocco: $6\n* Tiempo 'e blocco: $7\n\nPutite cuntattà $1 o n'atu [[{{MediaWiki:Grouppage-sysop}}|ammenistratore]] pe' discutere 'o blocco.\n\nVedite c' 'a funzione 'Scrivete a ll'utente' nun è attiva si nun s'è riggistrato 'o ndirizzo e-mail buono dint' 'e [[Special:Preferences|preferenze]] o pùre si ll'uso 'e tale funzione è stato bloccato.\n\n'O ndirizzo IP attuale è $3, 'o nummero ID d' 'o blocco è #$5.\nPe' piacere avite 'e specificà tutte sti dettaglie ccà ncoppa quanno facite cocche dumanna.",
"blockednoreason": "nisciuna ragione è stata indicata",
"whitelistedittext": "Pe' cagnà 'e ppaggene è necessario $1.",
"confirmedittext": "Pe puté cagnà paggene hè 'a cunfermà l'indirizzo e-mail.\nPe' piacere abbìa e ffà 'a validazione d' 'o ndirizzo e-mail pe' bbìa d' 'e [[Special:Preferences|preferenze d'utente]].",
"note": "'''Nota:'''",
"previewnote": "'''Chesta è sola n'anteprimma; 'e cagnamiénte â paggena nun songo ancora sarvate!'''",
"continue-editing": "Tràse int'a l'area 'e modifica",
- "previewconflict": "L'anteprimma currisponne a 'o testo presente dint'a cascia 'e modifica ccà ncoppa e rappresentasse 'a paggena comme cumpare si scigliete 'e Sarvà ind'a stu mumento.",
+ "previewconflict": "L'anteprimma currisponne a 'o testo presente dint'a cascia 'e modifica ccà ncoppa e rappresentasse 'a paggena comme cumpare si sciglite 'e Sarvà ind'a stu mumento.",
"session_fail_preview": "'''Nun è possibbile prucessà 'o cagnamiento pecché se so' sperdut' 'e date d' 'a sessione.\nProva n'ata vota.\nSi nun funziona ancora, può pruvà 'a te [[Special:UserLogout|n'ascì]] e a trasì n'ata vota.'''",
"session_fail_preview_html": "'''Nun è possibbile prucessà 'o cagnamiento pecché se so' sperdut' 'e date d' 'a sessione.\nProva n'ata vota.'''\n''Siccome dint' 'o {{SITENAME}} è abilitato l'uso 'e l'HTML cruro, 'o buttone d'anteprimma nun è abbiàto comme misura 'e sicurezza annanza cocch'attacco JavaScript''\n'''Si chest'era nu tentativo legittimo 'e cagnamiento, prova n'ata vota. Si nun funziona ancora, può pruvà 'a te [[Special:UserLogout|n'ascì]] e a trasì n'ata vota.'''",
"token_suffix_mismatch": "'''Stu cagnamiento nun è stato sarvato pecché 'o client ave mmustato nu sbaglio dint'o scrivere d' 'e carattere d' 'a punteggiatura token. Pe luvà na possibbile corruzione d' 'o testo dint'a paggena, s'è rifiutat' 'a modifeca.\n\nSta situazione se può truvà, quanno staje ausanno nu servizio 'e proxy anonime via web cu d' 'e bug.'''",
"editingcomment": "Cagnamiénto 'e $1 (nova sezzione)",
"editconflict": "Conflitto d'edizzione: $1",
"explainconflict": "N'at'utente ave sarvato na nova verziona d' 'a paggena pe' tramente ca stive a fà 'e cagnamiente.\n'A cascia 'e mudifeca ncoppa cuntene 'o testo d' 'a paggena ca mò sta online, accussì comme è stato agghiurnato a l'at'utente.\n'A verziona ch' 'e cagnamiente tuoje è stata mmece riportata dint'a cascia 'e mudifeca abbascio.\nSi 'e bbuò cunfermà hè 'a ripurtà 'e cagnamiente d' 'e tuoje dint'o testo ca esiste (dint'a cascia ncoppa).\nSpremmendo 'o buttón '{{int:savearticle}}', sarrà sarvato '''sulamente''' 'o testo cuntenuto dint'a cascia 'e cagnamiento ncoppa.",
- "yourtext": "'O testo tuojo",
+ "yourtext": "'O testo vuosto",
"storedversion": "A verziona 'n memoria",
"nonunicodebrowser": "'''Attenziò: staje ausanno nu navigatóre ca nun è compatibbele ch' 'e carattere Unicode. Pe' te permettere 'o cagnamiento d' 'e paggene senza crià ncunveniente, 'e carattere nun ASCII veneno viste dint' 'a cascia 'e cagnamiento sotto forma 'e codece esadecimale.'''",
"editingold": "'''Attenziò: staje cagnanno na verziona nun agghiurnata d' 'a paggena. Si 'a sarve accussì, tutte 'e cagnamiente fatte aropp'a sta verziona sarranno sperdute.'''",
"undo-summary-username-hidden": "Annullato 'o cagnamiento $1 pe n'utente annascunnuto",
"cantcreateaccounttitle": "Nun se può crià cunto",
"cantcreateaccount-text": "'A riggistraziona è stata bloccata 'a l'utente [[User:$3|$3]] 'a st'innerizzo IP ('''$1''').\n\n'O mutivo dato 'a $3 è chistu ccà: ''$2''",
- "cantcreateaccount-range-text": "'A criazione 'e cunte 'a ll'indirizze int'o ntervallo '''$1''', che cummiglia 'o tuojo ('''$4'''), è stata bloccata 'a l'utente [[User:$3|$3]].\n\n'O mutivo dato 'a $3 è chistu ccà: ''$2''",
+ "cantcreateaccount-range-text": "'A criazione 'e cunte 'a ll'indirizze int'o ntervallo '''$1''', che cummiglia 'o vuosto ('''$4'''), è stata bloccata 'a l'utente [[User:$3|$3]].\n\n'O mutivo dato 'a $3 è chistu ccà: ''$2''",
"viewpagelogs": "Vide 'e log azzeccate a sta paggena",
"nohistory": "Nun esiste na cronologgia 'e verziune pe' sta paggena.",
"currentrev": "Verzione 'e mmo",
"last": "prec",
"page_first": "primma",
"page_last": "úrdema",
- "histlegend": "Confronto nfra verziune: scigliete 'e casciulelle c'attoccassero a 'e verziune che volete cunfruntà e spremmete Invio o pure 'o buttóne ccà abbascio.\n\nLiggenda: '''({{int:cur}})''' = differenze c' 'a verzione 'e mmò, '''({{int:last}})''' = differenze c' 'a verzione 'e primma, '''{{int:minoreditletter}}''' = cagnamiento minore",
+ "histlegend": "Confronto nfra verziune: sciglite 'e casciulelle c'attoccassero a 'e verziune che vulite cunfruntà e spremmite Invio o pure 'o buttóne ccà abbascio.\n\nLiggenda: '''({{int:cur}})''' = differenze c' 'a verzione 'e mmò, '''({{int:last}})''' = differenze c' 'a verzione 'e primma, '''{{int:minoreditletter}}''' = cagnamiento minore",
"history-fieldset-title": "Naviga dint' 'a cronologgia",
"history-show-deleted": "Solo chille canciellate",
"histfirst": "primma",
"logdelete-selected": "{{PLURAL:$1|Fatto scigliuto d' 'o riggistro|Fatte scigliute d' 'o riggistro}}:",
"revdelete-text-text": "'E verziune scancellate cumpareno ancora dint' 'a cronologgia d' 'a paggena, ma na parte d' 'o cuntenuto lloro nun sarrà disponibbele a 'o pubbreco.",
"revdelete-text-file": "'E verziune 'e file scancellate cumpareno ancora dint' 'a cronologgia d' 'o file, ma parte d' 'o cuntenuto lloro nun sarrà disponibbele a 'o pubbreco.",
+ "logdelete-text": "'E fatte 'e riggistro scancellate cumpareno ancora dint' 'a cronologgia 'e riggistro, ma na parte d' 'o cuntenuto lloro nun sarrà disponibbele a 'o pubbreco.",
+ "revdelete-text-others": "Ll'at'ammenistrature puterranno ancora trasì e arrepiglià 'e cuntenute annascunnute, si nun so' state mpustate cchiù restrizziune.",
+ "revdelete-confirm": "Pe' piacere cunferma ca overo bbuò ffà chesto, ca cunosce 'e cunseguenze, e ca staje facenno chesto rispettanno 'e [[{{MediaWiki:Policy-url}}|linee guida]].",
+ "revdelete-suppress-text": "Sti luvamiente hana essere fatte '''unicamente''' dint' 'e situaziune ccà abbascio:\n* nfurmaziune potenzialmente diffamatorie\n* date perzunale inopportune\n*: ''indirizze, nummeri 'e telefono, codece fiscale, ecc.''",
+ "revdelete-legend": "Miette 'e limmete 'e visibilità",
+ "revdelete-hide-text": "Testo d' 'a verziona",
+ "revdelete-hide-image": "Annascunne 'e cuntenute d' 'o file",
+ "revdelete-hide-name": "Annascunne aziona e l'oggetto 'e cchesta",
+ "revdelete-hide-comment": "Modifeca oggetto",
+ "revdelete-hide-user": "Nomme o indirizzo IP 'e ll'autore",
+ "revdelete-hide-restricted": "Annascunne 'e nfurmaziune 'nnecate pure a l'ammenistrature",
+ "revdelete-radio-same": "(nun cagnà)",
"revdelete-radio-set": "Nasconde",
"revdelete-radio-unset": "Faje vedé",
+ "revdelete-suppress": "Annascunne 'e nfurmaziune pure a l'ammenistrature",
+ "revdelete-unsuppress": "Scancella 'e limmete ncopp' 'e verziune arripigliate",
+ "revdelete-log": "Mutivo:",
+ "revdelete-submit": "Applica {{PLURAL:$1|â virziona scigliuta|a 'e virziune scigliute}}",
+ "revdelete-success": "'''Visibbelità d' 'a verziona agghiurnata e apposto.'''",
+ "revdelete-failure": "'''Int'a sta virziona 'a visibbelità nun se può agghiurnà:'''\n$1",
+ "logdelete-success": "'''Int'a stu riggistro 'a visibbelità è stata scigliuta currettamente.'''",
+ "logdelete-failure": "'''Int'a stu riggistro 'a visibbelità nun se può scegliere:'''\n$1",
"revdel-restore": "càgna visiblità",
+ "pagehist": "Verziune 'e primma",
+ "deletedhist": "Cronologgia scancellata",
+ "revdelete-hide-current": "Nun se ponno annasconnere ll'item cu data 2, $1: pecché song'a la verziona 'e mmò.",
+ "revdelete-show-no-access": "Errore a mmustà ll'oggetto cu data $2, $1: St'oggetto è stato nzegnàto comme \"riservato\".\nNun tiene acciesso a chesto.",
+ "revdelete-modify-no-access": "Nun se può cagnà l'oggetto cu data $2, $1: pecché st'oggetto è stato nzegnàto comme \"riservato\".\nVuje nun avete acciesso.",
+ "revdelete-modify-missing": "Nun se può cagnà l'oggetto cu l'ID $1 pecché nun è prisente int' 'o database.",
+ "revdelete-no-change": "'''Attenziò:''' l'oggetto cu data $2, $1 teneva già 'e mpustaziune 'e visibbilità addimannate.",
+ "revdelete-concurrent-change": "Nun se può cagnà l'oggetto cu data $2, $1: 'O status 'e chisto pare ch'è stato cagnato pe cocch'utente pe' tramente ca 'o stive a cagnà.\nPe' piacere cuntrolla 'o riggistro.",
+ "revdelete-only-restricted": "Errore quanno s'annasconneva l'oggetto cu data $2, $1: Nun può luvà oggette d' 'a vista 'e ll'ammenistratore senza scegliere manco una 'e l'ati ozzione 'e visibbelità.",
+ "revdelete-reason-dropdown": "* Mutive comune pe' ffà scancellamiento\n** Violazione d' 'o copyright\n** Cummente o nfurmaziune perzunale inappropriate\n** Nomme utente inappropriato\n** Nfurmazione potenzialmente diffamatoria",
+ "revdelete-otherreason": "Ati/cchiù ragiune:",
+ "revdelete-reasonotherlist": "Ati ragiune",
+ "revdelete-edit-reasonlist": "Càgna 'e mutive pe' fà 'o scancellamiento",
+ "revdelete-offender": "Autore d' 'a verziona:",
+ "suppressionlog": "Riggistro 'e luvamiente",
+ "suppressionlogtext": "Ccà abbascio ce sta n'alenco ch' 'e scancellamiente e blocche ca teneno cuntenute annascunnuto a l'ammenistrature.\nVide l'[[Special:BlockList|alenco d' 'e blocche]] pe' l'alenco e banne e blocche attive 'e mò.",
+ "mergehistory": "Aunisce 'e cronologgie",
+ "mergehistory-header": "Sta paggena te permette d'aunì 'e verziune d' 'a cronologgia 'e na paggena origgine a na paggena nova.\nVedite ca s'avesse 'a nchiantà stu cagnamiento senza scassà 'a continuità storeca d' 'a paggena.",
+ "mergehistory-box": "Aunisce 'a cronologgia 'e ddoje ppaggene:",
+ "mergehistory-from": "Paggena d'origgene:",
+ "mergehistory-into": "Paggena 'e destinazione:",
+ "mergehistory-list": "Cronologgia 'e paggena ca fosse applicabbele pe' se ffà l'unione",
+ "mergehistory-merge": "Se ponno aunì 'e verziune 'e [[:$1]] nzignata ccà int' 'a cronologgia 'e [[:$2]]. Ausàte 'a colonna ch' 'e buttóne d'ozzione pe' ffà l'aunione 'e tutt' 'e verziune nfin' 'a data e ora nzignàte.\nVedite ca si s'ausassero 'e buttóne 'e navigazione, 'a culonna ch' 'e buttóne d' 'ozzione fosse rinnovata.",
+ "mergehistory-go": "Vide 'e cagnamiente ca se ponno aunì",
+ "mergehistory-submit": "Aunisce 'e verziune",
+ "mergehistory-empty": "Nun ce stanno virziune pe' putè ffà l'aunione.",
+ "mergehistory-success": "{{PLURAL:$3|Na virziona 'e [[:$1]] è stata aunita|$3 versiune 'e [[:$1]] so' state aunite}} â cronologgia 'e [[:$2]].",
+ "mergehistory-fail": "Nun se ponno aunì 'e cronologgie. Pe' piacere cuntrolla n'ata vota 'a paggena e li parametre tempurale.",
+ "mergehistory-fail-toobig": "Nun se può fà l'aunione d' 'a cronologgia cu nu lémmeto 'e n'ati $1 {{PLURAL:$1|revisione|rivisiune}} 'a cagnà posto.",
+ "mergehistory-no-source": "'A paggena d'origgine $1 nun esiste.",
+ "mergehistory-no-destination": "'A paggena 'e destinazione $1 nun esiste.",
+ "mergehistory-invalid-source": "'A paggena d'origgine add'avé nu titolo bbuono.",
+ "mergehistory-invalid-destination": "'A paggena 'e destinazione add'avé nu titolo bbuono.",
+ "mergehistory-autocomment": "Aunione 'e [[:$1]] int'a [[:$2]]",
+ "mergehistory-comment": "Aunione 'e [[:$1]] int'a [[:$2]]: $3",
+ "mergehistory-same-destination": "'E paggene d'origgine e destinazione nun ponno essere eguale",
+ "mergehistory-reason": "Mutivo:",
+ "mergelog": "Riggistro d'aunione",
+ "pagemerge-logentry": "song'aunite [[$1]] int'a [[$2]] (verziune nfin'a $3)",
+ "revertmerge": "Annulla aunione",
+ "mergelogpagetext": "Ccà abbascio ce sta na lista cu ll'urdeme aunione int'a cronologgia d' 'e ddoje paggene.",
+ "history-title": "$1: cronologgia d' 'e cagnamiente",
+ "difference-title": "Differenze nfra 'e verziune 'e \"$1\"",
+ "difference-title-multipage": "Differenze nfra 'e verziune \"$1\" e \"$2\"",
+ "difference-multipage": "(Differenze nfra 'e paggene)",
"lineno": "Riga $1:",
+ "compareselectedversions": "Cunfronta 'e verziune scigliute",
+ "showhideselectedversions": "Cagna visibbelità d' 'e verziune scigliute",
"editundo": "annulla",
+ "diff-empty": "(Nisciuna differenza)",
+ "diff-multi-sameuser": "({{PLURAL:$1|Na verziona ntermedia|$1 verziune ntermedie}} 'e n'utente stisso nun {{PLURAL:$1|è mmustata|songo mmustate}})",
+ "diff-multi-otherusers": "({{PLURAL:$1|Na virzione ntermedia|$1 verziune ntermedie}} 'a {{PLURAL:$2|n'at'utente|$2 n'ati ddoj'utente}} nun è mmustata)",
+ "diff-multi-manyusers": "({{PLURAL:$1|Na virzione ntermedia|$1 verziune ntermedie}} 'a cchiù 'e $2 {{PLURAL:$2|utente|utente}} nun è mmustata)",
+ "difference-missing-revision": "{{PLURAL:$2|Na virziona|$2 verziune}} 'e sta differenza ($1) {{PLURAL:$2|nun è stata truvata|nun so' state truvate}}.\n\nChest'è succiesso quanno s'è secutato nu diff obsoleto a na paggena scancellata.\n'E dettaglie se ponno truvà dint'a [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} 'o riggistro 'e scancellamiente].",
"searchresults": "Risultato d''a recerca",
"searchresults-title": "Ascià risultate ppe \"$1\"",
+ "titlematches": "Currispunnenze d' 'o titolo d' 'e paggene",
+ "textmatches": "Currispunnenze d' 'o testo d' 'e paggene",
"notextmatches": "Voce addemannata nun truvata dint' 'e teste 'e articulo",
"prevn": "{{PLURAL:$1|precedente|precedente $1}}",
"nextn": "{{PLURAL:$1|successivo|successive $1}}",
"nextn-title": "{{PLURAL:$1|Risultato successivo|$1 risultate successive}}",
"shown-title": "Fa vere {{PLURAL:$1|'nu risultato|$1 risultate}} ppe paggena",
"viewprevnext": "Vere($1 {{int:pipe-separator}} $2) ($3).",
- "searchmenu-new": "<strong>'''Cria a paggena \"[[:$1]]\" ncopp'â chisto wiki!'''</strong> {{PLURAL:$2|0=|Vede anche 'a paggena truovata cu 'a recerca tuja|Vede anche 'e risultate d\"a recerca}}",
+ "searchmenu-exists": "'''Ncopp' 'o sito esiste na paggena c' 'o nomme \"[[:$1]]\"'''\n{{PLURAL:$2|0=|Vedite pure dint'a l'ati risultate 'e cerca.}}",
+ "searchmenu-new": "<strong>'''Cria a paggena \"[[:$1]]\" ncopp'â chisto wiki!'''</strong> {{PLURAL:$2|0=|Vide anche 'a paggena truovata cu 'a recerca vuosta|Vede anche 'e risultate d\"a recerca}}",
"searchprofile-articles": "Paggene 'e contenute",
"searchprofile-images": "Multimedia",
"searchprofile-everything": "Tutto",
"searchprofile-advanced": "Avanzate",
"searchprofile-articles-tooltip": "Circa dint'ô $1",
"searchprofile-images-tooltip": "Circa file",
+ "searchprofile-everything-tooltip": "Ascìa int'a tutte 'e cuntenute (pure dint' 'e chiacchiere)",
"searchprofile-advanced-tooltip": "Circa dint'e namespace perzonalizzate",
"search-result-size": "$1 ({{PLURAL:$2|'na parola|$2 parole}})",
+ "search-result-category-size": "{{PLURAL:$1|1 utente|$1 utente}} ({{PLURAL:$2|1 sottocategurìa|$2 sottocategurìe}}, {{PLURAL:$3|1 file|$3 files}})",
"search-redirect": "(redirect $1)",
"search-section": "(sezzione $1)",
+ "search-file-match": "(currispunnenza dint' 'e cuntenute d' 'o file)",
"search-suggest": "Prova chisto: $1",
"search-interwiki-caption": "Prugiette frate",
+ "search-interwiki-default": "Risultate 'a $1:",
+ "search-interwiki-more": "(cchiù)",
+ "search-relatedarticle": "Azzeccato",
+ "searchrelated": "azzeccato",
"searchall": "Tutte",
+ "showingresults": "Ccà abbascio {{PLURAL:$1|s'apprisentano 'o massimo '''1''' risultato|veneno apprisentate massimo '''$1''' risultate}} aropp' 'o nummero '''$2'''.",
+ "showingresultsinrange": "{{PLURAL:$1|Vene mmustato|Veneno mmustate}} abbascio {{PLURAL:$1|<strong>1</strong> risultato|<strong>$1</strong> risultate}} d' 'o <strong>$2</strong> a 'o <strong>$3</strong>.",
+ "showingresultsheader": "{{PLURAL:$5|Risultato '''$1''' 'e '''$3'''|Risultate '''$1 - $2''' 'e '''$3'''}} pe' '''$4'''",
"search-nonefound": "'A ricerca nun ha produtto risultate.",
+ "powersearch-legend": "Ricerca avanzata",
+ "powersearch-ns": "Ascìa dint' 'o namespace:",
+ "powersearch-togglelabel": "Cuntrolla:",
+ "powersearch-toggleall": "Tutto",
+ "powersearch-togglenone": "Nisciuno",
+ "powersearch-remember": "Arricuòrdate d' 'a selezziona quanno faje ricerche nfuturo",
+ "search-external": "Ricerca 'a fore",
+ "searchdisabled": "'A ricerca dint'a {{SITENAME}} nun è attiva; pe' tramente se putesse ausà nu mutore 'e cerca sterno comm'a Google. (Avite 'e sapé però, ca sti cuntenute d' 'o {{SITENAME}} dint' 'e mutore, può darse ca nun stanno agghiurnate.)",
+ "search-error": "È succiesso n'errore pe' tramente ca se faceva 'a ricerca: $1",
+ "preferences": "Preferenze d''e mmeje",
"mypreferences": "Preferenze d''e mmeje",
+ "prefs-edits": "Cagnamiente affettuate:",
+ "prefsnologintext2": "Pe' piacere, tràse pe' cagnà 'e preferenze tuje.",
+ "prefs-skin": "Aspetto grafeco (skin)",
+ "skin-preview": "Anteprimma",
+ "datedefault": "Nisciuna preferenza",
+ "prefs-labs": "Funzionalità sperimentale",
+ "prefs-user-pages": "Paggene utente",
+ "prefs-personal": "Profilo utente",
"prefs-rc": "Urdeme nove",
"prefs-watchlist": "Asservate speciale",
+ "prefs-watchlist-days": "Nummero 'e juorne 'a mmustà dint'a l'elenco 'e cuntrollo:",
+ "prefs-watchlist-days-max": "Massimo $1 {{PLURAL:$1|juorno|juorne}}",
+ "prefs-watchlist-edits": "Numero massimo 'e cagnamiente 'a mmustà ch' 'e funziune avanzate:",
+ "prefs-watchlist-edits-max": "Nummero massimo: 1000",
+ "prefs-watchlist-token": "Token 'e l'alenco 'e cuntrollo:",
+ "prefs-misc": "Varje",
+ "prefs-resetpass": "Cagna 'a password",
+ "prefs-changeemail": "Cagna l'indirizzo e-mail",
+ "prefs-setemail": "Mpizza nu ndirizzo e-mail",
+ "prefs-email": "Ozziune e-mail",
+ "prefs-rendering": "Aspetto",
"saveprefs": "Sarva",
+ "restoreprefs": "Arripiglia 'e mpustaziune predefinite (inta tutte 'e seziune)",
+ "prefs-editing": "Cascia 'e cagnamiento",
+ "rows": "Righe:",
"columns": "Culonne:",
"searchresultshead": "Truova",
+ "stub-threshold": "Valore minimo p' 'e <a href=\"#\" class=\"stub\">cullegamiente a 'e stub</a>, 'n byte:",
+ "stub-threshold-disabled": "Stutato",
+ "recentchangesdays": "Nummero 'e juorne a mmustà dint'a l'urdeme cagnamiente:",
+ "recentchangesdays-max": "Massimo $1 {{PLURAL:$1|juorno|juorne}}",
+ "recentchangescount": "Nummero predefinito 'e cagnamiente 'a mmustà:",
+ "prefs-help-recentchangescount": "Chesto ntenne ll'urdeme cagnamiente, 'e cronologgie 'e paggena, e riggistre.",
+ "prefs-help-watchlist-token2": "Chest'è 'a chiave segreta pe se ffà 'o feed web 'e l'alenco 'e cuntrolo d' 'o vuosto.\nSi coccheruno 'a cunoscesse, allora putesse vedé l'alenco 'e cuntrollo, picciò nun 'a spartite. [[Special:ResetTokens|Cliccate ccà se tenite necessità d' 'a rimpizzà]].",
+ "savedprefs": "'E preferenze songo state sarvate.",
+ "timezonelegend": "Fuso orario:",
+ "localtime": "Ora lucale:",
+ "timezoneuseserverdefault": "Aúsa ora predefinita d' 'o wiki ($1)",
+ "timezoneuseoffset": "Ato (specificà 'a differenza)",
+ "servertime": "Ora d' 'o server:",
+ "guesstimezone": "Aúsa l'ora d' 'o navigatóre",
"timezoneregion-africa": "Afreca",
+ "timezoneregion-america": "Amereca",
+ "timezoneregion-antarctica": "Antartide",
+ "timezoneregion-arctic": "Arteco",
+ "timezoneregion-asia": "Asia",
+ "timezoneregion-atlantic": "Oceano Atlanteco",
+ "timezoneregion-australia": "Australia",
+ "timezoneregion-europe": "Europa",
+ "timezoneregion-indian": "Oceano Indiano",
+ "timezoneregion-pacific": "Oceano Pacifeco",
+ "allowemail": "Abbìa 'a ricezione 'e mmasciate mannate 'a l'ati utente",
+ "prefs-searchoptions": "Ascìa",
+ "prefs-namespaces": "Namespace",
+ "default": "predefinito",
+ "prefs-files": "File",
+ "prefs-custom-css": "CSS personalizzato",
+ "prefs-custom-js": "JavaScript personalizzato",
+ "prefs-common-css-js": "CSS/JavaScript spartuto pe' tutt' 'e skin:",
+ "prefs-reset-intro": "Putisse ausà sta paggena pe' rimpizzà 'e preferenze proprie comme chille predefinite d' 'o sito.\nL'operazione nun se può annullà.",
+ "prefs-emailconfirm-label": "Cunferma 'e ll'e-mail:",
"youremail": "E-mail:",
"username": "{{GENDER:$1|Nomme utente}}:",
+ "prefs-memberingroups": "{{GENDER:$2|Membro}} {{PLURAL:$1|d' 'o gruppo|d' 'e gruppe}}:",
+ "prefs-registration": "Data 'e riggistrazione:",
"yourrealname": "Nomme vero",
"yourlanguage": "Lengua:",
+ "yourvariant": "Variante d' 'a llengua:",
+ "prefs-help-variant": "'A variante o grafia ca preferite 'e vedé ncopp' 'e paggene 'e chesta wiki.",
+ "yournick": "Soprannomme (nickname):",
+ "prefs-help-signature": "'E cummente dint' 'e paggene 'e chiacchiera hanna essere firmate cu \"<nowiki>~~~~</nowiki>\" ca s'addeventarrà automatecamente 'a firma propria c' 'a data.",
+ "badsig": "Errore 'e firma nun standard, cuntrullate 'e tag HTML.",
+ "badsiglength": "'A firma c'avite scigliuto è troppo luonga, chesta nun avesse 'a superà $1 {{PLURAL:$1|carattere|carattere}}.",
+ "yourgender": "Comme nce referimmo a vvuje?",
+ "gender-unknown": "Preferisco 'e nun 'o ddicere",
+ "gender-male": "È riggistrato ncopp' 'a {{SITENAME}}",
+ "gender-female": "È riggistrata ncopp' 'a {{SITENAME}}",
+ "prefs-help-gender": "Mpizzà sta preferenza è ozzionale.\n'O software aúsa stu valore pe' se vutà a vuje e v'anummenà a l'ati utente ausanno 'o gennere grammatecale buono.\nCheste nfurmaziune sarranno pubbreche.",
+ "email": "E-mail",
+ "prefs-help-realname": "'O nomme overo vuosto è ozzionale.\nSi sciglite 'e nzertà 'o nomme overo, chesto s'ausarrà pe' dà l'utente l'attribuzione d' 'a fatica fatta.",
+ "prefs-help-email": "L'e-mail vuosto è ozzionale, ma permettesse 'e ricevere 'a password propria quanno v' 'a scurdate.",
+ "prefs-help-email-others": "Putite pure scegliere 'e lassà che l'at'utente ve mannassero mmasciate via e-mail cu nu cullegamiento â paggena d'utente o chiacchiera.\nLl'indirizzo e-mail vuosto nun è scummigliato quanno l'at'utente ve cuntattano.",
+ "prefs-help-email-required": "L'indirizzo e-mail è obbligatorio.",
+ "prefs-info": "Nfurmaziune bbase",
+ "prefs-i18n": "Nternaziunalizzazione",
+ "prefs-signature": "Firma",
+ "prefs-dateformat": "Furmato data",
+ "prefs-timeoffset": "Ore 'e differenza",
+ "prefs-advancedediting": "Ozziune generale",
+ "prefs-editor": "Editore",
+ "prefs-preview": "Anteprimma",
+ "prefs-advancedrc": "Ozziune avanzate",
+ "prefs-advancedrendering": "Ozziune avanzate",
+ "prefs-advancedsearchoptions": "Ozziune avanzate",
+ "prefs-advancedwatchlist": "Ozziune avanzate",
+ "prefs-displayrc": "Ozziune 'e visualizzazione",
+ "prefs-displaywatchlist": "Ozziune 'e visualizzazione",
+ "prefs-tokenwatchlist": "Token",
+ "prefs-diffs": "Differenze",
+ "prefs-help-prefershttps": "Sta preferenza averrà affetto 'a 'o prossimo acciesso vuosto.",
+ "prefs-tabs-navigation-hint": "Suggerimento: se ponno ausà 'e buttòne 'e freccia a manca e a dritta pe' ve muovere nfra 'e schede dint'a l'alenco d' 'e schede.",
+ "email-address-validity-valid": "L'indirizzo e-mail pare valido",
+ "email-address-validity-invalid": "Nzerta n'indirizzo e-mail valido",
+ "userrights": "Gestione d' 'e permesse 'e l'utente",
+ "userrights-lookup-user": "Gestione 'e gruppe d'utenza",
+ "userrights-user-editname": "Nzertàte nu nomme utente:",
+ "editusergroup": "Cagnate 'e gruppe d'utenze",
+ "editinguser": "Cagnamiento d' 'e deritte d'utente '''[[User:$1|$1]]''' $2",
+ "userrights-editusergroup": "Cagnate 'e gruppe d'utenze",
+ "saveusergroups": "Sarvate 'e gruppe d'utenza",
+ "userrights-groupsmember": "Ffà parte {{PLURAL:$1|d' 'o gruppo|d' 'e gruppe}}:",
+ "userrights-groupsmember-auto": "Membro mplicito 'e:",
+ "userrights-groups-help": "Putite cagnà 'e gruppe assegnate a l'utente:\n* Na cascia 'e spunta scigliuta significasse ca appartenenza 'e l'utente a 'o gruppo\n* Na cascia 'e spunta nun scigliuta significasse 'a nun appartenenza a 'o gruppo.\n* 'O simmolo * significasse ca nun se può scancellà l'appartenenza a 'o gruppo aropp'a ll'avé miso (o viceversa).",
+ "userrights-reason": "Mutivo:",
+ "userrights-no-interwiki": "Nun tenite permesse pe' cagnà 'e deritte 'e l'utente ncopp'a l'ati wiki.",
+ "userrights-nodatabase": "'O database $1 nun esiste o nun è nu database lucale.",
+ "userrights-nologin": "Avite 'a [[Special:UserLogin|trasì]] comme ammenistratore si vulite assegnà 'e deritte 'e l'utente.",
+ "userrights-notallowed": "Nun tenite 'e permesse pe' jognere o luvà 'e permesse utente.",
+ "userrights-changeable-col": "Gruppe ca putite cagnà",
+ "userrights-unchangeable-col": "Gruppe ca nun putite cagnà",
+ "userrights-conflict": "Conflitto 'e cagnamiento 'e deritte utente! Cuntrullate e cunfermate 'e cagnamiente vuoste.",
+ "userrights-removed-self": "Avete rimosso buono 'e deritte vuoste. Picciò nun putite trasì cchiù dint'a sta paggena.",
+ "group": "Gruppo:",
+ "group-user": "Utente",
+ "group-autoconfirmed": "Utente autocunfermate",
+ "group-bot": "Bot",
+ "group-sysop": "Ammenistrature",
+ "group-bureaucrat": "Burocrate",
+ "group-suppress": "Oversight",
+ "group-all": "(tutte)",
+ "group-user-member": "{{GENDER:$1|utente}}",
+ "group-autoconfirmed-member": "{{GENDER:$1|utente autocunfermato|utente autocunfermata|utente autocunfermato/a}}",
+ "group-bot-member": "{{GENDER:$1|bot}}",
+ "group-sysop-member": "{{GENDER:$1|ammenistratore|ammenistratrice|ammenistratore/trice}}",
+ "group-bureaucrat-member": "{{GENDER:$1|burocrate}}",
+ "group-suppress-member": "{{GENDER:$1|oversight}}",
+ "grouppage-user": "{{ns:project}}:Utente",
+ "grouppage-autoconfirmed": "{{ns:project}}:Utente autocunfermate",
+ "grouppage-bot": "{{ns:project}}:Bot",
+ "grouppage-sysop": "{{ns:project}}:Ammenistrature",
+ "grouppage-bureaucrat": "{{ns:project}}:Burocrate",
+ "grouppage-suppress": "{{ns:project}}:Oversight",
+ "right-read": "Liegge paggene",
+ "right-edit": "Cagna paggene",
+ "right-createpage": "Crìa paggene (ca nun songo paggene 'e chiacchiera)",
+ "right-createtalk": "Crìa chiacchiere 'e paggena",
+ "right-createaccount": "Crìa utenze nove",
+ "right-minoredit": "Nzigna 'e cagnamiente comme minure",
+ "right-move": "Muove 'e paggene",
+ "right-move-subpages": "Muove 'e paggene nzieme ê sottopaggene suje",
+ "right-move-rootuserpages": "Muove 'e paggene princepale d'utente",
+ "right-move-categorypages": "Muove 'e categurìe",
+ "right-movefile": "Muove 'e file",
+ "right-suppressredirect": "Nun crià 'e redirect automateco quanno se muoveno 'e paggene",
+ "right-upload": "Carreca file",
+ "right-reupload": "Sovrascrive nu file ch'esiste",
+ "right-reupload-own": "Sovrascrive nu file esistente carrecat'a l'utente stesso",
+ "right-reupload-shared": "Sovrascrive lucalmente file prisente dint'a l'archivio spartuto",
+ "right-upload_by_url": "Carreca nu file 'a n'indirizzo URL",
+ "right-purge": "Pulezza 'a cache d' 'o sito senza cunferma",
+ "right-autoconfirmed": "Nun suggetto a 'o lemmeto d'aziune 'a l'IP",
+ "right-bot": "S'avesse 'e trattà comm'a nu prucesso automateco",
+ "right-nominornewtalk": "Fa ch' 'e cagnamiente minore a 'e paggene 'e chiacchiera nun facciano scattà l'avviso 'e mmasciata nnova",
+ "right-apihighlimits": "Usa límmete cchiù aute pe l'interrogaziune a ll'API",
+ "right-writeapi": "Usa l'API 'n scrittura",
+ "right-delete": "Scancella paggene",
+ "right-bigdelete": "Scancella paggene ch' 'e cronologgie luonghe",
+ "right-deletelogentry": "Scancella e arripiglia vvoce 'e riggistro specifiche",
+ "right-deleterevision": "Annascunne verziune specifiche d' 'e paggene",
+ "right-deletedhistory": "Vide 'e verziune d' 'a cronologgia scancellate senza 'o testo suoccio a lloro",
+ "right-deletedtext": "Vide 'o testo scancellato e cagnamiente nfra virziune scancellate",
+ "right-browsearchive": "Ascìa dint' 'e paggene scancellate",
+ "right-undelete": "Arripiglia na paggena",
+ "right-suppressrevision": "Vide, annascunne e ripiglia 'e verziune specifiche d' 'e paggene a cocherun'utente",
+ "right-viewsuppressed": "Vide 'e verziune annascunnute a coccherun'utente",
+ "right-suppressionlog": "Vide 'e riggistre private",
+ "right-block": "Blocca 'e cagnamiente 'a parte 'e l'at'utente",
+ "right-blockemail": "Blocca n'utente a mannà e-mail",
+ "right-hideuser": "Blocca n'utente e fallo sparì 'a 'o pubbreco",
+ "right-ipblock-exempt": "Ignora 'e blocche 'e l'IP, 'e blocche automatece e li blocche 'e range 'e l'IP",
+ "right-proxyunbannable": "Passa 'e blocche automatiche d' 'e proxy",
+ "right-unblockself": "Sblocca se stesso",
+ "right-protect": "Cagna 'e livelle 'e prutezione 'e cagna paggene prutette ricurzivamente",
+ "right-editprotected": "Cagna 'e paggene prutette cu \"{{int:protect-level-sysop}}\"",
+ "right-editsemiprotected": "Cagna 'e paggene prutette cu \"{{int:protect-level-autoconfirmed}}\"",
+ "right-editinterface": "Modifeca 'a nterfaccia utente",
+ "right-editusercssjs": "Cagna 'e file CSS e JS e l'at'utente",
+ "right-editusercss": "Cagna 'e file CSS 'e l'at'utente",
+ "right-edituserjs": "Cagna 'e file JS e l'at'utente",
+ "right-editmyusercss": "Cagna 'e proprie file CSS",
+ "right-editmyuserjs": "Cagna 'e proprie file JavaScript",
+ "right-viewmywatchlist": "Vide l'alenco 'e cuntrollo proprio",
+ "right-editmywatchlist": "Cagna l'alenco 'e cuntrollo proprio. Vedete ca cocch'azione putesse jògnere ancora paggene senza stu deritto.",
+ "right-viewmyprivateinfo": "Vide 'e proprie date private (e.g. e-mail, nomme overo)",
+ "right-editmyprivateinfo": "Cagna 'e date perzunale proprie (p'esempio: e-mail, nomme overo)",
+ "right-editmyoptions": "Cagna 'e preferenze proprie",
+ "right-rollback": "Annulla ampresso 'e cagnamiente 'e ll'urdem'utente c'avesse cagnato na paggena particolare",
+ "right-markbotedits": "Nzégna 'e cagnamiente suggette a rollback comme affettuate 'a nu bot",
+ "right-noratelimit": "Nun suggetto a lemmeto d'aziune",
+ "right-import": "Carreca paggene 'a n'ati wiki",
+ "right-importupload": "Carreca paggene 'a n'upload 'e file",
+ "right-patrol": "Nzegna 'e cagnamiente 'e l'ati utente comme cuntrullate",
+ "right-autopatrol": "Nzegna automatecamente 'e cagnamiente proprie comme cuntrullate",
+ "right-patrolmarks": "Vide ll'urdeme cagnamiente int' 'a funzione 'e cuntrollo",
+ "right-unwatchedpages": "Vide n'alenco 'e pagene nun cuntrullate",
+ "right-mergehistory": "Aunisce 'a cronologgia d' 'e paggene",
+ "right-userrights": "Cagna 'e deritte 'e ll'utente",
+ "right-userrights-interwiki": "Cagna 'e deritte 'e ll'utente int'a l'ati wiki",
+ "right-siteadmin": "Blocca e sblocca 'o database",
+ "right-override-export-depth": "Esporta 'e paggene azzeccanno 'e paggene cullegate nfin'a na profondità 'e 5",
+ "right-sendemail": "Manna na mail a ll'at'utente",
+ "right-passwordreset": "Vide 'e mmasciate 'e rimpustazione d' 'a password",
+ "newuserlogpage": "Riggistro 'e nuove utente",
+ "newuserlogpagetext": "Chest'è nu riggistro 'e criazione d'utenze.",
+ "rightslog": "Deritte 'e ll'utente",
+ "rightslogtext": "Ccà abbascio sta nu riggistro d' 'e cagnamiente a 'e deritte 'e ll'utente",
+ "action-read": "lieggere sta paggena",
"action-edit": "càgna chesta paggena",
+ "action-createpage": "crìa paggene",
+ "action-createtalk": "crìa chiacchiere 'e paggena",
+ "action-createaccount": "crìa stu cunto utente",
+ "action-history": "vide 'a cronologgia 'e sta paggena",
+ "action-minoredit": "nzegnà stu cagnamiento comme minore",
+ "action-move": "Spusta chista paggena",
+ "action-move-subpages": "muovere sta paggena, e le sottopaggene relative",
+ "action-move-rootuserpages": "muove 'e paggene princepale d'utente",
+ "action-move-categorypages": "muove 'e categurìe",
+ "action-movefile": "muove stu file",
+ "action-upload": "carreca stu file",
+ "action-reupload": "sovrascrive stu file esistente",
+ "action-reupload-shared": "sovrascrive stu file prisente dint'a ll'archivio condiviso",
+ "action-upload_by_url": "carreca stu file 'a n'indirizzo URL",
+ "action-writeapi": "usa l'API 'n scrittura",
+ "action-delete": "scancèlla chista paggena",
+ "action-deleterevision": "scancellà sta verziona",
+ "action-deletedhistory": "vide 'a cronologgia scancellata 'e sta paggena",
+ "action-browsearchive": "ascìa dint' 'e paggene scancellate",
+ "action-undelete": "arripiglia chista paggena",
+ "action-suppressrevision": "rivedé e arripiglià 'e cagnamiente annascunnute",
+ "action-suppressionlog": "vide stu riggistro privato",
+ "action-block": "blocca 'e cagnamiente 'a parte 'e st'utente",
+ "action-protect": "cagna 'e livelle 'e prutezione pe' sta paggena",
+ "action-rollback": "annulla ampresso 'e cagnamiente 'e ll'urdem'utente c'avesse cagnato na paggena particolare",
+ "action-import": "carreca paggene 'a n'ata wiki",
+ "action-importupload": "carreca paggene 'a n'upload 'e file",
+ "action-patrol": "nzegna 'e cagnamiente 'e l'ati utente comme cuntrullate",
+ "action-autopatrol": "nzignà 'e proprie cagnamiente comme cuntrullate",
+ "action-unwatchedpages": "vide l'alenco 'e pagene nun cuntrullate",
+ "action-mergehistory": "aunisce 'a cronologgia 'e sta paggena",
+ "action-userrights": "cagna 'e deritte 'e ll'utente",
+ "action-userrights-interwiki": "cagna 'e deritte 'e ll'utente int'a l'ati wiki",
+ "action-siteadmin": "blocca o sblocca 'o database",
+ "action-sendemail": "manna e-mail",
+ "action-editmywatchlist": "cagna l'alenco 'e cuntrolo 'o tuojo",
+ "action-viewmywatchlist": "vide l'alenco 'e cuntrollo proprio",
+ "action-viewmyprivateinfo": "vide 'e date perzunale",
+ "action-editmyprivateinfo": "cagnà 'e proprie date perzunale",
+ "nchanges": "$1 {{PLURAL:$1|cagnamiento|cagnamiente}}",
+ "enhancedrc-since-last-visit": "$1 {{PLURAL:$1|'a ll'urdema visita}}",
+ "enhancedrc-history": "cronologgia",
"recentchanges": "Urdeme nove",
"recentchanges-legend": "Opzione urdeme cagnamiénte",
- "recentchanges-summary": "Ncoppa chesta paggena song' appresentate ll'urdeme cagnamiente fatto ê cuntenute d\"o sito.",
+ "recentchanges-summary": "Ncoppa chesta paggena song' appresentate ll'urdeme cagnamiente fatte ê cuntenute d\"o sito.",
+ "recentchanges-noresult": "Nisciuno cagnamiento dint'o periodo dato ca soddisfà sti criterie.",
+ "recentchanges-feed-description": "Ncoppa chistu feed song' appresentate ll'urdeme cagnamiente fatte ê cuntenute d\"o sito.",
"recentchanges-label-newpage": "Chista modifica ha criato 'na nova paggena",
"recentchanges-label-minor": "Chisto è nu cagnamiénto piccerillo",
+ "recentchanges-label-bot": "Cagnamiento affettuato 'a nu bot",
"recentchanges-label-unpatrolled": "Chista modifica nun è stata 'ncora verificata",
+ "recentchanges-label-plusminus": "'A grannezza d' 'a paggena s'è cagnata pe' bbia 'e stu nummero 'e bytes",
+ "recentchanges-legend-heading": "'''Liggenda:'''",
+ "recentchanges-legend-newpage": "{{int:recentchanges-label-newpage}} (vide [[Special:NewPages|'e paggene nove]])",
+ "rcnotefrom": "Ccà abbascio {{PLURAL:$5|è alencato 'o cagnamiento appurtato|song' alincate 'e cagnamiente appurtate}} 'a <strong>$3, $4</strong> (mmustate nfin'a <strong>$1</strong>).",
"rclistfrom": "Faje vedé 'e cagnamiénte fatte a partì 'a $3 $2",
"rcshowhideminor": "$1 'e cagnamiénte piccerille",
+ "rcshowhideminor-show": "Faje vedé",
+ "rcshowhideminor-hide": "Annascunne",
"rcshowhidebots": "$1 'e bot",
+ "rcshowhidebots-show": "Faje vedé",
+ "rcshowhidebots-hide": "Annascunne",
"rcshowhideliu": "$1 ll'utente reggìstrate",
+ "rcshowhideliu-show": "Faje vedé",
+ "rcshowhideliu-hide": "Annascunne",
"rcshowhideanons": "$1 ll'utente anonime",
+ "rcshowhideanons-show": "Faje vedé",
+ "rcshowhideanons-hide": "Annascunne",
+ "rcshowhidepatr": "$1 cagnamiente cuntrullate",
+ "rcshowhidepatr-show": "Faje vedé",
+ "rcshowhidepatr-hide": "Annascunne",
"rcshowhidemine": "$1 'e ffatiche mmee",
+ "rcshowhidemine-show": "Faje vedé",
+ "rcshowhidemine-hide": "Annascunne",
"rclinks": "Faje vedé ll'urdeme $1 cagnamiente dint' ll'urdeme $2 juorne<br />$3",
"diff": "diff",
"hist": "cron",
"minoreditletter": "m",
"newpageletter": "N",
"boteditletter": "b",
+ "number_of_watching_users_pageview": "[osservata 'a {{PLURAL:$1|n'utente|$1 utente}}]",
+ "rc_categories": "Lemmeta a 'e categurìe (spartute 'a \"|\")",
"rc_categories_any": "Qualònca",
+ "rc-change-size-new": "$1 {{PLURAL:$1|byte|byte}} aropp'ô cagnamiento",
+ "newsectionsummary": "/* $1 */ sezziona nnova",
"rc-enhanced-expand": "Fa vede dettaglie",
"rc-enhanced-hide": "Annascunne dettaglie",
+ "rc-old-title": "origginariamente criata comme \"$1\"",
"recentchangeslinked": "Cagnamiénte cullegate",
"recentchangeslinked-feed": "Cagnamiénte cullegate",
"recentchangeslinked-toolbox": "Cagnamiénte cullegate",
"unwatchthispage": "Fjerner overvåkning",
"notanarticle": "Ikke en artikkel",
"notvisiblerev": "Revisjonen er slettet",
- "watchlist-details": "{{PLURAL:$1|Én side|$1 sider}} på din overvåkningsliste, teller ikke diskusjonssider.",
+ "watchlist-details": "Du har {{PLURAL:$1|én side|$1 sider}} på overvåkningslisten din (pluss tilhørende diskusjonssider).",
"wlheader-enotif": "E-postvarsling er slått på.",
- "wlheader-showupdated": "Sider som har blitt forandret siden du sist besøkte dem vises i '''fet tekst'''",
+ "wlheader-showupdated": "Sider som har blitt endret siden du besøkte dem sist vises i '''fet tekst'''.",
"wlnote": "Nedenfor er {{PLURAL:$1|den siste endringen|de siste <strong>$1</strong> endringene}} {{PLURAL:$2|den siste timen|de siste <strong>$2</strong> timene}}, per $3 kl. $4",
"wlshowlast": "Vis siste $1 timer $2 dager $3",
"watchlist-options": "Alternativ for overvåkningslisten",
"logentry-rights-rights-legacy": "$1 {{GENDER:$2|heeft}} het groepslidmaatschap gewijzigd voor $3",
"logentry-rights-autopromote": "$1 {{GENDER:$2|is}} automatisch gepromoveerd van $4 naar $5",
"logentry-upload-upload": "$1 heeft $3 {{GENDER:$2|geupload}}",
- "logentry-upload-overwrite": "$1 heeft een nieuwe versie van $3 {{GENDER:$2|geupload}}",
+ "logentry-upload-overwrite": "$1 {{GENDER:$2|heeft}} een nieuwe versie van $3 geüpload",
"logentry-upload-revert": "$1 heeft $3 {{GENDER:$2|geupload}}",
"rightsnone": "(geen)",
"feedback-bugornote": "Als u zover bent om een technisch probleem in detail te beschrijven, [$1 rapporteer dan een bug].\nAnders kunt u ook het eenvoudige formulier hieronder gebruiken. Uw reactie wordt dan toegevoegd aan de pagina \"[$3 $2]\", samen met uw gebruikersnaam en de browser die u gebruikt.",
"randomincategory": "Tilfeldig side frå kategori",
"randomincategory-invalidcategory": "«$1» er ikkje eit gildt kategorinamn.",
"randomincategory-nopages": "Det er ingen sider i kategorien [[:Category:$1|$1]].",
- "randomincategory-selectcategory": "Hent tilfeldig side frå kategori: $1 $2.",
- "randomincategory-selectcategory-submit": "Hent",
"randomredirect": "Tilfeldig omdirigering",
"randomredirect-nopages": "Det finst ingen omdirigeringar i namnerommet «$1».",
"statistics": "Statistikk",
"whatlinkshere-filters": "Filter",
"autoblockid": "Autoblokker #$1",
"block": "Blokker brukar",
- "unblock": "Opphev blokkeringa av brukaren",
+ "unblock": "Opphev blokkering av brukar",
"blockip": "Blokker brukar",
"blockip-legend": "Blokker brukar",
"blockiptext": "Bruk skjemaet nedanfor for å blokkere skrivetilgangen frå ei spesifikk IP-adresse eller brukarnamn. Dette bør berre gjerast for å hindre hærverk, og i samsvar med [[{{MediaWiki:Policy-url}}|retningslinene]].",
"import": "Importer sider",
"importinterwiki": "Transwikiimport",
"import-interwiki-text": "Vel ei wiki og ei side å importere. Endringssdatoer og brukarar som har medverka vert bevart. Alle transwiki-importeringar vert vist i [[Special:Log/import|importloggen]].",
- "import-interwiki-source": "Kjeldewiki/sida:",
"import-interwiki-history": "Kopier all historikken for denne sida",
"import-interwiki-templates": "Inkluder alle malar",
"import-interwiki-submit": "Importer",
"resetpass-abort-generic": "La modificacion del senhal es estada anulada per una extension.",
"resetpass-expired": "Vòstre senhal a expirat. Provesissètz-ne un novèl per vos connectar.",
"resetpass-expired-soft": "Vòstre senhal a expirat, e deu èsser reïnicializat. Causissètz-ne un novèl ara, o clicatz sus « {{int:resetpass-submit-cancel}} » per o far mai tard.",
+ "resetpass-validity-soft": "Vòstre senhal es pas valid : $1\n\nCausissètz un senhal novèl ara, o clicatz sus « {{int:resetpass-submit-cancel}} » per lo reïnicializar mai tard.",
"passwordreset": "Remesa a zèro del senhal",
"passwordreset-text-one": "Emplenatz aqueste formulari per reïnicializar vòstre senhal.",
"passwordreset-text-many": "{{PLURAL:$1|Completatz un d'aqueles camps per recebre un senhal temporari per corrièr electronic.}}",
"preview": "Previsualizar",
"showpreview": "Previsualizacion",
"showdiff": "Veire los cambiaments",
+ "blankarticle": "<strong>Atencion :</strong> La pagina que creatz es voida.\nSe clicatz tornarmai sus « {{int:savearticle}} », la pagina serà creada sens cap de contengut.",
"anoneditwarning": "'''Atencion :''' sètz pas identificat(ada).\nVòstra adreça IP serà enregistrada dins l’istoric d'aquesta pagina.",
"anonpreviewwarning": "''Sètz pas identificat. Salvar enregistrarà vòstra adreça IP dins l’istoric de las modificacions de la pagina.''",
"missingsummary": "'''Atencion :''' avètz pas modificat lo resumit de vòstra modificacion. Se clicatz tornarmai sul boton « Salvar », lo salvament serà fach sens avertiment mai.",
"revdelete-selected-text": "{{PLURAL:$1|Revision seleccionada|Revisions seleccionadas}} de [[:$2]] :",
"revdelete-selected-file": "{{PLURAL:$1|Version de fichièr seleccionada|Versions de fichièr seleccionadas}} de [[:$2]] :",
"logdelete-selected": "{{PLURAL:$1|Eveniment d'istoric seleccionat|Eveniments d'istoric seleccionats}} :",
+ "revdelete-text-text": "Las revisions suprimidas contunharàn d'aparéisser dins l’istoric de la pagina, mas una partida de lor contengut serà inaccessibla al public.",
+ "revdelete-text-file": "Las versions de fichièr suprimidas contunharàn d'aparéisser dins l’istoric dels fichièrs, mas una partida de lor contengut serà indisponibla al public.",
+ "logdelete-text": "Los eveniments del jornal suprimits contunharàn d'aparéisser dins los jornals, mas una partida de lor contengut serà indisponibla al public.",
+ "revdelete-text-others": "Los autres administrators seràn totjorn en mesura d'accedir al contengut amagat e de lo restablir, levat se de restriccions suplementàrias son fixadas.",
"revdelete-confirm": "Confirmatz que volètz efectuar aquesta accion, que ne comprenètz las consequéncias, e qu'o fasètz en acòrd amb [[{{MediaWiki:Policy-url}}|las règlas]].",
"revdelete-suppress-text": "La supression deu èsser utilizada '''sonque''' dins los cases seguents :\n* Informacions potencialament difamatòrias\n* Informacions personalas inapropriadas\n*: ''adreça, numèro de telefòn, numèro de seguretat sociala, ...''",
"revdelete-legend": "Metre en plaça de restriccions de version :",
"mergehistory-empty": "Cap de revision pòt pas èsser fusionada.",
"mergehistory-success": "$3 {{PLURAL:$3|revision|revisions}} de [[:$1]] {{PLURAL:$3|fusionada|fusionadas}} amb succès amb [[:$2]].",
"mergehistory-fail": "Impossible de procedir a la fusion dels istorics. Seleccionatz tornamai la pagina e mai los paramètres de data.",
+ "mergehistory-fail-toobig": "Impossible d’efectuar la fusion de l’istoric perque un nombre de {{PLURAL:$1|revisions}} superior al limit de $1 deuriá èsser desplaçat.",
"mergehistory-no-source": "La pagina d'origina $1 existís pas.",
"mergehistory-no-destination": "La pagina de destinacion $1 existís pas.",
"mergehistory-invalid-source": "La pagina d’origina deu aver un títol valid.",
"editundo": "desfar",
"diff-empty": "(Pas cap de diferéncia)",
"diff-multi-sameuser": "({{PLURAL:$1|Una revision intermediària pel meteis utilizaire pas afichada|$1 revisions intermediàrias pel meteis utilizaire pas afichadas}})",
+ "diff-multi-otherusers": "({{PLURAL:$1|Una revision intermediària|$1 revisions intermediàrias}} per {{PLURAL:$2|un autre utilizaire|$2 utilizaires}} pas {{PLURAL:$1|afichada|afichadas}})",
"diff-multi-manyusers": "({{PLURAL:$1|Una revision intermediària amagada|$1 revisions intermediàrias amagadas}}) per ({{PLURAL:$2|un utilizaire pas afichada|$2 utilizaires pas afichadas}})",
"difference-missing-revision": "{{PLURAL:$2|Una revision|$2 revisions}} d'aquesta diferéncia ($1) {{PLURAL:$2|es pas estada trobada|son pas estadas trobadas}}.\n\nAquò se produtz en general en seguent un ligam de diferéncia obsolèta cap a una pagina qu'es estada suprimada.\nPodètz trobar de detalhs dins lo [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} jornal de las supressions].",
"searchresults": "Resultats de la recèrca",
"prefs-tokenwatchlist": "Geton",
"prefs-diffs": "Diferéncias",
"prefs-help-prefershttps": "Aquesta preferéncia serà efectiva al moment de vòstra connexion que ven.",
+ "prefs-tabs-navigation-hint": "Astúcia : Podètz utilizar las flèchas d'esquèrra e de drecha per navigar entre los onglets.",
"email-address-validity-valid": "L'adreça electronica sembla bona",
"email-address-validity-invalid": "entrar una adreça electronica valida",
"userrights": "Gestion dels dreches d'utilizaire",
"fileexists-shared-forbidden": "Un fichièr amb lo meteis nom existís ja dins la banca de donadas comuna.\nS'o volètz importar tornamai, tornatz en rèire e importatz-lo jos un autre nom. [[File:$1|thumb|center|$1]]",
"file-exists-duplicate": "Aqueste fichièr es un doble {{PLURAL:$1|del fichièr seguent|dels fichièrs seguents}} :",
"file-deleted-duplicate": "Un fichièr identic a aqueste ([[:$1]]) ja es estat suprimit. Vos caldriá verificar lo jornal de las supressions d'aqueste fichièr abans de la tornar telecargar.",
+ "file-deleted-duplicate-notitle": "Un fichièr identic a aqueste fichièr es ja estat suprimit amai lo títol. \nVos caldriá demandar a qualqu'un la possibilitat de verificar lo jornal d'aqueste fichièr suprimit per tal d'examinar la situacion abans de l'importar tornarmai.",
"uploadwarning": "Atencion !",
"uploadwarning-text": "Modificatz la descripcion del fichièr e ensajatz tornarmai.",
"savefile": "Salvar lo fichièr",
"addedwatchtext-short": "La pagina « $1 » es estada aponduda a vòstra lista de seguiment.",
"removewatch": "Suprimir de la lista de seguiment",
"removedwatchtext": "La pagina « [[:$1]] » es estada levada de vòstra [[Special:Watchlist|lista de seguiment]].",
+ "removedwatchtext-short": "La pagina « $1 » es estada suprimida de vòstra lista de seguiment.",
"watch": "Seguir",
"watchthispage": "Seguir aquesta pagina",
"unwatch": "Arrestar de seguir",
"delete-edit-reasonlist": "Modifica los motius de la supression",
"delete-toobig": "Aquesta pagina dispausa d'un istoric important, depassant {{PLURAL:$1|revision|revisions}}.\nLa supression de talas paginas es estada limitada per evitar de perturbacions accidentalas de {{SITENAME}}.",
"delete-warning-toobig": "Aquesta pagina dispausa d'un istoric important, depassant {{PLURAL:$1|revision|revisions}}.\nLa suprimir pòt perturbar lo foncionament de la banca de donada de {{SITENAME}}.\nD'efectuar amb prudéncia.",
+ "deleteprotected": "Podètz pas suprimir aquesta pagina perque es estada protegida.",
"rollback": "Anullar las modificacions",
"rollback_short": "Anullar",
"rollbacklink": "anullar",
"movenotallowedfile": "Avètz pas la permission de desplaçar los fichièrs.",
"cant-move-user-page": "Avètz pas la permission de tornar nomenar de paginas d'utilizaires raices sus aqueste wiki.",
"cant-move-to-user-page": "Avètz pas la permission de tornar nomenar una pagina cap a una pagina d'utilizaire (a l'excepcion d'una sospagina).",
+ "cant-move-category-page": "Avètz pas la permission de renomenar las paginas de categorias.",
"newtitle": "Títol novèl",
"move-watch": "Seguir aquesta pagina",
"movepagebtn": "Tornar nomenar l'article",
"userlogin-resetlink": "A l'ha dësmentià ij sò detaj për intré ant ël sistema?",
"userlogin-resetpassword-link": "Ciav dësmentià?",
"userlogin-helplink2": "Agiut a la conession",
- "userlogin-loggedin": "A l'é già rintrà an ël sistema tanme {{GENDER:$1|$1}}.\nCh'a deuvra ël formolari sì-sota për rintré coma n'àutr n'utent.",
- "userlogin-createanother": "Creé n'àutr cont",
"createacct-emailrequired": "Adrëssa ëd pòsta eletrònica",
"createacct-emailoptional": "Adrëssa ëd pòsta eletrònica (opsional)",
"createacct-email-ph": "Ch'a buta soa adrëssa ëd pòsta eletrònica",
"showpreview": "Mostré na preuva",
"showdiff": "Smon-me le modìfiche",
"blankarticle": "<strong>Atension:</strong> La pàgina ch'a l'ha creà a l'é veuida. S'a sgnaca torna «{{int:savearticle}}», la pàgina a sarà creà sensa contnù.",
- "anoneditwarning": "'''Atension:''' A l'é nen rintrà ant ël sistema. Soa adrëssa IP a sarà registrà ant la stòria dle modìfiche ëd sa pàgina.",
+ "anoneditwarning": "<strong>Atension:<strong> A l'é nen rintrà ant ël sistema. Soa adrëssa IP a së sc-iairërà s'a fà dle modìfiche. Si chiel a <strong>[$1 rintra ant ël sistema]</strong> o <strong>[$2 a crea an cont]</strong>, soe modìfiche a saran atribuìe a sò stranòm, ansema a d'àutri vantagg.",
"anonpreviewwarning": "''A l'é nen rintrà ant ël sistema. An salvand a sarà memorisà soa adrëssa IP ant la stòria dle modìfiche ëd sa pàgina.''",
"missingsummary": "'''Nòta:''' a l'ha butà gnun resumé dla modìfica. Se a sgnaca «{{int:savearticle}}» n'àutra vira, soa modìfica a resterà salvà sensa resumé.",
"missingcommenttext": "Për piasì, che a buta un coment sì-sota.",
"filedelete-maintenance": "Lë scancelament e la restaurassion d'archivi a l'é al moment disabilità durant la manutension.",
"filedelete-maintenance-title": "As peul pa scancelesse l'archivi",
"mimesearch": "Arserca për sòrt MIME",
- "mimesearch-summary": "Sta pàgina-sì a lassa filtré j'archivi për sòrt MIME. Buté: sòrt/sotasòrt, pr'es. <code>image/jpeg</code>.",
+ "mimesearch-summary": "Sta pàgina-sì a lassa filtré j'archivi për sòrt MIME. Buté: sòrt/sotasòrt o sòrt/*, pr'es. <code>image/jpeg</code>.",
"mimetype": "Sòrt MIME:",
"download": "dëscarié",
"unwatchedpages": "Pàgine che gnun a ten sot-euj",
"randomincategory": "Pàgina a l'ancàpit ant la categorìa",
"randomincategory-invalidcategory": "«$1» a l'é pa un nòm ëd categorìa bon.",
"randomincategory-nopages": "A-i é gnun-e pàgine ant la categorìa [[:Category:$1|$1]].",
+ "randomincategory-category": "Categorìa:",
"randomredirect": "Na ridiression qualsëssìa",
"randomredirect-nopages": "A-i é pa gnun-a ridiression ant lë spassi nominal \"$1\".",
"statistics": "Statìstiche",
"showpreview": "Antever resultado",
"showdiff": "Mostrar alterações",
"blankarticle": "<strong>Aviso:</strong> A página que está prestes a criar está em branco. \nSe clicar \"{{int:savearticle}}\" outra vez, a página será criada sem qualquer conteúdo.",
- "anoneditwarning": "'''Aviso''': Não iniciou sessão.\nO seu endereço IP será registado no histórico de edições desta página.",
+ "anoneditwarning": "<strong>Aviso</strong>: Não iniciou sessão. O seu endereço IP será registado no histórico de edições desta página. Se <strong>[$1 iniciar sessão]</strong> ou <strong>[$2 criar uma conta]</strong>, as suas edições serão registadas com o seu nome de utilizador(a), bem como usufruir de outros benefícios.",
"anonpreviewwarning": "''Não iniciou sessão. Ao gravar, registará o seu endereço IP no histórico de edições da página.''",
"missingsummary": "'''Atenção:''' Não introduziu um resumo da edição.\nSe clicar novamente \"Gravar página\" a sua edição será gravada sem resumo.",
"missingcommenttext": "Introduza um comentário abaixo, por favor.",
"lockfilenotwritable": "'No longer needed' on wikipedia.",
"databasenotlocked": "Used as error message in [[Special:UnlockDB]].\nThe title of this error message is {{msg-mw|Lockdb}}.\n\nSee also:\n* {{msg-mw|Lockdb|title}}\n* {{msg-mw|Databasenotlocked|message}}",
"lockedbyandtime": "Used as part of the message when a database is locked through [[Special:LockDB]]. Parameters:\n* $1 is the user that locked the database.\n* $2 is the date on which the lock was made\n* $3 is the time at which the lock was made",
- "move-page": "Used as page title of [[Special:MovePage]] to move pages.\n\nSee example: [[Special:MovePage/Portal:En]].\n\nParameters:\n* $1 - the name of the page to be moved (without link)",
+ "move-page": "Used as page title of [[Special:MovePage]] to move pages.\n\nSee example: [[Special:MovePage/Portal:En]].\n\nParameters:\n* $1 - the name of the page to be moved (without link)\n{{Identical|Move}}",
"movepage-summary": "{{doc-specialpagesummary|movepage}}",
"move-page-legend": "Legend of the fieldset around the input form of [[Special:MovePage/testpage]].\n\nSee also:\n* {{msg-mw|movearticle|label for old title}}\n* {{msg-mw|newtitle|label for new title}}\n* {{msg-mw|movereason|label for textarea}}\n* {{msg-mw|movetalk|label for checkbox}}\n* {{msg-mw|move-leave-redirect|label for checkbox}}\n* {{msg-mw|fix-double-redirects|label for checkbox}}\n* {{msg-mw|move-subpages|label for checkbox}}\n* {{msg-mw|move-talk-subpages|label for checkbox}}\n* {{msg-mw|move-watch|label for checkbox}}\n{{Identical|Move page}}",
"movepagetext": "Introduction shown when moving a page ([[Special:MovePage]]).\n\nSpecial pages mentioned: {{msg-mw|Doubleredirects}}, {{msg-mw|Brokenredirects}}\n\nSee also:\n* {{msg-mw|Movepagetext-noredirectfixer}}",
"showpreview": "Previzualizare",
"showdiff": "Afișare diferențe",
"blankarticle": "<strong>Atenție:</strong> Pagina pe care o creați este goală.\nDacă faceți din nou clic pe „{{int:savearticle}}”, pagina va fi creată fără niciun conținut.",
- "anoneditwarning": "'''Atenție:''' Nu v-ați autentificat. Adresa IP vă va fi înregistrată în istoricul acestei pagini.",
+ "anoneditwarning": "<strong>Atenție:</strong> Nu v-ați autentificat. Adresa dumneavoastră IP va fi vizibilă în mod public dacă efectuați modificări. Dacă vă <strong>[$1 autentificați]</strong> sau vă <strong>[$2 creați un cont]</strong>, modificările dumneavoastră vor fi asociate numelui de utilizator, pe lângă alte beneficii.",
"anonpreviewwarning": "''Nu v-ați autentificat. Dacă salvați pagina adresa dumneavoastră IP va fi înregistrată în istoric.''",
"missingsummary": "'''Atenție:''' Nu ați completat caseta „descriere modificări”. Dacă apăsați din nou butonul „salvează pagina” modificările vor fi salvate fără descriere.",
"missingcommenttext": "Vă rugăm să introduceți un comentariu.",
"showpreview": "Предварительный просмотр",
"showdiff": "Внесённые изменения",
"blankarticle": "<strong>Предупреждение:</strong> Страница, которую вы создаёте, пуста.\nЕсли снова нажмёте кнопку «{{int:savearticle}}», страница будет создана без какого-либо содержания.",
- "anoneditwarning": "'''Внимание!''' Вы не авторизовались на сайте.\nВ истории изменений этой страницы будет записан ваш IP-адрес.",
+ "anoneditwarning": "<strong>Внимание!</strong> Вы не авторизовались на сайте. Ваш IP-адрес будет публично видимым, если вы будете вносить любые правки. Если вы <strong>[$1 войдёте]</strong> или <strong>[$2 создадите учётную запись]</strong>, правки вместо этого будут связаны с вашим именем пользователя, а также у вас появятся другие преимущества.",
"anonpreviewwarning": "''Вы не представились системе. Сохранение приведёт к записи вашего IP-адреса в историю изменений страницы.''",
"missingsummary": "'''Напоминание.''' Вы не дали краткого описания изменений. При повторном нажатии на кнопку «{{int:savearticle}}», ваши изменения будут сохранены без комментария.",
"missingcommenttext": "Пожалуйста, введите ниже ваше сообщение.",
"pageinfo-hidden-categories": "{{PLURAL:$1|1=Скрытая категория|Скрытых категорий}} ($1)",
"pageinfo-templates": "{{PLURAL:$1|1=Шаблон|Шаблонов}} ($1)",
"pageinfo-transclusions": "{{PLURAL:$1|1=Включаемая страница|Включаемых страниц}} ($1)",
- "pageinfo-toolboxlink": "Сведения о странице",
+ "pageinfo-toolboxlink": "Сведения о странице",
"pageinfo-redirectsto": "Перенаправление",
"pageinfo-redirectsto-info": "сведения",
"pageinfo-contentpage": "Учитывается счётчиком как содержательная страница",
"category_header": "Pàginas in sa categoria \"$1\"",
"subcategories": "Subcategorias",
"category-media-header": "Mèdios in sa categoria \"$1\"",
- "category-empty": "''In custa categoria non b't peruna pàgina o mèdiu.''",
+ "category-empty": "''In custa categoria non b'at peruna pàgina o mèdiu.''",
"hidden-categories": "{{PLURAL:$1|Categoria cuada|Categorias cuadas}}",
"hidden-category-category": "Categorias cuadas",
"category-subcat-count": "{{PLURAL:$2|Custa categoria cuntenet un'ùnica subcategoria ammustrada in suta.|Custa categoria cuntenet {{PLURAL:$1|sa subcategoria inditada|$1 subcategorias inditadas}} in suta, de $2 totales.}}",
"hidetoc": "cua",
"collapsible-collapse": "Serra e istringhe",
"collapsible-expand": "Aberi",
+ "confirmable-confirm": "Ses {{GENDER:$1|seguru|segura}}?",
"confirmable-yes": "Eja",
"confirmable-no": "No",
"thisisdeleted": "Càstiare o recuperare $1?",
"formerror": "Errore: impossìbile imbiare su modellu",
"badarticleerror": "Operatzione non cunsentida pro custa pàgina.",
"cannotdelete": "No est stadu possìbile burrare sa pàgina o su file \"$1\".\nPodet èsser stadu burradu dae calicunu àteru.",
+ "cannotdelete-title": "Impossìbile burrare sa pàgina \"$1\"",
"badtitle": "Tìtulu malu",
"badtitletext": "Su tìtulu de sa pàgina ch'as pediu est bùidu, isballiau, o iscritu in is cullegamentus inter-wiki in manera non currègia o cun caràteres no amìtius.",
"viewsource": "Càstia mitza",
"viewsource-title": "Càstia sa mitza de $1",
"actionthrottled": "Atzione rimandada",
+ "viewsourcetext": "Podes bìere o copiare su còdighe mitza de custa pàgina:",
"namespaceprotected": "Non tenes su permissu de cambiare is pàginas in su nùmene-lugu '''$1'''.",
+ "customcssprotected": "Non tenes sos permissos pro cambiare custa pàgina CSS proite cuntènnidi sas impostaduras pessonales de un'àteru impitadore.",
+ "customjsprotected": "Non tenes sos permissos pro cambiare custa pàgina JavaScript proite cuntènnidi sas impostaduras pessonales de un'àteru impitadore.",
+ "mycustomcssprotected": "Non tenes sos permissos pro cambiare custa pàgina CSS.",
+ "mycustomjsprotected": "Non tenes sos permissos pro cambiare custa pàgina JavaScript.",
"ns-specialprotected": "Is pàginas ispetziales non podent èssere acontzadas.",
+ "titleprotected": "Sa creatzione de una pàgina cun custu tìtulu est istada arreada dae [[User:$1|$1]].\nSa motivatzione est \"<em>$2</em>\".",
"exception-nologin": "Non ses intrau",
+ "exception-nologin-text": "Pro atzèdere a custa pàgina o atzione est netzessàriu a ti identificare.",
"virus-scanfailed": "scansione faddida (còdixe $1)",
"virus-unknownscanner": "antivirus disconnotu:",
"logouttext": "<strong>As acabadu sa sessione.</strong>\n\nTene contu ca is pàginas ki sunt giai abertas in àteras bentanas podent sighire a pàrrer comente cando fias identificadu, fintzas a cando non ddas renfriscas dae su browser tuo.",
"createacct-yourpasswordagain": "Cunfirma sa password",
"createacct-yourpasswordagain-ph": "Inserta sa password torra",
"remembermypassword": "Ammenta sa paràula de òrdine in custu carculadore (pro unu màssimu de $1 {{PLURAL:$1|die|dies}})",
+ "userlogin-remembermypassword": "Mantènnemi cullegadu",
+ "userlogin-signwithsecure": "Imprea una cunnessione segura",
"yourdomainname": "Ispetzìfica su domìniu",
+ "password-change-forbidden": "Non podes cambiare sa password in custa wiki.",
"login": "Intra",
"nav-login-createaccount": "Intra / crea contu",
"userlogin": "Intra / crea contu",
"createaccount": "Crea contu",
"gotaccount": "Tenes giai unu contu? $1.",
"gotaccountlink": "Identìfica·ti",
+ "userlogin-resetpassword-link": "As ismentigadu sa password?",
+ "userlogin-helplink2": "Agiudu pro s'atzessu",
"createacct-emailrequired": "Indirutzu Email",
"createacct-emailoptional": "Indiritzu email (optzionale)",
"createacct-email-ph": "Inserta s'indiritzu email tuo",
"userexists": "Su nùmene impitadore insertadu est giai impreadu.\nSèbera unu nùmene diferente.",
"loginerror": "Faddina de identificatzione",
"createacct-error": "Faddina in sa creatzione de su contu",
+ "createaccounterror": "Impossìbile creare su contu: $1",
+ "nocookiesnew": "Su contu de s'impitadore est istadu creadu, ma no est istadu possìbile fàghere s'atzessu a {{SITENAME}} proite sos \"cookies\" sunt deativados.\nTorra a proare a pustis de los àere ativados.",
"noname": "Su nùmene impitadore insertadu no est vàlidu.",
"loginsuccesstitle": "Ti ses identificadu",
"loginsuccess": "'''Immoe ses intradu in {{SITENAME}} cun su nùmene impitadore \"$1\".'''",
"nosuchuser": "Non b'at impitadore cun su nùmene \"$1\".\nIs nùmenes impitadore sunt sensìbiles a is lìteras mannas.\nVerìfica su nùmene insertadu o [[Special:UserLogin/signup|crea unu contu nou]].",
"nouserspecified": "Depes ispetzificare unu nùmene impitadore.",
+ "login-userblocked": "{{GENDER:$1|Custu impitadore est arreadu|Custa impidadora est arreada}}. Atzessu impossìbile.",
"wrongpassword": "Sa paràula de òrdine insertada no est bona. Prova torra.",
"wrongpasswordempty": "No as iscritu sa paràula de òrdine.\nProva torra.",
"passwordtooshort": "Is passwords depent tènner a su mancu {{PLURAL:$1|1 caràtere|$1 caràteres}}.",
"password-name-match": "Sa password tua depet èsser diferente dae su nùmene impitadore tuo.",
+ "password-login-forbidden": "S'impreau de custu nùmene impitadore e de custa password est istadu proibidu.",
"mailmypassword": "Resetta sa password",
"passwordremindertitle": "Servìtziu Password Reminder de {{SITENAME}}",
"passwordremindertext": "Calicunu (probabilmenti tue, cun s'indiritzu IP $1) at pediu de arritziri una password noa pro intrare a {{SITENAME}} ($4).\nUna password temporanea pro s'impitadore \"$2\" est istada impostada a \"$3\".\nChi custu fiat ne is intentziones tuas, depis intrare (log in) e scioberari una password noa.\nSa password temporanea tua at a iscadiri in {{PLURAL:$5|una die|$5 dies}}.\n\nChi non ses istadu a pediri sa password, o chi as torrau a agatare sa password torra e non da depis cambiari prus, non cunsideras custu messagiu e sighi a impreare sa password beccia.",
"preview": "Antiprima",
"showpreview": "Ammustra s'antiprima",
"showdiff": "Ammustra is càmbios",
- "anoneditwarning": "'''Dae cara:''' Non ses identificadu (log in).\nS'indiritzu IP tuo at a èssere registradu in s'istòria de custa pàgina.",
+ "anoneditwarning": "<strong>Dae cara:</strong> Non ses identificadu.\nS'indiritzu IP tuo at a èssere annòtidu si faghes unos cantos càmbios. Si <strong>idendificas</strong> tibe o <strong>[$2 creas unu contu]</strong>, is càmbios tuos ant a esser marcados cun su nùmene impitadore tuo, paris a àteros giuamentos.",
"anonpreviewwarning": "''Non ses identificadu. Sarvende s'indiritzu IP tuo at a èssere registradu in s'istòria de sa pàgina.''",
"missingcommenttext": "Inserta unu cummentu inoghe suta.",
"summary-preview": "Antiprima ogetu:",
"histlast": "ùrtima",
"historysize": "({{PLURAL:$1|1 byte|$1 bytes}})",
"historyempty": "(bùida)",
+ "history-feed-title": "Istòria de is revisiones",
+ "history-feed-description": "Istòria de is revisiones de sa pàgina in custa wiki",
"history-feed-item-nocomment": "$1 su $2",
+ "rev-deleted-user": "(nùmene impitadore bogadu)",
"rev-delundel": "ammustra/cua",
"rev-showdeleted": "ammustra",
"revdelete-no-file": "Su documentu ispetzuficadu no esistit",
"revdelete-show-file-submit": "Eja",
"revdelete-radio-set": "Cua",
+ "revdelete-radio-unset": "Ammustra",
"revdelete-log": "Motivu:",
"revdel-restore": "Muda sa visibilidade",
"pagehist": "Istòria de sa pàgina",
"timezoneregion-antarctica": "Antàrtide",
"timezoneregion-arctic": "Àrtide",
"timezoneregion-asia": "Àsia",
+ "timezoneregion-atlantic": "Otzèanu Atlànticu",
"timezoneregion-australia": "Austràlia",
"timezoneregion-europe": "Europa",
+ "timezoneregion-indian": "Otzèanu Indianu",
+ "timezoneregion-pacific": "Otzèanu Patzìficu",
"prefs-searchoptions": "Chirca",
"prefs-namespaces": "Nùmene-logos",
"prefs-files": "Files",
+ "prefs-emailconfirm-label": "Cunfirma de sa email:",
"youremail": "E-mail:",
"username": "{{GENDER:$1|Nùmene impitadore}}:Nùmene impitadore",
"prefs-registration": "Ora de registratzione:",
"yourrealname": "Nùmene beru:",
"yourlanguage": "Limba:",
"yournick": "Sa firma tua:",
- "yourgender": "Natura:",
- "gender-unknown": "Non spetzificadu",
- "gender-male": "Mascu",
- "gender-female": "Fèmina",
+ "yourgender": "Comente preferes a ti descrir?",
+ "gender-unknown": "Preferu a no ddu narrer",
+ "gender-male": "Issu càmbiat pàginas wiki",
+ "gender-female": "Issa càmbiat pàginas wiki",
"email": "E-mail",
"prefs-info": "Informatzione bàsica",
"prefs-signature": "Firma",
"emailsent": "E-mail ispedia",
"emailsenttext": "Sa e-mail tua est istada imbiada.",
"usermessage-editor": "Missu de su sistema",
- "watchlist": "Sa watchlist mea",
+ "watchlist": "Pàginas annotadas",
"mywatchlist": "Pàginas annotadas",
"watchlistfor2": "Pro $1 $2",
"nowatchlist": "No as indicadu pàginas in sa watchlist tua.",
"unwatch": "Tira dae sa watchlist",
"unwatchthispage": "Boga custa pàgina dae sa watchlist tua",
"notanarticle": "Custa pàgina no est unu artìculu",
- "watchlist-details": "Sa watchlist tua cuntènnit {{PLURAL:$1|$1 pàgina|$1 pàginas}}, chentza contare is pàginas de cuntierras.",
+ "watchlist-details": "Tenes {{PLURAL:$1|$1 pàgina annotada paris a sa pagina de cuntierra sua|$1 pàginas annotadas paris a is pàginas de cuntierra issoro}}.",
"wlshowlast": "Ammustra is ùrtimas $1 oras $2 dies $3",
"watchlist-options": "Possibilidades subra sa watchlist",
"watching": "Giunghende a sa watchlist...",
"showpreview": "Prikaži predogled",
"showdiff": "Prikaži spremembe",
"blankarticle": "<strong>Opozorilo:</strong> Stran, ki jo ustvarjate, je prazna.\nČe ponovno kliknete »{{int:savearticle}}«, bomo stran ustvarili brez kakršne koli vsebine.",
- "anoneditwarning": "'''Opozorilo''': niste prijavljeni. V zgodovino strani se bo zapisal vaš IP-naslov.",
+ "anoneditwarning": "<strong>Opozorilo:</strong> Niste prijavljeni. Vaš IP-naslov bo javno viden, če naredite kakršno koli urejanje. Če se <strong>[$1 prijavite]</strong> ali <strong>[$2 ustvarite račun]</strong>, bodo vaša urejanja pripisana vašemu uporabniškemu imenu skupaj z drugimi prednostmi.",
"anonpreviewwarning": "Niste prijavljeni. Ob spremembi strani se bo vaš IP-naslov zapisal v zgodovini urejanja te strani.",
"missingsummary": "'''Opozorilo:''' Niste napisali povzetka urejanja. Ob ponovnem kliku gumba ''Shrani'' se bo vaše urejanje shranilo brez njega.",
"missingcommenttext": "Prosimo, vpišite v spodnje polje komentar.",
"subject-preview": "Преглед теме/наслова:",
"blockedtitle": "Корисник је блокиран",
"blockedtext": "<strong>Ваше корисничко име или ИП адреса је блокирана.</strong>\n\nБлокирање је {{GENDER:$4|извршио|извршила}} $1.\nРазлог: <em>$2</em>.\n\n* Датум блокирања: $8\n* Блокирање истиче: $6\n* Име корисника: $7\n\nОбратите се {{GENDER:$4|кориснику|корисници}} $1 или [[{{MediaWiki:Grouppage-sysop}}|администратору]] да разјасните ствар.\nНе можете користити могућност „Пошаљи поруку овом кориснику“ ако нисте унели исправну е-адресу у [[Special:Preferences|подешавањима]].\nВаша блокирана ИП адреса је $3, а ID блокирања $5.\nНаведите све податке изнад при стварања било каквих упита.",
- "autoblockedtext": "Ваша ИП адреса је блокирана јер ју је употребљавао други корисник, кога је {{GENDER:$1|блокирао|блокирала|блокирао}} $1.\nРазлог:\n\n:''$2''\n\n* Датум блокирања: $8\n* Блокирање истиче: $6\n* Име корисника: $7\n\nОбратите се {{GENDER:$1|кориснику|корисници|кориснику}} $1 или [[{{MediaWiki:Grouppage-sysop}}|администратору]] да разјасните ствар.\n\nНе можете користити могућност „Пошаљи поруку овом кориснику“ ако нисте унели исправну е-адресу у [[Special:Preferences|подешавањима]].\n\nВаша блокирана ИП адреса је $3, а ИБ $5.\nНаведите све податке изнад при стварању било каквих упита.",
+ "autoblockedtext": "Ваша ИП адреса је блокирана јер ју је употребљавао други корисник, кога је {{GENDER:$4|блокирао|блокирала}} $1.\nРазлог:\n\n:<em>$2</em>\n\n* Датум блокирања: $8\n* Блокирање истиче: $6\n* Име корисника: $7\n\nОбратите се {{GENDER:$4|кориснику|корисници}} $1 или [[{{MediaWiki:Grouppage-sysop}}|администратору]] да разјасните ствар.\n\nНе можете користити могућност „Пошаљи поруку овом кориснику“ ако нисте унели исправну е-адресу у [[Special:Preferences|подешавањима]].\n\nВаша блокирана ИП адреса је $3, а ID $5.\nНаведите све податке изнад при стварању било каквих упита.",
"blockednoreason": "разлог није наведен",
"whitelistedittext": "За уређивање странице је потребно да будете $1.",
"confirmedittext": "Морате да потврдите своју е-адресу пре уређивања страница.\nПоставите и потврдите адресу преко [[Special:Preferences|подешавања]].",
"undo-summary": "Поништена измена $1 {{GENDER:$2|корисника|кориснице}} [[Special:Contribs/$2|$2]] ([[User talk:$2|разговор]])",
"undo-summary-username-hidden": "Поништи измену $1 скривеног корисника",
"cantcreateaccounttitle": "Не могу да отворим налог",
- "cantcreateaccount-text": "Отварање налога с ове IP адресе ('''$1''') је {{GENDER:$3|блокирао|блокирала|блокирао}} [[User:$3|$3]].\n\nРазлог који је навео {{GENDER:$3|корисник|корисница|корисник}} $3 је ''$2''",
+ "cantcreateaccount-text": "Отварање налога с ове IP адресе (<strong>$1</strong>) је блокирао/ла [[User:$3|$3]].\n\nРазлог који је навео/ла $3 је <em>$2</em>",
+ "cantcreateaccount-range-text": "Отварање налога са IP адреса у распону '''$1''', који укључује и вашу IP адресу ('''$4''') је блокирао/ла [[User:$3|$3]].\n\nРазлог који је навео/ла $3 је <em>$2</em>",
"viewpagelogs": "Погледај дневнике ове странице",
"nohistory": "Не постоји историја измена ове странице.",
"currentrev": "Текућа измена",
"exbeforeblank": "садржај пре брисања је био: „$1“",
"delete-confirm": "Брисање странице „$1“",
"delete-legend": "Обриши",
- "historywarning": "<strong>Упозорење:</strong> страница коју желите да обришете има историју с приближно $1 {{PLURAL:$1|изменом|измене|измена}}:",
+ "historywarning": "<strong>Упозорење:</strong> страница коју желите да обришете има историју са $1 {{PLURAL:$1|изменом|измене|измена}}:",
"confirmdeletetext": "Управо ћете обрисати страницу, укључујући и њену историју.\nПотврдите своју намеру, да разумете последице и да ово радите у складу с [[{{MediaWiki:Policy-url}}|правилима]].",
"actioncomplete": "Радња је завршена",
"actionfailed": "Радња није успела",
"emaillink": "пошаљи е-поруку",
"autoblocker": "Аутоматски сте блокирани јер делите ИП адресу с корисником/цом [[User:$1|$1]].\nРазлог блокирања: „$2“",
"blocklogpage": "Дневник блокирања",
- "blocklog-showlog": "{{GENDER:$1|Овај корисник је раније блокиран|Ова корисница је раније блокирана|Овај корисник је раније блокиран}}.\nИсторија блокирања се налази испод:",
- "blocklog-showsuppresslog": "{{GENDER:|Овај корисник је раније блокиран и сакривен|Ова корисница је раније блокирана и сакривена|Овај корисник је раније блокиран и сакривен}}.\nИсторија сакривања се налази испод:",
+ "blocklog-showlog": "{{GENDER:$1|Овај корисник је раније блокиран|Ова корисница је раније блокирана}}.\nИсторија блокирања се налази испод:",
+ "blocklog-showsuppresslog": "{{GENDER:$1|Овај корисник је раније блокиран и сакривен|Ова корисница је раније блокирана и сакривена}}.\nИсторија сакривања се налази испод:",
"blocklogentry": "је блокирао [[$1]] с роком истицања од $2 $3",
"reblock-logentry": "{{GENDER:|је променио|је променила|је променио}} подешавања за блокирање {{GENDER:$1|корисника|кориснице|корисника}} [[$1]] с роком истека од $2 ($3)",
"blocklogtext": "Ово је дневник блокирања и деблокирања корисника.\nАутоматски блокиране ИП адресе нису наведене.\nТекуће забране и блокирања можете наћи [[Special:BlockList|овде]].",
"scarytranscludefailed-httpstatus": "[Не могу да преузмем шаблон $1: HTTP $2]",
"scarytranscludetoolong": "[URL адреса је предугачка]",
"deletedwhileediting": "<strong>Упозорење</strong>: ова страница је обрисана након што сте почели с уређивањем!",
- "confirmrecreate": "[[User:$1|$1]] ([[User talk:$1|разговор]]) {{GENDER:$1|је обрисао|је обрисала|обриса}} ову страницу након што сте почели да је уређујете из следећег разлога:\n: ''$2''\nПотврдите да стварно желите да направите страницу.",
+ "confirmrecreate": "Корисник [[User:$1|$1]] ([[User talk:$1|разговор]]) је обрисао ову страницу након што сте почели да је уређујете из следећег разлога:\n: <em>$2</em>\nПотврдите да стварно желите да направите страницу.",
"confirmrecreate-noreason": "Корисник [[User:$1|$1]] ([[User talk:$1|разговор]]) је обрисао ову страницу након што сте почели да га уређујете. Потврдите да стварно желите да поново направите ову страницу.",
"recreate": "Поново направи",
"unit-pixel": "px",
"subject-preview": "Pregled teme/naslova:",
"blockedtitle": "Korisnik je blokiran",
"blockedtext": "<strong>Vaše korisničko ime ili IP adresa je blokirana.</strong>\n\nBlokiranje je {{GENDER:$4|izvršio|izvršila}} $1.\nRazlog: <em>$2</em>.\n\n* Datum blokiranja: $8\n* Blokiranje ističe: $6\n* Ime korisnika: $7\n\nObratite se {{GENDER:$4|korisniku|korisnici}} $1 ili [[{{MediaWiki:Grouppage-sysop}}|administratoru]] da razjasnite stvar.\nNe možete koristiti mogućnost „Pošalji poruku ovom korisniku“ ako niste uneli ispravnu e-adresu u [[Special:Preferences|podešavanjima]].\nVaša blokirana IP adresa je $3, a ID blokiranja $5.\nNavedite sve podatke iznad pri stvaranja bilo kakvih upita.",
- "autoblockedtext": "Vaša IP adresa je blokirana jer ju je upotrebljavao drugi korisnik, koga je {{GENDER:$1|blokirao|blokirala|blokirao}} $1.\nRazlog:\n\n:''$2''\n\n* Datum blokiranja: $8\n* Blokiranje ističe: $6\n* Ime korisnika: $7\n\nObratite se {{GENDER:$1|korisniku|korisnici|korisniku}} $1 ili [[{{MediaWiki:Grouppage-sysop}}|administratoru]] da razjasnite stvar.\n\nNe možete koristiti mogućnost „Pošalji poruku ovom korisniku“ ako niste uneli ispravnu e-adresu u [[Special:Preferences|podešavanjima]].\n\nVaša blokirana IP adresa je $3, a IB $5.\nNavedite sve podatke iznad pri stvaranju bilo kakvih upita.",
+ "autoblockedtext": "Vaša IP adresa je blokirana jer ju je upotrebljavao drugi korisnik, koga je {{GENDER:$4|blokirao|blokirala}} $1.\nRazlog:\n\n:<em>$2</em>\n\n* Datum blokiranja: $8\n* Blokiranje ističe: $6\n* Ime korisnika: $7\n\nObratite se {{GENDER:$4|korisniku|korisnici}} $1 ili [[{{MediaWiki:Grouppage-sysop}}|administratoru]] da razjasnite stvar.\n\nNe možete koristiti mogućnost „Pošalji poruku ovom korisniku“ ako niste uneli ispravnu e-adresu u [[Special:Preferences|podešavanjima]].\n\nVaša blokirana IP adresa je $3, a ID $5.\nNavedite sve podatke iznad pri stvaranju bilo kakvih upita.",
"blockednoreason": "razlog nije naveden",
"whitelistedittext": "Za uređivanje stranice je potrebno da budete $1.",
"confirmedittext": "Morate da potvrdite svoju e-adresu pre uređivanja stranica.\nPostavite i potvrdite adresu preko [[Special:Preferences|podešavanja]].",
"undo-summary": "Poništena izmena $1 {{GENDER:$2|korisnika|korisnice}} [[Special:Contribs/$2|$2]] ([[User talk:$2|razgovor]])",
"undo-summary-username-hidden": "Poništi izmenu $1 skrivenog korisnika",
"cantcreateaccounttitle": "Ne mogu da otvorim nalog",
- "cantcreateaccount-text": "Otvaranje naloga s ove IP adrese ('''$1''') je {{GENDER:$3|blokirao|blokirala|blokirao}} [[User:$3|$3]].\n\nRazlog koji je naveo {{GENDER:$3|korisnik|korisnica|korisnik}} $3 je ''$2''",
+ "cantcreateaccount-text": "Otvaranje naloga s ove IP adrese (<strong>$1</strong>) je blokirao/la [[User:$3|$3]].\n\nRazlog koji je naveo/la $3 je <em>$2</em>",
"viewpagelogs": "Pogledaj dnevnike ove stranice",
"nohistory": "Ne postoji istorija izmena ove stranice.",
"currentrev": "Tekuća izmena",
"autoblocker": "Automatski ste blokirani jer delite IP adresu s korisnikom/com [[User:$1|$1]].\nRazlog blokiranja: „$2“",
"blocklogpage": "Dnevnik blokiranja",
"blocklog-showlog": "{{GENDER:$1|Ovaj korisnik je ranije blokiran|Ova korisnica je ranije blokirana|Ovaj korisnik je ranije blokiran}}.\nIstorija blokiranja se nalazi ispod:",
- "blocklog-showsuppresslog": "{{GENDER:|Ovaj korisnik je ranije blokiran i sakriven|Ova korisnica je ranije blokirana i sakrivena|Ovaj korisnik je ranije blokiran i sakriven}}.\nIstorija sakrivanja se nalazi ispod:",
+ "blocklog-showsuppresslog": "{{GENDER:$1|Ovaj korisnik je ranije blokiran i sakriven|Ova korisnica je ranije blokirana i sakrivena}}.\nIstorija sakrivanja se nalazi ispod:",
"blocklogentry": "je blokirao [[$1]] s rokom isticanja od $2 $3",
"reblock-logentry": "{{GENDER:|je promenio|je promenila|je promenio}} podešavanja za blokiranje {{GENDER:$1|korisnika|korisnice|korisnika}} [[$1]] s rokom isteka od $2 ($3)",
"blocklogtext": "Ovo je dnevnik blokiranja i deblokiranja korisnika.\nAutomatski blokirane IP adrese nisu navedene.\nTekuće zabrane i blokiranja možete naći [[Special:BlockList|ovde]].",
"scarytranscludefailed-httpstatus": "[Ne mogu da preuzmem šablon $1: HTTP $2]",
"scarytranscludetoolong": "[URL adresa je predugačka]",
"deletedwhileediting": "<strong>Upozorenje</strong>: ova stranica je obrisana nakon što ste počeli s uređivanjem!",
- "confirmrecreate": "[[User:$1|$1]] ([[User talk:$1|razgovor]]) {{GENDER:$1|je obrisao|je obrisala|je obrisao}} ovu stranicu nakon što ste počeli da je uređujete iz sledećeg razloga:\n: ''$2''\nPotvrdite da stvarno želite da napravite stranicu.",
+ "confirmrecreate": "Korisnik [[User:$1|$1]] ([[User talk:$1|razgovor]]) je obrisao ovu stranicu nakon što ste počeli da je uređujete iz sledećeg razloga:\n: <em>$2</em>\nPotvrdite da stvarno želite da napravite stranicu.",
"confirmrecreate-noreason": "Korisnik [[User:$1|$1]] ([[User talk:$1|razgovor]]) je obrisao ovu stranicu nakon što ste počeli da ga uređujete. Potvrdite da stvarno želite da ponovo napravite ovu stranicu.",
"recreate": "Ponovo napravi",
"unit-pixel": "px",
"userlogin-resetlink": "Har du glömt dina inloggningsuppgifter?",
"userlogin-resetpassword-link": "Glömt ditt lösenord?",
"userlogin-helplink2": "Hjälp med inloggning",
- "userlogin-loggedin": "Du är redan inloggad som {{GENDER:$1|$1}}.\nAnvänd formuläret nedan för att logga in som en annan användare.",
- "userlogin-createanother": "Skapa ett annat konto",
"createacct-emailrequired": "E-postadress",
"createacct-emailoptional": "E-postadress (valfritt)",
"createacct-email-ph": "Bekräfta din e-postadress",
"shown-title": "Показувати $1 {{PLURAL:$1|запис|записи|записів}} на сторінці",
"viewprevnext": "Переглянути ($1 {{int:pipe-separator}} $2) ($3).",
"searchmenu-exists": "'''У цій вікі є сторінка з назвою «[[:$1]]»'''",
- "searchmenu-new": "<strong>Створити сторінку «[[:$1]]» у цьому вікі-проекті!</strong>\n{{PLURAL:$2|0=|Див. також сторінку, знайдену по результатами вашого пошуку.|Див. також знайдені результати пошуку.}}",
+ "searchmenu-new": "<strong>Створити сторінку «[[:$1]]» у цьому вікіпроекті!</strong>\n{{PLURAL:$2|0=|Див. також сторінку, знайдену за результатами вашого пошуку.|Див. також знайдені результати пошуку.}}",
"searchprofile-articles": "Статті",
"searchprofile-images": "Мультимедіа",
"searchprofile-everything": "Усюди",
"showpreview": "ווײַזן פֿאָרױסקוק",
"showdiff": "ווײַז די ענדערונגען",
"blankarticle": "<strong>אזהרה:</strong> דער בלאט איר גייט שאפן איז ליידיק.\nטאמער איר וועט דריקן אויף \"{{int:savearticle}}\" נאכאמאל, וועט דער בלאט ווערן געשאפן אן קיין אינהאלט.",
- "anoneditwarning": "'''ווארענונג:''' איר זענט נישט אריינלאגירט אין אייער קאנטע. אייער איי פי אדרעס וועט ווערן דאקומענטירט אין דעם בלאטס היסטאריע פון ענדערונגען. אויב זארגט איר זיך פאר פריוואטקייטן, ביטע טוט זיך אריינלאגירן.",
+ "anoneditwarning": "<strong>ווארענונג:</strong> איר זענט נישט אריינלאגירט. אייער איי פי אדרעס וועט ווערן עפנטלעך זעבאר ווען איר פירט דורך ענדערונגען . אז איר <strong>[$1 לאגירט ארײַן]</strong> אדער <strong>[$2 שאפט א קאנטע]</strong>, וועלן אײַערע רעדאקטירונגען ווערן צוגעשריבן צו אײַער באניצער-נאמען, ווי אויך אנדערע טובות.",
"anonpreviewwarning": "''איר זענט נישט אַרײַנלאגירט. אויפֿהיטן וועט ארײַנשרײַבן אײַער IP אַדרעס אין דער רעדאַקטירונג היסטאריע פונעם בלאַט.''",
"missingsummary": "'''דערמאנונג:''' איר האט נישט אויסגעפילט דעם קורץ ווארט אויפקלערונג אויף אייער עדיט. אויב וועט איר דרוקן נאכאמאל אויף \"היט אפ דעם בלאט\", וועט אייער ענדערונג ווערן געהיטן אן דעם.",
"missingcommenttext": "ביטע שטעלט אריין א אנמערקונג פון אונטן.",
"sp-contributions-search": "זוכן בײַשטײַערונגען",
"sp-contributions-username": "באניצער נאמען אדער IP אדרעס:",
"sp-contributions-toponly": "בלויז ווײַזן רעדאַקטירונגען וואָס זענען די לעצטיקע רעוויזיעס",
- "sp-contributions-newonly": "בלוז ווײַזן רעדאקטירונגען וואס זענען נײַ־געשאפענע בלעטער",
+ "sp-contributions-newonly": "×\91×\9c×\95×\99×\96 ×\95×\95ײַ×\96×\9f רע×\93×\90ק×\98×\99ר×\95× ×\92×¢×\9f ×\95×\95×\90ס ×\96×¢× ×¢×\9f × ×²Ö·Ö¾×\92עש×\90×¤×¢× ×¢ ×\91×\9c×¢×\98ער",
"sp-contributions-submit": "זוכן",
"whatlinkshere": "װאָס פֿאַרבינדט אַהער",
"whatlinkshere-title": "בלעטער וואס פֿארבינדן צו $1",
"showpreview": "显示预览",
"showdiff": "显示更改",
"blankarticle": "<strong>警告</strong>:您创建的页面是空白的。如果您再次点击“{{int:savearticle}}”,您将真的创建没有任何内容的页面。",
- "anoneditwarning": "<strong>警告:</strong>您没有登录。您的IP地址将被记录在该页面的编辑历史中。",
+ "anoneditwarning": "<strong>警告:</strong>您没有登录。您做出任何编辑后您的IP地址会公开可见。如果您<strong>[$1 登陆]</strong>或<strong>[$2 注册]</strong>一个账户,您的编辑将归属于您的用户名,以及有其他好处。",
"anonpreviewwarning": "<em>你没有登录。保存会记录你的IP地址于该页面的编辑历史中。</em>",
"missingsummary": "'''提示:'''你没有提供编辑摘要。如果你再次点击“{{int:savearticle}}”,你的编辑将不带编辑摘要保存。",
"missingcommenttext": "请在下面输入评论。",
"showpreview": "顯示預覽",
"showdiff": "顯示變更",
"blankarticle": "<strong>警告:</strong>您正在建立的頁面是空白的。\n如果您再按一下\"{{int:savearticle}}\",將建立沒有任何內容的頁面。",
- "anoneditwarning": "<strong>警告:</strong>您尚未登入。\n您的 IP 位址將記錄在此頁的編輯歷史中。",
+ "anoneditwarning": "<strong>警告:</strong>您尚未登入。 若您進行任何的編輯您的 IP 位置將會被公開。 若您 <strong>[$1 登入]</strong> 或 <strong>[$2 建立帳號]</strong>,您的編輯將會以您的使用者名稱標示,擁有其他優點。",
"anonpreviewwarning": "<em>您尚未登入。儲存頁面會將您的 IP 位址記錄在此頁面的編輯歷史中。</em>",
"missingsummary": "<strong>提醒:</strong>您未填寫編輯摘要。\n若您再點選 \"{{int:savearticle}}\" 一次,將略過摘要直接儲存您的編輯。",
"missingcommenttext": "請在下方輸入評論。",
--- /dev/null
+<?php
+/**
+ * Script to populate a bloom filter with a BloomFilter* class
+ *
+ * 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
+ * @ingroup Maintenance
+ */
+
+require_once __DIR__ . '/Maintenance.php';
+
+/**
+ * Script to populate a bloom filter with a BloomFilter* class
+ *
+ * @ingroup Maintenance
+ */
+class PopulateBloomFilter extends Maintenance {
+ public function __construct() {
+ parent::__construct();
+ $this->addOption( 'cache', 'Bloom cache store name', true, true );
+ $this->addOption( 'filter', 'Bloom filter name', true, true );
+ $this->addOption( 'domain', 'Bloom filter domain', true, true );
+ $this->addOption( 'delay', 'Sleep delay between batches (us)', false, true );
+ $this->mDescription = "Populate the specified bloom filter";
+ }
+
+ public function execute() {
+ $type = $this->getOption( 'filter' );
+ $domain = $this->getOption( 'domain' );
+ $bcache = BloomCache::get( $this->getOption( 'cache' ) );
+ $delay = $this->getOption( 'delay', 1e5 );
+
+ if ( !method_exists( "BloomFilter{$type}", 'merge' ) ) {
+ $this->error( "No \"BloomFilter{$type}::merge\" method found.", 1 );
+ }
+
+ $virtualKey = "$domain:$type";
+ $status = $bcache->getStatus( $virtualKey );
+ if ( $status == false ) {
+ $this->error( "Could not query virtual bloom filter '$virtualKey'.", 1 );
+ }
+
+ $startTime = microtime( true );
+ $this->output( "Current timestamp is '$startTime'.\n" );
+ $this->output( "Current filter timestamp is '{$status['asOfTime']}'.\n" );
+
+ do {
+ $status = call_user_func_array(
+ array( "BloomFilter{$type}", 'merge' ),
+ array( $bcache, $domain, $virtualKey, $status )
+ );
+ if ( $status == false ) {
+ $this->error( "Could not query virtual bloom filter '$virtualKey'.", 1 );
+ }
+ $this->output( "Filter updated to timestamp '{$status['asOfTime']}'.\n" );
+ usleep( $delay );
+ } while ( $status['asOfTime'] && $status['asOfTime'] < $startTime );
+
+ $this->output( "Done, filter $type of domain $domain reached time '$startTime'.\n" );
+ }
+}
+
+$maintClass = "PopulateBloomFilter";
+require_once RUN_MAINTENANCE_IF_MAIN;
),
),
'mediawiki.action.view.metadata' => array(
+ 'styles' => 'resources/src/mediawiki.action/mediawiki.action.view.metadata.css',
'scripts' => 'resources/src/mediawiki.action/mediawiki.action.view.metadata.js',
'messages' => array(
'metadata-expand',
'mediawiki.cldr',
),
'targets' => array( 'desktop', 'mobile' ),
+ 'messages' => array(
+ 'and',
+ 'comma-separator',
+ 'word-separator'
+ ),
),
'mediawiki.cldr' => array(
/*!
- * OOjs v1.0.12 optimised for jQuery
+ * OOjs v1.1.0 optimised for jQuery
* https://www.mediawiki.org/wiki/OOjs
*
* Copyright 2011-2014 OOjs Team and other contributors.
* Released under the MIT license
* http://oojs.mit-license.org
*
- * Date: 2014-08-20T22:33:41Z
+ * Date: 2014-08-31T21:15:46Z
*/
( function ( global ) {
};
/**
- * Utility for common usage of Object#create for inheriting from one
- * prototype to another.
+ * Inherit from prototype to another using Object#create.
*
* Beware: This redefines the prototype, call before setting your prototypes.
+ *
* Beware: This redefines the prototype, can only be called once on a function.
- * If called multiple times on the same function, the previous prototype is lost.
- * This is how prototypal inheritance works, it can only be one straight chain
- * (just like classical inheritance in PHP for example). If you need to work with
- * multiple constructors consider storing an instance of the other constructor in a
- * property instead, or perhaps use a mixin (see OO.mixinClass).
+ * If called multiple times on the same function, the previous prototype is lost.
+ * This is how prototypal inheritance works, it can only be one straight chain
+ * (just like classical inheritance in PHP for example). If you need to work with
+ * multiple constructors consider storing an instance of the other constructor in a
+ * property instead, or perhaps use a mixin (see OO.mixinClass).
*
* function Thing() {}
* Thing.prototype.exists = function () {};
};
/**
- * Utility to copy over *own* prototype properties of a mixin.
+ * Copy over *own* prototype properties of a mixin.
+ *
* The 'constructor' (whether implicit or explicit) is not copied over.
*
* This does not create inheritance to the origin. If inheritance is needed
* use oo.inheritClass instead.
*
* Beware: This can redefine a prototype property, call before setting your prototypes.
+ *
* Beware: Don't call before oo.inheritClass.
*
* function Foo() {}
};
/**
- * Recursively compares properties between two objects.
+ * Recursively compare properties between two objects.
*
* A false result may be caused by property inequality or by properties in one object missing from
* the other. An asymmetrical test may also be performed, which checks only that properties in the
*
* If either a or b is null or undefined it will be treated as an empty object.
*
- * @param {Object|undefined} a First object to compare
- * @param {Object|undefined} b Second object to compare
+ * @param {Object|undefined|null} a First object to compare
+ * @param {Object|undefined|null} b Second object to compare
* @param {boolean} [asymmetrical] Whether to check only that b contains values from a
* @return {boolean} If the objects contain the same values as each other
*/
};
/**
- * Helper function for OO.getHash which sorts objects by key.
+ * Sort objects by key (helper function for OO.getHash).
*
* This is a callback passed into JSON.stringify.
*
/*global hasOwn */
-/**
- * @class OO.EventEmitter
- *
- * @constructor
- */
-oo.EventEmitter = function OoEventEmitter() {
- // Properties
+( function () {
/**
- * Storage of bound event handlers by event name.
+ * @class OO.EventEmitter
*
- * @property
+ * @constructor
*/
- this.bindings = {};
-};
+ oo.EventEmitter = function OoEventEmitter() {
+ // Properties
-oo.initClass( oo.EventEmitter );
-
-/* Methods */
+ /**
+ * Storage of bound event handlers by event name.
+ *
+ * @property
+ */
+ this.bindings = {};
+ };
-/**
- * Add a listener to events of a specific event.
- *
- * The listener can be a function or the string name of a method; if the latter, then the
- * name lookup happens at the time the listener is called.
- *
- * @param {string} event Type of event to listen to
- * @param {Function|string} method Function or method name to call when event occurs
- * @param {Array} [args] Arguments to pass to listener, will be prepended to emitted arguments
- * @param {Object} [context=null] Context object for function or method call
- * @throws {Error} Listener argument is not a function or a valid method name
- * @chainable
- */
-oo.EventEmitter.prototype.on = function ( event, method, args, context ) {
- var bindings;
+ oo.initClass( oo.EventEmitter );
- this.constructor.static.validateMethod( method, context );
+ /* Private helper functions */
- if ( hasOwn.call( this.bindings, event ) ) {
- bindings = this.bindings[event];
- } else {
- // Auto-initialize bindings list
- bindings = this.bindings[event] = [];
+ /**
+ * Validate a function or method call in a context
+ *
+ * For a method name, check that it names a function in the context object
+ *
+ * @private
+ * @param {Function|string} method Function or method name
+ * @param {Mixed} context The context of the call
+ * @throws {Error} A method name is given but there is no context
+ * @throws {Error} In the context object, no property exists with the given name
+ * @throws {Error} In the context object, the named property is not a function
+ */
+ function validateMethod( method, context ) {
+ // Validate method and context
+ if ( typeof method === 'string' ) {
+ // Validate method
+ if ( context === undefined || context === null ) {
+ throw new Error( 'Method name "' + method + '" has no context.' );
+ }
+ if ( !( method in context ) ) {
+ // Technically the method does not need to exist yet: it could be
+ // added before call time. But this probably signals a typo.
+ throw new Error( 'Method not found: "' + method + '"' );
+ }
+ if ( typeof context[method] !== 'function' ) {
+ // Technically the property could be replaced by a function before
+ // call time. But this probably signals a typo.
+ throw new Error( 'Property "' + method + '" is not a function' );
+ }
+ } else if ( typeof method !== 'function' ) {
+ throw new Error( 'Invalid callback. Function or method name expected.' );
+ }
}
- // Add binding
- bindings.push( {
- method: method,
- args: args,
- context: ( arguments.length < 4 ) ? null : context
- } );
- return this;
-};
-/**
- * Adds a one-time listener to a specific event.
- *
- * @param {string} event Type of event to listen to
- * @param {Function} listener Listener to call when event occurs
- * @chainable
- */
-oo.EventEmitter.prototype.once = function ( event, listener ) {
- var eventEmitter = this,
- listenerWrapper = function () {
- eventEmitter.off( event, listenerWrapper );
- listener.apply( eventEmitter, Array.prototype.slice.call( arguments, 0 ) );
- };
- return this.on( event, listenerWrapper );
-};
+ /* Methods */
-/**
- * Remove a specific listener from a specific event.
- *
- * @param {string} event Type of event to remove listener from
- * @param {Function|string} [method] Listener to remove. Must be in the same form as was passed
- * to "on". Omit to remove all listeners.
- * @param {Object} [context=null] Context object function or method call
- * @chainable
- * @throws {Error} Listener argument is not a function or a valid method name
- */
-oo.EventEmitter.prototype.off = function ( event, method, context ) {
- var i, bindings;
+ /**
+ * Add a listener to events of a specific event.
+ *
+ * The listener can be a function or the string name of a method; if the latter, then the
+ * name lookup happens at the time the listener is called.
+ *
+ * @param {string} event Type of event to listen to
+ * @param {Function|string} method Function or method name to call when event occurs
+ * @param {Array} [args] Arguments to pass to listener, will be prepended to emitted arguments
+ * @param {Object} [context=null] Context object for function or method call
+ * @throws {Error} Listener argument is not a function or a valid method name
+ * @chainable
+ */
+ oo.EventEmitter.prototype.on = function ( event, method, args, context ) {
+ var bindings;
- if ( arguments.length === 1 ) {
- // Remove all bindings for event
- delete this.bindings[event];
+ validateMethod( method, context );
+
+ if ( hasOwn.call( this.bindings, event ) ) {
+ bindings = this.bindings[event];
+ } else {
+ // Auto-initialize bindings list
+ bindings = this.bindings[event] = [];
+ }
+ // Add binding
+ bindings.push( {
+ method: method,
+ args: args,
+ context: ( arguments.length < 4 ) ? null : context
+ } );
return this;
- }
+ };
- this.constructor.static.validateMethod( method, context );
+ /**
+ * Add a one-time listener to a specific event.
+ *
+ * @param {string} event Type of event to listen to
+ * @param {Function} listener Listener to call when event occurs
+ * @chainable
+ */
+ oo.EventEmitter.prototype.once = function ( event, listener ) {
+ var eventEmitter = this,
+ listenerWrapper = function () {
+ eventEmitter.off( event, listenerWrapper );
+ listener.apply( eventEmitter, Array.prototype.slice.call( arguments, 0 ) );
+ };
+ return this.on( event, listenerWrapper );
+ };
- if ( !( event in this.bindings ) || !this.bindings[event].length ) {
- // No matching bindings
- return this;
- }
+ /**
+ * Remove a specific listener from a specific event.
+ *
+ * @param {string} event Type of event to remove listener from
+ * @param {Function|string} [method] Listener to remove. Must be in the same form as was passed
+ * to "on". Omit to remove all listeners.
+ * @param {Object} [context=null] Context object function or method call
+ * @chainable
+ * @throws {Error} Listener argument is not a function or a valid method name
+ */
+ oo.EventEmitter.prototype.off = function ( event, method, context ) {
+ var i, bindings;
- // Default to null context
- if ( arguments.length < 3 ) {
- context = null;
- }
+ if ( arguments.length === 1 ) {
+ // Remove all bindings for event
+ delete this.bindings[event];
+ return this;
+ }
- // Remove matching handlers
- bindings = this.bindings[event];
- i = bindings.length;
- while ( i-- ) {
- if ( bindings[i].method === method && bindings[i].context === context ) {
- bindings.splice( i, 1 );
+ validateMethod( method, context );
+
+ if ( !( event in this.bindings ) || !this.bindings[event].length ) {
+ // No matching bindings
+ return this;
}
- }
- // Cleanup if now empty
- if ( bindings.length === 0 ) {
- delete this.bindings[event];
- }
- return this;
-};
+ // Default to null context
+ if ( arguments.length < 3 ) {
+ context = null;
+ }
-/**
- * Emit an event.
- *
- * TODO: Should this be chainable? What is the usefulness of the boolean
- * return value here?
- *
- * @param {string} event Type of event
- * @param {Mixed} args First in a list of variadic arguments passed to event handler (optional)
- * @return {boolean} If event was handled by at least one listener
- */
-oo.EventEmitter.prototype.emit = function ( event ) {
- var i, len, binding, bindings, args, method;
-
- if ( event in this.bindings ) {
- // Slicing ensures that we don't get tripped up by event handlers that add/remove bindings
- bindings = this.bindings[event].slice();
- args = Array.prototype.slice.call( arguments, 1 );
- for ( i = 0, len = bindings.length; i < len; i++ ) {
- binding = bindings[i];
- if ( typeof binding.method === 'string' ) {
- // Lookup method by name (late binding)
- method = binding.context[ binding.method ];
- } else {
- method = binding.method;
+ // Remove matching handlers
+ bindings = this.bindings[event];
+ i = bindings.length;
+ while ( i-- ) {
+ if ( bindings[i].method === method && bindings[i].context === context ) {
+ bindings.splice( i, 1 );
}
- method.apply(
- binding.context,
- binding.args ? binding.args.concat( args ) : args
- );
}
- return true;
- }
- return false;
-};
-/**
- * Connect event handlers to an object.
- *
- * @param {Object} context Object to call methods on when events occur
- * @param {Object.<string,string>|Object.<string,Function>|Object.<string,Array>} methods List of
- * event bindings keyed by event name containing either method names, functions or arrays containing
- * method name or function followed by a list of arguments to be passed to callback before emitted
- * arguments
- * @chainable
- */
-oo.EventEmitter.prototype.connect = function ( context, methods ) {
- var method, args, event;
-
- for ( event in methods ) {
- method = methods[event];
- // Allow providing additional args
- if ( Array.isArray( method ) ) {
- args = method.slice( 1 );
- method = method[0];
- } else {
- args = [];
+ // Cleanup if now empty
+ if ( bindings.length === 0 ) {
+ delete this.bindings[event];
}
- // Add binding
- this.on( event, method, args, context );
- }
- return this;
-};
+ return this;
+ };
-/**
- * Disconnect event handlers from an object.
- *
- * @param {Object} context Object to disconnect methods from
- * @param {Object.<string,string>|Object.<string,Function>|Object.<string,Array>} [methods] List of
- * event bindings keyed by event name. Values can be either method names or functions, but must be
- * consistent with those used in the corresponding call to "connect".
- * @chainable
- */
-oo.EventEmitter.prototype.disconnect = function ( context, methods ) {
- var i, event, bindings;
+ /**
+ * Emit an event.
+ *
+ * TODO: Should this be chainable? What is the usefulness of the boolean
+ * return value here?
+ *
+ * @param {string} event Type of event
+ * @param {Mixed} args First in a list of variadic arguments passed to event handler (optional)
+ * @return {boolean} If event was handled by at least one listener
+ */
+ oo.EventEmitter.prototype.emit = function ( event ) {
+ var i, len, binding, bindings, args, method;
+
+ if ( event in this.bindings ) {
+ // Slicing ensures that we don't get tripped up by event handlers that add/remove bindings
+ bindings = this.bindings[event].slice();
+ args = Array.prototype.slice.call( arguments, 1 );
+ for ( i = 0, len = bindings.length; i < len; i++ ) {
+ binding = bindings[i];
+ if ( typeof binding.method === 'string' ) {
+ // Lookup method by name (late binding)
+ method = binding.context[ binding.method ];
+ } else {
+ method = binding.method;
+ }
+ method.apply(
+ binding.context,
+ binding.args ? binding.args.concat( args ) : args
+ );
+ }
+ return true;
+ }
+ return false;
+ };
+
+ /**
+ * Connect event handlers to an object.
+ *
+ * @param {Object} context Object to call methods on when events occur
+ * @param {Object.<string,string>|Object.<string,Function>|Object.<string,Array>} methods List of
+ * event bindings keyed by event name containing either method names, functions or arrays containing
+ * method name or function followed by a list of arguments to be passed to callback before emitted
+ * arguments
+ * @chainable
+ */
+ oo.EventEmitter.prototype.connect = function ( context, methods ) {
+ var method, args, event;
- if ( methods ) {
- // Remove specific connections to the context
for ( event in methods ) {
- this.off( event, methods[event], context );
+ method = methods[event];
+ // Allow providing additional args
+ if ( Array.isArray( method ) ) {
+ args = method.slice( 1 );
+ method = method[0];
+ } else {
+ args = [];
+ }
+ // Add binding
+ this.on( event, method, args, context );
}
- } else {
- // Remove all connections to the context
- for ( event in this.bindings ) {
- bindings = this.bindings[event];
- i = bindings.length;
- while ( i-- ) {
- // bindings[i] may have been removed by the previous step's
- // this.off so check it still exists
- if ( bindings[i] && bindings[i].context === context ) {
- this.off( event, bindings[i].method, context );
+ return this;
+ };
+
+ /**
+ * Disconnect event handlers from an object.
+ *
+ * @param {Object} context Object to disconnect methods from
+ * @param {Object.<string,string>|Object.<string,Function>|Object.<string,Array>} [methods] List of
+ * event bindings keyed by event name. Values can be either method names or functions, but must be
+ * consistent with those used in the corresponding call to "connect".
+ * @chainable
+ */
+ oo.EventEmitter.prototype.disconnect = function ( context, methods ) {
+ var i, event, bindings;
+
+ if ( methods ) {
+ // Remove specific connections to the context
+ for ( event in methods ) {
+ this.off( event, methods[event], context );
+ }
+ } else {
+ // Remove all connections to the context
+ for ( event in this.bindings ) {
+ bindings = this.bindings[event];
+ i = bindings.length;
+ while ( i-- ) {
+ // bindings[i] may have been removed by the previous step's
+ // this.off so check it still exists
+ if ( bindings[i] && bindings[i].context === context ) {
+ this.off( event, bindings[i].method, context );
+ }
}
}
}
- }
- return this;
-};
+ return this;
+ };
-/**
- * Validate a function or method call in a context
- *
- * For a method name, check that it names a function in the context object
- *
- * @static
- * @param {Function|string} method Function or method name
- * @param {Mixed} context The context of the call
- * @throws {Error} A method name is given but there is no context
- * @throws {Error} In the context object, no property exists with the given name
- * @throws {Error} In the context object, the named property is not a function
- */
-oo.EventEmitter.static.validateMethod = function ( method, context ) {
- // Validate method and context
- if ( typeof method === 'string' ) {
- // Validate method
- if ( context === undefined || context === null ) {
- throw new Error( 'Method name "' + method + '" has no context.' );
- }
- if ( !( method in context ) ) {
- // Technically the method does not need to exist yet: it could be
- // added before call time. But this probably signals a typo.
- throw new Error( 'Method not found: "' + method + '"' );
- }
- if ( typeof context[method] !== 'function' ) {
- // Technically the property could be replaced by a function before
- // call time. But this probably signals a typo.
- throw new Error( 'Property "' + method + '" is not a function' );
- }
- } else if ( typeof method !== 'function' ) {
- throw new Error( 'Invalid callback. Function or method name expected.' );
- }
-};
+}() );
/*global hasOwn */
* by placing buttons in a queue if this method is called before
* the toolbar is created.
*
- * For compatiblity, passing the properties listed below as separate arguments
- * (in the listed order) is also supported.
+ * For backwards-compatibility, passing `imageFile`, `speedTip`, `tagOpen`, `tagClose`,
+ * `sampleText` and `imageId` as separate arguments (in this order) is also supported.
*
- * @param {Object} button Object with the following properties:
- * @param {string} button.imageFile
- * @param {string} button.speedTip
- * @param {string} button.tagOpen
- * @param {string} button.tagClose
- * @param {string} button.sampleText
- * @param {string} [button.imageId]
- * @param {Function} [button.onClick]
+ * @param {Object} button Object with the following properties.
+ * You are required to provide *either* the `onClick` parameter, or the three parameters
+ * `tagOpen`, `tagClose` and `sampleText`, but not both (they're mutually exclusive).
+ * @param {string} button.imageFile Image to use for the button.
+ * @param {string} button.speedTip Tooltip displayed when user mouses over the button.
+ * @param {Function} [button.onClick] Function to be executed when the button is clicked.
+ * @param {string} [button.tagOpen]
+ * @param {string} [button.tagClose]
+ * @param {string} [button.sampleText] Alternative to `onClick`. `tagOpen`, `tagClose` and
+ * `sampleText` together provide the markup that should be inserted into page text at
+ * current cursor position.
+ * @param {string} [button.imageId] `id` attribute of the button HTML element.
*/
addButton: function () {
if ( isReady ) {
--- /dev/null
+/*!
+ * Hide collapsable rows in a collapsed table.
+ */
+table.collapsed tr.collapsable {
+ display: none;
+}
* Add an expand/collapse link and collapse by default if set to
* (with JS disabled, user will see all items)
*
- * See also:
- * - ImagePage.php#makeMetadataTable (creates the HTML)
- * - shared.css (hides tr.collapsable inside table.collapsed)
+ * See also ImagePage.php#makeMetadataTable (creates the HTML)
*/
( function ( mw, $ ) {
$( function () {
return grammarForms[form][word] || word;
}
return word;
- }
+ },
+ /**
+ * Turn a list of string into a simple list using commas and 'and'.
+ *
+ * See Language::listToText in languages/Language.php
+ *
+ * @param {string[]} list
+ * @return {string}
+ */
+ listToText: function ( list ) {
+ var text = '', i = 0;
+ for ( ; i < list.length; i++ ) {
+ text += list[i];
+ if ( list.length - 2 === i ) {
+ text += mw.msg( 'and' ) + mw.msg( 'word-separator' );
+ } else if ( list.length - 1 !== i ) {
+ text += mw.msg( 'comma-separator' );
+ }
+ }
+ return text;
+ }
} );
}( mediaWiki, jQuery ) );
}
/**
- * Efficiently replicate a string `n` times.
+ * Replicate a string 'n' times.
*
* @private
* @param {string} str The string to replicate
}
var buf = [];
- while (num) {
+ while ( num-- ) {
buf.push( str );
- str += str;
}
return buf.join( '' );
}
}
for ( whole = valueParts[0]; whole; ) {
- off = whole.length - groupSize;
-
+ off = groupSize ? whole.length - groupSize : 0;
pieces.push( ( off > 0 ) ? whole.substr( off ) : whole );
whole = ( off > 0 ) ? whole.slice( 0, off ) : '';
if ( groupSize2 ) {
groupSize = groupSize2;
+ groupSize2 = null;
}
}
valueParts[0] = pieces.reverse().join( options.group );
min-width: 0 !important;
}
-#content {
+.mw-body {
background: white;
border: none !important;
padding: 0 !important;
margin: 0 !important;
}
-#column-content #content {
+#column-content .mw-body {
padding: 1em;
margin: 0 !important;
}
}
/* Expand URLs for printing */
-#content a.external.text:after,
-#content a.external.autonumber:after {
+.mw-body a.external.text:after,
+.mw-body a.external.autonumber:after {
content: " (" attr(href) ")";
}
/* Expand protocol-relative URLs for printing */
-#content a.external.text[href^='//']:after,
-#content a.external.autonumber[href^='//']:after {
+.mw-body a.external.text[href^='//']:after,
+.mw-body a.external.autonumber[href^='//']:after {
content: " (https:" attr(href) ")";
}
border-bottom: none;
}
-table.collapsed tr.collapsable {
- display: none;
-}
-
.visualClear {
clear: both;
}
}
/* @noflip */
-html > body.rtl div#bodyContent ul#filetoc {
+html > body.rtl .mw-body ul#filetoc {
display: block;
}
/* Plainlinks - this can be used to switch
* off special external link styling */
-.plainlinks a {
+.plainlinks a.external {
background: none !important;
padding: 0 !important;
}
font-weight: bold;
}
-/**
- * Hide collapsable rows in a collapsed table.
- *
- * Used by ImagePage and the mediawiki.action.view.metadata module.
- */
-table.collapsed tr.collapsable {
- display: none;
-}
-
/* success and error messages */
.error,
.warning,
// This specifies styling for individual field validation error messages.
// Show them below the fields to prevent line break glitches, and leave
// some space between the field and the error message box.
- .mw-ui-vform-div .error, /* for backwards-compatibility, remove before 1.24 */
.mw-ui-vform-field .error {
display: block;
margin-top: 5px;
//
// (We use a broad definition of 'field' here: a purely textual information
// block is also a "field".)
-.mw-ui-vform-div, /* for backwards-compatibility, remove before 1.24 */
.mw-ui-vform-field {
display: block;
margin: 0 0 15px;
}
&:focus {
- box-shadow: inset .45em 0 0 #5088f7;
+ box-shadow: inset .45em 0 0 @colorProgressive;
border-color: @colorGrayDark;
// Remove focus glow on input[type="search"]
outline: 0;
page_url URL.url("Special:Preferences#mw-prefsection-rendering")
checkbox(:auto_number_check, id: "mw-input-wpnumberheadings")
- checkbox(:collapse_sidebar_vector_check, id: "mw-input-wpvector-collapsiblenav")
radio_button(:cologne_blue, id: "mw-input-wpskin-cologneblue")
radio_button(:day_mo_year_radio, id: "mw-input-wpdate-dmy")
checkbox(:dont_show_aft_check, id: "mw-input-wparticlefeedback-disable")
);
}
+ /*
+ * Test cases for random functions could hypothetically fail,
+ * even though they shouldn't.
+ */
+
/**
* @covers ::wfRandom
*/
public function testRandom() {
- # This could hypothetically fail, but it shouldn't ;)
$this->assertFalse(
- wfRandom() == wfRandom() );
+ wfRandom() == wfRandom()
+ );
+ }
+
+ /**
+ * @covers ::wfRandomString
+ */
+ public function testRandomString() {
+ $this->assertFalse(
+ wfRandomString() == wfRandomString()
+ );
+ $this->assertEquals(
+ strlen( wfRandomString( 10 ) ), 10
+ );
+ $this->assertTrue(
+ preg_match( '/^[0-9a-f]+$/i', wfRandomString() ) === 1
+ );
}
/**
strlen( wfBaseConvert( $number, 2, 2, strlen( $number ) - 5 ) )
);
}
+
+ public function testLeadingZero() {
+ $this->assertSame( '24', wfBaseConvert( '010', 36, 16 ) );
+ $this->assertSame( '37d4', wfBaseConvert( '0b10', 36, 16 ) );
+ $this->assertSame( 'a734', wfBaseConvert( '0x10', 36, 16 ) );
+ }
}
'<link rel=stylesheet href="http://127.0.0.1:8080/w/load.php?debug=false&lang=en&modules=test.bar%2Cbaz%2Cfoo&only=styles&skin=fallback&*">
'
),
- // Load private module (scripts)
+ // Load private module (only=scripts)
+ // This is asserted for completion (would get two condition wrappers),
+ // though in practice we'd never embed a module with only=scripts,
+ // that mode is reserved for hardcoded requests. Embedded modules
+ // would always be combined.
array(
array( 'test.quux', ResourceLoaderModule::TYPE_SCRIPTS ),
- '<script>if(window.mw){mw.test.baz({token:123});mw.loader.state({"test.quux":"ready"});}
-</script>
+ '<script>if(window.mw){
+if(window.mw){mw.test.baz({token:123});mw.loader.state({"test.quux":"ready"});}
+
+}</script>
'
),
// Load private module (combined)
array(
array( 'test.quux', ResourceLoaderModule::TYPE_COMBINED ),
- '<script>mw.loader.implement("test.quux",function($,jQuery){mw.test.baz({token:123});},{"css":[".mw-icon{transition:none}\n"]},{});
-</script>
+ '<script>if(window.mw){
+mw.loader.implement("test.quux",function($,jQuery){mw.test.baz({token:123});},{"css":[".mw-icon{transition:none}\n"]},{});
+
+}</script>
'
),
// Load module script with with ESI
assert.equal( mw.language.getData( 'en', 'invalidkey' ), undefined, 'Getter setter test for mw.language with invalid key' );
} );
+ QUnit.test( 'mw.language.commafy test', 9, function ( assert ) {
+ // Number grouping patterns are as per http://cldr.unicode.org/translation/number-patterns
+ assert.equal( mw.language.commafy( 1234.567, '###0.#####' ), '1234.567', 'Pattern with no digit grouping separator defined' );
+ assert.equal( mw.language.commafy( 123456789.567, '###0.#####' ), '123456789.567', 'Pattern with no digit grouping seperator defined, bigger decimal part' );
+ assert.equal( mw.language.commafy( 0.567, '###0.#####' ), '0.567', 'Decimal part 0' );
+ assert.equal( mw.language.commafy( '.567', '###0.#####' ), '0.567', 'Decimal part missing. replace with zero' );
+ assert.equal( mw.language.commafy( 1234, '##,#0.#####' ), '12,34', 'Pattern with no fractional part' );
+ assert.equal( mw.language.commafy( -1234.567, '###0.#####' ), '-1234.567', 'Negative number' );
+ assert.equal( mw.language.commafy( -1234.567, '#,###.00' ), '-1,234.56', 'Fractional part bigger than pattern.' );
+ assert.equal( mw.language.commafy( 123456789.567, '###,##0.00' ), '123,456,789.56', 'Decimal part as group of 3' );
+ assert.equal( mw.language.commafy( 123456789.567, '###,###,#0.00' ), '1,234,567,89.56', 'Decimal part as group of 3 and last one 2' );
+ } );
+
function grammarTest( langCode, test ) {
// The test works only if the content language is opt.language
// because it requires [lang].js to be loaded.
grammarTest( langCode, test );
}
} );
+
+ QUnit.test( 'List to text test', 4, function ( assert ) {
+ assert.equal( mw.language.listToText( [] ), '', 'Blank list' );
+ assert.equal( mw.language.listToText( ['a'] ), 'a', 'Single item' );
+ assert.equal( mw.language.listToText( ['a', 'b'] ), 'a and b', 'Two items' );
+ assert.equal( mw.language.listToText( ['a', 'b', 'c'] ), 'a, b and c', 'More than two items' );
+ } );
}( mediaWiki, jQuery ) );