ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/src/rxvtfont.h
(Generate patch)

Comparing rxvt-unicode/src/rxvtfont.h (file contents):
Revision 1.29 by root, Tue Mar 30 23:36:14 2010 UTC vs.
Revision 1.45 by root, Thu Jun 17 11:01:57 2021 UTC

6# include <X11/Xft/Xft.h> 6# include <X11/Xft/Xft.h>
7#endif 7#endif
8 8
9#include <inttypes.h> 9#include <inttypes.h>
10 10
11#include "feature.h"
12#include "encoding.h" 11#include "encoding.h"
13#include "rxvtutil.h" 12#include "rxvtutil.h"
14#include "rxvttoolkit.h" 13#include "rxvttoolkit.h"
15 14
16struct rxvt_term; 15struct rxvt_term;
32 rxvt_term *term; 31 rxvt_term *term;
33 void set_term (rxvt_term *term) { this->term = term; } 32 void set_term (rxvt_term *term) { this->term = term; }
34 33
35 char *name; 34 char *name;
36 codeset cs; 35 codeset cs;
37 bool loaded; // wether we tried loading it before (not wether it's loaded) 36 bool loaded; // whether we tried loading it before (not whether it's loaded)
37 bool can_compose; // whether the font composes glyphs itself or not, should be a class method, but.. speed....
38 38
39 // managed by the font object 39 // managed by the font object
40 int ascent, descent, 40 int ascent, descent,
41 width, height; 41 width, height;
42 42
56 56
57 virtual void draw (rxvt_drawable &d, 57 virtual void draw (rxvt_drawable &d,
58 int x, int y, 58 int x, int y,
59 const text_t *text, int len, 59 const text_t *text, int len,
60 int fg, int bg) = 0; 60 int fg, int bg) = 0;
61
62 void unref ()
63 {
64 clear ();
65 delete this;
66 }
61}; 67};
62
63#define FONT_UNREF(f) do { (f)->clear (); delete (f); } while (0)
64 68
65struct rxvt_fallback_font; 69struct rxvt_fallback_font;
66 70
67struct rxvt_fontset 71struct rxvt_fontset
68{ 72{
69 char *fontdesc; 73 char *fontdesc;
70 74
71 enum { fontCount = 3 }; // must be power-of-two - 1, also has to match RS_fontMask in rxvt.h 75 // must be power-of-two - 1, also has to match RS_fontMask in rxvt.h
72 enum { Careful = fontCount + 1 }; 76#if USE_256_COLORS
77 enum { fontCount = 7 }; // 2 extra colors bits, 2 fewer fontcount bits
78#else
79 enum { fontCount = 31 };
80#endif
81
82 // index of first font in set
83 enum { firstFont = 2 };
73 84
74 rxvt_fontset (rxvt_term *term); 85 rxvt_fontset (rxvt_term *term);
75 ~rxvt_fontset (); 86 ~rxvt_fontset ();
76 87
77 bool populate (const char *desc); 88 bool populate (const char *desc);
78 void set_prop (const rxvt_fontprop &prop, bool force_prop) { this->prop = prop; this->force_prop = force_prop; } 89 void set_prop (const rxvt_fontprop &prop, bool force_prop) { this->prop = prop; this->force_prop = force_prop; }
79 int find_font (uint32_t unicode); 90 int find_font_idx (uint32_t unicode);
80 int find_font (const char *name) const; 91 int find_font (const char *name) const;
81 bool realize_font (int i); 92 bool realize_font (int i);
82 93
83 // font-id's MUST fit into a signed 16 bit integer, and within 0..255 94 rxvt_font *operator [] (int id) const
84 rxvt_font *get (uint32_t unicode, int id = fontCount)
85 { 95 {
86 bool dummy; 96 return fonts[id >> 1];
97 }
87 98
88 id &= fontCount; 99 int
100 find_font (unicode_t unicode)
101 {
102 return min<int> ((fontCount << 1) | 1, find_font_idx (unicode));
103 }
89 104
90 return fonts[id == fontCount ? find_font_idx (unicode, dummy) : id]; 105 // 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;
91 } 112 }
92 113
93private: 114private:
94 rxvt_term *term; 115 rxvt_term *term;
95 rxvt_fontprop prop; 116 rxvt_fontprop prop;
96 bool force_prop; 117 bool force_prop;
97 simplevec<rxvt_font *> fonts; 118 simplevec<rxvt_font *> fonts;
98 const rxvt_fallback_font *fallback; 119 const rxvt_fallback_font *fallback;
99 120
100 typedef unsigned char pagemap[256]; 121 // this once was a "typedef xxx pagemap[256]
122 // but c++ arrays are not normal types, and cannot be
123 // put into containers, new doesn't work for them etc. etc.
124 // so we wrap out array into an object that acts like one. doh.
125 // 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 };
101 vector<pagemap *> fmap; 133 vector<pagemap *> fmap;
102 134
103 void clear (); 135 void clear ();
104 rxvt_font *new_font (const char *name, codeset cs); 136 rxvt_font *new_font (const char *name, codeset cs);
137 void prepare_font (rxvt_font *font, codeset cs);
105 void add_fonts (const char *desc); 138 void add_fonts (const char *desc);
106 int find_font_idx (uint32_t unicode, bool &careful); // same as find_font, but does not limit index 139 void push_font (rxvt_font *font);
107}; 140};
108 141
109#endif /* _DEFAULTFONT_H_ */ 142#endif /* _DEFAULTFONT_H_ */
110 143

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines