Автоматизация труда программиста. Библиотека прикладных функций

Программист - это человек, непрерывно принимающий решения. Написание кода не является процессом принятия решения - это всего лишь трансляция ваших желаний. Если вас периодически тяготит написание сотен строк кода ради решения задач, то прошу обратить внимание. Данный продукт позволит существенно сократить время на рутинные операции при разработке. За счет библиотечной реализации сокращается объём кода, а его читаемость повышается. К библиотеке прилагается документация API и шаблоны кода для наиболее популярных методов.

Арт.: 1421272

ЯДумаю.png
ЯДумаю.png

18000 руб.

4200 руб.

7500 руб.

 
 Обзор наиболее крупных и "вкусных" блоков функциональности

 I. Запросы:
1. Существующая функциональность:

 - Универсальные, легко переопределяемые запросы к физическим и виртуальным таблицам.
 - Конструктор параметров запросов. Отборы, поля, сортировки, итоги и др. Возможность слияния и/или дополнения нескольких параметров (например, дефолтные и пользовательские).
 - Автогенерируемые запросы. Декларативные запросы к любым физическим и виртуальным таблицам с любыми отборами.
 - Автогенерируемые запросы. Возможность запроса по нескольким таблицам одного класса (документы, справочники и.т.п.).
 - Повторное использование единожды написанных запросов. Конструктор позволяющий получить результат запроса или сам запрос на основании существующего шаблона запроса и переданных параметров.
 - Возможность построения единого интерфейса обращения к данным, с использованием прокси поддерживающего автогененируемые, перепределенные разработчиком и произвольные запросы через один и тот же интерфейс. То есть обращение к данным всегда осуществляется через одну и ту же точку входа, будь то поиск документа, получение стандартной или переопределенной выборки из таблицы БД или абсолютно произвольного запроса по его имени.
 - Удобная опция по помещению результата запроса в контейнер (РезультатЗапроса, ТаблицаЗначений, ДеревоЗначений, Массив, СписокЗначений, Структура). По умолчанию включена в проксируемые запросах, но доступна для использования и независимо.


2. Планы развития (уже есть решения в тестовых ветках, но не было большой потребности в доведении до релиза):
а. Пакетные запросы.
б. Запрос-объединение и/или пакетный запрос с независимыми наборами таблиц и параметров.

II. Расширение классов ДокументОбъект, справочникОбъект, ПВХОбъект и частично их менеджеров.
1. Существующая функциональность:
 - Улучшенный поиск взамен функций НайтиПо... Поддерживает сложные отборы.
 - Улучшенный поиск взамен функции Выбрать(). Поддерживает более сложные отборы, позволяет более тонко настраивать результат запроса. Для деталей см. параграф I
 - Новый конструктор для инициализации новых объектов как при создании, так и по ссылке. При создании сразу можно передать данные заполнения.
 - Упрощенный интерфейс для работы с БД. Функции Провести(), Распровести(), ПометитьНаУдаление(), СнятьПометкуНаУдаление() возвратом флага успеха/неуспеха операции
д. Логирование ошибок. Возможность переопределения формата записи ошибки в ЖР (при инициализации объекта). Также, текст исключения может быть получен для иных операций. 
 - Безопасная запись с соблюдением правил работы с транзакций. Функциональность по умолчанию работает так как заложено платформой, но предусмотрено гибкое переопределение поведения объекта в случае ошибок. Например не бросать исключение если запись не удалась, а пробросить информацию об исключении в вызывающий код или не регистрировать ошибку в ЖР, а лишь сообщить о ней пользователю.
 - Расширение событийной модели. Добавлена возможность обработки событий: ДоНачалаТранзакции, ПослеФиксацииТранзакции, ПослеОтменыТранзакции.
 - Мелкие удобства типа встроенной проверки наличия реквизита в объекте и изначально заполненного реквизита ссылка сразу после инициализации объекта.

III. Класс менеджер для упрощенной работы с внешними обработчиками.
 1. Параметризуемая инициализация с учетом опций безопасного режима и защиты от опасных действий. 
 2. Ведение списка инициализированных объектов
 3. Выборочная или полная деструкция инициализированных менеджером объектов.

IV. Движение по регистрам.

 1. Движение по регистрам накопления без описания движений в документе. В обработке проведения вызывается функция ДвиженияПоРегистрам, куда передаются метаданные регистра, таблица движений (как правило это выгрузка из ТЧ).
 2. Движения можно выполнять в режиме эмуляции. В этом случае движения не будут записаны, а вернутся в виде таблицы значений.
 3. Автоматически накладывается управляемая блокировка на регистр. Если блокировка недоступна, то накладывается автоматическая блокировка средствами платформы.
 4. Для регистров остатков предусмотрен подбор и контроль отрицательных остатков по набору измерений.
 5. При необходимости, алгоритм подбора остатков может быть переопределен для выбранных регистров. В данном случае, специализированный класс-расширение для менеджера регистра накопления, выполнит не собственный универсальный метод, а запросит переопределенный регистр и вернет полученный результат. Подробнее см. параграф V.

V. Расширение классов РегистрНакопленияМенеджер и РегистрСведенийМенеджер.
1. Существующая функциональность:
 - Возможность получить срезы данных со сложным отбором, как на определенную дату/момент времени, так и актуальные.
 - Возможность выполнения движений по регистру с подбором остатков при списании (для РН с видом остатки). Подбор производится по классической схеме с контролем остатков до движения, при этом можно переопределить поведение выбранного регистра и отключить контроль. При подборе автоматически подбираются измерения и ресурсы.
 - Возможность для гибкого переопределения. Может быть переопределено всё - от текста запроса остатков (по-умолчанию генерится автоматически), до набора измерений и параметров списания ресурсов. Переопределение осуществляется созданием соответствующего API в переопределяемом регистре. Интерфейс создаётся через прилагаемый к библиотеке каталог шаблонов без написания кода вручную.
2. Планы развития (уже есть решения в тестовых ветках, но не было большой потребности в доведении до релиза):
 - Добавить поддержку прочих регистров, по которым могут выполняться движения. Приоритет реализации: регистры бухгалтерии, регистры расчета.

VI Динамическая подмена кода.
1. Существующая функциональность:
 - Возможность подмены модулей объектов, менеджера и и.т.д. Как целиком так и фрагментарно (здесь потребуются точки входа в отдельных методах)
 - Подмена реализуется через создание точек входа в часто изменяемых участках кода. При первом обращении выполняется правка, создание точки входа и обновление. При повторном обращении код подменяется без обновления.
 - В случае получения отчетов/обработок через единый метод подсистемы, точки входа не нужны.
 - При следующем (плановом) обновлении, замененный код, снова будет выполняться из "родного" источника, а не из внешнего обработчиками. То есть не нужно беспокоиться о том, когда и в каких объёмах будет обновление. Достаточно, чтобы велся версионный контроль в репозитории конфигурации. Принцип работы подсистемы - "подменил и забыл", по аналогии с системами управляемого вооружения класса "выстрелил и забыл".

VII Расширение класса таблиц. Преимущественно ТЗ, но в ряде случаев поддерживаются все возможные таблицы от дерева значений до результата запроса и табличной части.
1. Существующая функциональность:
 - Конструкторы для новой пустой ТЗ по результату запроса и по метаданным.
 - Конструктор кросс-таблицы из обычной таблицы с возможностью выбора списка измерений строк и целевого показателя.
 - Конструктор по выборке. В отличие от конструктора по результату запроса позволяет сформировать или дополнить таблицу по части данных (если выборка с итогами), а не по всему результату запроса.
 - Сложение/вычитание таблиц по аналогии со сложением и вычитанием матриц, но с поддержкой матриц разного размера, где матрицы приводятся к единому размеру виртуально по набору измерений.
 - Добавление недостающих и расширение несуществующих методов как то: отбор по сложному отбору, дополнение таблицы не только строками но и колонками, итоги по отбору, удаление по отбору, нумерация, индексация, конвертация в массив массивов и обратно, вывод в табличный документ и др.
 - Объединение таблиц "как в запросе" с объединением типов колонок. Добавление колонки с объединением типов, если колонка уже существует.

