--- rxvt-unicode/src/defaultfont.h 2004/02/13 12:16:21 1.11 +++ rxvt-unicode/src/defaultfont.h 2004/02/24 00:44:23 1.14 @@ -1,6 +1,11 @@ #ifndef DEFAULTFONT_H_ #define DEFAULTFONT_H_ +#include +#if XFT +# include +#endif + #ifdef HAVE_XSETLOCALE # define X_LOCALE # include @@ -28,6 +33,20 @@ int weight, slant; }; +struct rxvt_drawable { + rxvt_display *display; + Drawable drawable; +# if XFT + XftDraw *xftdrawable; +#endif + rxvt_drawable (rxvt_display *display, Drawable drawable) + : display(display), drawable(drawable), xftdrawable(0) { } + ~rxvt_drawable (); + + operator Drawable() { return drawable; } + operator XftDraw *(); +}; + struct rxvt_font { // managed by the fontset rxvt_t r; @@ -49,9 +68,9 @@ } rxvt_font () { name = 0; } - ~rxvt_font () { clear (); free (name); }; + ~rxvt_font () { free (name); }; - void clear_rect (int x, int y, int w, int h, int color); + void clear_rect (rxvt_drawable &d, int x, int y, int w, int h, int color); virtual void clear () { }; @@ -60,14 +79,13 @@ virtual bool load (const rxvt_fontprop &prop) = 0; virtual bool has_codepoint (uint32_t unicode) = 0; - virtual void draw (int x, int y, + virtual void draw (rxvt_drawable &d, + int x, int y, const text_t *text, int len, int fg, int bg) = 0; }; -//#define FONT_REF(obj) (obj)->refcnt++ -//#define FONT_UNREF(obj) if (!--(obj)->refcnt) delete (obj) -#define FONT_UNREF(f) delete f +#define FONT_UNREF(f) do { (f)->clear (); delete (f); } while (0) struct rxvt_fallback_font; @@ -77,7 +95,7 @@ rxvt_font *new_font (const char *name, codeset cs); - void populate (const char *desc); + bool populate (const char *desc); int find_font (uint32_t unicode); rxvt_font *operator [] (int id) const