1 |
root |
1.1 |
#ifndef DEFAULTFONT_H_ |
2 |
|
|
#define DEFAULTFONT_H_ |
3 |
|
|
|
4 |
|
|
#include <X11/Xlib.h> |
5 |
|
|
#if XFT |
6 |
|
|
# include <X11/Xft/Xft.h> |
7 |
|
|
#endif |
8 |
|
|
|
9 |
|
|
#include <inttypes.h> |
10 |
|
|
|
11 |
|
|
#include "encoding.h" |
12 |
|
|
#include "rxvtutil.h" |
13 |
root |
1.12 |
#include "rxvttoolkit.h" |
14 |
|
|
|
15 |
|
|
struct rxvt_term; |
16 |
root |
1.1 |
|
17 |
root |
1.25 |
struct rxvt_fontprop |
18 |
|
|
{ |
19 |
root |
1.1 |
enum { |
20 |
root |
1.12 |
unset = -1, |
21 |
root |
1.1 |
medium = 100, bold = 200, |
22 |
|
|
roman = 0, italic = 100, |
23 |
|
|
}; |
24 |
root |
1.17 |
int width, height, ascent; |
25 |
root |
1.1 |
int weight, slant; |
26 |
|
|
}; |
27 |
|
|
|
28 |
root |
1.25 |
struct rxvt_font |
29 |
|
|
{ |
30 |
root |
1.1 |
// managed by the fontset |
31 |
root |
1.18 |
rxvt_term *term; |
32 |
|
|
void set_term (rxvt_term *term) { this->term = term; } |
33 |
root |
1.1 |
|
34 |
|
|
char *name; |
35 |
|
|
codeset cs; |
36 |
sf-exg |
1.31 |
bool loaded; // whether we tried loading it before (not whether it's loaded) |
37 |
root |
1.44 |
bool can_compose; // whether the font composes glyphs itself or not, should be a class method, but.. speed.... |
38 |
root |
1.1 |
|
39 |
|
|
// managed by the font object |
40 |
|
|
int ascent, descent, |
41 |
|
|
width, height; |
42 |
|
|
|
43 |
root |
1.26 |
void set_name (char *name_); |
44 |
root |
1.1 |
|
45 |
root |
1.20 |
rxvt_font (); |
46 |
root |
1.12 |
virtual ~rxvt_font () { free (name); }; |
47 |
|
|
|
48 |
|
|
virtual void clear () { }; |
49 |
root |
1.1 |
|
50 |
root |
1.18 |
void clear_rect (rxvt_drawable &d, int x, int y, int w, int h, int color) const; |
51 |
root |
1.1 |
|
52 |
|
|
virtual rxvt_fontprop properties () = 0; |
53 |
|
|
|
54 |
root |
1.22 |
virtual bool load (const rxvt_fontprop &morph, bool force_prop) = 0; |
55 |
root |
1.18 |
virtual bool has_char (uint32_t unicode, const rxvt_fontprop *prop, bool &careful) const = 0; |
56 |
root |
1.1 |
|
57 |
|
|
virtual void draw (rxvt_drawable &d, |
58 |
|
|
int x, int y, |
59 |
|
|
const text_t *text, int len, |
60 |
|
|
int fg, int bg) = 0; |
61 |
root |
1.37 |
|
62 |
|
|
void unref () |
63 |
|
|
{ |
64 |
|
|
clear (); |
65 |
|
|
delete this; |
66 |
|
|
} |
67 |
root |
1.1 |
}; |
68 |
|
|
|
69 |
|
|
struct rxvt_fallback_font; |
70 |
|
|
|
71 |
root |
1.25 |
struct rxvt_fontset |
72 |
|
|
{ |
73 |
root |
1.1 |
char *fontdesc; |
74 |
|
|
|
75 |
root |
1.39 |
// must be power-of-two - 1, also has to match RS_fontMask in rxvt.h |
76 |
|
|
#if USE_256_COLORS |
77 |
sf-exg |
1.43 |
enum { fontCount = 7 }; // 2 extra colors bits, 2 fewer fontcount bits |
78 |
root |
1.39 |
#else |
79 |
sf-exg |
1.43 |
enum { fontCount = 31 }; |
80 |
root |
1.39 |
#endif |
81 |
|
|
|
82 |
|
|
// index of first font in set |
83 |
|
|
enum { firstFont = 2 }; |
84 |
root |
1.27 |
|
85 |
root |
1.18 |
rxvt_fontset (rxvt_term *term); |
86 |
root |
1.1 |
~rxvt_fontset (); |
87 |
|
|
|
88 |
root |
1.13 |
bool populate (const char *desc); |
89 |
root |
1.22 |
void set_prop (const rxvt_fontprop &prop, bool force_prop) { this->prop = prop; this->force_prop = force_prop; } |
90 |
sf-exg |
1.32 |
int find_font_idx (uint32_t unicode); |
91 |
root |
1.1 |
int find_font (const char *name) const; |
92 |
root |
1.12 |
bool realize_font (int i); |
93 |
root |
1.1 |
|
94 |
root |
1.30 |
rxvt_font *operator [] (int id) const |
95 |
root |
1.1 |
{ |
96 |
root |
1.33 |
return fonts[id >> 1]; |
97 |
root |
1.1 |
} |
98 |
|
|
|
99 |
root |
1.34 |
int |
100 |
|
|
find_font (unicode_t unicode) |
101 |
|
|
{ |
102 |
|
|
return min<int> ((fontCount << 1) | 1, find_font_idx (unicode)); |
103 |
|
|
} |
104 |
|
|
|
105 |
root |
1.45 |
// find the font containing ' ' - we always assume this is font 1, as |
106 |
|
|
// every font should contain space, and font 1 is our base font. |
107 |
|
|
// pango assumes this, so it must be correct! |
108 |
|
|
int |
109 |
|
|
find_space_font () |
110 |
|
|
{ |
111 |
|
|
return 1 << 1; |
112 |
|
|
} |
113 |
|
|
|
114 |
root |
1.1 |
private: |
115 |
root |
1.18 |
rxvt_term *term; |
116 |
root |
1.13 |
rxvt_fontprop prop; |
117 |
root |
1.22 |
bool force_prop; |
118 |
root |
1.1 |
simplevec<rxvt_font *> fonts; |
119 |
|
|
const rxvt_fallback_font *fallback; |
120 |
|
|
|
121 |
root |
1.41 |
// this once was a "typedef xxx pagemap[256] |
122 |
sf-exg |
1.42 |
// but c++ arrays are not normal types, and cannot be |
123 |
root |
1.41 |
// put into containers, new doesn't work for them etc. etc. |
124 |
sf-exg |
1.42 |
// so we wrap out array into an object that acts like one. doh. |
125 |
root |
1.41 |
// example: C++ has no separate new and new [] forms, |
126 |
|
|
// and if pagemap is char[256], new incorrectly assumes we want to |
127 |
|
|
// allocate an array of chars instead of a single pagemap. |
128 |
|
|
struct pagemap |
129 |
|
|
{ |
130 |
|
|
unsigned char cppsucks[256]; |
131 |
|
|
unsigned char &operator [](int i) { return cppsucks [i]; }; |
132 |
|
|
}; |
133 |
root |
1.12 |
vector<pagemap *> fmap; |
134 |
root |
1.1 |
|
135 |
root |
1.13 |
void clear (); |
136 |
|
|
rxvt_font *new_font (const char *name, codeset cs); |
137 |
root |
1.34 |
void prepare_font (rxvt_font *font, codeset cs); |
138 |
root |
1.1 |
void add_fonts (const char *desc); |
139 |
root |
1.34 |
void push_font (rxvt_font *font); |
140 |
root |
1.1 |
}; |
141 |
|
|
|
142 |
|
|
#endif /* _DEFAULTFONT_H_ */ |
143 |
|
|
|