User:Unsane/MirLua/m core: Difference between revisions

From Miranda NG
Jump to navigation Jump to search
mNo edit summary
Line 19: Line 19:
===HookEvent===
===HookEvent===
Устанавливает функция обратного вызова ("ловушку") для реакции на вызов события.
Устанавливает функция обратного вызова ("ловушку") для реакции на вызов события.
 
;Параметры
<code>Параметры</code>
: '''''name'''''
* name - имя события
:: Тип: '''string'''
* hook - функция-ловушки
:: Имя события.
<code>Результат</code>
: '''''hook'''''
: Возвращает дескриптор подписки или nil
:: Тип: '''function'''
<code>Пример</code>
:: Функция-ловушка, которая будет вызвана при наступлении события.
;Результат
: Тип: '''light userdata'''
: Возвращает дескриптор ловушка, если ловушка была успешно создана, иначе nil
;Пример
{{Content:MirLua/Example|code=local hHook = m.HookEvent('MyEvent', function(w, l)
{{Content:MirLua/Example|code=local hHook = m.HookEvent('MyEvent', function(w, l)
   print('MyEvent is raised!')
   print('MyEvent is raised!')
end)
end)
}}
}}


===NotifyEventHooks===
===NotifyEventHooks===

Revision as of 18:28, 10 November 2015

Этот модуль изначально импортирован в глобальную таблицу и доступен через переменную m в любом модуле. Он предоставляет доступ к основным возможностям ядра Miranda NG.

Именованные события

CreateHookableEvent

Создает событие

Параметры
name
Тип: string
Имя события
Результат
Тип: light userdata
Дескриптор события, если событие было успешно создано, иначе nil
Пример
local hEvent = m.CreateHookableEvent('MyEvent')


HookEvent

Устанавливает функция обратного вызова ("ловушку") для реакции на вызов события.

Параметры
name
Тип: string
Имя события.
hook
Тип: function
Функция-ловушка, которая будет вызвана при наступлении события.
Результат
Тип: light userdata
Возвращает дескриптор ловушка, если ловушка была успешно создана, иначе nil
Пример
local hHook = m.HookEvent('MyEvent', function(w, l)
  print('MyEvent is raised!')
end)

NotifyEventHooks

Вызывает событие. При вызове события поочередно сработают все функции-ловушки, которые были подписаны на это событие.

Параметры

  • hEvent - дескриптор события, который был получен при вызове CreateHookableEvent
  • wParam
  • lParam

Результат

Пример

m.NotifyEventHooks(hEvent)

UnhookEvent

Удаляет подписку на именованное событие Параметры

  • hEvent - дескриптор события, который был получен при вызове CreateHookableEvent

Результат

Пример

m.UnhookEvent(hHook)

DestroyHookableEvent

Удаляет именованное событие

m.DestroyHookableEvent(hEvent)


Именованные сервисные функции

CreateServiceFunction

Создает именованную сервисную функцию

local hService = m.CreateServiceFunction('MyService', function(w, l)
  print('MyServiceis called!')
end)


CallService

Вызывает именованную сервисную функцию

m.CallService('MyService', 0, 0)


ServiceExists

Проверяет существование сервиса по имени

if m.ServiceExists('MyService') then
  m.CallService('MyService')
end


DestroyServiceFunction

Удаляет сервисную функцию

m.DestroyServiceFunction(hService)


Остальное

IsPluginLoaded

Проверяет загружен ли плагин по его muuid

if m.IsPluginLoaded('{F0FDF73A-753D-499d-8DBA-336DB79CDD41}') then
  print('Advanced auto away plugin is loaded!')
end


Utf8DecodeA

Конвертирует содержимое lua строки в ANSI

m.CallService("Quotes/Import", 0, Utf8DecodeA('c:\\quotes.xml'))


Utf8DecodeW

Конвертирует содержимое lua строки в Unicode

m.CallService("Popup/ShowMessageW", m.Utf8DecodeW('Hello, World!'), 2)


Translate

Переводит строку на язык текущего языкового пакета

m.Translate('Exit')


ReplaceVariables

Заменяет переменные ядра Miranda NG в строке

local profileName = m.ReplaceVariables('%miranda_profilename%')