VIII Каталог шаблонов для использования наиболее популярной функциональности. Помимо готового кода содержит примеры реализации с подробными комментариями.

Библиотека позволяет решать комплекс проблем за счет нескольких стратегических решений, которые вы можете принять и осуществить с использованием библиотеки:

I Стандартизация и сокращение объема кода. Повышение его предсказуемости и безопасности

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

- За счет сокращения объёма кода, который необходимо написать

- За счет сокращения объёма кода, который необходимо перечитать хотя бы раз (в реальной разработке бывает намного чаще)

- За счет стандартизации методологии разработки, что сокращает число обидных ошибок, когда забыл обработать исключение или неверно откатил транзакцию.

 
 Пример I-1. Сравнение способов записи группы объектов.

 

 
 Пример I-2. Движения по любому регистру накопления для любого документа в 1-2 строки

 

II Сокращение числа зависимостей между интерфейсами и архитектурой БД. 

Отказ от десятков, а то и сотен зависимостей между кодом и архитектурой, за счет повторного использования текстов запроса или их автоматической генерации. Это также позволяет экономить на поддержке текстов запросов.

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

В руках опытного специалиста, библиотека станет надежным помощником в деле изоляции интерфейсов от архитектуры БД. Как следствие - повышение гибкости программы и облегчение её сопровождения.

Например, можно написать ровно одну функцию возвращающую результат запроса по какой-либо физической таблице. При этом, текст запроса писать не обязательно. Появится новое поле в таблице или переименуется старое - не беда. Не нужно переписывать все тексты. Их или нет, или он хранится в одном месте. Там где список полей определен явно, потребуется внести изменения. остальные запросы автоматически добавят новое поле в выборку.

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

Фактически, это является реализацией на 1с MVC паттерна (MVC - ссылка вики) с предусмотренной защитой от наиболее распространенной ошибки применения паттерна - толстые контроллеры.

 

 
 Пример II-1. Запросы данных

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

При этом, все запросы формируемые через специальные интерфейсы (Прокси-запросы, модули менеджеров, движения по регистрам), являются переопределяемыми "из коробки". В данном случае, если не существует определенного разработчиком текста запроса для физической или виртуальной таблицы, то он сгенерируется автоматически. Если же потребности изменятся, то и текст запроса можно создать самому, добавив недостающие данные. Предыдущие обращения, при этом не потребуется модифицировать - они продолжат работать, но результат будут получать не из автосгенерированного, а из определенного разработчиком текста запроса.

 
 Решение 1. Запрос данных из физической таблицы (справочники, документы, регистры и.т.д.)
 
 Решение 2. Запрос данных из нескольких физических таблиц одного класса (несколько документов или справочников и.т.д.)
 
 Решение 3. Запрос данных из виртуальной таблицы (остатки, обороты, срез последних и.т.д.)
 
 Решение 4. Запрос данных с повторным использованием текста запроса
 
 Решение 5. Поиск ссылок по отбору

 

 
 Пример II-2. Регистрация исключений

 

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

Ассортимент методов по работе со стандартными коллекциями представлен в той мере, которые требовались для решения прикладных задач. Это преимущественно или создание недостающего функционала или вольное/невольное воспроизведение в случаях интеграций в нетиповые конфигурации не использующих БСП. Некоторые методы, могут показаться знакомыми по БСП, но это или переопределение недостаточно функциональных методов или результат конвергентной эволюции. Некоторые методы в этой библиотеке ровесники первых версий БСП.

 
 Пример III-1. Работа с таблицами
 
 Конструкторы таблиц
// по другой таблице, включая результаты запроса, деревья и табличные части
ИсключаемыеКолонки = "Сумма";
Результат = Таблицы_ауф.ТаблицаЗначенийПоРезультатуЗапроса(РезультатЗапроса,, ИсключаемыеКолонки);

