Fix range calculation for done tasks
This commit is contained in:
parent
c69af9bcde
commit
6d0acf8db7
4 changed files with 35 additions and 7 deletions
|
|
@ -69,11 +69,14 @@ impl DateSpec {
|
|||
fn start_and_range(&self, s: &CommandState<'_>) -> Option<(NaiveDate, DateRange)> {
|
||||
let (start, range) = match s.command.command {
|
||||
Command::Task(_) => {
|
||||
let last_done = s.last_done();
|
||||
let start = last_done
|
||||
let start = s
|
||||
.last_done_completion()
|
||||
.filter(|_| self.start_at_done)
|
||||
.unwrap_or(self.start);
|
||||
let range_from = last_done.map(|date| date.succ()).unwrap_or(self.start);
|
||||
let range_from = s
|
||||
.last_done_root()
|
||||
.map(|date| date.succ())
|
||||
.unwrap_or(self.start);
|
||||
let range = s
|
||||
.range
|
||||
.expand_by(&self.end_delta)
|
||||
|
|
|
|||
|
|
@ -326,8 +326,8 @@ impl FormulaSpec {
|
|||
.move_by(&self.start_delta);
|
||||
|
||||
if let Command::Task(_) = s.command.command {
|
||||
if let Some(last_done) = s.last_done() {
|
||||
range = range.with_from(last_done.succ())?;
|
||||
if let Some(last_done_root) = s.last_done_root() {
|
||||
range = range.with_from(last_done_root.succ())?;
|
||||
}
|
||||
// TODO Otherwise, go back one year or so if no FROM is specified
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue