gogpm

command module
v0.0.0-...-e30d026 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 6, 2015 License: BSD-3-Clause Imports: 12 Imported by: 0

README

Gogpm

Gogpm is a go implementation of gpm

gogpm

gogpm is a tool for managing package dependency versions

gogpm leverages the power of the go get command and the underlying version control systems used by it to set your Go dependencies to desired versions, thus allowing easily reproducible builds in your Go projects.

A Godeps file in the root of your Go application is expected containing the import paths of your packages and a specific tag or commit hash from its version control system, an example Godeps file looks like this:

$ cat Godeps
# This is a comment
github.com/nu7hatch/gotrail         v0.0.2
github.com/replicon/fast-archiver   v1.02   #This is another comment!
github.com/nu7hatch/gotrail         2eb79d1f03ab24bacbc32b15b75769880629a865
Usage:
$ gogpm bootstrap [packages]    # Downloads all top-level packages required by the listed
                                # import paths and generates a Godeps file with their
                                # latest tags or revisions.
                                # For more about specifying packages, see 'go help packages'.

$ gogpm install                 # Parses the Godeps file, installs dependencies and sets
                                # them to the appropriate version.

$ gogpm version                 # Outputs version information

$ gogpm help                    # Prints this message
Example usage
$ ls .
Godeps  foo.go  foo_test.go

$ cat Godeps
github.com/nu7hatch/gotrail               v0.0.2
github.com/replicon/fast-archiver         v1.02
launchpad.net/gocheck                     r2013.03.03   # Bazaar repositories are supported
code.google.com/p/go.example/hello        ae081cd1d6cc  # And so are Mercurial ones

$ gpm install
>> Getting github.com/nu7hatch/gotrail
>> Setting github.com/nu7hatch/gotrail to version v0.0.2
>> Getting code.google.com/p/go.example/hello
>> Setting code.google.com/p/go.example/hello to version ae081cd1d6cc
>> Getting launchpad.net/gocheck
>> Setting launchpad.net/gocheck to version r2013.03.03
>> Getting github.com/replicon/fast-archiver
>> Setting github.com/replicon/fast-archiver to version v1.02
>> All Done

Goals

  • Keep things small and simple
  • Try to use go get wherever possible
  • No external dependencies
  • Use Go's own logic for package import path resolution (the vcs package code is from Go 1.2.2)
  • Don't replicate any functionality of go get

Differences from gpm

  • Gogpm does not implicitly run the install command when no arguments are given. You'll need to gogpm install
  • The bootstrap command behaves slightly differently
    • it includes dependencies in tests (gpm does not)
    • it takes optional arguments for packages (so that you can create a Godeps file with dependencies from multiple packages)
    • it does not update a package if it already exists (gpm does a go get -u on bootstrap)

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL