Skip to main content

Buildout recipe to download bazaar branches

Project description

This recipe can be used to get development checkouts from Bazaar repositories for zc.buildout.

Installation and Setup

Read INSTALL.txt

Documentation

Goals

  • Allow fetching eggs directly from bzr repositories.

  • The specified repositories are branched locally on the first buildout run. It is possible to use these local branches for development and make local changes. The local changes can be committed locally, and can be pushed back to the remote repository or to any other location.

  • When buildout is run again, the branches are updated (pulled) automatically from the remote location. If pulling would cause conflicts, buildout stops with an error. The parent branch (pull) location remembered by bazaar will be used for pulling, so it is possible to change this any time from bzr.

  • Local changes can be pushed back to the remote branches. This is also enforced: When buildout wants to uninstall the local branches, they are checked. If they contain uncommitted or unpushed local changes, buildout stops with an error. This forces developers to save local changes to upstream and avoids loosing local work.

  • When buildout checks if the branches contain local changes, the parent (pull) location and the push location, remembered by bazaar, are used (in this order). This makes it possible to switch existing branches during development, without changing the buildout configuration.

  • Parameters are similar to those used with “infrae.subversion” and also compatible with the “bazaarrecipe” package.

  • With bzr-svn, the remote branch can also be an svn branch. So it actually can be used to branch off native svn repository branches as well (although, performance of updates and sanity checks may depend on bzr-svn’s performance, thus infrae.subversion may provide faster operation for svn.)

Usage

Usage example:

[bzr]
recipe = gf.recipe.bzr
urls =
    http://bazaar.launchpad.net/~kissbooth/kss.plugin.sdnd/trunk kss.plugin.sdnd
    http://bazaar.launchpad.net/~kissbooth/kss.plugin.livesearch/trunk kss.plugin.livesearch
in_parts = False
http_authentication = username:password

This will bzr get the branches to bzr/kss.plugin.sdnd and bzr/kss.plugin.livesearch. Branches are pulled if buildout is called. Uninstall is protected, if there are local modifications, or modifications that are missing in the upstream, an error will be raised. In case you create a local bzr directory, make sure it has a push location, otherwise uninstall will fail.

No directories are really removed on uninstall, this has the consequence that if the setup is changed, the local repositories will not follow it.

The in_parts option

in_parts is by default false, which means the directory that holds the branches is created in the buildout root. This is the default mode as it is handy for development. If in_parts = True is specified, then the directory will be created in the parts directory (compatible with infrae.subversion).

The http_authentication option

If http authentication is specified as username:password, it will be used for authenticating into http and https realms. This is rarely needed as ssh offers a more confortable repository access, but it allows password protected http access that would not be easy (or possible at all) otherwise.

The option is inactive with bzr+ssh:// repository urls.

The develop option

The branches fetched by the recipe are also installed as development eggs, by default. The develop = False option can be used to force the recipe not to develop the eggs. This can be useful, for example, to use buildout to update local read-only bazaar mirrors of an svn repository:

[kukit.js]
recipe = gf.recipe.bzr
urls=
    https://codespeak.net/svn/kukit/kukit.js/trunk              trunk
    https://codespeak.net/svn/kukit/kukit.js/branch/1.2         1.2
    https://codespeak.net/svn/kukit/kukit.js/branch/1.4         1.4
develop = False

[kss.demo]
recipe = gf.recipe.bzr
urls=
    https://codespeak.net/svn/kukit/kss.demo/trunk              trunk
    https://codespeak.net/svn/kukit/kss.demo/branch/1.2         1.2
    https://codespeak.net/svn/kukit/kss.demo/branch/1.4         1.4
develop = False

Offline mode is not supported for uninstalls

Offline mode is not supported for uninstalls, because there seems to be no way of detecting during uninstall, if we are in offline mode.

This means that if you run buildout in offline mode, and buildout decides that an uninstall is needed, the recipe will still attempt an online connection to the upstream repository. If this gets you into a deadlock, you need to run buildout in online mode, or remove your branches manually if you choose to resolve the situation by loosing all your local changes.

Other configuration needed

In addition you also need to include the eggs you configured with the recipe, in the buildout section:

[buildout]
...
eggs =
    ...
    kss.plugin.sdnd
    kss.plugin.livesearch

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gf.recipe.bzr-1.0dev-20090103.tar.gz (12.8 kB view details)

Uploaded Source

Built Distributions

gf.recipe.bzr-1.0dev_20090103-py2.5.egg (12.4 kB view details)

Uploaded Source

gf.recipe.bzr-1.0dev_20090103-py2.4.egg (12.5 kB view details)

Uploaded Source

File details

Details for the file gf.recipe.bzr-1.0dev-20090103.tar.gz.

File metadata

File hashes

Hashes for gf.recipe.bzr-1.0dev-20090103.tar.gz
Algorithm Hash digest
SHA256 928e831447c1e8531d912e8b9c546a6ce9e18e81eb375624df924e2e8ac7c227
MD5 6d75c2337229e1f9171c3798fe0fcadd
BLAKE2b-256 91fc678dd4e7ed5628b64453797a69163227967d0751db51af188a8fa402655c

See more details on using hashes here.

File details

Details for the file gf.recipe.bzr-1.0dev_20090103-py2.5.egg.

File metadata

File hashes

Hashes for gf.recipe.bzr-1.0dev_20090103-py2.5.egg
Algorithm Hash digest
SHA256 b88ecd173f9d8d770641326fc01aaf23c460fd302dd887592e29ad04886ab425
MD5 f64756cb30e97d51f8a3397622dd061c
BLAKE2b-256 5eb32dd4e09d282736ee062aa346072f40487042bfed2548a947419e00a571f5

See more details on using hashes here.

File details

Details for the file gf.recipe.bzr-1.0dev_20090103-py2.4.egg.

File metadata

File hashes

Hashes for gf.recipe.bzr-1.0dev_20090103-py2.4.egg
Algorithm Hash digest
SHA256 bd83cc4ec0860b2c965f7280d26869449ed0db42a42327da32725a7677742785
MD5 eff886ec440524e44d8a0918555a6d95
BLAKE2b-256 462beac60be252d5a388f1401e5952e8186fbfeb6df7889460f0a1c15474ccf8

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page