Browse Source

Update customized domain support

pull/103/head
Unknown 12 years ago
parent
commit
f7ee57d1dd
  1. 1
      cmd/get.go
  2. 8
      doc/bitbucket.go
  3. 8
      doc/github.go
  4. 8
      doc/google.go
  5. 8
      doc/oschina.go
  6. 58
      doc/utils.go

1
cmd/get.go

@ -212,6 +212,7 @@ func downloadPackages(nodes []*doc.Node) {
// Invalid import path. // Invalid import path.
doc.ColorLog("[WARN] Skipped invalid package path( %s => %s:%s )\n", doc.ColorLog("[WARN] Skipped invalid package path( %s => %s:%s )\n",
n.ImportPath, n.Type, n.Value) n.ImportPath, n.Type, n.Value)
failConut++
} }
} }
} }

8
doc/bitbucket.go

@ -99,14 +99,18 @@ func getBitbucketDoc(client *http.Client, match map[string]string, installRepoPa
return nil, err return nil, err
} }
var installPath string
if nod.ImportPath == nod.DownloadURL {
suf := "." + nod.Value suf := "." + nod.Value
if len(suf) == 1 { if len(suf) == 1 {
suf = "" suf = ""
} }
projectPath := expand("bitbucket.org/{owner}/{repo}", match) projectPath := expand("bitbucket.org/{owner}/{repo}", match)
installPath := installRepoPath + "/" + projectPath + suf installPath = installRepoPath + "/" + projectPath + suf
nod.ImportPath = projectPath nod.ImportPath = projectPath
} else {
installPath = installRepoPath + "/" + nod.ImportPath
}
// Remove old files. // Remove old files.
os.RemoveAll(installPath + "/") os.RemoveAll(installPath + "/")

8
doc/github.go

@ -75,14 +75,18 @@ func getGithubDoc(client *http.Client, match map[string]string, installRepoPath
shaName = strings.Replace(shaName, "-v", "-", 1) shaName = strings.Replace(shaName, "-v", "-", 1)
} }
var installPath string
if nod.ImportPath == nod.DownloadURL {
suf := "." + nod.Value suf := "." + nod.Value
if len(suf) == 1 { if len(suf) == 1 {
suf = "" suf = ""
} }
projectPath := expand("github.com/{owner}/{repo}", match) projectPath := expand("github.com/{owner}/{repo}", match)
installPath := installRepoPath + "/" + projectPath + suf installPath = installRepoPath + "/" + projectPath + suf
nod.ImportPath = projectPath nod.ImportPath = projectPath
} else {
installPath = installRepoPath + "/" + nod.ImportPath
}
// Remove old files. // Remove old files.
os.RemoveAll(installPath + "/") os.RemoveAll(installPath + "/")

8
doc/google.go

@ -74,14 +74,18 @@ func getGoogleDoc(client *http.Client, match map[string]string, installRepoPath
return nil, err return nil, err
} }
var installPath string
if nod.ImportPath == nod.DownloadURL {
suf := "." + nod.Value suf := "." + nod.Value
if len(suf) == 1 { if len(suf) == 1 {
suf = "" suf = ""
} }
projectPath := expand("code.google.com/p/{repo}{dot}{subrepo}{dir}", match) projectPath := expand("code.google.com/p/{repo}{dot}{subrepo}{dir}", match)
installPath := installRepoPath + "/" + projectPath + suf installPath = installRepoPath + "/" + projectPath + suf
nod.ImportPath = projectPath nod.ImportPath = projectPath
} else {
installPath = installRepoPath + "/" + nod.ImportPath
}
// Remove old files. // Remove old files.
os.RemoveAll(installPath + "/") os.RemoveAll(installPath + "/")

8
doc/oschina.go

