In conjunction to my vote, I really think Pierrick's proposal and patch is
worth another look if we talk implementation.

On Mon, Nov 15, 2010 at 8:43 PM, Pierrick Charron <pierr...@webstart.fr>wrote:

> +1
>
> On 15 November 2010 21:27, guilhermebla...@gmail.com <
> guilhermebla...@gmail.com> wrote:
>
> > @Zeev: That topic was related to an already built patch, which some
> > where in favor, some against. That discussion lead to nowhere.
> > So I opened a thread topic by topic for some democracy approval. As
> > soon as we reach some reasonable consensus, we can start another patch
> > implementation based on what we end up with this thread.
> >
> > If result of the poll says "OK" to meta attribute, then we can discuss
> > next topic (possible implementations).
> > Until then, I'd rather appreciate everyone to stick to their votes
> > instead of revamp another discussion that lead to nothing.
> >
> > BTW, I forgot to add my vote:
> >
> > +1
> >
> > On Mon, Nov 15, 2010 at 8:22 PM, Zeev Suraski <z...@zend.com> wrote:
> > > I don't see a point in repeating the discussion we've already had on
> that
> > topic several weeks ago.  There needs to be an overwhelmingly good reason
> to
> > add a brand new syntax to the language, a whole branch of it in the case
> of
> > annotations - and there simply isn't.
> > >
> > > Zeev
> > >
> > >> -----Original Message-----
> > >> From: guilhermebla...@gmail.com [mailto:guilhermebla...@gmail.com]
> > >> Sent: Monday, November 15, 2010 7:08 PM
> > >> To: PHP internals
> > >> Subject: [PHP-DEV] PHP 5.4 - Meta attribute (aka. Annotations) support
> > >> discussion
> > >>
> > >> Hi folks,
> > >>
> > >> I'll start a series of topics (in this thread) about meta attribute
> > (aka.
> > >> Annotations) discussion.
> > >> So as soon as we agree on each topic I'll open another point to be
> > discussed.
> > >> Only when we reach some consensus I'll open another topic discussion.
> > >> I suggest to have a poll for each topic, so we can do some democratic
> > >> internals decision. I'd reduce the scope of voters to only people with
> > PHP
> > >> karma.
> > >>
> > >> The first topic to be defined is: Does PHP need meta attribute
> support?
> > >>
> > >> Any language is built at the top of syntax, words, semantics and
> > context.
> > >> We cannot define it as a language if we don't have these 4 parts well
> > fit
> > >> together.
> > >> For a simple sentence like: I am all ears, we can easily identify
> these
> > parts.
> > >> But the real meaning of this sentence (context) is only achieved with
> > another
> > >> part of the language: signifier-significate.
> > >> A signifier is an atomic form, material element, visible, sensitive.
> > >> A significate is an idea, semantic content, conceptual element, not
> > sensitive
> > >> perceptive.
> > >>
> > >> This important part is only reminded when we get back to semantics,
> > >> specifically when talking about idiomatic expressions, a metaphor in
> our
> > >> sample. The meaning will only work if we have the context, a known
> > >> information. Our sentence would mean that spoker person only have
> ears,
> > >> while the true meaning is that he/she is paying attention.
> > >> A computer language doesn't differ from a language by any means. We
> have
> > >> tokens (words), a syntax, semantic. But the lack of contextualization
> > brings a
> > >> hole on language and how your application should behave. This behavior
> > can
> > >> be achieved by many different ways; the simplest way is known as meta
> > >> information.
> > >>
> > >> Considering you have a lack of idiomatic expressions knowledge of
> > someone
> > >> that is reading. He'd think person only have ears, but if you meta
> > notify him
> > >> that it is a metaphor, he'd try to find a different meaning. Example:
> > >> (Metaphor) I am all ears.
> > >>
> > >> Now that we find how meta-information can benefit languages, it is
> time
> > to
> > >> understand how meta-information can benefit a computer language.
> > >>
> > >> A good example is define a Service that validates Domain Objects.
> > >> Imagining a scenario where you have a User class that holds email and
> > >> password. Email and password fields must be validated, for example,
> > email
> > >> as an email and password with at least 6 chars. A generic validation
> > service
> > >> could not have the User validation hardcoded inside the service, so
> the
> > >> solution would be an external factor that explains to service how to
> > validate
> > >> the DO. One of the possible implementations would be a UserValidator
> > class
> > >> that contains validation rules for each field. This external factor is
> a
> > good
> > >> sample of meta-information. But how would a meta attribute would solve
> > >> this situation?
> > >> A Service could simple retrieve the validation instructions by
> > Reflecting the
> > >> class which instance is going to be validated.
> > >> Basically, to validate a Domain Object, it is simply required to add
> > validation
> > >> rules on desired attributes. Example:
> > >>
> > >> class User {
> > >>     <Email Meta Information>
> > >>     protected $email;
> > >>
> > >>     <At least 6 chars Meta Information>
> > >>     protected $password;
> > >> }
> > >>
> > >> *NOTE*: Please understand that this do not enter in any implementation
> > >> details. It is not time (yet) to talk baout docblock, new syntax, etc.
> > >> Scope now is simpler than that.
> > >>
> > >> Now that is possible to see how meta attribute support could benefit a
> > >> language, I compiled a simple list of known projects and how can they
> > >> benefit of meta support:
> > >> - phpUnit Providing meta functionality for test cases, examples:
> > >> @dataProvider for test data iteration, @expectedException for catching
> > >> exceptions, etc.
> > >> - Doctrine For Object-Relational mapping, examples: @Entity,
> @OneToOne,
> > >> @Id, etc.
> > >> - Zend Framework Server classes Used to automate mappings for XML-RPC,
> > >> SOAP, etc.
> > >> - FLOW3 for dependency injection and validation
> > >> - Symfony2 for validation and routing rules
> > >> - Others: Validation, Functional Behavior injection (which could take
> > >> advantage of Traits), etc.
> > >>
> > >>
> > >> Poll will be opened for voting for 7 days (1 week) starting from now.
> > >> Poll will be closed next Monday at 5pm GMT.
> > >> Question: Does PHP need meta attribute support?
> > >>
> > >> Happy voting!
> > >>
> > >> --
> > >> Guilherme Blanco
> > >> Mobile: +55 (16) 9215-8480
> > >> MSN: guilhermebla...@hotmail.com
> > >> São Paulo - SP/Brazil
> > >>
> > >> --
> > >> PHP Internals - PHP Runtime Development Mailing List To unsubscribe,
> > visit:
> > >> http://www.php.net/unsub.php
> > >
> > >
> >
> >
> >
> > --
> > Guilherme Blanco
> > Mobile: +55 (16) 9215-8480
> > MSN: guilhermebla...@hotmail.com
> > São Paulo - SP/Brazil
> >
> > --
> > PHP Internals - PHP Runtime Development Mailing List
> > To unsubscribe, visit: http://www.php.net/unsub.php
> >
> >
>



-- 

Thanks,

Will Fitch
Director of Operations | Quepasa.com
931.205.8242 | will.fi...@quepasacorp.com
Twitter: twitter.com/willfitch

Reply via email to