comparison Resources/Graveyard/Deprecated/Applications/Wasm/StartupParametersBuilder.h @ 1503:553084468225

moving /Deprecated/ to /Resources/Graveyard/Deprecated/
author Sebastien Jodogne <s.jodogne@gmail.com>
date Tue, 30 Jun 2020 11:38:13 +0200
parents Deprecated/Applications/Wasm/StartupParametersBuilder.h@ff8d2e46ac63
children
comparison
equal deleted inserted replaced
1502:e5729dab3f67 1503:553084468225
1 /**
2 * Stone of Orthanc
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics
4 * Department, University Hospital of Liege, Belgium
5 * Copyright (C) 2017-2020 Osimis S.A., Belgium
6 *
7 * This program is free software: you can redistribute it and/or
8 * modify it under the terms of the GNU Affero General Public License
9 * as published by the Free Software Foundation, either version 3 of
10 * the License, or (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Affero General Public License for more details.
16 *
17 * You should have received a copy of the GNU Affero General Public License
18 * along with this program. If not, see <http://www.gnu.org/licenses/>.
19 **/
20
21
22 #pragma once
23
24 #include <boost/program_options.hpp>
25 #include <tuple>
26
27 #if ORTHANC_ENABLE_SDL == 1
28 #error this file shall be included only with the ORTHANC_ENABLE_SDL set to 0
29 #endif
30
31 namespace OrthancStone
32 {
33 // This class is used to generate boost program options from a dico.
34 // In a Wasm context, startup options are passed as URI arguments that
35 // are then passed to this class as a dico.
36 // This class regenerates a fake command-line and parses it to produce
37 // the same output as if the app was started at command-line.
38 class StartupParametersBuilder
39 {
40 typedef std::list<std::tuple<std::string, std::string>> StartupParameters;
41 StartupParameters startupParameters_;
42
43 public:
44
45 void Clear();
46 // Please note that if a parameter is a flag-style one, the value that
47 // is passed should be an empty string
48 void SetStartupParameter(const char* name, const char* value);
49 void GetStartupParameters(
50 boost::program_options::variables_map& parameters_,
51 const boost::program_options::options_description& options);
52 };
53
54 }