Skip to content

Commit

Permalink
Code refactors
Browse files Browse the repository at this point in the history
  • Loading branch information
miyucomics committed Oct 27, 2024
1 parent 73aa2f9 commit cf055ae
Show file tree
Hide file tree
Showing 5 changed files with 25 additions and 19 deletions.
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,10 @@
- fixed Offer Mind spell allowing for overflow
- fixed error in documentation: Racer's Purification can work on nonplayers
- fixed error in documentation: Telepathy Reflection does not return null ever
- fixed error in documentation: genie lamps can not cast Offer Mind
- fixed oversight: plain glass and plain glass panes can now be dyed
- made code much better
- gambits now have an interface so they are easy to add
- used lambdas rather than larger switch statements
- specklikes are now modularized
- merged Arch Lamp Storage spells into the Arch Lamps page
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,11 @@ import at.petrak.hexcasting.api.spell.getList
import at.petrak.hexcasting.api.spell.iota.Iota
import at.petrak.hexcasting.api.spell.mishaps.MishapNotEnoughArgs
import at.petrak.hexcasting.common.lib.hex.HexEvalSounds
import miyucomics.hexical.enums.FakeGambit
import miyucomics.hexical.enums.InjectedGambit
import miyucomics.hexical.interfaces.FrameForEachMinterface