// по метаданным
ВидыРеквизитов = "Измерения,Ресурсы"; //если не заполнять, то сформируется по всем доступным полям физической таблицы
МетаОбъект = Метаданные.РегистрыНакопления.ОстаткиТоваров;
Результат = Таблицы_ауф.ТаблицаЗначенийПоМетаданным(МетаОбъект, ВидыРеквизитов);

// формирование кросс таблицы по ТЗ, ТЧ, данным формы
ИзмеренияСтрок = "Клиент,Договор";
ИзмерениеКолонок = "Организация";
Показатель = "Сумма";
Результат = Таблицы_ауф.КроссТаблица(Таблица, ИзмеренияСтрок, ИзмерениеКолонок, Показатель);

// формирование таблицы путём объединения других таблиц. Количество не ограничено.
// Работает как Объединить в запросе
Таблицы = МассивТаблицДляОбъединения();
ТолькоУникальныеЗаписи = Истина;
Результат = Таблицы_ауф.КроссТаблица(Таблицы , ТолькоУникальныеЗаписи);

 

 
 И много других полезных методов расширяющих возможности таблиц

 

 
 Пример III-2. Работа с массивами

 

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

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

 

IV Облегчение тестирования и отказ от динамического обновления.

 

Подсистема динамической подмены кода идет особняком. Это единственная функциональность, которую я не рекомендую использовать. Разрабатывалась она для тестирования, и неудобства обновления конфигурации в процессе тестирования целиком . Но, видимо, это то самое нечаянно гениальное решение, которое пришлось по вкусу всем кому пришлось с ней работать. Данная подсистема позволяет обеспечить простой и прозрачный способ отказа от динамических обновлений без отказа от контроля версий и централизованной разработки. При использовании в продуктиве, подсистема требует известной степени организации процессов и самодисциплины, но об это ниже. Сейчас же расскажу, о возможностях:

 

Загрузка заменяемого обработчика, выполяется через специальную форму. Сам обработчик это обычная внешняя обработка содержащая необходимые для режима симуляции (подмены) свойства и методы. Подсистема контролирует актуальность замененного обработчика, и когда наконец-то пройдет обычное обновление, то вызов будет производиться уже для настоящего обработчика.

 

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

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

При этом обеспечивается версионная целостность данных и плановое обновление, когда оно всё таки произойдет, не сломает внеочередные заплатки, а дополнит их.

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

 

ВАЖНО! Позитивные свойства данной системы обеспечиваются версионированием данных и централизованной разработкой. Если данный механизм будет использоваться бессистемно в рамках парадигмы "хренак-хренак и в продакшн", то данная подсистема станет отличным способом отстрелить себе ногу.

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

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

 
 Пример замены по условию
// Например для тестирования алгоритма или для обхода конкретной ошибки в конкретном случае
Если НужноЗаменитьМодуль Тогда 
	ШифрМодуля = Метаданные.ОбщиеМодули.ОбщегоНазначения.ПолноеИмя();
	РабочийМодуль = ЗаменяемыйКод.ОбъектНаВыполнение(ШифрМодуля, ОбщегоНазначения);
Иначе
	РабочийМодуль = ОбщегоНазначения_ауф;
КонецЕсли;

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

// ВАЖНО!!! Рекомендуется пользоваться прилагаемыми к поставке шаблонами текста

 

 

V Совместимость

 
 Старые версии платформы

 Библиотека работает даже на 8.1. На более старых нет опыта интеграции.

Для раритетных версий платформы в комплект поставки включены опциональные модули обеспечивающие совместимость.

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

 
 Использование модальности

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

 

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

Причины купить

Даже полный комплект поставки для одного программиста окупится максимум через месяц использования. Только за счет экономии времени. Кумулятивный эффект по сокращению числа зависимостей и объёмов кода будет действовать дольше, но тоже будет давать позитивный эффект.

