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

Suggest a micro change for added interface fields #1559

Conversation

laeubi
Copy link
Contributor

@laeubi laeubi commented Jan 13, 2025

If one adds a field to an interface this will not result in any problem for the consumer or the provider of the interface.

Because of this these changes can be made in a micro package version
increment.

@laeubi laeubi force-pushed the suggest_micro_change_for_default_methods branch from 9cc68ec to 981f28b Compare January 13, 2025 16:29
@merks
Copy link
Contributor

merks commented Jan 13, 2025

I just wanted to point out that this (will not result in a problem) isn't strictly true. Here if we add this default method to Foo, bad things will definitely happen in Bar:

image

That being said, Java has been doing this regularly and I suspect the API tools checking has not adapted to the concept of default methods. I wonder why a field in an interface was ever done this way in the first place? I should also mention I did not read this in detail:

https://docs.oracle.com/javase/specs/jls/se7/html/jls-13.html

Copy link

github-actions bot commented Jan 13, 2025

Test Results

   285 files  ±0     285 suites  ±0   48m 49s ⏱️ - 1m 56s
 3 586 tests ±0   3 510 ✅ ±0   76 💤 ±0  0 ❌ ±0 
10 950 runs  ±0  10 719 ✅ ±0  231 💤 ±0  0 ❌ ±0 

Results for commit 20fc9ef. ± Comparison against base commit 5d46304.

♻️ This comment has been updated with latest results.

@laeubi laeubi force-pushed the suggest_micro_change_for_default_methods branch from 981f28b to 6985cde Compare January 14, 2025 05:55
@laeubi laeubi changed the title Suggest a micro change for default added interface methods and fields Suggest a micro change for added interface fields Jan 14, 2025
@laeubi
Copy link
Contributor Author

laeubi commented Jan 14, 2025

The important part about package versions is binary compatibility, and java says here:

Adding a default method, or changing a method from abstract to default, does not break compatibility with pre-existing binaries, but may cause an IncompatibleClassChangeError if a pre-existing binary attempts to invoke the method.

So even if it is binary compatible, I think its not sufficient for a micro change and therefore removed this now and only assume adding fields is safe.

I also want to note that currently everything is only made as a suggestion, so one is still allowed to do a minor or major increment if it seems more sufficient.

If one adds a field to an interface this will not result in any problem
for the consumer or the provider of the interface.

Because of this these changes can be made in a micro package version
increment.
@laeubi laeubi force-pushed the suggest_micro_change_for_default_methods branch from 6985cde to 20fc9ef Compare January 17, 2025 09:49
@laeubi
Copy link
Contributor Author

laeubi commented Jan 17, 2025

Closing as

https://github.com/eclipse-platform/eclipse.platform/blob/master/docs/VersionNumbering.md#How-to-version-packages

says same rules for plugins apply to package versions as well

and

https://docs.osgi.org/whitepaper/semantic-versioning/040-semantic-versions.html

suggests micro is only for bug-fixes "that do not affect either consumers or providers of the API", while this is the case here, adding a field is merely a bugfix...

@laeubi laeubi closed this Jan 17, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants