-
Notifications
You must be signed in to change notification settings - Fork 716
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add assignByRef
Support
#986
base: master
Are you sure you want to change the base?
Conversation
I noticed the same yesterday. Looks like the domain name haa expired. I've contacted Monte to see if we can get it back. Also, these unit test need to be looked at. I don't think they should fail when a website is down or changes layout. |
My fear is that non local scopes might be an issue 😆 Will have to spend more time on it. |
Yep. I'll spend more time on testing those today. Just wanted to make sure you weren't against adding it back in before spending the time on it. |
@wisskid, I added more tests for each scope. I think they are all working, so I think this is ready for review. |
I'll have a look at it. But to be honest, right now I still doubt if we really need this. |
I was worried about that. That's why I asked before spending the time to update the tests. I really hope it makes it in. I know it's not a feature that should be recommended and at my company, we try to avoid it now, but it's a major hurdle in order to move from version 4 to 5. |
Why don't you subclass public function assignByRef($tpl_var, &$value = null, $nocache = false)
{
$this->tpl_vars[$tpl_var] = new ByRefVariable($value, $nocache);
} You would need to subclass public function __construct(&$value = null, $nocache = false)
{
$this->value = &$value;
$this->nocache = $nocache;
} right? |
I probably could do that. Since this PR seems to be fully working with scopes too, I'd probably include all the new code. However, I probably won't do this. It would mean I still need to change a ton of type hints in our code to use our new subclass. The worst part though is the risk. In general, I don't think it's a good idea to be subclassing classes in another library. Even if the library has really good release notes, I doubt they'll go into the fine grained details of internal class changes that shouldn't matter to people using it normally, but could break a subclass. It sounds like the path of least resistance for my company will probably be to lock composer down to version 4.4.1 and fork the library if it comes to that. I get that it's your library and you have the final say on the direction of Smarty. I've been very happy with Smarty for years and was trying to help out by contributing code back. I find it hard to believe that at least a small number of other people aren't going to be affected by the removing of assigning by reference, but at least now they can see a way to hack it if they do choose to upgrade to version 5 and still need |
We use assignByRef in a large application which we are currently updating from v3 to latest version and the removal of this causes pretty big issues because the code contains cases where the assigned value changes after it was assigned. |
@ssigwart I'm considering adding You are citing 'pretty big issues', could you explain why it's not feasible to change your application instead. Or use the sub-class approach I suggested above? |
@wisskid for us, it's too late now, we have already started changing the code and spend multiple days, probably weeks on it. with at least another 2-3 full days to go. Yesterday I had to look through a few hundred php files and read through all the code below every single assignByRef statement, to make sure that the assigned php var is not changed. Took me 4-5 hour of the most boring work you could imagine. Now I have a table with around 70-80 occurrences in which the php var is changed after it was assigned. Now another team member has to go through each of them and make sure it will work with assign only. Essentially it's just a massive waste of time. Our code will not be better (on the contrary, it will be worse and most likely have more bugs). And we gain absolutely nothing from this. While I understand the intent and I fully agree, I think thar assignByRef is a special case. Removing this has an impact on essentially how applications should be designed from the ground up. And this is where I think it's important to respect smarty's history. I am pretty sure that there are a lot of massive v3 applications out there, still in use, that at some point will need to be updated. and I think that most devs will not be looking through the pull requests section here on github and find the subclass approach. They will just be like: Oh shit, we need to replace assignByRef - and they will start doing it one by one, same as we did before I came to check here. All in all I think removing this will cause a lot of unnecessary work and more buggy applications. |
@simplexx sorry to hear that. Could you share one or two examples of code where the variable is changed after it was assigned? |
@wisskid sure: Example 1:
Example 2:
|
@wisskid, you are referring this a part of the following statement from https://www.smarty.net/docs/en/api.append.by.ref.tpl: Honestly, I've never paid attention to that or probably even seen it since we started on Smarty 2, which states this on https://www.smarty.net/docsv2/en/api.assign.by.ref.tpl: The first part of that is exactly what we rely on. As for the Smarty 3 note, it says it's probably not needed, but I don't get the impression that it would be removed. I find it to be a clever trick to be able to assign a variable like an array and have it see added values after the assignment, both in the file and in other files. I think I've mentioned this before here or in the discussion, but it's not that I can't replace |
I rebased this so that the unit tests pass now that the Smarty website dependency is fixed. |
@wisskid, it looks like the following works to add back in
assignByRef
. I didn't fully test the non-local scopes yet, but wanted to get your thoughts on adding this back in before spending too much time on it. What do you think?