mirror of
				https://github.com/beego/bee.git
				synced 2025-10-25 22:13:52 +00:00 
			
		
		
		
	1. new,api,hprose 命令增加两个参数 [-module=true] [-beego=v1.12.1] 用于生成go module项目
2. generate,migrate命令不再打印GOPATH. 3. pack命令排除。 4. run命令支持传递ldflags参数 5. fix watch file bug.ignoredFilesRegExps数组对每个文件增加$,防止目录存在tmp的情况 6. getPackagePath函数被调用时如果找不到GOPATH,则看看工程有没有go.mod 有就当做go module项目处理。 7. .travis.yml检查时排除/pkg/mod/目录
This commit is contained in:
		| @@ -15,8 +15,10 @@ | ||||
| package generate | ||||
|  | ||||
| import ( | ||||
| 	"bufio" | ||||
| 	"database/sql" | ||||
| 	"fmt" | ||||
| 	"io" | ||||
| 	"os" | ||||
| 	"path" | ||||
| 	"path/filepath" | ||||
| @@ -948,11 +950,40 @@ func getFileName(tbName string) (filename string) { | ||||
| func getPackagePath(curpath string) (packpath string) { | ||||
| 	gopath := os.Getenv("GOPATH") | ||||
| 	if gopath == "" { | ||||
| 		beeLogger.Log.Fatal("GOPATH environment variable is not set or empty") | ||||
| 		info := "GOPATH environment variable is not set or empty" | ||||
| 		gomodpath := filepath.Join(curpath, `go.mod`) | ||||
| 		re, err := regexp.Compile(`^module\s+(.+)$`) | ||||
| 		if err != nil { | ||||
| 			beeLogger.Log.Error(info) | ||||
| 			beeLogger.Log.Fatalf("try `go.mod` generate regexp error:%s", err) | ||||
| 			return "" | ||||
| 		} | ||||
| 		fd, err := os.Open(gomodpath) | ||||
| 		if err != nil { | ||||
| 			beeLogger.Log.Error(info) | ||||
| 			beeLogger.Log.Fatalf("try `go.mod`  Error while reading 'go.mod',%s", gomodpath) | ||||
| 		} | ||||
| 		reader := bufio.NewReader(fd) | ||||
| 		for { | ||||
| 			byteLine, _, er := reader.ReadLine() | ||||
| 			if er != nil && er != io.EOF { | ||||
| 				return "" | ||||
| 			} | ||||
| 			if er == io.EOF { | ||||
| 				break | ||||
| 			} | ||||
| 			line := string(byteLine) | ||||
| 			s := re.FindStringSubmatch(line) | ||||
| 			if len(s) >= 2 { | ||||
| 				return s[1] | ||||
| 			} | ||||
| 		} | ||||
| 		beeLogger.Log.Error(info) | ||||
| 		beeLogger.Log.Fatalf("try `go.mod` Error while parse 'go.mod',%s", gomodpath) | ||||
| 	} else { | ||||
| 		beeLogger.Log.Debugf("GOPATH: %s", utils.FILE(), utils.LINE(), gopath) | ||||
| 	} | ||||
|  | ||||
| 	beeLogger.Log.Debugf("GOPATH: %s", utils.FILE(), utils.LINE(), gopath) | ||||
|  | ||||
| 	appsrcpath := "" | ||||
| 	haspath := false | ||||
| 	wgopath := filepath.SplitList(gopath) | ||||
|   | ||||
| @@ -432,22 +432,27 @@ func analyseControllerPkg(vendorPath, localName, pkgpath string) { | ||||
| 		pps := strings.Split(pkgpath, "/") | ||||
| 		importlist[pps[len(pps)-1]] = pkgpath | ||||
| 	} | ||||
| 	gopaths := bu.GetGOPATHs() | ||||
| 	if len(gopaths) == 0 { | ||||
| 		beeLogger.Log.Fatal("GOPATH environment variable is not set or empty") | ||||
| 	} | ||||
|  | ||||
| 	pkgRealpath := "" | ||||
|  | ||||
| 	wg, _ := filepath.EvalSymlinks(filepath.Join(vendorPath, pkgpath)) | ||||
| 	if utils.FileExists(wg) { | ||||
| 		pkgRealpath = wg | ||||
| 	if os.Getenv(`GO111MODULE`) == `on` { | ||||
| 		pkgRealpath = filepath.Join(bu.GetBeeWorkPath(), "..", pkgpath) | ||||
| 	} else { | ||||
| 		wgopath := gopaths | ||||
| 		for _, wg := range wgopath { | ||||
| 			wg, _ = filepath.EvalSymlinks(filepath.Join(wg, "src", pkgpath)) | ||||
| 			if utils.FileExists(wg) { | ||||
| 				pkgRealpath = wg | ||||
| 				break | ||||
| 		gopaths := bu.GetGOPATHs() | ||||
| 		if len(gopaths) == 0 { | ||||
| 			beeLogger.Log.Fatal("GOPATH environment variable is not set or empty") | ||||
| 		} | ||||
| 		wg, _ := filepath.EvalSymlinks(filepath.Join(vendorPath, pkgpath)) | ||||
| 		if utils.FileExists(wg) { | ||||
| 			pkgRealpath = wg | ||||
| 		} else { | ||||
| 			wgopath := gopaths | ||||
| 			for _, wg := range wgopath { | ||||
| 				wg, _ = filepath.EvalSymlinks(filepath.Join(wg, "src", pkgpath)) | ||||
| 				if utils.FileExists(wg) { | ||||
| 					pkgRealpath = wg | ||||
| 					break | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| @@ -468,6 +473,7 @@ func analyseControllerPkg(vendorPath, localName, pkgpath string) { | ||||
| 	if err != nil { | ||||
| 		beeLogger.Log.Fatalf("Error while parsing dir at '%s': %s", pkgpath, err) | ||||
| 	} | ||||
|  | ||||
| 	for _, pkg := range astPkgs { | ||||
| 		for _, fl := range pkg.Files { | ||||
| 			for _, d := range fl.Decls { | ||||
| @@ -802,7 +808,7 @@ func setParamType(para *swagger.Parameter, typ string, pkgpath, controllerName s | ||||
| 		paraFormat = typeFormat[1] | ||||
| 		if para.In == "body" { | ||||
| 			para.Schema = &swagger.Schema{ | ||||
| 				Type: paraType, | ||||
| 				Type:   paraType, | ||||
| 				Format: paraFormat, | ||||
| 			} | ||||
| 		} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 qiantao
					qiantao