GNUnet 0.22.2
gnunet_program_lib.h
Go to the documentation of this file.
1/*
2 This file is part of GNUnet.
3 Copyright (C) 2001-2013 GNUnet e.V.
4
5 GNUnet is free software: you can redistribute it and/or modify it
6 under the terms of the GNU Affero General Public License as published
7 by the Free Software Foundation, either version 3 of the License,
8 or (at your 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 Affero General Public License for more details.
14
15 You should have received a copy of the GNU Affero General Public License
16 along with this program. If not, see <http://www.gnu.org/licenses/>.
17
18 SPDX-License-Identifier: AGPL3.0-or-later
19 */
20
21#if ! defined (__GNUNET_UTIL_LIB_H_INSIDE__)
22#error "Only <gnunet_util_lib.h> can be included directly."
23#endif
24
40#ifndef GNUNET_PROGRAM_LIB_H
41#define GNUNET_PROGRAM_LIB_H
42
43#ifdef __cplusplus
44extern "C"
45{
46#if 0 /* keep Emacsens' auto-indent happy */
47}
48#endif
49#endif
50
51
53#include "gnunet_getopt_lib.h"
55
64typedef void
65(*GNUNET_PROGRAM_Main) (void *cls,
66 char *const *args,
67 const char *cfgfile,
68 const struct GNUNET_CONFIGURATION_Handle *cfg);
69
70
92 int argc,
93 char *const *argv,
94 const char *binaryName,
95 const char *binaryHelp,
98 void *task_cls,
99 int run_without_scheduler);
100
101
121 int argc,
122 char *const *argv,
123 const char *binaryName,
124 const char *binaryHelp,
127 void *task_cls);
128
129
131GNUNET_DAEMON_register (const char *daemon_name,
132 const char *daemon_desc,
134
135
143void
145 int argc,
146 char *const *argv,
148
149#ifndef HAVE_GNUNET_MONOLITH
150#define GNUNET_DAEMON_MAIN(daemon_name, daemon_help, init_cb) \
151 int \
152 main (int argc, \
153 char *const *argv) \
154 { \
155 int ret; \
156 struct GNUNET_GETOPT_CommandLineOption options[] = { \
157 GNUNET_GETOPT_OPTION_END \
158 }; \
159 ret = GNUNET_PROGRAM_run (GNUNET_OS_project_data_gnunet (), \
160 argc, \
161 argv, \
162 daemon_name, \
163 daemon_help, \
164 options, \
165 init_cb, \
166 NULL); \
167 return ret; \
168 }
169#else
170#define GNUNET_DAEMON_MAIN(daemon_name, daemon_help, init_cb) \
171 int init (void); \
172 int __attribute__ ((constructor)) \
173 init (void) \
174 { \
175 return GNUNET_DAEMON_register (daemon_name, \
176 daemon_help, \
177 init_cb); \
178 }
179#endif
180
181
191 int argc,
192 char *const *argv,
194
195
204void
206 int argc,
207 char *const *argv,
209 enum GNUNET_GenericReturnValue with_scheduler);
210
211
212#if 0 /* keep Emacsens' auto-indent happy */
213{
214#endif
215#ifdef __cplusplus
216}
217#endif
218
219/* ifndef GNUNET_PROGRAM_LIB_H */
220#endif
221 /* end of group program */
223 /* end of group addition */
225
226/* end of gnunet_program_lib.h */
struct GNUNET_GETOPT_CommandLineOption options[]
Definition: 002.c:5
static struct GNUNET_CONFIGURATION_Handle * cfg
Our configuration.
Definition: gnunet-arm.c:108
Configuration API.
Command line parsing and –help formatting.
API to schedule computations using continuation passing style.
GNUNET_GenericReturnValue
Named constants for return values.
enum GNUNET_GenericReturnValue GNUNET_DAEMON_register(const char *daemon_name, const char *daemon_desc, GNUNET_PROGRAM_Main task)
Definition: program.c:683
enum GNUNET_GenericReturnValue GNUNET_PROGRAM_run2(const struct GNUNET_OS_ProjectData *pd, int argc, char *const *argv, const char *binaryName, const char *binaryHelp, const struct GNUNET_GETOPT_CommandLineOption *options, GNUNET_PROGRAM_Main task, void *task_cls, int run_without_scheduler)
Run a standard GNUnet command startup sequence (initialize loggers and configuration,...
Definition: program.c:132
void GNUNET_PROGRAM_monolith_main(const struct GNUNET_OS_ProjectData *pd, int argc, char *const *argv, struct GNUNET_CONFIGURATION_Handle *cfg)
Start all services and daemons in a single process.
Definition: program.c:582
void(* GNUNET_PROGRAM_Main)(void *cls, char *const *args, const char *cfgfile, const struct GNUNET_CONFIGURATION_Handle *cfg)
Main function that will be run.
enum GNUNET_GenericReturnValue GNUNET_PROGRAM_run(const struct GNUNET_OS_ProjectData *pd, int argc, char *const *argv, const char *binaryName, const char *binaryHelp, const struct GNUNET_GETOPT_CommandLineOption *options, GNUNET_PROGRAM_Main task, void *task_cls)
Run a standard GNUnet command startup sequence (initialize loggers and configuration,...
Definition: program.c:407
enum GNUNET_GenericReturnValue GNUNET_PROGRAM_conf_and_options(const struct GNUNET_OS_ProjectData *pd, int argc, char *const *argv, struct GNUNET_CONFIGURATION_Handle *cfg)
Create configuration handle from options and configuration file.
Definition: program.c:429
void GNUNET_DAEMON_main(const struct GNUNET_OS_ProjectData *pd, int argc, char *const *argv, struct GNUNET_CONFIGURATION_Handle *cfg, enum GNUNET_GenericReturnValue with_scheduler)
Run the mainloop in a monolithic libgnunet.
Definition: program.c:658
const struct GNUNET_OS_ProjectData * pd
Project data for this configuration object.
Definition of a command line option.
Project-specific data used to help the OS subsystem find installation paths.