161 lines
5.3 KiB
C++
161 lines
5.3 KiB
C++
/*************************************************************************
|
|
*
|
|
* $RCSfile: current_context.hxx,v $
|
|
*
|
|
* $Revision: 1.7 $
|
|
*
|
|
* last change: $Author: dbo $ $Date: 2001-11-09 09:14:30 $
|
|
*
|
|
* The Contents of this file are made available subject to the terms of
|
|
* either of the following licenses
|
|
*
|
|
* - GNU Lesser General Public License Version 2.1
|
|
* - Sun Industry Standards Source License Version 1.1
|
|
*
|
|
* Sun Microsystems Inc., October, 2000
|
|
*
|
|
* GNU Lesser General Public License Version 2.1
|
|
* =============================================
|
|
* Copyright 2000 by Sun Microsystems, Inc.
|
|
* 901 San Antonio Road, Palo Alto, CA 94303, USA
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License version 2.1, as published by the Free Software Foundation.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
|
* MA 02111-1307 USA
|
|
*
|
|
*
|
|
* Sun Industry Standards Source License Version 1.1
|
|
* =================================================
|
|
* The contents of this file are subject to the Sun Industry Standards
|
|
* Source License Version 1.1 (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.openoffice.org/license.html.
|
|
*
|
|
* Software provided under this License is provided on an "AS IS" basis,
|
|
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
|
|
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
|
|
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
|
|
* See the License for the specific provisions governing your rights and
|
|
* obligations concerning the Software.
|
|
*
|
|
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
|
|
*
|
|
* Copyright: 2000 by Sun Microsystems, Inc.
|
|
*
|
|
* All Rights Reserved.
|
|
*
|
|
* Contributor(s): _______________________________________
|
|
*
|
|
*
|
|
************************************************************************/
|
|
#ifndef _UNO_CURRENT_CONTEXT_HXX_
|
|
#define _UNO_CURRENT_CONTEXT_HXX_
|
|
|
|
#include <uno/current_context.h>
|
|
|
|
#include <com/sun/star/uno/XCurrentContext.hpp>
|
|
|
|
|
|
namespace com
|
|
{
|
|
namespace sun
|
|
{
|
|
namespace star
|
|
{
|
|
namespace uno
|
|
{
|
|
|
|
/** Getting the current context.
|
|
@attention
|
|
Don't spread the returned interface around to other threads. Every thread has its own
|
|
current context.
|
|
|
|
@return current context or null ref, if none is set
|
|
*/
|
|
inline Reference< XCurrentContext > SAL_CALL getCurrentContext()
|
|
SAL_THROW( () )
|
|
{
|
|
Reference< XCurrentContext > xRet;
|
|
::rtl::OUString aEnvTypeName( RTL_CONSTASCII_USTRINGPARAM(CPPU_CURRENT_LANGUAGE_BINDING_NAME) );
|
|
::uno_getCurrentContext( (void **)&xRet, aEnvTypeName.pData, 0 );
|
|
return xRet;
|
|
}
|
|
/** Setting the current context.
|
|
|
|
@param xContext current context to be set
|
|
@return true, if context has been successfully set
|
|
*/
|
|
inline bool SAL_CALL setCurrentContext(
|
|
Reference< XCurrentContext > const & xContext )
|
|
SAL_THROW( () )
|
|
{
|
|
::rtl::OUString aEnvTypeName( RTL_CONSTASCII_USTRINGPARAM(CPPU_CURRENT_LANGUAGE_BINDING_NAME) );
|
|
return (::uno_setCurrentContext( xContext.get(), aEnvTypeName.pData, 0 ) != sal_False);
|
|
}
|
|
|
|
/** Objects of this class are used for applying a current context until they are destructed, i.e.
|
|
the ctor of this class saves the previous and sets the given context while the dtor restores
|
|
the previous one upon destruction.
|
|
*/
|
|
class ContextLayer
|
|
{
|
|
/** this C++ environment type name.
|
|
@internal
|
|
*/
|
|
::rtl::OUString m_aEnvTypeName;
|
|
/** previous context
|
|
@internal
|
|
*/
|
|
Reference< XCurrentContext > m_xPreviousContext;
|
|
|
|
public:
|
|
/** Constructor: Saves the previous context and sets the new (given) one.
|
|
|
|
@param xNewContext new context to be set
|
|
*/
|
|
inline ContextLayer(
|
|
Reference< XCurrentContext > const & xNewContext = Reference< XCurrentContext >() )
|
|
SAL_THROW( () );
|
|
/** Destructor: restores the previous context.
|
|
*/
|
|
inline ~ContextLayer() SAL_THROW( () );
|
|
|
|
/** Gets the previously set context.
|
|
|
|
@return the previously set context
|
|
*/
|
|
inline Reference< XCurrentContext > SAL_CALL getPreviousContext() SAL_THROW( () )
|
|
{ return m_xPreviousContext; }
|
|
};
|
|
//__________________________________________________________________________________________________
|
|
inline ContextLayer::ContextLayer( Reference< XCurrentContext > const & xNewContext )
|
|
SAL_THROW( () )
|
|
: m_aEnvTypeName( RTL_CONSTASCII_USTRINGPARAM(CPPU_CURRENT_LANGUAGE_BINDING_NAME) )
|
|
{
|
|
::uno_getCurrentContext( (void **)&m_xPreviousContext, m_aEnvTypeName.pData, 0 );
|
|
::uno_setCurrentContext( xNewContext.get(), m_aEnvTypeName.pData, 0 );
|
|
}
|
|
//__________________________________________________________________________________________________
|
|
inline ContextLayer::~ContextLayer()
|
|
SAL_THROW( () )
|
|
{
|
|
::uno_setCurrentContext( m_xPreviousContext.get(), m_aEnvTypeName.pData, 0 );
|
|
}
|
|
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
#endif
|