summaryrefslogtreecommitdiff
Side-by-side diff
Diffstat (more/less context) (show whitespace changes)
-rw-r--r--core/applets/obex/obex.cc62
-rw-r--r--core/applets/obex/obex.h4
-rw-r--r--core/applets/obex/obeximpl.cc10
3 files changed, 71 insertions, 5 deletions
diff --git a/core/applets/obex/obex.cc b/core/applets/obex/obex.cc
index 683964b..2218dbc 100644
--- a/core/applets/obex/obex.cc
+++ b/core/applets/obex/obex.cc
@@ -14,4 +14,9 @@ Obex::Obex( QObject *parent, const char* name )
m_send=0;
m_count = 0;
+ m_receive = false;
+ connect( this, SIGNAL(error(int) ), // for recovering to receive
+ SLOT(slotError() ) );
+ connect( this, SIGNAL(sent() ),
+ SLOT(slotError() ) );
};
Obex::~Obex() {
@@ -20,4 +25,5 @@ Obex::~Obex() {
}
void Obex::receive() {
+ m_receive = true;
qWarning("Receive" );
m_rec = new OProcess();
@@ -33,14 +39,32 @@ void Obex::receive() {
qWarning("could not start :(");
emit done( false );
+ delete m_rec;
+ m_rec = 0;
}
- emit currentTry(m_count );
+// emit currentTry(m_count );
}
-void Obex::send( const QString& fileName) {
+void Obex::send( const QString& fileName) { // if currently receiving stop it send receive
m_count = 0;
m_file = fileName;
+ qWarning("send");
+ if (m_rec != 0 ) {
+ qWarning("running");
+ if (m_rec->isRunning() ) {
+ emit error(-1 );
+ qWarning("is running");
+ delete m_rec;
+ m_rec = 0;
+
+ }else{
+ qWarning("is not running");
+ emit error( -1 ); // we did not delete yet but it's not running slotExited is pending
+ return;
+ }
+ }
sendNow();
}
void Obex::sendNow(){
+ qWarning("sendNow");
if ( m_count >= 25 ) { // could not send
emit error(-1 );
@@ -57,4 +81,5 @@ void Obex::sendNow(){
connect(m_send, SIGNAL(receivedStdout(OProcess*, char*, int )),
this, SLOT(slotStdOut(OProcess*, char*, int) ) );
+
// now start it
if (!m_send->start(/*OProcess::NotifyOnExit, OProcess::AllOutput*/ ) ) {
@@ -62,4 +87,6 @@ void Obex::sendNow(){
m_count = 25;
emit error(-1 );
+ delete m_send;
+ m_send=0;
}
// end
@@ -89,7 +116,9 @@ void Obex::recieved() {
}
}else{
- emit error(-1);
+ emit done(false);
};
delete m_rec;
+ m_rec = 0;
+ receive();
}
@@ -127,2 +156,29 @@ QString Obex::parseOut( ){
return path;
}
+/**
+ * when sent is done slotError is called we will start receive again
+ */
+void Obex::slotError() {
+ qWarning("slotError");
+ if ( m_receive )
+ receive();
+};
+void Obex::setReceiveEnabled( bool receive ) {
+ if ( !receive ) { //
+ m_receive = false;
+ shutDownReceive();
+ }
+}
+
+void Obex::shutDownReceive() {
+ if (m_rec != 0 ) {
+ qWarning("running");
+ if (m_rec->isRunning() ) {
+ emit error(-1 );
+ qWarning("is running");
+ delete m_rec;
+ m_rec = 0;
+ }
+ }
+
+}
diff --git a/core/applets/obex/obex.h b/core/applets/obex/obex.h
index 4e78015..2ce44f2 100644
--- a/core/applets/obex/obex.h
+++ b/core/applets/obex/obex.h
@@ -27,4 +27,5 @@ namespace OpieObex {
void receive();
void send( const QString& );
+ void setReceiveEnabled( bool = false );
signals:
@@ -56,4 +57,6 @@ namespace OpieObex {
OProcess *m_send;
OProcess *m_rec;
+ bool m_receive : 1;
+ void shutDownReceive();
private slots:
@@ -68,4 +71,5 @@ namespace OpieObex {
void slotExited(OProcess* proc) ;
void slotStdOut(OProcess*, char*, int);
+ void slotError();
private:
diff --git a/core/applets/obex/obeximpl.cc b/core/applets/obex/obeximpl.cc
index 856f100..0c137af 100644
--- a/core/applets/obex/obeximpl.cc
+++ b/core/applets/obex/obeximpl.cc
@@ -50,4 +50,5 @@ void ObexImpl::slotMessage( const QCString& msg, const QByteArray&data ) {
QString filename;
stream >> filename;
+ m_sendgui->raise(); // should be on top
m_sendgui->showMaximized();
m_sendgui->lblPath->setText(filename);
@@ -57,7 +58,12 @@ void ObexImpl::slotMessage( const QCString& msg, const QByteArray&data ) {
connect( (QObject*)m_obex, SIGNAL( sent() ), this,
SLOT( slotSent() ) );
- }else if(msg == "receive(bool)" ) { // open a GUI
+ }else if(msg == "receive(int)" ) { // open a GUI
m_recvgui->showMaximized();
+ int receiveD = 0;
+ stream >> receiveD;
+ if ( receiveD == 1)
m_obex->receive();
+ else
+ m_obex->setReceiveEnabled( false );
} else if (msg =="done(QString)") {
@@ -88,5 +94,5 @@ void ObexImpl::slotError( int errorCode) {
QString errorString = "";
- if (errorCode = -1) {
+ if (errorCode == -1) {
errorString = "test";
}