int isatty(int fd); //
如果打开的文件描述符fd连接到一个终端,则系统调用isatty返回1,否则返回0
if(!isatty(fileno(stdout)))
{
fprintf(stderr,"You are not a terminal!\n");
exit(1);
}
// int fileno(FILE *f); FILE * -> fd
最小的termios结构的典型定义:
struct termios{
tcflag_t c_iflag; 输入模式
tcflag_t c_oflag; 输出模式
tcflag_t c_cflag; 控制模式
tcflag_t c_lflag; 本地模式
cc_t c_cc[NCCS]; 特殊控制字符
}; //
int tcgetattr(int fd, struct termios *termios_p); //
作用:把当前终端接口变量的值写入termios_p参数指向的结构。
int tcsetattr(int fd, int actions, const struct termios *termios_p);//
作用:如果这些值其后被修改了,可以调用tcsetattr来重新配置终端接口
/* actions参数控制修改方式:共有3种:
TCSANOW 立刻对值修改
TCSADRAIN 等当前的输出完成后再对值进行修改
TCSAFLUSH 等当前的输出完成后再对值进行修改,但丢弃还未从read调用返回的当前可用的任何输入
*/
$ stty -a
通过函数调用来实现。
int tcgetattr(int fd, struct termios *termios_p); //
根据文件描述符,得到与fd相关联的终端的终端设置,并保存在termios_p所指向的内存。
int tcsetattr(int fd, int actions, const struct termios *termios_p);//
//见前面。
speed_t cfgetispeed(const struct termios *);
speed_t cfgetospeed(const struct termios *);
int cfsetispeed(struct termios *, speed_t speed);
int cfsetospeed(struct termios *, speed_t speed); //
输入速度与输出速度分开。
要想设置新的终端速度,必须先调用tcgetattr来获取当前终端设置,
只有调用了函数tcsetattr之后,终端速度才会改变。
speed参数可能的值很多:
B0: 挂起终端
B1200: 1200波特
B2400: 2400波特
B9600: 9600波特
B19200: 19200波特
B38400: 38400波特
$ echo $TERM
xterm-256color
shell通过xterm程序(一个X视窗系统的终端仿真程序)或是提供类似功能的程序运行的。
$ infocmp vt100
# Reconstructed via infocmp from file: /lib/terminfo/v/vt100
vt100|vt100-am|dec vt100 (w/advanced video),
am, mc5i, msgr, xenl, xon,
cols#80, it#8, lines#24, vt#3,
acsc=``aaffggjjkkllmmnnooppqqrrssttuuvvwwxxyyzz{
{
||}}~~,
bel=^G, blink=\E[5m$<2>, bold=\E[1m$<2>,
clear=\E[H\E[J$<50>, cr=\r, csr=\E[%i%p1%d;%p2%dr,
cub=\E[%p1%dD, cub1=^H, cud=\E[%p1%dB, cud1=\n,
cuf=\E[%p1%dC, cuf1=\E[C$<2>,
cup=\E[%i%p1%d;%p2%dH$<5>, cuu=\E[%p1%dA,
cuu1=\E[A$<2>, ed=\E[J$<50>, el=\E[K$<3>, el1=\E[1K$<3>,
enacs=\E(B\E)0, home=\E[H, ht=^I, hts=\EH, ind=\n, ka1=\EOq,
ka3=\EOs, kb2=\EOr, kbs=^H, kc1=\EOp, kc3=\EOn, kcub1=\EOD,
kcud1=\EOB, kcuf1=\EOC, kcuu1=\EOA, kent=\EOM, kf0=\EOy,
kf1=\EOP, kf10=\EOx, kf2=\EOQ, kf3=\EOR, kf4=\EOS, kf5=\EOt,
kf6=\EOu, kf7=\EOv, kf8=\EOl, kf9=\EOw, lf1=pf1, lf2=pf2,
lf3=pf3, lf4=pf4, mc0=\E[0i, mc4=\E[4i, mc5=\E[5i, rc=\E8,
rev=\E[7m$<2>, ri=\EM$<5>, rmacs=^O, rmam=\E[?7l,
rmkx=\E[?1l\E>, rmso=\E[m$<2>, rmul=\E[m$<2>,
rs2=\E<\E>\E[?3;4;5l\E[?7;8h\E[r, sc=\E7,
sgr=\E[0%?%p1%p6%|%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;%?%p4%t;5%;m%?%p9%t\016%e\017%;$<2>,
sgr0=\E[m\017$<2>, smacs=^N, smam=\E[?7h, smkx=\E[?1h\E=,
smso=\E[7m$<2>, smul=\E[4m$<2>, tbc=\E[3g,
int setupterm(char *term, int fd, int *errret); //
setupterm库函数将当前终端类型设置为参数term指向的值,
如果term是空指针,就用环境变量TERM的值。
参数fd是一个打开的文件描述符,用于向终端写数据。
如果errret不是一个空指针,则函数的返回值保存在该参数指向的整型变量中。
写入errret的值:
-1 terminfo数据库不存在
0 terminfo数据库中没有匹配的数据项
1 成功
该函数成功时返回常量OK,失败时返回ERR。
如果errret被设置为空指针,setupterm函数会在失败时输出一条诊断信息并导致程序直接退出。