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

Comparing rxvt-unicode/src/rxvt.h (file contents):
Revision 1.232 by root, Sat Jan 21 23:50:33 2006 UTC vs.
Revision 1.253 by root, Wed Feb 1 21:15:33 2006 UTC

15#endif 15#endif
16 16
17#if ENABLE_FRILLS 17#if ENABLE_FRILLS
18# define ENABLE_XEMBED 1 18# define ENABLE_XEMBED 1
19# define ENABLE_EWMH 1 19# define ENABLE_EWMH 1
20# define ENABLE_XIM_ONTHESPOT 1
20# define CURSOR_BLINK 1 21# define CURSOR_BLINK 1
21#else 22#else
22# define ENABLE_MINIMAL 1 23# define ENABLE_MINIMAL 1
23#endif 24#endif
24 25
31#if ENABLE_FRILLS 32#if ENABLE_FRILLS
32# include <X11/Xmd.h> 33# include <X11/Xmd.h>
33#endif 34#endif
34 35
35#include "encoding.h" 36#include "encoding.h"
37#include "rxvtutil.h"
36#include "rxvtfont.h" 38#include "rxvtfont.h"
37#include "rxvttoolkit.h" 39#include "rxvttoolkit.h"
38#include "iom.h" 40#include "iom.h"
39#include "salloc.h" 41#include "salloc.h"
42#include "libptytty.h"
40 43
41#include "rxvtperl.h" 44#include "rxvtperl.h"
42 45
43// try to avoid some macros to decrease code size, on some systems 46// try to avoid some macros to decrease code size, on some systems
44#if ENABLE_MINIMAL 47#if ENABLE_MINIMAL
96# define STDERR_FILENO 2 99# define STDERR_FILENO 2
97#endif 100#endif
98 101
99/****************************************************************************/ 102/****************************************************************************/
100 103
101#ifndef __attribute__
102# if __GNUC__
103# if (__GNUC__ == 2 && __GNUC_MINOR__ < 5) || (__GNUC__ < 2)
104# define __attribute__(x)
105# endif
106# endif
107# define __attribute__(x)
108#endif
109
110#define NORETURN __attribute__ ((noreturn))
111#define UNUSED __attribute__ ((unused))
112
113// increases code size unless -fno-enforce-eh-specs
114#if __GNUC__
115# define NOTHROW
116# define THROW(x)
117#else
118# define NOTHROW throw()
119# define THROW(x) throw x
120#endif
121
122// exception thrown on fatal (per-instance) errors 104// exception thrown on fatal (per-instance) errors
123class rxvt_failure_exception { }; 105class rxvt_failure_exception { };
124 106
125// exception thrown when the command parser runs out of input data 107// exception thrown when the command parser runs out of input data
126class out_of_input { }; 108class out_of_input { };
141// misc.C 123// misc.C
142char * rxvt_wcstombs (const wchar_t *str, int len = -1); 124char * rxvt_wcstombs (const wchar_t *str, int len = -1);
143wchar_t * rxvt_mbstowcs (const char *str, int len = -1); 125wchar_t * rxvt_mbstowcs (const char *str, int len = -1);
144char * rxvt_wcstoutf8 (const wchar_t *str, int len = -1); 126char * rxvt_wcstoutf8 (const wchar_t *str, int len = -1);
145wchar_t * rxvt_utf8towcs (const char *str, int len = -1); 127wchar_t * rxvt_utf8towcs (const char *str, int len = -1);
128char * rxvt_strdup_cpp (const char *str);
146 129
147#define rxvt_strdup(s) ((s) ? strdup(s) : 0) 130#define rxvt_strdup(s) ((s) ? strdup(s) : 0)
148 131
149char * rxvt_r_basename (const char *str) NOTHROW; 132char * rxvt_r_basename (const char *str) NOTHROW;
150void rxvt_vlog (const char *fmt, va_list arg_ptr) NOTHROW; 133void rxvt_vlog (const char *fmt, va_list arg_ptr) NOTHROW;
167extern char **environ; 150extern char **environ;
168extern char **rxvt_environ; // the original environ pointer 151extern char **rxvt_environ; // the original environ pointer
169 152
170inline void set_environ (stringvec *envv) 153inline void set_environ (stringvec *envv)
171{ 154{
155#if ENABLE_PERL
156 assert (envv);
157#else
172 if (envv) 158 if (envv)
159#endif
173 environ = (char **)envv->begin (); 160 environ = (char **)envv->begin ();
174} 161}
175 162
176inline void set_environ (char **envv) 163inline void set_environ (char **envv)
177{ 164{
165#if ENABLE_PERL
166 assert (envv);
167#else
178 if (envv) 168 if (envv)
169#endif
179 environ = envv; 170 environ = envv;
180} 171}
181 172
182/* 173/*
183 ***************************************************************************** 174 *****************************************************************************
199typedef struct { 190typedef struct {
200 short w, h, x, y; 191 short w, h, x, y;
201 Pixmap pixmap; 192 Pixmap pixmap;
202} bgPixmap_t; 193} bgPixmap_t;
203#endif 194#endif
204
205struct rxvt_ptytty {
206 int pty; // pty file descriptor; connected to rxvt
207 int tty; // tty file descriptor; connected to child
208
209 rxvt_ptytty ()
210 : pty(-1), tty(-1)
211 {
212 }
213
214 virtual ~rxvt_ptytty ()
215 {
216 }
217
218 virtual bool get () = 0;
219#if UTMP_SUPPORT
220 virtual void login (int cmd_pid, bool login_shell, const char *hostname) = 0;
221#endif
222
223 void close_tty ();
224 bool make_controlling_tty ();
225 void set_utf8_mode (bool on);
226};
227
228rxvt_ptytty *rxvt_new_ptytty (); // create a new pty object
229void rxvt_ptytty_server (); // start the ptytty server process
230 195
231/* 196/*
232 * the 'essential' information for reporting Mouse Events 197 * the 'essential' information for reporting Mouse Events
233 * pared down from XButtonEvent 198 * pared down from XButtonEvent
234 */ 199 */
447// fake styles 412// fake styles
448#define RS_Blink 0x00010000UL // blink 413#define RS_Blink 0x00010000UL // blink
449#define RS_RVid 0x00020000UL // reverse video 414#define RS_RVid 0x00020000UL // reverse video
450#define RS_Uline 0x00040000UL // underline 415#define RS_Uline 0x00040000UL // underline
451 416
417// toggle this to force redraw, must be != RS_Careful
418#define RS_redraw 0x01000000UL
419
452// 5 custom bits for extensions 420// 5 custom bits for extensions
453#define RS_customCount 32 421#define RS_customCount 32
454#define RS_customMask 0x00f80000UL 422#define RS_customMask 0x00f80000UL
455#define RS_customShift 19 423#define RS_customShift 19
456 424
525 Rxvt_restoreFG = 39, // change default fg color 493 Rxvt_restoreFG = 39, // change default fg color
526 Rxvt_restoreBG = 49, // change default bg color 494 Rxvt_restoreBG = 49, // change default bg color
527 Rxvt_dumpscreen = 55, // dump scrollback and all of screen 495 Rxvt_dumpscreen = 55, // dump scrollback and all of screen
528 496
529 URxvt_locale = 701, // change locale 497 URxvt_locale = 701, // change locale
498 URxvt_version = 702, // request version
530 499
531 URxvt_Color_IT = 704, // change actual 'Italic' colour 500 URxvt_Color_IT = 704, // change actual 'Italic' colour
532 URxvt_Color_tint = 705, // change actual tint colour 501 URxvt_Color_tint = 705, // change actual tint colour
533 URxvt_Color_BD = 706, 502 URxvt_Color_BD = 706,
534 URxvt_Color_UL = 707, 503 URxvt_Color_UL = 707,
619#endif 588#endif
620}; 589};
621 590
622#define Color_Bits 7 // 0 .. maxTermCOLOR 591#define Color_Bits 7 // 0 .. maxTermCOLOR
623 592
624#define NPIXCLR_SETS ((TOTAL_COLORS + 31) / 32)
625#define NPIXCLR_BITS 32
626
627/* 593/*
628 * Resource list 594 * Resource list
629 */ 595 */
630enum { 596enum {
631# define def(name) Rs_ ## name, 597# define def(name) Rs_ ## name,
632# define reserve(name,count) Rs_ ## name ## _ = Rs_ ## name + (count) - 1, 598# define reserve(name,count) Rs_ ## name ## _ = Rs_ ## name + (count) - 1,
633# include "rsinc.h" 599# include "rsinc.h"
634# undef def 600# undef def
635# undef reserve 601# undef reserve
636 NUM_RESOURCES 602 NUM_RESOURCES
637};
638
639// see init.C:xa_names, which must be kept in sync
640enum {
641 XA_TEXT = 0,
642 XA_COMPOUND_TEXT,
643 XA_UTF8_STRING,
644 XA_MULTIPLE,
645 XA_TARGETS,
646 XA_TIMESTAMP,
647 XA_VT_SELECTION,
648 XA_INCR,
649 XA_WM_PROTOCOLS,
650 XA_WM_DELETE_WINDOW,
651 XA_CLIPBOARD,
652#if ENABLE_FRILLS
653 XA_MOTIF_WM_HINTS,
654#endif
655#if ENABLE_EWMH
656 XA_NET_WM_PID,
657 XA_NET_WM_NAME,
658 XA_NET_WM_ICON_NAME,
659 XA_NET_WM_PING,
660#endif
661#if USE_XIM
662 XA_WM_LOCALE_NAME,
663#endif
664#if TRANSPARENT
665 XA_XROOTPMAP_ID,
666 XA_ESETROOT_PMAP_ID,
667#endif
668#if ENABLE_XEMBED
669 XA_XEMBED,
670 XA_XEMBED_INFO,
671#endif
672 NUM_XA
673}; 603};
674 604
675/* DEC private modes */ 605/* DEC private modes */
676#define PrivMode_132 (1UL<<0) 606#define PrivMode_132 (1UL<<0)
677#define PrivMode_132OK (1UL<<1) 607#define PrivMode_132OK (1UL<<1)
750 ***************************************************************************** 680 *****************************************************************************
751 * MACRO DEFINES 681 * MACRO DEFINES
752 ***************************************************************************** 682 *****************************************************************************
753 */ 683 */
754#define dLocal(type,name) type const name = this->name 684#define dLocal(type,name) type const name = this->name
755#define dDisp Display *disp = this->display->display 685
686// for speed reasons, we assume that all latin1 characters
687// are single-width (the first unicode combining character
688// is actually 0x300, but ascii is what matters most).
689#define WCWIDTH(c) ((c) & ~0xff ? wcwidth (c) : 1)
756 690
757/* convert pixel dimensions to row/column values. Everything as int32_t */ 691/* convert pixel dimensions to row/column values. Everything as int32_t */
758#define Pixel2Col(x) Pixel2Width((int32_t)(x)) 692#define Pixel2Col(x) Pixel2Width((int32_t)(x))
759#define Pixel2Row(y) Pixel2Height((int32_t)(y)) 693#define Pixel2Row(y) Pixel2Height((int32_t)(y))
760#define Pixel2Width(x) ((int32_t)(x) / (int32_t)fwidth) 694#define Pixel2Width(x) ((int32_t)(x) / (int32_t)fwidth)
794#define SET_BGCOLOR(x,bg) (((x) & ~RS_bgMask) | ((bg)<<Color_Bits)) 728#define SET_BGCOLOR(x,bg) (((x) & ~RS_bgMask) | ((bg)<<Color_Bits))
795#define SET_ATTR(x,a) (((x) & ~RS_attrMask) | (a)) 729#define SET_ATTR(x,a) (((x) & ~RS_attrMask) | (a))
796 730
797#define RS_SAME(a,b) (!(((a) ^ (b)) & ~RS_Careful)) 731#define RS_SAME(a,b) (!(((a) ^ (b)) & ~RS_Careful))
798 732
799#define SET_PIXCOLOR(x) (pixcolor_set[(x) / NPIXCLR_BITS] |= (1 << ((x) % NPIXCLR_BITS))) 733#define PIXCOLOR_NAME(idx) rs[Rs_color + (idx)]
800#define ISSET_PIXCOLOR(x) (pixcolor_set[(x) / NPIXCLR_BITS] & (1 << ((x) % NPIXCLR_BITS))) 734#define ISSET_PIXCOLOR(idx) (!!rs[Rs_color + (idx)])
801 735
802#if ENABLE_STYLES 736#if ENABLE_STYLES
803# define FONTSET(style) fontset[GET_STYLE (style)] 737# define FONTSET(style) fontset[GET_STYLE (style)]
804#else 738#else
805# define FONTSET(style) fontset[0] 739# define FONTSET(style) fontset[0]
839# define XPMClearArea(a, b, c, d, e, f, g) XClearArea((a), (b), (c), (d), (e), (f), (g)) 773# define XPMClearArea(a, b, c, d, e, f, g) XClearArea((a), (b), (c), (d), (e), (f), (g))
840#else 774#else
841# define XPMClearArea(a, b, c, d, e, f, g) 775# define XPMClearArea(a, b, c, d, e, f, g)
842#endif 776#endif
843 777
844#ifdef DEBUG_CMD
845# define D_CMD(x) fprintf x ; fputc('\n', stderr)
846#else
847# define D_CMD(x)
848#endif
849#ifdef DEBUG_INIT
850# define D_INIT(x) fprintf x ; fputc('\n', stderr)
851#else
852# define D_INIT(x)
853#endif
854#ifdef DEBUG_MAIN
855# define D_MAIN(x) fprintf x ; fputc('\n', stderr)
856#else
857# define D_MAIN(x)
858#endif
859#ifdef DEBUG_SIZE
860# define D_SIZE(x) fprintf x ; fputc('\n', stderr)
861#else
862# define D_SIZE(x)
863#endif
864
865typedef callback1<void, const char *> log_callback; 778typedef callback1<void, const char *> log_callback;
866typedef callback1<int, int> getfd_callback; 779typedef callback1<int, int> getfd_callback;
867 780
868#define SET_LOCALE(locale) rxvt_set_locale (locale) 781#define SET_LOCALE(locale) rxvt_set_locale (locale)
869extern bool rxvt_set_locale (const char *locale) NOTHROW; 782extern bool rxvt_set_locale (const char *locale) NOTHROW;
936# define COMPOSE_LO 0x40000000UL 849# define COMPOSE_LO 0x40000000UL
937# define COMPOSE_HI 0x400fffffUL 850# define COMPOSE_HI 0x400fffffUL
938# define IS_COMPOSE(n) ((int32_t)(n) >= COMPOSE_LO) 851# define IS_COMPOSE(n) ((int32_t)(n) >= COMPOSE_LO)
939#else 852#else
940# if ENABLE_PERL 853# if ENABLE_PERL
941# define COMPOSE_LO 0xe000UL // our _own_ routiens don't like (illegal) surrogates 854# define COMPOSE_LO 0xe000UL // our _own_ functions don't like (illegal) surrogates
942# define COMPOSE_HI 0xf8ffUL // in utf-8, so use private use area only 855# define COMPOSE_HI 0xf8ffUL // in utf-8, so use private use area only
943# else 856# else
944# define COMPOSE_LO 0xd800UL 857# define COMPOSE_LO 0xd800UL
945# define COMPOSE_HI 0xf8ffUL 858# define COMPOSE_HI 0xf8ffUL
946# endif 859# endif
975#endif 888#endif
976 889
977/****************************************************************************/ 890/****************************************************************************/
978 891
979#ifdef KEYSYM_RESOURCE 892#ifdef KEYSYM_RESOURCE
980 class keyboard_manager; 893class keyboard_manager;
981#endif 894#endif
982 895
983struct rxvt_term : zero_initialized, rxvt_vars { 896struct rxvt_term : zero_initialized, rxvt_vars, rxvt_screen {
897
898 // special markers with magic addresses
899 static const char resval_undef []; // options specifically unset
900 static const char resval_on []; // boolean options switched on
901 static const char resval_off []; // or off
902
984 log_callback *log_hook; // log error messages through this hook, if != 0 903 log_callback *log_hook; // log error messages through this hook, if != 0
985 getfd_callback *getfd_hook; // convert remote to local fd, if != 0 904 getfd_callback *getfd_hook; // convert remote to local fd, if != 0
986#if ENABLE_PERL 905#if ENABLE_PERL
987 rxvt_perl_term perl; 906 rxvt_perl_term perl;
988#endif 907#endif
989 struct mbstate mbstate; // current input multibyte state 908 struct mbstate mbstate; // current input multibyte state
1028 int num_scr; /* screen: number lines scrolled */ 947 int num_scr; /* screen: number lines scrolled */
1029 int prev_ncol, /* screen: previous number of columns */ 948 int prev_ncol, /* screen: previous number of columns */
1030 prev_nrow; /* screen: previous number of rows */ 949 prev_nrow; /* screen: previous number of rows */
1031/* ---------- */ 950/* ---------- */
1032 rend_t rstyle; 951 rend_t rstyle;
1033/* ---------- */
1034 uint32_t pixcolor_set[NPIXCLR_SETS];
1035/* ---------- */ 952/* ---------- */
1036#ifdef SELECTION_SCROLLING 953#ifdef SELECTION_SCROLLING
1037 int scroll_selection_lines; 954 int scroll_selection_lines;
1038 enum page_dirn scroll_selection_dir; 955 enum page_dirn scroll_selection_dir;
1039 int selection_save_x, 956 int selection_save_x,
1066 int old_width, /* last used width in screen resize */ 983 int old_width, /* last used width in screen resize */
1067 old_height; /* last used height in screen resize */ 984 old_height; /* last used height in screen resize */
1068 unsigned long priv_modes, 985 unsigned long priv_modes,
1069 SavedModes; 986 SavedModes;
1070/* ---------- */ 987/* ---------- */
1071 Atom xa[NUM_XA]; 988 Atom *xa;
1072/* ---------- */ 989/* ---------- */
1073#ifdef RXVT_SCROLLBAR 990#ifdef RXVT_SCROLLBAR
1074 GC scrollbarGC, 991 GC scrollbarGC,
1075 topShadowGC, 992 topShadowGC,
1076 botShadowGC; 993 botShadowGC;
1133 void scr_overlay_set (int x, int y, const wchar_t *s) NOTHROW; 1050 void scr_overlay_set (int x, int y, const wchar_t *s) NOTHROW;
1134#endif 1051#endif
1135 1052
1136 vector<void *> allocated; // free these memory blocks with free() 1053 vector<void *> allocated; // free these memory blocks with free()
1137 1054
1138 char *env_windowid; /* environmental variable WINDOWID */ 1055 char env_windowid[21]; /* environmental variable WINDOWID */
1056 char env_colorfgbg[sizeof ("COLORFGBG=default;default;bg") + 1];
1139 char *env_display; /* environmental variable DISPLAY */ 1057 char *env_display; /* environmental variable DISPLAY */
1140 char *env_term; /* environmental variable TERM */ 1058 char *env_term; /* environmental variable TERM */
1141 char *env_colorfgbg; 1059
1142 char *locale; 1060 char *locale;
1143 char charsets[4]; 1061 char charsets[4];
1144 char *v_buffer; /* pointer to physical buffer */ 1062 char *v_buffer; /* pointer to physical buffer */
1145 unsigned int v_buflen; /* size of area to write */ 1063 unsigned int v_buflen; /* size of area to write */
1146 stringvec *argv, *envv; /* if != 0, will be freed on destroy time */ 1064 stringvec *argv, *envv; /* if != 0, will be freed at destroy time */
1147 1065
1148#ifdef KEYSYM_RESOURCE 1066#ifdef KEYSYM_RESOURCE
1149 keyboard_manager *keyboard; 1067 keyboard_manager *keyboard;
1150#endif 1068#endif
1151 1069
1152 const char *rs[NUM_RESOURCES]; 1070 const char *rs[NUM_RESOURCES];
1153 /* command input buffering */ 1071 /* command input buffering */
1154 char *cmdbuf_ptr, *cmdbuf_endp; 1072 char *cmdbuf_ptr, *cmdbuf_endp;
1155 char cmdbuf_base[CBUFSIZ]; 1073 char cmdbuf_base[CBUFSIZ];
1156 1074
1157 rxvt_ptytty *pty; 1075 ptytty *pty;
1158 1076
1159 rxvt_salloc *talloc; // text line allocator 1077 rxvt_salloc *talloc; // text line allocator
1160 rxvt_salloc *ralloc; // rend line allocator 1078 rxvt_salloc *ralloc; // rend line allocator
1161 1079
1162 static vector<rxvt_term *> termlist; // a vector of all running rxvt_term's 1080 static vector<rxvt_term *> termlist; // a vector of all running rxvt_term's
1173#endif 1091#endif
1174 1092
1175 // modifies first argument(!) 1093 // modifies first argument(!)
1176 void paste (char *data, unsigned int len) NOTHROW; 1094 void paste (char *data, unsigned int len) NOTHROW;
1177 1095
1178 long vt_emask, vt_emask_perl; 1096 long vt_emask, vt_emask_perl, vt_emask_xim;
1179 1097
1180 void vt_select_input () const NOTHROW 1098 void vt_select_input () const NOTHROW
1181 { 1099 {
1182 XSelectInput (display->display, vt, vt_emask | vt_emask_perl); 1100 XSelectInput (xdisp, vt, vt_emask | vt_emask_perl | vt_emask_xim);
1183 } 1101 }
1184 1102
1185#if TRANSPARENT 1103#if TRANSPARENT
1186 void rootwin_cb (XEvent &xev); 1104 void rootwin_cb (XEvent &xev);
1187 xevent_watcher rootwin_ev; 1105 xevent_watcher rootwin_ev;
1237 rxvt_term (); 1155 rxvt_term ();
1238 ~rxvt_term (); 1156 ~rxvt_term ();
1239 void destroy (); 1157 void destroy ();
1240 void emergency_cleanup (); 1158 void emergency_cleanup ();
1241 1159
1242 bool init (int argc, const char *const *argv); 1160 bool init (int argc, const char *const *argv, stringvec *envv);
1161
1162 bool init (stringvec *argv, stringvec *envv)
1163 {
1164 this->argv = argv;
1165 return init (argv->size (), argv->begin (), envv);
1166 }
1167
1243 bool init_vars (); 1168 bool init_vars ();
1244 1169
1245 bool pty_fill (); 1170 bool pty_fill ();
1246 1171
1247 void make_current () const // make this the "currently active" urxvt instance 1172 void make_current () const // make this the "currently active" urxvt instance
1266 void create_windows (int argc, const char *const *argv); 1191 void create_windows (int argc, const char *const *argv);
1267 void resize_all_windows (unsigned int newwidth, unsigned int newheight, int ignoreparent); 1192 void resize_all_windows (unsigned int newwidth, unsigned int newheight, int ignoreparent);
1268 void window_calc (unsigned int newwidth, unsigned int newheight); 1193 void window_calc (unsigned int newwidth, unsigned int newheight);
1269 1194
1270#if USE_XIM 1195#if USE_XIM
1271 rxvt_xim *input_method; 1196 rxvt_xim *input_method;
1272 XIC Input_Context; 1197 XIC Input_Context;
1273 XIMStyle input_style; 1198 XIMStyle input_style;
1274 XPoint spot; // most recently sent spot position 1199 XPoint spot; // most recently sent spot position
1275 1200
1276 void im_destroy (); 1201 void im_destroy ();
1277 void im_cb (); im_watcher im_ev; 1202 void im_cb (); im_watcher im_ev;
1278 void im_set_size (XRectangle &size); 1203 void im_set_size (XRectangle &size);
1279 void im_set_position (XPoint &pos) NOTHROW; 1204 void im_set_position (XPoint &pos) NOTHROW;
1332 void set_utf8_property (Atom prop, const char *str, int len = -1); 1257 void set_utf8_property (Atom prop, const char *str, int len = -1);
1333 void set_title (const char *str); 1258 void set_title (const char *str);
1334 void set_icon_name (const char *str); 1259 void set_icon_name (const char *str);
1335 void set_window_color (int idx, const char *color); 1260 void set_window_color (int idx, const char *color);
1336 void set_colorfgbg (); 1261 void set_colorfgbg ();
1337 int rXParseAllocColor (rxvt_color * screen_in_out, const char *colour); 1262 bool set_color (rxvt_color &color, const char *name);
1263 void alias_color (int dst, int src);
1338 void set_widthheight (unsigned int newwidth, unsigned int newheight); 1264 void set_widthheight (unsigned int newwidth, unsigned int newheight);
1339 1265
1340 // screen.C 1266 // screen.C
1341 1267
1342 void lalloc (line_t &l) const NOTHROW 1268 void lalloc (line_t &l) const
1343 { 1269 {
1344 l.t = (text_t *)talloc->alloc (); 1270 l.t = (text_t *)talloc->alloc ();
1345 l.r = (rend_t *)ralloc->alloc (); 1271 l.r = (rend_t *)ralloc->alloc ();
1346 } 1272 }
1347 1273
1351 talloc->free (l.t); 1277 talloc->free (l.t);
1352 ralloc->free (l.r); 1278 ralloc->free (l.r);
1353 } 1279 }
1354#endif 1280#endif
1355 1281
1356 void lresize (line_t &l) const NOTHROW 1282 void lresize (line_t &l) const
1357 { 1283 {
1358 if (!l.t) 1284 if (!l.t)
1359 return; 1285 return;
1360 1286
1361 l.t = (text_t *)talloc->alloc (l.t, prev_ncol * sizeof (text_t)); 1287 l.t = (text_t *)talloc->alloc (l.t, prev_ncol * sizeof (text_t));
1429 void scr_remap_chars () NOTHROW; 1355 void scr_remap_chars () NOTHROW;
1430 void scr_remap_chars (line_t &l) NOTHROW; 1356 void scr_remap_chars (line_t &l) NOTHROW;
1431 1357
1432 enum cursor_mode { SAVE, RESTORE }; 1358 enum cursor_mode { SAVE, RESTORE };
1433 1359
1434 void scr_poweron () NOTHROW; 1360 void scr_poweron ();
1435 void scr_cursor (cursor_mode mode) NOTHROW; 1361 void scr_cursor (cursor_mode mode) NOTHROW;
1436 void scr_do_wrap () NOTHROW; 1362 void scr_do_wrap () NOTHROW;
1363 void scr_swap_screen () NOTHROW;
1437 int scr_change_screen (int scrn) NOTHROW; 1364 void scr_change_screen (int scrn);
1438 void scr_color (unsigned int color, int fgbg) NOTHROW; 1365 void scr_color (unsigned int color, int fgbg) NOTHROW;
1439 void scr_rendition (int set, int style) NOTHROW; 1366 void scr_rendition (int set, int style) NOTHROW;
1440 void scr_add_lines (const wchar_t *str, int len, int minlines = 0) NOTHROW; 1367 void scr_add_lines (const wchar_t *str, int len, int minlines = 0) NOTHROW;
1441 void scr_backspace () NOTHROW; 1368 void scr_backspace () NOTHROW;
1442 void scr_tab (int count, bool ht = false) NOTHROW; 1369 void scr_tab (int count, bool ht = false) NOTHROW;
1534# define __PROTO(p) p 1461# define __PROTO(p) p
1535#else 1462#else
1536# define __PROTO(p) () 1463# define __PROTO(p) ()
1537#endif 1464#endif
1538 1465
1539#ifdef DEBUG_malloc
1540# include "dmalloc.h" /* This comes last */
1541#endif
1542
1543#endif /* _RXVT_H_ */ 1466#endif /* _RXVT_H_ */
1544 1467

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines