class MapNamingStrategy in Zircon Profile 8
Same name in this branch
- 8 vendor/zendframework/zend-hydrator/src/NamingStrategy/MapNamingStrategy.php \Zend\Hydrator\NamingStrategy\MapNamingStrategy
- 8 vendor/zendframework/zend-stdlib/src/Hydrator/NamingStrategy/MapNamingStrategy.php \Zend\Stdlib\Hydrator\NamingStrategy\MapNamingStrategy
Same name and namespace in other branches
- 8.0 vendor/zendframework/zend-hydrator/src/NamingStrategy/MapNamingStrategy.php \Zend\Hydrator\NamingStrategy\MapNamingStrategy
Hierarchy
- class \Zend\Hydrator\NamingStrategy\MapNamingStrategy implements NamingStrategyInterface
Expanded class hierarchy of MapNamingStrategy
1 file declares its use of MapNamingStrategy
- MapNamingStrategy.php in vendor/
zendframework/ zend-stdlib/ src/ Hydrator/ NamingStrategy/ MapNamingStrategy.php
File
- vendor/
zendframework/ zend-hydrator/ src/ NamingStrategy/ MapNamingStrategy.php, line 14
Namespace
Zend\Hydrator\NamingStrategyView source
class MapNamingStrategy implements NamingStrategyInterface {
/**
* Map for hydrate name conversion.
*
* @var array
*/
protected $mapping = [];
/**
* Reversed map for extract name conversion.
*
* @var array
*/
protected $reverse = [];
/**
* Initialize.
*
* @param array $mapping Map for name conversion on hydration
* @param array $reverse Reverse map for name conversion on extraction
*/
public function __construct(array $mapping, array $reverse = null) {
$this->mapping = $mapping;
$this->reverse = $reverse ?: $this
->flipMapping($mapping);
}
/**
* Safelly flip mapping array.
*
* @param array $array Array to flip
* @return array Flipped array
* @throws InvalidArgumentException
*/
protected function flipMapping(array $array) {
array_walk($array, function ($value) {
if (!is_string($value) && !is_int($value)) {
throw new InvalidArgumentException('Mapping array can\'t be flipped because of invalid value');
}
});
return array_flip($array);
}
/**
* Converts the given name so that it can be extracted by the hydrator.
*
* @param string $name The original name
* @return mixed The hydrated name
*/
public function hydrate($name) {
if (array_key_exists($name, $this->mapping)) {
return $this->mapping[$name];
}
return $name;
}
/**
* Converts the given name so that it can be hydrated by the hydrator.
*
* @param string $name The original name
* @return mixed The extracted name
*/
public function extract($name) {
if (array_key_exists($name, $this->reverse)) {
return $this->reverse[$name];
}
return $name;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
MapNamingStrategy:: |
protected | property | Map for hydrate name conversion. | |
MapNamingStrategy:: |
protected | property | Reversed map for extract name conversion. | |
MapNamingStrategy:: |
public | function |
Converts the given name so that it can be hydrated by the hydrator. Overrides NamingStrategyInterface:: |
|
MapNamingStrategy:: |
protected | function | Safelly flip mapping array. | |
MapNamingStrategy:: |
public | function |
Converts the given name so that it can be extracted by the hydrator. Overrides NamingStrategyInterface:: |
|
MapNamingStrategy:: |
public | function | Initialize. |