glfw: Bug fix: Do not pass Go's int pointer

Go's int can be 64bit or 32bit, while C's int is always 32bit on
Windows in Ebiten usage. For C's int argument, do not pass Go's
int pointer or broken values are set.

Related to #829
This commit is contained in:
Hajime Hoshi 2019-02-24 23:10:14 +09:00
parent 288e0a33ba
commit d4a522d9da

View File

@ -77,10 +77,11 @@ type Monitor struct {
m uintptr m uintptr
} }
func (m *Monitor) GetPos() (x, y int) { func (m *Monitor) GetPos() (int, int) {
var x, y int32
glfwDLL.call("glfwGetMonitorPos", m.m, uintptr(unsafe.Pointer(&x)), uintptr(unsafe.Pointer(&y))) glfwDLL.call("glfwGetMonitorPos", m.m, uintptr(unsafe.Pointer(&x)), uintptr(unsafe.Pointer(&y)))
panicError() panicError()
return return int(x), int(y)
} }
func (m *Monitor) GetVideoMode() *VidMode { func (m *Monitor) GetVideoMode() *VidMode {
@ -145,16 +146,18 @@ func (w *Window) GetMouseButton(button MouseButton) Action {
return Action(r) return Action(r)
} }
func (w *Window) GetPos() (x, y int) { func (w *Window) GetPos() (int, int) {
var x, y int32
glfwDLL.call("glfwGetWindowPos", w.w, uintptr(unsafe.Pointer(&x)), uintptr(unsafe.Pointer(&y))) glfwDLL.call("glfwGetWindowPos", w.w, uintptr(unsafe.Pointer(&x)), uintptr(unsafe.Pointer(&y)))
panicError() panicError()
return return int(x), int(y)
} }
func (w *Window) GetSize() (width, height int) { func (w *Window) GetSize() (int, int) {
var width, height int32
glfwDLL.call("glfwGetWindowSize", w.w, uintptr(unsafe.Pointer(&width)), uintptr(unsafe.Pointer(&height))) glfwDLL.call("glfwGetWindowSize", w.w, uintptr(unsafe.Pointer(&width)), uintptr(unsafe.Pointer(&height)))
panicError() panicError()
return return int(width), int(height)
} }
func (w *Window) MakeContextCurrent() { func (w *Window) MakeContextCurrent() {
@ -303,11 +306,11 @@ func CreateWindow(width, height int, title string, monitor *Monitor, share *Wind
} }
func GetJoystickAxes(joy Joystick) []float32 { func GetJoystickAxes(joy Joystick) []float32 {
l := 0 var l int32
ptr := glfwDLL.call("glfwGetJoystickAxes", uintptr(joy), uintptr(unsafe.Pointer(&l))) ptr := glfwDLL.call("glfwGetJoystickAxes", uintptr(joy), uintptr(unsafe.Pointer(&l)))
panicError() panicError()
as := make([]float32, l) as := make([]float32, l)
for i := 0; i < l; i++ { for i := int32(0); i < l; i++ {
as[i] = *(*float32)(unsafe.Pointer(ptr)) as[i] = *(*float32)(unsafe.Pointer(ptr))
ptr += unsafe.Sizeof(float32(0)) ptr += unsafe.Sizeof(float32(0))
} }
@ -315,11 +318,11 @@ func GetJoystickAxes(joy Joystick) []float32 {
} }
func GetJoystickButtons(joy Joystick) []byte { func GetJoystickButtons(joy Joystick) []byte {
l := 0 var l int32
ptr := glfwDLL.call("glfwGetJoystickButtons", uintptr(joy), uintptr(unsafe.Pointer(&l))) ptr := glfwDLL.call("glfwGetJoystickButtons", uintptr(joy), uintptr(unsafe.Pointer(&l)))
panicError() panicError()
bs := make([]byte, l) bs := make([]byte, l)
for i := 0; i < l; i++ { for i := int32(0); i < l; i++ {
bs[i] = *(*byte)(unsafe.Pointer(ptr)) bs[i] = *(*byte)(unsafe.Pointer(ptr))
ptr++ ptr++
} }
@ -327,11 +330,11 @@ func GetJoystickButtons(joy Joystick) []byte {
} }
func GetMonitors() []*Monitor { func GetMonitors() []*Monitor {
l := 0 var l int32
ptr := glfwDLL.call("glfwGetMonitors", uintptr(unsafe.Pointer(&l))) ptr := glfwDLL.call("glfwGetMonitors", uintptr(unsafe.Pointer(&l)))
panicError() panicError()
ms := make([]*Monitor, l) ms := make([]*Monitor, l)
for i := 0; i < l; i++ { for i := int32(0); i < l; i++ {
m := *(*unsafe.Pointer)(unsafe.Pointer(ptr)) m := *(*unsafe.Pointer)(unsafe.Pointer(ptr))
if m != nil { if m != nil {
ms[i] = &Monitor{uintptr(m)} ms[i] = &Monitor{uintptr(m)}