openbox/DESIGN/thoughts

129 lines
6.1 KiB
Text

goals:
openbox3 is supposed to be a wm shell, in that it offers a window management
core, and you are able to make it look however you want by writing theme
engines.
versioning:
im kinda thinking of openbox3 as being a product on its own, and then future
additions to it going as 3.x, instead of the crazy fast number system we've
adhered to so far. openbox4 would be an entirely new product as well. Maybe not
to the extent that 3 will be, but significantly different. If we ever even got
to that point, 3.x could live forever! :)
source heirarchy:
openbox3/
rules/ architechture/platform specific Makefile rules
po/ translations into every language known to man, even klingon!
libob3/ classes which wrap obtool functionality, this is our toolkit (builds a separate .la)
src/ the window manager
util/ utility classes/functions (Rect, itostring, etc)
engines/ abstract interface and common code for the engines
simple/ initial testbed. renders a simple hardcoded decroation style
blackbox/ renders blackbox themes (bsetroot/bsetbg in here? no. fuck that)
gl/ renders insane gl themes
pixmap/ renders some sort of pixmap themes. a less generic name might
be nice. (?)
sawfish/ renders sawfish themes (?)
gfxcore/ base gfx stuff for all to use (BColor, etc)
gl/ code for drawing gl stuff
pixmap/ code for drawing pixmaps
coding practices:
braces for if's/etc's shall go like this:
if () {
}
but, braces for funtions/classes/structs shall go like this:
class foo
{
}
and
void func()
{
}
thou shalt not 'cvs commit' without reading your 'cvs diff' first
indentation: 2 spaces (NO TABS). just like the ob2 format.
use const everywhere. pass pointer variables to functions as const.
we will be using doxygen to build documentation for the source code. *every*
function must have a doxygen comment for it.
misc:
the libob external header(s) and the engine interface header need to be
installed to the system include/ dir
make sure that obtools can render things with the current engine!
im going to write our own configure script! see if that works out. It will use
the rules directory to support all these fun platforms.
use GNU gettext for translation/nls support. See:
http://www.gnu.org/manual/gettext/html_chapter/gettext_10.html#SEC141
for its config, it will use $prefix/share/openbox/rc3 and ~/.openbox/rc3
unsigned is the DEVIL. we will use signed variables EVERYWHERE. Xlib
unsigned's should be converted to a signed long. If int isn't big enough
for your data, than use a long.
src:
everything will be event based. When you tell ob3 to add a workspace, it will
simply send the client message the same way an external app does. This way
there is only 1 code path for any process, not one for internally and one
for externally generated actions.
fuck workspace classes. all windows will exist in a screen list, and any per-
workspace processing can be done by checking each window's workspace()
value.
in each screen, have a list of the windows on the currently visible workspace.
This is updated when the workspace changes, or when windows are moved
between workspaces.
do we provide a callback interface from the plugins for when they catch mouse
input on the decorations? we should make some way to make mouse input std
across engines
dockapp support as good as wmaker
click-drag menus like wmaker/pwm/etc
allow for 'session management' of a sort. let the wm remember a window's
position/size/other attributes if they are saved by the user (window menu
or something). this is especially important for dockapps to be cool
on shutdown, first try to close each window with a normal close message. there
should be a timeout for this, and then kill it hard after the timeout/with a
dialog/whatever. This should be a separate option from normal exit, and
it should not do this from catching a signal.
for FocusIn/Out and Enter/LeaveNotify events, dont act on them immediately.
Rather, save which window's focused/entered until the queue is empty, then
if the focused/entered window has changed, act on it. This will be mad fast.
Do the same for changing workspaces.
keybindings. inside. final. god damn. i dont need 2 copies of the window
manager running, one just grabbing keys.
mouse gestures!
resizing modes (support one of these)
old style like now but without the server grab
old style like now but creating windows which show the bars so no grab is
needed
opaque mode
opaque mode where the frame resizes, and the client is resized aferwards (i
dont like this)
menus should have a most-recently or most-frequently chosen items section.
engines:
each engine builds as a separate .so library. they are opened by the src/ and
libob/ code.
engines will be passed any number of screens, and must deal with them all with
a single instance.
engines must get events for most everything so they can be cool
you can run a different engine on each screen (most people wont want GL on
their second screen without accel!)
engines are responsible for creating all of the appropriate decor windows
engines must tell the wm how big the decorations are at all times and keep it
updated for things like gravity.
all engines will have to inherit from an abstract interface defined in the
engines/ dir. there will be 2 abstact interfaces. the "lower power" mode,
and the "full power mode". The engines must each inherit from both
interfaces for the window manager and obtools to work.
normally, an engine would setup the root window, window borders, timers, etc
for everything involved in decorating windows. But also, it needs to be able
to run in a slimmed mode that mostly consists of paintSurface() (the same
way the menus are painted probably!). This would then be used by client
apps like obtoolbar. These 2 modes are the "low power" and "full power"
interfaces described above.
tool engine:
FillSurface
DrawBitmap (button pictures, such as X)
main engine:
DecorateWindow
etc :)