gifts2017

TestIB8x - Разное - глСообщить() - приглашение к обсуждению

Опубликовал brix8x (brix8x) в раздел Программирование - Практика программирования

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

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

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

Для обеспечения симметричности картины можно предложить такой вариант:
Сообщить() -> глСообщить(), обёртка вокруг СообщитьОбОшибке() от 1С.
Состояние() -> глСостояние()
Предупреждение() -> глПредупреждение()

Как идея? Что забыто? Что хотелось бы еще? Где подводные камни?



См. также

Подписаться Добавить вознаграждение

Комментарии

1. Александр (alexkr) 18.01.08 17:00
Если речь идет о 8-ке, то забыты команды препроцессора, которые позволяют определить режим работы и соответственно вариант выполнения, кроме этого функции сообщить() и состояние() работают как на сервере так и в клиентстком режиме.
А в общем случае можно сообщить и предупредить заменять одной функцией, и там уже определять, что нужно какому пользователю: сообщение, или можно в пользовательском режиме видать предупреждение с таймером.
2. hopter _ (hopter) 21.01.08 03:45
Команды не забыты, т.к. в СообщитьОбОшибке() все и прописано. Об этом автор написал в первом абзаце решения.
3. brix8x (brix8x) 21.01.08 09:09
Есть желание "обернуть" команду Вопрос, но вот логического обоснования под это подвести не могу, уж больно эта команда интерактивна, в потому желательно, чтобы проверка в контексте внешнего соединения или сервера показывала ошибку на Вопрос.
Так что, наверное, остановлюсь на "Трех Богатырях" ж-)
Для написания сообщения необходимо авторизоваться
Прикрепить файл
Дополнительные параметры ответа