aboutsummaryrefslogtreecommitdiff
path: root/src/template/gnunet-service-template.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/template/gnunet-service-template.c')
-rw-r--r--src/template/gnunet-service-template.c87
1 files changed, 87 insertions, 0 deletions
diff --git a/src/template/gnunet-service-template.c b/src/template/gnunet-service-template.c
new file mode 100644
index 000000000..c43d681d7
--- /dev/null
+++ b/src/template/gnunet-service-template.c
@@ -0,0 +1,87 @@
1/*
2 This file is part of GNUnet.
3 (C) 2009 Christian Grothoff (and other contributing authors)
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 2, 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., 59 Temple Place - Suite 330,
18 Boston, MA 02111-1307, USA.
19*/
20
21/**
22 * @file template/gnunet-service-template.c
23 * @brief program that tracks template
24 * @author Christian Grothoff
25 */
26#include "platform.h"
27#include "gnunet_getopt_lib.h"
28#include "gnunet_service_lib.h"
29
30/**
31 * Do cleanup here.
32 *
33 * @param cls closure
34 * @param cfg configuration to use
35 */
36static void
37finish (void *cls, struct GNUNET_CONFIGURATION_Handle *cfg)
38{
39 /* FIXME */
40}
41
42
43/**
44 * List of handlers for the messages understood by this
45 * service.
46 */
47static struct GNUNET_SERVER_MessageHandler handlers[] = {
48 /* FIXME: add handlers here! */
49 {NULL, NULL, 0, 0}
50};
51
52/**
53 * Process template requests.
54 *
55 * @param cls closure
56 * @param sched scheduler to use
57 * @param server the initialized server
58 * @param cfg configuration to use
59 */
60static void
61run (void *cls,
62 struct GNUNET_SCHEDULER_Handle *sched,
63 struct GNUNET_SERVER_Handle *server,
64 struct GNUNET_CONFIGURATION_Handle *cfg)
65{
66 /* FIXME: do setup here */
67 GNUNET_SERVER_add_handlers (server, handlers);
68}
69
70
71/**
72 * The main function for the template service.
73 *
74 * @param argc number of arguments from the command line
75 * @param argv command line arguments
76 * @return 0 ok, 1 on error
77 */
78int
79main (int argc, char *const *argv)
80{
81 return (GNUNET_OK ==
82 GNUNET_SERVICE_run (argc,
83 argv,
84 "template", &run, NULL, &finish, NULL)) ? 0 : 1;
85}
86
87/* end of gnunet-service-template.c */