- Issue created by @wengerk
- Status changed to Active
11 months ago 1:53pm 16 February 2024 - 🇦🇹Austria klausi 🇦🇹 Vienna
Thanks for reporting!
Not sure we should do something here as the Drupal coding standards say: "PHP allows classes to be aliased when they are imported into a namespace. In general that should only be done to avoid a name collision." https://www.drupal.org/docs/develop/coding-standards/namespaces#s-class-... →
In your example there is no name collision. I don't think it is good practice from Symfony to alias "Constraints" to "Assert", which can be super confusing as there is no Assert namespace anywhere.
Would like to hear more opinions on this!
- 🇨🇭Switzerland wengerk Lausanne
Many thanks for your consideration and answer.
I totally understand your point of view.
I still reckon using aliases forAttribute
is a smart move, just like Symfony does. Let me proceed with why.There's this discussion in the community (https://github.com/symfony/symfony/discussions/45525) that backs up this convention.
I'll sum up one of the responses below for easier reading:Having alias provides additional context to what you're doing, especially when you're in a class that might be using attributes from multiple packages. Suppose you have a class User with validation constraints and Serialization, it wouldn't be all that farfetched to have a property definition like this one:
class User { #[Assert\Email] #[Serializer\Groups(['list'])] public string $email; }
With the aliased imports, you know where each of the attributes is coming from and what their purpose is (validation constraint, serialization group configuration, etc ...). If you take away the imports, there's a bit more ambiguity with each attribute:
class User { #[Email] #[Groups(['list'])] public string $email; }
Hope this helps explain why having aliases makes sense.
Keep up the awesome work with thedrupal/coder
! - 🇦🇹Austria klausi 🇦🇹 Vienna
Thanks a lot for the explanation.
I would argue that your example is an indication of a code smell. Never name a class "Email", that is a very bad name on its own as it is very ambiguous. You should not solve bad naming by using aliases all over the place when your class is used.
Yes, that would mean repeating the namespace in the class name, but that is totally fine and much better. Don't optimize your fully qualified class name for shortness; it still should convey meaning on its own.
What would be a good example for the Email class name here? In my opinion: "Symfony\Component\Validator\Constraints\EmailConstraint", then "EmailConstraint" is much clearer that this is a validation constraint.
Same for serialization groups. Is "Groups" a good class name? Probably not. I like "SerializationGroups" much more.
Doing that consistently suddenly all your aliasing problems go away because you now you actually have good class names that mean something.
So much for my rant on this topic :-) I'm still open to support aliasing in Coder for attributes, since we probably can't convince the Symfony folks to use meaningful class names.
- Status changed to Needs review
4 days ago 3:32pm 11 January 2025 - 🇦🇹Austria klausi 🇦🇹 Vienna
Turns out that Drush commands are also defined with partial namespaces, this caused some problems in 🐛 Drupal.Classes.FullyQualifiedNamespace sniff doesn't work with attributes Active .
The conclusion is now that we don't have a standard yet, so Coder will allow any namespacing in PHP attributes.
Pull request: https://github.com/pfrenssen/coder/pull/258 , will merge this soonish.