ls command: include projects, list all if no specific context is named.

This commit is contained in:
Jonathan Bernard 2013-08-05 10:21:45 -05:00
parent 4339a7db2a
commit a2f8b7b7a6
2 changed files with 28 additions and 29 deletions

View File

@ -1,8 +1,8 @@
#Wed, 19 Jun 2013 10:34:26 -0500
#Mon, 05 Aug 2013 10:16:09 -0500
lib.local=true
name=jdb-gtd
version=1.0
version=1.1
nailgun.classpath.dir=/home/jdbernard/programs/nailgun/classpath
executable.jar=true
main.class=com.jdblabs.gtd.cli.GTDCLI
build.number=3
build.number=2

View File

@ -10,7 +10,7 @@ import org.joda.time.DateTime
public class GTDCLI {
public static final String VERSION = "1.0"
public static final String VERSION = "1.1"
private static String EOL = System.getProperty("line.separator")
private static GTDCLI nailgunInst
@ -98,7 +98,7 @@ public class GTDCLI {
case ~/list-copies/: listCopies(parsedArgs); break
case ~/new/: newAction(parsedArgs); break
case ~/tickler/: tickler(parsedArgs); break
case ~/ls|list-context/: ls(parsedArgs); break;
case ~/ls|list/: ls(parsedArgs); break;
default:
println "Unrecognized command: ${command}"
break } } }
@ -380,35 +380,33 @@ public class GTDCLI {
protected void ls(LinkedList args) {
def context = args.poll()
if (!context) return
def contextNextActions = new File(gtdDirs['next-actions'], context)
def contextWaiting = new File(gtdDirs.waiting, context)
def target = args.poll()
def printItems = { dir ->
if (!dir.exists() || !dir.isDirectory()) return
println "-- ${getRelativePath(gtdDirs.root, dir)} --"
dir.eachFile { file ->
if (!file.exists() || !file.isFile() || file.isHidden())
return
def item = new Item(file)
println item.action }
println "" }
if (!contextNextActions.exists())
println "next-actions/${context} does not exist, skipping"
else if (!contextNextActions.isDirectory())
println "next-actions/${context} is not a directory, skipping"
else {
println "-- next-actions/${context} --"
printItems(contextNextActions) }
// If we have a named context or project, look for those items
// specifically
if (target) {
printItems(new File(gtdDirs['next-actions'], target))
printItems(new File(gtdDirs.waiting, target))
printItems(new File(gtdDirs.projects, target)) }
if (!contextWaiting.exists())
println "waiting/${context} does not exist, skipping"
else if (!contextWaiting.isDirectory())
println "waiting/${context} is not a directory, skipping"
else {
println "-- waiting/${context} --"
printItems(contextWaiting) } }
printItems(gtdDirs['next-actions'])
printItems(gtdDirs['waiting'])
gtdDirs['next-actions'].eachDir(printItems)
gtdDirs['waiting'].eachDir(printItems) } }
protected void printUsage(LinkedList args) {
@ -532,11 +530,12 @@ and moves them out of the tickler file and into the next-actions file."""
break
case ~/ls|list-context/: println """\
usage gtd ls <context> [<context> ...]
usage gtd ls [<context> ...]
This command lists all the tasks for a given context. The purpose is to list in
one place items that are sitting in the next-actions folder or the waiting
folder for a specific context."""
This command lists all the tasks for a given context or project. The purpose is
to list in one place items that are sitting in the next-actions folder or the
waiting folder for a specific context or list items for a given project. If no
context or project is named, all contexts are listed."""
}
}
}
@ -571,7 +570,7 @@ folder for a specific context."""
// parent path.
return true }
protected String getRelativePath(File parent, File child) {
protected static String getRelativePath(File parent, File child) {
def parentPath = parent.canonicalPath.split("/")
def childPath = child.canonicalPath.split("/")