mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-12 03:58:55 +01:00
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:
parent
288e0a33ba
commit
d4a522d9da
@ -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)}
|
||||||
|
Loading…
Reference in New Issue
Block a user