Skip to main content

Repo helps manage many Git repositories, does the uploads to revision control systems, and automates parts of the development workflow.

Project description

repo

Repo is a tool built on top of Git. Repo helps manage many Git repositories, does the uploads to revision control systems, and automates parts of the development workflow. Repo is not meant to replace Git, only to make it easier to work with Git. The repo command is an executable Python script that you can put anywhere in your path.

Contact

Please use the repo-discuss mailing list or issue tracker for questions.

You can file a new bug report under the "repo" component.

Please do not e-mail individual developers for support. They do not have the bandwidth for it, and often times questions have already been asked on repo-discuss or bugs posted to the issue tracker. So please search those sites first.

Install

Many distros include repo, so you might be able to install from there.

# Debian/Ubuntu.
$ sudo apt-get install repo

# Gentoo.
$ sudo emerge dev-vcs/repo

You can install it manually as well as it's a single script.

$ mkdir -p ~/.bin
$ PATH="${HOME}/.bin:${PATH}"
$ curl https://storage.googleapis.com/git-repo-downloads/repo > ~/.bin/repo
$ chmod a+rx ~/.bin/repo

About pypi version

Version in pypi is not the official version from google, but a friendly fork (https://github.com/tardyp/google-repo), with support for normal setup.py style installation

  • local imports replaced by module imports, "repo" being the name of the python module
  • subcommand discovery uses the python entrypoint system
  • support for custom repo subcommand in an separate python package

It would be difficult to support a version that supports all of that and the legacy installation mode, this is why we didn't work on upstreaming it yet.

This version is used in a large installation and backup by automated internal tests that we cannot really share yet (as dependent on our infra)

Installation

pip3 install --user gitrepo

Custom commands

  • create a python module starting from any example in the repo/subcmds directory

  • add an entrypoint to your setup.py module:

  setup(...,
    install_requires=["gitrepo"],
    entry_points={
      'repo.subcmds': [
        'my_custom_cmd = mycustomrepo.my_custom_cmd:CustomCmd',
    }
  )

Then you can ask your developers to install your own mycustomrepo package instead of the gitrepo package.

Project details


Download files

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

Files for gitrepo, version 2.6.0
Filename, size File type Python version Upload date Hashes
Filename, size gitrepo-2.6.0-py2.py3-none-any.whl (177.1 kB) File type Wheel Python version py2.py3 Upload date Hashes View
Filename, size gitrepo-2.6.0.tar.gz (143.9 kB) File type Source Python version None Upload date Hashes View

Supported by

Pingdom Pingdom Monitoring Google Google Object Storage and Download Analytics Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN DigiCert DigiCert EV certificate StatusPage StatusPage Status page