From c76d0048975e7c1c6d4690d0bf691cf93eafe79e Mon Sep 17 00:00:00 2001 From: Shaun Ruffell Date: Sun, 7 Apr 2019 16:01:57 -0500 Subject: [PATCH] #212: "--help" should show help, not considered to be a tag. This change makes any instance of '--help' on the command line to be made the command for this particular invocation. --- src/CLI.cpp | 17 +++++++++++++++++ test/help.t | 54 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 71 insertions(+) create mode 100755 test/help.t diff --git a/src/CLI.cpp b/src/CLI.cpp index 9f5a0b8a..65141983 100644 --- a/src/CLI.cpp +++ b/src/CLI.cpp @@ -445,6 +445,23 @@ void CLI::canonicalizeNames () alreadyFoundCmd = true; } + // 'timew --help' should be treated the same as 'timew help + // '. Therefore, "--help" on the command line should always + // become the command. + else if (alreadyFoundCmd && (raw == "--help")) + { + for (auto& b : _args) { + if (b.hasTag("CMD")) + { + b.unTag("CMD"); + break; + } + } + + a.tag ("CMD"); + a.attribute("canonical", canonical); + } + // Hints. else if (exactMatch ("hint", raw) || canonicalize (canonical, "hint", raw)) diff --git a/test/help.t b/test/help.t new file mode 100755 index 00000000..c86deef2 --- /dev/null +++ b/test/help.t @@ -0,0 +1,54 @@ +#!/usr/bin/env python2.7 +# -*- coding: utf-8 -*- +############################################################################### +# +# Copyright 2006 - 2019, Thomas Lauf, Paul Beckingham, Federico Hernandez. +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to deal +# in the Software without restriction, including without limitation the rights +# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +# copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included +# in all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL +# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +# SOFTWARE. +# +# https://www.opensource.org/licenses/mit-license.php +# +############################################################################### + +import os +import sys +import unittest + +# Ensure python finds the local simpletap module +sys.path.append(os.path.dirname(os.path.abspath(__file__))) + +from basetest import Timew, TestCase + +class TestHelp(TestCase): + def setUp(self): + """Executed before each test in the class""" + self.t = Timew() + + def test_help(self): + """Check that 'track --help' is the same is 'help track'""" + code, out1, err1 = self.t("help track") + code, out2, err2 = self.t("track --help") + self.assertEquals(out1, out2) + +if __name__ == "__main__": + from simpletap import TAPTestRunner + + unittest.main(testRunner=TAPTestRunner()) + +# vim: ai sts=4 et sw=4 ft=python