Files
libreoffice/sc/source/ui/view/viewfun5.cxx

615 lines
22 KiB
C++
Raw Normal View History

2000-09-18 16:07:07 +00:00
/*************************************************************************
*
* $RCSfile: viewfun5.cxx,v $
*
* $Revision: 1.11 $
2000-09-18 16:07:07 +00:00
*
* last change: $Author: fs $ $Date: 2001-08-09 09:47:41 $
2000-09-18 16:07:07 +00:00
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
*
* - GNU Lesser General Public License Version 2.1
* - Sun Industry Standards Source License Version 1.1
*
* Sun Microsystems Inc., October, 2000
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2000 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
*
* Sun Industry Standards Source License Version 1.1
* =================================================
* The contents of this file are subject to the Sun Industry Standards
* Source License Version 1.1 (the "License"); You may not use this file
* except in compliance with the License. You may obtain a copy of the
* License at http://www.openoffice.org/license.html.
*
* Software provided under this License is provided on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
* See the License for the specific provisions governing your rights and
* obligations concerning the Software.
*
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
*
* Copyright: 2000 by Sun Microsystems, Inc.
*
* All Rights Reserved.
*
* Contributor(s): _______________________________________
*
*
************************************************************************/
#ifdef PCH
#include "ui_pch.hxx"
#endif
#pragma hdrstop
//------------------------------------------------------------------
#include <svx/dbexch.hrc>
#include <svx/fmmodel.hxx>
#include <svx/svdetc.hxx>
#include <svx/svditer.hxx>
#include <svx/svdobj.hxx>
#include <svx/svdogrp.hxx>
#include <svx/svdouno.hxx>
#include <svx/svdpage.hxx>
#include <sfx2/dispatch.hxx>
#include <sfx2/docfile.hxx>
#include <so3/ipobj.hxx>
#include <so3/svstor.hxx>
#include <offmgr/app.hxx>
#include <so3/clsids.hxx>
#include <sot/formats.hxx>
2000-09-29 09:21:10 +00:00
#include <svtools/pathoptions.hxx>
2000-09-18 16:07:07 +00:00
#include <svtools/ptitem.hxx>
#include <svtools/stritem.hxx>
2001-02-14 18:30:56 +00:00
#include <svtools/transfer.hxx>
2000-09-18 16:07:07 +00:00
#include <vcl/graph.hxx>
#include <sot/formats.hxx>
#define SOT_FORMATSTR_ID_STARCALC_CURRENT SOT_FORMATSTR_ID_STARCALC_50
#ifndef SO2_DECL_SVINPLACEOBJECT_DEFINED
#define SO2_DECL_SVINPLACEOBJECT_DEFINED
SO2_DECL_REF(SvInPlaceObject)
#endif
#ifndef SO2_DECL_SVSTORAGE_DEFINED
#define SO2_DECL_SVSTORAGE_DEFINED
SO2_DECL_REF(SvStorage)
#endif
#include "viewfunc.hxx"
#include "docsh.hxx"
#include "drawview.hxx"
#include "impex.hxx"
#include "dbfunc.hxx"
#include "dbcolect.hxx"
#include "sc.hrc"
#include "filter.hxx"
#include "scextopt.hxx"
#include "tabvwsh.hxx" // wegen GetViewFrame
#include "compiler.hxx"
#ifndef _SFXVIEWFRM_HXX //autogen
#include <sfx2/viewfrm.hxx>
#endif
#ifndef _SVX_DBAEXCHANGE_HXX_
#include <svx/dbaexchange.hxx>
#endif
2000-09-18 16:07:07 +00:00
2001-02-14 18:30:56 +00:00
using namespace com::sun::star;
2000-09-18 16:07:07 +00:00
2001-02-14 18:30:56 +00:00
//------------------------------------------------------------------
BOOL ScViewFunc::PasteDataFormat( ULONG nFormatId,
const uno::Reference<datatransfer::XTransferable>& rxTransferable,
USHORT nPosX, USHORT nPosY, Point* pLogicPos )
{
Point aPos; // inserting position (1/100 mm)
if (pLogicPos)
aPos = *pLogicPos;
else
{
// inserting position isn't needed for text formats
BOOL bIsTextFormat = ( ScImportExport::IsFormatSupported( nFormatId ) ||
nFormatId == FORMAT_RTF );
if ( !bIsTextFormat )
{
// Window MapMode isn't drawing MapMode if DrawingLayer hasn't been created yet
ScDocument* pDoc = GetViewData()->GetDocument();
USHORT nTab = GetViewData()->GetTabNo();
USHORT i;
long nXT = 0;
for (i=0; i<nPosX; i++)
nXT += pDoc->GetColWidth(i,nTab);
long nYT = 0;
for (i=0; i<nPosY; i++)
nYT += pDoc->FastGetRowHeight(i,nTab);
aPos = Point( (long)(nXT * HMM_PER_TWIPS), (long)(nYT * HMM_PER_TWIPS) );
}
}
TransferableDataHelper aDataHelper( rxTransferable );
BOOL bRet = FALSE;
//
// handle individual formats
//
if ( nFormatId == SOT_FORMATSTR_ID_EMBED_SOURCE ||
nFormatId == SOT_FORMATSTR_ID_LINK_SOURCE ||
nFormatId == SOT_FORMATSTR_ID_EMBED_SOURCE_OLE ||
nFormatId == SOT_FORMATSTR_ID_LINK_SOURCE_OLE )
{
SotStorageStreamRef xStm;
TransferableObjectDescriptor aObjDesc;
if( aDataHelper.GetTransferableObjectDescriptor( SOT_FORMATSTR_ID_OBJECTDESCRIPTOR, aObjDesc ) &&
aDataHelper.GetSotStorageStream( nFormatId, xStm ) )
{
SvStorageRef xStore( new SvStorage( *xStm ) );
if ( aObjDesc.maClassName == SvGlobalName( SO3_SC_CLASSID_30 ) ||
aObjDesc.maClassName == SvGlobalName( SO3_SC_CLASSID_40 ) ||
aObjDesc.maClassName == SvGlobalName( SO3_SC_CLASSID_50 ) ||
aObjDesc.maClassName == SvGlobalName( SO3_SC_CLASSID_60 ) )
2001-02-14 18:30:56 +00:00
{
// own format (including old formats)
2001-02-14 18:30:56 +00:00
ScDocShellRef xDocShRef = new ScDocShell(SFX_CREATE_MODE_EMBEDDED);
if (xDocShRef->DoLoad(xStore))
{
ScDocument* pSrcDoc = xDocShRef->GetDocument();
USHORT nSrcTab = pSrcDoc->GetVisibleTab();
if (!pSrcDoc->HasTable(nSrcTab))
nSrcTab = 0;
ScMarkData aSrcMark;
aSrcMark.SelectOneTable( nSrcTab ); // for CopyToClip
ScDocument* pClipDoc = new ScDocument( SCDOCMODE_CLIP );
USHORT nFirstCol, nFirstRow, nLastCol, nLastRow;
2001-03-23 18:26:39 +00:00
if ( pSrcDoc->GetDataStart( nSrcTab, nFirstCol, nFirstRow ) )
pSrcDoc->GetCellArea( nSrcTab, nLastCol, nLastRow );
else
nFirstCol = nFirstRow = nLastCol = nLastRow = 0;
2001-02-14 18:30:56 +00:00
pSrcDoc->CopyToClip( nFirstCol, nFirstRow, nLastCol, nLastRow,
FALSE, pClipDoc, FALSE, &aSrcMark );
ScGlobal::SetClipDocName( xDocShRef->GetTitle( SFX_TITLE_FULLNAME ) );
SetCursor( nPosX, nPosY );
Unmark();
PasteFromClip( IDF_ALL, pClipDoc );
delete pClipDoc;
bRet = TRUE;
}
((SfxInPlaceObject*)xDocShRef)->DoClose();
xDocShRef.Clear();
}
else
{
SvInPlaceObjectRef xIPObj = &( (SvFactory*) SvInPlaceObject::ClassFactory() )->CreateAndLoad( xStore );
if ( xIPObj.Is() )
{
PasteObject( aPos, xIPObj, &aObjDesc.maSize );
bRet = TRUE;
}
else
DBG_ERROR("Error in CreateAndLoad");
}
}
}
else if ( nFormatId == SOT_FORMATSTR_ID_LINK ) // LINK is also in ScImportExport
{
bRet = PasteDDE( rxTransferable );
}
else if ( ScImportExport::IsFormatSupported( nFormatId ) || nFormatId == SOT_FORMAT_RTF )
{
if ( nFormatId == SOT_FORMAT_RTF && aDataHelper.HasFormat( SOT_FORMATSTR_ID_EDITENGINE ) )
{
2001-03-30 18:14:44 +00:00
// use EditView's PasteSpecial / Drop
PasteRTF( nPosX, nPosY, rxTransferable );
bRet = TRUE;
2001-02-14 18:30:56 +00:00
}
2001-03-30 18:14:44 +00:00
else
{
ScAddress aPos( nPosX, nPosY, GetViewData()->GetTabNo() );
ScImportExport aObj( GetViewData()->GetDocument(), aPos );
2001-02-14 18:30:56 +00:00
2001-03-30 18:14:44 +00:00
String aStr;
SotStorageStreamRef xStream;
if ( aDataHelper.GetSotStorageStream( nFormatId, xStream ) && xStream.Is() )
bRet = aObj.ImportStream( *xStream, nFormatId );
else if ( aDataHelper.GetString( nFormatId, aStr ) )
bRet = aObj.ImportString( aStr, nFormatId );
2001-02-14 18:30:56 +00:00
2001-03-30 18:14:44 +00:00
InvalidateAttribs();
GetViewData()->UpdateInputHandler();
}
2001-02-14 18:30:56 +00:00
}
else if (nFormatId == SOT_FORMATSTR_ID_SBA_DATAEXCHANGE)
{
// import of database data into table
String sDataDesc;
if ( aDataHelper.GetString( nFormatId, sDataDesc ) )
{
SfxStringItem aDataDesc(SID_SBA_IMPORT, sDataDesc);
2000-09-18 16:07:07 +00:00
2001-02-14 18:30:56 +00:00
ScDocShell* pDocSh = GetViewData()->GetDocShell();
ScDocument* pDoc = pDocSh->GetDocument();
USHORT nTab = GetViewData()->GetTabNo();
ClickCursor(nPosX, nPosY, FALSE); // set cursor position
// Creation of database area "Import1" isn't here, but in the DocShell
// slot execute, so it can be added to the undo action
ScDBData* pDBData = pDocSh->GetDBData( ScRange(nPosX,nPosY,nTab), SC_DB_OLD, FALSE );
String sTarget;
if (pDBData)
sTarget = pDBData->GetName();
else
{
ScAddress aPos( nPosX,nPosY,nTab );
aPos.Format( sTarget, SCA_ABS_3D, pDoc );
}
SfxStringItem aTarget(FN_PARAM_1, sTarget);
BOOL bAreaIsNew = !pDBData;
SfxBoolItem aAreaNew(FN_PARAM_2, bAreaIsNew);
// asynchronous, to avoid doing the whole import in drop handler
SfxDispatcher& rDisp = GetViewData()->GetDispatcher();
rDisp.Execute(SID_SBA_IMPORT, SFX_CALLMODE_ASYNCHRON,
&aDataDesc, &aTarget, &aAreaNew, 0L );
bRet = TRUE;
}
}
else if (nFormatId == SOT_FORMATSTR_ID_SBA_FIELDDATAEXCHANGE)
{
// insert database field control
if ( ::svx::OColumnTransferable::canExtractColumnDescriptor( aDataHelper.GetDataFlavorExVector(), CTF_COLUMN_DESCRIPTOR ) )
2001-02-14 18:30:56 +00:00
{
MakeDrawLayer();
ScDrawView* pDrawView = GetScDrawView();
SdrObject* pObj = pDrawView->CreateFieldControl( ::svx::OColumnTransferable::extractColumnDescriptor( aDataHelper ) );
2001-02-14 18:30:56 +00:00
if (pObj)
{
Point aInsPos = aPos;
Rectangle aRect(pObj->GetLogicRect());
aInsPos.X() -= aRect.GetSize().Width() / 2;
aInsPos.Y() -= aRect.GetSize().Height() / 2;
if ( aInsPos.X() < 0 ) aInsPos.X() = 0;
if ( aInsPos.Y() < 0 ) aInsPos.Y() = 0;
aRect.SetPos(aInsPos);
pObj->SetLogicRect(aRect);
if ( pObj->ISA(SdrUnoObj) )
pObj->NbcSetLayer(SC_LAYER_CONTROLS);
else
pObj->NbcSetLayer(SC_LAYER_FRONT);
if (pObj->ISA(SdrObjGroup))
{
SdrObjListIter aIter( *pObj, IM_DEEPWITHGROUPS );
SdrObject* pSubObj = aIter.Next();
while (pSubObj)
{
if ( pSubObj->ISA(SdrUnoObj) )
pSubObj->NbcSetLayer(SC_LAYER_CONTROLS);
else
pSubObj->NbcSetLayer(SC_LAYER_FRONT);
pSubObj = aIter.Next();
}
}
pDrawView->InsertObjectSafe(pObj, *pDrawView->GetPageViewPvNum(0));
GetViewData()->GetViewShell()->SetDrawShell( TRUE );
bRet = TRUE;
}
}
}
else if (nFormatId == SOT_FORMAT_BITMAP)
{
Bitmap aBmp;
if( aDataHelper.GetBitmap( FORMAT_BITMAP, aBmp ) )
bRet = PasteBitmap( aPos, aBmp );
}
else if (nFormatId == SOT_FORMAT_GDIMETAFILE)
{
GDIMetaFile aMtf;
if( aDataHelper.GetGDIMetaFile( FORMAT_GDIMETAFILE, aMtf ) )
bRet = PasteMetaFile( aPos, aMtf );
}
else if (nFormatId == SOT_FORMATSTR_ID_SVXB)
{
SotStorageStreamRef xStm;
if( aDataHelper.GetSotStorageStream( SOT_FORMATSTR_ID_SVXB, xStm ) )
{
Graphic aGraphic;
*xStm >> aGraphic;
bRet = PasteGraphic( aPos, aGraphic, EMPTY_STRING, EMPTY_STRING );
}
}
else if ( nFormatId == SOT_FORMATSTR_ID_DRAWING )
{
SotStorageStreamRef xStm;
if( aDataHelper.GetSotStorageStream( SOT_FORMATSTR_ID_DRAWING, xStm ) )
{
MakeDrawLayer(); // before loading model, so 3D factory has been created
SvtPathOptions aPathOpt;
String aPath = aPathOpt.GetPalettePath();
FmFormModel* pModel = new FmFormModel(
aPath, NULL, GetViewData()->GetDocShell() );
pModel->GetItemPool().FreezeIdRanges();
xStm->Seek(0);
// SdrModel stream operator doesn't support XML
//! call XML export here!
xStm->SetVersion(SOFFICE_FILEFORMAT_50);
pModel->SetStreamingSdrModel(TRUE);
pModel->GetItemPool().Load(*xStm);
*xStm >> *pModel;
pModel->SetStreamingSdrModel(FALSE);
// set everything to right layer:
ULONG nObjCount = 0;
USHORT nPages = pModel->GetPageCount();
for (USHORT i=0; i<nPages; i++)
{
SdrPage* pPage = pModel->GetPage(i);
SdrObjListIter aIter( *pPage, IM_DEEPWITHGROUPS );
SdrObject* pObject = aIter.Next();
while (pObject)
{
++nObjCount;
if ( pObject->ISA(SdrUnoObj) )
pObject->NbcSetLayer(SC_LAYER_CONTROLS);
else
pObject->NbcSetLayer(SC_LAYER_FRONT);
pObject = aIter.Next();
}
}
PasteDraw( aPos, pModel, (nObjCount > 1) ); // grouped if more than 1 object
delete pModel;
bRet = TRUE;
}
}
else if ( nFormatId == SOT_FORMATSTR_ID_BIFF_5 )
{
// do excel import into a clipboard document
SotStorageStreamRef xStm;
if( aDataHelper.GetSotStorageStream( SOT_FORMATSTR_ID_BIFF_5, xStm ) )
{
SvStorageRef pStor = new SvStorage( *xStm );
#if 0
SvStorage aDest( "d:\\test.xls" ); // to see the file
pStor->CopyTo( &aDest );
#endif
ScDocument* pDoc = GetViewData()->GetDocument();
ScDocument* pInsDoc = new ScDocument( SCDOCMODE_CLIP );
USHORT nSrcTab = 0; // Biff5 in clipboard: always sheet 0
pInsDoc->ResetClip( pDoc, nSrcTab );
SfxMedium aMed( pStor, TRUE );
FltError eErr = ScImportExcel( aMed, pInsDoc, EIF_AUTO );
if ( eErr == eERR_OK )
{
ScRange aSource;
const ScExtDocOptions* pExtOpt = pInsDoc->GetExtDocOptions();
const ScExtTabOptions* pTabOpt = pExtOpt ?
pExtOpt->GetExtTabOptions(nSrcTab) : NULL;
if ( pTabOpt && pTabOpt->bValidDim &&
pTabOpt->aDim.aEnd.Col() > pTabOpt->aDim.aStart.Col() &&
pTabOpt->aDim.aEnd.Row() > pTabOpt->aDim.aStart.Row() )
{
// "end" points behind the data area
aSource = ScRange(
pTabOpt->aDim.aStart.Col(), pTabOpt->aDim.aStart.Row(), nSrcTab,
pTabOpt->aDim.aEnd.Col()-1, pTabOpt->aDim.aEnd.Row()-1, nSrcTab );
// selection can be bigger than the used area
if ( pTabOpt->bValidSel )
{
if ( pTabOpt->aLastSel.aStart.Col() < aSource.aStart.Col() )
aSource.aStart.SetCol( pTabOpt->aLastSel.aStart.Col() );
if ( pTabOpt->aLastSel.aStart.Row() < aSource.aStart.Row() )
aSource.aStart.SetRow( pTabOpt->aLastSel.aStart.Row() );
// "end" in selection is really the end
if ( pTabOpt->aLastSel.aEnd.Col() > aSource.aEnd.Col() )
aSource.aEnd.SetCol( pTabOpt->aLastSel.aEnd.Col() );
if ( pTabOpt->aLastSel.aEnd.Row() > aSource.aEnd.Row() )
aSource.aEnd.SetRow( pTabOpt->aLastSel.aEnd.Row() );
}
}
else
{
DBG_ERROR("no dimension"); //! possible?
USHORT nFirstCol, nFirstRow, nLastCol, nLastRow;
2001-03-23 18:26:39 +00:00
if ( pInsDoc->GetDataStart( nSrcTab, nFirstCol, nFirstRow ) )
pInsDoc->GetCellArea( nSrcTab, nLastCol, nLastRow );
else
nFirstCol = nFirstRow = nLastCol = nLastRow = 0;
2001-02-14 18:30:56 +00:00
aSource = ScRange( nFirstCol, nFirstRow, nSrcTab,
nLastCol, nLastRow, nSrcTab );
}
if ( pLogicPos )
{
// position specified (Drag&Drop) - change selection
MoveCursorAbs( nPosX, nPosY, SC_FOLLOW_NONE, FALSE, FALSE );
Unmark();
}
pInsDoc->SetClipArea( aSource );
PasteFromClip(IDF_ALL, pInsDoc);
delete pInsDoc;
bRet = TRUE;
}
}
}
else if ( nFormatId == SOT_FORMAT_FILE )
{
2001-06-29 19:28:09 +00:00
//! multiple files?
//USHORT nCount = DragServer::GetItemCount();
//if (nCount == 0) // normal handling (not D&D)
2001-02-14 18:30:56 +00:00
{
String aFile;
if ( aDataHelper.GetString( nFormatId, aFile ) )
bRet = PasteFile( aPos, aFile );
}
2001-06-29 19:28:09 +00:00
#if 0
2001-02-14 18:30:56 +00:00
else // use multiple items from drag server
{
for( USHORT i = 0; i < nCount ; i++ )
{
String aFile = DragServer::PasteFile( i );
SfxStringItem aNameItem( FID_INSERT_FILE, aFile );
SfxPointItem aPosItem( FN_PARAM_1, aPos );
SfxDispatcher* pDisp =
GetViewData()->GetViewShell()->GetViewFrame()->GetDispatcher();
if (pDisp)
pDisp->Execute( FID_INSERT_FILE, SFX_CALLMODE_ASYNCHRON,
&aNameItem, &aPosItem, (void*)0 );
aPos.X() += 400;
aPos.Y() += 400;
}
bRet = TRUE;
}
2001-06-29 19:28:09 +00:00
#endif
2001-02-14 18:30:56 +00:00
}
2001-03-30 18:14:44 +00:00
else if ( nFormatId == SOT_FORMATSTR_ID_SOLK ||
nFormatId == SOT_FORMATSTR_ID_UNIFORMRESOURCELOCATOR ||
nFormatId == SOT_FORMATSTR_ID_NETSCAPE_BOOKMARK ||
nFormatId == SOT_FORMATSTR_ID_FILEGRPDESCRIPTOR )
{
bRet = PasteBookmark( nFormatId, rxTransferable, nPosX, nPosY );
}
2001-02-14 18:30:56 +00:00
return bRet;
}
String lcl_GetSubString( sal_Char* pData, long nStart, long nDataSize, rtl_TextEncoding eEncoding )
{
if ( nDataSize <= nStart /* || pData[nDataSize] != 0 */ )
{
DBG_ERROR("DDE Data: invalid data");
return String();
}
return String( pData + nStart, eEncoding );
}
BOOL ScViewFunc::PasteDDE( const uno::Reference<datatransfer::XTransferable>& rxTransferable )
{
TransferableDataHelper aDataHelper( rxTransferable );
// check size (only if string is available in transferable)
USHORT nCols = 1;
USHORT nRows = 1;
if ( aDataHelper.HasFormat( SOT_FORMAT_STRING ) )
{
String aDataStr;
if ( aDataHelper.GetString( SOT_FORMAT_STRING, aDataStr ) )
{
// get size from string the same way as in ScDdeLink::DataChanged
aDataStr.ConvertLineEnd(LINEEND_LF);
xub_StrLen nLen = aDataStr.Len();
if (nLen && aDataStr.GetChar(nLen-1) == '\n')
aDataStr.Erase(nLen-1);
if (aDataStr.Len())
{
nRows = aDataStr.GetTokenCount( '\n' );
String aLine = aDataStr.GetToken( 0, '\n' );
if (aLine.Len())
nCols = aLine.GetTokenCount( '\t' );
}
}
}
// create formula
uno::Sequence<sal_Int8> aSequence;
if ( !aDataHelper.GetSequence( SOT_FORMATSTR_ID_LINK, aSequence ) )
{
DBG_ERROR("DDE Data not found.");
return FALSE;
}
long nSeqLen = aSequence.getLength();
sal_Char* pData = (sal_Char*)aSequence.getConstArray();
rtl_TextEncoding eSysEnc = gsl_getSystemTextEncoding();
String aApp = lcl_GetSubString( pData, 0, nSeqLen, eSysEnc );
String aTopic = lcl_GetSubString( pData, aApp.Len() + 1, nSeqLen, eSysEnc );
String aItem = lcl_GetSubString( pData, aApp.Len() + aTopic.Len() + 2, nSeqLen, eSysEnc );
if (!ScCompiler::pSymbolTableNative)
{
DBG_ERROR("ScCompiler::pSymbolTableNative missing");
return FALSE;
}
//! use tokens
String aFormula( '=' );
aFormula += ScCompiler::pSymbolTableNative[SC_OPCODE_DDE];
aFormula.AppendAscii(RTL_CONSTASCII_STRINGPARAM("(\""));
aFormula += aApp;
aFormula.AppendAscii(RTL_CONSTASCII_STRINGPARAM("\";\""));
aFormula += aTopic;
aFormula.AppendAscii(RTL_CONSTASCII_STRINGPARAM("\";\""));
aFormula += aItem;
aFormula.AppendAscii(RTL_CONSTASCII_STRINGPARAM("\")"));
// mark range
USHORT nTab = GetViewData()->GetTabNo();
USHORT nCurX = GetViewData()->GetCurX();
USHORT nCurY = GetViewData()->GetCurY();
HideAllCursors();
DoneBlockMode();
InitBlockMode( nCurX, nCurY, nTab );
MarkCursor( nCurX+nCols-1, nCurY+nRows-1, nTab );
ShowAllCursors();
// enter formula
EnterMatrix( aFormula );
CursorPosChanged();
return TRUE;
}
2000-09-18 16:07:07 +00:00