chore: fmt
This commit is contained in:
parent
ecf9086b35
commit
36f708b514
@ -4,11 +4,13 @@ import java.time.Duration;
|
||||
import java.util.Optional;
|
||||
|
||||
public abstract sealed class RetryStrategy {
|
||||
|
||||
@Override
|
||||
public boolean equals(Object other) {
|
||||
return switch (this) {
|
||||
case Exponential self -> switch (other) {
|
||||
case Exponential e -> e.initMin == self.initMin && e.initMax == self.initMax;
|
||||
case Exponential e -> e.initMin == self.initMin &&
|
||||
e.initMax == self.initMax;
|
||||
default -> false;
|
||||
};
|
||||
case Linear self -> switch (other) {
|
||||
@ -20,10 +22,12 @@ public abstract sealed class RetryStrategy {
|
||||
}
|
||||
|
||||
public final class Exponential extends RetryStrategy {
|
||||
|
||||
public final Duration initMin;
|
||||
public final Duration initMax;
|
||||
|
||||
private static native Exponential fromRust(byte[] mem);
|
||||
|
||||
private native byte[] toRust();
|
||||
|
||||
public Exponential(Duration initMin, Duration initMax) {
|
||||
@ -33,10 +37,12 @@ public abstract sealed class RetryStrategy {
|
||||
}
|
||||
|
||||
public final class Linear extends RetryStrategy {
|
||||
|
||||
public final Duration min;
|
||||
public final Duration max;
|
||||
|
||||
private static native Linear fromRust(byte[] mem);
|
||||
|
||||
private native byte[] toRust();
|
||||
|
||||
public Linear(Duration min, Duration max) {
|
||||
|
@ -1,6 +1,7 @@
|
||||
package dev.toad;
|
||||
|
||||
public class Runtime {
|
||||
|
||||
public static native void init(RuntimeOptions o);
|
||||
|
||||
private Runtime() {}
|
||||
|
@ -4,10 +4,16 @@ import java.util.List;
|
||||
|
||||
public interface Message {
|
||||
public int id();
|
||||
|
||||
public byte[] token();
|
||||
|
||||
public MessageCode code();
|
||||
|
||||
public MessageType type();
|
||||
|
||||
public List<MessageOption> options();
|
||||
|
||||
public byte[] payloadBytes();
|
||||
|
||||
public String payloadString();
|
||||
}
|
||||
|
@ -4,5 +4,6 @@ import java.util.List;
|
||||
|
||||
public interface MessageOption {
|
||||
public long number();
|
||||
|
||||
public List<MessageOptionValue> values();
|
||||
}
|
||||
|
@ -6,17 +6,25 @@ import java.util.List;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
public class MessageOptionOwned implements MessageOption {
|
||||
|
||||
public final long number;
|
||||
public final List<MessageOptionValue> values;
|
||||
|
||||
public MessageOptionOwned(MessageOptionRef ref) {
|
||||
this.number = ref.number();
|
||||
this.values = Arrays.asList(ref.valueRefs())
|
||||
this.values =
|
||||
Arrays
|
||||
.asList(ref.valueRefs())
|
||||
.stream()
|
||||
.map(MessageOptionValueRef::clone)
|
||||
.collect(Collectors.toList());
|
||||
}
|
||||
|
||||
public long number() {return this.number;}
|
||||
public List<MessageOptionValue> values() {return this.values;}
|
||||
public long number() {
|
||||
return this.number;
|
||||
}
|
||||
|
||||
public List<MessageOptionValue> values() {
|
||||
return this.values;
|
||||
}
|
||||
}
|
||||
|
@ -4,6 +4,7 @@ import java.util.Arrays;
|
||||
import java.util.List;
|
||||
|
||||
public class MessageOptionRef implements MessageOption {
|
||||
|
||||
private final long addr;
|
||||
private final long number;
|
||||
|
||||
|
@ -2,5 +2,6 @@ package dev.toad.msg;
|
||||
|
||||
public interface MessageOptionValue {
|
||||
public byte[] asBytes();
|
||||
|
||||
public String asString();
|
||||
}
|
||||
|
@ -6,6 +6,7 @@ import java.util.List;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
public class MessageOptionValueOwned implements MessageOptionValue {
|
||||
|
||||
public final byte[] bytes;
|
||||
|
||||
public MessageOptionValueOwned(MessageOptionValueRef ref) {
|
||||
|
@ -1,7 +1,9 @@
|
||||
package dev.toad.msg;
|
||||
|
||||
public class MessageOptionValueRef implements MessageOptionValue {
|
||||
|
||||
private final long addr;
|
||||
|
||||
private native byte[] bytes(long addr);
|
||||
|
||||
public MessageOptionValueRef(long addr) {
|
||||
|
@ -6,6 +6,7 @@ import java.util.List;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
public class MessageOwned implements Message {
|
||||
|
||||
private static int id;
|
||||
private static byte[] token;
|
||||
private static byte[] payload;
|
||||
@ -20,7 +21,9 @@ public class MessageOwned implements Message {
|
||||
this.type = ref.type();
|
||||
this.payload = ref.payloadBytes().clone();
|
||||
|
||||
this.opts = Arrays.asList(ref.optionRefs())
|
||||
this.opts =
|
||||
Arrays
|
||||
.asList(ref.optionRefs())
|
||||
.stream()
|
||||
.map(MessageOptionRef::clone)
|
||||
.collect(Collectors.toList());
|
||||
|
@ -11,13 +11,19 @@ import java.util.List;
|
||||
* MessageRef should never be stored in state; invoke `.clone()` first.
|
||||
*/
|
||||
public class MessageRef implements Message {
|
||||
|
||||
private final long addr;
|
||||
|
||||
private static native int id(long addr);
|
||||
|
||||
private static native byte[] token(long addr);
|
||||
|
||||
private static native byte[] payload(long addr);
|
||||
|
||||
private static native MessageCode code(long addr);
|
||||
|
||||
private static native MessageType type(long addr);
|
||||
|
||||
private static native MessageOptionRef[] opts(long addr);
|
||||
|
||||
public MessageRef(long addr) {
|
||||
|
@ -1,27 +1,40 @@
|
||||
package dev.toad.msg;
|
||||
|
||||
public enum MessageType {
|
||||
CON(1), NON(2), ACK(3), RESET(4);
|
||||
CON(1),
|
||||
NON(2),
|
||||
ACK(3),
|
||||
RESET(4);
|
||||
|
||||
private MessageType(int val) {}
|
||||
|
||||
public String toString() {
|
||||
switch(this) {
|
||||
case CON: return "CON";
|
||||
case NON: return "NON";
|
||||
case ACK: return "ACK";
|
||||
case RESET: return "RESET";
|
||||
default: throw new Error();
|
||||
switch (this) {
|
||||
case CON:
|
||||
return "CON";
|
||||
case NON:
|
||||
return "NON";
|
||||
case ACK:
|
||||
return "ACK";
|
||||
case RESET:
|
||||
return "RESET";
|
||||
default:
|
||||
throw new Error();
|
||||
}
|
||||
}
|
||||
|
||||
public static MessageType fromString(String s) {
|
||||
switch(s.toLowerCase().trim()) {
|
||||
case "con": return CON;
|
||||
case "non": return NON;
|
||||
case "ack": return ACK;
|
||||
case "reset": return RESET;
|
||||
default: throw new Error();
|
||||
switch (s.toLowerCase().trim()) {
|
||||
case "con":
|
||||
return CON;
|
||||
case "non":
|
||||
return NON;
|
||||
case "ack":
|
||||
return ACK;
|
||||
case "reset":
|
||||
return RESET;
|
||||
default:
|
||||
throw new Error();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user