1
0
mirror of https://github.com/go-kratos/kratos.git synced 2025-01-07 23:02:12 +02:00

modify kratos cmd new project (#907)

* Modifying the kratos cmd new project does not use the go git module, but uses the native git command
This commit is contained in:
包子 2021-05-12 22:33:26 +08:00 committed by GitHub
parent 42313e9368
commit 0e4a057027
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 29 additions and 31 deletions

View File

@ -73,10 +73,8 @@ func copyDir(src, dst string, replaces, ignores []string) error {
if hasSets(fd.Name(), ignores) {
continue
}
srcfp := path.Join(src, fd.Name())
dstfp := path.Join(dst, fd.Name())
if fd.IsDir() {
if err = copyDir(srcfp, dstfp, replaces, ignores); err != nil {
return err

View File

@ -2,12 +2,10 @@ package base
import (
"context"
"errors"
"os"
"os/exec"
"path"
"strings"
"github.com/go-git/go-git/v5"
)
// Repo is git repository manager.
@ -18,11 +16,17 @@ type Repo struct {
// NewRepo new a repository manager.
func NewRepo(url string) *Repo {
start := strings.Index(url, "//")
var start int
start = strings.Index(url, "//")
if start == -1 {
start = strings.Index(url, ":") + 1
} else {
start += 2
}
end := strings.LastIndex(url, "/")
return &Repo{
url: url,
home: kratosHomeWithDir("repo/" + url[start+2:end]),
home: kratosHomeWithDir("repo/" + url[start:end]),
}
}
@ -30,25 +34,19 @@ func NewRepo(url string) *Repo {
func (r *Repo) Path() string {
start := strings.LastIndex(r.url, "/")
end := strings.LastIndex(r.url, ".git")
if end == -1 {
end = len(r.url)
}
return path.Join(r.home, r.url[start+1:end])
}
// Pull fetch the repository from remote url.
func (r *Repo) Pull(ctx context.Context) error {
repo, err := git.PlainOpen(r.Path())
if err != nil {
return err
}
w, err := repo.Worktree()
if err != nil {
return err
}
if err = w.PullContext(ctx, &git.PullOptions{
RemoteName: "origin",
Progress: os.Stdout,
}); errors.Is(err, git.NoErrAlreadyUpToDate) {
return nil
}
cmd := exec.Command("git", "pull")
cmd.Dir = r.Path()
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
err := cmd.Run()
return err
}
@ -57,10 +55,10 @@ func (r *Repo) Clone(ctx context.Context) error {
if _, err := os.Stat(r.Path()); !os.IsNotExist(err) {
return r.Pull(ctx)
}
_, err := git.PlainCloneContext(ctx, r.Path(), false, &git.CloneOptions{
URL: r.url,
Progress: os.Stdout,
})
cmd := exec.Command("git", "clone", r.url, r.Path())
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
err := cmd.Run()
return err
}

View File

@ -37,6 +37,7 @@ const (
}
]
}`
// _testYaml = `
//Foo:
// bar :
@ -46,6 +47,7 @@ const (
//
//`
)
//func TestScan(t *testing.T) {
//
//}
@ -168,19 +170,19 @@ func testScan(t *testing.T, c config.Config) {
type TestJSON struct {
Test struct {
Settings struct {
IntKey int `json:"int_key"`
FloatKey float64 `json:"float_key"`
DurationKey int `json:"duration_key"`
StringKey string `json:"string_key"`
IntKey int `json:"int_key"`
FloatKey float64 `json:"float_key"`
DurationKey int `json:"duration_key"`
StringKey string `json:"string_key"`
} `json:"settings"`
Server struct {
Addr string `json:"addr"`
Port int `json:"port"`
Port int `json:"port"`
} `json:"server"`
} `json:"test"`
Foo []struct {
Name string `json:"name"`
Age int `json:"age"`
Age int `json:"age"`
} `json:"foo"`
}
var conf TestJSON