summaryrefslogtreecommitdiff
path: root/sc/source/ui/collab
diff options
context:
space:
mode:
Diffstat (limited to 'sc/source/ui/collab')
-rw-r--r--sc/source/ui/collab/collab.cxx99
-rw-r--r--sc/source/ui/collab/sendfunc.cxx58
2 files changed, 153 insertions, 4 deletions
diff --git a/sc/source/ui/collab/collab.cxx b/sc/source/ui/collab/collab.cxx
new file mode 100644
index 000000000000..bc0c99e8a05e
--- /dev/null
+++ b/sc/source/ui/collab/collab.cxx
@@ -0,0 +1,99 @@
+/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
+/*
+ * Version: MPL 1.1 / GPLv3+ / LGPLv3+
+ *
+ * The contents of this file are subject to the Mozilla Public License Version
+ * 1.1 (the "License"); you may not use this file except in compliance with
+ * the License or as specified alternatively below. You may obtain a copy of
+ * the License at http://www.mozilla.org/MPL/
+ *
+ * Software distributed under the License is distributed on an "AS IS" basis,
+ * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
+ * for the specific language governing rights and limitations under the
+ * License.
+ *
+ * Major Contributor(s):
+ * Copyright (C) 2012 Red Hat, Inc., Eike Rathke <erack@redhat.com>
+ *
+ * All Rights Reserved.
+ *
+ * For minor contributions see the git repository.
+ *
+ * Alternatively, the contents of this file may be used under the terms of
+ * either the GNU General Public License Version 3 or later (the "GPLv3+"), or
+ * the GNU Lesser General Public License Version 3 or later (the "LGPLv3+"),
+ * in which case the provisions of the GPLv3+ or the LGPLv3+ are applicable
+ * instead of those above.
+ */
+
+#include "collab.hxx"
+#include <tubes/manager.hxx>
+#include <tubes/conference.hxx>
+#include <tubes/contact-list.hxx>
+
+ScCollaboration::ScCollaboration( const Link& rLink )
+ :
+ maLink( rLink),
+ mpAccount( NULL),
+ mpContact( NULL),
+ mpManager( NULL)
+{
+}
+
+
+ScCollaboration::~ScCollaboration()
+{
+ if (mpAccount)
+ g_object_unref( mpAccount);
+ if (mpContact)
+ g_object_unref( mpContact);
+ delete mpManager;
+}
+
+
+bool ScCollaboration::initManager()
+{
+ mpManager = new TeleManager( maLink);
+ bool bOk = mpManager->connect();
+ return bOk;
+}
+
+
+bool ScCollaboration::initAccountContact()
+{
+ ContactList aContacts;
+ AccountContactPairV aVec( aContacts.getContacts());
+ if (aVec.empty())
+ return false;
+
+ /* TODO: select a pair, for now just take the first */
+ mpAccount = aVec[0].first;
+ mpContact = aVec[0].second;
+ return true;
+}
+
+
+bool ScCollaboration::startCollaboration()
+{
+ bool bOk = mpManager->startBuddySession( mpAccount, mpContact);
+ return bOk;
+}
+
+
+bool ScCollaboration::sendPacket( const rtl::OString& rString )
+{
+ TelePacket aPacket( "sender", rString.getStr(), rString.getLength());
+ bool bOk = mpManager->sendPacket( aPacket);
+ return bOk;
+}
+
+
+bool ScCollaboration::recvPacket( rtl::OString& rString, TeleConference* pConference )
+{
+ TelePacket aPacket;
+ bool bOk = (pConference ? pConference->popPacket( aPacket) : mpManager->popPacket( aPacket));
+ rString = rtl::OString( aPacket.getData(), aPacket.getSize());
+ return bOk;
+}
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/sc/source/ui/collab/sendfunc.cxx b/sc/source/ui/collab/sendfunc.cxx
index 9d9a10c37297..ed089558ee25 100644
--- a/sc/source/ui/collab/sendfunc.cxx
+++ b/sc/source/ui/collab/sendfunc.cxx
@@ -33,6 +33,8 @@
#include "cell.hxx"
#include "docsh.hxx"
#include "docfunc.hxx"
+#include "collab.hxx"
+#include <tubes/conference.hxx>
// new file send/recv fun ...
#include <unotools/tempfile.hxx>
@@ -233,16 +235,25 @@ public:
class ScDocFuncRecv : public ScDocFunc
{
ScDocFunc *mpChain;
+ ScCollaboration* mpCollab;
public:
// FIXME: really ScDocFunc should be an abstract base
ScDocFuncRecv( ScDocShell& rDocSh, ScDocFunc *pChain )
: ScDocFunc( rDocSh ),
- mpChain( pChain )
+ mpChain( pChain ),
+ mpCollab( NULL)
{
fprintf( stderr, "Receiver created !\n" );
}
virtual ~ScDocFuncRecv() {}
+ void SetCollaboration( ScCollaboration* pCollab )
+ {
+ mpCollab = pCollab;
+ }
+
+ DECL_LINK( ReceiverCallback, TeleConference* );
+
void RecvMessage( const rtl::OString &rString )
{
try {
@@ -280,14 +291,26 @@ public:
}
};
+IMPL_LINK( ScDocFuncRecv, ReceiverCallback, TeleConference*, pConference )
+{
+ rtl::OString aStr;
+ if (mpCollab && mpCollab->recvPacket( aStr, pConference))
+ RecvMessage( aStr);
+ return 0;
+}
+
class ScDocFuncSend : public ScDocFunc
{
ScDocFuncRecv *mpChain;
+ ScCollaboration* mpCollab;
void SendMessage( ScChangeOpWriter &rOp )
{
fprintf( stderr, "Op: '%s'\n", rOp.toString().getStr() );
- mpChain->RecvMessage( rOp.toString() );
+ if (mpCollab)
+ mpCollab->sendPacket( rOp.toString());
+ else
+ mpChain->RecvMessage( rOp.toString() );
}
void SendFile( const rtl::OUString &rURL )
@@ -321,12 +344,18 @@ public:
// we don't need the rDocSh hack/pointer
ScDocFuncSend( ScDocShell& rDocSh, ScDocFuncRecv *pChain )
: ScDocFunc( rDocSh ),
- mpChain( pChain )
+ mpChain( pChain ),
+ mpCollab( NULL)
{
fprintf( stderr, "Sender created !\n" );
}
virtual ~ScDocFuncSend() {}
+ void SetCollaboration( ScCollaboration* pCollab )
+ {
+ mpCollab = pCollab;
+ }
+
virtual void EnterListAction( sal_uInt16 nNameResId )
{
// Want to group these operations for the other side ...
@@ -441,9 +470,30 @@ public:
SC_DLLPRIVATE ScDocFunc *ScDocShell::CreateDocFunc()
{
- // FIXME: the chains should be auto-ptrs.
+ // FIXME: the chains should be auto-ptrs, so should be collab
if (getenv ("INTERCEPT"))
return new ScDocFuncSend( *this, new ScDocFuncRecv( *this, new ScDocFuncDirect( *this ) ) );
+ else if (getenv ("LIBO_TUBES"))
+ {
+ ScDocFuncRecv* pReceiver = new ScDocFuncRecv( *this, new ScDocFuncDirect( *this ) );
+ ScDocFuncSend* pSender = new ScDocFuncSend( *this, pReceiver );
+ bool bOk = true;
+ ScCollaboration* pCollab = new ScCollaboration( LINK( pReceiver, ScDocFuncRecv, ReceiverCallback));
+ bOk = bOk && pCollab->initManager();
+ bOk = bOk && pCollab->initAccountContact();
+ bOk = bOk && pCollab->startCollaboration();
+ if (bOk)
+ {
+ pReceiver->SetCollaboration( pCollab);
+ pSender->SetCollaboration( pCollab);
+ }
+ else
+ {
+ fprintf( stderr, "Could not start collaboration.\n");
+ delete pCollab;
+ }
+ return pSender;
+ }
else
return new ScDocFuncDirect( *this );
}