Merge pull request #266 from awesomeWM/juw-docs

docs: move documentation to C source
This commit is contained in:
Daniel Hahler 2015-06-21 21:33:22 +02:00
commit d4d5bbcd5d
119 changed files with 1074 additions and 1314 deletions

View File

@ -85,6 +85,11 @@ install:
# Install ldoc for building docs. # Install ldoc for building docs.
- sudo luarocks install ldoc - sudo luarocks install ldoc
# Install CMake 3+, via http://www.cmake.org/download/#latest.
- wget http://www.cmake.org/files/v3.2/cmake-3.2.3-Linux-x86_64.tar.Z
- tar xf cmake-3.2.3-Linux-x86_64.tar.Z
- PATH=$PWD/cmake-3.2.3-Linux-x86_64/bin:$PATH
script: script:
- export CMAKE_ARGS="-DLUA_LIBRARY=${LUALIB} -DLUA_INCLUDE_DIR=/usr/include/lua${LUAPKG}" - export CMAKE_ARGS="-DLUA_LIBRARY=${LUALIB} -DLUA_INCLUDE_DIR=/usr/include/lua${LUAPKG}"
- make && sudo make install && awesome --version - make && sudo env PATH=$PATH make install && awesome --version

View File

@ -1,4 +1,4 @@
cmake_minimum_required(VERSION 2.8.0) cmake_minimum_required(VERSION 3.0.0)
set(CMAKE_ALLOW_LOOSE_LOOP_CONSTRUCTS TRUE) set(CMAKE_ALLOW_LOOSE_LOOP_CONSTRUCTS TRUE)
if(COMMAND cmake_policy) if(COMMAND cmake_policy)
@ -15,7 +15,6 @@ endif()
include(awesomeConfig.cmake) include(awesomeConfig.cmake)
include_directories( include_directories(
${SOURCE_DIR}
${BUILD_DIR} ${BUILD_DIR}
${AWESOME_COMMON_REQUIRED_INCLUDE_DIRS} ${AWESOME_COMMON_REQUIRED_INCLUDE_DIRS}
${AWESOME_REQUIRED_INCLUDE_DIRS} ${AWESOME_REQUIRED_INCLUDE_DIRS}
@ -36,45 +35,45 @@ set(AWE_DOC_FILES
${SOURCE_DIR}/LICENSE) ${SOURCE_DIR}/LICENSE)
set(AWE_SRCS set(AWE_SRCS
${SOURCE_DIR}/awesome.c ${BUILD_DIR}/awesome.c
${SOURCE_DIR}/banning.c ${BUILD_DIR}/banning.c
${SOURCE_DIR}/color.c ${BUILD_DIR}/color.c
${SOURCE_DIR}/dbus.c ${BUILD_DIR}/dbus.c
${SOURCE_DIR}/draw.c ${BUILD_DIR}/draw.c
${SOURCE_DIR}/event.c ${BUILD_DIR}/event.c
${SOURCE_DIR}/ewmh.c ${BUILD_DIR}/ewmh.c
${SOURCE_DIR}/keygrabber.c ${BUILD_DIR}/keygrabber.c
${SOURCE_DIR}/luaa.c ${BUILD_DIR}/luaa.c
${SOURCE_DIR}/mouse.c ${BUILD_DIR}/mouse.c
${SOURCE_DIR}/mousegrabber.c ${BUILD_DIR}/mousegrabber.c
${SOURCE_DIR}/property.c ${BUILD_DIR}/property.c
${SOURCE_DIR}/root.c ${BUILD_DIR}/root.c
${SOURCE_DIR}/selection.c ${BUILD_DIR}/selection.c
${SOURCE_DIR}/spawn.c ${BUILD_DIR}/spawn.c
${SOURCE_DIR}/stack.c ${BUILD_DIR}/stack.c
${SOURCE_DIR}/strut.c ${BUILD_DIR}/strut.c
${SOURCE_DIR}/systray.c ${BUILD_DIR}/systray.c
${SOURCE_DIR}/xwindow.c ${BUILD_DIR}/xwindow.c
${SOURCE_DIR}/xkb.c ${BUILD_DIR}/xkb.c
${SOURCE_DIR}/common/atoms.c ${BUILD_DIR}/common/atoms.c
${SOURCE_DIR}/common/backtrace.c ${BUILD_DIR}/common/backtrace.c
${SOURCE_DIR}/common/buffer.c ${BUILD_DIR}/common/buffer.c
${SOURCE_DIR}/common/luaclass.c ${BUILD_DIR}/common/luaclass.c
${SOURCE_DIR}/common/lualib.c ${BUILD_DIR}/common/lualib.c
${SOURCE_DIR}/common/luaobject.c ${BUILD_DIR}/common/luaobject.c
${SOURCE_DIR}/common/util.c ${BUILD_DIR}/common/util.c
${SOURCE_DIR}/common/version.c ${BUILD_DIR}/common/version.c
${SOURCE_DIR}/common/xcursor.c ${BUILD_DIR}/common/xcursor.c
${SOURCE_DIR}/common/xembed.c ${BUILD_DIR}/common/xembed.c
${SOURCE_DIR}/common/xutil.c ${BUILD_DIR}/common/xutil.c
${SOURCE_DIR}/objects/button.c ${BUILD_DIR}/objects/button.c
${SOURCE_DIR}/objects/client.c ${BUILD_DIR}/objects/client.c
${SOURCE_DIR}/objects/drawable.c ${BUILD_DIR}/objects/drawable.c
${SOURCE_DIR}/objects/drawin.c ${BUILD_DIR}/objects/drawin.c
${SOURCE_DIR}/objects/key.c ${BUILD_DIR}/objects/key.c
${SOURCE_DIR}/objects/screen.c ${BUILD_DIR}/objects/screen.c
${SOURCE_DIR}/objects/tag.c ${BUILD_DIR}/objects/tag.c
${SOURCE_DIR}/objects/window.c) ${BUILD_DIR}/objects/window.c)
set(AWE_MAN_SRCS set(AWE_MAN_SRCS
${SOURCE_DIR}/manpages/awesome.1.txt ${SOURCE_DIR}/manpages/awesome.1.txt
@ -225,21 +224,13 @@ if(GENERATE_MANPAGES)
endif() endif()
# }}} # }}}
# {{{ Doxygen
if(DOXYGEN_EXECUTABLE)
add_custom_target(doc
COMMAND ${DOXYGEN_EXECUTABLE} awesome.doxygen
WORKING_DIRECTORY ${BUILD_DIR})
endif()
# }}}
# {{{ Lua API Documentation # {{{ Lua API Documentation
if(GENERATE_DOC) if(GENERATE_DOC)
if(NOT BUILD_DIR STREQUAL SOURCE_DIR) if(NOT BUILD_DIR STREQUAL SOURCE_DIR)
file(MAKE_DIRECTORY ${BUILD_DIR}/lib) file(MAKE_DIRECTORY ${BUILD_DIR}/lib)
endif() endif()
file(GLOB_RECURSE AWE_LUA_FILES ${BUILD_DIR}/lib/*.lua ${AWE_DOC_DIR}/capi/*.lua) file(GLOB_RECURSE AWE_LUA_FILES ${BUILD_DIR}/lib/*.lua)
file(GLOB_RECURSE AWE_MD_FILES ${AWE_DOC_DIR}/*.md) file(GLOB_RECURSE AWE_MD_FILES ${AWE_DOC_DIR}/*.md)
add_custom_target(ldoc ALL add_custom_target(ldoc ALL

View File

@ -1,246 +0,0 @@
DOXYFILE_ENCODING = UTF-8
PROJECT_NAME = awesome
PROJECT_NUMBER = devel
OUTPUT_DIRECTORY = doc
CREATE_SUBDIRS = NO
OUTPUT_LANGUAGE = English
BRIEF_MEMBER_DESC = YES
REPEAT_BRIEF = YES
ABBREVIATE_BRIEF = "The $name class" \
"The $name widget" \
"The $name file" \
is \
provides \
specifies \
contains \
represents \
a \
an \
the
ALWAYS_DETAILED_SEC = NO
INLINE_INHERITED_MEMB = NO
FULL_PATH_NAMES = YES
STRIP_FROM_PATH =
STRIP_FROM_INC_PATH =
SHORT_NAMES = NO
JAVADOC_AUTOBRIEF = NO
QT_AUTOBRIEF = NO
MULTILINE_CPP_IS_BRIEF = NO
INHERIT_DOCS = YES
SEPARATE_MEMBER_PAGES = NO
TAB_SIZE = 4
ALIASES =
OPTIMIZE_OUTPUT_FOR_C = YES
OPTIMIZE_OUTPUT_JAVA = NO
BUILTIN_STL_SUPPORT = NO
CPP_CLI_SUPPORT = NO
DISTRIBUTE_GROUP_DOC = NO
SUBGROUPING = YES
ALIASES += luastack="\par Lua Stack:"
ALIASES += lvalue="- \em value "
ALIASES += lparam="- \em param "
ALIASES += lreturn="- \em returns "
ALIASES += lfield="- \em fields "
#---------------------------------------------------------------------------
# Build related configuration options
#---------------------------------------------------------------------------
EXTRACT_ALL = YES
EXTRACT_PRIVATE = YES
EXTRACT_STATIC = YES
EXTRACT_LOCAL_CLASSES = YES
EXTRACT_LOCAL_METHODS = YES
EXTRACT_ANON_NSPACES = YES
HIDE_UNDOC_MEMBERS = NO
HIDE_UNDOC_CLASSES = NO
HIDE_FRIEND_COMPOUNDS = NO
HIDE_IN_BODY_DOCS = NO
INTERNAL_DOCS = NO
CASE_SENSE_NAMES = YES
HIDE_SCOPE_NAMES = NO
SHOW_INCLUDE_FILES = YES
INLINE_INFO = YES
SORT_MEMBER_DOCS = YES
SORT_BRIEF_DOCS = NO
SORT_BY_SCOPE_NAME = NO
GENERATE_TODOLIST = YES
GENERATE_TESTLIST = YES
GENERATE_BUGLIST = YES
GENERATE_DEPRECATEDLIST= YES
ENABLED_SECTIONS =
MAX_INITIALIZER_LINES = 30
SHOW_USED_FILES = YES
FILE_VERSION_FILTER =
#---------------------------------------------------------------------------
# configuration options related to warning and progress messages
#---------------------------------------------------------------------------
QUIET = YES
WARNINGS = YES
WARN_IF_UNDOCUMENTED = YES
WARN_IF_DOC_ERROR = YES
WARN_NO_PARAMDOC = NO
WARN_FORMAT = "$file:$line: $text"
WARN_LOGFILE =
#---------------------------------------------------------------------------
# configuration options related to the input files
#---------------------------------------------------------------------------
INPUT = @awesome_SOURCE_DIR@
INPUT_ENCODING = UTF-8
FILE_PATTERNS = *.c \
*.h \
common/*.c \
common/*.h \
widgets/*.c \
widgets/*.h \
RECURSIVE = YES
EXCLUDE =
EXCLUDE_SYMLINKS = NO
EXCLUDE_PATTERNS =
EXCLUDE_SYMBOLS =
EXAMPLE_PATH =
EXAMPLE_PATTERNS = *
EXAMPLE_RECURSIVE = NO
IMAGE_PATH =
INPUT_FILTER =
FILTER_PATTERNS =
FILTER_SOURCE_FILES = NO
#---------------------------------------------------------------------------
# configuration options related to source browsing
#---------------------------------------------------------------------------
SOURCE_BROWSER = YES
INLINE_SOURCES = NO
STRIP_CODE_COMMENTS = NO
REFERENCED_BY_RELATION = YES
REFERENCES_RELATION = YES
REFERENCES_LINK_SOURCE = YES
USE_HTAGS = NO
VERBATIM_HEADERS = YES
#---------------------------------------------------------------------------
# configuration options related to the alphabetical class index
#---------------------------------------------------------------------------
ALPHABETICAL_INDEX = NO
COLS_IN_ALPHA_INDEX = 5
IGNORE_PREFIX =
#---------------------------------------------------------------------------
# configuration options related to the HTML output
#---------------------------------------------------------------------------
GENERATE_HTML = YES
HTML_OUTPUT = html
HTML_FILE_EXTENSION = .html
HTML_HEADER =
HTML_FOOTER =
HTML_STYLESHEET =
GENERATE_HTMLHELP = NO
HTML_DYNAMIC_SECTIONS = NO
CHM_FILE =
HHC_LOCATION =
GENERATE_CHI = NO
BINARY_TOC = NO
TOC_EXPAND = NO
DISABLE_INDEX = NO
ENUM_VALUES_PER_LINE = 4
GENERATE_TREEVIEW = YES
TREEVIEW_WIDTH = 250
#---------------------------------------------------------------------------
# configuration options related to the LaTeX output
#---------------------------------------------------------------------------
GENERATE_LATEX = NO
LATEX_OUTPUT = latex
LATEX_CMD_NAME = latex
MAKEINDEX_CMD_NAME = makeindex
COMPACT_LATEX = NO
PAPER_TYPE = a4wide
EXTRA_PACKAGES =
LATEX_HEADER =
PDF_HYPERLINKS = NO
USE_PDFLATEX = NO
LATEX_BATCHMODE = NO
LATEX_HIDE_INDICES = NO
#---------------------------------------------------------------------------
# configuration options related to the RTF output
#---------------------------------------------------------------------------
GENERATE_RTF = NO
RTF_OUTPUT = rtf
COMPACT_RTF = NO
RTF_HYPERLINKS = NO
RTF_STYLESHEET_FILE =
RTF_EXTENSIONS_FILE =
#---------------------------------------------------------------------------
# configuration options related to the man page output
#---------------------------------------------------------------------------
GENERATE_MAN = NO
MAN_OUTPUT = man
MAN_EXTENSION = .3
MAN_LINKS = NO
#---------------------------------------------------------------------------
# configuration options related to the XML output
#---------------------------------------------------------------------------
GENERATE_XML = NO
XML_OUTPUT = xml
XML_SCHEMA =
XML_DTD =
XML_PROGRAMLISTING = YES
#---------------------------------------------------------------------------
# configuration options for the AutoGen Definitions output
#---------------------------------------------------------------------------
GENERATE_AUTOGEN_DEF = NO
#---------------------------------------------------------------------------
# configuration options related to the Perl module output
#---------------------------------------------------------------------------
GENERATE_PERLMOD = NO
PERLMOD_LATEX = NO
PERLMOD_PRETTY = YES
PERLMOD_MAKEVAR_PREFIX =
#---------------------------------------------------------------------------
# Configuration options related to the preprocessor
#---------------------------------------------------------------------------
ENABLE_PREPROCESSING = YES
MACRO_EXPANSION = YES
EXPAND_ONLY_PREDEF = YES
SEARCH_INCLUDES = YES
INCLUDE_PATH =
INCLUDE_FILE_PATTERNS =
PREDEFINED = WITH_DBUS = \
"__attribute__(x)="
EXPAND_AS_DEFINED =
SKIP_FUNCTION_MACROS = YES
#---------------------------------------------------------------------------
# Configuration::additions related to external references
#---------------------------------------------------------------------------
TAGFILES =
GENERATE_TAGFILE =
ALLEXTERNALS = NO
EXTERNAL_GROUPS = YES
PERL_PATH = /usr/bin/perl
#---------------------------------------------------------------------------
# Configuration options related to the dot tool
#---------------------------------------------------------------------------
CLASS_DIAGRAMS = NO
MSCGEN_PATH =
HIDE_UNDOC_RELATIONS = YES
HAVE_DOT = YES
CLASS_GRAPH = YES
COLLABORATION_GRAPH = YES
GROUP_GRAPHS = YES
UML_LOOK = YES
TEMPLATE_RELATIONS = YES
INCLUDE_GRAPH = YES
INCLUDED_BY_GRAPH = YES
CALL_GRAPH = YES
CALLER_GRAPH = YES
GRAPHICAL_HIERARCHY = YES
DIRECTORY_GRAPH = YES
DOT_IMAGE_FORMAT = png
DOT_PATH =
DOTFILE_DIRS =
DOT_GRAPH_MAX_NODES = 50
MAX_DOT_GRAPH_DEPTH = 1000
DOT_TRANSPARENT = YES
DOT_MULTI_TARGETS = NO
GENERATE_LEGEND = YES
DOT_CLEANUP = YES
#---------------------------------------------------------------------------
# Configuration::additions related to the search engine
#---------------------------------------------------------------------------
SEARCHENGINE = NO

View File

@ -56,12 +56,10 @@ if(NOT LDOC_EXECUTABLE)
endif() endif()
# theme graphics # theme graphics
a_find_program(CONVERT_EXECUTABLE convert TRUE) a_find_program(CONVERT_EXECUTABLE convert TRUE)
# doxygen
include(FindDoxygen)
# pkg-config # pkg-config
include(FindPkgConfig) include(FindPkgConfig)
# lua 5.1 # lua
include(FindLua51) include(FindLua)
# }}} # }}}
# {{{ Check if documentation can be build # {{{ Check if documentation can be build
@ -189,11 +187,6 @@ else()
message(STATUS "checking for __builtin_clz -- no") message(STATUS "checking for __builtin_clz -- no")
endif() endif()
# Error check
if(NOT LUA51_FOUND AND NOT LUA50_FOUND) # This is a workaround to a cmake bug
message(FATAL_ERROR "lua library not found")
endif()
set(AWESOME_REQUIRED_LDFLAGS set(AWESOME_REQUIRED_LDFLAGS
${AWESOME_COMMON_REQUIRED_LDFLAGS} ${AWESOME_COMMON_REQUIRED_LDFLAGS}
${AWESOME_REQUIRED_LDFLAGS} ${AWESOME_REQUIRED_LDFLAGS}
@ -284,31 +277,43 @@ set(AWESOME_THEMES_PATH ${AWESOME_DATA_PATH}/themes)
# }}} # }}}
# {{{ Configure files # {{{ Configure files
file(GLOB_RECURSE awesome_c_configure_files RELATIVE
${SOURCE_DIR}
${SOURCE_DIR}/*.c
${SOURCE_DIR}/*.h
${SOURCE_DIR}/*/*.c
${SOURCE_DIR}/*/*.h)
file(GLOB_RECURSE awesome_lua_configure_files RELATIVE file(GLOB_RECURSE awesome_lua_configure_files RELATIVE
${SOURCE_DIR} ${SOURCE_DIR}
${SOURCE_DIR}/lib/*.lua.in ${SOURCE_DIR}/lib/*.lua
${SOURCE_DIR}/docs/capi/*.lua.in ${SOURCE_DIR}/themes/*/*.lua)
${SOURCE_DIR}/docs/*.md
${SOURCE_DIR}/themes/*/*.lua.in)
set(AWESOME_CONFIGURE_FILES set(AWESOME_CONFIGURE_FILES
${awesome_c_configure_files}
${awesome_lua_configure_files} ${awesome_lua_configure_files}
config.h.in config.h
docs/config.ld.in docs/config.ld
awesomerc.lua.in awesomerc.lua
awesome-version-internal.h.in awesome-version-internal.h)
awesome.doxygen.in)
macro(a_configure_file file)
string(REGEX REPLACE ".in\$" "" outfile ${file})
message(STATUS "Configuring ${outfile}")
configure_file(${SOURCE_DIR}/${file}
${BUILD_DIR}/${outfile}
ESCAPE_QUOTE
@ONLY)
endmacro()
foreach(file ${AWESOME_CONFIGURE_FILES}) foreach(file ${AWESOME_CONFIGURE_FILES})
a_configure_file(${file}) configure_file(${SOURCE_DIR}/${file}
${BUILD_DIR}/${file}
ESCAPE_QUOTES
@ONLY)
endforeach()
#}}}
# {{{ Copy additional files
file(GLOB_RECURSE awesome_md_docs RELATIVE
${SOURCE_DIR}
${SOURCE_DIR}/docs/*.md)
set(AWESOME_ADDITIONAL_FILES
${awesome_md_docs})
foreach(file ${AWESOME_ADDITIONAL_FILES})
configure_file(${SOURCE_DIR}/${file}
${BUILD_DIR}/${file}
COPYONLY)
endforeach() endforeach()
#}}} #}}}

View File

@ -19,6 +19,14 @@
* *
*/ */
/** Handling of signals.
*
* This can not be used as a standalone class, but is instead referenced
* explicitely in the classes, where it can be used. In the respective classes,
* it then can be used via `classname:connect_signal(...)` etc.
* @classmod signals
*/
#include "common/luaobject.h" #include "common/luaobject.h"
#include "common/backtrace.h" #include "common/backtrace.h"
@ -160,6 +168,11 @@ luaA_settype(lua_State *L, lua_class_t *lua_class)
return 1; return 1;
} }
/** Add a signal.
* @tparam string name A signal name.
* @tparam func func A function to call when the signal is emitted.
* @function connect_signal
*/
void void
luaA_object_connect_signal(lua_State *L, int oud, luaA_object_connect_signal(lua_State *L, int oud,
const char *name, lua_CFunction fn) const char *name, lua_CFunction fn)
@ -168,6 +181,11 @@ luaA_object_connect_signal(lua_State *L, int oud,
luaA_object_connect_signal_from_stack(L, oud, name, -1); luaA_object_connect_signal_from_stack(L, oud, name, -1);
} }
/** Remove a signal.
* @tparam string name A signal name.
* @tparam func func A function to remove.
* @function disconnect_signal
*/
void void
luaA_object_disconnect_signal(lua_State *L, int oud, luaA_object_disconnect_signal(lua_State *L, int oud,
const char *name, lua_CFunction fn) const char *name, lua_CFunction fn)
@ -242,11 +260,10 @@ signal_object_emit(lua_State *L, signal_array_t *arr, const char *name, int narg
lua_pop(L, nargs); lua_pop(L, nargs);
} }
/** Emit a signal to an object. /** Emit a signal.
* \param L The Lua VM state. * @tparam string name A signal name.
* \param oud The object index on the stack. * @param[opt] ... Various arguments.
* \param name The name of the signal. * @function emit_signal
* \param nargs The number of arguments to pass to the called functions.
*/ */
void void
luaA_object_emit_signal(lua_State *L, int oud, luaA_object_emit_signal(lua_State *L, int oud,

88
dbus.c
View File

@ -19,6 +19,13 @@
* *
*/ */
/** awesome D-Bus API
* @author Julien Danjou <julien@danjou.info>
* @copyright 2008-2009 Julien Danjou
* @release @AWESOME_VERSION@
* @module dbus
*/
#include "config.h" #include "config.h"
#include "dbus.h" #include "dbus.h"
@ -666,12 +673,11 @@ a_dbus_bus_getbyname(const char *name)
} }
/** Register a D-Bus name to receive message from. /** Register a D-Bus name to receive message from.
* \param L The Lua VM state. *
* \return The number of elements pushed on stack. * @param bus A string indicating if we are using system or session bus.
* \luastack * @param name A string with the name of the D-Bus name to register.
* \lparam A string indicating if we are using system or session bus. * @return True if everything worked fine, false otherwise.
* \lparam A string with the name of the D-Bus name to register. * @function request_name
* \lreturn True if everything worked fine, false otherwise.
*/ */
static int static int
luaA_dbus_request_name(lua_State *L) luaA_dbus_request_name(lua_State *L)
@ -684,12 +690,11 @@ luaA_dbus_request_name(lua_State *L)
} }
/** Release a D-Bus name. /** Release a D-Bus name.
* \param L The Lua VM state. *
* \return The number of elements pushed on stack. * @param bus A string indicating if we are using system or session bus.
* \luastack * @param name A string with the name of the D-Bus name to unregister.
* \lparam A string indicating if we are using system or session bus. * @return True if everything worked fine, false otherwise.
* \lparam A string with the name of the D-Bus name to unregister. * @function release_name
* \lreturn True if everything worked fine, false otherwise.
*/ */
static int static int
luaA_dbus_release_name(lua_State *L) luaA_dbus_release_name(lua_State *L)
@ -702,11 +707,10 @@ luaA_dbus_release_name(lua_State *L)
} }
/** Add a match rule to match messages going through the message bus. /** Add a match rule to match messages going through the message bus.
* \param L The Lua VM state. *
* \return The number of elements pushed on stack. * @param bus A string indicating if we are using system or session bus.
* \luastack * @param name A string with the name of the match rule.
* \lparam A string indicating if we are using system or session bus. * @function add_match
* \lparam A string with the name of the match rule.
*/ */
static int static int
luaA_dbus_add_match(lua_State *L) luaA_dbus_add_match(lua_State *L)
@ -726,11 +730,10 @@ luaA_dbus_add_match(lua_State *L)
/** Remove a previously added match rule "by value" /** Remove a previously added match rule "by value"
* (the most recently-added identical rule gets removed). * (the most recently-added identical rule gets removed).
* \param L The Lua VM state. *
* \return The number of elements pushed on stack. * @param bus A string indicating if we are using system or session bus.
* \luastack * @param name A string with the name of the match rule.
* \lparam A string indicating if we are using system or session bus. * @function remove_match
* \lparam A string with the name of the match rule.
*/ */
static int static int
luaA_dbus_remove_match(lua_State *L) luaA_dbus_remove_match(lua_State *L)
@ -749,11 +752,10 @@ luaA_dbus_remove_match(lua_State *L)
} }
/** Add a signal receiver on the D-Bus. /** Add a signal receiver on the D-Bus.
* \param L The Lua VM state. *
* \return The number of elements pushed on stack. * @param interface A string with the interface name.
* \luastack * @param func The function to call.
* \lparam A string with the interface name. * @function connect_signal
* \lparam The function to call.
*/ */
static int static int
luaA_dbus_connect_signal(lua_State *L) luaA_dbus_connect_signal(lua_State *L)
@ -772,12 +774,11 @@ luaA_dbus_connect_signal(lua_State *L)
return 0; return 0;
} }
/** Add a signal receiver on the D-Bus. /** Remove a signal receiver on the D-Bus.
* \param L The Lua VM state. *
* \return The number of elements pushed on stack. * @param interface A string with the interface name.
* \luastack * @param func The function to call.
* \lparam A string with the interface name. * @function disconnect_signal
* \lparam The function to call.
*/ */
static int static int
luaA_dbus_disconnect_signal(lua_State *L) luaA_dbus_disconnect_signal(lua_State *L)
@ -791,18 +792,17 @@ luaA_dbus_disconnect_signal(lua_State *L)
} }
/** Emit a signal on the D-Bus. /** Emit a signal on the D-Bus.
* \param L The Lua VM state. *
* \return The number of elements pushed on stack. * @param bus A string indicating if we are using system or session bus.
* \luastack * @param path A string with the dbus path.
* \lparam A string indicating if we are using system or session bus. * @param interface A string with the dbus interface.
* \lparam A string with the dbus path. * @param method A string with the dbus method name.
* \lparam A string with the dbus interface. * @param type_1st_arg type of 1st argument
* \lparam A string with the dbus method name. * @param value_1st_arg value of 1st argument
* \lparam type of 1st arg * @param type_2nd_arg type of 2nd argument
* \lparam 1st arg value * @param value_2nd_arg value of 2nd argument
* \lparam type of 2nd arg
* \lparam 2nd arg value
* ... etc * ... etc
* @function emit_signal
*/ */
static int static int
luaA_dbus_emit_signal(lua_State *L) luaA_dbus_emit_signal(lua_State *L)

