Reserve container persistence schema
This commit is contained in:
@@ -762,7 +762,11 @@ Target deliverable: A small group can join a server, spawn into one biome, gathe
|
|||||||
`UAgrarianSaveGame::Weather`, provider `WeatherInputs`, and `WeatherDebug`,
|
`UAgrarianSaveGame::Weather`, provider `WeatherInputs`, and `WeatherDebug`,
|
||||||
then restore mapped provider inputs when present or the saved enum weather
|
then restore mapped provider inputs when present or the saved enum weather
|
||||||
otherwise.
|
otherwise.
|
||||||
- [ ] Save containers.
|
- [x] Save containers. The save schema now reserves
|
||||||
|
`FAgrarianSavedContainer` records with stable container ID, type, transform,
|
||||||
|
item stacks, and owner player ID; 0.1.M has no placed container actor yet, so
|
||||||
|
the current craftable `simple_container` remains covered by player inventory
|
||||||
|
persistence until placed containers arrive.
|
||||||
- [ ] Add server-side save interval.
|
- [ ] Add server-side save interval.
|
||||||
- [x] Add manual admin save command.
|
- [x] Add manual admin save command.
|
||||||
- [ ] Add load-on-server-start.
|
- [ ] Add load-on-server-start.
|
||||||
|
|||||||
@@ -429,6 +429,14 @@ from `UAgrarianInventoryComponent::Items`, and restored through
|
|||||||
values and broadcasts inventory changes so HUD/debug listeners see loaded item
|
values and broadcasts inventory changes so HUD/debug listeners see loaded item
|
||||||
state.
|
state.
|
||||||
|
|
||||||
|
Container persistence reserves `FAgrarianSavedContainer` records with stable
|
||||||
|
container ID, container type ID, transform, item stacks, and owner player ID.
|
||||||
|
Version 0.1.M does not yet have a placed container actor to capture; the current
|
||||||
|
`simple_container` remains a craftable inventory item and is covered by player
|
||||||
|
inventory persistence. The saved container array is intentionally present now
|
||||||
|
so the first placed-container actor can use the same save format without a
|
||||||
|
schema break.
|
||||||
|
|
||||||
World time is stored in `UAgrarianSaveGame::WorldHours`. The persistence
|
World time is stored in `UAgrarianSaveGame::WorldHours`. The persistence
|
||||||
subsystem captures it from `AAgrarianGameState::WorldHours` during world save
|
subsystem captures it from `AAgrarianGameState::WorldHours` during world save
|
||||||
and restores it only on authority during world load.
|
and restores it only on authority during world load.
|
||||||
|
|||||||
@@ -0,0 +1,44 @@
|
|||||||
|
from pathlib import Path
|
||||||
|
|
||||||
|
|
||||||
|
ROOT = Path(__file__).resolve().parents[1]
|
||||||
|
|
||||||
|
EXPECTED = {
|
||||||
|
ROOT / "Source" / "AgrarianGame" / "AgrarianSaveGame.h": [
|
||||||
|
"struct FAgrarianSavedContainer",
|
||||||
|
"FName ContainerId = NAME_None;",
|
||||||
|
"FName ContainerTypeId = NAME_None;",
|
||||||
|
"FTransform Transform;",
|
||||||
|
"TArray<FAgrarianItemStack> Inventory;",
|
||||||
|
"FString OwnerPlayerId;",
|
||||||
|
"TArray<FAgrarianSavedContainer> Containers;",
|
||||||
|
],
|
||||||
|
ROOT / "Docs" / "PersistenceDesignDocument.md": [
|
||||||
|
"`FAgrarianSavedContainer`",
|
||||||
|
"Version 0.1.M does not yet have a placed container actor to capture",
|
||||||
|
"`simple_container` remains a craftable inventory item",
|
||||||
|
],
|
||||||
|
ROOT / "AGRARIAN_DEVELOPMENT_ROADMAP.md": [
|
||||||
|
"[x] Save containers.",
|
||||||
|
"`FAgrarianSavedContainer`",
|
||||||
|
"`simple_container` remains covered by player inventory",
|
||||||
|
],
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
def main() -> None:
|
||||||
|
missing = []
|
||||||
|
for path, snippets in EXPECTED.items():
|
||||||
|
text = path.read_text(encoding="utf-8")
|
||||||
|
for snippet in snippets:
|
||||||
|
if snippet not in text:
|
||||||
|
missing.append(f"{path.relative_to(ROOT)}: {snippet}")
|
||||||
|
|
||||||
|
if missing:
|
||||||
|
raise RuntimeError("Container persistence schema verification failed: " + "; ".join(missing))
|
||||||
|
|
||||||
|
print("PASS: container persistence schema is reserved without claiming placed-container capture.")
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
||||||
@@ -85,6 +85,27 @@ struct FAgrarianSavedResourceNode
|
|||||||
bool bRespawnsForMvp = false;
|
bool bRespawnsForMvp = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
USTRUCT(BlueprintType)
|
||||||
|
struct FAgrarianSavedContainer
|
||||||
|
{
|
||||||
|
GENERATED_BODY()
|
||||||
|
|
||||||
|
UPROPERTY(EditAnywhere, BlueprintReadWrite, Category = "Agrarian|Save")
|
||||||
|
FName ContainerId = NAME_None;
|
||||||
|
|
||||||
|
UPROPERTY(EditAnywhere, BlueprintReadWrite, Category = "Agrarian|Save")
|
||||||
|
FName ContainerTypeId = NAME_None;
|
||||||
|
|
||||||
|
UPROPERTY(EditAnywhere, BlueprintReadWrite, Category = "Agrarian|Save")
|
||||||
|
FTransform Transform;
|
||||||
|
|
||||||
|
UPROPERTY(EditAnywhere, BlueprintReadWrite, Category = "Agrarian|Save")
|
||||||
|
TArray<FAgrarianItemStack> Inventory;
|
||||||
|
|
||||||
|
UPROPERTY(EditAnywhere, BlueprintReadWrite, Category = "Agrarian|Save")
|
||||||
|
FString OwnerPlayerId;
|
||||||
|
};
|
||||||
|
|
||||||
UCLASS()
|
UCLASS()
|
||||||
class UAgrarianSaveGame : public USaveGame
|
class UAgrarianSaveGame : public USaveGame
|
||||||
{
|
{
|
||||||
@@ -114,4 +135,7 @@ public:
|
|||||||
|
|
||||||
UPROPERTY(EditAnywhere, BlueprintReadWrite, Category = "Agrarian|Save")
|
UPROPERTY(EditAnywhere, BlueprintReadWrite, Category = "Agrarian|Save")
|
||||||
TArray<FAgrarianSavedResourceNode> ResourceNodes;
|
TArray<FAgrarianSavedResourceNode> ResourceNodes;
|
||||||
|
|
||||||
|
UPROPERTY(EditAnywhere, BlueprintReadWrite, Category = "Agrarian|Save")
|
||||||
|
TArray<FAgrarianSavedContainer> Containers;
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user