-rw-r--r-- | noncore/apps/opie-console/sz_transfer.cpp | 111 |
1 files changed, 109 insertions, 2 deletions
diff --git a/noncore/apps/opie-console/sz_transfer.cpp b/noncore/apps/opie-console/sz_transfer.cpp index a5af2be..41917c0 100644 --- a/noncore/apps/opie-console/sz_transfer.cpp +++ b/noncore/apps/opie-console/sz_transfer.cpp @@ -3,6 +3,105 @@ #include <qfile.h> #include <opie/oprocess.h> #include <stdio.h> +#include <sys/termios.h> + +/* following function ripped out of minicom's sysdep2.c */ + + +/* + * Set cbreak mode. + * Mode 0 = normal. + * Mode 1 = cbreak, no echo + * Mode 2 = raw, no echo. + * Mode 3 = only return erasechar (for wkeys.c) + * + * Returns: the current erase character. + */ + +static struct termios savetty; +int setcbreak(int mode) +{ +#if 1 + struct termios tty; + static int init = 0; + static int erasechar; + + + if (init == 0) { + tcgetattr(0, &savetty); + erasechar = savetty.c_cc[VERASE]; + init++; + } + + if (mode == 3) return(erasechar); + + + + /* Always return to default settings first */ + tcsetattr(0, TCSADRAIN, &savetty); + + if (mode == 0) { + return(erasechar); + } + + tcgetattr(0, &tty); + if (mode == 1) { + tty.c_oflag &= ~OPOST; + tty.c_lflag &= ~(XCASE|ECHONL|NOFLSH); + tty.c_lflag &= ~(ICANON | ISIG | ECHO); + tty.c_iflag &= ~(ICRNL|INLCR); + tty.c_cflag |= CREAD; + tty.c_cc[VTIME] = 5; + tty.c_cc[VMIN] = 1; + } + if (mode == 2) { /* raw */ + tty.c_iflag &= ~(IGNBRK | IGNCR | INLCR | ICRNL | IUCLC | + IXANY | IXON | IXOFF | INPCK | ISTRIP); + tty.c_iflag |= (BRKINT | IGNPAR); + tty.c_oflag &= ~OPOST; + tty.c_lflag &= ~(XCASE|ECHONL|NOFLSH); + tty.c_lflag &= ~(ICANON | ISIG | ECHO); + tty.c_cflag |= CREAD; + tty.c_cc[VTIME] = 5; + tty.c_cc[VMIN] = 1; + } + tcsetattr(0, TCSADRAIN, &tty); + return(erasechar); +#else + struct sgttyb args; + static int init = 0; + static int erasechar; + + if (init == 0) { + (void) ioctl(0, TIOCGETP, &savetty); + (void) ioctl(0, TIOCGETC, &savetty2); + erasechar = savetty.sg_erase; + init++; + } + + if (mode == 3) return(erasechar); + + if (mode == 0) { + (void) ioctl(0, TIOCSETP, &savetty); + (void) ioctl(0, TIOCSETC, &savetty2); + return(erasechar); + } + + (void) ioctl(0, TIOCGETP, &args); + if (mode == 1) { + args.sg_flags |= CBREAK; + args.sg_flags &= ~(ECHO|RAW); + } + if (mode == 2) { + args.sg_flags |= RAW; + args.sg_flags &= ~(ECHO|CBREAK); + } + (void) ioctl(0, TIOCSETP, &args); + return(erasechar); +#endif + +} + SzTransfer::SzTransfer(Type t, IOLayer *layer) : FileTransferLayer(layer), m_t(t) { @@ -18,6 +117,8 @@ void SzTransfer::sendFile(const QFile& file) { void SzTransfer::sendFile(const QString& file) { + //setcbreak(2); /* raw no echo */ + proc = new OProcess; *proc << "sz"; *proc << "-v" << "-v" << "-v" << "-b" << file; @@ -35,7 +136,7 @@ void SzTransfer::sendFile(const QString& file) { void SzTransfer::SzReceivedStdout(OProcess *, char *buffer, int buflen) { - qWarning("recieved from sz %d bytes", buflen); + //qWarning("recieved from sz %d bytes", buflen); QByteArray data(buflen); data.fill(*buffer, buflen); @@ -54,7 +155,8 @@ void SzTransfer::SzReceivedStderr(OProcess *, char *buffer, int length) { void SzTransfer::receivedStdin(const QByteArray &data) { - qWarning("recieved from io_serial %d bytes", data.size()); + //qWarning("recieved from io_serial %d bytes", data.size()); + // recieved data from the io layer goes to sz proc->writeStdin(data.data(), data.size()); @@ -63,7 +165,12 @@ void SzTransfer::receivedStdin(const QByteArray &data) { void SzTransfer::sent() { qWarning("sent file"); + + //setcbreak(0); /* default */ + + delete proc; disconnect(layer(), SIGNAL(received(const QByteArray &)), this, SLOT(receivedStdin(const QByteArray &))); + } |