From 061cf9aef8eba1e4b921b4ae083539dd2bd3c9d0 Mon Sep 17 00:00:00 2001 From: Lunny Xiao Date: Tue, 10 Dec 2013 17:18:07 +0800 Subject: [PATCH 1/4] supports local path for gopmfile deps package's value --- cmd/cmd.go | 6 ++++++ cmd/get.go | 4 ++++ cmd/gopath.go | 23 ++++++++++++++++++++--- doc/struct.go | 3 ++- gopm.go | 2 +- 5 files changed, 33 insertions(+), 5 deletions(-) diff --git a/cmd/cmd.go b/cmd/cmd.go index a7c2ac839..d2bff0c43 100644 --- a/cmd/cmd.go +++ b/cmd/cmd.go @@ -18,6 +18,7 @@ import ( "os" "strings" + "github.com/Unknwon/com" "github.com/codegangsta/cli" "github.com/gpmgo/gopm/doc" @@ -56,6 +57,11 @@ func validPath(info string) (string, string) { l := len(infos) switch { case l == 1: + // for local imports + if com.IsFile(infos[0]) { + return doc.LOCAL, infos[0] + } + return doc.BRANCH, "" case l == 2: switch infos[1] { diff --git a/cmd/get.go b/cmd/get.go index 31668fdd5..ab98da8e0 100644 --- a/cmd/get.go +++ b/cmd/get.go @@ -180,6 +180,10 @@ func copyToGopath(srcPath, destPath string) { func downloadPackages(ctx *cli.Context, nodes []*doc.Node) { // Check all packages, they may be raw packages path. for _, n := range nodes { + // Check if local reference + if n.Type == doc.LOCAL { + continue + } // Check if it is a valid remote path. if doc.IsValidRemotePath(n.ImportPath) { gopathDir := path.Join(installGopath, n.ImportPath) diff --git a/cmd/gopath.go b/cmd/gopath.go index 65a1d8fdd..305ab1eba 100644 --- a/cmd/gopath.go +++ b/cmd/gopath.go @@ -52,6 +52,13 @@ func getGopmPkgs(dirPath string, isTest bool) (pkgs map[string]*doc.Pkg, err err Value: info[i+1:], } continue + } else if com.IsDir(info) { + pkgs[name] = &doc.Pkg{ + ImportPath: name, + Type: doc.LOCAL, + Value: info, + } + continue } } } @@ -81,7 +88,7 @@ func getChildPkgs(ctx *cli.Context, cpath string, ppkg *doc.Pkg, cachePkgs map[s pkg.RootPath = doc.GetProjectPath(pkg.ImportPath) if !pkgInCache(pkg.RootPath, cachePkgs) { var newPath string - if !build.IsLocalImport(name) { + if !build.IsLocalImport(name) && pkg.Type != doc.LOCAL { suf := versionSuffix(pkg.Value) pkgPath := strings.Replace( pkg.ImportPath, pkg.RootPath, pkg.RootPath+suf, 1) @@ -102,7 +109,11 @@ func getChildPkgs(ctx *cli.Context, cpath string, ppkg *doc.Pkg, cachePkgs map[s } } } else { - newPath, err = filepath.Abs(name) + if pkg.Type == doc.LOCAL { + newPath, err = filepath.Abs(pkg.Value) + } else { + newPath, err = filepath.Abs(name) + } if err != nil { return err } @@ -216,7 +227,13 @@ func genNewGoPath(ctx *cli.Context, isTest bool) { for name, pkg := range cachePkgs { 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) paths := strings.Split(name, "/") var isExistP, isCurChild bool diff --git a/doc/struct.go b/doc/struct.go index f92151618..96c538503 100644 --- a/doc/struct.go +++ b/doc/struct.go @@ -32,13 +32,14 @@ const ( TAG = "tag" BRANCH = "branch" COMMIT = "commit" + LOCAL = "local" ) type Pkg struct { ImportPath string RootPath string Type string - Value string // Branch, tag or commit. + Value string // Branch, tag, commit or local. } func (pkg *Pkg) VerString() string { diff --git a/gopm.go b/gopm.go index c3d3a7893..9bf0c7d64 100644 --- a/gopm.go +++ b/gopm.go @@ -29,7 +29,7 @@ import ( // Test that go1.1 tag above is included in builds. main.go refers to this definition. const go11tag = true -const APP_VER = "0.6.0.1209" +const APP_VER = "0.6.0.1210" // //cmd.CmdSearch, // cmdClean, From 56f5a6bce1d397ddfae05cf337916c8c55ba8d9f Mon Sep 17 00:00:00 2001 From: Lunny Xiao Date: Tue, 10 Dec 2013 18:04:28 +0800 Subject: [PATCH 2/4] fixed bug for windows --- cmd/gopath.go | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/cmd/gopath.go b/cmd/gopath.go index 305ab1eba..124906e77 100644 --- a/cmd/gopath.go +++ b/cmd/gopath.go @@ -44,19 +44,20 @@ func getGopmPkgs(dirPath string, isTest bool) (pkgs map[string]*doc.Pkg, err err if !doc.IsGoRepoPath(name) { if builds != nil { if info, ok := builds[name]; ok { - // Check version. - if i := strings.Index(info, ":"); i > -1 { + // Check version. there should chek + // local first because d:\ contains : + if com.IsDir(info) { pkgs[name] = &doc.Pkg{ ImportPath: name, - Type: info[:i], - Value: info[i+1:], + Type: doc.LOCAL, + Value: info, } continue - } else if com.IsDir(info) { + } else if i := strings.Index(info, ":"); i > -1 { pkgs[name] = &doc.Pkg{ ImportPath: name, - Type: doc.LOCAL, - Value: info, + Type: info[:i], + Value: info[i+1:], } continue } From 9dc90cac911e949557b60440c6cfc9930ea4498d Mon Sep 17 00:00:00 2001 From: Lunny Xiao Date: Wed, 11 Dec 2013 09:47:30 +0800 Subject: [PATCH 3/4] add trace --- cmd/gopath.go | 1 + doc/utils.go | 1 + 2 files changed, 2 insertions(+) diff --git a/cmd/gopath.go b/cmd/gopath.go index 124906e77..8b196275e 100644 --- a/cmd/gopath.go +++ b/cmd/gopath.go @@ -38,6 +38,7 @@ func getGopmPkgs(dirPath string, isTest bool) (pkgs map[string]*doc.Pkg, err err imports := doc.GetAllImports([]string{dirPath}, ".", false) pkgs = make(map[string]*doc.Pkg) for _, name := range imports { + println(name) if name == "C" { continue } diff --git a/doc/utils.go b/doc/utils.go index 7cc054e83..16c87593e 100644 --- a/doc/utils.go +++ b/doc/utils.go @@ -68,6 +68,7 @@ func GetImports(absPath, importPath string, example bool) []string { imports := make([]string, 0, len(pkg.Imports)) for _, p := range pkg.Imports { + println(p, IsGoRepoPath(p), importPath) if !IsGoRepoPath(p) && !strings.HasPrefix(p, importPath) { imports = append(imports, p) } From 9892de104e4eefd000e302ddca31aa2097da7e78 Mon Sep 17 00:00:00 2001 From: Lunny Xiao Date: Wed, 11 Dec 2013 10:32:18 +0800 Subject: [PATCH 4/4] remove trace --- cmd/gopath.go | 1 - doc/utils.go | 1 - 2 files changed, 2 deletions(-) diff --git a/cmd/gopath.go b/cmd/gopath.go index 8b196275e..124906e77 100644 --- a/cmd/gopath.go +++ b/cmd/gopath.go @@ -38,7 +38,6 @@ func getGopmPkgs(dirPath string, isTest bool) (pkgs map[string]*doc.Pkg, err err imports := doc.GetAllImports([]string{dirPath}, ".", false) pkgs = make(map[string]*doc.Pkg) for _, name := range imports { - println(name) if name == "C" { continue } diff --git a/doc/utils.go b/doc/utils.go index 16c87593e..7cc054e83 100644 --- a/doc/utils.go +++ b/doc/utils.go @@ -68,7 +68,6 @@ func GetImports(absPath, importPath string, example bool) []string { imports := make([]string, 0, len(pkg.Imports)) for _, p := range pkg.Imports { - println(p, IsGoRepoPath(p), importPath) if !IsGoRepoPath(p) && !strings.HasPrefix(p, importPath) { imports = append(imports, p) }