mirror of
https://github.com/Llewellynvdm/conky.git
synced 2024-11-17 10:35:10 +00:00
$font is now usable, fixed other things
git-svn-id: https://conky.svn.sourceforge.net/svnroot/conky/trunk/conky@46 7f574dfc-610e-0410-a909-a81674777703
This commit is contained in:
parent
c2b79415d0
commit
c1af5e969c
@ -1,3 +1,9 @@
|
|||||||
|
2005-07-02
|
||||||
|
* dramatically improved how conky handles fonts
|
||||||
|
* fixed issues with graph args
|
||||||
|
* shades and outlines don't work properly with graph gradients
|
||||||
|
(sorry!)
|
||||||
|
|
||||||
2005-07-01
|
2005-07-01
|
||||||
* stabilized code
|
* stabilized code
|
||||||
* added gradients to graphs (very pretty)
|
* added gradients to graphs (very pretty)
|
||||||
|
@ -38,7 +38,8 @@ mldonkey = mldonkey.c
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
conky_SOURCES = common.c fs.c top.c $(linux) mail.c mixer.c $(seti) $(mpd) \
|
conky_SOURCES = common.c fs.c top.c $(linux) mail.c mixer.c $(seti) $(mpd) \
|
||||||
$(solaris) $(freebsd) $(netbsd) $(cairo) conky.c conky.h x11.c $(metar) $(mldonkey)
|
$(solaris) $(freebsd) $(netbsd) $(cairo) conky.c conky.h x11.c $(metar) \
|
||||||
|
$(mldonkey)
|
||||||
|
|
||||||
conky_LDFLAGS = $(X11_LIBS) $(XFT_LIBS) $(CAIRO_LIBS)
|
conky_LDFLAGS = $(X11_LIBS) $(XFT_LIBS) $(CAIRO_LIBS)
|
||||||
|
|
||||||
|
@ -207,7 +207,8 @@ target_alias = @target_alias@
|
|||||||
@BUILD_METAR_TRUE@METAR_LIBS = -lmetar
|
@BUILD_METAR_TRUE@METAR_LIBS = -lmetar
|
||||||
@BUILD_MLDONKEY_TRUE@mldonkey = mldonkey.c
|
@BUILD_MLDONKEY_TRUE@mldonkey = mldonkey.c
|
||||||
conky_SOURCES = common.c fs.c top.c $(linux) mail.c mixer.c $(seti) $(mpd) \
|
conky_SOURCES = common.c fs.c top.c $(linux) mail.c mixer.c $(seti) $(mpd) \
|
||||||
$(solaris) $(freebsd) $(netbsd) $(cairo) conky.c conky.h x11.c $(metar) $(mldonkey)
|
$(solaris) $(freebsd) $(netbsd) $(cairo) conky.c conky.h x11.c $(metar) \
|
||||||
|
$(mldonkey)
|
||||||
|
|
||||||
conky_LDFLAGS = $(X11_LIBS) $(XFT_LIBS) $(CAIRO_LIBS)
|
conky_LDFLAGS = $(X11_LIBS) $(XFT_LIBS) $(CAIRO_LIBS)
|
||||||
conky_LDADD = $(METAR_LIBS)
|
conky_LDADD = $(METAR_LIBS)
|
||||||
|
4
README
4
README
@ -19,7 +19,9 @@
|
|||||||
|
|
||||||
Conky is generally very good on resources. However, certain objects in
|
Conky is generally very good on resources. However, certain objects in
|
||||||
Conky are harder on resources then others. In particular, the $tail,
|
Conky are harder on resources then others. In particular, the $tail,
|
||||||
$top, and $graph objects are quite costly in comparison to the rest of Conky.
|
$top, $font, and $graph objects are quite costly in comparison to
|
||||||
|
the rest of Conky.
|
||||||
|
|
||||||
If you do use them, please do not complain about memory or CPU usage,
|
If you do use them, please do not complain about memory or CPU usage,
|
||||||
unless you think something is going seriously wrong (mem leak, et cetera).
|
unless you think something is going seriously wrong (mem leak, et cetera).
|
||||||
|
|
||||||
|
339
conky.c
339
conky.c
@ -36,6 +36,130 @@ enum alignment {
|
|||||||
BOTTOM_RIGHT,
|
BOTTOM_RIGHT,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/* for fonts */
|
||||||
|
struct font_list {
|
||||||
|
|
||||||
|
char name[TEXT_BUFFER_SIZE];
|
||||||
|
int num;
|
||||||
|
XFontStruct *font;
|
||||||
|
|
||||||
|
#ifdef XFT
|
||||||
|
XftFont *xftfont;
|
||||||
|
int font_alpha;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
};
|
||||||
|
static int selected_font = 0;
|
||||||
|
static int font_count = -1;
|
||||||
|
struct font_list *fonts = NULL;
|
||||||
|
|
||||||
|
#ifdef XFT
|
||||||
|
|
||||||
|
#define font_height() use_xft ? (fonts[selected_font].xftfont->ascent + fonts[selected_font].xftfont->descent) : \
|
||||||
|
(fonts[selected_font].font->max_bounds.ascent + fonts[selected_font].font->max_bounds.descent)
|
||||||
|
#define font_ascent() use_xft ? fonts[selected_font].xftfont->ascent : fonts[selected_font].font->max_bounds.ascent
|
||||||
|
#define font_descent() use_xft ? fonts[selected_font].xftfont->descent : fonts[selected_font].font->max_bounds.descent
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
#define font_height() (fonts[selected_font].font->max_bounds.ascent + fonts[selected_font].font->max_bounds.descent)
|
||||||
|
#define font_ascent() fonts[selected_font].font->max_bounds.ascent
|
||||||
|
#define font_descent() fonts[selected_font].font->max_bounds.descent
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define MAX_FONTS 64 // hmm, no particular reason, just makes sense.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
int addfont(const char *data_in)
|
||||||
|
{
|
||||||
|
if (font_count > MAX_FONTS) {
|
||||||
|
CRIT_ERR("you don't need that many fonts, sorry.");
|
||||||
|
}
|
||||||
|
font_count++;
|
||||||
|
if (font_count == 0) {
|
||||||
|
if ((fonts = (struct font_list*)malloc(sizeof(struct font_list))) == NULL) {
|
||||||
|
CRIT_ERR("malloc");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fonts = realloc(fonts, (sizeof(struct font_list) * (font_count+1)));
|
||||||
|
if (fonts == NULL) {
|
||||||
|
CRIT_ERR("realloc in addfont");
|
||||||
|
}
|
||||||
|
if (strlen(data_in) < TEXT_BUFFER_SIZE) { // must account for null terminator
|
||||||
|
strncpy(fonts[font_count].name, data_in, TEXT_BUFFER_SIZE);
|
||||||
|
fonts[font_count].font_alpha = 0xffff;
|
||||||
|
} else {
|
||||||
|
CRIT_ERR("Oops...looks like something overflowed in addfont().");
|
||||||
|
}
|
||||||
|
return font_count;
|
||||||
|
}
|
||||||
|
|
||||||
|
void set_first_font(const char *data_in)
|
||||||
|
{
|
||||||
|
if (font_count < 0) {
|
||||||
|
if ((fonts = (struct font_list*)malloc(sizeof(struct font_list))) == NULL) {
|
||||||
|
CRIT_ERR("malloc");
|
||||||
|
}
|
||||||
|
font_count++;
|
||||||
|
}
|
||||||
|
if (strlen(data_in) > 1) {
|
||||||
|
strncpy(fonts[0].name, data_in, TEXT_BUFFER_SIZE-1);
|
||||||
|
fonts[0].font_alpha = 0xffff;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*void freefonts()
|
||||||
|
{
|
||||||
|
free(fonts);
|
||||||
|
}*/
|
||||||
|
|
||||||
|
|
||||||
|
static void load_fonts()
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
for (i=0;i<=font_count;i++) {
|
||||||
|
#ifdef XFT
|
||||||
|
/* load Xft font */
|
||||||
|
if (use_xft) {
|
||||||
|
if (fonts[i].xftfont != NULL)
|
||||||
|
XftFontClose(display, fonts[i].xftfont);
|
||||||
|
|
||||||
|
if ((fonts[i].xftfont =
|
||||||
|
XftFontOpenName(display, screen, fonts[i].name)) != NULL)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
ERR("can't load Xft font '%s'", fonts[i].name);
|
||||||
|
if ((fonts[i].xftfont =
|
||||||
|
XftFontOpenName(display, screen,
|
||||||
|
"courier-12")) != NULL)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
ERR("can't load Xft font '%s'", "courier-12");
|
||||||
|
|
||||||
|
if ((fonts[i].font = XLoadQueryFont(display, "fixed")) == NULL) {
|
||||||
|
CRIT_ERR("can't load font '%s'", "fixed");
|
||||||
|
}
|
||||||
|
use_xft = 0;
|
||||||
|
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
/* load normal font */
|
||||||
|
if (fonts[i].font != NULL)
|
||||||
|
XFreeFont(display, fonts[i].font);
|
||||||
|
|
||||||
|
if ((fonts[i].font = XLoadQueryFont(display, fonts[i].name)) == NULL) {
|
||||||
|
ERR("can't load font '%s'", fonts[i].name);
|
||||||
|
if ((fonts[i].font = XLoadQueryFont(display, "fixed")) == NULL) {
|
||||||
|
CRIT_ERR("can't load font '%s'", "fixed");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* default config file */
|
/* default config file */
|
||||||
static char *current_config;
|
static char *current_config;
|
||||||
|
|
||||||
@ -46,9 +170,6 @@ static unsigned int stuff_in_upper_case;
|
|||||||
static int text_alignment;
|
static int text_alignment;
|
||||||
static int gap_x, gap_y;
|
static int gap_x, gap_y;
|
||||||
|
|
||||||
/* Font used */
|
|
||||||
static char *font_name;
|
|
||||||
|
|
||||||
/* Update interval */
|
/* Update interval */
|
||||||
static double update_interval;
|
static double update_interval;
|
||||||
|
|
||||||
@ -89,10 +210,6 @@ static int pad_percents = 0;
|
|||||||
/* UTF-8 */
|
/* UTF-8 */
|
||||||
int utf8_mode = 0;
|
int utf8_mode = 0;
|
||||||
|
|
||||||
static void load_font();
|
|
||||||
static void set_font();
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* Text that is shown */
|
/* Text that is shown */
|
||||||
static char original_text[] =
|
static char original_text[] =
|
||||||
@ -132,15 +249,6 @@ static char *text = original_text;
|
|||||||
|
|
||||||
static int total_updates;
|
static int total_updates;
|
||||||
|
|
||||||
/* font stuff */
|
|
||||||
|
|
||||||
static XFontStruct *font;
|
|
||||||
|
|
||||||
#ifdef XFT
|
|
||||||
static XftFont *xftfont;
|
|
||||||
static int font_alpha = 65535;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* if-blocks */
|
/* if-blocks */
|
||||||
static int blockdepth = 0;
|
static int blockdepth = 0;
|
||||||
static int if_jumped = 0;
|
static int if_jumped = 0;
|
||||||
@ -174,33 +282,18 @@ static inline int calc_text_width(const char *s, unsigned int l)
|
|||||||
if (use_xft) {
|
if (use_xft) {
|
||||||
XGlyphInfo gi;
|
XGlyphInfo gi;
|
||||||
if (utf8_mode) {
|
if (utf8_mode) {
|
||||||
XftTextExtentsUtf8(display, xftfont, s, l, &gi);
|
XftTextExtentsUtf8(display, fonts[selected_font].xftfont, s, l, &gi);
|
||||||
} else {
|
} else {
|
||||||
XftTextExtents8(display, xftfont, s, l, &gi);
|
XftTextExtents8(display, fonts[selected_font].xftfont, s, l, &gi);
|
||||||
}
|
}
|
||||||
return gi.xOff;
|
return gi.xOff;
|
||||||
} else
|
} else
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
return XTextWidth(font, s, l);
|
return XTextWidth(fonts[selected_font].font, s, l);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef XFT
|
|
||||||
|
|
||||||
#define font_height() use_xft ? (xftfont->ascent + xftfont->descent) : \
|
|
||||||
(font->max_bounds.ascent + font->max_bounds.descent)
|
|
||||||
#define font_ascent() use_xft ? xftfont->ascent : font->max_bounds.ascent
|
|
||||||
#define font_descent() use_xft ? xftfont->descent : font->max_bounds.descent
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
#define font_height() (font->max_bounds.ascent + font->max_bounds.descent)
|
|
||||||
#define font_ascent() font->max_bounds.ascent
|
|
||||||
#define font_descent() font->max_bounds.descent
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* formatted text to render on screen, generated in generate_text(),
|
/* formatted text to render on screen, generated in generate_text(),
|
||||||
* drawn in draw_stuff() */
|
* drawn in draw_stuff() */
|
||||||
|
|
||||||
@ -230,10 +323,10 @@ static struct special_t {
|
|||||||
short width;
|
short width;
|
||||||
long arg;
|
long arg;
|
||||||
double *graph;
|
double *graph;
|
||||||
char *args;
|
|
||||||
double graph_scale;
|
double graph_scale;
|
||||||
int graph_width;
|
int graph_width;
|
||||||
int scaled;
|
int scaled;
|
||||||
|
short font_added;
|
||||||
unsigned long first_colour; // for graph gradient
|
unsigned long first_colour; // for graph gradient
|
||||||
unsigned long last_colour;
|
unsigned long last_colour;
|
||||||
} specials[128];
|
} specials[128];
|
||||||
@ -326,11 +419,15 @@ static char *scan_font(const char *args)
|
|||||||
else {
|
else {
|
||||||
ERR("font scan failed, lets hope it doesn't mess stuff up");
|
ERR("font scan failed, lets hope it doesn't mess stuff up");
|
||||||
}
|
}
|
||||||
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void new_font(char *buf, char * args) {
|
static void new_font(char *buf, char * args) {
|
||||||
struct special_t *s = new_special(buf, FONT);
|
struct special_t *s = new_special(buf, FONT);
|
||||||
s->args = args;
|
if (!s->font_added) {
|
||||||
|
s->font_added = addfont(args);
|
||||||
|
load_fonts();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void graph_append(struct special_t *graph, double f)
|
inline void graph_append(struct special_t *graph, double f)
|
||||||
@ -376,21 +473,23 @@ static const char *scan_graph(const char *args, int *w, int *h, unsigned int *fi
|
|||||||
/* graph's argument is either height or height,width */
|
/* graph's argument is either height or height,width */
|
||||||
if (args) {
|
if (args) {
|
||||||
if (sscanf(args, "%*s %d,%d %x %x", h, w, first_colour, last_colour) < 4) {
|
if (sscanf(args, "%*s %d,%d %x %x", h, w, first_colour, last_colour) < 4) {
|
||||||
|
if (sscanf(args, "%d,%d %x %x", h, w, first_colour, last_colour) < 4) {
|
||||||
|
*w = 0;
|
||||||
|
*h = 25;
|
||||||
if (sscanf(args, "%*s %x %x", first_colour, last_colour) < 2) {
|
if (sscanf(args, "%*s %x %x", first_colour, last_colour) < 2) {
|
||||||
|
*w = 0;
|
||||||
|
*h = 25;
|
||||||
if (sscanf(args, "%x %x", first_colour, last_colour) < 2) {
|
if (sscanf(args, "%x %x", first_colour, last_colour) < 2) {
|
||||||
|
*first_colour = 0;
|
||||||
|
*last_colour = 0;
|
||||||
if (sscanf(args, "%d,%d", h, w) < 2) {
|
if (sscanf(args, "%d,%d", h, w) < 2) {
|
||||||
|
*first_colour = 0;
|
||||||
|
*last_colour = 0;
|
||||||
sscanf(args, "%*s %d,%d", h, w);
|
sscanf(args, "%*s %d,%d", h, w);
|
||||||
*first_colour = 0;
|
|
||||||
*last_colour = 0;
|
|
||||||
}
|
}
|
||||||
*first_colour = 0;
|
|
||||||
*last_colour = 0;
|
|
||||||
}
|
}
|
||||||
*w = 0;
|
|
||||||
*h = 25;
|
|
||||||
}
|
}
|
||||||
*w = 0;
|
}
|
||||||
*h = 25;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2418,6 +2517,27 @@ static void generate_text()
|
|||||||
//free(p);
|
//free(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void set_font()
|
||||||
|
{
|
||||||
|
#ifdef XFT
|
||||||
|
if (use_xft) {
|
||||||
|
if (window.xftdraw != NULL)
|
||||||
|
XftDrawDestroy(window.xftdraw);
|
||||||
|
window.xftdraw = XftDrawCreate(display, window.drawable,
|
||||||
|
DefaultVisual(display,
|
||||||
|
screen),
|
||||||
|
DefaultColormap(display,
|
||||||
|
screen));
|
||||||
|
|
||||||
|
} else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
XSetFont(display, window.gc, fonts[selected_font].font->fid);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* text size
|
* text size
|
||||||
*/
|
*/
|
||||||
@ -2430,8 +2550,7 @@ static inline int get_string_width(const char *s)
|
|||||||
return *s ? calc_text_width(s, strlen(s)) : 0;
|
return *s ? calc_text_width(s, strlen(s)) : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int fontchange = 0;
|
int fontchange = 0;
|
||||||
static char *tmpfont = NULL;
|
|
||||||
|
|
||||||
static void text_size_updater(char *s)
|
static void text_size_updater(char *s)
|
||||||
{
|
{
|
||||||
@ -2460,12 +2579,8 @@ static void text_size_updater(char *s)
|
|||||||
}
|
}
|
||||||
|
|
||||||
else if (specials[special_index].type == FONT) {
|
else if (specials[special_index].type == FONT) {
|
||||||
fontchange = 1;
|
fontchange = specials[special_index].font_added;
|
||||||
tmpfont = strdup(font_name);
|
selected_font = specials[special_index].font_added;
|
||||||
free(font_name);
|
|
||||||
font_name = strdup(specials[special_index].args);
|
|
||||||
load_font();
|
|
||||||
set_font();
|
|
||||||
h = font_height();
|
h = font_height();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2475,15 +2590,9 @@ static void text_size_updater(char *s)
|
|||||||
}
|
}
|
||||||
p++;
|
p++;
|
||||||
}
|
}
|
||||||
|
|
||||||
w += get_string_width(s);
|
w += get_string_width(s);
|
||||||
if (fontchange) {
|
if (fontchange) {
|
||||||
fontchange = 0;
|
selected_font = 0;
|
||||||
free(font_name);
|
|
||||||
font_name = tmpfont;
|
|
||||||
tmpfont = NULL;
|
|
||||||
load_font();
|
|
||||||
set_font();
|
|
||||||
}
|
}
|
||||||
if (w > text_width)
|
if (w > text_width)
|
||||||
text_width = w;
|
text_width = w;
|
||||||
@ -2624,13 +2733,13 @@ static void draw_string(const char *s)
|
|||||||
c2.color.red = c.red;
|
c2.color.red = c.red;
|
||||||
c2.color.green = c.green;
|
c2.color.green = c.green;
|
||||||
c2.color.blue = c.blue;
|
c2.color.blue = c.blue;
|
||||||
c2.color.alpha = font_alpha;
|
c2.color.alpha = fonts[selected_font].font_alpha;
|
||||||
if (utf8_mode) {
|
if (utf8_mode) {
|
||||||
XftDrawStringUtf8(window.xftdraw, &c2, xftfont,
|
XftDrawStringUtf8(window.xftdraw, &c2, fonts[selected_font].xftfont,
|
||||||
cur_x, cur_y, (XftChar8 *) s,
|
cur_x, cur_y, (XftChar8 *) s,
|
||||||
strlen(s));
|
strlen(s));
|
||||||
} else {
|
} else {
|
||||||
XftDrawString8(window.xftdraw, &c2, xftfont,
|
XftDrawString8(window.xftdraw, &c2, fonts[selected_font].xftfont,
|
||||||
cur_x, cur_y, (XftChar8 *) s,
|
cur_x, cur_y, (XftChar8 *) s,
|
||||||
strlen(s));
|
strlen(s));
|
||||||
}
|
}
|
||||||
@ -2867,17 +2976,18 @@ static void draw_line(char *s)
|
|||||||
int gradient_size = 0;
|
int gradient_size = 0;
|
||||||
float gradient_factor = 0;
|
float gradient_factor = 0;
|
||||||
float gradient_update = 0;
|
float gradient_update = 0;
|
||||||
|
unsigned int tmpcolour = current_color;
|
||||||
if (specials[special_index].first_colour != 0 && specials[special_index].last_colour != 0) {
|
if (specials[special_index].first_colour != 0 && specials[special_index].last_colour != 0) {
|
||||||
current_color = specials[special_index].first_colour;
|
tmpcolour = specials[special_index].first_colour;
|
||||||
gradient_size = gradient_max(specials[special_index].first_colour, specials[special_index].last_colour);
|
gradient_size = gradient_max(specials[special_index].first_colour, specials[special_index].last_colour);
|
||||||
gradient_factor = (float)gradient_size / (w - 3);
|
gradient_factor = (float)gradient_size / (w - 3);
|
||||||
}
|
}
|
||||||
for (i = 0; i < w - 3; i++) {
|
for (i = 0; i < w - 3; i++) {
|
||||||
if (specials[special_index].first_colour != 0 && specials[special_index].last_colour != 0) {
|
if (specials[special_index].first_colour != 0 && specials[special_index].last_colour != 0) {
|
||||||
XSetForeground(display, window.gc, current_color);
|
XSetForeground(display, window.gc, tmpcolour);
|
||||||
gradient_update += gradient_factor;
|
gradient_update += gradient_factor;
|
||||||
while (gradient_update > 0) {
|
while (gradient_update > 0) {
|
||||||
current_color = do_gradient(current_color, specials[special_index].last_colour);
|
tmpcolour = do_gradient(tmpcolour, specials[special_index].last_colour);
|
||||||
gradient_update--;
|
gradient_update--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2902,14 +3012,13 @@ static void draw_line(char *s)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case FONT:
|
case FONT:
|
||||||
fontchange = 1;
|
if (fontchange) {
|
||||||
tmpfont = strdup(font_name);
|
cur_y -= font_ascent();
|
||||||
free(font_name);
|
selected_font = fontchange;
|
||||||
font_name = strdup(specials[special_index].args);
|
cur_y += font_ascent();
|
||||||
load_font();
|
|
||||||
set_font();
|
set_font();
|
||||||
cur_y += font_height();
|
}
|
||||||
cur_y -= font_h;
|
|
||||||
break;
|
break;
|
||||||
case FG:
|
case FG:
|
||||||
if (draw_mode == FG)
|
if (draw_mode == FG)
|
||||||
@ -2982,15 +3091,19 @@ static void draw_line(char *s)
|
|||||||
}
|
}
|
||||||
|
|
||||||
draw_string(s);
|
draw_string(s);
|
||||||
|
|
||||||
if (fontchange) {
|
if (fontchange) {
|
||||||
|
selected_font = 0;
|
||||||
|
set_font();
|
||||||
|
}
|
||||||
|
|
||||||
|
/*if (fontchange) {
|
||||||
fontchange = 0;
|
fontchange = 0;
|
||||||
free(font_name);
|
free(font_name);
|
||||||
font_name = tmpfont;
|
font_name = tmpfont;
|
||||||
tmpfont = NULL;
|
tmpfont = NULL;
|
||||||
load_font();
|
load_font();
|
||||||
set_font();
|
set_font();
|
||||||
}
|
}*/
|
||||||
|
|
||||||
cur_y += font_descent();
|
cur_y += font_descent();
|
||||||
}
|
}
|
||||||
@ -3321,65 +3434,6 @@ static void main_loop()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void load_font()
|
|
||||||
{
|
|
||||||
#ifdef XFT
|
|
||||||
/* load Xft font */
|
|
||||||
if (use_xft) {
|
|
||||||
if (xftfont != NULL)
|
|
||||||
XftFontClose(display, xftfont);
|
|
||||||
|
|
||||||
if ((xftfont =
|
|
||||||
XftFontOpenName(display, screen, font_name)) != NULL)
|
|
||||||
return;
|
|
||||||
|
|
||||||
ERR("can't load Xft font '%s'", font_name);
|
|
||||||
if ((xftfont =
|
|
||||||
XftFontOpenName(display, screen,
|
|
||||||
"courier-12")) != NULL)
|
|
||||||
return;
|
|
||||||
|
|
||||||
ERR("can't load Xft font '%s'", "courier-12");
|
|
||||||
|
|
||||||
if ((font = XLoadQueryFont(display, "fixed")) == NULL) {
|
|
||||||
CRIT_ERR("can't load font '%s'", "fixed");
|
|
||||||
}
|
|
||||||
use_xft = 0;
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* load normal font */
|
|
||||||
if (font != NULL)
|
|
||||||
XFreeFont(display, font);
|
|
||||||
|
|
||||||
if ((font = XLoadQueryFont(display, font_name)) == NULL) {
|
|
||||||
ERR("can't load font '%s'", font_name);
|
|
||||||
if ((font = XLoadQueryFont(display, "fixed")) == NULL) {
|
|
||||||
CRIT_ERR("can't load font '%s'", "fixed");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void set_font()
|
|
||||||
{
|
|
||||||
#ifdef XFT
|
|
||||||
if (use_xft) {
|
|
||||||
if (window.xftdraw != NULL)
|
|
||||||
XftDrawDestroy(window.xftdraw);
|
|
||||||
window.xftdraw = XftDrawCreate(display, window.drawable,
|
|
||||||
DefaultVisual(display,
|
|
||||||
screen),
|
|
||||||
DefaultColormap(display,
|
|
||||||
screen));
|
|
||||||
} else
|
|
||||||
#endif
|
|
||||||
{
|
|
||||||
XSetFont(display, window.gc, font->fid);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void load_config_file(const char *);
|
static void load_config_file(const char *);
|
||||||
|
|
||||||
/* signal handler that reloads config file */
|
/* signal handler that reloads config file */
|
||||||
@ -3391,7 +3445,7 @@ static void reload_handler(int a)
|
|||||||
if (current_config) {
|
if (current_config) {
|
||||||
clear_fs_stats();
|
clear_fs_stats();
|
||||||
load_config_file(current_config);
|
load_config_file(current_config);
|
||||||
load_font();
|
load_fonts();
|
||||||
set_font();
|
set_font();
|
||||||
extract_variable_text(text);
|
extract_variable_text(text);
|
||||||
free(text);
|
free(text);
|
||||||
@ -3500,12 +3554,11 @@ static void set_default_configurations(void)
|
|||||||
draw_borders = 0;
|
draw_borders = 0;
|
||||||
draw_shades = 1;
|
draw_shades = 1;
|
||||||
draw_outline = 0;
|
draw_outline = 0;
|
||||||
free(font_name);
|
|
||||||
#ifdef XFT
|
#ifdef XFT
|
||||||
use_xft = 1;
|
use_xft = 1;
|
||||||
font_name = strdup("courier-12");
|
set_first_font("courier-12");
|
||||||
#else
|
#else
|
||||||
font_name = strdup("6x10");
|
set_first_font("6x10");
|
||||||
#endif
|
#endif
|
||||||
gap_x = 5;
|
gap_x = 5;
|
||||||
gap_y = 5;
|
gap_y = 5;
|
||||||
@ -3726,8 +3779,8 @@ else if (strcasecmp(name, a) == 0 || strcasecmp(name, a) == 0)
|
|||||||
/* font silently ignored when Xft */
|
/* font silently ignored when Xft */
|
||||||
}
|
}
|
||||||
CONF("xftalpha") {
|
CONF("xftalpha") {
|
||||||
if (value)
|
if (value && font_count >= 0)
|
||||||
font_alpha = atof(value)
|
fonts[0].font_alpha = atof(value)
|
||||||
* 65535.0;
|
* 65535.0;
|
||||||
else
|
else
|
||||||
CONF_ERR;
|
CONF_ERR;
|
||||||
@ -3747,8 +3800,8 @@ else if (strcasecmp(name, a) == 0 || strcasecmp(name, a) == 0)
|
|||||||
CONF("font") {
|
CONF("font") {
|
||||||
#endif
|
#endif
|
||||||
if (value) {
|
if (value) {
|
||||||
free(font_name);
|
set_first_font(value);
|
||||||
font_name = strdup(value);
|
load_fonts();
|
||||||
} else
|
} else
|
||||||
CONF_ERR;
|
CONF_ERR;
|
||||||
}
|
}
|
||||||
@ -4070,7 +4123,7 @@ int main(int argc, char **argv)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 'f':
|
case 'f':
|
||||||
font_name = strdup(optarg);
|
set_first_font(optarg);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
#ifdef OWN_WINDOW
|
#ifdef OWN_WINDOW
|
||||||
@ -4113,7 +4166,7 @@ int main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* load font */
|
/* load font */
|
||||||
load_font();
|
load_fonts();
|
||||||
|
|
||||||
/* generate text and get initial size */
|
/* generate text and get initial size */
|
||||||
extract_variable_text(text);
|
extract_variable_text(text);
|
||||||
|
4
conky.h
4
conky.h
@ -1,7 +1,7 @@
|
|||||||
#ifndef _conky_h_
|
#ifndef _conky_h_
|
||||||
#define _conky_h_
|
#define _conky_h_
|
||||||
|
|
||||||
//#include <mcheck.h>
|
#include <mcheck.h>
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include <sys/utsname.h>
|
#include <sys/utsname.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
@ -378,8 +378,6 @@ extern mldonkey_config mlconfig;
|
|||||||
int get_mldonkey_status(mldonkey_config * config, mldonkey_info * info);
|
int get_mldonkey_status(mldonkey_config * config, mldonkey_info * info);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* in linux.c */
|
/* in linux.c */
|
||||||
|
|
||||||
/* nothing to see here */
|
/* nothing to see here */
|
||||||
|
Loading…
Reference in New Issue
Block a user