taskwarrior/src/commands/CmdLog.cpp
Paul Beckingham 2ecafd5d5e Task Validation
- Cleaned up 'log' command due to the new validation.
2011-08-31 01:39:53 -04:00

80 lines
2.4 KiB
C++

////////////////////////////////////////////////////////////////////////////////
// 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
//
////////////////////////////////////////////////////////////////////////////////
#define L10N // Localization complete.
#include <Context.h>
#include <text.h>
#include <i18n.h>
#include <util.h>
#include <main.h>
#include <CmdLog.h>
extern Context context;
////////////////////////////////////////////////////////////////////////////////
CmdLog::CmdLog ()
{
_keyword = "log";
_usage = "task log <modifications>";
_description = STRING_CMD_LOG_USAGE;
_read_only = false;
_displays_id = false;
}
////////////////////////////////////////////////////////////////////////////////
int CmdLog::execute (std::string& output)
{
int rc = 0;
// Apply the command line modifications to the new task.
A3 modifications = context.a3.extract_modifications ();
Task task;
modify_task_description_replace (task, modifications);
task.setStatus (Task::completed);
// Recurring tasks get a special status.
if (task.has ("recur"))
throw std::string (STRING_CMD_LOG_NO_RECUR);
if (task.has ("wait"))
throw std::string (STRING_CMD_LOG_NO_WAITING);
context.tdb2.add (task);
/*
context.footnote (onProjectChange (task));
*/
context.tdb2.commit ();
if (context.config.getBoolean ("echo.command"))
output = std::string (STRING_CMD_LOG_LOGGED) + "\n";
return rc;
}
////////////////////////////////////////////////////////////////////////////////