@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.
Files changed (71) hide show
  1. package/dist/agents/canonValidator.d.ts +9 -0
  2. package/dist/agents/canonValidator.js +51 -0
  3. package/dist/agents/chapterPlanner.d.ts +50 -0
  4. package/dist/agents/chapterPlanner.js +250 -0
  5. package/dist/agents/completeness.d.ts +7 -0
  6. package/dist/agents/completeness.js +51 -0
  7. package/dist/agents/memoryExtractor.d.ts +12 -0
  8. package/dist/agents/memoryExtractor.js +82 -0
  9. package/dist/agents/stateUpdater.d.ts +30 -0
  10. package/dist/agents/stateUpdater.js +150 -0
  11. package/dist/agents/storyDirector.d.ts +40 -0
  12. package/dist/agents/storyDirector.js +213 -0
  13. package/dist/agents/summarizer.d.ts +8 -0
  14. package/dist/agents/summarizer.js +56 -0
  15. package/dist/agents/tensionController.d.ts +68 -0
  16. package/dist/agents/tensionController.js +197 -0
  17. package/dist/agents/writer.d.ts +12 -0
  18. package/dist/agents/writer.js +148 -0
  19. package/dist/constraints/constraintGraph.d.ts +117 -0
  20. package/dist/constraints/constraintGraph.js +381 -0
  21. package/dist/constraints/validator.d.ts +58 -0
  22. package/dist/constraints/validator.js +236 -0
  23. package/dist/index.d.ts +25 -0
  24. package/dist/index.js +115 -0
  25. package/dist/llm/client.d.ts +14 -0
  26. package/dist/llm/client.js +108 -0
  27. package/dist/memory/canonStore.d.ts +20 -0
  28. package/dist/memory/canonStore.js +110 -0
  29. package/dist/memory/memoryRetriever.d.ts +28 -0
  30. package/dist/memory/memoryRetriever.js +126 -0
  31. package/dist/memory/stateUpdater.d.ts +49 -0
  32. package/dist/memory/stateUpdater.js +315 -0
  33. package/dist/memory/vectorStore.d.ts +41 -0
  34. package/dist/memory/vectorStore.js +166 -0
  35. package/dist/pipeline/generateChapter.d.ts +17 -0
  36. package/dist/pipeline/generateChapter.js +75 -0
  37. package/dist/story/bible.d.ts +4 -0
  38. package/dist/story/bible.js +53 -0
  39. package/dist/story/state.d.ts +3 -0
  40. package/dist/story/state.js +27 -0
  41. package/dist/story/structuredState.d.ts +39 -0
  42. package/dist/story/structuredState.js +159 -0
  43. package/dist/test/canon.test.d.ts +1 -0
  44. package/dist/test/canon.test.js +104 -0
  45. package/dist/test/chapter-planner.test.d.ts +1 -0
  46. package/dist/test/chapter-planner.test.js +171 -0
  47. package/dist/test/constraints.test.d.ts +1 -0
  48. package/dist/test/constraints.test.js +210 -0
  49. package/dist/test/simple.test.d.ts +1 -0
  50. package/dist/test/simple.test.js +51 -0
  51. package/dist/test/state-updater.test.d.ts +1 -0
  52. package/dist/test/state-updater.test.js +200 -0
  53. package/dist/test/story-director.test.d.ts +1 -0
  54. package/dist/test/story-director.test.js +142 -0
  55. package/dist/test/structured-state.test.d.ts +1 -0
  56. package/dist/test/structured-state.test.js +144 -0
  57. package/dist/test/tension-controller.test.d.ts +1 -0
  58. package/dist/test/tension-controller.test.js +116 -0
  59. package/dist/test/vector-memory.test.d.ts +1 -0
  60. package/dist/test/vector-memory.test.js +153 -0
  61. package/dist/test/world-simulation.test.d.ts +1 -0
  62. package/dist/test/world-simulation.test.js +152 -0
  63. package/dist/types/index.d.ts +79 -0
  64. package/dist/types/index.js +3 -0
  65. package/dist/world/characterAgent.d.ts +73 -0
  66. package/dist/world/characterAgent.js +232 -0
  67. package/dist/world/eventResolver.d.ts +52 -0
  68. package/dist/world/eventResolver.js +205 -0
  69. package/dist/world/worldState.d.ts +93 -0
  70. package/dist/world/worldState.js +258 -0
  71. 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
+ }