Skip to content

Latest commit

 

History

History
216 lines (164 loc) · 5.8 KB

supported_types.md

File metadata and controls

216 lines (164 loc) · 5.8 KB

Supported types

You are viewing this content from Github (that does not support video embedding. Click here to view the video.

<iframe width="853" height="480" src="//www.youtube.com/embed/vRSVk6JnyOE?rel=0&vq=hd720" frameborder="0" allowfullscreen></iframe>

Finished the video? Learn more about using PHP code for injection >

There are 4 kinds of supported types:

  • Primitive types
  • Classes and interfaces
  • Arrays (and associative arrays)
  • Mixed types

Note: if you are using a third party library that requires injecting a type that is not supported, you can always fallback to injecting values via PHP code.

##Primitive types

Mouf supports those primitive types: string, char, bool, boolean, int, integer, double, float, real, mixed, number

If your type is one of those, you will be able to input text directly in the property in Mouf UI. Note that there is a special behaviour for "bool" and "boolean". They are rendered as a checkbox in Mouf UI.

For instance:

class Wizard {
	...
	/**
	 * @param string $name The name of the wizard
	 * @param int $hp The hit points of the wizard
	 * @param bool $isAlive Whether the wizard is alive or not
	 */
	public function __construct($name, $hp, $isAlive) {
		...
	}
	...
}

Primitive properties

##Classes and interfaces

We already saw that classes and interfaces can be used as types in the example above.

In the Mouf user interface, these properties will be displayed like this:

class Wizard {
	...
	/**
	 * The best pal of the wizard.
	 * @param Warrior $sideKick
	 */
	public function setSideKick(Warrior $sideKick) {
		$this->sideKick = $sideKick;
	}
	...
}

Object properties

Best practice: As much as possible, try putting on interface as the type instead of a class. This is more flexible.

##Arrays

Mouf does a difference between indexed arrays and associative arrays (aka maps). Inside an array, you can inject primitive types or objects (but you cannot mix both, unless you use the injection via PHP code feature).

###Indexed arrays

Here are 2 samples of indexed arrays.

class Wizard {
	...
	/**
	 * The words the wizard pronounces.
	 * @param array<string> $wordsOfPower
	 */
	public function setWordsOfPower(array $wordsOfPower) {
		$this->wordsOfPower = $wordsOfPower;
	}

	/**
	 * The spells this wizard knows.
	 * @param SpellInterface[] $spells
	 */
	public function setSpells(array $spells) {
		$this->spells = $spells;
	}
	...
}

Indexed arrays

As you can notice, there are 2 ways to write arrays: using brackets or the array keyword.

Therefore, string[] and array<string> are similar.

###Associative arrays (aka maps)

Here are 2 samples of maps.

class Wizard {
	...
	/**
	 * This wizard's masters => a map of Wizard objects
	 * @param array<string, Wizard> $masters
	 */
	public function setMasters(array $masters) {
		$this->masters = $masters;
	}
	
	/**
	 * This wizard's name in many contries.
	 * The key is the country code, the value is the name.
	 * @param array<string, string> $internationalNames
	 */
	public function setInternationalNames(array $internationalNames) {
		$this->internationalNames = $internationalNames;
	}
	...
}

Arrays

As you can notice, associative arrays (or maps) can only be achieved using the array<xxx, xxx> notation.

###Generic "array" type

The "pure" array type is unsupported.

class Wizard {
	...
	/**
	 * This is not supported
	 * @var array
	 */
	public $unsupported;
}
If you are trying to create an instance of a class provided by a third party library, it is likely that you will have at some point a property whose type is array. Mouf has no clue what can be injected in an array (is it an array of strings? of objects? a map? In this case, you can still inject the value you want by using the inject property by PHP code option that will let you type some PHP code to fill the property.

##Mixed types

Mouf does not support the mixed keyword. However, you can use a pipe to declare that a property can have many different types.

For instance:

  • string|Healer|Warrior|Wizard is a valid type

Let's rewrite the "sideKick" setter and assume that the sidekick of our wizard can be anything (a warrior, a healer, another wizard or simply a string containing the name of someone:

class Wizard {
	...
	/**
	 * The best pal of the wizard.
	 * @param string|Healer|Warrior|Wizard $sideKick
	 */
	public function setSideKick($sideKick) {
		$this->sideKick = $sideKick;
	}
	...
}

Multitype

Using the UI, you can choose the type you want to inject by clicking on it.

Using mixed types can be sometimes convenient, but is generally not a great idea. As much as possible, the parameter's type of a constructor or a setter should be clearly defined. Use this feature sparingly.