X-Git-Url: https://ncurses.scripts.mit.edu/?p=ncurses.git;a=blobdiff_plain;f=ncurses%2Ftinfo%2Flib_cur_term.c;h=5dc53fca9b001fc87ec2b0fe5ecc9b20eec71c35;hp=7d0aa127d9dbb5c11155ca3837fdb2ad845eec9f;hb=7a6bbc8cf41c5186d46accc3d08622dc86526b34;hpb=b1f61d9f3aa244512045a6b02e759825d7049d34 diff --git a/ncurses/tinfo/lib_cur_term.c b/ncurses/tinfo/lib_cur_term.c index 7d0aa127..5dc53fca 100644 --- a/ncurses/tinfo/lib_cur_term.c +++ b/ncurses/tinfo/lib_cur_term.c @@ -1,5 +1,5 @@ /**************************************************************************** - * Copyright (c) 1998,1999 Free Software Foundation, Inc. * + * Copyright (c) 1998-2008,2009 Free Software Foundation, Inc. * * * * Permission is hereby granted, free of charge, to any person obtaining a * * copy of this software and associated documentation files (the * @@ -37,34 +37,83 @@ */ #include -#include /* TTY, cur_term */ -#include /* ospeed */ +#include /* TTY, cur_term */ +#include /* ospeed */ -MODULE_ID("$Id: lib_cur_term.c,v 1.9 1999/10/30 23:00:16 tom Exp $") +MODULE_ID("$Id: lib_cur_term.c,v 1.21 2009/04/18 21:02:22 tom Exp $") -TERMINAL *cur_term = 0; +#undef CUR +#define CUR termp->type. -TERMINAL *set_curterm(TERMINAL *termp) +#if BROKEN_LINKER && !USE_REENTRANT +NCURSES_EXPORT_VAR(TERMINAL *) cur_term = 0; +#elif BROKEN_LINKER || USE_REENTRANT +NCURSES_EXPORT(TERMINAL *) +NCURSES_PUBLIC_VAR(cur_term) (void) { - TERMINAL *oldterm = cur_term; + return (SP != 0 && SP->_term != 0) ? SP->_term : _nc_prescreen._cur_term; +} +#else +NCURSES_EXPORT_VAR(TERMINAL *) cur_term = 0; +#endif + +NCURSES_EXPORT(TERMINAL *) +set_curterm(TERMINAL * termp) +{ + TERMINAL *oldterm; - if ((cur_term = termp) != 0) { - ospeed = _nc_ospeed(cur_term->_baudrate); - PC = (pad_char != NULL) ? pad_char[0] : 0; + T((T_CALLED("set_curterm(%p)"), termp)); + + _nc_lock_global(curses); + oldterm = cur_term; + if (SP) + SP->_term = termp; +#if BROKEN_LINKER && !USE_REENTRANT + cur_term = termp; +#elif BROKEN_LINKER || USE_REENTRANT + _nc_prescreen._cur_term = termp; +#else + cur_term = termp; +#endif + if (termp != 0) { + ospeed = _nc_ospeed(termp->_baudrate); + if (termp->type.Strings) { + PC = (char) ((pad_char != NULL) ? pad_char[0] : 0); } - return oldterm; + } + _nc_unlock_global(curses); + + T((T_RETURN("%p"), oldterm)); + return (oldterm); } -int del_curterm(TERMINAL *termp) +NCURSES_EXPORT(int) +NCURSES_SP_NAME(del_curterm) (NCURSES_SP_DCLx TERMINAL * termp) { - T((T_CALLED("del_curterm(%p)"), termp)); + int rc = ERR; - if (termp != 0) { - _nc_free_termtype(&(termp->type)); - free(termp); - if (termp == cur_term) - cur_term = 0; - returnCode(OK); - } - returnCode(ERR); + T((T_CALLED("del_curterm(%p)"), termp)); + + _nc_lock_global(curses); + if (termp != 0) { + _nc_free_termtype(&(termp->type)); + FreeIfNeeded(termp->_termname); + free(termp); + if (termp == cur_term) + set_curterm(0); + rc = OK; + } + _nc_unlock_global(curses); + + returnCode(rc); +} + +#if NCURSES_SP_FUNCS +NCURSES_EXPORT(int) +del_curterm(TERMINAL * termp) +{ + int rc = ERR; + rc = NCURSES_SP_NAME(del_curterm) (CURRENT_SCREEN, termp); + return (rc); } +#endif