Compare commits
3 Commits
Author | SHA1 | Date | |
---|---|---|---|
d01d6e37f4 | |||
b98596574d | |||
ea9f8ea7ac |
174
nimble.lock
Normal file
174
nimble.lock
Normal file
@ -0,0 +1,174 @@
|
|||||||
|
{
|
||||||
|
"version": 2,
|
||||||
|
"packages": {
|
||||||
|
"asynctools": {
|
||||||
|
"version": "0.1.1",
|
||||||
|
"vcsRevision": "0e6bdc3ed5bae8c7cc9e03cfbf66b7c882a908a7",
|
||||||
|
"url": "https://github.com/cheatfate/asynctools",
|
||||||
|
"downloadMethod": "git",
|
||||||
|
"dependencies": [],
|
||||||
|
"checksums": {
|
||||||
|
"sha1": "54314dceabb06b20908ecb0f2c007e9ff3aaa054"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"isaac": {
|
||||||
|
"version": "0.1.3",
|
||||||
|
"vcsRevision": "45a5cbbd54ff59ba3ed94242620c818b9aad1b5b",
|
||||||
|
"url": "https://github.com/pragmagic/isaac/",
|
||||||
|
"downloadMethod": "git",
|
||||||
|
"dependencies": [],
|
||||||
|
"checksums": {
|
||||||
|
"sha1": "05c3583a954715d84b0bf1be97f9a503249e9cdf"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"uuids": {
|
||||||
|
"version": "0.1.11",
|
||||||
|
"vcsRevision": "8cb8720b567c6bcb261bd1c0f7491bdb5209ad06",
|
||||||
|
"url": "https://github.com/pragmagic/uuids/",
|
||||||
|
"downloadMethod": "git",
|
||||||
|
"dependencies": [
|
||||||
|
"isaac"
|
||||||
|
],
|
||||||
|
"checksums": {
|
||||||
|
"sha1": "393f5fcefbc8ad3cf167e59760144208ff8f9f76"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"unicodedb": {
|
||||||
|
"version": "0.11.2",
|
||||||
|
"vcsRevision": "c70f8bc8c7373265670e0575bc5eda36fe3761b0",
|
||||||
|
"url": "https://github.com/nitely/nim-unicodedb",
|
||||||
|
"downloadMethod": "git",
|
||||||
|
"dependencies": [],
|
||||||
|
"checksums": {
|
||||||
|
"sha1": "612c5955f91bd90a263ce914d1d5de74a33af3c6"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"regex": {
|
||||||
|
"version": "0.20.1",
|
||||||
|
"vcsRevision": "66f144f935cc73977c61185fab15a3147bf117ff",
|
||||||
|
"url": "https://github.com/nitely/nim-regex",
|
||||||
|
"downloadMethod": "git",
|
||||||
|
"dependencies": [
|
||||||
|
"unicodedb"
|
||||||
|
],
|
||||||
|
"checksums": {
|
||||||
|
"sha1": "ea9b6600443e73b1ea89a477c7a5d1fce742c9da"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"docopt": {
|
||||||
|
"version": "0.7.0",
|
||||||
|
"vcsRevision": "17803d1205f9e752cce03a66b0a29b710520398e",
|
||||||
|
"url": "https://github.com/docopt/docopt.nim",
|
||||||
|
"downloadMethod": "git",
|
||||||
|
"dependencies": [
|
||||||
|
"regex"
|
||||||
|
],
|
||||||
|
"checksums": {
|
||||||
|
"sha1": "21150284640b882fa91147181c52da3e5bb44df8"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"filetype": {
|
||||||
|
"version": "0.9.0",
|
||||||
|
"vcsRevision": "1fe1e7d988cd802abc26505efb5a91891bd6f53e",
|
||||||
|
"url": "https://github.com/jiro4989/filetype",
|
||||||
|
"downloadMethod": "git",
|
||||||
|
"dependencies": [],
|
||||||
|
"checksums": {
|
||||||
|
"sha1": "d2242b94eeb0f6d3810a8c71af4664f28853e1be"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"zero_functional": {
|
||||||
|
"version": "1.3.0",
|
||||||
|
"vcsRevision": "edf3b7f59119f75706da435c2b7f080a0cf4960c",
|
||||||
|
"url": "https://github.com/zero-functional/zero-functional",
|
||||||
|
"downloadMethod": "git",
|
||||||
|
"dependencies": [],
|
||||||
|
"checksums": {
|
||||||
|
"sha1": "2dc01ca0925ac1c2dcb46a0c6d9c93c57a9cddec"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"update_nim_package_version": {
|
||||||
|
"version": "0.2.0",
|
||||||
|
"vcsRevision": "5a78579fd7f88014263aed38c60327c85f6f8bcf",
|
||||||
|
"url": "https://git.jdb-software.com/jdb/update-nim-package-version",
|
||||||
|
"downloadMethod": "git",
|
||||||
|
"dependencies": [],
|
||||||
|
"checksums": {
|
||||||
|
"sha1": "37052b7ce30d5493ef24253a82a6087350b4eabb"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"data_uri": {
|
||||||
|
"version": "1.0.2",
|
||||||
|
"vcsRevision": "f43ac66e44c37edd3cc7282d75d6fa2fa031b2ec",
|
||||||
|
"url": "",
|
||||||
|
"downloadMethod": "git",
|
||||||
|
"dependencies": [
|
||||||
|
"docopt",
|
||||||
|
"filetype",
|
||||||
|
"zero_functional",
|
||||||
|
"update_nim_package_version"
|
||||||
|
],
|
||||||
|
"checksums": {
|
||||||
|
"sha1": "949c11ffab4e85ff538b0bd3e5bb193f118b56d7"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"timeutils": {
|
||||||
|
"version": "0.5.4",
|
||||||
|
"vcsRevision": "a9308cbaf3c89496b5832ddd18404dc0debe66a2",
|
||||||
|
"url": "https://git.jdb-software.com/jdb/nim-time-utils.git",
|
||||||
|
"downloadMethod": "git",
|
||||||
|
"dependencies": [],
|
||||||
|
"checksums": {
|
||||||
|
"sha1": "9ecd1020f5644bc59acb2f44ca9d30f4c7f066d3"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"cliutils": {
|
||||||
|
"version": "0.8.0",
|
||||||
|
"vcsRevision": "b1cc4fbe51d5e617789363efe716793ebe5bc5f1",
|
||||||
|
"url": "https://git.jdb-software.com/jdb/nim-cli-utils",
|
||||||
|
"downloadMethod": "git",
|
||||||
|
"dependencies": [
|
||||||
|
"docopt"
|
||||||
|
],
|
||||||
|
"checksums": {
|
||||||
|
"sha1": "5b114094c314007fa6f15e62852d62a58a3cbb62"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"langutils": {
|
||||||
|
"version": "0.4.0",
|
||||||
|
"vcsRevision": "8122660da3fc78132b823e76c9e990fd92802b0e",
|
||||||
|
"url": "https://git.jdb-software.com/jdb/nim-lang-utils.git",
|
||||||
|
"downloadMethod": "git",
|
||||||
|
"dependencies": [],
|
||||||
|
"checksums": {
|
||||||
|
"sha1": "2da09deb0e0bfc186000f0d941d06dd974bf6e58"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"httpbeast": {
|
||||||
|
"version": "0.4.1",
|
||||||
|
"vcsRevision": "abc13d11c210b614960fe8760e581d44cfb2e3e9",
|
||||||
|
"url": "https://github.com/dom96/httpbeast",
|
||||||
|
"downloadMethod": "git",
|
||||||
|
"dependencies": [
|
||||||
|
"asynctools"
|
||||||
|
],
|
||||||
|
"checksums": {
|
||||||
|
"sha1": "b23e57a401057dcb9b7fae1fb8279a6a2ce1d0b8"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"jester": {
|
||||||
|
"version": "0.5.0",
|
||||||
|
"vcsRevision": "a21b36a02b7745d6cdcda32d4ab3fba328cda17a",
|
||||||
|
"url": "https://github.com/dom96/jester/",
|
||||||
|
"downloadMethod": "git",
|
||||||
|
"dependencies": [
|
||||||
|
"httpbeast",
|
||||||
|
"asynctools"
|
||||||
|
],
|
||||||
|
"checksums": {
|
||||||
|
"sha1": "a192ca25bfc05d5de5c9a5fafca3b0cee47d82d2"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"tasks": {}
|
||||||
|
}
|
@ -1,6 +1,6 @@
|
|||||||
# Package
|
# Package
|
||||||
|
|
||||||
version = "4.21.2"
|
version = "4.22.2"
|
||||||
author = "Jonathan Bernard"
|
author = "Jonathan Bernard"
|
||||||
description = "Personal issue tracker."
|
description = "Personal issue tracker."
|
||||||
license = "MIT"
|
license = "MIT"
|
||||||
@ -21,7 +21,7 @@ requires @[
|
|||||||
requires @[
|
requires @[
|
||||||
"cliutils >= 0.6.4",
|
"cliutils >= 0.6.4",
|
||||||
"langutils >= 0.4.0",
|
"langutils >= 0.4.0",
|
||||||
"timeutils >= 0.4.0",
|
"timeutils >= 0.5.4",
|
||||||
"data_uri > 1.0.0",
|
"data_uri > 1.0.0",
|
||||||
"https://git.jdb-software.com/jdb/update-nim-package-version >= 0.2.0"
|
"https://git.jdb-software.com/jdb/update-nim-package-version >= 0.2.0"
|
||||||
]
|
]
|
||||||
|
39
src/pit.nim
39
src/pit.nim
@ -16,7 +16,6 @@ type
|
|||||||
cfg*: PitConfig
|
cfg*: PitConfig
|
||||||
contexts*: TableRef[string, string]
|
contexts*: TableRef[string, string]
|
||||||
defaultContext*: Option[string]
|
defaultContext*: Option[string]
|
||||||
tasksDir*: string
|
|
||||||
issues*: TableRef[IssueState, seq[Issue]]
|
issues*: TableRef[IssueState, seq[Issue]]
|
||||||
termWidth*: int
|
termWidth*: int
|
||||||
triggerPtk*, verbose*: bool
|
triggerPtk*, verbose*: bool
|
||||||
@ -43,7 +42,6 @@ proc initContext(args: Table[string, Value]): CliContext =
|
|||||||
else: some(cliJson["defaultContext"].getStr()),
|
else: some(cliJson["defaultContext"].getStr()),
|
||||||
verbose: parseBool(cliCfg.getVal("verbose", "false")) and not args["--quiet"],
|
verbose: parseBool(cliCfg.getVal("verbose", "false")) and not args["--quiet"],
|
||||||
issues: newTable[IssueState, seq[Issue]](),
|
issues: newTable[IssueState, seq[Issue]](),
|
||||||
tasksDir: pitCfg.tasksDir,
|
|
||||||
termWidth: parseInt(cliCfg.getVal("termWidth", "80")),
|
termWidth: parseInt(cliCfg.getVal("termWidth", "80")),
|
||||||
triggerPtk: cliJson.getOrDefault("triggerPtk").getBool(false))
|
triggerPtk: cliJson.getOrDefault("triggerPtk").getBool(false))
|
||||||
|
|
||||||
@ -169,15 +167,14 @@ proc formatSection(ctx: CliContext, issues: seq[Issue], state: IssueState,
|
|||||||
else: result &= ctx.formatSectionIssueList(issues, innerWidth, indent, verbose)
|
else: result &= ctx.formatSectionIssueList(issues, innerWidth, indent, verbose)
|
||||||
|
|
||||||
proc loadIssues(ctx: CliContext, state: IssueState) =
|
proc loadIssues(ctx: CliContext, state: IssueState) =
|
||||||
ctx.issues[state] = loadIssues(ctx.tasksDir / $state)
|
ctx.issues[state] = loadIssues(ctx.cfg.tasksDir, state)
|
||||||
|
|
||||||
proc loadOpenIssues(ctx: CliContext) =
|
proc loadOpenIssues(ctx: CliContext) =
|
||||||
ctx.issues = newTable[IssueState, seq[Issue]]()
|
ctx.issues = newTable[IssueState, seq[Issue]]()
|
||||||
for state in [Current, TodoToday, Todo, Pending, Todo]: ctx.loadIssues(state)
|
for state in [Current, TodoToday, Todo, Pending, Todo]: ctx.loadIssues(state)
|
||||||
|
|
||||||
proc loadAllIssues(ctx: CliContext) =
|
proc loadAllIssues(ctx: CliContext) =
|
||||||
ctx.issues = newTable[IssueState, seq[Issue]]()
|
ctx.issues = ctx.cfg.tasksDir.loadAllIssues()
|
||||||
for state in IssueState: ctx.loadIssues(state)
|
|
||||||
|
|
||||||
proc filterIssues(ctx: CliContext, filter: IssueFilter) =
|
proc filterIssues(ctx: CliContext, filter: IssueFilter) =
|
||||||
for state, issueList in ctx.issues:
|
for state, issueList in ctx.issues:
|
||||||
@ -214,7 +211,7 @@ proc reorder(ctx: CliContext, state: IssueState) =
|
|||||||
|
|
||||||
# load the issues to make sure the order file contains all issues in the state.
|
# load the issues to make sure the order file contains all issues in the state.
|
||||||
ctx.loadIssues(state)
|
ctx.loadIssues(state)
|
||||||
discard os.execShellCmd(EDITOR & " '" & (ctx.tasksDir / $state / "order.txt") & "' </dev/tty >/dev/tty")
|
discard os.execShellCmd(EDITOR & " '" & (ctx.cfg.tasksDir / $state / "order.txt") & "' </dev/tty >/dev/tty")
|
||||||
|
|
||||||
proc edit(issue: Issue) =
|
proc edit(issue: Issue) =
|
||||||
|
|
||||||
@ -380,7 +377,7 @@ when isMainModule:
|
|||||||
if tagsOption.isSome: tagsOption.get
|
if tagsOption.isSome: tagsOption.get
|
||||||
else: newSeq[string]())
|
else: newSeq[string]())
|
||||||
|
|
||||||
ctx.tasksDir.store(issue, state)
|
ctx.cfg.tasksDir.store(issue, state)
|
||||||
|
|
||||||
stdout.writeLine ctx.formatIssue(issue)
|
stdout.writeLine ctx.formatIssue(issue)
|
||||||
|
|
||||||
@ -400,7 +397,7 @@ when isMainModule:
|
|||||||
ctx.loadIssues(state)
|
ctx.loadIssues(state)
|
||||||
for issue in ctx.issues[state]: edit(issue)
|
for issue in ctx.issues[state]: edit(issue)
|
||||||
|
|
||||||
else: edit(ctx.tasksDir.loadIssueById(editRef))
|
else: edit(ctx.cfg.tasksDir.loadIssueById(editRef))
|
||||||
|
|
||||||
elif args["tag"]:
|
elif args["tag"]:
|
||||||
if tagsOption.isNone: raise newException(Exception, "no tags given")
|
if tagsOption.isNone: raise newException(Exception, "no tags given")
|
||||||
@ -408,7 +405,7 @@ when isMainModule:
|
|||||||
let newTags = tagsOption.get
|
let newTags = tagsOption.get
|
||||||
|
|
||||||
for id in @(args["<id>"]):
|
for id in @(args["<id>"]):
|
||||||
var issue = ctx.tasksDir.loadIssueById(id)
|
var issue = ctx.cfg.tasksDir.loadIssueById(id)
|
||||||
issue.tags = deduplicate(issue.tags & newTags)
|
issue.tags = deduplicate(issue.tags & newTags)
|
||||||
issue.store()
|
issue.store()
|
||||||
|
|
||||||
@ -418,7 +415,7 @@ when isMainModule:
|
|||||||
else: @[]
|
else: @[]
|
||||||
|
|
||||||
for id in @(args["<id>"]):
|
for id in @(args["<id>"]):
|
||||||
var issue = ctx.tasksDir.loadIssueById(id)
|
var issue = ctx.cfg.tasksDir.loadIssueById(id)
|
||||||
if tagsToRemove.len > 0:
|
if tagsToRemove.len > 0:
|
||||||
issue.tags = issue.tags.filter(
|
issue.tags = issue.tags.filter(
|
||||||
proc (tag: string): bool = not tagsToRemove.anyIt(it == tag))
|
proc (tag: string): bool = not tagsToRemove.anyIt(it == tag))
|
||||||
@ -437,24 +434,24 @@ when isMainModule:
|
|||||||
elif args["suspend"]: targetState = Dormant
|
elif args["suspend"]: targetState = Dormant
|
||||||
|
|
||||||
for id in @(args["<id>"]):
|
for id in @(args["<id>"]):
|
||||||
var issue = ctx.tasksDir.loadIssueById(id)
|
var issue = ctx.cfg.tasksDir.loadIssueById(id)
|
||||||
if propertiesOption.isSome:
|
if propertiesOption.isSome:
|
||||||
for k,v in propertiesOption.get:
|
for k,v in propertiesOption.get:
|
||||||
issue[k] = v
|
issue[k] = v
|
||||||
if targetState == Done:
|
if targetState == Done:
|
||||||
issue["completed"] = getTime().local.formatIso8601
|
issue["completed"] = getTime().local.formatIso8601
|
||||||
if issue.hasProp("recurrence") and issue.getRecurrence.isSome:
|
if issue.hasProp("recurrence") and issue.getRecurrence.isSome:
|
||||||
let nextIssue = ctx.tasksDir.nextRecurrence(issue.getRecurrence.get, issue)
|
let nextIssue = ctx.cfg.tasksDir.nextRecurrence(issue.getRecurrence.get, issue)
|
||||||
ctx.tasksDir.store(nextIssue, Todo)
|
ctx.cfg.tasksDir.store(nextIssue, Todo)
|
||||||
info "created the next recurrence:"
|
info "created the next recurrence:"
|
||||||
stdout.writeLine ctx.formatIssue(nextIssue)
|
stdout.writeLine ctx.formatIssue(nextIssue)
|
||||||
|
|
||||||
|
|
||||||
issue.changeState(ctx.tasksDir, targetState)
|
issue.changeState(ctx.cfg.tasksDir, targetState)
|
||||||
|
|
||||||
if ctx.triggerPtk or args["--ptk"]:
|
if ctx.triggerPtk or args["--ptk"]:
|
||||||
if targetState == Current:
|
if targetState == Current:
|
||||||
let issue = ctx.tasksDir.loadIssueById($(args["<id>"][0]))
|
let issue = ctx.cfg.tasksDir.loadIssueById($(args["<id>"][0]))
|
||||||
var cmd = "ptk start"
|
var cmd = "ptk start"
|
||||||
if issue.tags.len > 0 or issue.hasProp("context"):
|
if issue.tags.len > 0 or issue.hasProp("context"):
|
||||||
let tags = concat(
|
let tags = concat(
|
||||||
@ -471,14 +468,14 @@ when isMainModule:
|
|||||||
|
|
||||||
elif args["hide-until"]:
|
elif args["hide-until"]:
|
||||||
|
|
||||||
let issue = ctx.tasksDir.loadIssueById($(args["<id>"]))
|
let issue = ctx.cfg.tasksDir.loadIssueById($(args["<id>"]))
|
||||||
issue.setDateTime("hide-until", parseDate($args["<date>"]))
|
issue.setDateTime("hide-until", parseDate($args["<date>"]))
|
||||||
|
|
||||||
issue.store()
|
issue.store()
|
||||||
|
|
||||||
elif args["delegate"]:
|
elif args["delegate"]:
|
||||||
|
|
||||||
let issue = ctx.tasksDir.loadIssueById($(args["<id>"]))
|
let issue = ctx.cfg.tasksDir.loadIssueById($(args["<id>"]))
|
||||||
issue["delegated-to"] = $args["<delegated-to>"]
|
issue["delegated-to"] = $args["<delegated-to>"]
|
||||||
|
|
||||||
issue.store()
|
issue.store()
|
||||||
@ -486,7 +483,7 @@ when isMainModule:
|
|||||||
elif args["delete"] or args["rm"]:
|
elif args["delete"] or args["rm"]:
|
||||||
for id in @(args["<id>"]):
|
for id in @(args["<id>"]):
|
||||||
|
|
||||||
let issue = ctx.tasksDir.loadIssueById(id)
|
let issue = ctx.cfg.tasksDir.loadIssueById(id)
|
||||||
|
|
||||||
if not args["--yes"]:
|
if not args["--yes"]:
|
||||||
stderr.write("Delete '" & issue.summary & "' (y/n)? ")
|
stderr.write("Delete '" & issue.summary & "' (y/n)? ")
|
||||||
@ -569,7 +566,7 @@ when isMainModule:
|
|||||||
# List a specific issue
|
# List a specific issue
|
||||||
elif issueIdsOption.isSome:
|
elif issueIdsOption.isSome:
|
||||||
for issueId in issueIdsOption.get:
|
for issueId in issueIdsOption.get:
|
||||||
let issue = ctx.tasksDir.loadIssueById(issueId)
|
let issue = ctx.cfg.tasksDir.loadIssueById(issueId)
|
||||||
stdout.writeLine ctx.formatIssue(issue)
|
stdout.writeLine ctx.formatIssue(issue)
|
||||||
|
|
||||||
# List all issues
|
# List all issues
|
||||||
@ -585,7 +582,7 @@ when isMainModule:
|
|||||||
verbose = ctx.verbose)
|
verbose = ctx.verbose)
|
||||||
|
|
||||||
elif args["add-binary-property"]:
|
elif args["add-binary-property"]:
|
||||||
let issue = ctx.tasksDir.loadIssueById($(args["<id>"]))
|
let issue = ctx.cfg.tasksDir.loadIssueById($(args["<id>"]))
|
||||||
|
|
||||||
let propIn =
|
let propIn =
|
||||||
if $(args["<propSource>"]) == "-": stdin
|
if $(args["<propSource>"]) == "-": stdin
|
||||||
@ -597,7 +594,7 @@ when isMainModule:
|
|||||||
issue.store()
|
issue.store()
|
||||||
|
|
||||||
elif args["get-binary-property"]:
|
elif args["get-binary-property"]:
|
||||||
let issue = ctx.tasksDir.loadIssueById($(args["<id>"]))
|
let issue = ctx.cfg.tasksDir.loadIssueById($(args["<id>"]))
|
||||||
|
|
||||||
if not issue.hasProp($(args["<propName>"])):
|
if not issue.hasProp($(args["<propName>"])):
|
||||||
raise newException(Exception,
|
raise newException(Exception,
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
const PIT_VERSION* = "4.21.2"
|
const PIT_VERSION* = "4.22.2"
|
||||||
|
|
||||||
const USAGE* = """Usage:
|
const USAGE* = """Usage:
|
||||||
pit ( new | add) <summary> [<state>] [options]
|
pit ( new | add) <summary> [<state>] [options]
|
||||||
|
@ -306,6 +306,13 @@ proc loadIssues*(path: string): seq[Issue] =
|
|||||||
# Finally, save current order
|
# Finally, save current order
|
||||||
result.storeOrder(path)
|
result.storeOrder(path)
|
||||||
|
|
||||||
|
proc loadIssues*(tasksDir: string, state: IssueState): seq[Issue] =
|
||||||
|
loadIssues(tasksDir / $state)
|
||||||
|
|
||||||
|
proc loadAllIssues*(tasksDir: string): TableRef[IssueState, seq[Issue]] =
|
||||||
|
result = newTable[IssueState, seq[Issue]]()
|
||||||
|
for state in IssueState: result[state] = tasksDir.loadIssues(state)
|
||||||
|
|
||||||
proc changeState*(issue: Issue, tasksDir: string, newState: IssueState) =
|
proc changeState*(issue: Issue, tasksDir: string, newState: IssueState) =
|
||||||
let oldFilepath = issue.filepath
|
let oldFilepath = issue.filepath
|
||||||
if newState == Done: issue.setDateTime("completed", getTime().local)
|
if newState == Done: issue.setDateTime("completed", getTime().local)
|
||||||
@ -378,6 +385,14 @@ proc filter*(issues: seq[Issue], filter: IssueFilter): seq[Issue] =
|
|||||||
for exclTag in filter.exclTags:
|
for exclTag in filter.exclTags:
|
||||||
result = result.filterIt(it.tags.find(exclTag) < 0)
|
result = result.filterIt(it.tags.find(exclTag) < 0)
|
||||||
|
|
||||||
|
proc find*(
|
||||||
|
issues: TableRef[IssueState, seq[Issue]],
|
||||||
|
filter: IssueFilter
|
||||||
|
): seq[Issue] =
|
||||||
|
|
||||||
|
result = @[]
|
||||||
|
for stateIssues in issues.values: result &= stateIssues.filter(filter)
|
||||||
|
|
||||||
### Configuration utilities
|
### Configuration utilities
|
||||||
proc loadConfig*(args: Table[string, Value] = initTable[string, Value]()): PitConfig =
|
proc loadConfig*(args: Table[string, Value] = initTable[string, Value]()): PitConfig =
|
||||||
let pitrcLocations = @[
|
let pitrcLocations = @[
|
||||||
|
Reference in New Issue
Block a user