public static DataReferenceDefinition::createFromDataType($data_type)
Creates a new data definition object.
This method is typically used by \Drupal\Core\TypedData\TypedDataManager::createDataDefinition() to build a definition object for an arbitrary data type. When the definition class is known, it is recommended to directly use the static create() method on that class instead; e.g.:
1 | $map_definition = \Drupal\Core\TypedData\MapDataDefinition::create(); |
Parameters
string $data_type: The data type, for which a data definition should be created.
Return value
static
Throws
\InvalidArgumentException If an unsupported data type gets passed to the class; e.g., 'string' to a definition class handling 'entity:* data types.
Overrides DataDefinition::createFromDataType
File
- core/lib/Drupal/Core/TypedData/DataReferenceDefinition.php, line 37
Class
- DataReferenceDefinition
- A typed data definition class for defining references.
Namespace
Drupal\Core\TypedData
Code
1 2 3 4 5 6 7 | public static function createFromDataType( $data_type ) { if ( substr ( $data_type , - strlen ( '_reference' )) != '_reference' ) { throw new \InvalidArgumentException( 'Data type must be of the form "{TARGET_TYPE}_reference"' ); } // Cut of the _reference suffix. return static ::create( substr ( $data_type , 0, strlen ( $data_type ) - strlen ( '_reference' ))); } |
Please login to continue.