//////////////////////////////////////////////////////////////////////////////// // // Copyright 2022, Dustin J. Mitchell // // 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 // cmake.h include header must come first #include #include "tc/Task.h" #include "tc/util.h" using namespace tc::ffi; //////////////////////////////////////////////////////////////////////////////// tc::Task::Task(TCTask* tctask) { inner = unique_tctask_ptr(tctask, [](TCTask* task) { tc_task_free(task); }); } //////////////////////////////////////////////////////////////////////////////// tc::Task::Task(Task&& other) noexcept { // move inner from other inner = unique_tctask_ptr(other.inner.release(), [](TCTask* task) { tc_task_free(task); }); } //////////////////////////////////////////////////////////////////////////////// tc::Task& tc::Task::operator=(Task&& other) noexcept { if (this != &other) { // move inner from other inner = unique_tctask_ptr(other.inner.release(), [](TCTask* task) { tc_task_free(task); }); } return *this; } //////////////////////////////////////////////////////////////////////////////// void tc::Task::to_mut(TCReplica* replica) { tc_task_to_mut(&*inner, replica); } //////////////////////////////////////////////////////////////////////////////// void tc::Task::to_immut() { tc_task_to_immut(&*inner); } //////////////////////////////////////////////////////////////////////////////// std::string tc::Task::get_uuid() const { auto uuid = tc_task_get_uuid(&*inner); return tc2uuid(uuid); } //////////////////////////////////////////////////////////////////////////////// tc::Status tc::Task::get_status() const { auto status = tc_task_get_status(&*inner); return tc::Status(status); } //////////////////////////////////////////////////////////////////////////////// std::map tc::Task::get_taskmap() const { TCKVList kv = tc_task_get_taskmap(&*inner); if (!kv.items) { throw task_error(); } std::map taskmap; for (size_t i = 0; i < kv.len; i++) { auto k = tc2string_clone(kv.items[i].key); auto v = tc2string_clone(kv.items[i].value); taskmap[k] = v; } return taskmap; } //////////////////////////////////////////////////////////////////////////////// std::string tc::Task::get_description() const { auto desc = tc_task_get_description(&*inner); return tc2string(desc); } //////////////////////////////////////////////////////////////////////////////// std::optional tc::Task::get_value(std::string property) const { auto maybe_desc = tc_task_get_value(&*inner, string2tc(property)); if (maybe_desc.ptr == NULL) { return std::nullopt; } return std::make_optional(tc2string(maybe_desc)); } bool tc::Task::is_waiting() const { return tc_task_is_waiting(&*inner); } //////////////////////////////////////////////////////////////////////////////// bool tc::Task::is_active() const { return tc_task_is_active(&*inner); } //////////////////////////////////////////////////////////////////////////////// bool tc::Task::is_blocked() const { return tc_task_is_blocked(&*inner); } //////////////////////////////////////////////////////////////////////////////// bool tc::Task::is_blocking() const { return tc_task_is_blocking(&*inner); } //////////////////////////////////////////////////////////////////////////////// void tc::Task::set_status(tc::Status status) { TCResult res = tc_task_set_status(&*inner, (TCStatus)status); if (res != TC_RESULT_OK) { throw task_error(); } } //////////////////////////////////////////////////////////////////////////////// void tc::Task::set_value(std::string property, std::optional value) { TCResult res; if (value.has_value()) { res = tc_task_set_value(&*inner, string2tc(property), string2tc(value.value())); } else { TCString nullstr; nullstr.ptr = NULL; res = tc_task_set_value(&*inner, string2tc(property), nullstr); } if (res != TC_RESULT_OK) { throw task_error(); } } //////////////////////////////////////////////////////////////////////////////// void tc::Task::set_modified(time_t modified) { TCResult res = tc_task_set_modified(&*inner, modified); if (res != TC_RESULT_OK) { throw task_error(); } } //////////////////////////////////////////////////////////////////////////////// std::string tc::Task::task_error() const { TCString error = tc_task_error(&*inner); std::string errmsg; if (!error.ptr) { errmsg = std::string("Unknown TaskChampion error"); } else { errmsg = std::string(tc_string_content(&error)); } tc_string_free(&error); return errmsg; } ////////////////////////////////////////////////////////////////////////////////