> What happens if you say <<$x>> and then call $reflection->getAttributes() in 
> your eample? what is $x?
>
> That is the problem with immediately evaluating everything non "constant". 
> There is no context.

There's is no context. Annotations should be context-free - that's by design.

There's also no $this, and no self:: or static:: either, because the
annotations are supposed to be context-free. They're meta-data, not
functions - you already have functions, interfaces, abstract methods
etc. for that.

Suppose you don't have an instance of a class yet, and you reflect and
try to get the value of something that requires context - it doesn't
exist yet. Then what? Obtaining the meta-data before you have an
instance is a common use-case, for example when generating schema from
table/column meta-data attached to entities, you don't have an
instance yet - you're inspecting the class, methods and properties,
not an object.

If you insist on putting something in annotations that requires
context, what you should put in there, is an anonymous function - e.g.
a function that expects the consumer to provide the context, such that
you're not dependent on some implied context, instead you're asking
for a specific context. Dependency injection - good stuff. There's an
example of that in my comment below the gist.

Though personally I would never, ever put functionality in an
annotation - it's a huge misunderstanding, in my opinion. If what you
wanted was executable functionality that requires a context, what you
really want is an interface that you can implement. Context requires a
contract.

Just my opinion, of course, and there's nothing stopping you from
using functions if that's your fancy. And it's much safer and
friendlier to readers, and static analysis tools, not to expect a
run-time context to always be established by the consumer.

Either way, the majority use-case is attaching meta-data to
classes/properties/methods - wanting to attach code and evaluate it at
run-time is a marginal use-case. Designing the whole thing for that
first, and sacrificing all the flexibility of the language itself by
inventing an entirely new concept, which is entirely dependent on
run-time interpretation, in my opinion, is just completely backwards,
when you can do something much, much simpler with far more freedom and
options and design-time safety.


On Thu, May 12, 2016 at 9:27 PM, Benjamin Eberlei <kont...@beberlei.de> wrote:
>
>
> On Thu, May 12, 2016 at 9:02 PM, Rasmus Schultz <ras...@mindplay.dk> wrote:
>>
>> My problem with this PSR is you've created something that strongly
>> resembles function or constructor calls, but in reality is just
>> key/value pairs.
>
>
> Its actually function calls, not constructors calls :-)
>>
>>
>> That's confusing in itself, but also puts an unnecessary burden on
>> consumers who have to figure out how to map this apparently
>> "something" to "something real" - since it really isn't anything other
>> than pretty syntax for arrays associated with source-code elements.
>>
>> Did anybody look at my notes here?
>>
>> https://gist.github.com/mindplay-dk/ebd5e4f7da51da3c4e56232adef41b46
>>
>> I think this is much simpler and far more flexible - it lets you do
>> what you're proposing with attributes (by annotating with simple
>> arrays) and also lets you create annotation classes.
>>
>> Would anyone care to comment?
>
>
> What happens if you say <<$x>> and then call $reflection->getAttributes() in
> your eample? what is $x?
>
> That is the problem with immediately evaluating everything non "constant".
> There is no context.
>>
>>
>>
>> On Thu, May 12, 2016 at 4:53 PM, Marco Pivetta <ocram...@gmail.com> wrote:
>> > On 12 May 2016 at 16:29, Benjamin Eberlei <kont...@beberlei.de> wrote:
>> >
>> >> On Tue, May 10, 2016 at 8:29 PM, Dmitry Stogov <dmi...@zend.com> wrote:
>> >>
>> >> > Hi internals,
>> >> >
>> >> >
>> >> > I've started voting on "PHP Attributes" RFC.
>> >> >
>> >> >
>> >> > https://wiki.php.net/rfc/attributes
>> >> >
>> >> >
>> >> > In my opinion, "PHP Attributes" might be a smart tool for PHP
>> >> > extension,
>> >> > but it's not going to be the end of the world, if we decided to live
>> >> > with
>> >> > doc-comments only.
>> >> >
>> >> >
>> >> > Thanks. Dmitry.
>> >> >
>> >>
>> >> I voted -1
>> >>
>> >> Reasons: from a Doctrine Annotations maintainer perspective, either
>> >> getting
>> >> a list (without keys) of strings back or ast\nodes are not enough or
>> >> way
>> >> too advanced for our use-case. The middle ground is missing where a
>> >> <php-constant> (Name borrowed from the RFC) can be an arbitrarily deep
>> >> nested array, that means getAttributes() does should not only return
>> >> "string" or ast\node as result for each attribute, to there should be a
>> >> way
>> >> to get arrays back.
>> >>
>> >> Example:
>> >>
>> >> https://gist.github.com/beberlei/18db9f7d5f6157b817348a58fa2aee25
>> >>
>> >> greetings
>> >> Benjamin
>> >>
>> >
>> > Urgh, that is indeed quirky, and makes it unusable.
>> >
>> > Is that an implementation or a spec issue? I know PHP 5.6+ allows array
>> > constants, but I am not aware of whether that is in the specification.
>> >
>> > Indeed, show-stopper here. I'll have to vote "-1" for now, and wait for
>> > a
>> > version that either explicitly contains any constant expression or just
>> > supports arrays as constants.
>> >
>> > I'll also need to compile the branch and try it out myself before voting
>> > further: my bad for being hasty.
>> >
>> > Marco Pivetta
>> >
>> > http://twitter.com/Ocramius
>> >
>> > http://ocramius.github.com/
>
>

-- 
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to