View File

@ -1,90 +0,0 @@
--- awesome core API
-- @author Julien Danjou <julien@danjou.info>
-- @copyright 2008-2009 Julien Danjou
-- @release @AWESOME_VERSION@
-- @module awesome
--- awesome global table.
--
-- @field version The version of awesome.
-- @field release The release name of awesome.
-- @field conffile The configuration file which has been loaded.
-- @field startup True if we are still in startup, false otherwise.
-- @field startup_errors Error message for errors that occured during startup.
-- @field composite_manager_running True if a composite manager is running.
-- @table awesome
--- Quit awesome.
--
-- @function quit
--- Execute another application, probably a window manager, to replace
-- awesome.
--
-- @param cmd The command line to execute.
-- @function exec
--- Restart awesome.
--
-- @name restart
-- @class function
--- Spawn a program.
--
-- @param cmd The command to launch. Either a string or a table of strings.
-- @param use_sn Use startup-notification, true or false, default to true.
-- @return Process ID if everything is OK, or an error string if an error occured.
--- Load an image
--
-- @param name The file name
-- @return A cairo image surface as light user datum
-- @function load_image
--- Register a new xproperty.
--
-- @param name The name of the X11 property
-- @param type One of "string", "number" or "boolean"
-- @function register_xproperty
--- Change a xproperty.
--
-- @param name The name of the X11 property
-- @param value The new value for the property
-- @function set_xproperty
--- Get the value of a xproperty.
--
-- @param name The name of the X11 property
-- @function get_xproperty
--- Add a global signal.
--
-- @param name A string with the event name.
-- @param func The function to call.
-- @function connect_signal
--- Remove a global signal.
--
-- @param name A string with the event name.
-- @param func The function to call.
-- @function disconnect_signal
--- Emit a global signal.
--
-- @param name A string with the event name.
-- @param ... Signal arguments.
-- @function emit_signal
--- Switch keyboard layout group.
-- @param num keyboard layout number, integer from 0 to 3
-- @function xkb_set_layout_group
--- Get current keyboard layout group.
-- @return current keyboard layout number
-- @function xkb_get_layout_group
--- Get description of configured layouts
-- @return String with description of configured layouts
-- @function xkb_get_group_names

View File

@ -1,31 +0,0 @@
--- awesome button API
-- @author Julien Danjou <julien@danjou.info>
-- @copyright 2008-2009 Julien Danjou
-- @release @AWESOME_VERSION@
-- @classmod button
--- Button object.
--
-- @tfield int button The mouse button number, or 0 for any button.
-- @tfield table modifiers The modifier key table that should be pressed while the
-- button is pressed.
-- @table button
--- Add a signal.
-- @tparam string name A signal name.
-- @tparam func func A function to call when the signal is emitted.
-- @function connect_signal
--- Remove a signal.
-- @tparam string name A signal name.
-- @tparam func func A function to remove.
-- @function disconnect_signal
--- Emit a signal.
-- @tparam string name A signal name.
-- @param[opt] ... Various arguments.
-- @function emit_signal
--- Get the number of instances.
-- @treturn int The number of button objects alive.
-- @function instances

View File

@ -1,156 +0,0 @@
--- awesome client API
-- @author Julien Danjou <julien@danjou.info>
-- @copyright 2008-2009 Julien Danjou
-- @release @AWESOME_VERSION@
-- @classmod client
--- Client object.
--
-- @field window The X window id.
-- @field name The client title.
-- @field skip_taskbar True if the client does not want to be in taskbar.
-- @field type The window type (desktop, normal, dock, …).
-- @field class The client class.
-- @field instance The client instance.
-- @field pid The client PID, if available.
-- @field role The window role, if available.
-- @field machine The machine client is running on.
-- @field icon_name The client name when iconified.
-- @field icon The client icon.
-- @field screen Client screen.
-- @field hidden Define if the client must be hidden, i.e. never mapped,
-- invisible in taskbar.
-- @field minimized Define it the client must be iconify, i.e. only visible in
-- taskbar.
-- @field size_hints_honor Honor size hints, i.e. respect size ratio.
-- @field border_width The client border width.
-- @field border_color The client border color.
-- @field urgent The client urgent state.
-- @field content An image representing the client window content (screenshot).
-- @field focus The focused client.
-- @field opacity The client opacity between 0 and 1.
-- @field ontop The client is on top of every other windows.
-- @field above The client is above normal windows.
-- @field below The client is below normal windows.
-- @field fullscreen The client is fullscreen or not.
-- @field maximized The client is maximized (horizontally and vertically) or not.
-- @field maximized_horizontal The client is maximized horizontally or not.
-- @field maximized_vertical The client is maximized vertically or not.
-- @field transient_for The client the window is transient for.
-- @field group_window Window identification unique to a group of windows.
-- @field leader_window Identification unique to windows spawned by the same command.
-- @field size_hints A table with size hints of the client: user_position,
-- user_size, program_position, program_size, etc.
-- @field sticky Set the client sticky, i.e. available on all tags.
-- @field modal Indicate if the client is modal.
-- @field focusable True if the client can receive the input focus.
-- @field shape_bounding The client's bounding shape as set by awesome as a (native) cairo surface.
-- @field shape_clip The client's clip shape as set by awesome as a (native) cairo surface.
-- @field shape_client_bounding The client's bounding shape as set by the program as a (native) cairo surface.
-- @field shape_client_clip The client's clip shape as set by the program as a (native) cairo surface.
-- @field startup_id The FreeDesktop StartId.
-- @field valid If the client that this object refers to is still managed by awesome.
-- @table client
--- Get all clients into a table.
--
-- @param[opt] screen A screen number.
-- @return A table with all clients.
-- @function get
--- Check if a client is visible on its screen.
--
-- @return A boolean value, true if the client is visible, false otherwise.
-- @function isvisible
--- Return client geometry.
--
-- @param arg1 A table with new coordinates, or none.
-- @return A table with client coordinates.
-- @function geometry
--- Apply size hints to a size.
-- @param width Desired width of client
-- @param height Desired height of client
-- @return Actual width of client
-- @return Actual height of client
-- @name apply_size_hints
-- @class function
--- Return client struts (reserved space at the edge of the screen).
--
-- @param struts A table with new strut values, or none.
-- @return A table with strut values.
-- @function struts
--- Get or set mouse buttons bindings for a client.
--
-- @param buttons_table An array of mouse button bindings objects, or nothing.
-- @return A table with all buttons.
-- @function buttons
--- Get or set keys bindings for a client.
--
-- @param keys_table An array of key bindings objects, or nothing.
-- @return A table with all keys.
-- @function keys
--- Access or set the client tags.
--
-- @param tags_table A table with tags to set, or none to get the current tags table.
-- @return A table with all tags.
-- @function tags
--- Kill a client.
--
-- @function kill
--- Swap a client with another one in global client list.
-- @client A client to swap with.
-- @function swap
--- Raise a client on top of others which are on the same layer.
--
-- @function raise
--- Lower a client on bottom of others which are on the same layer.
--
-- @function lower
--- Stop managing a client.
--
-- @function unmanage
--- Change a xproperty.
--
-- @param name The name of the X11 property
-- @param value The new value for the property
-- @function set_xproperty
--- Get the value of a xproperty.
--
-- @param name The name of the X11 property
-- @function get_xproperty
--- Add a signal.
--
-- @param name A signal name.
-- @param func A function to call when the signal is emitted.
-- @function connect_signal
--- Remove a signal.
--
-- @param name A signal name.
-- @param func A function to remove.
-- @function disconnect_signal
--- Emit a signal.
--
-- @param name A signal name.
-- @param[opt] ... Various arguments.
-- @function emit_signal
--- Get the number of instances.
--
-- @return The number of client objects alive.
-- @function instances

