bump product version to 4.1.6.2
[LibreOffice.git] / filter / source / msfilter / msocximex.cxx
blob5706df0b8562f6cb502fa10221614ccab1ae7c1e
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #include <com/sun/star/beans/XPropertySet.hpp>
21 #include <com/sun/star/drawing/XDrawPage.hpp>
22 #include <com/sun/star/drawing/XShapes.hpp>
23 #include <com/sun/star/lang/XMultiServiceFactory.hpp>
24 #include <com/sun/star/container/XIndexContainer.hpp>
25 #include <com/sun/star/drawing/XDrawPageSupplier.hpp>
26 #include <com/sun/star/form/XFormsSupplier.hpp>
27 #include <com/sun/star/form/XForm.hpp>
28 #include <filter/msfilter/msocximex.hxx>
30 using namespace ::com::sun::star;
31 using namespace ::rtl;
33 OUString sWW8_form( "WW-Standard" );
35 SvxMSConvertOCXControls::SvxMSConvertOCXControls( const uno::Reference< frame::XModel >& rxModel) : mxModel(rxModel)
39 SvxMSConvertOCXControls::~SvxMSConvertOCXControls()
43 const uno::Reference< drawing::XDrawPage >&
44 SvxMSConvertOCXControls::GetDrawPage()
46 if( !xDrawPage.is() && mxModel.is() )
48 uno::Reference< drawing::XDrawPageSupplier > xTxtDoc(mxModel,
49 uno::UNO_QUERY);
50 OSL_ENSURE(xTxtDoc.is(),"no XDrawPageSupplier from XModel");
51 xDrawPage = xTxtDoc->getDrawPage();
52 OSL_ENSURE( xDrawPage.is(), "no XDrawPage" );
55 return xDrawPage;
59 const uno::Reference< lang::XMultiServiceFactory >&
60 SvxMSConvertOCXControls::GetServiceFactory()
62 if( !xServiceFactory.is() && mxModel.is() )
64 xServiceFactory = uno::Reference< lang::XMultiServiceFactory >
65 (mxModel, uno::UNO_QUERY);
66 OSL_ENSURE( xServiceFactory.is(),
67 "no XMultiServiceFactory from doc Model" );
70 return xServiceFactory;
73 const uno::Reference< drawing::XShapes >& SvxMSConvertOCXControls::GetShapes()
75 if( !xShapes.is() )
77 GetDrawPage();
78 if( xDrawPage.is() )
81 xShapes = uno::Reference< drawing::XShapes >(xDrawPage,
82 uno::UNO_QUERY);
83 OSL_ENSURE( xShapes.is(), "UNO_QUERY failed for XShapes from XDrawPage" );
86 return xShapes;
89 const uno::Reference< container::XIndexContainer >&
90 SvxMSConvertOCXControls::GetFormComps()
92 if( !xFormComps.is() )
94 GetDrawPage();
95 if( xDrawPage.is() )
97 uno::Reference< form::XFormsSupplier > xFormsSupplier( xDrawPage,
98 uno::UNO_QUERY );
99 OSL_ENSURE( xFormsSupplier.is(),
100 "UNO_QUERY failed for XFormsSupplier from XDrawPage" );
102 uno::Reference< container::XNameContainer > xNameCont =
103 xFormsSupplier->getForms();
105 // The form gets a new name like "WW-Standard[n]" and will
106 // created new in any case.
107 OUString sName( sWW8_form );
108 sal_uInt16 n = 0;
110 while( xNameCont->hasByName( sName ) )
112 sName = sWW8_form;
113 sName += OUString::number( ++n );
116 const uno::Reference< lang::XMultiServiceFactory > &rServiceFactory
117 = GetServiceFactory();
118 if( !rServiceFactory.is() )
119 return xFormComps;
121 uno::Reference< uno::XInterface > xCreate =
122 rServiceFactory->createInstance(
123 "com.sun.star.form.component.Form" );
124 if( xCreate.is() )
126 uno::Reference< beans::XPropertySet > xFormPropSet( xCreate,
127 uno::UNO_QUERY );
129 uno::Any aTmp(&sName,getCppuType((OUString *)0));
130 xFormPropSet->setPropertyValue( "Name", aTmp );
132 uno::Reference< form::XForm > xForm( xCreate, uno::UNO_QUERY );
133 OSL_ENSURE(xForm.is(), "no Form?");
135 uno::Reference< container::XIndexContainer > xForms( xNameCont,
136 uno::UNO_QUERY );
137 OSL_ENSURE( xForms.is(), "XForms not available" );
139 aTmp.setValue( &xForm,
140 ::getCppuType((uno::Reference < form::XForm >*)0));
141 xForms->insertByIndex( xForms->getCount(), aTmp );
143 xFormComps = uno::Reference< container::XIndexContainer >
144 (xCreate, uno::UNO_QUERY);
149 return xFormComps;
152 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */