//////////////////////////////////////////////////////////////////////////////// // // Copyright 2006 - 2021, 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 // //////////////////////////////////////////////////////////////////////////////// #include #include #include #include #include #include #include #include std::string zshColonReplacement = ","; //////////////////////////////////////////////////////////////////////////////// CmdIDs::CmdIDs () { _keyword = "ids"; _usage = "task ids"; _description = "Shows the IDs of matching tasks, as a range"; _read_only = true; _displays_id = true; _needs_gc = true; _uses_context = false; _accepts_filter = true; _accepts_modifications = false; _accepts_miscellaneous = false; _category = Command::Category::metadata; } //////////////////////////////////////////////////////////////////////////////// int CmdIDs::execute (std::string& output) { // Apply filter. handleUntil (); handleRecurrence (); Filter filter; std::vector filtered; filter.subset (filtered); // Find number of matching tasks. std::vector ids; for (auto& task : filtered) if (task.id) ids.push_back (task.id); std::sort (ids.begin (), ids.end ()); output = compressIds (ids) + '\n'; Context::getContext ().headers.clear (); return 0; } //////////////////////////////////////////////////////////////////////////////// // The vector must be sorted first. This is a modified version of the run- // length encoding algorithm. // // This function converts the vector: // // [1, 3, 4, 6, 7, 8, 9, 11] // // to ths string: // // 1,3-4,6-9,11 // std::string CmdIDs::compressIds (const std::vector & ids) { std::stringstream result; auto range_start = 0; auto range_end = 0; for (unsigned int i = 0; i < ids.size (); ++i) { if (i + 1 == ids.size ()) { if (result.str ().length ()) result << ' '; if (range_start < range_end) result << ids[range_start] << '-' << ids[range_end]; else result << ids[range_start]; } else { if (ids[range_end] + 1 == ids[i + 1]) { ++range_end; } else { if (result.str ().length ()) result << ' '; if (range_start < range_end) result << ids[range_start] << '-' << ids[range_end]; else result << ids[range_start]; range_start = range_end = i + 1; } } } return result.str (); } //////////////////////////////////////////////////////////////////////////////// CmdCompletionIds::CmdCompletionIds () { _keyword = "_ids"; _usage = "task _ids"; _description = "Shows the IDs of matching tasks, in the form of a list"; _read_only = true; _displays_id = true; _needs_gc = true; _uses_context = false; _accepts_filter = true; _accepts_modifications = false; _accepts_miscellaneous = false; _category = Command::Category::internal; } //////////////////////////////////////////////////////////////////////////////// int CmdCompletionIds::execute (std::string& output) { // Apply filter. handleUntil (); handleRecurrence (); Filter filter; std::vector filtered; filter.subset (filtered); std::vector ids; for (auto& task : filtered) if (task.getStatus () != Task::deleted && task.getStatus () != Task::completed) ids.push_back (task.id); std::sort (ids.begin (), ids.end ()); output = join ("\n", ids) + '\n'; Context::getContext ().headers.clear (); return 0; } //////////////////////////////////////////////////////////////////////////////// CmdZshCompletionIds::CmdZshCompletionIds () { _keyword = "_zshids"; _usage = "task _zshids"; _description = "Shows the IDs and descriptions of matching tasks"; _read_only = true; _displays_id = true; _needs_gc = true; _uses_context = false; _accepts_filter = true; _accepts_modifications = false; _accepts_miscellaneous = false; _category = Command::Category::internal; } //////////////////////////////////////////////////////////////////////////////// int CmdZshCompletionIds::execute (std::string& output) { // Apply filter. handleUntil (); handleRecurrence (); Filter filter; std::vector filtered; filter.subset (filtered); std::stringstream out; for (auto& task : filtered) if (task.getStatus () != Task::deleted && task.getStatus () != Task::completed) out << task.id << ':' << str_replace(task.get ("description"), ":", zshColonReplacement) << '\n'; output = out.str (); Context::getContext ().headers.clear (); return 0; } //////////////////////////////////////////////////////////////////////////////// CmdUUIDs::CmdUUIDs () { _keyword = "uuids"; _usage = "task uuids"; _description = "Shows the UUIDs of matching tasks, as a space-separated list"; _read_only = true; _displays_id = false; _needs_gc = true; _uses_context = false; _accepts_filter = true; _accepts_modifications = false; _accepts_miscellaneous = false; _category = Command::Category::metadata; } //////////////////////////////////////////////////////////////////////////////// int CmdUUIDs::execute (std::string& output) { // Apply filter. handleUntil (); handleRecurrence (); Filter filter; std::vector filtered; filter.subset (filtered); std::vector uuids; uuids.reserve(filtered.size()); for (auto& task : filtered) uuids.push_back (task.get ("uuid")); std::sort (uuids.begin (), uuids.end ()); output = join (" ", uuids) + '\n'; Context::getContext ().headers.clear (); return 0; } //////////////////////////////////////////////////////////////////////////////// CmdCompletionUuids::CmdCompletionUuids () { _keyword = "_uuids"; _usage = "task _uuids"; _description = "Shows the UUIDs of matching tasks, as a list"; _read_only = true; _displays_id = false; _needs_gc = true; _uses_context = false; _accepts_filter = true; _accepts_modifications = false; _accepts_miscellaneous = false; _category = Command::Category::internal; } //////////////////////////////////////////////////////////////////////////////// int CmdCompletionUuids::execute (std::string& output) { // Apply filter. handleUntil (); handleRecurrence (); Filter filter; std::vector filtered; filter.subset (filtered); std::vector uuids; uuids.reserve(filtered.size()); for (auto& task : filtered) uuids.push_back (task.get ("uuid")); std::sort (uuids.begin (), uuids.end ()); output = join ("\n", uuids) + '\n'; Context::getContext ().headers.clear (); return 0; } //////////////////////////////////////////////////////////////////////////////// CmdZshCompletionUuids::CmdZshCompletionUuids () { _keyword = "_zshuuids"; _usage = "task _zshuuids"; _description = "Shows the UUIDs and descriptions of matching tasks"; _read_only = true; _displays_id = false; _needs_gc = true; _uses_context = false; _accepts_filter = true; _accepts_modifications = false; _accepts_miscellaneous = false; _category = Command::Category::internal; } //////////////////////////////////////////////////////////////////////////////// int CmdZshCompletionUuids::execute (std::string& output) { // Apply filter. handleUntil (); handleRecurrence (); Filter filter; std::vector filtered; filter.subset (filtered); std::stringstream out; for (auto& task : filtered) out << task.get ("uuid") << ':' << str_replace (task.get ("description"), ":", zshColonReplacement) << '\n'; output = out.str (); Context::getContext ().headers.clear (); return 0; } ///////////////////////////////////////////////////////////////////////////////