office-gobmx/include/com/sun/star/uno/Reference.hxx
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

442 lines
12 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 .
*/
#ifndef INCLUDED_COM_SUN_STAR_UNO_REFERENCE_HXX
#define INCLUDED_COM_SUN_STAR_UNO_REFERENCE_HXX
#include <sal/config.h>
#include <cstddef>
#include <com/sun/star/uno/Reference.h>
#include <com/sun/star/uno/RuntimeException.hpp>
#include <com/sun/star/uno/XInterface.hpp>
#include <com/sun/star/uno/Any.hxx>
#include <cppu/cppudllapi.h>
extern "C" CPPU_DLLPUBLIC rtl_uString * SAL_CALL cppu_unsatisfied_iquery_msg(
typelib_TypeDescriptionReference * pType )
SAL_THROW_EXTERN_C();
extern "C" CPPU_DLLPUBLIC rtl_uString * SAL_CALL cppu_unsatisfied_iset_msg(
typelib_TypeDescriptionReference * pType )
SAL_THROW_EXTERN_C();
namespace com
{
namespace sun
{
namespace star
{
namespace uno
{
inline XInterface * BaseReference::iquery(
XInterface * pInterface, const Type & rType )
{
if (pInterface)
{
Any aRet( pInterface->queryInterface( rType ) );
if (typelib_TypeClass_INTERFACE == aRet.pType->eTypeClass)
{
XInterface * pRet = static_cast< XInterface * >( aRet.pReserved );
aRet.pReserved = NULL;
return pRet;
}
}
return NULL;
}
template< class interface_type >
inline XInterface * Reference< interface_type >::iquery(
XInterface * pInterface )
{
return BaseReference::iquery(pInterface, interface_type::static_type());
}
inline XInterface * BaseReference::iquery_throw(
XInterface * pInterface, const Type & rType )
{
XInterface * pQueried = iquery( pInterface, rType );
if (pQueried)
return pQueried;
throw RuntimeException(
::rtl::OUString( cppu_unsatisfied_iquery_msg( rType.getTypeLibType() ), SAL_NO_ACQUIRE ),
Reference< XInterface >( pInterface ) );
}
template< class interface_type >
inline XInterface * Reference< interface_type >::iquery_throw(
XInterface * pInterface )
{
return BaseReference::iquery_throw(
pInterface, interface_type::static_type());
}
template< class interface_type >
inline interface_type * Reference< interface_type >::iset_throw(
interface_type * pInterface )
{
if (pInterface)
{
castToXInterface(pInterface)->acquire();
return pInterface;
}
throw RuntimeException(
::rtl::OUString( cppu_unsatisfied_iset_msg( interface_type::static_type().getTypeLibType() ), SAL_NO_ACQUIRE ),
NULL );
}
template< class interface_type >
inline Reference< interface_type >::~Reference()
{
if (_pInterface)
_pInterface->release();
}
template< class interface_type >
inline Reference< interface_type >::Reference()
{
_pInterface = NULL;
}
template< class interface_type >
inline Reference< interface_type >::Reference( const Reference< interface_type > & rRef )
{
_pInterface = rRef._pInterface;
if (_pInterface)
_pInterface->acquire();
}
#if defined LIBO_INTERNAL_ONLY
template< class interface_type >
inline Reference< interface_type >::Reference( Reference< interface_type > && rRef )
{
_pInterface = rRef._pInterface;
rRef._pInterface = nullptr;
}
#endif
template< class interface_type > template< class derived_type >
inline Reference< interface_type >::Reference(
const Reference< derived_type > & rRef,
typename detail::UpCast< interface_type, derived_type >::t )
{
interface_type * p = rRef.get();
_pInterface = p;
if (_pInterface)
_pInterface->acquire();
}
template< class interface_type >
inline Reference< interface_type >::Reference( interface_type * pInterface )
{
_pInterface = castToXInterface(pInterface);
if (_pInterface)
_pInterface->acquire();
}
template< class interface_type >
inline Reference< interface_type >::Reference( interface_type * pInterface, __sal_NoAcquire )
{
_pInterface = castToXInterface(pInterface);
}
template< class interface_type >
inline Reference< interface_type >::Reference( interface_type * pInterface, UnoReference_NoAcquire )
{
_pInterface = castToXInterface(pInterface);
}
template< class interface_type >
inline Reference< interface_type >::Reference( const BaseReference & rRef, UnoReference_Query )
{
_pInterface = iquery( rRef.get() );
}
template< class interface_type >
inline Reference< interface_type >::Reference( XInterface * pInterface, UnoReference_Query )
{
_pInterface = iquery( pInterface );
}
template< class interface_type >
inline Reference< interface_type >::Reference( const Any & rAny, UnoReference_Query )
{
_pInterface = (typelib_TypeClass_INTERFACE == rAny.pType->eTypeClass
? iquery( static_cast< XInterface * >( rAny.pReserved ) ) : NULL);
}
template< class interface_type >
inline Reference< interface_type >::Reference( const BaseReference & rRef, UnoReference_QueryThrow )
{
_pInterface = iquery_throw( rRef.get() );
}
template< class interface_type >
inline Reference< interface_type >::Reference( XInterface * pInterface, UnoReference_QueryThrow )
{
_pInterface = iquery_throw( pInterface );
}
template< class interface_type >
inline Reference< interface_type >::Reference( const Any & rAny, UnoReference_QueryThrow )
{
_pInterface = iquery_throw( typelib_TypeClass_INTERFACE == rAny.pType->eTypeClass
? static_cast< XInterface * >( rAny.pReserved ) : NULL );
}
template< class interface_type >
inline Reference< interface_type >::Reference( const Reference< interface_type > & rRef, UnoReference_SetThrow )
{
_pInterface = castToXInterface( iset_throw( rRef.get() ) );
}
template< class interface_type >
inline Reference< interface_type >::Reference( interface_type * pInterface, UnoReference_SetThrow )
{
_pInterface = castToXInterface( iset_throw( pInterface ) );
}
template< class interface_type >
inline void Reference< interface_type >::clear()
{
if (_pInterface)
{
XInterface * const pOld = _pInterface;
_pInterface = NULL;
pOld->release();
}
}
template< class interface_type >
inline bool Reference< interface_type >::set(
interface_type * pInterface )
{
if (pInterface)
castToXInterface(pInterface)->acquire();
XInterface * const pOld = _pInterface;
_pInterface = castToXInterface(pInterface);
if (pOld)
pOld->release();
return (NULL != pInterface);
}
template< class interface_type >
inline bool Reference< interface_type >::set(
interface_type * pInterface, __sal_NoAcquire )
{
XInterface * const pOld = _pInterface;
_pInterface = castToXInterface(pInterface);
if (pOld)
pOld->release();
return (NULL != pInterface);
}
template< class interface_type >
inline bool Reference< interface_type >::set(
interface_type * pInterface, UnoReference_NoAcquire )
{
return set( pInterface, SAL_NO_ACQUIRE );
}
template< class interface_type >
inline bool Reference< interface_type >::set(
const Reference< interface_type > & rRef )
{
return set( castFromXInterface( rRef._pInterface ) );
}
template< class interface_type >
inline bool Reference< interface_type >::set(
XInterface * pInterface, UnoReference_Query )
{
return set( castFromXInterface(iquery( pInterface )), SAL_NO_ACQUIRE );
}
template< class interface_type >
inline bool Reference< interface_type >::set(
const BaseReference & rRef, UnoReference_Query )
{
return set( castFromXInterface(iquery( rRef.get() )), SAL_NO_ACQUIRE );
}
template< class interface_type >
inline bool Reference< interface_type >::set(
Any const & rAny, UnoReference_Query )
{
return set(
castFromXInterface(
iquery(
rAny.pType->eTypeClass == typelib_TypeClass_INTERFACE
? static_cast< XInterface * >( rAny.pReserved ) : NULL )),
SAL_NO_ACQUIRE );
}
template< class interface_type >
inline void Reference< interface_type >::set(
XInterface * pInterface, UnoReference_QueryThrow )
{
set( castFromXInterface(iquery_throw( pInterface )), SAL_NO_ACQUIRE );
}
template< class interface_type >
inline void Reference< interface_type >::set(
const BaseReference & rRef, UnoReference_QueryThrow )
{
set( castFromXInterface(iquery_throw( rRef.get() )), SAL_NO_ACQUIRE );
}
template< class interface_type >
inline void Reference< interface_type >::set(
Any const & rAny, UnoReference_QueryThrow )
{
set( castFromXInterface(
iquery_throw(
rAny.pType->eTypeClass == typelib_TypeClass_INTERFACE
? static_cast< XInterface * >( rAny.pReserved ) : NULL )),
SAL_NO_ACQUIRE );
}
template< class interface_type >
inline void Reference< interface_type >::set(
interface_type * pInterface, UnoReference_SetThrow )
{
set( iset_throw( pInterface ), SAL_NO_ACQUIRE );
}
template< class interface_type >
inline void Reference< interface_type >::set(
const Reference< interface_type > & rRef, UnoReference_SetThrow )
{
set( rRef.get(), UNO_SET_THROW );
}
template< class interface_type >
inline Reference< interface_type > & Reference< interface_type >::operator = (
interface_type * pInterface )
{
set( pInterface );
return *this;
}
template< class interface_type >
inline Reference< interface_type > & Reference< interface_type >::operator = (
const Reference< interface_type > & rRef )
{
set( castFromXInterface( rRef._pInterface ) );
return *this;
}
#if defined LIBO_INTERNAL_ONLY
template< class interface_type >
inline Reference< interface_type > & Reference< interface_type >::operator = (
Reference< interface_type > && rRef )
{
if (_pInterface)
_pInterface->release();
_pInterface = rRef._pInterface;
rRef._pInterface = nullptr;
return *this;
}
#endif
template< class interface_type >
inline Reference< interface_type > Reference< interface_type >::query(
const BaseReference & rRef )
{
return Reference< interface_type >(
castFromXInterface(iquery( rRef.get() )), SAL_NO_ACQUIRE );
}
template< class interface_type >
inline Reference< interface_type > Reference< interface_type >::query(
XInterface * pInterface )
{
return Reference< interface_type >(
castFromXInterface(iquery( pInterface )), SAL_NO_ACQUIRE );
}
inline bool BaseReference::operator == ( XInterface * pInterface ) const
{
if (_pInterface == pInterface)
return true;
try
{
// only the query to XInterface must return the same pointer if they belong to same objects
Reference< XInterface > x1( _pInterface, UNO_QUERY );
Reference< XInterface > x2( pInterface, UNO_QUERY );
return (x1._pInterface == x2._pInterface);
}
catch (RuntimeException &)
{
return false;
}
}
inline bool BaseReference::operator < (
const BaseReference & rRef ) const
{
if (_pInterface == rRef._pInterface)
return false;
try
{
// only the query to XInterface must return the same pointer:
Reference< XInterface > x1( _pInterface, UNO_QUERY );
Reference< XInterface > x2( rRef, UNO_QUERY );
return (x1._pInterface < x2._pInterface);
}
catch (RuntimeException &)
{
return false;
}
}
inline bool BaseReference::operator != ( XInterface * pInterface ) const
{
return (! operator == ( pInterface ));
}
inline bool BaseReference::operator == ( const BaseReference & rRef ) const
{
return operator == ( rRef._pInterface );
}
inline bool BaseReference::operator != ( const BaseReference & rRef ) const
{
return (! operator == ( rRef._pInterface ));
}
}
}
}
}
#endif
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */