android: Update app-specific/MIME type icons
[LibreOffice.git] / include / rtl / bootstrap.h
blobe532cd0e3dacf646d87fee73c918f71ca59a2287
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
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 .
21 * This file is part of LibreOffice published API.
23 #ifndef INCLUDED_RTL_BOOTSTRAP_H
24 #define INCLUDED_RTL_BOOTSTRAP_H
26 #include "sal/config.h"
28 #include "rtl/ustring.h"
29 #include "sal/saldllapi.h"
31 #ifdef __cplusplus
32 extern "C" {
33 #endif
35 /**
36 @file
38 The described concept provides a platform independent way to access
39 minimum bootstrap settings for every application by explicitly or
40 implicitly passing the values to the application.
42 <strong>MULTI-LEVEL STRATEGY FOR RETRIEVAL OF BOOTSTRAP VALUES:</strong>
44 The 1st level is tried first. On failure,
45 the next level is tried. Every query starts at the first level again, so
46 that one setting may be taken from the 3rd and one from the 1st level.
48 1st level: explicitly set variables via rtl_bootstrap_set()
50 2nd level: command line arguments. A `-env:SETTINGNAME=value` is given on
51 command line. This allows giving an application a certain setting, even
52 if an ini-file exists (especially useful for e.g. daemons that want to
53 start an executable with dynamical changing settings).
55 3rd level: environment variables. The application tries to get the
56 setting from the environment.
58 4th level: executable ini-file. Every application looks for an ini-file.
59 The filename defaults to `/absolute/path/to/executable[rc|.ini]`
60 without .bin or .exe suffix. The ini-filename can be
61 set by the special command line parameter
62 `-env:INIFILENAME=/absolute/path/to/inifile` at runtime or it may
63 be set at compile time by an API-call.
65 5th level: URE_BOOTSTRAP ini-file. If the bootstrap variable URE_BOOTSTRAP
66 expands to the URL of an ini-file, that ini-file is searched.
68 6th level: default. An application can have some default settings decided
69 at compile time, which allow the application to run even with no
70 deployment settings.
72 If neither of the above levels leads to a successful retrieval of the value
73 (no default possible), the application may fail to start.
75 <strong>NAMING CONVENTIONS</strong>
77 Naming conventions for names of bootstrap values:
78 Names may only include characters, that are allowed characters for
79 environment variables. This excludes '.', ' ', ';', ':' and any non-ascii
80 character. Names are case insensitive.
82 An ini-file is only allowed to have one section, which must be named
83 `[Bootstrap]` with the square brackets.
84 The section may be omitted.
85 The section name does not appear in the name of the corresponding
86 environment variable or commandline arg.
87 Values may be arbitrary unicode strings, they must be encoded in UTF8.
89 <em>Example:</em>
91 in an ini-file:
92 <code>
93 [Sectionname]
94 Name=value
95 </code>
97 as commandline arg:
98 <code>-env:Name=value</code>
100 as environment:
101 - <code>setenv Name value</code>
102 - <code>set Name=value</code>
104 <strong>SPECIAL VARIABLES:</strong>
106 - INIFILENAME<br>
107 This variable allows to set the inifilename. This makes only sense, if the filename
108 is different than the executable file name. It must be given on command line. If it is
109 given the executable ini-file is ignored.
112 /** may be called by an application to set an ini-filename.
114 Must be called before rtl_bootstrap_get(). May not be called twice.
115 If it is never called, the filename is based on the name of the executable,
116 with the suffix ".ini" on Windows or "rc" on Unix.
118 @param pFileUri URL of the inifile with path but WITHOUT suffix (.ini or rc)
120 SAL_DLLPUBLIC void SAL_CALL rtl_bootstrap_setIniFileName( rtl_uString *pFileUri );
123 @param pName
124 The name of the bootstrap setting to be retrieved.
125 @param[out] ppValue
126 Contains always a valid rtl_uString pointer.
127 @param pDefault
128 maybe <code>NULL</code>. If once the default is
129 returned, successive calls always return this
130 default value, even when called with different
131 defaults.
133 @retval sal_True when a value could be retrieved successfully.
134 When a <code>pDefault</code> value is given,
135 the function always returns <code>sal_True</code>.
136 @retval sal_False when none of the 4 methods gave a value.
137 <code>ppValue</code> then contains an empty string.
139 SAL_DLLPUBLIC sal_Bool SAL_CALL rtl_bootstrap_get(
140 rtl_uString *pName, rtl_uString **ppValue, rtl_uString *pDefault );
142 /** Sets a bootstrap parameter.
144 @param pName
145 name of bootstrap parameter
146 @param pValue
147 value of bootstrap parameter
149 SAL_DLLPUBLIC void SAL_CALL rtl_bootstrap_set(
150 rtl_uString * pName, rtl_uString * pValue );
153 typedef void * rtlBootstrapHandle;
156 Opens a bootstrap argument container.
157 @param[in] pIniName The name of the ini-file to use, if <code>NULL</code> defaults
158 to the executables name
159 @return Handle for a bootstrap argument container
161 SAL_DLLPUBLIC rtlBootstrapHandle SAL_CALL rtl_bootstrap_args_open(rtl_uString * pIniName);
164 Closes a bootstrap argument container.
165 @param[in] handle The handle got by rtl_bootstrap_args_open()
167 SAL_DLLPUBLIC void SAL_CALL rtl_bootstrap_args_close(rtlBootstrapHandle handle)
168 SAL_THROW_EXTERN_C();
171 @param[in] handle The handle got by rtl_bootstrap_args_open()
172 @param[in] pName The name of the variable to be retrieved
173 @param[out] ppValue The result of the retrieval. *ppValue may be null in case of failure.
174 @param[in] pDefault The default value for the retrieval, may be <code>NULL</code>
176 @return The status of the retrieval, <code>sal_True</code> on success.
178 SAL_DLLPUBLIC sal_Bool SAL_CALL rtl_bootstrap_get_from_handle(
179 rtlBootstrapHandle handle, rtl_uString *pName, rtl_uString **ppValue, rtl_uString *pDefault);
182 /** Returns the name of the inifile associated with this handle.
184 @param[in] handle The handle got by rtl_bootstrap_args_open()
185 @param[out] ppIniName contains after the call the name of the ini-filename.
187 SAL_DLLPUBLIC void SAL_CALL rtl_bootstrap_get_iniName_from_handle(
188 rtlBootstrapHandle handle, rtl_uString ** ppIniName);
190 /** Expands a macro using bootstrap variables.
192 @param[in] handle The handle got by rtl_bootstrap_args_open()
193 @param[in,out] macro The macro to be expanded
195 SAL_DLLPUBLIC void SAL_CALL rtl_bootstrap_expandMacros_from_handle(
196 rtlBootstrapHandle handle, rtl_uString ** macro );
198 /** Expands a macro using default bootstrap variables.
200 @param[in,out] macro The macro to be expanded
202 SAL_DLLPUBLIC void SAL_CALL rtl_bootstrap_expandMacros(
203 rtl_uString ** macro);
205 /** Escapes special characters ("$" and "\").
207 @param value
208 an arbitrary, non-NULL value
210 @param[out] encoded
211 the given value with all occurrences of special characters ("$" and "\") escaped
213 @since UDK 3.2.9
215 SAL_DLLPUBLIC void SAL_CALL rtl_bootstrap_encode(
216 rtl_uString const * value, rtl_uString ** encoded );
218 #ifdef __cplusplus
220 #endif
222 #endif
224 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */