Mercurial > hg > xemacs-beta
annotate src/objects-tty.c @ 5008:cad59a0a3b19
Add license information from Marcus Thiessel.
See xemacs-beta message <20100208091453.25900@gmx.net>.
| author | Jerry James <james@xemacs.org> |
|---|---|
| date | Tue, 09 Feb 2010 09:50:49 -0700 |
| parents | 16112448d484 |
| children | d95c102a96d3 |
| rev | line source |
|---|---|
| 428 | 1 /* TTY-specific Lisp objects. |
| 2 Copyright (C) 1995 Board of Trustees, University of Illinois. | |
| 793 | 3 Copyright (C) 1995, 1996, 2001, 2002 Ben Wing. |
| 428 | 4 |
| 5 This file is part of XEmacs. | |
| 6 | |
| 7 XEmacs is free software; you can redistribute it and/or modify it | |
| 8 under the terms of the GNU General Public License as published by the | |
| 9 Free Software Foundation; either version 2, or (at your option) any | |
| 10 later version. | |
| 11 | |
| 12 XEmacs is distributed in the hope that it will be useful, but WITHOUT | |
| 13 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
| 14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
| 15 for more details. | |
| 16 | |
| 17 You should have received a copy of the GNU General Public License | |
| 18 along with XEmacs; see the file COPYING. If not, write to | |
| 19 the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | |
| 20 Boston, MA 02111-1307, USA. */ | |
| 21 | |
| 22 /* Synched up with: Not in FSF. */ | |
| 23 | |
| 24 #include <config.h> | |
| 25 #include "lisp.h" | |
| 26 | |
| 872 | 27 #include "console-tty-impl.h" |
| 428 | 28 #include "insdel.h" |
| 872 | 29 #include "objects-tty-impl.h" |
| 428 | 30 #include "device.h" |
| 771 | 31 #include "charset.h" |
| 428 | 32 |
|
4710
3a87551bfeb5
Fixes for a number of minor warnings issued by gcc. See xemacs-patches message
Jerry James <james@xemacs.org>
parents:
4353
diff
changeset
|
33 #ifdef NEW_GC |
|
3a87551bfeb5
Fixes for a number of minor warnings issued by gcc. See xemacs-patches message
Jerry James <james@xemacs.org>
parents:
4353
diff
changeset
|
34 # define UNUSED_IF_NEW_GC(decl) UNUSED (decl) |
|
3a87551bfeb5
Fixes for a number of minor warnings issued by gcc. See xemacs-patches message
Jerry James <james@xemacs.org>
parents:
4353
diff
changeset
|
35 #else |
|
3a87551bfeb5
Fixes for a number of minor warnings issued by gcc. See xemacs-patches message
Jerry James <james@xemacs.org>
parents:
4353
diff
changeset
|
36 # define UNUSED_IF_NEW_GC(decl) decl |
|
3a87551bfeb5
Fixes for a number of minor warnings issued by gcc. See xemacs-patches message
Jerry James <james@xemacs.org>
parents:
4353
diff
changeset
|
37 #endif |
|
3a87551bfeb5
Fixes for a number of minor warnings issued by gcc. See xemacs-patches message
Jerry James <james@xemacs.org>
parents:
4353
diff
changeset
|
38 |
| 428 | 39 /* An alist mapping from color names to a cons of (FG-STRING, BG-STRING). */ |
| 40 Lisp_Object Vtty_color_alist; | |
| 41 #if 0 /* This stuff doesn't quite work yet */ | |
| 42 Lisp_Object Vtty_dynamic_color_fg; | |
| 43 Lisp_Object Vtty_dynamic_color_bg; | |
| 44 #endif | |
| 45 | |
| 1204 | 46 static const struct memory_description tty_color_instance_data_description_1 [] = { |
| 47 { XD_LISP_OBJECT, offsetof (struct tty_color_instance_data, symbol) }, | |
| 48 { XD_END } | |
| 49 }; | |
| 50 | |
| 3092 | 51 #ifdef NEW_GC |
| 52 DEFINE_LRECORD_IMPLEMENTATION ("tty-color-instance-data", | |
| 53 tty_color_instance_data, | |
| 54 0, /*dumpable-flag*/ | |
| 55 0, 0, 0, 0, 0, | |
| 56 tty_color_instance_data_description_1, | |
| 57 struct tty_color_instance_data); | |
| 58 #else /* not NEW_GC */ | |
| 1204 | 59 const struct sized_memory_description tty_color_instance_data_description = { |
| 60 sizeof (struct tty_color_instance_data), tty_color_instance_data_description_1 | |
| 61 }; | |
| 3092 | 62 #endif /* not NEW_GC */ |
| 1204 | 63 |
| 64 static const struct memory_description tty_font_instance_data_description_1 [] = { | |
| 65 { XD_LISP_OBJECT, offsetof (struct tty_font_instance_data, charset) }, | |
| 66 { XD_END } | |
| 67 }; | |
| 68 | |
| 3092 | 69 #ifdef NEW_GC |
| 70 DEFINE_LRECORD_IMPLEMENTATION ("tty-font-instance-data", | |
| 71 tty_font_instance_data, | |
| 72 0, /*dumpable-flag*/ | |
| 73 0, 0, 0, 0, 0, | |
| 74 tty_font_instance_data_description_1, | |
| 75 struct tty_font_instance_data); | |
| 76 #else /* not NEW_GC */ | |
| 1204 | 77 const struct sized_memory_description tty_font_instance_data_description = { |
| 78 sizeof (struct tty_font_instance_data), tty_font_instance_data_description_1 | |
| 79 }; | |
| 3092 | 80 #endif /* not NEW_GC */ |
| 1204 | 81 |
| 428 | 82 DEFUN ("register-tty-color", Fregister_tty_color, 3, 3, 0, /* |
| 83 Register COLOR as a recognized TTY color. | |
| 84 COLOR should be a string. | |
| 85 Strings FG-STRING and BG-STRING should specify the escape sequences to | |
| 86 set the foreground and background to the given color, respectively. | |
| 87 */ | |
| 88 (color, fg_string, bg_string)) | |
| 89 { | |
| 90 CHECK_STRING (color); | |
| 91 CHECK_STRING (fg_string); | |
| 92 CHECK_STRING (bg_string); | |
| 93 | |
| 94 color = Fintern (color, Qnil); | |
| 95 Vtty_color_alist = Fremassq (color, Vtty_color_alist); | |
| 96 Vtty_color_alist = Fcons (Fcons (color, Fcons (fg_string, bg_string)), | |
| 97 Vtty_color_alist); | |
| 98 | |
| 99 return Qnil; | |
| 100 } | |
| 101 | |
| 102 DEFUN ("unregister-tty-color", Funregister_tty_color, 1, 1, 0, /* | |
| 103 Unregister COLOR as a recognized TTY color. | |
| 104 */ | |
| 105 (color)) | |
| 106 { | |
| 107 CHECK_STRING (color); | |
| 108 | |
| 109 color = Fintern (color, Qnil); | |
| 110 Vtty_color_alist = Fremassq (color, Vtty_color_alist); | |
| 111 return Qnil; | |
| 112 } | |
| 113 | |
| 114 DEFUN ("find-tty-color", Ffind_tty_color, 1, 1, 0, /* | |
| 115 Look up COLOR in the list of registered TTY colors. | |
| 116 If it is found, return a list (FG-STRING BG-STRING) of the escape | |
| 117 sequences used to set the foreground and background to the color, respectively. | |
| 118 If it is not found, return nil. | |
| 119 */ | |
| 120 (color)) | |
| 121 { | |
| 122 Lisp_Object result; | |
| 123 | |
| 124 CHECK_STRING (color); | |
| 125 | |
| 126 result = Fassq (Fintern (color, Qnil), Vtty_color_alist); | |
| 127 if (!NILP (result)) | |
| 128 return list2 (Fcar (Fcdr (result)), Fcdr (Fcdr (result))); | |
| 129 else | |
| 130 return Qnil; | |
| 131 } | |
| 132 | |
| 2527 | 133 static Lisp_Object |
| 134 tty_color_list (void) | |
| 428 | 135 { |
| 136 Lisp_Object result = Qnil; | |
| 137 Lisp_Object rest; | |
| 138 | |
| 139 LIST_LOOP (rest, Vtty_color_alist) | |
| 140 { | |
| 141 result = Fcons (Fsymbol_name (XCAR (XCAR (rest))), result); | |
| 142 } | |
| 143 | |
| 144 return Fnreverse (result); | |
| 145 } | |
| 146 | |
| 147 #if 0 | |
| 148 | |
| 149 /* This approach is too simplistic. The problem is that the | |
| 150 dynamic color settings apply to *all* text in the default color, | |
| 151 not just the text output after the escape sequence has been given. */ | |
| 152 | |
| 153 DEFUN ("set-tty-dynamic-color-specs", Fset_tty_dynamic_color_specs, 2, 2, 0, /* | |
| 154 Set the dynamic color specifications for TTY's. | |
| 155 FG and BG should be either nil or vaguely printf-like strings, | |
| 156 where each occurrence of %s is replaced with the color name and each | |
| 157 occurrence of %% is replaced with a single % character. | |
| 158 */ | |
| 159 (fg, bg)) | |
| 160 { | |
| 161 if (!NILP (fg)) | |
| 162 CHECK_STRING (fg); | |
| 163 if (!NILP (bg)) | |
| 164 CHECK_STRING (bg); | |
| 165 | |
| 166 Vtty_dynamic_color_fg = fg; | |
| 167 Vtty_dynamic_color_bg = bg; | |
| 168 | |
| 169 return Qnil; | |
| 170 } | |
| 171 | |
| 172 DEFUN ("tty-dynamic-color-specs", Ftty_dynamic_color_specs, 0, 0, 0, /* | |
| 173 Return the dynamic color specifications for TTY's as a list of (FG BG). | |
| 174 See `set-tty-dynamic-color-specs'. | |
| 175 */ | |
| 176 ()) | |
| 177 { | |
| 178 return list2 (Vtty_dynamic_color_fg, Vtty_dynamic_color_bg); | |
| 179 } | |
| 180 | |
| 181 #endif /* 0 */ | |
| 182 | |
| 183 static int | |
| 440 | 184 tty_initialize_color_instance (Lisp_Color_Instance *c, Lisp_Object name, |
| 2286 | 185 Lisp_Object UNUSED (device), |
| 186 Error_Behavior UNUSED (errb)) | |
| 428 | 187 { |
| 188 Lisp_Object result; | |
| 189 | |
| 190 name = Fintern (name, Qnil); | |
| 191 result = assq_no_quit (name, Vtty_color_alist); | |
| 192 | |
| 193 if (NILP (result)) | |
| 194 { | |
| 195 #if 0 | |
| 196 if (!STRINGP (Vtty_dynamic_color_fg) | |
| 197 && !STRINGP (Vtty_dynamic_color_bg)) | |
| 198 #endif | |
| 199 return 0; | |
| 200 } | |
| 201 | |
| 202 /* Don't allocate the data until we're sure that we will succeed. */ | |
| 3092 | 203 #ifdef NEW_GC |
| 204 c->data = alloc_lrecord_type (struct tty_color_instance_data, | |
| 205 &lrecord_tty_color_instance_data); | |
| 206 #else /* not NEW_GC */ | |
| 428 | 207 c->data = xnew (struct tty_color_instance_data); |
| 3092 | 208 #endif /* not NEW_GC */ |
| 428 | 209 COLOR_INSTANCE_TTY_SYMBOL (c) = name; |
| 210 | |
| 211 return 1; | |
| 212 } | |
| 213 | |
| 214 static void | |
| 440 | 215 tty_mark_color_instance (Lisp_Color_Instance *c) |
| 428 | 216 { |
| 217 mark_object (COLOR_INSTANCE_TTY_SYMBOL (c)); | |
| 218 } | |
| 219 | |
| 220 static void | |
| 2286 | 221 tty_print_color_instance (Lisp_Color_Instance *UNUSED (c), |
| 222 Lisp_Object UNUSED (printcharfun), | |
| 223 int UNUSED (escapeflag)) | |
| 428 | 224 { |
| 225 } | |
| 226 | |
| 227 static void | |
|
4710
3a87551bfeb5
Fixes for a number of minor warnings issued by gcc. See xemacs-patches message
Jerry James <james@xemacs.org>
parents:
4353
diff
changeset
|
228 tty_finalize_color_instance (Lisp_Color_Instance *UNUSED_IF_NEW_GC (c)) |
| 428 | 229 { |
| 4141 | 230 #ifndef NEW_GC |
| 428 | 231 if (c->data) |
|
4976
16112448d484
Rename xfree(FOO, TYPE) -> xfree(FOO)
Ben Wing <ben@xemacs.org>
parents:
4953
diff
changeset
|
232 xfree (c->data); |
| 4141 | 233 #endif /* not NEW_GC */ |
| 4117 | 234 } |
| 428 | 235 |
| 236 static int | |
| 440 | 237 tty_color_instance_equal (Lisp_Color_Instance *c1, |
| 238 Lisp_Color_Instance *c2, | |
| 2286 | 239 int UNUSED (depth)) |
| 428 | 240 { |
| 241 return (EQ (COLOR_INSTANCE_TTY_SYMBOL (c1), | |
| 242 COLOR_INSTANCE_TTY_SYMBOL (c2))); | |
| 243 } | |
| 244 | |
| 2515 | 245 static Hashcode |
| 2286 | 246 tty_color_instance_hash (Lisp_Color_Instance *c, int UNUSED (depth)) |
| 428 | 247 { |
| 248 return LISP_HASH (COLOR_INSTANCE_TTY_SYMBOL (c)); | |
| 249 } | |
| 250 | |
| 251 static int | |
| 2286 | 252 tty_valid_color_name_p (struct device *UNUSED (d), Lisp_Object color) |
| 428 | 253 { |
| 254 return (!NILP (assoc_no_quit (Fintern (color, Qnil), Vtty_color_alist))); | |
| 255 #if 0 | |
| 256 || STRINGP (Vtty_dynamic_color_fg) | |
| 257 || STRINGP (Vtty_dynamic_color_bg) | |
| 258 #endif | |
| 259 } | |
| 260 | |
| 261 | |
| 262 static int | |
| 440 | 263 tty_initialize_font_instance (Lisp_Font_Instance *f, Lisp_Object name, |
| 2286 | 264 Lisp_Object UNUSED (device), |
| 265 Error_Behavior UNUSED (errb)) | |
| 428 | 266 { |
| 867 | 267 Ibyte *str = XSTRING_DATA (name); |
| 428 | 268 Lisp_Object charset = Qnil; |
| 269 | |
| 2367 | 270 if (qxestrncmp_ascii (str, "normal", 6)) |
| 428 | 271 return 0; |
| 272 str += 6; | |
| 273 if (*str) | |
| 274 { | |
| 275 #ifdef MULE | |
| 276 if (*str != '/') | |
| 277 return 0; | |
| 278 str++; | |
|
4953
304aebb79cd3
function renamings to track names of char typedefs
Ben Wing <ben@xemacs.org>
parents:
4952
diff
changeset
|
279 charset = Ffind_charset (intern_istring (str)); |
| 428 | 280 if (NILP (charset)) |
| 281 return 0; | |
| 282 #else | |
| 283 return 0; | |
| 284 #endif | |
| 285 } | |
| 286 | |
| 287 /* Don't allocate the data until we're sure that we will succeed. */ | |
| 3092 | 288 #ifdef NEW_GC |
| 289 f->data = alloc_lrecord_type (struct tty_font_instance_data, | |
| 290 &lrecord_tty_font_instance_data); | |
| 291 #else /* not NEW_GC */ | |
| 428 | 292 f->data = xnew (struct tty_font_instance_data); |
| 3092 | 293 #endif /* not NEW_GC */ |
| 428 | 294 FONT_INSTANCE_TTY_CHARSET (f) = charset; |
| 295 #ifdef MULE | |
| 296 if (CHARSETP (charset)) | |
| 297 f->width = XCHARSET_COLUMNS (charset); | |
| 298 else | |
| 299 #endif | |
| 300 f->width = 1; | |
| 301 | |
| 302 f->proportional_p = 0; | |
| 303 f->ascent = f->height = 1; | |
| 304 f->descent = 0; | |
| 305 | |
| 306 return 1; | |
| 307 } | |
| 308 | |
| 309 static void | |
| 440 | 310 tty_mark_font_instance (Lisp_Font_Instance *f) |
| 428 | 311 { |
| 312 mark_object (FONT_INSTANCE_TTY_CHARSET (f)); | |
| 313 } | |
| 314 | |
| 315 static void | |
| 2286 | 316 tty_print_font_instance (Lisp_Font_Instance *UNUSED (f), |
| 317 Lisp_Object UNUSED (printcharfun), | |
| 318 int UNUSED (escapeflag)) | |
| 428 | 319 { |
| 320 } | |
| 321 | |
| 322 static void | |
|
4710
3a87551bfeb5
Fixes for a number of minor warnings issued by gcc. See xemacs-patches message
Jerry James <james@xemacs.org>
parents:
4353
diff
changeset
|
323 tty_finalize_font_instance (Lisp_Font_Instance *UNUSED_IF_NEW_GC (f)) |
| 428 | 324 { |
| 4141 | 325 #ifndef NEW_GC |
| 428 | 326 if (f->data) |
|
4976
16112448d484
Rename xfree(FOO, TYPE) -> xfree(FOO)
Ben Wing <ben@xemacs.org>
parents:
4953
diff
changeset
|
327 xfree (f->data); |
| 4141 | 328 #endif /* not NEW_GC */ |
| 4117 | 329 } |
| 428 | 330 |
| 331 static Lisp_Object | |
| 2527 | 332 tty_font_list (Lisp_Object UNUSED (pattern), Lisp_Object UNUSED (device), |
| 2286 | 333 Lisp_Object UNUSED (maxnumber)) |
| 428 | 334 { |
|
4952
19a72041c5ed
Mule-izing, various fixes related to char * arguments
Ben Wing <ben@xemacs.org>
parents:
4710
diff
changeset
|
335 return list1 (build_ascstring ("normal")); |
| 428 | 336 } |
| 337 | |
| 338 #ifdef MULE | |
| 339 | |
| 340 static int | |
| 2286 | 341 tty_font_spec_matches_charset (struct device *UNUSED (d), Lisp_Object charset, |
| 867 | 342 const Ibyte *nonreloc, Lisp_Object reloc, |
| 872 | 343 Bytecount offset, Bytecount length, |
| 3841 | 344 enum font_specifier_matchspec_stages stage) |
| 428 | 345 { |
| 867 | 346 const Ibyte *the_nonreloc = nonreloc; |
| 428 | 347 |
| 872 | 348 if (stage) |
| 349 return 0; | |
| 350 | |
| 428 | 351 if (!the_nonreloc) |
| 352 the_nonreloc = XSTRING_DATA (reloc); | |
| 353 fixup_internal_substring (nonreloc, reloc, offset, &length); | |
| 354 the_nonreloc += offset; | |
| 355 | |
|
4353
4143b78d0df0
Merge an old patch of Ben's, involving font instantiation and charsets.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4141
diff
changeset
|
356 if (NILP (charset)) |
| 428 | 357 return !memchr (the_nonreloc, '/', length); |
| 867 | 358 the_nonreloc = (const Ibyte *) memchr (the_nonreloc, '/', length); |
| 428 | 359 if (!the_nonreloc) |
| 360 return 0; | |
| 361 the_nonreloc++; | |
| 362 { | |
| 793 | 363 Lisp_Object s = symbol_name (XSYMBOL (XCHARSET_NAME (charset))); |
| 364 return !qxestrcmp (the_nonreloc, XSTRING_DATA (s)); | |
| 428 | 365 } |
| 366 } | |
| 367 | |
| 368 /* find a font spec that matches font spec FONT and also matches | |
| 369 (the registry of) CHARSET. */ | |
| 370 static Lisp_Object | |
| 371 tty_find_charset_font (Lisp_Object device, Lisp_Object font, | |
| 3659 | 372 Lisp_Object charset, |
| 373 enum font_specifier_matchspec_stages stage) | |
| 428 | 374 { |
| 867 | 375 Ibyte *fontname = XSTRING_DATA (font); |
| 428 | 376 |
| 872 | 377 if (stage) |
| 378 return Qnil; | |
| 379 | |
| 442 | 380 if (strchr ((const char *) fontname, '/')) |
| 428 | 381 { |
| 382 if (tty_font_spec_matches_charset (XDEVICE (device), charset, 0, | |
| 4124 | 383 font, 0, -1, initial)) |
| 428 | 384 return font; |
| 385 return Qnil; | |
| 386 } | |
| 387 | |
|
4353
4143b78d0df0
Merge an old patch of Ben's, involving font instantiation and charsets.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4141
diff
changeset
|
388 if (NILP (charset)) |
| 428 | 389 return font; |
| 390 | |
|
4952
19a72041c5ed
Mule-izing, various fixes related to char * arguments
Ben Wing <ben@xemacs.org>
parents:
4710
diff
changeset
|
391 return concat3 (font, build_ascstring ("/"), |
| 428 | 392 Fsymbol_name (XCHARSET_NAME (charset))); |
| 393 } | |
| 394 | |
| 395 #endif /* MULE */ | |
| 396 | |
| 397 | |
| 398 /************************************************************************/ | |
| 399 /* initialization */ | |
| 400 /************************************************************************/ | |
| 401 | |
| 402 void | |
| 403 syms_of_objects_tty (void) | |
| 404 { | |
| 3092 | 405 #ifdef NEW_GC |
| 406 INIT_LRECORD_IMPLEMENTATION (tty_color_instance_data); | |
| 407 INIT_LRECORD_IMPLEMENTATION (tty_font_instance_data); | |
| 408 #endif /* NEW_GC */ | |
| 409 | |
| 428 | 410 DEFSUBR (Fregister_tty_color); |
| 411 DEFSUBR (Funregister_tty_color); | |
| 412 DEFSUBR (Ffind_tty_color); | |
| 413 #if 0 | |
| 414 DEFSUBR (Fset_tty_dynamic_color_specs); | |
| 415 DEFSUBR (Ftty_dynamic_color_specs); | |
| 416 #endif | |
| 417 } | |
| 418 | |
| 419 void | |
| 420 console_type_create_objects_tty (void) | |
| 421 { | |
| 422 /* object methods */ | |
| 423 CONSOLE_HAS_METHOD (tty, initialize_color_instance); | |
| 424 CONSOLE_HAS_METHOD (tty, mark_color_instance); | |
| 425 CONSOLE_HAS_METHOD (tty, print_color_instance); | |
| 426 CONSOLE_HAS_METHOD (tty, finalize_color_instance); | |
| 427 CONSOLE_HAS_METHOD (tty, color_instance_equal); | |
| 428 CONSOLE_HAS_METHOD (tty, color_instance_hash); | |
| 429 CONSOLE_HAS_METHOD (tty, valid_color_name_p); | |
| 2527 | 430 CONSOLE_HAS_METHOD (tty, color_list); |
| 428 | 431 |
| 432 CONSOLE_HAS_METHOD (tty, initialize_font_instance); | |
| 433 CONSOLE_HAS_METHOD (tty, mark_font_instance); | |
| 434 CONSOLE_HAS_METHOD (tty, print_font_instance); | |
| 435 CONSOLE_HAS_METHOD (tty, finalize_font_instance); | |
| 2527 | 436 CONSOLE_HAS_METHOD (tty, font_list); |
| 428 | 437 #ifdef MULE |
| 438 CONSOLE_HAS_METHOD (tty, font_spec_matches_charset); | |
| 439 CONSOLE_HAS_METHOD (tty, find_charset_font); | |
| 440 #endif | |
| 441 } | |
| 442 | |
| 443 void | |
| 444 vars_of_objects_tty (void) | |
| 445 { | |
| 446 staticpro (&Vtty_color_alist); | |
| 447 Vtty_color_alist = Qnil; | |
| 448 | |
| 449 #if 0 | |
| 450 staticpro (&Vtty_dynamic_color_fg); | |
| 451 Vtty_dynamic_color_fg = Qnil; | |
| 452 | |
| 453 staticpro (&Vtty_dynamic_color_bg); | |
| 454 Vtty_dynamic_color_bg = Qnil; | |
| 455 #endif | |
| 456 } |