View File

@ -1,56 +0,0 @@
--- awesome D-Bus API
-- @author Julien Danjou <julien@danjou.info>
-- @copyright 2008-2009 Julien Danjou
-- @release @AWESOME_VERSION@
-- @module dbus
--- Register a D-Bus name to receive message from.
--
-- @param bus A string indicating if we are using system or session bus.
-- @param name A string with the name of the D-Bus name to register.
-- @return True if everything worked fine, false otherwise.
-- @function request_name
--- Release a D-Bus name.
--
-- @param bus A string indicating if we are using system or session bus.
-- @param name A string with the name of the D-Bus name to unregister.
-- @return True if everything worked fine, false otherwise.
-- @function release_name
--- Add a match rule to match messages going through the message bus.
--
-- @param bus A string indicating if we are using system or session bus.
-- @param name A string with the name of the match rule.
-- @function add_match
--- Remove a previously added match rule "by value"
-- (the most recently-added identical rule gets removed).
--
-- @param bus A string indicating if we are using system or session bus.
-- @param name A string with the name of the match rule.
-- @function remove_match
--- Add a signal receiver on the D-Bus.
--
-- @param interface A string with the interface name.
-- @param func The function to call.
-- @function connect_signal
--- Remove a signal receiver on the D-Bus.
--
-- @param interface A string with the interface name.
-- @param func The function to call.
-- @function disconnect_signal
-- Emit a signal on the D-Bus.
-- @param bus A string indicating if we are using system or session bus.
-- @param path A string with the dbus path.
-- @param interface A string with the dbus interface.
-- @param method A string with the dbus method name.
-- @param type_1st_arg type of 1st argument
-- @param value_1st_arg value of 1st argument
-- @param type_2nd_arg type of 2nd argument
-- @param value_2nd_arg value of 2nd argument
-- ... etc
-- @function emit_signal

View File

@ -1,43 +0,0 @@
--- awesome drawable API
-- @author Uli Schlachter <psychon@znc.in>
-- @copyright 2012 Uli Schlachter
-- @release @AWESOME_VERSION@
-- @classmod drawable
--- Drawable object.
--
-- @field surface The drawable's cairo surface.
-- @function drawable
--- Get drawable geometry. The geometry consists of x, y, width and height.
--
-- @return A table with drawable coordinates and geometry.
-- @function geometry
--- Refresh the drawable. When you are drawing to the surface, you have
-- call this function when you are done to make the result visible.
--
-- @function refresh
--- Add a signal.
--
-- @param name A signal name.
-- @param func A function to call when the signal is emitted.
-- @function connect_signal
--- Remove a signal.
--
-- @param name A signal name.
-- @param func A function to remove.
-- @function disconnect_signal
--- Emit a signal.
--
-- @param name A signal name.
-- @param[opt] ... Various arguments.
-- @function emit_signal
--- Get the number of instances.
--
-- @return The number of drawable objects alive.
-- @function instances

View File

@ -1,76 +0,0 @@
--- awesome drawin API
-- @author Julien Danjou <julien@danjou.info>
-- @copyright 2008-2009 Julien Danjou
-- @release @AWESOME_VERSION@
-- @classmod drawin
--- Drawin object.
--
-- @field border_width Border width.
-- @field border_color Border color.
-- @field ontop On top of other windows.
-- @field cursor The mouse cursor.
-- @field visible Visibility.
-- @field opacity The opacity of the drawin, between 0 and 1.
-- @field type The window type (desktop, normal, dock, …).
-- @field x The x coordinates.
-- @field y The y coordinates.
-- @field width The width of the drawin.
-- @field height The height of the drawin.
-- @field drawable The drawin's drawable.
-- @field window The X window id.
-- @field shape_bounding The drawin's bounding shape as a (native) cairo surface.
-- @field shape_clip The drawin's clip shape as a (native) cairo surface.
-- @table drawin
--- Get or set mouse buttons bindings to a drawin.
--
-- @param buttons_table A table of buttons objects, or nothing.
-- @function buttons
--- Get or set drawin struts.
--
-- @param strut A table with new strut, or nothing
-- @return The drawin strut in a table.
-- @function struts
--- Get or set drawin geometry. That's the same as accessing or setting the x, y, width or height
-- properties of a drawin.
--
-- @param A table with coordinates to modify.
-- @return A table with drawin coordinates and geometry.
-- @function geometry
--- Change a xproperty.
--
-- @param name The name of the X11 property
-- @param value The new value for the property
-- @function set_xproperty
--- Get the value of a xproperty.
--
-- @param name The name of the X11 property
-- @function get_xproperty
--- Add a signal.
--
-- @param name A signal name.
-- @param func A function to call when the signal is emitted.
-- @function connect_signal
--- Remove a signal.
--
-- @param name A signal name.
-- @param func A function to remove.
-- @function disconnect_signal
--- Emit a signal.
--
-- @param name A signal name.
-- @param[opt] ... Various arguments.
-- @function emit_signal
--- Get the number of instances.
--
-- @return The number of drawin objects alive.
-- @function instances

