ID: 46373 Updated by: [EMAIL PROTECTED] Reported By: phpbugs at sevenlight dot com -Status: Bogus +Status: Open Bug Type: Scripting Engine problem Operating System: OSX 10.5.5 PHP Version: 5.3CVS-2008-10-23 (snap) New Comment:
Thank you for this bug report. To properly diagnose the problem, we need a short but complete example script to be able to reproduce this bug ourselves. A proper reproducing script starts with <?php and ends with ?>, is max. 10-20 lines long and does not require any external resources such as databases, etc. If the script requires a database to demonstrate the issue, please make sure it creates all necessary tables, stored procedures etc. Please avoid embedding huge scripts into the report. Well, I can't reproduce it. namespace MyNamespace; class foo { public function test(bla::foobar $a) { } } $x = new foo; #$x->test(new stdclass); /* Catchable fatal error: Argument 1 passed to MyNamespace::foo::test() must be an instance of bla::foobar, instance of stdClass given ... */ #$x->test(NULL); /* Catchable fatal error: Argument 1 passed to MyNamespace::foo::test() must be an instance of bla::foobar, null given, called in ... */ $reflect = new ReflectionClass(__NAMESPACE__ .'::foo'); $y = $reflect->getMethod('test'); #$y->invoke(new foo, 1); /* Catchable fatal error: Argument 1 passed to MyNamespace::foo::test() must be an instance of bla::foobar, integer given */ Previous Comments: ------------------------------------------------------------------------ [2008-10-23 21:46:47] phpbugs at sevenlight dot com That is not the issue. The issue is that I DO NOT want NULLs to be accepted, yet they are being accepted (ie. no error be thrown). The issue is that I want an instance of Class A and if I pass it an instance of Class B, it is still accepted (Class B is not a child of Class A). The issue is if I pass ANY value of ANY kind if is accepted. The issue is if I ask for a non-existant class, no error is thrown at all... In all of these instances, errors should be thrown, but they are not being thrown. This is why I am seeking advice as to why this might be happening, and how I might be able to debug the actual PHP C code to figure out what is wrong... -Andrew ------------------------------------------------------------------------ [2008-10-23 21:25:14] [EMAIL PROTECTED] Using $x = new myclass; $x->execute();, i got: Catchable fatal error: Argument 1 passed to MyNamespace::MyClass::test() must be an instance of MyBogusNamespace::MyBogusClass, null given, called ... If you want accept NULL to be passed, it must be the default value to the parameter. public function test(MyBogusNamespace::MyBogusClass $m = NULL) So, we will have... Method [ <user> public method test ] { @@ ... 15 - 22 - Parameters [1] { Parameter #0 [ <optional> MyBogusNamespace::MyBogusClass or NULL $m = NULL ] } } Thanks. ------------------------------------------------------------------------ [2008-10-23 21:06:45] phpbugs at sevenlight dot com Can nobody provide any assistance? I realize I cannot provide a small test-case script, but that is because this exact same script works fine in the smaller test cases. I am looking for any advice as to how I can help track down the cause of this bug. If I need to add some debugging code to the PHP source and recompile, or something else, I'm willing to do this, I just need some guidance. I've covered the extent of what I can come up with to test out inside my PHP code itself, and the bug is at the point where I feel that it would need some modifications to the PHP code for debugging purposes, but I have no experience in debugging the PHP C code. I can get around debugging C, but not debugging PHP in C. I know your job is impossible without a test case, but please give me some help in getting you a test case. The bug is obviously not simple enough that a 10 line test case will trigger it (although maybe it can, but I don't know how to yet). Thank you, -Andrew ------------------------------------------------------------------------ [2008-10-23 20:54:21] [EMAIL PROTECTED] Thank you for taking the time to write to us, but this is not a bug. Please double-check the documentation available at http://www.php.net/manual/ and the instructions on how to report a bug at http://bugs.php.net/how-to-report.php ------------------------------------------------------------------------ [2008-10-23 18:50:07] phpbugs at sevenlight dot com Description: ------------ Using a type-hint with a namespace does not work. It allows an object of a different class to be passed, and even allows a bogus namespace to be used. It will also allow null variables, and will pass through any value, no matter what class type-hinting you use. Unfortunately, in my simplest test cases I have not been able to reproduce it, it is only in my larger project that it causes this problem. I really don't know where to start with this, and how to duplicate it. Needless to say, have provided the failing code from my project. The entire project is several thousand lines of code. And I've really done my best to track down the problem, even using the 5.3-alpha3-dev. I'll include the code that causes the problem. I really don't know what's wrong, and why it is doing it. Any hints as to what I might be able to do to try to reproduce this in a simpler way would be nice, but I really don't know where to go from here. Reproduce code: --------------- <?php namespace MyNamespace; class MyClass { // execute public function execute() { $this->test(NULL); return $this->_execute($this->_mc); } protected function test(MyBogusNamespace::MyBogusClass $m) { $reflect = new ReflectionClass(get_class($this)); $method = $reflect->getMethod('test'); echo $method; var_export($m); echo "\n\nClass: " . get_class($m) . " == MyBogusNamespace::MyBogusClass\n\n"; } } ?> Expected result: ---------------- Catchable fatal error: Argument 1 passed to MyNamespace::MyClass::test() must be an instance of MyBogusNamespace::MyBogusClass, null given, called in /srv/www/test/ns/new.php on line 9 and defined in /srv/www/test/ns/new.php on line 13 Actual result: -------------- Method [ <user> protected method test ] { @@ /srv/spin/spin4/spinnaker/extender/universal/tablelibrary.php 73 - 80 - Parameters [1] { Parameter #0 [ <required> MyBogusNamespace::MyBogusClass $m ] } } NULL == MyBogusNamespace::MyBogusClass ------------------------------------------------------------------------ -- Edit this bug report at http://bugs.php.net/?id=46373&edit=1