Project

General

Profile

unexist.dev

Assorted tidbits and projects

Hacking » History » Version 44

« Previous - Version 44/100 (diff) - Next » - Current version
Anonymous, 04/07/2009 11:49 PM


Development\015\012\015\012The following stuff is for developers only, that are interested in subtle's internals.\015\012\015\012{{>toc}}\015\012\015\012\015\012h1. Unit testing\015\012\015\012Subtle is shipped with a bunch of unit tests that can be run easily via rake tasks. (They can be found in the test folder.)\015\012\015\012Following tests are included:\015\012\015\012h2. Subtlext\015\012\015\012
\015\012% rake test                \015\012(in /home/unexist/projects/subtle)\015\012LD subtle\015\012LD subtler\015\012LD subtlext\015\012Loaded suite /usr/bin/rake\015\012Started\015\012......\015\012Finished in 0.047792 seconds.\015\012\015\0126 tests, 84 assertions, 0 failures, 0 errors\015\012
\015\012\015\012h2. Sublets\015\012\015\012
\015\012% rake test sublet=clock.rb\015\012(in /home/unexist/projects/subtle)\015\012LD subtle\015\012LD subtler\015\012LD subtlext\015\012Loaded suite /usr/bin/rake\015\012Started\015\012.\015\012Finished in 0.000561 seconds.\015\012\015\0121 tests, 2 assertions, 0 failures, 0 errors\015\012
\015\012\015\012h1. EWMH/ICCCM\015\012\015\012Here are all EWMH/NetWM atoms listed that are supported by subtle, subtler and subtlext.\015\012\015\012h2. Default\015\012\015\012h3. NET_NUMBER_OF_DESKTOPS\015\012\015\012top\015\012\015\012h3. _NET_DESKTOP_NAMES\015\012\015\012top\015\012\015\012h3. _NET_VIRTUAL_ROOTS\015\012\015\012top\015\012\015\012h3. _NET_CURRENT_DESKTOP\015\012\015\012Change current desktop\015\012
\015\012data.l[0] = <View id>\015\012data.l[1] = 0\015\012data.l[2] = 0\015\012data.l[3] = 0\015\012data.l[4] = 0\015\012
\015\012\015\012top\015\012\015\012h3. _NET_CLOSE_WINDOW\015\012\015\012Close client window\015\012
\015\012data.l[0] = <Timestamp>\015\012data.l[1] = <Ignored\015\012data.l[2] = 0\015\012data.l[3] = 0\015\012data.l[4] = 0\015\012
\015\012\015\012top\015\012\015\012h2. WM State\015\012\015\012Normally there are three types of actions: remove (0), add (1) and toggle (2), but we _always
toggle the states independent of the supplied action. The second property will be ignored.\015\012\015\012h3. _NET_WM_STATE_FULLSCREEN\015\012\015\012Toggle client fullscreen\015\012
\015\012data.l[0] = <Action>\015\012data.l[1] = _NET_WM_STATE_FULLSCREEN\015\012data.l[2] = <Ignored>\015\012data.l[3] = 0\015\012data.l[4] = 0\015\012
\015\012\015\012top\015\012\015\012h3. _NET_WM_STATE_ABOVE\015\012\015\012Toggle client float\015\012
\015\012data.l[0] = <Action>\015\012data.l[1] = _NET_WM_STATE_ABOVE\015\012data.l[2] = <Ignored>\015\012data.l[3] = 0\015\012data.l[4] = 0\015\012
\015\012\015\012top\015\012\015\012h3. _NET_WM_STATE_STICKY\015\012\015\012Toggle client urgent\015\012
\015\012data.l[0] = <Action>\015\012data.l[1] = _NET_WM_STATE_STICKY\015\012data.l[2] = <Ignored>\015\012data.l[3] = 0\015\012data.l[4] = 0\015\012
\015\012\015\012top\015\012\015\012h2. XEmbed\015\012\015\012h3. MANAGER\015\012\015\012top\015\012\015\012h3. _NET_SYSTEM_TRAY_OPCODE \015\012\015\012top\015\012\015\012h3. _NET_SYSTEM_TRAY_MESSAGE_DATA \015\012\015\012top\015\012\015\012h3. _NET_SYSTEM_TRAY_S\015\012\015\012top\015\012\015\012h3. _XEMBED\015\012\015\012top\015\012\015\012h3. _XEMBED_INFO\015\012\015\012top\015\012\015\012h3. XEMBED_EMBEDDED_NOTIFY\015\012\015\012top\015\012\015\012h3. XEMBED_WINDOW_ACTIVATE\015\012\015\012top\015\012\015\012h3. XEMBED_WINDOW_DEACTIVATE\015\012\015\012top\015\012\015\012h3. XEMBED_REQUEST_FOCUS\015\012\015\012top\015\012\015\012h3. XEMBED_FOCUS_IN\015\012\015\012top\015\012\015\012h3. XEMBED_FOCUS_OUT\015\012\015\012top\015\012\015\012h2. Extension\015\012\015\012h3. SUBTLE_WINDOW_TAG\015\012\015\012Add a tag to window (Client or View)\015\012
\015\012data.l[0] = <Window id>\015\012data.l[1] = <Tag id>\015\012data.l[2] = <Type>\015\012data.l[3] = 0\015\012data.l[4] = 0\015\012
\015\012\015\012*Type*: 0 = Client, 1 = View\015\012\015\012top\015\012\015\012h3. SUBTLE_WINDOW_UNTAG\015\012\015\012Remove a tag from window (Client or View)\015\012
\015\012data.l[0] = <Window id>\015\012data.l[1] = <Tag id>\015\012data.l[2] = <Type>\015\012data.l[3] = 0\015\012data.l[4] = 0\015\012
\015\012\015\012*Type*: 0 = Client, 1 = View\015\012\015\012top\015\012\015\012h3. SUBTLE_WINDOW_TAGS\015\012\015\012top\015\012\015\012h3. SUBTLE_WINDOW_GRAVITY\015\012\015\012Set client window gravity\015\012
\015\012data.l[0] = <Window id>\015\012data.l[1] = <View id>\015\012data.l[2] = <Gravity type>\015\012data.l[3] = 0\015\012data.l[4] = 0\015\012
\015\012\015\012*View*: If view id is -1 the current view will be used.\015\012\015\012top\015\012\015\012h3. SUBTLE_TAG_NEW\015\012\015\012Create a new tag\015\012
\015\012data.b = <Tag name>\015\012
\015\012\015\012top\015\012\015\012h3. SUBTLE_TAG_KILL\015\012\015\012Kill a tag\015\012
\015\012data.l[0] = <Tag id>\015\012data.l[1] = 0\015\012data.l[2] = 0\015\012data.l[3] = 0\015\012data.l[4] = 0\015\012
\015\012\015\012top\015\012\015\012h3. SUBTLE_VIEW_NEW\015\012\015\012Create a new view\015\012
\015\012data.b = <View name>\015\012
\015\012\015\012top\015\012\015\012h3. SUBTLE_SUBLET_UPDATE\015\012\015\012Get sublet list\015\012
\015\012data.l[0] = <Sublet id>\015\012data.l[1] = 0\015\012data.l[2] = 0\015\012data.l[3] = 0\015\012data.l[4] = 0\015\012
\015\012\015\012top\015\012\015\012h3. SUBTLE_SUBLET_LIST\015\012\015\012Get sublet list\015\012
\015\012data.l[0] = 0\015\012data.l[1] = 0\015\012data.l[2] = 0\015\012data.l[3] = 0\015\012data.l[4] = 0\015\012
\015\012\015\012top\015\012\015\012h3. SUBTLE_SUBLET_KILL\015\012\015\012Kill a sublet\015\012
\015\012data.l[0] = <Sublet id>\015\012data.l[1] = 0\015\012data.l[2] = 0\015\012data.l[3] = 0\015\012data.l[4] = 0\015\012
\015\012\015\012top\015\012