//////////////////////////////////////////////////////////////////////////////// // taskwarrior - a command line task list manager. // // Copyright 2006 - 2011, Paul Beckingham, Federico Hernandez. // All rights reserved. // // This program is free software; you can redistribute it and/or modify it under // the terms of the GNU General Public License as published by the Free Software // Foundation; either version 2 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 General Public License for more // details. // // You should have received a copy of the GNU General Public License along with // this program; if not, write to the // // Free Software Foundation, Inc., // 51 Franklin Street, Fifth Floor, // Boston, MA // 02110-1301 // USA // //////////////////////////////////////////////////////////////////////////////// #include #include #include #include #include #include #include extern Context context; //////////////////////////////////////////////////////////////////////////////// CmdIDs::CmdIDs () { _keyword = "ids"; _usage = "task ids []"; _description = "Shows only the IDs of matching tasks, in the form of a range."; _read_only = true; _displays_id = true; } //////////////////////////////////////////////////////////////////////////////// int CmdIDs::execute (std::string& output) { // Scan the pending tasks, applying any filter. std::vector tasks; context.tdb.lock (context.config.getBoolean ("locking")); handleRecurrence (); context.tdb.load (tasks); context.tdb.commit (); context.tdb.unlock (); // Filter. Arguments f = context.args.extract_read_only_filter (); Expression e (f); std::vector filtered; std::vector ::iterator task; for (task = tasks.begin (); task != tasks.end (); ++task) if (e.eval (*task)) filtered.push_back (*task); // Find number of matching tasks. std::vector ids; for (task = filtered.begin (); task != filtered.end (); ++task) if (task->id) ids.push_back (task->id); std::sort (ids.begin (), ids.end ()); output = compressIds (ids) + "\n"; return 0; } //////////////////////////////////////////////////////////////////////////////// CmdCompletionIds::CmdCompletionIds () { _keyword = "_ids"; _usage = "task _ids []"; _description = "Shows only the IDs of matching tasks, in the form of a list."; _read_only = true; _displays_id = true; } //////////////////////////////////////////////////////////////////////////////// int CmdCompletionIds::execute (std::string& output) { std::vector tasks; context.tdb.lock (context.config.getBoolean ("locking")); context.tdb.loadPending (tasks); context.tdb.commit (); context.tdb.unlock (); // Filter. Arguments f = context.args.extract_read_only_filter (); Expression e (f); std::vector filtered; std::vector ::iterator task; for (task = tasks.begin (); task != tasks.end (); ++task) if (e.eval (*task)) filtered.push_back (*task); std::vector ids; for (task = filtered.begin (); task != filtered.end (); ++task) if (task->getStatus () != Task::deleted && task->getStatus () != Task::completed) ids.push_back (task->id); std::sort (ids.begin (), ids.end ()); std::stringstream out; std::vector ::iterator id; for (id = ids.begin (); id != ids.end (); ++id) out << *id << "\n"; output = out.str (); return 0; } //////////////////////////////////////////////////////////////////////////////// CmdZshCompletionIds::CmdZshCompletionIds () { _keyword = "_zshids"; _usage = "task _zshids []"; _description = "Shows the IDs and descriptions of matching tasks."; _read_only = true; _displays_id = true; } //////////////////////////////////////////////////////////////////////////////// int CmdZshCompletionIds::execute (std::string& output) { std::vector tasks; context.tdb.lock (context.config.getBoolean ("locking")); context.tdb.loadPending (tasks); context.tdb.commit (); context.tdb.unlock (); // Filter. Arguments f = context.args.extract_read_only_filter (); Expression e (f); std::vector filtered; std::vector ::iterator task; for (task = tasks.begin (); task != tasks.end (); ++task) if (e.eval (*task)) filtered.push_back (*task); std::stringstream out; for (task = filtered.begin (); task != filtered.end (); ++task) if (task->getStatus () != Task::deleted && task->getStatus () != Task::completed) out << task->id << ":" << task->get ("description") << "\n"; output = out.str (); return 0; } ////////////////////////////////////////////////////////////////////////////////