Skip to content
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

Append field number to accessors if there is conflict #6169

Merged
merged 1 commit into from
May 24, 2019

Conversation

TeBoring
Copy link
Contributor

Previously, foo_value and foo (wrapper field) will both have get/setFooValue

Previously, foo_value and foo (wrapper field) will both have get/setFooValue
@@ -16,6 +16,44 @@

class WrapperTypeSettersTest extends TestBase
{
public function testConflictNormalVsWrapper()
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It looks like both functions have been renamed with a number on the end. Is that necessary? Why not just rename one of them, and keep the other unchanged?

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think that is necessary. One field may be added before the other, and we don't want to accidentally change which field user is calling.

Consider the case if int32 normal_vs_wrapper_value = 1; is added first, and user is calling getNormalVsWrapperValue(), then someone added google.protobuf.Int32Value normal_vs_wrapper = 2;. If we rename the field 1 but not field 2, that user is suddenly reading from field 2, which is a behavior change. Similar problem exist for the other ordering too. Not to mention that it is also not clear which field getNormalVsWrapperValue() is referring to.


message TestWrapperAccessorConflicts {
int32 normal_vs_wrapper_value = 1;
google.protobuf.Int32Value normal_vs_wrapper = 2;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Appending the field number works for this example, but what if there was also a field named normal_vs_wrapper_value_2? I'm not suggesting that that is very likely, but WDYT about a more general solution to this problem that would guarantee no conflicts. For example, inside a class, create a container of names used for methods, and each time you generate a method, add it to the container, check for conflicts, and if there is a conflict, resolve it by appending an incrementing counter - keep incrementing until the name is unique. This would also cover any other possible cases of collision (I'm not sure if any other cases exist in PHP).

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This will forces us to delay generating all accessors until we have traversed all fields of the same message. I feel this will be quite complicate.
For now, we used the same approach in java (which also has the problem of conflict after renaming)
In future, we would like to introducing some rules for naming a field, like no field can be named as a prefix of another field.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ok, sgtm.

@TeBoring
Copy link
Contributor Author

@fiboknacky please take a look

@@ -16,6 +16,44 @@

class WrapperTypeSettersTest extends TestBase
{
public function testConflictNormalVsWrapper()
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think that is necessary. One field may be added before the other, and we don't want to accidentally change which field user is calling.

Consider the case if int32 normal_vs_wrapper_value = 1; is added first, and user is calling getNormalVsWrapperValue(), then someone added google.protobuf.Int32Value normal_vs_wrapper = 2;. If we rename the field 1 but not field 2, that user is suddenly reading from field 2, which is a behavior change. Similar problem exist for the other ordering too. Not to mention that it is also not clear which field getNormalVsWrapperValue() is referring to.

Copy link

@sonya1st sonya1st left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@ @ @ # # @ #

TeBoring added a commit that referenced this pull request Jun 21, 2019
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants