X-Git-Url: https://git.realraum.at/?a=blobdiff_plain;f=serial_console%2Fusocket.c;h=9f05355e4c12d6fd84dda1ab729ec2b3305711ae;hb=c28acc820c3a9f1dc343e8b5aba4e65d95060c71;hp=d00a8b5f3cbe9ff172417c618f4fe916fe2dd361;hpb=51b8c0cb530de874de351d6a7d954c21a7644a3e;p=svn42.git diff --git a/serial_console/usocket.c b/serial_console/usocket.c index d00a8b5..9f05355 100644 --- a/serial_console/usocket.c +++ b/serial_console/usocket.c @@ -64,7 +64,9 @@ void connect_terminal(int fd) { send(fd,buffer,num_byte,0); } - if (num_byte == 0 || (num_byte <0 && errno != EAGAIN)) + if (num_byte <0 && errno != EAGAIN) + return; + if (quit_on_eof_ && num_byte == 0) return; } @@ -104,12 +106,17 @@ int main(int argc, char* argv[]) { int ret = 0; int socket_fd = 0; + char *socket_file; //~ struct termios tmio_prev; + if (argc > 1) + socket_file = argv[1]; + else + socket_file = default_socket_file_; - if (argc > 0) - socket_file_ = argv[1]; + if (argc > 2) + quit_on_eof_=0; - socket_fd = establish_socket_connection(socket_file_); + socket_fd = establish_socket_connection(socket_file); if(socket_fd) { //~ ret = set_tty_raw(STDIN_FILENO,&tmio_prev); @@ -124,7 +131,7 @@ int main(int argc, char* argv[]) } else { - fprintf(stderr, "%s error, aborting..\n", socket_file_); + fprintf(stderr, "%s error, aborting..\n", socket_file); ret=2; }