docs/api.mdwn
author Myhailo Danylenko <isbear@ukrpost.net>
Thu, 17 Mar 2016 23:17:00 +0200
changeset 151 5d90caa7fb2c
parent 150 c8514af9b449
child 152 0cf6c938ac03
permissions -rw-r--r--
Switch global name from 'main' to 'mcabber' (v0.0.5)
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
     1
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
     2
[[!meta title="Documentation for Lua module for MCabber"]]
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
     3
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
     4
[[!toc]]
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
     5
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
     6
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
     7
- - -
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
     8
130
de560dec87a5 Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 129
diff changeset
     9
<a name="Lua.for.mcabber"></a>
de560dec87a5 Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 129
diff changeset
    10
## Lua for mcabber
de560dec87a5 Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 129
diff changeset
    11
Module provides embedded lua environment with some accessors to
de560dec87a5 Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 129
diff changeset
    12
mcabber functionality.
de560dec87a5 Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 129
diff changeset
    13
de560dec87a5 Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 129
diff changeset
    14
<a name="Options"></a>
de560dec87a5 Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 129
diff changeset
    15
### Options
de560dec87a5 Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 129
diff changeset
    16
de560dec87a5 Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 129
diff changeset
    17
* lua_init_filename - lua script, that will be loaded at startup
de560dec87a5 Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 129
diff changeset
    18
* lua_lm_debug      - if lm log handler is enabled, this option controls, whether lm log messages are dropped or passed to mcabber logging facility
de560dec87a5 Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 129
diff changeset
    19
134
d7ab555b9766 Add section header to docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 133
diff changeset
    20
<a name="Provided.lua.functions"></a>
d7ab555b9766 Add section header to docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 133
diff changeset
    21
### Provided lua functions
d7ab555b9766 Add section header to docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 133
diff changeset
    22
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    23
<a name="print"></a>
130
de560dec87a5 Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 129
diff changeset
    24
### print
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    25
Prints its arguments to log with default priority.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    26
**Arguments:** something, ...  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    27
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    28
<a name="dopath"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    29
### dopath
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    30
Loads lua file from default location.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    31
XXX: g_filename_from_utf8?  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    32
**Arguments:** string (filename, without ".lua")    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    33
**Return values:** string (error message, optional)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    34
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    35
<a name="yes.or.no.ansvers"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    36
### yes or no ansvers  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    37
**Values:**  1, 0, enable, disable, true, false, on, off, yes, no  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    38
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
    39
<a name="mcabber.yesno"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
    40
