xref: /aoo4110/main/sw/source/ui/vba/vbaapplication.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 <stdio.h>
24*b1cdbd2cSJim Jagielski #include "vbaapplication.hxx"
25*b1cdbd2cSJim Jagielski #include "vbadocument.hxx"
26*b1cdbd2cSJim Jagielski #include <osl/file.hxx>
27*b1cdbd2cSJim Jagielski #include <vbahelper/vbahelper.hxx>
28*b1cdbd2cSJim Jagielski #include "vbawindow.hxx"
29*b1cdbd2cSJim Jagielski #include "vbasystem.hxx"
30*b1cdbd2cSJim Jagielski #include "vbaoptions.hxx"
31*b1cdbd2cSJim Jagielski #include "vbaselection.hxx"
32*b1cdbd2cSJim Jagielski #include "vbadocuments.hxx"
33*b1cdbd2cSJim Jagielski #include "vbaaddins.hxx"
34*b1cdbd2cSJim Jagielski #include "vbadialogs.hxx"
35*b1cdbd2cSJim Jagielski #include <ooo/vba/word/WdEnableCancelKey.hpp>
36*b1cdbd2cSJim Jagielski #include <editeng/acorrcfg.hxx>
37*b1cdbd2cSJim Jagielski #include "wordvbahelper.hxx"
38*b1cdbd2cSJim Jagielski #include <docsh.hxx>
39*b1cdbd2cSJim Jagielski 
40*b1cdbd2cSJim Jagielski using namespace ::ooo;
41*b1cdbd2cSJim Jagielski using namespace ::ooo::vba;
42*b1cdbd2cSJim Jagielski using namespace ::com::sun::star;
43*b1cdbd2cSJim Jagielski 
44*b1cdbd2cSJim Jagielski using ::com::sun::star::uno::Reference;
45*b1cdbd2cSJim Jagielski using ::com::sun::star::uno::UNO_QUERY_THROW;
46*b1cdbd2cSJim Jagielski using ::com::sun::star::uno::UNO_QUERY;
47*b1cdbd2cSJim Jagielski using ::rtl::OUString;
48*b1cdbd2cSJim Jagielski 
49*b1cdbd2cSJim Jagielski // Enable our own join detection for Intersection and Union
50*b1cdbd2cSJim Jagielski // should be more efficient than using ScRangeList::Join ( because
51*b1cdbd2cSJim Jagielski // we already are testing the same things )
52*b1cdbd2cSJim Jagielski 
53*b1cdbd2cSJim Jagielski #define OWN_JOIN 1
54*b1cdbd2cSJim Jagielski 
55*b1cdbd2cSJim Jagielski // #TODO is this defined somewhere else?
56*b1cdbd2cSJim Jagielski #if ( defined UNX ) || ( defined OS2 ) //unix
57*b1cdbd2cSJim Jagielski #define FILE_PATH_SEPERATOR "/"
58*b1cdbd2cSJim Jagielski #else // windows
59*b1cdbd2cSJim Jagielski #define FILE_PATH_SEPERATOR "\\"
60*b1cdbd2cSJim Jagielski #endif
61*b1cdbd2cSJim Jagielski 
62*b1cdbd2cSJim Jagielski #define EXCELVERSION "11.0"
63*b1cdbd2cSJim Jagielski 
64*b1cdbd2cSJim Jagielski uno::Any sbxToUnoValue( SbxVariable* pVar );
65*b1cdbd2cSJim Jagielski 
SwVbaApplication(uno::Reference<uno::XComponentContext> & xContext)66*b1cdbd2cSJim Jagielski SwVbaApplication::SwVbaApplication( uno::Reference<uno::XComponentContext >& xContext ): SwVbaApplication_BASE( xContext )
67*b1cdbd2cSJim Jagielski {
68*b1cdbd2cSJim Jagielski }
69*b1cdbd2cSJim Jagielski 
~SwVbaApplication()70*b1cdbd2cSJim Jagielski SwVbaApplication::~SwVbaApplication()
71*b1cdbd2cSJim Jagielski {
72*b1cdbd2cSJim Jagielski }
73*b1cdbd2cSJim Jagielski 
GetDocShell(const uno::Reference<frame::XModel> & xModel)74*b1cdbd2cSJim Jagielski SfxObjectShell* SwVbaApplication::GetDocShell( const uno::Reference< frame::XModel >& xModel ) throw (uno::RuntimeException)
75*b1cdbd2cSJim Jagielski {
76*b1cdbd2cSJim Jagielski     return static_cast< SfxObjectShell* >( word::getDocShell( xModel ) );
77*b1cdbd2cSJim Jagielski }
78*b1cdbd2cSJim Jagielski 
79*b1cdbd2cSJim Jagielski rtl::OUString SAL_CALL
getName()80*b1cdbd2cSJim Jagielski SwVbaApplication::getName() throw (uno::RuntimeException)
81*b1cdbd2cSJim Jagielski {
82*b1cdbd2cSJim Jagielski     static rtl::OUString appName( RTL_CONSTASCII_USTRINGPARAM("Microsoft Word" ) );
83*b1cdbd2cSJim Jagielski     return appName;
84*b1cdbd2cSJim Jagielski }
85*b1cdbd2cSJim Jagielski 
86*b1cdbd2cSJim Jagielski uno::Reference< word::XDocument > SAL_CALL
getActiveDocument()87*b1cdbd2cSJim Jagielski SwVbaApplication::getActiveDocument() throw (uno::RuntimeException)
88*b1cdbd2cSJim Jagielski {
89*b1cdbd2cSJim Jagielski     return new SwVbaDocument( this, mxContext, getCurrentDocument() );
90*b1cdbd2cSJim Jagielski }
91*b1cdbd2cSJim Jagielski 
92*b1cdbd2cSJim Jagielski uno::Reference< word::XWindow > SAL_CALL
getActiveWindow()93*b1cdbd2cSJim Jagielski SwVbaApplication::getActiveWindow() throw (uno::RuntimeException)
94*b1cdbd2cSJim Jagielski {
95*b1cdbd2cSJim Jagielski 	// #FIXME sofar can't determine Parent
96*b1cdbd2cSJim Jagielski 	uno::Reference< frame::XModel > xModel( getCurrentDocument(), uno::UNO_SET_THROW );
97*b1cdbd2cSJim Jagielski 	uno::Reference< frame::XController > xController( xModel->getCurrentController(), uno::UNO_SET_THROW );
98*b1cdbd2cSJim Jagielski 	return new SwVbaWindow( uno::Reference< XHelperInterface >(), mxContext, xModel, xController );
99*b1cdbd2cSJim Jagielski }
100*b1cdbd2cSJim Jagielski 
101*b1cdbd2cSJim Jagielski uno::Reference<word::XSystem > SAL_CALL
getSystem()102*b1cdbd2cSJim Jagielski SwVbaApplication::getSystem() throw (uno::RuntimeException)
103*b1cdbd2cSJim Jagielski {
104*b1cdbd2cSJim Jagielski     return uno::Reference< word::XSystem >( new SwVbaSystem( mxContext ) );
105*b1cdbd2cSJim Jagielski }
106*b1cdbd2cSJim Jagielski 
107*b1cdbd2cSJim Jagielski uno::Reference<word::XOptions > SAL_CALL
getOptions()108*b1cdbd2cSJim Jagielski SwVbaApplication::getOptions() throw (uno::RuntimeException)
109*b1cdbd2cSJim Jagielski {
110*b1cdbd2cSJim Jagielski     return uno::Reference< word::XOptions >( new SwVbaOptions( mxContext ) );
111*b1cdbd2cSJim Jagielski }
112*b1cdbd2cSJim Jagielski 
113*b1cdbd2cSJim Jagielski uno::Any SAL_CALL
CommandBars(const uno::Any & aIndex)114*b1cdbd2cSJim Jagielski SwVbaApplication::CommandBars( const uno::Any& aIndex ) throw (uno::RuntimeException)
115*b1cdbd2cSJim Jagielski {
116*b1cdbd2cSJim Jagielski     return VbaApplicationBase::CommandBars( aIndex );
117*b1cdbd2cSJim Jagielski }
118*b1cdbd2cSJim Jagielski 
119*b1cdbd2cSJim Jagielski uno::Reference< word::XSelection > SAL_CALL
getSelection()120*b1cdbd2cSJim Jagielski SwVbaApplication::getSelection() throw (uno::RuntimeException)
121*b1cdbd2cSJim Jagielski {
122*b1cdbd2cSJim Jagielski     return new SwVbaSelection( this, mxContext, getCurrentDocument() );
123*b1cdbd2cSJim Jagielski }
124*b1cdbd2cSJim Jagielski 
125*b1cdbd2cSJim Jagielski uno::Any SAL_CALL
Documents(const uno::Any & index)126*b1cdbd2cSJim Jagielski SwVbaApplication::Documents( const uno::Any& index ) throw (uno::RuntimeException)
127*b1cdbd2cSJim Jagielski {
128*b1cdbd2cSJim Jagielski     uno::Reference< XCollection > xCol( new SwVbaDocuments( this, mxContext ) );
129*b1cdbd2cSJim Jagielski     if ( index.hasValue() )
130*b1cdbd2cSJim Jagielski         return xCol->Item( index, uno::Any() );
131*b1cdbd2cSJim Jagielski     return uno::makeAny( xCol );
132*b1cdbd2cSJim Jagielski }
133*b1cdbd2cSJim Jagielski 
134*b1cdbd2cSJim Jagielski uno::Any SAL_CALL
Addins(const uno::Any & index)135*b1cdbd2cSJim Jagielski SwVbaApplication::Addins( const uno::Any& index ) throw (uno::RuntimeException)
136*b1cdbd2cSJim Jagielski {
137*b1cdbd2cSJim Jagielski     static uno::Reference< XCollection > xCol( new SwVbaAddins( this, mxContext ) );
138*b1cdbd2cSJim Jagielski     if ( index.hasValue() )
139*b1cdbd2cSJim Jagielski         return xCol->Item( index, uno::Any() );
140*b1cdbd2cSJim Jagielski     return uno::makeAny( xCol );
141*b1cdbd2cSJim Jagielski }
142*b1cdbd2cSJim Jagielski 
143*b1cdbd2cSJim Jagielski uno::Any SAL_CALL
Dialogs(const uno::Any & index)144*b1cdbd2cSJim Jagielski SwVbaApplication::Dialogs( const uno::Any& index ) throw (uno::RuntimeException)
145*b1cdbd2cSJim Jagielski {
146*b1cdbd2cSJim Jagielski     uno::Reference< word::XDialogs > xCol( new SwVbaDialogs( this, mxContext, getCurrentDocument() ));
147*b1cdbd2cSJim Jagielski     if ( index.hasValue() )
148*b1cdbd2cSJim Jagielski         return xCol->Item( index );
149*b1cdbd2cSJim Jagielski     return uno::makeAny( xCol );
150*b1cdbd2cSJim Jagielski }
151*b1cdbd2cSJim Jagielski 
getDisplayAutoCompleteTips()152*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL SwVbaApplication::getDisplayAutoCompleteTips() throw (css::uno::RuntimeException)
153*b1cdbd2cSJim Jagielski {
154*b1cdbd2cSJim Jagielski     return SvxAutoCorrCfg::Get()->IsAutoTextTip();
155*b1cdbd2cSJim Jagielski }
156*b1cdbd2cSJim Jagielski 
setDisplayAutoCompleteTips(sal_Bool _displayAutoCompleteTips)157*b1cdbd2cSJim Jagielski void SAL_CALL SwVbaApplication::setDisplayAutoCompleteTips( sal_Bool _displayAutoCompleteTips ) throw (css::uno::RuntimeException)
158*b1cdbd2cSJim Jagielski {
159*b1cdbd2cSJim Jagielski     SvxAutoCorrCfg::Get()->SetAutoTextTip( _displayAutoCompleteTips );
160*b1cdbd2cSJim Jagielski }
161*b1cdbd2cSJim Jagielski 
getEnableCancelKey()162*b1cdbd2cSJim Jagielski sal_Int32 SAL_CALL SwVbaApplication::getEnableCancelKey() throw (css::uno::RuntimeException)
163*b1cdbd2cSJim Jagielski {
164*b1cdbd2cSJim Jagielski     // the default value is wdCancelInterrupt in Word
165*b1cdbd2cSJim Jagielski     return word::WdEnableCancelKey::wdCancelInterrupt;
166*b1cdbd2cSJim Jagielski }
167*b1cdbd2cSJim Jagielski 
setEnableCancelKey(sal_Int32)168*b1cdbd2cSJim Jagielski void SAL_CALL SwVbaApplication::setEnableCancelKey( sal_Int32/* _enableCancelKey */) throw (css::uno::RuntimeException)
169*b1cdbd2cSJim Jagielski {
170*b1cdbd2cSJim Jagielski     // seems not supported in Writer
171*b1cdbd2cSJim Jagielski }
172*b1cdbd2cSJim Jagielski 
CentimetersToPoints(float _Centimeters)173*b1cdbd2cSJim Jagielski float SAL_CALL SwVbaApplication::CentimetersToPoints( float _Centimeters ) throw (uno::RuntimeException)
174*b1cdbd2cSJim Jagielski {
175*b1cdbd2cSJim Jagielski     return VbaApplicationBase::CentimetersToPoints( _Centimeters );
176*b1cdbd2cSJim Jagielski }
177*b1cdbd2cSJim Jagielski 
178*b1cdbd2cSJim Jagielski uno::Reference< frame::XModel >
getCurrentDocument()179*b1cdbd2cSJim Jagielski SwVbaApplication::getCurrentDocument() throw (css::uno::RuntimeException)
180*b1cdbd2cSJim Jagielski {
181*b1cdbd2cSJim Jagielski     return getCurrentWordDoc( mxContext );
182*b1cdbd2cSJim Jagielski }
183*b1cdbd2cSJim Jagielski 
184*b1cdbd2cSJim Jagielski rtl::OUString&
getServiceImplName()185*b1cdbd2cSJim Jagielski SwVbaApplication::getServiceImplName()
186*b1cdbd2cSJim Jagielski {
187*b1cdbd2cSJim Jagielski 	static rtl::OUString sImplName( RTL_CONSTASCII_USTRINGPARAM("SwVbaApplication") );
188*b1cdbd2cSJim Jagielski 	return sImplName;
189*b1cdbd2cSJim Jagielski }
190*b1cdbd2cSJim Jagielski 
191*b1cdbd2cSJim Jagielski uno::Sequence< rtl::OUString >
getServiceNames()192*b1cdbd2cSJim Jagielski SwVbaApplication::getServiceNames()
193*b1cdbd2cSJim Jagielski {
194*b1cdbd2cSJim Jagielski 	static uno::Sequence< rtl::OUString > aServiceNames;
195*b1cdbd2cSJim Jagielski 	if ( aServiceNames.getLength() == 0 )
196*b1cdbd2cSJim Jagielski 	{
197*b1cdbd2cSJim Jagielski 		aServiceNames.realloc( 1 );
198*b1cdbd2cSJim Jagielski 		aServiceNames[ 0 ] = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("ooo.vba.word.Application" ) );
199*b1cdbd2cSJim Jagielski 	}
200*b1cdbd2cSJim Jagielski 	return aServiceNames;
201*b1cdbd2cSJim Jagielski }
202