]> Cypherpunks repositories - gostls13.git/commitdiff
goinstall: process dependencies for package main
authorRoger Peppe <rogpeppe@gmail.com>
Mon, 21 Jun 2010 18:01:20 +0000 (11:01 -0700)
committerRuss Cox <rsc@golang.org>
Mon, 21 Jun 2010 18:01:20 +0000 (11:01 -0700)
Currently to install a command, you have to manually
goinstall each of the remote packages that it depends on.
This patch lets goinstall P work where P is
contains files in package main.
It does not actually build the package, but
it installs all of its dependencies and prints a message
to that effect.

R=rsc
CC=golang-dev
https://golang.org/cl/1301043

src/cmd/goinstall/main.go
src/cmd/goinstall/make.go
src/cmd/goinstall/parse.go

index 59e66288b9d84dc484b65917d3eac96536bd705f..ecd21536e328b44f3f3706c5659c0a635c76cf5b 100644 (file)
@@ -122,7 +122,7 @@ func install(pkg, parent string) {
        }
 
        // Install prerequisites.
-       files, m, err := goFiles(dir)
+       files, m, pkgname, err := goFiles(dir, parent == "")
        if err != nil {
                fmt.Fprintf(os.Stderr, "%s: %s: %s\n", argv0, pkg, err)
                errors = true
@@ -138,6 +138,14 @@ func install(pkg, parent string) {
        for p := range m {
                install(p, pkg)
        }
+       if pkgname == "main" {
+               if !errors {
+                       fmt.Fprintf(os.Stderr, "%s: %s's dependencies are installed.\n", argv0, pkg)
+               }
+               errors = true
+               visit[pkg] = done
+               return
+       }
 
        // Install this package.
        if !errors {
index 59fc332b61832523cae7a4dbcee1edc0ae537e3d..c15709b313c330f9c566a5b086bf01b5629c3e6e 100644 (file)
@@ -35,11 +35,10 @@ func domake(dir, pkg string, local bool) os.Error {
 // installing as package pkg.  It includes all *.go files in the directory
 // except those in package main and those ending in _test.go.
 func makeMakefile(dir, pkg string) ([]byte, os.Error) {
-       files, _, err := goFiles(dir)
+       files, _, _, err := goFiles(dir, false)
        if err != nil {
                return nil, err
        }
-
        var buf bytes.Buffer
        if err := makefileTemplate.Execute(&makedata{pkg, files}, &buf); err != nil {
                return nil, err
index 066c47ff5f3b4242d734a56b95d28cd488bb81d3..ae391ed9a95a713dbc5058506c2c9889e26a134f 100644 (file)
@@ -16,25 +16,25 @@ import (
        "go/parser"
 )
 
-// goFiles returns a list of the *.go source files in dir,
-// excluding those in package main or ending in _test.go.
-// It also returns a map giving the packages imported
-// by those files.  The map keys are the imported paths.
-// The key's value is one file that imports that path.
-func goFiles(dir string) (files []string, imports map[string]string, err os.Error) {
+// goFiles returns a list of the *.go source files in dir, excluding
+// those in package main (unless allowMain is true) or ending in
+// _test.go.  It also returns a map giving the packages imported by
+// those files, and the package name.
+// The map keys are the imported paths.  The key's value
+// is one file that imports that path.
+func goFiles(dir string, allowMain bool) (files []string, imports map[string]string, pkgName string, err os.Error) {
        f, err := os.Open(dir, os.O_RDONLY, 0)
        if err != nil {
-               return nil, nil, err
+               return nil, nil, "", err
        }
        dirs, err := f.Readdir(-1)
        f.Close()
        if err != nil {
-               return nil, nil, err
+               return nil, nil, "", err
        }
 
        files = make([]string, 0, len(dirs))
        imports = make(map[string]string)
-       pkgName := ""
        for i := range dirs {
                d := &dirs[i]
                if !strings.HasSuffix(d.Name, ".go") || strings.HasSuffix(d.Name, "_test.go") {
@@ -43,16 +43,23 @@ func goFiles(dir string) (files []string, imports map[string]string, err os.Erro
                filename := path.Join(dir, d.Name)
                pf, err := parser.ParseFile(filename, nil, nil, parser.ImportsOnly)
                if err != nil {
-                       return nil, nil, err
+                       return nil, nil, "", err
                }
                s := string(pf.Name.Name())
-               if s == "main" {
+               if s == "main" && !allowMain {
                        continue
                }
                if pkgName == "" {
                        pkgName = s
                } else if pkgName != s {
-                       return nil, nil, os.ErrorString("multiple package names in " + dir)
+                       // Only if all files in the directory are in package main
+                       // do we return pkgName=="main".
+                       // A mix of main and another package reverts
+                       // to the original (allowMain=false) behaviour.
+                       if allowMain && pkgName == "main" {
+                               return goFiles(dir, false)
+                       }
+                       return nil, nil, "", os.ErrorString("multiple package names in " + dir)
                }
                n := len(files)
                files = files[0 : n+1]
@@ -68,5 +75,5 @@ func goFiles(dir string) (files []string, imports map[string]string, err os.Erro
                        }
                }
        }
-       return files, imports, nil
+       return files, imports, pkgName, nil
 }