mirror of
https://github.com/Nikolay-Shirokov/cc-1c-skills.git
synced 2026-06-10 16:14:54 +03:00
feat(skd-decompile): externalize multi-line queries в отдельные .sql файлы
Если query ≥3 строк и указан -OutputPath, decompile выносит SQL в <datasetName>.sql рядом с decompiled.json. В JSON эмитится "@<name>.sql" вместо inline-строки. - Имя файла: dataset name (sanitized — non-word chars → _), коллизии разрешаются суффиксом _2/_3/... - compile уже поддерживает синтаксис @file.sql (Resolve-QueryValue) — round-trip симметричен. - Тесты не изменились: все тестовые queries по 1 строке (порог не срабатывает). - На реальных отчётах (ERP/ACC main DCS — 10-50 строк query типично) даёт значительно более компактный JSON + читаемый .sql с подсветкой синтаксиса в IDE. Новый тест dataset-query-multiline (round-trip с внешним .sql). v0.17 → v0.18.
This commit is contained in:
@@ -1,4 +1,4 @@
|
||||
# skd-decompile v0.17 — Decompile 1C DCS Template.xml to JSON DSL (draft)
|
||||
# skd-decompile v0.18 — Decompile 1C DCS Template.xml to JSON DSL (draft)
|
||||
# Source: https://github.com/Nikolay-Shirokov/cc-1c-skills
|
||||
param(
|
||||
[Parameter(Mandatory)]
|
||||
@@ -697,6 +697,45 @@ foreach ($k in $script:builtinPresets.Keys) {
|
||||
# existingUserPresetsRaw — копия загруженного skd-styles.json (PSCustomObject) для merge при записи.
|
||||
$script:existingUserPresetsRaw = $null
|
||||
|
||||
# Аккумулятор внешних SQL-файлов для записи рядом с outputPath: @{name = "filename.sql"; text = "...sql text..."}
|
||||
$script:queryFilesAccumulator = @()
|
||||
$script:queryFileNamesUsed = @{}
|
||||
|
||||
# Если запрос ≥3 строк и есть outputPath — вынести в отдельный <name>.sql и вернуть "@<name>.sql".
|
||||
# Иначе — оставить inline.
|
||||
function Maybe-ExternalizeQuery {
|
||||
param([string]$queryText, [string]$datasetName)
|
||||
if (-not $queryText) { return $queryText }
|
||||
if (-not $script:outputDir) { return $queryText }
|
||||
# Считаем строки — \r\n или \n
|
||||
$lineCount = ([regex]::Matches($queryText, "`n")).Count + 1
|
||||
if ($lineCount -lt 3) { return $queryText }
|
||||
# Уникализация имени файла
|
||||
$safeName = ($datasetName -replace '[^\w\-]', '_')
|
||||
if (-not $safeName) { $safeName = 'query' }
|
||||
$fileName = "$safeName.sql"
|
||||
$suffix = 1
|
||||
while ($script:queryFileNamesUsed.ContainsKey($fileName)) {
|
||||
$suffix++
|
||||
$fileName = "$safeName`_$suffix.sql"
|
||||
}
|
||||
$script:queryFileNamesUsed[$fileName] = $true
|
||||
$script:queryFilesAccumulator += [ordered]@{ fileName = $fileName; text = $queryText }
|
||||
return "@$fileName"
|
||||
}
|
||||
|
||||
# Записать все накопленные .sql файлы рядом с outputPath.
|
||||
function Save-QueryFiles {
|
||||
if ($script:queryFilesAccumulator.Count -eq 0) { return }
|
||||
if (-not $script:outputDir) { return }
|
||||
$enc = New-Object System.Text.UTF8Encoding($false)
|
||||
foreach ($qf in $script:queryFilesAccumulator) {
|
||||
$path = Join-Path $script:outputDir $qf.fileName
|
||||
[System.IO.File]::WriteAllText($path, $qf.text, $enc)
|
||||
}
|
||||
[Console]::Error.WriteLine("Saved $($script:queryFilesAccumulator.Count) external query file(s)")
|
||||
}
|
||||
|
||||
# customStylesAccumulator — новые customN, накопленные в текущем прогоне, для записи в skd-styles.json.
|
||||
$script:customStylesAccumulator = [ordered]@{}
|
||||
|
||||
@@ -1592,7 +1631,8 @@ function Build-DataSet {
|
||||
|
||||
switch ($xsiType) {
|
||||
'DataSetQuery' {
|
||||
$ds['query'] = Get-Text $dsNode "r:query"
|
||||
$queryText = Get-Text $dsNode "r:query"
|
||||
$ds['query'] = Maybe-ExternalizeQuery -queryText $queryText -datasetName $name
|
||||
}
|
||||
'DataSetObject' {
|
||||
$ds['objectName'] = Get-Text $dsNode "r:objectName"
|
||||
@@ -1850,6 +1890,7 @@ if ($OutputPath) {
|
||||
$enc = New-Object System.Text.UTF8Encoding($false)
|
||||
[System.IO.File]::WriteAllText($OutputPath, $json, $enc)
|
||||
Save-UserStyles -dirPath $script:outputDir
|
||||
Save-QueryFiles
|
||||
|
||||
if ($script:warnings.Count -gt 0) {
|
||||
$wPath = [System.IO.Path]::ChangeExtension($OutputPath, $null).TrimEnd('.') + '.warnings.md'
|
||||
|
||||
@@ -0,0 +1,23 @@
|
||||
{
|
||||
"name": "Многострочный query → внешний .sql файл (@<name>.sql)",
|
||||
"preRun": [
|
||||
{
|
||||
"script": "skd-compile/scripts/skd-compile",
|
||||
"input": {
|
||||
"dataSets": [{
|
||||
"name": "ПродажиПоПериодам",
|
||||
"query": "ВЫБРАТЬ\n\tНоменклатура,\n\tКоличество,\n\tСумма\nИЗ\n\tРегистрНакопления.Продажи\nГДЕ\n\tПериод МЕЖДУ &НачалоПериода И &КонецПериода",
|
||||
"fields": [
|
||||
"Номенклатура: CatalogRef.Номенклатура @dimension",
|
||||
"Количество: decimal(15,3)",
|
||||
"Сумма: decimal(15,2)"
|
||||
]
|
||||
}]
|
||||
},
|
||||
"args": { "-DefinitionFile": "{inputFile}", "-OutputPath": "Template.xml" },
|
||||
"cwd": "{workDir}"
|
||||
}
|
||||
],
|
||||
"params": { "templatePath": "Template.xml" },
|
||||
"outputPath": "decompiled.json"
|
||||
}
|
||||
@@ -0,0 +1,81 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<DataCompositionSchema xmlns="http://v8.1c.ru/8.1/data-composition-system/schema"
|
||||
xmlns:dcscom="http://v8.1c.ru/8.1/data-composition-system/common"
|
||||
xmlns:dcscor="http://v8.1c.ru/8.1/data-composition-system/core"
|
||||
xmlns:dcsset="http://v8.1c.ru/8.1/data-composition-system/settings"
|
||||
xmlns:v8="http://v8.1c.ru/8.1/data/core"
|
||||
xmlns:v8ui="http://v8.1c.ru/8.1/data/ui"
|
||||
xmlns:xs="http://www.w3.org/2001/XMLSchema"
|
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||
<dataSource>
|
||||
<name>ИсточникДанных1</name>
|
||||
<dataSourceType>Local</dataSourceType>
|
||||
</dataSource>
|
||||
<dataSet xsi:type="DataSetQuery">
|
||||
<name>ПродажиПоПериодам</name>
|
||||
<field xsi:type="DataSetFieldField">
|
||||
<dataPath>Номенклатура</dataPath>
|
||||
<field>Номенклатура</field>
|
||||
<role>
|
||||
<dcscom:dimension>true</dcscom:dimension>
|
||||
</role>
|
||||
<valueType>
|
||||
<v8:Type xmlns:d5p1="http://v8.1c.ru/8.1/data/enterprise/current-config">d5p1:CatalogRef.Номенклатура</v8:Type>
|
||||
</valueType>
|
||||
</field>
|
||||
<field xsi:type="DataSetFieldField">
|
||||
<dataPath>Количество</dataPath>
|
||||
<field>Количество</field>
|
||||
<valueType>
|
||||
<v8:Type>xs:decimal</v8:Type>
|
||||
<v8:NumberQualifiers>
|
||||
<v8:Digits>15</v8:Digits>
|
||||
<v8:FractionDigits>3</v8:FractionDigits>
|
||||
<v8:AllowedSign>Any</v8:AllowedSign>
|
||||
</v8:NumberQualifiers>
|
||||
</valueType>
|
||||
</field>
|
||||
<field xsi:type="DataSetFieldField">
|
||||
<dataPath>Сумма</dataPath>
|
||||
<field>Сумма</field>
|
||||
<valueType>
|
||||
<v8:Type>xs:decimal</v8:Type>
|
||||
<v8:NumberQualifiers>
|
||||
<v8:Digits>15</v8:Digits>
|
||||
<v8:FractionDigits>2</v8:FractionDigits>
|
||||
<v8:AllowedSign>Any</v8:AllowedSign>
|
||||
</v8:NumberQualifiers>
|
||||
</valueType>
|
||||
</field>
|
||||
<dataSource>ИсточникДанных1</dataSource>
|
||||
<query>ВЫБРАТЬ
|
||||
Номенклатура,
|
||||
Количество,
|
||||
Сумма
|
||||
ИЗ
|
||||
РегистрНакопления.Продажи
|
||||
ГДЕ
|
||||
Период МЕЖДУ &НачалоПериода И &КонецПериода</query>
|
||||
</dataSet>
|
||||
<settingsVariant>
|
||||
<dcsset:name>Основной</dcsset:name>
|
||||
<dcsset:presentation xsi:type="v8:LocalStringType">
|
||||
<v8:item>
|
||||
<v8:lang>ru</v8:lang>
|
||||
<v8:content>Основной</v8:content>
|
||||
</v8:item>
|
||||
</dcsset:presentation>
|
||||
<dcsset:settings xmlns:style="http://v8.1c.ru/8.1/data/ui/style" xmlns:sys="http://v8.1c.ru/8.1/data/ui/fonts/system" xmlns:web="http://v8.1c.ru/8.1/data/ui/colors/web" xmlns:win="http://v8.1c.ru/8.1/data/ui/colors/windows">
|
||||
<dcsset:selection>
|
||||
</dcsset:selection>
|
||||
<dcsset:item xsi:type="dcsset:StructureItemGroup">
|
||||
<dcsset:order>
|
||||
<dcsset:item xsi:type="dcsset:OrderItemAuto"/>
|
||||
</dcsset:order>
|
||||
<dcsset:selection>
|
||||
<dcsset:item xsi:type="dcsset:SelectedItemAuto"/>
|
||||
</dcsset:selection>
|
||||
</dcsset:item>
|
||||
</dcsset:settings>
|
||||
</settingsVariant>
|
||||
</DataCompositionSchema>
|
||||
@@ -0,0 +1,13 @@
|
||||
{
|
||||
"dataSets": [
|
||||
{
|
||||
"name": "ПродажиПоПериодам",
|
||||
"query": "@ПродажиПоПериодам.sql",
|
||||
"fields": [
|
||||
"Номенклатура: CatalogRef.Номенклатура @dimension",
|
||||
"Количество: decimal(15,3)",
|
||||
"Сумма: decimal(15,2)"
|
||||
]
|
||||
}
|
||||
]
|
||||
}
|
||||
+8
@@ -0,0 +1,8 @@
|
||||
ВЫБРАТЬ
|
||||
Номенклатура,
|
||||
Количество,
|
||||
Сумма
|
||||
ИЗ
|
||||
РегистрНакопления.Продажи
|
||||
ГДЕ
|
||||
Период МЕЖДУ &НачалоПериода И &КонецПериода
|
||||
Reference in New Issue
Block a user