Mercurial > freewnn
view Wnn/uum/termio.c @ 4:422e51e3191e
changed MAX_ENTRIES from 70000 to 500000.
author | Yoshiki Yazawa <yaz@cc.rim.or.jp> |
---|---|
date | Thu, 13 Dec 2007 20:45:52 +0900 |
parents | bbc77ca4def5 |
children |
line wrap: on
line source
/* * $Id: termio.c,v 1.7 2006/09/04 17:21:29 aonoto Exp $ */ /* * FreeWnn is a network-extensible Kana-to-Kanji conversion system. * This file is part of FreeWnn. * * Copyright Kyoto University Research Institute for Mathematical Sciences * 1987, 1988, 1989, 1990, 1991, 1992 * Copyright OMRON Corporation. 1987, 1988, 1989, 1990, 1991, 1992, 1999 * Copyright ASTEC, Inc. 1987, 1988, 1989, 1990, 1991, 1992 * Copyright FreeWnn Project 1999, 2000, 2002, 2006 * * Maintainer: FreeWnn Project * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #ifdef HAVE_CONFIG_H # include <config.h> #endif #include <stdio.h> #if STDC_HEADERS # include <stdlib.h> # include <string.h> #else # if defined (HAVE_STRINGS_H) # include <strings.h> # endif /* HAVE_STRINGS_H */ #endif /* STDC_HEADERS */ #include "commonhd.h" #include "sdefine.h" #include "sheader.h" /* * tparm() macro for fixed argument prototype systems: * It may not harm on systems that tparm() has variable argument prototype * (or no prototype for compatibility). */ #define TPARM_3ARGS(func, p1, p2) tparm((func), (p1), (p2), 0,0,0,0,0,0,0) #ifdef HAVE_TERMINFO #include <stdio.h> #include <curses.h> #include <term.h> #ifdef putchar #undef putchar #endif extern int putchar (); extern char Term_Name[]; extern char *Term_UnderScoreStart; extern char *Term_UnderScoreEnd; extern char *Term_ClrScreen; extern char *Term_ClrEofLine; extern char *Term_ThrowCursor; extern char *Term_StandOutStart; extern char *Term_StandOutEnd; extern char *Term_BoldOutStart; extern char *Term_BoldOutEnd; static int bold_mode_fun = 0; int openTermData () { char *cp, *get_kbd_env (); int status; /* int k; */ char lcode[10]; char termchar[20]; char errprefix[1024] = "error"; /* for convert_key --- added by Nide 10/3 */ if (NULL == (cp = get_kbd_env ()) || 0 != convert_getterm (cp, (0 != verbose_option))) { fprintf (stderr, "Cannot get keyboard information.\n"); return (-1); } if ((cp = getenv ("TERM")) == NULL) { fprintf (stderr, "Cannot get terminal name."); return (-1); } strcpy (Term_Name, cp); if ((strlen (Term_Name) > 2) && (strcmp (Term_Name + (strlen (Term_Name) - 2), "-j") == 0)) { fprintf (stderr, MSG_GET (4)); /* fprintf(stderr,"Uum:uumからuumはおこせません。\n"); */ return (-1); } setupterm (0, 1, &status); reset_shell_mode (); if (status != 1) { return (-1); } #if defined(uniosu) if (jterm < 2) { /* kanji terminal */ fprintf (stderr, "Not kanji terminal. Goodbye !\n"); return (-1); } #endif /* defined(uniosu) */ if (save_cursor == (char *) NULL || *save_cursor == NULL || restore_cursor == (char *) NULL || *restore_cursor == NULL || change_scroll_region == (char *) NULL || *change_scroll_region == NULL) { fprintf (stderr, "Your terminal is not strong enough. Goodbye !\n"); return (-1); } /* * setenv TERM "${TERM}-j" to prevent starting uum over * uum-controled terminal (disabled for now ...) */ termchar[0] = 0; strcat (termchar, cp); /* strcat (termchar, "-j"); */ if (setenv ("TERM", termchar, 1) != 0) { #if HAVE_SNPRINTF snprintf (errprefix, sizeof (errprefix), "error at %s (%d)", __FILE__, __LINE__); #endif /* HAVE_SNPRINTF */ perror (errprefix); exit (1); } sprintf (lcode, "%d", lines - conv_lines); if (setenv ("LINES", lcode, 1) != 0) { #if HAVE_SNPRINTF snprintf (errprefix, sizeof (errprefix), "error at %s (%d)", __FILE__, __LINE__); #endif /* HAVE_SNPRINTF */ perror (errprefix); exit (1); } if (cursor_normal && cursor_invisible) { cursor_invisible_fun = 1; } else { cursor_invisible_fun = 0; } if (keypad_xmit && *keypad_xmit && keypad_local && *keypad_local) { keypad_fun = 1; } else { keypad_fun = 0; } Term_UnderScoreEnd = exit_underline_mode; Term_UnderScoreStart = enter_underline_mode; Term_StandOutEnd = exit_standout_mode; Term_StandOutStart = enter_standout_mode; if (enter_bold_mode && exit_attribute_mode) bold_mode_fun = 1; else bold_mode_fun = 0; Term_BoldOutStart = enter_bold_mode; Term_BoldOutEnd = exit_attribute_mode; return (0); } void closeTermData () { resetterm (); reset_shell_mode (); } void set_keypad_on () { tputs (keypad_xmit, 1, putchar); } void set_keypad_off () { tputs (keypad_local, 1, putchar); } void set_scroll_region (start, end) int start, end; { tputs (TPARM_3ARGS (change_scroll_region, start, end), 1, putchar); } void clr_end_screen () { tputs (clr_eos, 1, putchar); } void clr_screen () { tputs (clear_screen, lines, putchar); Term_ClrScreen = clear_screen; } void clr_line1 () { tputs (clr_eol, 1, putchar); Term_ClrEofLine = clr_eol; } void throw_cur_raw (col, row) int col, row; { tputs (TPARM_3ARGS (cursor_address, row, col), 1, putchar); } void h_r_on_raw () { tputs (enter_standout_mode, 1, putchar); } void h_r_off_raw () { tputs (exit_standout_mode, 1, putchar); } void u_s_on_raw () { tputs (enter_underline_mode, 1, putchar); } void u_s_off_raw () { tputs (exit_underline_mode, 1, putchar); } void b_s_on_raw () { if (bold_mode_fun) tputs (enter_bold_mode, 1, putchar); else tputs (enter_underline_mode, 1, putchar); } void b_s_off_raw () { if (bold_mode_fun) tputs (exit_attribute_mode, 1, putchar); else tputs (exit_underline_mode, 1, putchar); } void ring_bell () { tputs (bell, 1, putchar); flush (); } void save_cursor_raw () { tputs (save_cursor, 1, putchar); } void restore_cursor_raw () { tputs (restore_cursor, 1, putchar); } void cursor_invisible_raw () { tputs (cursor_invisible, 1, putchar); } void cursor_normal_raw () { tputs (cursor_normal, 1, putchar); } #endif /* HAVE_TERMINFO */