mirror of
https://github.com/GothenburgBitFactory/taskwarrior.git
synced 2025-09-06 17:37:21 +02:00
ColDepends: Support dependency removal for the same formats as dependency addition
This commit is contained in:
parent
0cc2de6179
commit
112ac54a57
1 changed files with 45 additions and 36 deletions
|
@ -154,50 +154,59 @@ void ColumnDepends::modify (Task& task, const std::string& value)
|
||||||
// Apply or remove dendencies in turn.
|
// Apply or remove dendencies in turn.
|
||||||
for (auto& dep : split (value, ','))
|
for (auto& dep : split (value, ','))
|
||||||
{
|
{
|
||||||
|
bool removal = false;
|
||||||
if (dep[0] == '-')
|
if (dep[0] == '-')
|
||||||
{
|
{
|
||||||
if (dep.length () == 37)
|
removal = true;
|
||||||
task.removeDependency (dep.substr (1));
|
dep = dep.substr(1);
|
||||||
else
|
|
||||||
task.removeDependency (strtol (dep.substr (1).c_str (), nullptr, 10));
|
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
auto hyphen = dep.find ('-');
|
|
||||||
long lower, upper; // For ID ranges
|
|
||||||
std::regex valid_uuid ("[a-f0-9]{8}([a-f0-9-]{4,28})?"); // TODO: Make more precise
|
|
||||||
|
|
||||||
// UUID
|
auto hyphen = dep.find ('-');
|
||||||
if (dep.length () >= 8 && std::regex_match (dep, valid_uuid))
|
long lower, upper; // For ID ranges
|
||||||
{
|
std::regex valid_uuid ("[a-f0-9]{8}([a-f0-9-]{4,28})?"); // TODO: Make more precise
|
||||||
// Full UUID, can be added directly
|
|
||||||
if (dep.length () == 36)
|
// UUID
|
||||||
|
if (dep.length () >= 8 && std::regex_match (dep, valid_uuid))
|
||||||
|
{
|
||||||
|
// Full UUID, can be added directly
|
||||||
|
if (dep.length () == 36)
|
||||||
|
if (removal)
|
||||||
|
task.removeDependency (dep);
|
||||||
|
else
|
||||||
task.addDependency (dep);
|
task.addDependency (dep);
|
||||||
|
|
||||||
// Short UUID, need to look up full form
|
// Short UUID, need to look up full form
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Task loaded_task;
|
Task loaded_task;
|
||||||
if (Context::getContext ().tdb2.get (dep, loaded_task))
|
if (Context::getContext ().tdb2.get (dep, loaded_task))
|
||||||
task.addDependency (loaded_task.get ("uuid"));
|
if (removal)
|
||||||
|
task.removeDependency (loaded_task.get ("uuid"));
|
||||||
else
|
else
|
||||||
throw format ("Dependency could not be set - task with UUID '{1}' does not exist.", dep);
|
task.addDependency (loaded_task.get ("uuid"));
|
||||||
}
|
else
|
||||||
}
|
throw format ("Dependency could not be set - task with UUID '{1}' does not exist.", dep);
|
||||||
// ID range
|
}
|
||||||
else if (dep.find ('-') != std::string::npos &&
|
|
||||||
extractLongInteger (dep.substr (0, hyphen), lower) &&
|
|
||||||
extractLongInteger (dep.substr (hyphen + 1), upper))
|
|
||||||
{
|
|
||||||
for (long i = lower; i <= upper; i++)
|
|
||||||
task.addDependency(i);
|
|
||||||
}
|
|
||||||
// Simple ID
|
|
||||||
else if (extractLongInteger (dep, lower))
|
|
||||||
task.addDependency (lower);
|
|
||||||
else
|
|
||||||
throw format ("Invalid dependency value: '{1}'", dep);
|
|
||||||
}
|
}
|
||||||
|
// ID range
|
||||||
|
else if (dep.find ('-') != std::string::npos &&
|
||||||
|
extractLongInteger (dep.substr (0, hyphen), lower) &&
|
||||||
|
extractLongInteger (dep.substr (hyphen + 1), upper))
|
||||||
|
{
|
||||||
|
for (long i = lower; i <= upper; i++)
|
||||||
|
if (removal)
|
||||||
|
task.removeDependency (i);
|
||||||
|
else
|
||||||
|
task.addDependency (i);
|
||||||
|
}
|
||||||
|
// Simple ID
|
||||||
|
else if (extractLongInteger (dep, lower))
|
||||||
|
if (removal)
|
||||||
|
task.removeDependency (lower);
|
||||||
|
else
|
||||||
|
task.addDependency (lower);
|
||||||
|
else
|
||||||
|
throw format ("Invalid dependency value: '{1}'", dep);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue