On Thu, Dec 4, 2014 at 1:17 PM, Julien Pauli <jpa...@php.net> wrote:

> On Thu, Dec 4, 2014 at 12:39 PM, Ferenc Kovacs <tyr...@gmail.com> wrote:
> >
> >
> > On Thu, Dec 4, 2014 at 11:53 AM, Julien Pauli <jpa...@php.net> wrote:
> >>
> >> On Thu, Dec 4, 2014 at 9:30 AM, Benjamin Eberlei <kont...@beberlei.de>
> >> wrote:
> >> > Good morning,
> >> >
> >> > This is just a very small change, I propose this RFC for discussion to
> >> > turn
> >> > the C function "gc_collect_cycles" into a pointer.
> >> >
> >> > https://wiki.php.net/rfc/gc_fn_pointer
> >> >
> >> > Composer's garbage collection optimization showed that PHP Profilers
> >> > fail
> >> > to capture the dynamics of GC and we need better hooks to make this
> >> > possible.
> >>
> >> There are many other things that could be turned into function
> >> pointers to allow extensions to hook.
> >> Our hook strategy should be reviewed entirely.
> >>
> >> Not only GC. If you look at streams, many of them are not
> >> overwritable, and some are, but they are missing from the headers file
> >> so you may not overwrite them.
> >>
> >> I suggest we design a wider RFC for PHP7 about what we would be able
> >> to hook, and what not (and what is the impact, because the more you
> >> hook , the more complex it becomes about bad interactions).
> >>
> >> This may also include a refactoring in the zend_module_entry and the
> >> zend_extension structs. Fe, zend_extension hooks about the op_array
> >> could be reworked , I find the op_array_dtor_handler hook misplaced in
> >> the chain.
> >> zend_module_entry could also benefit from refactoring to have a better
> >> knowing of other extensions, and a true dependency manager.
> >>
> >
> > That sounds like a lot of work.
> > +1 if somebody willing to champion that effort, but I wouldn't
> delay/discard
> > this small improvement on the vague promise that maybe this will be
> solved
> > as part of a bigger rfc.
> > just my 2 cents ofc.
>
> Yep, but the problem in adding a new hook is that today its for
> feature A, tomorrow it will be for feature B, etc...
> There is a risk of lack of consistency between all the ideas, that's
> why I myself did not propose any single idea in this way, but prefer
> merging them and propose something more consistent.
> We could benefit from a new major release to have a more global
> hooking strategy.
> Also, as this changes the ABI by publishing a new ZEND_API, we should
> consider adding this in a major and not in a stable release (even
> thought that doesnt break the ABI).
>
> I agree some ideas may represent more work than others (like a
> dependency management system for extensions), however, big part of the
> ideas is just about "what hook to move", "where to", "why" and "what
> hook to add" (and why).
>
> Also, having too many hooks can lead to many problems like extensions
> incompatibility, something barely taken care of in our module API, but
> which should as well be redesigned as it doesn't really work that
> much.
>
> Julien.P
>

Those are all solid ideas and I wouldn't go against them if proposed, I'm
just a bit afraid that we end up with
http://en.wikipedia.org/wiki/Nirvana_fallacy where we reject small ideas on
the ground of not being perfect or part of a bigger scheme while we don't
have the resources to actually make those bigger schemes a reallity.
Let see what the others think though.

-- 
Ferenc Kovács
@Tyr43l - http://tyrael.hu

Reply via email to