ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/src/rxvtfont.h
Revision: 1.45
Committed: Thu Jun 17 11:01:57 2021 UTC (2 years, 11 months ago) by root
Content type: text/plain
Branch: MAIN
Changes since 1.44: +9 -0 lines
Log Message:
 a rare codesize + time optimisation

File Contents

# User Rev Content
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