View File

@ -1,39 +0,0 @@
--- awesome key API
-- @author Julien Danjou <julien@danjou.info>
-- @copyright 2008-2009 Julien Danjou
-- @release @AWESOME_VERSION@
-- @classmod key
--- Key object.
--
-- @tfield string key The key to trigger an event.
-- @tfield string keysym Same as key, but return the name of the key symbol. It
-- can be identical to key, but for characters like '.' it will return
-- 'period'.
-- @tfield table modifiers The modifier key that should be pressed while the
-- key is pressed. An array with all the modifiers. Valid modifiers are: Any,
-- Mod1, Mod2, Mod3, Mod4, Mod5, Shift, Lock and Control.
-- @table key
--- Add a signal.
--
-- @tparam string name A signal name.
-- @tparam function func A function to call when the signal is emitted.
-- @function connect_signal
--- Remove a signal.
--
-- @tparam string name A signal name.
-- @tparam function func A function to remove.
-- @function disconnect_signal
--- Emit a signal.
--
-- @tparam string name A signal name.
-- @param[opt] ... Various arguments.
-- @function emit_signal
--- Get the number of instances.
--
-- @treturn number The number of key objects alive.
-- @function instances

View File

@ -1,39 +0,0 @@
--- awesome keygrabber API
-- @author Julien Danjou <julien@danjou.info>
-- @copyright 2008-2009 Julien Danjou
-- @release @AWESOME_VERSION@
-- @module keygrabber
---
-- Grab keyboard input and read pressed keys, calling a callback function at
-- each keypress, until `keygrabber.stop` is called.
-- The callback function receives three arguments:
--
-- * a table containing modifiers keys
-- * a string with the pressed key
-- * a string with either "press" or "release" to indicate the event type.
--
-- @param callback A callback function as described above.
-- @function run
-- @usage The following function can be bound to a key, and will be used to
-- resize a client using keyboard.
--
-- function resize(c)
-- keygrabber.run(function(mod, key, event)
-- if event == "release" then return end
--
-- if key == 'Up' then awful.client.moveresize(0, 0, 0, 5, c)
-- elseif key == 'Down' then awful.client.moveresize(0, 0, 0, -5, c)
-- elseif key == 'Right' then awful.client.moveresize(0, 0, 5, 0, c)
-- elseif key == 'Left' then awful.client.moveresize(0, 0, -5, 0, c)
-- else keygrabber.stop()
-- end
-- end)
-- end
--- Stop grabbing the keyboard.
-- @function stop
--- Check if the keygrabber is running.
-- @return A boolean value, true if running, false otherwise.
-- @function isrunning