Реализованная в библиотеке поддержка правильного MVC паттерна позволит реализовать гибкие программные решения.

Сравнение версий

Библиотека никогда не планировалась и не позиционировалась как замена БСП. В некоторых моментах они могут пересекаться в функциональности, но в целом у них разное назначение. БСП содержит в себе набор готовой функциональности, снабженнной служебным кодом, который тоже можно использовать. Библиотека UFL содержит в себе шаблоны-кирпичики из которых вы можете создавать собственные решения. Помимо этого в библиотеку заложена определенная идеология архитектуры с изоляцией данных, кода и пользовательских интерфейсов друг от друга. Компактность библиотеки позволяет разворачивать небольшие решения не беспокоясь об объёме и быстродействии базы данных.

Статистика:
Просмотры 14570
Загрузки 5
Рейтинг 17
Создание 16.04.21 16:00
Обновление 24.08.23 12:09
№ Публикации 1421272
Характеристики:
Теги
Рубрики Инструментарий разработчика
Кому Программист
Тип файла Конфигурация (md, cf)
Платформа Платформа 1С v8.3 ,
Платформа 1C v8.2 ,
Платформа 1С v8.1
Конфигурация Конфигурации 1cv8
Операционная система Не имеет значения
Страна Не имеет значения
Отрасль Не имеет значения
Налоги Не имеет значения
Вид учета Не имеет значения
Доступ к файлу Платные (руб)
Код открыт Да
1. sashocq 22.04.21 16:20 Сейчас в теме
Вообще непонятно для чего это.
Несколько функций, на разбор которых что они делают и для чего нужны нужно потратить времени не меньше, чем на написание.

Половина функций работы с массивами я сразу вижу, что они уже есть в БСП.

А ещё есть какая-то полная поставка аж за 15 тыщ. И упоминается какая-то загадочная "динамическая подмена кода", что это?

Данная подсистема позволяет обеспечить простой и прозрачный способ отказа от динамических обновлений без отказа от контроля версий и централизованной разработки

Это о чём?

Позитивные свойства данной системы обеспечиваются версионированием данных и централизованной разработкой

Это для кого написано??? Для бухов или для разработчиков всё же?

Может, конечно, это что-то крутое. Но из описания совершенно непонятно что это. + наверное кто-то поставил просто чтобы в закладки внести.
RustIG; sleemp; +2 Ответить
2. Техподдержка 22.04.21 16:46
(1)
Здравствуйте, благодарю, что не прошли мимо.

Вообще непонятно для чего это.
- в анонсе и в названии статьи об этом и написано. Для сокращения издержек на воспроизведение и сопровождение часто используемых алгоритмов

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

Половина функций работы с массивами я сразу вижу, что они уже есть в БСП.
- не сомневаюсь. Но ряд функций в этой библиотеке появились как замена БСП-шных или дополнение. Часть возможно воспроизвелись синхронно. Да и не везде БСП можно применить с её немалым размером и сильной связностью подсистем между собой.

А ещё есть какая-то полная поставка аж за 15 тыщ
почему аж? Это окупится максимум за месяц, в зависимости от специфики работы.

И упоминается какая-то загадочная "динамическая подмена кода", что это?
- альтернатива динамическому обновлению.

Это о чём?
дело в том, что на практике не раз встречал различные кустарные методики подобные этой, но не обеспечивающие контроль версий, бесшовность и вообще беспроблемность при обычных обновлениях и.т.д.

Это для кого написано??? Для бухов или для разработчиков всё же?
вообще для программистов. С первых до последних слов. Программист является даже первым словом в данной публикации.

Спасибо за критику, Вы обратили внимание на слабые места в подаче. Попробую переработать. Но в любом случае детально описать библиотеку это то же самое что написать её повторно. Именно для этого я и предложил сомневающимся сеанс демонстрации возможностей:

