MediaWiki
master
|
Helper class to keep track of options when mixing links and form elements. More...
Public Member Functions | |
add ($name, $default, $type=self::AUTO) | |
Add an option to be handled by this FormOptions instance. More... | |
consumeValue ($name) | |
Get the value of given option and mark it as 'consumed'. More... | |
consumeValues ($names) | |
Get the values of given options and mark them as 'consumed'. More... | |
delete ($name) | |
Remove an option being handled by this FormOptions instance. More... | |
fetchValuesFromRequest (WebRequest $r, $optionKeys=null) | |
Fetch values for all options (or selected options) from the given WebRequest, making them available for accessing with getValue() or consumeValue() etc. More... | |
getAllValues () | |
Format options to an array ( name => value ) More... | |
getChangedValues () | |
Return options modified as an array ( name => value ) More... | |
getUnconsumedValues ($all=false) | |
Get all remaining values which have not been consumed by consumeValue() or consumeValues(). More... | |
getValue ($name) | |
Get the value for the given option name. More... | |
reset ($name) | |
Delete the option value. More... | |
setValue ($name, $value, $force=false) | |
Use to set the value of an option. More... | |
validateBounds ($name, $min, $max) | |
Constrain a numeric value for a given option to a given range. More... | |
validateIntBounds ($name, $min, $max) | |
validateName ($name, $strict=false) | |
Verify that the given option name exists. More... | |
ArrayAccess functions | |
These functions implement the ArrayAccess PHP interface. | |
offsetExists ($name) | |
Whether the option exists. More... | |
offsetGet ($name) | |
Retrieve an option value. More... | |
offsetSet ($name, $value) | |
Set an option to given value. More... | |
offsetUnset ($name) | |
Delete the option. More... | |
Static Public Member Functions | |
static | guessType ($data) |
Used to find out which type the data is. More... | |
Public Attributes | |
Type constants | |
Used internally to map an option value to a WebRequest accessor | |
const | AUTO = -1 |
Mark value for automatic detection (for simple data types only) More... | |
const | STRING = 0 |
String type, maps guessType() to WebRequest::getText() More... | |
const | INT = 1 |
Integer type, maps guessType() to WebRequest::getInt() More... | |
const | FLOAT = 4 |
Float type, maps guessType() to WebRequest::getFloat() More... | |
const | BOOL = 2 |
Boolean type, maps guessType() to WebRequest::getBool() More... | |
const | INTNULL = 3 |
Integer type or null, maps to WebRequest::getIntOrNull() This is useful for the namespace selector. More... | |
Protected Member Functions | |
getValueReal ($option) | |
Return current option value, based on a structure taken from $options. More... | |
Protected Attributes | |
$options = [] | |
Map of known option names to information about them. More... | |
Helper class to keep track of options when mixing links and form elements.
Definition at line 35 of file FormOptions.php.
FormOptions::add | ( | $name, | |
$default, | |||
$type = self::AUTO |
|||
) |
Add an option to be handled by this FormOptions instance.
string | $name | Request parameter name |
mixed | $default | Default value when the request parameter is not present |
int | $type | One of the type constants (optional, defaults to AUTO) |
Definition at line 78 of file FormOptions.php.
References $name, $type, and options().
Referenced by SpecialNewFiles\execute(), SpecialLog\execute(), SpecialWhatLinksHere\execute(), FormOptionsTest\setUp(), and SpecialNewpages\setup().
FormOptions::consumeValue | ( | $name | ) |
Get the value of given option and mark it as 'consumed'.
Consumed options are not returned by getUnconsumedValues().
MWException | If the option does not exist |
string | $name | Option name |
Definition at line 214 of file FormOptions.php.
References $name, getValueReal(), options(), and validateName().
FormOptions::consumeValues | ( | $names | ) |
Get the values of given options and mark them as 'consumed'.
Consumed options are not returned by getUnconsumedValues().
MWException | If any option does not exist |
array | $names | Array of option names as strings |
Definition at line 230 of file FormOptions.php.
References $name, $out, as, getValueReal(), options(), and validateName().
FormOptions::delete | ( | $name | ) |
Remove an option being handled by this FormOptions instance.
This is the inverse of add().
string | $name | Request parameter name |
Definition at line 98 of file FormOptions.php.
References $name, options(), and validateName().
FormOptions::fetchValuesFromRequest | ( | WebRequest | $r, |
$optionKeys = null |
|||
) |
Fetch values for all options (or selected options) from the given WebRequest, making them available for accessing with getValue() or consumeValue() etc.
WebRequest | $r | The request to fetch values from |
array | $optionKeys | Which options to fetch the values for (default: all of them). Note that passing an empty array will also result in values for all keys being fetched. |
MWException | If the type of any option is invalid |
Definition at line 336 of file FormOptions.php.
References $name, $type, $value, as, WebRequest\getBool(), WebRequest\getFloat(), WebRequest\getInt(), WebRequest\getIntOrNull(), WebRequest\getText(), and options().
Referenced by SpecialNewFiles\execute(), SpecialWhatLinksHere\execute(), and SpecialNewpages\setup().
FormOptions::getAllValues | ( | ) |
Format options to an array ( name => value )
Definition at line 314 of file FormOptions.php.
References $name, as, getValueReal(), and options().
FormOptions::getChangedValues | ( | ) |
Return options modified as an array ( name => value )
Definition at line 298 of file FormOptions.php.
References $name, as, and options().
Referenced by SpecialWatchlist\setTopText().
FormOptions::getUnconsumedValues | ( | $all = false | ) |
Get all remaining values which have not been consumed by consumeValue() or consumeValues().
bool | $all | Whether to include unchanged options (default: false) |
Definition at line 280 of file FormOptions.php.
References $name, as, getValueReal(), and options().
FormOptions::getValue | ( | $name | ) |
Get the value for the given option name.
Uses getValueReal() internally.
string | $name | Option name |
Definition at line 175 of file FormOptions.php.
References $name, getValueReal(), options(), and validateName().
Referenced by NewFilesPager\__construct(), ActiveUsersPager\__construct(), SpecialWhatLinksHere\execute(), NewFilesPager\getQueryInfo(), offsetGet(), and SpecialLog\show().
|
protected |
Return current option value, based on a structure taken from $options.
array | $option | Array structure describing the option |
Definition at line 187 of file FormOptions.php.
Referenced by consumeValue(), consumeValues(), getAllValues(), getUnconsumedValues(), getValue(), and validateBounds().
|
static |
Used to find out which type the data is.
All types are defined in the 'Type constants' section of this class.
Detection of the INTNULL type is not supported; INT will be assumed if the data is an integer, MWException will be thrown if it's null.
mixed | $data | Value to guess the type for |
MWException | If unable to guess the type |
Definition at line 114 of file FormOptions.php.
Referenced by FormOptionsTest\guess().
FormOptions::offsetExists | ( | $name | ) |
Whether the option exists.
string | $name |
Definition at line 381 of file FormOptions.php.
FormOptions::offsetGet | ( | $name | ) |
Retrieve an option value.
string | $name |
Definition at line 390 of file FormOptions.php.
References $name, and getValue().
FormOptions::offsetSet | ( | $name, | |
$value | |||
) |
Set an option to given value.
string | $name | |
mixed | $value |
Definition at line 399 of file FormOptions.php.
References $name, $value, and setValue().
FormOptions::offsetUnset | ( | $name | ) |
Delete the option.
string | $name |
Definition at line 407 of file FormOptions.php.
References $name.
FormOptions::reset | ( | $name | ) |
Delete the option value.
This will make future calls to getValue() return the default value.
string | $name | Option name |
Definition at line 200 of file FormOptions.php.
References $name, options(), and validateName().
Referenced by SpecialRecentChanges\buildMainQueryConds().
FormOptions::setValue | ( | $name, | |
$value, | |||
$force = false |
|||
) |
Use to set the value of an option.
string | $name | Option name |
mixed | $value | Value for the option |
bool | $force | Whether to set the value when it is equivalent to the default value for this option (default false). |
Definition at line 158 of file FormOptions.php.
References $name, $value, options(), and validateName().
Referenced by SpecialNewFiles\execute(), SpecialWhatLinksHere\execute(), offsetSet(), SpecialLog\parseParams(), and validateBounds().
FormOptions::validateBounds | ( | $name, | |
$min, | |||
$max | |||
) |
Constrain a numeric value for a given option to a given range.
The value will be altered to fit in the range.
string | $name | Option name |
int | float | $min | Minimum value |
int | float | $max | Maximum value |
MWException | If option is not of type INT |
Definition at line 260 of file FormOptions.php.
References $name, $type, $value, getValueReal(), options(), setValue(), and validateName().
Referenced by validateIntBounds().
FormOptions::validateIntBounds | ( | $name, | |
$min, | |||
$max | |||
) |
Definition at line 245 of file FormOptions.php.
References $name, and validateBounds().
Referenced by SpecialNewFiles\execute(), SpecialWhatLinksHere\execute(), SpecialNewpages\setup(), and SpecialRecentChanges\validateOptions().
FormOptions::validateName | ( | $name, | |
$strict = false |
|||
) |
Verify that the given option name exists.
string | $name | Option name |
bool | $strict | Throw an exception when the option doesn't exist instead of returning false |
MWException |
Definition at line 138 of file FormOptions.php.
References $name, and options().
Referenced by consumeValue(), consumeValues(), delete(), getValue(), reset(), setValue(), and validateBounds().
|
protected |
Map of known option names to information about them.
Each value is an array with the following keys:
Definition at line 67 of file FormOptions.php.
Referenced by FormOptionsExposed\getOptions().
const FormOptions::AUTO = -1 |
Mark value for automatic detection (for simple data types only)
Definition at line 41 of file FormOptions.php.
const FormOptions::BOOL = 2 |
Boolean type, maps guessType() to WebRequest::getBool()
Definition at line 50 of file FormOptions.php.
Referenced by FormOptionsTest\assertGuessBoolean(), and SpecialActiveUsers\execute().
const FormOptions::FLOAT = 4 |
Float type, maps guessType() to WebRequest::getFloat()
Definition at line 48 of file FormOptions.php.
Referenced by FormOptionsTest\assertGuessFloat(), and SpecialWatchlist\getDefaultOptions().
const FormOptions::INT = 1 |
Integer type, maps guessType() to WebRequest::getInt()
Definition at line 45 of file FormOptions.php.
Referenced by FormOptionsTest\assertGuessInt(), and FormOptionsInitializationTest\testAddIntegers().
const FormOptions::INTNULL = 3 |
Integer type or null, maps to WebRequest::getIntOrNull() This is useful for the namespace selector.
Definition at line 54 of file FormOptions.php.
Referenced by SpecialLog\execute(), SpecialWhatLinksHere\execute(), ChangesListSpecialPage\getDefaultOptions(), and FormOptionsTest\setUp().
const FormOptions::STRING = 0 |
String type, maps guessType() to WebRequest::getText()
Definition at line 43 of file FormOptions.php.
Referenced by FormOptionsTest\assertGuessString(), and FormOptionsInitializationTest\testAddStringOption().