1
0
mirror of https://github.com/Llewellynvdm/conky.git synced 2025-01-14 19:39:47 +00:00

make own_window a lua setting

This commit is contained in:
Pavel Labath 2010-02-26 14:37:34 +01:00
parent 12e98c7da5
commit efac83e814
3 changed files with 26 additions and 24 deletions

View File

@ -365,7 +365,6 @@ long default_fg_color, default_bg_color, default_out_color;
static int set_transparent = 0;
#ifdef OWN_WINDOW
static int own_window = 0;
static int background_colour = 0;
/* fixed size/pos is set if wm/user changes them */
@ -973,7 +972,7 @@ static void update_text_area(void)
#endif /* OWN_WINDOW */
#ifdef OWN_WINDOW
if (own_window && !fixed_pos) {
if (own_window.get(*state) && !fixed_pos) {
x += workarea[0];
y += workarea[1];
text_start_x = window.border_inner_margin + window.border_outer_margin + window.border_width;
@ -1956,7 +1955,7 @@ static void main_loop(void)
selected_font = 0;
update_text_area();
#ifdef OWN_WINDOW
if (own_window) {
if (own_window.get(*state)) {
int changed = 0;
/* resize window if it isn't right size */
@ -2071,13 +2070,13 @@ static void main_loop(void)
#ifdef OWN_WINDOW
case ReparentNotify:
/* make background transparent */
if (own_window) {
if (own_window.get(*state)) {
set_transparent_background(window.window, own_window_argb_value);
}
break;
case ConfigureNotify:
if (own_window) {
if (own_window.get(*state)) {
/* if window size isn't what expected, set fixed size */
if (ev.xconfigure.width != window.width
|| ev.xconfigure.height != window.height) {
@ -2121,7 +2120,7 @@ static void main_loop(void)
break;
case ButtonPress:
if (own_window) {
if (own_window.get(*state)) {
/* if an ordinary window with decorations */
if ((window.type == TYPE_NORMAL &&
(!TEST_HINT(window.hints,
@ -2144,7 +2143,7 @@ static void main_loop(void)
break;
case ButtonRelease:
if (own_window) {
if (own_window.get(*state)) {
/* if an ordinary window with decorations */
if ((window.type == TYPE_NORMAL)
&& (!TEST_HINT(window.hints,
@ -2573,7 +2572,6 @@ static void set_default_configurations(void)
minimum_height = 5;
maximum_width = 0;
#ifdef OWN_WINDOW
own_window = 0;
window.type = TYPE_NORMAL;
window.hints = 0;
strcpy(window.class_name, PACKAGE_NAME);
@ -2699,11 +2697,11 @@ static void X11_create_window(void)
{
if (out_to_x.get(*state)) {
#ifdef OWN_WINDOW
init_window(own_window, text_width + window.border_inner_margin * 2 + window.border_outer_margin * 2 + window.border_width * 2,
init_window(text_width + window.border_inner_margin * 2 + window.border_outer_margin * 2 + window.border_width * 2,
text_height + window.border_inner_margin * 2 + window.border_outer_margin * 2 + window.border_width * 2, set_transparent, background_colour,
xargv, xargc);
#else /* OWN_WINDOW */
init_window(0, text_width + window.border_inner_margin * 2 + window.border_outer_margin * 2 + window.border_width * 2,
init_window(text_width + window.border_inner_margin * 2 + window.border_outer_margin * 2 + window.border_width * 2,
text_height + window.border_inner_margin * 2 + window.border_outer_margin * 2 + window.border_width * 2, set_transparent, 0,
xargv, xargc);
#endif /* OWN_WINDOW */
@ -2713,10 +2711,10 @@ static void X11_create_window(void)
update_text_area(); /* to position text/window on screen */
#ifdef OWN_WINDOW
if (own_window && !fixed_pos) {
XMoveWindow(display, window.window, window.x, window.y);
}
if (own_window) {
if (own_window.get(*state)) {
if (not fixed_pos)
XMoveWindow(display, window.window, window.x, window.y);
set_transparent_background(window.window, own_window_argb_value);
}
#endif
@ -3245,11 +3243,6 @@ char load_config_file(const char *f)
}
#ifdef BUILD_X11
#ifdef OWN_WINDOW
CONF("own_window") {
if (value) {
own_window = string_to_bool(value);
}
}
CONF("own_window_class") {
if (value) {
memset(window.class_name, 0, sizeof(window.class_name));
@ -3979,7 +3972,8 @@ void initialisation(int argc, char **argv) {
#ifdef OWN_WINDOW
case 'o':
own_window = 1;
state->pushboolean(true);
own_window.lua_set(*state);
break;
#endif
#ifdef BUILD_XDBE

View File

@ -263,7 +263,7 @@ void destroy_window(void)
colour_set = -1;
}
void init_window(int own_window, int w, int h, int set_trans, int back_colour,
void init_window(int w, int h, int set_trans, int back_colour,
char **argv, int argc)
{
/* There seems to be some problems with setting transparent background
@ -274,7 +274,7 @@ void init_window(int own_window, int w, int h, int set_trans, int back_colour,
window_created = 1;
#ifdef OWN_WINDOW
if (own_window) {
if (own_window.get(*state)) {
int depth = 0, flags;
Visual *visual = NULL;
@ -578,7 +578,7 @@ void init_window(int own_window, int w, int h, int set_trans, int back_colour,
XSelectInput(display, window.window, ExposureMask | PropertyChangeMask
#ifdef OWN_WINDOW
| (own_window ? (StructureNotifyMask |
| (own_window.get(*state) ? (StructureNotifyMask |
ButtonPressMask | ButtonReleaseMask) : 0)
#endif
);
@ -928,3 +928,7 @@ conky::lua_traits<alignment>::Map conky::lua_traits<alignment>::map = {
conky::config_setting<alignment> text_alignment("alignment", conky::simple_accessors<alignment>(NONE, false));
conky::config_setting<bool> out_to_x("out_to_x", conky::simple_accessors<bool>(false, false));
#ifdef OWN_WINDOW
conky::config_setting<bool> own_window("own_window", conky::simple_accessors<bool>(false, false));
#endif

View File

@ -120,7 +120,7 @@ extern struct conky_window window;
extern char window_created;
void init_X11(const char*);
void init_window(int use_own_window, int width, int height, int set_trans,
void init_window(int width, int height, int set_trans,
int back_colour, char **argv, int argc);
void destroy_window(void);
void create_gc(void);
@ -156,5 +156,9 @@ enum alignment {
extern conky::config_setting<alignment> text_alignment;
extern conky::config_setting<bool> out_to_x;
#ifdef OWN_WINDOW
extern conky::config_setting<bool> own_window;
#endif
#endif /*X11_H_*/
#endif /* BUILD_X11 */