CFU-reader


Обработка, предназначенная для анализа файлов обновлений — cfu (с возможностью их последующего сравнения с обновляемой конфигурацией) ДО факта обновления. Позволяет изучить объем и структуру полученного обновления.

Обновление… Суровая необходимость, вызванная прогрессом. Черный ящик, содержимое которого непредсказуемым образом может отразиться на всей последующей работе. Мало у кого из программистов это слово не вызывает противоречивых чувств.

Возможность посмотреть, что там внутри, могла бы сильно упростить (хотя бы психологически) дальнейшие действия.

При разработке использовалась программа V8Unpack и рекомендации уважаемого awa, высказанные в этом сообщении.

Также был использован весь опыт, накопленный в процессе написания обработки //infostart.ru/public/69976/

Ну и, если честно, немного заимствовано оформление у обработки //infostart.ru/public/65449/

В общем-то все. Скриншоты:

59 Comments

  1. kapustinag

    Посмотреть, что там внутри, можно и в режиме Конфигуратора, запустив обновление. Ведь никто не заставляет двигаться дальше после окна сравнения и объединения.

    Получили окно сравнения и объединения — и анализируем, что есть в обновлении, и как со всем этим бороться.

    …А, я понял…Имеется в виду, что если конфигурация на поддержке с запретом изменений, то окно сравнения и объединения не появляется. Да, согласен, полезная вещь.

    На каких конфигурациях проверяли?

    Reply
  2. Damian

    Если конфигурация на поддержке, то скорее всего в любом случае придется обновлять, т.к. полезностей в новом релизе чаще больше, чем нехорошестей. И управлять нехорошестями не получится.

    Ну а если не на поддержке, то, как и писалось в (1).

    Но автор, в любом случае, молодец. Дельная идея.

    Reply
  3. German

    Респект, наконец то у кого-то дошли руки

    Reply
  4. Magister

    Респект, плюс авансом.

    //вот бы еще с хранилищем что-то сделать…. эх, мечты, мечты…

    Reply
  5. German

    (4) как альтернатива хранилищу http://main.1c-ei.ru/Home/help/object_config/depot

    Reply
  6. Magister

    (5) Знаю, видел — но это не то, что мне надо.

    Хочется хранить всю историю в нормальной VCS, конкретно — git. А для этого нужна не только распаковка, но и обратная операция — сборка .cf.



    По теме — посмотрел, к сожалению разбор метаданных выполняется регулярками… а я то уж понадеялся, что кто-то таки нормально понял их структуру…

    Но и то хорошо 🙂

    Reply
  7. bambr1975

    (1) на РАЗЛИЧНЫХ типовых и нетиповых конфигурациях платформ 8.1 и 8.2. В каталоге распаковки неопределенных (не относенных к соответствующему объекту) файлов не остается. Это проверено-перепроверено (на этом ставился приоритет). Если и есть недоделки — они, скорее всего, касаются чего-то более мелочного. Обнаружится ошибка — сообщите.

    Reply
  8. CaSH_2004

    Отличная реализация, авансом плюсую, пока без надобности, но за хорошие инструменты не грех плюсануть.

    Reply
  9. Boroda

    Оригинально! Это что-то типа «Новое и изменённое в текущем релизе», но наглядно, в реальной форме. Интересно будет попроовать, может быть, и использовать в дальнейшем для экспресс-анализа, т.к. в обычном режиме используется же Конфигуратор (см. (1)). Спасибо за творческий подход.

    Reply
  10. sergnik

    плюсану, все достижения человеческого ума находят свое применение )) автору респект

    Reply
  11. che666

    + автору респект за отличный инструмент

    Reply
  12. bambr1975

    Обнаружилась ошибка в работе программы при выводе дерева для обновлений версии 8.1. Обновил.

    Reply
  13. napan

    Хороша, очень понравилась

    Спасибо автору, незаменимая вещь в работе программиста

    Зачет автору и плюс

    Reply
  14. rus128

    Отличная идея!

    Автору респект!

    Reply
  15. Doomino

    Вот спасибо! Очень нужна такая вещь в работе!

    Reply
  16. artspeed

    На самом деле идея неплохая.

    Смущает только то, что сразу при распаковке ошибка:

    {Форма.Форма.Форма(894)}: Значение не является значением объектного типа (ВидМетаданных)

    ВидМетаданныхОбъекта=СтрокаДереваМетаданных.ВидМетаданных;

    Торговля 10.3.14.3

    Применял CFU 10.3.14.4

    Reply
  17. bambr1975

    Только что попробовал на обновлении 10.3.14.4 для платформы 8.2.

    Скриншот:

    Reply
  18. bambr1975

    а также в режиме сравнения:

    Reply
  19. NovSL

    Вещь преотличнейшая.

    Reply
  20. bambr1975

    Изменил некоторые эргономические параметры обработки — почистил и упорядочил код, изменил раскраску строк сравнения, добавил возможность установки флажка для сохранения настроек, добавил проверку на пустоту каталога распаковки — если каталог не пустой, создается подкаталог.

    Reply
  21. psamt1k

    Отличная вещь! спасибо автору!

    Reply
  22. Angeros

    Рэспект

    Reply
  23. ch1mera

    Респект, Отличная идея!

    Reply
  24. WellMaster

    Присоединяюсь ко всем респектующим.

    Reply
  25. WellMaster

    (1) kapustinag, «если конфигурация на поддержке с запретом изменений, то окно сравнения и объединения не появляется»

    Можно вызвать меню «Конфигурация — Сравнить конфигурации» даже в режиме поддержки без возможности объединений.

    По сути, обработка дублирует встроенные средства. Однако, плюс остается плюсом за пытливость ума.

    Reply
  26. bambr1975

    (25) К сожалению в режиме «Сравнить конфигурации» нет возможности сравнить конфигурацию (файл конфигурации) с файлом обновления. Если бы эта возможность была — тогда бы обработка действительно дублировала встроенные средства. Задача этой публикации — все-таки, в разборе внутреннего формата 1С и приведении его из вида «черного ящика» к «человекочитаемому виду».

    Reply
  27. WellMaster

    (26) Верно, этого я не учел. Спасибо за наводку.

    Reply
  28. Slach

    Отличная разработка, я правильно понимаю, что на ее основе можно попытаться написать распаковщик не в GUID папки а сопоставить GUID и нормальные имена в дереве метаданных?

    Скажите пожалуйста а дизайн форм и дизайн макетов отчетов, в каком виде хранится в 1С? это текстовые или полностью бинарные данные?

    Очень хочу написать распаковщик CF файлов в НОРМАЛЬНУЮ файловую структуру и интегрировать его с SVN

    Reply
  29. asg1975

    Автор молодец, что тут скажешь. Кладем в копилку!

    Reply
  30. bambr1975

    (28) макеты отчетов хранятся в том виде, в котором они понятны 1С. Их 9 видов: табличный документ (MOXEL), двоичные данные (base64), Active document (base64), HTML Документ (base64), текстовый документ (обычный текст), географическая схема, схема компоновки данных (xml), макет оформления компоновки данных, графическая схема. Вы можете сами посмотреть — инструментарий в обработке вполне достаточный: открыть в дереве метаданных двойным щелчком или найти в файлах — открыть в блокноте.

    Reply
  31. Slach
    bambr1975 пишет:

    (28) макеты отчетов хранятся в том виде, в котором они понятны 1С. Их 9 видов:

    а как хранятся макеты форм? тоже чтото похожее на MXL?

    Reply
  32. Magister

    (28) Сам давно о таком мечтаю… даже аналог V8Unpack писать начал — но не закончил.

    (32) Что-то страшное 🙂

    Выполните команду, например, ЗначениеВСтрокуВнутр(Новый ДеревоЗначений) — вот примерно такого вида структура, если мне память не изменяет. И так много чего хранится.

    Интересно, хоть кто-нибудь понял как разбирать и собирать эту структуру? Данная обработка парсит её регулярками, что для чтения нормально, но вот сохранять данные таким образом ну никак не получится…

    Reply
  33. bambr1975

    (33) есть V8Unpack, который НОРМАЛЬНО разбирает и собирает. Есть алгоритм вывода полученных из результатов разбора V8Unpack-ом данных в «человекочитаемом» виде. 1с-ка, в принципе все разобранное в отдельности и собранное воедино вполне нормально переваривает. Что хотелось бы еще сохранять?

    Reply
  34. Magister

    (34) V8Unpack распаковывает и упаковывает .cf. Но внутренние структуры — нет. Например вот форму по элементам разложить, ну или хотя бы получить всё не в виде файлов с именами в виде GUID-ов, а как дерево конфигурации — типа Документ -> Реквизиты -> Реквизит 1, Реквизит2, …

    То есть — интересует этот формат со скобочками фигурными. Полной его разборки и сборки я нигде не видел.

    Reply
  35. bambr1975

    (35) мат. часть: формой называется совокупность трех взаимосвязанных компонентов:

    1) собственно объекта «форма»

    2) программного модуля (при помощи его создаются различные свойства объекта, объект как бы управляется программным модулем)

    3) диалогового окна (которое визуализирует объект и организует взаимодействие с пользователем)

    Так вот, если посмотреть в состав файлов формы — их там как раз три и наберется — сам объект формы (файл без расширения), + папка с расширением, в которой будет т.н. «макет» (представление) формы и ее программный модуль (файлы form и module).

    Вы хотите, чтобы вам «представление» формы в виде дерева разобрали?

    В принципе, если действовать по инструкции http://infostart.ru/public/17108/ — и не вызывать форма.Открыть() — то то, что вы получите — можно передать на вход ну хотя бы этому — и получить вполне себе корректную разборку(только без заголовков элементов). А вот как быть с заголовками — я и сам не знаю. Но 1с — точно знает. В составе собранной сборки — открывает корректно.

    Reply
  36. Magister

    (36) Спасибо, но «мат.часть» я и так знаю. Под словом «Форма» я имел ввиду именно представление в вашей терминологии.

    За наводку на обработки спасибо, но это опять не то… это использование «черного ящика» 1С, и никак не поможет со сборкой/разборкой всей конфигурации в читаемый и легко редактируемый человеком вид.

    «Скобочки» — действительно можно получить через V8Unpack. А что дальше с ними делать?

    Reply
  37. bambr1975

    «Скобочки» — внутренний формат 1с — внутреннее представление массивов, структур, таблиц, деревьев значений и форм тоже. Вам это представление нужно где-то в отрыве от 1с? Если 1с знает, как из него получать данные, значит, за помощью надо обращаться к нему же. И «дальше что-то с ними делать» тоже с помощью этого замечательного метода ( ЗначениеИзСтрокиВнутр(ТекстСоСкобочками))

    Reply
  38. awa

    (38) Ну, вообще говоря, «скобочки» — это собственный 1С-овский способ сериализации объектов. В принципе, разобраться с их форматом особой сложности не представляет, просто это нудная кропотливая работа. Другое дело, я согласен, это почти никому не нужно. Но иногда приходится разбираться. Например, когда я делал декомпилятор запароленных модулей, то пришлось досконально разобраться с форматом файлов image, содержащих компилированный код модулей, и представляющих из себя все те же «скобочки». Благо, там формат совсем несложный. Или вот, описание таблиц в файле 1CD тоже хранится в таком формате «скобочек». Это описание можно увидеть в Tool_1CD.

    Так что, все зависит от поставленных целей.

    (37) Совет для желающих разбираться со «скобочками» не на основе регулярных выражений. Скобочки — это, по-сути, текстовое представление дерева. Открывающая фигурная скобка «{» — это начало дерева или ветки, запятая — это разделитель листьев дерева одного уровня, закрывающая фигурная скобка «}» — это конец ветки или дерева. Листьями могут являться:

    • вложенные деревья (ветки), начинаются с «{» и заканчиваются «}»;
    • строки (выделяются кавычками);
    • числа (целые или с десятичной точкой);
    • GUIDы;
    • ссылки вида <десятичное число>:<шестнадцатиричное 32х-значное число> (такую ссылку можно увидеть, например, в битой ссылке «Объект не найден…»);
    • числа с экспонентой (типа 3.67E12);
    • двоичные данные в формате base64 с префиксом «#base64:»;
    • двоичные данные в формате base64 с префиксом «#data:»;
    • двоичные данные в формате base64 без префикса.
    Reply
  39. Magister

    (38) Именно, нужно в отрыве от 1С. Точнее — преобразование его в что-либо более понятное.

    Цель — иметь возможность безболезненно хранить историю конфигурации в VCS, и — главное для чего нужен формат — иметь возможность легко разрешать конфликтующие изменения.

    Например — есть основная ветка, есть несколько параллельных веток для разработки, и ветка, которая будет в рабочей базе.

    Хочется иметь возможность легко переносить нужные изменения в рабочую базу, и в то же время иметь возможность неспешной разработки несколькими разработчиками слабо связанного функционала в отдельных ветках, и в то же время обновлять их ветки изменениями в других ветках.

    Примерно вот так: http://nakedstartup.com/2010/04/simple-daily-git-workflow

    Reply
  40. Magister

    (39) Вот! Спасибо за ваш комментарий!

    Примерно так я и думал, но до таких подробностей не дошел.

    А, если можно, подскажите — как понимать строки вида {5, ….}

    То есть когда первым элементом стоит число — иногда оно совпадает с количеством элементов, разделенных запятыми — но не всегда. Это просто совпадение, или закономерность?

    Reply
  41. bambr1975

    (41) Действительно, число — это не всегда количество элементов.

    Пример: сравнение форм базовой и проф конфигураций:



    А для представления формата «скобочек» в виде дерева удобно использовать обработку

    РазборФайлаОписания1С 81 (изначально выложенную в http://infostart.ru/public/15597/ ), приведенную к виду прикладного инструмента в составе http://infostart.ru/public/69976/ (доступна при нажатии на кнопку «Разобрать»).

    Reply
  42. balabani

    Вот спасибо! Очень нужна такая вещь в работе!

    Reply
  43. RFRDCT
    kapustinag пишет:

    Посмотреть, что там внутри, можно и в режиме Конфигуратора, запустив обновление. Ведь никто не заставляет двигаться дальше после окна сравнения и объединения.

    Получили окно сравнения и объединения — и анализируем, что есть в обновлении, и как со всем этим бороться.

    …А, я понял…Имеется в виду, что если конфигурация на поддержке с запретом изменений, то окно сравнения и объединения не появляется. Да, согласен, полезная вещь.

    На каких конфигурациях проверяли?

    При случае посмотрим

    Reply
  44. Attest

    Спасибо! Пригодится 100%!

    Reply
  45. Little-ann

    Отличная вещь! Все время хотелось чего-то такого, но руки не доходили…

    Reply
  46. bambr1975

    Дежавю?

    Конечно, если Вы, Maka2003, серьезно, то ответы были даны в (7) и (26). В любом случае, спасибо за проявленный интерес.

    Reply
  47. keln

    Прекрасная вещь. Очень признателен афтору за идею.

    Reply
  48. Il

    однозначно плюс!

    Reply
  49. BalVlad

    Спасибо. + поставил.

    Reply
  50. vkr

    «С помощью кольта и доброго слова вы сможете достичь

    гораздо большего, чем только одним добрым словом» (с) Аль Капоне

    Всегда уважаю тех, кто делает «кольты» — особенно для 1С… 🙂

    Reply
  51. РазДва

    Спасибо. отлчно

    Reply
  52. bambr1975

    (52) vkr, спасибо, прослезило… Хотя, ничего «кольтового» не задумывалось… Просто интересно было.

    Reply
  53. vkr

    (54) Под «кольтом» имеется в виду некий сервисный инструмент, который

    нормальные разработчики всегда прилагают к своим программным

    пакетам (если они достаточно серьезны и масштабны).

    За это и респект… 🙂

    Reply
  54. mihast

    Замечательная вещь. Спасибо !

    Reply
  55. SJR

    Если ли такая же вещь для управляемого приложения?

    Reply
  56. soulsteps

    SUPER!!!! + 100))

    Reply
  57. Key-Zed

    Не работает с cfu файлами выпущенными на платформе 8.3.6

    Reply
  58. bambr1975

    (59) Key-Zed, советую для файлов обновлений, предназначенных для платформы 8.3 и выше использовать обработку V8Reader (она является более функциональной и также содержит в себе возможность анализа файлов обновлений).

    Reply
  59. Akuji

    {ВнешняяОбработка.CFU_ридер.Форма.Форма.Форма(1394)}: Значение не является значением объектного типа (Submatches)

    ТипМакета=Match.Submatches(5);

    Reply

Leave a Comment

Ваш адрес email не будет опубликован. Обязательные поля помечены *