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

De-duplicate identical classes and avoid __1 #1655

Open
wants to merge 4 commits into
base: master
Choose a base branch
from

Conversation

matusfaro
Copy link

@matusfaro matusfaro commented Dec 11, 2024

Hello,

Thank you very much for your amazing project!

I know you have previously decided (in #1082) not to support de-duplication of identical classes and instead suggest to use $refs, but please re-consider.

This seems to be an arguably common request: #1562 #1559 #1151 #1192 #1081 #784 #114 #112 #885

Mainly this will solve the case where it's not possible to modify the input and replace $refs (my case), but it'll also make it friendlier for others not having to refactor their input to use $refs.

Take a look at the implementation which is fairly simple. I'd appreciate any feedback on the implementation, even if you don't decide to go ahead with it.

If I still can't change your mind, no problem, I will maintain this change in my fork.


UPDATE: For now I have it in my repo published under my groupId if anyone wants to use it, e.g.:

<plugin>
    <groupId>io.dataspray</groupId>
    <artifactId>jsonschema2pojo-maven-plugin</artifactId>
    <version>1.2.8</version>
</plugin>

@@ -47,6 +50,7 @@ public class RuleFactory {
private GenerationConfig generationConfig;
private Annotator annotator;
private SchemaStore schemaStore;
private Map<Class<?>, Map<String, ?>> dedupeCache;
Copy link
Author

Choose a reason for hiding this comment

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

Track duplicates in each RuleFactory instance

return new ObjectRule(this, new ParcelableHelper(), reflectionHelper);
Rule<JPackage, JType> rule = new ObjectRule(this, new ParcelableHelper(), reflectionHelper);
if (generationConfig.isUseDeduplication()) {
rule = new DeduplicateRule<>(dedupeCache, rule);
Copy link
Author

Choose a reason for hiding this comment

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

Wrap specific Rules that require de-duplication.


public DeduplicateRule(Map<Class<?>, Map<String, ?>> dedupeCacheByRule, Rule<T, R> rule) {
// noinspection unchecked map is populated by us and guaranteed to be of the correct type
Map<String, R> dedupeCache = (Map<String, R>) dedupeCacheByRule.get(rule.getClass());
Copy link
Author

Choose a reason for hiding this comment

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

Each Rule has its own individual cache

* @return same {@code R} instance if a previous schema with the same hash code was already processed
*/
@Override
public R apply(String nodeName, JsonNode node, JsonNode parent, T generatableType, Schema currentSchema) {
Copy link
Author

Choose a reason for hiding this comment

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

Performs de-duplication here during rule transformation of Schema to result.

@@ -75,4 +80,13 @@ public boolean isGenerated() {
return javaType != null;
}

public String calculateHash() {
Copy link
Author

Choose a reason for hiding this comment

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

Using SHA-256 of the compact JSON string for de-duplication.

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.

1 participant