summaryrefslogtreecommitdiffstats
path: root/vncterm/VNCommand.c
diff options
context:
space:
mode:
authordscho <dscho>2003-02-09 18:05:54 +0000
committerdscho <dscho>2003-02-09 18:05:54 +0000
commit23f45bc7641dbe9b87ba281cf54ba844fe7edcee (patch)
treefdebf0bd19eaed02335ff89e1d431acb93b0dc16 /vncterm/VNCommand.c
parent28a84b63fe186a443704ade90a3e6370f127a2ec (diff)
downloadlibtdevnc-23f45bc7641dbe9b87ba281cf54ba844fe7edcee.tar.gz
libtdevnc-23f45bc7641dbe9b87ba281cf54ba844fe7edcee.zip
included vncterm
Diffstat (limited to 'vncterm/VNCommand.c')
-rw-r--r--vncterm/VNCommand.c116
1 files changed, 116 insertions, 0 deletions
diff --git a/vncterm/VNCommand.c b/vncterm/VNCommand.c
new file mode 100644
index 0000000..1e86fe6
--- /dev/null
+++ b/vncterm/VNCommand.c
@@ -0,0 +1,116 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include <fcntl.h>
+#include <sys/time.h>
+#include <unistd.h>
+#include <errno.h>
+#include "VNConsole.h"
+#include "vga.h"
+
+
+int main(int argc, char **argv)
+{
+ Bool interactive=FALSE,sendOnlyWholeLines=TRUE;
+ int serverArgc,programArg0;
+ for(serverArgc=1;serverArgc<argc
+ && argv[serverArgc][0]=='-' && argv[serverArgc][1]!='-';serverArgc++)
+ if(!strcmp(argv[serverArgc],"-interactive")) {
+ interactive=TRUE;
+ sendOnlyWholeLines=FALSE;
+
+ rfbPurgeArguments(&argc,&serverArgc,1,argv);
+ }
+ programArg0=serverArgc;
+ if(programArg0<argc && argv[programArg0][0]=='-' && argv[programArg0][1]=='-')
+ programArg0++;
+ argv[argc]=0;
+
+ if(programArg0<argc) {
+ int in[2],out[2],err[2],pid;
+ if(pipe(in)<0 || pipe(out)<0 || pipe(err)<0) {
+ fprintf(stderr,"Couldn't make pipes!");
+ return(1);
+ }
+
+ pid=fork();
+ if(!pid) {
+ dup2(in[0],0);
+ dup2(out[1],1);
+ dup2(err[1],2);
+ //setbuf(stdin,NULL);
+ execvp(argv[programArg0],argv+programArg0);
+ }
+
+ {
+ char buffer[1024];
+ fd_set fs,fs1/*,ifs,ifs1*/;
+ struct timeval tv,tv1;
+ int i,c=1,num_fds,max_fd=out[0];
+ FILE *input_pipe;
+ vncConsolePtr console=vcGetConsole(&serverArgc,argv,80,25,&vgaFont,FALSE);
+ if(interactive)
+ console->doEcho = FALSE;
+
+ if(max_fd<err[0])
+ max_fd=err[0];
+ FD_ZERO(&fs);
+ FD_SET(out[0],&fs);
+ FD_SET(err[0],&fs);
+ //FD_SET(0,&fs);
+ tv.tv_sec=0; tv.tv_usec=5000;
+
+ input_pipe=fdopen(in[1],"w");
+ setbuf(input_pipe,NULL);
+ while(c || getpgid(pid)>=0) {
+ /* event loop */
+ vcProcessEvents(console);
+
+ /* get input */
+ if(console->inputCount) {
+ if(sendOnlyWholeLines) {
+ for(i=0;i<console->inputCount;i++)
+ if(console->inputBuffer[i]=='\n') {
+ i++;
+ fwrite(console->inputBuffer,i,1,input_pipe);
+ fflush(input_pipe);
+ /* fwrite(console->inputBuffer,i,1,stderr); */
+ if(console->inputCount>i)
+ memmove(console->inputBuffer,console->inputBuffer+i,console->inputCount-i);
+ console->inputCount-=i;
+ i=0;
+ }
+ } else {
+ fwrite(console->inputBuffer,console->inputCount,1,input_pipe);
+ fflush(input_pipe);
+ /* fwrite(console->inputBuffer,console->inputCount,1,stderr); */
+ console->inputCount=0;
+ }
+ }
+ /* process output */
+ fs1=fs; tv1=tv;
+ num_fds=select(max_fd+1,&fs1,NULL,NULL,&tv1);
+ if(num_fds>0) {
+ /*
+ if(FD_ISSET(0,&fs1)) {
+ ch=getchar();
+ fputc(ch,f);
+ }
+ */
+ if(FD_ISSET(out[0],&fs1)) {
+ c=read(out[0],buffer,1024);
+ for(i=0;i<c;i++)
+ vcPutChar(console,buffer[i]);
+ }
+ if(FD_ISSET(err[0],&fs1)) {
+ c=read(err[0],buffer,1024);
+ for(i=0;i<c;i++)
+ vcPutChar(console,buffer[i]);
+ }
+ } else
+ c=0;
+ }
+ }
+ }
+ fprintf(stderr,"exit\n");
+ return(0);
+}