mirror of
https://github.com/Aigor44/ncursesw-morphos.git
synced 2025-01-24 15:13:56 +08:00
59108c98bd
+ supply a null-terminator to buffer in _nc_viswibuf(). + fix a sign-extension bug in unget_wch() (report by Mike Gran). + minor fixes to error-returns in default function for tputs, as well as in lib_screen.c
308 lines
7.2 KiB
C
308 lines
7.2 KiB
C
/****************************************************************************
|
|
* Copyright (c) 2005-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 *
|
|
* "Software"), to deal in the Software without restriction, including *
|
|
* without limitation the rights to use, copy, modify, merge, publish, *
|
|
* distribute, distribute with modifications, sublicense, and/or sell *
|
|
* copies of the Software, and to permit persons to whom the Software is *
|
|
* furnished to do so, subject to the following conditions: *
|
|
* *
|
|
* The above copyright notice and this permission notice shall be included *
|
|
* in all copies or substantial portions of the Software. *
|
|
* *
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS *
|
|
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF *
|
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. *
|
|
* IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, *
|
|
* DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR *
|
|
* OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR *
|
|
* THE USE OR OTHER DEALINGS IN THE SOFTWARE. *
|
|
* *
|
|
* Except as contained in this notice, the name(s) of the above copyright *
|
|
* holders shall not be used in advertising or otherwise to promote the *
|
|
* sale, use or other dealings in this Software without prior written *
|
|
* authorization. *
|
|
****************************************************************************/
|
|
|
|
/*
|
|
* Author: Thomas E. Dickey
|
|
*
|
|
* $Id: demo_termcap.c,v 1.12 2009/10/10 16:01:41 tom Exp $
|
|
*
|
|
* A simple demo of the termcap interface.
|
|
*/
|
|
#define USE_TINFO
|
|
#include <test.priv.h>
|
|
|
|
#if HAVE_TGETENT
|
|
|
|
#if defined(HAVE_CURSES_DATA_BOOLNAMES) || defined(DECL_CURSES_DATA_BOOLNAMES)
|
|
#define USE_CODE_LISTS 1
|
|
#else
|
|
#define USE_CODE_LISTS 0
|
|
#endif
|
|
|
|
#define FCOLS 8
|
|
#define FNAME(type) "%s %-*s = ", #type, FCOLS
|
|
|
|
#if USE_CODE_LISTS
|
|
static bool b_opt = FALSE;
|
|
static bool n_opt = FALSE;
|
|
static bool s_opt = FALSE;
|
|
#endif
|
|
|
|
#define isCapName(c) (isgraph(c) && strchr("^#=:\\", c) == 0)
|
|
|
|
static void
|
|
dumpit(NCURSES_CONST char *cap)
|
|
{
|
|
/*
|
|
* One of the limitations of the termcap interface is that the library
|
|
* cannot determine the size of the buffer passed via tgetstr(), nor the
|
|
* amount of space remaining. This demo simply reuses the whole buffer
|
|
* for each call; a normal termcap application would try to use the buffer
|
|
* to hold all of the strings extracted from the terminal entry.
|
|
*/
|
|
char area[1024], *ap = area;
|
|
char *str;
|
|
int num;
|
|
|
|
if ((str = tgetstr(cap, &ap)) != 0) {
|
|
/*
|
|
* Note that the strings returned are mostly terminfo format, since
|
|
* ncurses does not convert except for a handful of special cases.
|
|
*/
|
|
printf(FNAME(str), cap);
|
|
while (*str != 0) {
|
|
int ch = UChar(*str++);
|
|
switch (ch) {
|
|
case '\177':
|
|
fputs("^?", stdout);
|
|
break;
|
|
case '\033':
|
|
fputs("\\E", stdout);
|
|
break;
|
|
case '\b':
|
|
fputs("\\b", stdout);
|
|
break;
|
|
case '\f':
|
|
fputs("\\f", stdout);
|
|
break;
|
|
case '\n':
|
|
fputs("\\n", stdout);
|
|
break;
|
|
case '\r':
|
|
fputs("\\r", stdout);
|
|
break;
|
|
case ' ':
|
|
fputs("\\s", stdout);
|
|
break;
|
|
case '\t':
|
|
fputs("\\t", stdout);
|
|
break;
|
|
case '^':
|
|
fputs("\\^", stdout);
|
|
break;
|
|
case ':':
|
|
fputs("\\072", stdout);
|
|
break;
|
|
case '\\':
|
|
fputs("\\\\", stdout);
|
|
break;
|
|
default:
|
|
if (isgraph(ch))
|
|
fputc(ch, stdout);
|
|
else if (ch < 32)
|
|
printf("^%c", ch + '@');
|
|
else
|
|
printf("\\%03o", ch);
|
|
break;
|
|
}
|
|
}
|
|
printf("\n");
|
|
} else if ((num = tgetnum(cap)) >= 0) {
|
|
printf(FNAME(num), cap);
|
|
printf(" %d\n", num);
|
|
} else if ((num = tgetflag(cap)) > 0) {
|
|
printf(FNAME(flg), cap);
|
|
printf("%s\n", "true");
|
|
}
|
|
fflush(stdout);
|
|
}
|
|
|
|
static void
|
|
brute_force(const char *name)
|
|
{
|
|
char buffer[1024];
|
|
|
|
printf("Terminal type %s\n", name);
|
|
if (tgetent(buffer, name) >= 0) {
|
|
char cap[3];
|
|
int c1, c2;
|
|
|
|
cap[2] = 0;
|
|
for (c1 = 0; c1 < 256; ++c1) {
|
|
cap[0] = (char) c1;
|
|
if (isCapName(c1)) {
|
|
for (c2 = 0; c2 < 256; ++c2) {
|
|
cap[1] = (char) c2;
|
|
if (isCapName(c2)) {
|
|
dumpit(cap);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
#if USE_CODE_LISTS
|
|
static void
|
|
demo_terminfo(NCURSES_CONST char *name)
|
|
{
|
|
unsigned n;
|
|
NCURSES_CONST char *cap;
|
|
|
|
printf("Terminal type \"%s\"\n", name);
|
|
setupterm(name, 1, (int *) 0);
|
|
|
|
if (b_opt) {
|
|
for (n = 0;; ++n) {
|
|
cap = boolcodes[n];
|
|
if (cap == 0)
|
|
break;
|
|
dumpit(cap);
|
|
}
|
|
}
|
|
|
|
if (n_opt) {
|
|
for (n = 0;; ++n) {
|
|
cap = numcodes[n];
|
|
if (cap == 0)
|
|
break;
|
|
dumpit(cap);
|
|
}
|
|
}
|
|
|
|
if (s_opt) {
|
|
for (n = 0;; ++n) {
|
|
cap = strcodes[n];
|
|
if (cap == 0)
|
|
break;
|
|
dumpit(cap);
|
|
}
|
|
}
|
|
}
|
|
|
|
static void
|
|
usage(void)
|
|
{
|
|
static const char *msg[] =
|
|
{
|
|
"Usage: demo_terminfo [options] [terminal]",
|
|
"",
|
|
"If no options are given, print all (boolean, numeric, string)",
|
|
"capabilities for the given terminal, using short names.",
|
|
"",
|
|
"Options:",
|
|
" -a try all names, print capabilities found",
|
|
" -b print boolean-capabilities",
|
|
" -n print numeric-capabilities",
|
|
" -r COUNT repeat for given count",
|
|
" -s print string-capabilities",
|
|
};
|
|
unsigned n;
|
|
for (n = 0; n < SIZEOF(msg); ++n) {
|
|
fprintf(stderr, "%s\n", msg[n]);
|
|
}
|
|
ExitProgram(EXIT_FAILURE);
|
|
}
|
|
#endif
|
|
|
|
int
|
|
main(int argc, char *argv[])
|
|
{
|
|
int n;
|
|
char *name;
|
|
bool a_opt = FALSE;
|
|
|
|
#if USE_CODE_LISTS
|
|
int repeat;
|
|
int r_opt = 1;
|
|
|
|
while ((n = getopt(argc, argv, "abnr:s")) != -1) {
|
|
switch (n) {
|
|
case 'a':
|
|
a_opt = TRUE;
|
|
break;
|
|
case 'b':
|
|
b_opt = TRUE;
|
|
break;
|
|
case 'n':
|
|
n_opt = TRUE;
|
|
break;
|
|
case 'r':
|
|
if ((r_opt = atoi(optarg)) <= 0)
|
|
usage();
|
|
break;
|
|
case 's':
|
|
s_opt = TRUE;
|
|
break;
|
|
default:
|
|
usage();
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (!(b_opt || n_opt || s_opt)) {
|
|
b_opt = TRUE;
|
|
n_opt = TRUE;
|
|
s_opt = TRUE;
|
|
}
|
|
#else
|
|
a_opt = TRUE;
|
|
#endif
|
|
|
|
if (a_opt) {
|
|
if (optind < argc) {
|
|
for (n = optind; n < argc; ++n) {
|
|
brute_force(argv[n]);
|
|
}
|
|
} else if ((name = getenv("TERM")) != 0) {
|
|
brute_force(name);
|
|
} else {
|
|
static char dumb[] = "dumb";
|
|
brute_force(dumb);
|
|
}
|
|
}
|
|
#if USE_CODE_LISTS
|
|
else {
|
|
for (repeat = 0; repeat < r_opt; ++repeat) {
|
|
if (optind < argc) {
|
|
for (n = optind; n < argc; ++n) {
|
|
demo_terminfo(argv[n]);
|
|
}
|
|
} else if ((name = getenv("TERM")) != 0) {
|
|
demo_terminfo(name);
|
|
} else {
|
|
static char dumb[] = "dumb";
|
|
demo_terminfo(dumb);
|
|
}
|
|
}
|
|
}
|
|
#endif
|
|
|
|
ExitProgram(EXIT_SUCCESS);
|
|
}
|
|
|
|
#else
|
|
int
|
|
main(int argc GCC_UNUSED,
|
|
char *argv[]GCC_UNUSED)
|
|
{
|
|
printf("This program requires termcap\n");
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
#endif
|