Skip to content

abstrakraft/rug

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

The Rug

The Rug

another repository of repositories implementation, inspired by git-repo, ivy and others

note that this document is a plan of operation, and that most of the commands and workflows in it are not yet implemented

formerly known as gitri

Installing and Checking Out the Rug Test Project

From the root of your rug repository (the directory containing this file), run

	python setup.py install

Then, to clone the test repository, run

	rug clone https://github.com/abstrakraft/rug-test-project.git

Nomenclature

  • repository: a git (or other VCS) repository. repo is accepted shorthand.
  • project: A collection of repos in a specified layout. A project is defined by a manifest repo.
  • revset: A set of revisions of the repos in a project. They are named by the branch of the project in which they are stored.

Workflows

New Project

use git to arrange repos and stuff

rug init [dir]

adds repos to "index" = working copy of manifest

rug add

publish changes to project

rug publish

Clone Project

rug clone <url> [dir] [revset]
rug checkout <revset>

Track server changes

fetches from all repos, rebases or merges in all changes

rug fetch
rug update

Create a new revset to work a ticket

creates a new branch in manifest

rug revset <new_revset> [source_revset]

use git to commit locally, change branches, etc.

rug develop

update local manifest file

rug add [-h|--hash|-b|--branch] <repo names>

commit local manifest file, push all repo branches and manifest branch

rug publish

Porcelain Commands

  • init create a new rug project
  • clone clone an existing rug project
  • update update all repos with upstream updates (fetch followed by ?resetish command?)
  • checkout checkout another revset.
  • revset create a new revset
  • add add a repos branch or commit to the local manifest file
  • publish push repo changes to servers (commit (manifest) followed by repo-push and manifest-push)
  • status print status of all repos (--deep option for internal status)
  • fetch fetch all repos
  • commit commit everything necessary to checkout another revset, then check out the current one again, and get the same "stuff"

Future Commands

  • reset reset a subset of repos to the proper rug branch
  • merge merge repos of other revsets into current one

Project Layout

The .rug folder in the main repo contains the manifest repo.

For each revset, and in each repo, the following branches exist:

  • live The name of the branch that should be checked out. Note that this is really just a branch name - what that name happens to point to doesn't mean anything.
  • rug Tracks the revset's local branch across checkouts. This branch points to the sha that should become the live branch when the revset in question is checked out.
  • rug_index Tracks the version of the revset's local branch that should be committed/published between checkouts.
  • bookmark Tracks the remote branch as of the last commit. Used to rebase changes on update if there is no bookmark_index.
  • bookmark_index Tracks the remote branch as of the last update. Used to rebase changes on update, if it exists. This branch is used so that bookmark is unaltered until the revset is committed.

A more detailed branch name is required because there may be branches with the same name from different sources, revsets, and remotes.

Current philosophy is that development from different revsets with the same branches, should be separate.

Branches

Checking out a revset for the first time creates the local rug branch (see above for naming convention). Note that two revsets that point to the same branch will have two local copies of that branch - this is by design. In this way, we implicitly maintain (committed, at least) local state of revsets between across checkouts. Checking out subsequent times leaves the current branch and checks out the local rug branch. Checkout options are passed straight through to git.

A message should be printed indicating the last time the revset was fetched from the server, and any local changes to the revset.

Command Implementation Details

  • 'checkout' checks out the rug branch of every repo in the manifest, recursively. Current repository status (HEAD, uncommited changes) is ignored.
  • 'fetch' recursively fetches, from the remotes indicated in the manifest, for all repos.
  • 'update' attempts to apply changes made to the rug branches to the current remote branch. The bookmark and bookmark_index branches are used to determine the original remote branch that changes were made against in the event of remote branches that are not descendants of previous versions of themselves.
  • 'add' "stages" changes made to repositories in something conceptually resembling an index. Changes to the name of a revision (sha or branch name) are recorded in the (uncommitted) manifest, and changes to the identity of the revision are recorded in the rug_index branch.
  • 'commit' records all changes that have been added. This involves committing the manifest, and if {rug,bookmark}_index exist, setting {rug,bookmark} to {rug,bookmark}_index and deleting {rug,bookmark}_index.
  • 'publish' pushes all committed changes. This involves pushing the manifest, as well as all repos whose revisions have changed name or identity. All repos are tested for push-ability before any are actually pushed to avoid inconsistent state.

Philosophy

Obviously, given the original name (gitri), rug is meant to mimic git in some sense. However, there are fundamental differences between managing "projects" and "repositories." Some loose design guidelines:

  1. Follow git when it makes sense.

  2. Similarly, and important enough to state explicitly, don't follow git when it doesn't make sense. Whether because git itself doesn't make sense, or because the design parameter in question simply doesn't map well to projects, doesn't matter.

  3. Modifying repositores (committing, changing branches) requires (for now) knowledge of the underlying version control software (git). However, a user should be able to clone a project and checkout various revsets, ALWAYS getting the correct thing (I'm referring to the quagmire that is fully-qualified branch names here), without any knowledge of the underlying vcs's.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages