1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
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 .
19 #ifndef _CPPUHELPER_WEAKAGG_HXX_
20 #define _CPPUHELPER_WEAKAGG_HXX_
22 #include <cppuhelper/weak.hxx>
23 #include <com/sun/star/uno/XAggregation.hpp>
24 #include "cppuhelperdllapi.h"
30 /** Base class to implement an UNO object supporting weak references, i.e. the object can be held
31 weakly (by a ::com::sun::star::uno::WeakReference) and aggregation, i.e. the object can be
32 aggregated by another (delegator).
33 This implementation copes with reference counting. Upon last release(), the virtual dtor
37 Inherit from this class and delegate acquire()/ release() calls. Re-implement
38 XAggregation::queryInterface().
40 class CPPUHELPER_DLLPUBLIC OWeakAggObject
41 : public ::cppu::OWeakObject
42 , public ::com::sun::star::uno::XAggregation
45 /** Constructor. No delegator set.
47 inline OWeakAggObject() SAL_THROW(())
50 /** If a delegator is set, then the delegators gets acquired. Otherwise call is delegated to
51 base class ::cppu::OWeakObject.
53 virtual void SAL_CALL
acquire() throw();
54 /** If a delegator is set, then the delegators gets released. Otherwise call is delegated to
55 base class ::cppu::OWeakObject.
57 virtual void SAL_CALL
release() throw();
58 /** If a delegator is set, then the delegator is queried for the demanded interface. If the
59 delegator cannot provide the demanded interface, it calls queryAggregation() on its
62 @param rType demanded interface type
63 @return demanded type or empty any
64 @see queryAggregation.
66 virtual ::com::sun::star::uno::Any SAL_CALL
queryInterface( const ::com::sun::star::uno::Type
& rType
)
67 throw(::com::sun::star::uno::RuntimeException
);
69 /** Set the delegator. The delegator member reference is a weak reference.
71 @param Delegator the object that delegate its queryInterface to this aggregate.
73 virtual void SAL_CALL
setDelegator( const ::com::sun::star::uno::Reference
< ::com::sun::star::uno::XInterface
> & Delegator
)
74 throw(::com::sun::star::uno::RuntimeException
);
75 /** Called by the delegator or queryInterface. Re-implement this method instead of
80 virtual ::com::sun::star::uno::Any SAL_CALL
queryAggregation( const ::com::sun::star::uno::Type
& rType
)
81 throw(::com::sun::star::uno::RuntimeException
);
84 /** Virtual dtor. Called when reference count is 0.
87 Despite the fact that a RuntimeException is allowed to be thrown, you must not throw any
88 exception upon destruction!
90 virtual ~OWeakAggObject() SAL_THROW( (::com::sun::star::uno::RuntimeException
) );
92 /** weak reference to delegator.
94 ::com::sun::star::uno::WeakReferenceHelper xDelegator
;
96 OWeakAggObject( const OWeakAggObject
& rObj
) SAL_THROW(());
97 OWeakAggObject
& operator = ( const OWeakAggObject
& rObj
) SAL_THROW(());
104 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */