Caveats for build tags:
// +build
constraint must be placed at the top of the file, even before package clause.List of valid platforms for both build tags and file suffixes |
---|
android |
darwin |
dragonfly |
freebsd |
linux |
netbsd |
openbsd |
plan9 |
solaris |
windows |
Refer to $GOOS
list in https://golang.org/doc/install/source#environment for the most up-to-date platform list.
// +build linux
package lib
var OnlyAccessibleInLinux int // Will only be compiled in Linux
Negate a platform by placing !
before it:
// +build !windows
package lib
var NotWindows int // Will be compiled in all platforms but not Windows
List of platforms can be specified by separating them with spaces
// +build linux darwin plan9
package lib
var SomeUnix int // Will be compiled in linux, darwin and plan9 but not on others
If you name your file lib_linux.go
, all the content in that file will only be compiled in linux environments:
package lib
var OnlyCompiledInLinux string
Different platforms can have separate implementations of the same method. This example also illustrates how build tags and file suffixes can be used together.
File main.go
:
package main
import "fmt"
func main() {
fmt.Println("Hello World from Conditional Compilation Doc!")
printDetails()
}
details.go
:
// +build !windows
package main
import "fmt"
func printDetails() {
fmt.Println("Some specific details that cannot be found on Windows")
}
details_windows.go
:
package main
import "fmt"
func printDetails() {
fmt.Println("Windows specific details")
}
// +build
", a single platform or a list can follow!
sign