@ -54,14 +54,18 @@ func getOSCDoc(client *http.Client, match map[string]string, installRepoPath str
return nil, errors.New("Fail to donwload OSChina repo -> " + err.Error()) return nil, errors.New("Fail to donwload OSChina repo -> " + err.Error())
} }
var installPath string
if nod.ImportPath == nod.DownloadURL {
suf := "." + nod.Value suf := "." + nod.Value
if len(suf) == 1 { if len(suf) == 1 {
suf = "" suf = ""
} }
projectPath := expand("git.oschina.net/{owner}/{repo}", match) projectPath := expand("git.oschina.net/{owner}/{repo}", match)
installPath := installRepoPath + "/" + projectPath + suf installPath = installRepoPath + "/" + projectPath + suf
nod.ImportPath = projectPath nod.ImportPath = projectPath
} else {
installPath = installRepoPath + "/" + nod.ImportPath
}
// Remove old files. // Remove old files.
os.RemoveAll(installPath + "/") os.RemoveAll(installPath + "/")

58
doc/utils.go

@ -21,6 +21,7 @@ import (
"regexp" "regexp"
"runtime" "runtime"
"strings" "strings"
"syscall"
) )
// IsExist returns if a file or directory exists // IsExist returns if a file or directory exists
@ -29,6 +30,7 @@ func IsExist(path string) bool {
return err == nil || os.IsExist(err) return err == nil || os.IsExist(err)
} }
// Non-Windows.
const ( const (
Gray = uint8(iota + 90) Gray = uint8(iota + 90)
Red Red
@ -40,6 +42,26 @@ const (
EndColor = "\033[0m" EndColor = "\033[0m"
) )
// Windows.
const (
WDefault = uintptr(iota)
WBlue
WGreen
WCyan
WRed
WPurple
WYellow
WGray
WSilver
WLightBlue
WLime
WLightCyan
WLightRed
WLightPurple
WLightYellow
WWhite
)
// ColorLog colors log and print to stdout. // ColorLog colors log and print to stdout.
// Log format: <level> <content [highlight][path]> [ error ]. // Log format: <level> <content [highlight][path]> [ error ].
// Level: TRAC -> blue; ERRO -> red; WARN -> Magenta; SUCC -> green; others -> default. // Level: TRAC -> blue; ERRO -> red; WARN -> Magenta; SUCC -> green; others -> default.
@ -74,6 +96,16 @@ func ColorLog(format string, a ...interface{}) {
log = strings.Replace(log, " #", EndColor, -1) log = strings.Replace(log, " #", EndColor, -1)
log = clog + log log = clog + log
} else {
// Level.
i := strings.Index(log, "]")
if log[0] == '[' && i > -1 {
fmt.Print("[")
printColorLevel(log[1:i])
fmt.Print("]")
}
log = log[i+1:]
} }
fmt.Print(log) fmt.Print(log)
@ -96,6 +128,32 @@ func getColorLevel(level string) string {
} }
} }
// printColorLevel prints color level prompt, this is only for Windows.
func printColorLevel(level string) {
cc := WDefault
level = strings.ToUpper(level)
switch level {
case "TRAC":
cc = WBlue
case "ERRO":
cc = WRed
case "WARN":
cc = WPurple
case "SUCC":
cc = WGreen
default:
cc = WWhite
}
kernel32 := syscall.NewLazyDLL("kernel32.dll")
proc := kernel32.NewProc("SetConsoleTextAttribute")
handle, _, _ := proc.Call(uintptr(syscall.Stdout), uintptr(cc))
fmt.Print(level)
handle, _, _ = proc.Call(uintptr(syscall.Stdout), uintptr(WSilver))
CloseHandle := kernel32.NewProc("CloseHandle")
CloseHandle.Call(handle)
}
// GetGOPATH returns all paths in GOPATH variable. // GetGOPATH returns all paths in GOPATH variable.
func GetGOPATH() []string { func GetGOPATH() []string {
gopath := os.Getenv("GOPATH") gopath := os.Getenv("GOPATH")

Loading…
Cancel
Save