Documentation ¶
Overview ¶
Package com is an open source project for commonly used functions for the Go programming language.
Index ¶
- Constants
- Variables
- func AESGCMDecrypt(key, ciphertext []byte) ([]byte, error)
- func AESGCMEncrypt(key, plaintext []byte) ([]byte, error)
- func AppendStr(strs []string, str string) []string
- func Base64Decode(str string) (string, error)
- func Base64Encode(str string) string
- func ColorLog(format string, a ...interface{})
- func ColorLogS(format string, a ...interface{}) string
- func CompareSliceStr(s1, s2 []string) bool
- func CompareSliceStrU(s1, s2 []string) bool
- func Copy(src, dest string) error
- func CopyDir(srcPath, destPath string, filters ...func(filePath string) bool) error
- func Date(ti int64, format string) string
- func DateParse(dateString, format string) (time.Time, error)
- func DateS(ts string, format string) string
- func DateT(t time.Time, format string) string
- func ExecCmd(cmdName string, args ...string) (string, string, error)
- func ExecCmdBytes(cmdName string, args ...string) ([]byte, []byte, error)
- func ExecCmdDir(dir, cmdName string, args ...string) (string, string, error)
- func ExecCmdDirBytes(dir, cmdName string, args ...string) ([]byte, []byte, error)
- func Expand(template string, match map[string]string, subs ...string) string
- func FetchFiles(client *http.Client, files []RawFile, header http.Header) error
- func FetchFilesCurl(files []RawFile, curlOptions ...string) error
- func FileMTime(file string) (int64, error)
- func FileSize(file string) (int64, error)
- func GetAllSubDirs(rootPath string) ([]string, error)
- func GetFileListBySuffix(dirPath, suffix string) ([]string, error)
- func GetGOPATHs() []string
- func GetSrcPath(importPath string) (appPath string, err error)
- func HexStr2int(hexStr string) (int, error)
- func HomeDir() (home string, err error)
- func Html2JS(data []byte) []byte
- func HtmlDecode(str string) string
- func HtmlEncode(str string) string
- func HttpCall(client *http.Client, method, url string, header http.Header, body io.Reader) (io.ReadCloser, error)
- func HttpGet(client *http.Client, url string, header http.Header) (io.ReadCloser, error)
- func HttpGetBytes(client *http.Client, url string, header http.Header) ([]byte, error)
- func HttpGetJSON(client *http.Client, url string, v interface{}) error
- func HttpGetToFile(client *http.Client, url string, header http.Header, fileName string) error
- func HttpPost(client *http.Client, url string, header http.Header, body []byte) (io.ReadCloser, error)
- func HttpPostJSON(client *http.Client, url string, body, v interface{}) error
- func HumaneFileSize(s uint64) string
- func Int2HexStr(num int) (hex string)
- func IsDir(dir string) bool
- func IsEmail(email string) bool
- func IsEmailRFC(email string) bool
- func IsExist(path string) bool
- func IsFile(filePath string) bool
- func IsLetter(l uint8) bool
- func IsSliceContainsInt64(sl []int64, i int64) bool
- func IsSliceContainsStr(sl []string, str string) bool
- func IsUrl(url string) bool
- func LgetAllSubDirs(rootPath string) ([]string, error)
- func LstatDir(rootPath string, includeDir ...bool) ([]string, error)
- func Nl2br(str string) string
- func PowInt(x int, y int) int
- func RandomCreateBytes(n int, alphabets ...byte) []byte
- func Reverse(s string) string
- func StatDir(rootPath string, includeDir ...bool) ([]string, error)
- func StripTags(src string) string
- func ToSnakeCase(str string) string
- func ToStr(value interface{}, args ...int) (s string)
- func UrlDecode(str string) (string, error)
- func UrlEncode(str string) string
- func WriteFile(filename string, data []byte) error
- type NotFoundError
- type RawFile
- type RemoteError
- type StrTo
- func (f StrTo) Exist() bool
- func (f StrTo) Float64() (float64, error)
- func (f StrTo) Int() (int, error)
- func (f StrTo) Int64() (int64, error)
- func (f StrTo) MustFloat64() float64
- func (f StrTo) MustInt() int
- func (f StrTo) MustInt64() int64
- func (f StrTo) MustUint8() uint8
- func (f StrTo) String() string
- func (f StrTo) Uint8() (uint8, error)
Examples ¶
Constants ¶
const ( Gray = uint8(iota + 90) Red Green Yellow Blue Magenta //NRed = uint8(31) // Normal EndColor = "\033[0m" )
Color number constants.
const ( Byte = 1 KByte = Byte * 1024 MByte = KByte * 1024 GByte = MByte * 1024 TByte = GByte * 1024 PByte = TByte * 1024 EByte = PByte * 1024 )
Storage unit constants.
Variables ¶
var UserAgent = "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/29.0.1541.0 Safari/537.36"
Functions ¶
func AESGCMDecrypt ¶
AESGCMDecrypt decrypts ciphertext with the given key using AES in GCM mode.
func AESGCMEncrypt ¶
AESGCMEncrypt encrypts plaintext with the given key using AES in GCM mode.
func AppendStr ¶
AppendStr appends string to slice with no duplicates.
Example ¶
package main import ( "fmt" "github.com/Unknwon/com" ) func main() { s := []string{"a"} s = com.AppendStr(s, "a") s = com.AppendStr(s, "b") fmt.Println(s) }
Output: [a b]
func ColorLog ¶
func ColorLog(format string, a ...interface{})
ColorLog prints colored log to stdout. See color rules in function 'ColorLogS'.
Example ¶
package main import ( "fmt" "github.com/Unknwon/com" ) func main() { com.ColorLog(fmt.Sprintf( "[WARN] This is a tesing log that should be colored, path( %s ),"+ " highlight # %s #, error [ %s ].", "path to somewhere", "highlighted content", "tesing error")) }
Output:
func ColorLogS ¶
ColorLogS colors log and return colored content. Log format: <level> <content [highlight][path]> [ error ]. Level: TRAC -> blue; ERRO -> red; WARN -> Magenta; SUCC -> green; others -> default. Content: default; path: yellow; error -> red. Level has to be surrounded by "[" and "]". Highlights have to be surrounded by "# " and " #"(space), "#" will be deleted. Paths have to be surrounded by "( " and " )"(space). Errors have to be surrounded by "[ " and " ]"(space). Note: it hasn't support windows yet, contribute is welcome.
Example ¶
package main import ( "fmt" "github.com/Unknwon/com" ) func main() { coloredLog := com.ColorLogS(fmt.Sprintf( "[WARN] This is a tesing log that should be colored, path( %s ),"+ " highlight # %s #, error [ %s ].", "path to somewhere", "highlighted content", "tesing error")) fmt.Println(coloredLog) }
Output:
func CompareSliceStr ¶
CompareSliceStr compares two 'string' type slices. It returns true if elements and order are both the same.
func CompareSliceStrU ¶
CompareSliceStrU compares two 'string' type slices. It returns true if elements are the same, and ignores the order.
func CopyDir ¶
CopyDir copy files recursively from source to target directory.
The filter accepts a function that process the path info. and should return true for need to filter.
It returns error when error occurs in underlying functions.
func DateT ¶
Format time.Time struct to string MM - month - 01 M - month - 1, single bit DD - day - 02 D - day 2 YYYY - year - 2006 YY - year - 06 HH - 24 hours - 03 H - 24 hours - 3 hh - 12 hours - 03 h - 12 hours - 3 mm - minute - 04 m - minute - 4 ss - second - 05 s - second = 5
func ExecCmd ¶
ExecCmd executes system command and return stdout, stderr in string type, along with possible error.
Example ¶
package main import ( "fmt" "github.com/Unknwon/com" ) func main() { stdout, stderr, err := com.ExecCmd("go", "help", "get") fmt.Println(stdout, stderr, err) }
Output:
func ExecCmdBytes ¶
ExecCmdBytes executes system command and return stdout, stderr in bytes type, along with possible error.
func ExecCmdDir ¶
ExecCmdDir executes system command in given directory and return stdout, stderr in string type, along with possible error.
func ExecCmdDirBytes ¶
ExecCmdDirBytes executes system command in given directory and return stdout, stderr in bytes type, along with possible error.
func Expand ¶
Expand replaces {k} in template with match[k] or subs[atoi(k)] if k is not in match.
Example ¶
package main import ( "fmt" "github.com/Unknwon/com" ) func main() { match := map[string]string{ "domain": "gowalker.org", "subdomain": "github.com", } s := "http://{domain}/{subdomain}/{0}/{1}" fmt.Println(com.Expand(s, match, "Unknwon", "gowalker")) }
Output: http://gowalker.org/github.com/Unknwon/gowalker
func FetchFiles ¶
FetchFiles fetches files specified by the rawURL field in parallel.
Example ¶
package main import ( "fmt" "net/http" "github.com/Unknwon/com" ) type rawFile struct { name string rawURL string data []byte } func (rf *rawFile) Name() string { return rf.name } func (rf *rawFile) RawUrl() string { return rf.rawURL } func (rf *rawFile) Data() []byte { return rf.data } func (rf *rawFile) SetData(p []byte) { rf.data = p } func main() { // Code that should be outside of your function body. // type rawFile struct { // name string // rawURL string // data []byte // } // func (rf *rawFile) Name() string { // return rf.name // } // func (rf *rawFile) RawUrl() string { // return rf.rawURL // } // func (rf *rawFile) Data() []byte { // return rf.data // } // func (rf *rawFile) SetData(p []byte) { // rf.data = p // } files := []com.RawFile{ &rawFile{rawURL: "http://example.com"}, &rawFile{rawURL: "http://example.com/foo"}, } err := com.FetchFiles(&http.Client{}, files, nil) fmt.Println(err, len(files[0].Data()), len(files[1].Data())) }
Output:
func FetchFilesCurl ¶
FetchFilesCurl uses command `curl` to fetch files specified by the rawURL field in parallel.
Example ¶
package main import ( "fmt" "github.com/Unknwon/com" ) type rawFile struct { name string rawURL string data []byte } func (rf *rawFile) Name() string { return rf.name } func (rf *rawFile) RawUrl() string { return rf.rawURL } func (rf *rawFile) Data() []byte { return rf.data } func (rf *rawFile) SetData(p []byte) { rf.data = p } func main() { // Code that should be outside of your function body. // type rawFile struct { // name string // rawURL string // data []byte // } // func (rf *rawFile) Name() string { // return rf.name // } // func (rf *rawFile) RawUrl() string { // return rf.rawURL // } // func (rf *rawFile) Data() []byte { // return rf.data // } // func (rf *rawFile) SetData(p []byte) { // rf.data = p // } files := []com.RawFile{ &rawFile{rawURL: "http://example.com"}, &rawFile{rawURL: "http://example.com/foo"}, } err := com.FetchFilesCurl(files) fmt.Println(err, len(files[0].Data()), len(files[1].Data())) }
Output:
func GetAllSubDirs ¶
GetAllSubDirs returns all subdirectories of given root path. Slice does not include given path itself.
func GetFileListBySuffix ¶
GetFileListBySuffix returns an ordered list of file paths. It recognize if given path is a file, and don't do recursive find.
func GetGOPATHs ¶
func GetGOPATHs() []string
GetGOPATHs returns all paths in GOPATH variable.
Example ¶
package main import ( "fmt" "github.com/Unknwon/com" ) func main() { gps := com.GetGOPATHs() fmt.Println(gps) }
Output:
func GetSrcPath ¶
GetSrcPath returns app. source code path. It only works when you have src. folder in GOPATH, it returns error not able to locate source folder path.
Example ¶
package main import ( "fmt" "github.com/Unknwon/com" ) func main() { srcPath, err := com.GetSrcPath("github.com/Unknwon/com") if err != nil { fmt.Println(err) return } fmt.Println(srcPath) }
Output:
func HexStr2int ¶
HexStr2int converts hex format string to decimal number.
func HomeDir ¶
HomeDir returns path of '~'(in Linux) on Windows, it returns error when the variable does not exist.
Example ¶
package main import ( "fmt" "github.com/Unknwon/com" ) func main() { hd, err := com.HomeDir() fmt.Println(hd, err) }
Output:
func Html2JS ¶
Html2JS converts []byte type of HTML content into JS format.
Example ¶
package main import ( "fmt" "github.com/Unknwon/com" ) func main() { htm := "<div id=\"button\" class=\"btn\">Click me</div>\n\r" js := string(com.Html2JS([]byte(htm))) fmt.Println(js) }
Output: <div id=\"button\" class=\"btn\">Click me</div>\n
func HttpCall ¶
func HttpCall(client *http.Client, method, url string, header http.Header, body io.Reader) (io.ReadCloser, error)
HttpCall makes HTTP method call.
func HttpGet ¶
HttpGet gets the specified resource. ErrNotFound is returned if the server responds with status 404.
Example ¶
package main import ( "io/ioutil" "net/http" "github.com/Unknwon/com" ) func main() ([]byte, error) { rc, err := com.HttpGet(&http.Client{}, "http://gowalker.org", nil) if err != nil { return nil, err } p, err := ioutil.ReadAll(rc) rc.Close() return p, err }
Output:
func HttpGetBytes ¶
HttpGetBytes gets the specified resource. ErrNotFound is returned if the server responds with status 404.
Example ¶
package main import ( "net/http" "github.com/Unknwon/com" ) func main() ([]byte, error) { p, err := com.HttpGetBytes(&http.Client{}, "http://gowalker.org", nil) return p, err }
Output:
func HttpGetJSON ¶
HttpGetJSON gets the specified resource and mapping to struct. ErrNotFound is returned if the server responds with status 404.
Example ¶
package main import ( "net/http" "github.com/Unknwon/com" ) func main() interface{} { j := com.HttpGetJSON(&http.Client{}, "http://gowalker.org", nil) return j }
Output:
func HttpGetToFile ¶
HttpGetToFile gets the specified resource and writes to file. ErrNotFound is returned if the server responds with status 404.
func HttpPost ¶
func HttpPost(client *http.Client, url string, header http.Header, body []byte) (io.ReadCloser, error)
HttpPost posts the specified resource. ErrNotFound is returned if the server responds with status 404.
func HttpPostJSON ¶
HttpPostJSON posts the specified resource with struct values, and maps results to struct. ErrNotFound is returned if the server responds with status 404.
func HumaneFileSize ¶
HumaneFileSize calculates the file size and generate user-friendly string.
func Int2HexStr ¶
Int2HexStr converts decimal number to hex format string.
func IsDir ¶
IsDir returns true if given path is a directory, or returns false when it's a file or does not exist.
Example ¶
package main import ( "fmt" "github.com/Unknwon/com" ) func main() { if com.IsDir("files") { fmt.Println("directory 'files' exists") return } fmt.Println("'files' is not a directory or does not exist") }
Output:
func IsEmail ¶
IsEmail validates string is an email address, if not return false basically validation can match 99% cases
Example ¶
package main import ( "fmt" "github.com/Unknwon/com" ) func main() { fmt.Println(com.IsEmail("test@example.com")) fmt.Println(com.IsEmail("@example.com")) }
Output: true false
func IsEmailRFC ¶
IsEmailRFC validates string is an email address, if not return false this validation omits RFC 2822
func IsExist ¶
IsExist checks whether a file or directory exists. It returns false when the file or directory does not exist.
Example ¶
package main import ( "fmt" "github.com/Unknwon/com" ) func main() { if com.IsExist("file.go") { fmt.Println("file.go exists") return } fmt.Println("file.go does not exist") }
Output:
func IsFile ¶
IsFile returns true if given path is a file, or returns false when it's a directory or does not exist.
Example ¶
package main import ( "fmt" "github.com/Unknwon/com" ) func main() { if com.IsFile("file.go") { fmt.Println("file.go exists") return } fmt.Println("file.go is not a file or does not exist") }
Output:
func IsLetter ¶
IsLetter returns true if the 'l' is an English letter.
Example ¶
package main import ( "fmt" "github.com/Unknwon/com" ) func main() { fmt.Println(com.IsLetter('1')) fmt.Println(com.IsLetter('[')) fmt.Println(com.IsLetter('a')) fmt.Println(com.IsLetter('Z')) }
Output: false false true true
func IsSliceContainsInt64 ¶
IsSliceContainsInt64 returns true if the int64 exists in given slice.
func IsSliceContainsStr ¶
IsSliceContainsStr returns true if the string exists in given slice, ignore case.
func IsUrl ¶
IsUrl validates string is a url link, if not return false simple validation can match 99% cases
Example ¶
package main import ( "fmt" "github.com/Unknwon/com" ) func main() { fmt.Println(com.IsUrl("http://example.com")) fmt.Println(com.IsUrl("http//example.com")) }
Output: true false
func LgetAllSubDirs ¶
LgetAllSubDirs returns all subdirectories of given root path, including following symbolic links, if any. Slice does not include given path itself.
func LstatDir ¶
LstatDir gathers information of given directory by depth-first. It returns slice of file list, follows symbolic links and includes subdirectories if enabled; it returns error and nil slice when error occurs in underlying functions, or given path is not a directory or does not exist.
Slice does not include given path itself. If subdirectories is enabled, they will have suffix '/'.
func RandomCreateBytes ¶
RandomCreateBytes generate random []byte by specify chars.
func StatDir ¶
StatDir gathers information of given directory by depth-first. It returns slice of file list and includes subdirectories if enabled; it returns error and nil slice when error occurs in underlying functions, or given path is not a directory or does not exist.
Slice does not include given path itself. If subdirectories is enabled, they will have suffix '/'.
func ToSnakeCase ¶
ToSnakeCase can convert all upper case characters in a string to underscore format.
Some samples.
"FirstName" => "first_name" "HTTPServer" => "http_server" "NoHTTPS" => "no_https" "GO_PATH" => "go_path" "GO PATH" => "go_path" // space is converted to underscore. "GO-PATH" => "go_path" // hyphen is converted to underscore.
Types ¶
type NotFoundError ¶
type NotFoundError struct {
Message string
}
func (NotFoundError) Error ¶
func (e NotFoundError) Error() string
type RemoteError ¶
func (*RemoteError) Error ¶
func (e *RemoteError) Error() string