Browse Source

merge from gopmfile

pull/103/head
Lunny Xiao 11 years ago
parent
commit
35e6f39c7c
  1. 6
      cmd/cmd.go
  2. 4
      cmd/get.go
  3. 26
      cmd/gopath.go
  4. 3
      doc/struct.go
  5. 2
      gopm.go

6
cmd/cmd.go

@ -18,6 +18,7 @@ import (
"os" "os"
"strings" "strings"
"github.com/Unknwon/com"
"github.com/codegangsta/cli" "github.com/codegangsta/cli"
"github.com/gpmgo/gopm/doc" "github.com/gpmgo/gopm/doc"
@ -56,6 +57,11 @@ func validPath(info string) (string, string) {
l := len(infos) l := len(infos)
switch { switch {
case l == 1: case l == 1:
// for local imports
if com.IsFile(infos[0]) {
return doc.LOCAL, infos[0]
}
return doc.BRANCH, "" return doc.BRANCH, ""
case l == 2: case l == 2:
switch infos[1] { switch infos[1] {

4
cmd/get.go

@ -180,6 +180,10 @@ func copyToGopath(srcPath, destPath string) {
func downloadPackages(ctx *cli.Context, nodes []*doc.Node) { func downloadPackages(ctx *cli.Context, nodes []*doc.Node) {
// Check all packages, they may be raw packages path. // Check all packages, they may be raw packages path.
for _, n := range nodes { for _, n := range nodes {
// Check if local reference
if n.Type == doc.LOCAL {
continue
}
// Check if it is a valid remote path. // Check if it is a valid remote path.
if doc.IsValidRemotePath(n.ImportPath) { if doc.IsValidRemotePath(n.ImportPath) {
gopathDir := path.Join(installGopath, n.ImportPath) gopathDir := path.Join(installGopath, n.ImportPath)

26
cmd/gopath.go

@ -44,8 +44,16 @@ func getGopmPkgs(dirPath string, isTest bool) (pkgs map[string]*doc.Pkg, err err
if !doc.IsGoRepoPath(name) { if !doc.IsGoRepoPath(name) {
if builds != nil { if builds != nil {
if info, ok := builds[name]; ok { if info, ok := builds[name]; ok {
// Check version. // Check version. there should chek
if i := strings.Index(info, ":"); i > -1 { // local first because d:\ contains :
if com.IsDir(info) {
pkgs[name] = &doc.Pkg{
ImportPath: name,
Type: doc.LOCAL,
Value: info,
}
continue
} else if i := strings.Index(info, ":"); i > -1 {
pkgs[name] = &doc.Pkg{ pkgs[name] = &doc.Pkg{
ImportPath: name, ImportPath: name,
Type: info[:i], Type: info[:i],
@ -81,7 +89,7 @@ func getChildPkgs(ctx *cli.Context, cpath string, ppkg *doc.Pkg, cachePkgs map[s
pkg.RootPath = doc.GetProjectPath(pkg.ImportPath) pkg.RootPath = doc.GetProjectPath(pkg.ImportPath)
if !pkgInCache(pkg.RootPath, cachePkgs) { if !pkgInCache(pkg.RootPath, cachePkgs) {
var newPath string var newPath string
if !build.IsLocalImport(name) { if !build.IsLocalImport(name) && pkg.Type != doc.LOCAL {
suf := versionSuffix(pkg.Value) suf := versionSuffix(pkg.Value)
pkgPath := strings.Replace( pkgPath := strings.Replace(
pkg.ImportPath, pkg.RootPath, pkg.RootPath+suf, 1) pkg.ImportPath, pkg.RootPath, pkg.RootPath+suf, 1)
@ -101,8 +109,12 @@ func getChildPkgs(ctx *cli.Context, cpath string, ppkg *doc.Pkg, cachePkgs map[s
// TODO: Should handler download failed // TODO: Should handler download failed
} }
} }
} else {
if pkg.Type == doc.LOCAL {
newPath, err = filepath.Abs(pkg.Value)
} else { } else {
newPath, err = filepath.Abs(name) newPath, err = filepath.Abs(name)
}
if err != nil { if err != nil {
return err return err
} }
@ -216,7 +228,13 @@ func genNewGoPath(ctx *cli.Context, isTest bool) {
for name, pkg := range cachePkgs { for name, pkg := range cachePkgs {
suf := versionSuffix(pkg.Value) suf := versionSuffix(pkg.Value)
oldPath := filepath.Join(installRepoPath, name) + suf var oldPath string
if pkg.Type == doc.LOCAL {
oldPath, _ = filepath.Abs(pkg.Value)
} else {
oldPath = filepath.Join(installRepoPath, name) + suf
}
newPath := filepath.Join(newGoPathSrc, name) newPath := filepath.Join(newGoPathSrc, name)
paths := strings.Split(name, "/") paths := strings.Split(name, "/")
var isExistP, isCurChild bool var isExistP, isCurChild bool

3
doc/struct.go

@ -32,13 +32,14 @@ const (
TAG = "tag" TAG = "tag"
BRANCH = "branch" BRANCH = "branch"
COMMIT = "commit" COMMIT = "commit"
LOCAL = "local"
) )
type Pkg struct { type Pkg struct {
ImportPath string ImportPath string
RootPath string RootPath string
Type string Type string
Value string // Branch, tag or commit. Value string // Branch, tag, commit or local.
} }
func (pkg *Pkg) VerString() string { func (pkg *Pkg) VerString() string {

2
gopm.go

@ -29,7 +29,7 @@ import (
// Test that go1.1 tag above is included in builds. main.go refers to this definition. // Test that go1.1 tag above is included in builds. main.go refers to this definition.
const go11tag = true const go11tag = true
const APP_VER = "0.6.0.1209" const APP_VER = "0.6.0.1210"
// //cmd.CmdSearch, // //cmd.CmdSearch,
// cmdClean, // cmdClean,

Loading…
Cancel
Save