CFU-reader

Опубликовал bambr1975 в раздел Программирование - Инструментарий

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

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

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

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

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

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

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

Файлы

Наименование Файл Версия Размер Кол. Скачив.
CFU_ридер.epf
.epf 203,52Kb
14.11.11
509
.epf 203,52Kb 509 Скачать

См. также

Лучшие комментарии

39. awa 18.11.2011 00:10
(38) Ну, вообще говоря, "скобочки" - это собственный 1С-овский способ сериализации объектов. В принципе, разобраться с их форматом особой сложности не представляет, просто это нудная кропотливая работа. Другое дело, я согласен, это почти никому не нужно. Но иногда приходится разбираться. Например, когда я делал декомпилятор запароленных модулей, то пришлось досконально разобраться с форматом файлов image, содержащих компилированный код модулей, и представляющих из себя все те же "скобочки". Благо, там формат совсем несложный. Или вот, описание таблиц в файле 1CD тоже хранится в таком формате "скобочек". Это описание можно увидеть в Tool_1CD.
Так что, все зависит от поставленных целей.
(37) Совет для желающих разбираться со "скобочками" не на основе регулярных выражений. Скобочки - это, по-сути, текстовое представление дерева. Открывающая фигурная скобка "{" - это начало дерева или ветки, запятая - это разделитель листьев дерева одного уровня, закрывающая фигурная скобка "}" - это конец ветки или дерева. Листьями могут являться:
  • вложенные деревья (ветки), начинаются с "{" и заканчиваются "}";
  • строки (выделяются кавычками);
  • числа (целые или с десятичной точкой);
  • GUIDы;
  • ссылки вида <десятичное число>:<шестнадцатиричное 32х-значное число> (такую ссылку можно увидеть, например, в битой ссылке "Объект не найден...");
  • числа с экспонентой (типа 3.67E12);
  • двоичные данные в формате base64 с префиксом "#base64:";
  • двоичные данные в формате base64 с префиксом "#data:";
  • двоичные данные в формате base64 без префикса.
Ответили: (41)
# Ответить
52. vkr (файл скачал) 20.01.2012 13:16
"С помощью кольта и доброго слова вы сможете достичь
гораздо большего, чем только одним добрым словом" (с) Аль Капоне
Всегда уважаю тех, кто делает "кольты" - особенно для 1С... :)
Ответили: (54)
+ 1 [ awa; ]
# Ответить
8. CaSH_2004 05.11.2011 08:56
Отличная реализация, авансом плюсую, пока без надобности, но за хорошие инструменты не грех плюсануть.
+ 1 [ sound; ]
# Ответить

Комментарии

1. kapustinag 04.11.2011 20:59
Посмотреть, что там внутри, можно и в режиме Конфигуратора, запустив обновление. Ведь никто не заставляет двигаться дальше после окна сравнения и объединения.
Получили окно сравнения и объединения - и анализируем, что есть в обновлении, и как со всем этим бороться.
...А, я понял...Имеется в виду, что если конфигурация на поддержке с запретом изменений, то окно сравнения и объединения не появляется. Да, согласен, полезная вещь.
На каких конфигурациях проверяли?
Ответили: (2) (7) (9) (25)
# Ответить
2. Damian 04.11.2011 23:22
Если конфигурация на поддержке, то скорее всего в любом случае придется обновлять, т.к. полезностей в новом релизе чаще больше, чем нехорошестей. И управлять нехорошестями не получится.
Ну а если не на поддержке, то, как и писалось в (1).
Но автор, в любом случае, молодец. Дельная идея.
# Ответить
3. German (файл скачал) 05.11.2011 00:16
Респект, наконец то у кого-то дошли руки
# Ответить
4. Magister (файл скачал) 05.11.2011 00:38
Респект, плюс авансом.

