class FormFieldRegistry in Zircon Profile 8
Same name and namespace in other branches
- 8.0 vendor/symfony/dom-crawler/FormFieldRegistry.php \Symfony\Component\DomCrawler\FormFieldRegistry
This is an internal class that must not be used directly.
Hierarchy
- class \Symfony\Component\DomCrawler\FormFieldRegistry
Expanded class hierarchy of FormFieldRegistry
1 file declares its use of FormFieldRegistry
- FormTest.php in vendor/
symfony/ dom-crawler/ Tests/ FormTest.php
File
- vendor/
symfony/ dom-crawler/ FormFieldRegistry.php, line 19
Namespace
Symfony\Component\DomCrawlerView source
class FormFieldRegistry {
private $fields = array();
private $base;
/**
* Adds a field to the registry.
*
* @param FormField $field The field
*
* @throws \InvalidArgumentException when the name is malformed
*/
public function add(FormField $field) {
$segments = $this
->getSegments($field
->getName());
$target =& $this->fields;
while ($segments) {
if (!is_array($target)) {
$target = array();
}
$path = array_shift($segments);
if ('' === $path) {
$target =& $target[];
}
else {
$target =& $target[$path];
}
}
$target = $field;
}
/**
* Removes a field and its children from the registry.
*
* @param string $name The fully qualified name of the base field
*
* @throws \InvalidArgumentException when the name is malformed
*/
public function remove($name) {
$segments = $this
->getSegments($name);
$target =& $this->fields;
while (count($segments) > 1) {
$path = array_shift($segments);
if (!array_key_exists($path, $target)) {
return;
}
$target =& $target[$path];
}
unset($target[array_shift($segments)]);
}
/**
* Returns the value of the field and its children.
*
* @param string $name The fully qualified name of the field
*
* @return mixed The value of the field
*
* @throws \InvalidArgumentException when the name is malformed
* @throws \InvalidArgumentException if the field does not exist
*/
public function &get($name) {
$segments = $this
->getSegments($name);
$target =& $this->fields;
while ($segments) {
$path = array_shift($segments);
if (!array_key_exists($path, $target)) {
throw new \InvalidArgumentException(sprintf('Unreachable field "%s"', $path));
}
$target =& $target[$path];
}
return $target;
}
/**
* Tests whether the form has the given field.
*
* @param string $name The fully qualified name of the field
*
* @return bool Whether the form has the given field
*/
public function has($name) {
try {
$this
->get($name);
return true;
} catch (\InvalidArgumentException $e) {
return false;
}
}
/**
* Set the value of a field and its children.
*
* @param string $name The fully qualified name of the field
* @param mixed $value The value
*
* @throws \InvalidArgumentException when the name is malformed
* @throws \InvalidArgumentException if the field does not exist
*/
public function set($name, $value) {
$target =& $this
->get($name);
if (!is_array($value) && $target instanceof Field\FormField || $target instanceof Field\ChoiceFormField) {
$target
->setValue($value);
}
elseif (is_array($value)) {
$fields = self::create($name, $value);
foreach ($fields
->all() as $k => $v) {
$this
->set($k, $v);
}
}
else {
throw new \InvalidArgumentException(sprintf('Cannot set value on a compound field "%s".', $name));
}
}
/**
* Returns the list of field with their value.
*
* @return FormField[] The list of fields as array((string) Fully qualified name => (mixed) value)
*/
public function all() {
return $this
->walk($this->fields, $this->base);
}
/**
* Creates an instance of the class.
*
* This function is made private because it allows overriding the $base and
* the $values properties without any type checking.
*
* @param string $base The fully qualified name of the base field
* @param array $values The values of the fields
*
* @return FormFieldRegistry
*/
private static function create($base, array $values) {
$registry = new static();
$registry->base = $base;
$registry->fields = $values;
return $registry;
}
/**
* Transforms a PHP array in a list of fully qualified name / value.
*
* @param array $array The PHP array
* @param string $base The name of the base field
* @param array $output The initial values
*
* @return array The list of fields as array((string) Fully qualified name => (mixed) value)
*/
private function walk(array $array, $base = '', array &$output = array()) {
foreach ($array as $k => $v) {
$path = empty($base) ? $k : sprintf('%s[%s]', $base, $k);
if (is_array($v)) {
$this
->walk($v, $path, $output);
}
else {
$output[$path] = $v;
}
}
return $output;
}
/**
* Splits a field name into segments as a web browser would do.
*
* <code>
* getSegments('base[foo][3][]') = array('base', 'foo, '3', '');
* </code>
*
* @param string $name The name of the field
*
* @return string[] The list of segments
*
* @throws \InvalidArgumentException when the name is malformed
*/
private function getSegments($name) {
if (preg_match('/^(?P<base>[^[]+)(?P<extra>(\\[.*)|$)/', $name, $m)) {
$segments = array(
$m['base'],
);
while (!empty($m['extra'])) {
if (preg_match('/^\\[(?P<segment>.*?)\\](?P<extra>.*)$/', $m['extra'], $m)) {
$segments[] = $m['segment'];
}
else {
throw new \InvalidArgumentException(sprintf('Malformed field path "%s"', $name));
}
}
return $segments;
}
throw new \InvalidArgumentException(sprintf('Malformed field path "%s"', $name));
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
FormFieldRegistry:: |
private | property | ||
FormFieldRegistry:: |
private | property | ||
FormFieldRegistry:: |
public | function | Adds a field to the registry. | |
FormFieldRegistry:: |
public | function | Returns the list of field with their value. | |
FormFieldRegistry:: |
private static | function | Creates an instance of the class. | |
FormFieldRegistry:: |
public | function | Returns the value of the field and its children. | |
FormFieldRegistry:: |
private | function | Splits a field name into segments as a web browser would do. | |
FormFieldRegistry:: |
public | function | Tests whether the form has the given field. | |
FormFieldRegistry:: |
public | function | Removes a field and its children from the registry. | |
FormFieldRegistry:: |
public | function | Set the value of a field and its children. | |
FormFieldRegistry:: |
private | function | Transforms a PHP array in a list of fully qualified name / value. |