NAME

pt - command to manipulate pairtrees

SYNOPSIS

pt [-d dir] mktree directory [prefix]
pt [-l] [-d dir] [rmtree | lstree] [directory] ...
pt [-d dir] [mknode | rmnode | lsnode] id ...
pt [i2p | p2i] name ...

DESCRIPTION

The pt utility introduces commands that can be used to create, delete, modify, and report on a pairtree. When not made explicit via an argument (see the first two forms above), the pairtree in question is assumed to reside in a pairtree_root/ directory descending from the current directory or from a directory specified with -d.

The first form creates a pairtree, recording an optional prefix that will be stripped from an identifier before mapping it to a pairpath and prepended to an identifier generated from a pairpath. The second form deletes or lists an entire tree of nodes. The format of listing output can be specified with the --format option, currently one of "ANVL", "XML", "JSON", or "Plain" (default).

The third form creates, deletes, or tests the existence of tree nodes addressed via the identifier corresponding to each node's filesystem pairpath directory. When mknode is used with a non-existent pairtree, it will attempt first to create a pairtree. After creating a new pairpath, mknode will create a bud directory to encapsulate the new tree leaf (that will not otherwise be supplied by pt).

By default, the bud directory name will be taken from the full form of the identifier. While a pairpath may have any length, to properly encapsulate a leaf, there must be one and only one bud, and its name must be more than two characters long. An identifier shorter than that requires padding the bud name on the left with `0' (zero), except for an empty identifier, when the bud name simply becomes "supernode".

If -l is also given for lstree, the total number of octets and files within each leaf is listed after its identifier.

The fourth form permits access to the purely lexical lower level conversion between identifiers and pairpaths (no filesystem lookups take place).

This beta-level software has not been extensively tested.

EXAMPLES

$ pt mknode foo bar zafp
./pairtree_root/fo/o/foo
./pairtree_root/ba/r/bar
./pairtree_root/za/fp/zafp
$ pt rmnode bar
removed: bar | ./pairtree_root/ba/r/
$ touch ./pairtree_root/za/fp/zafp/{a,b,c}
$ pt lstree -l
zafp   0.3
foo   0.0
2 objects
$ pt mknode ab c ''
./pairtree_root/ab/0ab
./pairtree_root/c/00c
./pairtree_root/supernode

OPTIONS

-d directory

Specify pairtree directory. A "pairtree_root" component will be added on if not already present in directory.

-m format, --format format

Output in the given format, currently one of "ANVL", "XML", "JSON", or "Plain" (default).

-h, --help

Print extended help documentation.

-l, --long

Print more detailed listings.

--man

Print full documentation.

--version

Print the current version number and exit.

-bmfa

Options yet to come, for --bud, --force, --all.

SEE ALSO

touch(1)

AUTHOR

John Kunze jak at ucop dot edu

COPYRIGHT

Copyright 2009-2010 UC Regents. Open source BSD license.