//вот бы еще с хранилищем что-то сделать.... эх, мечты, мечты...
Ответили: (5)
# Ответить
5. German (файл скачал) 05.11.2011 00:45
(4) как альтернатива хранилищу http://main.1c-ei.ru/Home/help/object_config/depot
Ответили: (6)
# Ответить
6. Magister (файл скачал) 05.11.2011 00:51
(5) Знаю, видел - но это не то, что мне надо.
Хочется хранить всю историю в нормальной VCS, конкретно - git. А для этого нужна не только распаковка, но и обратная операция - сборка .cf.
--
По теме - посмотрел, к сожалению разбор метаданных выполняется регулярками... а я то уж понадеялся, что кто-то таки нормально понял их структуру...
Но и то хорошо :)
# Ответить
7. bambr1975 05.11.2011 08:54
(1) на РАЗЛИЧНЫХ типовых и нетиповых конфигурациях платформ 8.1 и 8.2. В каталоге распаковки неопределенных (не относенных к соответствующему объекту) файлов не остается. Это проверено-перепроверено (на этом ставился приоритет). Если и есть недоделки - они, скорее всего, касаются чего-то более мелочного. Обнаружится ошибка - сообщите.
# Ответить
8. CaSH_2004 05.11.2011 08:56
Отличная реализация, авансом плюсую, пока без надобности, но за хорошие инструменты не грех плюсануть.
+ 1 [ sound; ]
# Ответить
9. Boroda (файл скачал) 05.11.2011 11:28
Оригинально! Это что-то типа "Новое и изменённое в текущем релизе", но наглядно, в реальной форме. Интересно будет попроовать, может быть, и использовать в дальнейшем для экспресс-анализа, т.к. в обычном режиме используется же Конфигуратор (см. (1)). Спасибо за творческий подход.
+ 1 [ bambr1975; ]
# Ответить
10. sergnik 07.11.2011 22:13
плюсану, все достижения человеческого ума находят свое применение )) автору респект
# Ответить
11. che666 08.11.2011 17:58
+ автору респект за отличный инструмент
# Ответить
12. bambr1975 08.11.2011 19:25
Обнаружилась ошибка в работе программы при выводе дерева для обновлений версии 8.1. Обновил.
+ 1 [ awa; ]
# Ответить
13. napan 09.11.2011 09:07
Хороша, очень понравилась
Спасибо автору, незаменимая вещь в работе программиста
Зачет автору и плюс
# Ответить
14. rus128 09.11.2011 13:00
Отличная идея!
Автору респект!
# Ответить
15. Doomino (файл скачал) 10.11.2011 16:50
Вот спасибо! Очень нужна такая вещь в работе!
# Ответить
16. artspeed (файл скачал) 10.11.2011 17:53
На самом деле идея неплохая.
Смущает только то, что сразу при распаковке ошибка:

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

Применял CFU 10.3.14.4
# Ответить
17. bambr1975 10.11.2011 18:23
Только что попробовал на обновлении 10.3.14.4 для платформы 8.2.
Скриншот:
# Ответить
18. bambr1975 10.11.2011 18:34
а также в режиме сравнения:
# Ответить
19. NovSL (файл скачал) 11.11.2011 10:31
Вещь преотличнейшая.
# Ответить
20. bambr1975 12.11.2011 19:34
Изменил некоторые эргономические параметры обработки - почистил и упорядочил код, изменил раскраску строк сравнения, добавил возможность установки флажка для сохранения настроек, добавил проверку на пустоту каталога распаковки - если каталог не пустой, создается подкаталог.
# Ответить
21. psamt1k 14.11.2011 14:36
Отличная вещь! спасибо автору!
# Ответить
22. Angeros (файл скачал) 15.11.2011 12:31
Рэспект
# Ответить
23. ch1mera 15.11.2011 12:43
Респект, Отличная идея!
# Ответить
24. WellMaster 16.11.2011 11:17
Присоединяюсь ко всем респектующим.
# Ответить
25. WellMaster 16.11.2011 11:27
(1) kapustinag, "если конфигурация на поддержке с запретом изменений, то окно сравнения и объединения не появляется"
Можно вызвать меню "Конфигурация - Сравнить конфигурации" даже в режиме поддержки без возможности объединений.
По сути, обработка дублирует встроенные средства. Однако, плюс остается плюсом за пытливость ума.
Ответили: (26)
# Ответить
26. bambr1975 16.11.2011 12:12
(25) К сожалению в режиме "Сравнить конфигурации" нет возможности сравнить конфигурацию (файл конфигурации) с файлом обновления. Если бы эта возможность была - тогда бы обработка действительно дублировала встроенные средства. Задача этой публикации - все-таки, в разборе внутреннего формата 1С и приведении его из вида "черного ящика" к "человекочитаемому виду".
Ответили: (27)
# Ответить
27. WellMaster 16.11.2011 13:25
(26) Верно, этого я не учел. Спасибо за наводку.
# Ответить
28. Slach (файл скачал) 17.11.2011 09:24
Отличная разработка, я правильно понимаю, что на ее основе можно попытаться написать распаковщик не в GUID папки а сопоставить GUID и нормальные имена в дереве метаданных?

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

Очень хочу написать распаковщик CF файлов в НОРМАЛЬНУЮ файловую структуру и интегрировать его с SVN
Ответили: (30) (32) (33)
# Ответить
29. asg1975 (файл скачал) 17.11.2011 09:38
Автор молодец, что тут скажешь. Кладем в копилку!
# Ответить
30. bambr1975 17.11.2011 10:27
(28) макеты отчетов хранятся в том виде, в котором они понятны 1С. Их 9 видов: табличный документ (MOXEL), двоичные данные (base64), Active document (base64), HTML Документ (base64), текстовый документ (обычный текст), географическая схема, схема компоновки данных (xml), макет оформления компоновки данных, графическая схема. Вы можете сами посмотреть - инструментарий в обработке вполне достаточный: открыть в дереве метаданных двойным щелчком или найти в файлах - открыть в блокноте.
# Ответить
32. Slach (файл скачал) 17.11.2011 13:32
bambr1975 пишет:

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


а как хранятся макеты форм? тоже чтото похожее на MXL?
Ответили: (33)
# Ответить
33. Magister (файл скачал) 17.11.2011 13:57
(28) Сам давно о таком мечтаю... даже аналог V8Unpack писать начал - но не закончил.
(32) Что-то страшное :)
Выполните команду, например, ЗначениеВСтрокуВнутр(Новый ДеревоЗначений) - вот примерно такого вида структура, если мне память не изменяет. И так много чего хранится.
Интересно, хоть кто-нибудь понял как разбирать и собирать эту структуру? Данная обработка парсит её регулярками, что для чтения нормально, но вот сохранять данные таким образом ну никак не получится...
Ответили: (34)
# Ответить
34. bambr1975 17.11.2011 14:24
(33) есть V8Unpack, который НОРМАЛЬНО разбирает и собирает. Есть алгоритм вывода полученных из результатов разбора V8Unpack-ом данных в "человекочитаемом" виде. 1с-ка, в принципе все разобранное в отдельности и собранное воедино вполне нормально переваривает. Что хотелось бы еще сохранять?
Ответили: (35)
# Ответить
35. Magister (файл скачал) 17.11.2011 17:34
(34) V8Unpack распаковывает и упаковывает .cf. Но внутренние структуры - нет. Например вот форму по элементам разложить, ну или хотя бы получить всё не в виде файлов с именами в виде GUID-ов, а как дерево конфигурации - типа Документ -> Реквизиты -> Реквизит 1, Реквизит2, ...

То есть - интересует этот формат со скобочками фигурными. Полной его разборки и сборки я нигде не видел.
Ответили: (36)
# Ответить
36. bambr1975 17.11.2011 18:37
(35) мат. часть: формой называется совокупность трех взаимосвязанных компонентов:
1) собственно объекта "форма"
2) программного модуля (при помощи его создаются различные свойства объекта, объект как бы управляется программным модулем)
3) диалогового окна (которое визуализирует объект и организует взаимодействие с пользователем)
Так вот, если посмотреть в состав файлов формы - их там как раз три и наберется - сам объект формы (файл без расширения), + папка с расширением, в которой будет т.н. "макет" (представление) формы и ее программный модуль (файлы form и module).
Вы хотите, чтобы вам "представление" формы в виде дерева разобрали?
В принципе, если действовать по инструкции http://infostart.ru/public/17108/ - и не вызывать форма.Открыть() - то то, что вы получите - можно передать на вход ну хотя бы этому - и получить вполне себе корректную разборку(только без заголовков элементов). А вот как быть с заголовками - я и сам не знаю. Но 1с - точно знает. В составе собранной сборки - открывает корректно.
Ответили: (37)
# Ответить
37. Magister (файл скачал) 17.11.2011 20:51
(36) Спасибо, но "мат.часть" я и так знаю. Под словом "Форма" я имел ввиду именно представление в вашей терминологии.

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

"Скобочки" - действительно можно получить через V8Unpack. А что дальше с ними делать?
Ответили: (39)
# Ответить
38. bambr1975 17.11.2011 21:35
"Скобочки" - внутренний формат 1с - внутреннее представление массивов, структур, таблиц, деревьев значений и форм тоже. Вам это представление нужно где-то в отрыве от 1с? Если 1с знает, как из него получать данные, значит, за помощью надо обращаться к нему же. И "дальше что-то с ними делать" тоже с помощью этого замечательного метода ( ЗначениеИзСтрокиВнутр(ТекстСоСкобочками))
Ответили: (39) (40)
# Ответить
39. awa 18.11.2011 00:10
(38) Ну, вообще говоря, "скобочки" - это собственный 1С-овский способ сериализации объектов. В принципе, разобраться с их форматом особой сложности не представляет, просто это нудная кропотливая работа. Другое дело, я согласен, это почти никому не нужно. Но иногда приходится разбираться. Например, когда я делал декомпилятор запароленных модулей, то пришлось досконально разобраться с форматом файлов image, содержащих компилированный код модулей, и представляющих из себя все те же "скобочки". Благо, там формат совсем несложный. Или вот, описание таблиц в файле 1CD тоже хранится в таком формате "скобочек". Это описание можно увидеть в Tool_1CD.
Так что, все зависит от поставленных целей.
(37) Совет для желающих разбираться со "скобочками" не на основе регулярных выражений. Скобочки - это, по-сути, текстовое представление дерева. Открывающая фигурная скобка "{" - это начало дерева или ветки, запятая - это разделитель листьев дерева одного уровня, закрывающая фигурная скобка "}" - это конец ветки или дерева. Листьями могут являться:
  • вложенные деревья (ветки), начинаются с "{" и заканчиваются "}";
  • строки (выделяются кавычками);
  • числа (целые или с десятичной точкой);
  • GUIDы;
  • ссылки вида <десятичное число>:<шестнадцатиричное 32х-значное число> (такую ссылку можно увидеть, например, в битой ссылке "Объект не найден...");
  • числа с экспонентой (типа 3.67E12);
  • двоичные данные в формате base64 с префиксом "#base64:";
  • двоичные данные в формате base64 с префиксом "#data:";
  • двоичные данные в формате base64 без префикса.
Ответили: (41)
# Ответить
40. Magister (файл скачал) 18.11.2011 00:15
(38) Именно, нужно в отрыве от 1С. Точнее - преобразование его в что-либо более понятное.
Цель - иметь возможность безболезненно хранить историю конфигурации в VCS, и - главное для чего нужен формат - иметь возможность легко разрешать конфликтующие изменения.
Например - есть основная ветка, есть несколько параллельных веток для разработки, и ветка, которая будет в рабочей базе.
Хочется иметь возможность легко переносить нужные изменения в рабочую базу, и в то же время иметь возможность неспешной разработки несколькими разработчиками слабо связанного функционала в отдельных ветках, и в то же время обновлять их ветки изменениями в других ветках.

