@manifesto-ai/core 0.3.0 → 1.3.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/README.md +148 -498
- package/dist/__tests__/apply.test.d.ts +2 -0
- package/dist/__tests__/apply.test.d.ts.map +1 -0
- package/dist/__tests__/apply.test.js +144 -0
- package/dist/__tests__/apply.test.js.map +1 -0
- package/dist/__tests__/jcs.test.d.ts +2 -0
- package/dist/__tests__/jcs.test.d.ts.map +1 -0
- package/dist/__tests__/jcs.test.js +45 -0
- package/dist/__tests__/jcs.test.js.map +1 -0
- package/dist/core/apply.d.ts +17 -0
- package/dist/core/apply.d.ts.map +1 -0
- package/dist/core/apply.js +130 -0
- package/dist/core/apply.js.map +1 -0
- package/dist/core/compute.d.ts +17 -0
- package/dist/core/compute.d.ts.map +1 -0
- package/dist/core/compute.js +287 -0
- package/dist/core/compute.js.map +1 -0
- package/dist/core/compute.test.d.ts +2 -0
- package/dist/core/compute.test.d.ts.map +1 -0
- package/dist/core/compute.test.js +633 -0
- package/dist/core/compute.test.js.map +1 -0
- package/dist/core/explain.d.ts +14 -0
- package/dist/core/explain.d.ts.map +1 -0
- package/dist/core/explain.js +78 -0
- package/dist/core/explain.js.map +1 -0
- package/dist/core/index.d.ts +5 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +5 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/validate.d.ts +16 -0
- package/dist/core/validate.d.ts.map +1 -0
- package/dist/core/validate.js +361 -0
- package/dist/core/validate.js.map +1 -0
- package/dist/core/validate.test.d.ts +2 -0
- package/dist/core/validate.test.d.ts.map +1 -0
- package/dist/core/validate.test.js +638 -0
- package/dist/core/validate.test.js.map +1 -0
- package/dist/core/validation-utils.d.ts +20 -0
- package/dist/core/validation-utils.d.ts.map +1 -0
- package/dist/core/validation-utils.js +289 -0
- package/dist/core/validation-utils.js.map +1 -0
- package/dist/errors.d.ts +30 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/errors.js +51 -0
- package/dist/errors.js.map +1 -0
- package/dist/evaluator/computed.d.ts +14 -0
- package/dist/evaluator/computed.d.ts.map +1 -0
- package/dist/evaluator/computed.js +60 -0
- package/dist/evaluator/computed.js.map +1 -0
- package/dist/evaluator/context.d.ts +59 -0
- package/dist/evaluator/context.d.ts.map +1 -0
- package/dist/evaluator/context.js +41 -0
- package/dist/evaluator/context.js.map +1 -0
- package/dist/evaluator/dag.d.ts +30 -0
- package/dist/evaluator/dag.d.ts.map +1 -0
- package/dist/evaluator/dag.js +121 -0
- package/dist/evaluator/dag.js.map +1 -0
- package/dist/evaluator/expr.d.ts +11 -0
- package/dist/evaluator/expr.d.ts.map +1 -0
- package/dist/evaluator/expr.js +649 -0
- package/dist/evaluator/expr.js.map +1 -0
- package/dist/evaluator/expr.test.d.ts +2 -0
- package/dist/evaluator/expr.test.d.ts.map +1 -0
- package/dist/evaluator/expr.test.js +449 -0
- package/dist/evaluator/expr.test.js.map +1 -0
- package/dist/evaluator/flow.d.ts +35 -0
- package/dist/evaluator/flow.d.ts.map +1 -0
- package/dist/evaluator/flow.js +387 -0
- package/dist/evaluator/flow.js.map +1 -0
- package/dist/evaluator/flow.test.d.ts +2 -0
- package/dist/evaluator/flow.test.d.ts.map +1 -0
- package/dist/evaluator/flow.test.js +499 -0
- package/dist/evaluator/flow.test.js.map +1 -0
- package/dist/evaluator/index.d.ts +6 -0
- package/dist/evaluator/index.d.ts.map +1 -0
- package/dist/evaluator/index.js +6 -0
- package/dist/evaluator/index.js.map +1 -0
- package/dist/factories.d.ts +22 -0
- package/dist/factories.d.ts.map +1 -0
- package/dist/factories.js +44 -0
- package/dist/factories.js.map +1 -0
- package/dist/index.d.ts +47 -11
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +30 -45
- package/dist/index.js.map +1 -1
- package/dist/index.test.d.ts +2 -0
- package/dist/index.test.d.ts.map +1 -0
- package/dist/index.test.js +13 -0
- package/dist/index.test.js.map +1 -0
- package/dist/schema/action.d.ts +14 -0
- package/dist/schema/action.d.ts.map +1 -0
- package/dist/schema/action.js +30 -0
- package/dist/schema/action.js.map +1 -0
- package/dist/schema/common.d.ts +37 -0
- package/dist/schema/common.d.ts.map +1 -0
- package/dist/schema/common.js +20 -0
- package/dist/schema/common.js.map +1 -0
- package/dist/schema/computed.d.ts +23 -0
- package/dist/schema/computed.d.ts.map +1 -0
- package/dist/schema/computed.js +34 -0
- package/dist/schema/computed.js.map +1 -0
- package/dist/schema/domain.d.ts +50 -0
- package/dist/schema/domain.d.ts.map +1 -0
- package/dist/schema/domain.js +60 -0
- package/dist/schema/domain.js.map +1 -0
- package/dist/schema/expr.d.ts +303 -0
- package/dist/schema/expr.d.ts.map +1 -0
- package/dist/schema/expr.js +283 -0
- package/dist/schema/expr.js.map +1 -0
- package/dist/schema/field.d.ts +48 -0
- package/dist/schema/field.d.ts.map +1 -0
- package/dist/schema/field.js +31 -0
- package/dist/schema/field.js.map +1 -0
- package/dist/schema/flow.d.ts +103 -0
- package/dist/schema/flow.d.ts.map +1 -0
- package/dist/schema/flow.js +82 -0
- package/dist/schema/flow.js.map +1 -0
- package/dist/schema/host-context.d.ts +12 -0
- package/dist/schema/host-context.d.ts.map +1 -0
- package/dist/schema/host-context.js +23 -0
- package/dist/schema/host-context.js.map +1 -0
- package/dist/schema/index.d.ts +13 -2
- package/dist/schema/index.d.ts.map +1 -1
- package/dist/schema/index.js +25 -2
- package/dist/schema/index.js.map +1 -1
- package/dist/schema/patch.d.ts +59 -0
- package/dist/schema/patch.d.ts.map +1 -0
- package/dist/schema/patch.js +60 -0
- package/dist/schema/patch.js.map +1 -0
- package/dist/schema/result.d.ts +142 -0
- package/dist/schema/result.d.ts.map +1 -0
- package/dist/schema/result.js +94 -0
- package/dist/schema/result.js.map +1 -0
- package/dist/schema/snapshot.d.ts +153 -0
- package/dist/schema/snapshot.d.ts.map +1 -0
- package/dist/schema/snapshot.js +160 -0
- package/dist/schema/snapshot.js.map +1 -0
- package/dist/schema/trace.d.ts +98 -0
- package/dist/schema/trace.d.ts.map +1 -0
- package/dist/schema/trace.js +90 -0
- package/dist/schema/trace.js.map +1 -0
- package/dist/schema/type-spec.d.ts +34 -0
- package/dist/schema/type-spec.d.ts.map +1 -0
- package/dist/schema/type-spec.js +40 -0
- package/dist/schema/type-spec.js.map +1 -0
- package/dist/utils/canonical.d.ts +37 -0
- package/dist/utils/canonical.d.ts.map +1 -0
- package/dist/utils/canonical.js +122 -0
- package/dist/utils/canonical.js.map +1 -0
- package/dist/utils/canonical.test.d.ts +2 -0
- package/dist/utils/canonical.test.d.ts.map +1 -0
- package/dist/utils/canonical.test.js +183 -0
- package/dist/utils/canonical.test.js.map +1 -0
- package/dist/utils/hash.d.ts +28 -0
- package/dist/utils/hash.d.ts.map +1 -0
- package/dist/utils/hash.js +152 -0
- package/dist/utils/hash.js.map +1 -0
- package/dist/utils/hash.test.d.ts +2 -0
- package/dist/utils/hash.test.d.ts.map +1 -0
- package/dist/utils/hash.test.js +170 -0
- package/dist/utils/hash.test.js.map +1 -0
- package/dist/utils/index.d.ts +4 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +4 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/path.d.ts +40 -0
- package/dist/utils/path.d.ts.map +1 -0
- package/dist/utils/path.js +132 -0
- package/dist/utils/path.js.map +1 -0
- package/dist/utils/path.test.d.ts +2 -0
- package/dist/utils/path.test.d.ts.map +1 -0
- package/dist/utils/path.test.js +191 -0
- package/dist/utils/path.test.js.map +1 -0
- package/package.json +28 -41
- package/LICENSE +0 -21
- package/dist/dag/graph.d.ts +0 -62
- package/dist/dag/graph.d.ts.map +0 -1
- package/dist/dag/graph.js +0 -244
- package/dist/dag/graph.js.map +0 -1
- package/dist/dag/index.d.ts +0 -4
- package/dist/dag/index.d.ts.map +0 -1
- package/dist/dag/index.js +0 -4
- package/dist/dag/index.js.map +0 -1
- package/dist/dag/propagation.d.ts +0 -58
- package/dist/dag/propagation.d.ts.map +0 -1
- package/dist/dag/propagation.js +0 -224
- package/dist/dag/propagation.js.map +0 -1
- package/dist/dag/topological.d.ts +0 -33
- package/dist/dag/topological.d.ts.map +0 -1
- package/dist/dag/topological.js +0 -173
- package/dist/dag/topological.js.map +0 -1
- package/dist/domain/define.d.ts +0 -82
- package/dist/domain/define.d.ts.map +0 -1
- package/dist/domain/define.js +0 -105
- package/dist/domain/define.js.map +0 -1
- package/dist/domain/index.d.ts +0 -4
- package/dist/domain/index.d.ts.map +0 -1
- package/dist/domain/index.js +0 -4
- package/dist/domain/index.js.map +0 -1
- package/dist/domain/types.d.ts +0 -203
- package/dist/domain/types.d.ts.map +0 -1
- package/dist/domain/types.js +0 -2
- package/dist/domain/types.js.map +0 -1
- package/dist/domain/validate.d.ts +0 -17
- package/dist/domain/validate.d.ts.map +0 -1
- package/dist/domain/validate.js +0 -204
- package/dist/domain/validate.js.map +0 -1
- package/dist/effect/index.d.ts +0 -4
- package/dist/effect/index.d.ts.map +0 -1
- package/dist/effect/index.js +0 -4
- package/dist/effect/index.js.map +0 -1
- package/dist/effect/result.d.ts +0 -100
- package/dist/effect/result.d.ts.map +0 -1
- package/dist/effect/result.js +0 -163
- package/dist/effect/result.js.map +0 -1
- package/dist/effect/runner.d.ts +0 -98
- package/dist/effect/runner.d.ts.map +0 -1
- package/dist/effect/runner.js +0 -321
- package/dist/effect/runner.js.map +0 -1
- package/dist/effect/types.d.ts +0 -169
- package/dist/effect/types.d.ts.map +0 -1
- package/dist/effect/types.js +0 -28
- package/dist/effect/types.js.map +0 -1
- package/dist/expression/analyzer.d.ts +0 -42
- package/dist/expression/analyzer.d.ts.map +0 -1
- package/dist/expression/analyzer.js +0 -166
- package/dist/expression/analyzer.js.map +0 -1
- package/dist/expression/evaluator.d.ts +0 -16
- package/dist/expression/evaluator.d.ts.map +0 -1
- package/dist/expression/evaluator.js +0 -382
- package/dist/expression/evaluator.js.map +0 -1
- package/dist/expression/index.d.ts +0 -5
- package/dist/expression/index.d.ts.map +0 -1
- package/dist/expression/index.js +0 -5
- package/dist/expression/index.js.map +0 -1
- package/dist/expression/parser.d.ts +0 -37
- package/dist/expression/parser.d.ts.map +0 -1
- package/dist/expression/parser.js +0 -201
- package/dist/expression/parser.js.map +0 -1
- package/dist/expression/types.d.ts +0 -123
- package/dist/expression/types.d.ts.map +0 -1
- package/dist/expression/types.js +0 -10
- package/dist/expression/types.js.map +0 -1
- package/dist/policy/field-policy.d.ts +0 -63
- package/dist/policy/field-policy.d.ts.map +0 -1
- package/dist/policy/field-policy.js +0 -138
- package/dist/policy/field-policy.js.map +0 -1
- package/dist/policy/index.d.ts +0 -3
- package/dist/policy/index.d.ts.map +0 -1
- package/dist/policy/index.js +0 -3
- package/dist/policy/index.js.map +0 -1
- package/dist/policy/precondition.d.ts +0 -58
- package/dist/policy/precondition.d.ts.map +0 -1
- package/dist/policy/precondition.js +0 -115
- package/dist/policy/precondition.js.map +0 -1
- package/dist/runtime/index.d.ts +0 -4
- package/dist/runtime/index.d.ts.map +0 -1
- package/dist/runtime/index.js +0 -4
- package/dist/runtime/index.js.map +0 -1
- package/dist/runtime/runtime.d.ts +0 -94
- package/dist/runtime/runtime.d.ts.map +0 -1
- package/dist/runtime/runtime.js +0 -294
- package/dist/runtime/runtime.js.map +0 -1
- package/dist/runtime/snapshot.d.ts +0 -39
- package/dist/runtime/snapshot.d.ts.map +0 -1
- package/dist/runtime/snapshot.js +0 -264
- package/dist/runtime/snapshot.js.map +0 -1
- package/dist/runtime/subscription.d.ts +0 -82
- package/dist/runtime/subscription.d.ts.map +0 -1
- package/dist/runtime/subscription.js +0 -222
- package/dist/runtime/subscription.js.map +0 -1
- package/dist/schema/integration.d.ts +0 -89
- package/dist/schema/integration.d.ts.map +0 -1
- package/dist/schema/integration.js +0 -171
- package/dist/schema/integration.js.map +0 -1
- package/dist/schema/validation.d.ts +0 -51
- package/dist/schema/validation.d.ts.map +0 -1
- package/dist/schema/validation.js +0 -212
- package/dist/schema/validation.js.map +0 -1
package/dist/dag/propagation.js
DELETED
|
@@ -1,224 +0,0 @@
|
|
|
1
|
-
import { evaluate } from '../expression/evaluator.js';
|
|
2
|
-
import { getAffectedOrder } from './topological.js';
|
|
3
|
-
/**
|
|
4
|
-
* 변경 전파
|
|
5
|
-
*/
|
|
6
|
-
export function propagate(graph, changedPaths, snapshot) {
|
|
7
|
-
const changes = new Map();
|
|
8
|
-
const pendingEffects = [];
|
|
9
|
-
const errors = [];
|
|
10
|
-
// 영향받는 경로들을 위상 정렬 순서로 가져옴
|
|
11
|
-
const affectedOrder = getAffectedOrder(graph, changedPaths);
|
|
12
|
-
// 평가 컨텍스트 생성
|
|
13
|
-
const ctx = {
|
|
14
|
-
get: (path) => {
|
|
15
|
-
// 이미 변경된 값이 있으면 그것을 반환
|
|
16
|
-
if (changes.has(path)) {
|
|
17
|
-
return changes.get(path);
|
|
18
|
-
}
|
|
19
|
-
return snapshot.get(path);
|
|
20
|
-
},
|
|
21
|
-
};
|
|
22
|
-
// 순서대로 재계산
|
|
23
|
-
for (const path of affectedOrder) {
|
|
24
|
-
const node = graph.nodes.get(path);
|
|
25
|
-
if (!node)
|
|
26
|
-
continue;
|
|
27
|
-
try {
|
|
28
|
-
switch (node.kind) {
|
|
29
|
-
case 'source':
|
|
30
|
-
// Source는 외부 입력이므로 여기서 계산하지 않음
|
|
31
|
-
// 하지만 변경된 경로에 포함되어 있으면 changes에 기록
|
|
32
|
-
if (changedPaths.includes(path)) {
|
|
33
|
-
changes.set(path, snapshot.get(path));
|
|
34
|
-
}
|
|
35
|
-
break;
|
|
36
|
-
case 'derived':
|
|
37
|
-
// Expression 평가
|
|
38
|
-
const derivedResult = evaluate(node.definition.expr, ctx);
|
|
39
|
-
if (derivedResult.ok) {
|
|
40
|
-
const oldValue = snapshot.get(path);
|
|
41
|
-
const newValue = derivedResult.value;
|
|
42
|
-
if (!deepEqual(oldValue, newValue)) {
|
|
43
|
-
changes.set(path, newValue);
|
|
44
|
-
snapshot.set(path, newValue);
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
else {
|
|
48
|
-
errors.push({ path, error: derivedResult.error });
|
|
49
|
-
}
|
|
50
|
-
break;
|
|
51
|
-
case 'async':
|
|
52
|
-
// 조건 평가
|
|
53
|
-
let shouldTrigger = true;
|
|
54
|
-
if (node.definition.condition) {
|
|
55
|
-
const condResult = evaluate(node.definition.condition, ctx);
|
|
56
|
-
if (condResult.ok) {
|
|
57
|
-
shouldTrigger = Boolean(condResult.value);
|
|
58
|
-
}
|
|
59
|
-
else {
|
|
60
|
-
errors.push({ path, error: condResult.error });
|
|
61
|
-
shouldTrigger = false;
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
if (shouldTrigger) {
|
|
65
|
-
pendingEffects.push({
|
|
66
|
-
path,
|
|
67
|
-
effect: node.definition.effect,
|
|
68
|
-
});
|
|
69
|
-
// 로딩 상태 업데이트
|
|
70
|
-
changes.set(node.definition.loadingPath, true);
|
|
71
|
-
snapshot.set(node.definition.loadingPath, true);
|
|
72
|
-
}
|
|
73
|
-
break;
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
catch (e) {
|
|
77
|
-
errors.push({
|
|
78
|
-
path,
|
|
79
|
-
error: e instanceof Error ? e.message : String(e),
|
|
80
|
-
});
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
return { changes, pendingEffects, errors };
|
|
84
|
-
}
|
|
85
|
-
/**
|
|
86
|
-
* Async Effect 완료 후 결과 전파
|
|
87
|
-
*/
|
|
88
|
-
export function propagateAsyncResult(graph, asyncPath, result, snapshot) {
|
|
89
|
-
const node = graph.nodes.get(asyncPath);
|
|
90
|
-
if (!node || node.kind !== 'async') {
|
|
91
|
-
return { changes: new Map(), pendingEffects: [], errors: [] };
|
|
92
|
-
}
|
|
93
|
-
const changes = new Map();
|
|
94
|
-
const definition = node.definition;
|
|
95
|
-
// 로딩 상태 해제
|
|
96
|
-
changes.set(definition.loadingPath, false);
|
|
97
|
-
snapshot.set(definition.loadingPath, false);
|
|
98
|
-
if (result.ok) {
|
|
99
|
-
// 결과 저장
|
|
100
|
-
changes.set(definition.resultPath, result.value);
|
|
101
|
-
snapshot.set(definition.resultPath, result.value);
|
|
102
|
-
// 에러 클리어
|
|
103
|
-
changes.set(definition.errorPath, null);
|
|
104
|
-
snapshot.set(definition.errorPath, null);
|
|
105
|
-
}
|
|
106
|
-
else {
|
|
107
|
-
// 에러 저장
|
|
108
|
-
changes.set(definition.errorPath, result.error);
|
|
109
|
-
snapshot.set(definition.errorPath, result.error);
|
|
110
|
-
}
|
|
111
|
-
// 결과로 인한 추가 전파
|
|
112
|
-
const resultPaths = [definition.resultPath, definition.loadingPath, definition.errorPath];
|
|
113
|
-
const furtherPropagation = propagate(graph, resultPaths, snapshot);
|
|
114
|
-
// 병합
|
|
115
|
-
for (const [path, value] of furtherPropagation.changes) {
|
|
116
|
-
changes.set(path, value);
|
|
117
|
-
}
|
|
118
|
-
return {
|
|
119
|
-
changes,
|
|
120
|
-
pendingEffects: furtherPropagation.pendingEffects,
|
|
121
|
-
errors: furtherPropagation.errors,
|
|
122
|
-
};
|
|
123
|
-
}
|
|
124
|
-
/**
|
|
125
|
-
* 특정 경로 변경 시 영향 분석
|
|
126
|
-
*/
|
|
127
|
-
export function analyzeImpact(graph, path) {
|
|
128
|
-
const affectedOrder = getAffectedOrder(graph, [path]);
|
|
129
|
-
const affectedNodes = [];
|
|
130
|
-
const asyncTriggers = [];
|
|
131
|
-
for (const affectedPath of affectedOrder) {
|
|
132
|
-
const node = graph.nodes.get(affectedPath);
|
|
133
|
-
if (node) {
|
|
134
|
-
affectedNodes.push(node);
|
|
135
|
-
if (node.kind === 'async') {
|
|
136
|
-
asyncTriggers.push(affectedPath);
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
return {
|
|
141
|
-
affectedPaths: affectedOrder,
|
|
142
|
-
affectedNodes,
|
|
143
|
-
asyncTriggers,
|
|
144
|
-
};
|
|
145
|
-
}
|
|
146
|
-
/**
|
|
147
|
-
* 깊은 동등성 비교 (간단한 구현)
|
|
148
|
-
*/
|
|
149
|
-
function deepEqual(a, b) {
|
|
150
|
-
if (a === b)
|
|
151
|
-
return true;
|
|
152
|
-
if (a === null || b === null)
|
|
153
|
-
return a === b;
|
|
154
|
-
if (typeof a !== typeof b)
|
|
155
|
-
return false;
|
|
156
|
-
if (typeof a !== 'object')
|
|
157
|
-
return a === b;
|
|
158
|
-
if (Array.isArray(a) && Array.isArray(b)) {
|
|
159
|
-
if (a.length !== b.length)
|
|
160
|
-
return false;
|
|
161
|
-
for (let i = 0; i < a.length; i++) {
|
|
162
|
-
if (!deepEqual(a[i], b[i]))
|
|
163
|
-
return false;
|
|
164
|
-
}
|
|
165
|
-
return true;
|
|
166
|
-
}
|
|
167
|
-
if (Array.isArray(a) || Array.isArray(b))
|
|
168
|
-
return false;
|
|
169
|
-
const aKeys = Object.keys(a);
|
|
170
|
-
const bKeys = Object.keys(b);
|
|
171
|
-
if (aKeys.length !== bKeys.length)
|
|
172
|
-
return false;
|
|
173
|
-
for (const key of aKeys) {
|
|
174
|
-
if (!deepEqual(a[key], b[key])) {
|
|
175
|
-
return false;
|
|
176
|
-
}
|
|
177
|
-
}
|
|
178
|
-
return true;
|
|
179
|
-
}
|
|
180
|
-
/**
|
|
181
|
-
* 디바운스된 전파를 위한 유틸리티
|
|
182
|
-
*/
|
|
183
|
-
export function createDebouncedPropagator(graph, snapshot, debounceMs) {
|
|
184
|
-
let pendingPaths = new Set();
|
|
185
|
-
let timeoutId = null;
|
|
186
|
-
let lastResult = {
|
|
187
|
-
changes: new Map(),
|
|
188
|
-
pendingEffects: [],
|
|
189
|
-
errors: [],
|
|
190
|
-
};
|
|
191
|
-
return {
|
|
192
|
-
queue(paths) {
|
|
193
|
-
for (const path of paths) {
|
|
194
|
-
pendingPaths.add(path);
|
|
195
|
-
}
|
|
196
|
-
if (timeoutId) {
|
|
197
|
-
clearTimeout(timeoutId);
|
|
198
|
-
}
|
|
199
|
-
timeoutId = setTimeout(() => {
|
|
200
|
-
this.flush();
|
|
201
|
-
}, debounceMs);
|
|
202
|
-
},
|
|
203
|
-
flush() {
|
|
204
|
-
if (timeoutId) {
|
|
205
|
-
clearTimeout(timeoutId);
|
|
206
|
-
timeoutId = null;
|
|
207
|
-
}
|
|
208
|
-
if (pendingPaths.size === 0) {
|
|
209
|
-
return lastResult;
|
|
210
|
-
}
|
|
211
|
-
lastResult = propagate(graph, [...pendingPaths], snapshot);
|
|
212
|
-
pendingPaths = new Set();
|
|
213
|
-
return lastResult;
|
|
214
|
-
},
|
|
215
|
-
cancel() {
|
|
216
|
-
if (timeoutId) {
|
|
217
|
-
clearTimeout(timeoutId);
|
|
218
|
-
timeoutId = null;
|
|
219
|
-
}
|
|
220
|
-
pendingPaths = new Set();
|
|
221
|
-
},
|
|
222
|
-
};
|
|
223
|
-
}
|
|
224
|
-
//# sourceMappingURL=propagation.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"propagation.js","sourceRoot":"","sources":["../../src/dag/propagation.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
import type { SemanticPath } from '../domain/types.js';
|
|
2
|
-
import type { DependencyGraph } from './graph.js';
|
|
3
|
-
/**
|
|
4
|
-
* 위상 정렬 결과
|
|
5
|
-
*/
|
|
6
|
-
export type TopologicalSortResult = {
|
|
7
|
-
ok: true;
|
|
8
|
-
order: SemanticPath[];
|
|
9
|
-
} | {
|
|
10
|
-
ok: false;
|
|
11
|
-
cycle: SemanticPath[];
|
|
12
|
-
};
|
|
13
|
-
/**
|
|
14
|
-
* 고급 위상 정렬 (순환 탐지 포함)
|
|
15
|
-
*/
|
|
16
|
-
export declare function topologicalSortWithCycleDetection(graph: DependencyGraph): TopologicalSortResult;
|
|
17
|
-
/**
|
|
18
|
-
* 레벨별 정렬 (같은 레벨의 노드들은 병렬 처리 가능)
|
|
19
|
-
*/
|
|
20
|
-
export declare function getLevelOrder(graph: DependencyGraph): SemanticPath[][];
|
|
21
|
-
/**
|
|
22
|
-
* 역방향 위상 정렬 (리프부터 루트로)
|
|
23
|
-
*/
|
|
24
|
-
export declare function reverseTopologicalSort(graph: DependencyGraph): SemanticPath[];
|
|
25
|
-
/**
|
|
26
|
-
* 부분 그래프의 위상 정렬
|
|
27
|
-
*/
|
|
28
|
-
export declare function partialTopologicalSort(graph: DependencyGraph, paths: SemanticPath[]): SemanticPath[];
|
|
29
|
-
/**
|
|
30
|
-
* 변경된 경로들의 영향을 받는 경로들의 위상 정렬된 순서
|
|
31
|
-
*/
|
|
32
|
-
export declare function getAffectedOrder(graph: DependencyGraph, changedPaths: SemanticPath[]): SemanticPath[];
|
|
33
|
-
//# sourceMappingURL=topological.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"topological.d.ts","sourceRoot":"","sources":["../../src/dag/topological.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAElD;;GAEG;AACH,MAAM,MAAM,qBAAqB,GAC7B;IAAE,EAAE,EAAE,IAAI,CAAC;IAAC,KAAK,EAAE,YAAY,EAAE,CAAA;CAAE,GACnC;IAAE,EAAE,EAAE,KAAK,CAAC;IAAC,KAAK,EAAE,YAAY,EAAE,CAAA;CAAE,CAAC;AAEzC;;GAEG;AACH,wBAAgB,iCAAiC,CAC/C,KAAK,EAAE,eAAe,GACrB,qBAAqB,CAoDvB;AA0DD;;GAEG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,eAAe,GAAG,YAAY,EAAE,EAAE,CAyCtE;AAED;;GAEG;AACH,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,eAAe,GAAG,YAAY,EAAE,CAE7E;AAED;;GAEG;AACH,wBAAgB,sBAAsB,CACpC,KAAK,EAAE,eAAe,EACtB,KAAK,EAAE,YAAY,EAAE,GACpB,YAAY,EAAE,CAGhB;AAED;;GAEG;AACH,wBAAgB,gBAAgB,CAC9B,KAAK,EAAE,eAAe,EACtB,YAAY,EAAE,YAAY,EAAE,GAC3B,YAAY,EAAE,CAsBhB"}
|
package/dist/dag/topological.js
DELETED
|
@@ -1,173 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* 고급 위상 정렬 (순환 탐지 포함)
|
|
3
|
-
*/
|
|
4
|
-
export function topologicalSortWithCycleDetection(graph) {
|
|
5
|
-
const inDegree = new Map();
|
|
6
|
-
const result = [];
|
|
7
|
-
// 진입 차수 초기화
|
|
8
|
-
for (const path of graph.nodes.keys()) {
|
|
9
|
-
inDegree.set(path, 0);
|
|
10
|
-
}
|
|
11
|
-
// 진입 차수 계산
|
|
12
|
-
for (const [path, deps] of graph.dependencies) {
|
|
13
|
-
let count = 0;
|
|
14
|
-
for (const dep of deps) {
|
|
15
|
-
if (graph.nodes.has(dep)) {
|
|
16
|
-
count++;
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
inDegree.set(path, count);
|
|
20
|
-
}
|
|
21
|
-
// 진입 차수가 0인 노드들로 시작
|
|
22
|
-
const queue = [];
|
|
23
|
-
for (const [path, degree] of inDegree) {
|
|
24
|
-
if (degree === 0) {
|
|
25
|
-
queue.push(path);
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
while (queue.length > 0) {
|
|
29
|
-
const current = queue.shift();
|
|
30
|
-
result.push(current);
|
|
31
|
-
// 현재 노드를 의존하는 노드들의 진입 차수 감소
|
|
32
|
-
const dependents = graph.dependents.get(current);
|
|
33
|
-
if (dependents) {
|
|
34
|
-
for (const dep of dependents) {
|
|
35
|
-
const newDegree = (inDegree.get(dep) ?? 0) - 1;
|
|
36
|
-
inDegree.set(dep, newDegree);
|
|
37
|
-
if (newDegree === 0) {
|
|
38
|
-
queue.push(dep);
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
// 모든 노드가 포함되지 않았다면 순환이 있음
|
|
44
|
-
if (result.length !== graph.nodes.size) {
|
|
45
|
-
const cycle = findCycleNodes(graph, inDegree);
|
|
46
|
-
return { ok: false, cycle };
|
|
47
|
-
}
|
|
48
|
-
return { ok: true, order: result };
|
|
49
|
-
}
|
|
50
|
-
/**
|
|
51
|
-
* 순환에 포함된 노드 찾기
|
|
52
|
-
*/
|
|
53
|
-
function findCycleNodes(graph, inDegree) {
|
|
54
|
-
const cycleNodes = [];
|
|
55
|
-
for (const [path, degree] of inDegree) {
|
|
56
|
-
if (degree > 0) {
|
|
57
|
-
cycleNodes.push(path);
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
// DFS로 실제 순환 경로 찾기
|
|
61
|
-
if (cycleNodes.length > 0) {
|
|
62
|
-
const visited = new Set();
|
|
63
|
-
const recursionStack = [];
|
|
64
|
-
const pathSet = new Set();
|
|
65
|
-
function dfs(node) {
|
|
66
|
-
visited.add(node);
|
|
67
|
-
recursionStack.push(node);
|
|
68
|
-
pathSet.add(node);
|
|
69
|
-
const deps = graph.dependencies.get(node);
|
|
70
|
-
if (deps) {
|
|
71
|
-
for (const dep of deps) {
|
|
72
|
-
if (!visited.has(dep)) {
|
|
73
|
-
const cycle = dfs(dep);
|
|
74
|
-
if (cycle)
|
|
75
|
-
return cycle;
|
|
76
|
-
}
|
|
77
|
-
else if (pathSet.has(dep)) {
|
|
78
|
-
// 순환 발견
|
|
79
|
-
const cycleStart = recursionStack.indexOf(dep);
|
|
80
|
-
return recursionStack.slice(cycleStart);
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
recursionStack.pop();
|
|
85
|
-
pathSet.delete(node);
|
|
86
|
-
return null;
|
|
87
|
-
}
|
|
88
|
-
for (const node of cycleNodes) {
|
|
89
|
-
if (!visited.has(node)) {
|
|
90
|
-
const cycle = dfs(node);
|
|
91
|
-
if (cycle)
|
|
92
|
-
return cycle;
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
return cycleNodes;
|
|
97
|
-
}
|
|
98
|
-
/**
|
|
99
|
-
* 레벨별 정렬 (같은 레벨의 노드들은 병렬 처리 가능)
|
|
100
|
-
*/
|
|
101
|
-
export function getLevelOrder(graph) {
|
|
102
|
-
const levels = [];
|
|
103
|
-
const nodeLevel = new Map();
|
|
104
|
-
// 각 노드의 레벨 계산
|
|
105
|
-
function calculateLevel(path) {
|
|
106
|
-
if (nodeLevel.has(path)) {
|
|
107
|
-
return nodeLevel.get(path);
|
|
108
|
-
}
|
|
109
|
-
const deps = graph.dependencies.get(path);
|
|
110
|
-
if (!deps || deps.size === 0) {
|
|
111
|
-
nodeLevel.set(path, 0);
|
|
112
|
-
return 0;
|
|
113
|
-
}
|
|
114
|
-
let maxDepLevel = -1;
|
|
115
|
-
for (const dep of deps) {
|
|
116
|
-
if (graph.nodes.has(dep)) {
|
|
117
|
-
maxDepLevel = Math.max(maxDepLevel, calculateLevel(dep));
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
const level = maxDepLevel + 1;
|
|
121
|
-
nodeLevel.set(path, level);
|
|
122
|
-
return level;
|
|
123
|
-
}
|
|
124
|
-
for (const path of graph.nodes.keys()) {
|
|
125
|
-
calculateLevel(path);
|
|
126
|
-
}
|
|
127
|
-
// 레벨별로 그룹화
|
|
128
|
-
for (const [path, level] of nodeLevel) {
|
|
129
|
-
while (levels.length <= level) {
|
|
130
|
-
levels.push([]);
|
|
131
|
-
}
|
|
132
|
-
levels[level].push(path);
|
|
133
|
-
}
|
|
134
|
-
return levels;
|
|
135
|
-
}
|
|
136
|
-
/**
|
|
137
|
-
* 역방향 위상 정렬 (리프부터 루트로)
|
|
138
|
-
*/
|
|
139
|
-
export function reverseTopologicalSort(graph) {
|
|
140
|
-
return [...graph.topologicalOrder].reverse();
|
|
141
|
-
}
|
|
142
|
-
/**
|
|
143
|
-
* 부분 그래프의 위상 정렬
|
|
144
|
-
*/
|
|
145
|
-
export function partialTopologicalSort(graph, paths) {
|
|
146
|
-
const pathSet = new Set(paths);
|
|
147
|
-
return graph.topologicalOrder.filter((p) => pathSet.has(p));
|
|
148
|
-
}
|
|
149
|
-
/**
|
|
150
|
-
* 변경된 경로들의 영향을 받는 경로들의 위상 정렬된 순서
|
|
151
|
-
*/
|
|
152
|
-
export function getAffectedOrder(graph, changedPaths) {
|
|
153
|
-
const affected = new Set();
|
|
154
|
-
// BFS로 영향받는 모든 경로 수집
|
|
155
|
-
const queue = [...changedPaths];
|
|
156
|
-
while (queue.length > 0) {
|
|
157
|
-
const current = queue.shift();
|
|
158
|
-
if (affected.has(current))
|
|
159
|
-
continue;
|
|
160
|
-
affected.add(current);
|
|
161
|
-
const dependents = graph.dependents.get(current);
|
|
162
|
-
if (dependents) {
|
|
163
|
-
for (const dep of dependents) {
|
|
164
|
-
if (!affected.has(dep)) {
|
|
165
|
-
queue.push(dep);
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
// 위상 정렬 순서로 필터링
|
|
171
|
-
return graph.topologicalOrder.filter((p) => affected.has(p));
|
|
172
|
-
}
|
|
173
|
-
//# sourceMappingURL=topological.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"topological.js","sourceRoot":"","sources":["../../src/dag/topological.ts"],"names":[],"mappings":"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"}
|
package/dist/domain/define.d.ts
DELETED
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
import type { ZodType } from 'zod';
|
|
2
|
-
import type { ManifestoDomain, PathDefinitions, ActionDefinition, DomainMeta, SourceDefinition, DerivedDefinition, AsyncDefinition, SemanticPath, SemanticMeta, FieldPolicy, ConditionRef, ActionSemanticMeta } from './types.js';
|
|
3
|
-
import type { Expression } from '../expression/types.js';
|
|
4
|
-
import type { Effect } from '../effect/types.js';
|
|
5
|
-
/**
|
|
6
|
-
* Domain 정의 옵션
|
|
7
|
-
*/
|
|
8
|
-
export type DefineDomainOptions<TData, TState> = {
|
|
9
|
-
id: string;
|
|
10
|
-
name: string;
|
|
11
|
-
description: string;
|
|
12
|
-
dataSchema: ZodType<TData>;
|
|
13
|
-
stateSchema: ZodType<TState>;
|
|
14
|
-
initialState: TState;
|
|
15
|
-
paths?: Partial<PathDefinitions<TData, TState>>;
|
|
16
|
-
actions?: Record<string, ActionDefinition>;
|
|
17
|
-
meta?: DomainMeta;
|
|
18
|
-
};
|
|
19
|
-
/**
|
|
20
|
-
* 도메인 정의 헬퍼 함수
|
|
21
|
-
*/
|
|
22
|
-
export declare function defineDomain<TData, TState>(options: DefineDomainOptions<TData, TState>): ManifestoDomain<TData, TState>;
|
|
23
|
-
/**
|
|
24
|
-
* Source 정의 헬퍼
|
|
25
|
-
*/
|
|
26
|
-
export type DefineSourceOptions = {
|
|
27
|
-
schema: ZodType;
|
|
28
|
-
defaultValue?: unknown;
|
|
29
|
-
policy?: FieldPolicy;
|
|
30
|
-
semantic: SemanticMeta;
|
|
31
|
-
};
|
|
32
|
-
export declare function defineSource(options: DefineSourceOptions): SourceDefinition;
|
|
33
|
-
/**
|
|
34
|
-
* Derived 정의 헬퍼
|
|
35
|
-
*/
|
|
36
|
-
export type DefineDerivedOptions = {
|
|
37
|
-
deps: SemanticPath[];
|
|
38
|
-
expr: Expression;
|
|
39
|
-
semantic: SemanticMeta;
|
|
40
|
-
};
|
|
41
|
-
export declare function defineDerived(options: DefineDerivedOptions): DerivedDefinition;
|
|
42
|
-
/**
|
|
43
|
-
* Async 정의 헬퍼
|
|
44
|
-
*/
|
|
45
|
-
export type DefineAsyncOptions = {
|
|
46
|
-
deps: SemanticPath[];
|
|
47
|
-
condition?: Expression;
|
|
48
|
-
debounce?: number;
|
|
49
|
-
effect: Effect;
|
|
50
|
-
resultPath: SemanticPath;
|
|
51
|
-
loadingPath: SemanticPath;
|
|
52
|
-
errorPath: SemanticPath;
|
|
53
|
-
semantic: SemanticMeta;
|
|
54
|
-
};
|
|
55
|
-
export declare function defineAsync(options: DefineAsyncOptions): AsyncDefinition;
|
|
56
|
-
/**
|
|
57
|
-
* Action 정의 헬퍼
|
|
58
|
-
*/
|
|
59
|
-
export type DefineActionOptions = {
|
|
60
|
-
deps: SemanticPath[];
|
|
61
|
-
input?: ZodType;
|
|
62
|
-
effect: Effect;
|
|
63
|
-
preconditions?: ConditionRef[];
|
|
64
|
-
semantic: ActionSemanticMeta;
|
|
65
|
-
};
|
|
66
|
-
export declare function defineAction(options: DefineActionOptions): ActionDefinition;
|
|
67
|
-
/**
|
|
68
|
-
* FieldPolicy 빌더
|
|
69
|
-
*/
|
|
70
|
-
export declare function fieldPolicy(options: {
|
|
71
|
-
relevantWhen?: ConditionRef[];
|
|
72
|
-
editableWhen?: ConditionRef[];
|
|
73
|
-
requiredWhen?: ConditionRef[];
|
|
74
|
-
}): FieldPolicy;
|
|
75
|
-
/**
|
|
76
|
-
* ConditionRef 빌더
|
|
77
|
-
*/
|
|
78
|
-
export declare function condition(path: SemanticPath, options?: {
|
|
79
|
-
expect?: 'true' | 'false';
|
|
80
|
-
reason?: string;
|
|
81
|
-
}): ConditionRef;
|
|
82
|
-
//# sourceMappingURL=define.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"define.d.ts","sourceRoot":"","sources":["../../src/domain/define.ts"],"names":[],"mappings":"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"}
|
package/dist/domain/define.js
DELETED
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Adds namespace prefix to keys if not already present.
|
|
3
|
-
* Supports nested paths (e.g., 'user.name' → 'data.user.name').
|
|
4
|
-
*/
|
|
5
|
-
function prefixKeys(record, prefix) {
|
|
6
|
-
if (!record)
|
|
7
|
-
return {};
|
|
8
|
-
const result = {};
|
|
9
|
-
for (const [key, value] of Object.entries(record)) {
|
|
10
|
-
const prefixedKey = key.startsWith(`${prefix}.`) ? key : `${prefix}.${key}`;
|
|
11
|
-
result[prefixedKey] = value;
|
|
12
|
-
}
|
|
13
|
-
return result;
|
|
14
|
-
}
|
|
15
|
-
/**
|
|
16
|
-
* 도메인 정의 헬퍼 함수
|
|
17
|
-
*/
|
|
18
|
-
export function defineDomain(options) {
|
|
19
|
-
return {
|
|
20
|
-
id: options.id,
|
|
21
|
-
name: options.name,
|
|
22
|
-
description: options.description,
|
|
23
|
-
dataSchema: options.dataSchema,
|
|
24
|
-
stateSchema: options.stateSchema,
|
|
25
|
-
initialState: options.initialState,
|
|
26
|
-
paths: {
|
|
27
|
-
sources: prefixKeys(options.paths?.sources, 'data'),
|
|
28
|
-
derived: prefixKeys(options.paths?.derived, 'derived'),
|
|
29
|
-
async: prefixKeys(options.paths?.async, 'async'),
|
|
30
|
-
},
|
|
31
|
-
actions: options.actions ?? {},
|
|
32
|
-
meta: options.meta,
|
|
33
|
-
};
|
|
34
|
-
}
|
|
35
|
-
export function defineSource(options) {
|
|
36
|
-
return {
|
|
37
|
-
schema: options.schema,
|
|
38
|
-
defaultValue: options.defaultValue,
|
|
39
|
-
policy: options.policy,
|
|
40
|
-
semantic: {
|
|
41
|
-
readable: true,
|
|
42
|
-
writable: true,
|
|
43
|
-
...options.semantic,
|
|
44
|
-
},
|
|
45
|
-
};
|
|
46
|
-
}
|
|
47
|
-
export function defineDerived(options) {
|
|
48
|
-
return {
|
|
49
|
-
deps: options.deps,
|
|
50
|
-
expr: options.expr,
|
|
51
|
-
semantic: {
|
|
52
|
-
readable: true,
|
|
53
|
-
writable: false,
|
|
54
|
-
...options.semantic,
|
|
55
|
-
},
|
|
56
|
-
};
|
|
57
|
-
}
|
|
58
|
-
export function defineAsync(options) {
|
|
59
|
-
return {
|
|
60
|
-
deps: options.deps,
|
|
61
|
-
condition: options.condition,
|
|
62
|
-
debounce: options.debounce,
|
|
63
|
-
effect: options.effect,
|
|
64
|
-
resultPath: options.resultPath,
|
|
65
|
-
loadingPath: options.loadingPath,
|
|
66
|
-
errorPath: options.errorPath,
|
|
67
|
-
semantic: {
|
|
68
|
-
readable: true,
|
|
69
|
-
writable: false,
|
|
70
|
-
...options.semantic,
|
|
71
|
-
},
|
|
72
|
-
};
|
|
73
|
-
}
|
|
74
|
-
export function defineAction(options) {
|
|
75
|
-
return {
|
|
76
|
-
deps: options.deps,
|
|
77
|
-
input: options.input,
|
|
78
|
-
effect: options.effect,
|
|
79
|
-
preconditions: options.preconditions,
|
|
80
|
-
semantic: {
|
|
81
|
-
readable: true,
|
|
82
|
-
writable: false,
|
|
83
|
-
risk: 'none',
|
|
84
|
-
reversible: false,
|
|
85
|
-
...options.semantic,
|
|
86
|
-
},
|
|
87
|
-
};
|
|
88
|
-
}
|
|
89
|
-
/**
|
|
90
|
-
* FieldPolicy 빌더
|
|
91
|
-
*/
|
|
92
|
-
export function fieldPolicy(options) {
|
|
93
|
-
return options;
|
|
94
|
-
}
|
|
95
|
-
/**
|
|
96
|
-
* ConditionRef 빌더
|
|
97
|
-
*/
|
|
98
|
-
export function condition(path, options) {
|
|
99
|
-
return {
|
|
100
|
-
path,
|
|
101
|
-
expect: options?.expect ?? 'true',
|
|
102
|
-
reason: options?.reason,
|
|
103
|
-
};
|
|
104
|
-
}
|
|
105
|
-
//# sourceMappingURL=define.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"define.js","sourceRoot":"","sources":["../../src/domain/define.ts"],"names":[],"mappings":"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"}
|
package/dist/domain/index.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/domain/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,eAAe,CAAC"}
|
package/dist/domain/index.js
DELETED
package/dist/domain/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/domain/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,eAAe,CAAC"}
|