2 This file is part of GNUnet.
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.
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.
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.
22 * @file peerstore/gnunet-peerstore.c
23 * @brief peerstore tool
24 * @author Omar Tarabai
27 #include "gnunet_util_lib.h"
28 #include "gnunet_peerstore_service.h"
33 * Handle to PEERSTORE service
35 static struct GNUNET_PEERSTORE_Handle *peerstore_handle;
44 shutdown_task (void *cls)
46 if (NULL != peerstore_handle)
48 GNUNET_PEERSTORE_disconnect (peerstore_handle, GNUNET_YES);
49 peerstore_handle = NULL;
55 * Main function that will be run by the scheduler.
58 * @param args remaining command-line arguments
59 * @param cfgfile name of the configuration file used (for saving, can be NULL!)
60 * @param cfg configuration
66 const struct GNUNET_CONFIGURATION_Handle *cfg)
68 GNUNET_SCHEDULER_add_shutdown (&shutdown_task,
70 peerstore_handle = GNUNET_PEERSTORE_connect (cfg);
71 GNUNET_assert (NULL != peerstore_handle);
77 * The main function to peerstore.
79 * @param argc number of arguments from the command line
80 * @param argv command line arguments
81 * @return 0 ok, 1 on error
84 main (int argc, char *const *argv)
86 static const struct GNUNET_GETOPT_CommandLineOption options[] = {
87 GNUNET_GETOPT_OPTION_END
90 GNUNET_PROGRAM_run (argc, argv, "gnunet-peerstore [options [value]]",
91 gettext_noop ("peerstore"), options, &run,
95 /* end of gnunet-peerstore.c */