View File

@ -1,25 +0,0 @@
--- awesome mouse API
-- @author Julien Danjou <julien@danjou.info>
-- @copyright 2008-2009 Julien Danjou
-- @release @AWESOME_VERSION@
-- @module mouse
--- Mouse library.
--
-- @field screen Mouse screen number.
-- @table mouse
--- A table with X and Y coordinates.
-- @field x X coordinate.
-- @field y Y coordinate.
-- @table coords_table
--- Get or set the mouse coords.
-- @tparam coords_table coords_table None or a table with x and y keys as mouse coordinates.
-- @tparam boolean silent Disable mouse::enter or mouse::leave events that could be triggered by the pointer when moving.
-- @treturn coords_table A table with mouse coordinates.
-- @function coords
--- Get the client or any object which is under the pointer.
-- @treturn client.client|nil A client or nil.
-- @function object_under_pointer

View File

@ -1,24 +0,0 @@
--- awesome mousegrabber API
-- @author Julien Danjou <julien@danjou.info>
-- @copyright 2008-2009 Julien Danjou
-- @release @AWESOME_VERSION@
-- @module mousegrabber
--- Grab the mouse pointer and list motions, calling callback function at each
-- motion. The callback function must return a boolean value: true to
-- continue grabbing, false to stop.
-- The function is called with one argument:
-- a table containing modifiers pointer coordinates.
--
-- @param func A callback function as described above.
-- @param cursor The name of a X cursor to use while grabbing.
-- @function run
--- Stop grabbing the mouse pointer.
--
-- @function stop
--- Check if the mousegrabber is running.
--
-- @return A boolean value, true if running, false otherwise.
-- @function isrunning

View File

@ -1,51 +0,0 @@
--- awesome root window API
-- @author Julien Danjou <julien@danjou.info>
-- @copyright 2008-2009 Julien Danjou
-- @release @AWESOME_VERSION@
-- @module root
--- Get or set global mouse bindings.
-- This binding will be available when you'll click on root window.
--
-- @param button_table An array of mouse button bindings objects, or nothing.
-- @return The array of mouse button bindings objects.
-- @function buttons
--- Get or set global key bindings.
-- These binding will be available when you press keys on the root window.
-- @tparam table|nil keys_array An array of key binding objects, or nothing.
-- @return The array of key bindings objects of this client.
-- @function keys
--- Set the root cursor.
--
-- @param cursor_name A X cursor name.
-- @function cursor
--- Send fake events. Usually the current focused client will get it.
--
-- @param event_type The event type: key_press, key_release, button_press, button_release
-- or motion_notify.
-- @param detail The detail: in case of a key event, this is the keycode to send, in
-- case of a button event this is the number of the button. In case of a
-- motion event, this is a boolean value which if true make the coordinates
-- relatives.
-- @param x In case of a motion event, this is the X coordinate.
-- @param y In case of a motion event, this is the Y coordinate.
-- @function fake_input
--- Get the drawins attached to a screen.
--
-- @return A table with all drawins.
-- @function drawins
--- Get the wallpaper as a cairo surface or set it as a cairo pattern.
--
-- @param pattern A cairo pattern as light userdata
-- @return A cairo surface or nothing.
-- @function wallpaper
--- Get the attached tags.
--
-- @return A table with all tags.
-- @function tags

View File

