From 3ba95668b0724b7abf6709ec328a623ff0f49f15 Mon Sep 17 00:00:00 2001 From: JoelCourtney Date: Mon, 11 Nov 2024 14:28:06 -0800 Subject: [PATCH] Flatten committed changes into one object --- .../nasa/jpl/aerie/scheduler/plan/Commit.kt | 17 ------------- .../scheduler/plan/InMemoryEditablePlan.kt | 25 ++++++++++++++----- 2 files changed, 19 insertions(+), 23 deletions(-) delete mode 100644 scheduler-driver/src/main/kotlin/gov/nasa/jpl/aerie/scheduler/plan/Commit.kt diff --git a/scheduler-driver/src/main/kotlin/gov/nasa/jpl/aerie/scheduler/plan/Commit.kt b/scheduler-driver/src/main/kotlin/gov/nasa/jpl/aerie/scheduler/plan/Commit.kt deleted file mode 100644 index 9a8a1314d8..0000000000 --- a/scheduler-driver/src/main/kotlin/gov/nasa/jpl/aerie/scheduler/plan/Commit.kt +++ /dev/null @@ -1,17 +0,0 @@ -package gov.nasa.jpl.aerie.scheduler.plan - -import gov.nasa.ammos.aerie.procedural.scheduling.plan.Edit -import java.lang.ref.WeakReference - -data class Commit( - val diff: List, - - /** - * A record of the simulation results objects that were up-to-date when the commit - * was created. - * - * This has SHARED OWNERSHIP with [InMemoryEditablePlan]; the editable plan may add more to - * this list AFTER the commit is created. - */ - val upToDateSimResultsSet: MutableSet> -) diff --git a/scheduler-driver/src/main/kotlin/gov/nasa/jpl/aerie/scheduler/plan/InMemoryEditablePlan.kt b/scheduler-driver/src/main/kotlin/gov/nasa/jpl/aerie/scheduler/plan/InMemoryEditablePlan.kt index 1a8a3ffeee..049d7eb808 100644 --- a/scheduler-driver/src/main/kotlin/gov/nasa/jpl/aerie/scheduler/plan/InMemoryEditablePlan.kt +++ b/scheduler-driver/src/main/kotlin/gov/nasa/jpl/aerie/scheduler/plan/InMemoryEditablePlan.kt @@ -54,12 +54,25 @@ data class InMemoryEditablePlan( private val lookupActivityType: (String) -> ActivityType ) : EditablePlan, Plan by plan { - private val commits = mutableListOf() + private data class Commit( + val diff: List, + + /** + * A record of the simulation results objects that were up-to-date when the commit + * was created. + * + * This has SHARED OWNERSHIP with [InMemoryEditablePlan]; the editable plan may add more to + * this list AFTER the commit is created. + */ + val upToDateSimResultsSet: MutableSet> + ) + + private var committedChanges = Commit(listOf(), mutableSetOf()) var uncommittedChanges = mutableListOf() private set val totalDiff: List - get() = commits.flatMap { it.diff } + get() = committedChanges.diff // Jointly owned set of up-to-date simulation results. See class-level comment for algorithm explanation. private var upToDateSimResultsSet: MutableSet> = mutableSetOf() @@ -108,11 +121,11 @@ data class InMemoryEditablePlan( // Probably unnecessary, but shared ownership freaks me out enough already. if (uncommittedChanges.isEmpty()) return - val committedEdits = uncommittedChanges + val newCommittedChanges = uncommittedChanges uncommittedChanges = mutableListOf() // Create a commit that shares ownership of the simResults set. - commits.add(Commit(committedEdits, upToDateSimResultsSet)) + committedChanges = Commit(committedChanges.diff + newCommittedChanges, upToDateSimResultsSet) } override fun rollback(): List { @@ -131,10 +144,10 @@ data class InMemoryEditablePlan( for (simResult in upToDateSimResultsSet) { simResult.get()?.stale = true } - for (simResult in commits.last().upToDateSimResultsSet) { + for (simResult in committedChanges.upToDateSimResultsSet) { simResult.get()?.stale = false } - upToDateSimResultsSet = commits.last().upToDateSimResultsSet + upToDateSimResultsSet = committedChanges.upToDateSimResultsSet return result }