Если вы хотите больше иллюстраций, то в комментариях можете оставить задание, реализация которого вам не нравится и вы бы хотели посмотреть, как с данной задачей можно справиться, используя библиотеку.
3. user1703622 07.04.23 17:21 Сейчас в теме
Здравствуйте а есть возможность увидеть больше подробностей по части динамической подмены кода? Пытался придумать как ей воспользоваться, но что-то из шаблонов кода мне не стало понятнее как этот функционал правильно и где применять возможно.

Например хотел попробовать подменить форму обработки из внешней сходной обработки, но по коду шаблона нужно ловить событие формы "Перед открытием" которого в тонком клиенте нет.

Еще вопрос как эту динамическую подмену применять правильно? Т.е. в теории мы должны пихать внешнюю обработку с измененным кодом для тестирования доработок и при этом нам не надо будет по 100 раз обновлять базу для тестов. Предположим я хочу подменить процедуру в модуле формы обработки или документа. Как это правильно делается?

Для других может быть тут очевидно применение библиотеки динамической подмены, но не для меня. Если сможете описать несколько хороших примеров живых, буду очень признателен, потому что лаконичность в описании это хорошо, но без живых примеров вообще непонятно как ее правильно применять
4. Техподдержка 10.04.23 10:20
(3) Примеры подмены модуля целиком

Подмена отдельной процедуры так же доступна, но придётся создавать отдельный идентификатор. Обычно это полное имя плюс имя процедуры.
Далее так же подменяете объект и вызываете нужную процедуру. Разница в том, что в подменяющем объекте будет только эта процедура. остальной код не будет затронут
Прикрепленные файлы:
5. user1703622 10.04.23 16:16 Сейчас в теме
(4) 1. Подскажите пожалуйста в какие события нужно вклиниваться у исходного объекта для выполнения подмены?

С общим модулем понятна подмена, но не стала понятнее подмена кода отдельной процедуры для других объектов (справочников, документов).

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

2. Не очень понятно как мы должны достигать эффекта, что мы один раз сделали подмену и можем без динамического обновления делать эксперименты с кодом?

3. Еще если не ошибаюсь должна быть справка к этой библиотеке, только не смог ее нигде найти. Не подскажете куда помещена справка по этой библиотеке?

Вопрос живых примеров остается. Лучше один рабочий пример правильной и полезной подмены кода, чем обрывочная информация
6. Техподдержка 11.04.23 15:39
(5)
1. Оптимальнее подменять целиком сам объект из вызывающего его кода. Если хотите подменять форму "на лету", то ПриОткрытии выполняете проверку подмены, если подмена выполнена, то формируете параметры и открываете форму внешней обработки, эмулирующей подменяемый объект.

2. Не понял вопроса. Если один раз сделали - то обновление уже не нужно. Можно ещё что-то поправить и снова подменить - браться будет объект с актуальной версией. Причем, при равенстве версий запустится встроенный объект.

3. Поищу примеры подмены самой формы, если примеры с подменой объекта целиком не устраивают. Это не совсем удобная и стандартная практика, но если настаиваете, конечно покажу. Но нужно действительно поискать по репозиториям
7. user1703622 11.04.23 16:20 Сейчас в теме
(6)
1. Так при создании на сервере мы не можем открыть форму другого объекта, это можно на клиенте только делать или мы параметры потом в событие при открытии передавать должны?

2. Тут скорее мы не совсем правильно друг друга понимаем по поводу подмены объекта. В моем понимании мы должны вклиниваться в исходный объект конфигурации через нашу внешнюю обработку именуемую обработчиком и в ней творить все наши эксперименты. Мое предположение в использовании было в том, чтобы мы могли например подменить процедуру например документа и выполнять свои эксперименты. Правда если вас правильно понял то тут получается, что мы должны на каждую процедуру создавать свой обработчик.

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

У меня видимо неправильное понимание работы библиотеки подмены, поэтому я не очень вообще понимаю ее применение и плюсы использования.

3. Мне не очень принципиально подменять конкретно форму на самом деле. Мне просто хочется начать применять эту библиотеку, но я вообще ее смысл и плюсы не вижу из текущей информации. Если приведете понятный пример, когда эта подмена нас может сильно выручить, буду признателен.
Что-то из разряда: "если бы мы пытались сделать то-то без библиотеки нам бы пришлось делать так а благодаря подмене мы можем упростить себе работу сделав так".

Потому что из текущей информации вообще непонятно где, как, когда применять эту подмену и какие плюсы по факту мы от этого получаем
8. Техподдержка 11.04.23 16:41
(7)

Посмотрите на примеры кода в (4)

Типовой кейс:
1. Протестировать какую-то функциональность можно только на определённом сервере, где развёрнуто тестовое окружение имитирующее прод.
2. Пишем код, и вставляем точки входа для подмены для того кода, который не смогли протестировать или в котором не уверены.
3. Обновляем базу. Тестим, смотрим ошибки. Если находим, то вносим правки. Если правки внесены в объект на который мы внесли точки входа, то подменяем его целиком и продолжаем тестирование до успешного завершения.
4. Не забываем соблюдать правило - правки вносятся сразу в репозиторий и оттуда выгружаются уже для замены.
5. На выходе без обновлений, получаем проверенную функциональность, которую смело можем запускать в прод.

Хардкорный кейс:
Всё то же самое, но это не тестовый сервер, а прод и мы рассчитываем исправить ошибки до того как они станут фатальными, причем без обновлений.
9. Техподдержка 11.04.23 16:45
(7)

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


Потому что у вас получится только заменить конкретный запускаемый интерактивно объект. Для более сложных случаев, когда используются разнообразные общие модули, другие объекты, много уровней вложенности итд. Здесь не получится просто взять и скопировать
10. RustIG 29.12.23 09:29 Сейчас в теме
(0) видеообзор выложите - иначе не понятно что вы разработали

Оставьте свое сообщение

См. также

Infostart Toolkit: Инструменты разработчика 1С 8.3 на управляемых формах

Набор инструментов программиста и специалиста 1С для всех конфигураций на управляемых формах. В состав входят инструменты: Консоль запросов, Консоль СКД, Консоль кода, Редактор объекта, Анализ прав доступа, Метаданные, Поиск ссылок, Сравне...

10000 руб.

Infostart PrintWizard - создание и редактирование печатных форм в 1С 8.3

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

18000 руб.

Infostart УДиФ: Управление данными и формами 1С

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

10000 руб.

PowerTools

Универсальный инструмент программиста для администрирования конфигураций. Сборник наиболее часто используемых обработок под единым интерфейсом.

3600 2304 руб.

SALE! 36%

Бустер Конвертации данных 3 (Infostart Toolkit)

Расширение для конфигурации “Конвертация данных 3”. Добавляет подсветку синтаксиса, детальную контекстную подсказку, глобальный поиск по коду.

15000 руб.

Многопоточность. Универсальный «Менеджер потоков» 2.1

Восстановление партий или взаиморасчетов, расчет зарплаты, пакетное формирование документов или отчетов - теперь все это стало доступнее. * Есть желание повысить скорость работы медленных алгоритмов! Но... * Нет времени думать о реализа...

5000 руб.

[ЕХТ] Фреймворк для Расширений 1С

"Фреймворк для Расширений 1С" это универсальное и многофункциональное решение, упрощающее разработку и поддержку создаваемых Расширений. Поставляется в виде комплекта из нескольких Расширений с открытым исходным кодом. Работает в ...

3000 руб.

Выполнение произвольного кода или запроса с параметрами через Web-сервис (замена COM-подключений)

В процессе работы в 1С часто возникает потребность получить данные из другой базы.  Обычно это делается через COM-соединение, и время выполнения запроса при этом оставляет желать лучшего. В данной публикации представлено универсальное реш...

2400 руб.

Конвертер данных 1С в JSON и обратно

Механизм для однопальцевой конвертации произвольных данных 1С-формата в JSON и обратно. Продукт полезен, если вам приходится тратить время на настройку типовой конвертации данных в JSON или вы знаете, что это потребует значимых затрат на ра...

4800 руб.