-/* Conky, a system monitor, based on torsmo
+/* -*- mode: c; c-basic-offset: 4; tab-width: 4; indent-tabs-mode: t -*-
+ * vim: ts=4 sw=4 noet ai cindent syntax=c
+ *
+ * Conky, a system monitor, based on torsmo
*
* Please see COPYING for details
*
- * Copyright (c) 2005-2009 Brenden Matthews, et. al.
+ * Copyright (c) 2005-2010 Brenden Matthews, et. al.
* All rights reserved.
*
* This program is free software: you can redistribute it and/or modify
if (interval >= 0) {
cimlib_cache_flush_interval = interval;
} else {
- ERR("Imlib2: flush interval should be >= 0");
+ NORM_ERR("Imlib2: flush interval should be >= 0");
}
}
image_list_start = image_list_end = NULL;
}
-void cimlib_init(Display *display, Window drawable, Visual *visual, Colormap colourmap)
+Imlib_Context context;
+
+
+void cimlib_init(Display *disp, Drawable drawable, Visual *visual, Colormap
+ colourmap)
{
image_list_start = image_list_end = NULL;
+ context = imlib_context_new();
+ imlib_context_push(context);
if (!cache_size_set) cimlib_set_cache_size(DEFAULT_IMLIB2_CACHE_SIZE);
/* set the maximum number of colors to allocate for 8bpp and less to 256 */
imlib_set_color_usage(256);
/* dither for depths < 24bpp */
imlib_context_set_dither(1);
/* set the display , visual, colormap and drawable we are using */
- imlib_context_set_display(display);
+ imlib_context_set_display(disp);
imlib_context_set_visual(visual);
imlib_context_set_colormap(colourmap);
imlib_context_set_drawable(drawable);
}
+void cimlib_deinit(void)
+{
+ cimlib_cleanup();
+ cache_size_set = 0;
+// imlib_context_disconnect_display();
+ imlib_context_pop();
+ imlib_context_free(context);
+}
+
void cimlib_add_image(const char *args)
{
struct image_list_s *cur = NULL;
memset(cur, 0, sizeof(struct image_list_s));
if (!sscanf(args, "%1023s", cur->name)) {
- ERR("Invalid args for $image. Format is: '<path to image> (-p x,y) (-s WxH) (-n) (-f interval)' (got '%s')", args);
+ NORM_ERR("Invalid args for $image. Format is: '<path to image> (-p"
+ "x,y) (-s WxH) (-n) (-f interval)' (got '%s')", args);
free(cur);
return;
}
}
}
if (cur->flush_interval < 0) {
- ERR("Imlib2: flush interval should be >= 0");
+ NORM_ERR("Imlib2: flush interval should be >= 0");
cur->flush_interval = 0;
}
}
}
-static void
-cimlib_draw_image(struct image_list_s *cur, int *clip_x,
- int *clip_y, int *clip_x2, int *clip_y2)
+static void cimlib_draw_image(struct image_list_s *cur, int *clip_x, int
+ *clip_y, int *clip_x2, int *clip_y2)
{
int w, h;
time_t now = time(NULL);
+ static int rep = 0;
image = imlib_load_image(cur->name);
if (!image) {
- ERR("Unable to load image '%s'", cur->name);
+ if (!rep)
+ NORM_ERR("Unable to load image '%s'", cur->name);
+ rep = 1;
return;
}
+ rep = 0; /* reset so disappearing images are reported */
DBGP("Drawing image '%s' at (%i,%i) scaled to %ix%i, "
"caching interval set to %i (with -n opt %i)",
time_t now;
if (!image_list_start) return; /* are we actually drawing anything? */
-
- /* cheque if it's time to flush our cache */
+ fprintf(stderr, PACKAGE_NAME": cimlib_render start\n");
+ /* check if it's time to flush our cache */
now = time(NULL);
if (cimlib_cache_flush_interval && now - cimlib_cache_flush_interval > cimlib_cache_flush_last) {
int size = imlib_get_cache_size();
cimlib_cache_flush_last = now;
DBGP("Flushing Imlib2 cache (%li)\n", now);
}
-
/* take all the little rectangles to redraw and merge them into
* something sane for rendering */
buffer = imlib_create_image(width, height);
imlib_context_set_blend(1);
/* turn alpha channel on */
imlib_image_set_has_alpha(1);
-
cimlib_draw_all(&clip_x, &clip_y, &clip_x2, &clip_y2);
-
/* set the buffer image as our current image */
imlib_context_set_image(buffer);
-
/* setup our clip rect */
if (clip_x == INT_MAX) clip_x = 0;
if (clip_y == INT_MAX) clip_y = 0;
-
/* render the image at 0, 0 */
imlib_render_image_part_on_drawable_at_size(clip_x, clip_y, clip_x2 - clip_x,
clip_y2 - clip_y, x + clip_x, y + clip_y, clip_x2 - clip_x,