@haibun/core 2.0.0 → 3.0.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/build/applyEffectFeatures.d.ts.map +1 -1
- package/build/applyEffectFeatures.js +3 -6
- package/build/applyEffectFeatures.js.map +1 -1
- package/build/currentVersion.d.ts +1 -1
- package/build/currentVersion.js +1 -1
- package/build/jsprolog/converter.d.ts +9 -0
- package/build/jsprolog/converter.d.ts.map +1 -0
- package/build/jsprolog/converter.js +42 -0
- package/build/jsprolog/converter.js.map +1 -0
- package/build/jsprolog/stepper-utils.d.ts +8 -0
- package/build/jsprolog/stepper-utils.d.ts.map +1 -0
- package/build/jsprolog/stepper-utils.js +8 -0
- package/build/jsprolog/stepper-utils.js.map +1 -0
- package/build/jsprolog/test.jsprolog.d.ts +4 -0
- package/build/jsprolog/test.jsprolog.d.ts.map +1 -0
- package/build/jsprolog/test.jsprolog.js +19 -0
- package/build/jsprolog/test.jsprolog.js.map +1 -0
- package/build/jsprolog/test.kireji.d.ts +4 -0
- package/build/jsprolog/test.kireji.d.ts.map +1 -0
- package/build/jsprolog/test.kireji.js +19 -0
- package/build/jsprolog/test.kireji.js.map +1 -0
- package/build/jsprolog/withAction.d.ts +32 -0
- package/build/jsprolog/withAction.d.ts.map +1 -0
- package/build/jsprolog/withAction.js +65 -0
- package/build/jsprolog/withAction.js.map +1 -0
- package/build/kireji/converter.d.ts +9 -0
- package/build/kireji/converter.d.ts.map +1 -0
- package/build/kireji/converter.js +49 -0
- package/build/kireji/converter.js.map +1 -0
- package/build/kireji/test.kireji.d.ts +4 -0
- package/build/kireji/test.kireji.d.ts.map +1 -0
- package/build/kireji/test.kireji.js +19 -0
- package/build/kireji/test.kireji.js.map +1 -0
- package/build/kireji/withAction.d.ts +36 -0
- package/build/kireji/withAction.d.ts.map +1 -0
- package/build/kireji/withAction.js +66 -0
- package/build/kireji/withAction.js.map +1 -0
- package/build/lib/Logger.d.ts +2 -0
- package/build/lib/Logger.d.ts.map +1 -1
- package/build/lib/Logger.js +9 -5
- package/build/lib/Logger.js.map +1 -1
- package/build/lib/TestLogger.d.ts +1 -0
- package/build/lib/TestLogger.d.ts.map +1 -1
- package/build/lib/TestLogger.js +1 -0
- package/build/lib/TestLogger.js.map +1 -1
- package/build/lib/astepper.d.ts +4 -6
- package/build/lib/astepper.d.ts.map +1 -1
- package/build/lib/astepper.js +0 -1
- package/build/lib/astepper.js.map +1 -1
- package/build/lib/core-domains.d.ts +3 -3
- package/build/lib/core-domains.d.ts.map +1 -1
- package/build/lib/core-domains.js +3 -3
- package/build/lib/core-domains.js.map +1 -1
- package/build/lib/defs.d.ts +29 -23
- package/build/lib/defs.d.ts.map +1 -1
- package/build/lib/defs.js +2 -1
- package/build/lib/defs.js.map +1 -1
- package/build/lib/errors.d.ts +13 -0
- package/build/lib/errors.d.ts.map +1 -0
- package/build/lib/errors.js +18 -0
- package/build/lib/errors.js.map +1 -0
- package/build/lib/feature-variables.d.ts +4 -2
- package/build/lib/feature-variables.d.ts.map +1 -1
- package/build/lib/feature-variables.js +12 -2
- package/build/lib/feature-variables.js.map +1 -1
- package/build/lib/features.d.ts.map +1 -1
- package/build/lib/features.js +7 -3
- package/build/lib/features.js.map +1 -1
- package/build/lib/interfaces/logger.d.ts +4 -2
- package/build/lib/interfaces/logger.d.ts.map +1 -1
- package/build/lib/interfaces/logger.js +1 -0
- package/build/lib/interfaces/logger.js.map +1 -1
- package/build/lib/namedVars.d.ts.map +1 -1
- package/build/lib/namedVars.js +8 -1
- package/build/lib/namedVars.js.map +1 -1
- package/build/lib/populateActionArgs.js +1 -1
- package/build/lib/populateActionArgs.js.map +1 -1
- package/build/lib/test/TestSteps.d.ts +0 -5
- package/build/lib/test/TestSteps.d.ts.map +1 -1
- package/build/lib/test/TestSteps.js +0 -8
- package/build/lib/test/TestSteps.js.map +1 -1
- package/build/lib/test/lib.d.ts +4 -1
- package/build/lib/test/lib.d.ts.map +1 -1
- package/build/lib/test/lib.js +18 -5
- package/build/lib/test/lib.js.map +1 -1
- package/build/lib/test/resolvedTestFeatures.js +1 -1
- package/build/lib/test/resolvedTestFeatures.js.map +1 -1
- package/build/lib/util/featureStep-executor.d.ts +2 -1
- package/build/lib/util/featureStep-executor.d.ts.map +1 -1
- package/build/lib/util/featureStep-executor.js +31 -7
- package/build/lib/util/featureStep-executor.js.map +1 -1
- package/build/lib/util/index.d.ts +3 -1
- package/build/lib/util/index.d.ts.map +1 -1
- package/build/lib/util/index.js +2 -0
- package/build/lib/util/index.js.map +1 -1
- package/build/phases/Executor.d.ts +6 -1
- package/build/phases/Executor.d.ts.map +1 -1
- package/build/phases/Executor.js +156 -22
- package/build/phases/Executor.js.map +1 -1
- package/build/phases/Resolver.d.ts +4 -3
- package/build/phases/Resolver.d.ts.map +1 -1
- package/build/phases/Resolver.js +49 -31
- package/build/phases/Resolver.js.map +1 -1
- package/build/phases/collector.d.ts +1 -1
- package/build/phases/collector.d.ts.map +1 -1
- package/build/phases/collector.js +36 -7
- package/build/phases/collector.js.map +1 -1
- package/build/runner.d.ts.map +1 -1
- package/build/runner.js +4 -7
- package/build/runner.js.map +1 -1
- package/build/steps/activities-stepper.d.ts +79 -0
- package/build/steps/activities-stepper.d.ts.map +1 -0
- package/build/steps/activities-stepper.js +342 -0
- package/build/steps/activities-stepper.js.map +1 -0
- package/build/steps/conditions-stepper.d.ts +27 -0
- package/build/steps/conditions-stepper.d.ts.map +1 -0
- package/build/steps/conditions-stepper.js +99 -0
- package/build/steps/conditions-stepper.js.map +1 -0
- package/build/steps/debugger-stepper.d.ts +60 -2
- package/build/steps/debugger-stepper.d.ts.map +1 -1
- package/build/steps/debugger-stepper.js +5 -5
- package/build/steps/debugger-stepper.js.map +1 -1
- package/build/steps/haibun.d.ts +69 -22
- package/build/steps/haibun.d.ts.map +1 -1
- package/build/steps/haibun.js +138 -75
- package/build/steps/haibun.js.map +1 -1
- package/build/steps/narrator.d.ts +4 -4
- package/build/steps/parse.d.ts +1 -1
- package/build/steps/variables-stepper.d.ts +69 -4
- package/build/steps/variables-stepper.d.ts.map +1 -1
- package/build/steps/variables-stepper.js +44 -14
- package/build/steps/variables-stepper.js.map +1 -1
- package/package.json +1 -1
- package/build/lib/dependency-resolver.d.ts +0 -2
- package/build/lib/dependency-resolver.d.ts.map +0 -1
- package/build/lib/dependency-resolver.js +0 -3
- package/build/lib/dependency-resolver.js.map +0 -1
- package/build/lib/resolve-or-error.d.ts +0 -2
- package/build/lib/resolve-or-error.d.ts.map +0 -1
- package/build/lib/resolve-or-error.js +0 -3
- package/build/lib/resolve-or-error.js.map +0 -1
- package/build/lib/resolved-text-view.d.ts +0 -32
- package/build/lib/resolved-text-view.d.ts.map +0 -1
- package/build/lib/resolved-text-view.js +0 -103
- package/build/lib/resolved-text-view.js.map +0 -1
- package/build/lib/resolved-view.d.ts +0 -45
- package/build/lib/resolved-view.d.ts.map +0 -1
- package/build/lib/resolved-view.js +0 -133
- package/build/lib/resolved-view.js.map +0 -1
- package/build/phases/statement.test copy.d.ts +0 -2
- package/build/phases/statement.test copy.d.ts.map +0 -1
- package/build/phases/statement.test copy.js +0 -57
- package/build/phases/statement.test copy.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"conditions-stepper.js","sourceRoot":"","sources":["../../src/steps/conditions-stepper.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { AStepper, IHasCycles, IHasOptions
|
|
1
|
+
import { AStepper, IHasCycles, IHasOptions } from '../lib/astepper.js';
|
|
2
2
|
import { IStepperCycles, TActionResult, TWorld, TFeatureStep } from '../lib/defs.js';
|
|
3
3
|
export declare enum TDebuggingType {
|
|
4
4
|
StepByStep = "stepByStep",
|
|
@@ -26,7 +26,65 @@ export declare class DebuggerStepper extends AStepper implements IHasCycles, IHa
|
|
|
26
26
|
step(): Promise<TActionResult>;
|
|
27
27
|
continue(): Promise<TActionResult>;
|
|
28
28
|
debugLoop(prompt: string, prompts: string[], featureStep: TFeatureStep, inc: number): Promise<any>;
|
|
29
|
-
steps:
|
|
29
|
+
steps: {
|
|
30
|
+
f: {
|
|
31
|
+
expose: false;
|
|
32
|
+
exact: string;
|
|
33
|
+
action: () => Promise<TActionResult>;
|
|
34
|
+
};
|
|
35
|
+
fail: {
|
|
36
|
+
exact: string;
|
|
37
|
+
action: () => Promise<TActionResult>;
|
|
38
|
+
};
|
|
39
|
+
n: {
|
|
40
|
+
expose: false;
|
|
41
|
+
exact: string;
|
|
42
|
+
action: () => Promise<TActionResult>;
|
|
43
|
+
};
|
|
44
|
+
next: {
|
|
45
|
+
exact: string;
|
|
46
|
+
action: () => Promise<TActionResult>;
|
|
47
|
+
};
|
|
48
|
+
r: {
|
|
49
|
+
expose: false;
|
|
50
|
+
exact: string;
|
|
51
|
+
action: () => Promise<TActionResult>;
|
|
52
|
+
};
|
|
53
|
+
retry: {
|
|
54
|
+
exact: string;
|
|
55
|
+
action: () => Promise<TActionResult>;
|
|
56
|
+
};
|
|
57
|
+
s: {
|
|
58
|
+
expose: false;
|
|
59
|
+
exact: string;
|
|
60
|
+
action: () => Promise<TActionResult>;
|
|
61
|
+
};
|
|
62
|
+
step: {
|
|
63
|
+
exact: string;
|
|
64
|
+
action: () => Promise<TActionResult>;
|
|
65
|
+
};
|
|
66
|
+
c: {
|
|
67
|
+
expose: false;
|
|
68
|
+
exact: string;
|
|
69
|
+
action: () => Promise<TActionResult>;
|
|
70
|
+
};
|
|
71
|
+
continue: {
|
|
72
|
+
exact: string;
|
|
73
|
+
action: () => Promise<TActionResult>;
|
|
74
|
+
};
|
|
75
|
+
debugStepByStep: {
|
|
76
|
+
exact: string;
|
|
77
|
+
action: () => Promise<TActionResult>;
|
|
78
|
+
};
|
|
79
|
+
debugStepper: {
|
|
80
|
+
gwta: string;
|
|
81
|
+
action: ({ stepperName }: import("../lib/defs.js").TStepArgs) => Promise<import("../lib/defs.js").TOKActionResult | import("../lib/defs.js").TNotOKActionResult>;
|
|
82
|
+
};
|
|
83
|
+
continueStepper: {
|
|
84
|
+
gwta: string;
|
|
85
|
+
action: ({ stepperName }: import("../lib/defs.js").TStepArgs) => Promise<import("../lib/defs.js").TOKActionResult | import("../lib/defs.js").TNotOKActionResult>;
|
|
86
|
+
};
|
|
87
|
+
};
|
|
30
88
|
retry(): Promise<TActionResult>;
|
|
31
89
|
next(): Promise<TActionResult>;
|
|
32
90
|
constructor();
|
|
@@ -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,
|
|
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;AAM3J,oBAAY,cAAc;IACzB,UAAU,eAAe;IACzB,QAAQ,aAAa;CACrB;AAgBD,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;IAE7B,OAAO;;;;;;;;;;;MAKL;IAEI,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAe5D,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;IAuBzF,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"}
|
|
@@ -2,7 +2,7 @@ import { AStepper } from '../lib/astepper.js';
|
|
|
2
2
|
import { OK, ExecMode } from '../lib/defs.js';
|
|
3
3
|
import { EExecutionMessageType } from '../lib/interfaces/logger.js';
|
|
4
4
|
import { makePrompt } from '../lib/prompter.js';
|
|
5
|
-
import { actionNotOK, actionOK, getStepperOption, stringOrError } from '../lib/util/index.js';
|
|
5
|
+
import { actionNotOK, actionOK, formatCurrentSection, formatCurrentSeqPath, getStepperOption, stringOrError } from '../lib/util/index.js';
|
|
6
6
|
import { resolveAndExecuteStatement } from '../lib/util/featureStep-executor.js';
|
|
7
7
|
export var TDebuggingType;
|
|
8
8
|
(function (TDebuggingType) {
|
|
@@ -13,13 +13,13 @@ const cycles = (debuggerStepper) => ({
|
|
|
13
13
|
async beforeStep({ featureStep }) {
|
|
14
14
|
const { action } = featureStep;
|
|
15
15
|
if (debuggerStepper.debuggingType === TDebuggingType.StepByStep || debuggerStepper.debugSteppers.includes(action.stepperName)) {
|
|
16
|
-
const prompt = (debuggerStepper.debugSteppers.includes(action.stepperName)) ? `
|
|
17
|
-
return debuggerStepper.debugLoop(prompt
|
|
16
|
+
const prompt = (debuggerStepper.debugSteppers.includes(action.stepperName)) ? `Debugging ${action.stepperName}` : 'Debug';
|
|
17
|
+
return debuggerStepper.debugLoop(`${prompt} ${formatCurrentSection(debuggerStepper.getWorld().runtime)}`, ['*', 'step', 'continue'], featureStep, -1);
|
|
18
18
|
}
|
|
19
19
|
},
|
|
20
20
|
async afterStep({ featureStep, actionResult }) {
|
|
21
21
|
if (!actionResult.ok) {
|
|
22
|
-
return await debuggerStepper.debugLoop(
|
|
22
|
+
return await debuggerStepper.debugLoop(`[Failure] ${formatCurrentSection(debuggerStepper.getWorld().runtime)}`, ['*', 'retry', 'next', 'fail'], featureStep, 1);
|
|
23
23
|
}
|
|
24
24
|
}
|
|
25
25
|
});
|
|
@@ -71,7 +71,7 @@ export class DebuggerStepper extends AStepper {
|
|
|
71
71
|
let promptResult;
|
|
72
72
|
let continueLoop = true;
|
|
73
73
|
while (continueLoop) {
|
|
74
|
-
const response = await this.getWorld().prompter.prompt(makePrompt(`${featureStep.seqPath
|
|
74
|
+
const response = await this.getWorld().prompter.prompt(makePrompt(`${formatCurrentSeqPath(featureStep.seqPath)}-${prompt}`, undefined, prompts));
|
|
75
75
|
try {
|
|
76
76
|
promptResult = await resolveAndExecuteStatement(response.toString(), '<debugger>', this.steppers, this.getWorld(), ExecMode.PROMPT, seqStart);
|
|
77
77
|
const details = promptResult.stepActionResult.messageContext?.incidentDetails;
|
|
@@ -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,EAAgD,QAAQ,EAAkC,MAAM,gBAAgB,CAAC;AAC3J,OAAO,EAAmB,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AACrF,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;
|
|
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,EAAgD,QAAQ,EAAkC,MAAM,gBAAgB,CAAC;AAC3J,OAAO,EAAmB,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AACrF,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,oBAAoB,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAC1I,OAAO,EAAE,0BAA0B,EAAE,MAAM,qCAAqC,CAAC;AAEjF,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,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,IAAI,oBAAoB,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC;QACvJ,CAAC;IACF,CAAC;IACD,KAAK,CAAC,SAAS,CAAC,EAAE,WAAW,EAAE,YAAY,EAAc;QACxD,IAAI,CAAC,YAAY,CAAC,EAAE,EAAE,CAAC;YACtB,OAAO,MAAM,eAAe,CAAC,SAAS,CAAC,aAAa,oBAAoB,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC,GAAG,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC,CAAC;QACjK,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;IAE7B,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,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,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,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,YAAqC,CAAC;QAC1C,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;YACjJ,IAAI,CAAC;gBACJ,YAAY,GAAG,MAAM,0BAA0B,CAAC,QAAQ,CAAC,QAAQ,EAAE,EAAE,YAAY,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,QAAQ,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;gBAC9I,MAAM,OAAO,GAAG,YAAY,CAAC,gBAAgB,CAAC,cAAc,EAAE,eAAe,CAAC;gBAC9E,IAAI,OAAO,EAAE,IAAI,IAAI,OAAO,EAAE,QAAQ,IAAI,OAAO,EAAE,IAAI,IAAI,OAAO,EAAE,SAAS,IAAI,OAAO,EAAE,QAAQ,EAAE,CAAC;oBACpG,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,QAAQ,MAAM,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;YACpG,CAAC;QACF,CAAC;QACD,OAAO,YAAY,CAAC,gBAAgB,CAAC,cAAc,EAAE,eAAe,CAAC;IACtE,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
|
@@ -1,49 +1,94 @@
|
|
|
1
|
-
import { TFeatureStep,
|
|
1
|
+
import { TFeatureStep, TWorld, IStepperCycles, TFeatures, TResolvedFeature } from '../lib/defs.js';
|
|
2
2
|
import { AStepper } from '../lib/astepper.js';
|
|
3
3
|
declare class Haibun extends AStepper {
|
|
4
|
+
afterEverySteps: {
|
|
5
|
+
[stepperName: string]: TFeatureStep[];
|
|
6
|
+
};
|
|
4
7
|
steppers: AStepper[];
|
|
8
|
+
resolvedFeature: TResolvedFeature;
|
|
5
9
|
setWorld(world: TWorld, steppers: AStepper[]): Promise<void>;
|
|
10
|
+
cycles: IStepperCycles;
|
|
6
11
|
steps: {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
action: (
|
|
12
|
+
not: {
|
|
13
|
+
gwta: string;
|
|
14
|
+
action: ({ statements }: {
|
|
15
|
+
statements: TFeatureStep[];
|
|
16
|
+
}, featureStep: TFeatureStep) => Promise<import("../lib/defs.js").TOKActionResult | import("../lib/defs.js").TNotOKActionResult>;
|
|
10
17
|
};
|
|
11
|
-
|
|
18
|
+
if: {
|
|
12
19
|
gwta: string;
|
|
13
|
-
action: (
|
|
20
|
+
action: ({ ifStatements, thenStatements }: {
|
|
21
|
+
ifStatements: TFeatureStep[];
|
|
22
|
+
thenStatements: TFeatureStep[];
|
|
23
|
+
}, featureStep: TFeatureStep) => Promise<import("../lib/defs.js").TOKActionResult | import("../lib/defs.js").TNotOKActionResult>;
|
|
14
24
|
};
|
|
15
|
-
|
|
25
|
+
until: {
|
|
16
26
|
gwta: string;
|
|
17
|
-
action: (
|
|
27
|
+
action: ({ statements }: {
|
|
28
|
+
statements: TFeatureStep[];
|
|
29
|
+
}, featureStep: TFeatureStep) => Promise<import("../lib/defs.js").TOKActionResult>;
|
|
18
30
|
};
|
|
19
|
-
|
|
31
|
+
backgrounds: {
|
|
20
32
|
gwta: string;
|
|
21
|
-
|
|
33
|
+
resolveFeatureLine: (line: string, _path: string, _stepper: AStepper, backgrounds: TFeatures) => false;
|
|
34
|
+
action: ({ names }: {
|
|
35
|
+
names: string;
|
|
36
|
+
}, featureStep: TFeatureStep) => Promise<import("../lib/defs.js").TOKActionResult | import("../lib/defs.js").TNotOKActionResult>;
|
|
22
37
|
};
|
|
23
|
-
|
|
38
|
+
nothing: {
|
|
39
|
+
exact: string;
|
|
40
|
+
action: () => import("../lib/defs.js").TOKActionResult;
|
|
41
|
+
};
|
|
42
|
+
prose: {
|
|
43
|
+
match: RegExp;
|
|
44
|
+
fallback: true;
|
|
45
|
+
action: () => import("../lib/defs.js").TOKActionResult;
|
|
46
|
+
};
|
|
47
|
+
feature: {
|
|
48
|
+
gwta: string;
|
|
49
|
+
action: ({ feature }: {
|
|
50
|
+
feature: string;
|
|
51
|
+
}) => import("../lib/defs.js").TOKActionResult;
|
|
52
|
+
};
|
|
53
|
+
scenario: {
|
|
24
54
|
gwta: string;
|
|
25
|
-
action: ({
|
|
55
|
+
action: ({ scenario }: {
|
|
56
|
+
scenario: string;
|
|
57
|
+
}) => import("../lib/defs.js").TOKActionResult;
|
|
26
58
|
};
|
|
27
59
|
startStepDelay: {
|
|
28
60
|
gwta: string;
|
|
29
|
-
action: ({ ms }:
|
|
61
|
+
action: ({ ms }: {
|
|
62
|
+
ms: number;
|
|
63
|
+
}) => import("../lib/defs.js").TOKActionResult;
|
|
30
64
|
};
|
|
31
65
|
endsWith: {
|
|
32
66
|
gwta: string;
|
|
33
|
-
action: ({ result }:
|
|
34
|
-
|
|
67
|
+
action: ({ result }: {
|
|
68
|
+
result: string;
|
|
69
|
+
}) => import("../lib/defs.js").TOKActionResult | import("../lib/defs.js").TNotOKActionResult;
|
|
35
70
|
};
|
|
36
|
-
|
|
71
|
+
showSteppers: {
|
|
37
72
|
exact: string;
|
|
38
73
|
action: () => import("../lib/defs.js").TOKActionResult;
|
|
39
74
|
};
|
|
40
|
-
|
|
75
|
+
showSteps: {
|
|
41
76
|
gwta: string;
|
|
42
|
-
action: (
|
|
77
|
+
action: () => import("../lib/defs.js").TOKActionResult;
|
|
78
|
+
};
|
|
79
|
+
showFeatures: {
|
|
80
|
+
gwta: string;
|
|
81
|
+
action: () => import("../lib/defs.js").TOKActionResult;
|
|
82
|
+
};
|
|
83
|
+
showBackgrounds: {
|
|
84
|
+
gwta: string;
|
|
85
|
+
action: () => import("../lib/defs.js").TOKActionResult;
|
|
43
86
|
};
|
|
44
87
|
pauseSeconds: {
|
|
45
88
|
gwta: string;
|
|
46
|
-
action: ({ ms }:
|
|
89
|
+
action: ({ ms }: {
|
|
90
|
+
ms: number;
|
|
91
|
+
}) => Promise<import("../lib/defs.js").TOKActionResult>;
|
|
47
92
|
};
|
|
48
93
|
showDomains: {
|
|
49
94
|
gwta: string;
|
|
@@ -54,12 +99,14 @@ declare class Haibun extends AStepper {
|
|
|
54
99
|
action: () => import("../lib/defs.js").TOKActionResult;
|
|
55
100
|
};
|
|
56
101
|
afterEveryStepper: {
|
|
102
|
+
precludes: string[];
|
|
57
103
|
gwta: string;
|
|
58
|
-
action: (
|
|
59
|
-
|
|
104
|
+
action: ({ stepperName, statement }: {
|
|
105
|
+
stepperName: string;
|
|
106
|
+
statement: TFeatureStep[];
|
|
107
|
+
}) => import("../lib/defs.js").TOKActionResult;
|
|
60
108
|
};
|
|
61
109
|
};
|
|
62
|
-
newFeatureFromEffect(content: string, parentSeqPath: number[], steppers: AStepper[]): Promise<TFeatureStep>;
|
|
63
110
|
}
|
|
64
111
|
export default Haibun;
|
|
65
112
|
//# sourceMappingURL=haibun.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"haibun.d.ts","sourceRoot":"","sources":["../../src/steps/haibun.ts"],"names":[],"mappings":"AAAA,OAAO,EAAM,YAAY,EAAc,SAAS,EAAE,
|
|
1
|
+
{"version":3,"file":"haibun.d.ts","sourceRoot":"","sources":["../../src/steps/haibun.ts"],"names":[],"mappings":"AAAA,OAAO,EAAM,YAAY,EAAc,MAAM,EAAyB,cAAc,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAC1I,OAAO,EAAE,QAAQ,EAAiB,MAAM,oBAAoB,CAAC;AAQ7D,cAAM,MAAO,SAAQ,QAAQ;IAC5B,eAAe,EAAE;QAAE,CAAC,WAAW,EAAE,MAAM,GAAG,YAAY,EAAE,CAAA;KAAE,CAAM;IAChE,QAAQ,EAAE,QAAQ,EAAE,CAAM;IAC1B,eAAe,EAAE,gBAAgB,CAAC;IAG5B,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE;IAIlD,MAAM,EAAE,cAAc,CA8BpB;IAEF,KAAK;;;qCAI4B;gBAAE,UAAU,EAAE,YAAY,EAAE,CAAA;aAAE,eAAe,YAAY;;;;uDAWvC;gBAAE,YAAY,EAAE,YAAY,EAAE,CAAC;gBAAC,cAAc,EAAE,YAAY,EAAE,CAAA;aAAE,eAAe,YAAY;;;;qCAmB7G;gBAAE,UAAU,EAAE,YAAY,EAAE,CAAA;aAAE,eAAe,YAAY;;;;uCAY7D,MAAM,SAAS,MAAM,YAAY,QAAQ,eAAe,SAAS;gCAgBlE;gBAAE,KAAK,EAAE,MAAM,CAAA;aAAE,eAAe,YAAY;;;;;;;;;;;;;kCAoBhD;gBAAE,OAAO,EAAE,MAAM,CAAA;aAAE;;;;mCAOlB;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;;;;;;;;;;;;;iDAgBD;gBAAE,WAAW,EAAE,MAAM,CAAC;gBAAC,SAAS,EAAE,YAAY,EAAE,CAAA;aAAE;;MAK/D;CAC1B;AACD,eAAe,MAAM,CAAC"}
|
package/build/steps/haibun.js
CHANGED
|
@@ -1,89 +1,146 @@
|
|
|
1
1
|
import { OK, STEP_DELAY, ExecMode } from '../lib/defs.js';
|
|
2
2
|
import { AStepper } from '../lib/astepper.js';
|
|
3
|
-
import { Resolver } from '../phases/Resolver.js';
|
|
4
3
|
import { actionNotOK, actionOK, formattedSteppers, sleep } from '../lib/util/index.js';
|
|
5
|
-
import {
|
|
6
|
-
import { expand } from '../lib/features.js';
|
|
7
|
-
import { asFeatures } from '../lib/resolver-features.js';
|
|
4
|
+
import { executeSubFeatureSteps, findFeatureStepsFromStatement } from '../lib/util/featureStep-executor.js';
|
|
8
5
|
import { EExecutionMessageType } from '../lib/interfaces/logger.js';
|
|
9
6
|
import { endExecutonContext } from '../phases/Executor.js';
|
|
10
7
|
import { DOMAIN_STATEMENT } from '../lib/domain-types.js';
|
|
8
|
+
import { findFeatures } from '../lib/features.js';
|
|
11
9
|
class Haibun extends AStepper {
|
|
10
|
+
afterEverySteps = {};
|
|
12
11
|
steppers = [];
|
|
12
|
+
resolvedFeature;
|
|
13
13
|
// eslint-disable-next-line @typescript-eslint/require-await
|
|
14
14
|
async setWorld(world, steppers) {
|
|
15
15
|
this.world = world;
|
|
16
16
|
this.steppers = steppers;
|
|
17
17
|
}
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
},
|
|
23
|
-
feature: {
|
|
24
|
-
gwta: 'Feature: {feature}',
|
|
25
|
-
action: async () => Promise.resolve(OK),
|
|
26
|
-
},
|
|
27
|
-
scenario: {
|
|
28
|
-
gwta: 'Scenario: {scenario}',
|
|
29
|
-
action: async () => Promise.resolve(OK),
|
|
18
|
+
cycles = {
|
|
19
|
+
// processes any afterEvery effects after each step
|
|
20
|
+
startFeature: ({ resolvedFeature }) => {
|
|
21
|
+
this.resolvedFeature = resolvedFeature;
|
|
30
22
|
},
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
23
|
+
afterStep: async ({ featureStep }) => {
|
|
24
|
+
const afterEvery = this.afterEverySteps[featureStep.action.stepperName];
|
|
25
|
+
let failed = false;
|
|
26
|
+
if (afterEvery) {
|
|
27
|
+
for (const aeStep of afterEvery) {
|
|
28
|
+
// Skip if the afterEvery step is the same as the current step (prevent infinite recursion)
|
|
29
|
+
if (aeStep.action.actionName === featureStep.action.actionName) {
|
|
30
|
+
continue;
|
|
31
|
+
}
|
|
32
|
+
// Map the seqPath to extend from the current featureStep
|
|
33
|
+
const mappedStep = {
|
|
34
|
+
...aeStep,
|
|
35
|
+
seqPath: [...featureStep.seqPath, ...(aeStep.seqPath.slice(1))],
|
|
36
|
+
};
|
|
37
|
+
// After every steps are substeps (triggered by parent step)
|
|
38
|
+
const res = await executeSubFeatureSteps(featureStep, [mappedStep], this.steppers, this.getWorld(), ExecMode.NO_CYCLES, 1, true);
|
|
39
|
+
if (!res.ok) {
|
|
40
|
+
failed = true;
|
|
41
41
|
break;
|
|
42
|
+
}
|
|
42
43
|
}
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
44
|
+
}
|
|
45
|
+
return Promise.resolve({ failed });
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
steps = {
|
|
49
|
+
// --- LOGIC OPERATORS --- // Represents Logical Negation (~P).
|
|
50
|
+
not: {
|
|
51
|
+
gwta: `not {statements:${DOMAIN_STATEMENT}}`,
|
|
52
|
+
action: async ({ statements }, featureStep) => {
|
|
53
|
+
const lastResult = await executeSubFeatureSteps(featureStep, statements, this.steppers, this.getWorld(), ExecMode.NO_CYCLES, -1);
|
|
54
|
+
// Negation: action is OK if the inner statement failed (was NOT true)
|
|
55
|
+
return lastResult.ok ? actionNotOK('not statement was true (failed negation)') : OK;
|
|
46
56
|
},
|
|
47
57
|
},
|
|
58
|
+
// Represents Logical Implication (P => Q).
|
|
48
59
|
if: {
|
|
49
|
-
gwta: `if {
|
|
50
|
-
action: async ({
|
|
51
|
-
const
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
if (!whenResult.ok)
|
|
60
|
+
gwta: `if {ifStatements:${DOMAIN_STATEMENT}}, {thenStatements:${DOMAIN_STATEMENT}}`,
|
|
61
|
+
action: async ({ ifStatements, thenStatements }, featureStep) => {
|
|
62
|
+
const ifResult = await executeSubFeatureSteps(featureStep, ifStatements, this.steppers, this.getWorld(), ExecMode.NO_CYCLES, -1);
|
|
63
|
+
// If antecedent fails, the implication is true (vacuously true: F => T/F), so we return OK.
|
|
64
|
+
if (!ifResult.ok) {
|
|
55
65
|
return OK;
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
66
|
+
}
|
|
67
|
+
// 2. Evaluate Consequent (THEN) - use dir=1 for body execution
|
|
68
|
+
const ifThenResult = await executeSubFeatureSteps(featureStep, thenStatements, this.steppers, this.getWorld(), ExecMode.WITH_CYCLES, 1);
|
|
69
|
+
// Consequent must succeed to prove the implication is true (T => T)
|
|
70
|
+
return ifThenResult.ok ? OK : actionNotOK('if antecedent was TRUE, but consequent failed');
|
|
71
|
+
},
|
|
72
|
+
},
|
|
73
|
+
// --- META & UTILITIES ---
|
|
74
|
+
until: {
|
|
75
|
+
gwta: `until {statements:${DOMAIN_STATEMENT}}`,
|
|
76
|
+
action: async ({ statements }, featureStep) => {
|
|
77
|
+
let result;
|
|
78
|
+
do {
|
|
79
|
+
result = await executeSubFeatureSteps(featureStep, statements, this.steppers, this.getWorld(), ExecMode.WITH_CYCLES);
|
|
80
|
+
await sleep(200);
|
|
81
|
+
} while (!result.ok);
|
|
82
|
+
return OK;
|
|
83
|
+
},
|
|
84
|
+
},
|
|
85
|
+
backgrounds: {
|
|
86
|
+
gwta: 'Backgrounds: {names}',
|
|
87
|
+
resolveFeatureLine: (line, _path, _stepper, backgrounds) => {
|
|
88
|
+
if (!line.match(/^Backgrounds:\s*/i)) {
|
|
89
|
+
return false;
|
|
90
|
+
}
|
|
91
|
+
const names = line.replace(/^Backgrounds:\s*/i, '').trim();
|
|
92
|
+
const bgNames = names.split(',').map((a) => a.trim());
|
|
93
|
+
for (const bgName of bgNames) {
|
|
94
|
+
const bg = findFeatures(bgName, backgrounds);
|
|
95
|
+
if (bg.length !== 1) {
|
|
96
|
+
throw new Error(`can't find single "${bgName}.feature" from ${backgrounds.map((b) => b.path).join(', ')}`);
|
|
65
97
|
}
|
|
66
98
|
}
|
|
67
|
-
return
|
|
99
|
+
return false; // Don't skip - still needs to execute normally
|
|
100
|
+
},
|
|
101
|
+
action: async ({ names }, featureStep) => {
|
|
102
|
+
// Expand backgrounds at runtime using world.runtime.backgrounds
|
|
103
|
+
const world = this.getWorld();
|
|
104
|
+
const expanded = findFeatureStepsFromStatement(names, this.steppers, world, featureStep.path, featureStep.seqPath, 1);
|
|
105
|
+
const result = await executeSubFeatureSteps(featureStep, expanded, this.steppers, world, ExecMode.WITH_CYCLES);
|
|
106
|
+
return result.ok ? OK : actionNotOK('backgrounds failed');
|
|
68
107
|
},
|
|
69
108
|
},
|
|
109
|
+
nothing: {
|
|
110
|
+
exact: '',
|
|
111
|
+
action: () => OK,
|
|
112
|
+
},
|
|
113
|
+
prose: {
|
|
114
|
+
match: /.+[.!?]$/,
|
|
115
|
+
fallback: true,
|
|
116
|
+
action: () => OK,
|
|
117
|
+
},
|
|
118
|
+
feature: {
|
|
119
|
+
gwta: 'Feature: {feature}',
|
|
120
|
+
action: ({ feature }) => {
|
|
121
|
+
this.getWorld().runtime.feature = feature;
|
|
122
|
+
return OK;
|
|
123
|
+
}
|
|
124
|
+
},
|
|
125
|
+
scenario: {
|
|
126
|
+
gwta: 'Scenario: {scenario}',
|
|
127
|
+
action: ({ scenario }) => {
|
|
128
|
+
this.getWorld().runtime.scenario = scenario;
|
|
129
|
+
return OK;
|
|
130
|
+
}
|
|
131
|
+
},
|
|
70
132
|
startStepDelay: {
|
|
71
133
|
gwta: 'step delay of {ms:number}ms',
|
|
72
|
-
action: ({ ms }) => {
|
|
134
|
+
action: (({ ms }) => {
|
|
73
135
|
this.getWorld().options[STEP_DELAY] = ms;
|
|
74
136
|
return OK;
|
|
75
|
-
},
|
|
137
|
+
}),
|
|
76
138
|
},
|
|
77
139
|
endsWith: {
|
|
78
140
|
gwta: 'ends with {result}',
|
|
79
|
-
action: ({ result }) => (
|
|
80
|
-
checkAction: ({ result }) => {
|
|
81
|
-
if (['OK', 'NOT OK'].includes((result.toUpperCase())))
|
|
82
|
-
return true;
|
|
83
|
-
throw Error('must be "OK" or "not OK"');
|
|
84
|
-
}
|
|
141
|
+
action: (({ result }) => (result.toUpperCase() === 'OK' ? actionOK({ messageContext: endExecutonContext }) : actionNotOK('ends with not ok'))),
|
|
85
142
|
},
|
|
86
|
-
|
|
143
|
+
showSteppers: {
|
|
87
144
|
exact: 'show steppers',
|
|
88
145
|
action: () => {
|
|
89
146
|
const allSteppers = formattedSteppers(this.steppers);
|
|
@@ -91,15 +148,31 @@ class Haibun extends AStepper {
|
|
|
91
148
|
return actionOK({ messageContext: { incident: EExecutionMessageType.ACTION, incidentDetails: { steppers: allSteppers } } });
|
|
92
149
|
},
|
|
93
150
|
},
|
|
94
|
-
|
|
95
|
-
gwta: '
|
|
96
|
-
action:
|
|
97
|
-
|
|
98
|
-
|
|
151
|
+
showSteps: {
|
|
152
|
+
gwta: 'show step results',
|
|
153
|
+
action: () => {
|
|
154
|
+
const steps = this.getWorld().runtime.stepResults;
|
|
155
|
+
this.world?.logger.info(`Steps: ${JSON.stringify(steps, null, 2)}`);
|
|
156
|
+
return actionOK({ messageContext: { incident: EExecutionMessageType.ACTION, incidentDetails: { steps } } });
|
|
157
|
+
}
|
|
158
|
+
},
|
|
159
|
+
showFeatures: {
|
|
160
|
+
gwta: 'show features',
|
|
161
|
+
action: () => {
|
|
162
|
+
this.world?.logger.info(`Features: ${JSON.stringify(this.resolvedFeature, null, 2)}`);
|
|
163
|
+
return actionOK({ messageContext: { incident: EExecutionMessageType.ACTION, incidentDetails: { features: this.resolvedFeature } } });
|
|
164
|
+
}
|
|
165
|
+
},
|
|
166
|
+
showBackgrounds: {
|
|
167
|
+
gwta: 'show backgrounds',
|
|
168
|
+
action: () => {
|
|
169
|
+
this.world?.logger.info(`Backgrounds: ${JSON.stringify(this.getWorld().runtime.backgrounds, null, 2)}`);
|
|
170
|
+
return actionOK({ messageContext: { incident: EExecutionMessageType.ACTION, incidentDetails: { backgrounds: this.getWorld().runtime.backgrounds } } });
|
|
171
|
+
}
|
|
99
172
|
},
|
|
100
173
|
pauseSeconds: {
|
|
101
174
|
gwta: 'pause for {ms:number}s',
|
|
102
|
-
action: async ({ ms }) => { await sleep(ms * 1000); return OK; },
|
|
175
|
+
action: (async ({ ms }) => { await sleep(ms * 1000); return OK; }),
|
|
103
176
|
},
|
|
104
177
|
showDomains: {
|
|
105
178
|
gwta: 'show domains',
|
|
@@ -113,24 +186,14 @@ class Haibun extends AStepper {
|
|
|
113
186
|
action: () => OK,
|
|
114
187
|
},
|
|
115
188
|
afterEveryStepper: {
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
const newFeatureStep = await this.newFeatureFromEffect(String(line), currentFeatureStep.seqPath, steppers);
|
|
122
|
-
newSteps.push(newFeatureStep);
|
|
123
|
-
}
|
|
124
|
-
return newSteps;
|
|
189
|
+
precludes: [`Haibun.prose`],
|
|
190
|
+
gwta: `after every {stepperName: string}, {statement: ${DOMAIN_STATEMENT}}`,
|
|
191
|
+
action: ({ stepperName, statement }) => {
|
|
192
|
+
this.afterEverySteps[stepperName] = statement;
|
|
193
|
+
return OK;
|
|
125
194
|
},
|
|
126
195
|
},
|
|
127
196
|
};
|
|
128
|
-
async newFeatureFromEffect(content, parentSeqPath, steppers) {
|
|
129
|
-
const features = asFeatures([{ path: `resolved from ${content}`, content }]);
|
|
130
|
-
const expandedFeatures = await expand({ backgrounds: [], features });
|
|
131
|
-
const featureSteps = await new Resolver(steppers).findFeatureSteps(expandedFeatures[0]);
|
|
132
|
-
return { ...featureSteps[0], seqPath: [...parentSeqPath, 1] };
|
|
133
|
-
}
|
|
134
197
|
}
|
|
135
198
|
export default Haibun;
|
|
136
199
|
//# sourceMappingURL=haibun.js.map
|