Previous: Driving Process Automation with arch Hooks, Up: Customizing Arch
This chapter will teach you one technique for speeding up access to an
arch
archive.
Consider an arch
version that contains many revisions:
mainline -------- base-0 patch-1 .... patch-23 patch-24 patch-25 ... patch-42
Suppose that a user (with no local pristine cache) wants to get
the
patch-42
revision. get
proceeds by first getting and unpacking
the base-0
revision, then getting each patch-<N>
changeset, in
order, and applying those to the tree.
If the list of changesets that need to be applied is long, or the sum
of their sizes large in comparison to the tree side, then this
implementation of get
is needlessly inefficient.
One way to speed up get
is by archive caching revisions – storing
"pre-built" copies of some revisions with the archive.
For example, the command:
% tla cacherev -A lord@emf.net--2003-example \ hello-world--mainline--0.1--patch-40
will build the patch-40
revision, package it up as a tar bundle, and
store a copy of that tar bundle in the patch-40
directory of the
archive.
Subsequently, a get
of patch-42
will work by first fetching the
cached copy of the patch-40
revision, then getting and applying the
changesets for patch-41
and patch-42
: a savings of 40
changesets.
Usage Note: At this time, it's left up to you to decide which
revisions to cache and which not. You might decide, for example, to
automatically cache certain revisions from a cron
job or to simply
cache revisions by-hand whenever you notice that get
is too slow.
In the future, we hope to add better support for automatically caching
revisions.