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

Add helper methods to CustomValue and its implementations #338

Open
wants to merge 8 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 3 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
42 changes: 42 additions & 0 deletions src/main/java/net/fabricmc/loader/api/metadata/CustomValue.java
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,10 @@
package net.fabricmc.loader.api.metadata;

import java.util.Map;
import java.util.Set;
import java.util.stream.Collectors;
import java.util.stream.Stream;
import java.util.stream.StreamSupport;

/**
* Represents a custom value in the {@code fabric.mod.json}.
Expand Down Expand Up @@ -67,6 +71,23 @@ public interface CustomValue {
*/
boolean getAsBoolean();

/**
* Compares this custom value with another and returns whether they are equal.
*
* @param another The custom value to compare to.
*/
boolean equals(Object another);

/**
* Returns the hash code for this custom value.
*/
int hashCode();

/**
* Returns the value of this custom value as json.
*/
String toString();
BoogieMonster1O1 marked this conversation as resolved.
Show resolved Hide resolved

/**
* Represents an {@link CvType#OBJECT} value.
*/
Expand All @@ -91,6 +112,20 @@ interface CvObject extends CustomValue, Iterable<Map.Entry<String, CustomValue>>
* @return the value associated, or {@code null} if no such value is present
*/
CustomValue get(String key);

/**
* Returns a sequential {@link Stream} with this iterable as its source.
*/
default Stream<Map.Entry<String, CustomValue>> stream() {
return StreamSupport.stream(this.spliterator(), false);
BoogieMonster1O1 marked this conversation as resolved.
Show resolved Hide resolved
}

/**
* Returns the set of keys in this custom value.
*/
default Set<String> keys() {
BoogieMonster1O1 marked this conversation as resolved.
Show resolved Hide resolved
return this.stream().map(Map.Entry::getKey).collect(Collectors.toSet());
}
}

/**
Expand All @@ -110,6 +145,13 @@ interface CvArray extends CustomValue, Iterable<CustomValue> {
* @throws IndexOutOfBoundsException if the index is not within {{@link #size()}}
*/
CustomValue get(int index);

/**
* Returns a sequential {@link Stream} with this iterable as its source.
*/
default Stream<CustomValue> stream() {
BoogieMonster1O1 marked this conversation as resolved.
Show resolved Hide resolved
return StreamSupport.stream(this.spliterator(), false);
}
}

/**
Expand Down
165 changes: 165 additions & 0 deletions src/main/java/net/fabricmc/loader/metadata/CustomValueImpl.java
Original file line number Diff line number Diff line change
Expand Up @@ -157,6 +157,45 @@ public CustomValue get(String key) {
public Iterator<Entry<String, CustomValue>> iterator() {
return entries.entrySet().iterator();
}

@Override
public boolean equals(Object o) {
if (this == o) {
return true;
} else if (!(o instanceof ObjectImpl)) {
return false;
}

ObjectImpl object = (ObjectImpl) o;
return this.entries.equals(object.entries);
}

@Override
public int hashCode() {
return this.entries.hashCode();
}

@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("{");
Iterator<String> itr = this.keys().iterator();

while (itr.hasNext()) {
String key = itr.next();
// Key
sb.append("\"").append(key).append("\"").append(":");
// Value
sb.append(this.get(key).toString());

if (itr.hasNext()) {
sb.append(",");
}
}

sb.append("}");
return sb.toString();
}
}

private static final class ArrayImpl extends CustomValueImpl implements CvArray {
Expand Down Expand Up @@ -185,6 +224,51 @@ public CustomValue get(int index) {
public Iterator<CustomValue> iterator() {
return entries.iterator();
}

@Override
public boolean equals(Object o) {
if (this == o) {
return true;
} else if (!(o instanceof ArrayImpl)) {
return false;
}

ArrayImpl that = (ArrayImpl) o;
return this.entries.equals(that.entries);
}

@Override
public int hashCode() {
return this.entries.hashCode();
}

@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("[");
Iterator<CustomValue> itr = this.iterator();

while (itr.hasNext()) {
CustomValue value = itr.next();

if (value.getType() == CvType.STRING) {
sb.append("\"");
}

sb.append(value.toString());

if (value.getType() == CvType.STRING) {
sb.append("\"");
}

if (itr.hasNext()) {
sb.append(",");
}
}

sb.append("]");
return sb.toString();
}
}

private static final class StringImpl extends CustomValueImpl {
Expand All @@ -198,6 +282,28 @@ public StringImpl(String value) {
public CvType getType() {
return CvType.STRING;
}

@Override
public boolean equals(Object o) {
if (this == o) {
return true;
} else if (!(o instanceof StringImpl)) {
return false;
}

StringImpl string = (StringImpl) o;
return this.value.equals(string.value);
}

@Override
public int hashCode() {
return this.value.hashCode();
}

@Override
public String toString() {
return this.value;
}
}

private static final class NumberImpl extends CustomValueImpl {
Expand All @@ -211,6 +317,28 @@ public NumberImpl(Number value) {
public CvType getType() {
return CvType.NUMBER;
}

@Override
public boolean equals(Object o) {
if (this == o) {
return true;
} else if (!(o instanceof NumberImpl)) {
return false;
}

NumberImpl number = (NumberImpl) o;
return this.value.equals(number.value);
}

@Override
public int hashCode() {
return this.value.hashCode();
}

@Override
public String toString() {
return String.valueOf(this.value);
}
}

private static final class BooleanImpl extends CustomValueImpl {
Expand All @@ -224,12 +352,49 @@ public BooleanImpl(boolean value) {
public CvType getType() {
return CvType.BOOLEAN;
}

@Override
public int hashCode() {
return Boolean.hashCode(this.value);
}

@Override
public boolean equals(Object o) {
if (this == o) {
return true;
} else if (!(o instanceof BooleanImpl)) {
return false;
}

BooleanImpl aBoolean = (BooleanImpl) o;
return this.value == aBoolean.value;
}

@Override
public String toString() {
return String.valueOf(this.value);
}
}

private static final class NullImpl extends CustomValueImpl {
@Override
public CvType getType() {
return CvType.NULL;
}

@Override
public boolean equals(Object obj) {
return this == NULL;
BoogieMonster1O1 marked this conversation as resolved.
Show resolved Hide resolved
}

@Override
public int hashCode() {
return System.identityHashCode(null);
}

@Override
public String toString() {
return "null";
}
}
}