@narrative-os/engine 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/agents/canonValidator.d.ts +9 -0
- package/dist/agents/canonValidator.js +51 -0
- package/dist/agents/chapterPlanner.d.ts +50 -0
- package/dist/agents/chapterPlanner.js +250 -0
- package/dist/agents/completeness.d.ts +7 -0
- package/dist/agents/completeness.js +51 -0
- package/dist/agents/memoryExtractor.d.ts +12 -0
- package/dist/agents/memoryExtractor.js +82 -0
- package/dist/agents/stateUpdater.d.ts +30 -0
- package/dist/agents/stateUpdater.js +150 -0
- package/dist/agents/storyDirector.d.ts +40 -0
- package/dist/agents/storyDirector.js +213 -0
- package/dist/agents/summarizer.d.ts +8 -0
- package/dist/agents/summarizer.js +56 -0
- package/dist/agents/tensionController.d.ts +68 -0
- package/dist/agents/tensionController.js +197 -0
- package/dist/agents/writer.d.ts +12 -0
- package/dist/agents/writer.js +148 -0
- package/dist/constraints/constraintGraph.d.ts +117 -0
- package/dist/constraints/constraintGraph.js +381 -0
- package/dist/constraints/validator.d.ts +58 -0
- package/dist/constraints/validator.js +236 -0
- package/dist/index.d.ts +25 -0
- package/dist/index.js +115 -0
- package/dist/llm/client.d.ts +14 -0
- package/dist/llm/client.js +108 -0
- package/dist/memory/canonStore.d.ts +20 -0
- package/dist/memory/canonStore.js +110 -0
- package/dist/memory/memoryRetriever.d.ts +28 -0
- package/dist/memory/memoryRetriever.js +126 -0
- package/dist/memory/stateUpdater.d.ts +49 -0
- package/dist/memory/stateUpdater.js +315 -0
- package/dist/memory/vectorStore.d.ts +41 -0
- package/dist/memory/vectorStore.js +166 -0
- package/dist/pipeline/generateChapter.d.ts +17 -0
- package/dist/pipeline/generateChapter.js +75 -0
- package/dist/story/bible.d.ts +4 -0
- package/dist/story/bible.js +53 -0
- package/dist/story/state.d.ts +3 -0
- package/dist/story/state.js +27 -0
- package/dist/story/structuredState.d.ts +39 -0
- package/dist/story/structuredState.js +159 -0
- package/dist/test/canon.test.d.ts +1 -0
- package/dist/test/canon.test.js +104 -0
- package/dist/test/chapter-planner.test.d.ts +1 -0
- package/dist/test/chapter-planner.test.js +171 -0
- package/dist/test/constraints.test.d.ts +1 -0
- package/dist/test/constraints.test.js +210 -0
- package/dist/test/simple.test.d.ts +1 -0
- package/dist/test/simple.test.js +51 -0
- package/dist/test/state-updater.test.d.ts +1 -0
- package/dist/test/state-updater.test.js +200 -0
- package/dist/test/story-director.test.d.ts +1 -0
- package/dist/test/story-director.test.js +142 -0
- package/dist/test/structured-state.test.d.ts +1 -0
- package/dist/test/structured-state.test.js +144 -0
- package/dist/test/tension-controller.test.d.ts +1 -0
- package/dist/test/tension-controller.test.js +116 -0
- package/dist/test/vector-memory.test.d.ts +1 -0
- package/dist/test/vector-memory.test.js +153 -0
- package/dist/test/world-simulation.test.d.ts +1 -0
- package/dist/test/world-simulation.test.js +152 -0
- package/dist/types/index.d.ts +79 -0
- package/dist/types/index.js +3 -0
- package/dist/world/characterAgent.d.ts +73 -0
- package/dist/world/characterAgent.js +232 -0
- package/dist/world/eventResolver.d.ts +52 -0
- package/dist/world/eventResolver.js +205 -0
- package/dist/world/worldState.d.ts +93 -0
- package/dist/world/worldState.js +258 -0
- package/package.json +43 -0
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import type { CharacterAgent } from './characterAgent.js';
|
|
2
|
+
import type { WorldEvent, EventResolution } from './eventResolver.js';
|
|
3
|
+
export interface Location {
|
|
4
|
+
id: string;
|
|
5
|
+
name: string;
|
|
6
|
+
description: string;
|
|
7
|
+
connectedTo: string[];
|
|
8
|
+
characters: string[];
|
|
9
|
+
items: string[];
|
|
10
|
+
events: string[];
|
|
11
|
+
}
|
|
12
|
+
export interface WorldState {
|
|
13
|
+
storyId: string;
|
|
14
|
+
currentChapter: number;
|
|
15
|
+
locations: Map<string, Location>;
|
|
16
|
+
characters: Map<string, CharacterAgent>;
|
|
17
|
+
events: WorldEvent[];
|
|
18
|
+
history: string[];
|
|
19
|
+
globalState: Record<string, any>;
|
|
20
|
+
}
|
|
21
|
+
export declare class WorldStateManager {
|
|
22
|
+
private state;
|
|
23
|
+
constructor(storyId: string);
|
|
24
|
+
/**
|
|
25
|
+
* Initialize world from story bible
|
|
26
|
+
*/
|
|
27
|
+
initialize(setting: string, initialCharacters: CharacterAgent[]): void;
|
|
28
|
+
/**
|
|
29
|
+
* Add a new location
|
|
30
|
+
*/
|
|
31
|
+
addLocation(id: string, name: string, description: string, connectedTo?: string[]): Location;
|
|
32
|
+
/**
|
|
33
|
+
* Connect two locations
|
|
34
|
+
*/
|
|
35
|
+
connectLocations(locId1: string, locId2: string): void;
|
|
36
|
+
/**
|
|
37
|
+
* Move character between locations
|
|
38
|
+
*/
|
|
39
|
+
moveCharacter(characterName: string, toLocationId: string): boolean;
|
|
40
|
+
/**
|
|
41
|
+
* Get character's current location
|
|
42
|
+
*/
|
|
43
|
+
getCharacterLocation(characterName: string): Location | undefined;
|
|
44
|
+
/**
|
|
45
|
+
* Add character to world
|
|
46
|
+
*/
|
|
47
|
+
addCharacter(character: CharacterAgent): void;
|
|
48
|
+
/**
|
|
49
|
+
* Get characters at a location
|
|
50
|
+
*/
|
|
51
|
+
getCharactersAtLocation(locationId: string): CharacterAgent[];
|
|
52
|
+
/**
|
|
53
|
+
* Add event to world
|
|
54
|
+
*/
|
|
55
|
+
addEvent(event: WorldEvent): void;
|
|
56
|
+
/**
|
|
57
|
+
* Process event resolutions and update world
|
|
58
|
+
*/
|
|
59
|
+
applyResolutions(resolutions: EventResolution[]): void;
|
|
60
|
+
/**
|
|
61
|
+
* Advance to next chapter
|
|
62
|
+
*/
|
|
63
|
+
advanceChapter(): void;
|
|
64
|
+
/**
|
|
65
|
+
* Set global state value
|
|
66
|
+
*/
|
|
67
|
+
setGlobalState(key: string, value: any): void;
|
|
68
|
+
/**
|
|
69
|
+
* Get global state value
|
|
70
|
+
*/
|
|
71
|
+
getGlobalState(key: string): any;
|
|
72
|
+
/**
|
|
73
|
+
* Add entry to world history
|
|
74
|
+
*/
|
|
75
|
+
private addToHistory;
|
|
76
|
+
/**
|
|
77
|
+
* Get world state summary
|
|
78
|
+
*/
|
|
79
|
+
getSummary(): string;
|
|
80
|
+
/**
|
|
81
|
+
* Get full world state
|
|
82
|
+
*/
|
|
83
|
+
getState(): WorldState;
|
|
84
|
+
/**
|
|
85
|
+
* Serialize world state
|
|
86
|
+
*/
|
|
87
|
+
serialize(): string;
|
|
88
|
+
/**
|
|
89
|
+
* Deserialize world state
|
|
90
|
+
*/
|
|
91
|
+
load(data: string): void;
|
|
92
|
+
}
|
|
93
|
+
export declare function createWorldStateManager(storyId: string): WorldStateManager;
|
|
@@ -0,0 +1,258 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.WorldStateManager = void 0;
|
|
4
|
+
exports.createWorldStateManager = createWorldStateManager;
|
|
5
|
+
class WorldStateManager {
|
|
6
|
+
state;
|
|
7
|
+
constructor(storyId) {
|
|
8
|
+
this.state = {
|
|
9
|
+
storyId,
|
|
10
|
+
currentChapter: 0,
|
|
11
|
+
locations: new Map(),
|
|
12
|
+
characters: new Map(),
|
|
13
|
+
events: [],
|
|
14
|
+
history: [],
|
|
15
|
+
globalState: {},
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Initialize world from story bible
|
|
20
|
+
*/
|
|
21
|
+
initialize(setting, initialCharacters) {
|
|
22
|
+
// Create initial location from setting
|
|
23
|
+
const startingLocation = {
|
|
24
|
+
id: 'loc-start',
|
|
25
|
+
name: setting,
|
|
26
|
+
description: `The main setting of the story: ${setting}`,
|
|
27
|
+
connectedTo: [],
|
|
28
|
+
characters: initialCharacters.map(c => c.name),
|
|
29
|
+
items: [],
|
|
30
|
+
events: [],
|
|
31
|
+
};
|
|
32
|
+
this.state.locations.set(startingLocation.id, startingLocation);
|
|
33
|
+
// Add characters
|
|
34
|
+
for (const character of initialCharacters) {
|
|
35
|
+
this.state.characters.set(character.name, character);
|
|
36
|
+
}
|
|
37
|
+
this.addToHistory(`World initialized at ${setting} with ${initialCharacters.length} characters`);
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Add a new location
|
|
41
|
+
*/
|
|
42
|
+
addLocation(id, name, description, connectedTo = []) {
|
|
43
|
+
const location = {
|
|
44
|
+
id,
|
|
45
|
+
name,
|
|
46
|
+
description,
|
|
47
|
+
connectedTo,
|
|
48
|
+
characters: [],
|
|
49
|
+
items: [],
|
|
50
|
+
events: [],
|
|
51
|
+
};
|
|
52
|
+
this.state.locations.set(id, location);
|
|
53
|
+
this.addToHistory(`Location added: ${name}`);
|
|
54
|
+
return location;
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Connect two locations
|
|
58
|
+
*/
|
|
59
|
+
connectLocations(locId1, locId2) {
|
|
60
|
+
const loc1 = this.state.locations.get(locId1);
|
|
61
|
+
const loc2 = this.state.locations.get(locId2);
|
|
62
|
+
if (loc1 && loc2) {
|
|
63
|
+
if (!loc1.connectedTo.includes(locId2)) {
|
|
64
|
+
loc1.connectedTo.push(locId2);
|
|
65
|
+
}
|
|
66
|
+
if (!loc2.connectedTo.includes(locId1)) {
|
|
67
|
+
loc2.connectedTo.push(locId1);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Move character between locations
|
|
73
|
+
*/
|
|
74
|
+
moveCharacter(characterName, toLocationId) {
|
|
75
|
+
const character = this.state.characters.get(characterName);
|
|
76
|
+
const fromLocation = this.getCharacterLocation(characterName);
|
|
77
|
+
const toLocation = this.state.locations.get(toLocationId);
|
|
78
|
+
if (!character || !toLocation)
|
|
79
|
+
return false;
|
|
80
|
+
// Remove from old location
|
|
81
|
+
if (fromLocation) {
|
|
82
|
+
fromLocation.characters = fromLocation.characters.filter(c => c !== characterName);
|
|
83
|
+
}
|
|
84
|
+
// Add to new location
|
|
85
|
+
if (!toLocation.characters.includes(characterName)) {
|
|
86
|
+
toLocation.characters.push(characterName);
|
|
87
|
+
}
|
|
88
|
+
// Update character location
|
|
89
|
+
character.location = toLocation.name;
|
|
90
|
+
this.addToHistory(`${characterName} moved to ${toLocation.name}`);
|
|
91
|
+
return true;
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Get character's current location
|
|
95
|
+
*/
|
|
96
|
+
getCharacterLocation(characterName) {
|
|
97
|
+
for (const location of this.state.locations.values()) {
|
|
98
|
+
if (location.characters.includes(characterName)) {
|
|
99
|
+
return location;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
return undefined;
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* Add character to world
|
|
106
|
+
*/
|
|
107
|
+
addCharacter(character) {
|
|
108
|
+
this.state.characters.set(character.name, character);
|
|
109
|
+
// Add to location
|
|
110
|
+
for (const location of this.state.locations.values()) {
|
|
111
|
+
if (location.name === character.location) {
|
|
112
|
+
if (!location.characters.includes(character.name)) {
|
|
113
|
+
location.characters.push(character.name);
|
|
114
|
+
}
|
|
115
|
+
break;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
this.addToHistory(`Character added: ${character.name}`);
|
|
119
|
+
}
|
|
120
|
+
/**
|
|
121
|
+
* Get characters at a location
|
|
122
|
+
*/
|
|
123
|
+
getCharactersAtLocation(locationId) {
|
|
124
|
+
const location = this.state.locations.get(locationId);
|
|
125
|
+
if (!location)
|
|
126
|
+
return [];
|
|
127
|
+
return location.characters
|
|
128
|
+
.map(name => this.state.characters.get(name))
|
|
129
|
+
.filter((c) => c !== undefined);
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Add event to world
|
|
133
|
+
*/
|
|
134
|
+
addEvent(event) {
|
|
135
|
+
this.state.events.push(event);
|
|
136
|
+
// Add to location
|
|
137
|
+
const location = Array.from(this.state.locations.values())
|
|
138
|
+
.find(l => l.name === event.location);
|
|
139
|
+
if (location) {
|
|
140
|
+
location.events.push(event.id);
|
|
141
|
+
}
|
|
142
|
+
this.addToHistory(`Event: ${event.description}`);
|
|
143
|
+
}
|
|
144
|
+
/**
|
|
145
|
+
* Process event resolutions and update world
|
|
146
|
+
*/
|
|
147
|
+
applyResolutions(resolutions) {
|
|
148
|
+
for (const resolution of resolutions) {
|
|
149
|
+
// Update event
|
|
150
|
+
const eventIndex = this.state.events.findIndex(e => e.id === resolution.event.id);
|
|
151
|
+
if (eventIndex >= 0) {
|
|
152
|
+
this.state.events[eventIndex] = resolution.event;
|
|
153
|
+
}
|
|
154
|
+
// Add to history
|
|
155
|
+
this.addToHistory(`Resolved: ${resolution.outcome}`);
|
|
156
|
+
// Apply consequences to characters
|
|
157
|
+
for (const characterName of resolution.affectedCharacters) {
|
|
158
|
+
const character = this.state.characters.get(characterName);
|
|
159
|
+
if (character) {
|
|
160
|
+
// Could update emotional state, knowledge, etc. based on consequences
|
|
161
|
+
// For now, just log it
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
/**
|
|
167
|
+
* Advance to next chapter
|
|
168
|
+
*/
|
|
169
|
+
advanceChapter() {
|
|
170
|
+
this.state.currentChapter++;
|
|
171
|
+
this.addToHistory(`Chapter ${this.state.currentChapter} begins`);
|
|
172
|
+
}
|
|
173
|
+
/**
|
|
174
|
+
* Set global state value
|
|
175
|
+
*/
|
|
176
|
+
setGlobalState(key, value) {
|
|
177
|
+
this.state.globalState[key] = value;
|
|
178
|
+
}
|
|
179
|
+
/**
|
|
180
|
+
* Get global state value
|
|
181
|
+
*/
|
|
182
|
+
getGlobalState(key) {
|
|
183
|
+
return this.state.globalState[key];
|
|
184
|
+
}
|
|
185
|
+
/**
|
|
186
|
+
* Add entry to world history
|
|
187
|
+
*/
|
|
188
|
+
addToHistory(entry) {
|
|
189
|
+
const timestamp = `Ch${this.state.currentChapter}`;
|
|
190
|
+
this.state.history.push(`[${timestamp}] ${entry}`);
|
|
191
|
+
}
|
|
192
|
+
/**
|
|
193
|
+
* Get world state summary
|
|
194
|
+
*/
|
|
195
|
+
getSummary() {
|
|
196
|
+
const lines = ['## World State'];
|
|
197
|
+
lines.push(`\n**Current Chapter:** ${this.state.currentChapter}`);
|
|
198
|
+
lines.push(`**Locations:** ${this.state.locations.size}`);
|
|
199
|
+
lines.push(`**Characters:** ${this.state.characters.size}`);
|
|
200
|
+
lines.push(`**Active Events:** ${this.state.events.filter(e => !e.resolved).length}`);
|
|
201
|
+
// Location summary
|
|
202
|
+
lines.push('\n### Locations');
|
|
203
|
+
for (const location of this.state.locations.values()) {
|
|
204
|
+
lines.push(`- **${location.name}**: ${location.characters.length} characters`);
|
|
205
|
+
}
|
|
206
|
+
// Character summary
|
|
207
|
+
lines.push('\n### Character Locations');
|
|
208
|
+
for (const character of this.state.characters.values()) {
|
|
209
|
+
lines.push(`- ${character.name}: ${character.location} (${character.emotionalState})`);
|
|
210
|
+
}
|
|
211
|
+
// Recent history
|
|
212
|
+
lines.push('\n### Recent History');
|
|
213
|
+
for (const entry of this.state.history.slice(-5)) {
|
|
214
|
+
lines.push(`- ${entry}`);
|
|
215
|
+
}
|
|
216
|
+
return lines.join('\n');
|
|
217
|
+
}
|
|
218
|
+
/**
|
|
219
|
+
* Get full world state
|
|
220
|
+
*/
|
|
221
|
+
getState() {
|
|
222
|
+
return this.state;
|
|
223
|
+
}
|
|
224
|
+
/**
|
|
225
|
+
* Serialize world state
|
|
226
|
+
*/
|
|
227
|
+
serialize() {
|
|
228
|
+
return JSON.stringify({
|
|
229
|
+
storyId: this.state.storyId,
|
|
230
|
+
currentChapter: this.state.currentChapter,
|
|
231
|
+
locations: Array.from(this.state.locations.entries()),
|
|
232
|
+
characters: Array.from(this.state.characters.entries()),
|
|
233
|
+
events: this.state.events,
|
|
234
|
+
history: this.state.history,
|
|
235
|
+
globalState: this.state.globalState,
|
|
236
|
+
});
|
|
237
|
+
}
|
|
238
|
+
/**
|
|
239
|
+
* Deserialize world state
|
|
240
|
+
*/
|
|
241
|
+
load(data) {
|
|
242
|
+
const parsed = JSON.parse(data);
|
|
243
|
+
this.state = {
|
|
244
|
+
storyId: parsed.storyId,
|
|
245
|
+
currentChapter: parsed.currentChapter,
|
|
246
|
+
locations: new Map(parsed.locations),
|
|
247
|
+
characters: new Map(parsed.characters),
|
|
248
|
+
events: parsed.events,
|
|
249
|
+
history: parsed.history,
|
|
250
|
+
globalState: parsed.globalState,
|
|
251
|
+
};
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
exports.WorldStateManager = WorldStateManager;
|
|
255
|
+
function createWorldStateManager(storyId) {
|
|
256
|
+
return new WorldStateManager(storyId);
|
|
257
|
+
}
|
|
258
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"worldState.js","sourceRoot":"","sources":["../../src/world/worldState.ts"],"names":[],"mappings":"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","sourcesContent":["import type { CharacterAgent } from './characterAgent.js';\r\nimport type { WorldEvent, EventResolution } from './eventResolver.js';\r\n\r\nexport interface Location {\r\n  id: string;\r\n  name: string;\r\n  description: string;\r\n  connectedTo: string[];\r\n  characters: string[];\r\n  items: string[];\r\n  events: string[];\r\n}\r\n\r\nexport interface WorldState {\r\n  storyId: string;\r\n  currentChapter: number;\r\n  locations: Map<string, Location>;\r\n  characters: Map<string, CharacterAgent>;\r\n  events: WorldEvent[];\r\n  history: string[];\r\n  globalState: Record<string, any>;\r\n}\r\n\r\nexport class WorldStateManager {\r\n  private state: WorldState;\r\n  \r\n  constructor(storyId: string) {\r\n    this.state = {\r\n      storyId,\r\n      currentChapter: 0,\r\n      locations: new Map(),\r\n      characters: new Map(),\r\n      events: [],\r\n      history: [],\r\n      globalState: {},\r\n    };\r\n  }\r\n  \r\n  /**\r\n   * Initialize world from story bible\r\n   */\r\n  initialize(setting: string, initialCharacters: CharacterAgent[]): void {\r\n    // Create initial location from setting\r\n    const startingLocation: Location = {\r\n      id: 'loc-start',\r\n      name: setting,\r\n      description: `The main setting of the story: ${setting}`,\r\n      connectedTo: [],\r\n      characters: initialCharacters.map(c => c.name),\r\n      items: [],\r\n      events: [],\r\n    };\r\n    \r\n    this.state.locations.set(startingLocation.id, startingLocation);\r\n    \r\n    // Add characters\r\n    for (const character of initialCharacters) {\r\n      this.state.characters.set(character.name, character);\r\n    }\r\n    \r\n    this.addToHistory(`World initialized at ${setting} with ${initialCharacters.length} characters`);\r\n  }\r\n  \r\n  /**\r\n   * Add a new location\r\n   */\r\n  addLocation(\r\n    id: string,\r\n    name: string,\r\n    description: string,\r\n    connectedTo: string[] = []\r\n  ): Location {\r\n    const location: Location = {\r\n      id,\r\n      name,\r\n      description,\r\n      connectedTo,\r\n      characters: [],\r\n      items: [],\r\n      events: [],\r\n    };\r\n    \r\n    this.state.locations.set(id, location);\r\n    this.addToHistory(`Location added: ${name}`);\r\n    \r\n    return location;\r\n  }\r\n  \r\n  /**\r\n   * Connect two locations\r\n   */\r\n  connectLocations(locId1: string, locId2: string): void {\r\n    const loc1 = this.state.locations.get(locId1);\r\n    const loc2 = this.state.locations.get(locId2);\r\n    \r\n    if (loc1 && loc2) {\r\n      if (!loc1.connectedTo.includes(locId2)) {\r\n        loc1.connectedTo.push(locId2);\r\n      }\r\n      if (!loc2.connectedTo.includes(locId1)) {\r\n        loc2.connectedTo.push(locId1);\r\n      }\r\n    }\r\n  }\r\n  \r\n  /**\r\n   * Move character between locations\r\n   */\r\n  moveCharacter(characterName: string, toLocationId: string): boolean {\r\n    const character = this.state.characters.get(characterName);\r\n    const fromLocation = this.getCharacterLocation(characterName);\r\n    const toLocation = this.state.locations.get(toLocationId);\r\n    \r\n    if (!character || !toLocation) return false;\r\n    \r\n    // Remove from old location\r\n    if (fromLocation) {\r\n      fromLocation.characters = fromLocation.characters.filter(c => c !== characterName);\r\n    }\r\n    \r\n    // Add to new location\r\n    if (!toLocation.characters.includes(characterName)) {\r\n      toLocation.characters.push(characterName);\r\n    }\r\n    \r\n    // Update character location\r\n    character.location = toLocation.name;\r\n    \r\n    this.addToHistory(`${characterName} moved to ${toLocation.name}`);\r\n    return true;\r\n  }\r\n  \r\n  /**\r\n   * Get character's current location\r\n   */\r\n  getCharacterLocation(characterName: string): Location | undefined {\r\n    for (const location of this.state.locations.values()) {\r\n      if (location.characters.includes(characterName)) {\r\n        return location;\r\n      }\r\n    }\r\n    return undefined;\r\n  }\r\n  \r\n  /**\r\n   * Add character to world\r\n   */\r\n  addCharacter(character: CharacterAgent): void {\r\n    this.state.characters.set(character.name, character);\r\n    \r\n    // Add to location\r\n    for (const location of this.state.locations.values()) {\r\n      if (location.name === character.location) {\r\n        if (!location.characters.includes(character.name)) {\r\n          location.characters.push(character.name);\r\n        }\r\n        break;\r\n      }\r\n    }\r\n    \r\n    this.addToHistory(`Character added: ${character.name}`);\r\n  }\r\n  \r\n  /**\r\n   * Get characters at a location\r\n   */\r\n  getCharactersAtLocation(locationId: string): CharacterAgent[] {\r\n    const location = this.state.locations.get(locationId);\r\n    if (!location) return [];\r\n    \r\n    return location.characters\r\n      .map(name => this.state.characters.get(name))\r\n      .filter((c): c is CharacterAgent => c !== undefined);\r\n  }\r\n  \r\n  /**\r\n   * Add event to world\r\n   */\r\n  addEvent(event: WorldEvent): void {\r\n    this.state.events.push(event);\r\n    \r\n    // Add to location\r\n    const location = Array.from(this.state.locations.values())\r\n      .find(l => l.name === event.location);\r\n    if (location) {\r\n      location.events.push(event.id);\r\n    }\r\n    \r\n    this.addToHistory(`Event: ${event.description}`);\r\n  }\r\n  \r\n  /**\r\n   * Process event resolutions and update world\r\n   */\r\n  applyResolutions(resolutions: EventResolution[]): void {\r\n    for (const resolution of resolutions) {\r\n      // Update event\r\n      const eventIndex = this.state.events.findIndex(e => e.id === resolution.event.id);\r\n      if (eventIndex >= 0) {\r\n        this.state.events[eventIndex] = resolution.event;\r\n      }\r\n      \r\n      // Add to history\r\n      this.addToHistory(`Resolved: ${resolution.outcome}`);\r\n      \r\n      // Apply consequences to characters\r\n      for (const characterName of resolution.affectedCharacters) {\r\n        const character = this.state.characters.get(characterName);\r\n        if (character) {\r\n          // Could update emotional state, knowledge, etc. based on consequences\r\n          // For now, just log it\r\n        }\r\n      }\r\n    }\r\n  }\r\n  \r\n  /**\r\n   * Advance to next chapter\r\n   */\r\n  advanceChapter(): void {\r\n    this.state.currentChapter++;\r\n    this.addToHistory(`Chapter ${this.state.currentChapter} begins`);\r\n  }\r\n  \r\n  /**\r\n   * Set global state value\r\n   */\r\n  setGlobalState(key: string, value: any): void {\r\n    this.state.globalState[key] = value;\r\n  }\r\n  \r\n  /**\r\n   * Get global state value\r\n   */\r\n  getGlobalState(key: string): any {\r\n    return this.state.globalState[key];\r\n  }\r\n  \r\n  /**\r\n   * Add entry to world history\r\n   */\r\n  private addToHistory(entry: string): void {\r\n    const timestamp = `Ch${this.state.currentChapter}`;\r\n    this.state.history.push(`[${timestamp}] ${entry}`);\r\n  }\r\n  \r\n  /**\r\n   * Get world state summary\r\n   */\r\n  getSummary(): string {\r\n    const lines: string[] = ['## World State'];\r\n    \r\n    lines.push(`\\n**Current Chapter:** ${this.state.currentChapter}`);\r\n    lines.push(`**Locations:** ${this.state.locations.size}`);\r\n    lines.push(`**Characters:** ${this.state.characters.size}`);\r\n    lines.push(`**Active Events:** ${this.state.events.filter(e => !e.resolved).length}`);\r\n    \r\n    // Location summary\r\n    lines.push('\\n### Locations');\r\n    for (const location of this.state.locations.values()) {\r\n      lines.push(`- **${location.name}**: ${location.characters.length} characters`);\r\n    }\r\n    \r\n    // Character summary\r\n    lines.push('\\n### Character Locations');\r\n    for (const character of this.state.characters.values()) {\r\n      lines.push(`- ${character.name}: ${character.location} (${character.emotionalState})`);\r\n    }\r\n    \r\n    // Recent history\r\n    lines.push('\\n### Recent History');\r\n    for (const entry of this.state.history.slice(-5)) {\r\n      lines.push(`- ${entry}`);\r\n    }\r\n    \r\n    return lines.join('\\n');\r\n  }\r\n  \r\n  /**\r\n   * Get full world state\r\n   */\r\n  getState(): WorldState {\r\n    return this.state;\r\n  }\r\n  \r\n  /**\r\n   * Serialize world state\r\n   */\r\n  serialize(): string {\r\n    return JSON.stringify({\r\n      storyId: this.state.storyId,\r\n      currentChapter: this.state.currentChapter,\r\n      locations: Array.from(this.state.locations.entries()),\r\n      characters: Array.from(this.state.characters.entries()),\r\n      events: this.state.events,\r\n      history: this.state.history,\r\n      globalState: this.state.globalState,\r\n    });\r\n  }\r\n  \r\n  /**\r\n   * Deserialize world state\r\n   */\r\n  load(data: string): void {\r\n    const parsed = JSON.parse(data);\r\n    this.state = {\r\n      storyId: parsed.storyId,\r\n      currentChapter: parsed.currentChapter,\r\n      locations: new Map(parsed.locations),\r\n      characters: new Map(parsed.characters),\r\n      events: parsed.events,\r\n      history: parsed.history,\r\n      globalState: parsed.globalState,\r\n    };\r\n  }\r\n}\r\n\r\nexport function createWorldStateManager(storyId: string): WorldStateManager {\r\n  return new WorldStateManager(storyId);\r\n}\r\n"]}
|
package/package.json
ADDED
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@narrative-os/engine",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"description": "Core narrative engine for AI-powered story generation",
|
|
5
|
+
"main": "dist/index.js",
|
|
6
|
+
"types": "dist/index.d.ts",
|
|
7
|
+
"files": [
|
|
8
|
+
"dist"
|
|
9
|
+
],
|
|
10
|
+
"scripts": {
|
|
11
|
+
"build": "tsc",
|
|
12
|
+
"dev": "tsc --watch",
|
|
13
|
+
"lint": "eslint src/**/*.ts",
|
|
14
|
+
"prepublishOnly": "npm run build"
|
|
15
|
+
},
|
|
16
|
+
"keywords": [
|
|
17
|
+
"ai",
|
|
18
|
+
"story",
|
|
19
|
+
"narrative",
|
|
20
|
+
"writing",
|
|
21
|
+
"llm",
|
|
22
|
+
"memory",
|
|
23
|
+
"hnsw"
|
|
24
|
+
],
|
|
25
|
+
"author": "Your Name",
|
|
26
|
+
"license": "MIT",
|
|
27
|
+
"repository": {
|
|
28
|
+
"type": "git",
|
|
29
|
+
"url": "https://github.com/liwonder/NARRITIVE_OS.git"
|
|
30
|
+
},
|
|
31
|
+
"engines": {
|
|
32
|
+
"node": ">=20.0.0"
|
|
33
|
+
},
|
|
34
|
+
"dependencies": {
|
|
35
|
+
"hnswlib-node": "^3.0.0",
|
|
36
|
+
"openai": "^4.52.0",
|
|
37
|
+
"zod": "^3.23.0"
|
|
38
|
+
},
|
|
39
|
+
"devDependencies": {
|
|
40
|
+
"@types/node": "^20.0.0",
|
|
41
|
+
"typescript": "^5.4.0"
|
|
42
|
+
}
|
|
43
|
+
}
|