//////////////////////////////////////////////////////////////////////////////// // // Copyright 2006 - 2015, 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. // // http://www.opensource.org/licenses/mit-license.php // //////////////////////////////////////////////////////////////////////////////// #include #include #include #include #include #include #include #include extern Context context; //////////////////////////////////////////////////////////////////////////////// CmdCompletionCommands::CmdCompletionCommands () { _keyword = "_commands"; _usage = "task _commands"; _description = STRING_CMD_HCOMMANDS_USAGE; _read_only = true; _displays_id = false; _category = Command::Category::internal; } //////////////////////////////////////////////////////////////////////////////// int CmdCompletionCommands::execute (std::string& output) { // Get a list of all commands. std::vector commands; for (auto& command : context.commands) commands.push_back (command.first); // Sort alphabetically. std::sort (commands.begin (), commands.end ()); std::stringstream out; for (auto& c : commands) out << c << "\n"; output = out.str (); return 0; } //////////////////////////////////////////////////////////////////////////////// CmdZshCommands::CmdZshCommands () { _keyword = "_zshcommands"; _usage = "task _zshcommands"; _description = STRING_CMD_ZSHCOMMANDS_USAGE; _read_only = true; _displays_id = false; _category = Command::Category::internal; } //////////////////////////////////////////////////////////////////////////////// struct ZshCommand { bool operator< (const struct ZshCommand&); Command::Category _category; std::string _command; std::string _description; }; bool ZshCommand::operator< (const struct ZshCommand& other) { // Lexicographical comparison. if (_category != other._category) return (_category < other._category); if (_command != other._command) return (_command < other._command); if (_description != other._description) return (_description < other._description); return false; } //////////////////////////////////////////////////////////////////////////////// int CmdZshCommands::execute (std::string& output) { // Get a list of all command descriptions, sorted by category and then // alphabetically by command name. // Since not all supported compilers support tuples, we use a least common // denominator alternative: a custom struct type. std::vector commands; for (auto& command : context.commands) { ZshCommand zshCommand {command.second->_category, command.first, command.second->description ()}; commands.push_back (zshCommand); } std::sort (commands.begin (), commands.end ()); // Emit the commands in order. std::stringstream out; for (auto& zc : commands) out << zc._command << ":" << Command::categoryNames.at (zc._category) << ":" << zc._description << "\n"; output = out.str (); return 0; } ////////////////////////////////////////////////////////////////////////////////