This commit is contained in:
Allen Ray 2024-05-07 19:54:04 +02:00 committed by GitHub
commit bb9d4a94f7
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
9 changed files with 70 additions and 18 deletions

View file

@ -20,6 +20,6 @@ require (
)
require (
github.com/ebitengine/purego v0.6.0-alpha.1.0.20231122024802-192c5e846faa // indirect
golang.org/x/sys v0.14.0 // indirect
github.com/ebitengine/purego v0.6.1 // indirect
golang.org/x/sys v0.18.0 // indirect
)

View file

@ -1,8 +1,8 @@
github.com/ebitengine/purego v0.6.0-alpha.1.0.20231122024802-192c5e846faa h1:Ik7QikRgeH+bFOfAcMpttCbs6XxWXxCLXMm4awxtOXk=
github.com/ebitengine/purego v0.6.0-alpha.1.0.20231122024802-192c5e846faa/go.mod h1:ah1In8AOtksoNK6yk5z1HTJeUkC1Ez4Wk2idgGslMwQ=
github.com/ebitengine/purego v0.6.1 h1:sjN8rfzbhXQ59/pE+wInswbU9aMDHiwlup4p/a07Mkg=
github.com/ebitengine/purego v0.6.1/go.mod h1:ah1In8AOtksoNK6yk5z1HTJeUkC1Ez4Wk2idgGslMwQ=
github.com/jakecoffman/cp v1.2.1 h1:zkhc2Gpo9l4NLUZfeG3j33+3bQD7MkqPa+n5PdX+5mI=
github.com/jakecoffman/cp v1.2.1/go.mod h1:JjY/Fp6d8E1CHnu74gWNnU0+b9VzEdUVPoJxg2PsTQg=
github.com/neguse/go-box2d-lite v0.0.0-20170921151050-5d8ed9b7272b h1:+67TGbwfgeB5o03Rx+ZBW44zAQ+wUujcwdRA0p9CbJI=
github.com/neguse/go-box2d-lite v0.0.0-20170921151050-5d8ed9b7272b/go.mod h1:kvKwD9codtns5mvpA53V3vLnqFb/Ahcu8zgkGM0SIbI=
golang.org/x/sys v0.14.0 h1:Vz7Qs629MkJkGyHxUlRHizWJRG2j8fbQKjELVSNhy7Q=
golang.org/x/sys v0.14.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
golang.org/x/sys v0.18.0 h1:DBdB3niSjOA/O0blCZBqDefyWNYveAYMNF1Wum0DYQ4=
golang.org/x/sys v0.18.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=

View file

@ -3,6 +3,6 @@ module github.com/gen2brain/raylib-go/raylib
go 1.21
require (
github.com/ebitengine/purego v0.6.0-alpha.1.0.20231122024802-192c5e846faa
golang.org/x/sys v0.14.0
github.com/ebitengine/purego v0.6.1
golang.org/x/sys v0.18.0
)

View file

@ -1,4 +1,4 @@
github.com/ebitengine/purego v0.6.0-alpha.1.0.20231122024802-192c5e846faa h1:Ik7QikRgeH+bFOfAcMpttCbs6XxWXxCLXMm4awxtOXk=
github.com/ebitengine/purego v0.6.0-alpha.1.0.20231122024802-192c5e846faa/go.mod h1:ah1In8AOtksoNK6yk5z1HTJeUkC1Ez4Wk2idgGslMwQ=
golang.org/x/sys v0.14.0 h1:Vz7Qs629MkJkGyHxUlRHizWJRG2j8fbQKjELVSNhy7Q=
golang.org/x/sys v0.14.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
github.com/ebitengine/purego v0.6.1 h1:sjN8rfzbhXQ59/pE+wInswbU9aMDHiwlup4p/a07Mkg=
github.com/ebitengine/purego v0.6.1/go.mod h1:ah1In8AOtksoNK6yk5z1HTJeUkC1Ez4Wk2idgGslMwQ=
golang.org/x/sys v0.18.0 h1:DBdB3niSjOA/O0blCZBqDefyWNYveAYMNF1Wum0DYQ4=
golang.org/x/sys v0.18.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=

8
raylib/purego.go Normal file
View file

@ -0,0 +1,8 @@
//go:build !cgo
// +build !cgo
package rl
const (
requiredVersion = "5.0"
)

45
raylib/purego_unix.go Normal file
View file

@ -0,0 +1,45 @@
//go:build !cgo && (darwin || openbsd || freebsd || linux)
package rl
import (
"fmt"
"runtime"
"unsafe"
"github.com/ebitengine/purego"
"golang.org/x/sys/unix"
)
// loadLibrary loads the raylib dll and panics on error
func loadLibrary() uintptr {
libname := "raylib.so"
switch runtime.GOOS {
case "darwin":
libname = "raylib.dylib"
}
handle, err := purego.Dlopen(libname, purego.RTLD_NOW|purego.RTLD_GLOBAL)
if err != nil {
panic(fmt.Errorf("cannot load library %s: %w", libname, err))
}
proc, err := purego.Dlsym(handle, "raylib_version")
if err != nil {
panic(err)
}
version := unix.BytePtrToString(**(***byte)(unsafe.Pointer(&proc)))
if version != requiredVersion {
panic(fmt.Errorf("version %s of %s doesn't match the required version %s", version, libname, requiredVersion))
}
return uintptr(handle)
}
func traceLogCallbackWrapper(fn TraceLogCallbackFun) uintptr {
return purego.NewCallback(func(logLevel int32, text *byte) uintptr {
fn(int(logLevel), unix.BytePtrToString(text))
return 0
})
}

View file

@ -13,7 +13,6 @@ import (
const (
libname = "raylib.dll"
requiredVersion = "5.0"
)
// loadLibrary loads the raylib dll and panics on error

View file

@ -1,5 +1,5 @@
//go:build !cgo && windows
// +build !cgo,windows
//go:build !cgo
// +build !cgo
package rl

View file

@ -1,5 +1,5 @@
//go:build !cgo && windows
// +build !cgo,windows
//go:build !cgo
// +build !cgo
package rl