author | zautrix <zautrix> | 2005-02-23 22:51:41 (UTC) |
---|---|---|
committer | zautrix <zautrix> | 2005-02-23 22:51:41 (UTC) |
commit | a130c77b5c762131fb9ecb4cc96de52126b8c338 (patch) (side-by-side diff) | |
tree | 655ecb4c1bb5e735a7d9a63104db8872367e84e9 /libkdepim/ksyncmanager.cpp | |
parent | 4a9bf75c2ef12a40be3aea1d147f3703aee48638 (diff) | |
download | kdepimpi-a130c77b5c762131fb9ecb4cc96de52126b8c338.zip kdepimpi-a130c77b5c762131fb9ecb4cc96de52126b8c338.tar.gz kdepimpi-a130c77b5c762131fb9ecb4cc96de52126b8c338.tar.bz2 |
socket fix
-rw-r--r-- | libkdepim/ksyncmanager.cpp | 26 |
1 files changed, 24 insertions, 2 deletions
diff --git a/libkdepim/ksyncmanager.cpp b/libkdepim/ksyncmanager.cpp index 08a263c..5214fe7 100644 --- a/libkdepim/ksyncmanager.cpp +++ b/libkdepim/ksyncmanager.cpp @@ -1069,10 +1069,13 @@ void KSyncManager::syncPi() void KSyncManager::deleteCommandSocket(KCommandSocket*s, int state) { //enum { success, errorW, errorR, quiet }; - if ( state == KCommandSocket::errorR ||state == KCommandSocket::errorTO ) { - mParent->topLevelWidget()->setCaption( i18n("ERROR: Receiving remote file failed.") ); + if ( state == KCommandSocket::errorR ||state == KCommandSocket::errorTO ||state == KCommandSocket::errorPW ) { + if ( state == KCommandSocket::errorPW ) + mParent->topLevelWidget()->setCaption( i18n("Wrong password: Receiving remote file failed.") ); + else + mParent->topLevelWidget()->setCaption( i18n("ERROR: Receiving remote file failed.") ); delete s; if ( state == KCommandSocket::errorR ) { KCommandSocket* commandSocket = new KCommandSocket( mPassWordPiSync, mActiveSyncPort.toUInt(), mActiveSyncIP, this, mParent->topLevelWidget()); connect( commandSocket, SIGNAL(commandFinished( KCommandSocket*, int)), this, SLOT(deleteCommandSocket(KCommandSocket*, int )) ); @@ -1200,8 +1203,17 @@ void KServerSocket::readClient() end_connect(); } } } +void KServerSocket::error_connect() +{ + QTextStream os( mSocket ); + os.setEncoding( QTextStream::Latin1 ); + os << "ERROR_PW\r\n\r\n"; + mSocket->close(); + if ( mSocket->state() == QSocket::Idle ) + QTimer::singleShot( 10, this , SLOT ( discardClient())); +} void KServerSocket::end_connect() { delete mSyncActionDialog; mSyncActionDialog = 0; @@ -1350,8 +1362,9 @@ KCommandSocket::KCommandSocket ( QString password, Q_UINT16 port, QString host, { mPassWord = password; mSocket = 0; mFirst = false; + mFirstLine = true; mPort = port; mHost = host; tlw = cap; mRetVal = quiet; @@ -1447,8 +1460,9 @@ void KCommandSocket::startReadFileFromSocket() mFirst = false; mTimerSocket->stop(); mFileString = ""; mTime.start(); + mFirstLine = true; QTimer::singleShot( 1, this , SLOT (readFileFromSocket( ) )); } void KCommandSocket::readFileFromSocket() @@ -1456,8 +1470,16 @@ void KCommandSocket::readFileFromSocket() //qDebug("readBackFileFromSocket() %d ", mTime.elapsed ()); while ( mSocket->canReadLine () ) { mTime.restart(); QString line = mSocket->readLine (); + if ( mFirstLine ) { + mFirstLine = false; + if ( line.left( 8 ) == "ERROR_PW" ) { + mRetVal = errorPW; + deleteSocket(); + return ; + } + } mFileString += line; //qDebug("readline: %s ", line.latin1()); } if ( mTime.elapsed () < 3000 ) { |