Hi all, Here is more code, with a test case included. What I would prefer to do is call TypeAssist::$string(), instead of TypeAssist::$a->string(). Or at least __construct() the $a object. <code> <?php if (!class_exists('TypeAssert')) { class TypeAssert { public static $a; public static $assert; private static $types = array( 'array','bool','float','integer','null','numeric', 'object','resource','scalar','string' ); function __construct() { self::$assert =& self::$a; } public static function __call($method,$arguments) { $obj = self::assertStandardTypes($arguments[0]); return $obj->$method; } public static function assertStandardTypes($para) { $r = TypeAssert::getTypesObject(); foreach ($r as $type=>$v) { $func = "is_".strtolower($type); if (function_exists($func) === true) { if ($func($para) === true) { $r->$type = true; } else { $r->$type = false; } } } return $r; } public static function getTypesObject() { $obj = (object) ''; for ($i = 0; $i < count(self::$types); $i++) { $obj->{self::$types[$i]} = (bool) false; } return $obj; } } } TypeAssert::$a = new TypeAssert(); echo("<pre>\n"); switch($_GET['type']) { case 'int': $test = 100; $_test = 100; break; case 'float': $test = 100.001; $_test = 100.001; break; case 'null': $test = null; $_test = 'null'; break; case 'object': $test = TypeAssert::$a; $_test = '[object]'; break; default: $test = 'string'; $_test = 'string'; break; } foreach (TypeAssert::getTypesObject() as $type => $v) { echo("<div>is_<b style=\"color: #00a;\">$type</b>(<b>$_test</b>) === ". (TypeAssert::$assert->$type($test)? '<b style="color: #0a0;">true</b>': '<b style="color: #a00;">false</b>'). "</div>\n" ); } echo("</pre>\n"); ?> </code> Original Message Text
Hi all, I am building an assertType object using static functions. What I want to keep away from is the following: <code> public static function assertString($para){ return $answer; }; public static function assertBool($para){ return $answer; }; ... public static function assertArray($para){ return $answer; }; </code> What I would like to do is replace this with the following: <code> if (!class_exists('TypeAssert')) { class TypeAssert { private static $types = array( 'array','bool','float','integer','null','numeric', 'object','resource','scalar','string' ); public static function __call($method,$arguments) { $obj = self::assertStandardTypes($arguments[0]); return $obj->$method; } public static function assertStandardTypes($para) { $r = TypeAssert::getTypesObject(); if (is_array($para)) $r->array = true; if (is_bool($para)) $r->bool = true; if (is_float($para)) $r->float = true; if (is_integer($para)) $r->integer = true; if (is_null($para)) $r->null = true; if (is_numeric($para)) $r->numeric = true; if (is_object($para)) $r->object = true; if (is_resource($para)) $r->resource = true; if (is_scalar($para)) $r->scalar = true; if (is_string($para)) $r->string = true; return $r; } public static function getTypesObject() { $obj = (object) ''; for ($i = 0; $i < count(self::$types); $i++) { $obj->{self::$types[$i]} = (bool) false; } return $obj; } } } echo('<pre>'); echo(TypeAssert::string('test')); echo('</pre>'); </code> I don't think this is possible (see http://marc.info/?l=php-general&m=114558851102060&w=2 ). But I would LIKE for it to work (currently, the above code doesn't). Anybody have any insight on how I might get this to work? Thanks! -- Jared Farrish Intermediate Web Developer Denton, Tx Abraham Maslow: "If the only tool you have is a hammer, you tend to see every problem as a nail." $$
-- Jared Farrish Intermediate Web Developer Denton, Tx Abraham Maslow: "If the only tool you have is a hammer, you tend to see every problem as a nail." $$