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

fix: Fixed TagResolvers equality #751

Merged
merged 6 commits into from
Apr 29, 2022
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@

import java.util.HashMap;
import java.util.Map;
import java.util.Objects;
import net.kyori.adventure.text.Component;
import net.kyori.adventure.text.minimessage.internal.serializer.ClaimConsumer;
import net.kyori.adventure.text.minimessage.internal.serializer.SerializableResolver;
Expand Down Expand Up @@ -78,4 +79,22 @@ public void handle(final @NotNull Component serializable, final @NotNull ClaimCo
((SerializableResolver) this.resolver).handle(serializable, consumer);
}
}

@Override
public boolean equals(final @Nullable Object other) {
if (this == other) {
return true;
}
if (!(other instanceof CachingTagResolver)) {
return false;
}
final CachingTagResolver that = (CachingTagResolver) other;
return Objects.equals(this.resolver, that.resolver)
4drian3d marked this conversation as resolved.
Show resolved Hide resolved
|| Objects.equals(this.cache, that.cache);
}

@Override
public int hashCode() {
return Objects.hash(this.cache, this.resolver);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@
package net.kyori.adventure.text.minimessage.tag.resolver;

import java.util.Map;
import java.util.Objects;
import net.kyori.adventure.text.minimessage.tag.Tag;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
Expand All @@ -45,4 +46,21 @@ public boolean contributeToMap(final @NotNull Map<String, Tag> map) {
map.putAll(this.tagMap);
return true;
}

@Override
public boolean equals(final @Nullable Object other) {
if (this == other) {
return true;
}
if (!(other instanceof MapTagResolver)) {
return false;
}
final MapTagResolver that = (MapTagResolver) other;
return Objects.equals(this.tagMap, that.tagMap);
}

@Override
public int hashCode() {
return Objects.hash(this.tagMap);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
*/
package net.kyori.adventure.text.minimessage.tag.resolver;

import java.util.Arrays;
import net.kyori.adventure.text.Component;
import net.kyori.adventure.text.minimessage.Context;
import net.kyori.adventure.text.minimessage.ParsingException;
Expand Down Expand Up @@ -89,4 +90,21 @@ public void handle(@NotNull final Component serializable, @NotNull final ClaimCo
}
}
}

@Override
public boolean equals(final @Nullable Object other) {
if (other == this) {
return true;
}
if (!(other instanceof SequentialTagResolver)) {
return false;
}
final SequentialTagResolver that = (SequentialTagResolver) other;
return Arrays.equals(this.resolvers, that.resolvers);
}

@Override
public int hashCode() {
return Arrays.hashCode(this.resolvers);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -138,6 +138,29 @@ void testValidTagName() {
assertDoesNotThrow(() -> TagResolver.resolver("v_9_v", Tag.preProcessParsed("something")));
}

@Test
void testTagResolverEquality() {
final TagResolver first = TagResolver.resolver(
Placeholder.unparsed("single", "replace"),
TagResolver.standard(),
TagResolver.caching((name) -> null),
TagResolver.empty(),
TagResolver.resolver("tag", Tag.selfClosingInserting(Component.empty()))
);
final TagResolver second = TagResolver.resolver(
Placeholder.unparsed("single", "replace"),
TagResolver.standard(),
TagResolver.caching((name) -> null),
TagResolver.empty(),
TagResolver.resolver("tag", Tag.selfClosingInserting(Component.empty()))
);

AbstractTest.dummyContext("equality test")
.deserialize("<test>", first, second);

assertEquals(first, second);
}

private static @NotNull Tag resolveForTest(final TagResolver resolver, final String tag) {
try {
final Context ctx = AbstractTest.dummyContext("help i shouldn't be seen");
Expand Down