object OpSisyphus : Action {
object OpSisyphus : Action, FakeGambit {
override fun operate(continuation: SpellContinuation, stack: MutableList<Iota>, ravenmind: Iota?, ctx: CastingContext): OperationResult {
if (stack.size == 0)
throw MishapNotEnoughArgs(1, 0)
Expand All @@ -30,17 +31,15 @@ object OpSisyphus : Action {
return OperationResult(continuation.pushFrame(frame), stack, ravenmind, listOf())
}

@JvmStatic
fun breakDownwards(baseStack: List<Iota>): Pair<Boolean, List<Iota>> = true to baseStack
override fun breakDownwards(baseStack: List<Iota>, accumulator: MutableList<Iota>): Pair<Boolean, List<Iota>> = true to baseStack

@JvmStatic
fun evaluate(continuation: SpellContinuation, harness: CastingHarness, code: SpellList, baseStack: List<Iota>): CastingHarness.CastResult {
override fun evaluate(continuation: SpellContinuation, harness: CastingHarness, data: SpellList, code: SpellList, baseStack: List<Iota>?, accumulator: MutableList<Iota>): CastingHarness.CastResult {
harness.ctx.incDepth()
val frame = FrameForEach(SpellList.LList(0, listOf()), code, baseStack, mutableListOf())
(frame as FrameForEachMinterface).overwrite(InjectedGambit.SISYPHUS)
return CastingHarness.CastResult(
continuation.pushFrame(frame).pushFrame(FrameEvaluate(code, true)),
FunctionalData(baseStack, 0, listOf(), false, harness.ravenmind),
FunctionalData(baseStack!!, 0, listOf(), false, harness.ravenmind),
ResolvedPatternType.EVALUATED,
listOf(),
HexEvalSounds.THOTH,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,10 +15,11 @@ import at.petrak.hexcasting.api.spell.iota.PatternIota
import at.petrak.hexcasting.api.spell.mishaps.MishapNotEnoughArgs
import at.petrak.hexcasting.common.lib.hex.HexEvalSounds
import miyucomics.hexical.casting.mishaps.ThemisMishap
import miyucomics.hexical.enums.FakeGambit
import miyucomics.hexical.enums.InjectedGambit
import miyucomics.hexical.interfaces.FrameForEachMinterface

object OpThemis : Action {
object OpThemis : Action, FakeGambit {
override fun operate(continuation: SpellContinuation, stack: MutableList<Iota>, ravenmind: Iota?, ctx: CastingContext): OperationResult {
if (stack.size < 2)
throw MishapNotEnoughArgs(1, 0)
Expand All @@ -37,8 +38,7 @@ object OpThemis : Action {
return OperationResult(continuation.pushFrame(frame), stack, ravenmind, listOf())
}

@JvmStatic
fun breakDownwards(baseStack: List<Iota>, accumulator: MutableList<Iota>): Pair<Boolean, List<Iota>> {
override fun breakDownwards(baseStack: List<Iota>, accumulator: MutableList<Iota>): Pair<Boolean, List<Iota>> {
val final = mutableListOf<Iota>()
val itemPriorityPairs = accumulator.chunked(2)
val sortedPairs = itemPriorityPairs.sortedBy { (it[1] as DoubleIota).double }
Expand All @@ -49,8 +49,7 @@ object OpThemis : Action {
return true to newStack
}

@JvmStatic
fun evaluate(continuation: SpellContinuation, harness: CastingHarness, data: SpellList, code: SpellList, baseStack: List<Iota>?, accumulator: MutableList<Iota>): CastingHarness.CastResult {
override fun evaluate(continuation: SpellContinuation, harness: CastingHarness, data: SpellList, code: SpellList, baseStack: List<Iota>?, accumulator: MutableList<Iota>): CastingHarness.CastResult {
val stack: List<Iota> = if (baseStack == null) {
harness.stack.toList()
} else {
Expand Down
10 changes: 10 additions & 0 deletions src/main/java/miyucomics/hexical/enums/InjectedGambit.kt
Original file line number Diff line number Diff line change
@@ -1,7 +1,17 @@
package miyucomics.hexical.enums

import at.petrak.hexcasting.api.spell.SpellList
import at.petrak.hexcasting.api.spell.casting.CastingHarness
import at.petrak.hexcasting.api.spell.casting.eval.SpellContinuation
import at.petrak.hexcasting.api.spell.iota.Iota

enum class InjectedGambit {
THEMIS,
SISYPHUS,
NONE
}

interface FakeGambit {
fun breakDownwards(baseStack: List<Iota>, accumulator: MutableList<Iota>): Pair<Boolean, List<Iota>>
fun evaluate(continuation: SpellContinuation, harness: CastingHarness, data: SpellList, code: SpellList, baseStack: List<Iota>?, accumulator: MutableList<Iota>): CastingHarness.CastResult
}
11 changes: 3 additions & 8 deletions src/main/java/miyucomics/hexical/mixin/FrameForEachMixin.java
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
import kotlin.Pair;
import miyucomics.hexical.casting.patterns.eval.OpSisyphus;
import miyucomics.hexical.casting.patterns.eval.OpThemis;
import miyucomics.hexical.enums.FakeGambit;
import miyucomics.hexical.enums.InjectedGambit;
import miyucomics.hexical.interfaces.FrameForEachMinterface;
import net.minecraft.server.world.ServerWorld;
Expand Down Expand Up @@ -42,20 +43,14 @@ public abstract class FrameForEachMixin implements FrameForEachMinterface {
void hijackBreaking(List<? extends Iota> stack, CallbackInfoReturnable<Pair<Boolean, List<Iota>>> cir) {
if (hexical$injectedGambit == InjectedGambit.NONE)
return;
if (hexical$injectedGambit == InjectedGambit.SISYPHUS)
cir.setReturnValue(OpSisyphus.breakDownwards(getBaseStack()));
if (hexical$injectedGambit == InjectedGambit.THEMIS)
cir.setReturnValue(OpThemis.breakDownwards(getBaseStack(), getAcc()));
cir.setReturnValue(((FakeGambit) this).breakDownwards(getBaseStack(), getAcc()));
}

@Inject(method = "evaluate", at = @At("HEAD"), cancellable = true)
void hijackEvaluate(SpellContinuation continuation, ServerWorld level, CastingHarness harness, CallbackInfoReturnable<CastingHarness.CastResult> cir) {
if (hexical$injectedGambit == InjectedGambit.NONE)
return;
if (hexical$injectedGambit == InjectedGambit.SISYPHUS)
cir.setReturnValue(OpSisyphus.evaluate(continuation, harness, getCode(), getBaseStack()));
if (hexical$injectedGambit == InjectedGambit.THEMIS)
cir.setReturnValue(OpThemis.evaluate(continuation, harness, getData(), getCode(), getBaseStack(), getAcc()));
cir.setReturnValue(((FakeGambit) this).evaluate(continuation, harness, getData(), getCode(), getBaseStack(), getAcc()));
}

@Override
Expand Down

0 comments on commit cf055ae

Please sign in to comment.