How to resolve "must be an instance of string, string given" prior to PHP 7?
Prior to PHP 7 type hinting can only be used to force the types of objects and arrays. Scalar types are not type-hintable. In this case an object of the class string
is expected, but you're giving it a (scalar) string
. The error message may be funny, but it's not supposed to work to begin with. Given the dynamic typing system, this actually makes some sort of perverted sense.
You can only manually "type hint" scalar types:
function foo($string) {
if (!is_string($string)) {
trigger_error('No, you fool!');
return;
}
...
}
From PHP's manual:
Type Hints can only be of the object and array (since PHP 5.1) type. Traditional type hinting with int and string isn't supported.
So you have it. The error message is not really helpful, I give you that though.
** 2017 Edit **
PHP7 introduced more function data type declarations, and the aforementioned link has been moved to Function arguments : Type declarations. From that page :
Valid types
- Class/interface name : The parameter must be an instanceof the given class or interface name. (since PHP 5.0.0)
- self : The parameter must be an instanceof the same class as the one the method is defined on. This can only be used on class and instance methods. (since PHP 5.0.0)
- array : The parameter must be an array. (since PHP 5.1.0)
- callable : The parameter must be a valid callable. (since PHP 5.4.0)
- bool : The parameter must be a boolean value. (since PHP 7.0.0)
- float : The parameter must be a floating point number. (since PHP 7.0.0)
- int : The parameter must be an integer. (since PHP 7.0.0)
- string : The parameter must be a string. (since PHP 7.0.0)
- iterable : The parameter must be either an array or an instanceof Traversable. (since PHP 7.1.0)
Warning
Aliases for the above scalar types are not supported. Instead, they are treated as class or interface names. For example, using boolean as a parameter or return type will require an argument or return value that is an instanceof the class or interface boolean, rather than of type bool:
<?php function test(boolean $param) {} test(true); ?>
The above example will output:
Fatal error: Uncaught TypeError: Argument 1 passed to test() must be an instance of boolean, boolean given, called in - on line 1 and defined in -:1
The last warning is actually significant to understand the error "Argument must of type string, string given"; since mostly only class/interface names are allowed as argument type, PHP tries to locate a class name "string", but can't find any because it is a primitive type, thus fail with this awkward error.