### mcabber.yesno
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    41
According to [yes or no ansvers](#yes.or.no.ansvers) returns true or false.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    42
If ansver is not recognized, returns nil.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    43
**Arguments:** anything (string expected)    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    44
**Return values:** boolean or nil  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    45
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
    46
<a name="mcabber.version"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
    47
### mcabber.version
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
    48
Returns table with information about mcabber  version  
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    49
**Return values:** table  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    50
133
57a18ccaf9ff Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 130
diff changeset
    51
<a name="log.message.type"></a>
57a18ccaf9ff Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 130
diff changeset
    52
### log message type  
57a18ccaf9ff Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 130
diff changeset
    53
**Values:**  normal, log, debug, notutf8  
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    54
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    55
<a name="roster.type"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    56
### roster type  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    57
**Values:**  user, group, agent, room, special  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    58
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
    59
<a name="mcabber.log"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
    60
### mcabber.log
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    61
Prints message to log.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    62
Note: most likely you need notutf8 flag enabled.  
133
57a18ccaf9ff Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 130
diff changeset
    63
**Arguments:** [log message type](#log.message.type), message, message...  
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    64
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
    65
<a name="mcabber.option"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
    66
### mcabber.option
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
    67
Sets or gets value of given config option.
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    68
You can specify nil as a value to delete option.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    69
If you omit option name, it returns hash table of all options.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    70
**Arguments:** string (option name, optional), string (value, optional)    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    71
**Return values:** string (value, optional)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    72
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
    73
<a name="mcabber.alias"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
    74
### mcabber.alias
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    75
Sets or gets alias.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    76
You can specify nil as a command to delete alias.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    77
If you omit alias name, it will return hash table of all aliases.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    78
**Arguments:** string (alias name, optional), string (command, optional)    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    79
**Return values:** string (command, optional)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    80
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
    81
<a name="mcabber.bind"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
    82
### mcabber.bind
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    83
Sets or gets binding.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    84
You can specify nil as a command to unbind key.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    85
If you omit keycode, it will return hash table of all bindings.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    86
**Arguments:** string (keycode, optional), string (command, optional)    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    87
**Return values:** string (command, optional)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    88
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
    89
<a name="mcabber.fileoption"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
    90
### mcabber.fileoption
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    91
Gets option, expanding it as filename.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    92
**Arguments:** string (option name)    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    93
**Return values:** string (expanded option value) or nil  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    94
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
    95
<a name="mcabber.connection"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
    96
### mcabber.connection
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    97
Returns lightuserdata of mcabber's loudmouth connection.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    98
This can be very useful with lua-loudmouth, and not much otherwise.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
    99
**Return values:** lightuserdata or nil  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   100
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   101
<a name="mcabber.print.info"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   102
### mcabber.print_info
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   103
Prints a system message to buddy's window.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   104
**Arguments:** string (jid), string (message)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   105
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   106
<a name="mcabber.beep"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   107
### mcabber.beep
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   108
Beeps with system speaker.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   109
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   110
<a name="mcabber.run"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   111
### mcabber.run
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   112
Executes given string as a mcabber  command.
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   113
Note: You should omit '/' in the beginning.  
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   114
**Arguments:** string  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   115
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   116
<a name="mcabber.status"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   117
### mcabber.status
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   118
Returns your current status.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   119
**Return values:** string (status letter), string (status message)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   120
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   121
<a name="mcabber.roster"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   122
### mcabber.roster
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   123
Returns array of jids of buddies in roster.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   124
**Return values:** table  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   125
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   126
<a name="mcabber.current.buddy"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   127
### mcabber.current_buddy
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   128
Returns jid of current selected buddy or sets current buddy to buddy with specified jid.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   129
**Arguments:** string (optional)    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   130
**Return values:** string (optional)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   131
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   132
<a name="mcabber.full.jid"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   133
### mcabber.full_jid
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   134
Returns full jid (with current resource) of specified buddy (or current, if not specified).
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   135
Note, that if there are no resources online, it will return just what it got.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   136
**Arguments:** string (jid, optional)    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   137
**Return values:** string (jid)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   138
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   139
<a name="resources.table"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   140
### resources table
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   141
Hash table with resource name as keys and another hash tables as values.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   142
Inner tables contain resource-specific information: priority, status and message.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   143
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   144
<a name="mcabber.buddy.info"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   145
### mcabber.buddy_info
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   146
Returns a hash table with information on specified buddy.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   147
Table contains fields type, name, onserver and resources (which points to [resources table](#resources.table)).  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   148
**Arguments:** string (jid)    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   149
**Return values:** table  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   150
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   151
<a name="mcabber.add.feature"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   152
### mcabber.add_feature
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   153
Adds xmlns to disco#info features list.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   154
**Arguments:** string (xmlns)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   155
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   156
<a name="mcabber.del.feature"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   157
### mcabber.del_feature
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   158
Removes xmlns from disco#info features list.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   159
**Arguments:** stirng (xmlns)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   160
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   161
<a name="event.context"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   162
### event context
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   163
Enum, indicating what exactly caused [event function](#event.function) firing.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   164
**Values:**  timeout, cancel, reject, accept  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   165
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   166
<a name="event.function"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   167
### event function
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   168
Function to be called, when some event state change occurs  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   169
**Arguments:** [event context](#event.context), string (event args)    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   170
**Return values:** boolean (if event shoud be preserved)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   171
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   172
<a name="mcabber.event"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   173
### mcabber.event
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   174
Creates new event. If called without arguments, returns event id list.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   175
**Arguments:** [event function](#event.function) (optional), string (event id), string (description, optional), integer (expiration timeout, optional)    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   176
**Return values:** string (event id) or nothing (creation error) or table (list of event names)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   177
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   178
<a name="completion.type"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   179
### completion type
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   180
Built-it completion types can be specified as string, instead of id.  
150
c8514af9b449 docs: Update api
Myhailo Danylenko <isbear@ukrpost.net>
parents: 142
diff changeset
   181
**Values:**  cmd, jid, urljid, name, status, filename, roster, buffer, group, groupname, multiline, room, resource, auth, request, events, eventsid, pgp, color, otr, ortpolicy, module, carbons, yesno  
142
7e8f523b66af Add completion sorting.
Myhailo Danylenko <isbear@ukrpost.net>
parents: 138
diff changeset
   182
7e8f523b66af Add completion sorting.
Myhailo Danylenko <isbear@ukrpost.net>
parents: 138
diff changeset
   183
<a name="completion.sorting.order"></a>
7e8f523b66af Add completion sorting.
Myhailo Danylenko <isbear@ukrpost.net>
parents: 138
diff changeset
   184
### completion sorting order
7e8f523b66af Add completion sorting.
Myhailo Danylenko <isbear@ukrpost.net>
parents: 138
diff changeset
   185
Sorting order for completion category.  
7e8f523b66af Add completion sorting.
Myhailo Danylenko <isbear@ukrpost.net>
parents: 138
diff changeset
   186
**Values:**  sort, direct, reverse, append, prepend  
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   187
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   188
<a name="command.arguments.table"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   189
### command arguments table
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   190
It can parse barewords (with escapes), double-quoted strings (with escapes), single-quoted strings (without escapes), options and arguments.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   191
Arguments are separated only by whitespace, so, consequential quoted strings or barewords are one argument.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   192
This strings are equal:
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   193
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   194
* ab\ cd\'e\\f\"
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   195
* "ab cd'e\\f\""
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   196
* 'ab cd'\''e\f"'
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   197
* ab" cd'"'e\f"'
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   198
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   199
Returned table have option names as keys, option values as values, and arguments as sequential members. -- option is supported.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   200
Example: "-t jid -m 9 -- -aa bb cc" will result in { t = 'jid', m = 9, '-aa', 'bb', 'cc' }
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   201
Implementation notes:
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   202
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   203
* All options should be before any arguments. First non-option argument disables options recognizing.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   204
* EOL is a cutting edge, that can cut much earlier, than you expect. Non-closed quoted strings lose leading quote and option without value loses its leading minus.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   205
* Escape character just before EOL is preserved.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   206
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   207
<a name="command.function"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   208
### command function
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   209
Function to handle newly registered command.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   210
Argument type passed depends on how command is registered.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   211
**Arguments:** string (arguments) or [command arguments table](#command.arguments.table)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   212
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   213
<a name="mcabber.parse.args"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   214
### mcabber.parse_args
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   215
Function to parse command argument string to [command arguments table](#command.arguments.table).  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   216
**Arguments:** string    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   217
**Return values:** table  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   218
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   219
<a name="mcabber.add.category"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   220
### mcabber.add_category
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   221
Adds completion category.  
142
7e8f523b66af Add completion sorting.
Myhailo Danylenko <isbear@ukrpost.net>
parents: 138
diff changeset
   222
**Arguments:** table (values are used as words for completion, optional), argument enum value ([completion sorting order](#completion.sorting.order), optional)    
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   223
**Return values:** integer (category id, in fact [completion type](#completion.type)) or nil  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   224
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   225
<a name="mcabber.del.category"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   226
### mcabber.del_category
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   227
Removes completion category.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   228
**Arguments:** integer (category id)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   229
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   230
<a name="mcabber.add.completion"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   231
### mcabber.add_completion
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   232
Adds word to a completion list.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   233
**Arguments:** integer (completion group id), string (word)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   234
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   235
<a name="mcabber.del.completion"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   236
### mcabber.del_completion
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   237
Removes word from a completion list.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   238
**Arguments:** integer (completion group id), string (word)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   239
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   240
<a name="mcabber.command"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   241
### mcabber.command
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   242
Associates mcabber  command name with given lua function.
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   243
As a completion you can also specify a string name (see [completion type](#completion.type)) instead of table.
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   244
For third-party completions you can just pass integer id.
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   245
Note, that for now there are no way to unregister completion group, so, resources can be exausted easily.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   246
Also note, that it ignores keys in a completion table.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   247
**Arguments:** string (command name), [command function](#command.function), boolean (parse args flag, optional), table (completions, optional)/[completion type](#completion.type) (or integer comletion group id, optional)    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   248
**Return values:** userdata (command object)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   249
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   250
<a name="command:del"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   251
### command:del
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   252
Unregisters given command from mcabber. Object will be destroyed later.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   253
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   254
<a name="timer.function"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   255
### timer function
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   256
Function, that will be called periodically until it returns false.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   257
**Return values:** boolean  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   258
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   259
<a name="mcabber.timer"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   260
### mcabber.timer
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   261
Creates new [timer function](#timer.function), that will be called periodically.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   262
**Arguments:** integer (interval, seconds), [timer function](#timer.function)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   263
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   264
<a name="background.reading.function"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   265
### background reading function
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   266
Function, that processes output from pipe in asynchronous way.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   267
**Arguments:** string (data) or nil (eof)    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   268
**Return values:** boolean (false if reading should be terminated)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   269
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   270
<a name="mcabber.bgread"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   271
### mcabber.bgread
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   272
Runs specified command and passes its output to a given function.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   273
**Arguments:** string (command), [background reading function](#background.reading.function)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   274
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   275
<a name="hook.handler.result"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   276
### hook handler result
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   277
What to do with hook processing afterwards  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   278
**Values:**  proceed, stop, drop  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   279
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   280
<a name="hook.handler.priority"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   281
### hook handler priority
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   282
Feel free to specify just a number instead of some preset value.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   283
**Values:**  high, default, idle-high, idle, low  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   284
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   285
<a name="hook.function"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   286
### hook function
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   287
Function to be called, when hook will be processsed.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   288
XXX: we can provide object as argument, but is this necessary?  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   289
**Arguments:** table (arguments hash)    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   290
**Return values:** [hook handler result](#hook.handler.result)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   291
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   292
<a name="mcabber.hook.run"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   293
### mcabber.hook_run
138
832ded5b44c9 Update api
Myhailo Danylenko <isbear@ukrpost.net>
parents: 134
diff changeset
   294
Runs handlers for given hook with supplied arguments.  
832ded5b44c9 Update api
Myhailo Danylenko <isbear@ukrpost.net>
parents: 134
diff changeset
   295
**Arguments:** string (hook name), table (hook arguments)    
832ded5b44c9 Update api
Myhailo Danylenko <isbear@ukrpost.net>
parents: 134
diff changeset
   296
**Return values:** [return enum field](#return.enum.field) ([hook handler result](#hook.handler.result))  
832ded5b44c9 Update api
Myhailo Danylenko <isbear@ukrpost.net>
parents: 134
diff changeset
   297
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   298
<a name="mcabber.hook"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   299
### mcabber.hook
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   300
Installs hook handler, returns an object, that you need to keep until
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   301
hook handling is no more needed.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   302
**Arguments:** string (hook name), [hook function](#hook.function), integer (priority, optional)    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   303
**Return values:** userdata (hook object)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   304
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   305
<a name="hook:del"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   306
### hook:del
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   307
Unregisters given hook handler from mcabber. Object will be destroyed later.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   308
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   309
<a name="guard.function"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   310
### guard function
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   311
Function to be called, when option changes it's value.
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   312
Old option value is still accessible through main.option.  
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   313
**Arguments:** string (key), string (new value)    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   314
**Return values:** string (value to save in hash table)  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   315
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   316
<a name="mcabber.add.guard"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   317
### mcabber.add_guard
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   318
Installs option guard for given option.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   319
**Arguments:** string ( option name ), [guard function](#guard.function)    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   320
**Return values:** boolean ( success )  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   321
151
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   322
<a name="mcabber.del.guard"></a>
5d90caa7fb2c Switch global name from 'main' to 'mcabber' (v0.0.5)
Myhailo Danylenko <isbear@ukrpost.net>
parents: 150
diff changeset
   323
### mcabber.del_guard
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   324
Removes option guard from given option.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   325
By default, lua will refuse to remove guards, not installed
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   326
by lua. Still, you can force guard removal.  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   327
**Arguments:** string ( option name ), boolean ( force removal )    
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   328
**Return values:** boolean ( success )  
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   329
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   330
- - -
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   331
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   332
- - -
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   333
130
de560dec87a5 Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 129
diff changeset
   334
<a name="Utility.Lua.Routines"></a>
de560dec87a5 Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 129
diff changeset
   335
## Utility Lua Routines
de560dec87a5 Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 129
diff changeset
   336
To handle conversion of enums and flag fields to/from human-readable strings.
de560dec87a5 Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 129
diff changeset
   337
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   338
<a name="argument.enum.field"></a>
130
de560dec87a5 Update api docs
Myhailo Danylenko <isbear@ukrpost.net>
parents: 129
diff changeset
   339
### argument enum field
129
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   340
String that will be converted to number or just plain number, that will be passed as is.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   341
Note, that if enum name is not recognized no error will be raised and default vale will be used.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   342
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   343
<a name="return.enum.field"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   344
### return enum field
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   345
String. If no string found, plain number will be returned.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   346
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   347
<a name="argument.flags.field"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   348
### argument flags field
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   349
Can be just plain number, then it is passed as is.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   350
Can be a string, then it is recognized as a single enabled flag.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   351
Or can be a table of the following format:
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   352
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   353
* integer keys should have string values, that will be used as enabled flag names or numerical values, that will be just ORed;
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   354
* string keys should be flag names, that will be enabled, if corresponding value contains true value.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   355
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   356
<a name="returned.flags.field"></a>
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   357
### returned flags field
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   358
Is always a table with present flag names as keys with true values.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   359
Not present flags are not present in table either.
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   360
Not recognized values, if present, will be stored as a number in a first sequential table member (table[1]).
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   361
ea30cf6c5bea Rearrange documentation
Myhailo Danylenko <isbear@ukrpost.net>
parents:
diff changeset
   362
- - -