epf-validate
$
npx mdskill add SteelMorgan/1c-agent-based-dev-framework/epf-validateValidates 1C external processing (EPF) XML structure after creation or modification to ensure correctness.
- Helps developers verify structural integrity of EPF files, including properties, forms, and unique names.
- Integrates with Bash, Read, and Glob tools for file handling and script execution.
- Uses predefined checks on XML elements like InternalInfo and ChildObjects to detect errors.
- Outputs results to console or optionally writes them to a UTF-8 BOM file for review.
SKILL.md
.github/skills/epf-validateView on GitHub ↗
--- name: epf-validate description: Валидация внешней обработки 1С (EPF). Используй после создания или модификации обработки для проверки корректности argument-hint: <ObjectPath> [-MaxErrors 30] allowed-tools: - Bash - Read - Glob --- # /epf-validate — валидация внешней обработки (EPF) Проверяет структурную корректность XML-исходников внешней обработки: корневую структуру, InternalInfo, свойства, ChildObjects, реквизиты, табличные части, уникальность имён, наличие файлов форм и макетов. Скрипт также работает для внешних отчётов (ERF) — автоопределение по типу элемента. См. `/erf-validate`. ## Использование ``` /epf-validate <ObjectPath> ``` ## Параметры | Параметр | Обязательный | По умолчанию | Описание | |------------|:------------:|--------------|-------------------------------------------------| | ObjectPath | да | — | Путь к корневому XML или каталогу обработки | | MaxErrors | нет | 30 | Остановиться после N ошибок | | OutFile | нет | — | Записать результат в файл (UTF-8 BOM) | `ObjectPath` авторезолв: если указана директория — ищет `<dirName>/<dirName>.xml`. ## Команда ```bash python3 scripts/epf-validate.py -ObjectPath "<путь>" ``` ## Выполняемые проверки | # | Проверка | Серьёзность | |----|-------------------------------------------------------|--------------| | 1 | Root structure: MetaDataObject/ExternalDataProcessor | ERROR | | 2 | InternalInfo: ClassId, ContainedObject, GeneratedType | ERROR / WARN | | 3 | Properties: Name (identifier), Synonym | ERROR / WARN | | 4 | ChildObjects: допустимые типы, порядок | ERROR / WARN | | 5 | Cross-references: DefaultForm → Form, AuxiliaryForm | ERROR / WARN | | 6 | Attributes: UUID, Name, Type | ERROR | | 7 | TabularSections: UUID, Name, GeneratedType, Attributes | ERROR / WARN | | 8 | Уникальность имён (Attribute, TS, Form, Template, Command) | ERROR | | 9 | Файлы: формы (.xml + Ext/Form.xml), макеты | ERROR | | 10 | Дескрипторы форм: корневая структура, uuid, Name, FormType | ERROR / WARN | ## Вывод ``` === Validation: EPF.МояОбработка === [OK] 1. Root structure: MetaDataObject/ExternalDataProcessor, version 2.17 [OK] 2. InternalInfo: ClassId correct, 1 GeneratedType [OK] 3. Properties: Name="МояОбработка", Synonym present, DefaultForm set [OK] 4. ChildObjects: Attribute(3), TabularSection(1), Form(1) [OK] 5. Cross-references: DefaultForm valid [OK] 6. Attributes: 3 checked (UUID, Name, Type) [OK] 7. TabularSections: 1 sections, 5 inner attributes [OK] 8. Name uniqueness: 6 names, all unique [OK] 9. File existence: 3 files verified [OK] 10. Form descriptors: 1 checked === Result: 0 errors, 0 warnings === ``` Код возврата: 0 = все проверки пройдены, 1 = есть ошибки. ## Когда использовать - После `/epf-init`, добавления формы/макета, ручного редактирования XML — выявить структурные ошибки до сборки. - При отладке сборки — найти причину ошибки Designer.
More from SteelMorgan/1c-agent-based-dev-framework
- 1c-ai-agent-cliCLI 1C BSL Agent Framework — tools/install.py (clone, install). Используй при клонировании репозитория, установке компонентов в проект, настройке IDE (Cursor, Claude Code, Windsurf, VS Code+Continue).
- agent-debugПаттерн отладочных сообщений для 1С BSL. Используй, когда стандартная диагностика (event-log, скриншоты) не даёт понять фактическое поведение системы — нужно вставить временные точки логирования в код, запустить тест и проанализировать записи ЖР.
- agent-developmentCreate custom subagents for specialized AI tasks. Use when the user wants to create a new type of subagent, set up task-specific agents, configure code reviewers, debuggers, or domain-specific assistants with custom prompts.
- agent-development-ext>
- agent-git-workflowStandardizes git workflow for the AI agent in the sandbox devcontainer: work in agent/<task>-<yyyymmdd>, integrate via agent, never push to main/master, open PRs via GitHub CLI. Use when the user asks to create branches, push changes, open PRs, or follow this sandbox repo setup.
- auto-skill-bootstrapDeterministic helper to inventory existing project skills, detect missing capability coverage, search skills.sh via Skills CLI, and (optionally) install missing skills under a trust policy. Uses skills-manifest.json + state.json to stay idempotent across changing requirements.
- code-navigationНавигация по коду (Code Navigation). Навык учит агента **эффективно перемещаться по BSL-коду** с помощью LSP (Language Server Protocol).
- config-operationsОперации с конфигурацией 1С (CF) — init, info, edit, validate. Используй при создании конфигурации, анализе структуры, изменении свойств и ChildObjects, валидации Configuration.xml.
- epf-buildСобрать EPF/ERF из XML-исходников. Используй после внесения временных диагностических правок в разобранную обработку.
- epf-dumpРазобрать EPF/ERF в XML-исходники. Используй, когда нужно быстро получить исходный код внешней обработки или отчета для анализа и временной модификации.