<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>http://sfsys.ru/index.php?action=history&amp;feed=atom&amp;title=StandardOutputHook</id>
	<title>StandardOutputHook - Revision history</title>
	<link rel="self" type="application/atom+xml" href="http://sfsys.ru/index.php?action=history&amp;feed=atom&amp;title=StandardOutputHook"/>
	<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=StandardOutputHook&amp;action=history"/>
	<updated>2026-04-04T11:37:55Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.31.1</generator>
	<entry>
		<id>http://sfsys.ru/index.php?title=StandardOutputHook&amp;diff=4630&amp;oldid=prev</id>
		<title>Admin: 1 revision imported</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=StandardOutputHook&amp;diff=4630&amp;oldid=prev"/>
		<updated>2023-09-25T09:07:41Z</updated>

		<summary type="html">&lt;p&gt;1 revision imported&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revision as of 09:07, 25 September 2023&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-notice&quot; lang=&quot;en&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(No difference)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>
		
	</entry>
	<entry>
		<id>http://sfsys.ru/index.php?title=StandardOutputHook&amp;diff=4629&amp;oldid=prev</id>
		<title>1&gt;Admin at 08:53, 17 August 2023</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=StandardOutputHook&amp;diff=4629&amp;oldid=prev"/>
		<updated>2023-08-17T08:53:36Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revision as of 08:53, 17 August 2023&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l25&quot; &gt;Line 25:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 25:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;** '''2''' -- Перехват изменения статуса выполнения ([[Form.StatusText]], [[Form.UpdateProgress]] и т.п.).&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;** '''2''' -- Перехват изменения статуса выполнения ([[Form.StatusText]], [[Form.UpdateProgress]] и т.п.).&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* &amp;lt;code&amp;gt;''&amp;lt;Наименование функции, вызываемой при перехвате (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - {{Optional}} Аргумент задает наименование особой функции, которая будет вызываться в момент (и вместо) создания перехватываемого события. Если функция не задана, перехват, для указанного первым аргументом события, будет отменен. Любые исключения внутри функции будут игнорированы. Внутри функции-перехватчика вызов функции, создающей перехватываемое событие (к примеру, вызов [[Message]] в перехватчике вывода в стандартный лог) не будет вызывать рекурсивный вызов перехватчика. В зависимости от типа перехватываемого события, функция должна иметь следующий формат:&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* &amp;lt;code&amp;gt;''&amp;lt;Наименование функции, вызываемой при перехвате (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - {{Optional}} Аргумент задает наименование особой функции, которая будет вызываться в момент (и вместо) создания перехватываемого события. Если функция не задана, перехват, для указанного первым аргументом события, будет отменен. Любые исключения внутри функции будут игнорированы. Внутри функции-перехватчика вызов функции, создающей перехватываемое событие (к примеру, вызов [[Message]] в перехватчике вывода в стандартный лог) не будет вызывать рекурсивный вызов перехватчика. В зависимости от типа перехватываемого события, функция должна иметь следующий формат:&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;−&lt;/td&gt;&lt;td style=&quot;color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;** Для перехвата событий с типом ''0'': &amp;lt;code&amp;gt;&amp;lt;ФункцияПерехвата&amp;gt;({{Optional|&amp;lt;Текст, выводящийся в лог (STRING)&amp;gt;,&amp;lt;Тип текста (INT)&amp;gt;,&amp;lt;Метки форматирования текста (STRING)&amp;gt;,&amp;lt;Параметр, переданный из вызова StandardOutputHook&amp;gt;}})&amp;lt;/code&amp;gt;. Ниже дано описание аргументов функции:&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;+&lt;/td&gt;&lt;td style=&quot;color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;** Для перехвата событий с типом ''0'': &amp;lt;code&amp;gt;&amp;lt;ФункцияПерехвата&amp;gt;({{Optional|&amp;lt;Текст, выводящийся в лог (STRING)&amp;gt;,&amp;lt;Тип текста (INT)&amp;gt;,&amp;lt;Метки форматирования текста (STRING)&amp;gt;,&amp;lt;Параметр, переданный из вызова StandardOutputHook&lt;ins class=&quot;diffchange diffchange-inline&quot;&gt;&amp;gt;,&amp;lt;Список интерактивных объектов %LINK% (LIST)&lt;/ins&gt;&amp;gt;}})&amp;lt;/code&amp;gt;. Ниже дано описание аргументов функции:&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*** ''&amp;lt;Текст, выводящийся в лог (STRING)&amp;gt;'' - {{Optional}} аргумент получает текстовую строку, которая была бы выведена в лог.&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*** ''&amp;lt;Текст, выводящийся в лог (STRING)&amp;gt;'' - {{Optional}} аргумент получает текстовую строку, которая была бы выведена в лог.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*** ''&amp;lt;Тип текста (INT)&amp;gt;'' - {{Optional}} аргумент получает тип текстовой строки, доступны следующие типы:&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*** ''&amp;lt;Тип текста (INT)&amp;gt;'' - {{Optional}} аргумент получает тип текстовой строки, доступны следующие типы:&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l43&quot; &gt;Line 43:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 43:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;***** 1 символ задает формат шрифта, является битовой маской с битами: ''0'' (жирный шрифт), ''1'' (наклонный шрифт), ''2'' (подчеркнутый шрифт), ''3'' (зачеркнутый шрифт).&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;***** 1 символ задает формат шрифта, является битовой маской с битами: ''0'' (жирный шрифт), ''1'' (наклонный шрифт), ''2'' (подчеркнутый шрифт), ''3'' (зачеркнутый шрифт).&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*** ''&amp;lt;Параметр, переданный из вызова StandardOutputHook&amp;gt;'' - {{Optional}} Произвольный параметр, который был получен при регистрации функции-перехватчика функцией StandardOutputHook.&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*** ''&amp;lt;Параметр, переданный из вызова StandardOutputHook&amp;gt;'' - {{Optional}} Произвольный параметр, который был получен при регистрации функции-перехватчика функцией StandardOutputHook.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot;&gt;&amp;#160;&lt;/td&gt;&lt;td class='diff-marker'&gt;+&lt;/td&gt;&lt;td style=&quot;color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;*** ''&amp;lt;Список интерактивных объектов %LINK% (LIST)&amp;gt;'' - {{Optional}} аргумент получает список, хранящий все интерактивные объекты, переданные функции [[Message]]. Заголовками списка служат текстовые представления этих объектов, а объектами списка -- сами объекты, закодированные функцией [[ObjectToString]].&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;** Для перехвата событий с типом ''1'': &amp;lt;code&amp;gt;&amp;lt;ФункцияПерехвата&amp;gt;({{Optional|&amp;lt;Тип диалога (INT)&amp;gt;,&amp;lt;Заголовок диалога (STRING)&amp;gt;,{{ByRef|&amp;lt;Текст диалога (STRING)&amp;gt;}},&amp;lt;Опция 1&amp;gt;,&amp;lt;Опция 2&amp;gt;,&amp;lt;Параметр, переданный из вызова StandardOutputHook&amp;gt;}}):''&amp;lt;Результат выполнения диалога&amp;gt;''&amp;lt;/code&amp;gt;. Ниже дано описание аргументов функции:&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;** Для перехвата событий с типом ''1'': &amp;lt;code&amp;gt;&amp;lt;ФункцияПерехвата&amp;gt;({{Optional|&amp;lt;Тип диалога (INT)&amp;gt;,&amp;lt;Заголовок диалога (STRING)&amp;gt;,{{ByRef|&amp;lt;Текст диалога (STRING)&amp;gt;}},&amp;lt;Опция 1&amp;gt;,&amp;lt;Опция 2&amp;gt;,&amp;lt;Параметр, переданный из вызова StandardOutputHook&amp;gt;}}):''&amp;lt;Результат выполнения диалога&amp;gt;''&amp;lt;/code&amp;gt;. Ниже дано описание аргументов функции:&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*** ''&amp;lt;Тип диалога (INT)&amp;gt;'' - {{Optional}} аргумент получает тип перехватываемого визуального диалога. В зависимости от типа диалога аргументы &amp;quot;Опция 1&amp;quot; и &amp;quot;Опция 2&amp;quot; также могут содержать дополнительную информацию. Доступны следующие типы диалогов:&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #222; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;*** ''&amp;lt;Тип диалога (INT)&amp;gt;'' - {{Optional}} аргумент получает тип перехватываемого визуального диалога. В зависимости от типа диалога аргументы &amp;quot;Опция 1&amp;quot; и &amp;quot;Опция 2&amp;quot; также могут содержать дополнительную информацию. Доступны следующие типы диалогов:&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>1&gt;Admin</name></author>
		
	</entry>
	<entry>
		<id>http://sfsys.ru/index.php?title=StandardOutputHook&amp;diff=4586&amp;oldid=prev</id>
		<title>Admin: 1 revision imported</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=StandardOutputHook&amp;diff=4586&amp;oldid=prev"/>
		<updated>2023-06-08T10:12:22Z</updated>

		<summary type="html">&lt;p&gt;1 revision imported&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revision as of 10:12, 8 June 2023&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-notice&quot; lang=&quot;en&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(No difference)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>
		
	</entry>
	<entry>
		<id>http://sfsys.ru/index.php?title=StandardOutputHook&amp;diff=4585&amp;oldid=prev</id>
		<title>1&gt;Admin at 11:54, 8 May 2023</title>
		<link rel="alternate" type="text/html" href="http://sfsys.ru/index.php?title=StandardOutputHook&amp;diff=4585&amp;oldid=prev"/>
		<updated>2023-05-08T11:54:28Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;{{infobox function&lt;br /&gt;
|name=StandardOutputHook&lt;br /&gt;
|object=[[Функции общего назначения]]&lt;br /&gt;
|caption=Системные функции&lt;br /&gt;
|type=1&lt;br /&gt;
|status=2&lt;br /&gt;
|db=0&lt;br /&gt;
|exception=Невозможно превратить в строку или число, функция не найдена, неверные аргументы.&lt;br /&gt;
|visual=0}}&lt;br /&gt;
{{HeadLinks|&lt;br /&gt;
* [[Main_Page|Начальная страница]]&lt;br /&gt;
* [[Общее_описание_языка|Общее описание]]&lt;br /&gt;
* [[Объекты]]&lt;br /&gt;
* [[Функции общего назначения]]}}&lt;br /&gt;
Функция добавляет или удаляет ссылку на функцию-перехватчик визуальных событий (к примеру, вывода информации в лог или панель состояния формы). Может использоваться, к примеру, для получения и вывод на экран информации об обработках, протекающих в скрытом потоке. Крайне желательно использование конструкции &amp;lt;code&amp;gt;Try .. Finally&amp;lt;/code&amp;gt;, чтобы гарантированно вернуть предыдущее состояние перехватчика после того, как работа будет завершена. Перехватчики могут быть установлены также и другими функциями (к примеру [[ExecEx]]).&lt;br /&gt;
&lt;br /&gt;
== Синтаксис ==&lt;br /&gt;
&amp;lt;code&amp;gt;&lt;br /&gt;
'''StandardOutputHook'''({{Optional|&amp;lt;Тип перехватываемого события (INT)&amp;gt;{{Default|{{Eq}}0}},&amp;lt;Наименование функции, вызываемой при перехвате (STRING)&amp;gt;,&amp;lt;Глубина поиска (INT)&amp;gt;{{Default|{{Eq}}0}},&amp;lt;Параметр для передачи в функцию&amp;gt;}}):''&amp;lt;Наименование предыдущей функции-перехватчика (STRING)&amp;gt;''&lt;br /&gt;
&amp;lt;/code&amp;gt;&lt;br /&gt;
==== Аргументы ====&lt;br /&gt;
* &amp;lt;code&amp;gt;''&amp;lt;Тип перехватываемого события (INT)&amp;gt;''&amp;lt;/code&amp;gt; - {{Optional}} Тип события для перехвата, может принимать следующие значения:&lt;br /&gt;
** '''0''' (по умолчанию) -- Перехват вывода в стандартный лог визуального клиента (как сообщений, созданных функциями [[Message]], так и исключений).&lt;br /&gt;
** '''1''' -- Перехват вывода на экран стандартных диалогов ([[Box]], [[AskQuestion]] и т.п.).&lt;br /&gt;
** '''2''' -- Перехват изменения статуса выполнения ([[Form.StatusText]], [[Form.UpdateProgress]] и т.п.).&lt;br /&gt;
* &amp;lt;code&amp;gt;''&amp;lt;Наименование функции, вызываемой при перехвате (STRING)&amp;gt;''&amp;lt;/code&amp;gt; - {{Optional}} Аргумент задает наименование особой функции, которая будет вызываться в момент (и вместо) создания перехватываемого события. Если функция не задана, перехват, для указанного первым аргументом события, будет отменен. Любые исключения внутри функции будут игнорированы. Внутри функции-перехватчика вызов функции, создающей перехватываемое событие (к примеру, вызов [[Message]] в перехватчике вывода в стандартный лог) не будет вызывать рекурсивный вызов перехватчика. В зависимости от типа перехватываемого события, функция должна иметь следующий формат:&lt;br /&gt;
** Для перехвата событий с типом ''0'': &amp;lt;code&amp;gt;&amp;lt;ФункцияПерехвата&amp;gt;({{Optional|&amp;lt;Текст, выводящийся в лог (STRING)&amp;gt;,&amp;lt;Тип текста (INT)&amp;gt;,&amp;lt;Метки форматирования текста (STRING)&amp;gt;,&amp;lt;Параметр, переданный из вызова StandardOutputHook&amp;gt;}})&amp;lt;/code&amp;gt;. Ниже дано описание аргументов функции:&lt;br /&gt;
*** ''&amp;lt;Текст, выводящийся в лог (STRING)&amp;gt;'' - {{Optional}} аргумент получает текстовую строку, которая была бы выведена в лог.&lt;br /&gt;
*** ''&amp;lt;Тип текста (INT)&amp;gt;'' - {{Optional}} аргумент получает тип текстовой строки, доступны следующие типы:&lt;br /&gt;
**** '''-1''' -- эта строка является сообщением об ошибке.&lt;br /&gt;
**** '''0''' -- эта строка является обычным текстом (созданным, к примеру функциями [[Message]] или [[Writeln]]).&lt;br /&gt;
**** '''1''' -- эта строка является текстом созданным функцией [[Message]] с типом текста &amp;quot;i&amp;quot;.&lt;br /&gt;
**** '''2''' -- эта строка является текстом созданным функцией [[Message]] с типом текста &amp;quot;.&amp;quot;.&lt;br /&gt;
**** '''3''' -- эта строка является текстом созданным функцией [[Message]] с типом текста &amp;quot;!&amp;quot;.&lt;br /&gt;
**** '''4''' -- эта строка является текстом созданным функцией [[Message]] с типом текста &amp;quot;!!&amp;quot;.&lt;br /&gt;
**** '''5''' -- эта строка является текстом созданным функцией [[Message]] с типом текста &amp;quot;!!!&amp;quot;.&lt;br /&gt;
*** ''&amp;lt;Метки форматирования текста (STRING)&amp;gt;'' - {{Optional}} аргумент получает строку с метками форматирования текста. Иногда это будет пустая строка, если весь текст представляет собой строку без форматирования. В случае, когда строка задана, она отдается в виде ANSI, каждый ее символ может быть превращен в байт и будет задавать форматирование соответствующего символа в строке текста лога. Доступны следующие значения символов форматирования:&lt;br /&gt;
**** '''0''' -- Текущий символ строки лога использует стандартный цвет и шрифт (не форматирован).&lt;br /&gt;
**** '''1''' -- Текущий символ строки лога использует такой же цвет и шрифт, как и предыдущий символ.&lt;br /&gt;
**** '''2''' -- Текущий символ строки лога использует цвет и шрифт, заданные семью последующими символами строки с метками форматирования. Эти последующие символы должны быть пропущены при подсчете индекса символа строки лога (относятся только к текущему символу) и имеют следующее назначение:&lt;br /&gt;
***** 3 символа задают цвет шрифта (формате ''RGB'').&lt;br /&gt;
***** 3 символа задают цвет фона шрифта (формате ''RGB'').&lt;br /&gt;
***** 1 символ задает формат шрифта, является битовой маской с битами: ''0'' (жирный шрифт), ''1'' (наклонный шрифт), ''2'' (подчеркнутый шрифт), ''3'' (зачеркнутый шрифт).&lt;br /&gt;
*** ''&amp;lt;Параметр, переданный из вызова StandardOutputHook&amp;gt;'' - {{Optional}} Произвольный параметр, который был получен при регистрации функции-перехватчика функцией StandardOutputHook.&lt;br /&gt;
** Для перехвата событий с типом ''1'': &amp;lt;code&amp;gt;&amp;lt;ФункцияПерехвата&amp;gt;({{Optional|&amp;lt;Тип диалога (INT)&amp;gt;,&amp;lt;Заголовок диалога (STRING)&amp;gt;,{{ByRef|&amp;lt;Текст диалога (STRING)&amp;gt;}},&amp;lt;Опция 1&amp;gt;,&amp;lt;Опция 2&amp;gt;,&amp;lt;Параметр, переданный из вызова StandardOutputHook&amp;gt;}}):''&amp;lt;Результат выполнения диалога&amp;gt;''&amp;lt;/code&amp;gt;. Ниже дано описание аргументов функции:&lt;br /&gt;
*** ''&amp;lt;Тип диалога (INT)&amp;gt;'' - {{Optional}} аргумент получает тип перехватываемого визуального диалога. В зависимости от типа диалога аргументы &amp;quot;Опция 1&amp;quot; и &amp;quot;Опция 2&amp;quot; также могут содержать дополнительную информацию. Доступны следующие типы диалогов:&lt;br /&gt;
**** '''0''' -- Диалог, создаваемый функцией [[Box]]. Аргумент &amp;quot;Опция 1&amp;quot; содержит тип диалога Box (см. описание). Аргумент &amp;quot;Заголовок диалога&amp;quot; содержит сообщение функции Box.&lt;br /&gt;
**** '''1''' -- Диалог, создаваемый функцией [[AskQuestion]]. Аргумент &amp;quot;Опция 1&amp;quot; содержит тип диалога AskQuestion (см. описание), &amp;quot;опция 2&amp;quot; -- идентификатор кнопки по умолчанию. Аргумент &amp;quot;Заголовок диалога&amp;quot; содержит сообщение функции AskQuestion. Результат функции (Result) будет возвращен, как результат AskQuestion.&lt;br /&gt;
**** '''2''' -- Диалог, создаваемый функцией [[AskString]]. Аргумент &amp;quot;Опция 1&amp;quot; содержит тип строки AskString (см. описание), &amp;quot;опция 2&amp;quot; -- длину строки. Аргумент &amp;quot;Заголовок диалога&amp;quot; содержит заголовок функции AskString. Результат функции (Result) будет возвращен, как результат AskString.&lt;br /&gt;
**** '''3''' -- Диалог, создаваемый функцией [[AskNumber]]. Аргумент &amp;quot;Опция 1&amp;quot; содержит тип числа AskNumber в виде &amp;quot;&amp;lt;Длина числа.Знаков после точки&amp;gt;&amp;quot; (см. описание). Аргумент &amp;quot;Заголовок диалога&amp;quot; содержит заголовок функции AskNumber. Результат функции (Result) будет возвращен, как результат выполнения AskNumber.&lt;br /&gt;
**** '''4''' -- Диалог, создаваемый функцией [[AskDate]]. Аргумент &amp;quot;Опция 1&amp;quot; содержит начальную дату диалога AskDate (см. описание), &amp;quot;опция 2&amp;quot; -- режим показа диалога. Аргумент &amp;quot;Заголовок диалога&amp;quot; содержит заголовок функции AskDate. Результат функции (Result) будет возвращен, как результат выполнения AskDate.&lt;br /&gt;
**** '''5''' -- Диалог, создаваемый функцией [[AskPeriod]]. Аргумент &amp;quot;Текст диалога&amp;quot; содержит начальные даты диалога AskPeriod в виде &amp;quot;&amp;lt;Начальная дата@Конечная дата&amp;gt;&amp;quot; (см. описание), данный аргумент также принимается назад, как результат выполнения функции, &amp;quot;опция 1&amp;quot; -- тип периода. Аргумент &amp;quot;Заголовок диалога&amp;quot; содержит сообщение функции AskPeriod. Результат функции (Result) будет возвращен, как результат выполнения AskPeriod.&lt;br /&gt;
**** '''10''' -- Диалог, создаваемый функцией [[OpenFileDialog]]. Аргумент &amp;quot;Текст диалога&amp;quot; содержит имя файла OpenFileDialog (см. описание), данный аргумент также принимается назад, как результат выполнения функции, &amp;quot;опция 1&amp;quot; -- тип диалога, &amp;quot;опция 2&amp;quot; -- строку в виде &amp;quot;&amp;lt;Доступные фильтры файлов&amp;gt;&amp;quot;+Chr(1)+&amp;quot;&amp;lt;Расширение по умолчанию&amp;gt;&amp;quot;. Аргумент &amp;quot;Заголовок диалога&amp;quot; содержит заголовок функции OpenFileDialog. Результат функции (Result) будет возвращен, как результат выполнения OpenFileDialog.&lt;br /&gt;
**** '''11''' -- Диалог, создаваемый функцией [[SaveFileDialog]]. Аргумент &amp;quot;Текст диалога&amp;quot; содержит имя файла SaveFileDialog (см. описание), данный аргумент также принимается назад, как результат выполнения функции, &amp;quot;опция 1&amp;quot; -- тип диалога, &amp;quot;опция 2&amp;quot; -- строку в виде &amp;quot;&amp;lt;Доступные фильтры файлов&amp;gt;&amp;quot;+Chr(1)+&amp;quot;&amp;lt;Расширение по умолчанию&amp;gt;&amp;quot;. Аргумент &amp;quot;Заголовок диалога&amp;quot; содержит заголовок функции SaveFileDialog. Результат функции (Result) будет возвращен, как результат выполнения SaveFileDialog.&lt;br /&gt;
**** '''12''' -- Диалог, создаваемый функцией [[OpenFileDialogServer]]. Аргумент &amp;quot;Текст диалога&amp;quot; содержит имя файла OpenFileDialogServer (см. описание), данный аргумент также принимается назад, как результат выполнения функции, &amp;quot;опция 1&amp;quot; -- тип диалога, &amp;quot;опция 2&amp;quot; -- строку в виде &amp;quot;&amp;lt;Доступные фильтры файлов&amp;gt;&amp;quot;+Chr(1)+&amp;quot;&amp;lt;Расширение по умолчанию&amp;gt;&amp;quot;. Аргумент &amp;quot;Заголовок диалога&amp;quot; содержит заголовок функции OpenFileDialogServer. Результат функции (Result) будет возвращен, как результат выполнения OpenFileDialogServer.&lt;br /&gt;
**** '''13''' -- Диалог, создаваемый функцией [[SaveFileDialogServer]]. Аргумент &amp;quot;Текст диалога&amp;quot; содержит имя файла SaveFileDialogServer (см. описание), данный аргумент также принимается назад, как результат выполнения функции, &amp;quot;опция 1&amp;quot; -- тип диалога, &amp;quot;опция 2&amp;quot; -- строку в виде &amp;quot;&amp;lt;Доступные фильтры файлов&amp;gt;&amp;quot;+Chr(1)+&amp;quot;&amp;lt;Расширение по умолчанию&amp;gt;&amp;quot;. Аргумент &amp;quot;Заголовок диалога&amp;quot; содержит заголовок функции SaveFileDialogServer. Результат функции (Result) будет возвращен, как результат выполнения SaveFileDialogServer.&lt;br /&gt;
**** '''14''' -- Диалог, создаваемый функцией [[SelectFolderDialog]]. Аргумент &amp;quot;Текст диалога&amp;quot; содержит имя файла SelectFolderDialog (см. описание), данный аргумент также принимается назад, как результат выполнения функции. Аргумент &amp;quot;Заголовок диалога&amp;quot; содержит заголовок функции SelectFolderDialog. Результат функции (Result) будет возвращен, как результат выполнения SelectFolderDialog.&lt;br /&gt;
**** '''20''' -- Диалог, создаваемый функцией [[SelectDataType]]. Аргумент &amp;quot;Текст диалога&amp;quot; содержит список типов объектов SelectDataType (см. описание). Аргумент &amp;quot;Заголовок диалога&amp;quot; содержит заголовок функции SelectDataType. Результат функции (Result) будет возвращен, как результат выполнения SelectDataType.&lt;br /&gt;
**** '''21''' -- Диалог, создаваемый функцией [[SelectFormSettingsFile]]. Аргумент &amp;quot;Текст диалога&amp;quot; содержит путь файла установок и имя файла установок SelectFormSettingsFile в виде строки &amp;quot;&amp;lt;Пусть&amp;gt;\&amp;lt;Имя файла&amp;gt;&amp;quot; (см. описание), данный аргумент также принимается назад, как результат выполнения функции, &amp;quot;опция 1&amp;quot; -- тип диалога. Результат функции (Result) будет возвращен, как результат выполнения SelectFormSettingsFile.&lt;br /&gt;
**** '''22''' -- Диалог, создаваемый функцией [[SelectFontDialog]]. Аргумент &amp;quot;Текст диалога&amp;quot; содержит текст шрифта SelectFontDialog (см. описание), данный аргумент также принимается назад, как результат выполнения функции, &amp;quot;опция 1&amp;quot; -- настройки диалога в виде строки &amp;quot;&amp;lt;Запретить выбор стилей&amp;gt;&amp;quot;+Chr(1)+&amp;quot;&amp;lt;Минимальный размер шрифта&amp;gt;&amp;quot;+Chr(1)+&amp;quot;&amp;lt;Максимальный размер шрифта&amp;gt;&amp;quot;. Результат функции (Result) будет возвращен, как результат выполнения SelectFontDialog.&lt;br /&gt;
**** '''23''' -- Диалог, создаваемый функцией [[SelectIconDialog]]. Аргумент &amp;quot;Текст диалога&amp;quot; содержит номер иконки по умолчанию SelectIconDialog (см. описание), данный аргумент также принимается назад, как результат выполнения функции. Аргумент &amp;quot;Заголовок диалога&amp;quot; содержит заголовок функции SelectIconDialog. Результат функции (Result) будет возвращен, как результат выполнения SelectIconDialog.&lt;br /&gt;
**** '''24''' -- Диалог, создаваемый функцией [[EditScriptDialog]]. Аргумент &amp;quot;Текст диалога&amp;quot; содержит исходный текст EditScriptDialog (см. описание), данный аргумент также принимается назад, как результат выполнения функции, &amp;quot;опция 1&amp;quot; -- список внешних переменных через запятую. Аргумент &amp;quot;Заголовок диалога&amp;quot; содержит заголовок функции EditScriptDialog. Результат функции (Result) будет возвращен, как результат выполнения EditScriptDialog.&lt;br /&gt;
*** Аргументы ''&amp;lt;Заголовок диалога&amp;gt;'', ''&amp;lt;Текст диалога&amp;gt;'', ''&amp;lt;Опция 1&amp;gt;'', ''&amp;lt;Опция 2&amp;gt;'' зависят от аргумента ''Тип диалога'' (см. выше).&lt;br /&gt;
*** ''&amp;lt;Параметр, переданный из вызова StandardOutputHook&amp;gt;'' - {{Optional}} Произвольный параметр, который был получен при регистрации функции-перехватчика функцией StandardOutputHook.&lt;br /&gt;
** Для перехвата событий с типом ''2'': &amp;lt;code&amp;gt;&amp;lt;ФункцияПерехвата&amp;gt;({{Optional|&amp;lt;Тип вызова (INT)&amp;gt;,&amp;lt;Текст статуса, выполнения (STRING)&amp;gt;,&amp;lt;Текущий прогресс выполнения (INT)&amp;gt;,&amp;lt;Максимальный прогресс выполнения (INT)&amp;gt;,&amp;lt;Параметр, переданный из вызова StandardOutputHook&amp;gt;}})&amp;lt;/code&amp;gt;. Ниже дано описание аргументов функции:&lt;br /&gt;
*** ''&amp;lt;Тип вызова (INT)&amp;gt;'' - {{Optional}} аргумент получает тип перехватываемого вызова. Доступны следующие типы:&lt;br /&gt;
**** '''0''' -- Вызывалась функция [[Form.StatusText]]. Также заполнен аргумент ''Текст статуса, выполнения'' (см. описание функции).&lt;br /&gt;
**** '''1''' -- Вызывалась функция [[Form.UpdateProgress]]. Также заполнены аргументы ''Текст статуса, выполнения'', ''Текущий прогресс выполнения'' и ''Максимальный прогресс выполнения'' (см. описание функции).&lt;br /&gt;
**** '''2''' -- Вызывалась функция [[Form.StopProgress]].&lt;br /&gt;
*** Аргументы ''&amp;lt;Текст статуса, выполнения&amp;gt;'', ''&amp;lt;Текущий прогресс выполнения&amp;gt;'', ''&amp;lt;Максимальный прогресс выполнения&amp;gt;'' зависят от аргумента ''Тип вызова'' (см. выше).&lt;br /&gt;
*** ''&amp;lt;Параметр, переданный из вызова StandardOutputHook&amp;gt;'' - {{Optional}} Произвольный параметр, который был получен при регистрации функции-перехватчика функцией StandardOutputHook.&lt;br /&gt;
* &amp;lt;code&amp;gt;''&amp;lt;Глубина поиска (INT)&amp;gt;''&amp;lt;/code&amp;gt; - {{Optional}} Может принимать следующие значения:&lt;br /&gt;
** 0 (по умолчанию) -- выполнять поиск функции во всех модулях [[Общее описание языка#Вложенность функций и модулей, уровни вложенности|большего уровня вложенности]] (родительских) и во всех глобальных модулях.&lt;br /&gt;
** 1 -- выполнять поиск функции только внутри текущего модуля.&lt;br /&gt;
** 2 -- выполнять поиск функции только внутри родительского модуля.&lt;br /&gt;
** 3..x -- выполнять поиск функции только внутри родительского модуля указанного уровня (к примеру, для уровня 3, выполнять поиск только в родителе родителя текущего модуля).&lt;br /&gt;
* &amp;lt;code&amp;gt;''&amp;lt;Параметр для передачи в функцию&amp;gt;''&amp;lt;/code&amp;gt; - {{Optional}} Произвольный параметр, который будет передан в функцию-перехватчик при ее вызове.&lt;br /&gt;
&lt;br /&gt;
==== Возвращаемое значение ====&lt;br /&gt;
Функция возвращает предыдущее наименование функции-перехватчика, либо пустую строку, если такой функции не было задано.&lt;br /&gt;
&lt;br /&gt;
== Примеры ==&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
  //Функция перехвата вывод информации и исключений в лог&lt;br /&gt;
  Function ВнутренняяВыполнитьОбменРабочийПотокЛоги(Текст,Тип,Цвета,спПараметры)&lt;br /&gt;
    Элемент:=спПараметры[&amp;quot;Элемент&amp;quot;];&lt;br /&gt;
    If not IsEmpty(Элемент) Then&lt;br /&gt;
      Элемент.Caption:=Текст;&lt;br /&gt;
      If (Тип&amp;lt;0)or(Тип&amp;gt;2) Then&lt;br /&gt;
        Элемент.FontColor:=_CLR_RED;&lt;br /&gt;
        Элемент.FontStyle:=1;&lt;br /&gt;
      Else&lt;br /&gt;
        Элемент.FontColor:=_CLR_WINDOWTEXT;&lt;br /&gt;
        Элемент.FontStyle:=0;&lt;br /&gt;
      EndIf;&lt;br /&gt;
    EndIf;&lt;br /&gt;
  EndFunction&lt;br /&gt;
&lt;br /&gt;
  //Функция перехвата изменения статуса формы&lt;br /&gt;
  Function ВнутренняяВыполнитьОбменРабочийПотокСтатус(Тип,Текст,Прогресс,Всего,спПараметры)&lt;br /&gt;
    Элемент:=спПараметры[&amp;quot;Элемент&amp;quot;];&lt;br /&gt;
    If not IsEmpty(Элемент) Then&lt;br /&gt;
      Элемент.Caption:=Текст+?((Прогресс&amp;gt;0)And(Всего&amp;gt;0),&amp;quot;, &amp;quot;+Прогресс+&amp;quot; из &amp;quot;+Всего+&amp;quot;...&amp;quot;);&lt;br /&gt;
    EndIf;&lt;br /&gt;
  EndFunction&lt;br /&gt;
&lt;br /&gt;
//Поместим текстовый элемент &amp;quot;Информация&amp;quot; для его обновления текстом перехваченных вызовов.&lt;br /&gt;
спПараметры:=List.Create();&lt;br /&gt;
спПараметры[&amp;quot;Элемент&amp;quot;]:=Form.Информация;&lt;br /&gt;
//Перехват индикации деятельности обработки &amp;quot;...&amp;quot;, которая будет выведена на весь экран в модальном режиме.&lt;br /&gt;
StandardOutputHook(0,&amp;quot;ВывестиЛоги&amp;quot;,0,спПараметры);&lt;br /&gt;
StandardOutputHook(2,&amp;quot;ВывестиСТатус&amp;quot;,0,спПараметры);&lt;br /&gt;
Try&lt;br /&gt;
  Try&lt;br /&gt;
    //Вывоз длительной обработки &amp;quot;...&amp;quot;&lt;br /&gt;
    LoadModule(11,&amp;quot;...&amp;quot;,,0,&amp;quot;Module&amp;quot;,&amp;quot;Form&amp;quot;);&lt;br /&gt;
  Except&lt;br /&gt;
    //Текст исключения уже на экране, его перехватил StandardOutputHook&lt;br /&gt;
  EndTry;&lt;br /&gt;
Finally&lt;br /&gt;
  StandardOutputHook(2);&lt;br /&gt;
  StandardOutputHook(0);&lt;br /&gt;
  If Form.Информация.FontColor&amp;lt;&amp;gt;_CLR_RED Then&lt;br /&gt;
    Form.Информация.Caption:=&amp;quot;Работа окончена&amp;quot;;&lt;br /&gt;
  EndIf;&lt;br /&gt;
EndTry;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>1&gt;Admin</name></author>
		
	</entry>
</feed>