-
Notifications
You must be signed in to change notification settings - Fork 715
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Unable to override built-in modifiers. #1048
Comments
Here is a try to solve the problem (with Extension) : Idea is to replace DefaultExtension by MyCustomExtension, but still extending the first one. MyCustomExtension example :
Smarty config example :
An issue anyway : I still think that the default behaviour is tricky, and that we shouldn't have to replace DefautExtension by a Custom one. |
Fix proposition in #1049 |
@wisskid I think this behaviour needs to be added to the docs under "Upgrading from an older version" section in bold as it doesn't throw any errors and can lead to data loss. In my case I overrode |
Hello,
As it could be done in previous versions, with V5 we are not able to override a built-in modifier using registerPlugin function (Even with unregisterPlugin before).
For example :
By Searching in the issues, i have seen that there is a workaround, as it's suggested in #1011 (kind of describing that problem with a custom "json_encode" modifier).
Solution seems to be to create a custom Extension, implementing getModifierCompiler() and getModifierCallback() functions, and register it between Core and Defaut extensions. In that way our Custom Extension can handle modifiers before DefautExtension does it.
But it's not that easy for all cases, as it brings complexity with the different types of modifiers :
"Compiler" Ones (if i understand correctly, executed first when creating compiled templates files), and "Classic" Ones (executed after).
For example, let's say that i want to handle a modifier in MyCustomExtension->getModifierCallback() (not at compilation), if that modifier exists in DefautExtension->getModifierCompiler(), my implementation will be (silently) ignored too. That's because DefaultExtension->getModifierCompiler() will be executed way before MyCustomExtension->getModifierCallback();
So to summarize, if i understand correctly, and from what i've tested so far, for now with v5, every time i want to add/handle a modifier, i have to take care of these points :
If it's not handled in DefaultExtension :
Best scenario, i can do whatever i want.
I can use registerPlugin function.
Or i can handle it in a "MyCustomExtension" extension.
If it's handled in DefaultExtension->getModifierCallback() :
I can't use registerPlugin function (it will be silently ignored)
I can handle it in MyCustomExtension->getModifierCallback() or ->getModifierCompiler(), as both will be executed before DefaultExtension->getModifierCallback().
If it's handled in DefaultExtension->getModifierCompiler() :
I can't use registerPlugin function (it will be silently ignored)
I can't handle it in MyCustomExtension->getModifierCallback() (it will be silently ignored too)
I have to handle the modifier in MyCustomExtension->getModifierCompiler() (i have no other choice).
And in the future updates of Smarty, if DefaultExtension is changed (adding more modifiers, or moving from a type to another), then MyCustomExtension could be (silently) obsolete.
I'm not very enthousiastic with that Extension solution, it's not very intuitive or user fiendly, and seems to required to think about more cases than it appears.
It would be very very much simpler if by default, adding a modifier will take the lead over default ones defined in DefaultExtension.
As soon as we use "registerPlugin" function, don't we exepect that Smarty use the callback we just explicitly defined ?
The text was updated successfully, but these errors were encountered: