office-gobmx/svx/source/unogallery/unogaltheme.cxx
Chris Sherlock a238b1f8d3 Remove excess newlines
A ridiculously fast way of doing this is:

for i in $(pcregrep -l -M -r --include='.*[hc]xx$' \
  --exclude-dir=workdir --exclude-dir=instdir '^
{3,}' .)
do
    perl -0777 -i -pe 's/^
{3,}/

/gm' $i
done

Change-Id: Iebb93eccbee9e4fc5c4380474ba595858a27ac2c
Reviewed-on: https://gerrit.libreoffice.org/22224
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Chris Sherlock <chris.sherlock79@gmail.com>
2016-02-09 08:18:05 +00:00

401 lines
11 KiB
C++

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (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.apache.org/licenses/LICENSE-2.0 .
*/
#include <algorithm>
#include "unogaltheme.hxx"
#include "unogalitem.hxx"
#include "svx/galtheme.hxx"
#include "svx/gallery1.hxx"
#include "svx/galmisc.hxx"
#include <svx/fmmodel.hxx>
#include <svx/svdpage.hxx>
#include <svx/unopage.hxx>
#include <svl/itempool.hxx>
#include <osl/mutex.hxx>
#include <vcl/svapp.hxx>
#include <unotools/pathoptions.hxx>
#include <comphelper/servicehelper.hxx>
#include <cppuhelper/supportsservice.hxx>
using namespace ::com::sun::star;
namespace unogallery {
GalleryTheme::GalleryTheme( const OUString& rThemeName )
{
mpGallery = ::Gallery::GetGalleryInstance();
mpTheme = ( mpGallery ? mpGallery->AcquireTheme( rThemeName, *this ) : nullptr );
if( mpGallery )
StartListening( *mpGallery );
}
GalleryTheme::~GalleryTheme()
{
const SolarMutexGuard aGuard;
DBG_ASSERT( !mpTheme || mpGallery, "Theme is living without Gallery" );
implReleaseItems( nullptr );
if( mpGallery )
{
EndListening( *mpGallery );
if( mpTheme )
mpGallery->ReleaseTheme( mpTheme, *this );
}
}
OUString GalleryTheme::getImplementationName_Static()
throw()
{
return OUString( "com.sun.star.comp.gallery.GalleryTheme" );
}
uno::Sequence< OUString > GalleryTheme::getSupportedServiceNames_Static()
throw()
{
uno::Sequence< OUString > aSeq { "com.sun.star.gallery.GalleryTheme" };
return aSeq;
}
OUString SAL_CALL GalleryTheme::getImplementationName()
throw( uno::RuntimeException, std::exception )
{
return getImplementationName_Static();
}
sal_Bool SAL_CALL GalleryTheme::supportsService( const OUString& ServiceName )
throw( uno::RuntimeException, std::exception )
{
return cppu::supportsService( this, ServiceName );
}
uno::Sequence< OUString > SAL_CALL GalleryTheme::getSupportedServiceNames()
throw( uno::RuntimeException, std::exception )
{
return getSupportedServiceNames_Static();
}
uno::Sequence< uno::Type > SAL_CALL GalleryTheme::getTypes()
throw(uno::RuntimeException, std::exception)
{
uno::Sequence< uno::Type > aTypes( 5 );
uno::Type* pTypes = aTypes.getArray();
*pTypes++ = cppu::UnoType<lang::XServiceInfo>::get();
*pTypes++ = cppu::UnoType<lang::XTypeProvider>::get();
*pTypes++ = cppu::UnoType<container::XElementAccess>::get();
*pTypes++ = cppu::UnoType<container::XIndexAccess>::get();
*pTypes++ = cppu::UnoType<gallery::XGalleryTheme>::get();
return aTypes;
}
uno::Sequence< sal_Int8 > SAL_CALL GalleryTheme::getImplementationId()
throw(uno::RuntimeException, std::exception)
{
return css::uno::Sequence<sal_Int8>();
}
uno::Type SAL_CALL GalleryTheme::getElementType()
throw (uno::RuntimeException, std::exception)
{
return cppu::UnoType<gallery::XGalleryItem>::get();
}
sal_Bool SAL_CALL GalleryTheme::hasElements()
throw (uno::RuntimeException, std::exception)
{
const SolarMutexGuard aGuard;
return( ( mpTheme != nullptr ) && ( mpTheme->GetObjectCount() > 0 ) );
}
sal_Int32 SAL_CALL GalleryTheme::getCount()
throw (uno::RuntimeException, std::exception)
{
const SolarMutexGuard aGuard;
return( mpTheme ? mpTheme->GetObjectCount() : 0 );
}
uno::Any SAL_CALL GalleryTheme::getByIndex( ::sal_Int32 nIndex )
throw (lang::IndexOutOfBoundsException, lang::WrappedTargetException, uno::RuntimeException, std::exception)
{
const SolarMutexGuard aGuard;
uno::Any aRet;
if( mpTheme )
{
if( ( nIndex < 0 ) || ( nIndex >= getCount() ) )
{
throw lang::IndexOutOfBoundsException();
}
else
{
const GalleryObject* pObj = mpTheme->ImplGetGalleryObject( nIndex );
if( pObj )
aRet = uno::makeAny( uno::Reference< gallery::XGalleryItem >( new GalleryItem( *this, *pObj ) ) );
}
}
return aRet;
}
OUString SAL_CALL GalleryTheme::getName( )
throw (uno::RuntimeException, std::exception)
{
const SolarMutexGuard aGuard;
OUString aRet;
if( mpTheme )
aRet = mpTheme->GetName();
return aRet;
}
void SAL_CALL GalleryTheme::update( )
throw (uno::RuntimeException, std::exception)
{
const SolarMutexGuard aGuard;
if( mpTheme )
{
const Link<const INetURLObject&, void> aDummyLink;
mpTheme->Actualize( aDummyLink );
}
}
::sal_Int32 SAL_CALL GalleryTheme::insertURLByIndex(
const OUString& rURL, ::sal_Int32 nIndex )
throw (lang::WrappedTargetException, uno::RuntimeException, std::exception)
{
const SolarMutexGuard aGuard;
sal_Int32 nRet = -1;
if( mpTheme )
{
try
{
const INetURLObject aURL( rURL );
nIndex = ::std::max( ::std::min( nIndex, getCount() ), sal_Int32( 0 ) );
if( ( aURL.GetProtocol() != INetProtocol::NotValid ) && mpTheme->InsertURL( aURL, nIndex ) )
{
const GalleryObject* pObj = mpTheme->ImplGetGalleryObject( aURL );
if( pObj )
nRet = mpTheme->ImplGetGalleryObjectPos( pObj );
}
}
catch( ... )
{
}
}
return nRet;
}
::sal_Int32 SAL_CALL GalleryTheme::insertGraphicByIndex(
const uno::Reference< graphic::XGraphic >& rxGraphic, sal_Int32 nIndex )
throw (lang::WrappedTargetException, uno::RuntimeException, std::exception)
{
const SolarMutexGuard aGuard;
sal_Int32 nRet = -1;
if( mpTheme )
{
try
{
const Graphic aGraphic( rxGraphic );
nIndex = ::std::max( ::std::min( nIndex, getCount() ), sal_Int32( 0 ) );
if( mpTheme->InsertGraphic( aGraphic, nIndex ) )
nRet = nIndex;
}
catch( ... )
{
}
}
return nRet;
}
::sal_Int32 SAL_CALL GalleryTheme::insertDrawingByIndex(
const uno::Reference< lang::XComponent >& Drawing, sal_Int32 nIndex )
throw (lang::WrappedTargetException, uno::RuntimeException, std::exception)
{
const SolarMutexGuard aGuard;
sal_Int32 nRet = -1;
if( mpTheme )
{
GalleryDrawingModel* pModel = GalleryDrawingModel::getImplementation( Drawing );
if( pModel && pModel->GetDoc() && dynamic_cast<const FmFormModel*>(pModel->GetDoc()) != nullptr )
{
// Here we're inserting something that's already a gallery theme drawing
nIndex = ::std::max( ::std::min( nIndex, getCount() ), sal_Int32( 0 ) );
if( mpTheme->InsertModel( *static_cast< FmFormModel* >( pModel->GetDoc() ), nIndex ) )
nRet = nIndex;
}
else if (!pModel)
{
// #i80184# Try to do the right thing and make a Gallery drawing out
// of an ordinary Drawing if possible.
try
{
uno::Reference< drawing::XDrawPagesSupplier > xDrawPagesSupplier( Drawing, uno::UNO_QUERY_THROW );
uno::Reference< drawing::XDrawPages > xDrawPages( xDrawPagesSupplier->getDrawPages(), uno::UNO_QUERY_THROW );
uno::Reference< drawing::XDrawPage > xPage( xDrawPages->getByIndex( 0 ), uno::UNO_QUERY_THROW );
SvxDrawPage* pUnoPage = xPage.is() ? SvxDrawPage::getImplementation( xPage ) : nullptr;
SdrModel* pOrigModel = pUnoPage ? pUnoPage->GetSdrPage()->GetModel() : nullptr;
SdrPage* pOrigPage = pUnoPage ? pUnoPage->GetSdrPage() : nullptr;
if (pOrigPage && pOrigModel)
{
FmFormModel* pTmpModel = new FmFormModel(&pOrigModel->GetItemPool());
SdrPage* pNewPage = pOrigPage->Clone();
pTmpModel->InsertPage(pNewPage, 0);
uno::Reference< lang::XComponent > xDrawing( new GalleryDrawingModel( pTmpModel ) );
pTmpModel->setUnoModel( uno::Reference< uno::XInterface >::query( xDrawing ) );
nRet = insertDrawingByIndex( xDrawing, nIndex );
return nRet;
}
}
catch (...)
{
}
}
}
return nRet;
}
void SAL_CALL GalleryTheme::removeByIndex( sal_Int32 nIndex )
throw (lang::IndexOutOfBoundsException, uno::RuntimeException, std::exception)
{
const SolarMutexGuard aGuard;
if( mpTheme )
{
if( ( nIndex < 0 ) || ( nIndex >= getCount() ) )
throw lang::IndexOutOfBoundsException();
else
mpTheme->RemoveObject( nIndex );
}
}
void GalleryTheme::Notify( SfxBroadcaster&, const SfxHint& rHint )
{
const SolarMutexGuard aGuard;
const GalleryHint& rGalleryHint = static_cast< const GalleryHint& >( rHint );
switch( rGalleryHint.GetType() )
{
case( GalleryHintType::CLOSE_THEME ):
{
DBG_ASSERT( !mpTheme || mpGallery, "Theme is living without Gallery" );
implReleaseItems( nullptr );
if( mpGallery && mpTheme )
{
mpGallery->ReleaseTheme( mpTheme, *this );
mpTheme = nullptr;
}
}
break;
case( GalleryHintType::CLOSE_OBJECT ):
{
GalleryObject* pObj = reinterpret_cast< GalleryObject* >( rGalleryHint.GetData1() );
if( pObj )
implReleaseItems( pObj );
}
break;
default:
break;
}
}
void GalleryTheme::implReleaseItems( GalleryObject* pObj )
{
const SolarMutexGuard aGuard;
for( GalleryItemList::iterator aIter = maItemList.begin(); aIter != maItemList.end(); )
{
if( !pObj || ( (*aIter)->implGetObject() == pObj ) )
{
(*aIter)->implSetInvalid();
aIter = maItemList.erase( aIter );
}
else
++aIter;
}
}
void GalleryTheme::implRegisterGalleryItem( ::unogallery::GalleryItem& rItem )
{
const SolarMutexGuard aGuard;
// DBG_ASSERT( maItemList.find( &rItem ) == maItemList.end(), "Item already registered" );
maItemList.push_back( &rItem );
}
void GalleryTheme::implDeregisterGalleryItem( ::unogallery::GalleryItem& rItem )
{
const SolarMutexGuard aGuard;
// DBG_ASSERT( maItemList.find( &rItem ) != maItemList.end(), "Item is not registered" );
maItemList.remove( &rItem );
}
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */