r80015 MediaWiki - Code Review archive

Repository:MediaWiki
Revision:r80014‎ | r80015 | r80016 >
Date:15:07, 11 January 2011
Author:jeroendedauw
Status:deferred
Tags:
Comment:
Tag for version 0.4.3.
Modified paths:
  • /tags/extensions/Validator/REL_0_4_3 (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/COPYING (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/INSTALL (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/README (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/RELEASE-NOTES (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/Validator.i18n.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/Validator.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/Validator_Settings.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/CriterionValidationResult.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/ItemParameterCriterion.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/ItemParameterManipulation.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/ListParameter.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/ListParameterCriterion.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/ListParameterManipulation.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/Parameter.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/ParameterCriterion.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/ParameterManipulation.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/ParserHook.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/TopologicalSort.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/ValidationError.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/ValidationErrorHandler.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/Validator.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/criteria (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionHasLength.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionInArray.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionInRange.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionIsFloat.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionIsInteger.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionIsNumeric.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionItemCount.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionMatchesRegex.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionNotEmpty.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionTrue.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionUniqueItems.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/manipulations (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/manipulations/ParamManipulationBoolean.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/manipulations/ParamManipulationBoolstr.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/manipulations/ParamManipulationFloat.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/manipulations/ParamManipulationFunctions.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/manipulations/ParamManipulationImplode.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/manipulations/ParamManipulationInteger.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/parserHooks (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/parserHooks/Validator_Describe.php (added) (history)
  • /tags/extensions/Validator/REL_0_4_3/includes/parserHooks/Validator_ListErrors.php (added) (history)

Diff [purge]

Index: tags/extensions/Validator/REL_0_4_3/INSTALL
@@ -0,0 +1,11 @@
 2+[[Validator 0.4.3]]
 3+
 4+Once you have downloaded the code, place the 'Validator' directory within
 5+your MediaWiki 'extensions' directory. Then add the following code to your
 6+LocalSettings.php file BEFORE the inclusion of any extensions using Validator:
 7+
 8+# Validator
 9+require_once( "$IP/extensions/Validator/Validator.php" );
 10+
 11+
 12+More information can be found at http://www.mediawiki.org/wiki/Extension:Validator#Setup
\ No newline at end of file
Index: tags/extensions/Validator/REL_0_4_3/RELEASE-NOTES
@@ -0,0 +1,135 @@
 2+For a documentation of all features, see http://www.mediawiki.org/wiki/Extension:Validator
 3+
 4+== Validator change log ==
 5+This change log contains a list of completed to-do's (new features, bug fixes, refactoring) for every version of Validator.
 6+
 7+
 8+=== Validator 0.4.3 ===
 9+(2011-01-11)
 10+
 11+* Added describe parser hook that enables automatic documentation generation of parser hooks defined via Validator.
 12+
 13+* Modified the ParserHook and Parameter classes to allow specifying a description message.
 14+
 15+=== Validator 0.4.2 ===
 16+(2010-10-28)
 17+
 18+* Fixed compatibility with MediaWiki 1.15.x.
 19+
 20+* Removed the lowerCaseValue field in the Parameter class and replaced it's functionality with a ParameterManipulation.
 21+
 22+=== Validator 0.4.1 ===
 23+(2010-10-20)
 24+
 25+* Made several small fixes and improvements.
 26+
 27+=== Validator 0.4 ===
 28+(2010-10-15)
 29+
 30+==== New features ====
 31+
 32+* Added ParserHook class that allows for out-of-the-box parser function and tag extension creation
 33+: with full Validator support.
 34+
 35+* Added listerrors parser hook that allows you to list all validation errors that occurred at the point it's rendered.
 36+
 37+* Added support for conditional parameter adding.
 38+
 39+==== Refactoring ====
 40+
 41+Basically everything got rewritten...
 42+
 43+* Added Parameter and ListParameter classes to replace parameter definitions in array form.
 44+
 45+* Added ParameterCriterion and ListParameterCriterion classes for better handling of parameter criteria.
 46+
 47+* Added ParameterManipulation and ListParameterManipulation classes for more structured formatting of parameters.
 48+
 49+* Added ValidationError class to better describe errors.
 50+
 51+* Replaced the error level enum by ValidationError::SEVERITY_ and ValidationError::ACTION_, which are linked in $egErrorActions.
 52+
 53+=== Validator 0.3.6 ===
 54+(2010-08-26)
 55+
 56+* Added support for 'tolower' argument in parameter info definitions.
 57+
 58+=== Validator 0.3.5 ===
 59+(2010-07-26)
 60+
 61+* Fixed issue with the original parameter name (and in some cases also value) in error messages.
 62+
 63+=== Validator 0.3.4 ===
 64+(2010-07-07)
 65+
 66+* Fixed issue with parameter reference that occurred in php 5.3 and later.
 67+
 68+* Fixed escaping issue that caused parameter names in error messages to be shown incorrectly.
 69+
 70+* Fixed small issue with parameter value trimming that caused problems when objects where passed.
 71+
 72+=== Validator 0.3.3 ===
 73+(2010-06-20)
 74+
 75+* Fixed bug that caused notices when using the ValidatorManager::manageParsedParameters method in some cases.
 76+
 77+=== Validator 0.3.2 ===
 78+(2010-06-07)
 79+
 80+* Added lower casing to parameter names, and optionally, but default on, lower-casing for parameter values.
 81+
 82+* Added removal of default parameters from the default parameter queue when used as a named parameter.
 83+
 84+=== Validator 0.3.1 ===
 85+(2010-06-04)
 86+
 87+* Added ValidatorManager::manageParsedParameters and Validator::setParameters.
 88+
 89+=== Validator 0.3 ===
 90+(2010-05-31)
 91+
 92+* Added generic default parameter support.
 93+
 94+* Added parameter dependency support.
 95+
 96+* Added full meta data support for validation and formatting functions, enabling more advanced handling of parameters.
 97+
 98+* Major refactoring to conform to MediaWiki convention.
 99+
 100+=== Validator 0.2.2 ===
 101+(2010-03-01)
 102+
 103+* Fixed potential xss vectors.
 104+
 105+* Minor code improvements.
 106+
 107+=== Validator 0.2.1 ===
 108+(2010-02-01)
 109+
 110+* Changed the inclusion of the upper bound for range validation functions.
 111+
 112+* Small language fixes.
 113+
 114+=== Validator 0.2 ===
 115+(2009-12-25)
 116+
 117+* Added handling for lists of a type, instead of having list as a type. This includes per-item-validation and per-item-defaulting.
 118+
 119+* Added list validation functions: item_count and unique_items
 120+
 121+* Added boolean, number and char types.
 122+
 123+* Added support for output types. The build in output types are lists, arrays, booleans and strings. Via a hook you can add your own output types.
 124+
 125+* Added Validator_ERRORS_MINIMAL value for $egValidatorErrorLevel.
 126+
 127+* Added warning message to ValidatorManager that will be shown for errors when egValidatorErrorLevel is Validator_ERRORS_WARN.
 128+
 129+* Added criteria support for is_boolean, has_length and regex.
 130+
 131+=== Validator 0.1 ===
 132+(2009-12-17)
 133+
 134+* Initial release, featuring parameter validation, defaulting and error generation.
 135+
 136+{{Validator see also}}
\ No newline at end of file
Index: tags/extensions/Validator/REL_0_4_3/includes/ListParameterCriterion.php
@@ -0,0 +1,36 @@
 2+<?php
 3+
 4+/**
 5+ * List parameter criterion definition class. This is for criteria
 6+ * that apply to list parameters as a whole instead of to their
 7+ * individual items.
 8+ *
 9+ * TODO: error message support
 10+ *
 11+ * @since 0.4
 12+ *
 13+ * @file ListParameterCriterion.php
 14+ * @ingroup Validator
 15+ * @ingroup Criteria
 16+ *
 17+ * @author Jeroen De Dauw
 18+ */
 19+abstract class ListParameterCriterion extends ParameterCriterion {
 20+
 21+ /**
 22+ * Constructor.
 23+ *
 24+ * @since 0.4
 25+ */
 26+ public function __construct() {
 27+ parent::__construct();
 28+ }
 29+
 30+ /**
 31+ * @see ParameterCriterion::isForLists
 32+ */
 33+ public function isForLists() {
 34+ return true;
 35+ }
 36+
 37+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/ListParameterCriterion.php
___________________________________________________________________
Added: svn:eol-style
138 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/ListParameterManipulation.php
@@ -0,0 +1,34 @@
 2+<?php
 3+
 4+/**
 5+ * List parameter manipulation base class. This is for manipulations
 6+ * that apply to list parameters as a whole instead of to their
 7+ * individual items.
 8+ *
 9+ * @since 0.4
 10+ *
 11+ * @file ListParameterManipulation.php
 12+ * @ingroup Validator
 13+ * @ingroup ParameterManipulations
 14+ *
 15+ * @author Jeroen De Dauw
 16+ */
 17+abstract class ListParameterManipulation extends ParameterManipulation {
 18+
 19+ /**
 20+ * Constructor.
 21+ *
 22+ * @since 0.4
 23+ */
 24+ public function __construct() {
 25+ parent::__construct();
 26+ }
 27+
 28+ /**
 29+ * @see ParameterManipulation::isForLists
 30+ */
 31+ public function isForLists() {
 32+ return true;
 33+ }
 34+
 35+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/ListParameterManipulation.php
___________________________________________________________________
Added: svn:eol-style
136 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/manipulations/ParamManipulationFunctions.php
@@ -0,0 +1,54 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter manipulation for assigning the value to the result of one
 6+ * or more functions with as only argument the value itself.
 7+ *
 8+ * @since 0.4.2
 9+ *
 10+ * @file ParamManipulationFunctions.php
 11+ * @ingroup Validator
 12+ * @ingroup ParameterManipulations
 13+ *
 14+ * @author Jeroen De Dauw
 15+ */
 16+class ParamManipulationFunctions extends ItemParameterManipulation {
 17+
 18+ /**
 19+ * The names of functions to apply.
 20+ *
 21+ * @since 0.4.2
 22+ *
 23+ * @var array of callbacks
 24+ */
 25+ protected $functions = array();
 26+
 27+ /**
 28+ * Constructor.
 29+ *
 30+ * @since 0.4.2
 31+ *
 32+ * You can provide an array with function names or pass each function name as a seperate argument.
 33+ */
 34+ public function __construct() {
 35+ parent::__construct();
 36+
 37+ $args = func_get_args();
 38+
 39+ if ( count( $args ) > 0 ) {
 40+ $this->functions = is_array( $args[0] ) ? $args[0] : $args;
 41+ }
 42+ }
 43+
 44+ /**
 45+ * @see ItemParameterManipulation::doManipulation
 46+ *
 47+ * @since 0.4.2
 48+ */
 49+ public function doManipulation( &$value, Parameter $parameter, array &$parameters ) {
 50+ foreach ( $this->functions as $function ) {
 51+ $value = call_user_func( $function, $value );
 52+ }
 53+ }
 54+
 55+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/manipulations/ParamManipulationFunctions.php
___________________________________________________________________
Added: svn:eol-style
156 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/manipulations/ParamManipulationImplode.php
@@ -0,0 +1,55 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter manipulation converting the value into a list by joining the items together.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file ParamManipulationImplode.php
 10+ * @ingroup Validator
 11+ * @ingroup ParameterManipulations
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+class ParamManipulationImplode extends ListParameterManipulation {
 16+
 17+ /**
 18+ * The delimiter to join the items together with.
 19+ *
 20+ * @since 0.4
 21+ *
 22+ * @var string
 23+ */
 24+ protected $delimiter;
 25+
 26+ /**
 27+ * A wrapper to encapsulate each item in.
 28+ *
 29+ * @since 0.4
 30+ *
 31+ * @var string
 32+ */
 33+ protected $wrapper;
 34+
 35+ /**
 36+ * Constructor.
 37+ *
 38+ * @since 0.4
 39+ */
 40+ public function __construct( $delimiter = ',', $wrapper = '' ) {
 41+ parent::__construct();
 42+
 43+ $this->delimiter = $delimiter;
 44+ $this->wrapper = $wrapper;
 45+ }
 46+
 47+ /**
 48+ * @see ParameterManipulation::manipulate
 49+ *
 50+ * @since 0.4
 51+ */
 52+ public function manipulate( Parameter &$parameter, array &$parameters ) {
 53+ $parameter->setValue( $this->wrapper . implode( $this->wrapper . $this->delimiter . $this->wrapper, $parameter->getValue() ) . $this->wrapper );
 54+ }
 55+
 56+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/manipulations/ParamManipulationImplode.php
___________________________________________________________________
Added: svn:eol-style
157 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/manipulations/ParamManipulationInteger.php
@@ -0,0 +1,34 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter manipulation converting the value to a integer.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file ParamManipulationInteger.php
 10+ * @ingroup Validator
 11+ * @ingroup ParameterManipulations
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+class ParamManipulationInteger extends ItemParameterManipulation {
 16+
 17+ /**
 18+ * Constructor.
 19+ *
 20+ * @since 0.4
 21+ */
 22+ public function __construct() {
 23+ parent::__construct();
 24+ }
 25+
 26+ /**
 27+ * @see ItemParameterManipulation::doManipulation
 28+ *
 29+ * @since 0.4
 30+ */
 31+ public function doManipulation( &$value, Parameter $parameter, array &$parameters ) {
 32+ $value = (int)$value;
 33+ }
 34+
 35+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/manipulations/ParamManipulationInteger.php
___________________________________________________________________
Added: svn:eol-style
136 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/manipulations/ParamManipulationBoolean.php
@@ -0,0 +1,34 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter manipulation converting the value to a boolean.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file ParamManipulationBoolean.php
 10+ * @ingroup Validator
 11+ * @ingroup ParameterManipulations
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+class ParamManipulationBoolean extends ItemParameterManipulation {
 16+
 17+ /**
 18+ * Constructor.
 19+ *
 20+ * @since 0.4
 21+ */
 22+ public function __construct() {
 23+ parent::__construct();
 24+ }
 25+
 26+ /**
 27+ * @see ItemParameterManipulation::doManipulation
 28+ *
 29+ * @since 0.4
 30+ */
 31+ public function doManipulation( &$value, Parameter $parameter, array &$parameters ) {
 32+ $value = in_array( $value, array( 'yes', 'on' ) );
 33+ }
 34+
 35+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/manipulations/ParamManipulationBoolean.php
___________________________________________________________________
Added: svn:eol-style
136 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/manipulations/ParamManipulationBoolstr.php
@@ -0,0 +1,34 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter manipulation converting the value to a boolean value as string.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file ParamManipulationBoolstr.php
 10+ * @ingroup Validator
 11+ * @ingroup ParameterManipulations
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+class ParamManipulationBoolstr extends ItemParameterManipulation {
 16+
 17+ /**
 18+ * Constructor.
 19+ *
 20+ * @since 0.4
 21+ */
 22+ public function __construct() {
 23+ parent::__construct();
 24+ }
 25+
 26+ /**
 27+ * @see ItemParameterManipulation::doManipulation
 28+ *
 29+ * @since 0.4
 30+ */
 31+ public function doManipulation( &$value, Parameter $parameter, array &$parameters ) {
 32+ $value = $value ? 'true' : 'false';
 33+ }
 34+
 35+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/manipulations/ParamManipulationBoolstr.php
___________________________________________________________________
Added: svn:eol-style
136 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/manipulations/ParamManipulationFloat.php
@@ -0,0 +1,34 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter manipulation converting the value to a float.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file ParamManipulationFloat.php
 10+ * @ingroup Validator
 11+ * @ingroup ParameterManipulations
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+class ParamManipulationFloat extends ItemParameterManipulation {
 16+
 17+ /**
 18+ * Constructor.
 19+ *
 20+ * @since 0.4
 21+ */
 22+ public function __construct() {
 23+ parent::__construct();
 24+ }
 25+
 26+ /**
 27+ * @see ItemParameterManipulation::doManipulation
 28+ *
 29+ * @since 0.4
 30+ */
 31+ public function doManipulation( &$value, Parameter $parameter, array &$parameters ) {
 32+ $value = (float)$value;
 33+ }
 34+
 35+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/manipulations/ParamManipulationFloat.php
___________________________________________________________________
Added: svn:eol-style
136 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/ParameterCriterion.php
@@ -0,0 +1,46 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter criterion base class.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file ParameterCriterion.php
 10+ * @ingroup Validator
 11+ * @ingroup Criteria
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+abstract class ParameterCriterion {
 16+
 17+ /**
 18+ * Validate a parameter against the criterion.
 19+ *
 20+ * @param Parameter $parameter
 21+ * @param array $parameters
 22+ *
 23+ * @since 0.4
 24+ *
 25+ * @return CriterionValidationResult
 26+ */
 27+ public abstract function validate( Parameter $parameter, array $parameters );
 28+
 29+ /**
 30+ * Returns if the criterion applies to lists as a whole.
 31+ *
 32+ * @since 0.4
 33+ *
 34+ * @return boolean
 35+ */
 36+ public abstract function isForLists();
 37+
 38+ /**
 39+ * Constructor.
 40+ *
 41+ * @since 0.4
 42+ */
 43+ public function __construct() {
 44+
 45+ }
 46+
 47+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/ParameterCriterion.php
___________________________________________________________________
Added: svn:eol-style
148 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/ParameterManipulation.php
@@ -0,0 +1,44 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter manipulation base class.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file ParameterManipulation.php
 10+ * @ingroup Validator
 11+ * @ingroup ParameterManipulations
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+abstract class ParameterManipulation {
 16+
 17+ /**
 18+ * Validate a parameter against the criterion.
 19+ *
 20+ * @param Parameter $parameter
 21+ * @param array $parameters
 22+ *
 23+ * @since 0.4
 24+ */
 25+ public abstract function manipulate( Parameter &$parameter, array &$parameters );
 26+
 27+ /**
 28+ * Returns if the manipulation applies to lists as a whole.
 29+ *
 30+ * @since 0.4
 31+ *
 32+ * @return boolean
 33+ */
 34+ public abstract function isForLists();
 35+
 36+ /**
 37+ * Constructor.
 38+ *
 39+ * @since 0.4
 40+ */
 41+ public function __construct() {
 42+
 43+ }
 44+
 45+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/ParameterManipulation.php
___________________________________________________________________
Added: svn:eol-style
146 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/ValidationErrorHandler.php
@@ -0,0 +1,58 @@
 2+<?php
 3+
 4+/**
 5+ * Static class for error handling.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file Validator_ErrorHandler.php
 10+ * @ingroup Validator
 11+ *
 12+ * @author Jeroen De Dauw
 13+ */
 14+final class ValidationErrorHandler {
 15+
 16+ /**
 17+ * @since 0.4
 18+ *
 19+ * @var array of ValidationError
 20+ */
 21+ protected static $errors = array();
 22+
 23+ /**
 24+ * Adds a single ValidationError.
 25+ *
 26+ * @since 0.4
 27+ *
 28+ * @param string $errorMessage
 29+ * @param integer $severity
 30+ */
 31+ public static function addError( ValidationError $error ) {
 32+ self::$errors[$error->getElement()][] = $error;
 33+ }
 34+
 35+ /**
 36+ * Adds a list of ValidationError.
 37+ *
 38+ * @since 0.4
 39+ *
 40+ * @param array $errors
 41+ */
 42+ public static function addErrors( array $errors ) {
 43+ foreach ( $errors as $error ) {
 44+ self::addError( $error );
 45+ }
 46+ }
 47+
 48+ /**
 49+ * Returns a list of all registered errors.
 50+ *
 51+ * @since 0.4
 52+ *
 53+ * @return array of ValidationError
 54+ */
 55+ public static function getErrors() {
 56+ return self::$errors;
 57+ }
 58+
 59+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/ValidationErrorHandler.php
___________________________________________________________________
Added: svn:eol-style
160 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/ValidationError.php
@@ -0,0 +1,233 @@
 2+<?php
 3+
 4+/**
 5+ * Error class.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file Validator_Error.php
 10+ * @ingroup Validator
 11+ *
 12+ * @author Jeroen De Dauw
 13+ */
 14+class ValidationError {
 15+
 16+ const SEVERITY_MINOR = 0; // Minor error. ie a decapriation notice
 17+ const SEVERITY_LOW = 1; // Lower-then-normal severity. ie an unknown parameter
 18+ const SEVERITY_NORMAL = 2; // Normal severiry. ie an invalid value provided
 19+ const SEVERITY_HIGH = 3; // Higher-then-normal severity. ie an invalid value for a significant parameter
 20+ const SEVERITY_FATAL = 4; // Fatal error. Either a missing or an invalid required parameter
 21+
 22+ const ACTION_IGNORE = 0; // Ignore the error
 23+ const ACTION_LOG = 1; // Log the error
 24+ const ACTION_WARN = 2; // Warn that there is an error
 25+ const ACTION_SHOW = 3; // Show the error
 26+ const ACTION_DEMAND = 4; // Show the error and don't render output
 27+
 28+ public $message;
 29+ public $severity;
 30+
 31+ /**
 32+ * List of 'tags' for the error. This is mainly ment for indicating an error
 33+ * type, such as 'missing parameter' or 'invalid value', but allows for multiple
 34+ * such indications.
 35+ *
 36+ * @since 0.4
 37+ *
 38+ * @var array
 39+ */
 40+ protected $tags;
 41+
 42+ /**
 43+ * Where the error occured.
 44+ *
 45+ * @since 0.4
 46+ *
 47+ * @var mixed: string or false
 48+ */
 49+ public $element;
 50+
 51+ /**
 52+ * @since 0.4
 53+ *
 54+ * @param string $message
 55+ * @param integer $severity
 56+ */
 57+ public function __construct( $message, $severity = self::SEVERITY_NORMAL, $element = false, array $tags = array() ) {
 58+ $this->message = $message;
 59+ $this->severity = $severity;
 60+ $this->element = $element;
 61+ $this->tags = $tags;
 62+ }
 63+
 64+ /**
 65+ * Adds one or more tags.
 66+ *
 67+ * @since 0.4.1
 68+ *
 69+ * @param mixed $criteria string or array of string
 70+ */
 71+ public function addTags() {
 72+ $args = func_get_args();
 73+ $this->tags = array_merge( $this->tags, is_array( $args[0] ) ? $args[0] : $args );
 74+ }
 75+
 76+ /**
 77+ * Returns the error message describing the error.
 78+ *
 79+ * @since 0.4
 80+ *
 81+ * @return string
 82+ */
 83+ public function getMessage() {
 84+ return $this->message;
 85+ }
 86+
 87+ /**
 88+ * Returns the element this error occured at, or 'unknown' when i's unknown.
 89+ *
 90+ * @since 0.4
 91+ *
 92+ * @return string
 93+ */
 94+ public function getElement() {
 95+ return $this->element === false ? 'unknown' : $this->element;
 96+ }
 97+
 98+ /**
 99+ * Returns the severity of the error.
 100+ *
 101+ * @since 0.4
 102+ *
 103+ * @return integer Element of the ValidationError::SEVERITY_ enum
 104+ */
 105+ public function getSeverity() {
 106+ return $this->severity;
 107+ }
 108+
 109+ /**
 110+ * Returns if the severity is equal to or bigger then the provided one.
 111+ *
 112+ * @since 0.4
 113+ *
 114+ * @param integer $severity
 115+ *
 116+ * @return boolean
 117+ */
 118+ public function hasSeverity( $severity ) {
 119+ return $this->severity >= $severity;
 120+ }
 121+
 122+ /**
 123+ * Returns if the error has a certain tag.
 124+ *
 125+ * @since 0.4.1
 126+ *
 127+ * @param string $tag
 128+ *
 129+ * @return boolean
 130+ */
 131+ public function hasTag( $tag ) {
 132+ return in_array( $tag, $this->tags );
 133+ }
 134+
 135+ /**
 136+ * Returns the tags.
 137+ *
 138+ * @since 0.4.1
 139+ *
 140+ * @return array
 141+ */
 142+ public function getTags() {
 143+ return $this->tags;
 144+ }
 145+
 146+ /**
 147+ * Returns the action associated with the errors severity.
 148+ *
 149+ * @since 0.4
 150+ *
 151+ * @return integer Element of the ValidationError::ACTION_ enum
 152+ */
 153+ public function getAction() {
 154+ global $egErrorActions;
 155+
 156+ if ( $this->severity === self::SEVERITY_FATAL ) {
 157+ // This action should not be configurable, as lowering it would break in the Validator class.
 158+ return self::ACTION_DEMAND;
 159+ }
 160+ else if ( array_key_exists( $this->severity, $egErrorActions ) ) {
 161+ return $egErrorActions[$this->severity];
 162+ }
 163+ else {
 164+ throw new Exception( "No action associated with error severity '$this->severity'" );
 165+ }
 166+ }
 167+
 168+ /**
 169+ * Returns if the action associated with the severity is equal to or bigger then the provided one.
 170+ *
 171+ * @since 0.4
 172+ *
 173+ * @return boolean
 174+ */
 175+ public function hasAction( $action ) {
 176+ return $this->getAction() >= $action;
 177+ }
 178+
 179+ /**
 180+ * Returns if the error is fatal.
 181+ *
 182+ * @since 0.4
 183+ *
 184+ * @return boolean
 185+ */
 186+ public function isFatal() {
 187+ return $this->hasSeverity( self::SEVERITY_FATAL );
 188+ }
 189+
 190+ /**
 191+ * Returns if the error should be logged.
 192+ *
 193+ * @since 0.4
 194+ *
 195+ * @return boolean
 196+ */
 197+ public function shouldLog() {
 198+ return $this->hasAction( self::ACTION_LOG );
 199+ }
 200+
 201+ /**
 202+ * Returns if there should be a warning that errors are present.
 203+ *
 204+ * @since 0.4
 205+ *
 206+ * @return boolean
 207+ */
 208+ public function shouldWarn() {
 209+ return $this->hasAction( self::ACTION_WARN );
 210+ }
 211+
 212+ /**
 213+ * Returns if the error message should be shown.
 214+ *
 215+ * @since 0.4
 216+ *
 217+ * @return boolean
 218+ */
 219+ public function shouldShow() {
 220+ return $this->hasAction( self::ACTION_SHOW );
 221+ }
 222+
 223+ /**
 224+ * Returns if the error message should be shown, and the output not be rendered.
 225+ *
 226+ * @since 0.4
 227+ *
 228+ * @return boolean
 229+ */
 230+ public function shouldDemand() {
 231+ return $this->hasAction( self::ACTION_DEMAND );
 232+ }
 233+
 234+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/ValidationError.php
___________________________________________________________________
Added: svn:eol-style
1235 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/CriterionValidationResult.php
@@ -0,0 +1,104 @@
 2+<?php
 3+
 4+/**
 5+ * Class to hold parameter validation result info.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file CriterionValidationResult.php
 10+ * @ingroup Validator
 11+ *
 12+ * @author Jeroen De Dauw
 13+ */
 14+class CriterionValidationResult {
 15+
 16+ /**
 17+ * @since 0.4
 18+ *
 19+ * @var array of ValidationError
 20+ */
 21+ protected $errors = array();
 22+
 23+ /**
 24+ * @since 0.4
 25+ *
 26+ * @var array of string
 27+ */
 28+ protected $invalidItems = array();
 29+
 30+ /**
 31+ * Constructor.
 32+ *
 33+ * @since 0.4
 34+ */
 35+ public function __construct() {
 36+
 37+ }
 38+
 39+ /**
 40+ * Adds a single error object.
 41+ *
 42+ * @since 0.4
 43+ *
 44+ * @param ValidationError $error
 45+ */
 46+ public function addError( ValidationError $error ) {
 47+ $this->errors[] = $error;
 48+ }
 49+
 50+ /**
 51+ * Adds a single invalid item.
 52+ *
 53+ * @since 0.4
 54+ *
 55+ * @param string $item
 56+ */
 57+ public function addInvalidItem( $item ) {
 58+ $this->invalidItems[] = $item;
 59+ }
 60+
 61+ /**
 62+ * Gets the errors.
 63+ *
 64+ * @since 0.4
 65+ *
 66+ * @return array of ValidationError
 67+ */
 68+ public function getErrors() {
 69+ return $this->errors;
 70+ }
 71+
 72+ /**
 73+ * Gets the invalid items.
 74+ *
 75+ * @since 0.4
 76+ *
 77+ * @return array of string
 78+ */
 79+ public function getInvalidItems() {
 80+ return $this->invalidItems;
 81+ }
 82+
 83+ /**
 84+ * Returns whether no errors occured.
 85+ *
 86+ * @since 0.4
 87+ *
 88+ * @return boolean
 89+ */
 90+ public function isValid() {
 91+ return count( $this->errors ) == 0 && !$this->hasInvalidItems();
 92+ }
 93+
 94+ /**
 95+ * Returns there are any invalid items.
 96+ *
 97+ * @since 0.4
 98+ *
 99+ * @return boolean
 100+ */
 101+ public function hasInvalidItems() {
 102+ return count( $this->invalidItems ) != 0;
 103+ }
 104+
 105+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/CriterionValidationResult.php
___________________________________________________________________
Added: svn:eol-style
1106 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/parserHooks/Validator_ListErrors.php
@@ -0,0 +1,220 @@
 2+<?php
 3+
 4+/**
 5+ * Class for the 'listerrors' parser hooks.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file Validator_ListErrors.php
 10+ * @ingroup Validator
 11+ *
 12+ * @author Jeroen De Dauw
 13+ */
 14+class ValidatorListErrors extends ParserHook {
 15+
 16+ /**
 17+ * Array to map the possible values for the 'minseverity' parameter
 18+ * to their equivalent in the ValidationError::SEVERITY_ enum.
 19+ *
 20+ * @since 0.4
 21+ *
 22+ * @var array
 23+ */
 24+ protected static $severityMap = array(
 25+ 'minor' => ValidationError::SEVERITY_MINOR,
 26+ 'low' => ValidationError::SEVERITY_LOW,
 27+ 'normal' => ValidationError::SEVERITY_NORMAL,
 28+ 'high' => ValidationError::SEVERITY_HIGH,
 29+ 'fatal' => ValidationError::SEVERITY_FATAL
 30+ );
 31+
 32+ /**
 33+ * No LST in pre-5.3 PHP *sigh*.
 34+ * This is to be refactored as soon as php >=5.3 becomes acceptable.
 35+ */
 36+ public static function staticMagic( array &$magicWords, $langCode ) {
 37+ $className = __CLASS__;
 38+ $instance = new $className();
 39+ return $instance->magic( $magicWords, $langCode );
 40+ }
 41+
 42+ /**
 43+ * No LST in pre-5.3 PHP *sigh*.
 44+ * This is to be refactored as soon as php >=5.3 becomes acceptable.
 45+ */
 46+ public static function staticInit( Parser &$wgParser ) {
 47+ $className = __CLASS__;
 48+ $instance = new $className();
 49+ return $instance->init( $wgParser );
 50+ }
 51+
 52+ /**
 53+ * Gets the name of the parser hook.
 54+ * @see ParserHook::getName
 55+ *
 56+ * @since 0.4
 57+ *
 58+ * @return string
 59+ */
 60+ protected function getName() {
 61+ return 'listerrors';
 62+ }
 63+
 64+ /**
 65+ * Returns an array containing the parameter info.
 66+ * @see ParserHook::getParameterInfo
 67+ *
 68+ * @since 0.4
 69+ *
 70+ * @return array of Parameter
 71+ */
 72+ protected function getParameterInfo( $type ) {
 73+ global $egValidatorErrListMin;
 74+
 75+ $params = array();
 76+
 77+ $params['minseverity'] = new Parameter( 'minseverity' );
 78+ $params['minseverity']->setDefault( $egValidatorErrListMin );
 79+ $params['minseverity']->addCriteria( new CriterionInArray( array_keys( self::$severityMap ) ) );
 80+ $params['minseverity']->setDescription( wfMsg( 'validator-listerrors-par-minseverity' ) );
 81+
 82+ return $params;
 83+ }
 84+
 85+ /**
 86+ * Returns the list of default parameters.
 87+ * @see ParserHook::getDefaultParameters
 88+ *
 89+ * @since 0.4
 90+ *
 91+ * @return array
 92+ */
 93+ protected function getDefaultParameters( $type ) {
 94+ return array( 'minseverity' );
 95+ }
 96+
 97+ /**
 98+ * Renders and returns the output.
 99+ * @see ParserHook::render
 100+ *
 101+ * @since 0.4
 102+ *
 103+ * @param array $parameters
 104+ *
 105+ * @return string
 106+ */
 107+ public function render( array $parameters ) {
 108+ $errorList = $this->getErrorList(
 109+ ValidationErrorHandler::getErrors(),
 110+ self::$severityMap[$parameters['minseverity']]
 111+ );
 112+
 113+ return $errorList;
 114+ }
 115+
 116+ /**
 117+ * Returns a list of errors in wikitext.
 118+ *
 119+ * @since 0.4
 120+ *
 121+ * @param array $errors
 122+ * @param integer $minSeverity
 123+ *
 124+ * @return string
 125+ */
 126+ public function getErrorList( array $errors, $minSeverity = ValidationError::SEVERITY_MINOR ) {
 127+ $elementHtml = array();
 128+
 129+ if ( count( $errors ) == 0 ) {
 130+ return '';
 131+ }
 132+
 133+ $elements = array_keys( $errors );
 134+ natcasesort( $elements );
 135+
 136+ foreach ( $elements as $element ) {
 137+ $elementErrors = $this->getErrorListForElement( $errors[$element], $element, $minSeverity );
 138+
 139+ if ( $elementErrors ) {
 140+ $elementHtml[] = $elementErrors;
 141+ }
 142+ }
 143+
 144+ if ( count( $elementHtml ) == 0 ) {
 145+ return '';
 146+ }
 147+
 148+ return Html::element(
 149+ 'h2',
 150+ array(),
 151+ wfMsg( 'validator-listerrors-errors' )
 152+ ) . implode( "\n\n", $elementHtml );
 153+ }
 154+
 155+ /**
 156+ * Returns wikitext listing the errors for a single element.
 157+ *
 158+ * @since 0.4
 159+ *
 160+ * @param array $allErrors
 161+ * @param string $element
 162+ * @param integer $minSeverity
 163+ *
 164+ * @return mixed String or false
 165+ */
 166+ public function getErrorListForElement( array $allErrors, $element, $minSeverity = ValidationError::SEVERITY_MINOR ) {
 167+ $errors = array();
 168+
 169+ foreach ( $allErrors as $error ) {
 170+ if ( $error->hasSeverity( $minSeverity ) ) {
 171+ $errors[] = $error;
 172+ }
 173+ }
 174+
 175+ if ( count( $errors ) > 0 ) {
 176+ $lines = array();
 177+
 178+ foreach ( $errors as $error ) {
 179+ // TODO: switch on severity
 180+ $lines[] = '* ' . wfMsgExt(
 181+ 'validator-listerrors-severity-message',
 182+ 'parsemag',
 183+ $this->getSeverityMessage( $error->getSeverity() ),
 184+ $error->message
 185+ );
 186+ }
 187+
 188+ return '<h3>' . htmlspecialchars( $element ) . "</h3>\n\n" . implode( "\n", $lines );
 189+ }
 190+ else {
 191+ return false;
 192+ }
 193+ }
 194+
 195+ /**
 196+ * Returns a message for a severity.
 197+ *
 198+ * @since 0.4
 199+ *
 200+ * @param integer $severity
 201+ *
 202+ * @return string
 203+ */
 204+ protected function getSeverityMessage( $severity ) {
 205+ static $reverseMap = false;
 206+
 207+ if ( $reverseMap === false ) {
 208+ $reverseMap = array_flip( self::$severityMap );
 209+ }
 210+
 211+ return wfMsg( 'validator-listerrors-' . $reverseMap[$severity] );
 212+ }
 213+
 214+ /**
 215+ * @see ParserHook::getDescription()
 216+ */
 217+ public function getDescription() {
 218+ return wfMsg( 'validator-listerrors-description' );
 219+ }
 220+
 221+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/parserHooks/Validator_ListErrors.php
___________________________________________________________________
Added: svn:eol-style
1222 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/parserHooks/Validator_Describe.php
@@ -0,0 +1,458 @@
 2+<?php
 3+
 4+/**
 5+ * Class for the 'describe' parser hooks.
 6+ *
 7+ * @since 0.4.3
 8+ *
 9+ * @file Validator_Describe.php
 10+ * @ingroup Validator
 11+ *
 12+ * @licence GNU GPL v3 or later
 13+ *
 14+ * @author Jeroen De Dauw < jeroendedauw@gmail.com >
 15+ */
 16+class ValidatorDescribe extends ParserHook {
 17+
 18+ /**
 19+ * No LST in pre-5.3 PHP *sigh*.
 20+ * This is to be refactored as soon as php >=5.3 becomes acceptable.
 21+ */
 22+ public static function staticMagic( array &$magicWords, $langCode ) {
 23+ $className = __CLASS__;
 24+ $instance = new $className();
 25+ return $instance->magic( $magicWords, $langCode );
 26+ }
 27+
 28+ /**
 29+ * No LST in pre-5.3 PHP *sigh*.
 30+ * This is to be refactored as soon as php >=5.3 becomes acceptable.
 31+ */
 32+ public static function staticInit( Parser &$wgParser ) {
 33+ $className = __CLASS__;
 34+ $instance = new $className();
 35+ return $instance->init( $wgParser );
 36+ }
 37+
 38+ /**
 39+ * Gets the name of the parser hook.
 40+ * @see ParserHook::getName
 41+ *
 42+ * @since 0.4.3
 43+ *
 44+ * @return string
 45+ */
 46+ protected function getName() {
 47+ return 'describe';
 48+ }
 49+
 50+ /**
 51+ * Returns an array containing the parameter info.
 52+ * @see ParserHook::getParameterInfo
 53+ *
 54+ * @since 0.4.3
 55+ *
 56+ * @return array of Parameter
 57+ */
 58+ protected function getParameterInfo( $type ) {
 59+ $params = array();
 60+
 61+ $params['hooks'] = new ListParameter( 'hooks' );
 62+ $params['hooks']->setDefault( array_keys( ParserHook::getRegisteredParserHooks() ) );
 63+ $params['hooks']->setDescription( wfMsg( 'validator-describe-par-hooks' ) );
 64+ $params['hooks']->addAliases( 'hook' );
 65+
 66+ $params['pre'] = new Parameter( 'pre', Parameter::TYPE_BOOLEAN );
 67+ $params['pre']->setDefault( 'off' );
 68+ $params['pre']->setDescription( wfMsg( 'validator-describe-par-pre' ) );
 69+
 70+ return $params;
 71+ }
 72+
 73+ /**
 74+ * Returns the list of default parameters.
 75+ * @see ParserHook::getDefaultParameters
 76+ *
 77+ * @since 0.4.3
 78+ *
 79+ * @return array
 80+ */
 81+ protected function getDefaultParameters( $type ) {
 82+ return array( 'hooks' );
 83+ }
 84+
 85+ /**
 86+ * Renders and returns the output.
 87+ * @see ParserHook::render
 88+ *
 89+ * @since 0.4.3
 90+ *
 91+ * @param array $parameters
 92+ *
 93+ * @return string
 94+ */
 95+ public function render( array $parameters ) {
 96+ $parts = array();
 97+
 98+ // Loop over the hooks for which the docs should be added.
 99+ foreach ( $parameters['hooks'] as $hookName ) {
 100+ $parserHook = $this->getParserHookInstance( $hookName );
 101+
 102+ if ( $parserHook === false ) {
 103+ $parts[] = wfMsgExt( 'validator-describe-notfound', 'parsemag', $hookName );
 104+ }
 105+ else {
 106+ $parts[] = $this->getParserHookDescription( $hookName, $parameters, $parserHook );
 107+ }
 108+ }
 109+
 110+ // Parse the wikitext to HTML.
 111+ $output = $this->parser->parse(
 112+ implode( "\n\n", $parts ),
 113+ $this->parser->mTitle,
 114+ $this->parser->mOptions,
 115+ true,
 116+ false
 117+ );
 118+
 119+ // This str_replace is a hack to allow for placing <pre>s into <pre>s, without breaking the outer ones.
 120+ return str_replace( 'pre!&gt;', 'pre&gt;', $output->getText() );
 121+ }
 122+
 123+ /**
 124+ * Returns the wikitext description for a single parser hook.
 125+ *
 126+ * @since 0.4.3
 127+ *
 128+ * @param string $hookName
 129+ * @param array $parameters
 130+ * @param ParserHook $parserHook
 131+ *
 132+ * @return string
 133+ */
 134+ protected function getParserHookDescription( $hookName, array $parameters, ParserHook $parserHook ) {
 135+ global $wgLang;
 136+
 137+ $descriptionData = $parserHook->getDescriptionData( ParserHook::TYPE_TAG ); // TODO
 138+ $this->sortParameters( $descriptionData['parameters'], $descriptionData['defaults'] );
 139+
 140+ $description =
 141+ ( $parameters['pre'] ? '== ' : '<h2>' ) .
 142+ $hookName .
 143+ ( $parameters['pre'] ? ' ==' : '</h2>' );
 144+
 145+ if ( $parameters['pre'] ) {
 146+ $description .= "\n<!-- " . wfMsg( 'validator-describe-autogen' ) . ' -->';
 147+ }
 148+
 149+ $description .= "\n\n";
 150+
 151+ if ( $descriptionData['description'] !== false ) {
 152+ $description .= wfMsgExt( 'validator-describe-descriptionmsg', 'parsemag', $descriptionData['description'] );
 153+ $description .= "\n\n";
 154+ }
 155+
 156+ if ( count( $descriptionData['names'] ) > 1 ) {
 157+ $aliases = array();
 158+
 159+ foreach ( $descriptionData['names'] as $name ) {
 160+ if ( $name != $hookName ) {
 161+ $aliases[] = $name;
 162+ }
 163+ }
 164+
 165+ $description .= wfMsgExt( 'validator-describe-aliases', 'parsemag', $wgLang->listToText( $aliases ), count( $aliases ) );
 166+ $description .= "\n\n";
 167+ }
 168+
 169+ if ( $parserHook->forTagExtensions || $parserHook->forParserFunctions ) {
 170+ if ( $parserHook->forTagExtensions && $parserHook->forParserFunctions ) {
 171+ $description .= wfMsg( 'validator-describe-bothhooks' );
 172+ }
 173+ else if ( $parserHook->forTagExtensions ) {
 174+ $description .= wfMsg( 'validator-describe-tagextension' );
 175+ }
 176+ else { // if $parserHook->forParserFunctions
 177+ $description .= wfMsg( 'validator-describe-parserfunction' );
 178+ }
 179+
 180+ $description .= "\n\n";
 181+ }
 182+
 183+ $description .= $this->getParameterTable( $descriptionData['parameters'], $descriptionData['defaults'], $parameters['pre'] );
 184+
 185+ if ( $parserHook->forTagExtensions || $parserHook->forParserFunctions ) {
 186+ $description .= $this->getSyntaxExamples( $hookName, $descriptionData['parameters'], $parserHook, $descriptionData['defaults'], $parameters['pre'] );
 187+ }
 188+
 189+ if ( $parameters['pre'] ) {
 190+ $description = '<pre>' . $description . '</pre>';
 191+ }
 192+
 193+ return $description;
 194+ }
 195+
 196+ /**
 197+ * Sorts the provided parameters array to match the default parameter order.
 198+ *
 199+ * @since 0.4.3
 200+ *
 201+ * @param array of Parameter $parameters
 202+ * @param array of string $defaults
 203+ */
 204+ protected function sortParameters( array &$parameters, array $defaults ) {
 205+ $sort = array();
 206+ $count = 9000;
 207+
 208+ foreach ( $parameters as $parameter ) {
 209+ $position = array_search( $parameter->getName(), $defaults );
 210+
 211+ if ( $position === false ) {
 212+ $count++;
 213+ $sort[$count] = $parameter;
 214+ }
 215+ else {
 216+ $sort[$position] = $parameter;
 217+ }
 218+ }
 219+
 220+ ksort( $sort );
 221+ $parameters = array_values( $sort );
 222+ }
 223+
 224+ /**
 225+ * Returns the wikitext for some syntax examples.
 226+ *
 227+ * @since 0.4.3
 228+ *
 229+ * @param string $hookName
 230+ * @param array $parameters
 231+ * @param ParserHook $parserHook
 232+ * @param array $defaults
 233+ * @param boolean $pre
 234+ *
 235+ * @return string
 236+ */
 237+ protected function getSyntaxExamples( $hookName, array $parameters, ParserHook $parserHook, array $defaults, $pre ) {
 238+ $result = "\n\n" .
 239+ ( $pre ? '=== ' : '<h3>' ) .
 240+ wfMsg( 'validator-describe-syntax' ) .
 241+ ( $pre ? ' ===' : '</h3>' );
 242+ $result .= "\n\n";
 243+
 244+ $params = array();
 245+ $requiredParams = array();
 246+ $plainParams = array();
 247+
 248+ foreach ( $parameters as $parameter ) {
 249+ $params[$parameter->getName()] = '{' . $parameter->getTypeMessage() . '}';
 250+ $plainParams[$parameter->getName()] = $parameter->getTypeMessage();
 251+
 252+ if ( $parameter->isRequired() ) {
 253+ $requiredParams[$parameter->getName()] = '{' . $parameter->getTypeMessage() . '}';
 254+ }
 255+ }
 256+
 257+ if ( $parserHook->forTagExtensions ) {
 258+ $result .= "'''" . wfMsg( 'validator-describe-tagmin' ) . "'''\n\n";
 259+
 260+ $result .= "<pre!><nowiki>\n" . Xml::element(
 261+ $hookName,
 262+ $requiredParams
 263+ ) . "</nowiki></pre!>";
 264+
 265+ $result .= "'''" . wfMsg( 'validator-describe-tagmax' ) . "'''\n\n";
 266+
 267+ // TODO: multiline when long
 268+ $result .= "<pre!><nowiki>\n" . Xml::element(
 269+ $hookName,
 270+ $params
 271+ ) . "</nowiki></pre!>";
 272+
 273+ if ( count( $defaults ) > 0 ) {
 274+ $result .= "'''" . wfMsg( 'validator-describe-tagdefault' ) . "'''\n\n";
 275+
 276+ foreach ( $plainParams as $name => $type ) {
 277+ $contents = '{' . $name . ', ' . $type . '}';
 278+ break;
 279+ }
 280+
 281+ $result .= "<pre!><nowiki>\n" . Xml::element(
 282+ $hookName,
 283+ array_slice( $params, 1 ),
 284+ $contents
 285+ ) . "</nowiki></pre!>";
 286+ }
 287+ }
 288+
 289+ if ( $parserHook->forParserFunctions ) {
 290+ $result .= "'''" . wfMsg( 'validator-describe-pfmin' ) . "'''\n\n";
 291+
 292+ $result .= "<pre!><nowiki>\n" .
 293+ $this->buildParserFunctionSyntax( $hookName, $requiredParams )
 294+ . "</nowiki></pre!>";
 295+
 296+ $result .= "'''" . wfMsg( 'validator-describe-pfmax' ) . "'''\n\n";
 297+
 298+ $result .= "<pre!><nowiki>\n" .
 299+ $this->buildParserFunctionSyntax( $hookName, $params )
 300+ . "</nowiki></pre!>";
 301+
 302+ if ( count( $defaults ) > 0 ) {
 303+ $result .= "'''" . wfMsg( 'validator-describe-pfdefault' ) . "'''\n\n";
 304+
 305+ $result .= "<pre!><nowiki>\n" .
 306+ $this->buildParserFunctionSyntax( $hookName, $plainParams, $defaults )
 307+ . "</nowiki></pre!>";
 308+ }
 309+ }
 310+
 311+ return $result;
 312+ }
 313+
 314+ /**
 315+ * Builds the wikitext syntax for a parser function.
 316+ *
 317+ * @since 0.4.3
 318+ *
 319+ * @param string $functionName
 320+ * @param array $parameters Parameters (keys) and their type (values)
 321+ * @param array $defaults
 322+ *
 323+ * @return string
 324+ */
 325+ protected function buildParserFunctionSyntax( $functionName, array $parameters, array $defaults = array() ) {
 326+ $arguments = array();
 327+
 328+ foreach ( $parameters as $name => $type ) {
 329+ if ( in_array( $name, $defaults ) ) {
 330+ $arguments[] = '{' . $name . ', ' . $type . '}';
 331+ }
 332+ else {
 333+ $arguments[] = "$name=$type";
 334+ }
 335+ }
 336+
 337+ $singleLine = count( $arguments ) <= 3;
 338+ $delimiter = $singleLine ? '|' : "\n| ";
 339+ $wrapper = $singleLine ? '' : "\n";
 340+
 341+ return "{{#$functionName:$wrapper" . implode( $delimiter, $arguments ) . $wrapper . '}}';
 342+ }
 343+
 344+ /**
 345+ * Returns the wikitext for a table listing the provided parameters.
 346+ *
 347+ * @since 0.4.3
 348+ *
 349+ * @param array $parameters
 350+ * @param array $defaults
 351+ * @param boolean $pre
 352+ *
 353+ * @return string
 354+ */
 355+ protected function getParameterTable( array $parameters, array $defaults, $pre ) {
 356+ $tableRows = array();
 357+
 358+ foreach ( $parameters as $parameter ) {
 359+ $tableRows[] = $this->getDescriptionRow( $parameter, $defaults );
 360+ }
 361+
 362+ if ( count( $tableRows ) > 0 ) {
 363+ $tableRows = array_merge( array(
 364+ "! #\n" .
 365+ '!' . wfMsg( 'validator-describe-header-parameter' ) ."\n" .
 366+ '!' . wfMsg( 'validator-describe-header-aliases' ) ."\n" .
 367+ '!' . wfMsg( 'validator-describe-header-type' ) ."\n" .
 368+ '!' . wfMsg( 'validator-describe-header-default' ) ."\n" .
 369+ '!' . wfMsg( 'validator-describe-header-description' )
 370+ ), $tableRows );
 371+
 372+ $table = implode( "\n|-\n", $tableRows );
 373+
 374+ $h3 =
 375+ ( $pre ? '=== ' : '<h3>' ) .
 376+ wfMsg( 'validator-describe-parameters' ) .
 377+ ( $pre ? ' ===' : '</h3>' );
 378+
 379+ $table = "$h3\n\n" .
 380+ '{| class="wikitable sortable"' . "\n" .
 381+ $table .
 382+ "\n|}";
 383+ }
 384+
 385+ return $table;
 386+ }
 387+
 388+ /**
 389+ * Returns the wikitext for a table row describing a single parameter.
 390+ *
 391+ * @since 0.4.3
 392+ *
 393+ * @param Parameter $parameter
 394+ * @param array $defaults
 395+ *
 396+ * @return string
 397+ */
 398+ protected function getDescriptionRow( Parameter $parameter, array $defaults ) {
 399+ $aliases = $parameter->getAliases();
 400+ $aliases = count( $aliases ) > 0 ? implode( ', ', $aliases ) : '-';
 401+
 402+ $description = $parameter->getDescription();
 403+ if ( $description === false ) $description = '-';
 404+
 405+ $type = $parameter->getTypeMessage();
 406+
 407+ $number = 0;
 408+ $isDefault = false;
 409+
 410+ foreach ( $defaults as $default ) {
 411+ $number++;
 412+
 413+ if ( $default == $parameter->getName() ) {
 414+ $isDefault = true;
 415+ break;
 416+ }
 417+ }
 418+
 419+ $default = $parameter->isRequired() ? "''" . wfMsg( 'validator-describe-required' ) . "''" : $parameter->getDefault();
 420+ if ( is_array( $default ) ) $default = implode( ', ', $default );
 421+ if ( $default === '' ) $default = "''" . wfMsg( 'validator-describe-empty' ) . "''";
 422+
 423+ if ( !$isDefault ) {
 424+ $number = '-';
 425+ }
 426+
 427+ return <<<EOT
 428+| {$number}
 429+| {$parameter->getName()}
 430+| {$aliases}
 431+| {$type}
 432+| {$default}
 433+| {$description}
 434+EOT;
 435+ }
 436+
 437+ /**
 438+ * Returns an instance of the class handling the specified parser hook,
 439+ * or false if there is none.
 440+ *
 441+ * @since 0.4.3
 442+ *
 443+ * @param string $parserHookName
 444+ *
 445+ * @return mixed ParserHook or false
 446+ */
 447+ protected function getParserHookInstance( $parserHookName ) {
 448+ $className = ParserHook::getHookClassName( $parserHookName );
 449+ return $className !== false && class_exists( $className ) ? new $className() : false;
 450+ }
 451+
 452+ /**
 453+ * @see ParserHook::getDescription()
 454+ */
 455+ public function getDescription() {
 456+ return wfMsg( 'validator-describe-description' );
 457+ }
 458+
 459+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/parserHooks/Validator_Describe.php
___________________________________________________________________
Added: svn:eol-style
1460 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/ListParameter.php
@@ -0,0 +1,234 @@
 2+<?php
 3+
 4+/**
 5+ * Class for list parameters.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file ListParameter.php
 10+ * @ingroup Validator
 11+ *
 12+ * @author Jeroen De Dauw
 13+ */
 14+class ListParameter extends Parameter {
 15+
 16+ /**
 17+ * Indicates if errors in list items should cause the item to be omitted,
 18+ * versus having the whole list be set to it's default.
 19+ *
 20+ * @since 0.4
 21+ *
 22+ * @var boolean
 23+ */
 24+ public static $perItemValidation = true;
 25+
 26+ /**
 27+ * The default delimiter for lists, used when the parameter definition does not specify one.
 28+ *
 29+ * @since 0.4
 30+ *
 31+ * @var string
 32+ */
 33+ const DEFAULT_DELIMITER = ',';
 34+
 35+ /**
 36+ * The list delimiter.
 37+ *
 38+ * @since 0.4
 39+ *
 40+ * @var string
 41+ */
 42+ protected $delimiter;
 43+
 44+ /**
 45+ * List of criteria the parameter value as a whole needs to hold against.
 46+ *
 47+ * @since 0.4
 48+ *
 49+ * @var array of ListParameterCriterion
 50+ */
 51+ protected $listCriteria;
 52+
 53+ /**
 54+ * Holder for temporary information needed in the itemIsValid callback.
 55+ *
 56+ * @since 0.4
 57+ *
 58+ * @var array
 59+ */
 60+ protected $tempInvalidList;
 61+
 62+ /**
 63+ * Constructor.
 64+ *
 65+ * @since 0.4
 66+ *
 67+ * @param string $name
 68+ * @param string $delimiter
 69+ * @param mixed $type
 70+ * @param mixed $default Use null for no default (which makes the parameter required)
 71+ * @param array $aliases
 72+ * @param array $criteria
 73+ */
 74+ public function __construct( $name, $delimiter = ListParameter::DEFAULT_DELIMITER, $type = Parameter::TYPE_STRING,
 75+ $default = null, array $aliases = array(), array $criteria = array() ) {
 76+ $itemCriteria = array();
 77+ $listCriteria = array();
 78+
 79+ $this->cleanCriteria( $criteria );
 80+
 81+ foreach ( $criteria as $criterion ) {
 82+ if ( $criterion->isForLists() ) {
 83+ $listCriteria[] = $criterion;
 84+ }
 85+ else {
 86+ $itemCriteria[] = $criterion;
 87+ }
 88+ }
 89+
 90+ $this->listCriteria = $listCriteria;
 91+
 92+ parent::__construct( $name, $type, $default, $aliases, $itemCriteria );
 93+
 94+ $this->delimiter = $delimiter;
 95+
 96+ }
 97+
 98+ /**
 99+ * Returns if the parameter is a list or not.
 100+ *
 101+ * @since 0.4
 102+ *
 103+ * @return boolean
 104+ */
 105+ public function isList() {
 106+ return true;
 107+ }
 108+
 109+ /**
 110+ * Sets the $value to a cleaned value of $originalValue.
 111+ *
 112+ * @since 0.4
 113+ */
 114+ protected function cleanValue() {
 115+ if ( $this->originalValue == '' ) {
 116+ // If no value is provided, there are no items, and not a single empty item.
 117+ $this->value = array();
 118+ }
 119+ else {
 120+ $this->value = explode( $this->delimiter, $this->originalValue );
 121+
 122+ if ( $this->trimValue ) {
 123+ foreach ( $this->value as &$item ) {
 124+ $item = trim( $item );
 125+ }
 126+ }
 127+ }
 128+ }
 129+
 130+ /**
 131+ * @see Parameter::validate
 132+ */
 133+ public function validate( array $parameters ) {
 134+ $listSuccess = $this->validateListCriteria( $parameters );
 135+
 136+ if ( $listSuccess ) {
 137+ $this->doValidation( $parameters );
 138+ }
 139+ // TODO
 140+
 141+ // FIXME: it's possible the list criteria are not satisfied here anymore due to filtering of invalid items.
 142+ }
 143+
 144+ /**
 145+ * @see Parameter::setToDefaultIfNeeded
 146+ *
 147+ * @since 0.4
 148+ */
 149+ protected function setToDefaultIfNeeded() {
 150+ if ( count( $this->errors ) > 0 && count( $this->value ) == 0 && !$this->hasFatalError() ) {
 151+ $this->setToDefault();
 152+ }
 153+ }
 154+
 155+ /**
 156+ * @see Parameter::setToDefault
 157+ *
 158+ * @since 0.4
 159+ */
 160+ protected function setToDefault() {
 161+ $this->defaulted = true;
 162+ $this->value = is_array( $this->default ) ? $this->default : array( $this->default );
 163+ }
 164+
 165+ /**
 166+ *
 167+ *
 168+ * @since 0.4
 169+ *
 170+ * @param array $parameters
 171+ */
 172+ protected function validateListCriteria( array $parameters ) {
 173+ foreach ( $this->getListCriteria() as $listCriterion ) {
 174+ if ( !$listCriterion->validate( $this, $parameters ) ) {
 175+ $hasError = true;
 176+
 177+ if ( !self::$accumulateParameterErrors ) {
 178+ break;
 179+ }
 180+ }
 181+ }
 182+
 183+ // TODO
 184+ return true;
 185+ }
 186+
 187+ /**
 188+ * Returns the parameter list criteria.
 189+ *
 190+ * @since 0.4
 191+ *
 192+ * @return array of ListParameterCriterion
 193+ */
 194+ public function getListCriteria() {
 195+ return $this->listCriteria;
 196+ }
 197+
 198+ /**
 199+ * Handles any validation errors that occured for a single criterion.
 200+ *
 201+ * @since 0.4
 202+ *
 203+ * @param CriterionValidationResult $validationResult
 204+ */
 205+ protected function handleValidationError( CriterionValidationResult $validationResult ) {
 206+ parent::handleValidationError( $validationResult );
 207+
 208+ // Filter out the items that have already been found to be invalid.
 209+ if ( $validationResult->hasInvalidItems() ) {
 210+ $this->tempInvalidList = $validationResult->getInvalidItems();
 211+ $this->value = array_filter( $this->value, array( $this, 'itemIsValid' ) );
 212+ }
 213+ }
 214+
 215+ /**
 216+ * Returns if an item is valid or not.
 217+ *
 218+ * @since 0.4
 219+ *
 220+ * @return boolean
 221+ */
 222+ protected function itemIsValid( $item ) {
 223+ return !in_array( $item, $this->tempInvalidList );
 224+ }
 225+
 226+ /**
 227+ * @see Parameter::setDefault
 228+ *
 229+ * @since 0.4
 230+ */
 231+ public function setDefault( $default ) {
 232+ $this->default = is_array( $default ) ? $default : array( $default );
 233+ }
 234+
 235+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/ListParameter.php
___________________________________________________________________
Added: svn:eol-style
1236 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionHasLength.php
@@ -0,0 +1,62 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter criterion stating that the value must have a certain length.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file CriterionHasLength.php
 10+ * @ingroup Validator
 11+ * @ingroup Criteria
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+class CriterionHasLength extends ItemParameterCriterion {
 16+
 17+ protected $lowerBound;
 18+ protected $upperBound;
 19+
 20+ /**
 21+ * Constructor.
 22+ *
 23+ * @param integer $lowerBound
 24+ * @param mixed $upperBound
 25+ *
 26+ * @since 0.4
 27+ */
 28+ public function __construct( $lowerBound, $upperBound = false ) {
 29+ parent::__construct();
 30+
 31+ $this->lowerBound = $lowerBound;
 32+ $this->upperBound = $upperBound === false ? $lowerBound : $upperBound;
 33+ }
 34+
 35+ /**
 36+ * @see ItemParameterCriterion::validate
 37+ */
 38+ protected function doValidation( $value, Parameter $parameter, array $parameters ) {
 39+ $strlen = strlen( $value );
 40+ return $strlen <= $this->upperBound && $strlen >= $this->lowerBound;
 41+ }
 42+
 43+ /**
 44+ * @see ItemParameterCriterion::getItemErrorMessage
 45+ */
 46+ protected function getItemErrorMessage( Parameter $parameter ) {
 47+ global $wgLang;
 48+
 49+ if ( $this->lowerBound == $this->upperBound ) {
 50+ return wfMsgExt( 'validator-error-invalid-length', 'parsemag', $parameter->getOriginalName(), $wgLang->formatNum( $this->lowerBound ) );
 51+ }
 52+ else {
 53+ return wfMsgExt(
 54+ 'validator-error-invalid-length-range',
 55+ 'parsemag',
 56+ $parameter->getOriginalName(),
 57+ $wgLang->formatNum( $this->lowerBound ),
 58+ $wgLang->formatNum( $this->upperBound )
 59+ );
 60+ }
 61+ }
 62+
 63+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionHasLength.php
___________________________________________________________________
Added: svn:eol-style
164 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionIsNumeric.php
@@ -0,0 +1,46 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter criterion stating that the value must be a number.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file CriterionIsNumeric.php
 10+ * @ingroup Validator
 11+ * @ingroup Criteria
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+class CriterionIsNumeric extends ItemParameterCriterion {
 16+
 17+ /**
 18+ * Constructor.
 19+ *
 20+ * @since 0.4
 21+ */
 22+ public function __construct( ) {
 23+ parent::__construct();
 24+ }
 25+
 26+ /**
 27+ * @see ItemParameterCriterion::validate
 28+ */
 29+ protected function doValidation( $value, Parameter $parameter, array $parameters ) {
 30+ return is_numeric( $value );
 31+ }
 32+
 33+ /**
 34+ * @see ItemParameterCriterion::getItemErrorMessage
 35+ */
 36+ protected function getItemErrorMessage( Parameter $parameter ) {
 37+ return wfMsgExt( 'validator_error_must_be_number', 'parsemag', $parameter->getOriginalName() );
 38+ }
 39+
 40+ /**
 41+ * @see ItemParameterCriterion::getFullListErrorMessage
 42+ */
 43+ protected function getFullListErrorMessage( Parameter $parameter ) {
 44+ return wfMsgExt( 'validator_list_error_must_be_number', 'parsemag', $parameter->getOriginalName() );
 45+ }
 46+
 47+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionIsNumeric.php
___________________________________________________________________
Added: svn:eol-style
148 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionMatchesRegex.php
@@ -0,0 +1,59 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter criterion stating that the value must match a regex.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file CriterionMatchesRegex.php
 10+ * @ingroup Validator
 11+ * @ingroup Criteria
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+class CriterionMatchesRegex extends ItemParameterCriterion {
 16+
 17+ /**
 18+ * The pattern to match against.
 19+ *
 20+ * @since 0.4
 21+ *
 22+ * @var string
 23+ */
 24+ protected $pattern;
 25+
 26+ /**
 27+ * Constructor.
 28+ *
 29+ * @param string $pattern
 30+ *
 31+ * @since 0.4
 32+ */
 33+ public function __construct( $pattern ) {
 34+ parent::__construct();
 35+
 36+ $this->pattern = $pattern;
 37+ }
 38+
 39+ /**
 40+ * @see ItemParameterCriterion::validate
 41+ */
 42+ protected function doValidation( $value, Parameter $parameter, array $parameters ) {
 43+ return (bool)preg_match( $this->pattern, $value );
 44+ }
 45+
 46+ /**
 47+ * @see ItemParameterCriterion::getItemErrorMessage
 48+ */
 49+ protected function getItemErrorMessage( Parameter $parameter ) {
 50+ return wfMsgExt( 'validator-error-invalid-regex', 'parsemag', $parameter->getOriginalName(), $this->pattern );
 51+ }
 52+
 53+ /**
 54+ * @see ItemParameterCriterion::getFullListErrorMessage
 55+ */
 56+ protected function getFullListErrorMessage( Parameter $parameter ) {
 57+ return wfMsgExt( 'validator-list-error-invalid-regex', 'parsemag', $parameter->getOriginalName(), $this->pattern );
 58+ }
 59+
 60+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionMatchesRegex.php
___________________________________________________________________
Added: svn:eol-style
161 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionNotEmpty.php
@@ -0,0 +1,46 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter criterion stating that the value must not be empty (empty being a string with 0 lentgh).
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file CriterionNotEmpty.php
 10+ * @ingroup Validator
 11+ * @ingroup Criteria
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+class CriterionNotEmpty extends ItemParameterCriterion {
 16+
 17+ /**
 18+ * Constructor.
 19+ *
 20+ * @since 0.4
 21+ */
 22+ public function __construct() {
 23+ parent::__construct();
 24+ }
 25+
 26+ /**
 27+ * @see ItemParameterCriterion::validate
 28+ */
 29+ protected function doValidation( $value, Parameter $parameter, array $parameters ) {
 30+ return trim( $value ) != '';
 31+ }
 32+
 33+ /**
 34+ * @see ItemParameterCriterion::getItemErrorMessage
 35+ */
 36+ protected function getItemErrorMessage( Parameter $parameter ) {
 37+ return wfMsgExt( 'validator_error_empty_argument', 'parsemag', $parameter->getOriginalName() );
 38+ }
 39+
 40+ /**
 41+ * @see ItemParameterCriterion::getFullListErrorMessage
 42+ */
 43+ protected function getFullListErrorMessage( Parameter $parameter ) {
 44+ return wfMsgExt( 'validator_list_error_empty_argument', 'parsemag', $parameter->getOriginalName() );
 45+ }
 46+
 47+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionNotEmpty.php
___________________________________________________________________
Added: svn:eol-style
148 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionTrue.php
@@ -0,0 +1,46 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter criterion that is always true.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file CriterionTrue.php
 10+ * @ingroup Validator
 11+ * @ingroup Criteria
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+class CriterionTrue extends ItemParameterCriterion {
 16+
 17+ /**
 18+ * Constructor.
 19+ *
 20+ * @since 0.4
 21+ */
 22+ public function __construct() {
 23+ parent::__construct();
 24+ }
 25+
 26+ /**
 27+ * @see ItemParameterCriterion::validate
 28+ */
 29+ protected function doValidation( $value, Parameter $parameter, array $parameters ) {
 30+ return true;
 31+ }
 32+
 33+ /**
 34+ * @see ItemParameterCriterion::getItemErrorMessage
 35+ */
 36+ protected function getItemErrorMessage( Parameter $parameter ) {
 37+ return '';
 38+ }
 39+
 40+ /**
 41+ * @see ItemParameterCriterion::getListErrorMessage
 42+ */
 43+ protected function getListErrorMessage( Parameter $parameter, array $invalidItems, $allInvalid ) {
 44+ return '';
 45+ }
 46+
 47+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionTrue.php
___________________________________________________________________
Added: svn:eol-style
148 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionIsFloat.php
@@ -0,0 +1,46 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter criterion stating that the value must be a float.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file CriterionIsFloat.php
 10+ * @ingroup Validator
 11+ * @ingroup Criteria
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+class CriterionIsFloat extends ItemParameterCriterion {
 16+
 17+ /**
 18+ * Constructor.
 19+ *
 20+ * @since 0.4
 21+ */
 22+ public function __construct() {
 23+ parent::__construct();
 24+ }
 25+
 26+ /**
 27+ * @see ItemParameterCriterion::validate
 28+ */
 29+ protected function doValidation( $value, Parameter $parameter, array $parameters ) {
 30+ return preg_match( '/^(-)?\d+((\.|,)\d+)?$/', $value );
 31+ }
 32+
 33+ /**
 34+ * @see ItemParameterCriterion::getItemErrorMessage
 35+ */
 36+ protected function getItemErrorMessage( Parameter $parameter ) {
 37+ return wfMsgExt( 'validator-error-must-be-float', 'parsemag', $parameter->getOriginalName() );
 38+ }
 39+
 40+ /**
 41+ * @see ItemParameterCriterion::getFullListErrorMessage
 42+ */
 43+ protected function getFullListErrorMessage( Parameter $parameter ) {
 44+ return wfMsgExt( 'validator-list-error-must-be-float', 'parsemag', $parameter->getOriginalName() );
 45+ }
 46+
 47+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionIsFloat.php
___________________________________________________________________
Added: svn:eol-style
148 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionInRange.php
@@ -0,0 +1,93 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter criterion stating that the value must be in a certain range.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file CriterionInRange.php
 10+ * @ingroup Validator
 11+ * @ingroup Criteria
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+class CriterionInRange extends ItemParameterCriterion {
 16+
 17+ /**
 18+ * Lower bound of the range. Either a number or false, for no lower limit.
 19+ *
 20+ * @since 0.4
 21+ *
 22+ * @var mixed
 23+ */
 24+ protected $lowerBound;
 25+
 26+ /**
 27+ * Upper bound of the range. Either a number or false, for no upper limit.
 28+ *
 29+ * @since 0.4
 30+ *
 31+ * @var mixed
 32+ */
 33+ protected $upperBound;
 34+
 35+ /**
 36+ * Constructor.
 37+ *
 38+ * @param mixed $lowerBound
 39+ * @param mixed $upperBound
 40+ *
 41+ * @since 0.4
 42+ */
 43+ public function __construct( $lowerBound, $upperBound ) {
 44+ parent::__construct();
 45+
 46+ $this->lowerBound = $lowerBound;
 47+ $this->upperBound = $upperBound;
 48+ }
 49+
 50+ /**
 51+ * @see ItemParameterCriterion::validate
 52+ */
 53+ protected function doValidation( $value, Parameter $parameter, array $parameters ) {
 54+ if ( !is_numeric( $value ) ) {
 55+ return false;
 56+ }
 57+
 58+ $value = (int)$value;
 59+
 60+ return ( $this->upperBound === false || $value <= $this->upperBound )
 61+ && ( $this->lowerBound === false || $value >= $this->lowerBound );
 62+ }
 63+
 64+ /**
 65+ * @see ItemParameterCriterion::getItemErrorMessage
 66+ */
 67+ protected function getItemErrorMessage( Parameter $parameter ) {
 68+ global $wgLang;
 69+
 70+ return wfMsgExt(
 71+ 'validator_error_invalid_range',
 72+ 'parsemag',
 73+ $parameter->getOriginalName(),
 74+ $wgLang->formatNum( $this->lowerBound ),
 75+ $wgLang->formatNum( $this->upperBound )
 76+ );
 77+ }
 78+
 79+ /**
 80+ * @see ItemParameterCriterion::getFullListErrorMessage
 81+ */
 82+ protected function getFullListErrorMessage( Parameter $parameter ) {
 83+ global $wgLang;
 84+
 85+ return wfMsgExt(
 86+ 'validator_list_error_invalid_range',
 87+ 'parsemag',
 88+ $parameter->getOriginalName(),
 89+ $wgLang->formatNum( $this->lowerBound ),
 90+ $wgLang->formatNum( $this->upperBound )
 91+ );
 92+ }
 93+
 94+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionInRange.php
___________________________________________________________________
Added: svn:eol-style
195 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionInArray.php
@@ -0,0 +1,155 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter criterion stating that the value must be in an array.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file CriterionInArray.php
 10+ * @ingroup Validator
 11+ * @ingroup Criteria
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+class CriterionInArray extends ItemParameterCriterion {
 16+
 17+ /**
 18+ * List of allowed values.
 19+ *
 20+ * @since 0.4
 21+ *
 22+ * @var array
 23+ */
 24+ protected $allowedValues;
 25+
 26+ /**
 27+ * If the values should match case.
 28+ *
 29+ * @since 0.4.2
 30+ *
 31+ * @var boolean
 32+ */
 33+ protected $careAboutCapitalization = false;
 34+
 35+ /**
 36+ * Constructor.
 37+ *
 38+ * You can specify the allowed values either by passing an array,
 39+ * or by passing each value as an argument. You can also specify
 40+ * if the criterion should care about capitalization or not by
 41+ * adding a boolean as last argument. This value default to false.
 42+ *
 43+ * @since 0.4
 44+ */
 45+ public function __construct() {
 46+ parent::__construct();
 47+
 48+ $args = func_get_args();
 49+
 50+ $lastElement = array_pop( $args );
 51+
 52+ if ( is_bool( $lastElement ) ) {
 53+ // The element is a boolean, so it's the capitalization parameter.
 54+ $this->careAboutCapitalization = $lastElement;
 55+ }
 56+ else {
 57+ // Add the element back to the array.
 58+ $args[] = $lastElement;
 59+ }
 60+
 61+ if ( count( $args ) > 1 ) {
 62+ $this->allowedValues = $args;
 63+ }
 64+ elseif ( count( $args ) == 1 ) {
 65+ $this->allowedValues = (array)$args[0];
 66+ }
 67+ else {
 68+ // Not a lot that will pass validation in this case :D
 69+ $this->allowedValues = array();
 70+ }
 71+
 72+ if ( !$this->careAboutCapitalization ) {
 73+ // If case doesn't matter, lowercase everything and later on compare a lowercased value.
 74+ $this->allowedValues = array_map( 'strtolower', $this->allowedValues );
 75+ }
 76+ }
 77+
 78+ /**
 79+ * @see ItemParameterCriterion::validate
 80+ */
 81+ protected function doValidation( $value, Parameter $parameter, array $parameters ) {
 82+ return in_array(
 83+ $this->careAboutCapitalization ? $value : strtolower( $value ),
 84+ $this->allowedValues
 85+ );
 86+ }
 87+
 88+ /**
 89+ * @see ItemParameterCriterion::getItemErrorMessage
 90+ */
 91+ protected function getItemErrorMessage( Parameter $parameter ) {
 92+ global $wgLang;
 93+
 94+ $values = $parameter->getValue();
 95+ $originalCount = count( $this->allowedValues );
 96+
 97+ if ( $originalCount > 15 ) {
 98+ $allowedValues = array_slice( $this->allowedValues, 0, 13 );
 99+ $omitCount = $originalCount - count( $allowedValues );
 100+
 101+ return wfMsgExt(
 102+ 'validator-error-accepts-only-omitted',
 103+ 'parsemag',
 104+ $parameter->getOriginalName(),
 105+ $parameter->getValue(),
 106+ $wgLang->listToText( $allowedValues ),
 107+ $wgLang->formatNum( $omitCount )
 108+ );
 109+ }
 110+ else {
 111+ return wfMsgExt(
 112+ 'validator_error_accepts_only',
 113+ 'parsemag',
 114+ $parameter->getOriginalName(),
 115+ $wgLang->listToText( $this->allowedValues ),
 116+ count( $this->allowedValues ),
 117+ $parameter->getValue()
 118+ );
 119+ }
 120+ }
 121+
 122+ /**
 123+ * @see ItemParameterCriterion::getFullListErrorMessage
 124+ */
 125+ protected function getFullListErrorMessage( Parameter $parameter ) {
 126+ global $wgLang;
 127+
 128+ $values = $parameter->getValue();
 129+ $originalCount = count( $this->allowedValues );
 130+
 131+ if ( $originalCount > 15 ) {
 132+ $allowedValues = array_slice( $this->allowedValues, 0, 13 );
 133+ $omitCount = $originalCount - count( $allowedValues );
 134+
 135+ return wfMsgExt(
 136+ 'validator-list-error-accepts-only-omitted',
 137+ 'parsemag',
 138+ $parameter->getOriginalName(),
 139+ $wgLang->listToText( $allowedValues ),
 140+ count( $allowedValues ),
 141+ $wgLang->formatNum( $omitCount )
 142+ );
 143+ }
 144+ else {
 145+ return wfMsgExt(
 146+ 'validator-list-error-accepts-only',
 147+ 'parsemag',
 148+ $parameter->getOriginalName(),
 149+ $wgLang->listToText( $this->allowedValues ),
 150+ count( $this->allowedValues ),
 151+ $parameter->getValue()
 152+ );
 153+ }
 154+ }
 155+
 156+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionInArray.php
___________________________________________________________________
Added: svn:eol-style
1157 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionItemCount.php
@@ -0,0 +1,42 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter criterion stating that the value must have a certain length.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file CriterionHasLength.php
 10+ * @ingroup Validator
 11+ * @ingroup Criteria
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+class CriterionItemCount extends ListParameterCriterion {
 16+
 17+ protected $lowerBound;
 18+ protected $upperBound;
 19+
 20+ /**
 21+ * Constructor.
 22+ *
 23+ * @param integer $lowerBound
 24+ * @param mixed $upperBound
 25+ *
 26+ * @since 0.4
 27+ */
 28+ public function __construct( $lowerBound, $upperBound = false ) {
 29+ parent::__construct();
 30+
 31+ $this->lowerBound = $lowerBound;
 32+ $this->upperBound = $upperBound === false ? $lowerBound : $upperBound;
 33+ }
 34+
 35+ /**
 36+ * @see ParameterCriterion::validate
 37+ */
 38+ public function validate( Parameter $parameter, array $parameters) {
 39+ $count = count( $parameter->getValue() );
 40+ return $count <= $this->upperBound && $count >= $this->lowerBound;
 41+ }
 42+
 43+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionItemCount.php
___________________________________________________________________
Added: svn:eol-style
144 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionUniqueItems.php
@@ -0,0 +1,46 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter criterion stating that the value must have a certain length.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file CriterionHasLength.php
 10+ * @ingroup Validator
 11+ * @ingroup Criteria
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+class CriterionUniqueItems extends ListParameterCriterion {
 16+
 17+ /**
 18+ * If the values should match case.
 19+ *
 20+ * @since 0.4.2
 21+ *
 22+ * @var boolean
 23+ */
 24+ protected $careAboutCapitalization;
 25+
 26+ /**
 27+ * Constructor.
 28+ *
 29+ * @since 0.4
 30+ */
 31+ public function __construct( $careAboutCapitalization = false ) {
 32+ parent::__construct();
 33+
 34+ $this->careAboutCapitalization = $careAboutCapitalization;
 35+ }
 36+
 37+ /**
 38+ * @see ParameterCriterion::validate
 39+ */
 40+ public function validate( Parameter $parameter, array $parameters ) {
 41+ return count( $parameter->getValue() )
 42+ == count( array_unique(
 43+ $this->careAboutCapitalization ? $parameter->getValue() : array_map( 'strtolower', $parameter->getValue() )
 44+ ) );
 45+ }
 46+
 47+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionUniqueItems.php
___________________________________________________________________
Added: svn:eol-style
148 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionIsInteger.php
@@ -0,0 +1,46 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter criterion stating that the value must be an integer.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file CriterionIsInteger.php
 10+ * @ingroup Validator
 11+ * @ingroup Criteria
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+class CriterionIsInteger extends ItemParameterCriterion {
 16+
 17+ /**
 18+ * Constructor.
 19+ *
 20+ * @since 0.4
 21+ */
 22+ public function __construct( ) {
 23+ parent::__construct();
 24+ }
 25+
 26+ /**
 27+ * @see ItemParameterCriterion::validate
 28+ */
 29+ protected function doValidation( $value, Parameter $parameter, array $parameters ) {
 30+ return ctype_digit( (string)$value );
 31+ }
 32+
 33+ /**
 34+ * @see ItemParameterCriterion::getItemErrorMessage
 35+ */
 36+ protected function getItemErrorMessage( Parameter $parameter ) {
 37+ return wfMsgExt( 'validator_error_must_be_integer', 'parsemag', $parameter->getOriginalName() );
 38+ }
 39+
 40+ /**
 41+ * @see ItemParameterCriterion::getFullListErrorMessage
 42+ */
 43+ protected function getFullListErrorMessage( Parameter $parameter ) {
 44+ return wfMsgExt( 'validator_list_error_must_be_integer', 'parsemag', $parameter->getOriginalName() );
 45+ }
 46+
 47+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/criteria/CriterionIsInteger.php
___________________________________________________________________
Added: svn:eol-style
148 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/ParserHook.php
@@ -0,0 +1,465 @@
 2+<?php
 3+
 4+/**
 5+ * Class for out of the box parser hook functionality inetgrated with the validation
 6+ * provided by Validator.
 7+ *
 8+ * @since 0.4
 9+ *
 10+ * @file ParserHook.php
 11+ * @ingroup Validator
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+abstract class ParserHook {
 16+
 17+ const TYPE_TAG = 0;
 18+ const TYPE_FUNCTION = 1;
 19+
 20+ /**
 21+ * @since 0.4.3
 22+ *
 23+ * @var array
 24+ */
 25+ protected static $registeredHooks = array();
 26+
 27+ /**
 28+ * Returns an array of registered parser hooks (keys) and their handling
 29+ * ParserHook deriving class names (values).
 30+ *
 31+ * @since 0.4.3
 32+ *
 33+ * @return array
 34+ */
 35+ public static function getRegisteredParserHooks() {
 36+ return self::$registeredHooks;
 37+ }
 38+
 39+ /**
 40+ * Returns the name of the ParserHook deriving class that defines a certain parser hook,
 41+ * or false if there is none.
 42+ *
 43+ * @since 0.4.3
 44+ *
 45+ * @param string $hookName
 46+ *
 47+ * @return mixed string or false
 48+ */
 49+ public static function getHookClassName( $hookName ) {
 50+ return array_key_exists( $hookName, self::$registeredHooks ) ? self::$registeredHooks[$hookName] : false;
 51+ }
 52+
 53+ /**
 54+ * @since 0.4
 55+ *
 56+ * @var Validator
 57+ */
 58+ protected $validator;
 59+
 60+ /**
 61+ * @since 0.4
 62+ *
 63+ * @var Parser
 64+ */
 65+ protected $parser;
 66+
 67+ /**
 68+ * @since 0.4
 69+ *
 70+ * @var boolean
 71+ */
 72+ public $forTagExtensions;
 73+
 74+ /**
 75+ * @since 0.4
 76+ *
 77+ * @var boolean
 78+ */
 79+ public $forParserFunctions;
 80+
 81+ /**
 82+ * Gets the name of the parser hook.
 83+ *
 84+ * @since 0.4
 85+ *
 86+ * @return string or array of string
 87+ */
 88+ protected abstract function getName();
 89+
 90+ /**
 91+ * Renders and returns the output.
 92+ *
 93+ * @since 0.4
 94+ *
 95+ * @param array $parameters
 96+ *
 97+ * @return string
 98+ */
 99+ protected abstract function render( array $parameters );
 100+
 101+ /**
 102+ * Constructor.
 103+ *
 104+ * @since 0.4
 105+ *
 106+ * @param boolean $forTagExtensions
 107+ * @param boolean $forParserFunctions
 108+ */
 109+ public function __construct( $forTagExtensions = true, $forParserFunctions = true ) {
 110+ $this->forTagExtensions = $forTagExtensions;
 111+ $this->forParserFunctions = $forParserFunctions;
 112+ }
 113+
 114+ /**
 115+ * Function to hook up the coordinate rendering functions to the parser.
 116+ *
 117+ * @since 0.4
 118+ *
 119+ * @param Parser $wgParser
 120+ *
 121+ * @return true
 122+ */
 123+ public function init( Parser &$wgParser ) {
 124+ $className = get_class( $this );
 125+ $first = true;
 126+
 127+ foreach ( $this->getNames() as $name ) {
 128+ if ( $first ) {
 129+ self::$registeredHooks[$name] = $className;
 130+ $first = false;
 131+ }
 132+
 133+ if ( $this->forTagExtensions ) {
 134+ $wgParser->setHook(
 135+ $this->getTagName( $name ),
 136+ array( new ParserHookCaller( $className, 'renderTag' ), 'runHook' )
 137+ );
 138+ }
 139+
 140+ if ( $this->forParserFunctions ) {
 141+ $wgParser->setFunctionHook(
 142+ $this->getFunctionName( $name ),
 143+ array( new ParserHookCaller( $className, 'renderFunction' ), 'runHook' )
 144+ );
 145+ }
 146+ }
 147+
 148+ return true;
 149+ }
 150+
 151+ /**
 152+ * returns an array with the names for the parser hook.
 153+ *
 154+ * @since 0.4
 155+ *
 156+ * @return array
 157+ */
 158+ protected function getNames() {
 159+ $names = $this->getName();
 160+
 161+ if ( !is_array( $names ) ) {
 162+ $names = array( $names );
 163+ }
 164+
 165+ return $names;
 166+ }
 167+
 168+ /**
 169+ * Returns the tag extension version of the name.
 170+ *
 171+ * @since 0.4
 172+ *
 173+ * @param string $rawName
 174+ *
 175+ * @return string
 176+ */
 177+ protected function getTagName( $rawName ) {
 178+ return str_replace( '_', ' ', $rawName );
 179+ }
 180+
 181+ /**
 182+ * Returns the parser function version of the name.
 183+ *
 184+ * @since 0.4
 185+ *
 186+ * @param string $rawName
 187+ *
 188+ * @return string
 189+ */
 190+ protected function getFunctionName( $rawName ) {
 191+ return str_replace( ' ', '_', $rawName );
 192+ }
 193+
 194+ /**
 195+ * Function to add the magic word in pre MW 1.16.
 196+ *
 197+ * @since 0.4
 198+ *
 199+ * @param array $magicWords
 200+ * @param string $langCode
 201+ *
 202+ * @return true
 203+ */
 204+ public function magic( array &$magicWords, $langCode ) {
 205+ foreach ( $this->getNames() as $name ) {
 206+ $name = $this->getFunctionName( $name );
 207+ $magicWords[$name] = array( 0, $name );
 208+ }
 209+
 210+ return true;
 211+ }
 212+
 213+ /**
 214+ * Handler for rendering the tag hook.
 215+ *
 216+ * @since 0.4
 217+ *
 218+ * @param minxed $input string or null
 219+ * @param array $args
 220+ * @param Parser $parser
 221+ * @param PPFrame $frame Available from 1.16 - commented out for bc for now
 222+ *
 223+ * @return string
 224+ */
 225+ public function renderTag( $input, array $args, Parser $parser /*, PPFrame $frame*/ ) {
 226+ $this->parser = $parser;
 227+
 228+ $defaultParam = array_shift( $this->getDefaultParameters( self::TYPE_TAG ) );
 229+
 230+ // If there is a first default parameter, set the tag contents as it's value.
 231+ if ( !is_null( $defaultParam ) && !is_null( $input ) ) {
 232+ $args[$defaultParam] = $input;
 233+ }
 234+
 235+ return $this->validateAndRender( $args, self::TYPE_TAG );
 236+ }
 237+
 238+ /**
 239+ * Handler for rendering the function hook.
 240+ *
 241+ * @since 0.4
 242+ *
 243+ * @param Parser $parser
 244+ * ... further arguments ...
 245+ *
 246+ * @return array
 247+ */
 248+ public function renderFunction() {
 249+ $args = func_get_args();
 250+
 251+ $this->parser = array_shift( $args );
 252+
 253+ return array_merge(
 254+ array( $this->validateAndRender( $args, self::TYPE_FUNCTION ) ),
 255+ $this->getFunctionOptions()
 256+ );
 257+ }
 258+
 259+ /**
 260+ * Returns the parser function otpions.
 261+ *
 262+ * @since 0.4
 263+ *
 264+ * @return array
 265+ */
 266+ protected function getFunctionOptions() {
 267+ return array();
 268+ }
 269+
 270+ /**
 271+ * Takes care of validation and rendering, and returns the output.
 272+ *
 273+ * @since 0.4
 274+ *
 275+ * @param array $arguments
 276+ * @param integer $type Item of the ParserHook::TYPE_ enum
 277+ *
 278+ * @return string
 279+ */
 280+ public function validateAndRender( array $arguments, $type ) {
 281+ global $egValidatorErrorLevel;
 282+
 283+ $names = $this->getNames();
 284+ $this->validator = new Validator( $names[0] );
 285+
 286+ if ( $type === self::TYPE_FUNCTION ) {
 287+ $this->validator->setFunctionParams( $arguments, $this->getParameterInfo( $type ), $this->getDefaultParameters( $type ) );
 288+ }
 289+ else {
 290+ $this->validator->setParameters( $arguments, $this->getParameterInfo( $type ) );
 291+ }
 292+
 293+ $this->validator->validateParameters();
 294+
 295+ $fatalError = $this->validator->hasFatalError();
 296+
 297+ if ( $fatalError === false ) {
 298+ $output = $this->render( $this->validator->getParameterValues() );
 299+ $output = $this->renderErrors( $output );
 300+ }
 301+ else {
 302+ $output = $this->renderFatalError( $fatalError );
 303+ }
 304+
 305+ return $output;
 306+ }
 307+
 308+ /**
 309+ * Returns the ValidationError objects for the errors and warnings that should be displayed.
 310+ *
 311+ * @since 0.4
 312+ *
 313+ * @return array of array of ValidationError
 314+ */
 315+ protected function getErrorsToDisplay() {
 316+ $errors = array();
 317+ $warnings = array();
 318+
 319+ foreach ( $this->validator->getErrors() as $error ) {
 320+ // Check if the severity of the error is high enough to display it.
 321+ if ( $error->shouldShow() ) {
 322+ $errors[] = $error;
 323+ }
 324+ else if ( $error->shouldWarn() ) {
 325+ $warnings[] = $error;
 326+ }
 327+ }
 328+
 329+ return array( 'errors' => $errors, 'warnings' => $warnings );
 330+ }
 331+
 332+ /**
 333+ * Creates and returns the output when a fatal error prevent regular rendering.
 334+ *
 335+ * @since 0.4
 336+ *
 337+ * @param ValidationError $error
 338+ *
 339+ * @return string
 340+ */
 341+ protected function renderFatalError( ValidationError $error ) {
 342+ return '<div><span class="errorbox">' .
 343+ htmlspecialchars( wfMsgExt( 'validator-fatal-error', 'parsemag', $error->getMessage() ) ) .
 344+ '</span></div><br /><br />';
 345+ }
 346+
 347+ /**
 348+ * @since 0.4
 349+ *
 350+ * @param string $output
 351+ *
 352+ * @return string
 353+ */
 354+ protected function renderErrors( $output ) {
 355+ $displayStuff = $this->getErrorsToDisplay();
 356+
 357+ if ( count( $displayStuff['errors'] ) > 0 ) {
 358+ $output .= wfMsgExt( 'validator_error_parameters', 'parsemag', count( $displayStuff['errors'] ) );
 359+
 360+ foreach( $displayStuff['errors'] as $error ) {
 361+ $output .= '<br />* ' . $error->getMessage();
 362+ }
 363+
 364+ if ( count( $displayStuff['warnings'] ) > 0 ) {
 365+ $output .= '<br />* ' . wfMsgExt( 'validator-warning-adittional-errors', 'parsemag', count( $displayStuff['warnings'] ) );
 366+ }
 367+ }
 368+ else if ( count( $displayStuff['warnings'] ) > 0 ) {
 369+ $output .= wfMsgExt(
 370+ 'validator-warning',
 371+ 'parsemag',
 372+ wfMsgExt( 'validator_warning_parameters', 'parsemag', count( $displayStuff['warnings'] ) )
 373+ );
 374+ }
 375+
 376+ return $output;
 377+ }
 378+
 379+ /**
 380+ * Returns an array containing the parameter info.
 381+ * Override in deriving classes to add parameter info.
 382+ *
 383+ * @since 0.4
 384+ *
 385+ * @param integer $type Item of the ParserHook::TYPE_ enum
 386+ *
 387+ * @return array
 388+ */
 389+ protected function getParameterInfo( $type ) {
 390+ return array();
 391+ }
 392+
 393+ /**
 394+ * Returns the list of default parameters.
 395+ * Override in deriving classes to add default parameters.
 396+ *
 397+ * @since 0.4
 398+ *
 399+ * @param integer $type Item of the ParserHook::TYPE_ enum
 400+ *
 401+ * @return array
 402+ */
 403+ protected function getDefaultParameters( $type ) {
 404+ return array();
 405+ }
 406+
 407+ /**
 408+ * Returns the data needed to describe the parser hook.
 409+ * This is mainly needed because some of the individual get methods
 410+ * that return the needed data are protected, and cannot be made
 411+ * public without breaking b/c in a rather bad way.
 412+ *
 413+ * @since 0.4.3
 414+ *
 415+ * @param integer $type Item of the ParserHook::TYPE_ enum
 416+ *
 417+ * @return array
 418+ */
 419+ public function getDescriptionData( $type ) {
 420+ return array(
 421+ 'names' => $this->getNames(),
 422+ 'description' => $this->getDescription(),
 423+ 'parameters' => $this->getParameterInfo( $type ),
 424+ 'defaults' => $this->getDefaultParameters( $type ),
 425+ );
 426+ }
 427+
 428+ /**
 429+ * Returns a description message for the parser hook, or false when there is none.
 430+ * Override in deriving classes to add a message.
 431+ *
 432+ * @since 0.4.3
 433+ *
 434+ * @return mixed string or false
 435+ */
 436+ public function getDescription() {
 437+ return false;
 438+ }
 439+
 440+}
 441+
 442+/**
 443+ * Completely evil class to create a new instance of the handling ParserHook when the actual hook gets called.
 444+ *
 445+ * @evillness >9000 - to be replaced when a better solution (LSB?) is possible.
 446+ *
 447+ * @since 0.4
 448+ *
 449+ * @author Jeroen De Dauw
 450+ */
 451+class ParserHookCaller {
 452+
 453+ protected $class;
 454+ protected $method;
 455+
 456+ function __construct( $class, $method ) {
 457+ $this->class = $class;
 458+ $this->method = $method;
 459+ }
 460+
 461+ public function runHook() {
 462+ $args = func_get_args();
 463+ return call_user_func_array( array( new $this->class(), $this->method ), $args );
 464+ }
 465+
 466+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/ParserHook.php
___________________________________________________________________
Added: svn:eol-style
1467 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/ItemParameterCriterion.php
@@ -0,0 +1,172 @@
 2+<?php
 3+
 4+/**
 5+ * Item parameter criterion definition class. This is for criteria
 6+ * that apply to individial values, which can either be the whole value
 7+ * of a non-list parameter, or a single item of a list parameter.
 8+ *
 9+ * @since 0.4
 10+ *
 11+ * @file ItemParameterCriterion.php
 12+ * @ingroup Validator
 13+ * @ingroup Criteria
 14+ *
 15+ * @author Jeroen De Dauw
 16+ */
 17+abstract class ItemParameterCriterion extends ParameterCriterion {
 18+
 19+ /**
 20+ * Validate a value against the criterion.
 21+ *
 22+ * @param string $value
 23+ * @param Parameter $parameter
 24+ * @param array $parameters
 25+ *
 26+ * @since 0.4
 27+ *
 28+ * @return boolean
 29+ */
 30+ protected abstract function doValidation( $value, Parameter $parameter, array $parameters );
 31+
 32+ /**
 33+ * Gets an internationalized error message to construct a ValidationError with
 34+ * when the criterions validation failed. (for non-list values)
 35+ *
 36+ * @param Parameter $parameter
 37+ *
 38+ * @since 0.4
 39+ *
 40+ * @return string
 41+ */
 42+ protected abstract function getItemErrorMessage( Parameter $parameter );
 43+
 44+ /**
 45+ * Constructor.
 46+ *
 47+ * @since 0.4
 48+ */
 49+ public function __construct() {
 50+ parent::__construct();
 51+ }
 52+
 53+ /**
 54+ * @see ParameterCriterion::isForLists
 55+ */
 56+ public function isForLists() {
 57+ return false;
 58+ }
 59+
 60+ /**
 61+ * Validate the provided value or list of values against the criterion.
 62+ *
 63+ * @since 0.4
 64+ *
 65+ * @param Parameter $parameter
 66+ * @param array $parameters
 67+ *
 68+ * @return CriterionValidationResult
 69+ */
 70+ public function validate( Parameter $parameter, array $parameters ) {
 71+ $result = new CriterionValidationResult();
 72+
 73+ if ( is_array( $parameter->getValue() ) ) {
 74+ foreach ( $parameter->getValue() as $item ) {
 75+ if ( !$this->doValidation( $item, $parameter, $parameters ) ) {
 76+ $result->addInvalidItem( $item );
 77+ }
 78+ }
 79+
 80+ if ( $result->hasInvalidItems() ) {
 81+ $allInvalid = count( $result->getInvalidItems() ) == count( $parameter->getValue() );
 82+
 83+ // If the parameter is required and all items are invalid, it's fatal.
 84+ // Else it's high for required, and normal for non-required parameters.
 85+ if ( $parameter->isRequired() ) {
 86+ $severity = $allInvalid ? ValidationError::SEVERITY_FATAL : ValidationError::SEVERITY_HIGH;
 87+ }
 88+ else {
 89+ $severity = $allInvalid ? ValidationError::SEVERITY_NORMAL : ValidationError::SEVERITY_LOW;
 90+ }
 91+
 92+ $result->addError(
 93+ new ValidationError(
 94+ $this->getListErrorMessage( $parameter, $result->getInvalidItems(), $allInvalid ),
 95+ $severity
 96+ )
 97+ );
 98+ }
 99+ }
 100+ else {
 101+ if ( !$this->doValidation( $parameter->getValue(), $parameter, $parameters ) ) {
 102+ $result->addError(
 103+ new ValidationError(
 104+ $this->getItemErrorMessage( $parameter ),
 105+ $parameter->isRequired() ? ValidationError::SEVERITY_FATAL : ValidationError::SEVERITY_NORMAL
 106+ )
 107+ );
 108+ }
 109+ }
 110+
 111+ return $result;
 112+ }
 113+
 114+ /**
 115+ * Gets an internationalized error message to construct a ValidationError with
 116+ * when the criterions validation failed. (for list values)
 117+ *
 118+ * @param Parameter $parameter
 119+ * @param array $invalidItems
 120+ * @param boolean $allInvalid
 121+ *
 122+ * @since 0.4
 123+ *
 124+ * @return string
 125+ */
 126+ protected function getListErrorMessage( Parameter $parameter, array $invalidItems, $allInvalid ) {
 127+ if ( $allInvalid ) {
 128+ return $this->getFullListErrorMessage( $parameter );
 129+ }
 130+ else {
 131+ return $this->getPartialListErrorMessage( $parameter, $invalidItems, $allInvalid );
 132+ }
 133+ }
 134+
 135+ /**
 136+ * Gets an internationalized error message to construct a ValidationError with
 137+ * when the criterions validation failed. (for list values when all values are invalid)
 138+ *
 139+ * @param Parameter $parameter
 140+ *
 141+ * @since 0.4
 142+ *
 143+ * @return string
 144+ */
 145+ protected function getFullListErrorMessage( Parameter $parameter ) {
 146+ return wfMsgExt( 'validator-error-problem', 'parsemag', $parameter->getOriginalName() );
 147+ }
 148+
 149+ /**
 150+ * Gets an internationalized error message to construct a ValidationError with
 151+ * when the criterions validation failed. (for list values when only some values are invalid)
 152+ *
 153+ * @param Parameter $parameter
 154+ * @param array $invalidItems
 155+ * @param boolean $allInvalid
 156+ *
 157+ * @since 0.4
 158+ *
 159+ * @return string
 160+ */
 161+ protected function getPartialListErrorMessage( Parameter $parameter, array $invalidItems, $allInvalid ) {
 162+ global $wgLang;
 163+
 164+ return $this->getFullListErrorMessage( $parameter ) .
 165+ wfMsgExt(
 166+ 'validator-error-omitted',
 167+ 'parsemag',
 168+ $wgLang->listToText( $invalidItems ),
 169+ count( $invalidItems )
 170+ );
 171+ }
 172+
 173+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/ItemParameterCriterion.php
___________________________________________________________________
Added: svn:eol-style
1174 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/ItemParameterManipulation.php
@@ -0,0 +1,67 @@
 2+<?php
 3+
 4+/**
 5+ * Item parameter manipulation base class. This is for manipulations
 6+ * that apply to individial values, which can either be the whole value
 7+ * of a non-list parameter, or a single item of a list parameter.
 8+ *
 9+ * @since 0.4
 10+ *
 11+ * @file ItemParameterManipulation.php
 12+ * @ingroup Validator
 13+ * @ingroup ParameterManipulations
 14+ *
 15+ * @author Jeroen De Dauw
 16+ */
 17+abstract class ItemParameterManipulation extends ParameterManipulation {
 18+
 19+ /**
 20+ * Manipulate an actual value.
 21+ *
 22+ * @param string $value
 23+ * @param Parameter $parameter
 24+ * @param array $parameters
 25+ *
 26+ * @since 0.4
 27+ *
 28+ * @return mixed
 29+ */
 30+ protected abstract function doManipulation( &$value, Parameter $parameter, array &$parameters );
 31+
 32+ /**
 33+ * Constructor.
 34+ *
 35+ * @since 0.4
 36+ */
 37+ public function __construct() {
 38+ parent::__construct();
 39+ }
 40+
 41+ /**
 42+ * @see ParameterManipulation::isForLists
 43+ */
 44+ public function isForLists() {
 45+ return false;
 46+ }
 47+
 48+ /**
 49+ * Validate a parameter against the criterion.
 50+ *
 51+ * @param Parameter $parameter
 52+ * @param array $parameters
 53+ *
 54+ * @since 0.4
 55+ */
 56+ public function manipulate( Parameter &$parameter, array &$parameters ) {
 57+ if ( is_array( $parameter->getValue() ) ) {
 58+ $value = &$parameter->getValue();
 59+ foreach ( $value as &$item ) {
 60+ $this->doManipulation( $item, $parameter, $parameters );
 61+ }
 62+ }
 63+ else {
 64+ $this->doManipulation( $parameter->getValue(), $parameter, $parameters );
 65+ }
 66+ }
 67+
 68+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/ItemParameterManipulation.php
___________________________________________________________________
Added: svn:eol-style
169 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/Parameter.php
@@ -0,0 +1,785 @@
 2+<?php
 3+
 4+/**
 5+ * Parameter definition class.
 6+ *
 7+ * @since 0.4
 8+ *
 9+ * @file Parameter.php
 10+ * @ingroup Validator
 11+ *
 12+ * @author Jeroen De Dauw
 13+ */
 14+class Parameter {
 15+
 16+ const TYPE_STRING = 'string';
 17+ const TYPE_NUMBER = 'number';
 18+ const TYPE_INTEGER = 'integer';
 19+ const TYPE_FLOAT = 'float';
 20+ const TYPE_BOOLEAN = 'boolean';
 21+ const TYPE_CHAR = 'char';
 22+
 23+ /**
 24+ * Indicates whether parameters that are provided more then once should be accepted,
 25+ * and use the first provided value, or not, and generate an error.
 26+ *
 27+ * @since 0.4
 28+ *
 29+ * @var boolean
 30+ */
 31+ public static $acceptOverriding = false;
 32+
 33+ /**
 34+ * Indicates whether parameters not found in the criteria list
 35+ * should be stored in case they are not accepted. The default is false.
 36+ *
 37+ * @since 0.4
 38+ *
 39+ * @var boolean
 40+ */
 41+ public static $accumulateParameterErrors = false;
 42+
 43+ /**
 44+ * Indicates if the parameter value should trimmed.
 45+ *
 46+ * @since 0.4
 47+ *
 48+ * @var boolean
 49+ */
 50+ public $trimValue = true;
 51+
 52+ /**
 53+ * Dependency list containing parameters that need to be handled before this one.
 54+ *
 55+ * @since 0.4
 56+ *
 57+ * @var array
 58+ */
 59+ protected $dependencies = array();
 60+
 61+ /**
 62+ * The default value for the parameter, or null when the parameter is required.
 63+ *
 64+ * @since 0.4
 65+ *
 66+ * @var mixed
 67+ */
 68+ protected $default;
 69+
 70+ /**
 71+ * The main name of the parameter.
 72+ *
 73+ * @since 0.4
 74+ *
 75+ * @var string
 76+ */
 77+ protected $name;
 78+
 79+ /**
 80+ * The type of the parameter, element of the Parameter::TYPE_ enum.
 81+ *
 82+ * @since 0.4
 83+ *
 84+ * @var string
 85+ */
 86+ protected $type;
 87+
 88+ /**
 89+ * List of aliases for the parameter name.
 90+ *
 91+ * @since 0.4
 92+ *
 93+ * @var array
 94+ */
 95+ protected $aliases = array();
 96+
 97+ /**
 98+ * List of criteria the parameter value needs to hold against.
 99+ *
 100+ * @since 0.4
 101+ *
 102+ * @var array of ParameterCriterion
 103+ */
 104+ protected $criteria = array();
 105+
 106+ /**
 107+ * List of manipulations the parameter value needs to undergo.
 108+ *
 109+ * @since 0.4
 110+ *
 111+ * @var array of ParameterManipulation
 112+ */
 113+ protected $manipulations = array();
 114+
 115+ /**
 116+ * The original parameter name as provided by the user. This can be the
 117+ * main name or an alias.
 118+ *
 119+ * @since 0.4
 120+ *
 121+ * @var string
 122+ */
 123+ protected $originalName;
 124+
 125+ /**
 126+ * The original value as provided by the user. This is mainly retained for
 127+ * usage in error messages when the parameter turns out to be invalid.
 128+ *
 129+ * @since 0.4
 130+ *
 131+ * @var string
 132+ */
 133+ protected $originalValue;
 134+
 135+ /**
 136+ * The value of the parameter.
 137+ *
 138+ * @since 0.4
 139+ *
 140+ * @var mixed
 141+ */
 142+ protected $value;
 143+
 144+ /**
 145+ * Keeps track of how many times the parameter has been set by the user.
 146+ * This is used to detect overrides and for figuring out a parameter is missing.
 147+ *
 148+ * @since 0.4
 149+ *
 150+ * @var integer
 151+ */
 152+ protected $setCount = 0;
 153+
 154+ /**
 155+ * List of validation errors for this parameter.
 156+ *
 157+ * @since 0.4
 158+ *
 159+ * @var array of ValidationError
 160+ */
 161+ protected $errors = array();
 162+
 163+ /**
 164+ * Indicates if the parameter manipualations should be applied to the default value.
 165+ *
 166+ * @since 0.4
 167+ *
 168+ * @var boolean
 169+ */
 170+ protected $applyManipulationsToDefault = true;
 171+
 172+ /**
 173+ * Indicates if the parameter was set to it's default.
 174+ *
 175+ * @since 0.4
 176+ *
 177+ * @var boolean
 178+ */
 179+ protected $defaulted = false;
 180+
 181+ /**
 182+ * A description for the parameter or false when there is none.
 183+ * Can be obtained via getDescription and set via setDescription.
 184+ *
 185+ * @since 0.4.3
 186+ *
 187+ * @var mixed string or false
 188+ */
 189+ protected $description = false;
 190+
 191+ /**
 192+ * Constructor.
 193+ *
 194+ * @since 0.4
 195+ *
 196+ * @param string $name
 197+ * @param string $type
 198+ * @param mixed $default Use null for no default (which makes the parameter required)
 199+ * @param array $aliases
 200+ * @param array $criteria
 201+ * @param array $dependencies
 202+ */
 203+ public function __construct( $name, $type = Parameter::TYPE_STRING,
 204+ $default = null, array $aliases = array(), array $criteria = array(), array $dependencies = array() ) {
 205+
 206+ $this->name = $name;
 207+ $this->type = $type;
 208+ $this->default = $default;
 209+ $this->aliases = $aliases;
 210+
 211+ $this->cleanCriteria( $criteria );
 212+ $this->criteria = $criteria;
 213+
 214+ $this->dependencies = $dependencies;
 215+ }
 216+
 217+ /**
 218+ * Ensures all Validator 3.x-style criteria definitions are converted into ParameterCriterion instances.
 219+ *
 220+ * @since 0.4
 221+ *
 222+ * @param array $criteria
 223+ */
 224+ protected function cleanCriteria( array &$criteria ) {
 225+ foreach ( $criteria as $key => &$criterion ) {
 226+ if ( !$criterion instanceof ParameterCriterion ) {
 227+ throw new Exception( "$key is not a valid ParameterCriterion." );
 228+ }
 229+ }
 230+ }
 231+
 232+ /**
 233+ * Adds one or more aliases for the parameter name.
 234+ *
 235+ * @since 0.4
 236+ *
 237+ * @param mixed $aliases string or array of string
 238+ */
 239+ public function addAliases() {
 240+ $args = func_get_args();
 241+ $this->aliases = array_merge( $this->aliases, is_array( $args[0] ) ? $args[0] : $args );
 242+ }
 243+
 244+ /**
 245+ * Adds one or more ParameterCriterion.
 246+ *
 247+ * @since 0.4
 248+ *
 249+ * @param mixed $criteria ParameterCriterion or array of ParameterCriterion
 250+ */
 251+ public function addCriteria() {
 252+ $args = func_get_args();
 253+ $this->criteria = array_merge( $this->criteria, is_array( $args[0] ) ? $args[0] : $args );
 254+ }
 255+
 256+ /**
 257+ * Adds one or more dependencies. There are the names of parameters
 258+ * that need to be validated and formatted before this one.
 259+ *
 260+ * @since 0.4
 261+ *
 262+ * @return array
 263+ */
 264+ public function addDependencies() {
 265+ $args = func_get_args();
 266+ $this->dependencies = array_merge( $this->dependencies, is_array( $args[0] ) ? $args[0] : $args );
 267+ }
 268+
 269+ /**
 270+ * Adds one or more ParameterManipulation.
 271+ *
 272+ * @since 0.4
 273+ *
 274+ * @param mixed $manipulations ParameterManipulation or array of ParameterManipulation
 275+ */
 276+ public function addManipulations( $manipulations ) {
 277+ $args = func_get_args();
 278+ $this->manipulations = array_merge( $this->manipulations, is_array( $args[0] ) ? $args[0] : $args );
 279+ }
 280+
 281+ /**
 282+ * Sets and cleans the original value and name.
 283+ *
 284+ * @since 0.4
 285+ *
 286+ * @param string $paramName
 287+ * @param string $paramValue
 288+ *
 289+ * @return boolean
 290+ */
 291+ public function setUserValue( $paramName, $paramValue ) {
 292+ if ( $this->setCount > 0 && !self::$acceptOverriding ) {
 293+ // TODO: fatal error
 294+ /*
 295+ $this->registerError(
 296+ wfMsgExt(
 297+ 'validator-error-override-argument',
 298+ 'parsemag',
 299+ $paramName,
 300+ $this->mParameters[$mainName]['original-value'],
 301+ is_array( $paramData ) ? $paramData['original-value'] : $paramData
 302+ ),
 303+ 'override'
 304+ );
 305+ */
 306+ return false;
 307+ }
 308+ else {
 309+ $this->originalName = $paramName;
 310+ $this->originalValue = $paramValue;
 311+
 312+ $this->cleanValue();
 313+
 314+ $this->setCount++;
 315+
 316+ return true;
 317+ }
 318+ }
 319+
 320+ /**
 321+ * Sets the value.
 322+ *
 323+ * @since 0.4
 324+ *
 325+ * @param mixed $value
 326+ */
 327+ public function setValue( $value ) {
 328+ $this->value = $value;
 329+ }
 330+
 331+ /**
 332+ * Sets the $value to a cleaned value of $originalValue.
 333+ *
 334+ * @since 0.4
 335+ */
 336+ protected function cleanValue() {
 337+ $this->value = $this->originalValue;
 338+
 339+ if ( $this->trimValue ) {
 340+ $this->value = trim( $this->value );
 341+ }
 342+ }
 343+
 344+ /**
 345+ * Validates the parameter value and sets the value to it's default when errors occur.
 346+ *
 347+ * @since 0.4
 348+ *
 349+ * @param array $parameters
 350+ */
 351+ public function validate( array $parameters ) {
 352+ $this->doValidation( $parameters );
 353+ }
 354+
 355+ /**
 356+ * Applies the parameter manipulations.
 357+ *
 358+ * @since 0.4
 359+ *
 360+ * @param array $parameters
 361+ */
 362+ public function format( array &$parameters ) {
 363+ if ( $this->applyManipulationsToDefault || !$this->wasSetToDefault() ) {
 364+ foreach ( $this->getManipulations() as $manipulation ) {
 365+ $manipulation->manipulate( $this, $parameters );
 366+ }
 367+ }
 368+ }
 369+
 370+ /**
 371+ * Validates the parameter value.
 372+ * Also sets the value to the default when it's not set or invalid, assuming there is a default.
 373+ *
 374+ * @since 0.4
 375+ *
 376+ * @param array $parameters
 377+ */
 378+ protected function doValidation( array $parameters ) {
 379+ if ( $this->setCount == 0 ) {
 380+ if ( $this->isRequired() ) {
 381+ // This should not occur, so thorw an exception.
 382+ throw new Exception( 'Attempted to validate a required parameter without first setting a value.' );
 383+ }
 384+ else {
 385+ $this->setToDefault();
 386+ }
 387+ }
 388+ else {
 389+ $this->validateCriteria( $parameters );
 390+ $this->setToDefaultIfNeeded();
 391+ }
 392+ }
 393+
 394+ /**
 395+ * Sets the parameter value to the default if needed.
 396+ *
 397+ * @since 0.4
 398+ */
 399+ protected function setToDefaultIfNeeded() {
 400+ if ( count( $this->errors ) > 0 && !$this->hasFatalError() ) {
 401+ $this->setToDefault();
 402+ }
 403+ }
 404+
 405+ /**
 406+ * Validates the provided value against all criteria.
 407+ *
 408+ * @since 0.4
 409+ *
 410+ * @param array $parameters
 411+ */
 412+ protected function validateCriteria( array $parameters ) {
 413+ foreach ( $this->getCriteria() as $criterion ) {
 414+ $validationResult = $criterion->validate( $this, $parameters );
 415+
 416+ if ( !$validationResult->isValid() ) {
 417+ $this->handleValidationError( $validationResult );
 418+
 419+ if ( !self::$accumulateParameterErrors || $this->hasFatalError() ) {
 420+ break;
 421+ }
 422+ }
 423+ }
 424+ }
 425+
 426+ /**
 427+ * Handles any validation errors that occured for a single criterion.
 428+ *
 429+ * @since 0.4
 430+ *
 431+ * @param CriterionValidationResult $validationResult
 432+ */
 433+ protected function handleValidationError( CriterionValidationResult $validationResult ) {
 434+ foreach ( $validationResult->getErrors() as $error ) {
 435+ $error->addTags( $this->getName() );
 436+ $this->errors[] = $error;
 437+ }
 438+ }
 439+
 440+ /**
 441+ * Returns the parameters main name.
 442+ *
 443+ * @since 0.4
 444+ *
 445+ * @return string
 446+ */
 447+ public function getName() {
 448+ return $this->name;
 449+ }
 450+
 451+ /**
 452+ * Returns the parameters value.
 453+ *
 454+ * @since 0.4
 455+ *
 456+ * @return string
 457+ */
 458+ public function &getValue() {
 459+ return $this->value;
 460+ }
 461+
 462+ /**
 463+ * Returns the type of the parameter.
 464+ *
 465+ * @since 0.4.3
 466+ *
 467+ * @return string element of the Parameter::TYPE_ enum
 468+ */
 469+ public function getType() {
 470+ return $this->type;
 471+ }
 472+
 473+ /**
 474+ * Returns an internationalized message indicating the parameter type suited for display to users.
 475+ *
 476+ * @since 0.4.3
 477+ *
 478+ * @return string
 479+ */
 480+ public function getTypeMessage() {
 481+ $message = wfMsg( 'validator-type-' . $this->type );
 482+ return $this->isList() ?
 483+ wfMsgExt( 'validator-describe-listtype', 'parsemag', $message )
 484+ : Language::ucfirst( $message );
 485+ }
 486+
 487+ /**
 488+ * Returns a list of dependencies the parameter has, in the form of
 489+ * other parameter names.
 490+ *
 491+ * @since 0.4
 492+ *
 493+ * @return array
 494+ */
 495+ public function getDependencies() {
 496+ return $this->dependencies;
 497+ }
 498+
 499+ /**
 500+ * Returns the original use-provided name.
 501+ *
 502+ * @since 0.4
 503+ *
 504+ * @return string
 505+ */
 506+ public function getOriginalName() {
 507+ if ( $this->setCount == 0 ) {
 508+ throw new Exception( 'No user imput set to the parameter yet, so the original name does not exist' );
 509+ }
 510+ return $this->originalName;
 511+ }
 512+
 513+ /**
 514+ * Returns the original use-provided value.
 515+ *
 516+ * @since 0.4
 517+ *
 518+ * @return string
 519+ */
 520+ public function getOriginalValue() {
 521+ if ( $this->setCount == 0 ) {
 522+ throw new Exception( 'No user imput set to the parameter yet, so the original value does not exist' );
 523+ }
 524+ return $this->originalValue;
 525+ }
 526+
 527+ /**
 528+ * Returns all validation errors that occured so far.
 529+ *
 530+ * @since 0.4
 531+ *
 532+ * @return array of ValidationError
 533+ */
 534+ public function getErrors() {
 535+ return $this->errors;
 536+ }
 537+
 538+ /**
 539+ * Returns if the parameter is a required one or not.
 540+ *
 541+ * @since 0.4
 542+ *
 543+ * @return boolean
 544+ */
 545+ public function isRequired() {
 546+ return is_null( $this->default );
 547+ }
 548+
 549+ /**
 550+ * Returns if the parameter is a list or not.
 551+ *
 552+ * @since 0.4
 553+ *
 554+ * @return boolean
 555+ */
 556+ public function isList() {
 557+ return false;
 558+ }
 559+
 560+ /**
 561+ * Returns the parameter criteria.
 562+ *
 563+ * @since 0.4
 564+ *
 565+ * @return array of ParameterCriterion
 566+ */
 567+ public function getCriteria() {
 568+ return array_merge( $this->getCriteriaForType(), $this->criteria );
 569+ }
 570+
 571+ /**
 572+ * Returns the parameter manipulations.
 573+ *
 574+ * @since 0.4
 575+ *
 576+ * @return array of ParameterManipulation
 577+ */
 578+ public function getManipulations() {
 579+ return array_merge( $this->getManipulationsForType(), $this->manipulations );
 580+ }
 581+
 582+ /**
 583+ * Gets the criteria for the type of the parameter.
 584+ *
 585+ * @since 0.4
 586+ *
 587+ * @return array
 588+ */
 589+ protected function getCriteriaForType() {
 590+ $criteria = array();
 591+
 592+ switch( $this->type ) {
 593+ case self::TYPE_INTEGER:
 594+ $criteria[] = new CriterionIsInteger();
 595+ break;
 596+ case self::TYPE_FLOAT:
 597+ $criteria[] = new CriterionIsFloat();
 598+ break;
 599+ case self::TYPE_NUMBER: // Note: This accepts non-decimal notations!
 600+ $criteria[] = new CriterionIsNumeric();
 601+ break;
 602+ case self::TYPE_BOOLEAN:
 603+ // TODO: work with list of true and false values and i18n.
 604+ $criteria[] = new CriterionInArray( 'yes', 'no', 'on', 'off' );
 605+ break;
 606+ case self::TYPE_CHAR:
 607+ $criteria[] = new CriterionHasLength( 1, 1 );
 608+ break;
 609+ case self::TYPE_STRING: default:
 610+ // No extra criteria for strings.
 611+ break;
 612+ }
 613+
 614+ return $criteria;
 615+ }
 616+
 617+ /**
 618+ * Gets the manipulation for the type of the parameter.
 619+ *
 620+ * @since 0.4
 621+ *
 622+ * @return array
 623+ */
 624+ protected function getManipulationsForType() {
 625+ $manipulations = array();
 626+
 627+ switch( $this->type ) {
 628+ case self::TYPE_INTEGER:
 629+ $manipulations[] = new ParamManipulationInteger();
 630+ break;
 631+ case self::TYPE_FLOAT: case self::TYPE_NUMBER:
 632+ $manipulations[] = new ParamManipulationFloat();
 633+ break;
 634+ case self::TYPE_BOOLEAN:
 635+ $manipulations[] = new ParamManipulationBoolean();
 636+ break;
 637+ case self::TYPE_CHAR: case self::TYPE_STRING: default:
 638+ // No extra manipulations for these types
 639+ break;
 640+ }
 641+
 642+ return $manipulations;
 643+ }
 644+
 645+ /**
 646+ * Sets the parameter value to the default.
 647+ *
 648+ * @since 0.4
 649+ */
 650+ protected function setToDefault() {
 651+ $this->defaulted = true;
 652+ $this->value = $this->default;
 653+ }
 654+
 655+ /**
 656+ * Gets if the parameter was set to it's default.
 657+ *
 658+ * @since 0.4
 659+ *
 660+ * @return boolean
 661+ */
 662+ public function wasSetToDefault() {
 663+ return $this->defaulted;
 664+ }
 665+
 666+ /**
 667+ * Returns the criteria that apply to the list as a whole.
 668+ *
 669+ * @since 0.4
 670+ *
 671+ * @return array
 672+ */
 673+ public function getListCriteria() {
 674+ return array();
 675+ }
 676+
 677+ /**
 678+ * Returns the parameter name aliases.
 679+ *
 680+ * @since 0.4
 681+ *
 682+ * @return array
 683+ */
 684+ public function getAliases() {
 685+ return $this->aliases;
 686+ }
 687+
 688+ /**
 689+ * Returns if the parameter has a certain alias.
 690+ *
 691+ * @since 0.4
 692+ *
 693+ * @param string $alias
 694+ *
 695+ * @return boolean
 696+ */
 697+ public function hasAlias( $alias ) {
 698+ return in_array( $alias, $this->getAliases() );
 699+ }
 700+
 701+ /**
 702+ * Returns if the parameter has a certain dependency.
 703+ *
 704+ * @since 0.4
 705+ *
 706+ * @param string $dependency
 707+ *
 708+ * @return boolean
 709+ */
 710+ public function hasDependency( $dependency ) {
 711+ return in_array( $dependency, $this->getDependencies() );
 712+ }
 713+
 714+ /**
 715+ * Sets the default parameter value. Null indicates no default,
 716+ * and therefore makes the parameter required.
 717+ *
 718+ * @since 0.4
 719+ *
 720+ * @param mixed $default
 721+ */
 722+ public function setDefault( $default ) {
 723+ $this->default = $default;
 724+ }
 725+
 726+ /**
 727+ * Returns the default value.
 728+ *
 729+ * @since 0.4.3
 730+ *
 731+ * @return mixed
 732+ */
 733+ public function getDefault() {
 734+ return $this->default;
 735+ }
 736+
 737+ /**
 738+ * Set if the parameter manipualations should be applied to the default value.
 739+ *
 740+ * @since 0.4
 741+ *
 742+ * @param boolean $doOrDoNot
 743+ */
 744+ public function setDoManipulationOfDefault( $doOrDoNot ) {
 745+ $this->applyManipulationsToDefault = $doOrDoNot;
 746+ }
 747+
 748+ /**
 749+ * Returns false when there are no fatal errors or an ValidationError when one is found.
 750+ *
 751+ * @return mixed false or ValidationError
 752+ */
 753+ public function hasFatalError() {
 754+ foreach ( $this->errors as $error ) {
 755+ if ( $error->isFatal() ) {
 756+ return true;
 757+ }
 758+ }
 759+
 760+ return false;
 761+ }
 762+
 763+ /**
 764+ * Returns a description message for the parameter, or false when there is none.
 765+ * Override in deriving classes to add a message.
 766+ *
 767+ * @since 0.4.3
 768+ *
 769+ * @return mixed string or false
 770+ */
 771+ public function getDescription() {
 772+ return $this->description;
 773+ }
 774+
 775+ /**
 776+ * Sets a description message for the parameter.
 777+ *
 778+ * @since 0.4.3
 779+ *
 780+ * @param string $descriptionMessage
 781+ */
 782+ public function setDescription( $descriptionMessage ) {
 783+ $this->description = $descriptionMessage;
 784+ }
 785+
 786+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/Parameter.php
___________________________________________________________________
Added: svn:eol-style
1787 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/TopologicalSort.php
@@ -0,0 +1,163 @@
 2+<?php
 3+
 4+/**
 5+ * Sorts a series of dependency pairs in linear order.
 6+ *
 7+ * Based on http://blog.metafoundry.com/2007/09/topological-sort-in-php.html
 8+ *
 9+ * usage:
 10+ * $t = new TopologicalSort($dependency_pairs);
 11+ * $load_order = $t->doSort();
 12+ *
 13+ * where dependency_pairs is in the form:
 14+ * $name => (depends on) $value
 15+ *
 16+ * @author Eddie Haber
 17+ * @author Jeroen De Dauw
 18+ *
 19+ * TODO: fix conventions further
 20+ * TODO: include/load class
 21+ * TODO: Use in revised version of Validator class
 22+ */
 23+class TopologicalSort {
 24+
 25+ private $mNodes = array();
 26+ private $mNodeNames = array();
 27+
 28+ /**
 29+ * Dependency pairs are a list of arrays in the form
 30+ * $name => $val where $key must come before $val in load order.
 31+ */
 32+ function __construct( $dependencies = array(), $parse = true ) {
 33+ $this->mNodeNames = array_keys( $dependencies );
 34+
 35+ if ( $parse ) {
 36+ $dependencies = $this->parseDependencyList( $dependencies );
 37+ }
 38+
 39+ // turn pairs into double-linked node tree
 40+ foreach ( $dependencies as $key => $dpair ) {
 41+ list ( $module, $dependency ) = each ( $dpair );
 42+ if ( !isset( $this->mNodes[$module] ) ) $this->mNodes[$module] = new TSNode( $module );
 43+ if ( !isset( $this->mNodes[$dependency] ) ) $this->mNodes[$dependency] = new TSNode( $dependency );
 44+ if ( !in_array( $dependency, $this->mNodes[$module]->children ) ) $this->mNodes[$module]->children[] = $dependency;
 45+ if ( !in_array( $module, $this->mNodes[$dependency]->parents ) ) $this->mNodes[$dependency]->parents[] = $module;
 46+ }
 47+ }
 48+
 49+ /**
 50+ * Perform Topological Sort.
 51+ *
 52+ * @return sorted array
 53+ */
 54+ public function doSort() {
 55+ $nodes = $this->mNodes;
 56+
 57+ // get nodes without parents
 58+ $root_nodes = array_values( $this->getRootNodes( $nodes ) );
 59+
 60+ // begin algorithm
 61+ $sorted = array();
 62+ while ( count( $nodes ) > 0 ) {
 63+ // check for circular reference
 64+ if ( count( $root_nodes ) == 0 ) return false;
 65+
 66+
 67+ // remove this node from root_nodes
 68+ // and add it to the output
 69+ $n = array_pop( $root_nodes );
 70+ $sorted[] = $n->name;
 71+
 72+ // for each of its children
 73+ // queue the new node finally remove the original
 74+ for ( $i = count( $n->children ) - 1; $i >= 0; $i -- ) {
 75+ $childnode = $n->children[$i];
 76+ // remove the link from this node to its
 77+ // children ($nodes[$n->name]->children[$i]) AND
 78+ // remove the link from each child to this
 79+ // parent ($nodes[$childnode]->parents[?]) THEN
 80+ // remove this child from this node
 81+ unset( $nodes[$n->name]->children[$i] );
 82+ $parent_position = array_search ( $n->name, $nodes[$childnode]->parents );
 83+ unset( $nodes[$childnode]->parents[$parent_position] );
 84+ // check if this child has other parents
 85+ // if not, add it to the root nodes list
 86+ if ( !count( $nodes[$childnode]->parents ) ) {
 87+ array_push( $root_nodes, $nodes [$childnode] );
 88+ }
 89+ }
 90+
 91+ // nodes.Remove(n);
 92+ unset( $nodes[$n->name] );
 93+ }
 94+
 95+ $looseNodes = array();
 96+
 97+ // Return the result with the loose nodes (items with no dependencies) appended.
 98+ foreach( $this->mNodeNames as $name ) {
 99+ if ( !in_array( $name, $sorted ) ) {
 100+ $looseNodes[] = $name;
 101+ }
 102+ }
 103+
 104+ return array_merge( $sorted, $looseNodes );
 105+ }
 106+
 107+ /**
 108+ * Returns a list of node objects that do not have parents
 109+ *
 110+ * @param array $nodes array of node objects
 111+ *
 112+ * @return array of node objects
 113+ */
 114+ private function getRootNodes( array $nodes ) {
 115+ $output = array ();
 116+
 117+ foreach ( $nodes as $name => $node ) {
 118+ if ( !count ( $node->parents ) ) {
 119+ $output[$name] = $node;
 120+ }
 121+ }
 122+
 123+ return $output;
 124+ }
 125+
 126+ /**
 127+ * Parses an array of dependencies into an array of dependency pairs
 128+ *
 129+ * The array of dependencies would be in the form:
 130+ * $dependency_list = array(
 131+ * "name" => array("dependency1","dependency2","dependency3"),
 132+ * "name2" => array("dependencyA","dependencyB","dependencyC"),
 133+ * ...etc
 134+ * );
 135+ *
 136+ * @param array $dlist Array of dependency pairs for use as parameter in doSort method
 137+ *
 138+ * @return array
 139+ */
 140+ private function parseDependencyList( array $dlist = array() ) {
 141+ $output = array();
 142+
 143+ foreach ( $dlist as $name => $dependencies ) {
 144+ foreach ( $dependencies as $d ) {
 145+ array_push ( $output, array ( $d => $name ) );
 146+ }
 147+ }
 148+
 149+ return $output;
 150+ }
 151+}
 152+
 153+/**
 154+ * Node class for Topological Sort Class
 155+ */
 156+class TSNode {
 157+ public $name;
 158+ public $children = array();
 159+ public $parents = array();
 160+
 161+ public function TSNode( $name = '' ) {
 162+ $this->name = $name;
 163+ }
 164+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/TopologicalSort.php
___________________________________________________________________
Added: svn:eol-style
1165 + native
Index: tags/extensions/Validator/REL_0_4_3/includes/Validator.php
@@ -0,0 +1,441 @@
 2+<?php
 3+
 4+/**
 5+ * Class for parameter validation of a single parser hook or other parameterized construct.
 6+ *
 7+ * @since 0.1
 8+ *
 9+ * @file Validator.php
 10+ * @ingroup Validator
 11+ *
 12+ * @author Jeroen De Dauw
 13+ *
 14+ * TODO: break on fatal errors, such as missing required parameters that are dependencies
 15+ */
 16+class Validator {
 17+
 18+ /**
 19+ * Array containing the parameters.
 20+ *
 21+ * @since 0.4
 22+ *
 23+ * @var array of Parameter
 24+ */
 25+ protected $parameters;
 26+
 27+ /**
 28+ * Asscoaitive array containing parameter names (keys) and their user-provided data (values).
 29+ * This list is needed because adittional parameter definitions can be added to the $parameters
 30+ * feild during validation, so we can't determine in advance if a parameter is unknown.
 31+ *
 32+ * @since 0.4
 33+ *
 34+ * @var array of string
 35+ */
 36+ protected $rawParameters = array();
 37+
 38+ /**
 39+ * Array containing the names of the parameters to handle, ordered by priority.
 40+ *
 41+ * @since 0.4
 42+ *
 43+ * @var array
 44+ */
 45+ protected $paramsToHandle = array();
 46+
 47+ /**
 48+ * List of ValidationError.
 49+ *
 50+ * @since 0.4
 51+ *
 52+ * @var array
 53+ */
 54+ protected $errors = array();
 55+
 56+ /**
 57+ * Name of the element that's being validated.
 58+ *
 59+ * @since 0.4
 60+ *
 61+ * @var string
 62+ */
 63+ protected $element;
 64+
 65+ /**
 66+ * Indicates if unknown parameters should be seen as invalid.
 67+ * If this value is false, they will simply be ignored.
 68+ *
 69+ * @since 0.4.3
 70+ *
 71+ * @var boolean
 72+ */
 73+ protected $unknownInvalid;
 74+
 75+ /**
 76+ * Constructor.
 77+ *
 78+ * @param srting $element
 79+ *
 80+ * @since 0.4
 81+ */
 82+ public function __construct( $element = '', $unknownInvalid = true ) {
 83+ $this->element = $element;
 84+ $this->unknownInvalid = $unknownInvalid;
 85+ }
 86+
 87+ /**
 88+ * Determines the names and values of all parameters. Also takes care of default parameters.
 89+ * After that the resulting parameter list is passed to Validator::setParameters
 90+ *
 91+ * @since 0.4
 92+ *
 93+ * @param array $rawParams
 94+ * @param array $parameterInfo
 95+ * @param array $defaultParams
 96+ * @param boolean $toLower Indicates if the parameter values should be put to lower case. Defaults to true.
 97+ */
 98+ public function setFunctionParams( array $rawParams, array $parameterInfo, array $defaultParams = array(), $toLower = true ) {
 99+ $parameters = array();
 100+
 101+ $nr = 0;
 102+ $defaultNr = 0;
 103+
 104+ foreach ( $rawParams as $arg ) {
 105+ // Only take into account strings. If the value is not a string,
 106+ // it is not a raw parameter, and can not be parsed correctly in all cases.
 107+ if ( is_string( $arg ) ) {
 108+ $parts = explode( '=', $arg, 2 );
 109+
 110+ // If there is only one part, no parameter name is provided, so try default parameter assignment.
 111+ if ( count( $parts ) == 1 ) {
 112+ // Default parameter assignment is only possible when there are default parameters!
 113+ if ( count( $defaultParams ) > 0 ) {
 114+ $defaultParam = strtolower( array_shift( $defaultParams ) );
 115+
 116+ $parameters[$defaultParam] = array(
 117+ 'original-value' => trim( $parts[0] ),
 118+ 'default' => $defaultNr,
 119+ 'position' => $nr
 120+ );
 121+ $defaultNr++;
 122+ }
 123+ else {
 124+ // It might be nice to have some sort of warning or error here, as the value is simply ignored.
 125+ }
 126+ } else {
 127+ $paramName = trim( strtolower( $parts[0] ) );
 128+
 129+ $parameters[$paramName] = array(
 130+ 'original-value' => trim( $parts[1] ),
 131+ 'default' => false,
 132+ 'position' => $nr
 133+ );
 134+
 135+ // Let's not be evil, and remove the used parameter name from the default parameter list.
 136+ // This code is basically a remove array element by value algorithm.
 137+ $newDefaults = array();
 138+
 139+ foreach( $defaultParams as $defaultParam ) {
 140+ if ( $defaultParam != $paramName ) $newDefaults[] = $defaultParam;
 141+ }
 142+
 143+ $defaultParams = $newDefaults;
 144+ }
 145+ }
 146+
 147+ $nr++;
 148+ }
 149+
 150+ $this->setParameters( $parameters, $parameterInfo, false );
 151+ }
 152+
 153+ /**
 154+ * Loops through a list of provided parameters, resolves aliasing and stores errors
 155+ * for unknown parameters and optionally for parameter overriding.
 156+ *
 157+ * @param array $parameters Parameter name as key, parameter value as value
 158+ * @param array $parameterInfo Main parameter name as key, parameter meta data as valu
 159+ * @param boolean $toLower Indicates if the parameter values should be put to lower case. Defaults to true.
 160+ */
 161+ public function setParameters( array $parameters, array $parameterInfo, $toLower = true ) {
 162+ $this->cleanParameterInfo( $parameterInfo );
 163+
 164+ $this->parameters = $parameterInfo;
 165+
 166+ // Loop through all the user provided parameters, and destinguise between those that are allowed and those that are not.
 167+ foreach ( $parameters as $paramName => $paramData ) {
 168+ $paramName = trim( strtolower( $paramName ) );
 169+ $paramValue = is_array( $paramData ) ? $paramData['original-value'] : trim( $paramData );
 170+
 171+ $this->rawParameters[$paramName] = $paramValue;
 172+ }
 173+ }
 174+
 175+ /**
 176+ * Registers an error.
 177+ *
 178+ * @since 0.4
 179+ *
 180+ * @param string $message
 181+ * @param mixed $tags string or array
 182+ * @param integer $severity
 183+ */
 184+ protected function registerNewError( $message, $tags = array(), $severity = ValidationError::SEVERITY_NORMAL ) {
 185+ $this->registerError(
 186+ new ValidationError(
 187+ $message,
 188+ $severity,
 189+ $this->element,
 190+ (array)$tags
 191+ )
 192+ );
 193+ }
 194+
 195+ /**
 196+ * Registers an error.
 197+ *
 198+ * @since 0.4
 199+ *
 200+ * @param ValidationError $error
 201+ */
 202+ protected function registerError( ValidationError $error ) {
 203+ $error->element = $this->element;
 204+ $this->errors[] = $error;
 205+ ValidationErrorHandler::addError( $error );
 206+ }
 207+
 208+ /**
 209+ * Ensures all elements of the array are Parameter objects,
 210+ * and that the array keys match the main parameter name.
 211+ *
 212+ * @since 0.4
 213+ *
 214+ * @param array $paramInfo
 215+ */
 216+ protected function cleanParameterInfo( array &$paramInfo ) {
 217+ $cleanedList = array();
 218+
 219+ foreach ( $paramInfo as $key => $parameter ) {
 220+ if ( $parameter instanceof Parameter ) {
 221+ $cleanedList[$parameter->getName()] = $parameter;
 222+ }
 223+ else {
 224+ throw new Exception( "$key is not a valid Parameter." );
 225+ }
 226+ }
 227+
 228+ $paramInfo = $cleanedList;
 229+ }
 230+
 231+ /**
 232+ * Validates and formats all the parameters (but aborts when a fatal error occurs).
 233+ *
 234+ * @since 0.4
 235+ */
 236+ public function validateParameters() {
 237+ $this->doParamProcessing();
 238+
 239+ if ( !$this->hasFatalError() && $this->unknownInvalid ) {
 240+ // Loop over the remaining raw parameters.
 241+ // These are unrecognized parameters, as they where not used by any parameter definition.
 242+ foreach ( $this->rawParameters as $paramName => $paramValue ) {
 243+ $this->registerNewError(
 244+ wfMsgExt( 'validator_error_unknown_argument', 'parsemag', $paramName ),
 245+ $paramName
 246+ );
 247+ }
 248+ }
 249+ }
 250+
 251+ /**
 252+ * Does the actual parameter processing.
 253+ *
 254+ * @since 0.4
 255+ */
 256+ protected function doParamProcessing() {
 257+ $this->getParamsToProcess( array(), $this->parameters );
 258+
 259+ while ( $paramName = array_shift( $this->paramsTohandle ) ) {
 260+ $parameter = $this->parameters[$paramName];
 261+
 262+ $setUservalue = $this->attemptToSetUserValue( $parameter );
 263+
 264+ // If the parameter is required but not provided, register a fatal error and stop processing.
 265+ if ( !$setUservalue && $parameter->isRequired() ) {
 266+ $this->registerNewError(
 267+ wfMsgExt( 'validator_error_required_missing', 'parsemag', $paramName ),
 268+ array( $paramName, 'missing' ),
 269+ ValidationError::SEVERITY_FATAL
 270+ );
 271+ break;
 272+ }
 273+ else {
 274+ $parameter->validate( $this->parameters );
 275+
 276+ foreach ( $parameter->getErrors() as $error ) {
 277+ $this->registerError( $error );
 278+ }
 279+
 280+ if ( $parameter->hasFatalError() ) {
 281+ // If there was a fatal error, and the parameter is required, stop processing.
 282+ break;
 283+ }
 284+
 285+ $initialSet = $this->parameters;
 286+
 287+ $parameter->format( $this->parameters );
 288+
 289+ $this->getParamsToProcess( $initialSet, $this->parameters );
 290+ }
 291+ }
 292+ }
 293+
 294+ /**
 295+ * Gets an ordered list of parameters to process.
 296+ *
 297+ * @since 0.4
 298+ *
 299+ * @param array $initialParamSet
 300+ * @param array $resultingParamSet
 301+ */
 302+ protected function getParamsToProcess( array $initialParamSet, array $resultingParamSet ) {
 303+ if ( count( $initialParamSet ) == 0 ) {
 304+ $this->paramsTohandle = array_keys( $resultingParamSet );
 305+ }
 306+ else {
 307+ if ( !is_array( $this->paramsTohandle ) ) {
 308+ $this->paramsTohandle = array();
 309+ }
 310+
 311+ foreach ( $resultingParamSet as $paramName => $parameter ) {
 312+ if ( !array_key_exists( $paramName, $initialParamSet ) ) {
 313+ $this->paramsTohandle[] = $paramName;
 314+ }
 315+ }
 316+ }
 317+
 318+ $dependencyList = array();
 319+
 320+ // Loop over the parameters to handle to create a dependency list.
 321+ foreach ( $this->paramsTohandle as $paramName ) {
 322+ $dependencies = array();
 323+
 324+ // Only include dependencies that are in the list of parameters to handle.
 325+ foreach ( $this->parameters[$paramName]->getDependencies() as $dependency ) {
 326+ if ( in_array( $dependency, $this->paramsTohandle ) ) {
 327+ $dependencies[] = $dependency;
 328+ }
 329+ }
 330+
 331+ $dependencyList[$paramName] = $dependencies;
 332+ }
 333+
 334+ $sorter = new TopologicalSort( $dependencyList, true );
 335+
 336+ $this->paramsTohandle = $sorter->doSort();
 337+ }
 338+
 339+ /**
 340+ * Tries to find a matching user provided value and, when found, assingns it
 341+ * to the parameter, and removes it from the raw values. Returns a boolean
 342+ * indicating if there was any user value set or not.
 343+ *
 344+ * @since 0.4
 345+ *
 346+ * @return boolean
 347+ */
 348+ protected function attemptToSetUserValue( Parameter $parameter ) {
 349+ if ( array_key_exists( $parameter->getName(), $this->rawParameters ) ) {
 350+ $parameter->setUserValue( $parameter->getName(), $this->rawParameters[$parameter->getName()] );
 351+ unset( $this->rawParameters[$parameter->getName()] );
 352+ return true;
 353+ }
 354+ else {
 355+ foreach ( $parameter->getAliases() as $alias ) {
 356+ if ( array_key_exists( $alias, $this->rawParameters ) ) {
 357+ $parameter->setUserValue( $alias, $this->rawParameters[$alias] );
 358+ unset( $this->rawParameters[$alias] );
 359+ return true;
 360+ }
 361+ }
 362+ }
 363+
 364+ return false;
 365+ }
 366+
 367+ /**
 368+ * Returns the parameters.
 369+ *
 370+ * @since 0.4
 371+ *
 372+ * @return array
 373+ */
 374+ public function getParameters() {
 375+ return $this->parameters;
 376+ }
 377+
 378+ /**
 379+ * Returns a single parameter.
 380+ *
 381+ * @since 0.4
 382+ *
 383+ * @param string $parameterName The name of the parameter to return
 384+ *
 385+ * @return Parameter
 386+ */
 387+ public function getParameter( $parameterName ) {
 388+ return $this->parameters[$parameterName];
 389+ }
 390+
 391+ /**
 392+ * Returns an associative array with the parameter names as key and their
 393+ * correspinding values as value.
 394+ *
 395+ * @since 0.4
 396+ *
 397+ * @return array
 398+ */
 399+ public function getParameterValues() {
 400+ $parameters = array();
 401+
 402+ foreach ( $this->parameters as $parameter ) {
 403+ $parameters[$parameter->getName()] = $parameter->getValue();
 404+ }
 405+
 406+ return $parameters;
 407+ }
 408+
 409+ /**
 410+ * Returns the errors.
 411+ *
 412+ * @return array of ValidationError
 413+ */
 414+ public function getErrors() {
 415+ return $this->errors;
 416+ }
 417+
 418+ /**
 419+ * Returns if there where any errors during validation.
 420+ *
 421+ * @return boolean
 422+ */
 423+ public function hasErrors() {
 424+ return count( $this->errors ) > 0;
 425+ }
 426+
 427+ /**
 428+ * Returns false when there are no fatal errors or an ValidationError when one is found.
 429+ *
 430+ * @return mixed false or ValidationError
 431+ */
 432+ public function hasFatalError() {
 433+ foreach ( $this->errors as $error ) {
 434+ if ( $error->isFatal() ) {
 435+ return $error;
 436+ }
 437+ }
 438+
 439+ return false;
 440+ }
 441+
 442+}
\ No newline at end of file
Property changes on: tags/extensions/Validator/REL_0_4_3/includes/Validator.php
___________________________________________________________________
Added: svn:eol-style
1443 + native
Index: tags/extensions/Validator/REL_0_4_3/COPYING
@@ -0,0 +1,682 @@
 2+The license text below "----" applies to all files within this distribution, other
 3+than those that are in a directory which contains files named "LICENSE" or
 4+"COPYING", or a subdirectory thereof. For those files, the license text contained in
 5+said file overrides any license information contained in directories of smaller depth.
 6+Alternative licenses are typically used for software that is provided by external
 7+parties, and merely packaged with this software for convenience.
 8+----
 9+
 10+ GNU GENERAL PUBLIC LICENSE
 11+ Version 3, 29 June 2007
 12+
 13+ Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
 14+ Everyone is permitted to copy and distribute verbatim copies
 15+ of this license document, but changing it is not allowed.
 16+
 17+ Preamble
 18+
 19+ The GNU General Public License is a free, copyleft license for
 20+software and other kinds of works.
 21+
 22+ The licenses for most software and other practical works are designed
 23+to take away your freedom to share and change the works. By contrast,
 24+the GNU General Public License is intended to guarantee your freedom to
 25+share and change all versions of a program--to make sure it remains free
 26+software for all its users. We, the Free Software Foundation, use the
 27+GNU General Public License for most of our software; it applies also to
 28+any other work released this way by its authors. You can apply it to
 29+your programs, too.
 30+
 31+ When we speak of free software, we are referring to freedom, not
 32+price. Our General Public Licenses are designed to make sure that you
 33+have the freedom to distribute copies of free software (and charge for
 34+them if you wish), that you receive source code or can get it if you
 35+want it, that you can change the software or use pieces of it in new
 36+free programs, and that you know you can do these things.
 37+
 38+ To protect your rights, we need to prevent others from denying you
 39+these rights or asking you to surrender the rights. Therefore, you have
 40+certain responsibilities if you distribute copies of the software, or if
 41+you modify it: responsibilities to respect the freedom of others.
 42+
 43+ For example, if you distribute copies of such a program, whether
 44+gratis or for a fee, you must pass on to the recipients the same
 45+freedoms that you received. You must make sure that they, too, receive
 46+or can get the source code. And you must show them these terms so they
 47+know their rights.
 48+
 49+ Developers that use the GNU GPL protect your rights with two steps:
 50+(1) assert copyright on the software, and (2) offer you this License
 51+giving you legal permission to copy, distribute and/or modify it.
 52+
 53+ For the developers' and authors' protection, the GPL clearly explains
 54+that there is no warranty for this free software. For both users' and
 55+authors' sake, the GPL requires that modified versions be marked as
 56+changed, so that their problems will not be attributed erroneously to
 57+authors of previous versions.
 58+
 59+ Some devices are designed to deny users access to install or run
 60+modified versions of the software inside them, although the manufacturer
 61+can do so. This is fundamentally incompatible with the aim of
 62+protecting users' freedom to change the software. The systematic
 63+pattern of such abuse occurs in the area of products for individuals to
 64+use, which is precisely where it is most unacceptable. Therefore, we
 65+have designed this version of the GPL to prohibit the practice for those
 66+products. If such problems arise substantially in other domains, we
 67+stand ready to extend this provision to those domains in future versions
 68+of the GPL, as needed to protect the freedom of users.
 69+
 70+ Finally, every program is threatened constantly by software patents.
 71+States should not allow patents to restrict development and use of
 72+software on general-purpose computers, but in those that do, we wish to
 73+avoid the special danger that patents applied to a free program could
 74+make it effectively proprietary. To prevent this, the GPL assures that
 75+patents cannot be used to render the program non-free.
 76+
 77+ The precise terms and conditions for copying, distribution and
 78+modification follow.
 79+
 80+ TERMS AND CONDITIONS
 81+
 82+ 0. Definitions.
 83+
 84+ "This License" refers to version 3 of the GNU General Public License.
 85+
 86+ "Copyright" also means copyright-like laws that apply to other kinds of
 87+works, such as semiconductor masks.
 88+
 89+ "The Program" refers to any copyrightable work licensed under this
 90+License. Each licensee is addressed as "you". "Licensees" and
 91+"recipients" may be individuals or organizations.
 92+
 93+ To "modify" a work means to copy from or adapt all or part of the work
 94+in a fashion requiring copyright permission, other than the making of an
 95+exact copy. The resulting work is called a "modified version" of the
 96+earlier work or a work "based on" the earlier work.
 97+
 98+ A "covered work" means either the unmodified Program or a work based
 99+on the Program.
 100+
 101+ To "propagate" a work means to do anything with it that, without
 102+permission, would make you directly or secondarily liable for
 103+infringement under applicable copyright law, except executing it on a
 104+computer or modifying a private copy. Propagation includes copying,
 105+distribution (with or without modification), making available to the
 106+public, and in some countries other activities as well.
 107+
 108+ To "convey" a work means any kind of propagation that enables other
 109+parties to make or receive copies. Mere interaction with a user through
 110+a computer network, with no transfer of a copy, is not conveying.
 111+
 112+ An interactive user interface displays "Appropriate Legal Notices"
 113+to the extent that it includes a convenient and prominently visible
 114+feature that (1) displays an appropriate copyright notice, and (2)
 115+tells the user that there is no warranty for the work (except to the
 116+extent that warranties are provided), that licensees may convey the
 117+work under this License, and how to view a copy of this License. If
 118+the interface presents a list of user commands or options, such as a
 119+menu, a prominent item in the list meets this criterion.
 120+
 121+ 1. Source Code.
 122+
 123+ The "source code" for a work means the preferred form of the work
 124+for making modifications to it. "Object code" means any non-source
 125+form of a work.
 126+
 127+ A "Standard Interface" means an interface that either is an official
 128+standard defined by a recognized standards body, or, in the case of
 129+interfaces specified for a particular programming language, one that
 130+is widely used among developers working in that language.
 131+
 132+ The "System Libraries" of an executable work include anything, other
 133+than the work as a whole, that (a) is included in the normal form of
 134+packaging a Major Component, but which is not part of that Major
 135+Component, and (b) serves only to enable use of the work with that
 136+Major Component, or to implement a Standard Interface for which an
 137+implementation is available to the public in source code form. A
 138+"Major Component", in this context, means a major essential component
 139+(kernel, window system, and so on) of the specific operating system
 140+(if any) on which the executable work runs, or a compiler used to
 141+produce the work, or an object code interpreter used to run it.
 142+
 143+ The "Corresponding Source" for a work in object code form means all
 144+the source code needed to generate, install, and (for an executable
 145+work) run the object code and to modify the work, including scripts to
 146+control those activities. However, it does not include the work's
 147+System Libraries, or general-purpose tools or generally available free
 148+programs which are used unmodified in performing those activities but
 149+which are not part of the work. For example, Corresponding Source
 150+includes interface definition files associated with source files for
 151+the work, and the source code for shared libraries and dynamically
 152+linked subprograms that the work is specifically designed to require,
 153+such as by intimate data communication or control flow between those
 154+subprograms and other parts of the work.
 155+
 156+ The Corresponding Source need not include anything that users
 157+can regenerate automatically from other parts of the Corresponding
 158+Source.
 159+
 160+ The Corresponding Source for a work in source code form is that
 161+same work.
 162+
 163+ 2. Basic Permissions.
 164+
 165+ All rights granted under this License are granted for the term of
 166+copyright on the Program, and are irrevocable provided the stated
 167+conditions are met. This License explicitly affirms your unlimited
 168+permission to run the unmodified Program. The output from running a
 169+covered work is covered by this License only if the output, given its
 170+content, constitutes a covered work. This License acknowledges your
 171+rights of fair use or other equivalent, as provided by copyright law.
 172+
 173+ You may make, run and propagate covered works that you do not
 174+convey, without conditions so long as your license otherwise remains
 175+in force. You may convey covered works to others for the sole purpose
 176+of having them make modifications exclusively for you, or provide you
 177+with facilities for running those works, provided that you comply with
 178+the terms of this License in conveying all material for which you do
 179+not control copyright. Those thus making or running the covered works
 180+for you must do so exclusively on your behalf, under your direction
 181+and control, on terms that prohibit them from making any copies of
 182+your copyrighted material outside their relationship with you.
 183+
 184+ Conveying under any other circumstances is permitted solely under
 185+the conditions stated below. Sublicensing is not allowed; section 10
 186+makes it unnecessary.
 187+
 188+ 3. Protecting Users' Legal Rights From Anti-Circumvention Law.
 189+
 190+ No covered work shall be deemed part of an effective technological
 191+measure under any applicable law fulfilling obligations under article
 192+11 of the WIPO copyright treaty adopted on 20 December 1996, or
 193+similar laws prohibiting or restricting circumvention of such
 194+measures.
 195+
 196+ When you convey a covered work, you waive any legal power to forbid
 197+circumvention of technological measures to the extent such circumvention
 198+is effected by exercising rights under this License with respect to
 199+the covered work, and you disclaim any intention to limit operation or
 200+modification of the work as a means of enforcing, against the work's
 201+users, your or third parties' legal rights to forbid circumvention of
 202+technological measures.
 203+
 204+ 4. Conveying Verbatim Copies.
 205+
 206+ You may convey verbatim copies of the Program's source code as you
 207+receive it, in any medium, provided that you conspicuously and
 208+appropriately publish on each copy an appropriate copyright notice;
 209+keep intact all notices stating that this License and any
 210+non-permissive terms added in accord with section 7 apply to the code;
 211+keep intact all notices of the absence of any warranty; and give all
 212+recipients a copy of this License along with the Program.
 213+
 214+ You may charge any price or no price for each copy that you convey,
 215+and you may offer support or warranty protection for a fee.
 216+
 217+ 5. Conveying Modified Source Versions.
 218+
 219+ You may convey a work based on the Program, or the modifications to
 220+produce it from the Program, in the form of source code under the
 221+terms of section 4, provided that you also meet all of these conditions:
 222+
 223+ a) The work must carry prominent notices stating that you modified
 224+ it, and giving a relevant date.
 225+
 226+ b) The work must carry prominent notices stating that it is
 227+ released under this License and any conditions added under section
 228+ 7. This requirement modifies the requirement in section 4 to
 229+ "keep intact all notices".
 230+
 231+ c) You must license the entire work, as a whole, under this
 232+ License to anyone who comes into possession of a copy. This
 233+ License will therefore apply, along with any applicable section 7
 234+ additional terms, to the whole of the work, and all its parts,
 235+ regardless of how they are packaged. This License gives no
 236+ permission to license the work in any other way, but it does not
 237+ invalidate such permission if you have separately received it.
 238+
 239+ d) If the work has interactive user interfaces, each must display
 240+ Appropriate Legal Notices; however, if the Program has interactive
 241+ interfaces that do not display Appropriate Legal Notices, your
 242+ work need not make them do so.
 243+
 244+ A compilation of a covered work with other separate and independent
 245+works, which are not by their nature extensions of the covered work,
 246+and which are not combined with it such as to form a larger program,
 247+in or on a volume of a storage or distribution medium, is called an
 248+"aggregate" if the compilation and its resulting copyright are not
 249+used to limit the access or legal rights of the compilation's users
 250+beyond what the individual works permit. Inclusion of a covered work
 251+in an aggregate does not cause this License to apply to the other
 252+parts of the aggregate.
 253+
 254+ 6. Conveying Non-Source Forms.
 255+
 256+ You may convey a covered work in object code form under the terms
 257+of sections 4 and 5, provided that you also convey the
 258+machine-readable Corresponding Source under the terms of this License,
 259+in one of these ways:
 260+
 261+ a) Convey the object code in, or embodied in, a physical product
 262+ (including a physical distribution medium), accompanied by the
 263+ Corresponding Source fixed on a durable physical medium
 264+ customarily used for software interchange.
 265+
 266+ b) Convey the object code in, or embodied in, a physical product
 267+ (including a physical distribution medium), accompanied by a
 268+ written offer, valid for at least three years and valid for as
 269+ long as you offer spare parts or customer support for that product
 270+ model, to give anyone who possesses the object code either (1) a
 271+ copy of the Corresponding Source for all the software in the
 272+ product that is covered by this License, on a durable physical
 273+ medium customarily used for software interchange, for a price no
 274+ more than your reasonable cost of physically performing this
 275+ conveying of source, or (2) access to copy the
 276+ Corresponding Source from a network server at no charge.
 277+
 278+ c) Convey individual copies of the object code with a copy of the
 279+ written offer to provide the Corresponding Source. This
 280+ alternative is allowed only occasionally and noncommercially, and
 281+ only if you received the object code with such an offer, in accord
 282+ with subsection 6b.
 283+
 284+ d) Convey the object code by offering access from a designated
 285+ place (gratis or for a charge), and offer equivalent access to the
 286+ Corresponding Source in the same way through the same place at no
 287+ further charge. You need not require recipients to copy the
 288+ Corresponding Source along with the object code. If the place to
 289+ copy the object code is a network server, the Corresponding Source
 290+ may be on a different server (operated by you or a third party)
 291+ that supports equivalent copying facilities, provided you maintain
 292+ clear directions next to the object code saying where to find the
 293+ Corresponding Source. Regardless of what server hosts the
 294+ Corresponding Source, you remain obligated to ensure that it is
 295+ available for as long as needed to satisfy these requirements.
 296+
 297+ e) Convey the object code using peer-to-peer transmission, provided
 298+ you inform other peers where the object code and Corresponding
 299+ Source of the work are being offered to the general public at no
 300+ charge under subsection 6d.
 301+
 302+ A separable portion of the object code, whose source code is excluded
 303+from the Corresponding Source as a System Library, need not be
 304+included in conveying the object code work.
 305+
 306+ A "User Product" is either (1) a "consumer product", which means any
 307+tangible personal property which is normally used for personal, family,
 308+or household purposes, or (2) anything designed or sold for incorporation
 309+into a dwelling. In determining whether a product is a consumer product,
 310+doubtful cases shall be resolved in favor of coverage. For a particular
 311+product received by a particular user, "normally used" refers to a
 312+typical or common use of that class of product, regardless of the status
 313+of the particular user or of the way in which the particular user
 314+actually uses, or expects or is expected to use, the product. A product
 315+is a consumer product regardless of whether the product has substantial
 316+commercial, industrial or non-consumer uses, unless such uses represent
 317+the only significant mode of use of the product.
 318+
 319+ "Installation Information" for a User Product means any methods,
 320+procedures, authorization keys, or other information required to install
 321+and execute modified versions of a covered work in that User Product from
 322+a modified version of its Corresponding Source. The information must
 323+suffice to ensure that the continued functioning of the modified object
 324+code is in no case prevented or interfered with solely because
 325+modification has been made.
 326+
 327+ If you convey an object code work under this section in, or with, or
 328+specifically for use in, a User Product, and the conveying occurs as
 329+part of a transaction in which the right of possession and use of the
 330+User Product is transferred to the recipient in perpetuity or for a
 331+fixed term (regardless of how the transaction is characterized), the
 332+Corresponding Source conveyed under this section must be accompanied
 333+by the Installation Information. But this requirement does not apply
 334+if neither you nor any third party retains the ability to install
 335+modified object code on the User Product (for example, the work has
 336+been installed in ROM).
 337+
 338+ The requirement to provide Installation Information does not include a
 339+requirement to continue to provide support service, warranty, or updates
 340+for a work that has been modified or installed by the recipient, or for
 341+the User Product in which it has been modified or installed. Access to a
 342+network may be denied when the modification itself materially and
 343+adversely affects the operation of the network or violates the rules and
 344+protocols for communication across the network.
 345+
 346+ Corresponding Source conveyed, and Installation Information provided,
 347+in accord with this section must be in a format that is publicly
 348+documented (and with an implementation available to the public in
 349+source code form), and must require no special password or key for
 350+unpacking, reading or copying.
 351+
 352+ 7. Additional Terms.
 353+
 354+ "Additional permissions" are terms that supplement the terms of this
 355+License by making exceptions from one or more of its conditions.
 356+Additional permissions that are applicable to the entire Program shall
 357+be treated as though they were included in this License, to the extent
 358+that they are valid under applicable law. If additional permissions
 359+apply only to part of the Program, that part may be used separately
 360+under those permissions, but the entire Program remains governed by
 361+this License without regard to the additional permissions.
 362+
 363+ When you convey a copy of a covered work, you may at your option
 364+remove any additional permissions from that copy, or from any part of
 365+it. (Additional permissions may be written to require their own
 366+removal in certain cases when you modify the work.) You may place
 367+additional permissions on material, added by you to a covered work,
 368+for which you have or can give appropriate copyright permission.
 369+
 370+ Notwithstanding any other provision of this License, for material you
 371+add to a covered work, you may (if authorized by the copyright holders of
 372+that material) supplement the terms of this License with terms:
 373+
 374+ a) Disclaiming warranty or limiting liability differently from the
 375+ terms of sections 15 and 16 of this License; or
 376+
 377+ b) Requiring preservation of specified reasonable legal notices or
 378+ author attributions in that material or in the Appropriate Legal
 379+ Notices displayed by works containing it; or
 380+
 381+ c) Prohibiting misrepresentation of the origin of that material, or
 382+ requiring that modified versions of such material be marked in
 383+ reasonable ways as different from the original version; or
 384+
 385+ d) Limiting the use for publicity purposes of names of licensors or
 386+ authors of the material; or
 387+
 388+ e) Declining to grant rights under trademark law for use of some
 389+ trade names, trademarks, or service marks; or
 390+
 391+ f) Requiring indemnification of licensors and authors of that
 392+ material by anyone who conveys the material (or modified versions of
 393+ it) with contractual assumptions of liability to the recipient, for
 394+ any liability that these contractual assumptions directly impose on
 395+ those licensors and authors.
 396+
 397+ All other non-permissive additional terms are considered "further
 398+restrictions" within the meaning of section 10. If the Program as you
 399+received it, or any part of it, contains a notice stating that it is
 400+governed by this License along with a term that is a further
 401+restriction, you may remove that term. If a license document contains
 402+a further restriction but permits relicensing or conveying under this
 403+License, you may add to a covered work material governed by the terms
 404+of that license document, provided that the further restriction does
 405+not survive such relicensing or conveying.
 406+
 407+ If you add terms to a covered work in accord with this section, you
 408+must place, in the relevant source files, a statement of the
 409+additional terms that apply to those files, or a notice indicating
 410+where to find the applicable terms.
 411+
 412+ Additional terms, permissive or non-permissive, may be stated in the
 413+form of a separately written license, or stated as exceptions;
 414+the above requirements apply either way.
 415+
 416+ 8. Termination.
 417+
 418+ You may not propagate or modify a covered work except as expressly
 419+provided under this License. Any attempt otherwise to propagate or
 420+modify it is void, and will automatically terminate your rights under
 421+this License (including any patent licenses granted under the third
 422+paragraph of section 11).
 423+
 424+ However, if you cease all violation of this License, then your
 425+license from a particular copyright holder is reinstated (a)
 426+provisionally, unless and until the copyright holder explicitly and
 427+finally terminates your license, and (b) permanently, if the copyright
 428+holder fails to notify you of the violation by some reasonable means
 429+prior to 60 days after the cessation.
 430+
 431+ Moreover, your license from a particular copyright holder is
 432+reinstated permanently if the copyright holder notifies you of the
 433+violation by some reasonable means, this is the first time you have
 434+received notice of violation of this License (for any work) from that
 435+copyright holder, and you cure the violation prior to 30 days after
 436+your receipt of the notice.
 437+
 438+ Termination of your rights under this section does not terminate the
 439+licenses of parties who have received copies or rights from you under
 440+this License. If your rights have been terminated and not permanently
 441+reinstated, you do not qualify to receive new licenses for the same
 442+material under section 10.
 443+
 444+ 9. Acceptance Not Required for Having Copies.
 445+
 446+ You are not required to accept this License in order to receive or
 447+run a copy of the Program. Ancillary propagation of a covered work
 448+occurring solely as a consequence of using peer-to-peer transmission
 449+to receive a copy likewise does not require acceptance. However,
 450+nothing other than this License grants you permission to propagate or
 451+modify any covered work. These actions infringe copyright if you do
 452+not accept this License. Therefore, by modifying or propagating a
 453+covered work, you indicate your acceptance of this License to do so.
 454+
 455+ 10. Automatic Licensing of Downstream Recipients.
 456+
 457+ Each time you convey a covered work, the recipient automatically
 458+receives a license from the original licensors, to run, modify and
 459+propagate that work, subject to this License. You are not responsible
 460+for enforcing compliance by third parties with this License.
 461+
 462+ An "entity transaction" is a transaction transferring control of an
 463+organization, or substantially all assets of one, or subdividing an
 464+organization, or merging organizations. If propagation of a covered
 465+work results from an entity transaction, each party to that
 466+transaction who receives a copy of the work also receives whatever
 467+licenses to the work the party's predecessor in interest had or could
 468+give under the previous paragraph, plus a right to possession of the
 469+Corresponding Source of the work from the predecessor in interest, if
 470+the predecessor has it or can get it with reasonable efforts.
 471+
 472+ You may not impose any further restrictions on the exercise of the
 473+rights granted or affirmed under this License. For example, you may
 474+not impose a license fee, royalty, or other charge for exercise of
 475+rights granted under this License, and you may not initiate litigation
 476+(including a cross-claim or counterclaim in a lawsuit) alleging that
 477+any patent claim is infringed by making, using, selling, offering for
 478+sale, or importing the Program or any portion of it.
 479+
 480+ 11. Patents.
 481+
 482+ A "contributor" is a copyright holder who authorizes use under this
 483+License of the Program or a work on which the Program is based. The
 484+work thus licensed is called the contributor's "contributor version".
 485+
 486+ A contributor's "essential patent claims" are all patent claims
 487+owned or controlled by the contributor, whether already acquired or
 488+hereafter acquired, that would be infringed by some manner, permitted
 489+by this License, of making, using, or selling its contributor version,
 490+but do not include claims that would be infringed only as a
 491+consequence of further modification of the contributor version. For
 492+purposes of this definition, "control" includes the right to grant
 493+patent sublicenses in a manner consistent with the requirements of
 494+this License.
 495+
 496+ Each contributor grants you a non-exclusive, worldwide, royalty-free
 497+patent license under the contributor's essential patent claims, to
 498+make, use, sell, offer for sale, import and otherwise run, modify and
 499+propagate the contents of its contributor version.
 500+
 501+ In the following three paragraphs, a "patent license" is any express
 502+agreement or commitment, however denominated, not to enforce a patent
 503+(such as an express permission to practice a patent or covenant not to
 504+sue for patent infringement). To "grant" such a patent license to a
 505+party means to make such an agreement or commitment not to enforce a
 506+patent against the party.
 507+
 508+ If you convey a covered work, knowingly relying on a patent license,
 509+and the Corresponding Source of the work is not available for anyone
 510+to copy, free of charge and under the terms of this License, through a
 511+publicly available network server or other readily accessible means,
 512+then you must either (1) cause the Corresponding Source to be so
 513+available, or (2) arrange to deprive yourself of the benefit of the
 514+patent license for this particular work, or (3) arrange, in a manner
 515+consistent with the requirements of this License, to extend the patent
 516+license to downstream recipients. "Knowingly relying" means you have
 517+actual knowledge that, but for the patent license, your conveying the
 518+covered work in a country, or your recipient's use of the covered work
 519+in a country, would infringe one or more identifiable patents in that
 520+country that you have reason to believe are valid.
 521+
 522+ If, pursuant to or in connection with a single transaction or
 523+arrangement, you convey, or propagate by procuring conveyance of, a
 524+covered work, and grant a patent license to some of the parties
 525+receiving the covered work authorizing them to use, propagate, modify
 526+or convey a specific copy of the covered work, then the patent license
 527+you grant is automatically extended to all recipients of the covered
 528+work and works based on it.
 529+
 530+ A patent license is "discriminatory" if it does not include within
 531+the scope of its coverage, prohibits the exercise of, or is
 532+conditioned on the non-exercise of one or more of the rights that are
 533+specifically granted under this License. You may not convey a covered
 534+work if you are a party to an arrangement with a third party that is
 535+in the business of distributing software, under which you make payment
 536+to the third party based on the extent of your activity of conveying
 537+the work, and under which the third party grants, to any of the
 538+parties who would receive the covered work from you, a discriminatory
 539+patent license (a) in connection with copies of the covered work
 540+conveyed by you (or copies made from those copies), or (b) primarily
 541+for and in connection with specific products or compilations that
 542+contain the covered work, unless you entered into that arrangement,
 543+or that patent license was granted, prior to 28 March 2007.
 544+
 545+ Nothing in this License shall be construed as excluding or limiting
 546+any implied license or other defenses to infringement that may
 547+otherwise be available to you under applicable patent law.
 548+
 549+ 12. No Surrender of Others' Freedom.
 550+
 551+ If conditions are imposed on you (whether by court order, agreement or
 552+otherwise) that contradict the conditions of this License, they do not
 553+excuse you from the conditions of this License. If you cannot convey a
 554+covered work so as to satisfy simultaneously your obligations under this
 555+License and any other pertinent obligations, then as a consequence you may
 556+not convey it at all. For example, if you agree to terms that obligate you
 557+to collect a royalty for further conveying from those to whom you convey
 558+the Program, the only way you could satisfy both those terms and this
 559+License would be to refrain entirely from conveying the Program.
 560+
 561+ 13. Use with the GNU Affero General Public License.
 562+
 563+ Notwithstanding any other provision of this License, you have
 564+permission to link or combine any covered work with a work licensed
 565+under version 3 of the GNU Affero General Public License into a single
 566+combined work, and to convey the resulting work. The terms of this
 567+License will continue to apply to the part which is the covered work,
 568+but the special requirements of the GNU Affero General Public License,
 569+section 13, concerning interaction through a network will apply to the
 570+combination as such.
 571+
 572+ 14. Revised Versions of this License.
 573+
 574+ The Free Software Foundation may publish revised and/or new versions of
 575+the GNU General Public License from time to time. Such new versions will
 576+be similar in spirit to the present version, but may differ in detail to
 577+address new problems or concerns.
 578+
 579+ Each version is given a distinguishing version number. If the
 580+Program specifies that a certain numbered version of the GNU General
 581+Public License "or any later version" applies to it, you have the
 582+option of following the terms and conditions either of that numbered
 583+version or of any later version published by the Free Software
 584+Foundation. If the Program does not specify a version number of the
 585+GNU General Public License, you may choose any version ever published
 586+by the Free Software Foundation.
 587+
 588+ If the Program specifies that a proxy can decide which future
 589+versions of the GNU General Public License can be used, that proxy's
 590+public statement of acceptance of a version permanently authorizes you
 591+to choose that version for the Program.
 592+
 593+ Later license versions may give you additional or different
 594+permissions. However, no additional obligations are imposed on any
 595+author or copyright holder as a result of your choosing to follow a
 596+later version.
 597+
 598+ 15. Disclaimer of Warranty.
 599+
 600+ THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
 601+APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
 602+HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
 603+OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
 604+THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 605+PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
 606+IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
 607+ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
 608+
 609+ 16. Limitation of Liability.
 610+
 611+ IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
 612+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
 613+THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
 614+GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
 615+USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
 616+DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
 617+PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
 618+EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
 619+SUCH DAMAGES.
 620+
 621+ 17. Interpretation of Sections 15 and 16.
 622+
 623+ If the disclaimer of warranty and limitation of liability provided
 624+above cannot be given local legal effect according to their terms,
 625+reviewing courts shall apply local law that most closely approximates
 626+an absolute waiver of all civil liability in connection with the
 627+Program, unless a warranty or assumption of liability accompanies a
 628+copy of the Program in return for a fee.
 629+
 630+ END OF TERMS AND CONDITIONS
 631+
 632+ How to Apply These Terms to Your New Programs
 633+
 634+ If you develop a new program, and you want it to be of the greatest
 635+possible use to the public, the best way to achieve this is to make it
 636+free software which everyone can redistribute and change under these terms.
 637+
 638+ To do so, attach the following notices to the program. It is safest
 639+to attach them to the start of each source file to most effectively
 640+state the exclusion of warranty; and each file should have at least
 641+the "copyright" line and a pointer to where the full notice is found.
 642+
 643+ <one line to give the program's name and a brief idea of what it does.>
 644+ Copyright (C) <year> <name of author>
 645+
 646+ This program is free software: you can redistribute it and/or modify
 647+ it under the terms of the GNU General Public License as published by
 648+ the Free Software Foundation, either version 3 of the License, or
 649+ (at your option) any later version.
 650+
 651+ This program is distributed in the hope that it will be useful,
 652+ but WITHOUT ANY WARRANTY; without even the implied warranty of
 653+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 654+ GNU General Public License for more details.
 655+
 656+ You should have received a copy of the GNU General Public License
 657+ along with this program. If not, see <http://www.gnu.org/licenses/>.
 658+
 659+Also add information on how to contact you by electronic and paper mail.
 660+
 661+ If the program does terminal interaction, make it output a short
 662+notice like this when it starts in an interactive mode:
 663+
 664+ <program> Copyright (C) <year> <name of author>
 665+ This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
 666+ This is free software, and you are welcome to redistribute it
 667+ under certain conditions; type `show c' for details.
 668+
 669+The hypothetical commands `show w' and `show c' should show the appropriate
 670+parts of the General Public License. Of course, your program's commands
 671+might be different; for a GUI interface, you would use an "about box".
 672+
 673+ You should also get your employer (if you work as a programmer) or school,
 674+if any, to sign a "copyright disclaimer" for the program, if necessary.
 675+For more information on this, and how to apply and follow the GNU GPL, see
 676+<http://www.gnu.org/licenses/>.
 677+
 678+ The GNU General Public License does not permit incorporating your program
 679+into proprietary programs. If your program is a subroutine library, you
 680+may consider it more useful to permit linking proprietary applications with
 681+the library. If this is what you want to do, use the GNU Lesser General
 682+Public License instead of this License. But first, please read
 683+<http://www.gnu.org/philosophy/why-not-lgpl.html>.
\ No newline at end of file
Index: tags/extensions/Validator/REL_0_4_3/Validator.i18n.php
@@ -0,0 +1,1974 @@
 2+<?php
 3+
 4+/**
 5+ * Internationalization file for the Validator extension
 6+ *
 7+ * @file Validator.i18n.php
 8+ * @ingroup Validator
 9+ *
 10+ * @author Jeroen De Dauw
 11+*/
 12+
 13+$messages = array();
 14+
 15+/** English
 16+ * @author Jeroen De Dauw
 17+ */
 18+$messages['en'] = array(
 19+ 'validator-desc' => 'Provides generic parameter handling support for other extensions',
 20+
 21+ // General
 22+ 'validator-warning' => 'Warning: $1',
 23+ 'validator-error' => 'Error: $1',
 24+ 'validator-fatal-error' => 'Fatal error: $1',
 25+ 'validator_error_parameters' => 'The following {{PLURAL:$1|error has|errors have}} been detected in your syntax:',
 26+ 'validator_warning_parameters' => 'There {{PLURAL:$1|is an error|are errors}} in your syntax.',
 27+ 'validator-warning-adittional-errors' => '... and {{PLURAL:$1|one more issue|multiple more issues}}.',
 28+ 'validator-error-omitted' => 'The {{PLURAL:$2|value "$1" has|values "$1" have}} been omitted.',
 29+ 'validator-error-problem' => 'There was a problem with parameter $1.',
 30+
 31+ // General errors
 32+ 'validator_error_unknown_argument' => '$1 is not a valid parameter.',
 33+ 'validator_error_required_missing' => 'The required parameter "$1" is not provided.',
 34+ 'validator-error-override-argument' => 'Tried to override parameter $1 (value: $2) with value "$3"',
 35+
 36+ // Parameter types
 37+ 'validator-type-string' => 'text',
 38+ 'validator-type-number' => 'number',
 39+ 'validator-type-integer' => 'whole number',
 40+ 'validator-type-float' => 'number',
 41+ 'validator-type-boolean' => 'yes/no',
 42+ 'validator-type-char' => 'character',
 43+
 44+ // Listerrors
 45+ 'validator-listerrors-errors' => 'Errors',
 46+ 'validator-listerrors-severity-message' => '($1) $2', // $1 = severity; $2 = message
 47+ 'validator-listerrors-minor' => 'Minor',
 48+ 'validator-listerrors-low' => 'Low',
 49+ 'validator-listerrors-normal' => 'Normal',
 50+ 'validator-listerrors-high' => 'High',
 51+ 'validator-listerrors-fatal' => 'Fatal',
 52+ 'validator-listerrors-description' => 'Lists errors (and warnings) that occured in parser hooks added via Validator.
 53+Only lists for parser hooks added above where listerrors is inserted;
 54+place listerrors at or near the bottom of the page to get all errors.',
 55+ 'validator-listerrors-par-minseverity' => 'The minimum severity of an issue for it to be listed.',
 56+
 57+ // Describe
 58+ 'validator-describe-description' => 'Generates documentation for one or more parser hooks defined via Validator.',
 59+ 'validator-describe-notfound' => 'There is no parser hook that handles "$1".',
 60+ 'validator-describe-descriptionmsg' => "'''Description''': $1", // Because it's 1360 < 3
 61+ 'validator-describe-aliases' => "'''{{PLURAL:$2|Alias|Aliases}}''': $1",
 62+ 'validator-describe-parserfunction' => 'Implemented only as parser function.',
 63+ 'validator-describe-tagextension' => 'Implemented only as tag extension.',
 64+ 'validator-describe-bothhooks' => 'Implemented as both parser function and as tag extension.',
 65+ 'validator-describe-par-hooks' => 'The parser hooks for which to display documentation.',
 66+ 'validator-describe-par-pre' => 'Allows you to get the actual wikitext for the documentation, without it being rendered on the page.',
 67+ 'validator-describe-listtype' => 'List of $1 items',
 68+ 'validator-describe-empty' => 'empty',
 69+ 'validator-describe-required' => 'required',
 70+ 'validator-describe-header-parameter' => 'Parameter',
 71+ 'validator-describe-header-aliases' => 'Aliases',
 72+ 'validator-describe-header-type' => 'Type',
 73+ 'validator-describe-header-default' => 'Default',
 74+ 'validator-describe-header-description' => 'Description',
 75+ 'validator-describe-parameters' => 'Parameters',
 76+ 'validator-describe-syntax' => 'Syntax',
 77+ 'validator-describe-tagmin' => 'Tag extension with only the required parameters.',
 78+ 'validator-describe-tagmax' => 'Tag extension with all parameters.',
 79+ 'validator-describe-tagdefault' => 'Tag extension with all parameters using the default parameter notation.',
 80+ 'validator-describe-pfmin' => 'Parser function with only the required parameters.',
 81+ 'validator-describe-pfmax' => 'Parser function with all parameters.',
 82+ 'validator-describe-pfdefault' => 'Parser function with all parameters using the default parameter notation.',
 83+ 'validator-describe-autogen' => 'The contents of this section was auto-generated by the "describe" parser hook of the Validator extension.',
 84+
 85+ // Criteria errors for single values
 86+ 'validator_error_empty_argument' => 'Parameter $1 can not have an empty value.',
 87+ 'validator_error_must_be_number' => 'Parameter $1 can only be a number.',
 88+ 'validator_error_must_be_integer' => 'Parameter $1 can only be an integer.',
 89+ 'validator-error-must-be-float' => 'Parameter $1 can only be a floating point number.',
 90+ 'validator_error_invalid_range' => 'Parameter $1 must be between $2 and $3.',
 91+ 'validator-error-invalid-regex' => 'Parameter $1 must match this regular expression: $2.',
 92+ 'validator-error-invalid-length' => 'Parameter $1 must have a length of $2.',
 93+ 'validator-error-invalid-length-range' => 'Parameter $1 must have a length between $2 and $3.',
 94+ 'validator_error_invalid_argument' => 'The value $1 is not valid for parameter $2.',
 95+
 96+ // Criteria errors for lists
 97+ 'validator_list_error_empty_argument' => 'Parameter $1 does not accept empty values.',
 98+ 'validator_list_error_must_be_number' => 'Parameter $1 can only contain numbers.',
 99+ 'validator_list_error_must_be_integer' => 'Parameter $1 can only contain integers.',
 100+ 'validator-list-error-must-be-float' => 'Parameter $1 can only contain floats.',
 101+ 'validator_list_error_invalid_range' => 'All values of parameter $1 must be between $2 and $3.',
 102+ 'validator-list-error-invalid-regex' => 'All values of parameter $1 must match this regular expression: $2.',
 103+ 'validator_list_error_invalid_argument' => 'One or more values for parameter $1 are invalid.',
 104+ 'validator-list-error-accepts-only' => 'One or more values for parameter $1 are invalid. It only accepts {{PLURAL:$3|this value|these values}}: $2.',
 105+ 'validator-list-error-accepts-only-omitted' => 'One or more values for parameter $1 are invalid. It only accepts {{PLURAL:$3|this value|these values}}: $2 (and $4 omitted {{PLURAL:$4|value|values}}).',
 106+
 107+ // Criteria errors for single values & lists
 108+ 'validator_error_accepts_only' => 'The value "$4" is not valid for parameter $1. It only accepts {{PLURAL:$3|this value|these values}}: $2.',
 109+ 'validator-error-accepts-only-omitted' => 'The value "$2" is not valid for parameter $1. It only accepts {{PLURAL:$5|this value|these values}}: $3 (and $4 omitted {{PLURAL:$4|value|values}}).',
 110+
 111+ 'validator_list_omitted' => 'The {{PLURAL:$2|value|values}} $1 {{PLURAL:$2|has|have}} been omitted.',
 112+);
 113+
 114+/** Message documentation (Message documentation)
 115+ * @author EugeneZelenko
 116+ * @author Fryed-peach
 117+ * @author Purodha
 118+ * @author Raymond
 119+ */
 120+$messages['qqq'] = array(
 121+ 'validator-desc' => '{{desc}}',
 122+ 'validator-warning' => '{{Identical|Warning}}',
 123+ 'validator-error' => '{{Identical|Error}}',
 124+ 'validator_error_parameters' => 'Parameters:
 125+* $1 is the number of syntax errors, for PLURAL support (optional)',
 126+ 'validator-listerrors-errors' => '{{Identical|Error}}',
 127+ 'validator-listerrors-severity-message' => '{{Optional}}
 128+* $1 = severit
 129+* $2 = message',
 130+ 'validator-listerrors-normal' => '{{Identical|Normal}}',
 131+);
 132+
 133+/** Afrikaans (Afrikaans)
 134+ * @author Naudefj
 135+ */
 136+$messages['af'] = array(
 137+ 'validator-desc' => 'Die valideerder gee ander uitbreidings die vermoë om parameters van ontlederfunksies en etiket-uitbreidings te valideer, op hulle verstekwaardes in te stel en om foutboodskappe te genereer',
 138+ 'validator-warning' => 'Waarskuwing: $ 1',
 139+ 'validator-error' => 'Fout: $1',
 140+ 'validator-fatal-error' => 'Onherstelbare fout: $1',
 141+ 'validator_error_parameters' => 'Die volgende {{PLURAL:$1|fout|foute}} is in u sintaks waargeneem:',
 142+ 'validator_error_unknown_argument' => "$1 is nie 'n geldige parameter nie.",
 143+ 'validator_error_required_missing' => 'Die verpligte parameter $1 is nie verskaf nie.',
 144+ 'validator-listerrors-errors' => 'Foute',
 145+ 'validator-listerrors-minor' => 'Oorkomelik',
 146+ 'validator-listerrors-low' => 'Laag',
 147+ 'validator-listerrors-normal' => 'Gemiddeld',
 148+ 'validator-listerrors-high' => 'Groot',
 149+ 'validator-listerrors-fatal' => 'Fataal',
 150+ 'validator_error_empty_argument' => 'Die parameter $1 mag nie leeg wees nie.',
 151+ 'validator_error_must_be_number' => "Die parameter $1 mag net 'n getal wees.",
 152+ 'validator_error_must_be_integer' => "Die parameter $1 kan slegs 'n heelgetal wees.",
 153+ 'validator_error_invalid_range' => 'Die parameter $1 moet tussen $2 en $3 lê.',
 154+ 'validator_error_invalid_argument' => 'Die waarde $1 is nie geldig vir parameter $2 nie.',
 155+ 'validator_error_accepts_only' => 'Die parameter $1 kan slegs die volgende {{PLURAL:$3|waarde|waardes}} hê: $2.',
 156+);
 157+
 158+/** Gheg Albanian (Gegë)
 159+ * @author Mdupont
 160+ */
 161+$messages['aln'] = array(
 162+ 'validator-desc' => 'Validator është një zgjerim MediaWiki që ofron parametër përgjithshme trajtimin mbështetje të shtesave të tjera',
 163+ 'validator_error_parameters' => 'Më poshtë {{PLURAL:$1|gabim ka gabime|kanë}} është zbuluar në sintaksën e juaj:',
 164+ 'validator_warning_parameters' => 'Ka {{PLURAL:$1|është|janë gabime gabim}} në sintaksë tuaj.',
 165+ 'validator_error_unknown_argument' => '$1 nuk është një parametër i vlefshëm.',
 166+ 'validator_error_required_missing' => 'Parametrat e nevojshëm $1 nuk jepet.',
 167+ 'validator_error_empty_argument' => 'Parametër $1 nuk mund të ketë një vlerë bosh.',
 168+ 'validator_error_must_be_number' => 'Parametër $1 mund të jetë vetëm një numër.',
 169+ 'validator_error_must_be_integer' => 'Parametër $1 mund të jetë vetëm një numër i plotë.',
 170+ 'validator_error_invalid_range' => 'Parametër $1 duhet të jetë në mes të $2 dhe $3.',
 171+ 'validator_error_invalid_argument' => 'Vlera $1 nuk është i vlefshëm për parametër $2.',
 172+ 'validator_list_error_empty_argument' => 'Parametër $1 nuk e pranon vlerat bosh.',
 173+ 'validator_list_error_must_be_number' => 'Parametër $1 mund të përmbajë vetëm numrat.',
 174+ 'validator_list_error_must_be_integer' => 'Parametër $1 mund të përmbajë vetëm numra të plotë.',
 175+ 'validator_list_error_invalid_range' => 'Të gjitha vlerat e parametrit $1 duhet të jetë në mes të $2 dhe $3.',
 176+ 'validator_list_error_invalid_argument' => 'Një ose më shumë vlera për parametër $1 janë të pavlefshme.',
 177+ 'validator_error_accepts_only' => 'Parametër $1 vetëm pranon {{PLURAL:$3|kjo vlerë|këtyre vlerave}}: $2.',
 178+ 'validator_list_omitted' => '{{PLURAL:$2 |vlerë|vlerat}} $1 {{PLURAL:$2|ka|kanë}} janë lënë jashtë.',
 179+);
 180+
 181+/** Arabic (العربية)
 182+ * @author Meno25
 183+ */
 184+$messages['ar'] = array(
 185+ 'validator-desc' => 'المحقق يوفر طريقة سهلة للامتدادات الأخرى للتحقق من محددات دوال المحلل وامتدادات الوسوم، وضبط القيم الافتراضية وتوليد رسائل الخطأ',
 186+ 'validator_error_parameters' => '{{PLURAL:$1|الخطأ التالي|الاخطاء التالية}} تم كشفها في صياغتك:',
 187+ 'validator_warning_parameters' => 'هناك {{PLURAL:$1|خطأ|أخطاء}} في صياغتك.',
 188+ 'validator_error_unknown_argument' => '$1 ليس محددا صحيحا.',
 189+ 'validator_error_required_missing' => 'المحدد المطلوب $1 ليس متوفرا.',
 190+ 'validator_error_empty_argument' => 'المحدد $1 لا يمكن أن تكون قيمته فارغة.',
 191+ 'validator_error_must_be_number' => 'المحدد $1 يمكن أن يكون فقط عددا.',
 192+ 'validator_error_must_be_integer' => 'المحدد $1 يمكن أن يكون عددا صحيحا فقط.',
 193+ 'validator_error_invalid_range' => 'المحدد $1 يجب أن يكون بين $2 و $3.',
 194+ 'validator_error_invalid_argument' => 'القيمة $1 ليست صحيحة للمحدد $2.',
 195+ 'validator_list_error_empty_argument' => 'المحدد $1 لا يقبل القيم الفارغة.',
 196+ 'validator_list_error_must_be_number' => 'المحدد $1 يمكن أن يحتوي فقط على أرقام.',
 197+ 'validator_list_error_must_be_integer' => 'المحدد $1 يمكن أن يحتوي فقط على أرقام صحيحة.',
 198+ 'validator_list_error_invalid_range' => 'كل قيم المحدد $1 يجب أن تكون بين $2 و$3.',
 199+ 'validator_list_error_invalid_argument' => 'قيمة واحدة أو أكثر للمحدد $1 غير صحيحة.',
 200+ 'validator_error_accepts_only' => 'المحدد $1 يقبل فقط {{PLURAL:$3|هذه القيمة|هذه القيم}}: $2.',
 201+ 'validator_list_omitted' => '{{PLURAL:$2|القيمة|القيم}} $1 {{PLURAL:$2|تم|تم}} مسحها.',
 202+);
 203+
 204+/** Belarusian (Taraškievica orthography) (Беларуская (тарашкевіца))
 205+ * @author EugeneZelenko
 206+ * @author Jim-by
 207+ */
 208+$messages['be-tarask'] = array(
 209+ 'validator-desc' => 'Правяраючы палягчае іншым пашырэньням працу па праверцы парамэтраў функцыяў парсэру і тэгаў пашырэньняў, устанаўлівае значэньні па змоўчваньні і стварае паведамленьні пра памылкі',
 210+ 'validator-warning' => 'Папярэджаньне: $1',
 211+ 'validator-error' => 'Памылка: $1',
 212+ 'validator-fatal-error' => 'Крытычная памылка: $1',
 213+ 'validator_error_parameters' => 'У сынтаксісе {{PLURAL:$1|выяўленая наступная памылка|выяўленыя наступныя памылкі}}:',
 214+ 'validator_warning_parameters' => 'У Вашы сынтаксісе {{PLURAL:$1|маецца памылка|маюцца памылкі}}.',
 215+ 'validator-warning-adittional-errors' => '... і {{PLURAL:$1|яшчэ адна праблема|яшчэ некалькі праблемаў}}.',
 216+ 'validator-error-omitted' => '{{PLURAL:$2|Значэньне «$1» было прапушчанае|Значэньні «$1» былі прапушчаныя}}.',
 217+ 'validator-error-problem' => 'Узьнікла праблема з парамэтрам $1.',
 218+ 'validator_error_unknown_argument' => 'Няслушны парамэтар $1.',
 219+ 'validator_error_required_missing' => 'Не пададзены абавязковы парамэтар $1.',
 220+ 'validator-error-override-argument' => 'Спрабаваў памяняць значэньне парамэтру $1 з «$2» на «$3»',
 221+ 'validator-listerrors-errors' => 'Памылкі',
 222+ 'validator-listerrors-minor' => 'Дробная',
 223+ 'validator-listerrors-low' => 'Малая',
 224+ 'validator-listerrors-normal' => 'Звычайная',
 225+ 'validator-listerrors-high' => 'Значная',
 226+ 'validator-listerrors-fatal' => 'Фатальная',
 227+ 'validator_error_empty_argument' => 'Парамэтар $1 ня можа мець пустое значэньне.',
 228+ 'validator_error_must_be_number' => 'Парамэтар $1 можа быць толькі лікам.',
 229+ 'validator_error_must_be_integer' => 'Парамэтар $1 можа быць толькі цэлым лікам.',
 230+ 'validator-error-must-be-float' => 'Парамэтар $1 можа быць толькі лікам з плаваючай коскай.',
 231+ 'validator_error_invalid_range' => 'Парамэтар $1 павінен быць паміж $2 і $3.',
 232+ 'validator-error-invalid-regex' => 'парамэтар $1 мусіць адпавядаць гэтаму рэгулярнаму выразу: $2.',
 233+ 'validator-error-invalid-length' => 'Парамэтар $1 павінен мець даўжыню $2.',
 234+ 'validator-error-invalid-length-range' => 'Парамэтар $1 павінен мець даўжыню паміж $2 і $3.',
 235+ 'validator_error_invalid_argument' => 'Значэньне $1 не зьяўляецца слушным для парамэтру $2.',
 236+ 'validator_list_error_empty_argument' => 'Парамэтар $1 ня можа прымаць пустыя значэньні.',
 237+ 'validator_list_error_must_be_number' => 'Парамэтар $1 можа ўтрымліваць толькі лікі.',
 238+ 'validator_list_error_must_be_integer' => 'Парамэтар $1 можа ўтрымліваць толькі цэлыя лікі.',
 239+ 'validator-list-error-must-be-float' => 'Парамэтар $1 можа ўтрымліваць толькі лікі з плаваючай кропкай.',
 240+ 'validator_list_error_invalid_range' => 'Усе значэньні парамэтру $1 павінны знаходзіцца паміж $2 і $3.',
 241+ 'validator-list-error-invalid-regex' => 'Усе значэньні парамэтру $1 мусяць адпавядаць гэтаму рэгулярнаму выразу: $2.',
 242+ 'validator_list_error_invalid_argument' => 'Адно ці болей значэньняў парамэтру $1 зьяўляюцца няслушнымі.',
 243+ 'validator-list-error-accepts-only' => 'Адзін ці некалькі значэньняў парамэтру $1 зьяўляюцца няслушнымі.
 244+{{PLURAL:$3|Ён мусіць мець наступнае значэньне|Яны мусяць мець наступныя значэньні}}: $2.',
 245+ 'validator-list-error-accepts-only-omitted' => 'Адзін ці некалькі значэньняў парамэтру $1 зьяўляюцца няслушнымі.
 246+{{PLURAL:$3|Ён мусіць мець наступнае значэньне|Яны мусяць мець наступныя значэньні}}: $2. (і $4 {{PLURAL:$4|прапушчанае значэньне|прапушчаныя значэньні|прапушчаных значэньняў}}).',
 247+ 'validator_error_accepts_only' => 'Значэньне «$4» зьяўляецца няслушным для парамэтру $1. Ён можа прымаць толькі {{PLURAL:$3|гэтае значэньне|гэтыя значэньні}}: $2.',
 248+ 'validator-error-accepts-only-omitted' => 'Значэньне «$2» зьяўляецца няслушным для парамэтру $1.
 249+{{PLURAL:$5|Ён мусіць мець наступнае значэньне|Яны мусяць мець наступныя значэньні}}: $3. (і $4 {{PLURAL:$4|прапушчанае значэньне|прапушчаныя значэньні|прапушчаных значэньняў}}).',
 250+ 'validator_list_omitted' => '{{PLURAL:$2|Значэньне|Значэньні}} $1 {{PLURAL:$2|было прапушчанае|былі прапушчаныя}}.',
 251+);
 252+
 253+/** Bulgarian (Български)
 254+ * @author DCLXVI
 255+ * @author Reedy
 256+ */
 257+$messages['bg'] = array(
 258+ 'validator_error_empty_argument' => 'Параметърът $1 не може да има празна стойност.',
 259+);
 260+
 261+/** Breton (Brezhoneg)
 262+ * @author Fohanno
 263+ * @author Fulup
 264+ * @author Gwendal
 265+ * @author Y-M D
 266+ */
 267+$messages['br'] = array(
 268+ 'validator-desc' => 'Un doare aes eo kadarnataer evit an astennoù all da gadarnaat arventennoù ar fonksionoù parser hag astennoù ar balizennoù, evit termeniñ talvoudennoù dre ziouer ha sevel kemennoù fazioù',
 269+ 'validator-warning' => 'Diwallit : $1',
 270+ 'validator-error' => 'Fazi : $1',
 271+ 'validator-fatal-error' => 'Fazi diremed: $1',
 272+ 'validator_error_parameters' => "Kavet eo bet ar {{PLURAL:$1|fazi|fazioù}} da-heul en hoc'h ereadur :",
 273+ 'validator_warning_parameters' => "{{PLURAL:$1|Ur fazi|Fazioù}} zo en hoc'h ereadur.",
 274+ 'validator-warning-adittional-errors' => '... {{PLURAL:$1|hag ur gudenn bennak all|ha meur a gudenn all}}.',
 275+ 'validator-error-omitted' => 'N\'eo ket bet merket ar {{PLURAL:$2|roadenn "$1"|roadennoù "$1"}}.',
 276+ 'validator-error-problem' => 'Ur gudenn zo bet gant an arventenn $1.',
 277+ 'validator_error_unknown_argument' => "$1 n'eo ket un arventenn reizh.",
 278+ 'validator_error_required_missing' => "N'eo ket bet pourchaset an arventenn rekis $1",
 279+ 'validator-error-override-argument' => 'Klasket en deus ar meziant erlec\'hiañ an arventenn $1 (talvoud : $2) gant an talvoud "$3"',
 280+ 'validator-listerrors-errors' => 'Fazioù',
 281+ 'validator-listerrors-minor' => 'Minor',
 282+ 'validator-listerrors-low' => 'Gwan',
 283+ 'validator-listerrors-normal' => 'Reizh',
 284+ 'validator-listerrors-high' => 'Uhel',
 285+ 'validator-listerrors-fatal' => 'Diremed',
 286+ 'validator_error_empty_argument' => "N'hall ket an arventenn $1 bezañ goullo he zalvoudenn",
 287+ 'validator_error_must_be_number' => 'Un niver e rank an arventenn $1 bezañ hepken.',
 288+ 'validator_error_must_be_integer' => 'Rankout a ra an arventenn $1 bezañ un niver anterin.',
 289+ 'validator-error-must-be-float' => 'Rankout a ra an arventenn $1 bezañ un niver skej war-neuñv.',
 290+ 'validator_error_invalid_range' => 'Rankout a ra an arventenn $1 bezañ etre $2 hag $3.',
 291+ 'validator-error-invalid-regex' => 'Rankout a ra an arventenn $1 klotañ gant ar jedad poellek-mañ : $2.',
 292+ 'validator-error-invalid-length' => "Ret eo d'an arventenn $1 bezañ par he hed da $2.",
 293+ 'validator-error-invalid-length-range' => 'Rankout a ra an arventenn $1 bezañ he hed etre $2 hag $3.',
 294+ 'validator_error_invalid_argument' => "N'eo ket reizh an dalvoudenn $1 evit an arventenn $2.",
 295+ 'validator_list_error_empty_argument' => 'Ne zegemer ket an arventenn $1 an talvoudennoù goullo.',
 296+ 'validator_list_error_must_be_number' => "N'hall bezañ nemet niveroù en arventenn $1.",
 297+ 'validator_list_error_must_be_integer' => "N'hall bezañ nemet niveroù anterin en arventenn $1.",
 298+ 'validator-list-error-must-be-float' => "N'hall bezañ nemet niveroù gant skej en arventenn $1.",
 299+ 'validator_list_error_invalid_range' => 'An holl talvoudennoù eus an arventenn $1 a rank bezañ etre $2 ha $3.',
 300+ 'validator-list-error-invalid-regex' => 'Rankout a ra holl dalvoudoù an arventenn $1 klotañ gant ar jedad poellek-mañ : $2.',
 301+ 'validator_list_error_invalid_argument' => 'Faziek eo unan pe meur a dalvoudenn eus an arventenn $1.',
 302+ 'validator-list-error-accepts-only' => 'Direizh eo unan pe meur a hini eus an talvoudoù evit an arventenn $1.
 303+Ne zegemer nemet an {{PLURAL:$3|talvoud|talvoudoù}}-mañ : $2.',
 304+ 'validator-list-error-accepts-only-omitted' => 'Direizh eo unan pe meur a hini eus an talvoudoù evit an arventenn $1.
 305+Ne zegemer nemet an {{PLURAL:$3|talvoud|talvoudoù}}-mañ : $2 (ha $4 {{PLURAL:$4|talvoud anroet|talvoud anroet}}).',
 306+ 'validator_error_accepts_only' => 'Ne zegemer ket an arventenn $1 an talvoud "$4". Ne zegemer nemet {{PLURAL:$3|an talvoud|an talvoudoù}}-mañ : $2.',
 307+ 'validator-error-accepts-only-omitted' => 'Direizh eo an talvoud "$2" evit an arventenn $1.
 308+Ne zegemer nemet an {{PLURAL:$5|talvoud|talvoudoù}}-mañ : $3 (ha $4 {{PLURAL:$4|talvoud anroet|talvoud anroet}}).',
 309+ 'validator_list_omitted' => 'Disoñjet eo bet an {{PLURAL:$2|talvoudenn|talvoudennoù}} $1.',
 310+);
 311+
 312+/** Bosnian (Bosanski)
 313+ * @author CERminator
 314+ */
 315+$messages['bs'] = array(
 316+ 'validator-desc' => 'Validator pruža jednostavni način za druga proširenja u svrhu validacije parametara parserskih funkcija i proširenja oznaka, postavlja pretpostavljene vrijednosti i generira poruke pogrešaka.',
 317+ 'validator-warning' => 'Upozorenje: $1',
 318+ 'validator-error' => 'Greška: $1',
 319+ 'validator-fatal-error' => 'Fatalna greška: $1',
 320+ 'validator_error_parameters' => 'U Vašoj sintaksi {{PLURAL:$1|je|su}} {{PLURAL:$1|otkivena slijedeća greška|otkrivene slijedeće greške}}:',
 321+ 'validator_warning_parameters' => '{{PLURAL:$1|Postoji greška|Postoje greške}} u Vašoj sintaksi.',
 322+ 'validator-warning-adittional-errors' => '... i {{PLURAL:$1|još jedan problem|još nekoliko problema}}.',
 323+ 'validator_error_unknown_argument' => '$1 nije valjan parametar.',
 324+ 'validator_error_required_missing' => 'Obavezni parametar $1 nije naveden.',
 325+ 'validator-error-override-argument' => 'Pokušano da se preskoči parametar $1 (vrijednost: $2) vrijednošću "$3"',
 326+ 'validator-listerrors-normal' => 'Normalno',
 327+ 'validator_error_empty_argument' => 'Parametar $1 ne može imati praznu vrijednost.',
 328+ 'validator_error_must_be_number' => 'Parametar $1 može biti samo broj.',
 329+ 'validator_error_must_be_integer' => 'Parametar $1 može biti samo cijeli broj.',
 330+ 'validator-error-must-be-float' => 'Parametar $1 može biti samo broj sa plutajućim zarezom.',
 331+ 'validator_error_invalid_range' => 'Parametar $1 mora biti između $2 i $3.',
 332+ 'validator-error-invalid-length' => 'Parametar $1 mora imati dužinu $2.',
 333+ 'validator-error-invalid-length-range' => 'Parametar $1 mora imati dužinu između $2 i $3.',
 334+ 'validator_error_invalid_argument' => 'Vrijednost $1 nije valjana za parametar $2.',
 335+ 'validator_list_error_empty_argument' => 'Parametar $1 ne prima prazne vrijednosti.',
 336+ 'validator_list_error_must_be_number' => 'Parametar $1 može sadržavati samo brojeve.',
 337+ 'validator_list_error_must_be_integer' => 'Parametar $1 može sadržavati samo cijele brojeve.',
 338+ 'validator_list_error_invalid_range' => 'Sve vrijednosti parametra $1 moraju biti između $2 i $3.',
 339+ 'validator_list_error_invalid_argument' => 'Jedna ili više vrijednosti za parametar $1 nisu valjane.',
 340+ 'validator_error_accepts_only' => 'Vrijednost "$4" nije valjana za parametar $1. On prihvata samo {{PLURAL:$3|ovu vrijednost|ove vrijednosti}}: $2.',
 341+ 'validator_list_omitted' => '{{PLURAL:$2|Vrijednost|Vrijednosti}} $1 {{PLURAL:$2|je ispuštena|su ispuštene}}.',
 342+);
 343+
 344+/** Czech (Česky)
 345+ * @author Matěj Grabovský
 346+ * @author Mormegil
 347+ * @author Reaperman
 348+ */
 349+$messages['cs'] = array(
 350+ 'validator-desc' => 'Validátor poskytuje ostatním rozšířením snadnější způsob ověřování parametrů funkcí parseru a značek, nastavování výchozích hodnot a vytváření chybových zpráv.',
 351+ 'validator_error_parameters' => 'Ve vaší syntaxi {{PLURAL:$1|byla nalezena následující chyba|byly nalezeny následující chyby}}:',
 352+ 'validator_warning_parameters' => 'Ve vaší syntaxi {{PLURAL:$1|je chyba|jsou chyby}}.',
 353+ 'validator_error_unknown_argument' => '$1 není platný parametr.',
 354+ 'validator_error_required_missing' => 'Povinný parameter $1 nebyl specifikován.',
 355+ 'validator_error_empty_argument' => 'Parametr $1 nemůže být prázdný.',
 356+ 'validator_error_must_be_number' => 'Parametr $1 může být pouze číslo.',
 357+ 'validator_error_must_be_integer' => 'Parametr $1 může být pouze celé číslo.',
 358+ 'validator_error_invalid_range' => 'Parametr $1 musí být v rozmezí $2 až $3.',
 359+ 'validator_error_invalid_argument' => '$1 není platná hodnota pro parametr $2.',
 360+ 'validator_list_error_empty_argument' => 'Parametr $1 npeřijímá prázdné hoodnoty.',
 361+ 'validator_list_error_must_be_number' => 'Parametr $1 může obsahovat pouze čísla.',
 362+ 'validator_list_error_must_be_integer' => 'Paramter $1 může obsahovat pouze celá čísla.',
 363+ 'validator_list_error_invalid_range' => 'Všechny hodnoty parametru $1 musí být v rozmezí $2 až $3.',
 364+ 'validator_list_error_invalid_argument' => 'Jedna nebo více hodnot parametru $1 jsou neplatné.',
 365+ 'validator_error_accepts_only' => 'Parametr $1 nemůže mít hodnotu „$4“; přijímá pouze {{PLURAL:$3|tuto hodnotu|tyto hodnoty}}: $2.',
 366+ 'validator_list_omitted' => '{{PLURAL:$2|Hodnota $1 byla vynechána|Hodnoty $1 byly vynechány}}.',
 367+);
 368+
 369+/** German (Deutsch)
 370+ * @author DaSch
 371+ * @author Imre
 372+ * @author Kghbln
 373+ * @author LWChris
 374+ */
 375+$messages['de'] = array(
 376+ 'validator-desc' => 'Ermöglicht es anderen Softwareerweiterungen Parameter verarbeiten zu können',
 377+ 'validator-warning' => 'Warnung: $1',
 378+ 'validator-error' => 'Fehler: $1',
 379+ 'validator-fatal-error' => "'''Schwerwiegender Fehler:''' $1",
 380+ 'validator_error_parameters' => '{{PLURAL:$1|Der folgende Fehler wurde|Die folgenden Fehler wurden}} in der Syntax gefunden:',
 381+ 'validator_warning_parameters' => '{{PLURAL:$1|Es ist ein Fehler|Es sind Fehler}} in der Syntax.',
 382+ 'validator-warning-adittional-errors' => '… und {{PLURAL:$1|ein weiteres Problem|weitere Probleme}}.',
 383+ 'validator-error-omitted' => '{{PLURAL:$2|Der Wert „$1“ wurde|Die Werte „$1“ wurden}} ausgelassen.',
 384+ 'validator-error-problem' => 'Es gab ein Problem mit Parameter $1.',
 385+ 'validator_error_unknown_argument' => '$1 ist kein gültiger Parameter.',
 386+ 'validator_error_required_missing' => 'Der notwendige Parameter $1 wurde nicht angegeben.',
 387+ 'validator-error-override-argument' => 'Es wurde versucht Parameter $1 ($2) mit dem Wert „$3“ zu überschreiben.',
 388+ 'validator-type-string' => 'Text',
 389+ 'validator-type-number' => 'Zahl',
 390+ 'validator-type-integer' => 'Ganzzahl',
 391+ 'validator-type-float' => 'Zahl',
 392+ 'validator-type-boolean' => 'Ja/Nein',
 393+ 'validator-type-char' => 'Zeichen',
 394+ 'validator-listerrors-errors' => 'Fehler',
 395+ 'validator-listerrors-minor' => 'Marginal',
 396+ 'validator-listerrors-low' => 'Klein',
 397+ 'validator-listerrors-normal' => 'Normal',
 398+ 'validator-listerrors-high' => 'Groß',
 399+ 'validator-listerrors-fatal' => 'Schwerwiegend',
 400+ 'validator-listerrors-description' => 'Zeigt Fehler und Warnungen an, die bei über die Erweiterung Validator genutzten Parserhooks auftraten.
 401+Zeigt sie lediglich bezüglich der Parserhooks an, die über dem Element „listerrors“ eingefügt wurden. „Listerrors“ sollte daher am oder gegen Ende der Seite eingefügt werden, um alle Fehler und Warnungen angezeigt zu bekommen.',
 402+ 'validator-listerrors-par-minseverity' => 'Der Mindestschweregrad eines Problems, damit dieses angezeigt wird.',
 403+ 'validator-describe-description' => 'Erzeugt die Dokumentation für einen oder mehrere Parserhooks, die mit der Erweiterung Validator definiert wurden.',
 404+ 'validator-describe-notfound' => 'Es gibt keinen Parserhook, der „$1“ verarbeitet.',
 405+ 'validator-describe-descriptionmsg' => "'''Beschreibung:''' $1",
 406+ 'validator-describe-aliases' => "'''{{PLURAL:$2|Alias|Aliasse}}:''' $1",
 407+ 'validator-describe-parserfunction' => 'Lediglich als Parserfunktion implementiert.',
 408+ 'validator-describe-tagextension' => 'Lediglich als Elementerweiterung implementiert.',
 409+ 'validator-describe-bothhooks' => 'Sowohl als Parserfunktion wie auch Elementerweiterung implementiert.',
 410+ 'validator-describe-par-hooks' => 'Die Parserhooks für welche die Dokumentation angezeigt werden soll.',
 411+ 'validator-describe-par-pre' => 'Ermöglicht die Ausgabe der Dokumentation in Wikitext ohne dass dieser bei der Darstellung der Seite genutzt wird.',
 412+ 'validator-describe-listtype' => 'Liste von $1 {{PLURAL:$1|Elemente|Elementen}}',
 413+ 'validator-describe-empty' => 'leer',
 414+ 'validator-describe-required' => 'erforderlich',
 415+ 'validator-describe-header-parameter' => 'Parameter',
 416+ 'validator-describe-header-aliases' => 'Aliasse',
 417+ 'validator-describe-header-type' => 'Typ',
 418+ 'validator-describe-header-default' => 'Standard',
 419+ 'validator-describe-header-description' => 'Beschreibung',
 420+ 'validator-describe-parameters' => 'Parameter',
 421+ 'validator-describe-syntax' => 'Syntax',
 422+ 'validator-describe-tagmin' => 'Elementerweiterung, lediglich mit den erforderlichen Parametern.',
 423+ 'validator-describe-tagmax' => 'Elementerweiterung mit allen Parametern.',
 424+ 'validator-describe-tagdefault' => 'Elementerweiterung mit allen Parametern, welche die Standardnotation für Parameter nutzen.',
 425+ 'validator-describe-pfmin' => 'Parserfunktion, lediglich mit den erforderlichen Parametern.',
 426+ 'validator-describe-pfmax' => 'Parserfunktion mit allen Parametern.',
 427+ 'validator-describe-pfdefault' => 'Parserfunktion mit allen Parametern, welche die Standardnotation für Parameter nutzen.',
 428+ 'validator-describe-autogen' => 'Der Inhalt dieses Abschnitts wurde automatisch durch den Parserhook „describe“ der Erweiterung Validator erzeugt.',
 429+ 'validator_error_empty_argument' => 'Parameter $1 kann keinen leeren Wert haben.',
 430+ 'validator_error_must_be_number' => 'Parameter $1 kann nur eine Nummer sein.',
 431+ 'validator_error_must_be_integer' => 'Parameter $1 kann nur eine ganze Zahl sein.',
 432+ 'validator-error-must-be-float' => 'Parameter $1 kann nur eine Gleitkommazahl sein.',
 433+ 'validator_error_invalid_range' => 'Parameter $1 muss zwischen $2 und $3 liegen.',
 434+ 'validator-error-invalid-regex' => 'Parameter $1 muss diesem regulären Ausdruck entsprechen: $2.',
 435+ 'validator-error-invalid-length' => 'Parameter $1 muss eine Länge von $2 haben.',
 436+ 'validator-error-invalid-length-range' => 'Parameter $1 muss eine Länge zwischen $2 und $3 haben.',
 437+ 'validator_error_invalid_argument' => 'Der Wert „$1“ ist nicht gültig für Parameter $2.',
 438+ 'validator_list_error_empty_argument' => 'Parameter $1 akzeptiert keine leeren Werte.',
 439+ 'validator_list_error_must_be_number' => 'Parameter $1 kann nur Ziffern enthalten.',
 440+ 'validator_list_error_must_be_integer' => 'Parameter $1 kann nur ganze Zahlen enthalten.',
 441+ 'validator-list-error-must-be-float' => 'Parameter $1 kann nur Gleitkommazahlen enthalten.',
 442+ 'validator_list_error_invalid_range' => 'Alle Werte des Parameters $1 müssen zwischen „$2“ und „$3“ liegen.',
 443+ 'validator-list-error-invalid-regex' => 'Alle Werte des Parameters $1 müssen diesem regulären Ausdruck entsprechen: $2.',
 444+ 'validator_list_error_invalid_argument' => 'Einer oder mehrere Werte für Parameter $1 sind ungültig.',
 445+ 'validator-list-error-accepts-only' => 'Einer oder mehrere Werte für Parameter $1 sind ungültig.
 446+Nur {{PLURAL:$3|der folgende Wert wird|die folgenden Werte werden}} akzeptiert: $2.',
 447+ 'validator-list-error-accepts-only-omitted' => 'Einer oder mehrere Werte für Parameter $1 sind ungültig.
 448+Nur {{PLURAL:$3|der folgende Wert wird|die folgenden Werte werden}} akzeptiert: $2 (sowie $4 ausgelassene {{PLURAL:$4|Wert|Werte}}).',
 449+ 'validator_error_accepts_only' => 'Der Wert „$4“ ist nicht gültig für Parameter $1.
 450+Nur {{PLURAL:$3|der folgende Wert wird|die folgenden Werte werden}} akzeptiert: $2.',
 451+ 'validator-error-accepts-only-omitted' => 'Der Wert „$2“ ist nicht gültig für Parameter $1.
 452+Nur {{PLURAL:$5|der folgende Wert wird|die folgenden Werte werden}} akzeptiert: $3 (sowie $4 ausgelassene {{PLURAL:$4|Wert|Werte}}).',
 453+ 'validator_list_omitted' => '{{PLURAL:$2|Der Wert „$1“ wurde|Die Werte „$1“ wurden}} ausgelassen.',
 454+);
 455+
 456+/** Lower Sorbian (Dolnoserbski)
 457+ * @author Michawiki
 458+ */
 459+$messages['dsb'] = array(
 460+ 'validator-desc' => 'Validator stoj lažki nałog za druge rozšyrjenja k dispoziciji, aby se pśekontrolěrowali parametry parserowych funkcijow a toflickich rozšyrjenjow, nastajili standardne gódnoty a napórali zmólkowe powěsći',
 461+ 'validator-warning' => 'Warnowanje: $1',
 462+ 'validator-error' => 'Zmólka: $1',
 463+ 'validator-fatal-error' => 'Rozwažna zmólka: $1',
 464+ 'validator_error_parameters' => '{{PLURAL:$1|Slědujuca zmólka jo se namakała|Slědujucej zmólce stej se namakałej|Slědujuce zmólki su se namakali|Slědujuce zmólki su se namakali}} w twójej syntaksy:',
 465+ 'validator_warning_parameters' => '{{PLURAL:$1|Jo zmólka|Stej zmólce|Su zmólki|Su zmólki}} w twójej syntaksy.',
 466+ 'validator-error-problem' => 'Jo był problem z parametrom $1.',
 467+ 'validator_error_unknown_argument' => '$1 njejo płaśiwy parameter.',
 468+ 'validator_error_required_missing' => 'Trěbny parameter $1 njejo pódany.',
 469+ 'validator-type-string' => 'tekst',
 470+ 'validator-type-number' => 'licba',
 471+ 'validator-type-integer' => 'ceła licba',
 472+ 'validator-type-float' => 'licba',
 473+ 'validator-type-boolean' => 'jo/ně',
 474+ 'validator-type-char' => 'znamuško',
 475+ 'validator-listerrors-errors' => 'Zmólki',
 476+ 'validator-listerrors-minor' => 'Snadna',
 477+ 'validator-listerrors-low' => 'Niska',
 478+ 'validator-listerrors-normal' => 'Normalna',
 479+ 'validator-listerrors-high' => 'Wusoka',
 480+ 'validator-listerrors-fatal' => 'Rozwažna',
 481+ 'validator-describe-descriptionmsg' => "'''wopisanje''': $1",
 482+ 'validator-describe-aliases' => "'''{{PLURAL:$2|Alias|Aliasa|Aliase|Aliase}}''': $1",
 483+ 'validator-describe-listtype' => 'Lisćina $1 {{PLURAL:$1|elementa|elementowu|elementow|elementow}}',
 484+ 'validator-describe-empty' => 'prozny',
 485+ 'validator-describe-required' => 'trěbny',
 486+ 'validator-describe-header-parameter' => 'Parameter',
 487+ 'validator-describe-header-aliases' => 'Aliase',
 488+ 'validator-describe-header-type' => 'Typ',
 489+ 'validator-describe-header-default' => 'Standard',
 490+ 'validator-describe-header-description' => 'Wopisanje',
 491+ 'validator-describe-parameters' => 'Parametry',
 492+ 'validator-describe-syntax' => 'Syntaksa',
 493+ 'validator_error_empty_argument' => 'Parameter $1 njamóžo proznu gódnotu měś.',
 494+ 'validator_error_must_be_number' => 'Parameter $1 móžo jano licba byś.',
 495+ 'validator_error_must_be_integer' => 'Parameter $1 móžo jano ceła licba byś.',
 496+ 'validator_error_invalid_range' => 'Parameter $1 musy mjazy $2 a $3 byś.',
 497+ 'validator_error_invalid_argument' => 'Gódnota $1 njejo płaśiwa za parameter $2.',
 498+ 'validator_list_error_empty_argument' => 'Parameter $1 njeakceptěrujo prozne gódnoty.',
 499+ 'validator_list_error_must_be_number' => 'Parameter $1 móžo jano licby wopśimjeś.',
 500+ 'validator_list_error_must_be_integer' => 'Parameter $1 móžo jano cełe licby wopśimjeś.',
 501+ 'validator_list_error_invalid_range' => 'Wšykne gódnoty parametra $1 muse mjazy $2 a $3 byś.',
 502+ 'validator_list_error_invalid_argument' => 'Jadna gódnota abo wěcej gódnotow za parameter $1 su njepłaśiwe.',
 503+ 'validator_error_accepts_only' => 'Gódnota "$4" njejo płaśiwa za parameter $1. Akcepteptěrujo se jano {{PLURAL:$3|toś ta gódnota|toś tej gódnośe|toś te gódnoty|toś te gódnoty}}: $2.',
 504+ 'validator_list_omitted' => '{{PLURAL:$2|Gódnota|Gódnośe|Gódnoty|Gódnoty}} $1 {{PLURAL:$2|jo se wuwóstajiła|stej se wuwóstajiłej|su se wuwóstajili|su se wuwostajili}}.',
 505+);
 506+
 507+/** Greek (Ελληνικά)
 508+ * @author Dada
 509+ * @author Lou
 510+ * @author ZaDiak
 511+ * @author Απεργός
 512+ */
 513+$messages['el'] = array(
 514+ 'validator_error_unknown_argument' => '$1 δεν είναι μια έγκυρη παράμετρος.',
 515+ 'validator_error_required_missing' => 'Λείπει η απαιτούμενη παράμετρος $1.',
 516+ 'validator_error_must_be_number' => 'Η παράμετρος $1 μπορεί να είναι μόνο αριθμός.',
 517+ 'validator_error_must_be_integer' => 'Η παράμετρος $1 μπορεί να είναι μόνο ακέραιος αριθμός.',
 518+ 'validator_list_error_must_be_number' => 'Η παράμετρος $1 μπορεί να περιέχει μόνο αριθμούς.',
 519+ 'validator_list_error_must_be_integer' => 'Η παράμετρος $1 μπορεί να περιέχει μόνο ακέραιους αριθμούς.',
 520+ 'validator_list_error_invalid_range' => 'Όλες οι τιμές της παραμέτρου $1 πρέπει να είναι μεταξύ $2 και $3.',
 521+);
 522+
 523+/** Esperanto (Esperanto)
 524+ * @author Yekrats
 525+ */
 526+$messages['eo'] = array(
 527+ 'validator_error_unknown_argument' => '$1 ne estas valida parametro.',
 528+ 'validator_error_required_missing' => 'La nepra parametro $1 mankas.',
 529+ 'validator_error_empty_argument' => 'Parametro $1 ne povas esti nula valoro.',
 530+ 'validator_error_must_be_number' => 'Parametro $1 nur povas esti numero.',
 531+ 'validator_error_must_be_integer' => 'Parametro $1 nur povas esti entjero.',
 532+ 'validator_error_invalid_range' => 'Parametro $1 estu inter $2 kaj $3.',
 533+ 'validator_list_error_invalid_argument' => 'Unu aŭ pliaj valoroj por parametro $1 estas malvalida.',
 534+);
 535+
 536+/** Spanish (Español)
 537+ * @author Crazymadlover
 538+ * @author Imre
 539+ * @author Translationista
 540+ */
 541+$messages['es'] = array(
 542+ 'validator-desc' => 'FUZZY!!! El validador es una herramienta para que otras funciones validen fácilmente parámetros de funciones de análisis y extensiones de etiquetas, establecer valores predeterminados y generar mensajes de error',
 543+ 'validator-warning' => 'Advertencia: $1',
 544+ 'validator-error' => 'Error: $1',
 545+ 'validator-fatal-error' => 'Error fatal: $1',
 546+ 'validator_error_parameters' => 'Se detectó {{PLURAL:$1|el siguiente error|los siguientes errores}} en la sintaxis empleada:',
 547+ 'validator_warning_parameters' => 'Hay {{PLURAL:$1|un error|errores}} en tu sintaxis.',
 548+ 'validator-warning-adittional-errors' => '...y {{PLURAL:$1|otro problema|muchos otros problemas}}.',
 549+ 'validator-error-omitted' => '{{PLURAL:$2|el valor "$1" ha sido omitido|los valores "$1" han sido omitidos}}.',
 550+ 'validator-error-problem' => 'Ha habido un problema con el parámetro $1.',
 551+ 'validator_error_unknown_argument' => '$1 no es un parámetro válido.',
 552+ 'validator_error_required_missing' => 'No se ha provisto el parámetro requerido $1.',
 553+ 'validator-error-override-argument' => 'Se ha intentado sobreescribir el parámetro $1 (valor: $2) con el valor "$3"',
 554+ 'validator-listerrors-errors' => 'Errores',
 555+ 'validator-listerrors-minor' => 'Menor',
 556+ 'validator-listerrors-low' => 'Bajo',
 557+ 'validator-listerrors-normal' => 'Normal',
 558+ 'validator-listerrors-high' => 'Alto',
 559+ 'validator-listerrors-fatal' => 'Fatal',
 560+ 'validator_error_empty_argument' => 'El parámetro $1 no puede tener un valor vacío.',
 561+ 'validator_error_must_be_number' => 'El parámetro $1 sólo puede ser un número.',
 562+ 'validator_error_must_be_integer' => 'El parámetro $1 sólo puede ser un número entero.',
 563+ 'validator-error-must-be-float' => 'El parámetro $1 tiene que ser un número de punto flotante.',
 564+ 'validator_error_invalid_range' => 'El parámetro $1 debe ser entre $2 y $3.',
 565+ 'validator-error-invalid-regex' => 'El parámetro $1 tiene que coincidir con esta expresión racional : $2.',
 566+ 'validator-error-invalid-length' => 'El parámetro $1 tiene que tener una longitud de $2.',
 567+ 'validator-error-invalid-length-range' => 'El parámetro $1 tiene que tener una longitud comprendida entre $2 y $3.',
 568+ 'validator_error_invalid_argument' => 'El valor $1 no es válido para el parámetro $2.',
 569+ 'validator_list_error_empty_argument' => 'El parámetro $1 no acepta valores vacíos.',
 570+ 'validator_list_error_must_be_number' => 'El parámetro $1 sólo puede contener números.',
 571+ 'validator_list_error_must_be_integer' => 'El parámetro $1 sólo puede contener números enteros.',
 572+ 'validator-list-error-must-be-float' => 'El parámetro $1 sólo puede contener floats.',
 573+ 'validator_list_error_invalid_range' => 'Todos los valores del parámetro $1 deben ser entre $2 y $3.',
 574+ 'validator-list-error-invalid-regex' => 'El parámetro $1 tiene que coincidir con esta expresión regular: $2.',
 575+ 'validator_list_error_invalid_argument' => 'Uno o más valores del parámetros $1 son inválidos.',
 576+ 'validator-list-error-accepts-only' => 'Uno o más valores para el parámetro $1 son inválidos.
 577+Sólo acepta{{PLURAL:$3|este valor| estos valores}}: $2.',
 578+ 'validator-list-error-accepts-only-omitted' => 'Uno o más valores para el parámetro $1 son inválidos.
 579+Sólo acepta {{PLURAL:$3|este valor|estos valores}}: $2 (y $4 {{PLURAL:$4|valor omitido|valores omitidos}}).',
 580+ 'validator_error_accepts_only' => 'El valor "$4" no es válido para el parámetro $1. El parámetro sólo acepta {{PLURAL:$3|este valor|estos valores}}: $2.',
 581+ 'validator-error-accepts-only-omitted' => 'El valor $2 no es válido para el parámetro $1.
 582+Sólo acepta {{PLURAL:$5|este valor|estos valores}}: $3 (y $4 {{PLURAL:$4|valor omitido|valores omitidos}}).',
 583+ 'validator_list_omitted' => '{{PLURAL:$2|El valor|Los valores}} $1 {{PLURAL:$2|ha sido omitido|han sido omitidos}}.',
 584+);
 585+
 586+/** Finnish (Suomi)
 587+ * @author Crt
 588+ * @author Silvonen
 589+ * @author Str4nd
 590+ */
 591+$messages['fi'] = array(
 592+ 'validator-desc' => 'Tarkastaja tarjoaa helpon tavan muille laajennuksille jäsenninfunktioiden ja tagilaajennusten parametrien tarkastukseen, oletusarvojen asettamiseen ja virheilmoitusten luomiseen.',
 593+ 'validator_error_must_be_number' => 'Parametrin $1 on oltava luku.',
 594+ 'validator_error_must_be_integer' => 'Parametrin $1 on oltava kokonaisluku.',
 595+);
 596+
 597+/** French (Français)
 598+ * @author Cedric31
 599+ * @author Crochet.david
 600+ * @author IAlex
 601+ * @author Jean-Frédéric
 602+ * @author McDutchie
 603+ * @author Peter17
 604+ * @author PieRRoMaN
 605+ * @author Sherbrooke
 606+ * @author Urhixidur
 607+ * @author Verdy p
 608+ */
 609+$messages['fr'] = array(
 610+ 'validator-desc' => 'Le validateur fournit aux autres extensions un moyen simple de valider les paramètres des fonctions parseur et des extensions de balises, de définir des valeurs par défaut et de générer des messages d’erreur',
 611+ 'validator-warning' => 'Attention : $1',
 612+ 'validator-error' => 'Erreur : $1',
 613+ 'validator-fatal-error' => 'Erreur fatale : $1',
 614+ 'validator_error_parameters' => '{{PLURAL:$1|L’erreur suivante a été détectée|Les erreurs suivantes ont été détectées}} dans votre syntaxe :',
 615+ 'validator_warning_parameters' => 'Il y a {{PLURAL:$1|une erreur|des erreurs}} dans votre syntaxe.',
 616+ 'validator-warning-adittional-errors' => '... et {{PLURAL:$1|un problème supplémentaire|plusieurs autres problèmes}}.',
 617+ 'validator-error-omitted' => '{{PLURAL:$2|La valeur « $1 » a été oubliée|Les valeurs « $1 » ont été oubliées}}.',
 618+ 'validator-error-problem' => 'Il y a un problème avec le paramètre $1.',
 619+ 'validator_error_unknown_argument' => '$1 n’est pas un paramètre valide.',
 620+ 'validator_error_required_missing' => 'Le paramètre requis $1 n’est pas fourni.',
 621+ 'validator-error-override-argument' => 'Le logiciel a essayé de remplacer le paramètre $1 (valeur : $2) avec la valeur « $3 »',
 622+ 'validator-type-string' => 'texte',
 623+ 'validator-type-number' => 'nombre',
 624+ 'validator-type-integer' => 'nombre entier',
 625+ 'validator-type-float' => 'nombre',
 626+ 'validator-type-boolean' => 'oui/non',
 627+ 'validator-type-char' => 'caractère',
 628+ 'validator-listerrors-errors' => 'Erreurs',
 629+ 'validator-listerrors-minor' => 'Mineur',
 630+ 'validator-listerrors-low' => 'Faible',
 631+ 'validator-listerrors-normal' => 'Normal',
 632+ 'validator-listerrors-high' => 'Élevé',
 633+ 'validator-listerrors-fatal' => 'Fatal',
 634+ 'validator-listerrors-description' => "Liste les erreurs (et les avertissements) qui se sont produits dans les ''hooks'' de l'analyseur syntaxique ''via'' ''Validator''.
 635+Seules les listes pour les ''hooks'' de l'analyseur syntaxique (ajoutées où apparaît <code>listerrors</code>) sont insérées ;
 636+placer <code>listerrors</code> au plus bas de la page pour obtenir toutes les erreurs.",
 637+ 'validator-listerrors-par-minseverity' => "La sévérité minimale d'une erreur pour être listée.",
 638+ 'validator-describe-description' => "Génère la documentation pour un ou plusieurs ''hooks'' de l'analyseur syntaxique ''via'' ''Validator'.",
 639+ 'validator-describe-notfound' => "Il n'y a pas de ''hook'' qui gère « $1 ».",
 640+ 'validator-describe-descriptionmsg' => "'''Description''': $1",
 641+ 'validator-describe-aliases' => "'''{{PLURAL:$2|Alias|Alias}}''': $1",
 642+ 'validator-describe-parserfunction' => "Mis en oeuvre uniquement comme fonction de l'analyseur syntaxique.",
 643+ 'validator-describe-tagextension' => "Mis en œuvre seulement comme balise d'extension.",
 644+ 'validator-describe-bothhooks' => "Mis en oeuvre comme fonction de l'analyseur syntaxique et comme balise d'extension.",
 645+ 'validator-describe-par-hooks' => "Les ''hooks'' de l'analyseur syntaxique dont il faut afficher la documentation.",
 646+ 'validator-describe-par-pre' => "Permet d'obtenir le wikitexte de la documentation, sans qu'il soit rendu sur la page.",
 647+ 'validator-describe-listtype' => 'Liste de $1 éléments',
 648+ 'validator-describe-empty' => 'vide',
 649+ 'validator-describe-required' => 'requis',
 650+ 'validator-describe-header-parameter' => 'Paramètre',
 651+ 'validator-describe-header-aliases' => 'Alias',
 652+ 'validator-describe-header-type' => 'Type',
 653+ 'validator-describe-header-default' => 'Défaut',
 654+ 'validator-describe-header-description' => 'Description',
 655+ 'validator-describe-parameters' => 'Paramètres',
 656+ 'validator-describe-syntax' => 'Syntaxe',
 657+ 'validator-describe-tagmin' => "Balise d'extension avec seulement les paramètres requis.",
 658+ 'validator-describe-tagmax' => "Balise d'extension avec tous les paramètres.",
 659+ 'validator-describe-tagdefault' => "Balise d'extension avec tous les paramètres en utilisant la notation par défaut des paramètres.",
 660+ 'validator-describe-pfmin' => "Fonction de l'analyseur syntaxique avec seulement les paramètres requis.",
 661+ 'validator-describe-pfmax' => "Fonction de l'analyseur syntaxique avec tous les paramètres.",
 662+ 'validator-describe-pfdefault' => "Fonction de l'analyseur syntaxique avec tous les paramètres en utilisant la notation par défaut des paramètres.",
 663+ 'validator-describe-autogen' => "Le contenu de cette section a été généré automatiquement par le ''hook'' ''Describe'' de l'extension ''Validator''.",
 664+ 'validator_error_empty_argument' => 'Le paramètre $1 ne peut pas avoir une valeur vide.',
 665+ 'validator_error_must_be_number' => 'Le paramètre $1 peut être uniquement un nombre.',
 666+ 'validator_error_must_be_integer' => 'Le paramètre $1 peut seulement être un entier.',
 667+ 'validator-error-must-be-float' => 'Le paramètre $1 doit être un nombre à virgule flottante.',
 668+ 'validator_error_invalid_range' => 'Le paramètre $1 doit être entre $2 et $3.',
 669+ 'validator-error-invalid-regex' => 'Le paramètre $1 doit vérifier cette expression rationnelle : « $2 ».',
 670+ 'validator-error-invalid-length' => 'Le paramètre $1 doit avoir une longueur de $2.',
 671+ 'validator-error-invalid-length-range' => 'Le paramètre $1 doit avoir une longueur comprise entre $2 et $3.',
 672+ 'validator_error_invalid_argument' => 'La valeur $1 n’est pas valide pour le paramètre $2.',
 673+ 'validator_list_error_empty_argument' => 'Le paramètre $1 n’accepte pas les valeurs vides.',
 674+ 'validator_list_error_must_be_number' => 'Le paramètre $1 ne peut contenir que des nombres.',
 675+ 'validator_list_error_must_be_integer' => 'Le paramètre $1 ne peut contenir que des entiers.',
 676+ 'validator-list-error-must-be-float' => 'Le paramètre $1 ne peut contenir que des nombres à virgule.',
 677+ 'validator_list_error_invalid_range' => 'Toutes les valeurs du paramètre $1 doivent être comprises entre $2 et $3.',
 678+ 'validator-list-error-invalid-regex' => 'Toutes les valeurs du paramètre $1 doivent vérifier cette expression rationnelle : « $2 ».',
 679+ 'validator_list_error_invalid_argument' => 'Une ou plusieurs valeurs du paramètre $1 sont invalides.',
 680+ 'validator-list-error-accepts-only' => 'Une ou plusieurs valeur(s) du paramètre $1 est(sont) invalide(s).
 681+Il n’accepte que {{PLURAL:$3|cette valeur|ces valeurs}} : $2.',
 682+ 'validator-list-error-accepts-only-omitted' => 'Une ou plusieurs valeur(s) du paramètre $1 est(sont) invalide(s).
 683+Celui-ci n’accepte que {{PLURAL:$3|cette valeur|ces valeurs}} : $2 (et $4 {{PLURAL:$4|valeur omise|valeurs omises}}).',
 684+ 'validator_error_accepts_only' => "La valeur « $4 » n'est pas valable pour le paramètre $1. Il accepte uniquement {{PLURAL:$3|cette valeur|ces valeurs}} : $2.",
 685+ 'validator-error-accepts-only-omitted' => 'La valeur « $2 » n’est pas valable pour le paramètre $1.
 686+Celui-ci n’accepte que {{PLURAL:$5|cette valeur|ces valeurs}} : $3 (et $4 {{PLURAL:$4|valeur omise|valeurs omises}}).',
 687+ 'validator_list_omitted' => '{{PLURAL:$2|La valeur|Les valeurs}} $1 {{PLURAL:$2|a été oubliée|ont été oubliées}}.',
 688+);
 689+
 690+/** Franco-Provençal (Arpetan)
 691+ * @author ChrisPtDe
 692+ */
 693+$messages['frp'] = array(
 694+ 'validator_error_parameters' => '{{PLURAL:$1|Ceta èrror at étâ dècelâ|Cetes èrrors ont étâ dècelâs}} dens voutra sintaxa :',
 695+ 'validator_warning_parameters' => 'Y at {{PLURAL:$1|una èrror|des èrrors}} dens voutra sintaxa.',
 696+ 'validator_error_unknown_argument' => '$1 est pas un paramètre valido.',
 697+ 'validator_error_required_missing' => 'Lo paramètre nècèssèro $1 est pas balyê.',
 698+ 'validator_error_empty_argument' => 'Lo paramètre $1 pôt pas avêr una valor voueda.',
 699+ 'validator_error_must_be_number' => 'Lo paramètre $1 pôt étre ren qu’un nombro.',
 700+ 'validator_error_must_be_integer' => 'Lo paramètre $1 pôt étre ren qu’un entiér.',
 701+ 'validator_error_invalid_range' => 'Lo paramètre $1 dêt étre entre-mié $2 et $3.',
 702+ 'validator_error_invalid_argument' => 'La valor $1 est pas valida por lo paramètre $2.',
 703+ 'validator_list_error_empty_argument' => 'Lo paramètre $1 accèpte pas les valors vouedes.',
 704+ 'validator_list_error_must_be_number' => 'Lo paramètre $1 pôt contegnir ren que des nombros.',
 705+ 'validator_list_error_must_be_integer' => 'Lo paramètre $1 pôt contegnir ren que des entiérs.',
 706+ 'validator_list_error_invalid_range' => 'Totes les valors du paramètre $1 dêvont étre entre-mié $2 et $3.',
 707+ 'validator_list_error_invalid_argument' => 'Yona ou ben un mouél de valors du paramètre $1 sont envalides.',
 708+ 'validator_error_accepts_only' => 'La valor « $4 » est pas valida por lo paramètre $1. Accèpte ren que {{PLURAL:$3|ceta valor|cetes valors}} : $2.',
 709+ 'validator_list_omitted' => '{{PLURAL:$2|La valor|Les valors}} $1 {{PLURAL:$2|at étâ oubliâ|ont étâ oubliâs}}.',
 710+);
 711+
 712+/** Galician (Galego)
 713+ * @author Toliño
 714+ */
 715+$messages['gl'] = array(
 716+ 'validator-desc' => 'O servizo de validación ofrece un medio sinxelo a outras extensións para validar os parámetros de funcións analíticas e etiquetas de extensións, para establecer os valores por defecto e para xerar mensaxes de erro',
 717+ 'validator-warning' => 'Atención: $1',
 718+ 'validator-error' => 'Erro: $1',
 719+ 'validator-fatal-error' => 'Erro fatal: $1',
 720+ 'validator_error_parameters' => '{{PLURAL:$1|Detectouse o seguinte erro|Detectáronse os seguintes erros}} na sintaxe empregada:',
 721+ 'validator_warning_parameters' => 'Hai {{PLURAL:$1|un erro|erros}} na súa sintaxe.',
 722+ 'validator-warning-adittional-errors' => '... e {{PLURAL:$1|un problema máis|moitos máis problemas}}.',
 723+ 'validator-error-omitted' => '{{PLURAL:$2|Omitiuse o valor "$1"|Omitíronse os valores "$1"}}.',
 724+ 'validator-error-problem' => 'Houbo un problema co parámetro $1.',
 725+ 'validator_error_unknown_argument' => '"$1" non é un parámetro válido.',
 726+ 'validator_error_required_missing' => 'Non se proporcionou o parámetro $1 necesario.',
 727+ 'validator-error-override-argument' => 'Intentouse sobrescribir o parámetro $1 (valor: $2) co valor "$3"',
 728+ 'validator-type-string' => 'texto',
 729+ 'validator-type-number' => 'número',
 730+ 'validator-type-integer' => 'número completo',
 731+ 'validator-type-float' => 'número',
 732+ 'validator-type-boolean' => 'si/non',
 733+ 'validator-type-char' => 'carácter',
 734+ 'validator-listerrors-errors' => 'Erros',
 735+ 'validator-listerrors-minor' => 'Menor',
 736+ 'validator-listerrors-low' => 'Baixo',
 737+ 'validator-listerrors-normal' => 'Normal',
 738+ 'validator-listerrors-high' => 'Alto',
 739+ 'validator-listerrors-fatal' => 'Fatal',
 740+ 'validator-describe-descriptionmsg' => "'''Descrición:''' $1",
 741+ 'validator-describe-listtype' => 'Lista de $1 elementos',
 742+ 'validator-describe-empty' => 'baleiro',
 743+ 'validator-describe-required' => 'obrigatorio',
 744+ 'validator-describe-header-parameter' => 'Parámetro',
 745+ 'validator-describe-header-aliases' => 'Pseudónimos',
 746+ 'validator-describe-header-type' => 'Tipo',
 747+ 'validator-describe-header-default' => 'Por defecto',
 748+ 'validator-describe-header-description' => 'Descrición',
 749+ 'validator-describe-parameters' => 'Parámetros',
 750+ 'validator-describe-syntax' => 'Sintaxe',
 751+ 'validator_error_empty_argument' => 'O parámetro $1 non pode ter un valor baleiro.',
 752+ 'validator_error_must_be_number' => 'O parámetro $1 só pode ser un número.',
 753+ 'validator_error_must_be_integer' => 'O parámetro $1 só pode ser un número enteiro.',
 754+ 'validator-error-must-be-float' => 'O parámetro $1 só pode ser un número de coma flotante.',
 755+ 'validator_error_invalid_range' => 'O parámetro $1 debe estar entre $2 e $3.',
 756+ 'validator-error-invalid-regex' => 'O parámetro $1 debe coincidir con esta expresión regular: $2.',
 757+ 'validator-error-invalid-length' => 'O parámetro $1 debe ter unha lonxitude de $2.',
 758+ 'validator-error-invalid-length-range' => 'O parámetro $1 ter unha lonxitude de entre $2 e $3.',
 759+ 'validator_error_invalid_argument' => 'O valor $1 non é válido para o parámetro $2.',
 760+ 'validator_list_error_empty_argument' => 'O parámetro $1 non acepta valores en branco.',
 761+ 'validator_list_error_must_be_number' => 'O parámetro $1 só pode conter números.',
 762+ 'validator_list_error_must_be_integer' => 'O parámetro $1 só pode conter números enteiros.',
 763+ 'validator-list-error-must-be-float' => 'O parámetro $1 só pode conter comas flotantes.',
 764+ 'validator_list_error_invalid_range' => 'Todos os valores do parámetro $1 deben estar comprendidos entre $2 e $3.',
 765+ 'validator-list-error-invalid-regex' => 'Todos os valores do parámetro $1 deben coincidir con esta expresión regular: $2.',
 766+ 'validator_list_error_invalid_argument' => 'Un ou varios valores do parámetro $1 non son válidos.',
 767+ 'validator-list-error-accepts-only' => 'Un ou varios valores do parámetro $1 non son válidos.
 768+Só acepta {{PLURAL:$3|este valor|estes valores}}: $2.',
 769+ 'validator-list-error-accepts-only-omitted' => 'Un ou varios valores do parámetro $1 non son válidos.
 770+Só acepta {{PLURAL:$3|este valor|estes valores}}: $2 (e $4 {{PLURAL:$4|valor omitido|valores omitidos}}).',
 771+ 'validator_error_accepts_only' => 'O valor "$4" non é válido para o parámetro "$1". Só acepta {{PLURAL:$3|este valor|estes valores}}: $2.',
 772+ 'validator-error-accepts-only-omitted' => 'O valor "$2" non é válido para o parámetro $1.
 773+Só acepta {{PLURAL:$5|este valor|estes valores}}: $3 (e $4 {{PLURAL:$4|valor omitido|valores omitidos}}).',
 774+ 'validator_list_omitted' => '{{PLURAL:$2|O valor|Os valores}} $1 {{PLURAL:$2|foi omitido|foron omitidos}}.',
 775+);
 776+
 777+/** Swiss German (Alemannisch)
 778+ * @author Als-Holder
 779+ */
 780+$messages['gsw'] = array(
 781+ 'validator-desc' => 'Validator stellt e eifachi Form z Verfiegig fir anderi Erwyterige go Parameter validiere vu Parser- un Tag-Funktione, go Standardwärt definiere un Fählermäldige generiere',
 782+ 'validator-warning' => 'Warnig: $1',
 783+ 'validator-error' => 'Fähler: $1',
 784+ 'validator-fatal-error' => 'Fähler, wu nit cha behobe wäre: $1',
 785+ 'validator_error_parameters' => '{{PLURAL:$1|Dää Fähler isch|Die Fähler sin}} in Dyyre Syntax gfunde wore:',
 786+ 'validator_warning_parameters' => 'S het {{PLURAL:$1|e Fähler|Fähler}} in dyyre Syntax.',
 787+ 'validator-warning-adittional-errors' => '... un {{PLURAL:$1|e ander Probläm|$1 anderi Probläm}}.',
 788+ 'validator-error-omitted' => '{{PLURAL:$2|Dr Wärt|D Wärt}} „$1“ {{PLURAL:$2|isch|sin}} uusgloo wore.',
 789+ 'validator-error-problem' => 'S het e Probläm gee mit em Parameter $1.',
 790+ 'validator_error_unknown_argument' => '$1 isch kei giltige Parameter.',
 791+ 'validator_error_required_missing' => 'Dr Paramter $1, wu aagforderet woren isch, wird nit z Verfiegig gstellt.',
 792+ 'validator-error-override-argument' => 'S isch versuecht wore, dr Parameter $1 (Wärt: $2) mit em Wärt „$3“ z iberschryybe',
 793+ 'validator-listerrors-errors' => 'Fähler',
 794+ 'validator-listerrors-minor' => 'Gring',
 795+ 'validator-listerrors-low' => 'Chlei',
 796+ 'validator-listerrors-normal' => 'Normal',
 797+ 'validator-listerrors-high' => 'Groß',
 798+ 'validator-listerrors-fatal' => 'Schwär',
 799+ 'validator_error_empty_argument' => 'Dr Parameter $1 cha kei lääre Wärt haa.',
 800+ 'validator_error_must_be_number' => 'Dr Parameter $1 cha nume ne Zahl syy.',
 801+ 'validator_error_must_be_integer' => 'Parameter $1 cha nume ne giltigi Zahl syy.',
 802+ 'validator-error-must-be-float' => 'Parameter $1 cha nume ne Gleitkommazahl syy.',
 803+ 'validator_error_invalid_range' => 'Dr Parameter $1 muess zwische $2 un $3 syy.',
 804+ 'validator-error-invalid-regex' => 'Parameter $1 mueß däm reguläre Uusdruck entspräche: $2.',
 805+ 'validator-error-invalid-length' => 'Parameter $1 mueß e Lengi haa vu $2.',
 806+ 'validator-error-invalid-length-range' => 'Parameter $1 mueß e Lengi haa zwische $2 un $3.',
 807+ 'validator_error_invalid_argument' => 'Dr Wärt $1 isch nit giltig fir dr Parameter $2.',
 808+ 'validator_list_error_empty_argument' => 'Bim Parameter $1 sin keini lääre Wärt zuegloo.',
 809+ 'validator_list_error_must_be_number' => 'Fir dr Parameter $1 si nume Zahle zuegloo.',
 810+ 'validator_list_error_must_be_integer' => 'Fir dr Parameter $1 sin nume ganzi Zahle zuegloo.',
 811+ 'validator-list-error-must-be-float' => 'Im Parameter $1 cha s nume Gleitkommazahle haa.',
 812+ 'validator_list_error_invalid_range' => 'Alli Wärt fir dr Parameter $1 mien zwische $2 un $3 lige.',
 813+ 'validator-list-error-invalid-regex' => 'Alli Wärt vum Parameter $1 mien däm reguläre Uusdruck entspräche: $2.',
 814+ 'validator_list_error_invalid_argument' => 'Ein oder mehreri Wärt fir dr Parameter $1 sin nit giltig.',
 815+ 'validator-list-error-accepts-only' => 'Ein oder meh Wärt fir dr Parameter $1 sin nit giltig.
 816+Nume {{PLURAL:$3|dää Wärt wird|die Wärt wäre}} akzeptiert: $2.',
 817+ 'validator-list-error-accepts-only-omitted' => 'Ein oder meh Wärt fir dr Parameter $1 sin nit giltig.
 818+Nume {{PLURAL:$3|dää Wärt wird|die Wärt wäre}} akzeptiert: $2 (un $4 uusglosseni {{PLURAL:$4|Wärt|Wärt}}).',
 819+ 'validator_error_accepts_only' => 'Dr Wärt „$4“ isch nit giltig fir dr Parameter $1. Nume {{PLURAL:$3|dää Wärt wird|die Wärt wäre}} akzeptiert: „$2“.',
 820+ 'validator-error-accepts-only-omitted' => 'Dr Wärt „$2“ isch nit giltig fir dr Parameter $1.
 821+Nume {{PLURAL:$5|dää Wärt wird|die Wärt wäre}} akzeptiert: $3 (un $4 uusglosseni {{PLURAL:$4|Wärt|Wärt}}).',
 822+ 'validator_list_omitted' => '{{PLURAL:$2|Dr Wärt|D Wärt}} $1 {{PLURAL:$2|isch|sin}} uusgloo wore.',
 823+);
 824+
 825+/** Hebrew (עברית)
 826+ * @author Amire80
 827+ * @author Rotemliss
 828+ * @author YaronSh
 829+ */
 830+$messages['he'] = array(
 831+ 'validator-fatal-error' => 'שגיאה חמורה: $1',
 832+ 'validator_warning_parameters' => '{{PLURAL:$1|ישנה שגיאה|ישנן שגיאות}} בתחביר שלכם.',
 833+ 'validator_error_unknown_argument' => '$1 אינו פרמטר תקני.',
 834+ 'validator_error_required_missing' => 'הפרמטר הדרוש $1 לא צוין.',
 835+ 'validator-listerrors-errors' => 'שגיאות',
 836+ 'validator_error_empty_argument' => 'הפרמטר $1 לא יכול להיות ערך ריק.',
 837+ 'validator_error_must_be_number' => 'הפרמטר $1 יכול להיות מספר בלבד.',
 838+ 'validator_error_must_be_integer' => 'הפרמטר $1 יכול להיות מספר שלם בלבד.',
 839+ 'validator_error_invalid_range' => 'הפרמטר $1 חייב להיות בין $2 ל־$3.',
 840+ 'validator_error_invalid_argument' => 'הערך $1 אינו תקני עבור הפרמטר $2.',
 841+);
 842+
 843+/** Upper Sorbian (Hornjoserbsce)
 844+ * @author Michawiki
 845+ */
 846+$messages['hsb'] = array(
 847+ 'validator-desc' => 'Validator skići lochke wašnje za druhe rozšěrjenja, zo bychu so parametry parserowych funkcijow a tafličkowych rozšěrjenjow přepruwowali, standardne hódnoty nastajili a zmylkowe powěsće wutworili',
 848+ 'validator-warning' => 'Warnowanje: $1',
 849+ 'validator-error' => 'Zmylk: $1',
 850+ 'validator-fatal-error' => 'Chutny zmylk: $1',
 851+ 'validator_error_parameters' => '{{PLURAL:$1|Slědowacy zmylk bu|Slědowacej zmylkaj buštej|Slědowace zmylki buchu|Slědowace zmylki buchu}} w twojej syntaksy {{PLURAL:$1|wotkryty|wotkrytej|wotkryte|wotkryte}}:',
 852+ 'validator_warning_parameters' => '{{PLURAL:$1|Je zmylk|Stej zmylkaj|Su zmylki|Su zmylki}} w twojej syntaksy.',
 853+ 'validator-warning-adittional-errors' => '... a {{PLURAL:$1|dalši problem|dalšej problemaj|dalše problemy|dalše problemy}}.',
 854+ 'validator-error-omitted' => '{{PLURAL:$2|Hódnota "$1" je so wuwostajena|Hódnoće "$1" stej so wuwostajenej|Hódnoty "$1" su so wuwostajene|Hódnoty "$1" su so wuwostajene}}.',
 855+ 'validator-error-problem' => 'Bě problem z parametrom $1.',
 856+ 'validator_error_unknown_argument' => '$1 płaćiwy parameter njeje.',
 857+ 'validator_error_required_missing' => 'Trěbny parameter $1 njeje podaty.',
 858+ 'validator-error-override-argument' => 'Spyta so parameter $1 (hódnota: $2) přez "$3" přepisować',
 859+ 'validator-type-string' => 'tekst',
 860+ 'validator-type-number' => 'ličba',
 861+ 'validator-type-integer' => 'cyła ličba',
 862+ 'validator-type-float' => 'ličba',
 863+ 'validator-type-boolean' => 'haj/ně',
 864+ 'validator-type-char' => 'znamješko',
 865+ 'validator-listerrors-errors' => 'Zmylki',
 866+ 'validator-listerrors-minor' => 'Snadny',
 867+ 'validator-listerrors-low' => 'Niski',
 868+ 'validator-listerrors-normal' => 'Normalny',
 869+ 'validator-listerrors-high' => 'Wysoki',
 870+ 'validator-listerrors-fatal' => 'Chutny',
 871+ 'validator-listerrors-description' => 'Nalistuje zmylki (a warnowanja), kotrež su w parserowych hóčkach wustupili, kotrež su so přez Validator přidali.
 872+Listuje jenož parserowe hóčki, kotrež bu wyše "listerror" zasunjene;
 873+staj "listerrors" deleka na stronje abo blisko kónca strony, zo by wšě zmylki widźał.',
 874+ 'validator-listerrors-par-minseverity' => 'Minimalna ćežkosć problema, zo by so zwobraznił.',
 875+ 'validator-describe-description' => 'Płodźi dokumentaciju za jednu parserowu hóčku abo wjacore parserowe hóčki přez Validator.',
 876+ 'validator-describe-notfound' => 'Njeje parserowa hóčka, kotraž "$1" wobdźěłuje.',
 877+ 'validator-describe-descriptionmsg' => "'''Wopisanje''': $1",
 878+ 'validator-describe-aliases' => "'''{{PLURAL:$2|Alias|Aliasaj|Aliasy|Aliasow}}''': $1",
 879+ 'validator-describe-parserfunction' => 'Jenož jako parserowa funkcija implementowany.',
 880+ 'validator-describe-tagextension' => 'Jenož jako elementowe rozšěrjenje implementowany.',
 881+ 'validator-describe-bothhooks' => 'Jako parserowa funkcija kaž tež jako elementowe rozšěrjenje implementowany.',
 882+ 'validator-describe-par-hooks' => 'Parserowe hóčki, za kotrež ma so dokumentacija zwobraznić.',
 883+ 'validator-describe-par-pre' => 'Zmóžnja woprawdźity wikitekst za dokumentaciju wobstarać, bjez toho zo so na stronje rysował.',
 884+ 'validator-describe-listtype' => 'Lisćina $1 {{PLURAL:$1|elementa|elementow|elementow|elementow}}',
 885+ 'validator-describe-empty' => 'prózdny',
 886+ 'validator-describe-required' => 'trěbny',
 887+ 'validator-describe-header-parameter' => 'Parameter',
 888+ 'validator-describe-header-aliases' => 'Aliasy',
 889+ 'validator-describe-header-type' => 'Typ',
 890+ 'validator-describe-header-default' => 'Standard',
 891+ 'validator-describe-header-description' => 'Wopisanje',
 892+ 'validator-describe-parameters' => 'Parametry',
 893+ 'validator-describe-syntax' => 'Syntaksa',
 894+ 'validator-describe-tagmin' => 'Elementowe rozšěrjenje jenož z trěbnymi parametrami.',
 895+ 'validator-describe-tagmax' => 'Elementowe rozšěrjenje ze wšěmi parametrami.',
 896+ 'validator-describe-tagdefault' => 'Elementowe rozšěrjenje ze wšěmi parametrami, kotrež standardnu notaciju za parametry wužiwaja.',
 897+ 'validator-describe-pfmin' => 'Parserowa funkcija jenož z trěbnymi parametrami.',
 898+ 'validator-describe-pfmax' => 'Parserowa funkcija ze wšěmi parametrami.',
 899+ 'validator-describe-pfdefault' => 'Parserowa funkcija ze wšěmi parametrami, kotrež standardnu notaciju za parametry wužiwaja.',
 900+ 'validator-describe-autogen' => 'Wobsah tutoho wotrězka je so přez parserowu hóčku rozšěrjenja Validator awtomatisce spłodźił.',
 901+ 'validator_error_empty_argument' => 'Parameter $1 njemóže prózdnu hódnotu měć.',
 902+ 'validator_error_must_be_number' => 'Parameter $1 móže jenož ličba być.',
 903+ 'validator_error_must_be_integer' => 'Parameter $1 móže jenož cyła ličba być.',
 904+ 'validator-error-must-be-float' => 'Parameter $1 móže jenož ličba z pohibliwej komu być.',
 905+ 'validator_error_invalid_range' => 'Parameter $1 dyrbi mjez $2 a $3 być.',
 906+ 'validator-error-invalid-regex' => 'Parameter $1 dyrbi tutomu regularnemu wurazej wotpowědować: $2',
 907+ 'validator-error-invalid-length' => 'Parameter $1 dyrbi $2 dołhi być.',
 908+ 'validator-error-invalid-length-range' => 'Parameter $1 dyrbi mjez $2 a $3 dołhi być.',
 909+ 'validator_error_invalid_argument' => 'Hódnota $1 njeje płaćiwa za parameter $2.',
 910+ 'validator_list_error_empty_argument' => 'Parameter $1 njeakceptuje prózdne hódnoty.',
 911+ 'validator_list_error_must_be_number' => 'Parameter $1 móže jenož ličby wobsahować.',
 912+ 'validator_list_error_must_be_integer' => 'Parameter $1 móže jenož cyłe ličby wobsahować.',
 913+ 'validator-list-error-must-be-float' => 'Parameter $1 móže jenož ličby z pohibliwej komu wobsahować.',
 914+ 'validator_list_error_invalid_range' => 'Wšě hódnoty parametra $1 dyrbja mjez $2 a $3 być.',
 915+ 'validator-list-error-invalid-regex' => 'Wšě hódnoty parametra $1 dyrbja tutomu regularnemu wurazej wotpowědować: $2',
 916+ 'validator_list_error_invalid_argument' => 'Jedna hódnota abo wjace hódnotow za parameter $1 su njepłaćiwe.',
 917+ 'validator-list-error-accepts-only' => 'Jedna abo wjacore hódnoty za parameter $1 su njepłaćiwe. {{PLURAL:$3|Akceptuje|Akceptujetej|Akceptuja|Akceptuja}} so jenož {{PLURAL:$3|tuta hódnota|tutej hódnoće|tute hódnoty|tute hódnoty}}: $2',
 918+ 'validator-list-error-accepts-only-omitted' => 'Jedna abo wjacore hódnoty za parameter $1 su njepłaćiwe. {{PLURAL:$3|Akceptuje|Akceptujetej|Akceptuja|Akceptuja}} so jenož {{PLURAL:$3|tuta hódnota|tutej hódnoće|tute hódnoty|tute hódnoty}}: $2 (a $4 {{PLURAl:$4|wuwostajena hódnota|wuwostajenej hódnoće|wuwostajene hódnoty|wuwostajenych hódnotow}}).',
 919+ 'validator_error_accepts_only' => 'Hódnota "$4" za parameter $1 płaćiwa njeje. Akceptuje jenož {{PLURAL:$3|tutu hódnotu|tutej hódnoće|tute hódnoty|tute hódnoty}}: $2.',
 920+ 'validator-error-accepts-only-omitted' => 'Hódnota "$2" njeje płaćiwa za parameter $1. {{PLURAL:$5|Akceptuje|Akceptujetej|Akceptuja|Akceptuja}} so jenož {{PLURAL:$5|tuta hódnota|tutej hódnoće|tute hódnoty|tute hódnoty}}: $3 (a $4 {{PLURAl:$4|wuwostajena hódnota|wuwostajenej hódnoće|wuwostajene hódnoty|wuwostajenych hódnotow}}).',
 921+ 'validator_list_omitted' => '{{PLURAL:$2|Hódnota|Hódnoće|Hódnoty|Hódnoty}} $1 {{PLURAL:$2|je so wuwostajiła|stej so wuwostajiłoj|su so wuwostajili|su so wuwostajili}}.',
 922+);
 923+
 924+/** Hungarian (Magyar)
 925+ * @author Dani
 926+ * @author Glanthor Reviol
 927+ */
 928+$messages['hu'] = array(
 929+ 'validator-desc' => 'Az érvényesség-ellenőrző egyszerű lehetőséget nyújt más kiterjesztéseknek az elemzőfüggvények és tagek paramétereinek ellenőrzésére, alapértelmezett értékek beállítására, valamint hibaüzenetek generálására.',
 930+ 'validator-warning' => 'Figyelmeztetés: $1',
 931+ 'validator-error' => 'Hiba: $1',
 932+ 'validator-fatal-error' => 'Végzetes hiba: $1',
 933+ 'validator_error_parameters' => 'A következő {{PLURAL:$1|hiba található|hibák találhatóak}} a szintaxisban:',
 934+ 'validator_warning_parameters' => '{{PLURAL:$1|Hiba van|Hibák vannak}} a szintaxisodban.',
 935+ 'validator_error_unknown_argument' => 'A(z) $1 nem érvényes paraméter.',
 936+ 'validator_error_required_missing' => 'A(z) $1 kötelező paraméter nem lett megadva.',
 937+ 'validator-listerrors-errors' => 'Hibák',
 938+ 'validator-listerrors-minor' => 'Apró',
 939+ 'validator-listerrors-low' => 'Alacsony',
 940+ 'validator-listerrors-normal' => 'Normális',
 941+ 'validator-listerrors-high' => 'Komoly',
 942+ 'validator-listerrors-fatal' => 'Végzetes',
 943+ 'validator_error_empty_argument' => 'A(z) $1 paraméter értéke nem lehet üres.',
 944+ 'validator_error_must_be_number' => 'A(z) $1 paraméter csak szám lehet.',
 945+ 'validator_error_must_be_integer' => 'A(z) $1 paraméter csak egész szám lehet.',
 946+ 'validator-error-must-be-float' => 'A(z) $1 paraméter csak lebegőpontos szám lehet.',
 947+ 'validator_error_invalid_range' => 'A(z) $1 paraméter értékének $2 és $3 között kell lennie.',
 948+ 'validator-error-invalid-regex' => 'A(z) $1 paraméternek illeszkednie kell a következő reguláris kifejezésre: $2.',
 949+ 'validator-error-invalid-length' => 'A(z) $1 paraméternek legalább $2 karakter hosszúnak kell lennie.',
 950+ 'validator-error-invalid-length-range' => 'A(z) $1 paraméternek $2 és $3 karakter közötti hosszúnak kell lennie.',
 951+ 'validator_error_invalid_argument' => 'A(z) $1 érték nem érvényes a(z) $2 paraméterhez.',
 952+ 'validator_list_error_empty_argument' => 'A(z) $1 paraméter nem fogad el üres értékeket.',
 953+ 'validator_list_error_must_be_number' => 'A(z) $1 paraméter csak számokat tartalmazhat.',
 954+ 'validator_list_error_must_be_integer' => 'A(z) $1 paraméter csak egész számokat tartalmazhat.',
 955+ 'validator-list-error-must-be-float' => 'A(z) $1 paraméter csak lebegőpontos számokat tartalmazhat.',
 956+ 'validator_list_error_invalid_range' => 'A(z) $1 paraméter összes értékének $2 és $3 közöttinek kell lennie.',
 957+ 'validator_list_error_invalid_argument' => 'A(z) $1 paraméter egy vagy több értéke érvénytelen.',
 958+ 'validator_error_accepts_only' => 'A(z) $1 paraméter csak a következő {{PLURAL:$3|értéket|értékeket}} fogadja el: $2',
 959+ 'validator_list_omitted' => 'A(z) $1 {{PLURAL:$2|érték mellőzve lett.|értékek mellőzve lettek.}}',
 960+);
 961+
 962+/** Interlingua (Interlingua)
 963+ * @author McDutchie
 964+ */
 965+$messages['ia'] = array(
 966+ 'validator-desc' => 'Validator provide un modo facile a altere extensiones de validar parametros de functiones del analysator syntactic e extensiones de etiquettas, predefinir valores e generar messages de error',
 967+ 'validator-warning' => 'Aviso: $1',
 968+ 'validator-error' => 'Error: $1',
 969+ 'validator-fatal-error' => 'Error fatal: $1',
 970+ 'validator_error_parameters' => 'Le sequente {{PLURAL:$1|error|errores}} ha essite detegite in tu syntaxe:',
 971+ 'validator_warning_parameters' => 'Il ha {{PLURAL:$1|un error|errores}} in tu syntaxe.',
 972+ 'validator-warning-adittional-errors' => '... e {{PLURAL:$1|un altere problema|plure altere problemas}}.',
 973+ 'validator-error-omitted' => 'Le {{PLURAL:$2|valor|valores}} "$1" ha essite omittite.',
 974+ 'validator-error-problem' => 'Il habeva un problema con le parametro $1.',
 975+ 'validator_error_unknown_argument' => '$1 non es un parametro valide.',
 976+ 'validator_error_required_missing' => 'Le parametro requisite $1 non ha essite fornite.',
 977+ 'validator-error-override-argument' => 'Tentava supplantar le parametro $1 (valor: $2) con le valor "$3"',
 978+ 'validator-type-string' => 'texto',
 979+ 'validator-type-number' => 'numero',
 980+ 'validator-type-integer' => 'numero integre',
 981+ 'validator-type-float' => 'numero',
 982+ 'validator-type-boolean' => 'si/no',
 983+ 'validator-type-char' => 'character',
 984+ 'validator-listerrors-errors' => 'Errores',
 985+ 'validator-listerrors-minor' => 'Minor',
 986+ 'validator-listerrors-low' => 'Basse',
 987+ 'validator-listerrors-normal' => 'Normal',
 988+ 'validator-listerrors-high' => 'Alte',
 989+ 'validator-listerrors-fatal' => 'Fatal',
 990+ 'validator-listerrors-description' => 'Lista errores (e advertimentos) que occurreva in uncinos analysator addite con Validator.
 991+Isto face listas solmente pro le uncinos analysator addite supra le loco ubi "listerrors" es inserite;
 992+mitte "listerrors" al fin del pagina, o proxime al fin, pro obtener tote le errores.',
 993+ 'validator-listerrors-par-minseverity' => 'Le severitate minime de un problema pro esser listate.',
 994+ 'validator-describe-description' => 'Genera documentation pro un o plus uncinos del analysator syntactic, definite via Validator.',
 995+ 'validator-describe-notfound' => 'Non existe un uncino del analysator syntactic que manea "$1".',
 996+ 'validator-describe-descriptionmsg' => "'''Description''': $1",
 997+ 'validator-describe-aliases' => "'''{{PLURAL:$2|Alias|Aliases}}''': $1",
 998+ 'validator-describe-parserfunction' => 'Implementate solmente como function del analysator syntactic.',
 999+ 'validator-describe-tagextension' => 'Implementate solmente como extension de etiquetta.',
 1000+ 'validator-describe-bothhooks' => 'Implementate como function del analysator syntactic e como extension de etiquetta.',
 1001+ 'validator-describe-par-hooks' => 'Le uncinos del analysator syntactic pro le quales presentar documentation.',
 1002+ 'validator-describe-par-pre' => 'Permitte obtener le ver wikitexto pro le documentation, sin render lo in le pagina.',
 1003+ 'validator-describe-listtype' => 'Lista de $1 elementos',
 1004+ 'validator-describe-empty' => 'vacue',
 1005+ 'validator-describe-required' => 'requirite',
 1006+ 'validator-describe-header-parameter' => 'Parametro',
 1007+ 'validator-describe-header-aliases' => 'Aliases',
 1008+ 'validator-describe-header-type' => 'Typo',
 1009+ 'validator-describe-header-default' => 'Predefinition',
 1010+ 'validator-describe-header-description' => 'Description',
 1011+ 'validator-describe-parameters' => 'Parametros',
 1012+ 'validator-describe-syntax' => 'Syntaxe',
 1013+ 'validator-describe-tagmin' => 'Extension de etiquetta con solmente le parametros obligatori.',
 1014+ 'validator-describe-tagmax' => 'Extension de etiquetta con tote le parametros.',
 1015+ 'validator-describe-tagdefault' => 'Extension de etiquetta con tote le parametros usante le notation predefinite de parametros.',
 1016+ 'validator-describe-pfmin' => 'Function analysator con solmente le parametros obligatori.',
 1017+ 'validator-describe-pfmax' => 'Function analysator con tote le parametros.',
 1018+ 'validator-describe-pfdefault' => 'Function analysator con tote le parametros usante le notation predefinite de parametros.',
 1019+ 'validator-describe-autogen' => 'Le contento de iste section esseva auto-generate per le uncino analysator "describe" del extension Validator.',
 1020+ 'validator_error_empty_argument' => 'Le parametro $1 non pote haber un valor vacue.',
 1021+ 'validator_error_must_be_number' => 'Le parametro $1 pote solmente esser un numero.',
 1022+ 'validator_error_must_be_integer' => 'Le parametro $1 pote solmente esser un numero integre.',
 1023+ 'validator-error-must-be-float' => 'Le parametro $1 pote solmente esser un numero con fraction decimal.',
 1024+ 'validator_error_invalid_range' => 'Le parametro $1 debe esser inter $2 e $3.',
 1025+ 'validator-error-invalid-regex' => 'Le parametro $1 debe corresponder a iste expression regular: $2.',
 1026+ 'validator-error-invalid-length' => 'Le parametro $1 debe haber un longitude de $2.',
 1027+ 'validator-error-invalid-length-range' => 'Le parametro $1 debe haber un longitude inter $2 e $3.',
 1028+ 'validator_error_invalid_argument' => 'Le valor $1 non es valide pro le parametro $2.',
 1029+ 'validator_list_error_empty_argument' => 'Le parametro $1 non accepta valores vacue.',
 1030+ 'validator_list_error_must_be_number' => 'Le parametro $1 pote solmente continer numeros.',
 1031+ 'validator_list_error_must_be_integer' => 'Le parametro $1 pote solmente continer numeros integre.',
 1032+ 'validator-list-error-must-be-float' => 'Le parametro $1 pote solmente continer numeros a comma flottante.',
 1033+ 'validator_list_error_invalid_range' => 'Tote le valores del parametro $1 debe esser inter $2 e $3.',
 1034+ 'validator-list-error-invalid-regex' => 'Tote le valores del parametro $1 debe corresponder a iste expression regular: $2.',
 1035+ 'validator_list_error_invalid_argument' => 'Un o plus valores pro le parametro $1 es invalide.',
 1036+ 'validator-list-error-accepts-only' => 'Un o plus valores del parametro $1 es invalide.
 1037+Illo accepta solmente iste {{PLURAL:$3|valor|valores}}: $2.',
 1038+ 'validator-list-error-accepts-only-omitted' => 'Un o plus valores del parametro $1 es invalide.
 1039+Illo accepta solmente iste {{PLURAL:$3|valor|valores}}: $2. (e $4 {{PLURAL:$4|valor|valores}} omittite).',
 1040+ 'validator_error_accepts_only' => 'Le valor "$4" non es valide pro le parametro $1. Illo accepta solmente iste {{PLURAL:$3|valor|valores}}: $2.',
 1041+ 'validator-error-accepts-only-omitted' => 'Le valor "$2" non es valide pro le parametro $1.
 1042+Illo accepta solmente iste {{PLURAL:$5|valor|valores}}: $3 (e $4 {{PLURAL:$4|valor|valores}} omittite).',
 1043+ 'validator_list_omitted' => 'Le {{PLURAL:$2|valor|valores}} $1 ha essite omittite.',
 1044+);
 1045+
 1046+/** Indonesian (Bahasa Indonesia)
 1047+ * @author Bennylin
 1048+ * @author Farras
 1049+ * @author Irwangatot
 1050+ * @author IvanLanin
 1051+ */
 1052+$messages['id'] = array(
 1053+ 'validator-desc' => 'Validator memberikan cara mudah untuk ekstensi lain untuk memvalidasi parameter ParserFunction dan ekstensi tag, mengatur nilai biasa dan membuat pesan kesalahan',
 1054+ 'validator-warning' => 'Peringatan: $1',
 1055+ 'validator-error' => 'Kesalahan: $1',
 1056+ 'validator-fatal-error' => 'Kesalahan fatal: $1',
 1057+ 'validator_error_parameters' => '{{PLURAL:$1|Kesalahan|Kesalahan}} berikut telah terdeteksi pada sintaksis Anda:',
 1058+ 'validator_warning_parameters' => '{{PLURAL:$1|kesalahan|kesalahan}} ini pada sintaks anda.',
 1059+ 'validator-warning-adittional-errors' => '... dan {{PLURAL:$1|satu|banyak}} masalah lain.',
 1060+ 'validator-error-omitted' => 'Nilai {{PLURAL:$2|"$1"|"$1"}} telah diabaikan.',
 1061+ 'validator-error-problem' => 'Ada masalah dengan parameter $1.',
 1062+ 'validator_error_unknown_argument' => '$1 bukan parameter yang benar.',
 1063+ 'validator_error_required_missing' => 'Parameter $1 yang diperlukan tidak diberikan.',
 1064+ 'validator-error-override-argument' => 'Mencoba menimpa parameter $1 (nilai: $2) dengan nilai "$3"',
 1065+ 'validator-type-string' => 'teks',
 1066+ 'validator-type-number' => 'nomor',
 1067+ 'validator-type-integer' => 'bilangan bulat',
 1068+ 'validator-type-float' => 'nomor',
 1069+ 'validator-type-boolean' => 'ya/tidak',
 1070+ 'validator-type-char' => 'karakter',
 1071+ 'validator-listerrors-errors' => 'Kesalahan',
 1072+ 'validator-listerrors-minor' => 'Kecil',
 1073+ 'validator-listerrors-low' => 'Rendah',
 1074+ 'validator-listerrors-normal' => 'Normal',
 1075+ 'validator-listerrors-high' => 'Tinggi',
 1076+ 'validator-listerrors-fatal' => 'Fatal',
 1077+ 'validator-listerrors-description' => 'Daftar galat (dan peringatan) yang terjadi pada pengait parser yang ditambahkan melalui Validator.
 1078+Hanya daftar untuk pengait parser yang ditambahkan di atas bagian tempat listerrors disisipkan;
 1079+tempatkan listerrors pada atau di dekat bagian bawah halaman untuk mendapatkan semua kesalahan.',
 1080+ 'validator-listerrors-par-minseverity' => 'Tingkat keparahan minimum masalah yang didaftarkan.',
 1081+ 'validator-describe-description' => 'Menghasilkan dokumentasi untuk satu atau beberapa pengait parser yang didefinisikan melalui Validator.',
 1082+ 'validator-describe-notfound' => 'Tidak ada pengait parser yang menangani "$1".',
 1083+ 'validator-describe-descriptionmsg' => "'''Deskripsi''': $1",
 1084+ 'validator-describe-aliases' => "'''{{PLURAL:$2|Alias|Alias}}''': $1",
 1085+ 'validator-describe-parserfunction' => 'Diterapkan hanya sebagai fungsi parser.',
 1086+ 'validator-describe-tagextension' => 'Diterapkan hanya sebagai ekstensi tag.',
 1087+ 'validator-describe-bothhooks' => 'Diterapkan sebagai fungsi parser dan ekstensi tag.',
 1088+ 'validator-describe-par-hooks' => 'Pengait parser untuk menampilkan dokumentasi.',
 1089+ 'validator-describe-par-pre' => 'Memungkinkan Anda mengambil tekswiki aktual untuk dokumentasi, tanpa ditampilkan pada halaman.',
 1090+ 'validator-describe-listtype' => 'Daftar $1 butir',
 1091+ 'validator-describe-empty' => 'kosong',
 1092+ 'validator-describe-required' => 'wajib diisi',
 1093+ 'validator-describe-header-parameter' => 'Parameter',
 1094+ 'validator-describe-header-aliases' => 'Alias',
 1095+ 'validator-describe-header-type' => 'Jenis',
 1096+ 'validator-describe-header-default' => 'Bawaan',
 1097+ 'validator-describe-header-description' => 'Deskripsi',
 1098+ 'validator-describe-parameters' => 'Parameter',
 1099+ 'validator-describe-syntax' => 'Sintaksis',
 1100+ 'validator-describe-tagmin' => 'Ekstensi tag hanya dengan parameter wajib.',
 1101+ 'validator-describe-tagmax' => 'Ekstensi tag dengan semua parameter.',
 1102+ 'validator-describe-tagdefault' => 'Ekstensi tag dengan semua parameter menggunakan notasi parameter bawaan.',
 1103+ 'validator-describe-pfmin' => 'Fungsi parser hanya dengan parameter wajib.',
 1104+ 'validator-describe-pfmax' => 'Fungsi parser dengan semua parameter.',
 1105+ 'validator-describe-pfdefault' => 'Fungsi parser dengan semua parameter menggunakan notasi parameter bawaan.',
 1106+ 'validator-describe-autogen' => 'Isi bagian ini adalah dihasilkan otomatis oleh pengait parser "describe" dari ekstensi Validator.',
 1107+ 'validator_error_empty_argument' => 'Parameter $1 tidak dapat bernilai kosong.',
 1108+ 'validator_error_must_be_number' => 'Parameter $1 hanya dapat berupa angka.',
 1109+ 'validator_error_must_be_integer' => 'Parameter $1 hanya dapat berupa integer.',
 1110+ 'validator-error-must-be-float' => 'Parameter $1 hanya dapat berupa angka titik kambang.',
 1111+ 'validator_error_invalid_range' => 'Parameter $1 harus antara $2 dan $3.',
 1112+ 'validator-error-invalid-regex' => 'Parameter $1 harus sesuai dengan persamaan reguler: $2.',
 1113+ 'validator-error-invalid-length' => 'Parameter $1 harus memiliki panjang $2.',
 1114+ 'validator-error-invalid-length-range' => 'Parameter $1 harus memiliki panjang antara $2 dan $3.',
 1115+ 'validator_error_invalid_argument' => 'Nilai $1 tidak valid untuk parameter $2.',
 1116+ 'validator_list_error_empty_argument' => 'Parameter $1 tidak menerima nilai kosong.',
 1117+ 'validator_list_error_must_be_number' => 'Parameter $1 hanya dapat berisi angka.',
 1118+ 'validator_list_error_must_be_integer' => 'Parameter $1 hanya dapat berisi bilangan bulat.',
 1119+ 'validator-list-error-must-be-float' => 'Parameter $1 hanya dapat berisi angka kambang.',
 1120+ 'validator_list_error_invalid_range' => 'Semua nilai parameter $1 harus antara $2 dan $3.',
 1121+ 'validator-list-error-invalid-regex' => 'Semua nilai parameter $1 harus sesuai dengan persamaan reguler: $2.',
 1122+ 'validator_list_error_invalid_argument' => 'Satu nilai atau lebih untuk parameter $1 tidak sah.',
 1123+ 'validator-list-error-accepts-only' => 'Satu atau lebih nilai untuk parameter $1 tidak sah. Parameter itu hanya menerima {{PLURAL:$3|nilai berikut|nilai berikut}}: $2.',
 1124+ 'validator-list-error-accepts-only-omitted' => 'Satu atau lebih nilai untuk parameter $1 tidak sah. Parameter itu hanya menerima {{PLURAL:$3|nilai berikut|nilai berikut}}: $2 (dan $4 {{PLURAL:$4|nilai|nilai}} yang diabaikan).',
 1125+ 'validator_error_accepts_only' => 'Nilai "$4" tidak sah untuk parameter $1. Nilai yang diterima hanyalah {{PLURAL:$3|nilai ini|nilai-nilai ini}}: $2.',
 1126+ 'validator-error-accepts-only-omitted' => 'Nilai "$2" tidak sah untuk parameter $1. Parameter itu hanya menerima {{PLURAL:$5|nilai berikut|nilai berikut}}: $3 (dan $4 {{PLURAL:$4|nilai|nilai}} yang diabaikan).',
 1127+ 'validator_list_omitted' => '{{PLURAL:$2|Nilai|Nilai}} $1 {{PLURAL:$2|telah|telah}} dihapus.',
 1128+);
 1129+
 1130+/** Italian (Italiano)
 1131+ * @author Civvì
 1132+ * @author HalphaZ
 1133+ */
 1134+$messages['it'] = array(
 1135+ 'validator-desc' => 'Validator fornisce ad altre estensiono un modo semplice per la convalida dei parametri delle funzioni parser e dei tag introdotti, per impostare i valori di default e per generare messaggi di errore.',
 1136+ 'validator_error_parameters' => 'Nella tua sintassi {{PLURAL:$1|è stato individuato il seguente errore|sono stati individuati i seguenti errori}}:',
 1137+ 'validator_warning_parameters' => "Nella tua sintassi {{PLURAL:$1|c'è un errore|ci sono errori}}.",
 1138+ 'validator_error_unknown_argument' => '$1 non è un parametro valido.',
 1139+ 'validator_error_required_missing' => 'Il parametro richiesto $1 non è stato fornito.',
 1140+ 'validator_error_empty_argument' => 'Il parametro $1 non può avere un valore vuoto.',
 1141+ 'validator_error_must_be_number' => 'Il parametro $1 può essere solo un numero.',
 1142+ 'validator_error_must_be_integer' => 'Il parametro $1 può essere solo un intero.',
 1143+ 'validator_error_invalid_range' => 'Il parametro $1 deve essere compreso tra $2 e $3.',
 1144+ 'validator_error_invalid_argument' => 'Il valore $1 non è valido per il parametro $2.',
 1145+ 'validator_list_error_empty_argument' => 'Il parametro $1 non accetta valori vuoti.',
 1146+ 'validator_list_error_must_be_number' => 'Il parametro $1 può contenere solo numeri.',
 1147+ 'validator_list_error_must_be_integer' => 'Il parametro $1 può contenere solo numeri interi.',
 1148+ 'validator_list_error_invalid_range' => 'Tutti i valori del parametro $1 devono essere compresi tra $2 e $3.',
 1149+ 'validator_list_error_invalid_argument' => 'Uno o più valori del parametro $1 non sono validi.',
 1150+ 'validator_error_accepts_only' => 'Il parametro $1 accetta solo {{PLURAL:$3|questo valore|questi valori}}: $2.',
 1151+ 'validator_list_omitted' => '{{PLURAL:$2|Il valore|I valori}} $1 {{PLURAL:$2|è stato omesso|sono stati omessi}}.',
 1152+);
 1153+
 1154+/** Japanese (日本語)
 1155+ * @author Aotake
 1156+ * @author Fryed-peach
 1157+ * @author Marine-Blue
 1158+ * @author Whym
 1159+ * @author Yanajin66
 1160+ */
 1161+$messages['ja'] = array(
 1162+ 'validator-desc' => '妥当性評価器は他の拡張機能にパーサー関数やタグ拡張の引数の妥当性を確認したり、規定値を設定したり、エラーメッセージを生成する手段を提供する',
 1163+ 'validator-warning' => '警告: $1',
 1164+ 'validator-error' => 'エラー: $1',
 1165+ 'validator-fatal-error' => '致命的なエラー: $1',
 1166+ 'validator_error_parameters' => 'あなたの入力から以下の{{PLURAL:$1|エラー|エラー}}が検出されました:',
 1167+ 'validator_warning_parameters' => 'あなたの入力した構文には{{PLURAL:$1|エラー}}があります。',
 1168+ 'validator-warning-adittional-errors' => '...と{{PLURAL:$1|他の問題}}。',
 1169+ 'validator-error-omitted' => '{{PLURAL:$2|$1 個の値}}が省略されました。',
 1170+ 'validator-error-problem' => 'パラメータ $1 に問題が見つかりました。',
 1171+ 'validator_error_unknown_argument' => '$1 は有効な引数ではありません。',
 1172+ 'validator_error_required_missing' => '必須の引数「$1」が入力されていません。',
 1173+ 'validator-error-override-argument' => '値"$3"とともにパラメータ$1 (値: $2)を無視してみてください',
 1174+ 'validator-listerrors-errors' => 'エラー',
 1175+ 'validator-listerrors-minor' => '非常に軽度',
 1176+ 'validator-listerrors-low' => '軽度',
 1177+ 'validator-listerrors-normal' => '普通',
 1178+ 'validator-listerrors-high' => '重大',
 1179+ 'validator-listerrors-fatal' => '非常に重大',
 1180+ 'validator_error_empty_argument' => '引数「$1」は空の値をとることができません。',
 1181+ 'validator_error_must_be_number' => '引数「$1」は数値でなければなりません。',
 1182+ 'validator_error_must_be_integer' => '引数「$1」は整数でなければなりません。',
 1183+ 'validator-error-must-be-float' => 'パラメータ$1は浮動小数点数になることだけができます。',
 1184+ 'validator_error_invalid_range' => '引数「$1」は $2 と $3 の間の値でなければなりません。',
 1185+ 'validator-error-invalid-regex' => 'パラメータ $1 は次の正規表現と一致する必要があります: $2',
 1186+ 'validator-error-invalid-length' => 'パラメータ$1は$2の長さを保持していなければならない。',
 1187+ 'validator-error-invalid-length-range' => 'パラメータ$1は$2と$3間の長さを保持していなければならない。',
 1188+ 'validator_error_invalid_argument' => '値「$1」は引数「$2」として妥当ではありません。',
 1189+ 'validator_list_error_empty_argument' => '引数「$1」は空の値をとりません。',
 1190+ 'validator_list_error_must_be_number' => '引数「$1」は数値しかとることができません。',
 1191+ 'validator_list_error_must_be_integer' => '引数「$1」は整数値しかとることができません。',
 1192+ 'validator-list-error-must-be-float' => 'パラメータ $1 は整数値しか利用できません。',
 1193+ 'validator_list_error_invalid_range' => '引数「$1」の値はすべて $2 と $3 の間のものでなくてはなりません。',
 1194+ 'validator-list-error-invalid-regex' => 'パラメータ $1 の値は次の正規表現と一致する必要があります: $2',
 1195+ 'validator_list_error_invalid_argument' => '引数「$1」の値に不正なものが1つ以上あります。',
 1196+ 'validator-list-error-accepts-only' => 'パラメータ $1 に無効な値が含まれています。
 1197+このパラメータは{{PLURAL:$3|次の値}}しか利用できません: $2',
 1198+ 'validator-list-error-accepts-only-omitted' => 'パラメータ $1 に無効な値が含まれています。
 1199+このパラメータは{{PLURAL:$3|次の値}}しか利用できません: $2 (と省略された $4 の値)',
 1200+ 'validator_error_accepts_only' => '値"$4"はパラメーター$1にとって有効ではありません。{{PLURAL:$3|この値|これらの値}}のみ受け入れられます。: $2。',
 1201+ 'validator-error-accepts-only-omitted' => 'パラメータ $1 の値 "$2" は有効ではありません。
 1202+このパラメータは{{PLURAL:$5|次の値}}しか利用できません: $3 (と省略された $4 の値)',
 1203+ 'validator_list_omitted' => '{{PLURAL:$2|値}} $1 は省かれました。',
 1204+);
 1205+
 1206+/** Colognian (Ripoarisch)
 1207+ * @author Purodha
 1208+ */
 1209+$messages['ksh'] = array(
 1210+ 'validator-desc' => '{{int:validator_name}} brängk eine eijfache Wääsch, der Parrammeetere fun Paaser-Fungkßjohne un Zohsatzprojramme ze prööve, Schtandatt-Wääte enzefööje, un Fähler ze mällde.',
 1211+ 'validator_error_parameters' => '{{PLURAL:$1|Heh dä|Heh di|Keine}} Fähler {{PLURAL:$1|es|sin|es}} en Dinge Syntax opjevalle:',
 1212+ 'validator_error_unknown_argument' => '„$1“ es keine jöltijje Parameeter.',
 1213+ 'validator_error_required_missing' => 'Dä Parameeter $1 moß aanjejovve sin, un fählt.',
 1214+ 'validator_error_empty_argument' => 'Dä Parameeter $1 kann keine Wäät met nix dren hann.',
 1215+ 'validator_error_must_be_number' => 'Dä Parameeter $1 kann blohß en Zahl sin.',
 1216+ 'validator_error_must_be_integer' => 'Dä Parrameeter $1 kann bloß en jannze Zahl sin.',
 1217+ 'validator_error_invalid_range' => 'Dä Parameeter $1 moß zwesche $2 un $3 sin.',
 1218+ 'validator_error_invalid_argument' => 'Däm Parameeter $2 singe Wäät es $1, dat es ävver doför nit jöltesch.',
 1219+ 'validator_error_accepts_only' => '„$4“ es nit ze Bruche, weil dä Parameeter $1 {{PLURAL:$3|bloß eine Wäät|bloß eine vun heh dä Wääte|keine Wäät}} han kann: $2',
 1220+);
 1221+
 1222+/** Luxembourgish (Lëtzebuergesch)
 1223+ * @author Les Meloures
 1224+ * @author Robby
 1225+ */
 1226+$messages['lb'] = array(
 1227+ 'validator-desc' => 'Validator erlaabt et op eng einfach Manéier fir Parametere vu Parser-Fonctiounen an Tag-Erweiderungen ze validéieren, fir Standard-Wäerter festzeleeën a fir Feeler-Messagen ze generéieren',
 1228+ 'validator-warning' => 'Opgepasst: $1',
 1229+ 'validator-error' => 'Feeler: $1',
 1230+ 'validator-fatal-error' => 'Fatale Feeler: $1',
 1231+ 'validator_error_parameters' => '{{PLURAL:$1|Dëse Feeler gouf|Dës Feeler goufen}} an Ärer Syntax fonnt:',
 1232+ 'validator_warning_parameters' => 'Et {{PLURAL:$1|ass ee|si}} Feeler an Ärer Syntax.',
 1233+ 'validator-error-omitted' => '{{PLURAL:$2|De Wäert|D\'Wäerter}} "$1" {{PLURAL:$2|gouf|goufe}} vergiess.',
 1234+ 'validator-error-problem' => 'Et gouf e Problem mam Parameter $1.',
 1235+ 'validator_error_unknown_argument' => '$1 ass kee valbele Parameter.',
 1236+ 'validator_error_required_missing' => 'Den obligatoresche Parameter $1 war net derbäi.',
 1237+ 'validator-error-override-argument' => 'huet versicht de Parameter $1 (Wäert: $2) mam Wäert "$3" z\'iwwerschreiwen',
 1238+ 'validator-type-string' => 'Text',
 1239+ 'validator-type-number' => 'Zuel',
 1240+ 'validator-type-integer' => 'Ganz Zuel',
 1241+ 'validator-type-float' => 'Zuel',
 1242+ 'validator-type-boolean' => 'Jo/Neen',
 1243+ 'validator-type-char' => 'Zeechen',
 1244+ 'validator-listerrors-errors' => 'Feeler',
 1245+ 'validator-listerrors-minor' => 'Marginal',
 1246+ 'validator-listerrors-low' => 'Niddreg',
 1247+ 'validator-listerrors-normal' => 'Normal',
 1248+ 'validator-listerrors-high' => 'Héich',
 1249+ 'validator-listerrors-fatal' => 'Fatal',
 1250+ 'validator-describe-descriptionmsg' => "'''Beschreiwung''': $1",
 1251+ 'validator-describe-empty' => 'eidel',
 1252+ 'validator-describe-required' => 'obligatoresch',
 1253+ 'validator-describe-header-parameter' => 'Parameter',
 1254+ 'validator-describe-header-type' => 'Typ',
 1255+ 'validator-describe-header-default' => 'Standard',
 1256+ 'validator-describe-header-description' => 'Beschreiwung',
 1257+ 'validator-describe-parameters' => 'Parameteren',
 1258+ 'validator-describe-syntax' => 'Syntax',
 1259+ 'validator_error_empty_argument' => 'De Parameter $1 ka keen eidele Wäert hunn.',
 1260+ 'validator_error_must_be_number' => 'De Parameter $1 ka just eng Zuel sinn',
 1261+ 'validator_error_must_be_integer' => 'De Parameter $1 ka just eng ganz Zuel sinn.',
 1262+ 'validator-error-must-be-float' => 'Parameter $1 kann nëmmen eng Féisskommazuel sinn.',
 1263+ 'validator_error_invalid_range' => 'De Parameter $1 muss tëschent $2 an $3 leien.',
 1264+ 'validator-error-invalid-regex' => 'De Parameter $1 muss esou ausgesinn: $2',
 1265+ 'validator-error-invalid-length' => 'Parameter $1 muss eng Längt vu(n) $2 hunn.',
 1266+ 'validator-error-invalid-length-range' => 'De Parameter $1 muss eng Längt tëschent $2 an $3 hunn.',
 1267+ 'validator_error_invalid_argument' => 'De Wäert $1 ass net valabel fir de Parameter $2.',
 1268+ 'validator_list_error_empty_argument' => 'De Parameter $1 hëlt keng eidel Wäerter un.',
 1269+ 'validator_list_error_must_be_number' => 'Am Parameter $1 kënnen nëmmen Zuelen dra sinn.',
 1270+ 'validator_list_error_must_be_integer' => 'Am Parameter $1 kënnen nëmme ganz Zuele sinn.',
 1271+ 'validator-list-error-must-be-float' => 'Am Parameter $1 kënnen nëmme Kommazuelen dra sinn.',
 1272+ 'validator_list_error_invalid_range' => 'All Wäerter vum Parameter $1 mussen tëschent $2 an $3 leien.',
 1273+ 'validator-list-error-invalid-regex' => 'All Wäerter vum Parameter $1 mussen dësem regulären Ausdrock entspriechen: $2',
 1274+ 'validator_list_error_invalid_argument' => 'Een oder méi Wäerter fir de Parameter $1 sinn net valabel.',
 1275+ 'validator-list-error-accepts-only' => 'Een oder méi Wäerter vum Parameter $1 sinn net valabel.
 1276+En akzeptéiert nëmmen {{PLURAL:$3|dëse Wäert|dës Wäerter}}: $2.',
 1277+ 'validator_error_accepts_only' => 'De Wäert $4 ass net valabel fir de Parameter $1. En akzeptéiert just {{PLURAL:$3|dëse Wäert|dës Wäerter}}: $2',
 1278+ 'validator-error-accepts-only-omitted' => 'De Wäert "$2" ass net valabel fir de Parameter $1.
 1279+En akzeptéiert nëmmen {{PLURAL:$5|dëse Wäert|dës Wäerter}}: $3 (an {{PLURAL:$4|een ausgeloossene Wäert|$4 ausgeloosse Wäerter}}).',
 1280+ 'validator_list_omitted' => "{{PLURAL:$2|De Wäert|D'Wäerter}} $1 {{PLURAL:$2|gouf|goufe}} vergiess.",
 1281+);
 1282+
 1283+/** Macedonian (Македонски)
 1284+ * @author Bjankuloski06
 1285+ * @author McDutchie
 1286+ */
 1287+$messages['mk'] = array(
 1288+ 'validator-desc' => 'Потврдувачот овозможува лесен начин другите додатоци да ги потврдат параметрите на парсерските функции и додатоците со ознаки, да поставаат основно зададени вредности и да создаваат пораки за грешки',
 1289+ 'validator-warning' => 'Предупредување: $1',
 1290+ 'validator-error' => 'Грешка: $1',
 1291+ 'validator-fatal-error' => 'Фатална грешка: $1',
 1292+ 'validator_error_parameters' => 'Во вашата синтакса {{PLURAL:$1|е откриена следнава грешка|се откриени следниве грешки}}:',
 1293+ 'validator_warning_parameters' => 'Имате {{PLURAL:$1|грешка|грешки}} во синтаксата.',
 1294+ 'validator-warning-adittional-errors' => '... и {{PLURAL:$1|уште еден проблем|повеќе други проблеми}}.',
 1295+ 'validator-error-omitted' => '{{PLURAL:$2|Изоставена е вредноста „$1“|Изоставени се вредностите „$1“}}.',
 1296+ 'validator-error-problem' => 'Се појави проблем со параметарот $1.',
 1297+ 'validator_error_unknown_argument' => '$1 не е важечки параметар.',
 1298+ 'validator_error_required_missing' => 'Бараниот параметар $1 не е наведен.',
 1299+ 'validator-error-override-argument' => 'Се обидовте да презапишете врз параметарот $1 (вредност: $2) со вредност „$3“',
 1300+ 'validator-type-string' => 'текст',
 1301+ 'validator-type-number' => 'број',
 1302+ 'validator-type-integer' => 'цел број',
 1303+ 'validator-type-float' => 'број',
 1304+ 'validator-type-boolean' => 'да/не',
 1305+ 'validator-type-char' => 'знак',
 1306+ 'validator-listerrors-errors' => 'Грешки',
 1307+ 'validator-listerrors-minor' => 'Ситни',
 1308+ 'validator-listerrors-low' => 'Малку',
 1309+ 'validator-listerrors-normal' => 'Нормално',
 1310+ 'validator-listerrors-high' => 'Многу',
 1311+ 'validator-listerrors-fatal' => 'Фатални',
 1312+ 'validator-listerrors-description' => 'Ги наведува грешките (и предупредувањата) што се јавиле кај парсерските куки додадени преки Потврдувачот (Validator).
 1313+Ги наведува само парсерските куки додадени погоре каде е вметнато „listerrors“;
 1314+ставете го „listerrors“ на или близу дното на страницата за да ви се прикажат сите грешки.',
 1315+ 'validator-listerrors-par-minseverity' => 'Минималната сериозност на проблемот за да биде наведен.',
 1316+ 'validator-describe-description' => 'Создава документација за една или повеќе парсерски куки определени преку Потврдувачот.',
 1317+ 'validator-describe-notfound' => 'Нема парсерска кука што работи со „$1“.',
 1318+ 'validator-describe-descriptionmsg' => "'''Опис''': $1",
 1319+ 'validator-describe-aliases' => "'''{{PLURAL:$2|Алијас|Алијаси}}''': $1",
 1320+ 'validator-describe-parserfunction' => 'Се применува само во својство на парсерска функција.',
 1321+ 'validator-describe-tagextension' => 'Се применува само во својство на додаток за означување.',
 1322+ 'validator-describe-bothhooks' => 'Се применува во својство на парсерска функција и додаток за означување (обете).',
 1323+ 'validator-describe-par-hooks' => 'Парсерските куки за кои сакате да се прикаже документација.',
 1324+ 'validator-describe-par-pre' => 'Ви овозможува да го добиете самиот викитекст за документацијата, без да се испише на страницата',
 1325+ 'validator-describe-listtype' => 'Список на $1 ставки',
 1326+ 'validator-describe-empty' => 'празно',
 1327+ 'validator-describe-required' => 'задолжително',
 1328+ 'validator-describe-header-parameter' => 'Параметар',
 1329+ 'validator-describe-header-aliases' => 'Алијаси',
 1330+ 'validator-describe-header-type' => 'Вид',
 1331+ 'validator-describe-header-default' => 'По основно',
 1332+ 'validator-describe-header-description' => 'Опис',
 1333+ 'validator-describe-parameters' => 'Параметри',
 1334+ 'validator-describe-syntax' => 'Синтакса',
 1335+ 'validator-describe-tagmin' => 'Додаток за означување само со задолжителните параметри.',
 1336+ 'validator-describe-tagmax' => 'Додаток за означување со сите параметри.',
 1337+ 'validator-describe-tagdefault' => 'Додаток за означување кајшто сите параметри ја користат стандардната параметарска нотација.',
 1338+ 'validator-describe-pfmin' => 'Парсерска функција само со задолжителните параметри.',
 1339+ 'validator-describe-pfmax' => 'Парсерска функција со сите параметри.',
 1340+ 'validator-describe-pfdefault' => 'Парсерска функција кајшто сите параметри ја користат стандардната параметарска нотација.',
 1341+ 'validator-describe-autogen' => 'Содржината на овој поднаслов е создадена автоматски од парсерската кука „describe“ на додатокот Потврдувач (Validator).',
 1342+ 'validator_error_empty_argument' => 'Параметарот $1 не може да има празна вредност.',
 1343+ 'validator_error_must_be_number' => 'Параметарот $1 може да биде само број.',
 1344+ 'validator_error_must_be_integer' => 'Параметарот $1 може да биде само цел број.',
 1345+ 'validator-error-must-be-float' => 'Параметарот $1 може да биде само број со подвижна точка.',
 1346+ 'validator_error_invalid_range' => 'Параметарот $1 мора да изнесува помеѓу $2 и $3.',
 1347+ 'validator-error-invalid-regex' => 'Параметарот $1 мора да се совпаѓа со следниов регуларен израз: $2.',
 1348+ 'validator-error-invalid-length' => 'Параметарот $1 мора да има должина од $2.',
 1349+ 'validator-error-invalid-length-range' => 'Должината на параметарот параметарот $1 мора да изнесува помеѓу $2 и $3.',
 1350+ 'validator_error_invalid_argument' => 'Вредноста $1 е неважечка за параметарот $2.',
 1351+ 'validator_list_error_empty_argument' => 'Параметарот $1 не прифаќа празни вредности.',
 1352+ 'validator_list_error_must_be_number' => 'Параметарот $1 може да содржи само бројки.',
 1353+ 'validator_list_error_must_be_integer' => 'Параметарот $1 може да содржи само цели броеви.',
 1354+ 'validator-list-error-must-be-float' => 'Параметарот $1 може да содржи само подвижни бинарни точки.',
 1355+ 'validator_list_error_invalid_range' => 'Сите вредности на параметарот $1 мора да бидат помеѓу $2 и $3.',
 1356+ 'validator-list-error-invalid-regex' => 'Сите вредности на параметарот $1 мора да се совпаднат со следниов регуларен израз: $2.',
 1357+ 'validator_list_error_invalid_argument' => 'Една или повеќе вредности на параметарот $1 се неважечки.',
 1358+ 'validator-list-error-accepts-only' => 'Параметарот $1 има една или повеќе неважечки вредности.
 1359+Се {{PLURAL:$3|прифаќа само следнава вредност|прифаќаат само следниве вредности}}: $2.',
 1360+ 'validator-list-error-accepts-only-omitted' => 'Параметарот $1 има една или повеќе неважечки вредности.
 1361+Се {{PLURAL:$3|прифаќа само следнава вредност|прифаќаат само следниве вредности}}: $2 (и $4 {{PLURAL:$4|изоставена вредност|изоставени вредности}}).',
 1362+ 'validator_error_accepts_only' => 'Вредноста „$4“ е неважечка за параметарот $1. Се {{PLURAL:$3|прифаќа само следнава вредност|прифаќаат само следниве вредности}}: $2.',
 1363+ 'validator-error-accepts-only-omitted' => 'Вредноста „$2“ не е важечка за параметарот $1. Се прифаќаат само следниве вредности: $3 (и $4 изоставени вредности).',
 1364+ 'validator_list_omitted' => '{{PLURAL:$2|Вредноста|Вредностите}} $1 {{PLURAL:$2|беше испуштена|беа испуштени}}.',
 1365+);
 1366+
 1367+/** Dutch (Nederlands)
 1368+ * @author Jeroen De Dauw
 1369+ * @author Siebrand
 1370+ */
 1371+$messages['nl'] = array(
 1372+ 'validator-desc' => 'Validator geeft andere uitbreidingen de mogelijkheid om parameters van parserfuncties en taguitbreidingen te valideren, in te stellen op hun standaardwaarden en foutberichten te genereren',
 1373+ 'validator-warning' => 'Waarschuwing: $1',
 1374+ 'validator-error' => 'Fout: $1',
 1375+ 'validator-fatal-error' => 'Onherstelbare fout: $1',
 1376+ 'validator_error_parameters' => 'In uw syntaxis {{PLURAL:$1|is de volgende fout|zijn de volgende fouten}} gedetecteerd:',
 1377+ 'validator_warning_parameters' => 'Er {{PLURAL:$1|zit een fout|zitten $1 fouten}} in uw syntaxis.',
 1378+ 'validator-warning-adittional-errors' => '... en nog {{PLURAL:$1|een ander probleem|$1 andere problemen}}.',
 1379+ 'validator-error-omitted' => 'De {{PLURAL:$2|waarde "$1" mist|waarden "$1" missen}}.',
 1380+ 'validator-error-problem' => 'Er was een probleem met de parameter $1.',
 1381+ 'validator_error_unknown_argument' => '$1 is geen geldige parameter.',
 1382+ 'validator_error_required_missing' => 'De verplichte parameter $1 is niet opgegeven.',
 1383+ 'validator-error-override-argument' => 'Geprobeerd de parameter $1 (waarde: $2) te overschrijven met waarde "$3".',
 1384+ 'validator-type-string' => 'tekst',
 1385+ 'validator-type-number' => 'getal',
 1386+ 'validator-type-integer' => 'geheel getal',
 1387+ 'validator-type-float' => 'getal',
 1388+ 'validator-type-boolean' => 'ja / nee',
 1389+ 'validator-type-char' => 'teken',
 1390+ 'validator-listerrors-errors' => 'Fouten',
 1391+ 'validator-listerrors-minor' => 'Overkomelijk',
 1392+ 'validator-listerrors-low' => 'Laag',
 1393+ 'validator-listerrors-normal' => 'Gemiddeld',
 1394+ 'validator-listerrors-high' => 'Groot',
 1395+ 'validator-listerrors-fatal' => 'Fataal',
 1396+ 'validator-describe-descriptionmsg' => "'''Beschrijving''': $1",
 1397+ 'validator-describe-aliases' => "'''{{PLURAL:$2|Alias|Aliassen}}''': $1",
 1398+ 'validator-describe-parserfunction' => 'Alleen als parserfunctie geïmplementeerd.',
 1399+ 'validator-describe-tagextension' => 'Alleen als labeluitbreiding geïmplementeerd.',
 1400+ 'validator-describe-bothhooks' => 'Als parserfunctie en labeluitbreiding geïmplementeerd.',
 1401+ 'validator-describe-par-hooks' => 'Parserhooks waarvoor documentatie weergegeven moet worden.',
 1402+ 'validator-describe-par-pre' => 'Maakt het mogelijk de wikitekst voor de documentatie weer te geven zonder dat deze wordt verwerkt.',
 1403+ 'validator-describe-listtype' => 'Lijst met $1 items',
 1404+ 'validator-describe-empty' => 'leeg',
 1405+ 'validator-describe-required' => 'verplicht',
 1406+ 'validator-describe-header-parameter' => 'Parameter',
 1407+ 'validator-describe-header-aliases' => 'Aliassen',
 1408+ 'validator-describe-header-type' => 'Type',
 1409+ 'validator-describe-header-default' => 'Standaard',
 1410+ 'validator-describe-header-description' => 'Beschrijving',
 1411+ 'validator-describe-parameters' => 'Parameters',
 1412+ 'validator-describe-syntax' => 'Syntaxis',
 1413+ 'validator-describe-tagmin' => 'Labeluitbreiding met alleen de verplichte parameters.',
 1414+ 'validator-describe-tagmax' => 'Labeluitbreiding met alle parameters.',
 1415+ 'validator-describe-tagdefault' => 'Labeluitbreiding met alle parameters die de standaard parameternotatie gebruiken.',
 1416+ 'validator-describe-pfmin' => 'Parserfunctie met alleen de verplichte parameters.',
 1417+ 'validator-describe-pfmax' => 'Parserfunctie met alle parameters.',
 1418+ 'validator-describe-pfdefault' => 'Parserfunctie met alle parameters die de standaard parameternotatie gebruiken.',
 1419+ 'validator-describe-autogen' => 'De inhoud van deze paragraaf is automatisch aangemaakt door de parserhook "beschrijven" (describe) van de uitbreiding Validator.',
 1420+ 'validator_error_empty_argument' => 'De parameter $1 mag niet leeg zijn.',
 1421+ 'validator_error_must_be_number' => 'De parameter $1 mag alleen een getal zijn.',
 1422+ 'validator_error_must_be_integer' => 'De parameter $1 kan alleen een heel getal zijn.',
 1423+ 'validator-error-must-be-float' => 'Parameter $1 kan alleen een getal met decimalen zijn.',
 1424+ 'validator_error_invalid_range' => 'De parameter $1 moet tussen $2 en $3 liggen.',
 1425+ 'validator-error-invalid-regex' => 'De parameter $1 moet voldoen aan deze reguliere expressie: $2.',
 1426+ 'validator-error-invalid-length' => 'Parameter $1 moet een lengte hebben van $2.',
 1427+ 'validator-error-invalid-length-range' => 'Parameter $1 moet een lengte hebben tussen $2 en $3.',
 1428+ 'validator_error_invalid_argument' => 'De waarde $1 is niet geldig voor de parameter $2.',
 1429+ 'validator_list_error_empty_argument' => 'Voor de parameter $1 zijn lege waarden niet toegestaan.',
 1430+ 'validator_list_error_must_be_number' => 'Voor de parameter $1 zijn alleen getallen toegestaan.',
 1431+ 'validator_list_error_must_be_integer' => 'Voor de parameter $1 zijn alleen hele getallen toegestaan.',
 1432+ 'validator-list-error-must-be-float' => 'Voor de parameter $1 zijn alleen getallen met drijvende komma toegestaan.',
 1433+ 'validator_list_error_invalid_range' => 'Alle waarden voor de parameter $1 moeten tussen $2 en $3 liggen.',
 1434+ 'validator-list-error-invalid-regex' => 'Alle waarden voor de parameter $1 moeten voldoen aan deze reguliere expressie: $2.',
 1435+ 'validator_list_error_invalid_argument' => 'Een of meerdere waarden voor de parameter $1 zijn ongeldig.',
 1436+ 'validator-list-error-accepts-only' => 'Een of meer waarden voor de parameter $1 zijn ongeldig.
 1437+Alleen deze {{PLURAL:$3|waarde is|waarden zijn}} toegestaan: $2.',
 1438+ 'validator-list-error-accepts-only-omitted' => 'Een of meer waarden voor de parameter $1 zijn ongeldig.
 1439+Alleen deze {{PLURAL:$3|waarde is|waarden zijn}} toegestaan: $2.
 1440+Als ook $4 weggelaten {{PLURAL:$4|waarde|waarden}}.',
 1441+ 'validator_error_accepts_only' => 'De waarde "$4" is ongeldig voor parameter $1. Deze kan alleen de volgende {{PLURAL:$3|waarde|waarden}} hebben: $2.',
 1442+ 'validator-error-accepts-only-omitted' => 'De waarde "$2" is niet geldig voor de parameter $1.
 1443+Alleen deze {{PLURAL:$5|waarde is|waarden zijn}} toegestaan: $3.
 1444+Als ook $4 weggelaten {{PLURAL:$4|waarde|waarden}}.',
 1445+ 'validator_list_omitted' => 'De {{PLURAL:$2|waarde|waarden}} $1 {{PLURAL:$2|mist|missen}}.',
 1446+);
 1447+
 1448+/** Norwegian (bokmål)‬ (‪Norsk (bokmål)‬)
 1449+ * @author Jon Harald Søby
 1450+ * @author Nghtwlkr
 1451+ */
 1452+$messages['no'] = array(
 1453+ 'validator-desc' => 'Gir generisk støtte for parameterhåndtering for andre utvidelser',
 1454+ 'validator-warning' => 'Advarsel: $1',
 1455+ 'validator-error' => 'Feil: $1',
 1456+ 'validator-fatal-error' => 'Kritisk feil: $1',
 1457+ 'validator_error_parameters' => 'Følgende {{PLURAL:$1|feil|feil}} har blitt oppdaget i syntaksen din:',
 1458+ 'validator_warning_parameters' => 'Det er {{PLURAL:$1|én feil|flere feil}} i syntaksen din.',
 1459+ 'validator-warning-adittional-errors' => '... og {{PLURAL:$1|ett problem til|flere problem}}.',
 1460+ 'validator-error-omitted' => '{{PLURAL:$2|Verdien|Verdiene}} «$1» har blitt utelatt.',
 1461+ 'validator-error-problem' => 'Det var et problem med parameteren $1.',
 1462+ 'validator_error_unknown_argument' => '$1 er ikke en gyldig parameter.',
 1463+ 'validator_error_required_missing' => 'Den nødvendige parameteren «$1» er ikke angitt.',
 1464+ 'validator-error-override-argument' => 'Prøvde å overkjøre parameter $1 (verdi: $2) med verdien «$3»',
 1465+ 'validator-listerrors-errors' => 'Feil',
 1466+ 'validator-listerrors-minor' => 'Mindre',
 1467+ 'validator-listerrors-low' => 'Lav',
 1468+ 'validator-listerrors-normal' => 'Normal',
 1469+ 'validator-listerrors-high' => 'Høy',
 1470+ 'validator-listerrors-fatal' => 'Kritisk',
 1471+ 'validator_error_empty_argument' => 'Parameteren $1 kan ikke ha en tom verdi.',
 1472+ 'validator_error_must_be_number' => 'Parameteren $1 må være et tall.',
 1473+ 'validator_error_must_be_integer' => 'Parameteren $1 må være et heltall.',
 1474+ 'validator-error-must-be-float' => 'Parameter $1 må være et flyttall.',
 1475+ 'validator_error_invalid_range' => 'Parameter $1 må være mellom $2 og $3.',
 1476+ 'validator-error-invalid-regex' => 'Parameteren $1 må samsvare med dette regulære uttrykket: $2.',
 1477+ 'validator-error-invalid-length' => 'Parameter $1 må ha en lengde på $2.',
 1478+ 'validator-error-invalid-length-range' => 'Parameter $1 må ha en lengde mellom $2 og $3.',
 1479+ 'validator_error_invalid_argument' => 'Verdien $1 er ikke gyldig for parameter $2.',
 1480+ 'validator_list_error_empty_argument' => 'Parameteren $1 godtar ikke tomme verdier.',
 1481+ 'validator_list_error_must_be_number' => 'Parameteren $1 kan bare inneholde tall.',
 1482+ 'validator_list_error_must_be_integer' => 'Parameteren $1 kan bare inneholde heltall.',
 1483+ 'validator-list-error-must-be-float' => 'Parameteren $1 kan bare innholde flyttall.',
 1484+ 'validator_list_error_invalid_range' => 'Alle verdier av parameteren $1 må være mellom $2 og $3.',
 1485+ 'validator-list-error-invalid-regex' => 'Alle verdier av parameteren $1 må samsvare med dette regulære uttrykket: $2.',
 1486+ 'validator_list_error_invalid_argument' => 'Parameteren $1 har en eller flere ugyldige verdier.',
 1487+ 'validator-list-error-accepts-only' => 'En eller flere verdier for parameteren $1 er ugyldige.
 1488+Den godtar bare {{PLURAL:$3|denne verdien|disse verdiene}}: $2.',
 1489+ 'validator-list-error-accepts-only-omitted' => 'En eller flere verdier for parameteren $1 er ugyldige.
 1490+Den godtar bare {{PLURAL:$3|denne verdien|disse verdiene}}: $2 (og $4 {{PLURAL:$4|utelatt verdi|utelatte verdier}}).',
 1491+ 'validator_error_accepts_only' => 'Verdien «$4» er ikke gyldig for parameteren $1. Den aksepterer kun {{PLURAL:$3|denne verdien|disse verdiene}}: $2.',
 1492+ 'validator-error-accepts-only-omitted' => 'Verdien «$2» er ikke gyldig for parameteren $1.
 1493+Den godtar bare {{PLURAL:$5|denne verdien|disse verdiene}}: $3 (og $4 {{PLURAL:$4|utelatt verdi|utelatte verdier}}).',
 1494+ 'validator_list_omitted' => '{{PLURAL:$2|Verdien|Verdiene}} $1 har blitt utelatt.',
 1495+);
 1496+
 1497+/** Occitan (Occitan)
 1498+ * @author Cedric31
 1499+ * @author Jfblanc
 1500+ */
 1501+$messages['oc'] = array(
 1502+ 'validator-desc' => "Validator porgís a d'autras extensions un biais per validar aisidament los paramètres de foncions d'analisi e las extensions de mercas, definir de valors per manca e crear de messatges d'error",
 1503+ 'validator_error_parameters' => '{{PLURAL:$1|Aquela error es estada detectada|Aquelas errors son estadas detectadas}} dins la sintaxi',
 1504+ 'validator_error_unknown_argument' => '$1 es pas un paramètre valedor.',
 1505+ 'validator_error_required_missing' => "Manca lo paramètre $1 qu'es obligatòri.",
 1506+ 'validator_error_empty_argument' => 'Lo paramètre $1 pòt pas estar voide.',
 1507+ 'validator_error_must_be_number' => 'Lo paramètre $1 deu èsser un nombre.',
 1508+ 'validator_error_must_be_integer' => 'Lo paramètre $1 deu èsser un nombre entièr.',
 1509+ 'validator_error_invalid_range' => 'Lo paramètre $1 deu èsser entre $2 e $3.',
 1510+ 'validator_error_invalid_argument' => '$1 es pas valedor pel paramètre $2.',
 1511+ 'validator_error_accepts_only' => 'Sonque {{PLURAL:$3|aquela valor es valedora|aquelas valors son valedoras}}pel paramètre $1 : $2.',
 1512+);
 1513+
 1514+/** Polish (Polski)
 1515+ * @author Fizykaa
 1516+ * @author Sp5uhe
 1517+ */
 1518+$messages['pl'] = array(
 1519+ 'validator-desc' => 'Dostarcza innym rozszerzeniom ogólną obsługę parametrów',
 1520+ 'validator-warning' => 'Uwaga – $1',
 1521+ 'validator-error' => 'Błąd – $1',
 1522+ 'validator-fatal-error' => 'Błąd krytyczny – $1',
 1523+ 'validator_error_parameters' => 'W Twoim kodzie {{PLURAL:$1|został wykryty następujący błąd|zostały wykryte następujące błędy}} składni:',
 1524+ 'validator_warning_parameters' => 'W Twoim kodzie {{PLURAL:$1|wystąpił błąd|wystąpiły błędy}} składni.',
 1525+ 'validator-warning-adittional-errors' => '... i {{PLURAL:$1|jeszcze jeden problem|wiele więcej problemów}}.',
 1526+ 'validator-error-omitted' => '{{PLURAL:$2|Wartość „$1” została pominięta|Wartości „$1” zostały pominięte}}.',
 1527+ 'validator-error-problem' => 'Wystąpił problem z parametrem $1.',
 1528+ 'validator_error_unknown_argument' => '$1 jest niepoprawnym parametrem.',
 1529+ 'validator_error_required_missing' => 'Obowiązkowy parametr $1 nie został przekazany.',
 1530+ 'validator-error-override-argument' => 'Próba nadpisania parametru $1 o wartości „$2” nową wartością „$3”',
 1531+ 'validator-listerrors-errors' => 'Błędy',
 1532+ 'validator-listerrors-minor' => 'Nieistotny',
 1533+ 'validator-listerrors-low' => 'Mało istotny',
 1534+ 'validator-listerrors-normal' => 'Typowy',
 1535+ 'validator-listerrors-high' => 'Istotny',
 1536+ 'validator-listerrors-fatal' => 'Krytyczny',
 1537+ 'validator_error_empty_argument' => 'Parametr $1 nie może być pusty.',
 1538+ 'validator_error_must_be_number' => 'Parametr $1 musi być liczbą.',
 1539+ 'validator_error_must_be_integer' => 'Parametr $1 musi być liczbą całkowitą.',
 1540+ 'validator-error-must-be-float' => 'Parametr $1 musi być liczbą rzeczywistą.',
 1541+ 'validator_error_invalid_range' => 'Parametr $1 musi zawierać się w przedziale od $2 do $3.',
 1542+ 'validator-error-invalid-regex' => 'Parametr $1 musi pasować do wyrażenia regularnego $2.',
 1543+ 'validator-error-invalid-length' => 'Parametr $1 musi mieć długość $2.',
 1544+ 'validator-error-invalid-length-range' => 'Długość parametru $1 musi zawierać się w przedziale od $2 do $3.',
 1545+ 'validator_error_invalid_argument' => 'Nieprawidłowa wartość $1 parametru $2.',
 1546+ 'validator_list_error_empty_argument' => 'Parametr $1 nie może być pusty.',
 1547+ 'validator_list_error_must_be_number' => 'Parametrem $1 mogą być wyłącznie liczby.',
 1548+ 'validator_list_error_must_be_integer' => 'Parametrem $1 mogą być wyłącznie liczby całkowite.',
 1549+ 'validator-list-error-must-be-float' => 'Parametrem $1 mogą być wyłącznie liczby rzeczywiste.',
 1550+ 'validator_list_error_invalid_range' => 'Wartości parametru $1 muszą zawierać się w przedziale od $2 do $3.',
 1551+ 'validator-list-error-invalid-regex' => 'Wszystkie wartości parametru $1 muszą pasować do wyrażenia regularnego $2.',
 1552+ 'validator_list_error_invalid_argument' => 'Przynajmniej jedna wartość parametru $1 jest nieprawidłowa.',
 1553+ 'validator-list-error-accepts-only' => 'Jedna lub więcej wartości parametru $1 są nieprawidłowe.
 1554+Może przyjmować wyłącznie {{PLURAL:$3|wartość|wartości:}} $2.',
 1555+ 'validator-list-error-accepts-only-omitted' => 'Jedna lub więcej wartości parametru $1 są nieprawidłowe.
 1556+Może przyjmować wyłącznie {{PLURAL:$3|wartość|wartości:}} $2 (oraz $4 {{PLURAL:$4|pominiętą wartość|pominięte wartości|pominiętych wartości}}).',
 1557+ 'validator_error_accepts_only' => 'Wartość „$4” jest nieprawidłowa dla parametru $1. {{PLURAL:$3|Dopuszczalna jest wyłącznie wartość|Dopuszczalne są wyłącznie wartości:}} $2.',
 1558+ 'validator-error-accepts-only-omitted' => 'Wartość „$2” parametru $1 jest nieprawidłowa.
 1559+Parametr może przyjmować wyłącznie {{PLURAL:$5|wartość|wartości:}} $3 (oraz $4 {{PLURAL:$4|pominiętą wartość|pominięte wartości|pominiętych wartości}}).',
 1560+ 'validator_list_omitted' => '{{PLURAL:$2|Parametr|Parametry}} $1 {{PLURAL:$2|został opuszczony|zostały opuszczone}}.',
 1561+);
 1562+
 1563+/** Piedmontese (Piemontèis)
 1564+ * @author Borichèt
 1565+ * @author Dragonòt
 1566+ * @author McDutchie
 1567+ */
 1568+$messages['pms'] = array(
 1569+ 'validator-desc' => "Validator a dà na manera bel fé për àutre estension ëd validé ij paràmetr ëd le funsion dël parser e j'estension dij tag, d'amposté ij valor ëd default e generé mëssagi d'eror",
 1570+ 'validator-warning' => 'Avis: $1',
 1571+ 'validator-error' => 'Eror: $1',
 1572+ 'validator-fatal-error' => 'Eror Fatal: $1',
 1573+ 'validator_error_parameters' => "{{PLURAL:$1|L'eror sì-sota a l'é stàit|J'eror sì-sota a son ëstàit}} trovà an soa sintassi:",
 1574+ 'validator_warning_parameters' => "{{PLURAL:$1|A-i é n'|A-i son dj'}}eror ant soa sintassi.",
 1575+ 'validator-warning-adittional-errors' => "... e {{PLURAL:$1|ëdcò n'àutr problema|vàire àutri problema}}.",
 1576+ 'validator-error-omitted' => '{{PLURAL:$2|Ël valor "$1" a l\'é|Ij valor "$1" a son}} stàit sautà.',
 1577+ 'validator-error-problem' => 'A-i é staje un problema con ël paràmetr $1.',
 1578+ 'validator_error_unknown_argument' => "$1 a l'é un paràmetr pa bon.",
 1579+ 'validator_error_required_missing' => "Ël paràmetr obligatòri $1 a l'é pa dàit.",
 1580+ 'validator-error-override-argument' => 'Provà a coaté ël paràmetr $1 (valor: $2) con ël valor "$3"',
 1581+ 'validator-listerrors-errors' => 'Eror',
 1582+ 'validator-listerrors-minor' => 'Pi cit',
 1583+ 'validator-listerrors-low' => 'Bass',
 1584+ 'validator-listerrors-normal' => 'Normal',
 1585+ 'validator-listerrors-high' => 'Àut',
 1586+ 'validator-listerrors-fatal' => 'Fatal',
 1587+ 'validator_error_empty_argument' => 'Ël paràmetr $1 a peul pa avèj un valor veuid.',
 1588+ 'validator_error_must_be_number' => 'Ël paràmetr $1 a peul mach esse un nùmer.',
 1589+ 'validator_error_must_be_integer' => "Ël paràmetr $1 a peul mach esse n'antregh.",
 1590+ 'validator-error-must-be-float' => 'Ël paràmetr $1 a peul mach esse un nùmer an vìrgola mòbil.',
 1591+ 'validator_error_invalid_range' => 'Ël paràmetr $1 a deuv esse an tra $2 e $3.',
 1592+ 'validator-error-invalid-regex' => 'Ël paràmetr $1 a dev cobiesse con sta espression regolar: $2.',
 1593+ 'validator-error-invalid-length' => 'Ël paràmetr $1 a dev avèj na longheur ëd $2.',
 1594+ 'validator-error-invalid-length-range' => 'Ël paràmetr $1 a dev avèj na longheur antra $2 e $3.',
 1595+ 'validator_error_invalid_argument' => "Ël valor $1 a l'é pa bon për ël paràmetr $2.",
 1596+ 'validator_list_error_empty_argument' => 'Ël paràmetr $1 a aceta pa dij valor veuid.',
 1597+ 'validator_list_error_must_be_number' => 'Ël paràmetr $1 a peul mach conten-e dij nùmer.',
 1598+ 'validator_list_error_must_be_integer' => "Ël paràmetr $1 a peul mach conten-e dj'antegr.",
 1599+ 'validator-list-error-must-be-float' => 'Ël paràmetr $1 a peul mach conten-e dij nùmer con vìrgola.',
 1600+ 'validator_list_error_invalid_range' => 'Tùit ij valor dël paràmetr $1 a deuvo esse tra $2 e $3.',
 1601+ 'validator-list-error-invalid-regex' => 'Tùit ij valor dël paràmetr $1 a devo cobiesse con sta espression regolar: $2.',
 1602+ 'validator_list_error_invalid_argument' => 'Un o pi valor dël paràmetr $1 a son pa bon.',
 1603+ 'validator-list-error-accepts-only' => 'Un o pi valor për ël paràmetr $1 a son pa bon.
 1604+A aceta mach {{PLURAL:$3|sto valor|sti valor}}: $2.',
 1605+ 'validator-list-error-accepts-only-omitted' => 'Un o pi valor për ël paràmetr $1 a son pa bon.
 1606+A aceta mach {{PLURAL:$3|sto valor|sti valor}}: $2 (e $4 {{PLURAL:$4|valor|valor}} sautà).',
 1607+ 'validator_error_accepts_only' => 'Ël valor "$4" a l\'é pa bon për ël paràmetr $1. A aceta mach {{PLURAL:$3|sto valor-sì|sti valor-sì}}: $2.',
 1608+ 'validator-error-accepts-only-omitted' => 'Ël valor "$2" a l\'é pa bon për ël paràmetr $1. A aceta mach sti valor: $3 (e ij valor pa butà $4).',
 1609+ 'validator_list_omitted' => "{{PLURAL:$2|Ël valor|Ij valor}} $1 {{PLURAL:$2|a l'é|a son}} pa stàit butà.",
 1610+);
 1611+
 1612+/** Portuguese (Português)
 1613+ * @author Giro720
 1614+ * @author Hamilton Abreu
 1615+ * @author Waldir
 1616+ */
 1617+$messages['pt'] = array(
 1618+ 'validator-desc' => 'O Serviço de Validação permite que, de forma simples, as outras extensões possam validar parâmetros das funções do analisador sintáctico e das extensões dos elementos HTML, definir valores por omissão e gerar mensagens de erro',
 1619+ 'validator-warning' => 'Aviso: $1',
 1620+ 'validator-error' => 'Erro: $1',
 1621+ 'validator-fatal-error' => 'Erro fatal: $1',
 1622+ 'validator_error_parameters' => '{{PLURAL:$1|Foi detectado o seguinte erro sintáctico|Foram detectados os seguintes erros sintácticos}}:',
 1623+ 'validator_warning_parameters' => '{{PLURAL:$1|Existe um erro sintáctico|Existem erros sintácticos}}.',
 1624+ 'validator-warning-adittional-errors' => '... e {{PLURAL:$1|mais um problema|vários outros problemas}}.',
 1625+ 'validator-error-omitted' => '{{PLURAL:$2|O valor "$1" foi omitido|Os valores "$1" foram omitidos}}.',
 1626+ 'validator-error-problem' => 'Houve um problema com o parâmetro $1.',
 1627+ 'validator_error_unknown_argument' => '$1 não é um parâmetro válido.',
 1628+ 'validator_error_required_missing' => 'O parâmetro obrigatório $1 não foi fornecido.',
 1629+ 'validator-error-override-argument' => 'Tentativa de sobrepor o parâmetro $1 (valor: $2) com o valor "$3"',
 1630+ 'validator-listerrors-errors' => 'Erros',
 1631+ 'validator-listerrors-minor' => 'Menor',
 1632+ 'validator-listerrors-low' => 'Baixo',
 1633+ 'validator-listerrors-normal' => 'Normal',
 1634+ 'validator-listerrors-high' => 'Alto',
 1635+ 'validator-listerrors-fatal' => 'Fatal',
 1636+ 'validator_error_empty_argument' => 'O parâmetro $1 não pode estar vazio.',
 1637+ 'validator_error_must_be_number' => 'O parâmetro $1 só pode ser numérico.',
 1638+ 'validator_error_must_be_integer' => 'O parâmetro $1 só pode ser um número inteiro.',
 1639+ 'validator-error-must-be-float' => 'O parâmetro $1 só pode ser um número de vírgula flutuante.',
 1640+ 'validator_error_invalid_range' => 'O parâmetro $1 tem de ser entre $2 e $3.',
 1641+ 'validator-error-invalid-regex' => 'O parâmetro $1 deve corresponder à expressão regular: $2.',
 1642+ 'validator-error-invalid-length' => 'O parâmetro $1 tem de ter um comprimento de $2.',
 1643+ 'validator-error-invalid-length-range' => 'O parâmetro $1 tem de ter um comprimento entre $2 e $3.',
 1644+ 'validator_error_invalid_argument' => 'O valor $1 não é válido para o parâmetro $2.',
 1645+ 'validator_list_error_empty_argument' => 'O parâmetro $1 não pode estar vazio.',
 1646+ 'validator_list_error_must_be_number' => 'O parâmetro $1 só pode ser numérico.',
 1647+ 'validator_list_error_must_be_integer' => 'O parâmetro $1 só pode ser um número inteiro.',
 1648+ 'validator-list-error-must-be-float' => 'O parâmetro $1 só pode conter valores de vírgula flutuante.',
 1649+ 'validator_list_error_invalid_range' => 'Todos os valores do parâmetro $1 têm de ser entre $2 e $3.',
 1650+ 'validator-list-error-invalid-regex' => 'Todos os valores do parâmetro $1 devem corresponder à expressão regular: $2.',
 1651+ 'validator_list_error_invalid_argument' => 'Um ou mais valores do parâmetro $1 são inválidos.',
 1652+ 'validator-list-error-accepts-only' => 'Um ou mais valores para o parâmetro $1 são inválidos.
 1653+Só {{PLURAL:$3|é aceite este valor|são aceites estes valores}}: $2.',
 1654+ 'validator-list-error-accepts-only-omitted' => 'Um ou mais valores para o parâmetro $1 são inválidos.
 1655+Só {{PLURAL:$3|é aceite este valor|são aceites estes valores}}: $2 (e $4 {{PLURAL:$4|valor omitido|valores omitidos}}).',
 1656+ 'validator_error_accepts_only' => 'O valor "$4" não é válido para o parâmetro $1. O parâmetro só aceita {{PLURAL:$3|este valor|estes valores}}: $2.',
 1657+ 'validator-error-accepts-only-omitted' => 'O valor $2 não é válido para o parâmetro $1.
 1658+Só {{PLURAL:$5|é aceite este valor|são aceites estes valores}}: $3 (e $4 {{PLURAL:$4|valor omitido|valores omitidos}}).',
 1659+ 'validator_list_omitted' => '{{PLURAL:$2|O valor $1 foi omitido|Os valores $1 foram omitidos}}.',
 1660+);
 1661+
 1662+/** Brazilian Portuguese (Português do Brasil)
 1663+ * @author Giro720
 1664+ * @author Luckas Blade
 1665+ */
 1666+$messages['pt-br'] = array(
 1667+ 'validator-desc' => 'Fornece suporte a manipulação de parâmetros genéricos para outras extensões',
 1668+ 'validator-warning' => 'Atenção: $1',
 1669+ 'validator-error' => 'Erro: $1',
 1670+ 'validator-fatal-error' => 'Erro crítico: $1',
 1671+ 'validator_error_parameters' => '{{PLURAL:$1|Foi detectado o seguinte erro sintáctico|Foram detectados os seguintes erros sintácticos}}:',
 1672+ 'validator_warning_parameters' => '{{PLURAL:$1|Existe um erro|Existem erros}} em sua sintaxe.',
 1673+ 'validator-warning-adittional-errors' => '... e {{PLURAL:$1|mais um problema|vários outros problemas}}.',
 1674+ 'validator-error-omitted' => '{{PLURAL:$2|O valor "$1" foi omitido|Os valores "$1" foram omitidos}}.',
 1675+ 'validator-error-problem' => 'Houve um problema com o parâmetro $1.',
 1676+ 'validator_error_unknown_argument' => '$1 não é um parâmetro válido.',
 1677+ 'validator_error_required_missing' => 'O parâmetro obrigatório $1 não foi fornecido.',
 1678+ 'validator-error-override-argument' => 'Tentativa de sobrepor o parâmetro $1 (valor: $2) com o valor "$3"',
 1679+ 'validator-listerrors-errors' => 'Erros',
 1680+ 'validator-listerrors-minor' => 'Menor',
 1681+ 'validator-listerrors-low' => 'Baixo',
 1682+ 'validator-listerrors-normal' => 'Normal',
 1683+ 'validator-listerrors-high' => 'Alto',
 1684+ 'validator-listerrors-fatal' => 'Fatal',
 1685+ 'validator_error_empty_argument' => 'O parâmetro $1 não pode estar vazio.',
 1686+ 'validator_error_must_be_number' => 'O parâmetro $1 só pode ser numérico.',
 1687+ 'validator_error_must_be_integer' => 'O parâmetro $1 só pode ser um número inteiro.',
 1688+ 'validator-error-must-be-float' => 'O parâmetro $1 deve ser um número de ponto flutuante.',
 1689+ 'validator_error_invalid_range' => 'O parâmetro $1 tem de ser entre $2 e $3.',
 1690+ 'validator-error-invalid-regex' => 'O parâmetro $1 deve corresponder à expressão regular: $2.',
 1691+ 'validator-error-invalid-length' => 'O parâmetro $1 deve ter um comprimento de $2.',
 1692+ 'validator-error-invalid-length-range' => 'O parâmetro $1 deve ter um comprimento entre $2 e $3.',
 1693+ 'validator_error_invalid_argument' => 'O valor $1 não é válido para o parâmetro $2.',
 1694+ 'validator_list_error_empty_argument' => 'O parâmetro $1 não pode estar vazio.',
 1695+ 'validator_list_error_must_be_number' => 'O parâmetro $1 só pode ser numérico.',
 1696+ 'validator_list_error_must_be_integer' => 'O parâmetro $1 só pode ser um número inteiro.',
 1697+ 'validator-list-error-must-be-float' => 'O parâmetro $1 só pode conter valores de ponto flutuante.',
 1698+ 'validator_list_error_invalid_range' => 'Todos os valores do parâmetro $1 têm de ser entre $2 e $3.',
 1699+ 'validator-list-error-invalid-regex' => 'Todos os valores do parâmetro $1 devem corresponder à expressão regular: $2.',
 1700+ 'validator_list_error_invalid_argument' => 'Um ou mais valores do parâmetro $1 são inválidos.',
 1701+ 'validator-list-error-accepts-only' => 'Um ou mais valores para o parâmetro $1 são inválidos.
 1702+Só {{PLURAL:$3|é aceite este valor|são aceites estes valores}}: $2.',
 1703+ 'validator-list-error-accepts-only-omitted' => 'Um ou mais valores para o parâmetro $1 são inválidos.
 1704+Só {{PLURAL:$3|é aceite este valor|são aceites estes valores}}: $2 (e $4 {{PLURAL:$4|valor omitido|valores omitidos}}).',
 1705+ 'validator_error_accepts_only' => 'O valor $4 não é válido para o parâmetro $1. Esse parâmetro só aceita {{PLURAL:$3|este valor|estes valores}}: $2.',
 1706+ 'validator-error-accepts-only-omitted' => 'O valor $2 não é válido para o parâmetro $1.
 1707+Só {{PLURAL:$5|é aceite este valor|são aceites estes valores}}: $3 (e $4 {{PLURAL:$4|valor omitido|valores omitidos}}).',
 1708+ 'validator_list_omitted' => '{{PLURAL:$2|O valor $1 foi omitido|Os valores $1 foram omitidos}}.',
 1709+);
 1710+
 1711+/** Romanian (Română)
 1712+ * @author Stelistcristi
 1713+ */
 1714+$messages['ro'] = array(
 1715+ 'validator-warning' => 'Avertisment: $1',
 1716+ 'validator-fatal-error' => 'Eroare fatală: $1',
 1717+ 'validator_error_unknown_argument' => '$1 nu este un parametru valid.',
 1718+ 'validator_error_required_missing' => 'Parametrul solicitat „$1” nu este furnizat.',
 1719+ 'validator-listerrors-errors' => 'Erori',
 1720+ 'validator_error_empty_argument' => 'Parametrul $1 nu poate avea o valoare goală.',
 1721+ 'validator_error_must_be_number' => 'Parametrul $1 poate fi doar un număr.',
 1722+ 'validator_error_must_be_integer' => 'Parametrul $1 poate fi doar un număr întreg.',
 1723+);
 1724+
 1725+/** Russian (Русский)
 1726+ * @author Aleksandrit
 1727+ * @author Eleferen
 1728+ * @author Haffman
 1729+ * @author Lockal
 1730+ * @author MaxSem
 1731+ * @author McDutchie
 1732+ * @author Александр Сигачёв
 1733+ */
 1734+$messages['ru'] = array(
 1735+ 'validator-desc' => 'Валидатор предоставляет другим расширениям возможности проверки параметров функций парсера и тегов, установки значения по умолчанию и создания сообщения об ошибках',
 1736+ 'validator-warning' => 'Внимание: $1',
 1737+ 'validator-error' => 'Ошибка: $1',
 1738+ 'validator-fatal-error' => 'Критическая ошибка: $1',
 1739+ 'validator_error_parameters' => 'В вашем синтаксисе {{PLURAL:$1|обнаружена следующая ошибка|обнаружены следующие ошибки}}:',
 1740+ 'validator_warning_parameters' => 'В вашем синтаксисе {{PLURAL:$1|имеется ошибка|имеются ошибки}}.',
 1741+ 'validator-warning-adittional-errors' => '… и {{PLURAL:$1|ещё одна проблема|ещё несколько проблем}}.',
 1742+ 'validator-error-omitted' => '{{PLURAL:$2|Значение «$1» пропущено|Значения «$1» пропущены}}.',
 1743+ 'validator-error-problem' => 'Обнаружена проблема с параметром «$1».',
 1744+ 'validator_error_unknown_argument' => '$1 не является допустимым параметром.',
 1745+ 'validator_error_required_missing' => 'Не указан обязательный параметр $1.',
 1746+ 'validator-error-override-argument' => 'Попытка переопределения параметра $1 (значение: $2) значением «$3»',
 1747+ 'validator-type-string' => 'текст',
 1748+ 'validator-type-number' => 'число',
 1749+ 'validator-type-integer' => 'целое число',
 1750+ 'validator-type-float' => 'число',
 1751+ 'validator-type-boolean' => 'да/нет',
 1752+ 'validator-type-char' => 'символ',
 1753+ 'validator-listerrors-errors' => 'Ошибки',
 1754+ 'validator-listerrors-minor' => 'Незначительная',
 1755+ 'validator-listerrors-low' => 'Низкая',
 1756+ 'validator-listerrors-normal' => 'Обычная',
 1757+ 'validator-listerrors-high' => 'Высокая',
 1758+ 'validator-listerrors-fatal' => 'Фатальная',
 1759+ 'validator-listerrors-description' => 'Перечисляет ошибки (и предупреждения), произошедшие в обработчиках парсера, добавленных с помощью Validator.
 1760+Выводятся только обработчики парсера, добавленные выше вставленно listerrors.
 1761+Поместите listerrors в самый конец страницы, чтобы получить все ошибки.',
 1762+ 'validator-listerrors-par-minseverity' => 'Минимальная серьезность вопроса, для включения в список.',
 1763+ 'validator-describe-description' => 'Создает документацию для одного или нескольких обработчиков парсера, по пределениям Validator.',
 1764+ 'validator-describe-notfound' => 'Не существует обработчика парсера для «$1».',
 1765+ 'validator-describe-descriptionmsg' => "'''Описание''': $1",
 1766+ 'validator-describe-aliases' => "'''{{PLURAL:$2|Псевдоним|Псевдонимы}}''': $1",
 1767+ 'validator-describe-parserfunction' => 'Реализована только функция парсера.',
 1768+ 'validator-describe-tagextension' => 'Реализовано только как дополнительный тег.',
 1769+ 'validator-describe-bothhooks' => 'Реализовано и функция парсера, и дополнительный тег.',
 1770+ 'validator-describe-par-hooks' => 'Обработчик парсера, для которого отображать документацию.',
 1771+ 'validator-describe-par-pre' => 'Позволяет получить фактический викитекст для документации, без показа на странице.',
 1772+ 'validator-describe-listtype' => 'Перечень пунктов $1',
 1773+ 'validator-describe-empty' => 'пусто',
 1774+ 'validator-describe-required' => 'требуется',
 1775+ 'validator-describe-header-parameter' => 'Параметр',
 1776+ 'validator-describe-header-aliases' => 'Псевдонимы',
 1777+ 'validator-describe-header-type' => 'Тип',
 1778+ 'validator-describe-header-default' => 'По умолчанию',
 1779+ 'validator-describe-header-description' => 'Описание',
 1780+ 'validator-describe-parameters' => 'Параметры',
 1781+ 'validator-describe-syntax' => 'Синтаксис',
 1782+ 'validator-describe-tagmin' => 'Теговое расширение, имеющее только обязательные параметры.',
 1783+ 'validator-describe-tagmax' => 'Теговое расширение со всеми параметрами.',
 1784+ 'validator-describe-tagdefault' => 'Теговое расширение со всеми параметрами, использованием параметров по умолчанию.',
 1785+ 'validator-describe-pfmin' => 'Парсерная функция, имеющая только обязательные параметры.',
 1786+ 'validator-describe-pfmax' => 'Парсерная функция со всеми параметрами.',
 1787+ 'validator-describe-pfdefault' => 'Парсерная функция со всеми параметрами, использованием параметров по умолчанию.',
 1788+ 'validator-describe-autogen' => 'Содержимое этого раздела было автоматически создано парсерным обработчиком «describe» расширения Validator.',
 1789+ 'validator_error_empty_argument' => 'Параметр $1 не может принимать пустое значение.',
 1790+ 'validator_error_must_be_number' => 'Значением параметра $1 могут быть только числа.',
 1791+ 'validator_error_must_be_integer' => 'Параметр $1 может быть только целым числом.',
 1792+ 'validator-error-must-be-float' => 'Параметр $1 может быть числом с плавающей точкой.',
 1793+ 'validator_error_invalid_range' => 'Параметр $1 должен быть от $2 до $3.',
 1794+ 'validator-error-invalid-regex' => 'Параметр «$1» должен соответствовать регулярному выражению «$2».',
 1795+ 'validator-error-invalid-length' => 'Параметр $1 должен иметь длину $2.',
 1796+ 'validator-error-invalid-length-range' => 'Параметр $1 должен иметь длину от $2 до $3.',
 1797+ 'validator_error_invalid_argument' => 'Значение $1 не является допустимым параметром $2',
 1798+ 'validator_list_error_empty_argument' => 'Параметр $1 не может принимать пустые значения.',
 1799+ 'validator_list_error_must_be_number' => 'Параметр $1 может содержать только цифры.',
 1800+ 'validator_list_error_must_be_integer' => 'Параметр $1 может содержать только целые числа.',
 1801+ 'validator-list-error-must-be-float' => 'Параметр «$1» может содержать только числа с плавающей точкой.',
 1802+ 'validator_list_error_invalid_range' => 'Все значения параметра $1 должна находиться в диапазоне от $2 до $3.',
 1803+ 'validator-list-error-invalid-regex' => 'Все значения параметра «$1» должны соответствовать регулярноve выражению «$2».',
 1804+ 'validator_list_error_invalid_argument' => 'Одно или несколько значений параметра $1 ошибочны.',
 1805+ 'validator-list-error-accepts-only' => 'Ошибочны один или несколько значений параметра $1.
 1806+{{PLURAL:$3|Допустимо только следующее значение|Допустимы только следующие значения}}: $2.',
 1807+ 'validator-list-error-accepts-only-omitted' => 'Ошибочны один или несколько значений параметра $1.
 1808+{{PLURAL:$3|Допустимо только следующее значение|Допустимы только следующие значения}}: $2 (и $4 {{PLURAL:$4|опущенное значение|опущенных значения|опущенных значений}}).',
 1809+ 'validator_error_accepts_only' => 'Значение «$4» не подходит для параметра $1. Оно может принимать только {{PLURAL:$3|следующее значение|следующие значения}}: $2.',
 1810+ 'validator-error-accepts-only-omitted' => 'Значение «$2» не подходит для параметра $1.
 1811+{{PLURAL:$5|Допускается только значение|Допускаются только значения}}: $3 (и $4 {{PLURAL:$4|пропущенное значение|пропущенных значения|пропущенных значений}}).',
 1812+ 'validator_list_omitted' => '{{PLURAL:$2|Значение $1 было пропущено|Значения $1 были пропущены}}.',
 1813+);
 1814+
 1815+/** Sinhala (සිංහල)
 1816+ * @author Calcey
 1817+ */
 1818+$messages['si'] = array(
 1819+ 'validator-desc' => 'තහවුරු කරන්නා ටැග් දිඟුවන් හා parser ශ්‍රිතවල පරාමිතීන් තහවුරු කිරීමට අනෙක් දිඟුවන් සඳහා පහසු ක්‍රමයක් සපයයි,පෙරනිමි අගයන් පිහිටුවීම හා දෝෂ පණිවුඩ ජනනය කිරීම ද සිදු කරයි',
 1820+ 'validator_error_parameters' => 'ඔබේ වාග් රීතිය මඟින් පහත {{PLURAL:$1|දෝෂය|දෝෂයන්}} අනාවරණය කරනු ලැබ ඇත',
 1821+ 'validator_error_unknown_argument' => '$1 වලංගු පරාමිතියක් නොවේ.',
 1822+ 'validator_error_required_missing' => 'අවශ්‍ය වන $1 පරාමිතිය සපයා නොමැත.',
 1823+ 'validator_error_empty_argument' => '$1 පරාමිතියට හිස් අගයක් තිබිය නොහැක.',
 1824+ 'validator_error_must_be_number' => '$1 පරාමිතිය විය හැක්කේ ඉලක්කමක් පමණි.',
 1825+ 'validator_error_invalid_range' => '$1 පරාමිතිය $2 හා $3 අතර විය යුතුය.',
 1826+ 'validator_error_invalid_argument' => '$2 පරාමිතිය සඳහා $1 අගය වලංගු නොවේ.',
 1827+ 'validator_error_accepts_only' => '$1 පරාමිතිය විසින් පිළිගනු ලබන්නේ {{PLURAL:$3|මෙම අගය|මෙම අගයන්}}: $2 පමණි.',
 1828+);
 1829+
 1830+/** Swedish (Svenska)
 1831+ * @author Fluff
 1832+ * @author Ozp
 1833+ * @author Per
 1834+ * @author Sertion
 1835+ */
 1836+$messages['sv'] = array(
 1837+ 'validator-desc' => 'Valideraren skapar ett smidigt sätt för andra tillägg att validera olika parserfunktioners parametrar och taggar, sätta standardvärden för tilläggen samt att generera felmeddelanden',
 1838+ 'validator_error_parameters' => 'Följande {{PLURAL:$1|fel|fel}} har upptäckts i din syntax:',
 1839+ 'validator_warning_parameters' => 'Det finns {{PLURAL:$1|ett|flera}} fel i din syntax.',
 1840+ 'validator_error_unknown_argument' => '$1 är inte en giltig paramter.',
 1841+ 'validator_error_required_missing' => 'Den nödvändiga parametern $1 har inte angivits.',
 1842+ 'validator_error_empty_argument' => 'Parametern $1 kan inte lämnas tom.',
 1843+ 'validator_error_must_be_number' => 'Parameter $1 måste bestå av ett tal.',
 1844+ 'validator_error_must_be_integer' => 'Parametern $1 måste vara ett heltal.',
 1845+ 'validator_error_invalid_range' => 'Parameter $1 måste vara i mellan $2 och $3.',
 1846+ 'validator_error_invalid_argument' => 'Värdet $1 är inte giltigt som parameter $2.',
 1847+ 'validator_list_error_empty_argument' => 'Parameter $1 accepterar inte tomma värden.',
 1848+ 'validator_list_error_must_be_number' => 'Parameter $1 får endast innehålla siffror.',
 1849+ 'validator_list_error_must_be_integer' => 'Parameter $1 får endast innehålla heltal.',
 1850+ 'validator_list_error_invalid_range' => 'Alla värden av parameter $1 måste vara mellan $2 och $3.',
 1851+ 'validator_list_error_invalid_argument' => 'Ett eller flera värden av parameter $1 är ogiltiga.',
 1852+ 'validator_error_accepts_only' => 'Parametern $1 måste ha {{PLURAL:$3|detta värde|ett av dessa värden}}: $2.',
 1853+ 'validator_list_omitted' => '{{PLURAL:$2|Värdet|Värdena}} $1 har blivit {{PLURAL:$2|utelämnat|utelämnade}}.',
 1854+);
 1855+
 1856+/** Telugu (తెలుగు)
 1857+ * @author Ravichandra
 1858+ * @author Veeven
 1859+ */
 1860+$messages['te'] = array(
 1861+ 'validator-warning' => 'హెచ్చరిక: $1',
 1862+ 'validator-error' => 'పొరపాటు: $1',
 1863+ 'validator_error_unknown_argument' => '$1 అనేది సరైన పరామితి కాదు.',
 1864+ 'validator_error_required_missing' => 'తప్పకుండా కావాల్సిన $1 పరామితిని ఇవ్వలేదు.',
 1865+ 'validator-listerrors-errors' => 'పొరపాట్లు',
 1866+ 'validator_error_empty_argument' => '$1 పరామితి ఖాళీగా ఉండకూడదు',
 1867+ 'validator_error_must_be_number' => '$1 పరామితి ఖచ్చితంగా ఓ సంఖ్య అయిఉండాలి',
 1868+ 'validator_error_must_be_integer' => '$1 పరామితి ఒక పూర్ణసంఖ్య అయిఉండాలి',
 1869+ 'validator_error_invalid_range' => '$1 పరామితి $2, $3 మద్యలో ఉండాలి.',
 1870+ 'validator_error_invalid_argument' => '$2 పరామితి కోసం $1 విలువ సరైంది కాదు',
 1871+ 'validator_list_error_must_be_number' => '$1 పరామితి ఖచ్చితంగా సంఖ్యలను మాత్రమే కలిగివుండాలి.',
 1872+ 'validator_list_error_must_be_integer' => '$1 పరామితి పూర్ణసంఖ్యలను మాత్రమే కలిగివుండాలి.',
 1873+);
 1874+
 1875+/** Tagalog (Tagalog)
 1876+ * @author AnakngAraw
 1877+ */
 1878+$messages['tl'] = array(
 1879+ 'validator-desc' => 'Nagbibigay ng panlahatang magtangkilik na paghawak sa ibang mga dugtong',
 1880+ 'validator-warning' => 'Babala: $1',
 1881+ 'validator-error' => 'Kamalian: $1',
 1882+ 'validator-fatal-error' => 'Masidhing kamalian: $1',
 1883+ 'validator_error_parameters' => 'Ang sumusunod na {{PLURAL:$1|kamalian|mga kamalian}} ay napansin sa iyong sintaks:',
 1884+ 'validator_warning_parameters' => 'May {{PLURAL:$1|mali|mga mali}} sa sintaks mo.',
 1885+ 'validator-warning-adittional-errors' => '... at {{PLURAL:$1|isa pang paksa|maramihan pang mga paksa}}.',
 1886+ 'validator_error_unknown_argument' => 'Ang $1 ay isang hindi tanggap na parametro.',
 1887+ 'validator_error_required_missing' => 'Hindi ibinigay ang kailangang parametro na $1.',
 1888+ 'validator-error-override-argument' => 'Sinubukang pangingibabawan ang parametrong $1 (halaga: $2) ng halagang "$3"',
 1889+ 'validator_error_empty_argument' => 'Hindi dapat na isang halagang walang laman ang parametrong $1.',
 1890+ 'validator_error_must_be_number' => 'Dapat na bilang lang ang parametrong $1.',
 1891+ 'validator_error_must_be_integer' => 'Dapat na tambilang lang ang parametrong $1.',
 1892+ 'validator-error-must-be-float' => 'Ang parametrong $1 ay maaaring isang lumulutang na bilang ng punto lamang.',
 1893+ 'validator_error_invalid_range' => 'Dapat na nasa pagitan ng $2 at $3 ang parametrong $1.',
 1894+ 'validator-error-invalid-length' => 'Ang parametrong $1 ay dapat na may isang haba na $2.',
 1895+ 'validator-error-invalid-length-range' => 'Ang parametrong $1 ay dapat na may isang haba na nasa pagitan ng $2 at $3.',
 1896+ 'validator_error_invalid_argument' => 'Ang halagang $1 ay hindi tanggap para sa parametrong $2.',
 1897+ 'validator_list_error_empty_argument' => 'Hindi tumatanggap ng halagang walang laman ang parametrong $1.',
 1898+ 'validator_list_error_must_be_number' => 'Dapat na naglalaman lang ng mga bilang ang parametrong $1.',
 1899+ 'validator_list_error_must_be_integer' => 'Dapat na naglalaman lang ng mga tambilang ang parametrong $1.',
 1900+ 'validator_list_error_invalid_range' => 'Dapat na nasa pagitan ng $2 at $3 ang lahat ng mga halaga ng parametrong $1.',
 1901+ 'validator_list_error_invalid_argument' => 'Hindi tanggap ang isa o higit pang mga halaga para sa parametrong $1.',
 1902+ 'validator_error_accepts_only' => 'Ang halagang "$4" ay hindi tanggap para sa parametrong $1. Tumatanggap lamang ito ng
 1903+{{PLURAL:$3|ganitong halaga|ganitong mga halaga}}: $2.',
 1904+ 'validator_list_omitted' => 'Tinanggal {{PLURAL:$2|na ang|na ang mga}} {{PLURAL:$2|halaga|halaga}} ng $1.',
 1905+);
 1906+
 1907+/** Turkish (Türkçe)
 1908+ * @author Vito Genovese
 1909+ */
 1910+$messages['tr'] = array(
 1911+ 'validator_error_unknown_argument' => '$1, geçerli bir parametre değildir.',
 1912+ 'validator_error_empty_argument' => '$1 parametresi boş bir değere sahip olamaz.',
 1913+ 'validator_error_must_be_number' => '$1 parametresi sadece sayı olabilir.',
 1914+ 'validator_error_must_be_integer' => '$1 parametresi sadece bir tamsayı olabilir',
 1915+ 'validator_list_error_empty_argument' => '$1 parametresi boş değerleri kabul etmemektedir.',
 1916+ 'validator_list_error_must_be_number' => '$1 parametresi sadece sayı içerebilir.',
 1917+);
 1918+
 1919+/** Ukrainian (Українська)
 1920+ * @author NickK
 1921+ * @author Prima klasy4na
 1922+ */
 1923+$messages['uk'] = array(
 1924+ 'validator-desc' => 'Валідатор забезпечує іншим розширенням можливості перевірки параметрів функцій парсера і тегів, встановлення значень за умовчанням та створення повідомлень про помилки',
 1925+ 'validator_error_parameters' => 'У вашому синтаксисі {{PLURAL:$1|виявлена така помилка|виявлені такі помилки}}:',
 1926+);
 1927+
 1928+/** Vietnamese (Tiếng Việt)
 1929+ * @author Minh Nguyen
 1930+ * @author Vinhtantran
 1931+ */
 1932+$messages['vi'] = array(
 1933+ 'validator-desc' => 'Bộ phê chuẩn cho phép các phần mở rộng khác phê chuẩn tham số của hàm cú pháp và thẻ mở rộng, đặt giá trị mặc định, và báo cáo lỗi.',
 1934+ 'validator-warning' => 'Cảnh báo: $1',
 1935+ 'validator-error' => 'Lỗi: $1',
 1936+ 'validator_error_parameters' => '{{PLURAL:$1|Lỗi|Các lỗi}} cú pháp sau được nhận ra trong mã của bạn:',
 1937+ 'validator_warning_parameters' => 'Có {{PLURAL:$1|lỗi|lỗi}} cú pháp trong mã của bạn.',
 1938+ 'validator_error_unknown_argument' => '$1 không phải là tham số hợp lệ.',
 1939+ 'validator_error_required_missing' => 'Không định rõ tham số bắt buộc “$1”.',
 1940+ 'validator-listerrors-errors' => 'Lỗi',
 1941+ 'validator-listerrors-low' => 'Thấp',
 1942+ 'validator-listerrors-normal' => 'Thường',
 1943+ 'validator-listerrors-high' => 'Cao',
 1944+ 'validator_error_empty_argument' => 'Tham số “$1” không được để trống.',
 1945+ 'validator_error_must_be_number' => 'Tham số “$1” phải là con số.',
 1946+ 'validator_error_must_be_integer' => 'Tham số “$1” phải là số nguyên.',
 1947+ 'validator_error_invalid_range' => 'Tham số “$1” phải nằm giữa $2 và $3.',
 1948+ 'validator_error_invalid_argument' => 'Giá trị “$1” không hợp tham số “$2”.',
 1949+ 'validator_list_error_empty_argument' => 'Không được để trống tham số “$1”.',
 1950+ 'validator_list_error_must_be_number' => 'Tham số “$1” chỉ được phép bao gồm con số.',
 1951+ 'validator_list_error_must_be_integer' => 'Tham số “$1” chỉ được phép bao gồm số nguyên.',
 1952+ 'validator_list_error_invalid_range' => 'Tất cả các giá trị của tham số “$1” phải nằm giữa $2 và $3.',
 1953+ 'validator_list_error_invalid_argument' => 'Ít nhất một giá trị của tham số “$1” không hợp lệ.',
 1954+ 'validator_error_accepts_only' => 'Tham số $1 có giá trị không hợp lệ “$4”. Tham số chỉ nhận được {{PLURAL:$3|giá trị|các giá trị}} này: $2.',
 1955+ 'validator_list_omitted' => '{{PLURAL:$2|Giá trị|Các giá trị}} “$1” bị bỏ qua.',
 1956+);
 1957+
 1958+/** Simplified Chinese (‪中文(简体)‬)
 1959+ * @author Wilsonmess
 1960+ */
 1961+$messages['zh-hans'] = array(
 1962+ 'validator_error_unknown_argument' => '$1 不是合法参数。',
 1963+ 'validator_error_required_missing' => '未能提供所需要的参数 $1 。',
 1964+ 'validator_error_empty_argument' => '参数 $1 不能为空。',
 1965+ 'validator_error_must_be_number' => '参数 $1 只能为数字。',
 1966+ 'validator_error_must_be_integer' => '参数 $1 只能为整数。',
 1967+ 'validator_error_invalid_range' => '参数 $1 的范围必须介于 $2 与 $3 之间。',
 1968+ 'validator_error_invalid_argument' => '值 $1 对于参数 $2 不合法。',
 1969+ 'validator_list_error_empty_argument' => '参数 $1 不接受空值。',
 1970+ 'validator_list_error_must_be_number' => '参数 $1 只能包含数字。',
 1971+ 'validator_list_error_must_be_integer' => '参数 $1 只能包含整数。',
 1972+ 'validator_list_error_invalid_range' => '参数 $1 所有合法的值都必须介于 $2 与 $3 之间。',
 1973+ 'validator_list_error_invalid_argument' => '参数 $1 的一个或多个值不合法。',
 1974+);
 1975+
Property changes on: tags/extensions/Validator/REL_0_4_3/Validator.i18n.php
___________________________________________________________________
Added: svn:eol-style
11976 + native
Index: tags/extensions/Validator/REL_0_4_3/Validator.php
@@ -0,0 +1,104 @@
 2+<?php
 3+
 4+/**
 5+ * Initialization file for the Validator extension.
 6+ * Extension documentation: http://www.mediawiki.org/wiki/Extension:Validator
 7+ *
 8+ * You will be validated. Resistance is futile.
 9+ *
 10+ * @file Validator.php
 11+ * @ingroup Validator
 12+ *
 13+ * @author Jeroen De Dauw
 14+ */
 15+
 16+/**
 17+ * This documenation group collects source code files belonging to Validator.
 18+ *
 19+ * Please do not use this group name for other code.
 20+ *
 21+ * @defgroup Validator Validator
 22+ */
 23+
 24+if ( !defined( 'MEDIAWIKI' ) ) {
 25+ die( 'Not an entry point.' );
 26+}
 27+
 28+define( 'Validator_VERSION', '0.4.3' );
 29+
 30+// Register the internationalization file.
 31+$wgExtensionMessagesFiles['Validator'] = dirname( __FILE__ ) . '/Validator.i18n.php';
 32+
 33+$wgExtensionCredits['other'][] = array(
 34+ 'path' => __FILE__,
 35+ 'name' => 'Validator',
 36+ 'version' => Validator_VERSION,
 37+ 'author' => array( '[http://www.mediawiki.org/wiki/User:Jeroen_De_Dauw Jeroen De Dauw]' ),
 38+ 'url' => 'http://www.mediawiki.org/wiki/Extension:Validator',
 39+ 'descriptionmsg' => 'validator-desc',
 40+);
 41+
 42+// Autoload the classes.
 43+$incDir = dirname( __FILE__ ) . '/includes/';
 44+$wgAutoloadClasses['CriterionValidationResult'] = $incDir . 'CriterionValidationResult.php';
 45+$wgAutoloadClasses['ItemParameterCriterion'] = $incDir . 'ItemParameterCriterion.php';
 46+$wgAutoloadClasses['ItemParameterManipulation'] = $incDir . 'ItemParameterManipulation.php';
 47+$wgAutoloadClasses['ListParameter'] = $incDir . 'ListParameter.php';
 48+$wgAutoloadClasses['ListParameterCriterion'] = $incDir . 'ListParameterCriterion.php';
 49+$wgAutoloadClasses['ListParameterManipulation'] = $incDir . 'ListParameterManipulation.php';
 50+$wgAutoloadClasses['Parameter'] = $incDir . 'Parameter.php';
 51+$wgAutoloadClasses['ParameterCriterion'] = $incDir . 'ParameterCriterion.php';
 52+$wgAutoloadClasses['ParameterManipulation'] = $incDir . 'ParameterManipulation.php';
 53+$wgAutoloadClasses['ParserHook'] = $incDir . 'ParserHook.php';
 54+$wgAutoloadClasses['Validator'] = $incDir . 'Validator.php';
 55+$wgAutoloadClasses['TopologicalSort'] = $incDir . 'TopologicalSort.php';
 56+// No need to autoload this one, since it's directly included below.
 57+//$wgAutoloadClasses['ValidationError'] = $incDir . 'ValidationError.php';
 58+$wgAutoloadClasses['ValidationErrorHandler'] = $incDir . 'ValidationErrorHandler.php';
 59+
 60+$wgAutoloadClasses['CriterionHasLength'] = $incDir . 'criteria/CriterionHasLength.php';
 61+$wgAutoloadClasses['CriterionInArray'] = $incDir . 'criteria/CriterionInArray.php';
 62+$wgAutoloadClasses['CriterionInRange'] = $incDir . 'criteria/CriterionInRange.php';
 63+$wgAutoloadClasses['CriterionIsFloat'] = $incDir . 'criteria/CriterionIsFloat.php';
 64+$wgAutoloadClasses['CriterionIsInteger'] = $incDir . 'criteria/CriterionIsInteger.php';
 65+$wgAutoloadClasses['CriterionIsNumeric'] = $incDir . 'criteria/CriterionIsNumeric.php';
 66+$wgAutoloadClasses['CriterionItemCount'] = $incDir . 'criteria/CriterionItemCount.php';
 67+$wgAutoloadClasses['CriterionMatchesRegex'] = $incDir . 'criteria/CriterionMatchesRegex.php';
 68+$wgAutoloadClasses['CriterionNotEmpty'] = $incDir . 'criteria/CriterionNotEmpty.php';
 69+$wgAutoloadClasses['CriterionTrue'] = $incDir . 'criteria/CriterionTrue.php';
 70+$wgAutoloadClasses['CriterionUniqueItems'] = $incDir . 'criteria/CriterionUniqueItems.php';
 71+
 72+$wgAutoloadClasses['ParamManipulationBoolean'] = $incDir . 'manipulations/ParamManipulationBoolean.php';
 73+$wgAutoloadClasses['ParamManipulationBoolstr'] = $incDir . 'manipulations/ParamManipulationBoolstr.php';
 74+$wgAutoloadClasses['ParamManipulationFloat'] = $incDir . 'manipulations/ParamManipulationFloat.php';
 75+$wgAutoloadClasses['ParamManipulationFunctions']= $incDir . 'manipulations/ParamManipulationFunctions.php';
 76+$wgAutoloadClasses['ParamManipulationImplode'] = $incDir . 'manipulations/ParamManipulationImplode.php';
 77+$wgAutoloadClasses['ParamManipulationInteger'] = $incDir . 'manipulations/ParamManipulationInteger.php';
 78+
 79+$wgAutoloadClasses['ValidatorDescribe'] = $incDir . 'parserHooks/Validator_Describe.php';
 80+$wgAutoloadClasses['ValidatorListErrors'] = $incDir . 'parserHooks/Validator_ListErrors.php';
 81+unset( $incDir );
 82+
 83+$wgExtensionFunctions[] = 'efValidatorSetup';
 84+
 85+/**
 86+ * Function for backwards compatibility with MW 1.15.x.
 87+ *
 88+ * @since 0.4.2
 89+ */
 90+function efValidatorSetup() {
 91+ // This function has been deprecated in 1.16, but needed for earlier versions.
 92+ // It's present in 1.16 as a stub, but lets check if it exists in case it gets removed at some point.
 93+ global $wgVersion;
 94+ if ( version_compare( $wgVersion, '1.15', '<=' ) ) {
 95+ wfLoadExtensionMessages( 'Validator' );
 96+ }
 97+
 98+ return true;
 99+}
 100+
 101+// This file needs to be included directly, since Validator_Settings.php
 102+// uses it, in some rare cases before autoloading is defined.
 103+require_once 'includes/ValidationError.php' ;
 104+// Include the settings file.
 105+require_once 'Validator_Settings.php';
Property changes on: tags/extensions/Validator/REL_0_4_3/Validator.php
___________________________________________________________________
Added: svn:eol-style
1106 + native
Index: tags/extensions/Validator/REL_0_4_3/Validator_Settings.php
@@ -0,0 +1,40 @@
 2+<?php
 3+
 4+/**
 5+ * File defining the settings for the Validator extension
 6+ *
 7+ * NOTICE:
 8+ * Changing one of these settings can be done by copieng or cutting it,
 9+ * and placing it in LocalSettings.php, AFTER the inclusion of Validator.
 10+ *
 11+ * @file Validator_Settings.php
 12+ * @ingroup Validator
 13+ *
 14+ * @author Jeroen De Dauw
 15+ */
 16+
 17+if ( !defined( 'MEDIAWIKI' ) ) {
 18+ die( 'Not an entry point.' );
 19+}
 20+
 21+# Registration of the listerrors parser hooks.
 22+$wgHooks['ParserFirstCallInit'][] = 'ValidatorListErrors::staticInit';
 23+$wgHooks['LanguageGetMagic'][] = 'ValidatorListErrors::staticMagic';
 24+
 25+# Registration of the describe parser hooks.
 26+$wgHooks['ParserFirstCallInit'][] = 'ValidatorDescribe::staticInit';
 27+$wgHooks['LanguageGetMagic'][] = 'ValidatorDescribe::staticMagic';
 28+
 29+# Maps actions to error severity.
 30+# ACTION_LOG will cause the error to be logged
 31+# ACTION_WARN will cause a notice that there is an error to be shown inline
 32+# ACTION_SHOW will cause an error message to be shown inline
 33+# ACTION_DEMAND will cause an error message to be shown inline and prevent rendering of the regular output
 34+$egErrorActions = array(
 35+ ValidationError::SEVERITY_MINOR => ValidationError::ACTION_LOG,
 36+ ValidationError::SEVERITY_LOW => ValidationError::ACTION_WARN,
 37+ ValidationError::SEVERITY_NORMAL => ValidationError::ACTION_SHOW,
 38+ ValidationError::SEVERITY_HIGH => ValidationError::ACTION_DEMAND,
 39+);
 40+
 41+$egValidatorErrListMin = 'minor';
Property changes on: tags/extensions/Validator/REL_0_4_3/Validator_Settings.php
___________________________________________________________________
Added: svn:eol-style
142 + native
Index: tags/extensions/Validator/REL_0_4_3/README
@@ -0,0 +1,12 @@
 2+== About ==
 3+
 4+Validator is an extension that makes parameter validation functionality available
 5+to other extensions. This enables other extensions to validate parameters, set them
 6+to their defaults, and generate error messages, while only defining the parameters
 7+and their criteria.
 8+
 9+Notes on installing Validator are found in the file INSTALL.
 10+
 11+== Contributors ==
 12+
 13+http://www.mediawiki.org/wiki/Extension:Validator#Contributing_to_the_project

Status & tagging log