Обновление… Суровая необходимость, вызванная прогрессом. Черный ящик, содержимое которого непредсказуемым образом может отразиться на всей последующей работе. Мало у кого из программистов это слово не вызывает противоречивых чувств.
Возможность посмотреть, что там внутри, могла бы сильно упростить (хотя бы психологически) дальнейшие действия.
При разработке использовалась программа V8Unpack и рекомендации уважаемого awa, высказанные в этом сообщении.
Также был использован весь опыт, накопленный в процессе написания обработки //infostart.ru/public/69976/
Ну и, если честно, немного заимствовано оформление у обработки //infostart.ru/public/65449/
В общем-то все. Скриншоты:
Посмотреть, что там внутри, можно и в режиме Конфигуратора, запустив обновление. Ведь никто не заставляет двигаться дальше после окна сравнения и объединения.
Получили окно сравнения и объединения — и анализируем, что есть в обновлении, и как со всем этим бороться.
…А, я понял…Имеется в виду, что если конфигурация на поддержке с запретом изменений, то окно сравнения и объединения не появляется. Да, согласен, полезная вещь.
На каких конфигурациях проверяли?
Если конфигурация на поддержке, то скорее всего в любом случае придется обновлять, т.к. полезностей в новом релизе чаще больше, чем нехорошестей. И управлять нехорошестями не получится.
Ну а если не на поддержке, то, как и писалось в (1).
Но автор, в любом случае, молодец. Дельная идея.
Респект, наконец то у кого-то дошли руки
Респект, плюс авансом.
//вот бы еще с хранилищем что-то сделать…. эх, мечты, мечты…
(4) как альтернатива хранилищуhttp://main.1c-ei.ru/Home/help/object_config/depot
(5) Знаю, видел — но это не то, что мне надо.
Хочется хранить всю историю в нормальной VCS, конкретно — git. А для этого нужна не только распаковка, но и обратная операция — сборка .cf.
—
По теме — посмотрел, к сожалению разбор метаданных выполняется регулярками… а я то уж понадеялся, что кто-то таки нормально понял их структуру…
Но и то хорошо 🙂
(1) на РАЗЛИЧНЫХ типовых и нетиповых конфигурациях платформ 8.1 и 8.2. В каталоге распаковки неопределенных (не относенных к соответствующему объекту) файлов не остается. Это проверено-перепроверено (на этом ставился приоритет). Если и есть недоделки — они, скорее всего, касаются чего-то более мелочного. Обнаружится ошибка — сообщите.
Отличная реализация, авансом плюсую, пока без надобности, но за хорошие инструменты не грех плюсануть.
Оригинально! Это что-то типа «Новое и изменённое в текущем релизе», но наглядно, в реальной форме. Интересно будет попроовать, может быть, и использовать в дальнейшем для экспресс-анализа, т.к. в обычном режиме используется же Конфигуратор (см. (1)). Спасибо за творческий подход.
плюсану, все достижения человеческого ума находят свое применение )) автору респект
+ автору респект за отличный инструмент
Обнаружилась ошибка в работе программы при выводе дерева для обновлений версии 8.1. Обновил.
Хороша, очень понравилась
Спасибо автору, незаменимая вещь в работе программиста
Зачет автору и плюс
Отличная идея!
Автору респект!
Вот спасибо! Очень нужна такая вещь в работе!
На самом деле идея неплохая.
Смущает только то, что сразу при распаковке ошибка:
{Форма.Форма.Форма(894)}: Значение не является значением объектного типа (ВидМетаданных)
ВидМетаданныхОбъекта=СтрокаДереваМетаданных.ВидМетаданных;
Торговля 10.3.14.3
Применял CFU 10.3.14.4
Только что попробовал на обновлении 10.3.14.4 для платформы 8.2.
Скриншот:
а также в режиме сравнения:
Вещь преотличнейшая.
Изменил некоторые эргономические параметры обработки — почистил и упорядочил код, изменил раскраску строк сравнения, добавил возможность установки флажка для сохранения настроек, добавил проверку на пустоту каталога распаковки — если каталог не пустой, создается подкаталог.
Отличная вещь! спасибо автору!
Рэспект
Респект, Отличная идея!
Присоединяюсь ко всем респектующим.
(1) kapustinag, «если конфигурация на поддержке с запретом изменений, то окно сравнения и объединения не появляется»
Можно вызвать меню «Конфигурация — Сравнить конфигурации» даже в режиме поддержки без возможности объединений.
По сути, обработка дублирует встроенные средства. Однако, плюс остается плюсом за пытливость ума.
(25) К сожалению в режиме «Сравнить конфигурации» нет возможности сравнить конфигурацию (файл конфигурации) с файлом обновления. Если бы эта возможность была — тогда бы обработка действительно дублировала встроенные средства. Задача этой публикации — все-таки, в разборе внутреннего формата 1С и приведении его из вида «черного ящика» к «человекочитаемому виду».
(26) Верно, этого я не учел. Спасибо за наводку.
Отличная разработка, я правильно понимаю, что на ее основе можно попытаться написать распаковщик не в GUID папки а сопоставить GUID и нормальные имена в дереве метаданных?
Скажите пожалуйста а дизайн форм и дизайн макетов отчетов, в каком виде хранится в 1С? это текстовые или полностью бинарные данные?
Очень хочу написать распаковщик CF файлов в НОРМАЛЬНУЮ файловую структуру и интегрировать его с SVN
Автор молодец, что тут скажешь. Кладем в копилку!
(28) макеты отчетов хранятся в том виде, в котором они понятны 1С. Их 9 видов: табличный документ (MOXEL), двоичные данные (base64), Active document (base64), HTML Документ (base64), текстовый документ (обычный текст), географическая схема, схема компоновки данных (xml), макет оформления компоновки данных, графическая схема. Вы можете сами посмотреть — инструментарий в обработке вполне достаточный: открыть в дереве метаданных двойным щелчком или найти в файлах — открыть в блокноте.
а как хранятся макеты форм? тоже чтото похожее на MXL?
(28) Сам давно о таком мечтаю… даже аналог V8Unpack писать начал — но не закончил.
(32) Что-то страшное 🙂
Выполните команду, например, ЗначениеВСтрокуВнутр(Новый ДеревоЗначений) — вот примерно такого вида структура, если мне память не изменяет. И так много чего хранится.
Интересно, хоть кто-нибудь понял как разбирать и собирать эту структуру? Данная обработка парсит её регулярками, что для чтения нормально, но вот сохранять данные таким образом ну никак не получится…
(33) естьV8Unpack , который НОРМАЛЬНО разбирает и собирает. Есть алгоритм вывода полученных из результатов разбора V8Unpack-ом данных в «человекочитаемом» виде. 1с-ка, в принципе все разобранное в отдельности и собранное воедино вполне нормально переваривает. Что хотелось бы еще сохранять?
(34) V8Unpack распаковывает и упаковывает .cf. Но внутренние структуры — нет. Например вот форму по элементам разложить, ну или хотя бы получить всё не в виде файлов с именами в виде GUID-ов, а как дерево конфигурации — типа Документ -> Реквизиты -> Реквизит 1, Реквизит2, …
То есть — интересует этот формат со скобочками фигурными. Полной его разборки и сборки я нигде не видел.
(35) мат. часть: формой называется совокупность трех взаимосвязанных компонентов:
http://infostart.ru/public/17108/ — и не вызывать форма.Открыть() — то то, что вы получите — можно передать на вход ну хотя бы этому — и получить вполне себе корректную разборку(только без заголовков элементов). А вот как быть с заголовками — я и сам не знаю. Но 1с — точно знает. В составе собранной сборки — открывает корректно.
1) собственно объекта «форма»
2) программного модуля (при помощи его создаются различные свойства объекта, объект как бы управляется программным модулем)
3) диалогового окна (которое визуализирует объект и организует взаимодействие с пользователем)
Так вот, если посмотреть в состав файлов формы — их там как раз три и наберется — сам объект формы (файл без расширения), + папка с расширением, в которой будет т.н. «макет» (представление) формы и ее программный модуль (файлы form и module).
Вы хотите, чтобы вам «представление» формы в виде дерева разобрали?
В принципе, если действовать по инструкции
(36) Спасибо, но «мат.часть» я и так знаю. Под словом «Форма» я имел ввиду именно представление в вашей терминологии.
За наводку на обработки спасибо, но это опять не то… это использование «черного ящика» 1С, и никак не поможет со сборкой/разборкой всей конфигурации в читаемый и легко редактируемый человеком вид.
«Скобочки» — действительно можно получить через V8Unpack. А что дальше с ними делать?
«Скобочки» — внутренний формат 1с — внутреннее представление массивов, структур, таблиц, деревьев значений и форм тоже. Вам это представление нужно где-то в отрыве от 1с? Если 1с знает, как из него получать данные, значит, за помощью надо обращаться к нему же. И «дальше что-то с ними делать» тоже с помощью этого замечательного метода ( ЗначениеИзСтрокиВнутр(ТекстСоСкобочками))
(38) Ну, вообще говоря, «скобочки» — это собственный 1С-овский способ сериализации объектов. В принципе, разобраться с их форматом особой сложности не представляет, просто это нудная кропотливая работа. Другое дело, я согласен, это почти никому не нужно. Но иногда приходится разбираться. Например, когда я делал декомпилятор запароленных модулей, то пришлось досконально разобраться с форматом файлов image, содержащих компилированный код модулей, и представляющих из себя все те же «скобочки». Благо, там формат совсем несложный. Или вот, описание таблиц в файле 1CD тоже хранится в таком формате «скобочек». Это описание можно увидеть в Tool_1CD.
Так что, все зависит от поставленных целей.
(37) Совет для желающих разбираться со «скобочками» не на основе регулярных выражений. Скобочки — это, по-сути, текстовое представление дерева. Открывающая фигурная скобка «{» — это начало дерева или ветки, запятая — это разделитель листьев дерева одного уровня, закрывающая фигурная скобка «}» — это конец ветки или дерева. Листьями могут являться:
(38) Именно, нужно в отрыве от 1С. Точнее — преобразование его в что-либо более понятное.
Цель — иметь возможность безболезненно хранить историю конфигурации в VCS, и — главное для чего нужен формат — иметь возможность легко разрешать конфликтующие изменения.
Например — есть основная ветка, есть несколько параллельных веток для разработки, и ветка, которая будет в рабочей базе.
Хочется иметь возможность легко переносить нужные изменения в рабочую базу, и в то же время иметь возможность неспешной разработки несколькими разработчиками слабо связанного функционала в отдельных ветках, и в то же время обновлять их ветки изменениями в других ветках.
Примерно вот так:http://nakedstartup.com/2010/04/simple-daily-git-workflow
(39) Вот! Спасибо за ваш комментарий!
Примерно так я и думал, но до таких подробностей не дошел.
А, если можно, подскажите — как понимать строки вида {5, ….}
То есть когда первым элементом стоит число — иногда оно совпадает с количеством элементов, разделенных запятыми — но не всегда. Это просто совпадение, или закономерность?
(41) Действительно, число — это не всегда количество элементов.
http://infostart.ru/public/15597/ ), приведенную к виду прикладного инструмента в составе http://infostart.ru/public/69976/ (доступна при нажатии на кнопку «Разобрать»).
Пример: сравнение форм базовой и проф конфигураций:
А для представления формата «скобочек» в виде дерева удобно использовать обработку
РазборФайлаОписания1С 81 (изначально выложенную в
Вот спасибо! Очень нужна такая вещь в работе!
Посмотреть, что там внутри, можно и в режиме Конфигуратора, запустив обновление. Ведь никто не заставляет двигаться дальше после окна сравнения и объединения.
Получили окно сравнения и объединения — и анализируем, что есть в обновлении, и как со всем этим бороться.
…А, я понял…Имеется в виду, что если конфигурация на поддержке с запретом изменений, то окно сравнения и объединения не появляется. Да, согласен, полезная вещь.
На каких конфигурациях проверяли?
При случае посмотрим
Спасибо! Пригодится 100%!
Отличная вещь! Все время хотелось чего-то такого, но руки не доходили…
Дежавю?
Конечно, если Вы, Maka2003, серьезно, то ответы были даны в (7) и (26). В любом случае, спасибо за проявленный интерес.
Прекрасная вещь. Очень признателен афтору за идею.
однозначно плюс!
Спасибо. + поставил.
«С помощью кольта и доброго слова вы сможете достичь
гораздо большего, чем только одним добрым словом» (с) Аль Капоне
Всегда уважаю тех, кто делает «кольты» — особенно для 1С… 🙂
Спасибо. отлчно
(52) vkr, спасибо, прослезило… Хотя, ничего «кольтового» не задумывалось… Просто интересно было.
(54) Под «кольтом» имеется в виду некий сервисный инструмент, который
нормальные разработчики всегда прилагают к своим программным
пакетам (если они достаточно серьезны и масштабны).
За это и респект… 🙂
Замечательная вещь. Спасибо !
Если ли такая же вещь для управляемого приложения?
SUPER!!!! + 100))
Не работает с cfu файлами выпущенными на платформе 8.3.6
(59) Key-Zed, советую для файлов обновлений, предназначенных для платформы 8.3 и выше использовать обработкуV8Reader (она является более функциональной и также содержит в себе возможность анализа файлов обновлений).
{ВнешняяОбработка.CFU_ридер.Форма.Форма.Форма(1394)}: Значение не является значением объектного типа (Submatches)
ТипМакета=Match.Submatches(5);