Yatopia/patches/server/0058-Port-Cadmium.patch

1249 lines
60 KiB
Diff
Raw Normal View History

From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
From: Lucy-t <64509677+Lucy-t@users.noreply.github.com>
Date: Thu, 7 Jan 2021 00:24:16 -0500
Subject: [PATCH] Port Cadmium
Code from LucilleTea's port of cadmium to 1.16: https://github.com/LucilleTea/DataFixerUpper
diff --git a/src/main/java/com/mojang/datafixers/DataFixUtils.java b/src/main/java/com/mojang/datafixers/DataFixUtils.java
index cf8959aea3e48c1276ae9536d4de0f0127e1801e..b730a4c0b8b8c9036641d033568b3554062999cb 100644
--- a/src/main/java/com/mojang/datafixers/DataFixUtils.java
+++ b/src/main/java/com/mojang/datafixers/DataFixUtils.java
@@ -54,6 +54,15 @@ public class DataFixUtils {
return other;
}
+ // Yatopia start - Cadmium port
+ public static <U> U orElse(final U nullable, final U other) {
+ if (nullable!=null) {
+ return nullable;
+ }
+ return other;
+ }
+ // Yatopia end
+
public static <U> U orElseGet(final Optional<? extends U> optional, final Supplier<? extends U> other) {
if (optional.isPresent()) {
return optional.get();
diff --git a/src/main/java/com/mojang/datafixers/DataFixerBuilder.java b/src/main/java/com/mojang/datafixers/DataFixerBuilder.java
index abc265b00044b14abb55c2628d454ee01fef467b..c8c19535fa64edc392fa18093ba47b16a168ebaf 100644
--- a/src/main/java/com/mojang/datafixers/DataFixerBuilder.java
+++ b/src/main/java/com/mojang/datafixers/DataFixerBuilder.java
@@ -64,13 +64,17 @@ public class DataFixerBuilder {
public DataFixer build(final Executor executor) {
final DataFixerUpper fixerUpper = new DataFixerUpper(new Int2ObjectAVLTreeMap<>(schemas), new ArrayList<>(globalList), new IntAVLTreeSet(fixerVersions));
+ // Yatopia start - Cadmium port
+ long startTime = System.nanoTime();
+ final List<CompletableFuture<?>> futures = Lists.newArrayList();
+ // Yatopia end
final IntBidirectionalIterator iterator = fixerUpper.fixerVersions().iterator();
while (iterator.hasNext()) {
final int versionKey = iterator.nextInt();
if (versionKey < minDataFixPrecacheVersion) continue; // Paper
final Schema schema = schemas.get(versionKey);
for (final String typeName : schema.types()) {
- CompletableFuture.runAsync(() -> {
+ futures.add(CompletableFuture.runAsync(() -> { // Yatopia - Cadmium port
final Type<?> dataType = schema.getType(() -> typeName);
final TypeRewriteRule rule = fixerUpper.getRule(DataFixUtils.getVersion(versionKey), dataVersion);
dataType.rewrite(rule, DataFixerUpper.OPTIMIZATION_RULE);
@@ -78,9 +82,16 @@ public class DataFixerBuilder {
LOGGER.error("Unable to build datafixers", e);
Runtime.getRuntime().exit(1);
return null;
- });
+ })); // Yatopia - Cadmium port
}
}
+ // Yatopia start - Cadmium port
+ CompletableFuture.allOf(futures.toArray(new CompletableFuture<?>[0]))
+ .thenAccept((res) -> {
+ long endTime = System.nanoTime();
+ LOGGER.info("Finished building data fixers after {}ms", (endTime - startTime) / 1_000_000);
+ });
+ // Yatopia end
return fixerUpper;
}
diff --git a/src/main/java/com/mojang/datafixers/FieldFinder.java b/src/main/java/com/mojang/datafixers/FieldFinder.java
index a20a9dedcff2f3d633c5fd09d238a98fe18968c0..7ae4fab4c448ec3444624b6e671364a89243f6dc 100644
--- a/src/main/java/com/mojang/datafixers/FieldFinder.java
+++ b/src/main/java/com/mojang/datafixers/FieldFinder.java
@@ -118,7 +118,7 @@ public final class FieldFinder<FT> implements OpticFinder<FT> {
(Type<Pair<FT, V>>) choiceType,
type,
type,
- new Proj1<>()
+ Proj1.instance() // Yatopia - Cadmium port
);
}
diff --git a/src/main/java/com/mojang/datafixers/TypeRewriteRule.java b/src/main/java/com/mojang/datafixers/TypeRewriteRule.java
index 6f836c3382ed83e07000c0a5e4b6e9b69f8c45bf..37690009f2f3782e741f71272df525e9093794bc 100644
--- a/src/main/java/com/mojang/datafixers/TypeRewriteRule.java
+++ b/src/main/java/com/mojang/datafixers/TypeRewriteRule.java
@@ -105,20 +105,24 @@ public interface TypeRewriteRule {
}
}
- static TypeRewriteRule orElse(final TypeRewriteRule first, final TypeRewriteRule second) {
+ // Yatopia start - Cadmium port
+ static TypeRewriteRule orElse(final TypeRewriteRule first, final TypeRewriteRule second) {
+ /*
return orElse(first, () -> second);
}
static TypeRewriteRule orElse(final TypeRewriteRule first, final Supplier<TypeRewriteRule> second) {
- return new OrElse(first, second);
- }
+ */
+ return new OrElse(first, second);
+ }
+ // Yatopia end
final class OrElse implements TypeRewriteRule {
protected final TypeRewriteRule first;
- protected final Supplier<TypeRewriteRule> second;
+ protected final TypeRewriteRule second; // Yatopia - Cadmium port
private final int hashCode;
- public OrElse(final TypeRewriteRule first, final Supplier<TypeRewriteRule> second) {
+ public OrElse(final TypeRewriteRule first, final TypeRewriteRule second) { // Yatopia - Cadmium port
this.first = first;
this.second = second;
hashCode = Objects.hash(first, second);
@@ -130,7 +134,7 @@ public interface TypeRewriteRule {
if (view.isPresent()) {
return view;
}
- return second.get().rewrite(type);
+ return second.rewrite(type); // Yatopia - Cadmium port
}
@Override
@@ -159,9 +163,13 @@ public interface TypeRewriteRule {
return new One(rule);
}
+ // Yatopia start - Cadmium port
+ /*
static TypeRewriteRule once(final TypeRewriteRule rule) {
return orElse(rule, () -> one(once(rule)));
}
+ */
+ // Yatopia end
static TypeRewriteRule checkOnce(final TypeRewriteRule rule, final Consumer<Type<?>> onFail) {
// TODO: toggle somehow
diff --git a/src/main/java/com/mojang/datafixers/Typed.java b/src/main/java/com/mojang/datafixers/Typed.java
index 55c55beba58fb0505ccf8270a27d6c6ffc01c629..4b84d12d51eedf99d0b5d2168f31c8a2f819b432 100644
--- a/src/main/java/com/mojang/datafixers/Typed.java
+++ b/src/main/java/com/mojang/datafixers/Typed.java
@@ -184,11 +184,11 @@ public final class Typed<A> {
}
public <B> Typed<Either<A, B>> inj1(final Type<B> type) {
- return new Typed<>(DSL.or(this.type, type), ops, new Inj1<A, B, A>().build(value));
+ return new Typed<>(DSL.or(this.type, type), ops, Inj1.<A, B, A>instance().build(value)); // Yatopia - Cadmium port
}
public <B> Typed<Either<B, A>> inj2(final Type<B> type) {
- return new Typed<>(DSL.or(type, this.type), ops, new Inj2<B, A, A>().build(value));
+ return new Typed<>(DSL.or(type, this.type), ops, Inj2.<B, A, A>instance().build(value)); // Yatopia - Cadmium port
}
public static <A, B> Typed<Pair<A, B>> pair(final Typed<A> first, final Typed<B> second) {
diff --git a/src/main/java/com/mojang/datafixers/TypedOptic.java b/src/main/java/com/mojang/datafixers/TypedOptic.java
index 10c5565709510609f8b6c4c39bb25b163dd878bc..9e2b6e46ad846ebd964b969932da84c671ebc651 100644
--- a/src/main/java/com/mojang/datafixers/TypedOptic.java
+++ b/src/main/java/com/mojang/datafixers/TypedOptic.java
@@ -131,7 +131,7 @@ public final class TypedOptic<S, T, A, B> {
DSL.and(newType, gType),
fType,
newType,
- new Proj1<>()
+ Proj1.instance() // Yatopia - Cadmium port
);
}
@@ -142,7 +142,7 @@ public final class TypedOptic<S, T, A, B> {
DSL.and(fType, newType),
gType,
newType,
- new Proj2<>()
+ Proj2.instance() // Yatopia - Cadmium port
);
}
@@ -153,7 +153,7 @@ public final class TypedOptic<S, T, A, B> {
DSL.or(newType, gType),
fType,
newType,
- new Inj1<>()
+ Inj1.instance() // Yatopia - Cadmium port
);
}
@@ -164,7 +164,7 @@ public final class TypedOptic<S, T, A, B> {
DSL.or(fType, newType),
gType,
newType,
- new Inj2<>()
+ Inj2.instance() // Yatopia - Cadmium port
);
}
diff --git a/src/main/java/com/mojang/datafixers/View.java b/src/main/java/com/mojang/datafixers/View.java
index 4139dc999917d84c7dea5b02117a50af51206f04..58f856d95405f02c107fad12e830e98d1e1a8337 100644
--- a/src/main/java/com/mojang/datafixers/View.java
+++ b/src/main/java/com/mojang/datafixers/View.java
@@ -11,7 +11,6 @@ import com.mojang.datafixers.types.Type;
import com.mojang.serialization.DynamicOps;
import java.util.Objects;
-import java.util.Optional;
import java.util.function.Function;
public final class View<A, B> implements App2<View.Mu, A, B> {
@@ -73,9 +72,15 @@ public final class View<A, B> implements App2<View.Mu, A, B> {
return Objects.hash(type, newType, function);
}
- public Optional<? extends View<A, B>> rewrite(final PointFreeRule rule) {
- return rule.rewrite(DSL.func(type, newType), function()).map(f -> create(type, newType, f));
+ // Yatopia start - Cadmium port
+ public View<A, B> rewrite(final PointFreeRule rule) {
+ PointFree<Function<A, B>> result = rule.rewrite(DSL.func(type, newType), function());
+ if (result!=null) {
+ return create(type, newType, result);
+ }
+ return null;
}
+ // Yatopia end
public View<A, B> rewriteOrNop(final PointFreeRule rule) {
return DataFixUtils.orElse(rewrite(rule), this);
diff --git a/src/main/java/com/mojang/datafixers/functions/Apply.java b/src/main/java/com/mojang/datafixers/functions/Apply.java
index 32c55622c7a6de4d4eb4c70c62f4fbf11385667b..89793b452e95c9ae8bec42d22bebd762533a8046 100644
--- a/src/main/java/com/mojang/datafixers/functions/Apply.java
+++ b/src/main/java/com/mojang/datafixers/functions/Apply.java
@@ -3,11 +3,11 @@
package com.mojang.datafixers.functions;
import com.mojang.datafixers.DSL;
+import com.mojang.datafixers.DataFixUtils; // Yatopia - Cadmium port
import com.mojang.datafixers.types.Type;
import com.mojang.serialization.DynamicOps;
import java.util.Objects;
-import java.util.Optional;
import java.util.function.Function;
final class Apply<A, B> extends PointFree<B> {
@@ -31,20 +31,33 @@ final class Apply<A, B> extends PointFree<B> {
return "(ap " + func.toString(level + 1) + "\n" + indent(level + 1) + arg.toString(level + 1) + "\n" + indent(level) + ")";
}
+ // Yatopia start - Cadmium port
@Override
- public Optional<? extends PointFree<B>> all(final PointFreeRule rule, final Type<B> type) {
- return Optional.of(Functions.app(
- rule.rewrite(DSL.func(argType, type), func).map(f1 -> (PointFree<Function<A, B>>) f1).orElse(func),
- rule.rewrite(argType, arg).map(f -> (PointFree<A>) f).orElse(arg),
- argType
- ));
+ public PointFree<B> all(final PointFreeRule rule, final Type<B> type) {
+ return Functions.app(
+ DataFixUtils.orElse(rule.rewrite(DSL.func(argType, type), func), func),
+ DataFixUtils.orElse(rule.rewrite(argType, arg), arg),
+ argType
+ );
}
@Override
- public Optional<? extends PointFree<B>> one(final PointFreeRule rule, final Type<B> type) {
- return rule.rewrite(DSL.func(argType, type), func).map(f -> Optional.of(Functions.app(f, arg, argType)))
- .orElseGet(() -> rule.rewrite(argType, arg).map(a -> Functions.app(func, a, argType)));
+ public PointFree<B> one(final PointFreeRule rule, final Type<B> type) {
+ final PointFree<Function<A, B>> result1 = rule.rewrite(DSL.func(argType, type), func);
+
+ if (result1!=null) {
+ return Functions.app(result1, arg, argType);
+ }
+
+ final PointFree<A> result2 = rule.rewrite(argType, arg);
+
+ if (result2!=null) {
+ return Functions.app(func, result2, argType);
+ }
+
+ return null;
}
+ // Yatopia end
@Override
public boolean equals(final Object o) {
diff --git a/src/main/java/com/mojang/datafixers/functions/Comp.java b/src/main/java/com/mojang/datafixers/functions/Comp.java
index a7a0ba66c715709801c2839018a6bb19df5cfdc6..6ea5ecad576f880783b9503ec370a5171d4f4da4 100644
--- a/src/main/java/com/mojang/datafixers/functions/Comp.java
+++ b/src/main/java/com/mojang/datafixers/functions/Comp.java
@@ -3,12 +3,12 @@
package com.mojang.datafixers.functions;
import com.mojang.datafixers.DSL;
+import com.mojang.datafixers.DataFixUtils; // Yatopia - Cadmium port
import com.mojang.datafixers.types.Func;
import com.mojang.datafixers.types.Type;
import com.mojang.serialization.DynamicOps;
import java.util.Objects;
-import java.util.Optional;
import java.util.function.Function;
final class Comp<A, B, C> extends PointFree<Function<A, C>> {
@@ -28,21 +28,34 @@ final class Comp<A, B, C> extends PointFree<Function<A, C>> {
}
@Override
- public Optional<? extends PointFree<Function<A, C>>> all(final PointFreeRule rule, final Type<Function<A, C>> type) {
+ // Yatopia start - Cadmium port
+ public PointFree<Function<A, C>> all(final PointFreeRule rule, final Type<Function<A, C>> type) {
final Func<A, C> funcType = (Func<A, C>) type;
- return Optional.of(Functions.comp(
- middleType,
- rule.rewrite(DSL.func(middleType, funcType.second()), first).map(f -> (PointFree<Function<B, C>>) f).orElse(first),
- rule.rewrite(DSL.func(funcType.first(), middleType), second).map(f1 -> (PointFree<Function<A, B>>) f1).orElse(second)
- ));
+ return Functions.comp(
+ middleType,
+ DataFixUtils.orElse(rule.rewrite(DSL.func(middleType, funcType.second()), first), first),
+ DataFixUtils.orElse(rule.rewrite(DSL.func(funcType.first(), middleType), second), second)
+ );
}
@Override
- public Optional<? extends PointFree<Function<A, C>>> one(final PointFreeRule rule, final Type<Function<A, C>> type) {
+ public PointFree<Function<A, C>> one(final PointFreeRule rule, final Type<Function<A, C>> type) {
final Func<A, C> funcType = (Func<A, C>) type;
- return rule.rewrite(DSL.func(middleType, funcType.second()), first).map(f -> Optional.of(Functions.comp(middleType, f, second)))
- .orElseGet(() -> rule.rewrite(DSL.func(funcType.first(), middleType), second).map(s -> Functions.comp(middleType, first, s)));
+ final PointFree<Function<B, C>> result1 = rule.rewrite(DSL.func(middleType, funcType.second()), first);
+
+ if (result1!=null) {
+ return Functions.comp(middleType, result1, second);
+ }
+
+ final PointFree<Function<A, B>> result2 = rule.rewrite(DSL.func(funcType.first(), middleType), second);
+
+ if (result2!=null) {
+ return Functions.comp(middleType, first, result2);
+ }
+
+ return null;
}
+ // Yatopia end
@Override
public boolean equals(final Object o) {
diff --git a/src/main/java/com/mojang/datafixers/functions/PointFree.java b/src/main/java/com/mojang/datafixers/functions/PointFree.java
index f7593e3baf71a8992aa094719d9a369399996d46..b743d6d7188c53ac04ec087d9f89b6f87374e811 100644
--- a/src/main/java/com/mojang/datafixers/functions/PointFree.java
+++ b/src/main/java/com/mojang/datafixers/functions/PointFree.java
@@ -7,7 +7,6 @@ import com.mojang.serialization.DynamicOps;
import org.apache.commons.lang3.StringUtils;
import javax.annotation.Nullable;
-import java.util.Optional;
import java.util.function.Function;
public abstract class PointFree<T> {
@@ -30,13 +29,15 @@ public abstract class PointFree<T> {
public abstract Function<DynamicOps<?>, T> eval();
- Optional<? extends PointFree<T>> all(final PointFreeRule rule, final Type<T> type) {
- return Optional.of(this);
+ // Yatopia start - Cadmium port
+ PointFree<T> all(final PointFreeRule rule, final Type<T> type) {
+ return this;
}
- Optional<? extends PointFree<T>> one(final PointFreeRule rule, final Type<T> type) {
- return Optional.empty();
+ PointFree<T> one(final PointFreeRule rule, final Type<T> type) {
+ return null;
}
+ // Yatopia end
@Override
public final String toString() {
diff --git a/src/main/java/com/mojang/datafixers/functions/PointFreeRule.java b/src/main/java/com/mojang/datafixers/functions/PointFreeRule.java
index eaee52d2eb5c9051b1114ae307022d83984e5840..0e31fe8412cef25b209c72a628756d5b67cce79f 100644
--- a/src/main/java/com/mojang/datafixers/functions/PointFreeRule.java
+++ b/src/main/java/com/mojang/datafixers/functions/PointFreeRule.java
@@ -25,16 +25,23 @@ import org.apache.commons.lang3.ObjectUtils;
import java.util.BitSet;
import java.util.List;
import java.util.Objects;
-import java.util.Optional;
import java.util.function.Function;
import java.util.function.Supplier;
public interface PointFreeRule {
- <A> Optional<? extends PointFree<A>> rewrite(final Type<A> type, final PointFree<A> expr);
+ // Yatopia start - Cadmium port
+ <A> PointFree<A> rewrite(final Type<A> type, final PointFree<A> expr);
- default <A, B> Optional<View<A, B>> rewrite(final View<A, B> view) {
- return rewrite(view.getFuncType(), view.function()).map(pf -> View.create(view.type(), view.newType(), pf));
+ default <A, B> View<A, B> rewrite(final View<A, B> view) {
+ PointFree<Function<A, B>> result = rewrite(view.getFuncType(), view.function());
+
+ if (result!=null) {
+ return View.create(view.type(), view.newType(), result);
+ }
+
+ return null;
}
+ // Yatopia end
default <A> PointFree<A> rewriteOrNop(final Type<A> type, final PointFree<A> expr) {
return DataFixUtils.orElse(rewrite(type, expr), expr);
@@ -52,9 +59,11 @@ public interface PointFreeRule {
INSTANCE;
@Override
- public <A> Optional<PointFree<A>> rewrite(final Type<A> type, final PointFree<A> expr) {
- return Optional.of(expr);
+ // Yatopia start - Cadmium port
+ public <A> PointFree<A> rewrite(final Type<A> type, final PointFree<A> expr) {
+ return expr;
}
+ // Yatopia end
@Override
public PointFreeRule get() {
@@ -67,25 +76,28 @@ public interface PointFreeRule {
@SuppressWarnings("unchecked")
@Override
- public <A> Optional<? extends PointFree<A>> rewrite(final Type<A> type, final PointFree<A> expr) {
+ // Yatopia start - Cadmium port
+ public <A> PointFree<A> rewrite(final Type<A> type, final PointFree<A> expr) {
if (expr instanceof Bang) {
- return Optional.empty();
+ return null;
}
if (type instanceof Func<?, ?>) {
final Func<?, ?> func = (Func<?, ?>) type;
if (func.second() instanceof EmptyPart) {
- return Optional.of((PointFree<A>) Functions.bang());
+ return (PointFree<A>) Functions.bang();
}
}
- return Optional.empty();
+ return null;
}
+ // Yatopia end
}
enum CompAssocLeft implements PointFreeRule {
INSTANCE;
@Override
- public <A> Optional<? extends PointFree<A>> rewrite(final Type<A> type, final PointFree<A> expr) {
+ // Yatopia start - Cadmium port
+ public <A> PointFree<A> rewrite(final Type<A> type, final PointFree<A> expr) {
if (expr instanceof Comp<?, ?, ?>) {
final Comp<?, ?, ?> comp2 = (Comp<?, ?, ?>) expr;
final PointFree<? extends Function<?, ?>> second = comp2.second;
@@ -94,13 +106,14 @@ public interface PointFreeRule {
return swap(comp1, comp2);
}
}
- return Optional.empty();
+ return null;
}
+ // Yatopia end
@SuppressWarnings("unchecked")
- private static <A, B, C, D, E> Optional<PointFree<E>> swap(final Comp<A, B, C> comp1, final Comp<?, ?, D> comp2raw) {
+ private static <A, B, C, D, E> PointFree<E> swap(final Comp<A, B, C> comp1, final Comp<?, ?, D> comp2raw) { // Yatopia - Cadmium port
final Comp<A, C, D> comp2 = (Comp<A, C, D>) comp2raw;
- return Optional.of((PointFree<E>) new Comp<>(comp1.middleType, new Comp<>(comp2.middleType, comp2.first, comp1.first), comp1.second));
+ return (PointFree<E>) new Comp<>(comp1.middleType, new Comp<>(comp2.middleType, comp2.first, comp1.first), comp1.second); // Yatopia - Cadmium port
}
}
@@ -108,7 +121,7 @@ public interface PointFreeRule {
INSTANCE;
@Override
- public <A> Optional<? extends PointFree<A>> rewrite(final Type<A> type, final PointFree<A> expr) {
+ public <A> PointFree<A> rewrite(final Type<A> type, final PointFree<A> expr) { // Yatopia - Cadmium port
if (expr instanceof Comp<?, ?, ?>) {
final Comp<?, ?, ?> comp1 = (Comp<?, ?, ?>) expr;
final PointFree<? extends Function<?, ?>> first = comp1.first;
@@ -117,13 +130,13 @@ public interface PointFreeRule {
return swap(comp1, comp2);
}
}
- return Optional.empty();
+ return null; // Yatopia - Cadmium port
}
@SuppressWarnings("unchecked")
- private static <A, B, C, D, E> Optional<PointFree<E>> swap(final Comp<A, B, D> comp1, final Comp<?, C, ?> comp2raw) {
+ private static <A, B, C, D, E> PointFree<E> swap(final Comp<A, B, D> comp1, final Comp<?, C, ?> comp2raw) { // Yatopia - Cadmium port
final Comp<B, C, D> comp2 = (Comp<B, C, D>) comp2raw;
- return Optional.of((PointFree<E>) new Comp<>(comp2.middleType, comp2.first, new Comp<>(comp1.middleType, comp2.second, comp1.second)));
+ return (PointFree<E>) new Comp<>(comp2.middleType, comp2.first, new Comp<>(comp1.middleType, comp2.second, comp1.second)); // Yatopia - Cadmium port
}
}
@@ -133,15 +146,15 @@ public interface PointFreeRule {
// (ap lens id) -> id
@SuppressWarnings("unchecked")
@Override
- public <A> Optional<? extends PointFree<A>> rewrite(final Type<A> type, final PointFree<A> expr) {
+ public <A> PointFree<A> rewrite(final Type<A> type, final PointFree<A> expr) { // Yatopia - Cadmium port
if (expr instanceof Apply<?, ?>) {
final Apply<?, A> apply = (Apply<?, A>) expr;
final PointFree<? extends Function<?, A>> func = apply.func;
if (func instanceof ProfunctorTransformer<?, ?, ?, ?> && Objects.equals(apply.arg, Functions.id())) {
- return Optional.of((PointFree<A>) Functions.id());
+ return (PointFree<A>) Functions.id(); // Yatopia - Cadmium port
}
}
- return Optional.empty();
+ return null;
}
}
@@ -150,7 +163,7 @@ public interface PointFreeRule {
// (ap f1 (ap f2 arg)) -> (ap (f1 ◦ f2) arg)
@Override
- public <A> Optional<? extends PointFree<A>> rewrite(final Type<A> type, final PointFree<A> expr) {
+ public <A> PointFree<A> rewrite(final Type<A> type, final PointFree<A> expr) { // Yatopia - Cadmium port
if (expr instanceof Apply<?, ?>) {
final Apply<?, ?> applyFirst = (Apply<?, ?>) expr;
if (applyFirst.arg instanceof Apply<?, ?>) {
@@ -158,46 +171,54 @@ public interface PointFreeRule {
return cap(applyFirst, applySecond);
}
}
- return Optional.empty();
+ return null; // Yatopia - Cadmium port
}
@SuppressWarnings("unchecked")
- private <A, B, C, D, E> Optional<? extends PointFree<A>> cap(final Apply<D, E> applyFirst, final Apply<B, C> applySecond) {
+ private <A, B, C, D, E> PointFree<A> cap(final Apply<D, E> applyFirst, final Apply<B, C> applySecond) { // Yatopia - Cadmium port
final PointFree<?> func = applySecond.func;
- return Optional.of((PointFree<A>) Functions.app(Functions.comp(applyFirst.argType, applyFirst.func, (PointFree<Function<B, D>>) func), applySecond.arg, applySecond.argType));
+ return (PointFree<A>) Functions.app(Functions.comp(applyFirst.argType, applyFirst.func, (PointFree<Function<B, D>>) func), applySecond.arg, applySecond.argType); // Yatopia - Cadmium port
}
}
interface CompRewrite extends PointFreeRule {
@Override
- default <A> Optional<? extends PointFree<A>> rewrite(final Type<A> type, final PointFree<A> expr) {
+ default <A> PointFree<A> rewrite(final Type<A> type, final PointFree<A> expr) { // Yatopia - Cadmium port
if (expr instanceof Comp<?, ?, ?>) {
final Comp<?, ?, ?> comp = (Comp<?, ?, ?>) expr;
final PointFree<? extends Function<?, ?>> first = comp.first;
final PointFree<? extends Function<?, ?>> second = comp.second;
if (first instanceof Comp<?, ?, ?>) {
final Comp<?, ?, ?> firstComp = (Comp<?, ?, ?>) first;
- return doRewrite(type, comp.middleType, firstComp.second, comp.second).map(result -> {
+ final PointFree<?> result = doRewrite(type, comp.middleType, firstComp.second, comp.second); // Yatopia - Cadmium port
+
+ if (result!=null) { // Yatopia - Cadmium port
if (result instanceof Comp<?, ?, ?>) {
final Comp<?, ?, ?> resultComp = (Comp<?, ?, ?>) result;
return buildLeftNested(resultComp, firstComp);
}
return buildRight(firstComp, result);
- });
+ } // Yatopia - Cadmium port
+
+ return null;
}
if (second instanceof Comp<?, ?, ?>) {
final Comp<?, ?, ?> secondComp = (Comp<?, ?, ?>) second;
- return doRewrite(type, comp.middleType, comp.first, secondComp.first).map(result -> {
+ final PointFree<?> result = doRewrite(type, comp.middleType, comp.first, secondComp.first); // Yatopia - Cadmium port
+
+ if (result!=null) { // Yatopia - Cadmium port
if (result instanceof Comp<?, ?, ?>) {
final Comp<?, ?, ?> resultComp = (Comp<?, ?, ?>) result;
return buildRightNested(secondComp, resultComp);
}
return buildLeft(result, secondComp);
- });
+ }
+
+ return null; // Yatopia - Cadmium port
}
- return (Optional<? extends PointFree<A>>) doRewrite(type, comp.middleType, comp.first, comp.second);
+ return (PointFree<A>) doRewrite(type, comp.middleType, comp.first, comp.second); // Yatopia - Cadmium port
}
- return Optional.empty();
+ return null; // Yatopia - Cadmium port
}
@SuppressWarnings("unchecked")
@@ -222,7 +243,7 @@ public interface PointFreeRule {
return (PointFree<E>) new Comp<>(comp2.middleType, comp2.first, new Comp<>(comp1.middleType, comp2.second, comp1.second));
}
- <A> Optional<? extends PointFree<?>> doRewrite(Type<A> type, Type<?> middleType, PointFree<? extends Function<?, ?>> first, PointFree<? extends Function<?, ?>> second);
+ <A> PointFree<?> doRewrite(Type<A> type, Type<?> middleType, PointFree<? extends Function<?, ?>> first, PointFree<? extends Function<?, ?>> second); // Yatopia - Cadmium port
}
enum SortProj implements CompRewrite {
@@ -230,7 +251,7 @@ public interface PointFreeRule {
// (ap π1 f)◦(ap π2 g) -> (ap π2 g)◦(ap π1 f)
@Override
- public <A> Optional<? extends PointFree<?>> doRewrite(final Type<A> type, final Type<?> middleType, final PointFree<? extends Function<?, ?>> first, final PointFree<? extends Function<?, ?>> second) {
+ public <A> PointFree<?> doRewrite(final Type<A> type, final Type<?> middleType, final PointFree<? extends Function<?, ?>> first, final PointFree<? extends Function<?, ?>> second) { // Yatopia - Cadmium port
if (first instanceof Apply<?, ?> && second instanceof Apply<?, ?>) {
final Apply<?, ?> applyFirst = (Apply<?, ?>) first;
final Apply<?, ?> applySecond = (Apply<?, ?>) second;
@@ -253,11 +274,11 @@ public interface PointFreeRule {
if (Objects.equals(fo, Optics.proj2()) && Objects.equals(so, Optics.proj1())) {
final Func<?, ?> firstArg = (Func<?, ?>) applyFirst.argType;
final Func<?, ?> secondArg = (Func<?, ?>) applySecond.argType;
- return Optional.of(cap(firstArg, secondArg, applyFirst, applySecond));
+ return cap(firstArg, secondArg, applyFirst, applySecond); // Yatopia - Cadmium port
}
}
}
- return Optional.empty();
+ return null; // Yatopia - Cadmium port
}
@SuppressWarnings("unchecked")
@@ -275,7 +296,7 @@ public interface PointFreeRule {
// (ap i1 f)◦(ap i2 g) -> (ap i2 g)◦(ap i1 f)
@Override
- public <A> Optional<? extends PointFree<?>> doRewrite(final Type<A> type, final Type<?> middleType, final PointFree<? extends Function<?, ?>> first, final PointFree<? extends Function<?, ?>> second) {
+ public <A> PointFree<?> doRewrite(final Type<A> type, final Type<?> middleType, final PointFree<? extends Function<?, ?>> first, final PointFree<? extends Function<?, ?>> second) { // Yatopia - Cadmium port
if (first instanceof Apply<?, ?> && second instanceof Apply<?, ?>) {
final Apply<?, ?> applyFirst = (Apply<?, ?>) first;
final Apply<?, ?> applySecond = (Apply<?, ?>) second;
@@ -298,11 +319,11 @@ public interface PointFreeRule {
if (Objects.equals(fo, Optics.inj2()) && Objects.equals(so, Optics.inj1())) {
final Func<?, ?> firstArg = (Func<?, ?>) applyFirst.argType;
final Func<?, ?> secondArg = (Func<?, ?>) applySecond.argType;
- return Optional.of(cap(firstArg, secondArg, applyFirst, applySecond));
+ return cap(firstArg, secondArg, applyFirst, applySecond); // Yatopia - Cadmium port
}
}
}
- return Optional.empty();
+ return null; // Yatopia - Cadmium port
}
@SuppressWarnings("unchecked")
@@ -320,7 +341,7 @@ public interface PointFreeRule {
// Optic[o1] ◦ Optic[o2] -> Optic[o1 ◦ o2]
@Override
- public <A> Optional<? extends PointFree<A>> rewrite(final Type<A> type, final PointFree<A> expr) {
+ public <A> PointFree<A> rewrite(final Type<A> type, final PointFree<A> expr) { // Yatopia - Cadmium port
if (expr instanceof Comp<?, ?, ?>) {
final Comp<?, ?, ?> comp = (Comp<?, ?, ?>) expr;
final PointFree<? extends Function<?, ?>> first = comp.first;
@@ -328,10 +349,10 @@ public interface PointFreeRule {
if (first instanceof ProfunctorTransformer<?, ?, ?, ?> && second instanceof ProfunctorTransformer<?, ?, ?, ?>) {
final ProfunctorTransformer<?, ?, ?, ?> firstOptic = (ProfunctorTransformer<?, ?, ?, ?>) first;
final ProfunctorTransformer<?, ?, ?, ?> secondOptic = (ProfunctorTransformer<?, ?, ?, ?>) second;
- return Optional.of(cap(firstOptic, secondOptic));
+ return cap(firstOptic, secondOptic); // Yatopia - Cadmium port
}
}
- return Optional.empty();
+ return null; // Yatopia - Cadmium port
}
@SuppressWarnings("unchecked")
@@ -345,9 +366,8 @@ public interface PointFreeRule {
INSTANCE;
// (ap lens f)◦(ap lens g) -> (ap lens (f ◦ g))
- @SuppressWarnings("unchecked")
@Override
- public <A> Optional<? extends PointFree<?>> doRewrite(final Type<A> type, final Type<?> middleType, final PointFree<? extends Function<?, ?>> first, final PointFree<? extends Function<?, ?>> second) {
+ public <A> PointFree<?> doRewrite(final Type<A> type, final Type<?> middleType, final PointFree<? extends Function<?, ?>> first, final PointFree<? extends Function<?, ?>> second) { // Yatopia - Cadmium port
if (first instanceof Apply<?, ?> && second instanceof Apply<?, ?>) {
final Apply<?, ?> applyFirst = (Apply<?, ?>) first;
final Apply<?, ?> applySecond = (Apply<?, ?>) second;
@@ -364,17 +384,17 @@ public interface PointFreeRule {
}
}
}
- return Optional.empty();
+ return null; // Yatopia - Cadmium port
}
- private <R, A, B, C, S, T, U> Optional<? extends PointFree<R>> cap(final ProfunctorTransformer<S, T, A, B> l1, final ProfunctorTransformer<?, U, ?, C> l2, final PointFree<?> f1, final PointFree<?> f2, final Func<?, ?> firstType, final Func<?, ?> secondType) {
+ private <R, A, B, C, S, T, U> PointFree<R> cap(final ProfunctorTransformer<S, T, A, B> l1, final ProfunctorTransformer<?, U, ?, C> l2, final PointFree<?> f1, final PointFree<?> f2, final Func<?, ?> firstType, final Func<?, ?> secondType) { // Yatopia - Cadmium port
return cap2(l1, (ProfunctorTransformer<T, U, B, C>) l2, (PointFree<Function<B, C>>) f1, (PointFree<Function<A, B>>) f2, (Func<B, C>) firstType, (Func<A, B>) secondType);
}
- private <R, P extends K2, Proof extends K1, A, B, C, S, T, U> Optional<? extends PointFree<R>> cap2(final ProfunctorTransformer<S, T, A, B> l1, final ProfunctorTransformer<T, U, B, C> l2, final PointFree<Function<B, C>> f1, final PointFree<Function<A, B>> f2, final Func<B, C> firstType, final Func<A, B> secondType) {
+ private <R, P extends K2, Proof extends K1, A, B, C, S, T, U> PointFree<R> cap2(final ProfunctorTransformer<S, T, A, B> l1, final ProfunctorTransformer<T, U, B, C> l2, final PointFree<Function<B, C>> f1, final PointFree<Function<A, B>> f2, final Func<B, C> firstType, final Func<A, B> secondType) { // Yatopia - Cadmium port
final PointFree<Function<Function<A, C>, Function<S, U>>> lens = (PointFree<Function<Function<A, C>, Function<S, U>>>) (PointFree<?>) l1;
final PointFree<Function<A, C>> arg = Functions.comp(firstType.first(), f1, f2);
- return Optional.of((PointFree<R>) Functions.app(lens, arg, DSL.func(secondType.first(), firstType.second())));
+ return (PointFree<R>) Functions.app(lens, arg, DSL.func(secondType.first(), firstType.second())); // Yatopia - Cadmium port
}
}
@@ -382,15 +402,14 @@ public interface PointFreeRule {
INSTANCE;
// (fold g ◦ in) ◦ fold (f ◦ in) -> fold ( g ◦ f ◦ in), <== g ◦ in ◦ fold (f ◦ in) ◦ out == in ◦ fold (f ◦ in) ◦ out ◦ g <== g doesn't touch fold's index
- @SuppressWarnings("unchecked")
@Override
- public <A> Optional<? extends PointFree<?>> doRewrite(final Type<A> type, final Type<?> middleType, final PointFree<? extends Function<?, ?>> first, final PointFree<? extends Function<?, ?>> second) {
+ public <A> PointFree<?> doRewrite(final Type<A> type, final Type<?> middleType, final PointFree<? extends Function<?, ?>> first, final PointFree<? extends Function<?, ?>> second) { // Yatopia - Cadmium port
if (first instanceof Fold<?, ?> && second instanceof Fold<?, ?>) {
// fold (_) ◦ fold (_)
final Fold<?, ?> firstFold = (Fold<?, ?>) first;
final Fold<?, ?> secondFold = (Fold<?, ?>) second;
final RecursiveTypeFamily family = firstFold.aType.family();
- if (Objects.equals(family, secondFold.aType.family()) && firstFold.index == secondFold.index) {
+ if (firstFold.index==secondFold.index && Objects.equals(family, secondFold.aType.family())) { // Yatopia - Cadmium port
// same fold
final List<RewriteResult<?, ?>> newAlgebra = Lists.newArrayList();
@@ -399,8 +418,8 @@ public interface PointFreeRule {
boolean foundOne = false;
for (int i = 0; i < family.size(); i++) {
final RewriteResult<?, ?> firstAlgFunc = firstFold.algebra.apply(i);
- final RewriteResult<?, ?> secondAlgFunc = secondFold.algebra.apply(i);
final boolean firstId = Objects.equals(CompAssocRight.INSTANCE.rewriteOrNop(firstAlgFunc.view()).function(), Functions.id());
+ /*
final boolean secondId = Objects.equals(secondAlgFunc.view().function(), Functions.id());
if (firstId && secondId) {
@@ -408,15 +427,37 @@ public interface PointFreeRule {
} else if (!foundOne && !firstId && !secondId) {
newAlgebra.add(getCompose(firstAlgFunc, secondAlgFunc));
foundOne = true;
+ */
+ // Yatopia start - Cadmium port
+ if (firstId) {
+ final RewriteResult<?, ?> secondAlgFunc = secondFold.algebra.apply(i);
+ final boolean secondId = Objects.equals(secondAlgFunc.view().function(), Functions.id());
+
+ if (secondId) {
+ newAlgebra.add(firstFold.algebra.apply(i));
+ } else {
+ return null;
+ }
+ } else if (!foundOne) {
+ final RewriteResult<?, ?> secondAlgFunc = secondFold.algebra.apply(i);
+ final boolean secondId = Objects.equals(secondAlgFunc.view().function(), Functions.id());
+
+ if (!secondId) {
+ newAlgebra.add(getCompose(firstAlgFunc, secondAlgFunc));
+ foundOne = true;
+ } else {
+ return null;
+ }
+ // Yatopia end
} else {
- return Optional.empty();
+ return null; // Yatopia - Cadmium port
}
}
final Algebra algebra = new ListAlgebra("FusedSame", newAlgebra);
- return Optional.of((PointFree<A>) family.fold(algebra).apply(firstFold.index).view().function());
+ return family.fold(algebra).apply(firstFold.index).view().function(); // Yatopia - Cadmium port
}
}
- return Optional.empty();
+ return null; // Yatopia - Cadmium port
}
@SuppressWarnings("unchecked")
@@ -431,13 +472,14 @@ public interface PointFreeRule {
// (fold g ◦ in) ◦ fold (f ◦ in) -> fold ( g ◦ f ◦ in), <== g ◦ in ◦ fold (f ◦ in) ◦ out == in ◦ fold (f ◦ in) ◦ out ◦ g <== g doesn't touch fold's index
@SuppressWarnings("unchecked")
@Override
- public <A> Optional<? extends PointFree<?>> doRewrite(final Type<A> type, final Type<?> middleType, final PointFree<? extends Function<?, ?>> first, final PointFree<? extends Function<?, ?>> second) {
+ public <A> PointFree<?> doRewrite(final Type<A> type, final Type<?> middleType, final PointFree<? extends Function<?, ?>> first, final PointFree<? extends Function<?, ?>> second) { // Yatopia - Cadmium port
if (first instanceof Fold<?, ?> && second instanceof Fold<?, ?>) {
// fold (_) ◦ fold (_)
final Fold<?, ?> firstFold = (Fold<?, ?>) first;
final Fold<?, ?> secondFold = (Fold<?, ?>) second;
final RecursiveTypeFamily family = firstFold.aType.family();
- if (Objects.equals(family, secondFold.aType.family()) && firstFold.index == secondFold.index) {
+ // if (Objects.equals(family, secondFold.aType.family()) && firstFold.index == secondFold.index) {
+ if (firstFold.index==secondFold.index && Objects.equals(family, secondFold.aType.family())) { // Yatopia - Cadmium port
// same fold
final List<RewriteResult<?, ?>> newAlgebra = Lists.newArrayList();
@@ -460,46 +502,57 @@ public interface PointFreeRule {
// TODO: verify that this is enough
for (int i = 0; i < family.size(); i++) {
final RewriteResult<?, ?> firstAlgFunc = firstFold.algebra.apply(i);
+ // Yatopia start - Cadmium port
+ if (firstAlgFunc.recData().intersects(secondModifies)) {
+ // outer function depends on the result of the inner one
+ return null;
+ }
+ // Yatopia end
final RewriteResult<?, ?> secondAlgFunc = secondFold.algebra.apply(i);
+ /*
final PointFree<?> firstF = CompAssocRight.INSTANCE.rewriteOrNop(firstAlgFunc.view()).function();
final PointFree<?> secondF = CompAssocRight.INSTANCE.rewriteOrNop(secondAlgFunc.view()).function();
final boolean firstId = Objects.equals(firstF, Functions.id());
final boolean secondId = Objects.equals(secondF, Functions.id());
if (firstAlgFunc.recData().intersects(secondModifies) || secondAlgFunc.recData().intersects(firstModifies)) {
+ */
+ // Yatopia start - Cadmium port
+ if (secondAlgFunc.recData().intersects(firstModifies)) {
// outer function depends on the result of the inner one
- return Optional.empty();
+ return null;
}
- if (firstId) {
+ // Yatopia end
+ if (Objects.equals(CompAssocRight.INSTANCE.rewriteOrNop(firstAlgFunc.view()).function(), Functions.id())) { // Yatopia - Cadmium port
newAlgebra.add(secondAlgFunc);
- } else if (secondId) {
+ } else if (Objects.equals(CompAssocRight.INSTANCE.rewriteOrNop(secondAlgFunc.view()).function(), Functions.id())) { // Yatopia - Cadmium port
newAlgebra.add(firstAlgFunc);
} else {
- return Optional.empty();
+ return null; // Yatopia - Cadmium port
}
}
// have new algebra - make a new fold
final Algebra algebra = new ListAlgebra("FusedDifferent", newAlgebra);
- return Optional.of((PointFree<A>) family.fold(algebra).apply(firstFold.index).view().function());
+ return family.fold(algebra).apply(firstFold.index).view().function(); // Yatopia - Cadmium port
}
}
- return Optional.empty();
+ return null; // Yatopia - Cadmium port
}
}
/*final class ReflexCata implements Rule {
@SuppressWarnings("unchecked")
@Override
- public <A> Optional<? extends PF<A>> rewrite(final Type<A> type, final PF<A> expr) {
+ public <A> PF<A> rewrite(final Type<A> type, final PF<A> expr) { // Yatopia - Cadmium port
if (type instanceof Type.Func<?, ?> && expr instanceof PF.Cata<?, ?, ?, ?>) {
final Type.Func<?, ?> funcType = (Type.Func<?, ?>) type;
final PF.Cata<?, ?, ?, ?> cata = (PF.Cata<?, ?, ?, ?>) expr;
// TODO better equality
if (Objects.equals(cata.alg, PF.genBF(cata.family.to)) && Objects.equals(funcType.first, funcType.second)) {
- return Optional.of((PF<A>) PF.id());
+ return (PF<A>) PF.id(); // Yatopia - Cadmium port
}
}
- return Optional.empty();
+ return null; // Yatopia - Cadmium port
}
}*/
@@ -518,14 +571,20 @@ public interface PointFreeRule {
this.rules = ImmutableList.copyOf(rules);
}
+ // Yatopia start - Cadmium port
@Override
- public <A> Optional<? extends PointFree<A>> rewrite(final Type<A> type, final PointFree<A> expr) {
- Optional<? extends PointFree<A>> result = Optional.of(expr);
+ public <A> PointFree<A> rewrite(final Type<A> type, final PointFree<A> expr) {
+ PointFree<A> result = expr;
for (final Supplier<PointFreeRule> rule : rules) {
- result = result.flatMap(pf -> rule.get().<A>rewrite(type, pf));
+ if (result==null) {
+ return null;
+ }
+
+ result = rule.get().rewrite(type, result);
}
return result;
}
+ // Yatopia end
@Override
public boolean equals(final Object obj) {
@@ -546,30 +605,28 @@ public interface PointFreeRule {
}
static PointFreeRule orElse(final PointFreeRule first, final PointFreeRule second) {
- return new OrElse(first, () -> second);
- }
-
- static PointFreeRule orElseStrict(final PointFreeRule first, final Supplier<PointFreeRule> second) {
return new OrElse(first, second);
}
final class OrElse implements PointFreeRule {
protected final PointFreeRule first;
- protected final Supplier<PointFreeRule> second;
+ protected final PointFreeRule second; // Yatopia - Cadmium port
- public OrElse(final PointFreeRule first, final Supplier<PointFreeRule> second) {
+ public OrElse(final PointFreeRule first, final PointFreeRule second) { // Yatopia - Cadmium port
this.first = first;
this.second = second;
}
+ // Yatopia start - Cadmium port
@Override
- public <A> Optional<? extends PointFree<A>> rewrite(final Type<A> type, final PointFree<A> expr) {
- final Optional<? extends PointFree<A>> view = first.rewrite(type, expr);
- if (view.isPresent()) {
+ public <A> PointFree<A> rewrite(final Type<A> type, final PointFree<A> expr) {
+ final PointFree<A> view = first.rewrite(type, expr);
+ if (view!=null) {
return view;
}
- return second.get().rewrite(type, expr);
+ return second.rewrite(type, expr);
}
+ // Yatopia end
@Override
public boolean equals(final Object obj) {
@@ -589,6 +646,42 @@ public interface PointFreeRule {
}
}
+ // Yatopia start - Cadmium port
+ final class OrElseStrict implements PointFreeRule {
+ protected final PointFreeRule rule;
+
+ public OrElseStrict(final PointFreeRule rule) {
+ this.rule = rule;
+ }
+
+ @Override
+ public <A> PointFree<A> rewrite(final Type<A> type, final PointFree<A> expr) {
+ final PointFree<A> view = rule.rewrite(type, expr);
+ if (view!=null) {
+ return view;
+ }
+ return expr.one(this, type);
+ }
+
+ @Override
+ public boolean equals(final Object obj) {
+ if (obj == this) {
+ return true;
+ }
+ if (!(obj instanceof OrElse)) {
+ return false;
+ }
+ final OrElse that = (OrElse) obj;
+ return Objects.equals(rule, that.first);
+ }
+
+ @Override
+ public int hashCode() {
+ return Objects.hash(rule);
+ }
+ }
+ // Yatopia end
+
static PointFreeRule all(final PointFreeRule rule) {
return new All(rule);
}
@@ -598,7 +691,7 @@ public interface PointFreeRule {
}
static PointFreeRule once(final PointFreeRule rule) {
- return orElseStrict(rule, () -> one(once(rule)));
+ return new OrElseStrict(rule); // Yatopia - Cadmium port
}
static PointFreeRule many(final PointFreeRule rule) {
@@ -617,7 +710,7 @@ public interface PointFreeRule {
}
@Override
- public <A> Optional<? extends PointFree<A>> rewrite(final Type<A> type, final PointFree<A> expr) {
+ public <A> PointFree<A> rewrite(final Type<A> type, final PointFree<A> expr) { // Yatopia - Cadmium port
return expr.all(rule, type);
}
@@ -647,7 +740,7 @@ public interface PointFreeRule {
}
@Override
- public <A> Optional<? extends PointFree<A>> rewrite(final Type<A> type, final PointFree<A> expr) {
+ public <A> PointFree<A> rewrite(final Type<A> type, final PointFree<A> expr) { // Yatopia - Cadmium port
return expr.one(rule, type);
}
@@ -676,17 +769,22 @@ public interface PointFreeRule {
this.rule = rule;
}
+ // Yatopia start - Cadmium port
@Override
- public <A> Optional<? extends PointFree<A>> rewrite(final Type<A> type, final PointFree<A> expr) {
- Optional<? extends PointFree<A>> result = Optional.of(expr);
+ public <A> PointFree<A> rewrite(final Type<A> type, final PointFree<A> expr) {
+ PointFree<A> result = expr;
while (true) {
- final Optional<? extends PointFree<A>> newResult = result.flatMap(e -> rule.rewrite(type, e).map(r -> r));
- if (!newResult.isPresent()) {
+ if (result==null) {
+ return null;
+ }
+ final PointFree<A> newResult = rule.rewrite(type, result);
+ if (newResult==null) {
return result;
}
result = newResult;
}
}
+ // Yatopia end
@Override
public boolean equals(final Object o) {
diff --git a/src/main/java/com/mojang/datafixers/optics/IdAdapter.java b/src/main/java/com/mojang/datafixers/optics/IdAdapter.java
index 3f1793aca685a627d0e925d037f663a257522d8d..0e4bf4b58710be135e6573ccff3f8c0a2a41191a 100644
--- a/src/main/java/com/mojang/datafixers/optics/IdAdapter.java
+++ b/src/main/java/com/mojang/datafixers/optics/IdAdapter.java
@@ -3,6 +3,14 @@
package com.mojang.datafixers.optics;
class IdAdapter<S, T> implements Adapter<S, T, S, T> {
+ // Yatopia start - Cadmium port
+ private static final Adapter<?, ?, ?, ?> INSTANCE = new IdAdapter<>();
+
+ private IdAdapter() {
+
+ }
+ // Yatopia end
+
@Override
public S from(final S s) {
return s;
@@ -22,4 +30,11 @@ class IdAdapter<S, T> implements Adapter<S, T, S, T> {
public String toString() {
return "id";
}
+
+ // Yatopia start - Cadmium port
+ @SuppressWarnings("unchecked")
+ public static <S, T> Adapter<S, T, S, T> instance() {
+ return (Adapter<S, T, S, T>) INSTANCE;
+ }
+ // Yatopia end
}
diff --git a/src/main/java/com/mojang/datafixers/optics/Inj1.java b/src/main/java/com/mojang/datafixers/optics/Inj1.java
index 8c56955c9d6c3d6021d5c9fda452e39774ac587c..4813f335cd536d1b32b9095dbd76e18c22a6dea1 100644
--- a/src/main/java/com/mojang/datafixers/optics/Inj1.java
+++ b/src/main/java/com/mojang/datafixers/optics/Inj1.java
@@ -5,6 +5,14 @@ package com.mojang.datafixers.optics;
import com.mojang.datafixers.util.Either;
public final class Inj1<F, G, F2> implements Prism<Either<F, G>, Either<F2, G>, F, F2> {
+ // Yatopia start - Cadmium port
+ private static final Inj1<?, ?, ?> INSTANCE = new Inj1<>();
+
+ private Inj1() {
+
+ }
+ // Yatopia end
+
@Override
public Either<Either<F2, G>, F> match(final Either<F, G> either) {
return either.map(Either::right, g -> Either.left(Either.right(g)));
@@ -24,4 +32,11 @@ public final class Inj1<F, G, F2> implements Prism<Either<F, G>, Either<F2, G>,
public boolean equals(final Object obj) {
return obj instanceof Inj1<?, ?, ?>;
}
+
+ // Yatopia start - Cadmium port
+ @SuppressWarnings("unchecked")
+ public static <F, G, F2> Inj1<F, G, F2> instance() {
+ return (Inj1<F, G, F2>) INSTANCE;
+ }
+ // Yatopia end
}
diff --git a/src/main/java/com/mojang/datafixers/optics/Inj2.java b/src/main/java/com/mojang/datafixers/optics/Inj2.java
index 2f95715f310faec6e43c715cbf204a092bfc107e..ad2400ccdb159cbf8b882d0b5afc53d3e220f770 100644
--- a/src/main/java/com/mojang/datafixers/optics/Inj2.java
+++ b/src/main/java/com/mojang/datafixers/optics/Inj2.java
@@ -2,9 +2,18 @@
// Licensed under the MIT license.
package com.mojang.datafixers.optics;
+import com.mojang.datafixers.DataFixerBuilder; // Yatopia - Cadmium port
import com.mojang.datafixers.util.Either;
public final class Inj2<F, G, G2> implements Prism<Either<F, G>, Either<F, G2>, G, G2> {
+ // Yatopia start - Cadmium port
+ private static final Inj2<?, ?, ?> INSTANCE = new Inj2<>();
+
+ private Inj2() {
+
+ }
+ // Yatopia end
+
@Override
public Either<Either<F, G2>, G> match(final Either<F, G> either) {
return either.map(f -> Either.left(Either.left(f)), Either::right);
@@ -24,4 +33,11 @@ public final class Inj2<F, G, G2> implements Prism<Either<F, G>, Either<F, G2>,
public boolean equals(final Object obj) {
return obj instanceof Inj2<?, ?, ?>;
}
+
+ // Yatopia start - Cadmium port
+ @SuppressWarnings("unchecked")
+ public static <F, G, G2> Inj2<F, G, G2> instance() {
+ return (Inj2<F, G, G2>) INSTANCE;
+ }
+ // Yatopia end
}
diff --git a/src/main/java/com/mojang/datafixers/optics/Optics.java b/src/main/java/com/mojang/datafixers/optics/Optics.java
index 4bf469df6a9092a554df4dafdbfe37f51da28f32..cec492b8e633adedbf6c4d83cf257f640412de06 100644
--- a/src/main/java/com/mojang/datafixers/optics/Optics.java
+++ b/src/main/java/com/mojang/datafixers/optics/Optics.java
@@ -65,7 +65,7 @@ public abstract class Optics {
}
public static <S, T> Adapter<S, T, S, T> id() {
- return new IdAdapter<>();
+ return IdAdapter.instance(); // Yatopia - Cadmium port
}
public static <S, T, A, B> Adapter<S, T, A, B> adapter(final Function<S, A> from, final Function<B, T> to) {
@@ -223,19 +223,19 @@ public abstract class Optics {
}
public static <F, G, F2> Proj1<F, G, F2> proj1() {
- return new Proj1<>();
+ return Proj1.instance(); // Yatopia - Cadmium port
}
public static <F, G, G2> Proj2<F, G, G2> proj2() {
- return new Proj2<>();
+ return Proj2.instance(); // Yatopia - Cadmium port
}
public static <F, G, F2> Inj1<F, G, F2> inj1() {
- return new Inj1<>();
+ return Inj1.instance(); // Yatopia - Cadmium port
}
public static <F, G, G2> Inj2<F, G, G2> inj2() {
- return new Inj2<>();
+ return Inj2.instance(); // Yatopia - Cadmium port
}
/*public static <Proof extends Cartesian.Mu, S1, S2, T1, T2, A, B> Optic<Proof, Either<S1, S2>, Either<T1, T2>, A, B> choosing(final Optic<? super Profunctor.Mu, S1, T1, A, B> first, final Optic<? super Profunctor.Mu, S2, T2, A, B> second) {
diff --git a/src/main/java/com/mojang/datafixers/optics/Proj1.java b/src/main/java/com/mojang/datafixers/optics/Proj1.java
index 488e4cd9a87178a441eda0ee5bff9c5feca69e6d..ae8850e52feeff51f61c4527c792446ef5e23344 100644
--- a/src/main/java/com/mojang/datafixers/optics/Proj1.java
+++ b/src/main/java/com/mojang/datafixers/optics/Proj1.java
@@ -5,6 +5,14 @@ package com.mojang.datafixers.optics;
import com.mojang.datafixers.util.Pair;
public final class Proj1<F, G, F2> implements Lens<Pair<F, G>, Pair<F2, G>, F, F2> {
+ // Yatopia start - Cadmium port
+ private static final Proj1<?, ?, ?> INSTANCE = new Proj1<>();
+
+ private Proj1() {
+
+ }
+ // Yatopia end
+
@Override
public F view(final Pair<F, G> pair) {
return pair.getFirst();
@@ -24,4 +32,11 @@ public final class Proj1<F, G, F2> implements Lens<Pair<F, G>, Pair<F2, G>, F, F
public boolean equals(final Object obj) {
return obj instanceof Proj1<?, ?, ?>;
}
+
+ // Yatopia start - Cadmium port
+ @SuppressWarnings("unchecked")
+ public static <F, G, F2> Proj1<F, G, F2> instance() {
+ return (Proj1<F, G, F2>) INSTANCE;
+ }
+ // Yatopia end
}
diff --git a/src/main/java/com/mojang/datafixers/optics/Proj2.java b/src/main/java/com/mojang/datafixers/optics/Proj2.java
index 3bd3689115f25d34fceaa8f8f915c21656267af5..76d05449689808e3d0435aea7480dcad134730f1 100644
--- a/src/main/java/com/mojang/datafixers/optics/Proj2.java
+++ b/src/main/java/com/mojang/datafixers/optics/Proj2.java
@@ -5,6 +5,14 @@ package com.mojang.datafixers.optics;
import com.mojang.datafixers.util.Pair;
public final class Proj2<F, G, G2> implements Lens<Pair<F, G>, Pair<F, G2>, G, G2> {
+ // Yatopia start - Cadmium port
+ private static final Proj2<?, ?, ?> INSTANCE = new Proj2<>();
+
+ private Proj2() {
+
+ }
+ // Yatopia end
+
@Override
public G view(final Pair<F, G> pair) {
return pair.getSecond();
@@ -24,4 +32,11 @@ public final class Proj2<F, G, G2> implements Lens<Pair<F, G>, Pair<F, G2>, G, G
public boolean equals(final Object obj) {
return obj instanceof Proj2<?, ?, ?>;
}
+
+ // Yatopia start - Cadmium port
+ @SuppressWarnings("unchecked")
+ public static <F, G2, G> Proj2<F, G, G2> instance() {
+ return (Proj2<F, G, G2>) INSTANCE;
+ }
+ // Yatopia end
}
diff --git a/src/main/java/com/mojang/datafixers/types/Type.java b/src/main/java/com/mojang/datafixers/types/Type.java
index 4592da3c75e639164d10cc05518c27d8f488a103..53ab2332aaff5970e5f3825734906fc7f1f8c53c 100644
--- a/src/main/java/com/mojang/datafixers/types/Type.java
+++ b/src/main/java/com/mojang/datafixers/types/Type.java
@@ -87,7 +87,7 @@ public abstract class Type<A> implements App<Type.Mu, A> {
}
public Optional<RewriteResult<A, ?>> everywhere(final TypeRewriteRule rule, final PointFreeRule optimizationRule, final boolean recurse, final boolean checkIndex) {
- final TypeRewriteRule rule2 = TypeRewriteRule.seq(TypeRewriteRule.orElse(rule, TypeRewriteRule::nop), TypeRewriteRule.all(TypeRewriteRule.everywhere(rule, optimizationRule, recurse, checkIndex), recurse, checkIndex));
+ final TypeRewriteRule rule2 = TypeRewriteRule.seq(TypeRewriteRule.orElse(rule, TypeRewriteRule.Nop.INSTANCE), TypeRewriteRule.all(TypeRewriteRule.everywhere(rule, optimizationRule, recurse, checkIndex), recurse, checkIndex)); // Yatopia - Cadmium port
return rewrite(rule2, optimizationRule);
}
@@ -187,7 +187,17 @@ public abstract class Type<A> implements App<Type.Mu, A> {
});
if (ref.getValue() != null) {
- Optional<RewriteResult<A, ?>> result = rule.rewrite(this).flatMap(r -> r.view().rewrite(fRule).map(view -> RewriteResult.create(view, r.recData())));
+ // Yatopia start - Cadmium port
+ Optional<RewriteResult<A, ?>> result = rule.rewrite(this).flatMap(r -> {
+ View<A, ?> view = r.view().rewrite(fRule);
+
+ if (view!=null) {
+ return Optional.of(RewriteResult.create(view, r.recData()));
+ }
+
+ return Optional.empty();
+ });
+ // Yatopia end
REWRITE_CACHE.put(key, result);
pending.complete(result);
PENDING_REWRITE_CACHE.remove(key);