From 4492c0dad02d5330460b718591c43b9130fab06f Mon Sep 17 00:00:00 2001 From: Hajime Hoshi Date: Sun, 3 Apr 2016 01:14:39 +0900 Subject: [PATCH] audio/vorbis: Refactoring: Use uintptr to calc a pointer value with an offset --- exp/audio/vorbis/vorbis.go | 9 +++------ 1 file changed, 3 insertions(+), 6 deletions(-) diff --git a/exp/audio/vorbis/vorbis.go b/exp/audio/vorbis/vorbis.go index 512e44e78..c884b6003 100644 --- a/exp/audio/vorbis/vorbis.go +++ b/exp/audio/vorbis/vorbis.go @@ -5488,10 +5488,6 @@ int stb_vorbis_get_samples_float(stb_vorbis *f, int channels, float **buffer, in #endif // STB_VORBIS_HEADER_ONLY -static inline short shortValue(short* data, int i) { - return data[i]; -} - */ import "C" @@ -5547,8 +5543,9 @@ type decoded struct { } func (d *decoded) at(offset int) C.short { - // return *(*C.short)(unsafe.Pointer(uintptr(unsafe.Pointer(d.data)) + uintptr(offset))) - return C.shortValue(d.data, C.int(offset)) + const sizeOfShort = 2 + p := uintptr(unsafe.Pointer(d.data)) + return *(*C.short)(unsafe.Pointer(p + uintptr(offset*sizeOfShort))) } func (d *decoded) Read(b []byte) (int, error) {