2007-12-07 09:55:43 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2008-04-11 00:06:56 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
2007-12-07 09:55:43 +00:00
|
|
|
*
|
2010-02-12 15:01:35 +01:00
|
|
|
* Copyright 2000, 2010 Oracle and/or its affiliates.
|
2007-12-07 09:55:43 +00:00
|
|
|
*
|
2008-04-11 00:06:56 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2007-12-07 09:55:43 +00:00
|
|
|
*
|
2008-04-11 00:06:56 +00:00
|
|
|
* This file is part of OpenOffice.org.
|
2007-12-07 09:55:43 +00:00
|
|
|
*
|
2008-04-11 00:06:56 +00:00
|
|
|
* OpenOffice.org is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Lesser General Public License version 3
|
|
|
|
* only, as published by the Free Software Foundation.
|
2007-12-07 09:55:43 +00:00
|
|
|
*
|
2008-04-11 00:06:56 +00:00
|
|
|
* OpenOffice.org 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 version 3 for more details
|
|
|
|
* (a copy is included in the LICENSE file that accompanied this code).
|
2007-12-07 09:55:43 +00:00
|
|
|
*
|
2008-04-11 00:06:56 +00:00
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* version 3 along with OpenOffice.org. If not, see
|
|
|
|
* <http://www.openoffice.org/license.html>
|
|
|
|
* for a copy of the LGPLv3 License.
|
2007-12-07 09:55:43 +00:00
|
|
|
*
|
|
|
|
************************************************************************/
|
2009-09-18 15:24:22 +00:00
|
|
|
#include <vbahelper/helperdecl.hxx>
|
2007-12-07 09:55:43 +00:00
|
|
|
|
|
|
|
#include <com/sun/star/table/XCellRange.hpp>
|
|
|
|
#include <com/sun/star/sheet/XCellRangeAddressable.hpp>
|
2009-02-13 13:03:24 +00:00
|
|
|
#include <com/sun/star/sheet/XCellRangeReferrer.hpp>
|
2007-12-07 09:55:43 +00:00
|
|
|
|
|
|
|
#include "vbaname.hxx"
|
|
|
|
#include "vbarange.hxx"
|
|
|
|
#include "vbaglobals.hxx"
|
|
|
|
#include <vector>
|
|
|
|
#include <rangenam.hxx>
|
|
|
|
#include <vcl/msgbox.hxx>
|
|
|
|
#include "tabvwsh.hxx"
|
|
|
|
#include "viewdata.hxx"
|
|
|
|
|
2009-02-13 13:03:24 +00:00
|
|
|
using namespace ::ooo::vba;
|
2007-12-07 09:55:43 +00:00
|
|
|
using namespace ::com::sun::star;
|
|
|
|
|
2009-02-13 13:03:24 +00:00
|
|
|
ScVbaName::ScVbaName(const css::uno::Reference< ov::XHelperInterface >& xParent,
|
2007-12-07 09:55:43 +00:00
|
|
|
const css::uno::Reference< css::uno::XComponentContext >& xContext,
|
|
|
|
const css::uno::Reference< css::sheet::XNamedRange >& xName,
|
|
|
|
const css::uno::Reference< css::sheet::XNamedRanges >& xNames,
|
|
|
|
const css::uno::Reference< css::frame::XModel >& xModel ):
|
|
|
|
NameImpl_BASE( xParent , xContext ),
|
|
|
|
mxModel( xModel ),
|
|
|
|
mxNamedRange( xName ),
|
|
|
|
mxNames( xNames )
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
ScVbaName::~ScVbaName()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2009-02-13 13:03:24 +00:00
|
|
|
css::uno::Reference< ov::excel::XWorksheet >
|
2007-12-07 09:55:43 +00:00
|
|
|
ScVbaName::getWorkSheet() throw (css::uno::RuntimeException)
|
|
|
|
{
|
2009-09-18 15:24:22 +00:00
|
|
|
uno::Reference< excel::XApplication > xApplication( Application(), uno::UNO_QUERY_THROW );
|
|
|
|
return xApplication->getActiveSheet();
|
2007-12-07 09:55:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
::rtl::OUString
|
|
|
|
ScVbaName::getName() throw (css::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
String sName;
|
|
|
|
sName += UniString( getWorkSheet()->getName());
|
|
|
|
sName += String::CreateFromAscii("!");
|
|
|
|
sName += UniString ( mxNamedRange->getName() );
|
|
|
|
return ::rtl::OUString( sName );
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
ScVbaName::setName( const ::rtl::OUString & rName ) throw (css::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
mxNamedRange->setName( rName );
|
|
|
|
}
|
|
|
|
|
|
|
|
::rtl::OUString
|
|
|
|
ScVbaName::getNameLocal() throw (css::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
return getName();
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
ScVbaName::setNameLocal( const ::rtl::OUString & rName ) throw (css::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
setName( rName );
|
|
|
|
}
|
|
|
|
|
|
|
|
sal_Bool
|
|
|
|
ScVbaName::getVisible() throw (css::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
ScVbaName::setVisible( sal_Bool /*bVisible*/ ) throw (css::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
::rtl::OUString
|
|
|
|
ScVbaName::getValue() throw (css::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString sValue = mxNamedRange->getContent();
|
|
|
|
::rtl::OUString sSheetName = getWorkSheet()->getName();
|
2009-02-13 13:03:24 +00:00
|
|
|
::rtl::OUString sSegmentation = ::rtl::OUString::createFromAscii( ";" );
|
|
|
|
::rtl::OUString sNewSegmentation = ::rtl::OUString::createFromAscii( "," );
|
|
|
|
::rtl::OUString sResult;
|
|
|
|
sal_Int32 nFrom = 0;
|
|
|
|
sal_Int32 nTo = 0;
|
|
|
|
nTo = sValue.indexOf( sSegmentation, nFrom );
|
|
|
|
while ( nTo != -1 )
|
2007-12-07 09:55:43 +00:00
|
|
|
{
|
2009-02-13 13:03:24 +00:00
|
|
|
::rtl::OUString sTmpValue = sValue.copy( nFrom, nTo - nFrom );
|
|
|
|
if ( sTmpValue.toChar() == '$' )
|
|
|
|
{
|
|
|
|
::rtl::OUString sTmp = sTmpValue.copy( 1 );
|
|
|
|
sTmp = sTmp.replaceAt(0, (sSheetName + ::rtl::OUString::createFromAscii(".")).getLength(), sSheetName + ::rtl::OUString::createFromAscii("!"));
|
|
|
|
sResult += sTmp;
|
|
|
|
sResult += sNewSegmentation;
|
|
|
|
}
|
|
|
|
nFrom = nTo + 1;
|
|
|
|
nTo = sValue.indexOf( sSegmentation, nFrom );
|
|
|
|
}
|
|
|
|
::rtl::OUString sTmpValue = sValue.copy( nFrom );
|
|
|
|
if ( sTmpValue.toChar() == '$' )
|
|
|
|
{
|
|
|
|
::rtl::OUString sTmp = sTmpValue.copy(1);
|
|
|
|
sTmp = sTmp.replaceAt(0, (sSheetName + ::rtl::OUString::createFromAscii(".")).getLength(), sSheetName + ::rtl::OUString::createFromAscii("!"));
|
|
|
|
sResult += sTmp;
|
2007-12-07 09:55:43 +00:00
|
|
|
}
|
2009-02-13 13:03:24 +00:00
|
|
|
if (sResult.indexOf('=') != 0)
|
2007-12-07 09:55:43 +00:00
|
|
|
{
|
2009-02-13 13:03:24 +00:00
|
|
|
sResult = ::rtl::OUString::createFromAscii("=") + sResult;
|
2007-12-07 09:55:43 +00:00
|
|
|
}
|
2009-02-13 13:03:24 +00:00
|
|
|
return sResult;
|
2007-12-07 09:55:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
ScVbaName::setValue( const ::rtl::OUString & rValue ) throw (css::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
::rtl::OUString sSheetName = getWorkSheet()->getName();
|
|
|
|
::rtl::OUString sValue = rValue;
|
2009-02-13 13:03:24 +00:00
|
|
|
::rtl::OUString sSegmentation = ::rtl::OUString::createFromAscii( "," );
|
|
|
|
::rtl::OUString sNewSegmentation = ::rtl::OUString::createFromAscii( ";" );
|
|
|
|
::rtl::OUString sResult;
|
|
|
|
sal_Int32 nFrom = 0;
|
|
|
|
sal_Int32 nTo = 0;
|
2007-12-07 09:55:43 +00:00
|
|
|
if (sValue.indexOf('=') == 0)
|
|
|
|
{
|
|
|
|
::rtl::OUString sTmp = sValue.copy(1);
|
|
|
|
sValue = sTmp;
|
|
|
|
}
|
2009-02-13 13:03:24 +00:00
|
|
|
nTo = sValue.indexOf( sSegmentation, nFrom );
|
|
|
|
while ( nTo != -1 )
|
|
|
|
{
|
|
|
|
::rtl::OUString sTmpValue = sValue.copy( nFrom, nTo - nFrom );
|
|
|
|
sTmpValue = sTmpValue.replaceAt(0, (sSheetName + ::rtl::OUString::createFromAscii("!")).getLength(), sSheetName + ::rtl::OUString::createFromAscii("."));
|
|
|
|
if (sTmpValue.copy(0, sSheetName.getLength()).equals(sSheetName))
|
|
|
|
{
|
|
|
|
sTmpValue = ::rtl::OUString::createFromAscii("$") + sTmpValue;
|
|
|
|
}
|
|
|
|
sTmpValue += sNewSegmentation;
|
|
|
|
sResult += sTmpValue;
|
|
|
|
nFrom = nTo + 1;
|
|
|
|
nTo = sValue.indexOf( sSegmentation, nFrom );
|
|
|
|
}
|
|
|
|
::rtl::OUString sTmpValue = sValue.copy( nFrom );
|
|
|
|
sTmpValue = sTmpValue.replaceAt(0, (sSheetName + ::rtl::OUString::createFromAscii("!")).getLength(), sSheetName + ::rtl::OUString::createFromAscii("."));
|
|
|
|
if (sTmpValue.copy(0, sSheetName.getLength()).equals(sSheetName))
|
2007-12-07 09:55:43 +00:00
|
|
|
{
|
2009-02-13 13:03:24 +00:00
|
|
|
sTmpValue = ::rtl::OUString::createFromAscii("$") + sTmpValue;
|
2007-12-07 09:55:43 +00:00
|
|
|
}
|
2009-02-13 13:03:24 +00:00
|
|
|
sResult += sTmpValue;
|
|
|
|
mxNamedRange->setContent(sResult);
|
2007-12-07 09:55:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
::rtl::OUString
|
|
|
|
ScVbaName::getRefersTo() throw (css::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
return getValue();
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
ScVbaName::setRefersTo( const ::rtl::OUString & rRefersTo ) throw (css::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
setValue( rRefersTo );
|
|
|
|
}
|
|
|
|
|
|
|
|
::rtl::OUString
|
|
|
|
ScVbaName::getRefersToLocal() throw (css::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
return getRefersTo();
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
ScVbaName::setRefersToLocal( const ::rtl::OUString & rRefersTo ) throw (css::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
setRefersTo( rRefersTo );
|
|
|
|
}
|
|
|
|
|
|
|
|
::rtl::OUString
|
|
|
|
ScVbaName::getRefersToR1C1() throw (css::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
return getRefersTo();
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
ScVbaName::setRefersToR1C1( const ::rtl::OUString & rRefersTo ) throw (css::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
setRefersTo( rRefersTo );
|
|
|
|
}
|
|
|
|
|
|
|
|
::rtl::OUString
|
|
|
|
ScVbaName::getRefersToR1C1Local() throw (css::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
return getRefersTo();
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
ScVbaName::setRefersToR1C1Local( const ::rtl::OUString & rRefersTo ) throw (css::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
setRefersTo( rRefersTo );
|
|
|
|
}
|
|
|
|
|
2009-02-13 13:03:24 +00:00
|
|
|
css::uno::Reference< ov::excel::XRange >
|
2007-12-07 09:55:43 +00:00
|
|
|
ScVbaName::getRefersToRange() throw (css::uno::RuntimeException)
|
|
|
|
{
|
2009-09-18 15:24:22 +00:00
|
|
|
uno::Reference< ov::excel::XRange > xRange = ScVbaRange::getRangeObjectForName( mxContext, mxNamedRange->getName(), excel::getDocShell( mxModel ), formula::FormulaGrammar::CONV_XL_R1C1 );
|
2007-12-07 09:55:43 +00:00
|
|
|
return xRange;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2009-02-13 13:03:24 +00:00
|
|
|
ScVbaName::setRefersToRange( const css::uno::Reference< ov::excel::XRange > /*rRange*/ ) throw (css::uno::RuntimeException)
|
2007-12-07 09:55:43 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
ScVbaName::Delete() throw (css::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
mxNames->removeByName( mxNamedRange->getName() );
|
|
|
|
}
|
|
|
|
|
|
|
|
rtl::OUString&
|
|
|
|
ScVbaName::getServiceImplName()
|
|
|
|
{
|
|
|
|
static rtl::OUString sImplName( RTL_CONSTASCII_USTRINGPARAM("ScVbaName") );
|
|
|
|
return sImplName;
|
|
|
|
}
|
|
|
|
|
|
|
|
uno::Sequence< rtl::OUString >
|
|
|
|
ScVbaName::getServiceNames()
|
|
|
|
{
|
|
|
|
static uno::Sequence< rtl::OUString > aServiceNames;
|
|
|
|
if ( aServiceNames.getLength() == 0 )
|
|
|
|
{
|
|
|
|
aServiceNames.realloc( 1 );
|
2009-02-13 13:03:24 +00:00
|
|
|
aServiceNames[ 0 ] = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("ooo.vba.excel.Name" ) );
|
2007-12-07 09:55:43 +00:00
|
|
|
}
|
|
|
|
return aServiceNames;
|
|
|
|
}
|
|
|
|
|