mirror of
https://github.com/Nikolay-Shirokov/cc-1c-skills.git
synced 2026-06-14 18:04:58 +03:00
feat(form-decompile,form-compile): наборы типов TypeSet (определяемый тип, характеристика, любая ссылка)
<v8:TypeSet> (набор типов) не поддерживался: Decompile-Type итерировал только v8:Type
→ тип колонки/реквизита/параметра с TypeSet терялся (компилятор эмитил пустой <Type/>).
Покрыто (9282 вхождения в корпусе):
- DefinedType.X (6515) — определяемый тип (синоним ОпределяемыйТип.X)
- Characteristic.X (216) — характеристика (синоним Характеристика.X)
- AnyRef (268) / AnyIBRef (207) — любая ссылка / любая ссылка ИБ
- голый ref-вид без .Имя: CatalogRef/DocumentRef/EnumRef/ExchangePlanRef/TaskRef/
BusinessProcessRef/ChartOf*Ref — «любая ссылка вида»
Развязка с обычным типом — по наличию точки: CatalogRef.Валюты → <v8:Type>,
CatalogRef (голый) → <v8:TypeSet>. DefinedType/Characteristic/голый ref никогда не
бывают v8:Type (проверено: 0). Составной тип через " | " роутит каждую часть
независимо (в т.ч. смешанный Type+TypeSet).
Emit-SingleType (+py) детектит и эмитит <v8:TypeSet>; Decompile-Type снимает cfg:-префикс.
TOTAL diff lines выборки 2.17: 4443 → 4068 (-375), match 13 → 14. Снапшот table
(колонки AnyRef/CatalogRef) сертифицирован в 1С (8.3.24). Регресс form-compile 33/33
зелёный на ps + python. decompile v0.34, compile v1.52.
Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
This commit is contained in:
@@ -1,4 +1,4 @@
|
||||
# form-compile v1.51 — Compile 1C managed form from JSON or object metadata
|
||||
# form-compile v1.52 — Compile 1C managed form from JSON or object metadata
|
||||
# Source: https://github.com/Nikolay-Shirokov/cc-1c-skills
|
||||
param(
|
||||
[string]$JsonPath,
|
||||
@@ -1955,6 +1955,9 @@ $script:formTypeSynonyms["планобменассылка"] = "Exc
|
||||
$script:formTypeSynonyms["бизнеспроцессссылка"] = "BusinessProcessRef"
|
||||
$script:formTypeSynonyms["задачассылка"] = "TaskRef"
|
||||
$script:formTypeSynonyms["определяемыйтип"] = "DefinedType"
|
||||
$script:formTypeSynonyms["характеристика"] = "Characteristic"
|
||||
$script:formTypeSynonyms["любаяссылка"] = "AnyRef"
|
||||
$script:formTypeSynonyms["любаяссылкаиб"] = "AnyIBRef"
|
||||
|
||||
# Known invalid types (runtime/UI types that don't exist in XDTO schema)
|
||||
$script:knownInvalidTypes = @{
|
||||
@@ -2110,6 +2113,17 @@ function Emit-SingleType {
|
||||
return
|
||||
}
|
||||
|
||||
# TypeSet (набор типов) → <v8:TypeSet>: определяемый тип / характеристика (именованные)
|
||||
# + «любая ссылка вида» (голый ref-вид без .Имя). Развязка с обычным типом — по наличию точки.
|
||||
if ($typeStr -match '^(DefinedType|Characteristic)\.') {
|
||||
X "$indent<v8:TypeSet>cfg:$typeStr</v8:TypeSet>"
|
||||
return
|
||||
}
|
||||
if ($typeStr -match '^(AnyRef|AnyIBRef|CatalogRef|DocumentRef|EnumRef|ExchangePlanRef|TaskRef|BusinessProcessRef|ChartOfAccountsRef|ChartOfCharacteristicTypesRef|ChartOfCalculationTypesRef)$') {
|
||||
X "$indent<v8:TypeSet>cfg:$typeStr</v8:TypeSet>"
|
||||
return
|
||||
}
|
||||
|
||||
# cfg: references (CatalogRef.XXX, DocumentObject.XXX, etc.)
|
||||
if ($typeStr -match '^(CatalogRef|CatalogObject|DocumentRef|DocumentObject|EnumRef|ChartOfAccountsRef|ChartOfAccountsObject|ChartOfCharacteristicTypesRef|ChartOfCharacteristicTypesObject|ChartOfCalculationTypesRef|ChartOfCalculationTypesObject|ExchangePlanRef|ExchangePlanObject|BusinessProcessRef|BusinessProcessObject|TaskRef|TaskObject|InformationRegisterRecordSet|InformationRegisterRecordManager|AccumulationRegisterRecordSet|AccountingRegisterRecordSet|ConstantsSet|DataProcessorObject|ReportObject)\.') {
|
||||
X "$indent<v8:Type>cfg:$typeStr</v8:Type>"
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
#!/usr/bin/env python3
|
||||
# form-compile v1.51 — Compile 1C managed form from JSON or object metadata
|
||||
# form-compile v1.52 — Compile 1C managed form from JSON or object metadata
|
||||
# Source: https://github.com/Nikolay-Shirokov/cc-1c-skills
|
||||
import argparse
|
||||
import copy
|
||||
@@ -2345,6 +2345,9 @@ _FORM_TYPE_SYNONYMS = {
|
||||
"бизнеспроцессссылка": "BusinessProcessRef",
|
||||
"задачассылка": "TaskRef",
|
||||
"определяемыйтип": "DefinedType",
|
||||
"характеристика": "Characteristic",
|
||||
"любаяссылка": "AnyRef",
|
||||
"любаяссылкаиб": "AnyIBRef",
|
||||
}
|
||||
|
||||
|
||||
@@ -2432,6 +2435,15 @@ def emit_single_type(lines, type_str, indent):
|
||||
lines.append(f'{indent}<v8:Type>cfg:DynamicList</v8:Type>')
|
||||
return
|
||||
|
||||
# TypeSet (набор типов) → <v8:TypeSet>: определяемый тип / характеристика (именованные)
|
||||
# + «любая ссылка вида» (голый ref-вид без .Имя). Развязка с обычным типом — по наличию точки.
|
||||
if re.match(r'^(DefinedType|Characteristic)\.', type_str):
|
||||
lines.append(f'{indent}<v8:TypeSet>cfg:{type_str}</v8:TypeSet>')
|
||||
return
|
||||
if re.match(r'^(AnyRef|AnyIBRef|CatalogRef|DocumentRef|EnumRef|ExchangePlanRef|TaskRef|BusinessProcessRef|ChartOfAccountsRef|ChartOfCharacteristicTypesRef|ChartOfCalculationTypesRef)$', type_str):
|
||||
lines.append(f'{indent}<v8:TypeSet>cfg:{type_str}</v8:TypeSet>')
|
||||
return
|
||||
|
||||
# cfg: references
|
||||
if CFG_REF_PATTERN.match(type_str):
|
||||
lines.append(f'{indent}<v8:Type>cfg:{type_str}</v8:Type>')
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
# form-decompile v0.33 — Decompile 1C managed Form.xml to JSON DSL (draft)
|
||||
# form-decompile v0.34 — Decompile 1C managed Form.xml to JSON DSL (draft)
|
||||
# Source: https://github.com/Nikolay-Shirokov/cc-1c-skills
|
||||
# ВНИМАНИЕ: раундтрип не гарантируется. Навык исключён из авто-использования моделью.
|
||||
param(
|
||||
@@ -855,6 +855,13 @@ function Decompile-Type {
|
||||
}
|
||||
[void]$parts.Add($short)
|
||||
}
|
||||
# TypeSet (набор типов): определяемый тип / характеристика / «любая ссылка вида».
|
||||
# Префикс cfg:/v8: снимаем — обратный роутинг в компиляторе по форме токена.
|
||||
foreach ($ts in @($typeNode.SelectNodes("v8:TypeSet", $ns))) {
|
||||
$raw = $ts.InnerText.Trim()
|
||||
$short = $raw -replace '^(v8ui|v8|cfg):', ''
|
||||
[void]$parts.Add($short)
|
||||
}
|
||||
if ($parts.Count -eq 0) { return $null }
|
||||
if ($parts.Count -eq 1) { return $parts[0] }
|
||||
return ($parts -join ' | ')
|
||||
|
||||
+16
-1
@@ -742,12 +742,27 @@ Pages поддерживает `pagesRepresentation`: `None`, `TabsOnTop`, `Tabs
|
||||
| `"Picture"` | `v8ui:Picture` |
|
||||
| `"DynamicList"` | `cfg:DynamicList` |
|
||||
|
||||
### Наборы типов (TypeSet → `<v8:TypeSet>`)
|
||||
|
||||
«Набор типов» вместо конкретного типа. Развязка с обычным типом — по наличию `.Имя`:
|
||||
|
||||
| DSL | XML | Смысл |
|
||||
|-----|-----|-------|
|
||||
| `"DefinedType.ДенежнаяСумма"` | `<v8:TypeSet>cfg:DefinedType.ДенежнаяСумма</v8:TypeSet>` | определяемый тип (синоним `ОпределяемыйТип.X`) |
|
||||
| `"Characteristic.Номенклатура"` | `<v8:TypeSet>cfg:Characteristic.Номенклатура</v8:TypeSet>` | характеристика (синоним `Характеристика.X`) |
|
||||
| `"AnyRef"` | `<v8:TypeSet>cfg:AnyRef</v8:TypeSet>` | любая ссылка (синоним `ЛюбаяСсылка`) |
|
||||
| `"AnyIBRef"` | `<v8:TypeSet>cfg:AnyIBRef</v8:TypeSet>` | любая ссылка ИБ |
|
||||
| `"CatalogRef"` (голый, без `.Имя`) | `<v8:TypeSet>cfg:CatalogRef</v8:TypeSet>` | любая ссылка справочника (аналогично `DocumentRef`, `EnumRef`, `ExchangePlanRef`, `TaskRef`, `BusinessProcessRef`, `ChartOf*Ref`) |
|
||||
|
||||
`CatalogRef.Валюты` (с `.Имя`) → обычный `<v8:Type>`; `CatalogRef` (голый) → `<v8:TypeSet>`.
|
||||
|
||||
### Составные типы
|
||||
|
||||
Разделитель `" | "`:
|
||||
Разделитель `" | "` (или `+`). Каждая часть независимо роутится в `<v8:Type>` или `<v8:TypeSet>` (можно смешивать):
|
||||
|
||||
```json
|
||||
"type": "CatalogRef.Организации | CatalogRef.ИндивидуальныеПредприниматели"
|
||||
"type": "CatalogRef.Контрагенты | DefinedType.ДенежнаяСумма"
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
+11
-1
@@ -134,11 +134,21 @@
|
||||
</v8:StringQualifiers>
|
||||
</Type>
|
||||
</Column>
|
||||
<Column name="Объект" id="34">
|
||||
<Type>
|
||||
<v8:TypeSet>cfg:AnyRef</v8:TypeSet>
|
||||
</Type>
|
||||
</Column>
|
||||
<Column name="Источник" id="35">
|
||||
<Type>
|
||||
<v8:TypeSet>cfg:CatalogRef</v8:TypeSet>
|
||||
</Type>
|
||||
</Column>
|
||||
</Columns>
|
||||
</Attribute>
|
||||
</Attributes>
|
||||
<Commands>
|
||||
<Command name="Обновить" id="34">
|
||||
<Command name="Обновить" id="36">
|
||||
<Title>
|
||||
<v8:item>
|
||||
<v8:lang>ru</v8:lang>
|
||||
|
||||
@@ -38,7 +38,9 @@
|
||||
{ "name": "Данные", "type": "ValueTable", "columns": [
|
||||
{ "name": "Дата", "type": "date" },
|
||||
{ "name": "Сумма", "type": "decimal(15,2)" },
|
||||
{ "name": "Комментарий", "type": "string(200)" }
|
||||
{ "name": "Комментарий", "type": "string(200)" },
|
||||
{ "name": "Объект", "type": "AnyRef" },
|
||||
{ "name": "Источник", "type": "CatalogRef" }
|
||||
]}
|
||||
],
|
||||
"commands": [
|
||||
|
||||
Reference in New Issue
Block a user