The Hackerlab at regexps.com

Speeding up arch with Revision Tree Libraries

up: arch Meets hello-world
next: Driving Process Automation with arch Hooks
prev: Speeding up arch by Caching Revisions in Archives

For many purposes, it is useful to have a library containing pristine trees of a large number of revisions -- for example, all of the revisions in a particular version. To be practical, though, such a library must be represented in a space-efficient way.

Unix hard-links provide a natural way to store such a library. Each successive revision in a series is a copy of the previous, but with unmodified files shared via hard-links.

arch provides commands to help you build, maintain, and browse such a library.

As a pleasant side effect, many arch commands are speeded up if the revisions they need to operate are present in your revision library. You can read more about this in the next chapter.

Your Revision Library Location

To begin a new revision library, first create a new directory (DIR ) and then register its location:

        % tla my-revision-library DIR

You can check the location of your library with:

        % tla my-revision-library

or unregister it with:

        % tla my-revision-library -d

Revision Library Format

A revision library has subdirectories of the form:

        ARCHIVE-NAME/CATEGORY/BRANCH/VERSION/REVISION/

Each REVISION directory contains the complete source of a particular revision, along with some supplemantary subdirectories and files:


        REVISION/,,patch-set/

                The patch set that creates this revision from
                its ancestor (unless the revision is a full-source
                base revision).


Although the permissions on files in the revision library are determined as determined by patch sets, you must never modify files int the revision library. Doing so will cause odd errors and failures in various arch commands.

Adding a Revision to the Library

You can add a selected revision to your revision library with:

        % tla library-add REVISION

That will add not only REVISION to the library, but all directly preceeding revisions (recursively) which are either from the same archive, or from other archives which are also in the same library. ("Directly preceeding" in this case means the previous patch level, for ordinary revisions, or the tagged revision (for revisions which are tags).)

Finding a Revision in the Library

You can find a particular revision in the library with library-find :

        % tla library-find REVISION
        PATH-TO-REVSION

The output is an absolute path name to the library directory containing the revision. (Once again, you must not modify files in that directory.)

Removing a Revision from the Library

To remove a particular revision from the library, use:

        % tla library-remove REVISION

Be aware of the following limitation in the current release: suppose that you add three successive revisions, A , B , and C . Then you remove B , then re-add B . Now there is a chance that the file sharing between B and C will be less than optimal, causing your library to be larger than it needs to be. (You can fix this by then removing and re-adding C .)

Listing Library Contents

The command library-archives lists all archives with records in the library:

        % tla library-archives
        ARCHIVE-NAME
        ARCHIVE-NAME
        ...

Similarly, you can list categories, branches, versions, or revisions:

        % tla library-categories [ARCHIVE]
        % tla library-branches [ARCHIVE/CATEGORY]
        % tla library-versions [ARCHIVE/BRANCH]
        % tla library-revisions [ARCHIVE/VERSION]

Individual Files in the Revision Library

You can locate an individual file in a revision library with:

        % tla library-file FILE [REVISION]
        PATH

or obtain its contents with:

        % tla cat-library-file FILE [REVISION]
        ...file contents...

Both commands accept the options --id and --this . With --id , the argument FILE is interpreted as an inventory id, and the file with that id is found.

With --this , FILE is interpreted as a file relative to the current directory, which should be part of a project tree. The file's inventory id is computed and the corresponding file found in REVISION .

Determining Patch Set Prerequisits

          % tla touched-files-prereqs REVISION

That command looks at the patch set for REVISION and at all preceding patch sets in the same version (it searches your library rather than your repository for this purpose). It reports the list of patches that touch overlapping sets of files and directories -- in other words, it tells you what patches can be applied independently of others. The command has an option to exclude from consideration file names matching a certain pattern (e.g. =README or ChangeLog ). It has an option to exclude from the output list patches which have already been applied to a given project tree. It has an option to report the specific files which are overlapped.

arch Meets hello-world: A Tutorial Introduction to The arch Revision Control System
The Hackerlab at regexps.com