@rsconcept/rstool 0.5.1 → 0.6.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 +1 -1
- package/docs/CONCEPTUAL-SCHEMA.md +0 -29
- package/docs/CONSTITUENTA.md +0 -2
- package/docs/DIAGNOSTICS.md +1 -5
- package/docs/MODEL-TESTING.md +0 -9
- package/docs/README.md +4 -2
- package/examples/README.md +59 -0
- package/examples/agent-client.ts +76 -0
- package/examples/build-kinship-rsform.ts +466 -0
- package/examples/build-kinship-rsmodel.ts +125 -0
- package/examples/build-sample-rsform.ts +90 -0
- package/examples/build-sample-rsmodel.ts +106 -0
- package/examples/kinship/cli.ts +247 -0
- package/examples/kinship/constants.ts +12 -0
- package/examples/kinship/session.ts +190 -0
- package/examples/kinship/x1-actions.test.ts +136 -0
- package/examples/kinship/x1-actions.ts +371 -0
- package/examples/kinship-rsform-session.json +1221 -0
- package/examples/kinship-rsmodel-session.json +1263 -0
- package/examples/sample-rsform-session.json +134 -0
- package/examples/sample-rsmodel-session.json +163 -0
- package/package.json +3 -1
- package/skills/README.md +3 -3
- package/skills/rstool-helper/EXAMPLES.md +20 -29
- package/skills/rstool-helper/GUIDE.md +103 -49
- package/skills/rstool-helper/REFERENCE.md +105 -107
- package/skills/rstool-helper/SKILL.md +3 -3
package/README.md
CHANGED
|
@@ -78,7 +78,7 @@ From `rsconcept/rstool` (or run `powershell -File scripts/dev/LocalDevSetup.ps1`
|
|
|
78
78
|
- `npm test`
|
|
79
79
|
- `npm run build` — produce `dist/` via tsdown
|
|
80
80
|
- `npm run wrapper` — dev stdio wrapper via `tsx`
|
|
81
|
-
- `npm run example:client`, `npm run example:build-schema`, `npm run example:build-rsmodel`
|
|
81
|
+
- `npm run example:client`, `npm run example:build-schema`, `npm run example:build-rsmodel` — see [`examples/README.md`](examples/README.md) for the full list (kinship scripts, session JSON)
|
|
82
82
|
|
|
83
83
|
## Stdio protocol
|
|
84
84
|
|
|
@@ -96,32 +96,3 @@ card(S1) = card(Pr1,2(S1))
|
|
|
96
96
|
- `card(F[ξ]) = 1`.
|
|
97
97
|
|
|
98
98
|
Перед `D{x∈… | ∃d1∈… ∃d2∈…}` проверь, нельзя ли взять `Pr` от уже введенного отношения.
|
|
99
|
-
|
|
100
|
-
## Проверка на маленькой КМ
|
|
101
|
-
|
|
102
|
-
Если семантика не очевидна, собери минимальную модель: значения для `X#`, `C#`, `S#`; затем вычисли целевые `D#`, `F#`, `P#`, `A#`.
|
|
103
|
-
|
|
104
|
-
Особенно проверяй проекции, фильтры, `red`, `bool` / `debool`, аксиомы. Для важной проверки сделай скрипт-тест: сессия + значения неопределяемых конституент + проверка `success` и ожидаемого `value`.
|
|
105
|
-
|
|
106
|
-
Цикл: `MODEL-TESTING.md`.
|
|
107
|
-
|
|
108
|
-
## Быстрое ревью
|
|
109
|
-
|
|
110
|
-
- Атрибутивная и родоструктурная экспликации не смешаны без запроса.
|
|
111
|
-
- Нет проверки принадлежности к собственной типизации: `x∈X1` избыточно, если `x` уже объявлен в `X1`.
|
|
112
|
-
- Покрыты главные сущности, роли, отношения, утверждения.
|
|
113
|
-
- Повторяющиеся отборы вынесены в `F#`.
|
|
114
|
-
- Каждая аксиома имеет понятную цель.
|
|
115
|
-
- Сомнительная семантика проверена на маленькой КМ при наличии тестовых данных.
|
|
116
|
-
|
|
117
|
-
## Рабочий порядок
|
|
118
|
-
|
|
119
|
-
1. Собери словарь: базовые понятия, ключевые отношения, сценарий синтеза.
|
|
120
|
-
2. Добавь `X#`, `C#` с конвенциями из источника.
|
|
121
|
-
3. Добавь базовые `S#`: трансформация, перевод, допускание, выбор, цели, субъекты.
|
|
122
|
-
4. Проверь, что базовые понятия независимы и не выводятся друг из друга.
|
|
123
|
-
5. Добавь `A#` на структуры: `card`, покрытие `Pr1,2(S#)=…`, принадлежность выбора.
|
|
124
|
-
6. Введи `F#` для типовых запросов.
|
|
125
|
-
7. Производные понятия строй через `Pr*`, `Fi*`, `F#` от центрального `D#` и базовых `S#`.
|
|
126
|
-
8. Перед каждым upsert запускай `analyzeExpression`.
|
|
127
|
-
9. Для сомнительной семантики собери маленькую КМ (`MODEL-TESTING.md`).
|
package/docs/CONSTITUENTA.md
CHANGED
|
@@ -51,5 +51,3 @@
|
|
|
51
51
|
3. Все глобальные ссылки уже есть в сессии.
|
|
52
52
|
4. `axiom` и `statement` имеют типизацию `Logic`, иначе `expectedLogic`.
|
|
53
53
|
5. Выводимая конституента с пустой формулой дает `cstEmptyDerived`.
|
|
54
|
-
|
|
55
|
-
Цикл: `analyzeExpression` на черновике → исправить `diagnostics[].from/to` → `addOrUpdateConstituenta`.
|
package/docs/DIAGNOSTICS.md
CHANGED
|
@@ -78,8 +78,4 @@
|
|
|
78
78
|
|
|
79
79
|
## Цикл исправления
|
|
80
80
|
|
|
81
|
-
|
|
82
|
-
2. Прочитай `code`, `from`, `to`, `params`.
|
|
83
|
-
3. Исправь именно диапазон в `definitionFormal`.
|
|
84
|
-
4. Не повторяй вызов без изменения ввода.
|
|
85
|
-
5. После успеха вызывай `addOrUpdateConstituenta`.
|
|
81
|
+
Пошаговый цикл — в `../skills/rstool-helper/GUIDE.md`, раздел «Цикл диагностик». Здесь — справочник кодов и типичных ошибок.
|
package/docs/MODEL-TESTING.md
CHANGED
|
@@ -11,15 +11,6 @@
|
|
|
11
11
|
|
|
12
12
|
Для простой проверки типизации сначала используй `analyzeExpression`. КМ нужна, когда вопрос зависит от интерпретации данных и вычисленного значения.
|
|
13
13
|
|
|
14
|
-
## Минимальный цикл
|
|
15
|
-
|
|
16
|
-
1. Создай отдельную `createSession` или изолированную копию текущей сессии.
|
|
17
|
-
2. Добавь только нужные поставщики: `X#`, `C#`, `S#` и проверяемые `D#` / `F#` / `P#` / `A#`.
|
|
18
|
-
3. Проверь формулы через `analyzeExpression` и `addOrUpdateConstituenta`.
|
|
19
|
-
4. Задай значения базовых понятий через `setConstituentaValue` или `setConstituentaValues`.
|
|
20
|
-
5. Вычисли проверяемую формулу через `evaluateExpression` или сохраненную конституенту через `evaluateConstituenta`.
|
|
21
|
-
6. Сравни результат с ожидаемым значением; если есть несколько зависимых определений, запусти `recalculateModel`.
|
|
22
|
-
|
|
23
14
|
## Что задавать руками
|
|
24
15
|
|
|
25
16
|
`basic`, `constant`, `structure` можно интерпретировать напрямую. `term`, `function`, `predicate`, `axiom`, `statement` должны вычисляться из формулы, поэтому их напрямую не задавай.
|
package/docs/README.md
CHANGED
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
# Документация rstool
|
|
2
2
|
|
|
3
|
-
Краткая
|
|
3
|
+
Краткая справка для агентов.
|
|
4
|
+
|
|
5
|
+
**Воркфлоу и чеклисты** — в `../skills/rstool-helper/GUIDE.md` (начинай с него). Здесь — справочные правила языка и предметной области.
|
|
4
6
|
|
|
5
7
|
## Какой файл читать
|
|
6
8
|
|
|
@@ -14,4 +16,4 @@
|
|
|
14
16
|
- **PORTAL-API.md** — объекты REST API Portal.
|
|
15
17
|
- **GRAMMAR-REF.md** — краткая карта токенов и приоритетов.
|
|
16
18
|
|
|
17
|
-
Контракт агента `rstool`
|
|
19
|
+
Контракт агента `rstool` и примеры — `../skills/rstool-helper/REFERENCE.md`, `EXAMPLES.md` (на русском, вместе с `GUIDE.md`).
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
# Примеры rstool
|
|
2
|
+
|
|
3
|
+
Полные исполняемые сценарии поверх `RSToolWrapperClient` (stdio-обёртка) и готовые JSON-сессии для импорта. Короткие фрагменты кода для агентов — в [`../skills/rstool-helper/EXAMPLES.md`](../skills/rstool-helper/EXAMPLES.md); воркфлоу — [`../skills/rstool-helper/GUIDE.md`](../skills/rstool-helper/GUIDE.md).
|
|
4
|
+
|
|
5
|
+
## Как запускать
|
|
6
|
+
|
|
7
|
+
**Из checkout репозитория** (`rsconcept/rstool`):
|
|
8
|
+
|
|
9
|
+
```bash
|
|
10
|
+
npm install
|
|
11
|
+
npm run build # обёртка для скриптов
|
|
12
|
+
npm run example:client # и остальные example:* / kinship:cli — см. ниже
|
|
13
|
+
```
|
|
14
|
+
|
|
15
|
+
**После `npm install @rsconcept/rstool`** (нужен `tsx` или аналог):
|
|
16
|
+
|
|
17
|
+
```bash
|
|
18
|
+
npx tsx node_modules/@rsconcept/rstool/examples/agent-client.ts
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
Скрипты пишут JSON рядом с собой в `examples/`; запускайте из корня пакета (каталог, где лежит `package.json` rstool).
|
|
22
|
+
|
|
23
|
+
## Скрипты
|
|
24
|
+
|
|
25
|
+
| Файл | npm-скрипт | Назначение |
|
|
26
|
+
|------|------------|------------|
|
|
27
|
+
| [`agent-client.ts`](agent-client.ts) | `example:client` | Минимальный цикл: сессия, upsert, анализ, значения, диагностики через stdio |
|
|
28
|
+
| [`build-sample-rsform.ts`](build-sample-rsform.ts) | `example:build-schema` | Собрать учебную RSForm (X1, S1, D1) и сохранить сессию |
|
|
29
|
+
| [`build-sample-rsmodel.ts`](build-sample-rsmodel.ts) | `example:build-rsmodel` | RSForm + привязки + вычисления → учебная RSModel |
|
|
30
|
+
| [`build-kinship-rsform.ts`](build-kinship-rsform.ts) | `example:build-kinship-schema` | Полная концептуальная схема «родственные отношения» (много конституент) |
|
|
31
|
+
| [`build-kinship-rsmodel.ts`](build-kinship-rsmodel.ts) | `example:build-kinship-rsmodel` | Загрузить kinship RSForm, задать семью, вычислить модель (в т.ч. D3) |
|
|
32
|
+
| [`kinship/cli.ts`](kinship/cli.ts) | `kinship:cli` | Интерактивное редактирование людей (X1) и связей (S1) в kinship-модели |
|
|
33
|
+
|
|
34
|
+
## JSON-сессии
|
|
35
|
+
|
|
36
|
+
Готовые снимки `exportSession` — для `importSession`, тестов и CLI:
|
|
37
|
+
|
|
38
|
+
| Файл | Содержимое |
|
|
39
|
+
|------|------------|
|
|
40
|
+
| [`sample-rsform-session.json`](sample-rsform-session.json) | Учебная RSForm (результат `build-sample-rsform`) |
|
|
41
|
+
| [`sample-rsmodel-session.json`](sample-rsmodel-session.json) | Учебная RSModel с вычисленными значениями |
|
|
42
|
+
| [`kinship-rsform-session.json`](kinship-rsform-session.json) | Схема родства без привязок |
|
|
43
|
+
| [`kinship-rsmodel-session.json`](kinship-rsmodel-session.json) | Kinship-модель с примерной семьёй (по умолчанию для `kinship:cli`) |
|
|
44
|
+
|
|
45
|
+
Пересобрать JSON: соответствующий `build-*.ts` перезапишет файл в `examples/`.
|
|
46
|
+
|
|
47
|
+
## Папка `kinship/`
|
|
48
|
+
|
|
49
|
+
Вспомогательный код для сценария «родственные отношения», не отдельный пакет:
|
|
50
|
+
|
|
51
|
+
| Файл | Роль |
|
|
52
|
+
|------|------|
|
|
53
|
+
| [`constants.ts`](kinship/constants.ts) | Id конституент (X1, S1, D3, A1, …) и путь сессии по умолчанию |
|
|
54
|
+
| [`session.ts`](kinship/session.ts) | Обёртка над сессией: загрузка/сохранение, команды над X1 и S1 |
|
|
55
|
+
| [`x1-actions.ts`](kinship/x1-actions.ts) | Парсинг и применение изменений списка людей |
|
|
56
|
+
| [`x1-actions.test.ts`](kinship/x1-actions.test.ts) | Тесты логики X1 (`npm test`) |
|
|
57
|
+
| [`cli.ts`](kinship/cli.ts) | REPL: `list`, `add`, `remove`, `rename`, `set`, `save`, … |
|
|
58
|
+
|
|
59
|
+
См. также [`../docs/CONSTITUENTA.md`](../docs/CONSTITUENTA.md) (разбор kinship-схемы) и [`../docs/MODEL-TESTING.md`](../docs/MODEL-TESTING.md).
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { CstType, RSToolWrapperClient, type AddOrUpdateConstituentaInput, type AnalyzeExpressionInput } from '../src';
|
|
2
|
+
|
|
3
|
+
interface CreateSessionResult {
|
|
4
|
+
sessionId: string;
|
|
5
|
+
contractVersion: string;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
async function runExample() {
|
|
9
|
+
const client = new RSToolWrapperClient();
|
|
10
|
+
try {
|
|
11
|
+
await client.waitUntilReady();
|
|
12
|
+
|
|
13
|
+
const session = await client.call<CreateSessionResult>('createSession');
|
|
14
|
+
console.log('Session created:', session);
|
|
15
|
+
|
|
16
|
+
const baseInput: AddOrUpdateConstituentaInput = {
|
|
17
|
+
draft: {
|
|
18
|
+
id: 1,
|
|
19
|
+
alias: 'X1',
|
|
20
|
+
cstType: CstType.BASE,
|
|
21
|
+
definitionFormal: ''
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
await client.call('addOrUpdateConstituenta', {
|
|
25
|
+
sessionId: session.sessionId,
|
|
26
|
+
input: baseInput
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
const upsertInput: AddOrUpdateConstituentaInput = {
|
|
30
|
+
draft: {
|
|
31
|
+
id: 2,
|
|
32
|
+
alias: 'D1',
|
|
33
|
+
cstType: CstType.TERM,
|
|
34
|
+
definitionFormal: '1+2'
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
const upsert = await client.call('addOrUpdateConstituenta', {
|
|
38
|
+
sessionId: session.sessionId,
|
|
39
|
+
input: upsertInput
|
|
40
|
+
});
|
|
41
|
+
console.log('Upsert result:', upsert);
|
|
42
|
+
|
|
43
|
+
await client.call('setConstituentaValue', {
|
|
44
|
+
sessionId: session.sessionId,
|
|
45
|
+
input: { target: 1, value: { 0: 'zero', 1: 'one' } }
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
const evalResult = await client.call('evaluateConstituenta', {
|
|
49
|
+
sessionId: session.sessionId,
|
|
50
|
+
input: { constituentId: 2 }
|
|
51
|
+
});
|
|
52
|
+
console.log('Evaluation result:', evalResult);
|
|
53
|
+
|
|
54
|
+
const analyzeInput: AnalyzeExpressionInput = {
|
|
55
|
+
expression: '(',
|
|
56
|
+
cstType: CstType.TERM
|
|
57
|
+
};
|
|
58
|
+
const analysis = await client.call('analyzeExpression', {
|
|
59
|
+
sessionId: session.sessionId,
|
|
60
|
+
input: analyzeInput
|
|
61
|
+
});
|
|
62
|
+
console.log('Analysis result:', analysis);
|
|
63
|
+
|
|
64
|
+
const diagnostics = await client.call('listDiagnostics', {
|
|
65
|
+
sessionId: session.sessionId
|
|
66
|
+
});
|
|
67
|
+
console.log('Diagnostics count:', Array.isArray(diagnostics) ? diagnostics.length : diagnostics);
|
|
68
|
+
} finally {
|
|
69
|
+
await client.close();
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
runExample().catch(error => {
|
|
74
|
+
console.error(error);
|
|
75
|
+
process.exit(1);
|
|
76
|
+
});
|