@ -1,40 +0,0 @@
--- awesome screen API
-- @author Julien Danjou <julien@danjou.info>
-- @copyright 2008-2009 Julien Danjou
-- @release @AWESOME_VERSION@
-- @classmod screen
--- Screen is a table where indexes are screen numbers. You can use `screen[1]`
-- to get access to the first screen, etc. Alternatively, if RANDR information
-- is available, you can use output names for finding screen objects.
-- Each screen has a set of properties.
--
-- @tfield table geometry The screen coordinates. Immutable.
-- @tfield table workarea The screen workarea.
-- @tfield int index The screen number.
-- @tfield table outputs If RANDR information is available, a list of outputs
-- for this screen and their size in mm.
-- @table screen
--- Get the number of screens.
--
-- @return The screen count, at least 1.
-- @function count
--- Add a signal to a screen.
--
-- @string name A signal name.
-- @func func A function to call when the signal is emitted.
-- @function connect_signal
--- Remove a signal to a screen.
--
-- @string name A signal name.
-- @func func A function to remove
-- @function disconnect_signal
--- Emit a signal to a screen.
--
-- @string name A signal name.
-- @param[opt] ... Various arguments.
-- @function emit_signal

View File

@ -1,10 +0,0 @@
--- awesome selection (clipboard) API
-- @author Julien Danjou <julien@danjou.info>
-- @copyright 2008-2009 Julien Danjou
-- @release @AWESOME_VERSION@
-- @module selection
--- Get the selection (clipboard) content.
--
-- @return A string with the selection (clipboard) content.
-- @function selection

View File

@ -1,41 +0,0 @@
--- awesome tag API
-- @author Julien Danjou <julien@danjou.info>
-- @copyright 2008-2009 Julien Danjou
-- @release @AWESOME_VERSION@
-- @classmod tag
--- Tag object.
--
-- @field name Tag name.
-- @field selected True if the tag is selected to be viewed.
-- @field activated True if the tag is active and can be used.
-- @table tag
--- Get or set the clients attached to this tag.
--
-- @param clients_table None or a table of clients to set as being tagged with this tag.
-- @return A table with the clients attached to this tags.
-- @function clients
--- Add a signal.
--
-- @param name A signal name.
-- @param func A function to call when the signal is emitted.
-- @function connect_signal
--- Remove a signal.
--
-- @param name A signal name.
-- @param func A function to remove.
-- @function disconnect_signal
--- Emit a signal.
--
-- @param name A signal name.
-- @param[opt] ... Various arguments.
-- @function emit_signal
--- Get the number of instances.
--
-- @return The number of tag objects alive.
-- @function instances

View File

@ -26,6 +26,8 @@ tparam_alias('client', 'client.client')
tparam_alias('tag', 'tag') tparam_alias('tag', 'tag')
-- Should be default, but is not. Sets up "@tab" => "@tparam table". -- Should be default, but is not. Sets up "@tab" => "@tparam table".
tparam_alias('tab', 'table') tparam_alias('tab', 'table')
-- New type for signals
new_type("signal", "Signals", false, "Arguments")
-- More fitting section names -- More fitting section names
kind_names={topic='Documentation', module='Libraries'} kind_names={topic='Documentation', module='Libraries'}
@ -34,8 +36,19 @@ kind_names={topic='Documentation', module='Libraries'}
sort_modules=true sort_modules=true
file = { file = {
-- C parts of libraries
'../dbus.c',
'../keygrabber.c',
'../luaa.c',
'../mouse.c',
'../mousegrabber.c',
'../root.c',
'../selection.c',
'../spawn.c',
'../xkb.c',
'../common/luaobject.c',
'../objects/',
-- LUA libraries -- LUA libraries
'capi/',
'../lib/', '../lib/',
exclude = { exclude = {
-- exclude these modules, as they do not contain any written -- exclude these modules, as they do not contain any written

View File

@ -19,6 +19,13 @@
* *
*/ */
/** awesome keygrabber API
* @author Julien Danjou <julien@danjou.info>
* @copyright 2008-2009 Julien Danjou
* @release @AWESOME_VERSION@
* @module keygrabber
*/
#include <unistd.h> #include <unistd.h>
#include <xkbcommon/xkbcommon.h> #include <xkbcommon/xkbcommon.h>
#include <xkbcommon/xkbcommon-x11.h> #include <xkbcommon/xkbcommon-x11.h>
@ -106,18 +113,31 @@ keygrabber_handlekpress(lua_State *L, xcb_key_press_event_t *e)
return true; return true;
} }
/** Grab keyboard and read pressed keys, calling callback function at each key /** Grab keyboard input and read pressed keys, calling a callback function at
* press, until keygrabber.stop is called. * each keypress, until `keygrabber.stop` is called.
* The function is called with 3 arguments: * The callback function receives three arguments:
* a table containing modifiers keys, a string with the key pressed and a
* string with either "press" or "release" to indicate the event type.
* *
* \param L The Lua VM state. * * a table containing modifiers keys
* \return The number of elements pushed on stack. * * a string with the pressed key
* * a string with either "press" or "release" to indicate the event type.
* *
* \luastack * @param callback A callback function as described above.
* @function run
* @usage The following function can be bound to a key, and will be used to
* resize a client using keyboard.
* *
* \lparam A callback function as described above. * function resize(c)
* keygrabber.run(function(mod, key, event)
* if event == "release" then return end
*
* if key == 'Up' then awful.client.moveresize(0, 0, 0, 5, c)
* elseif key == 'Down' then awful.client.moveresize(0, 0, 0, -5, c)
* elseif key == 'Right' then awful.client.moveresize(0, 0, 5, 0, c)
* elseif key == 'Left' then awful.client.moveresize(0, 0, -5, 0, c)
* else keygrabber.stop()
* end
* end)
* end
*/ */
static int static int
luaA_keygrabber_run(lua_State *L) luaA_keygrabber_run(lua_State *L)
@ -137,8 +157,7 @@ luaA_keygrabber_run(lua_State *L)
} }
/** Stop grabbing the keyboard. /** Stop grabbing the keyboard.
* \param L The Lua VM state. * @function stop
* \return The number of elements pushed on stack.
*/ */
int int
luaA_keygrabber_stop(lua_State *L) luaA_keygrabber_stop(lua_State *L)
@ -149,10 +168,8 @@ luaA_keygrabber_stop(lua_State *L)
} }
/** Check if keygrabber is running. /** Check if keygrabber is running.
* \param L The Lua VM state. * @function isrunning
* \return The number of elements pushed on stack. * @treturn bool A boolean value, true if keygrabber is running, false otherwise.
* \luastack
* \lreturn A boolean value, true if keygrabber is running, false otherwise.
*/ */
static int static int
luaA_keygrabber_isrunning(lua_State *L) luaA_keygrabber_isrunning(lua_State *L)

Some files were not shown because too many files have changed in this diff Show More