-rw-r--r-- | core/applets/obex/obeximpl.cc | 40 | ||||
-rw-r--r-- | core/applets/obex/obeximpl.h | 4 |
2 files changed, 38 insertions, 6 deletions
diff --git a/core/applets/obex/obeximpl.cc b/core/applets/obex/obeximpl.cc index 0c137af..1a1c922 100644 --- a/core/applets/obex/obeximpl.cc +++ b/core/applets/obex/obeximpl.cc @@ -3,5 +3,8 @@ #include <qmessagebox.h> + #include <qpe/qcom.h> +#include <qpe/applnk.h> + #include <qlabel.h> @@ -23,4 +26,6 @@ ObexImpl::ObexImpl( ) connect(m_chan, SIGNAL(received(const QCString&, const QByteArray& ) ), this, SLOT(slotMessage(const QCString&, const QByteArray&) ) ); + connect(m_obex, SIGNAL(receivedFile(const QString& ) ), + this, SLOT(slotReceivedFile(const QString& ) ) ); } ObexImpl::~ObexImpl() { @@ -48,14 +53,15 @@ void ObexImpl::slotMessage( const QCString& msg, const QByteArray&data ) { QString desc; stream >> desc; - QString filename; - stream >> filename; + stream >> m_name; m_sendgui->raise(); // should be on top m_sendgui->showMaximized(); - m_sendgui->lblPath->setText(filename); + m_sendgui->lblPath->setText(m_name); connect( (QObject*)m_sendgui->PushButton2, SIGNAL(clicked()), this, SLOT(slotCancelSend())); - m_obex->send(filename ); + m_obex->send(m_name ); connect( (QObject*)m_obex, SIGNAL( sent() ), this, SLOT( slotSent() ) ); + connect( (QObject*)m_obex, SIGNAL( error(int) ), this, + SLOT( slotSent() ) ); }else if(msg == "receive(int)" ) { // open a GUI m_recvgui->showMaximized(); @@ -83,5 +89,5 @@ void ObexImpl::slotCancelSend() { void ObexImpl::slotDone(bool) { QCopEnvelope e ("QPE/Obex", "done(QString)" ); //but this into a slot - e << "Done!"; + e << m_name; } @@ -100,4 +106,28 @@ void ObexImpl::slotError( int errorCode) { m_sendgui->hide(); } +// Received a file via beam +// check for mime type and then either +// add to App via setDocument +void ObexImpl::slotReceivedFile( const QString &fileName ) { + qWarning("filename %s", fileName.latin1() ); + DocLnk lnk( fileName ); + QString exec = lnk.exec(); + qWarning("executing %s", exec.latin1() ); + if ( exec.isEmpty() || exec == "" ) { + qWarning("empty"); + if ( fileName.right(4) == ".vcf" ) + exec = "addressbook"; + else if ( fileName.right(4) == ".vcs" ) { + exec = "datebook"; + } + } // now prompt and then add it + QCString str= "QPE/Application/"; + str += exec.latin1(); + qWarning("channel %s", str.data() ); + QCopEnvelope e(str , "setDocument(QString)" ); + e << fileName; + +} + Q_EXPORT_INTERFACE() diff --git a/core/applets/obex/obeximpl.h b/core/applets/obex/obeximpl.h index 4e5109f..8d10cf1 100644 --- a/core/applets/obex/obeximpl.h +++ b/core/applets/obex/obeximpl.h @@ -24,4 +24,5 @@ namespace OpieObex { ObexDlg *m_sendgui; ObexInc *m_recvgui; + QString m_name; private slots: void slotCancelSend(); @@ -30,6 +31,7 @@ namespace OpieObex { // void slotCurrentTry( unsigned int ); */ void slotDone(bool); - //void slotReceivedFile(const QString & ); + void slotReceivedFile(const QString & ); void slotSent(); + }; }; |