xref: /aoo4110/main/sc/source/ui/vba/vbaglobals.cxx (revision b1cdbd2c)
1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski #include <vbahelper/helperdecl.hxx>
24*b1cdbd2cSJim Jagielski #include "vbaglobals.hxx"
25*b1cdbd2cSJim Jagielski 
26*b1cdbd2cSJim Jagielski #include <comphelper/unwrapargs.hxx>
27*b1cdbd2cSJim Jagielski 
28*b1cdbd2cSJim Jagielski #include <com/sun/star/lang/XMultiComponentFactory.hpp>
29*b1cdbd2cSJim Jagielski #include <com/sun/star/beans/XPropertySet.hpp>
30*b1cdbd2cSJim Jagielski #include <cppuhelper/component_context.hxx>
31*b1cdbd2cSJim Jagielski 
32*b1cdbd2cSJim Jagielski #include "vbaapplication.hxx"
33*b1cdbd2cSJim Jagielski #include "vbaworksheet.hxx"
34*b1cdbd2cSJim Jagielski #include "vbarange.hxx"
35*b1cdbd2cSJim Jagielski #include <cppuhelper/bootstrap.hxx>
36*b1cdbd2cSJim Jagielski using namespace ::com::sun::star;
37*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::uno;
38*b1cdbd2cSJim Jagielski using namespace ::ooo::vba;
39*b1cdbd2cSJim Jagielski 
40*b1cdbd2cSJim Jagielski 
41*b1cdbd2cSJim Jagielski 
42*b1cdbd2cSJim Jagielski // =============================================================================
43*b1cdbd2cSJim Jagielski // ScVbaGlobals
44*b1cdbd2cSJim Jagielski // =============================================================================
45*b1cdbd2cSJim Jagielski 
46*b1cdbd2cSJim Jagielski //ScVbaGlobals::ScVbaGlobals(  css::uno::Reference< css::uno::XComponentContext >const& rxContext,  ) : ScVbaGlobals_BASE( uno::Reference< XHelperInterface >(), rxContext )
47*b1cdbd2cSJim Jagielski rtl::OUString sDocCtxName( RTL_CONSTASCII_USTRINGPARAM("ExcelDocumentContext") );
48*b1cdbd2cSJim Jagielski 
ScVbaGlobals(uno::Sequence<uno::Any> const & aArgs,uno::Reference<uno::XComponentContext> const & rxContext)49*b1cdbd2cSJim Jagielski ScVbaGlobals::ScVbaGlobals( uno::Sequence< uno::Any > const& aArgs, uno::Reference< uno::XComponentContext >const& rxContext ) : ScVbaGlobals_BASE( uno::Reference< XHelperInterface >(), rxContext, sDocCtxName )
50*b1cdbd2cSJim Jagielski {
51*b1cdbd2cSJim Jagielski 	OSL_TRACE("ScVbaGlobals::ScVbaGlobals()");
52*b1cdbd2cSJim Jagielski 
53*b1cdbd2cSJim Jagielski         uno::Sequence< beans::PropertyValue > aInitArgs( 2 );
54*b1cdbd2cSJim Jagielski         aInitArgs[ 0 ].Name = rtl::OUString::createFromAscii("Application");
55*b1cdbd2cSJim Jagielski         aInitArgs[ 0 ].Value = uno::makeAny( getApplication() );
56*b1cdbd2cSJim Jagielski         aInitArgs[ 1 ].Name = sDocCtxName;
57*b1cdbd2cSJim Jagielski         aInitArgs[ 1 ].Value = uno::makeAny( getXSomethingFromArgs< frame::XModel >( aArgs, 0 ) );
58*b1cdbd2cSJim Jagielski 
59*b1cdbd2cSJim Jagielski         init( aInitArgs );
60*b1cdbd2cSJim Jagielski }
61*b1cdbd2cSJim Jagielski 
~ScVbaGlobals()62*b1cdbd2cSJim Jagielski ScVbaGlobals::~ScVbaGlobals()
63*b1cdbd2cSJim Jagielski {
64*b1cdbd2cSJim Jagielski 	OSL_TRACE("ScVbaGlobals::~ScVbaGlobals");
65*b1cdbd2cSJim Jagielski }
66*b1cdbd2cSJim Jagielski 
67*b1cdbd2cSJim Jagielski // =============================================================================
68*b1cdbd2cSJim Jagielski // XGlobals
69*b1cdbd2cSJim Jagielski // =============================================================================
70*b1cdbd2cSJim Jagielski uno::Reference<excel::XApplication >
getApplication()71*b1cdbd2cSJim Jagielski ScVbaGlobals::getApplication() throw (uno::RuntimeException)
72*b1cdbd2cSJim Jagielski {
73*b1cdbd2cSJim Jagielski //	OSL_TRACE("In ScVbaGlobals::getApplication");
74*b1cdbd2cSJim Jagielski         if ( !mxApplication.is() )
75*b1cdbd2cSJim Jagielski 	    mxApplication.set( new ScVbaApplication( mxContext) );
76*b1cdbd2cSJim Jagielski    	return mxApplication;
77*b1cdbd2cSJim Jagielski }
78*b1cdbd2cSJim Jagielski 
79*b1cdbd2cSJim Jagielski 
80*b1cdbd2cSJim Jagielski uno::Reference<excel::XApplication > SAL_CALL
getExcel()81*b1cdbd2cSJim Jagielski ScVbaGlobals::getExcel() throw (uno::RuntimeException)
82*b1cdbd2cSJim Jagielski {
83*b1cdbd2cSJim Jagielski    	return getApplication();
84*b1cdbd2cSJim Jagielski }
85*b1cdbd2cSJim Jagielski 
86*b1cdbd2cSJim Jagielski 
87*b1cdbd2cSJim Jagielski 
88*b1cdbd2cSJim Jagielski uno::Reference< excel::XWorkbook > SAL_CALL
getActiveWorkbook()89*b1cdbd2cSJim Jagielski ScVbaGlobals::getActiveWorkbook() throw (uno::RuntimeException)
90*b1cdbd2cSJim Jagielski {
91*b1cdbd2cSJim Jagielski //	OSL_TRACE("In ScVbaGlobals::getActiveWorkbook");
92*b1cdbd2cSJim Jagielski     uno::Reference< excel::XWorkbook > xWorkbook( getApplication()->getActiveWorkbook(), uno::UNO_QUERY);
93*b1cdbd2cSJim Jagielski     if ( xWorkbook.is() )
94*b1cdbd2cSJim Jagielski     {
95*b1cdbd2cSJim Jagielski         return xWorkbook;
96*b1cdbd2cSJim Jagielski     }
97*b1cdbd2cSJim Jagielski // FIXME check if this is correct/desired behavior
98*b1cdbd2cSJim Jagielski     throw uno::RuntimeException( rtl::OUString::createFromAscii(
99*b1cdbd2cSJim Jagielski         "No activeWorkbook available" ), Reference< uno::XInterface >() );
100*b1cdbd2cSJim Jagielski }
101*b1cdbd2cSJim Jagielski 
102*b1cdbd2cSJim Jagielski 
103*b1cdbd2cSJim Jagielski uno::Reference< excel::XWindow > SAL_CALL
getActiveWindow()104*b1cdbd2cSJim Jagielski ScVbaGlobals::getActiveWindow() throw (uno::RuntimeException)
105*b1cdbd2cSJim Jagielski {
106*b1cdbd2cSJim Jagielski     return getApplication()->getActiveWindow();
107*b1cdbd2cSJim Jagielski }
108*b1cdbd2cSJim Jagielski 
109*b1cdbd2cSJim Jagielski uno::Reference< excel::XWorksheet > SAL_CALL
getActiveSheet()110*b1cdbd2cSJim Jagielski ScVbaGlobals::getActiveSheet() throw (uno::RuntimeException)
111*b1cdbd2cSJim Jagielski {
112*b1cdbd2cSJim Jagielski     return getApplication()->getActiveSheet();
113*b1cdbd2cSJim Jagielski }
114*b1cdbd2cSJim Jagielski 
115*b1cdbd2cSJim Jagielski uno::Any SAL_CALL
WorkBooks(const uno::Any & aIndex)116*b1cdbd2cSJim Jagielski ScVbaGlobals::WorkBooks( const uno::Any& aIndex ) throw (uno::RuntimeException)
117*b1cdbd2cSJim Jagielski {
118*b1cdbd2cSJim Jagielski 	return uno::Any( getApplication()->Workbooks(aIndex) );
119*b1cdbd2cSJim Jagielski }
120*b1cdbd2cSJim Jagielski 
121*b1cdbd2cSJim Jagielski uno::Any SAL_CALL
WorkSheets(const uno::Any & aIndex)122*b1cdbd2cSJim Jagielski ScVbaGlobals::WorkSheets(const uno::Any& aIndex) throw (uno::RuntimeException)
123*b1cdbd2cSJim Jagielski {
124*b1cdbd2cSJim Jagielski 	return getApplication()->Worksheets( aIndex );
125*b1cdbd2cSJim Jagielski }
126*b1cdbd2cSJim Jagielski uno::Any SAL_CALL
Sheets(const uno::Any & aIndex)127*b1cdbd2cSJim Jagielski ScVbaGlobals::Sheets( const uno::Any& aIndex ) throw (uno::RuntimeException)
128*b1cdbd2cSJim Jagielski {
129*b1cdbd2cSJim Jagielski 	return WorkSheets( aIndex );
130*b1cdbd2cSJim Jagielski }
131*b1cdbd2cSJim Jagielski 
132*b1cdbd2cSJim Jagielski uno::Any SAL_CALL
Range(const uno::Any & Cell1,const uno::Any & Cell2)133*b1cdbd2cSJim Jagielski ScVbaGlobals::Range( const uno::Any& Cell1, const uno::Any& Cell2 ) throw (uno::RuntimeException)
134*b1cdbd2cSJim Jagielski {
135*b1cdbd2cSJim Jagielski 	return getApplication()->Range( Cell1, Cell2 );
136*b1cdbd2cSJim Jagielski }
137*b1cdbd2cSJim Jagielski 
138*b1cdbd2cSJim Jagielski uno::Any SAL_CALL
Names(const css::uno::Any & aIndex)139*b1cdbd2cSJim Jagielski ScVbaGlobals::Names( const css::uno::Any& aIndex ) throw ( uno::RuntimeException )
140*b1cdbd2cSJim Jagielski {
141*b1cdbd2cSJim Jagielski 	return getApplication()->Names( aIndex );
142*b1cdbd2cSJim Jagielski }
143*b1cdbd2cSJim Jagielski 
144*b1cdbd2cSJim Jagielski uno::Reference< excel::XRange > SAL_CALL
getActiveCell()145*b1cdbd2cSJim Jagielski ScVbaGlobals::getActiveCell() throw (uno::RuntimeException)
146*b1cdbd2cSJim Jagielski {
147*b1cdbd2cSJim Jagielski 	return getApplication()->getActiveCell();
148*b1cdbd2cSJim Jagielski }
149*b1cdbd2cSJim Jagielski 
150*b1cdbd2cSJim Jagielski uno::Reference< XAssistant > SAL_CALL
getAssistant()151*b1cdbd2cSJim Jagielski ScVbaGlobals::getAssistant() throw (uno::RuntimeException)
152*b1cdbd2cSJim Jagielski {
153*b1cdbd2cSJim Jagielski 	return getApplication()->getAssistant();
154*b1cdbd2cSJim Jagielski }
155*b1cdbd2cSJim Jagielski 
156*b1cdbd2cSJim Jagielski uno::Any SAL_CALL
getSelection()157*b1cdbd2cSJim Jagielski ScVbaGlobals::getSelection() throw (uno::RuntimeException)
158*b1cdbd2cSJim Jagielski {
159*b1cdbd2cSJim Jagielski 	return getApplication()->getSelection();
160*b1cdbd2cSJim Jagielski }
161*b1cdbd2cSJim Jagielski 
162*b1cdbd2cSJim Jagielski uno::Reference< excel::XWorkbook > SAL_CALL
getThisWorkbook()163*b1cdbd2cSJim Jagielski ScVbaGlobals::getThisWorkbook() throw (uno::RuntimeException)
164*b1cdbd2cSJim Jagielski {
165*b1cdbd2cSJim Jagielski 	return getApplication()->getThisWorkbook();
166*b1cdbd2cSJim Jagielski }
167*b1cdbd2cSJim Jagielski void SAL_CALL
Calculate()168*b1cdbd2cSJim Jagielski ScVbaGlobals::Calculate()  throw (::com::sun::star::script::BasicErrorException, ::com::sun::star::uno::RuntimeException)
169*b1cdbd2cSJim Jagielski {
170*b1cdbd2cSJim Jagielski 	return getApplication()->Calculate();
171*b1cdbd2cSJim Jagielski }
172*b1cdbd2cSJim Jagielski 
173*b1cdbd2cSJim Jagielski uno::Reference< excel::XRange > SAL_CALL
Cells(const uno::Any & RowIndex,const uno::Any & ColumnIndex)174*b1cdbd2cSJim Jagielski ScVbaGlobals::Cells( const uno::Any& RowIndex, const uno::Any& ColumnIndex ) throw (uno::RuntimeException)
175*b1cdbd2cSJim Jagielski {
176*b1cdbd2cSJim Jagielski 	return getApplication()->getActiveSheet()->Cells( RowIndex, ColumnIndex );
177*b1cdbd2cSJim Jagielski }
178*b1cdbd2cSJim Jagielski uno::Reference< excel::XRange > SAL_CALL
Columns(const uno::Any & aIndex)179*b1cdbd2cSJim Jagielski ScVbaGlobals::Columns( const uno::Any& aIndex ) throw (uno::RuntimeException)
180*b1cdbd2cSJim Jagielski {
181*b1cdbd2cSJim Jagielski 	return getApplication()->getActiveSheet()->Columns( aIndex );
182*b1cdbd2cSJim Jagielski }
183*b1cdbd2cSJim Jagielski 
184*b1cdbd2cSJim Jagielski uno::Any SAL_CALL
CommandBars(const uno::Any & aIndex)185*b1cdbd2cSJim Jagielski ScVbaGlobals::CommandBars( const uno::Any& aIndex ) throw (uno::RuntimeException)
186*b1cdbd2cSJim Jagielski {
187*b1cdbd2cSJim Jagielski 	uno::Reference< XApplicationBase > xBase( getApplication(), uno::UNO_QUERY_THROW );
188*b1cdbd2cSJim Jagielski 	return xBase->CommandBars( aIndex );
189*b1cdbd2cSJim Jagielski }
190*b1cdbd2cSJim Jagielski 
191*b1cdbd2cSJim Jagielski css::uno::Reference< ov::excel::XRange > SAL_CALL
Union(const css::uno::Reference<ov::excel::XRange> & Arg1,const css::uno::Reference<ov::excel::XRange> & Arg2,const css::uno::Any & Arg3,const css::uno::Any & Arg4,const css::uno::Any & Arg5,const css::uno::Any & Arg6,const css::uno::Any & Arg7,const css::uno::Any & Arg8,const css::uno::Any & Arg9,const css::uno::Any & Arg10,const css::uno::Any & Arg11,const css::uno::Any & Arg12,const css::uno::Any & Arg13,const css::uno::Any & Arg14,const css::uno::Any & Arg15,const css::uno::Any & Arg16,const css::uno::Any & Arg17,const css::uno::Any & Arg18,const css::uno::Any & Arg19,const css::uno::Any & Arg20,const css::uno::Any & Arg21,const css::uno::Any & Arg22,const css::uno::Any & Arg23,const css::uno::Any & Arg24,const css::uno::Any & Arg25,const css::uno::Any & Arg26,const css::uno::Any & Arg27,const css::uno::Any & Arg28,const css::uno::Any & Arg29,const css::uno::Any & Arg30)192*b1cdbd2cSJim Jagielski ScVbaGlobals::Union( const css::uno::Reference< ov::excel::XRange >& Arg1, const css::uno::Reference< ov::excel::XRange >& Arg2, const css::uno::Any& Arg3, const css::uno::Any& Arg4, const css::uno::Any& Arg5, const css::uno::Any& Arg6, const css::uno::Any& Arg7, const css::uno::Any& Arg8, const css::uno::Any& Arg9, const css::uno::Any& Arg10, const css::uno::Any& Arg11, const css::uno::Any& Arg12, const css::uno::Any& Arg13, const css::uno::Any& Arg14, const css::uno::Any& Arg15, const css::uno::Any& Arg16, const css::uno::Any& Arg17, const css::uno::Any& Arg18, const css::uno::Any& Arg19, const css::uno::Any& Arg20, const css::uno::Any& Arg21, const css::uno::Any& Arg22, const css::uno::Any& Arg23, const css::uno::Any& Arg24, const css::uno::Any& Arg25, const css::uno::Any& Arg26, const css::uno::Any& Arg27, const css::uno::Any& Arg28, const css::uno::Any& Arg29, const css::uno::Any& Arg30 ) throw (css::script::BasicErrorException, css::uno::RuntimeException)
193*b1cdbd2cSJim Jagielski {
194*b1cdbd2cSJim Jagielski 	return getApplication()->Union(  Arg1, Arg2, Arg3, Arg4, Arg5, Arg6, Arg7, Arg8, Arg9, Arg10, Arg11, Arg12, Arg13, Arg14, Arg15, Arg16, Arg17, Arg18, Arg19, Arg20, Arg21, Arg22, Arg23, Arg24, Arg25, Arg26, Arg27, Arg28, Arg29, Arg30 );
195*b1cdbd2cSJim Jagielski }
196*b1cdbd2cSJim Jagielski css::uno::Reference< ov::excel::XRange > SAL_CALL
Intersect(const css::uno::Reference<ov::excel::XRange> & Arg1,const css::uno::Reference<ov::excel::XRange> & Arg2,const css::uno::Any & Arg3,const css::uno::Any & Arg4,const css::uno::Any & Arg5,const css::uno::Any & Arg6,const css::uno::Any & Arg7,const css::uno::Any & Arg8,const css::uno::Any & Arg9,const css::uno::Any & Arg10,const css::uno::Any & Arg11,const css::uno::Any & Arg12,const css::uno::Any & Arg13,const css::uno::Any & Arg14,const css::uno::Any & Arg15,const css::uno::Any & Arg16,const css::uno::Any & Arg17,const css::uno::Any & Arg18,const css::uno::Any & Arg19,const css::uno::Any & Arg20,const css::uno::Any & Arg21,const css::uno::Any & Arg22,const css::uno::Any & Arg23,const css::uno::Any & Arg24,const css::uno::Any & Arg25,const css::uno::Any & Arg26,const css::uno::Any & Arg27,const css::uno::Any & Arg28,const css::uno::Any & Arg29,const css::uno::Any & Arg30)197*b1cdbd2cSJim Jagielski ScVbaGlobals::Intersect( const css::uno::Reference< ov::excel::XRange >& Arg1, const css::uno::Reference< ov::excel::XRange >& Arg2, const css::uno::Any& Arg3, const css::uno::Any& Arg4, const css::uno::Any& Arg5, const css::uno::Any& Arg6, const css::uno::Any& Arg7, const css::uno::Any& Arg8, const css::uno::Any& Arg9, const css::uno::Any& Arg10, const css::uno::Any& Arg11, const css::uno::Any& Arg12, const css::uno::Any& Arg13, const css::uno::Any& Arg14, const css::uno::Any& Arg15, const css::uno::Any& Arg16, const css::uno::Any& Arg17, const css::uno::Any& Arg18, const css::uno::Any& Arg19, const css::uno::Any& Arg20, const css::uno::Any& Arg21, const css::uno::Any& Arg22, const css::uno::Any& Arg23, const css::uno::Any& Arg24, const css::uno::Any& Arg25, const css::uno::Any& Arg26, const css::uno::Any& Arg27, const css::uno::Any& Arg28, const css::uno::Any& Arg29, const css::uno::Any& Arg30 ) throw (css::script::BasicErrorException, css::uno::RuntimeException)
198*b1cdbd2cSJim Jagielski {
199*b1cdbd2cSJim Jagielski 	return getApplication()->Intersect(  Arg1, Arg2, Arg3, Arg4, Arg5, Arg6, Arg7, Arg8, Arg9, Arg10, Arg11, Arg12, Arg13, Arg14, Arg15, Arg16, Arg17, Arg18, Arg19, Arg20, Arg21, Arg22, Arg23, Arg24, Arg25, Arg26, Arg27, Arg28, Arg29, Arg30 );
200*b1cdbd2cSJim Jagielski }
201*b1cdbd2cSJim Jagielski 
202*b1cdbd2cSJim Jagielski uno::Any SAL_CALL
Evaluate(const::rtl::OUString & Name)203*b1cdbd2cSJim Jagielski ScVbaGlobals::Evaluate( const ::rtl::OUString& Name ) throw (uno::RuntimeException)
204*b1cdbd2cSJim Jagielski {
205*b1cdbd2cSJim Jagielski 	return getApplication()->Evaluate( Name );
206*b1cdbd2cSJim Jagielski }
207*b1cdbd2cSJim Jagielski 
208*b1cdbd2cSJim Jagielski css::uno::Any SAL_CALL
WorksheetFunction()209*b1cdbd2cSJim Jagielski ScVbaGlobals::WorksheetFunction(  ) throw (css::uno::RuntimeException)
210*b1cdbd2cSJim Jagielski {
211*b1cdbd2cSJim Jagielski 	return getApplication()->WorksheetFunction();
212*b1cdbd2cSJim Jagielski }
213*b1cdbd2cSJim Jagielski 
214*b1cdbd2cSJim Jagielski uno::Any SAL_CALL
Windows(const uno::Any & aIndex)215*b1cdbd2cSJim Jagielski ScVbaGlobals::Windows( const uno::Any& aIndex ) throw (uno::RuntimeException)
216*b1cdbd2cSJim Jagielski {
217*b1cdbd2cSJim Jagielski 	return getApplication()->Windows( aIndex );
218*b1cdbd2cSJim Jagielski }
219*b1cdbd2cSJim Jagielski 
220*b1cdbd2cSJim Jagielski uno::Reference< excel::XRange > SAL_CALL
Rows(const uno::Any & aIndex)221*b1cdbd2cSJim Jagielski ScVbaGlobals::Rows( const uno::Any& aIndex ) throw (uno::RuntimeException)
222*b1cdbd2cSJim Jagielski {
223*b1cdbd2cSJim Jagielski 	return getApplication()->getActiveSheet()->Rows( aIndex );
224*b1cdbd2cSJim Jagielski 
225*b1cdbd2cSJim Jagielski }
226*b1cdbd2cSJim Jagielski 
227*b1cdbd2cSJim Jagielski 
228*b1cdbd2cSJim Jagielski uno::Any SAL_CALL
getDebug()229*b1cdbd2cSJim Jagielski ScVbaGlobals::getDebug() throw (uno::RuntimeException)
230*b1cdbd2cSJim Jagielski {
231*b1cdbd2cSJim Jagielski 	try // return empty object on error
232*b1cdbd2cSJim Jagielski 	{
233*b1cdbd2cSJim Jagielski 		uno::Reference< lang::XMultiComponentFactory > xServiceManager( mxContext->getServiceManager(), uno::UNO_SET_THROW );
234*b1cdbd2cSJim Jagielski 		uno::Reference< uno::XInterface > xVBADebug = xServiceManager->createInstanceWithContext(
235*b1cdbd2cSJim Jagielski             ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "ooo.vba.Debug" ) ), mxContext );
236*b1cdbd2cSJim Jagielski         return uno::Any( xVBADebug );
237*b1cdbd2cSJim Jagielski 	}
238*b1cdbd2cSJim Jagielski     catch( uno::Exception& )
239*b1cdbd2cSJim Jagielski 	{
240*b1cdbd2cSJim Jagielski 	}
241*b1cdbd2cSJim Jagielski 	return uno::Any();
242*b1cdbd2cSJim Jagielski }
243*b1cdbd2cSJim Jagielski 
244*b1cdbd2cSJim Jagielski uno::Sequence< ::rtl::OUString > SAL_CALL
getAvailableServiceNames()245*b1cdbd2cSJim Jagielski ScVbaGlobals::getAvailableServiceNames(  ) throw (uno::RuntimeException)
246*b1cdbd2cSJim Jagielski {
247*b1cdbd2cSJim Jagielski     static bool bInit = false;
248*b1cdbd2cSJim Jagielski     static uno::Sequence< rtl::OUString > serviceNames( ScVbaGlobals_BASE::getAvailableServiceNames() );
249*b1cdbd2cSJim Jagielski     if ( !bInit )
250*b1cdbd2cSJim Jagielski     {
251*b1cdbd2cSJim Jagielski          rtl::OUString names[] = {
252*b1cdbd2cSJim Jagielski             ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM ( "ooo.vba.excel.Range" ) ),
253*b1cdbd2cSJim Jagielski             ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM ( "ooo.vba.excel.Workbook" ) ),
254*b1cdbd2cSJim Jagielski             ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM ( "ooo.vba.excel.Window" ) ),
255*b1cdbd2cSJim Jagielski             ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM ( "ooo.vba.excel.Worksheet" ) ),
256*b1cdbd2cSJim Jagielski             ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM ( "ooo.vba.excel.Application" ) ),
257*b1cdbd2cSJim Jagielski             ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM ( "ooo.vba.excel.Hyperlink" ) ),
258*b1cdbd2cSJim Jagielski             ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM ( "com.sun.star.script.vba.VBASpreadsheetEventProcessor" ) )
259*b1cdbd2cSJim Jagielski           };
260*b1cdbd2cSJim Jagielski         sal_Int32 nExcelServices = ( sizeof( names )/ sizeof( names[0] ) );
261*b1cdbd2cSJim Jagielski         sal_Int32 startIndex = serviceNames.getLength();
262*b1cdbd2cSJim Jagielski         serviceNames.realloc( serviceNames.getLength() + nExcelServices );
263*b1cdbd2cSJim Jagielski         for ( sal_Int32 index = 0; index < nExcelServices; ++index )
264*b1cdbd2cSJim Jagielski              serviceNames[ startIndex + index ] = names[ index ];
265*b1cdbd2cSJim Jagielski         bInit = true;
266*b1cdbd2cSJim Jagielski     }
267*b1cdbd2cSJim Jagielski     return serviceNames;
268*b1cdbd2cSJim Jagielski }
269*b1cdbd2cSJim Jagielski 
270*b1cdbd2cSJim Jagielski rtl::OUString&
getServiceImplName()271*b1cdbd2cSJim Jagielski ScVbaGlobals::getServiceImplName()
272*b1cdbd2cSJim Jagielski {
273*b1cdbd2cSJim Jagielski         static rtl::OUString sImplName( RTL_CONSTASCII_USTRINGPARAM("ScVbaGlobals") );
274*b1cdbd2cSJim Jagielski         return sImplName;
275*b1cdbd2cSJim Jagielski }
276*b1cdbd2cSJim Jagielski 
277*b1cdbd2cSJim Jagielski uno::Sequence< rtl::OUString >
getServiceNames()278*b1cdbd2cSJim Jagielski ScVbaGlobals::getServiceNames()
279*b1cdbd2cSJim Jagielski {
280*b1cdbd2cSJim Jagielski         static uno::Sequence< rtl::OUString > aServiceNames;
281*b1cdbd2cSJim Jagielski         if ( aServiceNames.getLength() == 0 )
282*b1cdbd2cSJim Jagielski         {
283*b1cdbd2cSJim Jagielski                 aServiceNames.realloc( 1 );
284*b1cdbd2cSJim Jagielski                 aServiceNames[ 0 ] = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("ooo.vba.excel.Globals" ) );
285*b1cdbd2cSJim Jagielski         }
286*b1cdbd2cSJim Jagielski         return aServiceNames;
287*b1cdbd2cSJim Jagielski }
288*b1cdbd2cSJim Jagielski 
289*b1cdbd2cSJim Jagielski namespace globals
290*b1cdbd2cSJim Jagielski {
291*b1cdbd2cSJim Jagielski namespace sdecl = comphelper::service_decl;
292*b1cdbd2cSJim Jagielski sdecl::vba_service_class_<ScVbaGlobals, sdecl::with_args<true> > serviceImpl;
293*b1cdbd2cSJim Jagielski extern sdecl::ServiceDecl const serviceDecl(
294*b1cdbd2cSJim Jagielski     serviceImpl,
295*b1cdbd2cSJim Jagielski     "ScVbaGlobals",
296*b1cdbd2cSJim Jagielski     "ooo.vba.excel.Globals" );
297*b1cdbd2cSJim Jagielski }
298*b1cdbd2cSJim Jagielski 
299