mirror of
https://git.notmuchmail.org/git/notmuch
synced 2024-11-21 18:38:08 +01:00
notmuch-git: add --git-dir, --tag-prefix arguments
It is often more convenient to use command line arguments than environment variables.
This commit is contained in:
parent
b7c31f6581
commit
b7b111b9b5
1 changed files with 21 additions and 10 deletions
|
@ -50,13 +50,9 @@ _LOG = _logging.getLogger('nmbug')
|
|||
_LOG.setLevel(_logging.WARNING)
|
||||
_LOG.addHandler(_logging.StreamHandler())
|
||||
|
||||
NMBGIT = _os.path.expanduser(
|
||||
_os.getenv('NMBGIT', _os.path.join('~', '.nmbug')))
|
||||
_NMBGIT = _os.path.join(NMBGIT, '.git')
|
||||
if _os.path.isdir(_NMBGIT):
|
||||
NMBGIT = _NMBGIT
|
||||
NMBGIT = None
|
||||
TAG_PREFIX = None
|
||||
|
||||
TAG_PREFIX = _os.getenv('NMBPREFIX', 'notmuch::')
|
||||
_HEX_ESCAPE_REGEX = _re.compile('%[0-9A-F]{2}')
|
||||
_TAG_DIRECTORY = 'tags/'
|
||||
_TAG_FILE_REGEX = _re.compile(_TAG_DIRECTORY + '(?P<id>[^/]*)/(?P<tag>[^/]*)')
|
||||
|
@ -77,10 +73,6 @@ def _hex_quote(string, safe='+@=:,'):
|
|||
lambda match: match.group(0).lower(),
|
||||
uppercase_escapes)
|
||||
|
||||
|
||||
_ENCODED_TAG_PREFIX = _hex_quote(TAG_PREFIX, safe='+@=,') # quote ':'
|
||||
|
||||
|
||||
def _xapian_quote(string):
|
||||
"""
|
||||
Quote a string for Xapian's QueryParser.
|
||||
|
@ -686,6 +678,13 @@ if __name__ == '__main__':
|
|||
parser = argparse.ArgumentParser(
|
||||
description=__doc__.strip(),
|
||||
formatter_class=argparse.RawDescriptionHelpFormatter)
|
||||
parser.add_argument(
|
||||
'-C', '--git-dir', metavar='REPO',
|
||||
help='Git repository to operate on.')
|
||||
parser.add_argument(
|
||||
'-p', '--tag-prefix', metavar='PREFIX',
|
||||
default = _os.getenv('NMBPREFIX', 'notmuch::'),
|
||||
help='Prefix of tags to operate on.')
|
||||
parser.add_argument(
|
||||
'-l', '--log-level',
|
||||
choices=['critical', 'error', 'warning', 'info', 'debug'],
|
||||
|
@ -795,6 +794,18 @@ if __name__ == '__main__':
|
|||
|
||||
args = parser.parse_args()
|
||||
|
||||
if args.git_dir:
|
||||
NMBGIT = args.git_dir
|
||||
else:
|
||||
NMBGIT = _os.path.expanduser(
|
||||
_os.getenv('NMBGIT', _os.path.join('~', '.nmbug')))
|
||||
_NMBGIT = _os.path.join(NMBGIT, '.git')
|
||||
if _os.path.isdir(_NMBGIT):
|
||||
NMBGIT = _NMBGIT
|
||||
|
||||
TAG_PREFIX = args.tag_prefix
|
||||
_ENCODED_TAG_PREFIX = _hex_quote(TAG_PREFIX, safe='+@=,') # quote ':'
|
||||
|
||||
if args.log_level:
|
||||
level = getattr(_logging, args.log_level.upper())
|
||||
_LOG.setLevel(level)
|
||||
|
|
Loading…
Reference in a new issue