/* -*- 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 .
*/
/*
* This file is part of LibreOffice published API .
*/
#ifndef INCLUDED_RTL_BOOTSTRAP_HXX
#define INCLUDED_RTL_BOOTSTRAP_HXX
#include "sal/config.h"
#include <cstddef>
#include "rtl/ustring.hxx"
#include "rtl/bootstrap.h"
namespace rtl
{
class Bootstrap
{
void * _handle;
Bootstrap( Bootstrap const & ) SAL_DELETED_FUNCTION;
Bootstrap & operator = ( Bootstrap const & ) SAL_DELETED_FUNCTION;
public :
/**
* @ see rtl_bootstrap_setIniFileName ( )
*/
static inline void SAL_CALL setIniFilename( const ::rtl::OUString &sFileUri );
/** Retrieves a bootstrap parameter
@ param sName name of the bootstrap value . case insensitive .
@ param [ out ] outValue On success contains the value , otherwise
an empty string .
@ return false , if no value could be retrieved , otherwise true
@ see rtl_bootstrap_get ( )
*/
static inline bool get(
const ::rtl::OUString &sName,
::rtl::OUString &outValue );
/** Retrieves a bootstrap parameter
@ param sName name of the bootstrap value . case insensitive .
@ param [ out ] outValue Contains the value associated with < code > sName < / code > .
@ param aDefault if none of the other methods retrieved a value ,
< code > outValue < / code > is assigned to < code > aDefault < / code > .
@ see rtl_bootstrap_get ( )
*/
static inline void get(
const ::rtl::OUString &sName,
::rtl::OUString &outValue,
const ::rtl::OUString &aDefault );
/** Sets a bootstrap parameter.
@ param name
name of bootstrap parameter
@ param value
value of bootstrap parameter
@ see rtl_bootstrap_set ( )
*/
static inline void set( ::rtl::OUString const & name, ::rtl::OUString const & value );
/** default ctor.
*/
inline Bootstrap();
/** Opens a bootstrap argument container
@ see rtl_bootstrap_args_open ( )
*/
inline Bootstrap(const rtl::OUString & iniName);
/** Closes a bootstrap argument container
@ see rtl_bootstrap_args_close ( )
*/
inline ~Bootstrap();
/** 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 ( )
*/
inline bool getFrom(const ::rtl::OUString &sName,
::rtl::OUString &outValue) const ;
/** 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 ( )
*/
inline void getFrom(const ::rtl::OUString &sName,
::rtl::OUString &outValue,
const ::rtl::OUString &aDefault) const ;
/** Retrieves the name of the underlying ini-file.
@ see rtl_bootstrap_get_iniName_from_handle ( )
*/
inline void getIniName(::rtl::OUString & iniName) const ;
/** Expands a macro using bootstrap variables.
@ param [ in , out ] macro The macro to be expanded
*/
void expandMacrosFrom( ::rtl::OUString & macro ) const
{ rtl_bootstrap_expandMacros_from_handle( _handle, ¯o.pData ); }
/** Expands a macro using default bootstrap variables.
@ param [ in , out ] macro The macro to be expanded
*/
static void expandMacros( ::rtl::OUString & macro )
{ rtl_bootstrap_expandMacros( ¯o.pData ); }
/** Provides the bootstrap internal handle.
@ return bootstrap handle
*/
rtlBootstrapHandle getHandle() const
{ return _handle; }
/** Escapes special characters ("$" and "\").
@ param value
an arbitrary value
@ return
the given value , with all occurrences of special characters ( " $ " and
" \ " ) escaped
@ since UDK 3 . 2 . 9
*/
static inline ::rtl::OUString encode( ::rtl::OUString const & value );
};
// IMPLEMENTATION
inline void Bootstrap::setIniFilename( const ::rtl::OUString &sFile )
{
rtl_bootstrap_setIniFileName( sFile.pData );
}
inline bool Bootstrap::get( const ::rtl::OUString &sName,
::rtl::OUString & outValue )
{
return rtl_bootstrap_get( sName.pData , &(outValue.pData) , NULL );
}
inline void Bootstrap::get( const ::rtl::OUString &sName,
::rtl::OUString & outValue,
const ::rtl::OUString & sDefault )
{
rtl_bootstrap_get( sName.pData , &(outValue.pData) , sDefault.pData );
}
inline void Bootstrap::set( ::rtl::OUString const & name, ::rtl::OUString const & value )
{
rtl_bootstrap_set( name.pData, value.pData );
}
inline Bootstrap::Bootstrap()
{
_handle = NULL;
}
inline Bootstrap::Bootstrap(const rtl::OUString & iniName)
{
if (!iniName.isEmpty())
_handle = rtl_bootstrap_args_open(iniName.pData);
else
_handle = NULL;
}
inline Bootstrap::~Bootstrap()
{
rtl_bootstrap_args_close(_handle);
}
inline bool Bootstrap::getFrom(const ::rtl::OUString &sName,
::rtl::OUString &outValue) const
{
return rtl_bootstrap_get_from_handle(_handle, sName.pData, &outValue.pData, NULL);
}
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);
}
inline ::rtl::OUString Bootstrap::encode( ::rtl::OUString const & value )
{
::rtl::OUString encoded;
rtl_bootstrap_encode(value.pData, &encoded.pData);
return encoded;
}
}
#endif
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
Messung V0.5 in Prozent C=92 H=100 G=95
¤ Dauer der Verarbeitung: 0.3 Sekunden
¤
*© Formatika GbR, Deutschland