# System Package system contains some functions about os, runtime, shell command.
## Source: - [https://github.com/duke-git/lancet/blob/main/system/os.go](https://github.com/duke-git/lancet/blob/main/system/os.go) ## Usage: ```go import ( "github.com/duke-git/lancet/v2/system" ) ``` ## Index - [IsWindows](#IsWindows) - [IsLinux](#IsLinux) - [IsMac](#IsMac) - [GetOsEnv](#GetOsEnv) - [SetOsEnv](#SetOsEnv) - [RemoveOsEnv](#RemoveOsEnv) - [CompareOsEnv](#CompareOsEnv) - [ExecCommand](#ExecCommand) - [GetOsBits](#GetOsBits) ## Documentation ### IsWindowsCheck if current os is windows.
Signature: ```go func IsWindows() bool ``` Example: ```go import ( "fmt" "github.com/duke-git/lancet/v2/system" ) func main() { isOsWindows := system.IsWindows() fmt.Println(isOsWindows) } ``` ### IsLinuxCheck if current os is linux.
Signature: ```go func IsLinux() bool ``` Example: ```go import ( "fmt" "github.com/duke-git/lancet/v2/system" ) func main() { isOsLinux := system.IsLinux() fmt.Println(isOsLinux) } ``` ### IsMacCheck if current os is macos.
Signature: ```go func IsMac() bool ``` Example: ```go import ( "fmt" "github.com/duke-git/lancet/v2/system" ) func main() { isOsMac := system.IsMac() fmt.Println(isOsMac) } ``` ### GetOsEnvGets the value of the environment variable named by the key.
Signature: ```go func GetOsEnv(key string) string ``` Example: ```go import ( "fmt" "github.com/duke-git/lancet/v2/system" ) func main() { err := system.SetOsEnv("foo", "abc") result := system.GetOsEnv("foo") fmt.Println(err) fmt.Println(result) // Output: //Sets the value of the environment variable named by the key.
Signature: ```go func SetOsEnv(key, value string) error ``` Example: ```go import ( "fmt" "github.com/duke-git/lancet/v2/system" ) func main() { err := system.SetOsEnv("foo", "abc") result := system.GetOsEnv("foo") fmt.Println(err) fmt.Println(result) // Output: //Remove a single environment variable.
Signature: ```go func RemoveOsEnv(key string) error ``` Example: ```go import ( "fmt" "github.com/duke-git/lancet/v2/system" ) func main() { err1 := system.SetOsEnv("foo", "abc") result1 := GetOsEnv("foo") err2 := system.RemoveOsEnv("foo") result2 := GetOsEnv("foo") fmt.Println(err1) fmt.Println(err2) fmt.Println(result1) fmt.Println(result2) // Output: //Get env named by the key and compare it with comparedEnv.
Signature: ```go func CompareOsEnv(key, comparedEnv string) bool ``` Example: ```go import ( "fmt" "github.com/duke-git/lancet/v2/system" ) func main() { err := system.SetOsEnv("foo", "abc") if err != nil { return } result := system.CompareOsEnv("foo", "abc") fmt.Println(result) // Output: // true } ``` ### ExecCommandExecute shell command, return the stdout and stderr string of command, and error if error occur. param `command` is a complete command string, like, ls -a (linux), dir(windows), ping 127.0.0.1. In linux, use /bin/bash -c to execute command, In windows, use powershell.exe to execute command.
Signature: ```go type ( Option func(*exec.Cmd) ) func ExecCommand(command string, opts ...Option) (stdout, stderr string, err error) ``` Example: ```go import ( "fmt" "github.com/duke-git/lancet/v2/system" ) func main() { // linux or mac stdout, stderr, err := system.ExecCommand("ls") fmt.Println("std out: ", stdout) fmt.Println("std err: ", stderr) assert.Equal("", stderr) // windows stdout, stderr, err = system.ExecCommand("dir") fmt.Println("std out: ", stdout) fmt.Println("std err: ", stderr) // error command stdout, stderr, err = system.ExecCommand("abc") fmt.Println("std out: ", stdout) fmt.Println("std err: ", stderr) if err != nil { fmt.Println(err.Error()) } } ``` ### GetOsBitsGet current os bits, 32bit or 64bit. return 32 or 64
Signature: ```go func GetOsBits() int ``` Example: ```go import ( "fmt" "github.com/duke-git/lancet/v2/system" ) func main() { osBit := system.GetOsBits() fmt.Println(osBit) // 32 or 64 } ```