linux下利用偽終端同shell進行互動
--lihn1987
最近在公司總是要用到gdb進行程式調試,隨著調試等級的提高,萬能的printf越來越排不上用場了,莫法,將就用gdb吧,學了點gdb的知識發現gdb確實比較強大,但是比起vc之類的Integration Environment來說,其方便程度,讓我不大接受得了。。。於是一個想法悠然而生,
可視化gdb!曾經網上有過類似東東,但是寫的都不和我意,那就自己寫吧,關於用到的東東,我打算用gtk做介面,介面已經用glade工具設計好了,然後用偽終端同shell進行互動,相當於一個圖形程式中嵌入了一個偽終端。以前從來沒有用過偽終端,今天剛查了資料象徵性的寫了一個程式。可以讀取GDB輸出,並像gdb輸入。程式如下所示:
[code]
#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;
}
[/code]