2010-10-14 08:30:07 +02:00
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
2001-05-17 07:55:02 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2008-04-10 09:36:57 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
2001-05-17 07:55:02 +00:00
|
|
|
*
|
2010-02-12 15:01:35 +01:00
|
|
|
* Copyright 2000, 2010 Oracle and/or its affiliates.
|
2001-05-17 07:55:02 +00:00
|
|
|
*
|
2008-04-10 09:36:57 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2001-05-17 07:55:02 +00:00
|
|
|
*
|
2008-04-10 09:36:57 +00:00
|
|
|
* This file is part of OpenOffice.org.
|
2001-05-17 07:55:02 +00:00
|
|
|
*
|
2008-04-10 09:36:57 +00:00
|
|
|
* OpenOffice.org is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Lesser General Public License version 3
|
|
|
|
* only, as published by the Free Software Foundation.
|
2001-05-17 07:55:02 +00:00
|
|
|
*
|
2008-04-10 09:36:57 +00:00
|
|
|
* OpenOffice.org 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 version 3 for more details
|
|
|
|
* (a copy is included in the LICENSE file that accompanied this code).
|
2001-05-17 07:55:02 +00:00
|
|
|
*
|
2008-04-10 09:36:57 +00:00
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* version 3 along with OpenOffice.org. If not, see
|
|
|
|
* <http://www.openoffice.org/license.html>
|
|
|
|
* for a copy of the LGPLv3 License.
|
2001-05-17 07:55:02 +00:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
#ifndef _RTL_BOOTSTRAP_HXX_
|
|
|
|
#define _RTL_BOOTSTRAP_HXX_
|
|
|
|
#include <rtl/ustring.hxx>
|
|
|
|
#include <rtl/bootstrap.h>
|
|
|
|
|
|
|
|
namespace rtl
|
|
|
|
{
|
|
|
|
class Bootstrap
|
|
|
|
{
|
2001-08-30 10:51:36 +00:00
|
|
|
void * _handle;
|
2002-09-18 07:34:32 +00:00
|
|
|
|
|
|
|
inline Bootstrap( Bootstrap const & ); // not impl
|
|
|
|
inline Bootstrap & operator = ( Bootstrap const & ); // not impl
|
|
|
|
|
2001-05-17 07:55:02 +00:00
|
|
|
public:
|
|
|
|
/**
|
2012-03-22 09:57:36 +00:00
|
|
|
* @see rtl_bootstrap_setIniFileName()
|
2001-05-17 07:55:02 +00:00
|
|
|
*/
|
2012-03-22 09:57:36 +00:00
|
|
|
static inline void SAL_CALL setIniFilename( const ::rtl::OUString &sFileUri );
|
2001-05-17 07:55:02 +00:00
|
|
|
|
2001-10-24 09:51:08 +00:00
|
|
|
/** Retrieves a bootstrap parameter
|
2001-05-17 07:55:02 +00:00
|
|
|
@param sName name of the bootstrap value. case insensitive.
|
|
|
|
@param outValue (out parameter). On success contains the value, otherwise
|
|
|
|
an empty string.
|
|
|
|
@return sal_False, if no value could be retrieved, otherwise sal_True
|
2001-10-24 09:51:08 +00:00
|
|
|
@see rtl_bootstrap_get()
|
2001-05-17 07:55:02 +00:00
|
|
|
*/
|
|
|
|
static inline sal_Bool get(
|
|
|
|
const ::rtl::OUString &sName,
|
|
|
|
::rtl::OUString &outValue );
|
|
|
|
|
2001-10-24 09:51:08 +00:00
|
|
|
/** Retrieves a bootstrap parameter
|
|
|
|
|
2001-05-17 07:55:02 +00:00
|
|
|
@param sName name of the bootstrap value. case insensitive.
|
|
|
|
@param outValue (out parameter). Contains the value associated with sName.
|
|
|
|
@param aDefault if none of the other methods retrieved a value, outValue
|
|
|
|
is assigned to a Default.
|
|
|
|
|
2001-10-24 09:51:08 +00:00
|
|
|
@see rtl_bootstrap_get()
|
2001-05-17 07:55:02 +00:00
|
|
|
*/
|
|
|
|
static inline void get(
|
|
|
|
const ::rtl::OUString &sName,
|
|
|
|
::rtl::OUString &outValue,
|
|
|
|
const ::rtl::OUString &aDefault );
|
2001-08-30 10:51:36 +00:00
|
|
|
|
2002-10-21 14:08:20 +00:00
|
|
|
/** Sets a bootstrap parameter.
|
2001-08-30 10:51:36 +00:00
|
|
|
|
2012-01-05 19:40:38 +01:00
|
|
|
@param name
|
2002-10-21 14:08:20 +00:00
|
|
|
name of bootstrap parameter
|
2012-01-05 19:40:38 +01:00
|
|
|
@param value
|
2002-10-21 14:08:20 +00:00
|
|
|
value of bootstrap parameter
|
|
|
|
|
|
|
|
@see rtl_bootstrap_set()
|
|
|
|
*/
|
|
|
|
static inline void set( ::rtl::OUString const & name, ::rtl::OUString const & value )
|
2012-01-26 16:00:09 +01:00
|
|
|
SAL_THROW(());
|
2002-10-21 14:08:20 +00:00
|
|
|
|
|
|
|
/** default ctor.
|
|
|
|
*/
|
2001-08-30 10:51:36 +00:00
|
|
|
inline Bootstrap();
|
2001-10-24 09:51:08 +00:00
|
|
|
|
|
|
|
/** Opens a bootstrap argment container
|
|
|
|
@see rtl_bootstrap_args_open()
|
|
|
|
*/
|
2001-08-30 10:51:36 +00:00
|
|
|
inline Bootstrap(const OUString & iniName);
|
2001-10-24 09:51:08 +00:00
|
|
|
|
|
|
|
/** Closes a bootstrap argument container
|
|
|
|
@see rtl_bootstrap_args_close()
|
|
|
|
*/
|
2001-08-30 10:51:36 +00:00
|
|
|
inline ~Bootstrap();
|
|
|
|
|
2001-10-24 09:51:08 +00:00
|
|
|
/** Retrieves a bootstrap argument.
|
|
|
|
|
|
|
|
It is first tried to retrieve the value via the global function
|
|
|
|
and second via the special bootstrap container.
|
|
|
|
@see rtl_bootstrap_get_from_handle()
|
|
|
|
*/
|
|
|
|
|
2001-08-30 10:51:36 +00:00
|
|
|
inline sal_Bool getFrom(const ::rtl::OUString &sName,
|
|
|
|
::rtl::OUString &outValue) const;
|
|
|
|
|
2001-10-24 09:51:08 +00:00
|
|
|
/** Retrieves a bootstrap argument.
|
2001-08-30 10:51:36 +00:00
|
|
|
|
2001-10-24 09:51:08 +00:00
|
|
|
It is first tried to retrieve the value via the global function
|
|
|
|
and second via the special bootstrap container.
|
|
|
|
@see rtl_bootstrap_get_from_handle()
|
|
|
|
*/
|
2001-08-30 10:51:36 +00:00
|
|
|
inline void getFrom(const ::rtl::OUString &sName,
|
|
|
|
::rtl::OUString &outValue,
|
|
|
|
const ::rtl::OUString &aDefault) const;
|
|
|
|
|
2001-10-24 09:51:08 +00:00
|
|
|
/** Retrieves the name of the underlying ini-file.
|
|
|
|
@see rtl_bootstrap_get_iniName_from_handle()
|
|
|
|
*/
|
2001-08-30 10:51:36 +00:00
|
|
|
inline void getIniName(::rtl::OUString & iniName) const;
|
|
|
|
|
2002-04-26 15:25:37 +00:00
|
|
|
/** Expands a macro using bootstrap variables.
|
|
|
|
|
|
|
|
@param macro [inout] The macro to be expanded
|
|
|
|
*/
|
2012-01-26 16:00:09 +01:00
|
|
|
inline void expandMacrosFrom( ::rtl::OUString & macro ) const SAL_THROW(())
|
2002-04-26 15:25:37 +00:00
|
|
|
{ rtl_bootstrap_expandMacros_from_handle( _handle, ¯o.pData ); }
|
|
|
|
|
|
|
|
/** Expands a macro using default bootstrap variables.
|
|
|
|
|
|
|
|
@param macro [inout] The macro to be expanded
|
|
|
|
*/
|
2012-01-26 16:00:09 +01:00
|
|
|
static inline void expandMacros( ::rtl::OUString & macro ) SAL_THROW(())
|
2002-04-26 15:25:37 +00:00
|
|
|
{ rtl_bootstrap_expandMacros( ¯o.pData ); }
|
|
|
|
|
|
|
|
/** Provides the bootstrap internal handle.
|
|
|
|
|
|
|
|
@return bootstrap handle
|
|
|
|
*/
|
2012-01-26 16:00:09 +01:00
|
|
|
inline rtlBootstrapHandle getHandle() const SAL_THROW(())
|
2002-04-26 15:25:37 +00:00
|
|
|
{ return _handle; }
|
2008-06-09 11:46:33 +00:00
|
|
|
|
|
|
|
/** Escapes special characters ("$" and "\").
|
|
|
|
|
|
|
|
@param value
|
|
|
|
an arbitrary value
|
|
|
|
|
|
|
|
@return
|
2010-12-05 19:11:58 +00:00
|
|
|
the given value, with all occurrences of special characters ("$" and
|
2008-06-09 11:46:33 +00:00
|
|
|
"\") escaped
|
|
|
|
|
|
|
|
@since UDK 3.2.9
|
|
|
|
*/
|
|
|
|
static inline ::rtl::OUString encode( ::rtl::OUString const & value )
|
2012-01-26 16:00:09 +01:00
|
|
|
SAL_THROW(());
|
2001-05-17 07:55:02 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------------
|
|
|
|
// IMPLEMENTATION
|
|
|
|
//----------------------------------------------------------------------------
|
|
|
|
inline void Bootstrap::setIniFilename( const ::rtl::OUString &sFile )
|
|
|
|
{
|
|
|
|
rtl_bootstrap_setIniFileName( sFile.pData );
|
|
|
|
}
|
|
|
|
|
|
|
|
inline sal_Bool Bootstrap::get( const ::rtl::OUString &sName,
|
|
|
|
::rtl::OUString & outValue )
|
|
|
|
{
|
|
|
|
return rtl_bootstrap_get( sName.pData , &(outValue.pData) , 0 );
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void Bootstrap::get( const ::rtl::OUString &sName,
|
|
|
|
::rtl::OUString & outValue,
|
|
|
|
const ::rtl::OUString & sDefault )
|
|
|
|
{
|
|
|
|
rtl_bootstrap_get( sName.pData , &(outValue.pData) , sDefault.pData );
|
|
|
|
}
|
2001-08-30 10:51:36 +00:00
|
|
|
|
2002-10-21 14:08:20 +00:00
|
|
|
inline void Bootstrap::set( ::rtl::OUString const & name, ::rtl::OUString const & value )
|
2012-01-26 16:00:09 +01:00
|
|
|
SAL_THROW(())
|
2002-10-21 14:08:20 +00:00
|
|
|
{
|
|
|
|
rtl_bootstrap_set( name.pData, value.pData );
|
|
|
|
}
|
|
|
|
|
2001-08-30 10:51:36 +00:00
|
|
|
inline Bootstrap::Bootstrap()
|
|
|
|
{
|
|
|
|
_handle = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline Bootstrap::Bootstrap(const OUString & iniName)
|
|
|
|
{
|
2012-01-23 16:07:18 -02:00
|
|
|
if(!iniName.isEmpty())
|
2001-08-30 10:51:36 +00:00
|
|
|
_handle = rtl_bootstrap_args_open(iniName.pData);
|
|
|
|
|
|
|
|
else
|
|
|
|
_handle = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline Bootstrap::~Bootstrap()
|
|
|
|
{
|
|
|
|
rtl_bootstrap_args_close(_handle);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
inline sal_Bool Bootstrap::getFrom(const ::rtl::OUString &sName,
|
|
|
|
::rtl::OUString &outValue) const
|
|
|
|
{
|
|
|
|
return rtl_bootstrap_get_from_handle(_handle, sName.pData, &outValue.pData, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void Bootstrap::getFrom(const ::rtl::OUString &sName,
|
|
|
|
::rtl::OUString &outValue,
|
|
|
|
const ::rtl::OUString &aDefault) const
|
|
|
|
{
|
|
|
|
rtl_bootstrap_get_from_handle(_handle, sName.pData, &outValue.pData, aDefault.pData);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void Bootstrap::getIniName(::rtl::OUString & iniName) const
|
|
|
|
{
|
|
|
|
rtl_bootstrap_get_iniName_from_handle(_handle, &iniName.pData);
|
|
|
|
}
|
|
|
|
|
2008-06-09 11:46:33 +00:00
|
|
|
inline ::rtl::OUString Bootstrap::encode( ::rtl::OUString const & value )
|
2012-01-26 16:00:09 +01:00
|
|
|
SAL_THROW(())
|
2008-06-09 11:46:33 +00:00
|
|
|
{
|
|
|
|
::rtl::OUString encoded;
|
|
|
|
rtl_bootstrap_encode(value.pData, &encoded.pData);
|
|
|
|
return encoded;
|
|
|
|
}
|
2001-05-17 07:55:02 +00:00
|
|
|
}
|
|
|
|
#endif
|
2010-10-14 08:30:07 +02:00
|
|
|
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|