=== Other changes in 1.27 ===
* ProfilerOutputUdp was removed. Note that there is a ProfilerOutputStats class.
+* WikiPage::doDeleteArticleReal() and WikiPage::doDeleteArticle() now
+ ignore the 2nd and 3rd arguments (formerly $id and $commit).
== Compatibility ==
"ResourceModules": {
"type": "object",
"description": "ResourceLoader modules to register",
- "additionalProperties": false,
"patternProperties": {
"^[a-zA-Z0-9-\\.]+$": {
"type": "object",
- "description": "A single ResourceLoader module descriptor",
- "properties": {
- "localBasePath": {
- "type": "string",
- "description": "Base path to prepend to all local paths in $options. Defaults to $IP"
- },
- "remoteBasePath": {
- "type": "string",
- "description": "Base path to prepend to all remote paths in $options. Defaults to $wgScriptPath"
- },
- "remoteExtPath": {
- "type": "string",
- "description": "Equivalent of remoteBasePath, but relative to $wgExtensionAssetsPath"
- },
- "scripts": {
- "type": ["string", "array"],
- "description": "Scripts to always include (array of file paths)",
- "items": {
- "type": "string"
- }
- },
- "languageScripts": {
- "type": "object",
- "description": "Scripts to include in specific language contexts (mapping of language code to file path(s))",
- "patternProperties": {
- "^[a-zA-Z0-9-]{2,}$": {
- "type": [
- "string",
- "array"
- ],
+ "anyOf": [
+ {
+ "description": "A ResourceLoaderFileModule definition",
+ "additionalProperties": false,
+ "properties": {
+ "localBasePath": {
+ "type": "string",
+ "description": "Base path to prepend to all local paths in $options. Defaults to $IP"
+ },
+ "remoteBasePath": {
+ "type": "string",
+ "description": "Base path to prepend to all remote paths in $options. Defaults to $wgScriptPath"
+ },
+ "remoteExtPath": {
+ "type": "string",
+ "description": "Equivalent of remoteBasePath, but relative to $wgExtensionAssetsPath"
+ },
+ "scripts": {
+ "type": ["string", "array"],
+ "description": "Scripts to always include (array of file paths)",
"items": {
"type": "string"
}
- }
- }
- },
- "skinScripts": {
- "type": "object",
- "description": "Scripts to include in specific skin contexts (mapping of skin name to script(s)",
- "patternProperties": {
- ".+": {
- "type": [
- "string",
- "array"
- ],
+ },
+ "languageScripts": {
+ "type": "object",
+ "description": "Scripts to include in specific language contexts (mapping of language code to file path(s))",
+ "patternProperties": {
+ "^[a-zA-Z0-9-]{2,}$": {
+ "type": [
+ "string",
+ "array"
+ ],
+ "items": {
+ "type": "string"
+ }
+ }
+ }
+ },
+ "skinScripts": {
+ "type": "object",
+ "description": "Scripts to include in specific skin contexts (mapping of skin name to script(s)",
+ "patternProperties": {
+ ".+": {
+ "type": [
+ "string",
+ "array"
+ ],
+ "items": {
+ "type": "string"
+ }
+ }
+ }
+ },
+ "debugScripts": {
+ "type": ["string", "array"],
+ "description": "Scripts to include in debug contexts",
"items": {
"type": "string"
}
- }
- }
- },
- "debugScripts": {
- "type": ["string", "array"],
- "description": "Scripts to include in debug contexts",
- "items": {
- "type": "string"
- }
- },
- "loaderScripts": {
- "type": ["string", "array"],
- "description": "Scripts to include in the startup module",
- "items": {
- "type": "string"
- }
- },
- "dependencies": {
- "type": ["string", "array"],
- "description": "Modules which must be loaded before this module",
- "items": {
- "type": "string"
- }
- },
- "styles": {
- "type": ["string", "array", "object"],
- "description": "Styles to always load",
- "items": {
- "type": "string"
- }
- },
- "skinStyles": {
- "type": "object",
- "description": "Styles to include in specific skin contexts (mapping of skin name to style(s))",
- "patternProperties": {
- ".+": {
- "type": [
- "string",
- "array"
- ],
+ },
+ "loaderScripts": {
+ "type": ["string", "array"],
+ "description": "Scripts to include in the startup module",
+ "items": {
+ "type": "string"
+ }
+ },
+ "dependencies": {
+ "type": ["string", "array"],
+ "description": "Modules which must be loaded before this module",
+ "items": {
+ "type": "string"
+ }
+ },
+ "styles": {
+ "type": ["string", "array", "object"],
+ "description": "Styles to always load",
+ "items": {
+ "type": "string"
+ }
+ },
+ "skinStyles": {
+ "type": "object",
+ "description": "Styles to include in specific skin contexts (mapping of skin name to style(s))",
+ "patternProperties": {
+ ".+": {
+ "type": [
+ "string",
+ "array"
+ ],
+ "items": {
+ "type": "string"
+ }
+ }
+ }
+ },
+ "messages": {
+ "type": ["string", "array"],
+ "description": "Messages to always load",
+ "items": {
+ "type": "string"
+ }
+ },
+ "group": {
+ "type": "string",
+ "description": "Group which this module should be loaded together with"
+ },
+ "position": {
+ "type": "string",
+ "description": "Position on the page to load this module at",
+ "enum": [
+ "bottom",
+ "top"
+ ]
+ },
+ "templates": {
+ "type": "object",
+ "description": "Templates to be loaded for client-side usage"
+ },
+ "targets": {
+ "type": ["string", "array"],
+ "description": "ResourceLoader target the module can run on",
"items": {
"type": "string"
}
}
}
},
- "messages": {
- "type": ["string", "array"],
- "description": "Messages to always load",
- "items": {
- "type": "string"
+ {
+ "description": "A ResourceLoaderImageModule definition",
+ "additionalProperties": false,
+ "properties": {
+ "class": {
+ "enum": ["ResourceLoaderImageModule"]
+ },
+ "data": {
+ "type": "string"
+ },
+ "prefix": {
+ "type": "string"
+ },
+ "selector": {
+ "type": "string"
+ },
+ "selectorWithoutVariant": {
+ "type": "string"
+ },
+ "selectorWithVariant": {
+ "type": "string"
+ },
+ "variants": {
+ "type": "object"
+ },
+ "images": {
+ "type": "object"
+ },
+ "position": {
+ "enum": [
+ "top",
+ "bottom"
+ ]
+ }
}
},
- "group": {
- "type": "string",
- "description": "Group which this module should be loaded together with"
- },
- "position": {
- "type": "string",
- "description": "Position on the page to load this module at",
- "enum": [
- "bottom",
- "top"
- ]
- },
- "templates": {
- "type": "object",
- "description": "Templates to be loaded for client-side usage"
+ {
+ "description": "An arbitrary ResourceLoaderModule definition",
+ "properties": {
+ "class": {
+ "type": "string",
+ "pattern": "^((?!ResourceLoader(File|Image)Module).)*$"
+ }
+ },
+ "required": ["class"]
}
- }
+ ]
}
}
},
* the value is an associative array of parameters. The "cacheId" parameter is
* a cache identifier from $wgObjectCaches. The "relayerConfig" parameter is an
* array used to construct an EventRelayer object. The "pool" parameter is a
- * string that is used as a PubSub channel prefix.
+ * string that is used as a PubSub channel prefix. The "loggroup" parameter
+ * controls where log events are sent.
*
* @since 1.26
*/
'ThumbnailRender' => 'ThumbnailRenderJob',
'recentChangesUpdate' => 'RecentChangesUpdateJob',
'refreshLinksPrioritized' => 'RefreshLinksJob', // for cascading protection
+ 'refreshLinksDynamic' => 'RefreshLinksJob', // for pages with dynamic content
'activityUpdateJob' => 'ActivityUpdateJob',
'enqueue' => 'EnqueueJob', // local queue for multi-DC setups
'null' => 'NullJob'
}
/**
- * @param Title $title
+ * @param User $user
* @param string $oldModel
* @param string $newModel
* @param string $reason
$log->publish( $logid );
}
-
/**
* Register the change of watch status
*/
protected function updateWatchlist() {
global $wgUser;
- if ( $wgUser->isLoggedIn()
- && $this->watchthis != $wgUser->isWatched( $this->mTitle, WatchedItem::IGNORE_USER_RIGHTS )
- ) {
- $fname = __METHOD__;
- $title = $this->mTitle;
- $watch = $this->watchthis;
-
- // Do this in its own transaction to reduce contention...
- $dbw = wfGetDB( DB_MASTER );
- $dbw->onTransactionIdle( function () use ( $dbw, $title, $watch, $wgUser, $fname ) {
- WatchAction::doWatchOrUnwatch( $watch, $title, $wgUser );
- } );
+ if ( !$wgUser->isLoggedIn() ) {
+ return;
}
+
+ $user = $wgUser;
+ $title = $this->mTitle;
+ $watch = $this->watchthis;
+ // Do this in its own transaction to reduce contention...
+ DeferredUpdates::addCallableUpdate( function () use ( $user, $title, $watch ) {
+ if ( $watch == $user->isWatched( $title, WatchedItem::IGNORE_USER_RIGHTS ) ) {
+ return; // nothing to change
+ }
+ WatchAction::doWatchOrUnwatch( $watch, $title, $user );
+ } );
}
/**
$page = WikiPage::factory( $title );
$dbw = wfGetDB( DB_MASTER );
try {
+ $dbw->startAtomic( __METHOD__ );
// delete the associated article first
$error = '';
$deleteStatus = $page->doDeleteArticleReal( $reason, $suppress, 0, false, $error, $user );
if ( $deleteStatus->isOK() ) {
$status = $file->delete( $reason, $suppress, $user );
if ( $status->isOK() ) {
- $dbw->commit( __METHOD__ );
$status->value = $deleteStatus->value; // log id
+ $dbw->endAtomic( __METHOD__ );
} else {
+ // Page deleted but file still there? rollback page delete
$dbw->rollback( __METHOD__ );
}
+ } else {
+ // Done; nothing changed
+ $dbw->endAtomic( __METHOD__ );
}
} catch ( Exception $e ) {
// Rollback before returning to prevent UI from displaying
RepoGroup::singleton()->clearCache( $this->newTitle ); # clear false negative cache
}
- $dbw->begin( __METHOD__ ); # If $file was a LocalFile, its transaction would have closed our own.
+ $dbw->startAtomic( __METHOD__ );
$pageid = $this->oldTitle->getArticleID( Title::GAID_FOR_UPDATE );
$protected = $this->oldTitle->isProtected();
WatchedItem::duplicateEntries( $this->oldTitle, $this->newTitle );
}
- $dbw->commit( __METHOD__ );
+ $dbw->endAtomic( __METHOD__ );
+
+ $params = array( $this->oldTitle, $this->newTitle, $user, $pageid, $redirid, $reason );
+ $dbw->onTransactionIdle( function () use ( $params ) {
+ Hooks::run( 'TitleMoveComplete', $params );
+ } );
- Hooks::run(
- 'TitleMoveComplete',
- array( &$this->oldTitle, &$this->newTitle, &$user, $pageid, $redirid, $reason )
- );
return Status::newGood();
}
* @return array Array of module names
*/
public function getModuleStyles( $filter = false, $position = null ) {
- // T97420
- $resourceLoader = $this->getResourceLoader();
-
- foreach ( $this->mModuleStyles as $val ) {
- $module = $resourceLoader->getModule( $val );
-
- if ( $module instanceof ResourceLoaderModule && $module->isPositionDefault() ) {
- $warning = __METHOD__ . ': style module should define its position explicitly: ' .
- $val . ' ' . get_class( $module );
- wfDebugLog( 'resourceloader', $warning );
- wfLogWarning( $warning );
- }
- }
-
return $this->getModules( $filter, $position, 'mModuleStyles' );
}
ResourceLoaderModule::TYPE_SCRIPTS
);
- $links[] = $this->makeResourceLoaderLink( $this->getModuleStyles( true, 'bottom' ),
- ResourceLoaderModule::TYPE_STYLES
- );
-
// Modules requests - let the client calculate dependencies and batch requests as it likes
// Only load modules that have marked themselves for loading at the bottom
$modules = $this->getModules( true, 'bottom' );
* @return string
*/
function getBottomScripts() {
- // In case the skin wants to add bottom CSS
- $this->getSkin()->setupSkinUserCss( $this );
-
return $this->getScriptsForBottomQueue();
}
$otherTags = array(); // Tags to append after the normal <link> tags
$resourceLoader = $this->getResourceLoader();
- $moduleStyles = $this->getModuleStyles( true, 'top' );
+ $moduleStyles = $this->getModuleStyles();
// Per-site custom styles
$moduleStyles[] = 'site';
return $array;
}
+ /**
+ * Get a redirect's destination from a title
+ * @param Title $title A title to redirect. It may not redirect or even exist
+ * @return null|string If title exists and redirects, get the destination's prefixed name
+ */
private function getRedirectTarget( $title ) {
$page = WikiPage::factory( $title );
if ( !$page->exists() ) {
return null;
}
- return $page->getRedirectTarget()->getPrefixedText();
+ $redir = $page->getRedirectTarget();
+ return $redir ? $redir->getPrefixedText() : null;
}
/**
return false;
}
- global $wgMemc;
-
$limits = $wgRateLimits[$action];
$keys = array();
$id = $this->getId();
$keys[wfMemcKey( 'limiter', $action, 'user', $id )] = $userLimit;
}
+ $cache = ObjectCache::getLocalClusterInstance();
+
$triggered = false;
foreach ( $keys as $key => $limit ) {
list( $max, $period ) = $limit;
$summary = "(limit $max in {$period}s)";
- $count = $wgMemc->get( $key );
+ $count = $cache->get( $key );
// Already pinged?
if ( $count ) {
if ( $count >= $max ) {
} else {
wfDebug( __METHOD__ . ": adding record for $key $summary\n" );
if ( $incrBy > 0 ) {
- $wgMemc->add( $key, 0, intval( $period ) ); // first ping
+ $cache->add( $key, 0, intval( $period ) ); // first ping
}
}
if ( $incrBy > 0 ) {
- $wgMemc->incr( $key, $incrBy );
+ $cache->incr( $key, $incrBy );
}
}
),
),
'min' => array(
- ApiBase::PARAM_DFLT => null,
ApiBase::PARAM_TYPE => 'integer'
),
'max' => array(
- ApiBase::PARAM_DFLT => null,
ApiBase::PARAM_TYPE => 'integer'
),
'limit' => array(
'namespace' => array(
ApiBase::PARAM_ISMULTI => true,
ApiBase::PARAM_TYPE => 'namespace',
- ApiBase::PARAM_DFLT => null,
),
'start' => array(
ApiBase::PARAM_TYPE => 'timestamp',
)
),
'mime' => array(
- ApiBase::PARAM_DFLT => null,
ApiBase::PARAM_ISMULTI => true,
),
'limit' => array(
public function getAllowedParams() {
return array(
'prop' => array(
- ApiBase::PARAM_DFLT => null,
ApiBase::PARAM_ISMULTI => true,
ApiBase::PARAM_TYPE => array(
'protection',
),
'token' => array(
ApiBase::PARAM_DEPRECATED => true,
- ApiBase::PARAM_DFLT => null,
ApiBase::PARAM_ISMULTI => true,
ApiBase::PARAM_TYPE => array_keys( $this->getTokenFunctions() )
),
ApiBase::PARAM_HELP_MSG => 'apihelp-query+revisions+base-param-parse',
),
'section' => array(
- ApiBase::PARAM_DFLT => null,
ApiBase::PARAM_HELP_MSG => 'apihelp-query+revisions+base-param-section',
),
'diffto' => array(
- ApiBase::PARAM_DFLT => null,
ApiBase::PARAM_HELP_MSG => 'apihelp-query+revisions+base-param-diffto',
),
'difftotext' => array(
- ApiBase::PARAM_DFLT => null,
ApiBase::PARAM_HELP_MSG => 'apihelp-query+revisions+base-param-difftotext',
),
'difftotextpst' => array(
),
'contentformat' => array(
ApiBase::PARAM_TYPE => ContentHandler::getAllContentFormats(),
- ApiBase::PARAM_DFLT => null,
ApiBase::PARAM_HELP_MSG => 'apihelp-query+revisions+base-param-contentformat',
),
);
ApiBase::PARAM_ISMULTI => true,
),
'what' => array(
- ApiBase::PARAM_DFLT => null,
ApiBase::PARAM_TYPE => array(
'title',
'text',
return array(
'filekey' => array(
ApiBase::PARAM_ISMULTI => true,
- ApiBase::PARAM_DFLT => null
),
'sessionkey' => array(
ApiBase::PARAM_ISMULTI => true,
ApiBase::PARAM_DEPRECATED => true,
- ApiBase::PARAM_DFLT => null
),
'prop' => array(
ApiBase::PARAM_ISMULTI => true,
public function getAllowedParams() {
return array(
'prop' => array(
- ApiBase::PARAM_DFLT => null,
ApiBase::PARAM_ISMULTI => true,
ApiBase::PARAM_TYPE => array(
'blockinfo',
public function getAllowedParams() {
return array(
'prop' => array(
- ApiBase::PARAM_DFLT => null,
ApiBase::PARAM_ISMULTI => true,
ApiBase::PARAM_TYPE => array(
'blockinfo',
const ERROR_UNCACHEABLE = 'uncacheable';
public function execute() {
- global $wgMemc;
+ $cache = ObjectCache::getLocalClusterInstance();
$user = $this->getUser();
$params = $this->extractRequestParams();
// De-duplicate requests on the same key
if ( $user->pingLimiter( 'stashedit' ) ) {
$status = 'ratelimited';
- } elseif ( $wgMemc->lock( $key, 0, 30 ) ) {
+ } elseif ( $cache->lock( $key, 0, 30 ) ) {
/** @noinspection PhpUnusedLocalVariableInspection */
- $unlocker = new ScopedCallback( function() use ( $key ) {
- global $wgMemc;
- $wgMemc->unlock( $key );
+ $unlocker = new ScopedCallback( function() use ( $cache, $key ) {
+ $cache->unlock( $key );
} );
$status = self::parseAndStash( $page, $content, $user );
} else {
* @since 1.25
*/
public static function parseAndStash( WikiPage $page, Content $content, User $user ) {
- global $wgMemc;
+ $cache = ObjectCache::getLocalClusterInstance();
$format = $content->getDefaultFormat();
$editInfo = $page->prepareContentForEdit( $content, null, $user, $format, false );
);
if ( $stashInfo ) {
- $ok = $wgMemc->set( $key, $stashInfo, $ttl );
+ $ok = $cache->set( $key, $stashInfo, $ttl );
if ( $ok ) {
wfDebugLog( 'StashEdit', "Cached parser output for key '$key'." );
return self::ERROR_NONE;
* will do nothing. Provided the values are cacheable, they will be stored
* in memcached so that final edit submission might make use of them.
*
- * @param Article|WikiPage $page Page title
+ * @param Page|Article|WikiPage $page Page title
* @param Content $content Proposed page content
* @param Content $pstContent The result of preSaveTransform() on $content
* @param ParserOutput $pOut The result of getParserOutput() on $pstContent
Page $page, Content $content, Content $pstContent, ParserOutput $pOut,
ParserOptions $pstOpts, ParserOptions $pOpts, $timestamp
) {
- global $wgMemc;
+ $cache = ObjectCache::getLocalClusterInstance();
// getIsPreview() controls parser function behavior that references things
// like user/revision that don't exists yet. The user/text should already
return false;
}
- $ok = $wgMemc->set( $key, $stashInfo, $ttl );
+ $ok = $cache->set( $key, $stashInfo, $ttl );
if ( !$ok ) {
wfDebugLog( 'StashEdit', "Failed to cache preview parser output for key '$key'." );
} else {
* @return stdClass|bool Returns false on cache miss
*/
public static function checkCache( Title $title, Content $content, User $user ) {
- global $wgMemc;
+ $cache = ObjectCache::getLocalClusterInstance();
$key = self::getStashKey( $title, $content, $user );
- $editInfo = $wgMemc->get( $key );
+ $editInfo = $cache->get( $key );
if ( !is_object( $editInfo ) ) {
$start = microtime( true );
// We ignore user aborts and keep parsing. Block on any prior parsing
// so as to use it's results and make use of the time spent parsing.
- if ( $wgMemc->lock( $key, 30, 30 ) ) {
- $editInfo = $wgMemc->get( $key );
- $wgMemc->unlock( $key );
+ if ( $cache->lock( $key, 30, 30 ) ) {
+ $editInfo = $cache->get( $key );
+ $cache->unlock( $key );
}
$sec = microtime( true ) - $start;
if ( $sec > .01 ) {
'url' => null,
'filekey' => null,
'sessionkey' => array(
- ApiBase::PARAM_DFLT => null,
ApiBase::PARAM_DEPRECATED => true,
),
'stash' => false,
"apihelp-query+watchlist-paramvalue-prop-loginfo": "Ajoute l’information de trace le cas échéant.",
"apihelp-query+watchlist-param-show": "Afficher uniquement les éléments qui correspondent à ces critères. Par exemple, pour voir uniquement les modifications mineures faites par des utilisateurs connectés, mettre $1show=minor|!anon.",
"apihelp-query+watchlist-param-type": "Quels types de modification afficher :\n;edit:Modifications ordinaires de page.\n;external:Modifications externes.\n;new:Créations de page.\n;log:Entrées du journal.",
+ "apihelp-query+watchlist-paramvalue-type-new": "Créations de pages.",
+ "apihelp-query+watchlist-paramvalue-type-log": "Entrées du journal.",
"apihelp-query+watchlist-param-owner": "Utilisé avec $1token pour accéder à la liste de suivi d’un autre utilisateur.",
"apihelp-query+watchlist-param-token": "Un jeton de sécurité (disponible dans les [[Special:Preferences#mw-prefsection-watchlist|préférences]] de l’utilsiateur) pour autoriser l’accès à la liste de suivi d&un autre utilisateur.",
"apihelp-query+watchlist-example-simple": "Lister la révision de tête des pages récemment modifiées dans la liste de suivi de l’utilisateur actuel",
"apihelp-main-param-curtimestamp": "निकालात सद्य वेळठश्याचा अंतर्भाव करा.",
"apihelp-block-description": "सदस्यास प्रतिबंधित करा.",
"apihelp-block-param-user": "सदस्याचे नाव, अंक-पत्त्ता, किंवा प्रतिबंध करण्यासाठीचा आयपीचा आवाका.",
+ "apihelp-delete-description": "पान वगळा",
+ "apihelp-edit-param-minor": "छोटे संपादन",
+ "apihelp-edit-param-notminor": "छोटे नसलेले संपादन",
+ "apihelp-edit-example-edit": "पान संपादा",
+ "apihelp-login-param-name": "सदस्य नाव.",
+ "apihelp-login-param-password": "परवलीचा शब्द.",
+ "apihelp-login-example-login": "सनोंद-प्रवेश करा.",
+ "apihelp-move-description": "पृष्ठाचे स्थानांतरण करा.",
+ "apihelp-move-param-ignorewarnings": "सर्व सूचनांकडे दुर्लक्ष करा.",
+ "apihelp-options-example-reset": "पसंतीक्रमाची पुनर्स्थापना",
+ "apihelp-patrol-description": "पानावर किंवा आवृत्तीवर पहारा द्या.",
+ "apihelp-patrol-example-rcid": "अलीकडील बदलावर पहारा द्या.",
+ "apihelp-patrol-example-revid": "आवृत्तीवर पहारा द्या.",
+ "apihelp-protect-description": "पानाची सुरक्षापातळी बदला.",
+ "apihelp-protect-example-protect": "पानास सुरक्षित करा.",
+ "apihelp-query-param-list": "कोणती यादी मागवायची.",
+ "apihelp-query-param-meta": "कोणता मेटाडाटा हवा.",
"apihelp-query+allrevisions-description": "सर्व आवृत्त्यांची यादी",
"apihelp-query+allrevisions-param-user": "फक्त या सदस्याच्याच आवृत्त्यांची यादी करा",
"apihelp-query+allrevisions-param-excludeuser": "या सदस्याच्या आवृत्त्यांची यादी करु नका.",
"apihelp-query+allredirects-example-unique-generator": "获取所有目标页面,标记丢失的。",
"apihelp-query+allredirects-example-generator": "获取包含重定向的页面。",
"apihelp-query+allrevisions-description": "列举所有修订。",
+ "apihelp-query+allrevisions-param-start": "枚举的起始时间戳。",
+ "apihelp-query+allrevisions-param-end": "枚举的结束时间戳。",
"apihelp-query+allrevisions-param-user": "只列出此用户做出的修订。",
"apihelp-query+allrevisions-param-excludeuser": "不要列出此用户做出的修订。",
"apihelp-query+allrevisions-param-namespace": "只列出此名字空间的页面。",
* @return void
*/
public function incrMissesRecent( WebRequest $request ) {
- global $wgMemc;
if ( mt_rand( 0, self::MISS_FACTOR - 1 ) == 0 ) {
+ $cache = ObjectCache::getLocalClusterInstance();
# Get a large IP range that should include the user even if that
# person's IP address changes
$ip = $request->getIP();
# Bail out if a request already came from this range...
$key = wfMemcKey( get_class( $this ), 'attempt', $this->mType, $this->mKey, $ip );
- if ( $wgMemc->get( $key ) ) {
+ if ( $cache->get( $key ) ) {
return; // possibly the same user
}
- $wgMemc->set( $key, 1, self::MISS_TTL_SEC );
+ $cache->set( $key, 1, self::MISS_TTL_SEC );
# Increment the number of cache misses...
$key = $this->cacheMissKey();
- if ( $wgMemc->get( $key ) === false ) {
- $wgMemc->set( $key, 1, self::MISS_TTL_SEC );
+ if ( $cache->get( $key ) === false ) {
+ $cache->set( $key, 1, self::MISS_TTL_SEC );
} else {
- $wgMemc->incr( $key );
+ $cache->incr( $key );
}
}
}
* @return int
*/
public function getMissesRecent() {
- global $wgMemc;
+ $cache = ObjectCache::getLocalClusterInstance();
- return self::MISS_FACTOR * $wgMemc->get( $this->cacheMissKey() );
+ return self::MISS_FACTOR * $cache->get( $this->cacheMissKey() );
}
/**
return $this->__call( __FUNCTION__, func_get_args() );
}
+ public function writesPending() {
+ return $this->__call( __FUNCTION__, func_get_args() );
+ }
+
public function writesOrCallbacksPending() {
return $this->__call( __FUNCTION__, func_get_args() );
}
return $this->mDoneWrites ?: false;
}
+ /**
+ * @return bool Whether there is a transaction open with possible write queries
+ * @since 1.27
+ */
+ public function writesPending() {
+ return $this->mTrxLevel && $this->mTrxDoneWrites;
+ }
+
/**
* Returns true if there is a transaction open with possible write
* queries or transaction pre-commit/idle callbacks waiting on it to finish.
*
* @param IDatabase $db1
* @param IDatabase ...
- * @return array ('lag': highest lag, 'since': lowest estimate UNIX timestamp)
+ * @return array Map of values:
+ * - lag: highest lag of any of the DBs
+ * - since: oldest UNIX timestamp of any of the DB lag estimates
+ * - pending: whether any of the DBs have uncommitted changes
* @since 1.27
*/
public static function getCacheSetOptions( IDatabase $db1 ) {
- $res = array( 'lag' => 0, 'since' => INF );
+ $res = array( 'lag' => 0, 'since' => INF, 'pending' => false );
foreach ( func_get_args() as $db ) {
/** @var IDatabase $db */
$status = $db->getSessionLagStatus();
$res['lag'] = max( $res['lag'], $status['lag'] );
$res['since'] = min( $res['since'], $status['since'] );
+ $res['pending'] = $res['pending'] ?: $db->writesPending();
}
return $res;
return $s;
}
+ function getPageTitle() {
+ return $this->msg( 'databaseerror', 'Database error' );
+ }
+
/**
* @return string
*/
* @ingroup Database
*/
class DBReadOnlyError extends DBExpectedError {
+ function getPageTitle() {
+ return $this->msg( 'readonly', 'Database is locked' );
+ }
}
*/
public function lastDoneWrites();
+ /**
+ * @return bool Whether there is a transaction open with possible write queries
+ * @since 1.27
+ */
+ public function writesPending();
+
/**
* Returns true if there is a transaction open with possible write
* queries or transaction pre-commit/idle callbacks waiting on it to finish.
* Commit changes on all master connections
*/
public function commitMasterChanges() {
+ $start = microtime( true );
$this->forEachLBCallMethod( 'commitMasterChanges' );
+ $timeMs = 1000 * ( microtime( true ) - $start );
+ RequestContext::getMain()->getStats()->timing( "db.commit-masters", $timeMs );
}
/**
* @return \\Psr\\Log\\LoggerInterface
*/
public static function getInstance( $channel ) {
- if ( !interface_exists( '\Psr\Log\LoggerInterface' ) ) {
- $message = (
- 'MediaWiki requires the <a href="https://github.com/php-fig/log">PSR-3 logging ' .
- "library</a> to be present. This library is not embedded directly in MediaWiki's " .
- "git repository and must be installed separately by the end user.\n\n" .
- 'Please see <a href="https://www.mediawiki.org/wiki/Download_from_Git' .
- '#Fetch_external_libraries">mediawiki.org</a> for help on installing ' .
- 'the required components.'
- );
- echo $message;
- trigger_error( $message, E_USER_ERROR );
- die( 1 );
+ static $hasPSR3Interface = null;
+ if ( $hasPSR3Interface === null ) {
+ $hasPSR3Interface = interface_exists( '\Psr\Log\LoggerInterface' );
+ if ( !$hasPSR3Interface ) {
+ $message = (
+ 'MediaWiki requires the <a href="https://github.com/php-fig/log">PSR-3 logging ' .
+ "library</a> to be present. This library is not embedded directly in MediaWiki's " .
+ "git repository and must be installed separately by the end user.\n\n" .
+ 'Please see <a href="https://www.mediawiki.org/wiki/Download_from_Git' .
+ '#Fetch_external_libraries">mediawiki.org</a> for help on installing ' .
+ 'the required components.'
+ );
+ echo $message;
+ trigger_error( $message, E_USER_ERROR );
+ die( 1 );
+ }
}
return self::getProvider()->getLogger( $channel );
// Which ever runs first generally no-ops the other one.
$jobs = array();
foreach ( $bc->getCascadeProtectedLinks() as $title ) {
- $jobs[] = new RefreshLinksJob( $title, array( 'prioritize' => true ) );
+ $jobs[] = RefreshLinksJob::newPrioritized( $title, array() );
}
JobQueueGroup::singleton()->push( $jobs );
}
'job' => new JobSpecification(
'refreshLinksPrioritized',
array(
- 'prioritize' => true,
// Reuse the parser cache if it was saved
'rootJobTimestamp' => $this->mParserOutput->getCacheTime(),
'useRecursiveLinksUpdate' => $this->mRecursive
if ( empty( $opts['force'] ) ) { // sanity
unset( $opts['nonLocking'] );
}
- foreach ( $ops as &$op ) {
- if ( isset( $op['disposition'] ) ) { // b/c (MW 1.20)
- $op['headers']['Content-Disposition'] = $op['disposition'];
- }
- }
/** @noinspection PhpUnusedLocalVariableInspection */
$scope = $this->getScopedPHPBehaviorForOps(); // try to ignore client aborts
return $this->doOperationsInternal( $ops, $opts );
}
foreach ( $ops as &$op ) {
$op['overwrite'] = true; // avoids RTTs in key/value stores
- if ( isset( $op['disposition'] ) ) { // b/c (MW 1.20)
- $op['headers']['Content-Disposition'] = $op['disposition'];
- }
}
/** @noinspection PhpUnusedLocalVariableInspection */
$scope = $this->getScopedPHPBehaviorForOps(); // try to ignore client aborts
}
$sha1Hash = wfBaseConvert( sha1( $params['content'] ), 16, 36, 31 );
- $contentType = $this->getContentType( $params['dst'], $params['content'], null );
+ $contentType = isset( $params['headers']['content-type'] )
+ ? $params['headers']['content-type']
+ : $this->getContentType( $params['dst'], $params['content'], null );
$reqs = array( array(
'method' => 'PUT',
return $status;
}
$sha1Hash = wfBaseConvert( $sha1Hash, 16, 36, 31 );
- $contentType = $this->getContentType( $params['dst'], null, $params['src'] );
+ $contentType = isset( $params['headers']['content-type'] )
+ ? $params['headers']['content-type']
+ : $this->getContentType( $params['dst'], null, $params['src'] );
$handle = fopen( $params['src'], 'rb' );
if ( $handle === false ) { // source doesn't exist?
* @return bool|string
*/
function getThumbUrlFromCache( $name, $width, $height, $params = "" ) {
- global $wgMemc;
+ $cache = ObjectCache::getMainWANInstance();
// We can't check the local cache using FileRepo functions because
// we override fileExistsBatch(). We have to use the FileBackend directly.
$backend = $this->getBackend(); // convenience
$sizekey = "$width:$height:$params";
/* Get the array of urls that we already know */
- $knownThumbUrls = $wgMemc->get( $key );
+ $knownThumbUrls = $cache->get( $key );
if ( !$knownThumbUrls ) {
/* No knownThumbUrls for this file */
$knownThumbUrls = array();
if ( $remoteModified < $modified && $diff < $this->fileCacheExpiry ) {
/* Use our current and already downloaded thumbnail */
$knownThumbUrls[$sizekey] = $localUrl;
- $wgMemc->set( $key, $knownThumbUrls, $this->apiThumbCacheExpiry );
+ $cache->set( $key, $knownThumbUrls, $this->apiThumbCacheExpiry );
return $localUrl;
}
return $foreignUrl;
}
$knownThumbUrls[$sizekey] = $localUrl;
- $wgMemc->set( $key, $knownThumbUrls, $this->apiThumbCacheExpiry );
+ $cache->set( $key, $knownThumbUrls, $this->apiThumbCacheExpiry );
wfDebug( __METHOD__ . " got local thumb $localUrl, saving to cache \n" );
return $localUrl;
}
if ( !isset( $this->mQueryCache[$url] ) ) {
- global $wgMemc;
-
- $key = $this->getLocalCacheKey( get_class( $this ), $target, md5( $url ) );
- $data = $wgMemc->get( $key );
-
- if ( !$data ) {
- $data = self::httpGet( $url );
-
- if ( !$data ) {
- return null;
+ $data = ObjectCache::getMainWANInstance()->getWithSetCallback(
+ $this->getLocalCacheKey( get_class( $this ), $target, md5( $url ) ),
+ $cacheTTL,
+ function () use ( $url ) {
+ return ForeignAPIRepo::httpGet( $url );
}
+ );
- $wgMemc->set( $key, $data, $cacheTTL );
+ if ( !$data ) {
+ return null;
}
if ( count( $this->mQueryCache ) > 100 ) {
if ( !$thumb ) { // bad params?
$thumb = false;
} elseif ( $thumb->isError() ) { // transform error
+ /** @var $thumb MediaTransformError */
$this->lastError = $thumb->toText();
// Ignore errors if requested
if ( $wgIgnoreImageErrors && !( $flags & self::RENDER_NOW ) ) {
* @param string $reason
* @param bool $suppress Hide content from sysops?
* @param User|null $user
- * @return bool Boolean on success, false on some kind of failure
+ * @return FileRepoStatus
* STUB
* Overridden by LocalFile
*/
* @return string
*/
function getDescriptionText( $lang = false ) {
- global $wgMemc, $wgLang;
+ global $wgLang;
+
if ( !$this->repo || !$this->repo->fetchDescription ) {
return false;
}
- if ( !$lang ) {
- $lang = $wgLang;
- }
+
+ $lang = $lang ?: $wgLang;
+
$renderUrl = $this->repo->getDescriptionRenderUrl( $this->getName(), $lang->getCode() );
if ( $renderUrl ) {
+ $cache = ObjectCache::getMainWANInstance();
+
+ $key = null;
if ( $this->repo->descriptionCacheExpiry > 0 ) {
wfDebug( "Attempting to get the description from cache..." );
$key = $this->repo->getLocalCacheKey(
$lang->getCode(),
$this->getName()
);
- $obj = $wgMemc->get( $key );
+ $obj = $cache->get( $key );
if ( $obj ) {
wfDebug( "success!\n" );
}
wfDebug( "Fetching shared description from $renderUrl\n" );
$res = Http::get( $renderUrl, array(), __METHOD__ );
- if ( $res && $this->repo->descriptionCacheExpiry > 0 ) {
- $wgMemc->set( $key, $res, $this->repo->descriptionCacheExpiry );
+ if ( $res && $key ) {
+ $cache->set( $key, $res, $this->repo->descriptionCacheExpiry );
}
return $res;
}
function purgeDescriptionPage() {
- global $wgMemc, $wgContLang;
+ global $wgContLang;
$url = $this->repo->getDescriptionRenderUrl( $this->getName(), $wgContLang->getCode() );
$key = $this->repo->getLocalCacheKey( 'RemoteFileDescription', 'url', md5( $url ) );
- $wgMemc->delete( $key );
+ ObjectCache::getMainWANInstance()->delete( $key );
}
/**
* @param array $options
*/
function purgeThumbnails( $options = array() ) {
- global $wgMemc;
-
$key = $this->repo->getLocalCacheKey( 'ForeignAPIRepo', 'ThumbUrl', $this->getName() );
- $wgMemc->delete( $key );
+ ObjectCache::getMainWANInstance()->delete( $key );
$files = $this->getThumbnails();
// Give media handler a chance to filter the purge list
"config-header-sqlite": "SQLite-indstillinger",
"config-header-oracle": "Oracle-indstillinger",
"config-invalid-db-type": "Ugyldig databasetype",
+ "config-email-usertalk": "Aktiver notifikationer for brugerdiskussionsside",
"mainpagetext": "'''MediaWiki er nu installeret.'''",
"mainpagedocfooter": "Se [//meta.wikimedia.org/wiki/Help:Contents brugervejledningen] for oplysninger om brugen af wikiprogrammellet.\n\n== At komme i gang ==\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:Configuration_settings Listen over opsætningsmuligheder]\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:FAQ MediaWiki ofte stillede spørgsmål]\n* [https://lists.wikimedia.org/mailman/listinfo/mediawiki-announce Postliste angående udgivelser af MediaWiki]\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Localisation#Translation_resources Oversæt MediaWiki til dit sprog]"
}
"config-nofile": "Il file \"$1\" non può essere trovato. È stato eliminato?",
"config-extension-link": "Sapevi che il tuo wiki supporta le [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:Extensions estensioni]?\n\nPuoi navigare tra le [//www.mediawiki.org/wiki/Special:MyLanguage/Category:Extensions_by_category estensioni per categoria].",
"mainpagetext": "'''Installazione di MediaWiki completata correttamente.'''",
- "mainpagedocfooter": "Consulta la [//meta.wikimedia.org/wiki/Special:MyLanguage/Help:Contents Guida utente] per maggiori informazioni sull'uso di questo software wiki.\n\n== Per iniziare ==\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:Configuration_settings Impostazioni di configurazione]\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:FAQ Domande frequenti su MediaWiki]\n* [https://lists.wikimedia.org/mailman/listinfo/mediawiki-announce Mailing list annunci MediaWiki]\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Localisation#Translation_resources Localizza MediaWiki nella tua lingua]"
+ "mainpagedocfooter": "Consulta la [//meta.wikimedia.org/wiki/Special:MyLanguage/Help:Contents Guida utente] per maggiori informazioni sull'uso di questo software wiki.\n\n== Per iniziare ==\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:Configuration_settings Impostazioni di configurazione]\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:FAQ Domande frequenti su MediaWiki]\n* [https://lists.wikimedia.org/mailman/listinfo/mediawiki-announce Mailing list annunci MediaWiki]\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Localisation#Translation_resources Localizza MediaWiki nella tua lingua]\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:Combating_spam Imparare a combattere lo spam sul tuo wiki]"
}
"config-nofile": "找不到文件“$1”。它是否已被删除?",
"config-extension-link": "您是否知道您的wiki支持[//www.mediawiki.org/wiki/Special:MyLanguage/Manual:Extensions 拓展]?\n您可浏览[//www.mediawiki.org/wiki/Special:MyLanguage/Category:Extensions_by_category 拓展分类]。",
"mainpagetext": "'''已成功安装MediaWiki。'''",
- "mainpagedocfooter": "请查阅[//meta.wikimedia.org/wiki/Help:Contents 用户指南]以获取使用本wiki软件的信息!\n\n== 入门 ==\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:Configuration_settings MediaWiki配置设置列表]\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:FAQ/zh-hans MediaWiki常见问题]\n* [https://lists.wikimedia.org/mailman/listinfo/mediawiki-announce MediaWiki发布邮件列表]\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Localisation#Translation_resources 本地化MediaWiki到您的语言]"
+ "mainpagedocfooter": "请查阅[//meta.wikimedia.org/wiki/Help:Contents 用户指南]以获取使用本wiki软件的信息!\n\n== 入门 ==\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:Configuration_settings MediaWiki配置设置列表]\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:FAQ/zh-hans MediaWiki常见问题]\n* [https://lists.wikimedia.org/mailman/listinfo/mediawiki-announce MediaWiki发布邮件列表]\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Localisation#Translation_resources 本地化MediaWiki到您的语言]\n* [//www.mediawiki.org/wiki/Special:MyLanguage/Manual:Combating_spam 了解如何在您的wiki上打击破坏]"
}
*/
public static function factory( $command, Title $title, $params = array() ) {
global $wgJobClasses;
+
if ( isset( $wgJobClasses[$command] ) ) {
$class = $wgJobClasses[$command];
- return new $class( $title, $params );
+ $job = new $class( $title, $params );
+ $job->command = $command;
+
+ return $job;
}
- throw new MWException( "Invalid job command `{$command}`" );
+
+ throw new InvalidArgumentException( "Invalid job command '{$command}'" );
}
/**
* @throws MWException
*/
protected function doGetAbandonedCount() {
- global $wgMemc;
-
if ( $this->claimTTL <= 0 ) {
return 0; // no acknowledgements
}
$key = $this->getCacheKey( 'abandonedcount' );
- $count = $wgMemc->get( $key );
+ $count = $this->cache->get( $key );
if ( is_int( $count ) ) {
return $count;
}
} catch ( DBError $e ) {
$this->throwDBException( $e );
}
- $wgMemc->set( $key, $count, self::CACHE_TTL_SHORT );
+
+ $this->cache->set( $key, $count, self::CACHE_TTL_SHORT );
return $count;
}
* @since 1.23
*/
public function queuesHaveJobs( $type = self::TYPE_ANY ) {
- global $wgMemc;
-
$key = wfMemcKey( 'jobqueue', 'queueshavejobs', $type );
+ $cache = ObjectCache::getLocalClusterInstance();
- $value = $wgMemc->get( $key );
+ $value = $cache->get( $key );
if ( $value === false ) {
$queues = $this->getQueuesWithJobs();
if ( $type == self::TYPE_DEFAULT ) {
$queues = array_intersect( $queues, $this->getDefaultQueueTypes() );
}
$value = count( $queues ) ? 'true' : 'false';
- $wgMemc->add( $key, $value, 15 );
+ $cache->add( $key, $value, 15 );
}
return ( $value === 'true' );
* @return mixed
*/
private function getCachedConfigVar( $name ) {
- global $wgConf, $wgMemc;
+ global $wgConf;
if ( $this->wiki === wfWikiID() ) {
return $GLOBALS[$name]; // common case
} else {
+ $cache = ObjectCache::getLocalClusterInstance();
list( $db, $prefix ) = wfSplitWikiID( $this->wiki );
$key = wfForeignMemcKey( $db, $prefix, 'configvalue', $name );
- $value = $wgMemc->get( $key ); // ('v' => ...) or false
+ $value = $cache->get( $key ); // ('v' => ...) or false
if ( is_array( $value ) ) {
return $value['v'];
} else {
$value = $wgConf->getConfig( $this->wiki, $name );
- $wgMemc->set( $key, array( 'v' => $value ), 86400 + mt_rand( 0, 86400 ) );
+ $cache->set( $key, array( 'v' => $value ), 86400 + mt_rand( 0, 86400 ) );
return $value;
}
function __construct( Title $title, array $params ) {
parent::__construct( 'refreshLinks', $title, $params );
- // A separate type is used just for cascade-protected backlinks
- if ( !empty( $this->params['prioritize'] ) ) {
- $this->command .= 'Prioritized';
- }
// Base backlink update jobs and per-title update jobs can be de-duplicated.
// If template A changes twice before any jobs run, a clean queue will have:
// (A base, A base)
&& ( !isset( $params['pages'] ) || count( $params['pages'] ) == 1 );
}
+ /**
+ * @param Title $title
+ * @param array $params
+ * @return RefreshLinksJob
+ */
+ public static function newPrioritized( Title $title, array $params ) {
+ $job = new self( $title, $params );
+ $job->command = 'refreshLinksPrioritized';
+
+ return $job;
+ }
+
+ /**
+ * @param Title $title
+ * @param array $params
+ * @return RefreshLinksJob
+ */
+ public static function newDynamic( Title $title, array $params ) {
+ $job = new self( $title, $params );
+ $job->command = 'refreshLinksDynamic';
+
+ return $job;
+ }
+
function run() {
global $wgUpdateRowsPerJob;
* @author Aaron Schulz
*/
+use Psr\Log\LoggerAwareInterface;
+use Psr\Log\LoggerInterface;
+use Psr\Log\NullLogger;
+
/**
* Multi-datacenter aware caching interface
*
* @ingroup Cache
* @since 1.26
*/
-class WANObjectCache {
+class WANObjectCache implements LoggerAwareInterface {
/** @var BagOStuff The local datacenter cache */
protected $cache;
/** @var HashBagOStuff Script instance PHP cache */
protected $pool;
/** @var EventRelayer Bus that handles purge broadcasts */
protected $relayer;
+ /** @var LoggerInterface */
+ protected $logger;
/** @var int ERR_* constant for the "last error" registry */
protected $lastRelayError = self::ERR_NONE;
* - cache : BagOStuff object
* - pool : pool name
* - relayer : EventRelayer object
+ * - logger : LoggerInterface object
*/
public function __construct( array $params ) {
$this->cache = $params['cache'];
$this->pool = $params['pool'];
$this->relayer = $params['relayer'];
$this->procCache = new HashBagOStuff();
+ $this->setLogger( isset( $params['logger'] ) ? $params['logger'] : new NullLogger() );
+ }
+
+ public function setLogger( LoggerInterface $logger ) {
+ $this->logger = $logger;
}
/**
* the current time the data was read or (if applicable) the time when
* the snapshot-isolated transaction the data was read from started.
* Default: 0 seconds
+ * - pending : Whether this data is possibly from an uncommitted write transaction.
+ * Generally, other threads should not see values from the future and
+ * they certainly should not see ones that ended up getting rolled back.
+ * Default: false
* - lockTSE : if excessive possible snapshot lag is detected,
* then stash the value into a temporary location
* with this TTL. This is only useful if the reads
$age = isset( $opts['since'] ) ? max( 0, microtime( true ) - $opts['since'] ) : 0;
$lag = isset( $opts['lag'] ) ? $opts['lag'] : 0;
+ if ( !empty( $opts['pending'] ) ) {
+ $this->logger->info( "Rejected set() for $key due to pending writes." );
+
+ return true; // no-op the write for being unsafe
+ }
+
if ( $lag > self::MAX_REPLICA_LAG ) {
// Too much lag detected; lower TTL so it converges faster
$ttl = $ttl ? min( $ttl, self::TTL_LAGGED ) : self::TTL_LAGGED;
+ $this->logger->warning( "Lowered set() TTL for $key due to replication lag." );
}
if ( $age > self::MAX_SNAPSHOT_LAG ) {
$tempTTL = max( 1, (int)$lockTSE ); // set() expects seconds
$this->cache->set( self::STASH_KEY_PREFIX . $key, $value, $tempTTL );
}
+ $this->logger->warning( "Rejected set() for $key due to snapshot lag." );
return true; // no-op the write for being unsafe
}
if ( isset( $params['loggroup'] ) ) {
$params['logger'] = LoggerFactory::getInstance( $params['loggroup'] );
} else {
- // For backwards-compatability with custom parameters, lets not
- // have all logging suddenly disappear
$params['logger'] = LoggerFactory::getInstance( 'objectcache' );
}
if ( !isset( $params['keyspace'] ) ) {
$class = $params['relayerConfig']['class'];
$params['relayer'] = new $class( $params['relayerConfig'] );
$params['cache'] = self::newFromId( $params['cacheId'] );
+ if ( isset( $params['loggroup'] ) ) {
+ $params['logger'] = LoggerFactory::getInstance( $params['loggroup'] );
+ } else {
+ $params['logger'] = LoggerFactory::getInstance( 'objectcache' );
+ }
$class = $params['class'];
return new $class( $params );
/**
* @param string $reason
* @param bool $suppress
- * @param int $id
- * @param bool $commit
+ * @param int $u1 Unused
+ * @param bool $u2 Unused
* @param string $error
* @return bool
*/
- public function doDeleteArticle( $reason, $suppress = false, $id = 0,
- $commit = true, &$error = ''
+ public function doDeleteArticle(
+ $reason, $suppress = false, $u1 = null, $u2 = null, &$error = ''
) {
- return $this->mPage->doDeleteArticle( $reason, $suppress, $id, $commit, $error );
+ return $this->mPage->doDeleteArticle( $reason, $suppress, $u1, $u2, $error );
}
/**
* @param string $reason Delete reason for deletion log
* @param bool $suppress Suppress all revisions and log the deletion in
* the suppression log instead of the deletion log
- * @param int $id Article ID
- * @param bool $commit Defaults to true, triggers transaction end
- * @param array &$error Array of errors to append to
+ * @param int $u1 Unused
+ * @param bool $u2 Unused
+ * @param array|string &$error Array of errors to append to
* @param User $user The deleting user
* @return bool True if successful
*/
public function doDeleteArticle(
- $reason, $suppress = false, $id = 0, $commit = true, &$error = '', User $user = null
+ $reason, $suppress = false, $u1 = null, $u2 = null, &$error = '', User $user = null
) {
- $status = $this->doDeleteArticleReal( $reason, $suppress, $id, $commit, $error, $user );
+ $status = $this->doDeleteArticleReal( $reason, $suppress, $u1, $u2, $error, $user );
return $status->isGood();
}
* @param string $reason Delete reason for deletion log
* @param bool $suppress Suppress all revisions and log the deletion in
* the suppression log instead of the deletion log
- * @param int $id Article ID
- * @param bool $commit Defaults to true, triggers transaction end
- * @param array &$error Array of errors to append to
+ * @param int $u1 Unused
+ * @param bool $u2 Unused
+ * @param array|string &$error Array of errors to append to
* @param User $user The deleting user
* @return Status Status object; if successful, $status->value is the log_id of the
* deletion log entry. If the page couldn't be deleted because it wasn't
* found, $status is a non-fatal 'cannotdelete' error
*/
public function doDeleteArticleReal(
- $reason, $suppress = false, $id = 0, $commit = true, &$error = '', User $user = null
+ $reason, $suppress = false, $u1 = null, $u2 = null, &$error = '', User $user = null
) {
global $wgUser, $wgContentHandlerUseDB;
}
$dbw = wfGetDB( DB_MASTER );
- $dbw->begin( __METHOD__ );
-
- if ( $id == 0 ) {
- $this->loadPageData( self::READ_LATEST );
- $id = $this->getID();
- // T98706: lock the page from various other updates but avoid using
- // WikiPage::READ_LOCKING as that will carry over the FOR UPDATE to
- // the revisions queries (which also JOIN on user). Only lock the page
- // row and CAS check on page_latest to see if the trx snapshot matches.
- $lockedLatest = $this->lock();
- if ( $id == 0 || $this->getLatest() != $lockedLatest ) {
- // Page not there or trx snapshot is stale
- $dbw->rollback( __METHOD__ );
- $status->error( 'cannotdelete',
- wfEscapeWikiText( $this->getTitle()->getPrefixedText() ) );
- return $status;
- }
+ $dbw->startAtomic( __METHOD__ );
+
+ $this->loadPageData( self::READ_LATEST );
+ $id = $this->getID();
+ // T98706: lock the page from various other updates but avoid using
+ // WikiPage::READ_LOCKING as that will carry over the FOR UPDATE to
+ // the revisions queries (which also JOIN on user). Only lock the page
+ // row and CAS check on page_latest to see if the trx snapshot matches.
+ $lockedLatest = $this->lock();
+ if ( $id == 0 || $this->getLatest() != $lockedLatest ) {
+ $dbw->endAtomic( __METHOD__ );
+ // Page not there or trx snapshot is stale
+ $status->error( 'cannotdelete',
+ wfEscapeWikiText( $this->getTitle()->getPrefixedText() ) );
+ return $status;
}
+ // At this point we are now comitted to returning an OK
+ // status unless some DB query error or other exception comes up.
+ // This way callers don't have to call rollback() if $status is bad
+ // unless they actually try to catch exceptions (which is rare).
+
// we need to remember the old content so we can use it to generate all deletion updates.
$content = $this->getContent( Revision::RAW );
$row['ar_content_format'] = 'rev_content_format';
}
- $dbw->insertSelect( 'archive', array( 'page', 'revision' ),
+ // Copy all the page revisions into the archive table
+ $dbw->insertSelect(
+ 'archive',
+ array( 'page', 'revision' ),
$row,
array(
'page_id' => $id,
'page_id = rev_page'
- ), __METHOD__
+ ),
+ __METHOD__
);
// Now that it's safely backed up, delete it
$dbw->delete( 'page', array( 'page_id' => $id ), __METHOD__ );
- $ok = ( $dbw->affectedRows() > 0 ); // $id could be laggy
-
- if ( !$ok ) {
- $dbw->rollback( __METHOD__ );
- $status->error( 'cannotdelete',
- wfEscapeWikiText( $this->getTitle()->getPrefixedText() ) );
- return $status;
- }
if ( !$dbw->cascadingDeletes() ) {
$dbw->delete( 'revision', array( 'rev_page' => $id ), __METHOD__ );
$logEntry->publish( $logid );
} );
- if ( $commit ) {
- $dbw->commit( __METHOD__ );
- }
-
- // Show log excerpt on 404 pages rather than just a link
- $key = wfMemcKey( 'page-recent-delete', md5( $logTitle->getPrefixedText() ) );
- ObjectCache::getMainStashInstance()->set( $key, 1, 86400 );
+ $dbw->endAtomic( __METHOD__ );
$this->doDeleteUpdates( $id, $content );
Hooks::run( 'ArticleDeleteComplete',
array( &$this, &$user, $reason, $id, $content, $logEntry ) );
$status->value = $logid;
+
+ // Show log excerpt on 404 pages rather than just a link
+ $key = wfMemcKey( 'page-recent-delete', md5( $logTitle->getPrefixedText() ) );
+ ObjectCache::getMainStashInstance()->set( $key, 1, 86400 );
+
return $status;
}
return;
}
+ $params = array(
+ 'isOpportunistic' => true,
+ 'rootJobTimestamp' => $parserOutput->getCacheTime()
+ );
+
if ( $this->mTitle->areRestrictionsCascading() ) {
// If the page is cascade protecting, the links should really be up-to-date
- $params = array( 'prioritize' => true );
+ JobQueueGroup::singleton()->lazyPush(
+ RefreshLinksJob::newPrioritized( $this->mTitle, $params )
+ );
} elseif ( $parserOutput->hasDynamicContent() ) {
- // Assume the output contains time/random based magic words
- $params = array();
- } else {
- // If the inclusions are deterministic, the edit-triggered link jobs are enough
- return;
- }
-
- // Check if the last link refresh was before page_touched
- if ( $this->getLinksTimestamp() < $this->getTouched() ) {
- $params['isOpportunistic'] = true;
- $params['rootJobTimestamp'] = $parserOutput->getCacheTime();
- JobQueueGroup::singleton()->lazyPush( new RefreshLinksJob( $this->mTitle, $params ) );
+ // Assume the output contains "dynamic" time/random based magic words.
+ // Only update pages that expired due to dynamic content and NOT due to edits
+ // to referenced templates/files. When the cache expires due to dynamic content,
+ // page_touched is unchanged. We want to avoid triggering redundant jobs due to
+ // views of pages that were just purged via HTMLCacheUpdateJob. In that case, the
+ // template/file edit already triggered recursive RefreshLinksJob jobs.
+ if ( $this->getLinksTimestamp() > $this->getTouched() ) {
+ // If a page is uncacheable, do not keep spamming a job for it.
+ // Although it would be de-duplicated, it would still waste I/O.
+ $cache = ObjectCache::getLocalClusterInstance();
+ $key = $cache->makeKey( 'dynamic-linksupdate', 'last', $this->getId() );
+ if ( $cache->add( $key, time(), 60 ) ) {
+ JobQueueGroup::singleton()->lazyPush(
+ RefreshLinksJob::newDynamic( $this->mTitle, $params )
+ );
+ }
+ }
}
}
// Allow multiple modules to be registered in one call
$registrations = is_array( $name ) ? $name : array( $name => $info );
foreach ( $registrations as $name => $info ) {
- // Disallow duplicate registrations
+ // Warn on duplicate registrations
if ( isset( $this->moduleInfos[$name] ) ) {
// A module has already been registered by this name
- throw new MWException(
- 'ResourceLoader duplicate registration error. ' .
+ $this->logger->warning(
+ 'ResourceLoader duplicate registration warning. ' .
'Another module has already been registered as ' . $name
);
}
break;
// Single strings
case 'position':
- $this->isPositionDefined = true;
case 'group':
case 'skipFunction':
$this->{$member} = (string)$option;
break;
case 'position':
- $this->isPositionDefined = true;
case 'prefix':
case 'selectorWithoutVariant':
case 'selectorWithVariant':
$this->loadFromDefinition();
return $this->position;
}
-
- public function isPositionDefault() {
- $this->loadFromDefinition();
- return parent::isPositionDefault();
- }
}
// In-object cache for module content
protected $contents = array();
- // Whether the position returned by getPosition() is defined in the module configuration
- // and not a default value
- protected $isPositionDefined = false;
-
/**
* @var Config
*/
return 'bottom';
}
- /**
- * Whether the position returned by getPosition() is a default value or comes from the module
- * definition. This method is meant to be short-lived, and is only useful until classes added
- * via addModuleStyles with a default value define an explicit position. See getModuleStyles()
- * in OutputPage for the related migration warning.
- *
- * @return bool
- * @since 1.26
- */
- public function isPositionDefault() {
- return !$this->isPositionDefined;
- }
-
/**
* Whether this module's JS expects to work without the client-side ResourceLoader module.
* Returning true from this function will prevent mw.loader.state() call from being
foreach ( $options as $member => $option ) {
switch ( $member ) {
case 'position':
- $this->isPositionDefined = true;
- // Don't break since we need the member set as well
case 'styles':
case 'scripts':
case 'group':
* @ingroup Search
*/
class SearchResultSet {
+
+ /**
+ * Types of interwiki results
+ */
+ /**
+ * Results that are displayed only together with existing main wiki results
+ * @var int
+ */
+ const SECONDARY_RESULTS = 0;
+ /**
+ * Results that can displayed even if no existing main wiki results exist
+ * @var int
+ */
+ const INLINE_RESULTS = 1;
+
protected $containedSyntax = false;
public function __construct( $containedSyntax = false ) {
*
* @return SearchResultSet
*/
- function getInterwikiResults() {
+ function getInterwikiResults( $type = self::SECONDARY_RESULTS ) {
return null;
}
*
* @return bool
*/
- function hasInterwikiResults() {
- return $this->getInterwikiResults() != null;
+ function hasInterwikiResults( $type = self::SECONDARY_RESULTS ) {
+ return false;
}
/**
*/
protected $runSuggestion = true;
+ /**
+ * Names of the wikis, in format: Interwiki prefix -> caption
+ * @var array
+ */
+ protected $customCaptions;
+
const NAMESPACES_CURRENT = 'sense';
public function __construct() {
if ( $numTextMatches > 0 ) {
$out->addHTML( $this->showMatches( $textMatches ) );
}
- // show interwiki results if any
- if ( $textMatches->hasInterwikiResults() ) {
- $out->addHTML( $this->showInterwiki( $textMatches->getInterwikiResults(), $term ) );
+
+ // show secondary interwiki results if any
+ if ( $textMatches->hasInterwikiResults( SearchResultSet::SECONDARY_RESULTS ) ) {
+ $out->addHTML( $this->showInterwiki( $textMatches->getInterwikiResults(
+ SearchResultSet::SECONDARY_RESULTS ), $term ) );
}
$textMatches->free();
}
+
+ $hasOtherResults = $textMatches->hasInterwikiResults( SearchResultSet::INLINE_RESULTS );
+
if ( $num === 0 ) {
if ( $textStatus ) {
$out->addHTML( '<div class="error">' .
$textStatus->getMessage( 'search-error' ) . '</div>' );
} else {
- $out->wrapWikiMsg( "<p class=\"mw-search-nonefound\">\n$1</p>",
- array( 'search-nonefound', wfEscapeWikiText( $term ) ) );
$this->showCreateLink( $title, $num, $titleMatches, $textMatches );
+ $out->wrapWikiMsg( "<p class=\"mw-search-nonefound\">\n$1</p>",
+ array( $hasOtherResults ? 'search-nonefound-thiswiki' : 'search-nonefound',
+ wfEscapeWikiText( $term )
+ ) );
+ }
+ }
+
+ if ( $hasOtherResults ) {
+ foreach ( $textMatches->getInterwikiResults( SearchResultSet::INLINE_RESULTS )
+ as $interwiki => $interwikiResult ) {
+ if ( $interwikiResult instanceof Status || $interwikiResult->numRows() == 0 ) {
+ // ignore bad interwikis for now
+ continue;
+ }
+ // TODO: wiki header
+ $out->addHTML( $this->showMatches( $interwikiResult, $interwiki ) );
}
}
$out->addHTML( '<div class="visualClear"></div>' );
+
if ( $prevnext ) {
$out->addHTML( "<p class='mw-search-pager-bottom'>{$prevnext}</p>\n" );
}
}
+ /**
+ * Produce wiki header for interwiki results
+ * @param string $interwiki Interwiki name
+ * @param SearchResultSet $interwikiResult The result set
+ */
+ protected function interwikiHeader( $interwiki, $interwikiResult ) {
+ // TODO: we need to figure out how to name wikis correctly
+ $wikiMsg = $this->msg( 'search-interwiki-results-' . $interwiki )->parse();
+ return "<p class=\"mw-search-interwiki-header\">\n$wikiMsg</p>";
+ }
+
/**
* Decide if the suggested query should be run, and it's results returned
* instead of the provided $textMatches
* Show whole set of results
*
* @param SearchResultSet $matches
+ * @param string $interwiki Interwiki name
*
* @return string
*/
- protected function showMatches( &$matches ) {
+ protected function showMatches( &$matches, $interwiki = null ) {
global $wgContLang;
$terms = $wgContLang->convertForSearchResult( $matches->termMatches() );
-
- $out = "<ul class='mw-search-results'>\n";
+ $out = '';
$result = $matches->next();
$pos = $this->offset;
+
+ if ( $result && $interwiki ) {
+ $out .= $this->interwikiHeader( $interwiki, $result );
+ }
+
+ $out .= "<ul class='mw-search-results'>\n";
while ( $result ) {
$out .= $this->showHit( $result, $terms, ++$pos );
$result = $matches->next();
}
$link_t = clone $title;
+ $query = array();
Hooks::run( 'ShowSearchHitTitle',
- array( &$link_t, &$titleSnippet, $result, $terms, $this ) );
+ array( &$link_t, &$titleSnippet, $result, $terms, $this, &$query ) );
$link = Linker::linkKnown(
$link_t,
$titleSnippet,
- array( 'data-serp-pos' => $position ) // HTML attributes
+ array( 'data-serp-pos' => $position ), // HTML attributes
+ $query
);
// If page content is not readable, just return the title.
return $html;
}
+ /**
+ * Extract custom captions from search-interwiki-custom message
+ */
+ protected function getCustomCaptions() {
+ if ( is_null( $this->customCaptions ) ) {
+ $this->customCaptions = array();
+ // format per line <iwprefix>:<caption>
+ $customLines = explode( "\n", $this->msg( 'search-interwiki-custom' )->text() );
+ foreach ( $customLines as $line ) {
+ $parts = explode( ":", $line, 2 );
+ if ( count( $parts ) == 2 ) { // validate line
+ $this->customCaptions[$parts[0]] = $parts[1];
+ }
+ }
+ }
+ }
+
/**
* Show results from other wikis
*
$out .= "<ul class='mw-search-iwresults'>\n";
// work out custom project captions
- $customCaptions = array();
- // format per line <iwprefix>:<caption>
- $customLines = explode( "\n", $this->msg( 'search-interwiki-custom' )->text() );
- foreach ( $customLines as $line ) {
- $parts = explode( ":", $line, 2 );
- if ( count( $parts ) == 2 ) { // validate line
- $customCaptions[$parts[0]] = $parts[1];
- }
- }
+ $this->getCustomCaptions();
if ( !is_array( $matches ) ) {
$matches = array( $matches );
$prev = null;
$result = $set->next();
while ( $result ) {
- $out .= $this->showInterwikiHit( $result, $prev, $query, $customCaptions );
+ $out .= $this->showInterwikiHit( $result, $prev, $query );
$prev = $result->getInterwikiPrefix();
$result = $set->next();
}
* @param SearchResult $result
* @param string $lastInterwiki
* @param string $query
- * @param array $customCaptions Interwiki prefix -> caption
*
* @return string
*/
- protected function showInterwikiHit( $result, $lastInterwiki, $query, $customCaptions ) {
+ protected function showInterwikiHit( $result, $lastInterwiki, $query ) {
if ( $result->isBrokenTitle() ) {
return '';
$out = "";
// display project name
if ( is_null( $lastInterwiki ) || $lastInterwiki != $title->getInterwiki() ) {
- if ( array_key_exists( $title->getInterwiki(), $customCaptions ) ) {
+ if ( array_key_exists( $title->getInterwiki(), $this->customCaptions ) ) {
// captions from 'search-interwiki-custom'
- $caption = $customCaptions[$title->getInterwiki()];
+ $caption = $this->customCaptions[$title->getInterwiki()];
} else {
// default is to show the hostname of the other wiki which might suck
// if there are many wikis on one hostname
* @return Status
*/
public function addNewAccountInternal() {
- global $wgAuth, $wgMemc, $wgAccountCreationThrottle, $wgEmailConfirmToEdit;
+ global $wgAuth, $wgAccountCreationThrottle, $wgEmailConfirmToEdit;
// If the user passes an invalid domain, something is fishy
if ( !$wgAuth->validDomain( $this->mDomain ) ) {
return Status::newFatal( 'noname' );
}
+ $cache = ObjectCache::getLocalClusterInstance();
# Make sure the user does not exist already
- $lock = $wgMemc->getScopedLock( wfGlobalCacheKey( 'account', md5( $this->mUsername ) ) );
+ $lock = $cache->getScopedLock( wfGlobalCacheKey( 'account', md5( $this->mUsername ) ) );
if ( !$lock ) {
return Status::newFatal( 'usernameinprogress' );
} elseif ( $u->idForName( User::READ_LOCKING ) ) {
} else {
if ( ( $wgAccountCreationThrottle && $currentUser->isPingLimitable() ) ) {
$key = wfMemcKey( 'acctcreate', 'ip', $ip );
- $value = $wgMemc->get( $key );
+ $value = $cache->get( $key );
if ( !$value ) {
- $wgMemc->set( $key, 0, 86400 );
+ $cache->set( $key, 0, 86400 );
}
if ( $value >= $wgAccountCreationThrottle ) {
return Status::newFatal( 'acct_creation_throttle_hit', $wgAccountCreationThrottle );
}
- $wgMemc->incr( $key );
+ $cache->incr( $key );
}
}
* @return bool|int The integer hit count or True if it is already at the limit
*/
public static function incLoginThrottle( $username ) {
- global $wgPasswordAttemptThrottle, $wgMemc, $wgRequest;
+ global $wgPasswordAttemptThrottle, $wgRequest;
$username = trim( $username ); // sanity
$throttleCount = 0;
$count = $wgPasswordAttemptThrottle['count'];
$period = $wgPasswordAttemptThrottle['seconds'];
- $throttleCount = $wgMemc->get( $throttleKey );
+ $cache = ObjectCache::getLocalClusterInstance();
+ $throttleCount = $cache->get( $throttleKey );
if ( !$throttleCount ) {
- $wgMemc->add( $throttleKey, 1, $period ); // start counter
+ $cache->add( $throttleKey, 1, $period ); // start counter
} elseif ( $throttleCount < $count ) {
- $wgMemc->incr( $throttleKey );
+ $cache->incr( $throttleKey );
} elseif ( $throttleCount >= $count ) {
return true;
}
* @return void
*/
public static function clearLoginThrottle( $username ) {
- global $wgMemc, $wgRequest;
+ global $wgRequest;
$username = trim( $username ); // sanity
$throttleKey = wfMemcKey( 'password-throttle', $wgRequest->getIP(), md5( $username ) );
- $wgMemc->delete( $throttleKey );
+ ObjectCache::getLocalClusterInstance()->delete( $throttleKey );
}
/**
}
function processLogin() {
- global $wgMemc, $wgLang, $wgSecureLogin, $wgPasswordAttemptThrottle,
- $wgInvalidPasswordReset;
+ global $wgLang, $wgSecureLogin, $wgPasswordAttemptThrottle, $wgInvalidPasswordReset;
+ $cache = ObjectCache::getLocalClusterInstance();
$authRes = $this->authenticateUserData();
switch ( $authRes ) {
case self::SUCCESS:
// Reset the throttle
$request = $this->getRequest();
$key = wfMemcKey( 'password-throttle', $request->getIP(), md5( $this->mUsername ) );
- $wgMemc->delete( $key );
+ $cache->delete( $key );
if ( $this->hasSessionCookie() || $this->mSkipCookieCheck ) {
/* Replace the language object to provide user interface in
# We got the first byte only of a multibyte char; remove it.
$string = substr( $string, 0, -1 );
} elseif ( $char >= 0x80 &&
+ // Use the /s modifier (PCRE_DOTALL) so (.*) also matches newlines
preg_match( '/^(.*)(?:[\xe0-\xef][\x80-\xbf]|' .
- '[\xf0-\xf7][\x80-\xbf]{1,2})$/', $string, $m )
+ '[\xf0-\xf7][\x80-\xbf]{1,2})$/s', $string, $m )
) {
# We chopped in the middle of a character; remove it
$string = $m[1];
"search-category": "(التصنيف $1)",
"search-file-match": "(يطابق محتوى الملف)",
"search-suggest": "أتقصد: $1",
- "search-rewritten": "عرض النتائج ل$1. ابحث بدلا من ذلك عن $2.",
+ "search-rewritten": "نتائج البحث المشابه $1 معروضة. يمكنك بدل ذلك البحث عن $2.",
"search-interwiki-caption": "المشاريع الشقيقة",
"search-interwiki-default": "نتائح من $1:",
"search-interwiki-more": "(المزيد)",
"foreign-structured-upload-form-label-own-work-message-default": "Я разумею, што загружаю гэты файл у агульнае сховішча. Я пацьвярджаю, што раблю гэта ў адпаведнасьці з умовамі выкарыстаньня і ліцэнзійнай палітыкай.",
"foreign-structured-upload-form-label-not-own-work-message-default": "Калі вы ня можаце загрузіць гэты файл паводле правілаў агульнага сховішча, калі ласка, закрыйце гэты дыялёг і паспрабуйце іншы мэтад.",
"foreign-structured-upload-form-label-not-own-work-local-default": "Вы можаце паспрабаваць скарыстацца [[Special:Upload|старонкай загрузкі {{GRAMMAR:родны|{{SITENAME}}}}]], калі гэты файл можна туды загрузіць згодна з правіламі.",
+ "foreign-structured-upload-form-label-own-work-message-shared": "Я пацьвярджаю, што зьяўляюся ўласьнікам аўтарскіх правоў на гэты файл, і згодны незваротна перадаць гэты файл ў Вікісховішча на ўмовах ліцэнзіі [https://creativecommons.org/licenses/by-sa/4.0/ Creative Commons Attribution-ShareAlike 4.0], а таксама згодны з [https://wikimediafoundation.org/wiki/Terms_of_Use умовамі выкарыстаньня].",
"backend-fail-stream": "Немагчыма накіраваць файл $1.",
"backend-fail-backup": "Немагчыма зрабіць рэзэрвовую копію файла $1.",
"backend-fail-notexists": "Файл $1 не існуе.",
"passwordreset-emailerror-capture": "স্মরণ করিয়ে দেয়ার জন্য একটি ইমেইল তৈরী করা হয়েছিল, যা নিচে দেখানো হচ্ছে, তবে $1 {{GENDER:$2|ব্যবহারকারীকে}} এটি পাঠানো যায়নি!",
"changeemail": "ই-মেইল ঠিকানা পরিবর্তন বা বাতিল",
"changeemail-header": "অ্যাকাউন্ট ই-মেইল ঠিকানা পরিবর্তন",
+ "changeemail-passwordrequired": "এই পরিবর্তন নিশ্চিত করতে আপনাকে আপনার পাসওয়ার্ড লিখতে হবে।",
"changeemail-no-info": "এই পাতাটিতে সরাসরি প্রবেশাধিকার পেতে আপনাকে অবশ্যই লগইন করতে হবে।",
"changeemail-oldemail": "বর্তমান ই-মেইল ঠিকানা:",
"changeemail-newemail": "নতুন ই-মেইল ঠিকানা:",
"sig_tip": "সময় ও তারিখসহ আপনার স্বাক্ষর",
"hr_tip": "অনুভূমিক রেখা (সংযতভাবে ব্যবহার করুন)",
"summary": "সারাংশ:",
- "subject": "বিষয়/শিরোনাম:",
+ "subject": "বিষয়:",
"minoredit": "এটি একটি অনুল্লেখ্য সম্পাদনা",
"watchthis": "এই পাতাটি নজরে রাখুন",
"savearticle": "সংরক্ষণ",
"missingsummary": "'''খেয়াল করুন''': আপনি কিন্তু সম্পাদনার সারাংশ দেননি। আবার যদি \"সংরক্ষণ\" বোতামে ক্লিক করেন, তাহলে ঐ সারাংশ বাক্যটি ছাড়াই আপনার সম্পাদনা সংরক্ষিত হবে।",
"selfredirect": "<strong>সতর্কতা:</strong> আপনি এই পাতাকে এর নিজের দিকে পুনঃনির্দেশিত করছেন।\nআপনাকে পুনঃনির্দেশিত করার জন্য হয় ভুল লক্ষ্য নির্দিষ্ট করেছেন, অথবা আপনি ভুল পাতা সম্পাদনা করছেন।\nআপনি যদি আবার \"{{int:savearticle}}\" ক্লিক করেন, পুনর্নির্দেশ যেকোনোভাবেই হোক তৈরি করা হবে।",
"missingcommenttext": "দয়া করে নিচে মন্তব্য যোগ করুন।",
- "missingcommentheader": "'''খেয়াল করুন:''' আপনি এই মন্তব্যের জন্য কোন বিষয়/শিরোনাম দেননি। সংরক্ষণ বোতামে ক্লিক করলে, আপনার এই সম্পাদনা কোন বিষয়/শিরোনাম ছাড়াই সংরক্ষিত হবে।",
+ "missingcommentheader": "<strong>খেয়াল করুন:</strong> আপনি এই মন্তব্যের জন্য কোন বিষয় প্রদান করেননি।আপনি যদি আবার \"{{int:savearticle}}\" বোতামে ক্লিক করেন, আপনার এই সম্পাদনা কোন বিষয় ছাড়াই সংরক্ষিত হবে।",
"summary-preview": "সারাংশ প্রাকদর্শন:",
- "subject-preview": "বিষয়/শিরোনাম প্রাকদর্শন:",
+ "subject-preview": "বিষয় প্রাকদর্শন:",
"previewerrortext": "আপনার পরিবর্তনগুলি প্রাকদর্শন করার চেষ্টা করার সময় একটি ত্রুটি ঘটেছে।",
"blockedtitle": "ব্যবহারকারীকে বাধা দেয়া হয়েছে",
"blockedtext": "আপনার ব্যবহারকারী নাম বা আইপি ঠিকানার ঊপর নিষেধাজ্ঞা আরোপিত হয়েছে।\n\n$1 নিষেধাজ্ঞা আরোপ করেছেন। নিষেধের কারণ হিসেবে বলা হয়েছে:''$2''।\n\n* নিষেধাজ্ঞা শুরুর সময়:$8\n* নিষেধাজ্ঞা উঠিয়ে নেয়ার সময়: $6\n* যার উপর নিষেধাজ্ঞা আরোপ করা হয়েছে: $7\n\nআপনি $1 অথবা [[{{MediaWiki:Grouppage-sysop}}|প্রশাসকদের]] কারও সাথে এই নিষেধাজ্ঞা সংক্রান্ত বিষয়ে আলোচনা করতে পারেন।\n\nআপনি '(ব্যবহারকারীকে) ইমেইল করুন' ফিচারটি ব্যবহার করতে পারবেন না। তবে [[Special:Preferences|আপনার পছন্দ তালিকাতে]] যদি একটি বৈধ ই-মেইল ঠিকানা নির্দিষ্ট করা হয়ে থাকে এবং ফিচারটি ব্যবহারে যদি আপনাকে বাধা না দেওয়া হয়ে থাকে, তবে আপনি ফিচারটি ব্যবহার করতে পারবেন।\n\nআপনার বর্তমান আইপি ঠিকানা $3, এবং আপনার নিষেধাজ্ঞা নং হল #$5।\n\nদয়া করে আপনার যেকোন জিজ্ঞাসাতে উপরের সমস্ত বিবরণ অন্তর্ভুক্ত করুন।",
"mergehistory-go": "একত্রীকরণযোগ্য সম্পাদনাগুলি দেখানো হোক",
"mergehistory-submit": "সংশোধনগুলি একত্র করা হোক",
"mergehistory-empty": "কোন সংশোধন একত্র করা যাবে না.",
- "mergehistory-done": "$1 গুলোর মধ্যে $3 {{PLURAL:$3| টি সংশোধন |টি সংশোধনগুলো}} সফলভাবে [[:$2]]-এর সাথে একত্রিত করা হয়েছে।",
+ "mergehistory-done": "$1-এর $3{{PLURAL:$3|টি সংশোধন}} [[:$2]]-এর সাথে একত্রিত করা হয়েছে।",
"mergehistory-fail": "ইতিহাস একত্র করা গেল না। অনুগ্রহ করে পাতাটি ও সময়ের প্যারামিটারগুলি আবার পরীক্ষা করে দেখুন।",
"mergehistory-fail-toobig": "ইতিহাস থেকে আগের পাতাগুলো একীকরণ সম্ভব নয়, কারণ এর ফলে সর্বোচ্চ $1 টি {{PLURAL:$1|সংস্করণ}} স্থানান্তরের সীমানা অতিক্রম করবে।",
"mergehistory-no-source": "$1 বলে কোন উৎস পাতার অস্তিত্ব নেই।",
"prefs-help-recentchangescount": "এতে সাম্প্রতিক পরিবর্তনসমূহ, পাতার ইতিহাস এবং লগ অন্তর্ভুক্ত।",
"prefs-help-watchlist-token2": "এটি আপনার নজরতালিকার ওয়েব ফিডের গোপন চাবি। যে কেউ যিনি এটা জানেন তিনি আপনার নজরতালিকা পড়তে সক্ষম হবেন, তাই এটি প্রকাশ করবেন না। [[Special:ResetTokens|আপনার এটি পুনরায় সেট করার প্রয়োজন হলে এখানে ক্লিক করুন]]।",
"savedprefs": "আপনার পছন্দগুলো সংরক্ষণ করা হয়েছে।",
+ "savedrights": "{{GENDER:$1|$1}}-এর ব্যবহারকারী অধিকার সংরক্ষিত হয়েছে।",
"timezonelegend": "সময়স্থান:",
"localtime": "স্থানীয় সময়:",
"timezoneuseserverdefault": "উইকির পূর্বনির্ধারিত সময় ব্যবহার করো ($1)",
"recentchanges-page-added-to-category-bundled": "বিষয়শ্রেণীতে [[:$1]] এবং {{PLURAL:$2|একটি পাতা|$2টি পাতা}} যোগ করা হয়েছে",
"recentchanges-page-removed-from-category": "বিষয়শ্রেণী থেকে [[:$1]] সরানো হয়েছে",
"recentchanges-page-removed-from-category-bundled": "বিষয়শ্রেণী থেকে [[:$1]] এবং {{PLURAL:$2|একটি পাতা|$2টি পাতা}} সরানো হয়েছে",
+ "autochange-username": "মিডিয়াউইকি স্বয়ংক্রিয় পরিবর্তন",
"upload": "আপলোড",
"uploadbtn": "ফাইল আপলোড করুন",
"reuploaddesc": "আপলোড বাতিল করো এবং আপলোড ফর্মে ফেরত যাও।",
"uploadscripted": "এই ফাইলে এমন HTML বা স্ক্রিপ্ট কোড আছে যা একটি ওয়েব ব্রাউজার ভুল বুঝতে পারে।",
"uploaded-script-svg": "আপলোডকৃত SVG ফাইলে স্ক্রিপ্টযোগ্য উপাদান \"$1\" পাওয়া গেছে।",
"uploaded-hostile-svg": "আপলোড করা SVG ফাইলের শৈলী উপাদানে অনিরাপদ সিএসএস পাওয়া গেছে।",
+ "uploaded-image-filter-svg": "আপলোডকৃত SVG ফাইলে URL: <code><$1 $2=\"$3\"></code> সহ ছবি পরিশোধক পাওয়া গেছে।",
"uploadscriptednamespace": "এই SVG ফাইলে অবৈধ নামস্থান \"$1\" রয়েছে",
"uploadinvalidxml": "আপলোডকৃত ফাইলে XML পার্স করা যাবে না।",
"uploadvirus": "এই ফাইলটিতে ভাইরাস আছে! ব্যাখ্যা: $1",
"svg-long-error": "অবৈধ SVG ফাইল: $1",
"show-big-image": "মূল ফাইল",
"show-big-image-preview": "এই প্রাকদর্শনের আকার: $1।",
+ "show-big-image-preview-differ": "এই $2 ফাইলের জন্য এই $3 প্রাকদর্শনের আকার: $1।",
"show-big-image-other": "অন্যান্য {{PLURAL:$2|আকার|আকারসমূহ}}: $1।",
"show-big-image-size": "$1 × $2 পিক্সেল",
"file-info-gif-looped": "লুপকৃত",
"tags-create-reason": "কারণ:",
"tags-create-submit": "তৈরি করুন",
"tags-create-no-name": "আপনাকে একটি ট্যাগের নাম অবশ্যই উল্লেখ করতে হবে।",
+ "tags-create-already-exists": "\"$1\" ট্যাগ ইতিমধ্যেই বিদ্যমান।",
"tags-delete-title": "ট্যাগ অপসারণ",
"tags-delete-reason": "কারণ:",
"tags-delete-submit": "অপরিবর্তনীয় এই ট্যাগ অপসারন করো",
+ "tags-delete-not-found": "\"$1\" ট্যাগ বিদ্যমান নয়।",
"tags-activate-title": "সক্রিয় ট্যাগ",
"tags-activate-reason": "কারণ:",
"tags-activate-submit": "চালু",
"double-redirect-fixed-move": "[[$1]] агӀонан цӀе хийцина.\nХӀинца иза авто-карлаяьккхина а [[$2]] агӀона тӀехьажийна.",
"double-redirect-fixed-maintenance": "Шалха дӀасахьажинарг нисъяр [[$1]] → [[$2]].",
"double-redirect-fixer": "ДӀасахьажинарш нисерг",
- "brokenredirects": "ДIадаьхна долу дIасахьажораш",
+ "brokenredirects": "ДӀаяьхна йолу дIасахьажоргаш",
"brokenredirectstext": "Лахара дӀасахьажийнарш ю йоцучу агӀонийн тӀе хьажийна:",
"brokenredirects-edit": "нисъе",
"brokenredirects-delete": "дӀаяккха",
"wantedfiletext-nocat": "Лахара йоцу файлаш лело гӀерта. Оцу могӀам юкъа ца хууш файлаш кхета там бу, кхечу проекташ чохь йолу. Ишта ца хууш юкъа нийса елачарна тӀехула <del>сиз</del> хира ду.",
"wantedtemplates": "Оьшуш йолу кепаш",
"mostlinked": "Дуккха хьажоргаш тӀе тоьхна йолу агӀонаш",
- "mostlinkedcategories": "Дуккха тӀе хьажораш йолу категореш",
+ "mostlinkedcategories": "Ð\94Ñ\83ккÑ\85а Ñ\82Ó\80е Ñ\85Ñ\8cажоÑ\80гаÑ\88 йолÑ\83 каÑ\82егоÑ\80еÑ\88",
"mostlinkedtemplates": "Массарел дуккха а лелайо агӀонаш",
"mostcategories": "Дуккха категореш тӀе тоьхна йолу агӀонаш",
"mostimages": "Массарел дуккха лелайо файлаш",
"specialpages": "Леррина агӀонаш",
"specialpages-note-top": "Легенда",
"specialpages-note": "* Гуттарлера белха агlонаш.\n* <strong class=\"mw-specialpagerestricted\">Кlеззиг таронаш йолу леррина агlонаш.</strong>",
- "specialpages-group-maintenance": "Ð\96амlаÑ\88 гlиÑ\80Ñ\81а Ñ\85Ñ\8cаÑ\88Ñ\82аÑ\88 кÑ\85оÑ\87Ñ\83Ñ\88даÑ\80",
+ "specialpages-group-maintenance": "ТеÑ\85никийн Ñ\85Ñ\8cаÑ\88Ñ\82аÑ\88 кÑ\85оÑ\87Ñ\83Ñ\88даÑ\80ан Ñ\85аамаÑ\88",
"specialpages-group-other": "Кхин белхан агӀонаш",
"specialpages-group-login": "Системин чугӀо / дӀаяздар кхолла",
- "specialpages-group-changes": "Керла нисдарш а тéптарш",
- "specialpages-group-media": "Ð\96амlаÑ\88 оÑ\86Ñ\83 медиа-гlиÑ\80Ñ\81аÑ\88ан а Ñ\87Ñ\83Ñ\8fÑ\85аÑ\80ш",
- "specialpages-group-users": "Декъашхой а бакъонаш",
+ "specialpages-group-changes": "Керла нисдарш а, тéптарш а",
+ "specialpages-group-media": "Ð\9cедиа-гÓ\80иÑ\80Ñ\81ийн а, Ñ\87Ñ\83Ñ\8fÑ\85аÑ\80ийн а Ñ\85аамаш",
+ "specialpages-group-users": "Декъашхой а, бакъонаш а",
"specialpages-group-highuse": "Уггаре дукха лелайо агӀонаш",
"specialpages-group-pages": "АгӀонийн могӀанаш",
"specialpages-group-pagetools": "ГӀирсаш агӀонашна",
"tog-uselivepreview": "Benyt løbende forhåndsvisning",
"tog-forceeditsummary": "Advar mig hvis jeg ikke udfylder beskrivelsesfeltet",
"tog-watchlisthideown": "Skjul egne ændringer i overvågningslisten",
- "tog-watchlisthidebots": "Skjul ændringer fra bots i overvågningslisten",
+ "tog-watchlisthidebots": "Skjul ændringer fra botter i overvågningslisten",
"tog-watchlisthideminor": "Skjul mindre ændringer i overvågningslisten",
"tog-watchlisthideliu": "Skjul indloggede brugeres redigeringer i overvågningslisten",
"tog-watchlisthideanons": "Skjul anonyme brugeres redigeringer i overvågningslisten",
"rcshowhidemine": "$1 egne bidrag",
"rcshowhidemine-show": "Vis",
"rcshowhidemine-hide": "Skjul",
+ "rcshowhidecategorization-show": "Vis",
+ "rcshowhidecategorization-hide": "Skjul",
"rclinks": "Vis seneste $1 ændringer i de sidste $2 dage<br />$3",
"diff": "forskel",
"hist": "historik",
"foreign-structured-upload-form-label-infoform-categories": "Kategorier",
"foreign-structured-upload-form-label-infoform-date": "Dato",
"foreign-structured-upload-form-label-own-work-message-local": "Jeg bekræfter at jeg uploader filen i overenstemmelse med betingelser for brug og licenseringspoltikken på {{SITENAME}}.",
+ "foreign-structured-upload-form-label-not-own-work-message-local": "Hvis du ikke kan uploade filen under politikerne på {{SITENAME}}, skal du lukke dialogboksen og prøve en anden metode.",
+ "foreign-structured-upload-form-label-not-own-work-local-local": "Du kan også vælge at prøve [[Special:Upload|den almindelige uploadside]].",
"backend-fail-stream": "Kunne ikke streame filen $1.",
"backend-fail-backup": "Kunne ikke lave sikkerhedskopi af filen $1.",
"backend-fail-notexists": "Filen $1 findes ikke.",
"showingresultsinrange": "Showing below up to {{PLURAL:$1|<strong>1</strong> result|<strong>$1</strong> results}} in range #<strong>$2</strong> to #<strong>$3</strong>.",
"search-showingresults": "{{PLURAL:$4|Result <strong>$1</strong> of <strong>$3</strong>|Results <strong>$1 - $2</strong> of <strong>$3</strong>}}",
"search-nonefound": "There were no results matching the query.",
+ "search-nonefound-thiswiki": "There were no results matching the query in this site.",
"powersearch-legend": "Advanced search",
"powersearch-ns": "Search in namespaces:",
"powersearch-togglelabel": "Check:",
"hebrew-calendar-m2": "hechvan",
"hebrew-calendar-m3": "kislev",
"hebrew-calendar-m4": "tévet",
- "hebrew-calendar-m5": "Schébat",
- "hebrew-calendar-m6": "Adar",
+ "hebrew-calendar-m5": "chevat",
+ "hebrew-calendar-m6": "adar",
"hebrew-calendar-m7": "Nissane",
"hebrew-calendar-m8": "Iyar",
"hebrew-calendar-m9": "Sivane",
"hebrew-calendar-m2-gen": "hechvan",
"hebrew-calendar-m3-gen": "kislev",
"hebrew-calendar-m4-gen": "tévet",
- "hebrew-calendar-m5-gen": "Schébat",
- "hebrew-calendar-m6-gen": "Adar",
+ "hebrew-calendar-m5-gen": "chevat",
+ "hebrew-calendar-m6-gen": "adar",
"hebrew-calendar-m7-gen": "Nissane",
"hebrew-calendar-m8-gen": "Iyar",
"hebrew-calendar-m9-gen": "Sivane",
"permissionserrors": "権限エラー",
"permissionserrorstext": "あなたにはこの操作を行う権限はありません。{{PLURAL:$1|理由}}は以下の通りです:",
"permissionserrorstext-withaction": "あなたには「$2」を行う権限はありません。{{PLURAL:$1|理由}}は以下の通りです:",
+ "contentmodelediterror": "コンテンツモデルが <code>$1</code> であるため、この版を編集することができません。ページの現在のコンテンツモデルは <code>$2</code> です。",
"recreate-moveddeleted-warn": "<strong>警告: 以前削除されたページを再作成しようとしています。</strong>\n\nこのページの編集を続行するのが適切かどうかご確認ください。\n参考までに、このページの削除と移動の記録を以下に示します:",
"moveddeleted-notice": "このページは削除されています。\n参考のため、このページの削除と移動の記録を以下に表示します。",
"moveddeleted-notice-recent": "ごめんなさい、このページは最近に削除されました (過去24時間以内)。このページについての削除と移動の記録が、参考のため、以下にて提供されています。",
"recentchangeslinked-page": "ページ名:",
"recentchangeslinked-to": "このページへのリンク元での変更の表示に切り替え",
"recentchanges-page-added-to-category": "[[:$1]] カテゴリに追加",
+ "recentchanges-page-added-to-category-bundled": "[[:$1]]と他{{PLURAL:$2|1ページ|$2ページ}}をカテゴリに追加しました",
"recentchanges-page-removed-from-category": "[[:$1]] カテゴリから削除",
+ "recentchanges-page-removed-from-category-bundled": "[[:$1]]と他{{PLURAL:$2|1ページ|$2ページ}}をカテゴリから削除しました",
"autochange-username": "メディアウィキ自動変更",
"upload": "ファイルをアップロード",
"uploadbtn": "ファイルをアップロード",
"nopagetext": "指定したページは存在しません。",
"pager-newer-n": "{{PLURAL:$1|以後の$1件}}",
"pager-older-n": "{{PLURAL:$1|以前の$1件}}",
- "suppress": "秘匿する",
+ "suppress": "秘匿",
"querypage-disabled": "パフォーマンスに悪影響を与えるおそれがあるため、この特別ページは無効になっています。",
"apihelp": "API のヘルプ",
"apihelp-no-such-module": "モジュール「$1」が見つかりません。",
"category-file-count-limited": "Ағымдағы санатта келесі $1 файл бар.",
"listingcontinuesabbrev": "(жалғ.)",
"index-category": "Индекстелген беттер",
- "noindex-category": "Ð\98ндекÑ\81Ñ\82елмеген беттер",
+ "noindex-category": "Ð\98ндекÑ\81Ñ\82елмейÑ\82Ñ\96н беттер",
"broken-file-category": "Ақаулы файлдық сілтемелері бар беттер",
"about": "Жоба туралы",
"article": "Мағлұмат беті",
"createaccountreason": "Себебі:",
"createacct-reason": "Себебі:",
"createacct-reason-ph": "Неге басқа тіркегі жасамақшысыз",
- "createacct-captcha": "Құпиялық тексеруі",
- "createacct-imgcaptcha-ph": "Жоғарыдағы мәтінді енгізіңіз",
"createacct-submit": "Тіркелгіңізді жасаңыз",
"createacct-another-submit": "Тіркелгі жасау",
"createacct-benefit-heading": "{{SITENAME}} сіздермен жасалады.",
"mimesearch-summary": "Бұл бетте файлдарды MIME түрімен сүзгілеуі қосылған.\nКірісі: мағлұмат_түрі/түр_тарауы не мағлұмат_түрі/*, мысалы <code>image/jpeg</code>.",
"mimetype": "MIME түрі:",
"download": "Түсіріп алу",
- "unwatchedpages": "Бақыланылмаған беттер",
+ "unwatchedpages": "Бақыланбаған беттер",
"listredirects": "Айдағыш бет тізімі",
"listduplicatedfiles": "Телнұсқалы файлдар тізімі",
"listduplicatedfiles-summary": "Бұл кейбір басқа файлдың ең соңғы нұсқалы файлдың ең соңғы телнұсқасы файлдардың тізімі. Тек жергілікті файлдар есептелінеді.",
"specialpage-empty": "Бұл сұраныс бойынша нәтиже жоқ.",
"lonelypages": "Еш беттен сілтелмеген беттер",
"lonelypagestext": "Келесі беттерге {{SITENAME}} жобасындағы басқа беттерінің ішіндегі кірікбеттер сілтемейді.",
- "uncategorizedpages": "СанаÑ\82Ñ\81Ñ\8bз беттер",
+ "uncategorizedpages": "СанаÑ\82Ñ\82алмаÒ\93ан беттер",
"uncategorizedcategories": "Санатсыз санаттар",
"uncategorizedimages": "Санатсыз файлдар",
"uncategorizedtemplates": "Санатсыз үлгілер",
"createaccountreason": "Causa:",
"createacct-reason": "Causa",
"createacct-reason-ph": "Cur aliam rationem creas",
- "createacct-imgcaptcha-ph": "Textum quem supra vidis inscribe",
"createacct-submit": "Rationem tuam creare",
"createacct-another-submit": "Aliam rationem creare",
"createacct-benefit-body1": "{{PLURAL:$1|recensio|recensiones}}",
"enhancedrc-history": "Historia",
"recentchanges": "Nuper mutata",
"recentchanges-legend": "Indicis paginarum nuper mutatarum praeferentiae",
- "recentchanges-summary": "Inspice mutationes recentes huic vici in hac pagina.",
+ "recentchanges-summary": "Ecce mutationes recentes.",
"recentchanges-feed-description": "Nuper mutata Viciae hoc in fluxu observare.",
"recentchanges-label-newpage": "Haec recensio paginam novam creavit",
"recentchanges-label-minor": "Haec est recensio minor",
"july": "جوٙلای",
"august": "آگوست",
"september": "سئپتامر",
- "october": "ئوکتور",
+ "october": "ئÙ\88کتÙ\88بر",
"november": "نوڤامر",
"december": "دئسامر",
"january-gen": "جانڤیە",
"july-gen": "جوٙلای",
"august-gen": "آگوست",
"september-gen": "سئپتامر",
- "october-gen": "ئوکتوڤر",
+ "october-gen": "ئوکتوبر",
"november-gen": "نوڤامر",
"december-gen": "دئسامر",
"jan": "جانڤیە",
"july-date": "جوٙلای $1",
"august-date": "آگوست $1",
"september-date": "سئپتامر $1",
- "october-date": "ئوکتوڤر $1",
+ "october-date": "ئوکتوبر $1",
"november-date": "نوڤامر $1",
"december-date": "دئسامر $1",
"pagecategories": "{{PLURAL:$1|}}{{PLURAL:$1|دأسە|دأسە يا}}",
"tog-hideminor": "अलीकडील बदलांत छोटी संपादने लपवा",
"tog-hidepatrolled": "पहारा दिलेली संपादने (नित्य पहाण्यात असलेली संपादने) अलीकडील बदलांमधून लपवा",
"tog-newpageshidepatrolled": "नवीन पृष्ठ यादीतून पहारा दिलेली पाने (नित्य पहाण्यात असलेली संपादने) लपवा",
+ "tog-hidecategorization": "पानांचे वर्गीकरण लपवा",
"tog-extendwatchlist": "निरीक्षणसूचीत सगळे बदल दाखवा. फक्त अलीकडील नाही.",
"tog-usenewrc": "अलीकडील बदल आणि पहाऱ्याची सूचीत मांडणी करा",
"tog-numberheadings": "शीर्षके स्वयंक्रमांकित करा",
"tog-watchdefault": "मी संपादित केलेली पाने आणि संचिका माझ्या निरीक्षणसूचीत टाका",
"tog-watchmoves": "मी स्थानांतर केलेली पाने आणि संचिका माझ्या निरीक्षणसूचीत टाका",
"tog-watchdeletion": "मी वगळलेली पाने आणि संचिका माझ्या निरीक्षणसूचीत टाका",
+ "tog-watchrollback": "यात ज्या पानात मी माझ्या निरीक्षणसूचीत पुनर्परतीची (रोलबॅक) क्रिया केलेली आहे.",
"tog-minordefault": "सर्व संपादने 'छोटा बदल' म्हणून आपोआप जतन करा.",
"tog-previewontop": "झलक संपादन खिडकीच्या आधी दाखवा",
"tog-previewonfirst": "पहिल्या संपादनानंतर झलक दाखवा",
"tog-watchlisthideliu": "पहाऱ्याच्या सूचीतून प्रवेश केलेल्या सदस्यांची संपादने लपवा",
"tog-watchlisthideanons": "निरीक्षणसूचीतून अनामिक सदस्यांची संपादने लपवा",
"tog-watchlisthidepatrolled": "निरीक्षणसूचीतून तपासलेली संपादने लपवा",
+ "tog-watchlisthidecategorization": "पानांचे वर्गीकरण लपवा",
"tog-ccmeonemails": "मी इतर सदस्यांना पाठविलेल्या ई-मेल च्या प्रती मलाही माझ्या ई-मेल पत्त्यावर पाठवा",
"tog-diffonly": "निवडलेल्या आवृत्त्यांमधील बदल दाखवताना जुनी आवृत्ती दाखवू नका.",
"tog-showhiddencats": "लपविलेले वर्ग दाखवा",
"pool-timeout": "ताळ्यासाठी वाट पाहण्याची वेळ संपली",
"pool-queuefull": "सर्व्हरवर ताण आहे.",
"pool-errorunknown": "अपरिचित त्रुटी",
+ "pool-servererror": "पूल काउंटर सेवा उपलब्ध नाही($1).",
"poolcounter-usage-error": "वापर त्रूटी:$1",
"aboutsite": "{{SITENAME}}बद्दल",
"aboutpage": "Project:माहितीपृष्ठ",
"disclaimers": "उत्तरदायित्वास नकार",
"disclaimerpage": "Project: सर्वसाधारण उत्तरदायकत्वास नकार",
"edithelp": "संपादन साहाय्य",
- "helppage-top-gethelp": "मदत",
+ "helppage-top-gethelp": "साहायà¥\8dय",
"mainpage": "मुखपृष्ठ",
"mainpage-description": "मुखपृष्ठ",
"policy-url": "Project:नीती",
"readonly_lag": "मुख्य विदागार दात्याच्या (मास्टर डाटाबेस सर्व्हर) बरोबरीने पोहचण्यास पराधीन-विदागारदात्यास (स्लेव्ह सर्व्हर) वेळ लागल्यामुळे, विदागार आपोआप बंद झाला आहे.",
"internalerror": "अंतर्गत त्रुटी",
"internalerror_info": "अंतर्गत त्रुटी: $1",
+ "internalerror-fatal-exception": "\"$1\"प्रकारचा घातक अपवाद",
"filecopyerror": "\"$1\" संचिकेची \"$2\" ही प्रत करता आली नाही.",
"filerenameerror": "\"$1\" संचिकेचे \"$2\" असे नामांतर करता आले नाही.",
"filedeleteerror": "\"$1\" संचिका वगळता आली नाही.",
"title-invalid-empty": "आपण विनंति केलेले पान-शिर्षक एकतर रिकामे आहे किंवा त्यात एखाद्या नामविश्वाचे नाव आहे.",
"title-invalid-utf8": "आपण विनंती केलेल्या पानाच्या शिर्षकात अवैध यूटिएफ-८ क्रमवारी आहेत.",
"title-invalid-interwiki": "आपण विनंती केलेल्या पानात आंतरविकि दुवे आहेत जे शिर्षकात वापरता येउ शकत नाहीत.",
- "title-invalid-talk-namespace": "आपण विनंति केलेले पान उपलब्ध नसलेल्या चर्च्या पानास संबोधित करते",
+ "title-invalid-talk-namespace": "आपण विनंति केलेले पान शिर्षक चर्चा पानास संदर्भांकित करते जे अस्तित्वात नाही.",
+ "title-invalid-characters": "विनंती केलेल्या पानात अवैध वर्ण आहेत:\"$1\".",
+ "title-invalid-relative": "शिर्षकास संलग्न मार्ग आहेत.संलग्न पान शिर्षके (./, ../)अवैध आहेत, कारण ते सदस्याच्या न्याहाळकाद्वारे हाताळल्यावर, अनेकदा, त्यावर पोचता येणार नाही.",
+ "title-invalid-magic-tilde": "विनंती केलेल्या पानाच्या शिर्षकात अवैध जादुई नासिक्यत्व-चिन्ह क्रमवारी(मॅजिक टिल्ड सिक्वेन्स) आहे(<nowiki>~~~</nowiki>).",
+ "title-invalid-too-long": "विनंती केलेल्या पानाचे शिर्षक फारच लांबीचे आहे.यूटीएफ-८ एनकोडिंगमध्ये ते $1{{PLURAL:$1|बाईट|बाईटस्}} पेक्षा लांब नको.",
+ "title-invalid-leading-colon": "विनंती केलेल्या पानाचे शिर्षकाचे सुरुवातीस अवैध द्विबिंदुचिन्ह(:) आहे.",
"perfcached": "खालील माहिती सयीमधील (कॅशे) असल्यामुळे ती अद्ययावत् नाही.जास्तीतजास्त {{PLURAL:$1|एक प्रतिफळ |$1 प्रतिफळे }} सयीमध्ये असतात.",
"perfcachedts": "खालील माहिती सयीमधील (कॅशे) आहे व ती $1 पर्यंत अद्ययावत् आहे. जास्तीतजास्त {{PLURAL:$4|एक प्रतिफळ |$4 प्रतिफळे}} सयीमध्ये असतात.",
"querypage-no-updates": "सध्या या पानाकरिता नवी अद्यतने अनुपलब्ध केली आहेत.आत्ताच येथील विदा तरोताजा होणार नाही.",
"viewyourtext": "तुम्ही या पानाची,<strong>तुमची संपादने</strong> पाहू शकता व त्याची प्रत करू शकता.",
"protectedinterface": "हे पान सॉफ्टवेअरला इंटरफेस लेखन पुरवते, म्हणून दुरूपयोग टाळण्यासाठी संरक्षित केलेले आहे.\n\nसर्व विकिंवर, अनुवाद जोडण्याकरता किंवा बदलण्याकरता अथवा शुद्धलेखन चिकित्सेकरीता , कृपया [//translatewiki.net/ translatewiki.net], या मिडियाविकि स्थानिकीकरण प्रकल्पावर जा.",
"editinginterface": "<strong>सावधान</strong>तुम्ही संचेतनाचे (सॉफ्टवेअर) संपर्क माध्यम मजकूर असलेले पान संपादित करित आहात. या पानावरील बदल या विकिवरील इतर सदस्यांच्या सदस्य संपर्क माध्यमाचे स्वरूप बदलू शकते.",
+ "translateinterface": "सर्व विकिंवर अनुवाद जोडण्याकरता किंवा बदलण्याकरता, कृपया [//translatewiki.net/ ट्रांसलेटविकि.नेट]चा वापर करा,जो मिडियाविकिचा स्थानिकीकरण प्रकल्प आहे.",
"cascadeprotected": "हे पान संपादनांपासून सुरक्षित केल्या गेले आहे, कारण ते खालील {{PLURAL:$1|पानात|पानांमध्ये}} अंतर्भूत केलेले आहे,{{PLURAL:$1|जे पान|जी पाने }} निपतन पर्याय सुरु केल्यामुळे सुरक्षित आहेत:\n$2",
"namespaceprotected": "'''$1''' नामविश्वातील पाने संपादण्याची आपणांस परवानगी नाही.",
"customcssprotected": "या पानावर इतर सदस्याची वैयक्तिक मांडणी असल्यामुळे, तुम्हाला हे सीएसएस पान संपादित करण्याची परवानगी नाही.",
"invalidtitle-knownnamespace": "\"$2\" नामविश्वात \"$3\" मजकूराचे अयोग्य शीर्षक",
"invalidtitle-unknownnamespace": "अनोळखी नामविश्वाच्या आकड्यासह अवैध मथळा $1 व मजकूर \"$2\"",
"exception-nologin": "सनोंद-प्रवेशित नाही",
- "exception-nologin-text": "हà¥\87 पान à¤\95िà¤\82वा à¤\95à¥\8dरिया à¤\95रणà¥\8dयासाठà¥\80 à¤\86पलà¥\8dयाला या विà¤\95िवर [[Special:Userlogin|सनà¥\8bà¤\82द- पà¥\8dरवà¥\87शित]] असावयास हवे.",
+ "exception-nologin-text": "हà¥\87 पान à¤\95िà¤\82वा à¤\95à¥\8dरिया à¤\95रणà¥\8dयासाठà¥\80 à¤\86पलà¥\8dयाला सनà¥\8bà¤\82द- पà¥\8dरवà¥\87शित असावयास हवे.",
"exception-nologin-text-manual": "हे पान किंवा क्रियेस पोचण्यास कृपया $1 करा.",
"virus-badscanner": "खराब विन्यास (कॉन्फिगरेशन): अनोळखी व्हायरस स्कॅनर: ''$1''",
"virus-scanfailed": "क्रमवीक्षण (स्कॅन) अयशस्वी (कोड $1)",
"gotaccountlink": "सनोंद-प्रवेश करा",
"userlogin-resetlink": "सनोंद-प्रवेश तपशील विसरला असाल तर येथे टिचकी मारा.",
"userlogin-resetpassword-link": "आपला परवलीचा शब्द विसरलात?",
- "userlogin-helplink2": "सनà¥\8bà¤\82द पà¥\8dरवà¥\87शासà¤\82बà¤\82धà¥\80 मदत",
+ "userlogin-helplink2": "सनà¥\8bà¤\82द पà¥\8dरवà¥\87शासà¤\82बà¤\82धà¥\80 साहायà¥\8dय",
"userlogin-loggedin": "आपण पुर्वीच {{GENDER:$1|$1}} म्हणून सनोंद प्रवेशित आहात.वेगळ्या सदस्यनावाने सनोंद प्रवेशासाठी खालील आवेदन वापरा.",
"userlogin-createanother": "दुसरे नवीन खाते तयार करा",
"createacct-emailrequired": "विपत्र पत्ता(ई-मेल)",
"createacct-benefit-body2": "{{PLURAL:$1|लेख}}",
"createacct-benefit-body3": "अलीकडील {{PLURAL:$1|योगदानकर्ता|योगदानकर्ते}}",
"badretype": "तुम्ही टाकलेले परवलीचे शब्द जुळत नाहीत.",
+ "usernameinprogress": "या सदस्यनावाचे खाते तयार करण्याचे काम प्रगतीपथावर आहे. कृपया थांबा.",
"userexists": "तुम्ही टाकलेले सदस्यनाम पूर्वीच वापरात आहे.\nकृपया वेगळे सदस्यनाम निवडा.",
"loginerror": "सनोंद-प्रवेशात चूक झाली आहे",
"createacct-error": "खाते तयार करण्यात चुकी",
"nosuchusershort": "\"$1\" या नावाचा सदस्य नाही. लिहीताना आपली चूक तर नाही ना झाली?",
"nouserspecified": "तुम्हाला सदस्यनाव नमूद करावे लागेल.",
"login-userblocked": "हा सदस्य ’प्रतिबंधित’ आहे. त्यास सनोंद-प्रवेशाची परवानगी नाही.",
- "wrongpassword": "à¤\86पला परवलà¥\80à¤\9aा शबà¥\8dद à¤\9aà¥\81à¤\95à¥\80à¤\9aा आहे, पुन्हा एकदा प्रयत्न करा.",
- "wrongpasswordempty": "परवलà¥\80à¤\9aा शबà¥\8dद रिà¤\95ामा à¤\86हà¥\87; परत प्रयत्न करा.",
+ "wrongpassword": "à¤\86पण परवलà¥\80à¤\9aा शबà¥\8dद à¤\9aà¥\81à¤\95à¥\80à¤\9aा à¤\9fाà¤\95ला आहे, पुन्हा एकदा प्रयत्न करा.",
+ "wrongpasswordempty": "परवलà¥\80à¤\9aा शबà¥\8dद à¤\95à¥\8bरा à¤\86हà¥\87; पà¥\81नà¥\8dहा प्रयत्न करा.",
"passwordtooshort": "तुमच्या परवलीच्या शब्दात किमान {{PLURAL:$1|१ अक्षर |$1 अक्षरे}} हवीत.",
+ "passwordtoolong": "परवलीचा शब्द हा {{PLURAL:$1|१ वर्ण पेक्षा|$1 वर्णांपेक्षा}} लांबीचा नको.",
"password-name-match": "आपला परवलीचा शब्द हा आपल्या सदस्यनावापेक्षा वेगळा हवा.",
"password-login-forbidden": "या सदस्यनामाचा व परवलीच्या शब्दाचा वापर निषिद्ध आहे.",
"mailmypassword": "नवीन परवलीचा शब्द पुनर्स्थापित(रिसेट) करा",
- "passwordremindertitle": "{{SITENAME}}करिता नवा तात्पुरता परवलीचा शब्दांक.",
+ "passwordremindertitle": "{{SITENAME}}करिता नवा तात्पुरता परवलीचा शब्द",
"passwordremindertext": "कुणीतरी (कदाचित तुम्ही, अंकपत्ता $1 कडून) {{SITENAME}} करिता ’नवा परवलीचा शब्दांक पाठवावा’ अशी विनंती केली आहे ($4).\n\"$2\" सदस्याकरिता तात्पुरता परवलीचा शब्दांक \"$3\" झाला आहे.\nतुम्ही आता प्रवेश करा व तुमचा परवलीचा शब्दांक बदला. तुमचा अस्थायी शब्दांक {{PLURAL:$5|एका दिवसात|$5 दिवसांत}} मृत होईल.\n\nजर ही विनंती इतर कुणी केली असेल किंवा तुम्हाला तुमचा परवलीचा शब्दांक आठवला असेल आणि तुम्ही तो आता बदलू इच्छित नसाल तर, तुम्ही हा संदेश दुर्लक्षित करून जुना परवलीचा शब्दांक वापरत राहू शकता.",
"noemail": "\"$1\" सदस्याच्या कोणत्याही विपत्रपत्त्याची(ई-मेल)नोंद नाही.",
"noemailcreate": "आपण वैध विरोप-पत्ता (ई-मेल ऍड्रेस) देणे आवश्यक आहे.",
"eauthentsent": "नमूद केलेल्या ई-मेल पत्त्यावर एक निश्चितता स्वीकारक ई-मेल पाठविला गेला आहे.\nखात्यावर कोणताही इतर ई-मेल पाठविण्यापूर्वी - तो ई-मेल पत्ता तुमचाच आहे, हे सुनिश्चित करण्यासाठी - तुम्हाला त्या ई-मेल मधील सूचनांचे पालन करावे लागेल.",
"throttled-mailpassword": "मागील {{PLURAL:$1|तासात|$1 तासांत}} परवलीचा शब्द बदलण्यासाठीची सूचना विपत्राद्वारे पाठविलेली आहे. दुरुपयोग टाळण्यासाठी, {{PLURAL:$1|एका तासामध्ये|$1 तासांमध्ये}} फक्त एकदाच सूचना दिली जाईल.",
"mailerror": "विपत्र पाठवण्यात त्रुटी: $1",
- "acct_creation_throttle_hit": "माफ à¤\95रा, तà¥\81मà¥\8dहà¥\80 à¤\86तà¥\8dतापरà¥\8dयà¤\82त {{PLURAL:$1|१ à¤\96ातà¥\87 à¤\89à¤\98डलà¥\87 à¤\86हà¥\87|$1 à¤\96ातà¥\80 à¤\89à¤\98डलà¥\80 à¤\86हà¥\87त}}. तà¥\81मà¥\8dहाला à¤\86णà¤\96à¥\80 à¤\96ातà¥\80 उघडता येणार नाहीत.",
+ "acct_creation_throttle_hit": "à¤\86पला à¤\85à¤\82à¤\95पतà¥\8dता वापरà¥\81न या विà¤\95िस à¤à¥\87à¤\9f दà¥\87णाऱà¥\8dयाà¤\82नà¥\80 à¤\95ाल {{PLURAL:$1|१ à¤\96ातà¥\87|$1 à¤\96ातà¥\80}} à¤\89à¤\98डलà¥\80 à¤\86हà¥\87त तà¥\80 या à¤\95ालावधà¥\80तà¥\80ल महतà¥\8dतम à¤\86हà¥\87त.\n\nतà¥\8dयाà¤\9aा परिपाà¤\95 मà¥\8dहणà¥\82न सधà¥\8dया हा à¤\85à¤\82à¤\95पतà¥\8dता वापरà¥\81न à¤à¥\87à¤\9f दà¥\87णाऱà¥\8dयास à¤\85धिà¤\95 à¤\96ातà¥\87 उघडता येणार नाहीत.",
"emailauthenticated": "तुमचा विपत्रपत्ता $2 ला $3 यावेळी तपासण्यात आला आहे.",
"emailnotauthenticated": "तुमच्या ई-मेल पत्त्याची अद्याप निश्चिती झालेली नाही. खालील कोणत्याही फिचर्ससाठी ई-मेल पाठविला जाणार नाही.",
"noemailprefs": "खालील सुविधा कार्यान्वित करण्यासाठी,पसंतीक्रमात ई-मेल पत्ता नमूद करा.",
"createaccount-text": "तुमचा विपत्र पत्ता घेउन {{SITENAME}} ($4)वर \"$2\" नावाच्या कोण्या एकाने \"$3\" परवलीने खाते उघडले आहे. कृपया आपण सनोंद-प्रवेश करून आपला परवलीचा शब्द बदलावा.\n\nजर ही खातेनोंदणी चुकिने झाली असेल तर, तुम्ही या संदेशाकडे दुर्लक्ष करू शकता.",
"login-throttled": "तुम्ही नुकतेच सनोंद- प्रवेशासाठी अनेकानेक प्रयत्न केले आहेत.\nकृपया, पुन्हा प्रयत्न करण्याआधी $1 थोडी उसंत घ्या.",
"login-abort-generic": "तुमचा प्रवेश अयशस्वी होऊन रद्द झाला.",
+ "login-migrated-generic": "आपल्या खात्याचे स्थलांतर झाले आहे,या विकिवर आपले सदस्यनाव आता यापुढे अस्तित्वात राहणार नाही.",
"loginlanguagelabel": "भाषा: $1",
"suspicious-userlogout": "तुमच्या सनोंद-निर्गमनास नकार दिल्या गेला कारण असे दिसते की ती विनंती अन-अनुबंधित(डिसकनेक्टेड) न्याहाळकाद्वारे पाठवल्या गेली.",
"createacct-another-realname-tip": "आपले खरे नाव टाकणे वैकल्पिक आहे.\nजर आपण ते द्यायचे ठरविले तर,ते आपल्या कामाचा मूळ स्रोत म्णून देण्यास वापरले जाईल.",
"pt-createaccount": "खाते बनवा",
"pt-userlogout": "सनोंद-निर्गम",
"php-mail-error-unknown": "पीएचपीच्या विपत्र() पर्यायात अज्ञात चूक",
- "user-mail-no-addy": "à¤\88मà¥\87ल पतà¥\8dतà¥\8dया विना à¤\88मà¥\87ल पाठवणà¥\8dयà¤\9aा पà¥\8dरयतà¥\8dन à¤\95à¥\87ला",
+ "user-mail-no-addy": "à¤\88मà¥\87ल पतà¥\8dतà¥\8dया विना à¤\88मà¥\87ल पाठविणà¥\8dयाà¤\9aा पà¥\8dरयतà¥\8dन à¤\95à¥\87ला.",
"user-mail-no-body": "रिकामे किंवा अत्यंत छोटा मजकूर असलेले विपत्र पाठविण्याचा प्रयत्न करण्यात आला",
"changepassword": "परवलीचा शब्द बदला",
- "resetpass_announce": "à¤\96ातà¥\8dयामधà¥\8dयà¥\87 पà¥\8dरविषà¥\8dà¤\9f हà¥\8bणà¥\87 थाà¤\82बविणà¥\8dयाà¤\95रिता à¤\95à¥\83पया à¤\86पलà¥\8dया à¤\96ातà¥\8dयाà¤\9aा à¤\95à¥\82à¤\9fशबà¥\8dद बदला.",
+ "resetpass_announce": "सनà¥\8bà¤\82द पà¥\8dरवà¥\87श पà¥\82रà¥\8dण à¤\95रणà¥\8dयाà¤\95रिता à¤\95à¥\83पया à¤\86पला परवलà¥\80à¤\9aा शबà¥\8dद पà¥\81नरà¥\8dसà¥\8dथापित à¤\95रा.",
"resetpass_text": "<!-- मजकूर इथे लिहा -->",
"resetpass_header": "खात्याचा परवलीचा शब्द बदला",
"oldpassword": "जुना परवलीचा शब्दः",
"resetpass-submit-loggedin": "परवलीचा शब्द बदला",
"resetpass-submit-cancel": "रद्द करा",
"resetpass-wrong-oldpass": "अवैध किंवा अस्थायी परवलीचा शब्द.\nकदाचित तुम्ही आधीच तो यशस्वीरीत्या बदलला असेल किंवा नवीन तात्पुरता परवलीचा शब्द मागवला असेल.",
+ "resetpass-recycled": "सध्याच्या परवलीच्या शब्दापेक्षा काहीतरी वेगळ्या परवलीच्या शब्दाची पुनर्स्थापना करा.",
+ "resetpass-temp-emailed": "विप्त्राद्वारे पाठविलेल्या तात्पुरत्या संकेताने आपण प्रवेश घेतला.सनोंद प्रवेश पूर्ण करण्यास, आपण येथे नविन परवलीच्या शब्दाची स्थापना करावयास हवी:",
"resetpass-temp-password": "तात्पुरता परवलीचा शब्द",
"resetpass-abort-generic": "परवलीचा शब्दबदल विस्तारकाद्वारे नाकारण्यात आला.",
+ "resetpass-expired": "आपला परवलीचा शब्द संपुष्टात आला.कृपया प्रवेशास नविन परवलीचा शब्द स्थापा.",
+ "resetpass-expired-soft": "आपला परवलीचा शब्द संपुष्टात आला असुन त्याची पुनर्स्थापना करणे आवश्यक आहे. कृपया आता नविन परवलीचा शब्द निवडा किंवा नंतर पुनर्स्थापना करण्यास \"{{int:resetpass-submit-cancel}}\" येथे टिचका.",
+ "resetpass-validity-soft": "आपला परवलीचा शब्द वैध नाही:$1\n\nकृपया नविन परवलीचा शब्द निवडा किंवा नंतर पुनर्स्थापना करण्यास \"{{int:resetpass-submit-cancel}}\" येथे टिचका.",
"passwordreset": "परवलीचा शब्द पूर्ववत करा",
"passwordreset-text-one": "आपला परवलीचा शब्द बदलण्यास हे आवेदन भरा.",
"passwordreset-text-many": "{{PLURAL:$1|आपला तात्पुरता परवलीचा शब्द विपत्रामार्फत प्राप्त करण्यास खालील क्षेत्रातील एखादे भरा.}}",
"changeemail-no-info": "हे पान थेट बघण्यासठी तुम्हाला सनोंद-प्रवेशित असावे लागेल.",
"changeemail-oldemail": "सध्याचा ईमेल पत्ता :",
"changeemail-newemail": "नवा ईमेल पत्ता:",
+ "changeemail-newemail-help": "जर आपणास आपला विपत्रपत्ता(ई-मेल एड्रेस) हटवायचा असेल तर हे क्षेत्र आपण कोरे ठेवावयास हवे. जर आपण आपला विपत्रपत्ता हटविला तर, आपण विसरलेला परवलीचा शब्द पुनर्स्थापित करु शकणार नाही व या विकिवरुन आपणास विपत्रे प्राप्त होणार नाहीत.",
"changeemail-none": "(काहीही नाही)",
"changeemail-password": "तुमचा {{SITENAME}} संकेतांक:",
"changeemail-submit": "ईमेल बदला",
"changeemail-throttled": "तुम्ही नुकतेच सनोंद- प्रवेशासाठी अनेक प्रयत्न केले आहेत.\nकृपया, पुन्हा प्रयत्न करण्याआधी $1 थोडी उसंत घ्या.",
+ "changeemail-nochange": "कृपया वेगळा नविन विपत्रपत्ता टाका.",
"resettokens": "ओळखचिन्ह(टोकन) पुनर्स्थापित करा",
"resettokens-text": "येथे आपल्या खात्यात असलेला व्यक्तिगत मजकूरापर्यंत पोचण्यासाठी आपण ओळखचिन्ह(टोकन) पुनर्स्थापित करू शकता.\nआपण जर तो अपघाताने कोणासमवेत सहभागीला असेल किंवा आपले खात्याची आपण तडजोड केली असल्यास, हे करावयास हवे.",
"resettokens-no-tokens": "पुनर्स्थापित करण्यासाठी कोणतीही ओळखचिन्हे नाहीत.",
"preview": "झलक",
"showpreview": "झलक दाखवा",
"showdiff": "बदल दाखवा",
+ "blankarticle": "<strong>ईशारा:</strong>आपण तयार करीत असलेले पान कोरे आहे.जर आपण पुन्हा \"{{int:savearticle}}\" टिचकले तर,कोणताही आशय/मजकूर नसलेले पान तयार होईल.",
"anoneditwarning": "<strong>इशारा:</strong> तुम्ही विकिपीडियाचे सदस्य म्हणून सनोंद-प्रवेश (लॉग-इन) केलेले नाही.आपण काही संपादन केले तर, तुमचा अंकपत्ता (आयपी) सार्वजनिक रित्या दृष्य होईल. जर आपण <strong>[$1 सनोंद प्रवेश केला]</strong> किंवा <strong>[$2 खाते उघडले]</strong>,तर आपण केलेली संपादने ही आपल्या नांवाशी संलग्न होतील, त्याशिवाय याचे इतरही फायदे आहेत.",
"anonpreviewwarning": "\"'''सावधान:''' तुम्ही विकिपीडियाचे सदस्य म्हणून सनोंद-प्रवेश (लॉग-इन) केलेला नाही. या पानाच्या संपादन इतिहासात तुमचा अंकपत्ता (आय.पी. ॲड्रेस) नोंदला जाईल.\"",
"missingsummary": "'''आठवण:''' आपण संपादन सारांश पुरवलेला नाही.आपण 'जतन करा' वर पुन्हा टिचकी मारली तर, ते त्याशिवायच जतन होईल.",
+ "selfredirect": "<strong>ईशारा:</strong>आपण या पानास, त्याच पानावर पुनर्निर्देशित करीता आहात.\nआपण पुनर्निर्देशनासाठी चूकिचे लक्ष्य नमूद केले आहे किंवा आपण चूकिच्या पानाचे संपादन करीत आहात.\nजर आपण पुन्हा \"{{int:savearticle}}\" टिचकले तर, कसेहीकरुन ते पुनर्निर्देशन तयार होईल.",
"missingcommenttext": "कृपया खाली प्रतिक्रिया भरा.",
"missingcommentheader": "<strong>आठवण:<strong> आपण या लेखनाकरिता विषय दिलेला नाही. आपण पुन्हा \"{{int:savearticle}}\" वर टिचकले तर, तुमचे संपादन त्याशिवायच जतन होईल.",
"summary-preview": "आढाव्याची झलक:",
"subject-preview": "विषय झलक:",
+ "previewerrortext": "आपल्या बदलांची झलक बघण्याचे प्रयत्नादरम्यान त्रूटी उद्भवली.",
"blockedtitle": "हा सदस्य प्रतिबंधित आहे",
"blockedtext": "'''तुमचे सदस्यनाव अथवा IP पत्ता ब्लॉक केलेला आहे.'''\n\nहा ब्लॉक $1 यांनी केलेला आहे.\nयासाठी ''$2'' हे कारण दिलेले आहे.\n\n* ब्लॉकची सुरूवात: $8\n* ब्लॉकचा शेवट: $6\n* कुणाला ब्लॉक करायचे आहे: $7\n\nतुम्ही ह्या ब्लॉक संदर्भातील चर्चेसाठी $1 अथवा [[{{MediaWiki:Grouppage-sysop}}|प्रबंधकांशी]] संपर्क करू शकता.\nतुम्ही जोवर वैध ई-मेल पत्ता आपल्या [[Special:Preferences|'माझ्या पसंती']] पानावर देत नाही तोवर तुम्ही ’सदस्याला ई-मेल पाठवा’ हा दुवा वापरू शकत नाही. तसेच असे करण्यापासून आपल्याला ब्लॉक केलेले नाही.\nतुमचा सध्याचा IP पत्ता $3 हा आहे, व तुमचा ब्लॉक क्रमांक #$5 हा आहे.\nकृपया या संदर्भातील चर्चेमध्ये वरील सर्व तपशिल उद्घृत करा.",
"autoblockedtext": "तुमचा आंतरजालीय अंकपत्ता आपोआप स्थगित केला आहे कारण तो इतर अशा सदस्याने वापरला, ज्याला $1ने प्रतिबंधित केले.\nआणि दिलेले कारण खालील प्रमाणे आहे\n:''$2''\nब्लॉकची सुरूवात: $8\nब्लॉकचा शेवट: $6\nकुणाला ब्लॉक करायचे आहे: $7\n\nतुम्ही $1शी संपर्क करू शकता किंवा इतर [[{{MediaWiki:Grouppage-sysop}}|प्रबंधकां पैकी]] एकाशी स्थगनाबद्दल चर्चा करू शकता.\n\n[[Special:Preferences|सदस्य पसंतीत]]त शाबीत विपत्र पत्ता नमूद असल्या शिवाय आणि तुम्हाला तो वापरण्या पासून प्रतिबंधित केले असल्यास तुम्ही \"या सदस्यास विपत्र पाठवा\" सुविधा वापरू शकणार नाही.\nतुमचा सध्याचा IP पत्ता $3 हा आहे, व तुमचा ब्लॉक क्रमांक #$5 हा आहे. \nतुमचा स्थगन क्र $5 आहे. कृपया या संदर्भातील चर्चेमध्ये वरील सर्व तपशिल उद्घृत करा.",
"accmailtitle": "परवलीचा शब्द पाठविण्यात आलेला आहे.",
"accmailtext": "[[User talk:$1|$1]] यांसाठी अनियतक्रमाने निर्मित केलेला परवलीचा शब्द $2 यांना पाठवण्यात आला आहे.\n\nया नवीन खात्यासाठीचा परवलीचा शब्द,सनोंद-प्रवेश घेतल्यावर [[Special:ChangePassword|परवलीचा शब्द बदला]] येथे बदलता येईल.",
"newarticle": "(नवीन लेख)",
- "newarticletext": "तà¥\81मà¥\8dहाला à¤\85पà¥\87à¤\95à¥\8dषित à¤\85सलà¥\87ला लà¥\87à¤\96 à¤\85à¤\9cà¥\82न लिहिला à¤\97à¥\87लà¥\87ला नाहà¥\80. हा लà¥\87à¤\96 लिहिणà¥\8dयासाठà¥\80 à¤\96ालà¥\80ल पà¥\87à¤\9fà¥\80त मà¤\9cà¤\95à¥\82र लिहा. मदतà¥\80साठà¥\80 [$1 यà¥\87थà¥\87] à¤\9fिà¤\9aà¤\95à¥\80 दà¥\8dया.\n\nà¤\9cर यà¥\87थà¥\87 à¤\9aà¥\81à¤\95à¥\82न à¤\86ला à¤\85साल तर बà¥\8dराà¤\89à¤\9dरà¤\9aà¥\8dया बà¥\85à¤\95 (back) कळीवर टिचकी द्या.",
+ "newarticletext": "à¤\86पण सधà¥\8dया à¤\85सà¥\8dतितà¥\8dवात नसलà¥\87लà¥\8dया पानाà¤\9aà¥\8dया दà¥\81वà¥\8dयाà¤\9aा माà¤\97à¥\8bवा à¤\98à¥\87त à¤\86ला à¤\86हात.\nहà¥\87 पान तयार à¤\95रणà¥\8dयासाठà¥\80,à¤\96ालà¥\80ल पà¥\87à¤\9fà¥\80त à¤\9fà¤\82à¤\95न à¤\95रणà¥\87 सà¥\81रà¥\81 à¤\95रा(à¤\85धिà¤\95 माहितà¥\80साठà¥\80 [$1 साहायà¥\8dय पान] बà¤\98ा).\n\nà¤\9cर à¤\86पण यà¥\87थà¥\87 à¤\9aà¥\81à¤\95à¥\82न à¤\86ला à¤\85साल तर बà¥\8dराà¤\89à¤\9dरà¤\9aà¥\8dया <strong>परत</strong>(बà¥\85à¤\95) कळीवर टिचकी द्या.",
"anontalkpagetext": "---- ''हे चर्चापान अशा अज्ञात सदस्यासाठी आहे, ज्यांनी खाते तयार केलेले नाही किंवा त्याचा वापर करत नाहीत. त्यांच्या ओळखीसाठी आम्ही आंतरजाल अंकपत्ता वापरतो आहोत. असा अंकपत्ता बऱ्याच लोकांचा एकच असू शकतो. जर आपण अज्ञात सदस्य असाल आणि आपल्याला काही अप्रासंगिक संदेश मिळाला असेल तर कृपया [[Special:UserLogin| खाते तयार करा]] किंवा [[Special:UserLogin/signup|सनोंद-प्रवेश करा]] ज्यामुळे, पुढे असे गैरसमज होणार नाहीत.''",
"noarticletext": "या लेखात सध्या काहीही मजकूर नाही.\nतुम्ही विकिपीडियावरील इतर लेखांमध्ये या [[Special:Search/{{PAGENAME}}| मथळ्याचा शोध घेऊ शकता]], <span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAMEE}}}} इतर नोंदी शोधा],\nकिंवा हा लेख [{{fullurl:{{FULLPAGENAME}}|action=edit}} लिहू शकता]</span>.",
"noarticletext-nopermission": "सध्या या लेखात काहीही मजकूर नाही.\nतुम्ही विकिपीडियावरील इतर लेखांमध्ये [[Special:Search/{{PAGENAME}}| या मथळ्याचा शोध घेऊ शकता]], <span class=\"plainlinks\">[{{fullurl:{{#Special:Log}}|page={{FULLPAGENAME}}}}आपण या लेखाच्या इतर नोंदी शोधा]</span>,परंतु, आपणास हा लेख लिहीण्याची परवानगी देण्यात येउ शकत नाही.",
"token_suffix_mismatch": "'''तुमचे संपादन रद्द करण्यात आलेले आहे कारण तुमच्या क्लायंटनी तुमच्या संपादनातील उद्गारवाचक चिन्हांमध्ये (punctuation) बदल केलेले आहेत.\nपानातील मजकूर खराब होऊ नये यासाठी संपादन रद्द करण्यात आलेले आहे.\nअसे कदाचित तुम्ही अनामिक proxy वापरत असल्याने होऊ शकते.'''",
"edit_form_incomplete": "'''तुमच्या संपादनाचा काही भाग सर्व्हरपर्यंत पोचला नाही; तुमचे संपादन पूर्ण आहे का याची पुन्हा खात्री करा व पुन्हा प्रयत्न करा.'''",
"editing": "$1 चे संपादन होत आहे.",
- "creating": "$1 या लà¥\87à¤\96ाà¤\9aà¥\80 निरà¥\8dमितà¥\80 सà¥\81रà¥\82 à¤\86हà¥\87",
+ "creating": "$1 ची निर्मिती सुरू आहे",
"editingsection": "$1 (विभाग) संपादन",
"editingcomment": "$1 चे संपादन (प्रतिक्रिया)",
"editconflict": "संपादन मतभेद: $1",
"yourdiff": "फरक",
"copyrightwarning": "{{SITENAME}} येथे केलेले कोणतेही लेखन $2 (अधिक माहितीसाठी $1 पहा) अंतर्गत मुक्त उद्घोषित केले आहे असे गृहीत धरले जाईल याची कृपया नोंद घ्यावी. आपणास आपल्या लेखनाचे मुक्त संपादन आणि मुक्त वितरण होणे पसंत नसेल तर येथे संपादन करू नये.<br />\nतुम्ही येथे लेखन करताना हे सुद्धा गृहीत धरलेले असते की येथे केलेले लेखन तुमचे स्वतःचे आणि केवळ स्वतःच्या प्रताधिकार (कॉपीराईट) मालकीचे आहे किंवा प्रताधिकाराने गठित न होणाऱ्या सार्वजनिक ज्ञानक्षेत्रातून घेतले आहे किंवा तत्सम मुक्त स्रोतातून घेतले आहे. तुम्ही संपादन करताना तसे वचन देत आहात. '''प्रताधिकारयुक्त लेखन सुयोग्य परवानगीशिवाय मुळीच चढवू/भरू नये!'''",
"copyrightwarning2": "{{SITENAME}} येथे केलेले कोणतेही लेखन हे इतर संपादकांकरवी बदलले अथवा काढले जाऊ शकते. जर आपणास आपल्या लेखनाचे मुक्त संपादन होणे पसंत नसेल तर येथे संपादन करू नये.<br />\nतुम्ही येथे लेखन करताना हे सुद्धा गृहीत धरलेले असते की येथे केलेले लेखन तुमचे स्वतःचे आणि केवळ स्वतःच्या प्रताधिकार (कॉपीराईट) मालकीचे आहे किंवा प्रताधिकाराने गठित न होणाऱ्या सार्वजनिक ज्ञानक्षेत्रातून घेतले आहे किंवा तत्सम मुक्त स्रोतातून घेतले आहे. तुम्ही संपादन करताना तसे वचन देत आहात (अधिक माहितीसाठी $1 पहा). '''प्रताधिकारयुक्त लेखन सुयोग्य परवानगीशिवाय मुळीच चढवू/भरू नये!'''",
+ "editpage-cannot-use-custom-model": "या पानाचा आशय-आराखडा(कंटेन्ट मॉडेल) बदलता येणार नाही.",
"longpageerror": "त्रूटी:आपण दिलेला मजकूर जास्तीत जास्त शक्य {{PLURAL:$2|one किलोबाईट|$2 किलोबाईट}} पेक्षा अधिक लांबीचा {{PLURAL:$1|one किलोबाईट|$1 किलोबाईट}} आहे.तो जतन केला जाऊ शकत नाही",
"readonlywarning": "'''सावधान:विदागारास अनुरक्षणासाठी(मेंटेनन्स) ताळे ठोकले आहे,त्यामुळे सध्याच तुम्ही तुमचे संपादन जतन करू शकत नाही.'''\nजर तुम्हाला हवे असेल तर नंतर उपयोग करण्याच्या दृष्टीने, तुम्ही मजकूर नक्कल करुन, पुढील संपादनासाठी ’मजकुर संचिकेत’(टेक्स्ट फाईल)चिटकवू शकता.\nविदागारास ताळे ठोकलेल्या प्रचालकांनी खालील स्पष्टीकरण दिले आहे:$1",
"protectedpagewarning": "'''सूचना: हे सुरक्षित पान आहे. फक्त प्रचालक याच्यात बदल करू शकतात.'''",
"semiprotectedpagewarning": "'''सूचना:''' हे पान सुरक्षित आहे. फक्त नोंदणीकृत सदस्य याच्यात बदल करू शकतात.",
- "cascadeprotectedwarning": "'''ताकिद:''' हे पान निम्न-लिखीत निपतन-प्रतिबंधीत {{PLURAL:$1|पानात|पानांत}} आंतरभूत असल्यामुळे,केवळ प्रचालक सुविधाप्राप्त सदस्यांनाच संपादन करता यावे असे ताळे त्यास ठोकलेले आहे :",
+ "cascadeprotectedwarning": "<strong>ताकिद:</strong>हे पान निम्न-लिखीत निपतन-प्रतिबंधीत {{PLURAL:$1|पानात|पानांत}} आंतरभूत असल्यामुळे,केवळ प्रचालक-सुविधाप्राप्त सदस्यांनाच संपादन करता यावे असे ताळे त्यास ठोकलेले आहे :",
"titleprotectedwarning": "”’सावधान: फक्त काही सदस्यानांच [[Special:ListGroupRights|विशेष आधिकार]] तयार करता यावे म्हणून ह्या पानास ताळे आहे.'''",
"templatesused": "या पानामध्ये {{PLURAL:$1|वापरलेला साचा|वापरलेले साचे}}:",
"templatesusedpreview": "या झलकेमध्ये {{PLURAL:$1|वापरलेला साचा|वापरलेले साचे}}:",
"permissionserrors": "परवानगीस नकार",
"permissionserrorstext": "खालील{{PLURAL:$1|कारणामुळे|कारणांमुळे}} तुम्हाला तसे करण्याची परवानगी नाही:",
"permissionserrorstext-withaction": "तुम्हाला $2 क्रियेची परवानगी नाही, खालील {{PLURAL:$1|कारणासाठी|कारणांसाठी}}:",
+ "contentmodelediterror": "ही आवृत्ती आपण संपादू शकत नाही कारण त्याचा आशय-आराखडा (कंटेन्ट मॉडेल)<code>$1</code> आहे व सध्याच्या पानाचा आशय आराखडा <code>$2</code> आहे.",
"recreate-moveddeleted-warn": "'''सूचना: पूर्वी वगळलेला लेख तुम्ही पुन्हा बनवित आहात.'''\n\nआपण याचा विचार करा कि या पानाचे संपादन यापुढे करणे योग्य आहे काय.या पानाच्या वगळण्याच्या व स्थानांतराच्या नोंदी आपल्या (कामाच्या) सुलभतेसाठी दिलेल्या आहेत:",
"moveddeleted-notice": "हे पान वगळण्यात आलेले आहे.\nसंदर्भासाठी, वगळण्याची व स्थानांतराची नोंद खाली दिलेली आहे.",
+ "moveddeleted-notice-recent": "माफ करा,हे पान अलीकडेच (मागील २४ तासात) वगळल्या गेले आहे.हा पानाच्या वगळण्याचा व हलविण्याचा लॉग संदर्भासाठी खाली दिला आहे.",
"log-fulllog": "पूर्ण नोंदी पहा",
"edit-hook-aborted": "हूकद्वारे संपादन रद्द.\nकारण दिलेले नाही.",
"edit-gone-missing": "नविन पृष्ठ अद्यतन करता आले नाही. ते वगळले असण्याची शक्यता आहे.",
"edit-conflict": "वादग्रस्त संपादन",
"edit-no-change": "तुमचे संपादन दुर्लक्षित करण्यात आले आहे, कारण मजकूरात काहीही बदल झालेला नाही.",
- "postedit-confirmation-created": "पान निर्मित केले",
+ "postedit-confirmation-created": "पान निर्मित केल्या गेले आहे",
+ "postedit-confirmation-restored": "हे पान पुनर्स्थापित केल्या गेले.",
"postedit-confirmation-saved": "आपले संपादन जतन करण्यात आले आहे.",
"edit-already-exists": "नवीन पान तयार करता येऊ शकले नाही.\nया नावाचे पान पूर्वीच अस्तित्वात आहे.",
"defaultmessagetext": "अविचल संदेश मजकूर",
"expensive-parserfunction-warning": "”’इशारा:”’ या पानावर खूप सारे खर्चीक पार्सर क्रिया कॉल्स आहेत.\n\nते $2{{PLURAL:$2|कॉल|कॉल्स}} पेक्षा कमी असायला हवेत, सध्या $1{{PLURAL:$1| $1 कॉल| $1 कॉल्स}} एवढे आहेत.",
"expensive-parserfunction-category": "खूप सारे खर्चीक पार्सर क्रिया कॉल्स असणारी पाने",
"post-expand-template-inclusion-warning": "<strong>ईशारा:</strong> साचे वाढविण्याची मर्यादा संपलेली आहे.\nकाही साचे वगळले जातील.",
- "post-expand-template-inclusion-category": "अशी पाने ज्यांच्यावर साचे चढविण्याची मर्यादा संपलेली आहे",
+ "post-expand-template-inclusion-category": "à¤\85शà¥\80 पानà¥\87 à¤\9cà¥\8dयाà¤\82à¤\9aà¥\8dयावर साà¤\9aà¥\87 à¤\9aढविणà¥\8dयाà¤\9aà¥\80 à¤\86à¤\95ार मरà¥\8dयादा सà¤\82पलà¥\87लà¥\80 à¤\86हà¥\87",
"post-expand-template-argument-warning": "<strong>ईशारा:</strong> या पानावर असा एकतरी साचा आहे जो वाढविल्यास खूप मोठा होईल.\nअसे साचे वगळण्यात आलेले आहेत.",
"post-expand-template-argument-category": "अशी पाने ज्यांच्यामध्ये साचे वगळलेले आहेत",
"parser-template-loop-warning": "साचा चक्र मिळाले: [[$1]]",
"cantcreateaccounttitle": "खाते उघडू शकत नाही",
"cantcreateaccount-text": "('''$1''')या आंतरजाल अंकपत्त्याकडूनच्या खाते निर्मितीस [[User:$3|$3]]ने अटकाव केला आहे.\n\n$3ने ''$2'' कारण दिले आहे.",
"viewpagelogs": "या पानाच्या नोंदी पहा",
- "nohistory": "या पà¥\83षà¥\8dठासाठà¥\80 à¤\86वà¥\83तà¥\8dतà¥\80 इतिहास अस्तित्वात नाही.",
+ "nohistory": "या पà¥\83षà¥\8dठासाठà¥\80 सà¤\82पादन इतिहास अस्तित्वात नाही.",
"currentrev": "सध्याची आवृत्ती",
"currentrev-asof": "$1 ची नविनतम आवृत्ती",
"revisionasof": "$1 नुसारची आवृत्ती",
- "revision-info": "$2ने $1चे आवर्तन",
+ "revision-info": "{{GENDER:$6|$2}}द्वारा $1चे आवर्तन",
"previousrevision": "←मागील आवृत्ती",
"nextrevision": "नविनतम आवृत्ती→",
"currentrevisionlink": "सध्याची आवृत्ती",
"rev-deleted-event": "(क्रिया नोंद वगळली)",
"rev-deleted-user-contribs": "[सदस्यनाव / अंकपत्ता वगळला - योगदानातुन संपादन लपविले]",
"rev-deleted-text-permission": "या पानाची आवृत्ती सार्वजनिक विदागारातून '''वगळण्यात आली आहे'''.\n\n[{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} वगळल्याच्या नोंदीत] अधिक तपशील असण्याची शक्यता आहे.",
- "rev-suppressed-text-permission": "या पानाची आवृत्ती '''दडपली'''.\nआपण ती बघू शकता; [{{fullurl:{{#Special:Log}}/suppress|page={{FULLPAGENAMEE}}}} दडपलेल्यांचा क्रमलेख] येथे त्याची विस्तृत माहिती सापडेल.",
+ "rev-suppressed-text-permission": "या पानाची आवृत्ती <strong>दडपली</strong> आहे.\nआपण ती बघू शकता; [{{fullurl:{{#Special:Log}}/suppress|page={{FULLPAGENAMEE}}}} दडपलेल्यांचा क्रमलेख] येथे त्याची विस्तृत माहिती सापडेल.",
"rev-deleted-text-unhide": "या पानाचे संस्करण '''वगळले'''.\n [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} वगळलेल्या नोंदी] येथे याची माहिती मिळेल.\nजर आपणास पुढे जावयाचे असल्यास, अजूनही [$1 हे संस्करण बघू शकता].",
"rev-suppressed-text-unhide": "या पानाचे संस्करण '''दडपले'''.\n [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} दडपलेले क्रमलेख] येथे याची माहिती मिळेल.\nजर आपणास पुढे जावयाचे असल्यास, अजूनही [$1 हे संस्करण बघू शकता].",
"rev-deleted-text-view": "या पानाची आवृत्ती '''वगळण्यात आली आहे'''.\nती तुम्ही बघू शकता; अधिक तपशील [{{fullurl:{{#Special:Log}}/delete|page={{FULLPAGENAMEE}}}} वगळल्याच्या नोंदी] येथे मिळेल.",
"revdelete-legend": "दृश्य बंधने स्थापित करा",
"revdelete-hide-text": "आवर्तीत मजकूर",
"revdelete-hide-image": "संचिका आशय लपवा",
- "revdelete-hide-name": "à¤\95à¥\83तà¥\80 à¤\86णि लà¤\95à¥\8dषà¥\8dय लपवा",
+ "revdelete-hide-name": "लà¤\95à¥\8dषà¥\8dय व पà¥\8dराà¤\9aल लपवा",
"revdelete-hide-comment": "संपादन तपशील",
"revdelete-hide-user": "संपादकाचे सदस्यनाव/आयपी अंकपत्ता",
"revdelete-hide-restricted": "प्रशासकांद्वारेची माहिती दडपा तसेच ईतरांचीही",
"preferences": "पसंतीक्रम",
"mypreferences": "पसंतीक्रम",
"prefs-edits": "संपादनांची संख्या:",
- "prefsnologintext2": "आपला पसंतीक्रम बदलण्यास $1 करा",
+ "prefsnologintext2": "आपला पसंतीक्रम बदलण्यास सनोंद प्रवेश करा.",
"prefs-skin": "त्वचा",
"skin-preview": "झलक",
"datedefault": "प्राथमिकता नाही",
"prefs-personal": "सदस्य व्यक्तिरेखा",
"prefs-rc": "अलीकडील बदल",
"prefs-watchlist": "निरीक्षणसूची",
+ "prefs-editwatchlist": "पहाऱ्याच्या सूचीचे संपादन करा",
"prefs-watchlist-days": "निरीक्षणसूचीमध्ये दिसणाऱ्या दिवसांची संख्या:",
"prefs-watchlist-days-max": "जास्तीत जास्त $1 {{PLURAL:$1|दिवस|दिवस}}",
"prefs-watchlist-edits": "वाढीव निरीक्षणसूचीमध्ये दिसणाऱ्या संपादनांची संख्या:",
"columns": "स्तंभ:",
"searchresultshead": "शोध",
"stub-threshold": "<a href=\"#\" class=\"stub\">अंकुरीत दुव्यांच्या</a> रचनेची नांदी (बाईट्स):",
+ "stub-threshold-sample-link": "नमुना",
"stub-threshold-disabled": "अक्षम केले",
"recentchangesdays": "अलीकडील बदल मधील दाखवावयाचे दिवस:",
"recentchangesdays-max": "जास्तीतजास्त $1 {{PLURAL:$1|दिवस}}",
"prefs-help-recentchangescount": "यात नुकतेच झालेले बदल, पानांचे इतिहास व नोंदी या गोष्टी असतात.",
"prefs-help-watchlist-token2": "ही आपल्या निरिक्षणसूचीच्या 'वेब फिड'ची गुप्त चाबी आहे.ज्या कोणास त्याची माहिती होईल तो आपली निरिक्षणसूची बघू शकेल,म्हणुन कोणास यात सहभागी करून घेउ नका.[[Special:ResetTokens|पुनर्स्थापनाची आपणास गरज असल्यास येथे टिचकी द्या]].",
"savedprefs": "तुमच्या पसंती जतन केल्या आहेत.",
+ "savedrights": "{{GENDER:$1|$1}}चे सदस्याधिकार जतन केले आहेत.",
"timezonelegend": "वेळक्षेत्र",
"localtime": "स्थानिक वेळ:",
"timezoneuseserverdefault": "सर्व्हर मूलस्थिती वापरा ($1)",
"badsig": "अयोग्य कच्ची सही;HTML खुणपताका तपासा.",
"badsiglength": "तुमची स्वाक्षरी खूप लांब आहे.\nटोपणनाव $1 {{PLURAL:$1|अक्षरापेक्षा|अक्षरांपेक्षा}} कमी लांबीचे हवे.",
"yourgender": "आपणास कश्या प्रकारे वर्णन केल्या गेलेले आवडेल?",
- "gender-unknown": "मà¥\80 à¤\85धिà¤\95 दà¥\87à¤\89 à¤\87à¤\9aà¥\8dà¤\9bित नाहà¥\80",
+ "gender-unknown": "à¤\86पला à¤\89लà¥\8dलà¥\87à¤\96 à¤\95रताà¤\82ना, हà¥\87 सà¤\82à¤\9aà¥\87तन, à¤\9cà¥\87थà¥\87 शà¤\95à¥\8dय à¤\86हà¥\87 तà¥\87थà¥\87, लिà¤\82à¤\97ाबाबत à¤\85à¤\95à¥\8dरिय शबà¥\8dदाà¤\9aा वापर à¤\95रà¥\87ल.",
"gender-male": "तो विकिपाने संपादितो",
"gender-female": "ती विकिपाने संपादिते",
"prefs-help-gender": "या पसंतीक्रमास स्थापणे ऐच्छिक आहे:संचेतन याचा उपयोग आपल्यास लिंगानुसार संबोधित करण्यास करते व आपल्यास दुसऱ्यांना उल्लेखण्यास होतो. ही माहिती सार्वजनिक असेल.",
"email": "विपत्र",
- "prefs-help-realname": "तुमचे खरे नाव (वैकल्पिक): हे नाव दिल्यास आपले योगदान या नावाखाली नोंदले व दाखवले जाईल.",
+ "prefs-help-realname": "तुमचे खरे नाव वैकल्पिक आहे.\nते दिल्यास,त्याचा वापर आपणास आपल्या कामाचे श्रेय देण्यास होऊ शकतो.",
"prefs-help-email": "विपत्रपत्ता वैकल्पिक आहे,परंतु,परवलीचा शब्द आपण विसरल्यास, तो त्याच्या पुनर्स्थापनेसाठी आवश्यक आहे.",
"prefs-help-email-others": "आपण इतरांना आपल्याशी ईमेलद्वारे संपर्क साधण्यास,आपल्या सदस्य किंवा सदस्य चर्चा पानातून दुवा देण्याचे निवडू शकता.जेंव्हा इतर आपल्याशी संपर्क साधतात तेंव्हा, आपला विपत्रपत्ता त्यांना दाखविल्या जात नाही.",
"prefs-help-email-required": "विपत्र(ईमेल)पत्ता हवा.",
"prefs-tokenwatchlist": "ओळखचिन्ह",
"prefs-diffs": "फरक",
"prefs-help-prefershttps": "हा पसंतीक्रम आपल्या पुढील सनोंद प्रवेशानंतर कार्यान्वित होईल.",
+ "prefswarning-warning": "आपण आपल्या पसंतीक्रमात केलेला बदल अद्याप जतन झाला नाही.जर आपण \"$1\" न टिचकता, या पानावरुन दुसरीकडे गेलात तर आपला पसंतीक्रम अद्यतन होणार नाही.",
"email-address-validity-valid": "विपत्रपत्ता वैध दिसत आहे",
"email-address-validity-invalid": "वैध विपत्रपत्ता लिहा",
"userrights": "सदस्य अधिकार व्यवस्थापन",
"userrights-lookup-user": "सदस्य गटांचे(ग्रूप्स) व्यवस्थापन करा.",
"userrights-user-editname": "सदस्य नाव टाका:",
"editusergroup": "सदस्याचे गट संपादित करा",
- "editinguser": "सदस्य '''[[User:$1|$1]]''' $2 चे सदस्य अधिकारात बदल केला जात आहे.",
+ "editinguser": "{{GENDER:$1|सदस्य}}चे सदस्य अधिकारात बदल केला जात आहे <strong>[[User:$1|$1]]</strong> $2",
"userrights-editusergroup": "सदस्याचे गट संपादित करा",
"saveusergroups": "सदस्य गट जतन करा",
"userrights-groupsmember": "(चा) सभासद:",
"right-deletedtext": "वगळलेला मजकूर व वगळलेल्या आवृत्त्यांमधील बदल पहा",
"right-browsearchive": "वगळलेली पाने शोधा",
"right-undelete": "एखादे पान पुनर्स्थापित करा",
- "right-suppressrevision": "पà¥\8dरà¤\9aालà¤\95ाà¤\82पासà¥\82न लपविलà¥\87लà¥\8dया à¤\86वà¥\83तà¥\8dतà¥\8dया पà¥\81नरावलà¥\8bà¤\95ित व पà¥\81नरà¥\8dसà¥\8dथापित करा",
+ "right-suppressrevision": "à¤\95à¥\8bणतà¥\8dयाहà¥\80 सदसà¥\8dयास विशिषà¥\8dà¤\9f à¤\86वà¥\83तà¥\8dतà¥\8dया दरà¥\8dशवा,लपवा à¤\95िà¤\82वा पà¥\8dरà¤\97à¤\9f करा",
"right-suppressionlog": "खासगी नोंदी पहा",
"right-block": "इतर सदस्यांना संपादन करण्यापासून प्रतिबंधित करा",
"right-blockemail": "एखाद्या सदस्याला इ-मेल पाठविण्यास प्रतिबंधित करा",
"action-createpage": "लेख बनवा",
"action-createtalk": "चर्चा पृष्ठे तयार करा",
"action-createaccount": "हे सदस्यखाते तयार करा",
+ "action-history": "या पानाचा इतिहास बघा.",
"action-minoredit": "हे संपादन 'किरकोळ' म्हणून खूण करा",
"action-move": "हे पान स्थानांतरित करा",
"action-move-subpages": "हे पान व त्याची उपपाने हलवा",
"action-move-rootuserpages": "मूळ सदस्यपाने हलवा",
+ "action-move-categorypages": "वर्ग पाने स्थानांतरील करा",
"action-movefile": "ही संचिका हलवा",
"action-upload": "या संचिकेचे अपभारण करा",
"action-reupload": "अस्तित्वात असलेल्या संचिकेवर पुनर्लेखन करा",
"recentchanges-legend-heading": "'''विवरण:'''",
"recentchanges-legend-newpage": "{{int:recentchanges-label-newpage}} ([[Special:NewPages|नविन पानांची यादी]] हेही पाहा)",
"recentchanges-legend-plusminus": "(''±१२३'')",
- "rcnotefrom": "खाली <b>$2</b> पासूनचे ('''$1''' पर्यंत) बदल दाखविले आहेत.",
- "rclistfrom": "$3 $2 नंतर केले गेलेले बदल दाखवा.",
+ "rcnotefrom": "खाली {{PLURAL:$5|हा बदल आहे|हे बदल आहेत}} <strong>$3, $4</strong>पासून ते(<strong>$1</strong>पर्यंतचे बदल दाखविले आहेत).",
+ "rclistfrom": "$2,$3 नंतर केले गेलेले बदल दाखवा.",
"rcshowhideminor": "छोटे बदल $1",
"rcshowhideminor-show": "दाखवा",
"rcshowhideminor-hide": "लपवा",
"rcshowhidemine": "माझे बदल $1",
"rcshowhidemine-show": "दाखवा",
"rcshowhidemine-hide": "लपवा",
+ "rcshowhidecategorization-show": "दाखवा",
+ "rcshowhidecategorization-hide": "लपवा",
"rclinks": "मागील $2 दिवसांतील $1 बदल पहा.<br />$3",
"diff": "फरक",
"hist": "इति",
"newpageletter": "न",
"boteditletter": "सां",
"number_of_watching_users_pageview": "[$1 {{PLURAL:$1|सदस्याने|सदस्यांनी}} पहारा दिलेला आहे]",
- "rc_categories": "वर्गांपुरते मर्यादित ठेवा (\"|\"ने वेगळे करा)",
- "rc_categories_any": "कोणतेही",
+ "rc_categories": "वर्गांपुरते मर्यादित ठेवा (\"|\"ने वेगळे करा):",
+ "rc_categories_any": "निवडलà¥\8dयापà¥\88à¤\95à¥\80 à¤\95à¥\8bणतà¥\87हà¥\80",
"rc-change-size-new": " बदलानंतर $1 {{PLURAL:$1|बाईट|बाईटस्}}",
"newsectionsummary": "/* $1 */ नवीन विभाग",
"rc-enhanced-expand": "तपशील दाखवा",
"uploaderror": "अपभारणात चूक",
"upload-recreate-warning": "'''सावधान: या नावाची संचीका वगळली अथवा स्थलांतरित करण्यात आली आहे.'''\nया पानाची वगळल्याची व स्थलांतरणाची नोंद तुमच्या सोयीसाठी येथे पुरवली आहे.:",
"uploadtext": "खालील अर्ज नवीन संचिका चढविण्यासाठी वापरा.\nपूर्वी चढविलेल्या संचिका पाहण्यासाठी अथवा शोधण्यासाठी [[Special:FileList|चढविलेल्या संचिकांची यादी]] पहा. चढविलेल्या तसेच वगळलेल्या संचिकांची यादी पहाण्यासाठी [[Special:Log/upload|चढवलेल्या संचिकांची सूची]] व [[Special:Log/delete|वगळलेल्या संचिकांची सूची]] पहा.\n\nएखाद्या लेखात ही संचिका वापरण्यासाठी खालीलप्रमाणे दुवा द्या\n'''<nowiki>[[</nowiki>{{ns:file}}<nowiki>:File.jpg]]</nowiki>''',\n'''<nowiki>[[</nowiki>{{ns:file}}<nowiki>:File.png|alt text]]</nowiki>''' किंवा\n'''<nowiki>[[</nowiki>{{ns:media}}<nowiki>:File.ogg]]</nowiki>''' संचिकेला थेट दुवा देण्यासाठी वापरा.",
- "upload-permitted": "अनुमतीत संचिका वर्ग: $1.",
- "upload-preferred": "शà¥\8dरà¥\87यसà¥\8dà¤\95र सà¤\82à¤\9aिà¤\95ा पà¥\8dरà¤\95ार:$1.",
- "upload-prohibited": "प्रतिबंधीत संचिका प्रकार: $1.",
+ "upload-permitted": "अनुमतीत संचिका{{PLURAL:$2|प्रकार}}: $1.",
+ "upload-preferred": "पसà¤\82तà¥\80तला सà¤\82à¤\9aिà¤\95ा {{PLURAL:$2|पà¥\8dरà¤\95ार}}:$1.",
+ "upload-prohibited": "प्रतिबंधीत संचिका {{PLURAL:$2|प्रकार}}:$1.",
"uploadlogpage": "अपभारणाच्या नोंदी",
"uploadlogpagetext": "नवीनतम चढवलेल्या संचिकांची यादीखाली दिलेली आहे.जास्त बघण्यासाठी [[Special:NewFiles|नविन संचिकांची दिर्घिका]] बघा.",
"filename": "संचिकेचे नाव",
"largefileserver": "सेवा संगणकावर (सर्व्हर) निर्धारित केलेल्या आकारापेक्षा या संचिकेचा आकार मोठा आहे.",
"emptyfile": "चढवलेली संचिका रिकामी आहे.असे संचिकानाम चुकीचे लिहिल्याने होउ शकते. कृपया तुम्हाला हीच संचिका चढवायची आहे का ते तपासा.",
"windows-nonascii-filename": "या विकिवर विशेष वर्ण असलेल्या संचिकानामाचा आधार घेता येणार नाही.",
- "fileexists": "या नावाà¤\9aà¥\80 सà¤\82à¤\9aिà¤\95ा à¤\86धà¥\80à¤\9a à¤\85सà¥\8dतितà¥\8dवात à¤\86हà¥\87, à¤\95à¥\83पया हà¥\80 सà¤\82à¤\9aिà¤\95ा बदलणà¥\8dयाबदà¥\8dदल तà¥\81मà¥\8dहà¥\80 साशà¤\82à¤\95 à¤\85साल तर <strong>[[:$1]]</strong> तपासा.\n[[$1|thumb]]",
+ "fileexists": "या नावाà¤\9aà¥\80 सà¤\82à¤\9aिà¤\95ा à¤\86धà¥\80à¤\9a à¤\85सà¥\8dतितà¥\8dवात à¤\86हà¥\87, à¤\9cर हà¥\80 सà¤\82à¤\9aिà¤\95ा बदलणà¥\8dयाबदà¥\8dदल तà¥\81मà¥\8dहà¥\80 साशà¤\82à¤\95 à¤\85साल तर, à¤\95à¥\83पया <strong>[[:$1]]</strong>तपासा.\n[[$1|thumb]]",
"filepageexists": "या नावाचे एक माहितीपृष्ठ (संचिका नव्हे) अगोदरच अस्तित्त्वात आहे. कृपया जर आपणांस त्यात बदल करायचा नसेल तर <strong>[[:$1]]</strong> तपासा.\n[[$1|thumb]]",
- "fileexists-extension": "या नावाà¤\9aà¥\80 सà¤\82à¤\9aिà¤\95ा à¤\85सà¥\8dतितà¥\8dवात à¤\86हà¥\87: [[$2|thumb]]\n* à¤\9aढवà¥\80त à¤\85सलà¥\87लà¥\8dया सà¤\82à¤\9aिà¤\95à¥\87à¤\9aà¥\87 नाव: <strong>[[:$1]]</strong>\n* à¤\85सà¥\8dतितà¥\8dवात à¤\85सलà¥\87लà¥\8dया सà¤\82à¤\9aिà¤\95à¥\87à¤\9aà¥\87 नाव: <strong>[[:$2]]</strong>\nà¤\95à¥\83पया दà¥\81सरà¥\87 नाव निवडा.",
+ "fileexists-extension": "या सारà¤\96à¥\8dया नावाà¤\9aà¥\80 सà¤\82à¤\9aिà¤\95ा à¤\85सà¥\8dतितà¥\8dवात à¤\86हà¥\87: [[$2|thumb]]\n* à¤\9aढवà¥\80त à¤\85सलà¥\87लà¥\8dया सà¤\82à¤\9aिà¤\95à¥\87à¤\9aà¥\87 नाव: <strong>[[:$1]]</strong>\n* सधà¥\8dया à¤\85सà¥\8dतितà¥\8dवात à¤\85सलà¥\87लà¥\8dया सà¤\82à¤\9aिà¤\95à¥\87à¤\9aà¥\87 नाव: <strong>[[:$2]]</strong>\nà¤\86पणास à¤\85धिà¤\95 वà¥\88शिषà¥\8dà¤\9fà¥\8dयपà¥\82रà¥\8dण नाव निवडायà¤\9aà¥\87 à¤\86हà¥\87 à¤\95ाय?",
"fileexists-thumbnail-yes": "आपण चढवीत असलेली संचिका ही मोठ्या चित्राची इवलीशी प्रतिकृती ''(thumbnail)'' असण्याची शक्यता आहे. [[$1|इवलेसे]]\nकृपया <strong>[[:$1]]</strong> ही संचिका तपासा.\nजर तपासलेली संचिका ही याच आकाराची असेल तर नवीन प्रतिकृती चढविण्याची गरज नाही.",
"file-thumbnail-no": "या संचिकेचे नाव <strong>$1</strong> पासून सुरू होत आहे. ही कदाचित झलक असू शकते.\nजर तुमच्याकडे पूर्ण रिझोल्यूशनची संचिका असेल तर चढवा अथवा संचिकेचे नाव बदला.",
"fileexists-forbidden": "या नावाची संचिका अगोदरच अस्तित्त्वात आहे; कृपया पुन्हा परत जाऊन ही संचिका नवीन नावाने चढवा.\n[[File:$1|thumb|center|$1]]",
"filename-bad-prefix": "तुम्ही चढवत असलेल्या संचिकेचे नाव '''\"$1\"''' पासून सुरू होते, जे की अंकीय छाउ (कॅमेरा) ने दिलेले अवर्णनात्मक नाव आहे.कृपया तुमच्या संचिकेकरिता अधिक वर्णनात्मक नाव निवडा.",
"upload-success-subj": "यशस्वीरीत्या अपभारित केले",
"upload-success-msg": "तुमचे [$2] येथून अपभारण यशस्वी ठरले. ते येथे उपलब्ध आहे: [[:{{ns:file}}:$1]]",
- "upload-failure-subj": "à¤\9aढवणà¥\8dयातà¥\80ल तà¥\8dरà¥\82à¤\9fि:",
- "upload-failure-msg": "[$2] यà¥\87थà¥\82न तà¥\81मà¤\9aà¥\8dया à¤\9aढवणà¥\8dयात à¤\9aà¥\82à¤\95 झाली:\n\n$1",
- "upload-warning-subj": "à¤\9aढवताना सà¥\82à¤\9aना",
- "upload-warning-msg": "तà¥\81मà¤\9aà¥\8dया à¤\9aढवणà¥\8dयात [$2] यà¥\87थà¥\82न à¤\9aà¥\82à¤\95 झाली. तुम्ही [[Special:Upload/stash/$1|चढवण्याचा अर्ज]] पुन्हा भरून ही चूक दूर करू शकता.",
- "upload-proto-error": "à¤\9aà¥\82à¤\95à¥\80à¤\9aा सà¤\82à¤\95à¥\87त",
- "upload-proto-error-text": "दà¥\82रसà¥\8dथ à¤\9aढवणà¥\8dयाच्या क्रियेत <code>http://</code>पासून किंवा <code>ftp://</code>पासून सुरू होणारी URL लागतात.",
+ "upload-failure-subj": "à¤\85पà¤à¤¾à¤°à¤£à¤¾à¤¤à¥\80ल तà¥\8dरà¥\82à¤\9fि",
+ "upload-failure-msg": "[$2] यà¥\87थà¥\82न तà¥\81मà¤\9aà¥\8dया à¤\85पà¤à¤¾à¤°à¤£à¤¾à¤¤ à¤\85डà¤\9aण निरà¥\8dमाण झाली:\n\n$1",
+ "upload-warning-subj": "à¤\85पà¤à¤¾à¤°à¤£ ताà¤\95िद",
+ "upload-warning-msg": "तà¥\81मà¤\9aà¥\8dया à¤\85पà¤à¤¾à¤°à¤£à¤¾à¤¤ [$2] यà¥\87थà¥\82न à¤\85डà¤\9aण निरà¥\8dमाण झाली. तुम्ही [[Special:Upload/stash/$1|चढवण्याचा अर्ज]] पुन्हा भरून ही चूक दूर करू शकता.",
+ "upload-proto-error": "à¤\9aà¥\82à¤\95à¥\80à¤\9aा शिषà¥\8dà¤\9fाà¤\9aार",
+ "upload-proto-error-text": "दà¥\82रसà¥\8dथ à¤\85पà¤à¤¾à¤°à¤£ाच्या क्रियेत <code>http://</code>पासून किंवा <code>ftp://</code>पासून सुरू होणारी URL लागतात.",
"upload-file-error": "अंतर्गत त्रूटी",
- "upload-file-error-text": "विदादातà¥\8dयावर तातà¥\8dपà¥\81रतà¥\80 सà¤\82à¤\9aिà¤\95ा तयार à¤\95रणà¥\8dयाà¤\9aà¥\8dया पà¥\8dरयतà¥\8dन à¤\95रत à¤\85सताना à¤\85à¤\82तरà¥\8dà¤\97त ताà¤\82तà¥\8dरिà¤\95 à¤\85डà¤\9aण à¤\86ली.कृपया [[Special:ListUsers/sysop|प्रचालकांशी]] संपर्क करा.",
- "upload-misc-error": "सà¤\82à¤\9aिà¤\95ा à¤\9aढविताना माहà¥\80त नसलà¥\87लà¥\80 तà¥\8dरà¥\81à¤\9fà¥\80 à¤\86लà¥\87लà¥\80 à¤\86हà¥\87.",
- "upload-misc-error-text": "à¤\9aढवताना à¤\85à¤\9cà¥\8dà¤\9eात ताà¤\82तà¥\8dरिà¤\95 à¤\85डà¤\9aण à¤\86लà¥\80.à¤\95à¥\83पया à¤\86à¤\82तरà¤\9cालपतà¥\8dता सà¥\81यà¥\8bà¤\97à¥\8dय à¤\86णि à¤\89पलबà¥\8dध à¤\86हà¥\87 à¤\95ा तà¥\87 तपासा à¤\86णि पà¥\81नà¥\8dहा पà¥\8dरयतà¥\8dन à¤\95रा. à¤\85धिà¤\95 à¤\85डà¤\9aणà¥\80 à¤\86लà¥\8dयास तर [[Special:ListUsers/sysop|प्रचालकांशी]] संपर्क करा.",
+ "upload-file-error-text": "विदादातà¥\8dयावर तातà¥\8dपà¥\81रतà¥\80 सà¤\82à¤\9aिà¤\95ा तयार à¤\95रणà¥\8dयाà¤\9aà¥\8dया पà¥\8dरयतà¥\8dन à¤\95रत à¤\85सताना à¤\85à¤\82तरà¥\8dà¤\97त तà¥\8dरà¥\82à¤\9fà¥\80 à¤\98डली.कृपया [[Special:ListUsers/sysop|प्रचालकांशी]] संपर्क करा.",
+ "upload-misc-error": "à¤\85नà¥\8bळà¤\96à¥\80 à¤\85पà¤à¤¾à¤°à¤£ तà¥\8dरà¥\82à¤\9fà¥\80.",
+ "upload-misc-error-text": "à¤\85पà¤à¤¾à¤°à¤£à¤¾à¤¤ à¤\85नà¥\8bळà¤\96à¥\80 तà¥\8dरà¥\82à¤\9fà¥\80 à¤\98डलà¥\80.à¤\95à¥\83पया यà¥\82à¤\86रà¤\8fल वà¥\88ध à¤\86णि पà¥\8bहà¥\8bà¤\9aयà¥\8bà¤\97à¥\8dय à¤\86हà¥\87 à¤\95ा तà¥\87 तपासा à¤\86णि पà¥\81नà¥\8dहा पà¥\8dरयतà¥\8dन à¤\95रा. à¤\85डà¤\9aण तशà¥\80à¤\9a à¤\9fिà¤\95à¥\81न राहिलà¥\8dयास, [[Special:ListUsers/sysop|प्रचालकांशी]] संपर्क करा.",
"upload-too-many-redirects": "या आंतरजालपत्त्यात खूप पुनर्निर्देशने आहेत",
"upload-http-error": "एक एचटीटीपी चूक उद्भवली: $1",
- "upload-copy-upload-invalid-domain": "सà¤\82à¤\95à¥\8dरमित à¤\95à¥\87लà¥\87लà¥\80 महितà¥\80 à¤\85धिà¤\95à¥\8dषà¥\87तà¥\8dरात à¤\89पलबà¥\8dध नाहà¥\80.",
+ "upload-copy-upload-invalid-domain": "या डà¥\8bमà¥\87नमधà¥\8dयà¥\87 पà¥\8dरत-à¤\85पà¤à¤¾à¤°à¤£à¥\87 à¤\85नà¥\81पलबà¥\8dध à¤\86हà¥\87त.",
"upload-dialog-title": "संचिकेचे अपभारण करा",
"upload-dialog-button-cancel": "रद्द करा",
"upload-dialog-button-done": "झाले",
"backend-fail-hashes": "तुलना करण्यासाठी फाइल हॅशेस मिळाले नाही",
"backend-fail-notsame": " $1 येथे यापेक्षा विभिन्न असलेली संचिका पूर्वीच विद्यमान आहे",
"backend-fail-invalidpath": "$1 हा वैध संग्राहक-पथ नाही.",
- "backend-fail-delete": "$1 ही संचिका (फाईल) बनवता आली नाही.",
- "backend-fail-describe": "\"$1\" या सà¤\82à¤\9aिà¤\95à¥\87साठà¥\80 à¤\86पण मेटाडाटा बदलू शकत नाही.",
+ "backend-fail-delete": "\"$1\" ही संचिका (फाईल) वगळता आली नाही.",
+ "backend-fail-describe": "\"$1\" या सà¤\82à¤\9aिà¤\95à¥\87साठà¥\80 à¤\85सलà¥\87ला मेटाडाटा बदलू शकत नाही.",
"backend-fail-alreadyexists": "$1 ही संचिका अगोदरच अस्तित्वात आहे.",
- "backend-fail-store": "$1 ही संचिका $2मधे साठवू शकत नाही.",
- "backend-fail-copy": "\"$1\" सà¤\82à¤\9aिà¤\95à¥\87à¤\9aà¥\80 \"$2\" हà¥\80 पà¥\8dरत à¤\95रता à¤\86लà¥\80 नाही.",
- "backend-fail-move": "संचिका $1 पासून $2मधे हलवता आली नाही.",
+ "backend-fail-store": "\"$1\" ही संचिका \"$2\"मध्ये साठवू शकत नाही.",
+ "backend-fail-copy": "\"$1\" सà¤\82à¤\9aिà¤\95à¥\87स \"$2\" मधà¥\8dयà¥\87 नà¤\95लता à¤\86लà¥\87 नाही.",
+ "backend-fail-move": "संचिका \"$1\"ला \"$2\"मधे स्थानांतरीत करता आले नाही.",
"backend-fail-opentemp": "तात्पुरती संचिका उघडणे जमले नाही.",
"backend-fail-writetemp": "तात्पुरत्या संचिकेत लिहिणे जमले नाही.",
"backend-fail-closetemp": "तात्पुरती संचिका बंद करणे जमले नाही.",
- "backend-fail-read": "$1 ही संचिका वाचता आली नाही.",
- "backend-fail-create": "$1 ही संचिका लिहिता आली नाही.",
+ "backend-fail-read": "\"$1\"ही संचिका वाचता आली नाही.",
+ "backend-fail-create": "\"$1\"ही संचिका लिहिता आली नाही.",
"backend-fail-maxsize": "$1 ही संचिका लिहिता आली नाही कारण ती {{PLURAL:$2|एक बाइट|$2 बाइट्स}} पेक्षा मोठी आहे.",
"backend-fail-readonly": "पार्श्वभौमीक साठवण \"$1\" “फक्त वाचा” अशी आहे. दिलेले कारण आहे: \"<em>$2</em>\"",
"backend-fail-synced": "अंतर्गत पार्श्वभौमीक साठवणीतील फाईल \"$1\" विसंगत आहे.",
"backend-fail-connect": "पार्श्वभौमीक साठा \"$1\"शी संबंध जोडू शकत नाही.",
"backend-fail-internal": "पार्श्वभौमीक साठा \"$1\" यात अज्ञात चूक झाली आहे.",
- "backend-fail-contenttype": "\"$1\" मधà¥\8dयà¥\87 ठà¥\87वलà¥\87लà¥\8dया फाà¤\88लà¤\9aा महितà¥\80à¤\9aा पà¥\8dरà¤\95ार à¤\95ळत नाहà¥\80",
+ "backend-fail-contenttype": "\"$1\" मधà¥\8dयà¥\87 साठविणà¥\8dयात यà¥\87णाऱà¥\8dया सà¤\82à¤\9aिà¤\95à¥\87à¤\9aा à¤\86शय-पà¥\8dरà¤\95ार(à¤\95à¤\82à¤\9fà¥\87à¤\82à¤\9f à¤\9fाà¤\88प) नà¤\95à¥\8dà¤\95à¥\80 à¤\95रता à¤\86ला नाहà¥\80.",
"backend-fail-batchsize": "पार्श्वभौमीक साठयातील बॅच $1 फाईल{{PLURAL:$1|क्रियेत|क्रियांमध्ये}}; मर्यादित कस्त $२ {{PLURAL:$2|क्रिया}} असू शकते",
"backend-fail-usable": "अपुऱ्या परवानगीमुळे किंवा निर्देशिकेच्या/धारिकेच्या(डिरेक्टरीज/कंटेनर्स) अभावामुळे \"$1\" संचिका वाचु अथवा लिहू शकत नाही.",
"filejournal-fail-dbconnect": "\"$1\" स्टोरेज बॅकएंडकरिता, माहिती-भांडाराच्या ज्ञानपत्रिकेशी जुळता आले नाही.",
"lockmanager-fail-deletelock": "\"$1\" साठी लॉक फाइल वगळू शकत नाही",
"lockmanager-fail-acquirelock": "\"$1\" साठी लॉक फाइल मिळवू शकत नाही",
"lockmanager-fail-openlock": "\"$1\" साठी लॉक फाइल उघडू शकत नाही",
- "lockmanager-fail-releaselock": "\"$1\" साठà¥\80 लà¥\89à¤\95 à¤\89à¤\98डà¥\82 शà¤\95त नाहà¥\80",
+ "lockmanager-fail-releaselock": "\"$1\" साठà¥\80 ताळा à¤\89à¤\98डà¥\82 शà¤\95त नाहà¥\80.",
"lockmanager-fail-db-bucket": "$1 बकेट मधील कुलूप बंद डेटाबेसशी पुरेसा संपर्क होवू शकत नाही.",
- "lockmanager-fail-db-release": "\"$1\" डाà¤\9fाबà¥\87स वरà¥\80ल लà¥\89à¤\95 उघडू शकत नाही",
+ "lockmanager-fail-db-release": "\"$1\" डाà¤\9fाबà¥\87स वरà¥\80ल ताळा उघडू शकत नाही",
"lockmanager-fail-svr-acquire": "सर्व्हर \"$1\" वरील कुलूप उघडू शकत नाही",
"lockmanager-fail-svr-release": "सर्व्हर \"$1\" वरील् लॉक उघडू शकत नाही",
- "zip-file-open-error": "सà¤\82à¤\9aà¥\80à¤\95ा ZIP तपासणà¥\80साठà¥\80 à¤\89à¤\98डताना तà¥\8dरà¥\81à¤\9fà¥\80 à¤\86ली.",
- "zip-wrong-format": "हà¥\80 सà¤\82à¤\9aिà¤\95ा \"à¤\9dिप\" पà¥\8dरà¤\95ारà¤\9aà¥\80 नाही.",
+ "zip-file-open-error": "सà¤\82à¤\9aिà¤\95ा ZIP तपासणà¥\80साठà¥\80 à¤\89à¤\98डताना तà¥\8dरà¥\81à¤\9fà¥\80 à¤\89दà¥\8dà¤à¤µली.",
+ "zip-wrong-format": "नमà¥\82द à¤\95à¥\87लà¥\87लà¥\80 सà¤\82à¤\9aिà¤\95ा हà¥\80 à¤\9dिप(ZIP)सà¤\82à¤\9aिà¤\95ा नाही.",
"zip-bad": "ही संचिका दूषित किंवा न वाचता येणारी झिप संचिका आहे.\nती सुरक्षिततेसाठी नीट तपासता आली नाही.",
"zip-unsupported": "ही संचिका एक ZIP संचिका आहे जी मिडीयाविकी द्वारे (support) न केलेले ZIP वैशिष्ट्ये (features) वापरते.\nया संचिकेची सुरक्षा पडताळणी व्यवस्थितरीत्या होऊ शकत नाही.",
"uploadstash": "चढवणे लपवा",
"uploadstash-badtoken": "ही कृती अयशस्वी होती. कदाचित आपल्या संपादन अधिकारपत्राची (editing credentials) मुदत संपली.",
"uploadstash-errclear": "संचिका स्वच्छ करणे अयशस्वी.",
"uploadstash-refresh": "संचिकांची यादी ताजीतवानी करा",
- "invalid-chunk-offset": "à¤\85à¤\97à¥\8dराहà¥\8dय चंक ऑफसेट",
+ "invalid-chunk-offset": "à¤\85वà¥\88ध चंक ऑफसेट",
"img-auth-accessdenied": "पोहोच नाकारल्या गेली.",
- "img-auth-nopathinfo": "मारà¥\8dà¤\97 माहितà¥\80 à¤\86ढळलà¥\80 नाहà¥\80.\nà¤\86पला सरà¥\8dवà¥\8dहर हà¥\80 माहितà¥\80 पà¥\8bà¤\9aवà¥\82 शà¤\95त नाहà¥\80.\nतà¥\8b सà¥\80à¤\9cà¥\80à¤\86य-à¤\86धारित व à¤\87मà¥\87à¤\9c_à¤\91थला समरà¥\8dथन न दà¥\87à¤\8a शà¤\95णारा à¤\85सà¥\82 शà¤\95तà¥\8b.\nhttps://www.mediawiki.org/wiki/Special:MyLanguage/Manual:Image_Authorization à¤\95à¥\83पया हे पहा.",
- "img-auth-notindir": "माà¤\97ितलà¥\87ला मारà¥\8dà¤\97 à¤\85पलà¥\8bड निरà¥\8dदà¥\87शिà¤\95à¥\87à¤\95रà¥\80ता à¤\9cà¥\8bडलà¥\87ला नाही.",
+ "img-auth-nopathinfo": "मारà¥\8dà¤\97 माहितà¥\80 à¤\86ढळलà¥\80 नाहà¥\80.\nà¤\86पला सरà¥\8dवà¥\8dहर हà¥\80 माहितà¥\80 दà¥\87णà¥\8dयास à¤\85नà¥\81नत नाहà¥\80.\nतà¥\8b सà¥\80à¤\9cà¥\80à¤\86य-à¤\86धारित व à¤\87मà¥\87à¤\9c_à¤\91थला समरà¥\8dथन न दà¥\87à¤\8a शà¤\95णारा à¤\85सà¥\82 शà¤\95तà¥\8b.\nà¤\95à¥\83पया https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:Image_Authorization हे पहा.",
+ "img-auth-notindir": "विनà¤\82तà¥\80 à¤\95à¥\87लà¥\87ला मारà¥\8dà¤\97 à¤\85पà¤à¤¾à¤°à¤£ शबà¥\8dदà¤\95à¥\8bशाà¤\95रà¥\80ता रà¤\9aित नाही.",
"img-auth-badtitle": "\"$1\" पासून वैध शीर्षक बनवण्यात अयशस्वी.",
"img-auth-nologinnWL": "तुम्ही प्रवेश घेतलेला नाही व \"$1\" श्वेतयादीत नाही.",
"img-auth-nofile": "\"$1\" ही संचिका अस्तित्वात नाही.",
- "img-auth-isdir": "तुम्ही $1 निदेशक वापरण्याचा प्रयत्न करत आहात.\nफक्त संचिका वापरण्याची परवानगी आहे.",
+ "img-auth-isdir": "तुम्ही \"$1\" निदेशक वापरण्याचा प्रयत्न करत आहात.\nफक्त संचिका वापरण्याची परवानगी आहे.",
"img-auth-streaming": "स्ट्रीमिंग \"$1\".",
"img-auth-public": "img_auth.php हे वैयक्तिक विकीमधून माहिती प्रदान करण्याचे कार्य करते.\nहा विकि सार्वजनिक विकि म्हणून सब्चित करण्यात आला आहे.\nकिमान सुरक्षेसाठी img_auth.php ला अक्षम केले आहे.",
"img-auth-noread": "तुम्हाला \"$1\" वाचण्याची परवानगी नाही",
"http-bad-status": "एचटीटीपी मागणीदरम्यान एक चूक उद्भवली: $1 $2",
"upload-curl-error6": "आंतरजाल पत्त्यापाशी पोहोचले नाही",
"upload-curl-error6-text": "दिलेल्या URL ला पोहचू शकलो नाही.कृपया URL बरोबर असून संकेतस्थळ चालू असल्याची पुनश्च खात्री करा.",
- "upload-curl-error28": "à¤\9aढवणà¥\8dयात वà¥\87ळà¤\97à¥\87लà¥\80",
- "upload-curl-error28-text": "संकेतस्थळाने साद देण्यात खूप जास्त वेळ घेतला आहे,कृपया थोडा वेळ थांबा आणि पुन्हा प्रयत्न करा.कदाचित तुम्ही कमी गर्दीच्या वेळात प्रयत्न करू इच्छीताल.",
+ "upload-curl-error28": "à¤\85पà¤à¤¾à¤°à¤£ à¤\95ालबाहà¥\8dय à¤\9dालà¥\87",
+ "upload-curl-error28-text": "संकेतस्थळाने साद देण्यात खूप जास्त वेळ घेतला आहे.\nकृपया हे तपासा कि ते संकेतस्थळ सुरु आहे.थोडा वेळ थांबा आणि पुन्हा प्रयत्न करा.\nकदाचित तुम्ही कमी गर्दीच्या वेळात प्रयत्न करू इच्छीत असाल.",
"license": "परवाना:",
"license-header": "परवाना:",
"nolicense": "काही निवडलेले नाही",
"upload_source_file": "(तुमच्या संगणकावरील एक संचिका निवडली आहे)",
"listfiles-delete": "वगळा",
"listfiles-summary": "हे विशेष पान सर्व अपभारिलेल्या संचिका दर्शिविते.",
- "listfiles_search_for": "à¤\9aितà¥\8dर नावानà¥\87 शà¥\8bध:",
+ "listfiles_search_for": "माधà¥\8dयमाà¤\9aà¥\87 नाव शà¥\8bधा:",
"listfiles-userdoesnotexist": "सदस्यखाते \"$1\" हे नोंदलेले नाही.",
"imgfile": "संचिका",
- "listfiles": "à¤\9aितà¥\8dर यादी",
+ "listfiles": "सà¤\82à¤\9aिà¤\95ा यादी",
"listfiles_thumb": "नखुले",
"listfiles_date": "दिनांक",
"listfiles_name": "नाव",
"filehist-comment": "प्रतिक्रीया",
"imagelinks": "संचिका वापर",
"linkstoimage": "खालील {{PLURAL:$1|पान चित्राशी जोडले आहे|$1 पाने चित्राशी जोडली आहेत}}:",
- "linkstoimage-more": "या सà¤\82à¤\9aिà¤\95à¥\87 ला $1 {{PLURAL:$1|पान à¤\9cà¥\8bडलà¥\87|पानà¥\87 à¤\9cà¥\8bडलà¥\80}} à¤\86हà¥\87त.\nया सà¤\82à¤\9aिà¤\95à¥\87 ला à¤\9cà¥\8bडलà¥\87लà¥\8dया {{PLURAL:$1|पहिलà¥\8dया पानà¤\9aा दà¥\81वा à¤\96ालà¥\80 दिला à¤\86हà¥\87|पहिलà¥\8dया $1 पानाà¤\82à¤\9aà¥\87 दà¥\81वà¥\87 à¤\96ालà¥\80 दिलà¥\87 à¤\86हà¥\87त}}.\n[[Special:WhatLinksHere/$2|संपुर्ण यादी]] उपलब्ध आहे.",
+ "linkstoimage-more": "या सà¤\82à¤\9aिà¤\95à¥\87 ला $1 {{PLURAL:$1|पान à¤\9cà¥\8bडलà¥\87|पानà¥\87 à¤\9cà¥\8bडलà¥\80}} à¤\86हà¥\87त.\nà¤\96ालà¥\80ल यादà¥\80 या सà¤\82à¤\9aिà¤\95à¥\87 ला à¤\9cà¥\8bडलà¥\87लà¥\8dया {{PLURAL:$1|पहिलà¥\8dया पानाà¤\9aा दà¥\81वा |पहिलà¥\8dया $1 पानाà¤\82à¤\9aà¥\87 दà¥\81वà¥\87 }}दरà¥\8dशवितà¥\87.\n[[Special:WhatLinksHere/$2|संपुर्ण यादी]] उपलब्ध आहे.",
"nolinkstoimage": "या चित्राशी जोडलेली पृष्ठे नाही आहेत.",
"morelinkstoimage": "या संचिकेचे [[Special:WhatLinksHere/$1|अधिक दुवे]] पहा.",
"linkstoimage-redirect": "$1 (संचिका पुनर्निर्देशन) $2",
"duplicatesoffile": "खालील संचिका या दिलेल्या {{PLURAL:$1|संचिकेची प्रत आहे|$1 संचिकांच्या प्रती आहेत}}. [[Special:FileDuplicateSearch/$2|अधिक माहिती]]",
- "sharedupload": "हà¥\80 सà¤\82à¤\9aिà¤\95ा $1 मधà¥\80ल à¤\86हà¥\87 व तà¥\80 à¤\87तर पà¥\8dरà¤\95लà¥\8dपाà¤\82मधà¥\8dयà¥\87 वापरलà¥\80 à¤\97à¥\87लà¥\8dयाà¤\9aà¥\80 शà¤\95à¥\8dयता à¤\86हे.",
- "sharedupload-desc-there": "हà¥\80 सà¤\82à¤\9aिà¤\95ा $1 मधà¥\80ल à¤\86हà¥\87 व तà¥\80 à¤\87तर पà¥\8dरà¤\95लà¥\8dपाà¤\82मधà¥\8dयà¥\87 वापरलà¥\80 जाऊ शकते.\nअधिक माहिती साठी कृपया [$2 संचिका वर्णन पान] पहावे.",
+ "sharedupload": "हà¥\80 सà¤\82à¤\9aिà¤\95ा $1 मधà¥\80ल à¤\86हà¥\87 व तà¥\80 à¤\87तर पà¥\8dरà¤\95लà¥\8dपाà¤\82दà¥\8dवारà¥\87 वापरलà¥\8dया à¤\9cाà¤\8a शà¤\95ते.",
+ "sharedupload-desc-there": "हà¥\80 सà¤\82à¤\9aिà¤\95ा $1 मधà¥\80ल à¤\86हà¥\87 व तà¥\80 à¤\87तर पà¥\8dरà¤\95लà¥\8dपाà¤\82दà¥\8dवारà¥\87 वापरलà¥\8dया जाऊ शकते.\nअधिक माहिती साठी कृपया [$2 संचिका वर्णन पान] पहावे.",
"sharedupload-desc-here": "ही संचिका $1 येथील असून ती इतर प्रकल्पात वापरलेली असू शकते.\nतिचे तेथील [$2 संचिका वर्णन पान] खाली दाखवले आहे.",
"sharedupload-desc-edit": "संचिका $1 मधील आहे व ती इतर प्रकल्पांमध्ये वापरली जाऊ शकते.आपणास हवे असल्यास,या पानाच्या[$2 'संचिका वर्णन पान'] येथे,त्याची माहिती संपादु शकता.",
"sharedupload-desc-create": "संचिका $1 मधील आहे व ती इतर प्रकल्पांमध्ये वापरली जात असल्याची शक्यता आहे.आपणास हवे असल्यास,या पानाच्या[$2 'संचिका वर्णन पान'] येथे,त्याची माहिती संपादु शकता",
"filepage-nofile": "या नावाची संचिका अस्तित्वात नाही.",
"filepage-nofile-link": "या नावाची संचिका अस्तित्वात नाही, पण तुम्ही ती [$1 चढवू शकता].",
- "uploadnewversion-linktext": "या सà¤\82à¤\9aिà¤\95à¥\87à¤\9aà¥\80 नवà¥\80न à¤\86वà¥\83तà¥\8dतà¥\80 à¤\9aढवा",
+ "uploadnewversion-linktext": "या सà¤\82à¤\9aिà¤\95à¥\87à¤\9aà¥\8dया नवà¥\80न à¤\86वà¥\83तà¥\8dतà¥\80à¤\9aà¥\87 à¤\85पà¤à¤¾à¤°à¤£ à¤\95रा",
"shared-repo-from": "$1 पासून",
"shared-repo": "एक मुक्त कोश",
"upload-disallowed-here": "या संचिकेवर आपण पुनर्लिखाण करू शकत नाही.",
- "filerevert": "$1 पूर्वपद",
- "filerevert-legend": "संचिका पूर्वपदास",
+ "filerevert": "$1 पूर्वपदास न्या",
+ "filerevert-legend": "संचिका पूर्वपदास न्या",
"filerevert-intro": "तुम्ही [$3, $2 प्रमाणे आवर्तन$4 कडे]<strong>[[Media:$1|$1]]</strong> उलटवत आहात.",
"filerevert-comment": "कारण:",
"filerevert-defaultcomment": "$2, $1 च्या आवृत्तीस पूर्वपदावर ($3)",
- "filerevert-submit": "पूर्वपद",
+ "filerevert-submit": "पूर्वपदास न्या",
"filerevert-success": "[$3, $2 प्रमाणे आवर्तन $4]कडे<strong>[[Media:$1|$1]]</strong>उलटवण्यात आली.",
"filerevert-badversion": "दिलेलेल्या वेळ मापनानुसार,या संचिकेकरिता कोणतीही पूर्वीची स्थानिक आवृत्ती नाही.",
"filedelete": "$1 वगळा",
"statistics-edits": "{{SITENAME}} च्या सुरुवातीपासूनची पानांची संपादने",
"statistics-edits-average": "प्रतिपान सरासरी संपादने",
"statistics-users": "नोंदणीकृत [[Special:ListUsers|सदस्य]]",
- "statistics-users-active": "à¤\95ारà¥\8dयरत सदस्य",
- "statistics-users-active-desc": "{{PLURAL:$1|शेवटच्या दिवसात|शेवटच्या $1 दिवसांत}} एकतरी संपादन केलेले सदस्य",
+ "statistics-users-active": "à¤\95à¥\8dरियाशà¥\80ल सदस्य",
+ "statistics-users-active-desc": "शेवटच्या{{PLURAL:$1|दिवसात|$1 दिवसांत}} एकतरी संपादन केलेले सदस्य",
"pageswithprop": "'पृष्ठ गुणधर्म' असणारी पाने",
"pageswithprop-legend": "पृष्ठ गुणधर्म असणारी पाने",
"pageswithprop-text": "या पानावर अश्या पानांची यादी आहे जे एक विशिष्ट 'पृष्ठ गुणधर्म' वापरतात.",
"doubleredirects": "दुहेरी-पुनर्निर्देशने",
"doubleredirectstext": "हे पान, अशा पानांची यादी पुरवते की जी पाने, दुसऱ्या पुर्ननिर्देशीत पानाकडे पुर्ननिर्देशीत झाली आहेत.प्रत्येक ओळीत पहिल्या आणि दुसऱ्या पुर्ननिर्देशनाचा दुवा दिला आहे,तसेच, दुसऱ्या पुर्ननिर्देशनाचे लक्ष्य पान पण दिले आहे,जे मुळात ते \nलक्ष्यपान आहे ज्याकडे, पहिले पुनर्निर्देशन असावयास हवे.\n\n<del>खोडलेल्या प्रविष्टी</del>समायोजित करण्यात आलेल्या आहेत.",
"double-redirect-fixed-move": "[[$1]] हलवले गेले आहे.\nते आता स्वयंचलितरित्या अद्यतन केल्या गेले व [[$2]] येथे निर्देशित होते.",
- "double-redirect-fixed-maintenance": "[[$1]] ते [[$2]] हे चुकीचे पुनर्निर्देशन ठिकठाक केले.",
+ "double-redirect-fixed-maintenance": "देखभालीच्या कामादरम्यान,स्वयंचलितरित्या [[$1]]पासून ते [[$2]]ला, हे दुहेरी पुनर्निर्देशन ठिकठाक केले.",
"double-redirect-fixer": "पुनर्निर्देशन ठिकठाक करणारा",
"brokenredirects": "मोडकी पुनर्निर्देशने",
"brokenredirectstext": "खालील पुनर्निर्देशने अस्तित्वात नसलेली पाने जोडतात:",
"withoutinterwiki-submit": "दाखवा",
"fewestrevisions": "सगळ्यात कमी बदल असलेले लेख",
"nbytes": "$1 {{PLURAL:$1|बाइट}}",
- "ncategories": "$1 {{PLURAL:$1|वर्ग|वर्ग}}",
- "ninterwikis": "$1 {{PLURAL:$1|आंतरविकि|आंतरविकि दुवे}}",
+ "ncategories": "$1 {{PLURAL:$1|वर्ग}}",
+ "ninterwikis": "$1 {{PLURAL:$1|आंतरविकि}}",
"nlinks": "$1 {{PLURAL:$1|दुवा|दुवे}}",
"nmembers": "$1 {{PLURAL:$1|सदस्य}}",
"nmemberschanged": "$1 → $2 {{PLURAL:$2|सदस्य}}",
"lonelypagestext": "खालील पानांना {{SITENAME}}च्या इतर पानांकडून दुवा जोड झालेली नाही.",
"uncategorizedpages": "अवर्गीकृत पाने",
"uncategorizedcategories": "अवर्गीकृत वर्ग",
- "uncategorizedimages": "à¤\85वरà¥\8dà¤\97à¥\80à¤\95à¥\83त à¤\9aितà¥\8dरà¥\87",
+ "uncategorizedimages": "à¤\85वरà¥\8dà¤\97à¥\80à¤\95à¥\83त सà¤\82à¤\9aिà¤\95ा",
"uncategorizedtemplates": "अवर्गीकृत साचे",
"unusedcategories": "न वापरलेले वर्ग",
"unusedimages": "न वापरलेल्या संचिका",
"wantedpages": "पाहिजे असलेले लेख",
"wantedpages-badtitle": "परिणामाच्या यादीत अवैध शीर्षक: $1",
"wantedfiles": "पाहिजे असलेल्या संचिका",
- "wantedfiletext-cat": "पà¥\81ढà¥\80ल फाà¤\87लà¥\8dस वापरलà¥\8dया à¤\85सतà¥\80ल पण à¤\86ता à¤\85सà¥\8dतितà¥\8dवात नाहà¥\80त. बाहà¥\87रà¥\80ल ठिà¤\95ाणाà¤\82à¤\9aà¥\8dया फाà¤\87लà¥\8dस यà¥\87थà¥\87 दिसतात पण à¤\85सतà¥\80लà¤\9a à¤\85सà¥\87 नाहà¥\80. à¤\85शा फाà¤\87लà¥\8dस à¤\86ढळलà¥\8dयास वà¤\97ळलà¥\8dया à¤\9cातà¥\80ल. à¤\85शà¥\80 पानà¥\87 [[:$1]] यà¥\87थà¥\87 दिसतà¥\80ल.",
+ "wantedfiletext-cat": "पà¥\81ढà¥\80ल फाà¤\87लà¥\8dस वापरलà¥\8dया à¤\85सतà¥\80ल पण à¤\86ता à¤\85सà¥\8dतितà¥\8dवात नाहà¥\80त. बाहà¥\87रà¥\80ल ठिà¤\95ाणाà¤\82à¤\9aà¥\8dया फाà¤\87लà¥\8dस यà¥\87थà¥\87 दिसतात पण à¤\85सतà¥\80लà¤\9a à¤\85सà¥\87 नाहà¥\80. à¤\85शा फाà¤\87लà¥\8dस à¤\86ढळलà¥\8dयास वà¤\97ळलà¥\8dया à¤\9cातà¥\80ल. à¤\85तिरिà¤\95à¥\8dतपणà¥\87,à¤\85शà¥\80 पानà¥\87, à¤\9cà¥\8dयात à¤\9fाà¤\95लà¥\87लà¥\8dया सà¤\82à¤\9aिà¤\95ा à¤\85सà¥\8dतितà¥\8dवात नाहà¥\80त,तà¥\8dयाà¤\9aà¥\80 यादà¥\80 [[:$1]] यà¥\87थà¥\87 दिसà¥\87ल.",
"wantedfiletext-nocat": "पुढील फाइल्स वापरल्या असतील पण आता अस्तित्वात नाहीत. बाहेरील ठिकाणांच्या फाइल्स येथे दिसतात पण असतीलच असे नाही. अशा फाइल्स आढळल्यास वगळल्या जातील.",
"wantedtemplates": "पाहिजे असलेले साचे",
"mostlinked": "सर्वाधिक जोडलेली पाने",
"mostlinkedcategories": "सर्वाधिक जोडलेले वर्ग",
- "mostlinkedtemplates": "सरà¥\8dवाधिà¤\95 à¤\9cà¥\8bडलà¥\87लà¥\87 साà¤\9aे",
- "mostcategories": "सरà¥\8dवाधिà¤\95 वरà¥\8dà¤\97à¥\80à¤\95à¥\83त पाने",
+ "mostlinkedtemplates": "सरà¥\8dवाधिà¤\95 à¤\86à¤\82तरà¤à¥\82त पाने",
+ "mostcategories": "बहà¥\81तà¥\87à¤\95 सरà¥\8dव वरà¥\8dà¤\97 à¤\85सलà¥\87लà¥\80 पाने",
"mostimages": "सर्वाधिक जोडलेली चित्रे",
"mostinterwikis": "सर्वाधिक आंतरविकि दुवे असणारी पाने",
"mostrevisions": "सर्वाधिक बदललेले लेख",
"shortpages": "छोटी पाने",
"longpages": "मोठी पाने",
"deadendpages": "टोकाची पाने",
- "deadendpagestext": "या पानांवर या विकिवरील इतर कुठल्याही पानाला जोडणारा दुवा नाही.",
+ "deadendpagestext": "या पानांवर या {{SITENAME}}वरील इतर कुठल्याही पानाला जोडणारा दुवा नाही.",
"protectedpages": "सुरक्षित पाने",
"protectedpages-indef": "फक्त अनंत काळासाठी सुरक्षित केलेले",
- "protectedpages-summary": "या पानात,अस्तित्वात असणाऱ्या संरक्षित अशा पानाची यादी आहे.नवनिर्माणापासून संरक्षित शीर्षकांच्या यादीसाठी [[{{#special:ProtectedTitles}}|{{int:protectedtitles}}]] बघा.",
+ "protectedpages-summary": "या पानात,अस्तित्वात असणाऱ्या संरक्षित अशा पानाची यादी आहे.नवनिर्माणापासून संरक्षित शीर्षकांच्या यादीसाठी [[{{#special:ProtectedTitles}}|{{int:protectedtitles}}]] बघा.",
"protectedpages-cascade": "केवळ एकामेकांवर अवलंबून कास्केडींग सुरक्षा (सुरक्षा शिडी)",
"protectedpages-noredirect": "पुनर्निर्देशने लपवा",
"protectedpagesempty": "सध्या या नियमावलीने कोणतीही पाने सुरक्षित केलेली नाहीत.",
"movethispage": "हे पान स्थानांतरित करा",
"unusedimagestext": "कृपया लक्षात घ्या की इतर संकेतस्थळे संचिकेशी थेट दुव्याने जोडल्या असू शकतात, त्यामुळे सक्रिय उपयोगात असून सुद्धा यादीत असू शकतात.",
"unusedcategoriestext": "खालील वर्ग पाने अस्तित्वात आहेत पण कोणतेही लेख किंवा वर्ग त्यांचा वापर करत नाहीत.",
- "notargettitle": "à¤\95रà¥\8dम(target) नाही",
+ "notargettitle": "लà¤\95à¥\8dषà¥\8dय(à¤\9fारà¤\97à¥\87à¤\9f) नाही",
"notargettext": "ही क्रिया करण्यासाठी तुम्ही सदस्य किंवा पृष्ठ लिहिले नाही.",
"nopagetitle": "असे लक्ष्य पान नाही",
"nopagetext": "तुम्ही दिलेले लक्ष्य पान अस्तित्वात नाही.",
"pager-newer-n": "{{PLURAL:$1|नवे 1|नवे $1}}",
"pager-older-n": "{{PLURAL:$1|जुने 1|जुने $1}}",
- "suppress": "à¤\9dापडबà¤\82द",
+ "suppress": "दमन à¤\95रा(सपà¥\8dरà¥\87स)",
"querypage-disabled": "हे विषेश पान कार्यमापन (performance) करणांमुळे प्रतिबंधित करण्यात आले आहे.",
+ "apihelp": "एपीआय साहाय्य",
+ "apihelp-no-such-module": "मॉड्यूल \"$1\" सापडत नाही.",
"booksources": "पुस्तक स्रोत",
"booksources-search-legend": "पुस्तक स्रोत शोधा",
"booksources-search": "शोधा",
"booksources-text": "खालील यादीत नवी आणिजुनी पुस्तके विकणाऱ्या संकेतस्थळाचे दुवे आहेत,आणि त्यात कदाचित आपण शोधू पहात असलेल्या पुस्तकाची अधिक माहिती असेल:",
"booksources-invalid-isbn": "दिलेला आयएसबीएन वैध नाही; मूळ स्रोतातून उतरवताना झालेल्या चुकांचे निरसन करा.",
"specialloguserlabel": "कार्यकर्ता:",
- "speciallogtitlelabel": "à¤\89दà¥\8dदिषà¥\8dà¤\9f (लà¤\95à¥\8dष):",
+ "speciallogtitlelabel": "लà¤\95à¥\8dष (शिरà¥\8dषà¤\95 à¤\95िà¤\82वा {{ns:user}}:सदसà¥\8dयाà¤\9aà¥\87 सदसà¥\8dयनाव):",
"log": "नोंदी",
"all-logs-page": "सर्व नोंदी",
"alllogstext": "{{SITENAME}}च्या सर्व नोंदीचे एकत्र दर्शन.नोंद प्रकार, सदस्यनाव किंवा बाधित पान निवडून तुम्ही तुमचे दृश्यपान मर्यादित करू शकता.",
"allpages-hide-redirects": "पुनर्निर्देशने लपवा",
"cachedspecial-viewing-cached-ttl": "तुम्ही या पानाची कॅचड् आवृत्ती पहात आहात. पाहत आहात या पाठया ची छोटी आवृत्ती,जी $1 ईतकी जुनी असू शकते.",
"cachedspecial-viewing-cached-ts": "तुम्ही या पानाची कॅचड् आवृत्ती पहात आहात. पाहत आहात या पाठया ची छोटी आवृत्ती,जी पुर्णतः मुळ आवृत्ती नसू शकते.",
- "cachedspecial-refresh-now": "à¤\86à¤\96à¥\87रà¤\9aà¥\87 दà¥\83शà¥\8dय",
+ "cachedspecial-refresh-now": "नà¥\81à¤\95तà¥\87à¤\9a à¤\95à¥\87लà¥\87लà¥\87 दाà¤\96वा.",
"categories": "वर्ग",
"categoriespagetext": "विकिवर खालील वर्ग {{PLURAL:$1|आहे|आहेत}}.\n[[Special:UnusedCategories|न वापरलेले वर्ग]] येथे दाखवलेले नाहीत.\nहेही पहा: [[Special:WantedCategories|पाहिजे असलेले वर्ग]].",
"categoriesfrom": "या शब्दापासून सुरू होणारे वर्ग दाखवा:",
- "special-categories-sort-count": "à¤\95à¥\8dरमानà¥\81सार लावा",
- "special-categories-sort-abc": "à¤\85à¤\95à¥\8dषराà¤\82पà¥\8dरमाणà¥\87 लावा",
+ "special-categories-sort-count": "मà¥\8bà¤\9cणà¥\80नà¥\81सार निवडा",
+ "special-categories-sort-abc": "à¤\85à¤\95ारविलà¥\8dहà¥\87 निवडा",
"deletedcontributions": "वगळलेली सदस्य संपादने",
"deletedcontributions-title": "वगळलेली सदस्य संपादने",
"sp-deletedcontributions-contribs": "संपादने",
"linksearch": "बाह्य दुवे शोध",
- "linksearch-pat": "शोधण्याचा मजकूर:",
+ "linksearch-pat": "शोध पद्धत:",
"linksearch-ns": "नामविश्व:",
"linksearch-ok": "शोध",
"linksearch-text": "\"*.wikipedia.org\" सारखी वाईल्डकार्ड्स वापरायला परवानगी आहे.\nकिमान एक उच्च-स्तरिय डोमेन,उदा.- \"*.org\".<br />गरजेचे आहे.\nसहाय्याचे प्रोटोकॉल्स {{PLURAL:$2|protocol|protocols}}: \n $1(जर कोणतेही प्रोटोकॉल्स नमूद केल्या गेले नसतील तर http://)हा डिफॉल्ट आहे.",
"listusersfrom": "पुढील शब्दापासून सुरू होणारे सदस्य दाखवा:",
"listusers-submit": "दाखवा",
"listusers-noresult": "एकही सदस्य सापडला नाही.",
- "listusers-blocked": "(à¤\96à¤\82डित)",
- "activeusers": "à¤\95ारà¥\8dयरत सदस्यांची यादी",
- "activeusers-intro": "$1 {{PLURAL:$1|day|days}} मधे शेवटी काम केलेल्या सदस्यांची यादी येथे मिळेल",
+ "listusers-blocked": "(à¤\85वरà¥\8bधित)",
+ "activeusers": "à¤\95à¥\8dरियाशà¥\80ल सदस्यांची यादी",
+ "activeusers-intro": "शेवटच्या $1 {{PLURAL:$1|दिवसात}} काम केलेल्या सदस्यांची यादी येथे मिळेल",
"activeusers-count": "शेवटच्या {{PLURAL:$3|दिवसात|$3 दिवसांत}} $1 {{PLURAL:$1|क्रिया}}",
"activeusers-from": "पुढील शब्दापासून सुरू होणारे सदस्य दाखवा:",
"activeusers-hidebots": "सांगकामे लपवा",
"listgrouprights-namespaceprotection-namespace": "नामविश्व",
"trackingcategories": "वर्ग शोधत आहोत",
"trackingcategories-name": "संदेश नाम",
+ "trackingcategories-nodesc": "वर्णन उपलब्ध नाही.",
+ "trackingcategories-disabled": "वर्ग अक्षम केल्या गेला आहे",
"mailnologin": "पाठविण्याचा पत्ता नाही",
"mailnologintext": "इतर सदस्यांना विपत्र(ई-मेल) पाठवण्याकरिता तुम्ही [[Special:UserLogin|प्रवेश केलेला]] असणे आणि प्रमाणित (ई-मेल) पत्ता तुमच्या [[Special:Preferences|पसंतीत]] नमूद असणे आवश्यक आहे.",
"emailuser": "या सदस्याला ई-मेल पाठवा",
"watchnologin": "सनोंद-प्रवेशित नाही",
"addwatch": "पहाऱ्याच्या सूचीमध्ये टाका",
"addedwatchtext": "\"[[:$1]]\" हे पान तुमच्या [[Special:Watchlist|'माझी निरीक्षणसूची']]मध्ये टाकले आहे. या पानावरील तसेच त्याच्या चर्चा पानावरील भविष्यातील बदल तेथे दाखवले जातील",
+ "addedwatchtext-short": "\"$1\" हे पान आपल्या निरीक्षणसूचीत जोडण्यात आले आहे.",
"removewatch": "पहाऱ्याच्या सूचीतून वगळा",
- "removedwatchtext": "\"[[:$1]]\" पान तुमच्या [[Special:Watchlist|पहाऱ्याच्या सूची]]तून वगळण्यात आले आहे.",
+ "removedwatchtext": "\"[[:$1]]\" हे पान व त्याची चर्चापाने तुमच्या [[Special:Watchlist|निरीक्षण सूचीतून]] हटविण्यात आले आहे.",
+ "removedwatchtext-short": "\"$1\" हे पान आपल्या निरीक्षणसूचीतुन हटविण्यात आले आहे.",
"watch": "पहारा",
"watchthispage": "या पानावर बदलांसाठी लक्ष ठेवा.",
"unwatch": "पहारा काढा",
"unwatchthispage": "पहारा काढून टाका",
"notanarticle": "हे आशयपान नाही",
"notvisiblerev": "आवृत्ती वगळण्यात आलेली आहे",
- "watchlist-details": "पहाऱ्याच्या सूचीमधील {{PLURAL:$1|$1 पान|$1 पाने}}, यात चर्चा पाने मोजलेली नाहीत.",
+ "watchlist-details": "पहाऱ्याच्या सूचीमधील {{PLURAL:$1|$1 पान|$1 पाने}}, यात चर्चा पाने वेगळी मोजलेली नाहीत.",
"wlheader-enotif": "विपत्र अधिसूचना सुविधा शक्य केली.",
"wlheader-showupdated": "ती पाने, जी आपण दिलेल्या शेवटच्या भेटीनंतर बदललेली आहेत, '''ठळक''' दाखवली आहेत.",
"wlnote": "खाली $3, $4 पर्यंतचे गेल्या {{PLURAL:$2| '''१''' तासातील|'''$2''' तासातील}} {{PLURAL:$1|शेवटचा बदल दिला आहे|शेवटाचे '''$1'''बदल दिले आहेत}}.",
"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": "आंतरजाल अंकपत्ता किंवा सदस्यनाम:",
"sp-contributions-toponly": "केवळ नवीनतम आवर्तने असलेलीच संपादने दाखवा",
+ "sp-contributions-newonly": "केवळ पान तयार केलेली संपादनेच दाखवा",
"sp-contributions-submit": "शोध",
"whatlinkshere": "येथे काय जोडले आहे",
"whatlinkshere-title": "\"$1\" ला जुळलेली पाने",
"autoblockid": "स्वयंचलितपणे #$1ला प्रतिबंधित करा",
"block": "सदस्यास प्रतिबंध करा",
"unblock": "सदस्यप्रतिबंध काढा",
- "blockip": "हा अंकपत्ता अडवा",
+ "blockip": "{{GENDER:$1|सदस्यास}} प्रतिबंधित करा",
"blockip-legend": "सदस्यास प्रतिबंध करा",
"blockiptext": "एखाद्या विशिष्ट अंकपत्त्याची किंवा सदस्याची लिहिण्याची क्षमता प्रतिबंधित करण्याकरिता खालील सारणी वापरा.\nहे केवळ उच्छेद टाळण्याच्याच दृष्टीने आणि [[{{MediaWiki:Policy-url}}|निती]]स अनुसरून केले पाहिजे.\nखाली विशिष्ट कारण भरा(उदाहरणार्थ,ज्या पानांवर उच्छेद माजवला गेला त्यांची उद्धरणे देऊन).",
"ipaddressorusername": "अंकपत्ता किंवा सदस्यनाम:",
"ipb-unblock-addr": "$1चा प्रतिबंध उठवा",
"ipb-unblock": "सदस्यनाव आणि अंकपत्त्यावरचे प्रतिबंधन उठवा",
"ipb-blocklist": "सध्याचे प्रतिबंध पहा",
- "ipb-blocklist-contribs": "$1 साठी सदस्याचे योगदान",
+ "ipb-blocklist-contribs": "{{GENDER:$1|$1}}साठीचे योगदान",
"unblockip": "अंकपत्ता सोडवा",
"unblockiptext": "खाली दिलेला फॉर्म वापरून पूर्वी अडवलेल्या अंकपत्त्याला लेखनासाठी आधिकार द्या.",
"ipusubmit": "हा पत्ता सोडवा",
"thumbnail_image-failure-limit": "हे नखुले देण्यासाठी नुकतेच अनेक अयशस्वी प्रयत्न($1 किंवा अधिक) केल्या गेले आहेत.कृपया नंतर पुन्हा प्रयत्न करा.",
"import": "पाने आयात करा",
"importinterwiki": "दुसऱ्या विकीवरुन आयात करा",
- "import-interwiki-text": "à¤\86यात à¤\95रणà¥\8dयाà¤\95रिता à¤\8fà¤\95 विà¤\95ि à¤\86णि पानाà¤\9aा मथळा निवडा.\nà¤\86वरà¥\8dतनाà¤\82à¤\9aà¥\8dया तारà¤\96ा à¤\86णि सà¤\82पादà¤\95ाà¤\82à¤\9aà¥\80 नावà¥\87 à¤\9cतन à¤\95à¥\87लà¥\80 à¤\9cातà¥\80ल.\nसरà¥\8dव à¤\86à¤\82तरविà¤\95ि à¤\86यात à¤\95à¥\8dरिया [[Special:Log/import|à¤\86यात नà¥\8bà¤\82दà¥\80त]] दाà¤\96ल à¤\95à¥\87लà¥\8dया à¤\86हà¥\87त.",
+ "import-interwiki-text": "à¤\86यात à¤\95रणà¥\8dयाà¤\95रिता à¤\8fà¤\95 विà¤\95ि à¤\86णि पानाà¤\9aा मथळा निवडा.\nà¤\86वरà¥\8dतनाà¤\82à¤\9aà¥\8dया तारà¤\96ा à¤\86णि सà¤\82पादà¤\95ाà¤\82à¤\9aà¥\80 नावà¥\87 à¤\9cतन à¤\95à¥\87लà¥\80 à¤\9cातà¥\80ल.\nसरà¥\8dव à¤\86à¤\82तरविà¤\95ि à¤\86यात à¤\95à¥\8dरिया [[Special:Log/import|à¤\86यात नà¥\8bà¤\82दà¥\80त]] दाà¤\96ल à¤\95रणà¥\8dयात यà¥\87तात.",
"import-interwiki-sourcewiki": "स्रोत विकि:",
"import-interwiki-sourcepage": "स्रोत पान:",
"import-interwiki-history": "या पानाकरिताची साऱ्या इतिहास आवर्तनांची नक्कल करा",
"import-upload": "XML डाटा चढवा",
"import-token-mismatch": "अधिवेशन माहितीची हानी.\nकृपया पुन्हा प्रयत्न करा.",
"import-invalid-interwiki": "नमूद केलेल्या विकिमधून आयात करू शकत नाही.",
- "import-error-edit": "तुम्हाला संपादनाची परवानगी नसल्याने $1 पान आयात केले गेले नाही.",
- "import-error-create": "तुम्हाला $1 तयार करण्याची परवानगी नसल्याने ते आयात केले गेले नाही.",
- "import-error-interwiki": "à¤\87à¤\82à¤\9fर विà¤\95à¥\80 लिà¤\82à¤\95 साठà¥\80 $1 पान à¤\86रà¤\95à¥\8dषित à¤\95à¥\87लà¥\8dयामà¥\81ळà¥\87 तà¥\87 à¤\87मà¥\8dपà¥\8bरà¥\8dà¤\9f à¤\95रà¥\82 शà¤\95त नाहà¥\80",
- "import-error-special": "विशà¥\87ष नामविशà¥\8dवासाठà¥\80 $1 पान à¤\86रà¤\95à¥\8dषित à¤\95à¥\87लà¥\8dयामà¥\81ळà¥\87 तà¥\87 à¤\87मà¥\8dपà¥\8bरà¥\8dà¤\9f à¤\95रà¥\82 शà¤\95त नाहà¥\80. या नामविशà¥\8dवात पानà¥\87 à¤\85सत नाहà¥\80त.",
- "import-error-invalid": "नाव à¤\85यà¥\8bà¤\97à¥\8dय à¤\85सलà¥\8dयानà¥\87 $1 पान à¤\87मà¥\8dपà¥\8bरà¥\8dà¤\9f à¤\95रà¥\82 शà¤\95त नाहà¥\80.",
+ "import-error-edit": "तुम्हाला संपादनाची परवानगी नसल्याने \"$1\" पान आयात केल्या गेले नाही.",
+ "import-error-create": "तुम्हाला पान \"$1\" तयार करण्याची परवानगी नसल्याने ते आयात केल्या गेले नाही.",
+ "import-error-interwiki": "पान \"$1\" à¤\86यात à¤\95à¥\87लà¥\8dया à¤\97à¥\87लà¥\87 नाहà¥\80 à¤\95ारण तà¥\8dयाà¤\9aà¥\87 नाव बाहà¥\8dय दà¥\81वà¥\8dयाà¤\82साठà¥\80 (à¤\86à¤\82तरविà¤\95ि) à¤\86रà¤\95à¥\8dषित à¤\86हà¥\87.",
+ "import-error-special": "पान \"$1\" à¤\86यात à¤\95à¥\87लà¥\8dया à¤\97à¥\87लà¥\87 नाहà¥\80 à¤\95ारण तà¥\87 विशà¥\87ष नामविशà¥\8dवात à¤\85सलà¥\8dयामà¥\81ळà¥\87 तà¥\87 पानाà¤\82ना (साठविणà¥\8dयाà¤\9aà¥\80)परवानà¤\97à¥\80 दà¥\87त नाहà¥\80.",
+ "import-error-invalid": "पान \"$1\" à¤\86यात à¤\95à¥\87लà¥\8dया à¤\97à¥\87लà¥\87 नाहà¥\80 à¤\95ारण तà¥\87 à¤\9cà¥\8dया नावात à¤\86यात à¤\95रणà¥\8dयात यà¥\87त à¤\86हà¥\87 तà¥\87 नाव या विà¤\95ित à¤\85वà¥\88ध à¤\86हà¥\87.",
"import-error-unserialize": " \"$1\" पानाची $2 आवृत्ती अनुक्रमांकातून काढता आली नाही.ही आवृत्ती कंटेंट मॉडेल $3 वापरत असल्याचा व $4 म्हणून अनुक्रमांकीत झाली असल्याचा अहवाल प्राप्त झाला आहे.",
"import-options-wrong": "चुकिचे {{PLURAL:$2|विकल्प}}: <nowiki>$1</nowiki>",
"import-rootpage-invalid": "दिलेले मूळ पान अवैध नाव आहे",
"import-rootpage-nosubpage": "\"$1\" नामविश्वाची मुल पाने, उपपानास परवानगी देत नाही.",
"importlogpage": "ईम्पोर्ट सूची",
"importlogpagetext": "इतर विकिक्डून पानांची, संपादकीय इतिहासासहीत, प्रबंधकीय आयात.",
- "import-logentry-upload-detail": "$1 {{PLURAL:$1|आवर्तन|आवर्तने}}",
- "import-logentry-interwiki-detail": "$2 पासून $1 {{PLURAL:$1|आवर्तन|आवर्तने}}",
+ "import-logentry-upload-detail": "$1 {{PLURAL:$1|आवर्तन|आवर्तने}}आयात केलीत",
+ "import-logentry-interwiki-detail": "$2 पासून $1 {{PLURAL:$1|आवर्तन|आवर्तने}} आयात केलीत",
"javascripttest": "जावा स्क्रिप्ट तपासणी",
"javascripttest-pagetext-noframework": "हे पान जावा स्क्रिप्ट तपासणी साठी सुरक्षित केले आहे",
"javascripttest-pagetext-unknownframework": "अज्ञात तपासणीचे ठिकाण $1",
+ "javascripttest-pagetext-unknownaction": "अनोळखी क्रिया \"$1\".",
"javascripttest-pagetext-frameworks": "कृपया टेस्टिंग साठी पुढील पैकी व्यवस्था / पद्धत निवडावी: $1",
"javascripttest-pagetext-skins": "टेस्ट करण्यासाठी योग्य ती स्कीन निवडावी",
"javascripttest-qunit-intro": "mediawiki.org वर [$1 testing documentation] पहा",
"tooltip-feed-atom": "या पानाकरिता ऍटम रसद",
"tooltip-t-contributions": "या सदस्याच्या योगदानांची यादी पहा",
"tooltip-t-emailuser": "या सदस्याला ई-मेल पाठवा",
+ "tooltip-t-info": "या पानाबाबत अधिक माहिती",
"tooltip-t-upload": "संचिकेचे अपभारण करा",
"tooltip-t-specialpages": "सर्व विशेष पृष्ठांची यादी",
"tooltip-t-print": "या पानाची छापण्यायोग्य आवृत्ती",
"pageinfo-length": "पानाचा आकार (बाइट्समध्ये)",
"pageinfo-article-id": "पृष्ठ-परिचय",
"pageinfo-language": "पानाच्या मजकूराची भाषा",
+ "pageinfo-content-model": "पान आशय नमूना",
"pageinfo-robot-policy": "यंत्रमानवाद्वारे अनुक्रमन",
"pageinfo-robot-index": "अनुमती दिली",
"pageinfo-robot-noindex": "अनुमती दिल्या जात नाही",
"pageinfo-protect-cascading-yes": "होय",
"pageinfo-protect-cascading-from": "रखणे(प्रोटक्शन्स) प्रपातीत होतात (कॅस्केडिंग) येथून",
"pageinfo-category-info": "वर्ग माहिती",
+ "pageinfo-category-total": "सदस्यांचा एकूण आकडा",
"pageinfo-category-pages": "पानांची संख्या",
"pageinfo-category-subcats": "उपवर्गांची संख्या",
"pageinfo-category-files": "संचिकांची संख्या",
"confirm-watch-top": "हे पान तुमच्या पहारा सूचीमध्ये टाकायचे?",
"confirm-unwatch-button": "ठिक आहे",
"confirm-unwatch-top": "हे पान तुमच्या नित्य पहाण्याच्या सूचीतून काढायचे?",
+ "quotation-marks": "\"$1\"",
"imgmultipageprev": "← मागील पान",
"imgmultipagenext": "पुढील पान →",
"imgmultigo": "चला!",
"duplicate-defaultsort": "'''ताकिद:''' डिफॉल्ट सॉर्ट की \"$2\" ओवर्राइड्स अर्लीयर डिफॉल्ट सॉर्ट की \"$1\".",
"version": "आवृत्ती",
"version-extensions": "स्थापित विस्तार",
- "version-skins": "त्वचा",
+ "version-skins": "à¤\87à¤\82सà¥\8dà¤\9fà¥\89ल à¤\95à¥\87लà¥\8dया à¤\97à¥\87लà¥\87लà¥\8dया तà¥\8dवà¤\9aा",
"version-specialpages": "विशेष पाने",
"version-parserhooks": "पृथकक अंकुश",
"version-variables": "चल",
"version-hook-name": "अंकुश नाव",
"version-hook-subscribedby": "वर्गणीदार",
"version-version": "($1)",
+ "version-no-ext-name": "[नाव नाही]",
"version-license": "मिडियाविकि परवाना",
"version-ext-license": "परवाना",
"version-ext-colheader-name": "विस्तारक",
+ "version-skin-colheader-name": "त्वचा",
"version-ext-colheader-version": "आवृत्ती",
"version-ext-colheader-license": "परवाना",
"version-ext-colheader-description": "वर्णन",
"version-ext-colheader-credits": "लेखक",
"version-license-title": "$1 साठी परवाना",
"version-license-not-found": "या विस्तारकासाठी विस्तृत परवाना माहिती सापडली नाही.",
+ "version-credits-title": "$1साठीचे श्रेय",
+ "version-credits-not-found": "या विस्तारकासाठी विस्तृत श्रेयनिर्देशन माहिती सापडली नाही.",
"version-poweredby-credits": "हा विकी '''[https://www.mediawiki.org/ मीडियाविकी]'''द्वारे संचालित आहे, प्रताधिकारित © २००१-$1 $2.",
"version-poweredby-others": "इतर",
"version-poweredby-translators": "ट्रांसलेटविकि.नेट वरील भाषांतरकार",
"specialpages-group-wiki": "डाटा व उपकरणे",
"specialpages-group-redirects": "पुनर्निर्देशन करणारी विशेष पृष्ठे",
"specialpages-group-spam": "उत्पात साधने",
+ "specialpages-group-developer": "विकसक उपकरण",
"blankpage": "रिकामे पान",
"intentionallyblankpage": "हे पान मुद्दाम कोरे सोडण्यात आले आहे.",
"external_image_whitelist": "#ही ओळ जशी आहे तशीच घ्या.\n#\n#.\n#\n#\n#हे केस सेन्सेटिव्ह आहे.",
"feedback-subject": "विषय:",
"feedback-submit": "सादर करा",
"feedback-thanks": " \"[$2 $1]\" या पानात आपला पश्चप्रदाय (फिडबॅक) टाकत आहोत.",
+ "feedback-thanks-title": "आपणास धन्यवाद!",
+ "feedback-useragent": "सदस्य प्रतिनीधी:",
"searchsuggest-search": "शोधा",
"searchsuggest-containing": ".......हे असलेले",
"api-error-badaccess-groups": "आपणास ह्या विकिवर संचिका चढवण्याची परवानगी नाही",
"expand_templates_generate_xml": "XML चा पार्स (parse) वृक्ष दाखवा",
"expand_templates_preview": "झलक",
"pagelang-name": "पान",
+ "pagelang-language": "भाषा",
+ "pagelang-use-default": "अविचल भाषा वापरा",
+ "pagelang-select-lang": "भाषा निवडा",
+ "right-pagelang": "पानाची भाषा बदला",
+ "action-pagelang": "पानाची असलेली भाषा बदला",
+ "log-name-pagelang": "भाषा बदल नोंदवही",
+ "mediastatistics-table-extensions": "शक्य विस्तारके",
+ "mediastatistics-table-count": "संचिकांची संख्या",
+ "mediastatistics-table-totalbytes": "एकत्रित आकार",
+ "mediastatistics-header-unknown": "अनोळखी",
"mediastatistics-header-office": "कार्यालय",
"special-characters-group-latin": "लॅटीन",
"special-characters-group-latinextended": "विस्तारीत लॅटीन भाषा",
"special-characters-title-minus": "ॠण चिन्ह",
"mw-widgets-dateinput-no-date": "कोणताही दिनांक निवडला नाही",
"mw-widgets-titleinput-description-new-page": "अद्याप पान अस्तित्वात नाही",
+ "mw-widgets-titleinput-description-redirect": "$1ला पुनर्निर्देशित करा",
"api-error-blacklisted": "कुपया वेगळे वर्णनात्मक शीर्षक निवडा"
}
"foreign-structured-upload-form-label-own-work-message-local": "Potwierdzam, że wysyłam ten plik zgodnie z warunkami i zasadami licencjowania obowiązującymi na {{SITENAME}}.",
"foreign-structured-upload-form-label-not-own-work-message-local": "Jeśli nie możesz wysłać tego pliku zgodnie z zasadami obowiązującymi na {{SITENAME}}, zamknij ten komunikat i spróbuj innej metody.",
"foreign-structured-upload-form-label-not-own-work-message-default": "Jeśli nie jesteś w stanie przesłać tego pliku zgodnie z zasadami współdzielonego repozytorium, zamknij to okno i spróbuj innej metody.",
+ "foreign-structured-upload-form-label-own-work-message-shared": "Oświadczam, że mam prawa autorskie do tego pliku, nieodwołalnie publikuję go na Wikimedia Commons na licencji [https://creativecommons.org/licenses/by-sa/4.0/ Creative Commons BY-SA 4.0] i zgadzam się na [https://wikimediafoundation.org/wiki/Terms_of_Use warunki użytkowania].",
+ "foreign-structured-upload-form-label-not-own-work-message-shared": "Jeżeli nie masz praw autorskich do tego pliku albo chcesz go opublikować na innej licencji, rozważ użycie [https://commons.wikimedia.org/wiki/Special:UploadWizard kreatora przesyłania plików].",
+ "foreign-structured-upload-form-label-not-own-work-local-shared": "Możesz spróbować użyć [[Special:Upload|kreatora przesyłania plików {{GRAMMAR:D.lp|{{SITENAME}}}}]], jeżeli wolontariusze {{GRAMMAR:D.lp|{{SITENAME}}}} dopuszczają publikację plików na własnych zasadach.",
"backend-fail-stream": "Nie można odczytać pliku $1.",
"backend-fail-backup": "Nie można utworzyć kopii zapasowej pliku $1 .",
"backend-fail-notexists": "Plik $1 nie istnieje.",
"showingresultsinrange": "Used in pagination of [[Special:MostLinkedCategories]]. Parameters:\n* $1 - the total number of results in the batch shown\n* $2 - the number of the first item listed\n* $3 - the number of last item in the batch shown\n\nSee also {{msg-mw|Showingresults}}",
"search-showingresults": "Used in search results of [[Special:Search]]. Parameters:\n* $1 - minimum offset\n* $2 - maximum offset\n* $3 - total number of results\n* $4 - number of results",
"search-nonefound": "Message shown when a search returned no results (when using the default MediaWiki search engine).",
+ "search-nonefound-thiswiki": "Message shown when a search in current wiki returned no results (when using the default MediaWiki search engine) but search in other wikis did return results.",
"powersearch-legend": "Advanced search\n\n{{Identical|Advanced search}}",
"powersearch-ns": "Used in the extended search form at [[Special:Search]]",
"powersearch-togglelabel": "Used in [{{canonicalurl:Special:Search|advanced=1}} Advanced search]. Synonym: \"Select\" as verb.\n{{Identical|Check}}",
"prefs-displaywatchlist": "Tasvirlash moslamalari",
"prefs-diffs": "Versiyalar farqi",
"userrights": "Foydalanuvchi huquqlarini oʻzgartirish",
+ "userrights-lookup-user": "Foydalanuvchini tanlash",
"userrights-user-editname": "Foydalanuvchi nomi:",
- "editusergroup": "Guruhlardagi aʼzoligini oʻzgartirish",
- "userrights-groupsmember": "Aʼzolik:",
- "userrights-groupsmember-auto": "Quyidagi guruhlarga kiradi:",
+ "editusergroup": "Shu foydalanuvchi huquqlarini oʻzgartirish",
+ "editinguser": "{{GENDER:$1|Foydalanuvchi}} <strong>[[User:$1|$1]]</strong> $2 huquqlarini oʻzgartirish",
+ "userrights-editusergroup": "Guruhlardagi aʼzoligini oʻzgartirish",
+ "saveusergroups": "Oʻzgarishlarni saqlash",
+ "userrights-groupsmember": "Ushbu guruhlar aʼzosi:",
+ "userrights-groupsmember-auto": "Shuningdek, ushbu texnik guruhlar aʼzosi:",
+ "userrights-groups-help": "Ushbu foydalanuvchining guruhlardagi aʼzoligini oʻzgartirishingiz mumkin:\n* Guruh nomi yonida belgi turgan boʻlsa, demak foydalanuvchi ushbu guruh aʼzosidir\n* Guruh nomi yonida belgi yoʻq boʻlsa, demak foydalanuvchi ushbu guruh aʼzosi emas\n* * (yulduzcha) belgisi foydalanuvchini guruhga qoʻshsangiz, qaytarib chiqarib tashlay olmasligingizni (yoki chiqarib tashlasangiz, qaytarib qoʻsha olmasligingizni) anglatadi",
"userrights-reason": "Sabab:",
- "userrights-changeable-col": "Siz o'zgartirishingiz mumkin bo'lgan guruhlar",
- "userrights-unchangeable-col": "Siz o'zgartira olmaydigan guruhlar",
+ "userrights-changeable-col": "Quyidagi guruhlarga qoʻsha olasiz",
+ "userrights-unchangeable-col": "Quyidagi guruhlarga qoʻsha olmaysiz",
"group": "Guruh",
"group-user": "Foydalanuvchilar",
"group-autoconfirmed": "Tasdiqlangan foydalanuvchilar",
"tog-hideminor": "隱藏近期變更中的小修訂",
"tog-hidepatrolled": "隱藏近期變更中巡查過的編輯",
"tog-newpageshidepatrolled": "隱藏新頁面清單中巡查過的頁面",
+ "tog-hidecategorization": "隱藏頁面分類",
"tog-extendwatchlist": "展開監視清單顯示包含最近以外的所有變更",
"tog-usenewrc": "依近期變更與監視清單的頁面分類顯示變更",
"tog-numberheadings": "標題自動編號",
"tog-watchlisthideliu": "隱藏監視清單中已登入使用者的編輯",
"tog-watchlisthideanons": "隱藏監視清單中匿名使用者的編輯",
"tog-watchlisthidepatrolled": "隱藏監視清單中已巡查的編輯",
+ "tog-watchlisthidecategorization": "隱藏頁面分類",
"tog-ccmeonemails": "我給他人寄出郵件時,也寄出一份副本到我的電子郵件信箱",
"tog-diffonly": "比對差異時下方不顯示頁面內容",
"tog-showhiddencats": "顯示隱藏分類",
"createaccountreason": "原因:",
"createacct-reason": "原因",
"createacct-reason-ph": "您為什麼要建立另一個帳號",
- "createacct-captcha": "安全驗證",
- "createacct-imgcaptcha-ph": "輸入您在上方看到的文字",
"createacct-submit": "建立您的帳號",
"createacct-another-submit": "建立帳號",
"createacct-benefit-heading": "{{SITENAME}} 是由像您一樣貢獻的人所建立的。",
"passwordreset-emailsent-capture": "已寄出重設密碼的電子郵件,並於下方顯示。",
"passwordreset-emailerror-capture": "下列為重設密碼的電子郵件內容,傳送給{{GENDER:$2|使用者}}失敗:$1",
"changeemail": "變更或移除電子郵件地址",
- "changeemail-header": "變更帳號的電子郵箱地址",
+ "changeemail-header": "請填寫此表單來變更您的電子郵件地址,若您想要移除您帳號所連結的所有電子郵件地址,請於新電子郵件地址欄位留空。",
+ "changeemail-passwordrequired": "您須要輸入您的密碼來確認此次變更。",
"changeemail-no-info": "您必須登入方可直接存取此頁面。",
"changeemail-oldemail": "目前的電子郵件地址:",
"changeemail-newemail": "新的電子郵件地址:",
"missingsummary": "<strong>提醒:</strong>您未填寫編輯摘要。\n若您再點選 \"{{int:savearticle}}\" 一次,將略過摘要直接儲存您的編輯。",
"selfredirect": "<strong>警告:</strong> 您正建立連結至自己的重新導向。\n您可能指定錯要重新導向的目標頁面或者編輯錯頁面。\n若您再點選 \"{{int:savearticle}}\" 一次,將會繼續建立重新導向。",
"missingcommenttext": "請在下方輸入評論。",
- "missingcommentheader": "<strong>提醒:</strong>您未填寫此評論的主旨/標題。\n若您再點選 \"{{int:savearticle}}\" 一次,將略過主旨/標題直接儲存您的評論。",
+ "missingcommentheader": "<strong>提醒:</strong>您未填寫此評論的主旨。\n若您再點選 \"{{int:savearticle}}\" 一次,將略過主旨/標題直接儲存您的評論。",
"summary-preview": "摘要預覽:",
"subject-preview": "主旨預覽:",
"previewerrortext": "嘗試預覽您的變更時發生錯誤。",
"permissionserrors": "權限錯誤",
"permissionserrorstext": "由於下列{{PLURAL:$1|原因}},您沒有權限進行目前的動作:",
"permissionserrorstext-withaction": "由於下列{{PLURAL:$1|原因}},您沒有權限進行 $2 的動作:",
+ "contentmodelediterror": "您無法編輯此修訂,因此修訂使用的內容模型為 <code>$1</code> 而目前使用的頁面內容模型為 <code>$2</code>。",
"recreate-moveddeleted-warn": "<strong>警告:您正重新建立先前已刪除的頁面。</strong>\n\n您應考慮是否繼續編輯此頁。\n在此提供刪除與移動日誌方便作為參考:",
"moveddeleted-notice": "此頁面已刪除。\n下方提供此頁面的刪除和移動日誌以便參考。",
"moveddeleted-notice-recent": "抱歉,此頁面最近被刪除 (24 小時內)。\n以下提供此頁面的刪除與移動日誌做為參考。",
"prefs-help-recentchangescount": "這包含近期變更、頁面歷史以及日誌。",
"prefs-help-watchlist-token2": "訂閱您的監視清單所需的密鑰。\n任何人只要知道密鑰就能夠讀取您的監視清單,所以請勿任意與它人共享。\n若有需要 [[Special:ResetTokens|您可重設密鑰]]。",
"savedprefs": "已儲存您的偏好設定。",
+ "savedrights": "已儲存 {{GENDER:$1|$1}} 的使用者權限。",
"timezonelegend": "時區:",
"localtime": "當地時間:",
"timezoneuseserverdefault": "使用 Wiki 預設值 ($1)",
"rcshowhidemine": "$1 我的編輯",
"rcshowhidemine-show": "顯示",
"rcshowhidemine-hide": "隱藏",
+ "rcshowhidecategorization": "$1 頁面分類",
+ "rcshowhidecategorization-show": "顯示",
+ "rcshowhidecategorization-hide": "隱藏",
"rclinks": "顯示近期 $2 天內的 $1 次變更。<br />$3",
"diff": "差異",
"hist": "歷史",
"upload-options": "上傳選項",
"watchthisupload": "監視此檔案",
"filewasdeleted": "先前已有同樣名稱的檔案上傳,後來被刪除。\n您應在上傳此檔案前檢查 $1。",
+ "filename-thumb-name": "此檔名似乎為縮圖檔名,請不要重新上傳縮圖回相同 wiki。 否則請先修正為更具意義的檔案名稱並且去除縮圖的檔名字首。",
"filename-bad-prefix": "您上傳的檔案名稱以 <strong>\"$1\"</strong> 開頭,是不具任何描述意義的名稱,通常由數位相機自動產生。\n請替您的檔案使用一個更具描述意義的名稱。",
"upload-success-subj": "成功上傳",
"upload-success-msg": "您已成功使用 [$2] 上傳檔案,可於此處取得檔案:[[:{{ns:file}}:$1]]",
"upload-form-label-infoform-description": "描述",
"upload-form-label-usage-title": "用法",
"upload-form-label-usage-filename": "檔案名稱",
+ "foreign-structured-upload-form-label-own-work": "這是我的作品",
"foreign-structured-upload-form-label-infoform-categories": "分類",
"foreign-structured-upload-form-label-infoform-date": "日期",
+ "foreign-structured-upload-form-label-own-work-message-local": "我確定我上傳的檔案已遵守下列 {{SITENAME}} 的服務條款與授權條款。",
+ "foreign-structured-upload-form-label-not-own-work-message-local": "若您無法同意遵守 {{SITENAME}} 的政策上傳檔案,請關閉此對話框並嘗試其他方法。",
+ "foreign-structured-upload-form-label-not-own-work-local-local": "您也可嘗試[[Special:Upload|預設的上傳頁面]]。",
"backend-fail-stream": "無法傳輸檔案 \"$1\"。",
"backend-fail-backup": "無法備份檔案 \"$1\"。",
"backend-fail-notexists": "檔案 $1 不存在。",
return;
}
- $dbw = wfGetDB( DB_MASTER );
- $dbw->begin( __METHOD__ );
-
$updates = $content->getSecondaryDataUpdates( $page->getTitle() );
DataUpdate::runUpdates( $updates );
-
- $dbw->commit( __METHOD__ );
}
/**
"grunt-contrib-jshint": "0.11.3",
"grunt-contrib-watch": "0.6.1",
"grunt-jscs": "2.1.0",
- "grunt-jsonlint": "1.0.4",
+ "grunt-jsonlint": "1.0.5",
"grunt-karma": "0.12.1",
"karma": "0.13.10",
"karma-chrome-launcher": "0.2.0",
* @return {string} return.return Rendered HTML.
*/
mw.jqueryMsg.getMessageFunction = function ( options ) {
- var failableParserFn = getFailableParserFn( options ),
- format;
+ var failableParserFn, format;
if ( options && options.format !== undefined ) {
format = options.format;
}
return function () {
+ if ( !failableParserFn ) {
+ failableParserFn = getFailableParserFn( options );
+ }
var failableResult = failableParserFn( arguments );
if ( format === 'text' || format === 'escaped' ) {
return failableResult.text();
* @return {jQuery} return.return
*/
mw.jqueryMsg.getPlugin = function ( options ) {
- var failableParserFn = getFailableParserFn( options );
+ var failableParserFn;
return function () {
+ if ( !failableParserFn ) {
+ failableParserFn = getFailableParserFn( options );
+ }
var $target = this.empty();
appendWithoutParsing( $target, failableParserFn( arguments ) );
return $target;
};
mw.jqueryMsg.parser.prototype = {
- /**
- * Cache mapping MediaWiki message keys and the value onlyCurlyBraceTransform, to the AST of the message.
- *
- * In most cases, the message is a string so this is identical.
- * (This is why we would like to move this functionality server-side).
- *
- * The two parts of the key are separated by colon. For example:
- *
- * "message-key:true": ast
- *
- * if they key is "message-key" and onlyCurlyBraceTransform is true.
- *
- * This cache is shared by all instances of mw.jqueryMsg.parser.
- *
- * NOTE: We promise, it's static - when you create this empty object
- * in the prototype, each new instance of the class gets a reference
- * to the same object.
- *
- * @static
- * @property {Object}
- */
- astCache: {},
-
/**
* Where the magic happens.
* Parses a message from the key, and swaps in replacements as necessary, wraps in jQuery
* @return {string|Array} string of '[key]' if message missing, simple string if possible, array of arrays if needs parsing
*/
getAst: function ( key ) {
- var wikiText,
- cacheKey = [ key, this.settings.onlyCurlyBraceTransform ].join( ':' );
-
- if ( this.astCache[ cacheKey ] === undefined ) {
- wikiText = this.settings.messages.get( key );
- if ( typeof wikiText !== 'string' ) {
- wikiText = '\\[' + key + '\\]';
- }
- this.astCache[ cacheKey ] = this.wikiTextToAst( wikiText );
+ var wikiText = this.settings.messages.get( key );
+ if ( typeof wikiText !== 'string' ) {
+ wikiText = '\\[' + key + '\\]';
}
- return this.astCache[ cacheKey ];
+ return this.wikiTextToAst( wikiText );
},
/**
// I am deferring the work of turning it into prototypes & objects. It's quite fast enough
// finally let's do some actual work...
- // If you add another possible rootExpression, you must update the astCache key scheme.
result = start( this.settings.onlyCurlyBraceTransform ? curlyBraceTransformExpression : expression );
/*
*/
class ImportTest extends MediaWikiLangTestCase {
- private function getInputStreamSource( $xml ) {
- if ( ini_get( 'allow_url_fopen' ) != 1 ) {
- $this->markTestSkipped( 'bug 73283: this test needs allow_url_fopen to be enabled' );
- }
- $file = 'data:application/xml,' . $xml;
- $status = ImportStreamSource::newFromFile( $file );
- if ( !$status->isGood() ) {
- throw new MWException( "Cannot create InputStreamSource." );
- }
- return $status->value;
+ private function getDataSource( $xml ) {
+ return new ImportStringSource( $xml );
}
/**
* @param string|null $redirectTitle
*/
public function testHandlePageContainsRedirect( $xml, $redirectTitle ) {
- $source = $this->getInputStreamSource( $xml );
+ $source = $this->getDataSource( $xml );
$redirect = null;
$callback = function ( Title $title, ForeignTitle $foreignTitle, $revCount,
* @param array|null $namespaces
*/
public function testSiteInfoContainsNamespaces( $xml, $namespaces ) {
- $source = $this->getInputStreamSource( $xml );
+ $source = $this->getDataSource( $xml );
$importNamespaces = null;
$callback = function ( array $siteinfo, $innerImporter ) use ( &$importNamespaces ) {
public function testUpdateRedirect( $oldText, $expectedText ) {
$this->setMwGlobals( array(
'wgServer' => '//example.org',
- 'wgScriptPath' => '/w/index.php',
+ 'wgScriptPath' => '/w',
+ 'wgScript' => '/w/index.php',
+ 'wgResourceBasePath' => '/w',
) );
$target = Title::newFromText( "testUpdateRedirect_target" );
public function testGetRedirectTarget( $title, $text ) {
$this->setMwGlobals( array(
'wgServer' => '//example.org',
- 'wgScriptPath' => '/w/index.php',
+ 'wgScriptPath' => '/w',
+ 'wgScript' => '/w/index.php',
+ 'wgResourceBasePath' => '/w',
) );
$content = new JavaScriptContent( $text );
$target = $content->getRedirectTarget();
$this->getLang()->truncate( "1234567890", 5, 'XXX', false ),
'truncate without adjustment'
);
+ $this->assertEquals(
+ "泰乐菌...",
+ $this->getLang()->truncate( "泰乐菌素123456789", 11, '...', false ),
+ 'truncate does not chop Unicode characters in half'
+ );
+ $this->assertEquals(
+ "\n泰乐菌...",
+ $this->getLang()->truncate( "\n泰乐菌素123456789", 12, '...', false ),
+ 'truncate does not chop Unicode characters in half if there is a preceding newline'
+ );
}
/**
);
// xdebug's default of 100 is too low for MediaWiki
ini_set( 'xdebug.max_nesting_level', 1000 );
+
+ // Bug T116683 serialize_precision of 100
+ // may break testing against floating point values
+ // treated with PHP's serialize()
+ ini_set( 'serialize_precision', 14 );
}
public function execute() {
assert.equal( logSpy.callCount, 2, 'mw.log.warn calls' );
} );
+ QUnit.test( 'Integration', 4, function ( assert ) {
+ var expected, logSpy;
+
+ expected = '<b><a title="Bold" href="/wiki/Bold">Bold</a>!</b>';
+ mw.messages.set( 'integration-test', '<b>[[Bold]]!</b>' );
+
+ this.suppressWarnings();
+ logSpy = this.sandbox.spy( mw.log, 'warn' );
+ assert.equal(
+ window.gM( 'integration-test' ),
+ expected,
+ 'Global function gM() works correctly'
+ );
+ assert.equal( logSpy.callCount, 1, 'mw.log.warn called' );
+ this.restoreWarnings();
+
+ assert.equal(
+ mw.message( 'integration-test' ).parse(),
+ expected,
+ 'mw.message().parse() works correctly'
+ );
+
+ assert.equal(
+ $( '<span>' ).msg( 'integration-test' ).html(),
+ expected,
+ 'jQuery plugin $.fn.msg() works correctly'
+ );
+ } );
+
}( mediaWiki, jQuery ) );