Mercurial > libervia-backend
view frontends/src/jp/cmd_uri.py @ 2278:489efbda377c
jp (input): input command first draft:
this is an experimental command to use external data as input arguments.
A series of data is used (only CSV is implemented so far), and it is used to fill argument of a command according to a sequence.
The sequence is given using input arguments, with types corresponding to the data found (short option, long option, stdin).
e.g. if a CSV file has row with 3 columns, we can say that column 1 is subject (long option), column 2 is body (stdin), and column 3 is language (short option -l).
A filter can be used after each option type, to transform read value.
Finally a static part is used to have the main command and non dynamic arguments to use.
author | Goffi <goffi@goffi.org> |
---|---|
date | Wed, 28 Jun 2017 01:28:41 +0200 |
parents | 4b66f070cfbb |
children | 8b37a62336c3 |
line wrap: on
line source
#!/usr/bin/env python2 # -*- coding: utf-8 -*- # jp: a SàT command line tool # Copyright (C) 2009-2016 Jérôme Poisson (goffi@goffi.org) # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Affero General Public License for more details. # You should have received a copy of the GNU Affero General Public License # along with this program. If not, see <http://www.gnu.org/licenses/>. import base from sat.core.i18n import _ from sat_frontends.jp.constants import Const as C from sat.tools.common import uri __commands__ = ["Uri"] class Parse(base.CommandBase): def __init__(self, host): base.CommandBase.__init__(self, host, 'parse', use_profile=False, use_output=C.OUTPUT_DICT, help=_(u'parse URI')) def add_parser_options(self): self.parser.add_argument("uri", type=base.unicode_decoder, help=_(u"XMPP URI to parse")) def start(self): self.output(uri.parseXMPPUri(self.args.uri)) class Build(base.CommandBase): def __init__(self, host): base.CommandBase.__init__(self, host, 'build', use_profile=False, help=_(u'build URI')) def add_parser_options(self): self.parser.add_argument("type", type=base.unicode_decoder, help=_(u"URI type")) self.parser.add_argument("path", type=base.unicode_decoder, help=_(u"URI path")) self.parser.add_argument("-f", "--field", type=base.unicode_decoder, action='append', nargs=2, dest='fields', metavar=(u"KEY", u"VALUE"), help=_(u"URI fields")) def start(self): fields = dict(self.args.fields) if self.args.fields else {} self.disp(uri.buildXMPPUri(self.args.type, path=self.args.path, **fields)) class Uri(base.CommandBase): subcommands = (Parse, Build) def __init__(self, host): super(Uri, self).__init__(host, 'uri', use_profile=False, help=_('XMPP URI parsing/generation'))