您的位置:首页 > 运维架构 > Shell

linux下利用伪终端同shell进行交互

2009-10-27 16:21 197 查看
linux下利用伪终端同shell进行交互
--lihn1987
最近在公司总是要用到gdb进行程序调试,随着调试等级的提高,万能的printf越来越排不上用场了,莫法,将就用gdb吧,学了点gdb的知识发现gdb确实比较强大,但是比起vc之类的集成环境来说,其方便程度,让我不大接受得了。。。于是一个想法悠然而生,
可视化gdb!曾经网上有过类似东东,但是写的都不和我意,那就自己写吧,关于用到的东东,我打算用gtk做界面,界面已经用glade工具设计好了,然后用伪终端同shell进行交互,相当于一个图形程序中嵌入了一个伪终端。以前从来没有用过伪终端,今天刚查了资料象征性的写了一个程序。可以读取GDB输出,并像gdb输入。程序如下所示:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/types.h>
#include <linux/limits.h>
#include <pty.h>
void do_trans( int pty);
int main(int argc, char *argv[])
{
int pty, slave;
char pty_name[PATH_MAX];
int ret;
pid_t child;
ret = openpty(&pty, &slave, pty_name, NULL, NULL);
if (ret == -1)
{
perror("openpty");
exit(EXIT_FAILURE);
}
child = fork();
if (child == -1)
{
perror("fork");
exit(EXIT_FAILURE);
}
else if(child == 0)
{
close(pty);
login_tty(slave);
execl("/usr/bin/gdb", "gdb", NULL);
}
close(slave);
do_trans(pty);
exit(EXIT_SUCCESS);
}
void do_trans(int pty)
{
char buffer[800] = {0};
int ret;

write(pty, "l/n", 2);     //象征性的输入不标准的数据,作为查看交互是否成功
while(ret = read(pty, buffer, sizeof(buffer)-1)
{
buffer[ret-1] = 0;   //read是读不到字符串结束符的,需要自己添加,否则printf会出错
if (ret <= 0)
{
break;
}
fflush(stdout);//这步很重要,std中经常有数据滞留在存储区中需要此函数刷新
printf("%s",buffer);//打印出结果
}
return;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: