@haibun/core 3.0.5 → 3.1.1
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/build/currentVersion.d.ts +1 -1
- package/build/currentVersion.js +2 -1
- package/build/lib/EventLogger.d.ts +30 -0
- package/build/lib/EventLogger.d.ts.map +1 -0
- package/build/lib/EventLogger.js +110 -0
- package/build/lib/EventLogger.js.map +1 -0
- package/build/lib/astepper.d.ts +9 -0
- package/build/lib/astepper.d.ts.map +1 -1
- package/build/lib/astepper.js +8 -0
- package/build/lib/astepper.js.map +1 -1
- package/build/lib/core/flow-runner.d.ts +25 -0
- package/build/lib/core/flow-runner.d.ts.map +1 -0
- package/build/lib/core/flow-runner.js +128 -0
- package/build/lib/core/flow-runner.js.map +1 -0
- package/build/lib/core/protocol.d.ts +58 -0
- package/build/lib/core/protocol.d.ts.map +1 -0
- package/build/lib/core/protocol.js +18 -0
- package/build/lib/core/protocol.js.map +1 -0
- package/build/lib/core-domains.d.ts +2 -16
- package/build/lib/core-domains.d.ts.map +1 -1
- package/build/lib/core-domains.js +46 -27
- package/build/lib/core-domains.js.map +1 -1
- package/build/lib/defs.d.ts +31 -6
- package/build/lib/defs.d.ts.map +1 -1
- package/build/lib/defs.js +1 -1
- package/build/lib/defs.js.map +1 -1
- package/build/lib/domain-types.d.ts +12 -1
- package/build/lib/domain-types.d.ts.map +1 -1
- package/build/lib/domain-types.js +63 -3
- package/build/lib/domain-types.js.map +1 -1
- package/build/lib/event-bridge.d.ts +42 -0
- package/build/lib/event-bridge.d.ts.map +1 -0
- package/build/lib/event-bridge.js +214 -0
- package/build/lib/event-bridge.js.map +1 -0
- package/build/lib/feature-variables.d.ts +13 -0
- package/build/lib/feature-variables.d.ts.map +1 -1
- package/build/lib/feature-variables.js +125 -6
- package/build/lib/feature-variables.js.map +1 -1
- package/build/lib/namedVars.d.ts.map +1 -1
- package/build/lib/namedVars.js +18 -10
- package/build/lib/namedVars.js.map +1 -1
- package/build/lib/populateActionArgs.d.ts +1 -1
- package/build/lib/populateActionArgs.d.ts.map +1 -1
- package/build/lib/populateActionArgs.js +11 -49
- package/build/lib/populateActionArgs.js.map +1 -1
- package/build/lib/test/TestSteps.d.ts +1 -0
- package/build/lib/test/TestSteps.d.ts.map +1 -1
- package/build/lib/test/TestStepsWithOptions.d.ts +1 -0
- package/build/lib/test/TestStepsWithOptions.d.ts.map +1 -1
- package/build/lib/test/lib.d.ts.map +1 -1
- package/build/lib/test/lib.js +2 -0
- package/build/lib/test/lib.js.map +1 -1
- package/build/lib/util/actualURI.js +1 -1
- package/build/lib/util/actualURI.js.map +1 -1
- package/build/lib/util/index.d.ts +11 -2
- package/build/lib/util/index.d.ts.map +1 -1
- package/build/lib/util/index.js +46 -2
- package/build/lib/util/index.js.map +1 -1
- package/build/lib/util/variables.d.ts +9 -0
- package/build/lib/util/variables.d.ts.map +1 -0
- package/build/lib/util/variables.js +40 -0
- package/build/lib/util/variables.js.map +1 -0
- package/build/lib/util/workspace-lib.d.ts.map +1 -1
- package/build/lib/util/workspace-lib.js +30 -3
- package/build/lib/util/workspace-lib.js.map +1 -1
- package/build/monitor/browser-stubs.d.ts +12 -0
- package/build/monitor/browser-stubs.d.ts.map +1 -0
- package/build/monitor/browser-stubs.js +20 -0
- package/build/monitor/browser-stubs.js.map +1 -0
- package/build/monitor/constants.d.ts +9 -0
- package/build/monitor/constants.d.ts.map +1 -0
- package/build/monitor/constants.js +9 -0
- package/build/monitor/constants.js.map +1 -0
- package/build/monitor/event-view.d.ts +40 -0
- package/build/monitor/event-view.d.ts.map +1 -0
- package/build/monitor/event-view.js +104 -0
- package/build/monitor/event-view.js.map +1 -0
- package/build/monitor/filters.d.ts +17 -0
- package/build/monitor/filters.d.ts.map +1 -0
- package/build/monitor/filters.js +32 -0
- package/build/monitor/filters.js.map +1 -0
- package/build/monitor/formatters.d.ts +27 -0
- package/build/monitor/formatters.d.ts.map +1 -0
- package/build/monitor/formatters.js +89 -0
- package/build/monitor/formatters.js.map +1 -0
- package/build/monitor/index.d.ts +11 -0
- package/build/monitor/index.d.ts.map +1 -0
- package/build/monitor/index.js +15 -0
- package/build/monitor/index.js.map +1 -0
- package/build/monitor/jit-serialization.d.ts +9 -0
- package/build/monitor/jit-serialization.d.ts.map +1 -0
- package/build/monitor/jit-serialization.js +73 -0
- package/build/monitor/jit-serialization.js.map +1 -0
- package/build/monitor/monitor-types.d.ts +119 -0
- package/build/monitor/monitor-types.d.ts.map +1 -0
- package/build/monitor/monitor-types.js +43 -0
- package/build/monitor/monitor-types.js.map +1 -0
- package/build/monitor/speculative-tracker.d.ts +20 -0
- package/build/monitor/speculative-tracker.d.ts.map +1 -0
- package/build/monitor/speculative-tracker.js +38 -0
- package/build/monitor/speculative-tracker.js.map +1 -0
- package/build/monitor/state.d.ts +31 -0
- package/build/monitor/state.d.ts.map +1 -0
- package/build/monitor/state.js +110 -0
- package/build/monitor/state.js.map +1 -0
- package/build/monitor/timer.d.ts +11 -0
- package/build/monitor/timer.d.ts.map +1 -0
- package/build/monitor/timer.js +13 -0
- package/build/monitor/timer.js.map +1 -0
- package/build/monitor/tree-builder.d.ts +25 -0
- package/build/monitor/tree-builder.d.ts.map +1 -0
- package/build/monitor/tree-builder.js +36 -0
- package/build/monitor/tree-builder.js.map +1 -0
- package/build/phases/Executor.d.ts.map +1 -1
- package/build/phases/Executor.js +93 -22
- package/build/phases/Executor.js.map +1 -1
- package/build/phases/Resolver.d.ts +2 -1
- package/build/phases/Resolver.d.ts.map +1 -1
- package/build/phases/Resolver.js +64 -1
- package/build/phases/Resolver.js.map +1 -1
- package/build/runner.d.ts.map +1 -1
- package/build/runner.js +5 -0
- package/build/runner.js.map +1 -1
- package/build/schema/events.d.ts +426 -0
- package/build/schema/events.d.ts.map +1 -0
- package/build/schema/events.js +123 -0
- package/build/schema/events.js.map +1 -0
- package/build/steps/activities-stepper.d.ts +49 -8
- package/build/steps/activities-stepper.d.ts.map +1 -1
- package/build/steps/activities-stepper.js +277 -141
- package/build/steps/activities-stepper.js.map +1 -1
- package/build/steps/conformance.d.ts +1 -0
- package/build/steps/conformance.d.ts.map +1 -1
- package/build/steps/console-monitor-stepper.d.ts +44 -0
- package/build/steps/console-monitor-stepper.d.ts.map +1 -0
- package/build/steps/console-monitor-stepper.js +107 -0
- package/build/steps/console-monitor-stepper.js.map +1 -0
- package/build/steps/debugger-stepper.d.ts +5 -3
- package/build/steps/debugger-stepper.d.ts.map +1 -1
- package/build/steps/debugger-stepper.js +32 -8
- package/build/steps/debugger-stepper.js.map +1 -1
- package/build/steps/haibun.d.ts +6 -18
- package/build/steps/haibun.d.ts.map +1 -1
- package/build/steps/haibun.js +33 -54
- package/build/steps/haibun.js.map +1 -1
- package/build/steps/logic-stepper.d.ts +42 -0
- package/build/steps/logic-stepper.d.ts.map +1 -0
- package/build/steps/logic-stepper.js +143 -0
- package/build/steps/logic-stepper.js.map +1 -0
- package/build/steps/narrator.js +1 -1
- package/build/steps/narrator.js.map +1 -1
- package/build/steps/parse.d.ts +1 -0
- package/build/steps/parse.d.ts.map +1 -1
- package/build/steps/variables-stepper.d.ts +11 -75
- package/build/steps/variables-stepper.d.ts.map +1 -1
- package/build/steps/variables-stepper.js +527 -85
- package/build/steps/variables-stepper.js.map +1 -1
- package/package.json +16 -3
- package/build/applyEffectFeatures.d.ts +0 -4
- package/build/applyEffectFeatures.d.ts.map +0 -1
- package/build/applyEffectFeatures.js +0 -31
- package/build/applyEffectFeatures.js.map +0 -1
- package/build/jsprolog/converter.d.ts +0 -9
- package/build/jsprolog/converter.d.ts.map +0 -1
- package/build/jsprolog/converter.js +0 -42
- package/build/jsprolog/converter.js.map +0 -1
- package/build/jsprolog/stepper-utils.d.ts +0 -8
- package/build/jsprolog/stepper-utils.d.ts.map +0 -1
- package/build/jsprolog/stepper-utils.js +0 -8
- package/build/jsprolog/stepper-utils.js.map +0 -1
- package/build/jsprolog/test.jsprolog.d.ts +0 -4
- package/build/jsprolog/test.jsprolog.d.ts.map +0 -1
- package/build/jsprolog/test.jsprolog.js +0 -19
- package/build/jsprolog/test.jsprolog.js.map +0 -1
- package/build/jsprolog/test.kireji.d.ts +0 -4
- package/build/jsprolog/test.kireji.d.ts.map +0 -1
- package/build/jsprolog/test.kireji.js +0 -19
- package/build/jsprolog/test.kireji.js.map +0 -1
- package/build/jsprolog/withAction.d.ts +0 -32
- package/build/jsprolog/withAction.d.ts.map +0 -1
- package/build/jsprolog/withAction.js +0 -65
- package/build/jsprolog/withAction.js.map +0 -1
- package/build/kireji/test.kireji.d.ts +0 -4
- package/build/kireji/test.kireji.d.ts.map +0 -1
- package/build/kireji/test.kireji.js +0 -19
- package/build/kireji/test.kireji.js.map +0 -1
- package/build/lib/errors.d.ts +0 -13
- package/build/lib/errors.d.ts.map +0 -1
- package/build/lib/errors.js +0 -18
- package/build/lib/errors.js.map +0 -1
- package/build/lib/util/featureStep-executor.d.ts +0 -7
- package/build/lib/util/featureStep-executor.d.ts.map +0 -1
- package/build/lib/util/featureStep-executor.js +0 -63
- package/build/lib/util/featureStep-executor.js.map +0 -1
- package/build/steps/conditions-stepper.d.ts +0 -27
- package/build/steps/conditions-stepper.d.ts.map +0 -1
- package/build/steps/conditions-stepper.js +0 -99
- package/build/steps/conditions-stepper.js.map +0 -1
- package/build/steps/outcomesRegistry.d.ts +0 -8
- package/build/steps/outcomesRegistry.d.ts.map +0 -1
- package/build/steps/outcomesRegistry.js +0 -3
- package/build/steps/outcomesRegistry.js.map +0 -1
- package/build/steps/registeredOutcomesStore.d.ts +0 -12
- package/build/steps/registeredOutcomesStore.d.ts.map +0 -1
- package/build/steps/registeredOutcomesStore.js +0 -11
- package/build/steps/registeredOutcomesStore.js.map +0 -1
|
@@ -8,6 +8,7 @@ declare const Conformance: {
|
|
|
8
8
|
};
|
|
9
9
|
};
|
|
10
10
|
world?: import("../lib/defs.js").TWorld;
|
|
11
|
+
kind?: import("../lib/astepper.js").TStepperKind;
|
|
11
12
|
setWorld(world: import("../lib/defs.js").TWorld, _steppers: AStepper[]): Promise<void>;
|
|
12
13
|
getWorld(): import("../lib/defs.js").TWorld;
|
|
13
14
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"conformance.d.ts","sourceRoot":"","sources":["../../src/steps/conformance.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAE9C,QAAA,MAAM,WAAW
|
|
1
|
+
{"version":3,"file":"conformance.d.ts","sourceRoot":"","sources":["../../src/steps/conformance.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAE9C,QAAA,MAAM,WAAW;;;;;;;;;;;;;CAOhB,CAAC;AAEF,eAAe,WAAW,CAAC"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { AStepper, IHasCycles } from '../lib/astepper.js';
|
|
2
|
+
import { THaibunEvent } from '../lib/EventLogger.js';
|
|
3
|
+
/**
|
|
4
|
+
* ConsoleMonitorStepper - Console monitor using the onEvent pattern.
|
|
5
|
+
*/
|
|
6
|
+
export default class ConsoleMonitorStepper extends AStepper implements IHasCycles {
|
|
7
|
+
kind: "MONITOR";
|
|
8
|
+
steps: {};
|
|
9
|
+
options: {
|
|
10
|
+
CONSOLE_MONITOR_VERBOSE: {
|
|
11
|
+
desc: string;
|
|
12
|
+
parse: (s: string) => {
|
|
13
|
+
result: boolean;
|
|
14
|
+
};
|
|
15
|
+
};
|
|
16
|
+
CONSOLE_MONITOR_LOGS: {
|
|
17
|
+
desc: string;
|
|
18
|
+
parse: (s: string) => {
|
|
19
|
+
result: boolean;
|
|
20
|
+
};
|
|
21
|
+
};
|
|
22
|
+
CONSOLE_MONITOR_LIFECYCLE: {
|
|
23
|
+
desc: string;
|
|
24
|
+
parse: (s: string) => {
|
|
25
|
+
result: boolean;
|
|
26
|
+
};
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
private verbose;
|
|
30
|
+
private showLogEvents;
|
|
31
|
+
private showLifecycleEvents;
|
|
32
|
+
private lastLevel;
|
|
33
|
+
cycles: {
|
|
34
|
+
startExecution: () => void;
|
|
35
|
+
onEvent: (event: THaibunEvent) => void;
|
|
36
|
+
};
|
|
37
|
+
private handleEvent;
|
|
38
|
+
private handleLifecycleEvent;
|
|
39
|
+
private handleLogEvent;
|
|
40
|
+
private handleArtifactEvent;
|
|
41
|
+
private handleControlEvent;
|
|
42
|
+
private logLine;
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=console-monitor-stepper.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"console-monitor-stepper.d.ts","sourceRoot":"","sources":["../../src/steps/console-monitor-stepper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAgB,MAAM,oBAAoB,CAAC;AACxE,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAIrD;;GAEG;AACH,MAAM,CAAC,OAAO,OAAO,qBAAsB,SAAQ,QAAS,YAAW,UAAU;IAC/E,IAAI,YAAwB;IAC5B,KAAK,KAAM;IAEX,OAAO;;;uBAGQ,MAAM;;;;;;uBAIN,MAAM;;;;;;uBAIN,MAAM;;;;MAEnB;IAEF,OAAO,CAAC,OAAO,CAAkB;IACjC,OAAO,CAAC,aAAa,CAAiB;IACtC,OAAO,CAAC,mBAAmB,CAAiB;IAC5C,OAAO,CAAC,SAAS,CAAc;IAE/B,MAAM;;yBAQa,YAAY,KAAG,IAAI;MAGpC;IAEF,OAAO,CAAC,WAAW;IAYnB,OAAO,CAAC,oBAAoB;IA2B5B,OAAO,CAAC,cAAc;IAWtB,OAAO,CAAC,mBAAmB;IAK3B,OAAO,CAAC,kBAAkB;IAI1B,OAAO,CAAC,OAAO;CAShB"}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
import { AStepper, StepperKinds } from '../lib/astepper.js';
|
|
2
|
+
import { Timer } from '../lib/Timer.js';
|
|
3
|
+
import { CHECK_YES, CHECK_NO } from '../lib/defs.js';
|
|
4
|
+
/**
|
|
5
|
+
* ConsoleMonitorStepper - Console monitor using the onEvent pattern.
|
|
6
|
+
*/
|
|
7
|
+
export default class ConsoleMonitorStepper extends AStepper {
|
|
8
|
+
kind = StepperKinds.MONITOR;
|
|
9
|
+
steps = {};
|
|
10
|
+
options = {
|
|
11
|
+
CONSOLE_MONITOR_VERBOSE: {
|
|
12
|
+
desc: 'Show all events including step starts',
|
|
13
|
+
parse: (s) => ({ result: s === 'true' }),
|
|
14
|
+
},
|
|
15
|
+
CONSOLE_MONITOR_LOGS: {
|
|
16
|
+
desc: 'Show log events (default: true)',
|
|
17
|
+
parse: (s) => ({ result: s !== 'false' }),
|
|
18
|
+
},
|
|
19
|
+
CONSOLE_MONITOR_LIFECYCLE: {
|
|
20
|
+
desc: 'Show lifecycle events (default: true)',
|
|
21
|
+
parse: (s) => ({ result: s !== 'false' }),
|
|
22
|
+
},
|
|
23
|
+
};
|
|
24
|
+
verbose = false;
|
|
25
|
+
showLogEvents = true;
|
|
26
|
+
showLifecycleEvents = true;
|
|
27
|
+
lastLevel = '';
|
|
28
|
+
cycles = {
|
|
29
|
+
startExecution: () => {
|
|
30
|
+
const options = this.getWorld()?.moduleOptions || {};
|
|
31
|
+
this.verbose = options['HAIBUN_O_CONSOLEMONITORSTEPPER_CONSOLE_MONITOR_VERBOSE'] === 'true';
|
|
32
|
+
this.showLogEvents = options['HAIBUN_O_CONSOLEMONITORSTEPPER_CONSOLE_MONITOR_LOGS'] !== 'false';
|
|
33
|
+
this.showLifecycleEvents = options['HAIBUN_O_CONSOLEMONITORSTEPPER_CONSOLE_MONITOR_LIFECYCLE'] !== 'false';
|
|
34
|
+
},
|
|
35
|
+
onEvent: (event) => {
|
|
36
|
+
this.handleEvent(event);
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
handleEvent(event) {
|
|
40
|
+
if (event.kind === 'lifecycle' && this.showLifecycleEvents) {
|
|
41
|
+
this.handleLifecycleEvent(event);
|
|
42
|
+
}
|
|
43
|
+
else if (event.kind === 'log' && this.showLogEvents) {
|
|
44
|
+
this.handleLogEvent(event);
|
|
45
|
+
}
|
|
46
|
+
else if (event.kind === 'artifact') {
|
|
47
|
+
this.handleArtifactEvent(event);
|
|
48
|
+
}
|
|
49
|
+
else if (event.kind === 'control' && this.verbose) {
|
|
50
|
+
this.handleControlEvent(event);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
handleLifecycleEvent(event) {
|
|
54
|
+
const isSpeculative = event.intent?.mode === 'speculative';
|
|
55
|
+
let status;
|
|
56
|
+
if (event.status === 'completed') {
|
|
57
|
+
status = isSpeculative ? ' ✓' : CHECK_YES;
|
|
58
|
+
}
|
|
59
|
+
else if (event.status === 'failed') {
|
|
60
|
+
status = isSpeculative ? ' ✗' : CHECK_NO;
|
|
61
|
+
}
|
|
62
|
+
else if (event.status === 'running') {
|
|
63
|
+
status = '⏳';
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
status = ' •';
|
|
67
|
+
}
|
|
68
|
+
if (event.type === 'step') {
|
|
69
|
+
if (event.stage === 'end' || this.verbose) {
|
|
70
|
+
const error = event.error ? ` (${event.error})` : '';
|
|
71
|
+
this.logLine('log', event, `${status} ${event.id} ${event.label}${error}`);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
else if (event.type === 'feature' && event.stage === 'start') {
|
|
75
|
+
console.log('');
|
|
76
|
+
this.logLine('feature', event, `📄 ${event.label}`);
|
|
77
|
+
}
|
|
78
|
+
else if (event.type === 'scenario' && event.stage === 'start') {
|
|
79
|
+
this.logLine('scenario', event, `📋 ${event.label}`);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
handleLogEvent(event) {
|
|
83
|
+
const levelIcon = {
|
|
84
|
+
trace: '🔬', debug: '🐛', info: 'ℹ️', warn: '⚠️', error: '🚨'
|
|
85
|
+
};
|
|
86
|
+
const icon = levelIcon[event.level] || '•';
|
|
87
|
+
if (this.verbose || ['info', 'warn', 'error'].includes(event.level)) {
|
|
88
|
+
this.logLine(event.level, event, `${icon}${event.id} ${event.message}`);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
handleArtifactEvent(event) {
|
|
92
|
+
const path = 'path' in event ? ` (${event.path})` : '';
|
|
93
|
+
this.logLine('artifact', event, `📎 ${event.id} ${event.artifactType}${path}`);
|
|
94
|
+
}
|
|
95
|
+
handleControlEvent(event) {
|
|
96
|
+
this.logLine('control', event, `⚙️ ${event.id} ${event.signal}`);
|
|
97
|
+
}
|
|
98
|
+
logLine(level, event, message) {
|
|
99
|
+
const time = (Timer.since() / 1000).toFixed(3);
|
|
100
|
+
const emitter = event.emitter || 'unknown';
|
|
101
|
+
const showLevel = this.lastLevel === level ? level.charAt(0) : level;
|
|
102
|
+
this.lastLevel = level;
|
|
103
|
+
const prefix = showLevel.padStart(8) + ` █ ${time}:${emitter}`.padEnd(32) + ` | `;
|
|
104
|
+
console.log(prefix + message);
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
//# sourceMappingURL=console-monitor-stepper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"console-monitor-stepper.js","sourceRoot":"","sources":["../../src/steps/console-monitor-stepper.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { AStepper, IHasCycles, IHasOptions } from '../lib/astepper.js';
|
|
2
|
-
import { IStepperCycles, TActionResult, TWorld, TFeatureStep } from '../lib/defs.js';
|
|
2
|
+
import { IStepperCycles, TActionResult, TWorld, TFeatureStep, TNotOKActionResult } from '../lib/defs.js';
|
|
3
|
+
import { FlowRunner } from '../lib/core/flow-runner.js';
|
|
3
4
|
export declare enum TDebuggingType {
|
|
4
5
|
StepByStep = "stepByStep",
|
|
5
6
|
Continue = "continue"
|
|
@@ -9,6 +10,7 @@ export declare class DebuggerStepper extends AStepper implements IHasCycles, IHa
|
|
|
9
10
|
cycles: IStepperCycles;
|
|
10
11
|
steppers: AStepper[];
|
|
11
12
|
debugSteppers: string[];
|
|
13
|
+
runner: FlowRunner;
|
|
12
14
|
options: {
|
|
13
15
|
DEBUG_STEPPERS: {
|
|
14
16
|
desc: string;
|
|
@@ -78,11 +80,11 @@ export declare class DebuggerStepper extends AStepper implements IHasCycles, IHa
|
|
|
78
80
|
};
|
|
79
81
|
debugStepper: {
|
|
80
82
|
gwta: string;
|
|
81
|
-
action: ({ stepperName }: import("../lib/defs.js").TStepArgs) => Promise<
|
|
83
|
+
action: ({ stepperName }: import("../lib/defs.js").TStepArgs) => Promise<TNotOKActionResult | import("../lib/defs.js").TOKActionResult>;
|
|
82
84
|
};
|
|
83
85
|
continueStepper: {
|
|
84
86
|
gwta: string;
|
|
85
|
-
action: ({ stepperName }: import("../lib/defs.js").TStepArgs) => Promise<
|
|
87
|
+
action: ({ stepperName }: import("../lib/defs.js").TStepArgs) => Promise<TNotOKActionResult | import("../lib/defs.js").TOKActionResult>;
|
|
86
88
|
};
|
|
87
89
|
};
|
|
88
90
|
retry(): Promise<TActionResult>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"debugger-stepper.d.ts","sourceRoot":"","sources":["../../src/steps/debugger-stepper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,WAAW,EAAiB,MAAM,oBAAoB,CAAC;AACtF,OAAO,EAAE,cAAc,EAAE,aAAa,EAAM,MAAM,EAAoE,YAAY,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"debugger-stepper.d.ts","sourceRoot":"","sources":["../../src/steps/debugger-stepper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,WAAW,EAAiB,MAAM,oBAAoB,CAAC;AACtF,OAAO,EAAE,cAAc,EAAE,aAAa,EAAM,MAAM,EAAoE,YAAY,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAI/K,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAExD,oBAAY,cAAc;IACzB,UAAU,eAAe;IACzB,QAAQ,aAAa;CACrB;AAuCD,qBAAa,eAAgB,SAAQ,QAAS,YAAW,UAAU,EAAE,WAAW;IAC/E,aAAa,EAAE,cAAc,CAA2B;IACxD,MAAM,EAAE,cAAc,CAAgB;IACtC,QAAQ,EAAE,QAAQ,EAAE,CAAC;IACrB,aAAa,EAAE,MAAM,EAAE,CAAM;IAC7B,MAAM,EAAE,UAAU,CAAC;IAEnB,OAAO;;;;;;;;;;;MAKL;IAEI,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAgB5D,IAAI,IAAI,OAAO,CAAC,aAAa,CAAC;IAK9B,IAAI,IAAI,OAAO,CAAC,aAAa,CAAC;IAK9B,QAAQ,IAAI,OAAO,CAAC,aAAa,CAAC;IAOlC,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE,WAAW,EAAE,YAAY,EAAE,GAAG,EAAE,MAAM;IA+BzF,KAAK;;;;0BAIe,OAAO,CAAC,aAAa,CAAC;;;;0BAMtB,OAAO,CAAC,aAAa,CAAC;;;;;0BAOtB,OAAO,CAAC,aAAa,CAAC;;;;0BAMtB,OAAO,CAAC,aAAa,CAAC;;;;;0BAOtB,OAAO,CAAC,aAAa,CAAC;;;;0BAMtB,OAAO,CAAC,aAAa,CAAC;;;;;0BAQtB,OAAO,CAAC,aAAa,CAAC;;;;0BAMtB,OAAO,CAAC,aAAa,CAAC;;;;;0BAOtB,OAAO,CAAC,aAAa,CAAC;;;;0BAMtB,OAAO,CAAC,aAAa,CAAC;;;;0BAM5B,OAAO,CAAC,aAAa,CAAC;;;;;;;;;;MAoCV;IAEpB,KAAK,IAAI,OAAO,CAAC,aAAa,CAAC;IAK/B,IAAI,IAAI,OAAO,CAAC,aAAa,CAAC;;CASpC;AAED,eAAe,eAAe,CAAC"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { AStepper } from '../lib/astepper.js';
|
|
2
|
-
import { OK
|
|
2
|
+
import { OK } from '../lib/defs.js';
|
|
3
3
|
import { EExecutionMessageType } from '../lib/interfaces/logger.js';
|
|
4
4
|
import { makePrompt } from '../lib/prompter.js';
|
|
5
5
|
import { actionNotOK, actionOK, formatCurrentSeqPath, getStepperOption, stringOrError } from '../lib/util/index.js';
|
|
6
|
-
import {
|
|
6
|
+
import { FlowRunner } from '../lib/core/flow-runner.js';
|
|
7
7
|
export var TDebuggingType;
|
|
8
8
|
(function (TDebuggingType) {
|
|
9
9
|
TDebuggingType["StepByStep"] = "stepByStep";
|
|
@@ -11,6 +11,14 @@ export var TDebuggingType;
|
|
|
11
11
|
})(TDebuggingType || (TDebuggingType = {}));
|
|
12
12
|
const cycles = (debuggerStepper) => ({
|
|
13
13
|
async beforeStep({ featureStep }) {
|
|
14
|
+
// Skip debugging for debug commands themselves to avoid infinite recursion
|
|
15
|
+
if (featureStep.intent?.usage === 'debugging') {
|
|
16
|
+
return { featureStep };
|
|
17
|
+
}
|
|
18
|
+
// Skip debugging for speculative and polling steps (expected to possibly fail)
|
|
19
|
+
if (featureStep.intent?.mode === 'speculative' || featureStep.intent?.usage === 'polling') {
|
|
20
|
+
return { featureStep };
|
|
21
|
+
}
|
|
14
22
|
const { action } = featureStep;
|
|
15
23
|
if (debuggerStepper.debuggingType === TDebuggingType.StepByStep || debuggerStepper.debugSteppers.includes(action.stepperName)) {
|
|
16
24
|
const prompt = (debuggerStepper.debugSteppers.includes(action.stepperName)) ? `Debugging ${action.stepperName}` : 'Debug';
|
|
@@ -18,7 +26,18 @@ const cycles = (debuggerStepper) => ({
|
|
|
18
26
|
}
|
|
19
27
|
},
|
|
20
28
|
async afterStep({ featureStep, actionResult }) {
|
|
29
|
+
// Skip debugging for debug commands themselves to avoid infinite recursion
|
|
30
|
+
if (featureStep.intent?.usage === 'debugging') {
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
debuggerStepper.getWorld().logger.debug(`afterStep ${featureStep.in} ok=${actionResult.ok} intent=${JSON.stringify(featureStep.intent)}`);
|
|
34
|
+
if (!actionResult.ok && (featureStep.intent?.mode === 'speculative' || featureStep.intent?.usage === 'polling')) {
|
|
35
|
+
debuggerStepper.getWorld().logger.debug(`Skipping debugger for speculative/polling failure: ${featureStep.in} intent=${JSON.stringify(featureStep.intent)}`);
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
21
38
|
if (!actionResult.ok) {
|
|
39
|
+
debuggerStepper.getWorld().logger.error(`Step failed: ${actionResult.message}`);
|
|
40
|
+
debuggerStepper.getWorld().logger.debug(`Debugger triggering for failure: ${featureStep.in} intent=${JSON.stringify(featureStep.intent)}`);
|
|
22
41
|
return await debuggerStepper.debugLoop(`[Failure]`, ['*', 'retry', 'next', 'fail'], featureStep, 1);
|
|
23
42
|
}
|
|
24
43
|
}
|
|
@@ -28,6 +47,7 @@ export class DebuggerStepper extends AStepper {
|
|
|
28
47
|
cycles = cycles(this);
|
|
29
48
|
steppers;
|
|
30
49
|
debugSteppers = [];
|
|
50
|
+
runner;
|
|
31
51
|
options = {
|
|
32
52
|
DEBUG_STEPPERS: {
|
|
33
53
|
desc: 'Comma-separated list of steppers to debug',
|
|
@@ -37,6 +57,7 @@ export class DebuggerStepper extends AStepper {
|
|
|
37
57
|
async setWorld(world, steppers) {
|
|
38
58
|
this.steppers = steppers;
|
|
39
59
|
this.world = world;
|
|
60
|
+
this.runner = new FlowRunner(world, steppers);
|
|
40
61
|
const debugSteppersStart = getStepperOption(this, 'DEBUG_STEPPERS', world.moduleOptions);
|
|
41
62
|
if (debugSteppersStart) {
|
|
42
63
|
for (const stepper of debugSteppersStart.split(',').map(name => name.trim())) {
|
|
@@ -51,7 +72,7 @@ export class DebuggerStepper extends AStepper {
|
|
|
51
72
|
}
|
|
52
73
|
async fail() {
|
|
53
74
|
this.getWorld().logger.info('fail');
|
|
54
|
-
const messageContext = { incident: EExecutionMessageType.DEBUG, incidentDetails: {
|
|
75
|
+
const messageContext = { incident: EExecutionMessageType.DEBUG, incidentDetails: { failed: true } };
|
|
55
76
|
return Promise.resolve(actionOK({ messageContext }));
|
|
56
77
|
}
|
|
57
78
|
async step() {
|
|
@@ -68,16 +89,19 @@ export class DebuggerStepper extends AStepper {
|
|
|
68
89
|
async debugLoop(prompt, prompts, featureStep, inc) {
|
|
69
90
|
const prefix = featureStep.seqPath;
|
|
70
91
|
let seqStart = [...prefix, inc > 0 ? 1 : -1];
|
|
71
|
-
let promptResult;
|
|
92
|
+
let promptResult; // FlowSignal
|
|
72
93
|
let continueLoop = true;
|
|
73
94
|
while (continueLoop) {
|
|
74
95
|
const response = await this.getWorld().prompter.prompt(makePrompt(`${formatCurrentSeqPath(featureStep.seqPath)}-${prompt}`, undefined, prompts));
|
|
75
96
|
// If response is undefined (no prompter available), default to 'continue'
|
|
76
97
|
const responseStr = response === undefined ? 'continue' : response.toString();
|
|
77
98
|
try {
|
|
78
|
-
promptResult = await
|
|
79
|
-
|
|
80
|
-
|
|
99
|
+
promptResult = await this.runner.runStatement(responseStr, {
|
|
100
|
+
intent: { mode: 'authoritative', usage: 'debugging' },
|
|
101
|
+
seqPath: seqStart
|
|
102
|
+
});
|
|
103
|
+
const details = promptResult.payload?.messageContext?.incidentDetails;
|
|
104
|
+
if (details?.step || details?.continue || details?.failed || details?.rerunStep || details?.nextStep) {
|
|
81
105
|
continueLoop = false;
|
|
82
106
|
}
|
|
83
107
|
else {
|
|
@@ -89,7 +113,7 @@ export class DebuggerStepper extends AStepper {
|
|
|
89
113
|
this.getWorld().logger.error(`Failed to execute debug prompt command '${responseStr}': ${e.message}`);
|
|
90
114
|
}
|
|
91
115
|
}
|
|
92
|
-
return promptResult
|
|
116
|
+
return promptResult?.payload?.messageContext?.incidentDetails;
|
|
93
117
|
}
|
|
94
118
|
steps = {
|
|
95
119
|
f: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"debugger-stepper.js","sourceRoot":"","sources":["../../src/steps/debugger-stepper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAA0C,MAAM,oBAAoB,CAAC;AACtF,OAAO,EAAiC,EAAE,
|
|
1
|
+
{"version":3,"file":"debugger-stepper.js","sourceRoot":"","sources":["../../src/steps/debugger-stepper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAA0C,MAAM,oBAAoB,CAAC;AACtF,OAAO,EAAiC,EAAE,EAA8G,MAAM,gBAAgB,CAAC;AAC/K,OAAO,EAAmB,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AACrF,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACpH,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAExD,MAAM,CAAN,IAAY,cAGX;AAHD,WAAY,cAAc;IACzB,2CAAyB,CAAA;IACzB,uCAAqB,CAAA;AACtB,CAAC,EAHW,cAAc,KAAd,cAAc,QAGzB;AAED,MAAM,MAAM,GAAG,CAAC,eAAgC,EAAkB,EAAE,CAAC,CAAC;IACrE,KAAK,CAAC,UAAU,CAAC,EAAE,WAAW,EAAe;QAC5C,2EAA2E;QAC3E,IAAI,WAAW,CAAC,MAAM,EAAE,KAAK,KAAK,WAAW,EAAE,CAAC;YAC/C,OAAO,EAAE,WAAW,EAAE,CAAC;QACxB,CAAC;QAED,+EAA+E;QAC/E,IAAI,WAAW,CAAC,MAAM,EAAE,IAAI,KAAK,aAAa,IAAI,WAAW,CAAC,MAAM,EAAE,KAAK,KAAK,SAAS,EAAE,CAAC;YAC3F,OAAO,EAAE,WAAW,EAAE,CAAC;QACxB,CAAC;QAED,MAAM,EAAE,MAAM,EAAE,GAAG,WAAW,CAAC;QAC/B,IAAI,eAAe,CAAC,aAAa,KAAK,cAAc,CAAC,UAAU,IAAI,eAAe,CAAC,aAAa,CAAC,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC;YAC/H,MAAM,MAAM,GAAG,CAAC,eAAe,CAAC,aAAa,CAAC,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,aAAa,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;YAC1H,OAAO,eAAe,CAAC,SAAS,CAAC,GAAG,MAAM,EAAE,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3F,CAAC;IACF,CAAC;IACD,KAAK,CAAC,SAAS,CAAC,EAAE,WAAW,EAAE,YAAY,EAAc;QACxD,2EAA2E;QAC3E,IAAI,WAAW,CAAC,MAAM,EAAE,KAAK,KAAK,WAAW,EAAE,CAAC;YAC/C,OAAO;QACR,CAAC;QAED,eAAe,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,aAAa,WAAW,CAAC,EAAE,OAAO,YAAY,CAAC,EAAE,WAAW,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAE1I,IAAI,CAAC,YAAY,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,KAAK,aAAa,IAAI,WAAW,CAAC,MAAM,EAAE,KAAK,KAAK,SAAS,CAAC,EAAE,CAAC;YACjH,eAAe,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,sDAAsD,WAAW,CAAC,EAAE,WAAW,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;YAC7J,OAAO;QACR,CAAC;QACD,IAAI,CAAC,YAAY,CAAC,EAAE,EAAE,CAAC;YACtB,eAAe,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,gBAAiB,YAAmC,CAAC,OAAO,EAAE,CAAC,CAAC;YACxG,eAAe,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,oCAAoC,WAAW,CAAC,EAAE,WAAW,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;YAC3I,OAAO,MAAM,eAAe,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC,GAAG,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC,CAAC;QACrG,CAAC;IACF,CAAC;CACD,CAAC,CAAC;AACH,MAAM,OAAO,eAAgB,SAAQ,QAAQ;IAC5C,aAAa,GAAmB,cAAc,CAAC,QAAQ,CAAC;IACxD,MAAM,GAAmB,MAAM,CAAC,IAAI,CAAC,CAAC;IACtC,QAAQ,CAAa;IACrB,aAAa,GAAa,EAAE,CAAC;IAC7B,MAAM,CAAa;IAEnB,OAAO,GAAG;QACT,cAAc,EAAE;YACf,IAAI,EAAE,2CAA2C;YACjD,KAAK,EAAE,aAAa;SACpB;KACD,CAAC;IAEF,KAAK,CAAC,QAAQ,CAAC,KAAa,EAAE,QAAoB;QACjD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,MAAM,GAAG,IAAI,UAAU,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QAC9C,MAAM,kBAAkB,GAAG,gBAAgB,CAAC,IAAI,EAAE,gBAAgB,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC;QACzF,IAAI,kBAAkB,EAAE,CAAC;YACxB,KAAK,MAAM,OAAO,IAAI,kBAAkB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC;gBAC9E,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,IAAI,KAAK,OAAO,CAAC,EAAE,CAAC;oBAC9D,MAAM,IAAI,KAAK,CAAC,iBAAiB,OAAO,YAAY,CAAC,CAAC;gBACvD,CAAC;gBACD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAClC,CAAC;YACD,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,uBAAuB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACrF,CAAC;QACD,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;IAC1B,CAAC;IACD,KAAK,CAAC,IAAI;QACT,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACpC,MAAM,cAAc,GAAoB,EAAE,QAAQ,EAAE,qBAAqB,CAAC,KAAK,EAAE,eAAe,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,CAAC;QACrH,OAAO,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,cAAc,EAAE,CAAC,CAAC,CAAC;IACtD,CAAC;IACD,KAAK,CAAC,IAAI;QACT,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACpC,MAAM,cAAc,GAAoB,EAAE,QAAQ,EAAE,qBAAqB,CAAC,KAAK,EAAE,eAAe,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,CAAC;QACnH,OAAO,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,cAAc,EAAE,CAAC,CAAC,CAAC;IACtD,CAAC;IACD,KAAK,CAAC,QAAQ;QACb,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,wCAAwC,CAAC,CAAC;QACtE,IAAI,CAAC,aAAa,GAAG,cAAc,CAAC,QAAQ,CAAC;QAC7C,MAAM,cAAc,GAAoB,EAAE,QAAQ,EAAE,qBAAqB,CAAC,KAAK,EAAE,eAAe,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,EAAE,CAAC;QACvH,OAAO,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,cAAc,EAAE,CAAC,CAAC,CAAC;IACtD,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,MAAc,EAAE,OAAiB,EAAE,WAAyB,EAAE,GAAW;QACxF,MAAM,MAAM,GAAG,WAAW,CAAC,OAAO,CAAC;QACnC,IAAI,QAAQ,GAAG,CAAC,GAAG,MAAM,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7C,IAAI,YAAiB,CAAC,CAAC,aAAa;QACpC,IAAI,YAAY,GAAG,IAAI,CAAC;QAExB,OAAO,YAAY,EAAE,CAAC;YACrB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAU,CAAC,GAAG,oBAAoB,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,MAAM,EAAE,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC,CAAC;YAEjJ,0EAA0E;YAC1E,MAAM,WAAW,GAAG,QAAQ,KAAK,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;YAE9E,IAAI,CAAC;gBACJ,YAAY,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,WAAW,EAAE;oBAC1D,MAAM,EAAE,EAAE,IAAI,EAAE,eAAe,EAAE,KAAK,EAAE,WAAW,EAAE;oBACrD,OAAO,EAAE,QAAQ;iBACjB,CAAC,CAAC;gBAEH,MAAM,OAAO,GAAG,YAAY,CAAC,OAAO,EAAE,cAAc,EAAE,eAAe,CAAC;gBACtE,IAAI,OAAO,EAAE,IAAI,IAAI,OAAO,EAAE,QAAQ,IAAI,OAAO,EAAE,MAAM,IAAI,OAAO,EAAE,SAAS,IAAI,OAAO,EAAE,QAAQ,EAAE,CAAC;oBACtG,YAAY,GAAG,KAAK,CAAC;gBACtB,CAAC;qBAAM,CAAC;oBACP,MAAM,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBACpE,QAAQ,GAAG,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;gBACjD,CAAC;YACF,CAAC;YAAC,OAAO,CAAC,EAAE,CAAC;gBACZ,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,2CAA2C,WAAW,MAAM,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;YACvG,CAAC;QACF,CAAC;QACD,OAAO,YAAY,EAAE,OAAO,EAAE,cAAc,EAAE,eAAe,CAAC;IAC/D,CAAC;IACD,KAAK,GAAG;QACP,CAAC,EAAE;YACF,MAAM,EAAE,KAAK;YACb,KAAK,EAAE,GAAG;YACV,MAAM,EAAE,KAAK,IAA4B,EAAE;gBAC1C,OAAO,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC;YAC1B,CAAC;SACD;QACD,IAAI,EAAE;YACL,KAAK,EAAE,MAAM;YACb,MAAM,EAAE,KAAK,IAA4B,EAAE;gBAC1C,OAAO,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC;YAC1B,CAAC;SACD;QACD,CAAC,EAAE;YACF,MAAM,EAAE,KAAK;YACb,KAAK,EAAE,GAAG;YACV,MAAM,EAAE,KAAK,IAA4B,EAAE;gBAC1C,OAAO,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC;YAC1B,CAAC;SACD;QACD,IAAI,EAAE;YACL,KAAK,EAAE,MAAM;YACb,MAAM,EAAE,KAAK,IAA4B,EAAE;gBAC1C,OAAO,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC;YAC1B,CAAC;SACD;QACD,CAAC,EAAE;YACF,MAAM,EAAE,KAAK;YACb,KAAK,EAAE,GAAG;YACV,MAAM,EAAE,KAAK,IAA4B,EAAE;gBAC1C,OAAO,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;YAC3B,CAAC;SACD;QACD,KAAK,EAAE;YACN,KAAK,EAAE,OAAO;YACd,MAAM,EAAE,KAAK,IAA4B,EAAE;gBAC1C,OAAO,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;YAC3B,CAAC;SACD;QAED,CAAC,EAAE;YACF,MAAM,EAAE,KAAK;YACb,KAAK,EAAE,GAAG;YACV,MAAM,EAAE,KAAK,IAA4B,EAAE;gBAC1C,OAAO,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC;YAC1B,CAAC;SACD;QACD,IAAI,EAAE;YACL,KAAK,EAAE,MAAM;YACb,MAAM,EAAE,KAAK,IAA4B,EAAE;gBAC1C,OAAO,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC;YAC1B,CAAC;SACD;QACD,CAAC,EAAE;YACF,MAAM,EAAE,KAAK;YACb,KAAK,EAAE,GAAG;YACV,MAAM,EAAE,KAAK,IAA4B,EAAE;gBAC1C,OAAO,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC;YAC9B,CAAC;SACD;QACD,QAAQ,EAAE;YACT,KAAK,EAAE,UAAU;YACjB,MAAM,EAAE,KAAK,IAA4B,EAAE;gBAC1C,OAAO,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC;YAC9B,CAAC;SACD;QACD,eAAe,EAAE;YAChB,KAAK,EAAE,oBAAoB;YAC3B,MAAM,EAAE,GAA2B,EAAE;gBACpC,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;gBACpD,IAAI,CAAC,aAAa,GAAG,cAAc,CAAC,UAAU,CAAC;gBAC/C,OAAO,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YAC5B,CAAC;SACD;QACD,YAAY,EAAE;YACb,IAAI,EAAE,+BAA+B;YACrC,MAAM,EAAE,KAAK,EAAE,EAAE,WAAW,EAAE,EAAE,EAAE;gBACjC,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC;oBAAE,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;gBAC9E,MAAM,YAAY,GAAI,WAAsB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;gBACjF,KAAK,MAAM,IAAI,IAAI,YAAY,EAAE,CAAC;oBACjC,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC;oBACrE,IAAI,CAAC,KAAK,EAAE,CAAC;wBACZ,OAAO,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC,WAAW,IAAI,YAAY,CAAC,CAAC,CAAC;oBAClE,CAAC;gBACF,CAAC;gBACD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;gBAC7D,OAAO,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YAC5B,CAAC;SACD;QACD,eAAe,EAAE;YAChB,IAAI,EAAE,mCAAmC;YACzC,MAAM,EAAE,KAAK,EAAE,EAAE,WAAW,EAAE,EAAE,EAAE;gBACjC,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC;oBAAE,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;gBAC9E,MAAM,YAAY,GAAI,WAAsB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;gBACjF,KAAK,MAAM,IAAI,IAAI,YAAY,EAAE,CAAC;oBACjC,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC;oBACrE,IAAI,CAAC,KAAK,EAAE,CAAC;wBACZ,OAAO,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC,WAAW,IAAI,YAAY,CAAC,CAAC,CAAC;oBAClE,CAAC;gBACF,CAAC;gBACD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;gBACrF,OAAO,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YAC5B,CAAC;SACD;KACuB,CAAC;IAE1B,KAAK,CAAC,KAAK;QACV,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACrC,MAAM,cAAc,GAAoB,EAAE,QAAQ,EAAE,qBAAqB,CAAC,KAAK,EAAE,eAAe,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,iCAAiC;QAC1J,OAAO,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,cAAc,EAAE,CAAC,CAAC,CAAC;IACtD,CAAC;IACD,KAAK,CAAC,IAAI;QACT,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACpC,MAAM,cAAc,GAAoB,EAAE,QAAQ,EAAE,qBAAqB,CAAC,KAAK,EAAE,eAAe,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,qCAAqC;QAC7J,OAAO,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,cAAc,EAAE,CAAC,CAAC,CAAC;IACtD,CAAC;IAED;QACC,KAAK,EAAE,CAAC;IACT,CAAC;CACD;AAED,eAAe,eAAe,CAAC"}
|
package/build/steps/haibun.d.ts
CHANGED
|
@@ -6,6 +6,7 @@ declare class Haibun extends AStepper implements IHasCycles {
|
|
|
6
6
|
};
|
|
7
7
|
steppers: AStepper[];
|
|
8
8
|
resolvedFeature: TResolvedFeature;
|
|
9
|
+
private runner;
|
|
9
10
|
setWorld(world: TWorld, steppers: AStepper[]): Promise<void>;
|
|
10
11
|
cycles: IStepperCycles;
|
|
11
12
|
cyclesWhen: {
|
|
@@ -13,24 +14,11 @@ declare class Haibun extends AStepper implements IHasCycles {
|
|
|
13
14
|
startFeature: number;
|
|
14
15
|
};
|
|
15
16
|
steps: {
|
|
16
|
-
not: {
|
|
17
|
-
gwta: string;
|
|
18
|
-
action: ({ statements }: {
|
|
19
|
-
statements: TFeatureStep[];
|
|
20
|
-
}, featureStep: TFeatureStep) => Promise<import("../lib/defs.js").TNotOKActionResult | import("../lib/defs.js").TOKActionResult>;
|
|
21
|
-
};
|
|
22
|
-
if: {
|
|
23
|
-
gwta: string;
|
|
24
|
-
action: ({ ifStatements, thenStatements }: {
|
|
25
|
-
ifStatements: TFeatureStep[];
|
|
26
|
-
thenStatements: TFeatureStep[];
|
|
27
|
-
}, featureStep: TFeatureStep) => Promise<import("../lib/defs.js").TNotOKActionResult | import("../lib/defs.js").TOKActionResult>;
|
|
28
|
-
};
|
|
29
17
|
until: {
|
|
30
18
|
gwta: string;
|
|
31
19
|
action: ({ statements }: {
|
|
32
20
|
statements: TFeatureStep[];
|
|
33
|
-
}, featureStep: TFeatureStep) => Promise<import("../lib/defs.js").TOKActionResult>;
|
|
21
|
+
}, featureStep: TFeatureStep) => Promise<import("../lib/defs.js").TNotOKActionResult | import("../lib/defs.js").TOKActionResult>;
|
|
34
22
|
};
|
|
35
23
|
backgrounds: {
|
|
36
24
|
gwta: string;
|
|
@@ -50,12 +38,14 @@ declare class Haibun extends AStepper implements IHasCycles {
|
|
|
50
38
|
};
|
|
51
39
|
feature: {
|
|
52
40
|
gwta: string;
|
|
41
|
+
handlesUndefined: string[];
|
|
53
42
|
action: ({ feature }: {
|
|
54
43
|
feature: string;
|
|
55
44
|
}) => import("../lib/defs.js").TOKActionResult;
|
|
56
45
|
};
|
|
57
46
|
scenario: {
|
|
58
47
|
gwta: string;
|
|
48
|
+
handlesUndefined: string[];
|
|
59
49
|
action: ({ scenario }: {
|
|
60
50
|
scenario: string;
|
|
61
51
|
}) => import("../lib/defs.js").TOKActionResult;
|
|
@@ -94,17 +84,15 @@ declare class Haibun extends AStepper implements IHasCycles {
|
|
|
94
84
|
ms: number;
|
|
95
85
|
}) => Promise<import("../lib/defs.js").TOKActionResult>;
|
|
96
86
|
};
|
|
97
|
-
showDomains: {
|
|
98
|
-
gwta: string;
|
|
99
|
-
action: () => import("../lib/defs.js").TOKActionResult;
|
|
100
|
-
};
|
|
101
87
|
comment: {
|
|
102
88
|
gwta: string;
|
|
89
|
+
handlesUndefined: string[];
|
|
103
90
|
action: () => import("../lib/defs.js").TOKActionResult;
|
|
104
91
|
};
|
|
105
92
|
afterEveryStepper: {
|
|
106
93
|
precludes: string[];
|
|
107
94
|
gwta: string;
|
|
95
|
+
handlesUndefined: string[];
|
|
108
96
|
action: ({ stepperName, statement }: {
|
|
109
97
|
stepperName: string;
|
|
110
98
|
statement: TFeatureStep[];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"haibun.d.ts","sourceRoot":"","sources":["../../src/steps/haibun.ts"],"names":[],"mappings":"AAAA,OAAO,EAAM,YAAY,EAAc,MAAM,
|
|
1
|
+
{"version":3,"file":"haibun.d.ts","sourceRoot":"","sources":["../../src/steps/haibun.ts"],"names":[],"mappings":"AAAA,OAAO,EAAM,YAAY,EAAc,MAAM,EAAE,cAAc,EAAE,SAAS,EAAE,gBAAgB,EAA6C,MAAM,gBAAgB,CAAC;AAC9J,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAiB,MAAM,oBAAoB,CAAC;AASzE,cAAM,MAAO,SAAQ,QAAS,YAAW,UAAU;IAClD,eAAe,EAAE;QAAE,CAAC,WAAW,EAAE,MAAM,GAAG,YAAY,EAAE,CAAA;KAAE,CAAM;IAChE,QAAQ,EAAE,QAAQ,EAAE,CAAM;IAC1B,eAAe,EAAE,gBAAgB,CAAC;IAClC,OAAO,CAAC,MAAM,CAAa;IAGrB,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE;IAKlD,MAAM,EAAE,cAAc,CA4BpB;IACF,UAAU;;;MAGT;IAGD,KAAK;;;qCAI4B;gBAAE,UAAU,EAAE,YAAY,EAAE,CAAA;aAAE,eAAe,YAAY;;;;uCAmB7D,MAAM,SAAS,MAAM,YAAY,QAAQ,eAAe,SAAS;gCAgBlE;gBAAE,KAAK,EAAE,MAAM,CAAA;aAAE,eAAe,YAAY;;;;;;;;;;;;;;kCAuBhD;gBAAE,OAAO,EAAE,MAAM,CAAA;aAAE;;;;;mCAQlB;gBAAE,QAAQ,EAAE,MAAM,CAAA;aAAE;;;;6BAQzB;gBAAE,EAAE,EAAE,MAAM,CAAA;aAAE;;;;iCAOV;gBAAE,MAAM,EAAE,MAAM,CAAA;aAAE;;;;;;;;;;;;;;;;;;;;6BAkChB;gBAAE,EAAE,EAAE,MAAM,CAAA;aAAE;;;;;;;;;;;iDAWD;gBAAE,WAAW,EAAE,MAAM,CAAC;gBAAC,SAAS,EAAE,YAAY,EAAE,CAAA;aAAE;;MAK/D;IAE1B,8BAA8B,CAAC,IAAI,EAAE,MAAM,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,EAAE,KAAK,MAAY;CASpG;AACD,eAAe,MAAM,CAAC"}
|
package/build/steps/haibun.js
CHANGED
|
@@ -1,19 +1,22 @@
|
|
|
1
|
-
import { OK, STEP_DELAY,
|
|
1
|
+
import { OK, STEP_DELAY, CycleWhen } from '../lib/defs.js';
|
|
2
2
|
import { AStepper } from '../lib/astepper.js';
|
|
3
3
|
import { actionNotOK, actionOK, formattedSteppers, sleep } from '../lib/util/index.js';
|
|
4
|
-
import {
|
|
4
|
+
import { findFeatureStepsFromStatement } from '../phases/Resolver.js';
|
|
5
5
|
import { EExecutionMessageType } from '../lib/interfaces/logger.js';
|
|
6
6
|
import { endExecutonContext } from '../phases/Executor.js';
|
|
7
7
|
import { DOMAIN_STATEMENT } from '../lib/domain-types.js';
|
|
8
8
|
import { findFeatures } from '../lib/features.js';
|
|
9
|
+
import { FlowRunner } from '../lib/core/flow-runner.js';
|
|
9
10
|
class Haibun extends AStepper {
|
|
10
11
|
afterEverySteps = {};
|
|
11
12
|
steppers = [];
|
|
12
13
|
resolvedFeature;
|
|
14
|
+
runner;
|
|
13
15
|
// biome-disable-next-line @typescript-eslint/require-await
|
|
14
16
|
async setWorld(world, steppers) {
|
|
15
17
|
await super.setWorld(world, steppers);
|
|
16
18
|
this.steppers = steppers;
|
|
19
|
+
this.runner = new FlowRunner(world, steppers);
|
|
17
20
|
}
|
|
18
21
|
cycles = {
|
|
19
22
|
startExecution(resolvedFeatures) {
|
|
@@ -25,24 +28,18 @@ class Haibun extends AStepper {
|
|
|
25
28
|
this.createResolvedFeaturesArtifact(`feature-${index}`, [resolvedFeature]);
|
|
26
29
|
},
|
|
27
30
|
afterStep: async ({ featureStep }) => {
|
|
31
|
+
if (featureStep.isSubStep) {
|
|
32
|
+
return Promise.resolve({ failed: false });
|
|
33
|
+
}
|
|
28
34
|
const afterEvery = this.afterEverySteps[featureStep.action.stepperName];
|
|
29
35
|
let failed = false;
|
|
30
36
|
if (afterEvery) {
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
// Map the seqPath to extend from the current featureStep
|
|
37
|
-
const mappedStep = {
|
|
38
|
-
...aeStep,
|
|
39
|
-
seqPath: [...featureStep.seqPath, ...(aeStep.seqPath.slice(1))],
|
|
40
|
-
};
|
|
41
|
-
// After every steps are substeps (triggered by parent step)
|
|
42
|
-
const res = await executeSubFeatureSteps(featureStep, [mappedStep], this.steppers, this.getWorld(), ExecMode.NO_CYCLES, 1, true);
|
|
43
|
-
if (!res.ok) {
|
|
37
|
+
const stepsToRun = afterEvery.filter(aeStep => aeStep.action.actionName !== featureStep.action.actionName);
|
|
38
|
+
if (stepsToRun.length > 0) {
|
|
39
|
+
const mode = featureStep.intent?.mode === 'speculative' ? 'speculative' : 'authoritative';
|
|
40
|
+
const res = await this.runner.runSteps(stepsToRun, { intent: { mode }, parentStep: featureStep });
|
|
41
|
+
if (res.kind !== 'ok') {
|
|
44
42
|
failed = true;
|
|
45
|
-
break;
|
|
46
43
|
}
|
|
47
44
|
}
|
|
48
45
|
}
|
|
@@ -54,39 +51,22 @@ class Haibun extends AStepper {
|
|
|
54
51
|
startFeature: CycleWhen.LAST,
|
|
55
52
|
};
|
|
56
53
|
steps = {
|
|
57
|
-
// --- LOGIC OPERATORS --- // Represents Logical Negation (~P).
|
|
58
|
-
not: {
|
|
59
|
-
gwta: `not {statements:${DOMAIN_STATEMENT}}`,
|
|
60
|
-
action: async ({ statements }, featureStep) => {
|
|
61
|
-
const lastResult = await executeSubFeatureSteps(featureStep, statements, this.steppers, this.getWorld(), ExecMode.NO_CYCLES, -1);
|
|
62
|
-
// Negation: action is OK if the inner statement failed (was NOT true)
|
|
63
|
-
return lastResult.ok ? actionNotOK('not statement was true (failed negation)') : OK;
|
|
64
|
-
},
|
|
65
|
-
},
|
|
66
|
-
// Represents Logical Implication (P => Q).
|
|
67
|
-
if: {
|
|
68
|
-
gwta: `if {ifStatements:${DOMAIN_STATEMENT}}, {thenStatements:${DOMAIN_STATEMENT}}`,
|
|
69
|
-
action: async ({ ifStatements, thenStatements }, featureStep) => {
|
|
70
|
-
const ifResult = await executeSubFeatureSteps(featureStep, ifStatements, this.steppers, this.getWorld(), ExecMode.NO_CYCLES, -1);
|
|
71
|
-
// If antecedent fails, the implication is true (vacuously true: F => T/F), so we return OK.
|
|
72
|
-
if (!ifResult.ok) {
|
|
73
|
-
return OK;
|
|
74
|
-
}
|
|
75
|
-
// 2. Evaluate Consequent (THEN) - use dir=1 for body execution
|
|
76
|
-
const ifThenResult = await executeSubFeatureSteps(featureStep, thenStatements, this.steppers, this.getWorld(), ExecMode.WITH_CYCLES, 1);
|
|
77
|
-
// Consequent must succeed to prove the implication is true (T => T)
|
|
78
|
-
return ifThenResult.ok ? OK : actionNotOK('if antecedent was TRUE, but consequent failed');
|
|
79
|
-
},
|
|
80
|
-
},
|
|
81
54
|
// --- META & UTILITIES ---
|
|
82
55
|
until: {
|
|
83
56
|
gwta: `until {statements:${DOMAIN_STATEMENT}}`,
|
|
84
57
|
action: async ({ statements }, featureStep) => {
|
|
85
|
-
let
|
|
58
|
+
let signal;
|
|
59
|
+
const mode = featureStep.intent?.mode === 'speculative' ? 'speculative' : 'authoritative';
|
|
86
60
|
do {
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
61
|
+
signal = await this.runner.runSteps(statements, { intent: { mode, usage: 'polling' }, parentStep: featureStep });
|
|
62
|
+
if (signal.fatal) {
|
|
63
|
+
this.getWorld().logger.warn(`until: received terminal error, aborting loop`);
|
|
64
|
+
return actionNotOK('until: aborted due to terminal error');
|
|
65
|
+
}
|
|
66
|
+
if (signal.kind !== 'ok') {
|
|
67
|
+
await sleep(200);
|
|
68
|
+
}
|
|
69
|
+
} while (signal.kind !== 'ok');
|
|
90
70
|
return OK;
|
|
91
71
|
},
|
|
92
72
|
},
|
|
@@ -110,8 +90,9 @@ class Haibun extends AStepper {
|
|
|
110
90
|
// Expand backgrounds at runtime using world.runtime.backgrounds
|
|
111
91
|
const world = this.getWorld();
|
|
112
92
|
const expanded = findFeatureStepsFromStatement(names, this.steppers, world, featureStep.path, featureStep.seqPath, 1);
|
|
113
|
-
const
|
|
114
|
-
|
|
93
|
+
const mode = featureStep.intent?.mode === 'speculative' ? 'speculative' : 'authoritative';
|
|
94
|
+
const result = await this.runner.runSteps(expanded, { intent: { mode }, parentStep: featureStep });
|
|
95
|
+
return result.kind === 'ok' ? OK : actionNotOK(`backgrounds failed: ${result.message}`);
|
|
115
96
|
},
|
|
116
97
|
},
|
|
117
98
|
nothing: {
|
|
@@ -119,12 +100,14 @@ class Haibun extends AStepper {
|
|
|
119
100
|
action: () => OK,
|
|
120
101
|
},
|
|
121
102
|
prose: {
|
|
122
|
-
|
|
103
|
+
// prose starts with a capital letter and ends with punctuation, or starts with punctuation
|
|
104
|
+
match: /^([A-Z].*[.!?:;]|[^a-zA-Z].*)$/,
|
|
123
105
|
fallback: true,
|
|
124
106
|
action: () => OK,
|
|
125
107
|
},
|
|
126
108
|
feature: {
|
|
127
109
|
gwta: 'Feature: {feature}',
|
|
110
|
+
handlesUndefined: ['feature'],
|
|
128
111
|
action: ({ feature }) => {
|
|
129
112
|
this.getWorld().runtime.feature = feature;
|
|
130
113
|
return OK;
|
|
@@ -132,6 +115,7 @@ class Haibun extends AStepper {
|
|
|
132
115
|
},
|
|
133
116
|
scenario: {
|
|
134
117
|
gwta: 'Scenario: {scenario}',
|
|
118
|
+
handlesUndefined: ['scenario'],
|
|
135
119
|
action: ({ scenario }) => {
|
|
136
120
|
this.getWorld().runtime.scenario = scenario;
|
|
137
121
|
return OK;
|
|
@@ -182,20 +166,15 @@ class Haibun extends AStepper {
|
|
|
182
166
|
gwta: 'pause for {ms:number}s',
|
|
183
167
|
action: (async ({ ms }) => { await sleep(ms * 1000); return OK; }),
|
|
184
168
|
},
|
|
185
|
-
showDomains: {
|
|
186
|
-
gwta: 'show domains',
|
|
187
|
-
action: () => {
|
|
188
|
-
this.getWorld().logger.info(`Domains: ${JSON.stringify(this.getWorld().domains, null, 2)}`);
|
|
189
|
-
return OK;
|
|
190
|
-
}
|
|
191
|
-
},
|
|
192
169
|
comment: {
|
|
193
170
|
gwta: ';;{comment}',
|
|
171
|
+
handlesUndefined: ['comment'],
|
|
194
172
|
action: () => OK,
|
|
195
173
|
},
|
|
196
174
|
afterEveryStepper: {
|
|
197
175
|
precludes: [`Haibun.prose`],
|
|
198
176
|
gwta: `after every {stepperName: string}, {statement: ${DOMAIN_STATEMENT}}`,
|
|
177
|
+
handlesUndefined: ['stepperName'],
|
|
199
178
|
action: ({ stepperName, statement }) => {
|
|
200
179
|
this.afterEverySteps[stepperName] = statement;
|
|
201
180
|
return OK;
|