-rw-r--r-- | noncore/apps/opie-console/dialer.cpp | 33 |
1 files changed, 23 insertions, 10 deletions
diff --git a/noncore/apps/opie-console/dialer.cpp b/noncore/apps/opie-console/dialer.cpp index 10c16ef..bd6b50f 100644 --- a/noncore/apps/opie-console/dialer.cpp +++ b/noncore/apps/opie-console/dialer.cpp @@ -120,4 +120,6 @@ void Dialer::dial(const QString& number) if(usercancel) { + // modem hangup + trydial(QString::null); reject(); } @@ -126,11 +128,11 @@ void Dialer::dial(const QString& number) void Dialer::trydial(const QString& number) { - if(state != state_cancel) - { - switchState(state_preinit); + //if(state != state_cancel) + //{ + if(state != state_cancel) switchState(state_preinit); send("+++ATH"); send(""); //QString response = receive(); - } + //} if(state != state_cancel) @@ -148,5 +150,5 @@ void Dialer::trydial(const QString& number) switchState(state_options); - send("ATM0L0"); + send("ATM3L3"); QString response3 = receive(); if(!response3.contains("\nOK\r")) @@ -171,5 +173,9 @@ void Dialer::trydial(const QString& number) //send(QString("%1 %2").arg(m_profile.readEntry("DialPrefix1")).arg(number)); QString response5 = receive(); - if(!response5.contains("\nOK\r")) + if(!response5.contains("\nCONNECT")) + { + if(response5.contains("BUSY")) + switchState(state_dialing); + else { QMessageBox::warning(this, @@ -179,4 +185,5 @@ void Dialer::trydial(const QString& number) } } + } if(state != state_cancel) @@ -209,7 +216,10 @@ qWarning("Sending: '%s'", m.latin1()); QString Dialer::receive() { + QString buf; char buffer[1024]; int ret; + qApp->processEvents(); + while(1) { @@ -221,6 +231,11 @@ QString Dialer::receive() buffer[i] = buffer[i] & 0x7F; buffer[ret] = 0; - qWarning("Receiving: '%s'", buffer); - return QString(buffer); +qWarning("Got: '%s'", buffer); + buf.append(QString(buffer)); + if(buf.contains("OK") || buf.contains("ERROR") || buf.contains("CONNECT") || (buf.contains("BUSY"))) +{ +qWarning("Receiving: '%s'", buf.latin1()); + return buf; +} } else if(ret < 0) @@ -230,6 +245,4 @@ QString Dialer::receive() } - //for(int i = 0; i < 200000;i++) - // qApp->processEvents(); return QString::null; } |