summaryrefslogtreecommitdiffstats
path: root/vendor/github.com/GeertJohan/go.rice/rice/main.go
diff options
context:
space:
mode:
authorWim <wim@42.be>2017-02-18 23:00:46 +0100
committerWim <wim@42.be>2017-02-18 23:11:48 +0100
commit930b639cc9cd2d2873302f30303378c0e53816a8 (patch)
tree8cd3f1d464fb5d4e5607fe16255c35a31a9d8b62 /vendor/github.com/GeertJohan/go.rice/rice/main.go
parent58483ea70c2c99a352592c5e50686fb03985650e (diff)
downloadmatterbridge-msglm-930b639cc9cd2d2873302f30303378c0e53816a8.tar.gz
matterbridge-msglm-930b639cc9cd2d2873302f30303378c0e53816a8.tar.bz2
matterbridge-msglm-930b639cc9cd2d2873302f30303378c0e53816a8.zip
Update vendor
Diffstat (limited to 'vendor/github.com/GeertJohan/go.rice/rice/main.go')
-rw-r--r--vendor/github.com/GeertJohan/go.rice/rice/main.go68
1 files changed, 68 insertions, 0 deletions
diff --git a/vendor/github.com/GeertJohan/go.rice/rice/main.go b/vendor/github.com/GeertJohan/go.rice/rice/main.go
new file mode 100644
index 00000000..7bac5fa3
--- /dev/null
+++ b/vendor/github.com/GeertJohan/go.rice/rice/main.go
@@ -0,0 +1,68 @@
+package main
+
+import (
+ "fmt"
+ "go/build"
+ "log"
+ "os"
+)
+
+func main() {
+ // parser arguments
+ parseArguments()
+
+ // find package for path
+ var pkgs []*build.Package
+ for _, importPath := range flags.ImportPaths {
+ pkg := pkgForPath(importPath)
+ pkgs = append(pkgs, pkg)
+ }
+
+ // switch on the operation to perform
+ switch flagsParser.Active.Name {
+ case "embed", "embed-go":
+ for _, pkg := range pkgs {
+ operationEmbedGo(pkg)
+ }
+ case "embed-syso":
+ log.Println("WARNING: embedding .syso is experimental..")
+ for _, pkg := range pkgs {
+ operationEmbedSyso(pkg)
+ }
+ case "append":
+ operationAppend(pkgs)
+ case "clean":
+ for _, pkg := range pkgs {
+ operationClean(pkg)
+ }
+ }
+
+ // all done
+ verbosef("\n")
+ verbosef("rice finished successfully\n")
+}
+
+// helper function to get *build.Package for given path
+func pkgForPath(path string) *build.Package {
+ // get pwd for relative imports
+ pwd, err := os.Getwd()
+ if err != nil {
+ fmt.Printf("error getting pwd (required for relative imports): %s\n", err)
+ os.Exit(1)
+ }
+
+ // read full package information
+ pkg, err := build.Import(path, pwd, 0)
+ if err != nil {
+ fmt.Printf("error reading package: %s\n", err)
+ os.Exit(1)
+ }
+
+ return pkg
+}
+
+func verbosef(format string, stuff ...interface{}) {
+ if flags.Verbose {
+ log.Printf(format, stuff...)
+ }
+}