Re: Function __call

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



please keep replies on list unless your intending to pay me
an hourly fee ...

Diogo Neves schreef:
On Sat, Aug 30, 2008 at 4:40 PM, Jochem Maas <jochem@xxxxxxxxxxxxx> wrote:
Diogo Neves schreef:

...


nop... I wanna manipulate the $this and the $arguments, and possible
don't even execute the private method...

I'm tring to develop a "hook system" for my classes... and i simple
don't wanna to do all the hook verification every method of the class

I'll send my files for you to see what I'm doing in "do something" on
my __call() funtion

the code looks messy what with the global $hooks, functions required for hooking
(the function name class_hooker() is very funny btw) and you seem to
be mixing static/non-static class calls willy-nilly.

I'd rethink this if I we're you. if every can be hooked, then make the
hooking should be part of a base class, possibly a factory method for object
creation will help to keep things clean and in one place. a generic 'hooking'
decorator object might also be an idea. or maybe just using subclasses to
change/augment behaviour is a much simpler and cleaner approach.

your code makes me think of the hooking mechanism in WordPress ... works okay,
but it's a nightmare to code to (imho).

BTW. function and method names beginning with '__' are considered reserved
by the engine, it's not best practice to name userland functions/methods
things like '__magic'

On Sat, Aug 30, 2008 at 2:38 PM, Jochem Maas <jochem@xxxxxxxxxxxxx> wrote:
Diogo Neves schreef:
hi all,

I'm sending this email only to ask if someone know if the works of
__call in private methods is bug or feature.

ex.

class user {
public function __call ( $name, $arguments ) {
do something
return call_user_func( array( $this, $name ), $arguments );
the fatal error occurs because the method exists, but it's
private ... __call() is only called if the method does not exist
at all:

class user {
      public function __call($m, $a) {
              if (is_callable(array($this, "_".$m)))
                      return $this->{"_".$m}( $a );
      }

      private function _xpto($a)
      {
              var_dump($a);
      }
}

$u = new user;
$u->xpto(1, 2, 3);

}
private function xpto ( $arguments ) {
do something
}
}

new $user = new user();
the first 'new' is incorrect me thinks.

$user->xpto();

error:
Fatal error:  Call to private method user::xpto() from context '' in
xpto.php on line 11

PS:
what a fucking I was thinking?

well, it don't have this public method, then it sholdn't know it
exists, then go to __call()
i really don't know if it make any sense to someone else, but it still
make sense to me

any thoughts?


---- ----
Thanks by your attention,

Diogo Neves
Developer @ Sapo.pt by PrimeIT.pt

---- ----
Thanks by your attention,

Diogo Neves
Developer @ Sapo.pt by PrimeIT.pt





--
PHP General Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php


[Index of Archives]     [PHP Home]     [Apache Users]     [PHP on Windows]     [Kernel Newbies]     [PHP Install]     [PHP Classes]     [Pear]     [Postgresql]     [Postgresql PHP]     [PHP on Windows]     [PHP Database Programming]     [PHP SOAP]

  Powered by Linux