You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
126 lines
3.4 KiB
126 lines
3.4 KiB
/* This file is part of the KDE project
|
|
|
|
Copyright 2002 Ariya Hidayat <ariya@kde.org>
|
|
Copyright 2001 Laurent Montel <montel@kde.org>
|
|
Copyright 2001 Philipp Mueller <philipp.mueller@gmx.de>
|
|
Copyright 2000 Werner Trobin <trobin@kde.org>
|
|
Copyright 1999-2000 Torben Weis <weis@kde.org>
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Library General Public
|
|
License as published by the Free Software Foundation; either
|
|
version 2 of the License, or (at your option) any later version.
|
|
|
|
This library is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Library General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Library General Public License
|
|
along with this library; see the file COPYING.LIB. If not, write to
|
|
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
* Boston, MA 02110-1301, USA.
|
|
*/
|
|
|
|
#include <dcopclient.h>
|
|
#include <kapplication.h>
|
|
#include <kdebug.h>
|
|
|
|
#include "kspread_doc.h"
|
|
#include "kspread_map.h"
|
|
#include "kspread_sheet.h"
|
|
|
|
#include "KSpreadMapIface.h"
|
|
|
|
using namespace KSpread;
|
|
|
|
MapIface::MapIface( Map* map )
|
|
: DCOPObject( map )
|
|
{
|
|
m_map = map;
|
|
}
|
|
|
|
DCOPRef MapIface::sheet( const TQString& name )
|
|
{
|
|
Sheet* t = m_map->findSheet( name );
|
|
if ( !t )
|
|
return DCOPRef();
|
|
|
|
return DCOPRef( kapp->dcopClient()->appId(), t->dcopObject()->objId() );
|
|
}
|
|
|
|
DCOPRef MapIface::sheetByIndex( int index )
|
|
{
|
|
Sheet* t = m_map->sheetList().at( index );
|
|
if ( !t )
|
|
{
|
|
kdDebug(36001) << "+++++ No table found at index " << index << endl;
|
|
return DCOPRef();
|
|
}
|
|
|
|
kdDebug(36001) << "+++++++ Returning table " << t->TQObject::name() << endl;
|
|
|
|
return DCOPRef( kapp->dcopClient()->appId(), t->dcopObject()->objId() );
|
|
}
|
|
|
|
int MapIface::sheetCount() const
|
|
{
|
|
return m_map->count();
|
|
}
|
|
|
|
TQStringList MapIface::sheetNames() const
|
|
{
|
|
TQStringList names;
|
|
|
|
TQPtrList<Sheet>& lst = m_map->sheetList();
|
|
TQPtrListIterator<Sheet> it( lst );
|
|
for( ; it.current(); ++it )
|
|
names.append( it.current()->name() );
|
|
|
|
return names;
|
|
}
|
|
|
|
TQValueList<DCOPRef> MapIface::sheets()
|
|
{
|
|
TQValueList<DCOPRef> t;
|
|
|
|
TQPtrList<Sheet>& lst = m_map->sheetList();
|
|
TQPtrListIterator<Sheet> it( lst );
|
|
for( ; it.current(); ++it )
|
|
t.append( DCOPRef( kapp->dcopClient()->appId(), it.current()->dcopObject()->objId() ) );
|
|
|
|
return t;
|
|
}
|
|
|
|
DCOPRef MapIface::insertSheet( const TQString& name )
|
|
{
|
|
if ( m_map->findSheet( name ) )
|
|
return sheet( name );
|
|
|
|
Sheet* t = m_map->addNewSheet ();
|
|
t->setSheetName( name );
|
|
|
|
return sheet( name );
|
|
}
|
|
|
|
bool MapIface::processDynamic(const TQCString &fun, const TQByteArray &/*data*/,
|
|
TQCString& replyType, TQByteArray &replyData)
|
|
{
|
|
// Does the name follow the pattern "foobar()" ?
|
|
uint len = fun.length();
|
|
if ( len < 3 )
|
|
return false;
|
|
|
|
if ( fun[ len - 1 ] != ')' || fun[ len - 2 ] != '(' )
|
|
return false;
|
|
|
|
Sheet* t = m_map->findSheet( fun.left( len - 2 ).data() );
|
|
if ( !t )
|
|
return false;
|
|
|
|
replyType = "DCOPRef";
|
|
TQDataStream out( replyData, IO_WriteOnly );
|
|
out << DCOPRef( kapp->dcopClient()->appId(), t->dcopObject()->objId() );
|
|
return true;
|
|
}
|