Примерно вот так: http://nakedstartup.com/2010/04/simple-daily-git-workflow
# Ответить
41. Magister (файл скачал) 18.11.2011 00:19
(39) Вот! Спасибо за ваш комментарий!
Примерно так я и думал, но до таких подробностей не дошел.
А, если можно, подскажите - как понимать строки вида {5, ....}
То есть когда первым элементом стоит число - иногда оно совпадает с количеством элементов, разделенных запятыми - но не всегда. Это просто совпадение, или закономерность?
Ответили: (42)
# Ответить
42. bambr1975 18.11.2011 07:35
(41) Действительно, число - это не всегда количество элементов.
Пример: сравнение форм базовой и проф конфигураций:

А для представления формата "скобочек" в виде дерева удобно использовать обработку
РазборФайлаОписания1С 81 (изначально выложенную в http://infostart.ru/public/15597/ ), приведенную к виду прикладного инструмента в составе http://infostart.ru/public/69976/ (доступна при нажатии на кнопку "Разобрать").
# Ответить
43. balabani 20.11.2011 02:59
Вот спасибо! Очень нужна такая вещь в работе!
# Ответить
44. RFRDCT (файл скачал) 20.11.2011 17:41
kapustinag пишет:

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

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

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

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

При случае посмотрим
# Ответить
45. Attest 21.11.2011 14:55
Спасибо! Пригодится 100%!
# Ответить
46. Little-ann 22.11.2011 10:10
Отличная вещь! Все время хотелось чего-то такого, но руки не доходили...
# Ответить
48. bambr1975 25.11.2011 10:59
Дежавю?
Конечно, если Вы, Maka2003, серьезно, то ответы были даны в (7) и (26). В любом случае, спасибо за проявленный интерес.
# Ответить
49. keln 01.12.2011 01:13
Прекрасная вещь. Очень признателен афтору за идею.
# Ответить
50. Il 02.12.2011 09:00
однозначно плюс!
# Ответить
51. BalVlad (файл скачал) 20.01.2012 09:49
Спасибо. + поставил.
# Ответить
52. vkr (файл скачал) 20.01.2012 13:16
"С помощью кольта и доброго слова вы сможете достичь
гораздо большего, чем только одним добрым словом" (с) Аль Капоне
Всегда уважаю тех, кто делает "кольты" - особенно для 1С... :)
Ответили: (54)
+ 1 [ awa; ]
# Ответить
53. РазДва 20.01.2012 14:42
Спасибо. отлчно
# Ответить
54. bambr1975 21.01.2012 12:33
(52) vkr, спасибо, прослезило... Хотя, ничего "кольтового" не задумывалось... Просто интересно было.
Ответили: (55)
# Ответить
55. vkr (файл скачал) 23.01.2012 07:53
(54) Под "кольтом" имеется в виду некий сервисный инструмент, который
нормальные разработчики всегда прилагают к своим программным
пакетам (если они достаточно серьезны и масштабны).
За это и респект... :)
# Ответить
56. mihast 26.03.2014 20:05
Замечательная вещь. Спасибо !
# Ответить
57. SJR 11.11.2014 10:17
Если ли такая же вещь для управляемого приложения?
# Ответить
58. soulsteps (файл скачал) 15.01.2015 16:31
SUPER!!!! + 100))
# Ответить
59. Key-Zed (файл скачал) 03.07.2015 13:59
Не работает с cfu файлами выпущенными на платформе 8.3.6
Ответили: (60)
# Ответить
60. bambr1975 03.07.2015 14:24
(59) Key-Zed, советую для файлов обновлений, предназначенных для платформы 8.3 и выше использовать обработку V8Reader (она является более функциональной и также содержит в себе возможность анализа файлов обновлений).
# Ответить
Внимание! За постинг в данном форуме $m не начисляются.
Внимание! Для написания сообщения необходимо авторизоваться
Текст сообщения*
Прикрепить файл






IE 2016