2 common commandline code to ctdb test tools
4 Copyright (C) Andrew Tridgell 2007
6 This library is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Lesser General Public
8 License as published by the Free Software Foundation; either
9 version 2 of the License, or (at your option) any later version.
11 This library is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 Lesser General Public License for more details.
16 You should have received a copy of the GNU Lesser General Public
17 License along with this library; if not, write to the Free Software
18 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
22 #include "lib/events/events.h"
23 #include "system/filesys.h"
26 /* Handle common command line options for ctdb test progs
31 const char *transport;
32 const char *myaddress;
42 struct poptOption popt_ctdb_cmdline[] = {
43 { "nlist", 0, POPT_ARG_STRING, &ctdb_cmdline.nlist, 0, "node list file", "filename" },
44 { "listen", 0, POPT_ARG_STRING, &ctdb_cmdline.myaddress, 0, "address to listen on", "address" },
45 { "transport", 0, POPT_ARG_STRING, &ctdb_cmdline.transport, 0, "protocol transport", NULL },
46 { "self-connect", 0, POPT_ARG_NONE, &ctdb_cmdline.self_connect, 0, "enable self connect", "boolean" },
47 { "debug", 'd', POPT_ARG_INT, &LogLevel, 0, "debug level"},
53 startup daemon side of ctdb according to command line options
55 struct ctdb_context *ctdb_cmdline_init(struct event_context *ev)
57 struct ctdb_context *ctdb;
60 if (ctdb_cmdline.nlist == NULL || ctdb_cmdline.myaddress == NULL) {
61 printf("You must provide a node list with --nlist and an address with --listen\n");
68 printf("Failed to init ctdb\n");
72 if (ctdb_cmdline.self_connect) {
73 ctdb_set_flags(ctdb, CTDB_FLAG_SELF_CONNECT);
76 ret = ctdb_set_transport(ctdb, ctdb_cmdline.transport);
78 printf("ctdb_set_transport failed - %s\n", ctdb_errstr(ctdb));
82 /* tell ctdb what address to listen on */
83 ret = ctdb_set_address(ctdb, ctdb_cmdline.myaddress);
85 printf("ctdb_set_address failed - %s\n", ctdb_errstr(ctdb));
89 /* tell ctdb what nodes are available */
90 ret = ctdb_set_nlist(ctdb, ctdb_cmdline.nlist);
92 printf("ctdb_set_nlist failed - %s\n", ctdb_errstr(ctdb));