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

Reply via email to