//////////////////////////////////////////////////////////////////////////////// // // 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 #include extern Context context; //////////////////////////////////////////////////////////////////////////////// CmdUnique::CmdUnique () { _keyword = "_unique"; _usage = "task _unique "; _description = STRING_CMD_UNIQUE_USAGE; _read_only = false; _displays_id = true; _needs_gc = true; _uses_context = true; _accepts_filter = true; _accepts_modifications = false; _accepts_miscellaneous = true; _category = Command::Category::internal; } //////////////////////////////////////////////////////////////////////////////// int CmdUnique::execute (std::string& output) { // Apply filter. Filter filter; filter.disableSafety (); std::vector filtered; filter.subset (filtered); // Find . std::string attribute = ""; for (auto& a : context.cli2._args) { if ((a._lextype == Lexer::Type::word || a._lextype == Lexer::Type::dom) && a.hasTag ("MODIFICATION")) { // Stop at first matching arg. attribute = a.attribute ("raw"); break; } } if (attribute == "") throw std::string (STRING_CMD_UNIQUE_MISSING); std::string canonical; if (! context.cli2.canonicalize (canonical, "attribute", attribute)) throw std::string (STRING_CMD_UNIQUE_VALID); // Find number of matching tasks. std::set values; for (auto& task : filtered) if (task.has (canonical)) values.insert (task.get (canonical)); // Generate list of unique values. for (auto& value : values) std::cout << value << "\n"; context.headers.clear (); return 0; } ///////////////////////////////////////////////////////////////////////////////