commit 6b91519c11c222174a8e1138f40a38dd9cab4629
Author: Isis Lovecruft <isis(a)torproject.org>
Date: Sat Oct 26 12:01:04 2013 +0000
Move options parser to bridgedb.parse package and update bridgedb.Main.
---
lib/bridgedb/Main.py | 2 +-
lib/bridgedb/opt.py | 140 -----------------------------------------
lib/bridgedb/parse/options.py | 140 +++++++++++++++++++++++++++++++++++++++++
3 files changed, 141 insertions(+), 141 deletions(-)
diff --git a/lib/bridgedb/Main.py b/lib/bridgedb/Main.py
index e12c268..2b8e4f8 100644
--- a/lib/bridgedb/Main.py
+++ b/lib/bridgedb/Main.py
@@ -16,7 +16,7 @@ import gettext
from twisted.internet import reactor
-from bridgedb import options
+from bridgedb.parse import options
import bridgedb.Bridges as Bridges
import bridgedb.Dist as Dist
diff --git a/lib/bridgedb/opt.py b/lib/bridgedb/opt.py
deleted file mode 100644
index e7ec7c3..0000000
--- a/lib/bridgedb/opt.py
+++ /dev/null
@@ -1,140 +0,0 @@
-# -*- coding: utf-8 -*-
-#
-# This file is part of BridgeDB, a Tor bridge distribution system.
-#
-# :authors: Isis Lovecruft 0xA3ADB67A2CDB8B35 <isis(a)torproject.org>
-# please also see AUTHORS file
-# :copyright: (c) 2007-2013, The Tor Project, Inc.
-# (c) 2007-2013, all entities within the AUTHORS file
-# :license: 3-clause BSD, see included LICENSE for information
-
-"""Classes for commandline options parsing.
-
-** Module Overview: **
-
-"""
-
-from __future__ import print_function
-from __future__ import unicode_literals
-
-import sys
-import textwrap
-import os
-
-from twisted.python import usage
-
-from bridgedb import __version__
-
-
-def parseOptions():
- """Create the main options parser and its subcommand parsers.
-
- Any :exc:`~twisted.python.usage.UsageErrors` which are raised due to
- invalid options are ignored; their error message is printed and then we
- exit the program.
-
- :rtype: :class:`MainOptions`
- :returns: The main options parsing class, with any commandline arguments
- already parsed.
- """
- options = MainOptions()
- try:
- options.parseOptions()
- except usage.UsageError as uerr:
- print(uerr.message)
- sys.exit(1)
- return options
-
-
-class BaseOptions(usage.Options):
- """Base options included in all main and sub options menus."""
-
- longdesc = textwrap.dedent("""BridgeDB is a proxy distribution system for
- private relays acting as bridges into the Tor network. See `bridgedb
- <command> --help` for addition help.""")
-
- def opt_rundir(self, rundir):
- """Change to this directory"""
- if not rundir:
- rundir = os.getcwdu()
- else:
- try:
- rundir = os.path.abspath(os.path.expanduser(rundir))
- except Exception as error:
- raise usage.UsageError(error.message)
- if rundir and os.path.isdir(rundir):
- self['rundir'] = rundir
- opt_r = opt_rundir
-
- def __init__(self):
- """Create an options parser. All flags, parameters, and attributes of
- this base options parser are inherited by all child classes.
- """
- usage.Options.__init__(self)
- self['rundir'] = os.getcwdu()
- self['version'] = self.opt_version
- self['verbosity'] = 30
-
- def opt_quiet(self):
- """Decrease verbosity"""
- # We use '10' because then it corresponds to the log levels
- self['verbosity'] -= 10
-
- def opt_verbose(self):
- """Increase verbosity"""
- self['verbosity'] += 10
-
- opt_q = opt_quiet
- opt_v = opt_verbose
-
- def opt_version(self):
- """Display BridgeDB's version and exit."""
- print("%s-%s" % (__package__, __version__))
- sys.exit()
-
-
-class TestOptions(BaseOptions):
- """Suboptions for running twisted.trial and unittest based tests."""
-
- longdesc = textwrap.dedent("""BridgeDB testing commands.
- See the `bridgedb mock` command for generating testing environments.""")
-
- optFlags = [['coverage', 'c', 'Generate coverage statistics']]
- optParameters = [
- ['file', 'f', None, 'Run tests in specific file(s) (trial only)'],
- ['unittests', 'u', False, 'Run unittests in bridgedb.Tests'],
- ['trial', 't', True, 'Run twisted.trial tests in bridgedb.test']]
-
- completionData = usage.Completions(
- mutuallyExclusive=[('unittests', 'coverage'),
- ('unittests', 'file')],
- optActions={'file': usage.CompleteFiles('lib/bridgedb/test/test_*.py',
- repeat=True,
- descr="test filename")},
- extraActions=[
- usage.Completer(descr="extra arguments to pass to trial")])
-
- def parseArgs(self, *args):
- """Parse any additional arguments after the options and flags."""
- self['test_args'] = args
-
-class MockOptions(BaseOptions):
- """Suboptions for creating necessary conditions for testing purposes."""
-
- optParameters = [
- ['descriptors', 'n', 1000,
- '''Generate <n> mock bridge descriptor sets
- (types: netstatus, extrainfo, server)''']]
-
-
-class MainOptions(BaseOptions):
- """Main commandline options parser for BridgeDB."""
-
- optFlags = [
- ['dump-bridges', 'd', 'Dump bridges by hashring assignment into files'],
- ['reload', 'R', 'Reload bridge descriptors into running servers']]
- optParameters = [
- ['config', 'c', 'bridgedb.conf', 'Configuration file']]
- subCommands = [
- ['test', None, TestOptions, "Run twisted.trial tests or unittests"],
- ['mock', None, MockOptions, "Generate a testing environment"]]
diff --git a/lib/bridgedb/parse/options.py b/lib/bridgedb/parse/options.py
new file mode 100644
index 0000000..e7ec7c3
--- /dev/null
+++ b/lib/bridgedb/parse/options.py
@@ -0,0 +1,140 @@
+# -*- coding: utf-8 -*-
+#
+# This file is part of BridgeDB, a Tor bridge distribution system.
+#
+# :authors: Isis Lovecruft 0xA3ADB67A2CDB8B35 <isis(a)torproject.org>
+# please also see AUTHORS file
+# :copyright: (c) 2007-2013, The Tor Project, Inc.
+# (c) 2007-2013, all entities within the AUTHORS file
+# :license: 3-clause BSD, see included LICENSE for information
+
+"""Classes for commandline options parsing.
+
+** Module Overview: **
+
+"""
+
+from __future__ import print_function
+from __future__ import unicode_literals
+
+import sys
+import textwrap
+import os
+
+from twisted.python import usage
+
+from bridgedb import __version__
+
+
+def parseOptions():
+ """Create the main options parser and its subcommand parsers.
+
+ Any :exc:`~twisted.python.usage.UsageErrors` which are raised due to
+ invalid options are ignored; their error message is printed and then we
+ exit the program.
+
+ :rtype: :class:`MainOptions`
+ :returns: The main options parsing class, with any commandline arguments
+ already parsed.
+ """
+ options = MainOptions()
+ try:
+ options.parseOptions()
+ except usage.UsageError as uerr:
+ print(uerr.message)
+ sys.exit(1)
+ return options
+
+
+class BaseOptions(usage.Options):
+ """Base options included in all main and sub options menus."""
+
+ longdesc = textwrap.dedent("""BridgeDB is a proxy distribution system for
+ private relays acting as bridges into the Tor network. See `bridgedb
+ <command> --help` for addition help.""")
+
+ def opt_rundir(self, rundir):
+ """Change to this directory"""
+ if not rundir:
+ rundir = os.getcwdu()
+ else:
+ try:
+ rundir = os.path.abspath(os.path.expanduser(rundir))
+ except Exception as error:
+ raise usage.UsageError(error.message)
+ if rundir and os.path.isdir(rundir):
+ self['rundir'] = rundir
+ opt_r = opt_rundir
+
+ def __init__(self):
+ """Create an options parser. All flags, parameters, and attributes of
+ this base options parser are inherited by all child classes.
+ """
+ usage.Options.__init__(self)
+ self['rundir'] = os.getcwdu()
+ self['version'] = self.opt_version
+ self['verbosity'] = 30
+
+ def opt_quiet(self):
+ """Decrease verbosity"""
+ # We use '10' because then it corresponds to the log levels
+ self['verbosity'] -= 10
+
+ def opt_verbose(self):
+ """Increase verbosity"""
+ self['verbosity'] += 10
+
+ opt_q = opt_quiet
+ opt_v = opt_verbose
+
+ def opt_version(self):
+ """Display BridgeDB's version and exit."""
+ print("%s-%s" % (__package__, __version__))
+ sys.exit()
+
+
+class TestOptions(BaseOptions):
+ """Suboptions for running twisted.trial and unittest based tests."""
+
+ longdesc = textwrap.dedent("""BridgeDB testing commands.
+ See the `bridgedb mock` command for generating testing environments.""")
+
+ optFlags = [['coverage', 'c', 'Generate coverage statistics']]
+ optParameters = [
+ ['file', 'f', None, 'Run tests in specific file(s) (trial only)'],
+ ['unittests', 'u', False, 'Run unittests in bridgedb.Tests'],
+ ['trial', 't', True, 'Run twisted.trial tests in bridgedb.test']]
+
+ completionData = usage.Completions(
+ mutuallyExclusive=[('unittests', 'coverage'),
+ ('unittests', 'file')],
+ optActions={'file': usage.CompleteFiles('lib/bridgedb/test/test_*.py',
+ repeat=True,
+ descr="test filename")},
+ extraActions=[
+ usage.Completer(descr="extra arguments to pass to trial")])
+
+ def parseArgs(self, *args):
+ """Parse any additional arguments after the options and flags."""
+ self['test_args'] = args
+
+class MockOptions(BaseOptions):
+ """Suboptions for creating necessary conditions for testing purposes."""
+
+ optParameters = [
+ ['descriptors', 'n', 1000,
+ '''Generate <n> mock bridge descriptor sets
+ (types: netstatus, extrainfo, server)''']]
+
+
+class MainOptions(BaseOptions):
+ """Main commandline options parser for BridgeDB."""
+
+ optFlags = [
+ ['dump-bridges', 'd', 'Dump bridges by hashring assignment into files'],
+ ['reload', 'R', 'Reload bridge descriptors into running servers']]
+ optParameters = [
+ ['config', 'c', 'bridgedb.conf', 'Configuration file']]
+ subCommands = [
+ ['test', None, TestOptions, "Run twisted.trial tests or unittests"],
+ ['mock', None, MockOptions, "Generate a testing environment"]]