diff --git a/src/irc/channel.lua b/src/irc/channel.lua index 4e77ae9..99e4c59 100644 --- a/src/irc/channel.lua +++ b/src/irc/channel.lua @@ -1,3 +1,6 @@ +--- +-- Implementation of the Channel class + -- initialization {{{ local base = _G local irc = require 'irc' @@ -6,9 +9,25 @@ local socket = require 'socket' local table = require 'table' -- }}} +--- +-- This module implements a channel object representing a single channel we +-- have joined +-- @release 0.02 module 'irc.channel' -- object metatable {{{ +-- TODO: this
shouldn't be necessary - bug in luadoc +--- +-- An object of the Channel class represents a single joined channel. It has +-- several table fields, and can be used in string contexts (returning the +-- channel name).
+-- @class table +-- @name Channel +-- @field name Name of the channel (read only) +-- @field topic Channel topic, if set (read/write, writing to this sends a +-- topic change request to the server for this channel) +-- @field chanmode Channel mode (public/private/secret) (read only) +-- @field members Array of all members of this channel local mt = { -- __index() {{{ __index = function(self, key) @@ -63,7 +82,13 @@ local mt = { -- }}} -- private methods {{{ --- set_basic_mode() - sets a no-arg mode on a channel {{{ +-- set_basic_mode {{{ +-- +-- Sets a no-arg mode on a channel. +-- @name chan:set_basic_mode +-- @param self Channel object +-- @param set True to set the mode, false to unset it +-- @param letter Letter of the mode local function set_basic_mode(self, set, letter) if set then irc.send("MODE", self.name, "+" .. letter) @@ -75,6 +100,10 @@ end -- }}} -- constructor {{{ +--- +-- Creates a new Channel object. +-- @param chan Name of the new channel +-- @return The new channel instance function new(chan) return base.setmetatable({_name = chan, _topic = {}, _chanmode = "", _members = {}}, mt) @@ -83,7 +112,10 @@ end -- public methods {{{ -- iterators {{{ --- each_op() {{{ +-- each_op {{{ +--- +-- Iterator over the ops in the channel +-- @param self Channel object function each_op(self) return function(state, arg) return misc.value_iter(state, arg, @@ -96,7 +128,10 @@ function each_op(self) end -- }}} --- each_voice() {{{ +-- each_voice {{{ +--- +-- Iterator over the voiced users in the channel +-- @param self Channel object function each_voice(self) return function(state, arg) return misc.value_iter(state, arg, @@ -109,7 +144,10 @@ function each_voice(self) end -- }}} --- each_user() {{{ +-- each_user {{{ +--- +-- Iterator over the normal users in the channel +-- @param self Channel object function each_user(self) return function(state, arg) return misc.value_iter(state, arg, @@ -123,7 +161,10 @@ function each_user(self) end -- }}} --- each_member() {{{ +-- each_member {{{ +--- +-- Iterator over all users in the channel +-- @param self Channel object function each_member(self) return misc.value_iter, self._members, nil end @@ -131,7 +172,11 @@ end -- }}} -- return tables of users {{{ --- ops() {{{ +-- ops {{{ +--- +-- Gets an array of all the ops in the channel. +-- @param self Channel object +-- @return Array of channel ops function ops(self) local ret = {} for nick in self:each_op() do @@ -141,7 +186,11 @@ function ops(self) end -- }}} --- voices() {{{ +-- voices {{{ +--- +-- Gets an array of all the voiced users in the channel. +-- @param self Channel object +-- @return Array of channel voiced users function voices(self) local ret = {} for nick in self:each_voice() do @@ -151,7 +200,11 @@ function voices(self) end -- }}} --- users() {{{ +-- users {{{ +--- +-- Gets an array of all the normal users in the channel. +-- @param self Channel object +-- @return Array of channel normal users function users(self) local ret = {} for nick in self:each_user() do @@ -161,7 +214,11 @@ function users(self) end -- }}} --- members() {{{ +-- members {{{ +--- +-- Gets an array of all the users in the channel. +-- @param self Channel object +-- @return Array of channel users function members(self) local ret = {} -- not just returning self._members, since the return value shouldn't be