From 5fbdce155cd1cb37a85a8d1f8b69364c451f44b4 Mon Sep 17 00:00:00 2001 From: Brian Warner <warner@lothar.com> Date: Sat, 7 Jul 2007 11:17:32 -0700 Subject: [PATCH] runner.py: add --force flag to restart, to restart a not-already-running node --- src/allmydata/scripts/runner.py | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/src/allmydata/scripts/runner.py b/src/allmydata/scripts/runner.py index 379baef7..8b57b17c 100644 --- a/src/allmydata/scripts/runner.py +++ b/src/allmydata/scripts/runner.py @@ -100,6 +100,11 @@ class RestartOptions(BasedirMixin, usage.Options): optParameters = [ ["basedir", "C", None, "which directory to restart the node in"], ] + optFlags = [ + ["force", "f", "if the node is not already running, start it " + "instead of complaining that you should have used 'start' instead " + "of 'restart'"], + ] class CreateClientOptions(NoDefaultBasedirMixin, usage.Options): optParameters = [ @@ -232,6 +237,9 @@ def runner(argv, run_by_human=True, stdout=sys.stdout, stderr=sys.stderr): elif command == "restart": for basedir in so.basedirs: rc = stop(basedir, so, stdout, stderr) or rc + if rc == 2 and so['force']: + print >>stderr, "ignoring couldn't-stop" + rc = 0 if rc: print >>stderr, "not restarting" return rc @@ -306,7 +314,7 @@ def stop(basedir, config, out=sys.stdout, err=sys.stderr): pidfile = os.path.join(basedir, "twistd.pid") if not os.path.exists(pidfile): print >>err, "%s does not look like a running node directory (no twistd.pid)" % basedir - return 1 + return 2 pid = open(pidfile, "r").read() pid = int(pid) -- 2.45.2