expand GNUNET_OS_ProjectData API to also enable de-duplcation of logic for --help
[oweals/gnunet.git] / src / util / configuration_loader.c
1 /*
2      This file is part of GNUnet.
3      Copyright (C) 2006, 2007, 2008, 2009, 2013 GNUnet e.V.
4
5      GNUnet is free software; you can redistribute it and/or modify
6      it under the terms of the GNU General Public License as published
7      by the Free Software Foundation; either version 3, or (at your
8      option) any later version.
9
10      GNUnet is distributed in the hope that it will be useful, but
11      WITHOUT ANY WARRANTY; without even the implied warranty of
12      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13      General Public License for more details.
14
15      You should have received a copy of the GNU General Public License
16      along with GNUnet; see the file COPYING.  If not, write to the
17      Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
18      Boston, MA 02110-1301, USA.
19 */
20
21 /**
22  * @file src/util/configuration_loader.c
23  * @brief configuration loading
24  * @author Christian Grothoff
25  */
26
27 #include "platform.h"
28 #include "gnunet_util_lib.h"
29
30 #define LOG(kind,...) GNUNET_log_from (kind, "util", __VA_ARGS__)
31
32
33 /**
34  * Load configuration (starts with defaults, then loads
35  * system-specific configuration).
36  *
37  * @param cfg configuration to update
38  * @param filename name of the configuration file, NULL to load defaults
39  * @return #GNUNET_OK on success, #GNUNET_SYSERR on error
40  */
41 int
42 GNUNET_CONFIGURATION_load (struct GNUNET_CONFIGURATION_Handle *cfg,
43                            const char *filename)
44 {
45   char *baseconfig;
46
47   if (NULL != (baseconfig = getenv ("GNUNET_BASE_CONFIG")))
48   {
49     baseconfig = GNUNET_strdup (baseconfig);
50   }
51   else
52   {
53     char *ipath;
54
55     ipath = GNUNET_OS_installation_get_path (GNUNET_OS_IPK_DATADIR);
56     if (NULL == ipath)
57       return GNUNET_SYSERR;
58     GNUNET_asprintf (&baseconfig, "%s%s", ipath, "config.d");
59     GNUNET_free (ipath);
60   }
61
62   if (GNUNET_SYSERR ==
63       GNUNET_CONFIGURATION_load_from (cfg,
64                                       baseconfig))
65   {
66     GNUNET_free (baseconfig);
67     return GNUNET_SYSERR;       /* no configuration at all found */
68   }
69   GNUNET_free (baseconfig);
70   if ((NULL != filename) &&
71       (GNUNET_OK != GNUNET_CONFIGURATION_parse (cfg, filename)))
72   {
73     /* specified configuration not found */
74     return GNUNET_SYSERR;
75   }
76   if (((GNUNET_YES !=
77         GNUNET_CONFIGURATION_have_value (cfg, "PATHS", "DEFAULTCONFIG"))) &&
78       (filename != NULL))
79     GNUNET_CONFIGURATION_set_value_string (cfg, "PATHS", "DEFAULTCONFIG",
80                                            filename);
81   return GNUNET_OK;
82 }
83
84 /* end of configuration_loader.c */