From e9eee75195cc1fcf7f3aa69dbcc3e72c31315947 Mon Sep 17 00:00:00 2001 From: Larpon Date: Tue, 17 Oct 2023 19:51:55 +0200 Subject: [PATCH] all: fix `warning: unknown type C.XYZ (all virtual C types must be defined, ...)` (#604) --- a_types.c.v | 5 +++++ audio.c.v | 8 ++++---- blendmode.c.v | 2 +- gamecontroller.c.v | 4 ++-- joystick.c.v | 16 ++++++++-------- keyboard.c.v | 10 +++++----- log.c.v | 2 +- mixer/mixer.c.v | 6 +++--- power.c.v | 2 +- sensor.c.v | 12 ++++++------ stdinc.c.v | 8 ++++---- surface.c.v | 4 ++-- thread.c.v | 6 +++--- timer.c.v | 2 +- touch.c.v | 2 +- video.c.v | 6 +++--- 16 files changed, 50 insertions(+), 45 deletions(-) create mode 100644 a_types.c.v diff --git a/a_types.c.v b/a_types.c.v new file mode 100644 index 00000000..dcd98466 --- /dev/null +++ b/a_types.c.v @@ -0,0 +1,5 @@ +module sdl + +// va_list +[typedef] +pub struct C.va_list {} diff --git a/audio.c.v b/audio.c.v index 5b22f479..3f8d5a67 100644 --- a/audio.c.v +++ b/audio.c.v @@ -377,7 +377,7 @@ pub fn open_audio_device(const_device &char, iscapture int, const_desired &Audio allowed_changes)) } -fn C.SDL_OpenAudioDevice(const_device &char, iscapture int, const_desired &C.SDL_AudioSpec, obtained &C.SDL_AudioSpec, allowed_changes int) C.SDL_AudioDeviceID +fn C.SDL_OpenAudioDevice(const_device &char, iscapture int, const_desired &C.SDL_AudioSpec, obtained &C.SDL_AudioSpec, allowed_changes int) AudioDeviceID // AudioStatus // @@ -395,13 +395,13 @@ pub fn get_audio_status() AudioStatus { return AudioStatus(C.SDL_GetAudioStatus()) } -fn C.SDL_GetAudioStatus() C.SDL_AudioStatus +fn C.SDL_GetAudioStatus() AudioStatus pub fn get_audio_device_status(dev AudioDeviceID) AudioStatus { - return AudioStatus(C.SDL_GetAudioDeviceStatus(C.SDL_AudioDeviceID(dev))) + return AudioStatus(C.SDL_GetAudioDeviceStatus(dev)) } -fn C.SDL_GetAudioDeviceStatus(dev C.SDL_AudioDeviceID) C.SDL_AudioStatus +fn C.SDL_GetAudioDeviceStatus(dev AudioDeviceID) AudioStatus // Pause audio functions // diff --git a/blendmode.c.v b/blendmode.c.v index 5eb1c96d..9f0acd07 100644 --- a/blendmode.c.v +++ b/blendmode.c.v @@ -42,7 +42,7 @@ pub enum BlendFactor { one_minus_dst_alpha = C.SDL_BLENDFACTOR_ONE_MINUS_DST_ALPHA // 0xA, 1-dstA, 1-dstA, 1-dstA, 1-dstA } -fn C.SDL_ComposeCustomBlendMode(src_color_factor C.SDL_BlendFactor, dst_color_factor C.SDL_BlendFactor, color_operation C.SDL_BlendOperation, src_alpha_factor C.SDL_BlendFactor, dst_alpha_factor C.SDL_BlendFactor, alpha_operation C.SDL_BlendOperation) C.SDL_BlendMode +fn C.SDL_ComposeCustomBlendMode(src_color_factor C.SDL_BlendFactor, dst_color_factor C.SDL_BlendFactor, color_operation C.SDL_BlendOperation, src_alpha_factor C.SDL_BlendFactor, dst_alpha_factor C.SDL_BlendFactor, alpha_operation C.SDL_BlendOperation) BlendMode // compose_custom_blend_mode creates a custom blend mode, which may // or may not be supported by a given renderer diff --git a/gamecontroller.c.v b/gamecontroller.c.v index 4c1aa968..e8268fe4 100644 --- a/gamecontroller.c.v +++ b/gamecontroller.c.v @@ -288,7 +288,7 @@ pub enum GameControllerAxis { max = C.SDL_CONTROLLER_AXIS_MAX } -fn C.SDL_GameControllerGetAxisFromString(pch_string &char) C.SDL_GameControllerAxis +fn C.SDL_GameControllerGetAxisFromString(pch_string &char) GameControllerAxis // game_controller_get_axis_from_string turns the string into an axis mapping pub fn game_controller_get_axis_from_string(pch_string &char) GameControllerAxis { @@ -343,7 +343,7 @@ pub enum GameControllerButton { max = C.SDL_CONTROLLER_BUTTON_MAX } -fn C.SDL_GameControllerGetButtonFromString(pch_string &char) C.SDL_GameControllerButton +fn C.SDL_GameControllerGetButtonFromString(pch_string &char) GameControllerButton // game_controller_get_button_from_string turns the string into a button mapping pub fn game_controller_get_button_from_string(pch_string &char) GameControllerButton { diff --git a/joystick.c.v b/joystick.c.v index 297a54c4..83455359 100644 --- a/joystick.c.v +++ b/joystick.c.v @@ -53,8 +53,8 @@ pub enum JoystickType { throttle } -// C.SDL_JoystickID // Sint32 / int -pub type JoystickID = int +// C.SDL_JoystickID // Sint32 +pub type JoystickID = i32 // JoystickPowerLevel is C.SDL_JoystickPowerLevel pub enum JoystickPowerLevel { @@ -146,7 +146,7 @@ pub fn joystick_get_device_product_version(device_index int) u16 { return C.SDL_JoystickGetDeviceProductVersion(device_index) } -fn C.SDL_JoystickGetDeviceType(device_index int) C.SDL_JoystickType +fn C.SDL_JoystickGetDeviceType(device_index int) JoystickType // joystick_get_device_type gets the type of a joystick, if available. // This can be called before any joysticks are opened. @@ -154,7 +154,7 @@ pub fn joystick_get_device_type(device_index int) JoystickType { return unsafe { JoystickType(int(C.SDL_JoystickGetDeviceType(device_index))) } } -fn C.SDL_JoystickGetDeviceInstanceID(device_index int) C.SDL_JoystickID +fn C.SDL_JoystickGetDeviceInstanceID(device_index int) JoystickID // joystick_get_device_instance_id gets the instance ID of a joystick. // This can be called before any joysticks are opened. @@ -231,7 +231,7 @@ pub fn joystick_get_product_version(joystick &Joystick) u16 { return C.SDL_JoystickGetProductVersion(joystick) } -fn C.SDL_JoystickGetType(joystick &C.SDL_Joystick) C.SDL_JoystickType +fn C.SDL_JoystickGetType(joystick &C.SDL_Joystick) JoystickType // joystick_get_type gets the type of an opened joystick. pub fn joystick_get_type(joystick &Joystick) JoystickType { @@ -260,10 +260,10 @@ pub fn joystick_get_attached(joystick &Joystick) bool { return C.SDL_JoystickGetAttached(joystick) } -fn C.SDL_JoystickInstanceID(joystick &C.SDL_Joystick) C.SDL_JoystickID +fn C.SDL_JoystickInstanceID(joystick &C.SDL_Joystick) JoystickID // joystick_instance_id gets the instance ID of an opened joystick or -1 if the joystick is invalid. -pub fn joystick_instance_id(joystick &Joystick) C.SDL_JoystickID { +pub fn joystick_instance_id(joystick &Joystick) JoystickID { return C.SDL_JoystickInstanceID(joystick) } @@ -408,7 +408,7 @@ pub fn joystick_close(joystick &Joystick) { C.SDL_JoystickClose(joystick) } -fn C.SDL_JoystickCurrentPowerLevel(joystick &C.SDL_Joystick) C.SDL_JoystickPowerLevel +fn C.SDL_JoystickCurrentPowerLevel(joystick &C.SDL_Joystick) JoystickPowerLevel // joystick_current_power_level returns the battery level of this joystick pub fn joystick_current_power_level(joystick &Joystick) JoystickPowerLevel { diff --git a/keyboard.c.v b/keyboard.c.v index d0623aa5..070a461d 100644 --- a/keyboard.c.v +++ b/keyboard.c.v @@ -50,7 +50,7 @@ pub fn get_keyboard_state(numkeys &int) &u8 { return C.SDL_GetKeyboardState(numkeys) } -fn C.SDL_GetModState() C.SDL_Keymod +fn C.SDL_GetModState() Keymod // get_mod_state gets the current key modifier state for the keyboard. pub fn get_mod_state() Keymod { @@ -66,7 +66,7 @@ pub fn set_mod_state(modstate Keymod) { C.SDL_SetModState(C.SDL_Keymod(modstate)) } -fn C.SDL_GetKeyFromScancode(scancode C.SDL_Scancode) C.SDL_Keycode +fn C.SDL_GetKeyFromScancode(scancode C.SDL_Scancode) Keycode // get_key_from_scancode gets the key code corresponding to the given scancode according // to the current keyboard layout. @@ -78,7 +78,7 @@ pub fn get_key_from_scancode(scancode Scancode) Keycode { return Keycode(int(C.SDL_GetKeyFromScancode(C.SDL_Scancode(scancode)))) } -fn C.SDL_GetScancodeFromKey(key C.SDL_Keycode) C.SDL_Scancode +fn C.SDL_GetScancodeFromKey(key C.SDL_Keycode) Scancode // get_scancode_from_key gets the scancode corresponding to the given key code according to the // current keyboard layout. @@ -103,7 +103,7 @@ pub fn get_scancode_name(scancode Scancode) &char { return C.SDL_GetScancodeName(C.SDL_Scancode(scancode)) } -fn C.SDL_GetScancodeFromName(name &char) C.SDL_Scancode +fn C.SDL_GetScancodeFromName(name &char) Scancode // get_scancode_from_name gets a scancode from a human-readable name // @@ -128,7 +128,7 @@ pub fn get_key_name(key Keycode) &char { return C.SDL_GetKeyName(C.SDL_Keycode(key)) } -fn C.SDL_GetKeyFromName(name &char) C.SDL_Keycode +fn C.SDL_GetKeyFromName(name &char) Keycode // get_key_from_name gets a key code from a human-readable name // diff --git a/log.c.v b/log.c.v index bb09e849..7f7ca718 100644 --- a/log.c.v +++ b/log.c.v @@ -77,7 +77,7 @@ pub fn log_set_priority(category int, priority LogPriority) { C.SDL_LogSetPriority(category, C.SDL_LogPriority(int(priority))) } -fn C.SDL_LogGetPriority(category int) C.SDL_LogPriority +fn C.SDL_LogGetPriority(category int) LogPriority // log_get_priority gets the priority of a particular log category pub fn log_get_priority(category int) LogPriority { diff --git a/mixer/mixer.c.v b/mixer/mixer.c.v index 5bd6d050..63e1d919 100644 --- a/mixer/mixer.c.v +++ b/mixer/mixer.c.v @@ -277,7 +277,7 @@ pub fn has_music_decoder(name &char) bool { } */ -fn C.Mix_GetMusicType(music &C.Mix_Music) C.Mix_MusicType +fn C.Mix_GetMusicType(music &C.Mix_Music) MusicType // get_music_type finds out the music format of a mixer music, or the currently playing // music, if 'music' is NULL. @@ -749,14 +749,14 @@ pub fn fade_out_music(ms int) int { return C.Mix_FadeOutMusic(ms) } -fn C.Mix_FadingMusic() C.Mix_Fading +fn C.Mix_FadingMusic() Fading // fading_music queries the fading status of a channel pub fn fading_music() Fading { return Fading(C.Mix_FadingMusic()) } -fn C.Mix_FadingChannel(which int) C.Mix_Fading +fn C.Mix_FadingChannel(which int) Fading pub fn fading_channel(which int) Fading { return Fading(C.Mix_FadingChannel(which)) } diff --git a/power.c.v b/power.c.v index 796efa55..28d4d801 100644 --- a/power.c.v +++ b/power.c.v @@ -17,7 +17,7 @@ pub enum PowerState { charged = C.SDL_POWERSTATE_CHARGED // Plugged in, battery charged } -fn C.SDL_GetPowerInfo(secs &int, pct &int) C.SDL_PowerState +fn C.SDL_GetPowerInfo(secs &int, pct &int) PowerState // get_power_info gets the current power supply details. // diff --git a/sensor.c.v b/sensor.c.v index acc5743d..3203f897 100644 --- a/sensor.c.v +++ b/sensor.c.v @@ -94,7 +94,7 @@ pub fn sensor_get_device_name(device_index int) &char { return C.SDL_SensorGetDeviceName(device_index) } -fn C.SDL_SensorGetDeviceType(device_index int) C.SDL_SensorType +fn C.SDL_SensorGetDeviceType(device_index int) SensorType // sensor_get_device_type gets the type of a sensor. // @@ -116,7 +116,7 @@ pub fn sensor_get_device_non_portable_type(device_index int) int { return C.SDL_SensorGetDeviceNonPortableType(device_index) } -fn C.SDL_SensorGetDeviceInstanceID(device_index int) C.SDL_SensorID +fn C.SDL_SensorGetDeviceInstanceID(device_index int) SensorID // sensor_get_device_instance_id gets the instance ID of a sensor. // @@ -138,10 +138,10 @@ pub fn sensor_open(device_index int) &Sensor { return C.SDL_SensorOpen(device_index) } -fn C.SDL_SensorFromInstanceID(instance_id C.SDL_SensorID) &C.SDL_Sensor +fn C.SDL_SensorFromInstanceID(instance_id SensorID) &Sensor // sensor_from_instance_id returns the SDL_Sensor associated with an instance id. -pub fn sensor_from_instance_id(instance_id C.SDL_SensorID) &Sensor { +pub fn sensor_from_instance_id(instance_id SensorID) &Sensor { return C.SDL_SensorFromInstanceID(instance_id) } @@ -154,7 +154,7 @@ pub fn sensor_get_name(sensor &Sensor) &char { return C.SDL_SensorGetName(sensor) } -fn C.SDL_SensorGetType(sensor &C.SDL_Sensor) C.SDL_SensorType +fn C.SDL_SensorGetType(sensor &C.SDL_Sensor) SensorType // sensor_get_type gets the type of a sensor. // @@ -176,7 +176,7 @@ pub fn sensor_get_non_portable_type(sensor &Sensor) int { return C.SDL_SensorGetNonPortableType(sensor) } -fn C.SDL_SensorGetInstanceID(sensor &C.SDL_Sensor) C.SDL_SensorID +fn C.SDL_SensorGetInstanceID(sensor &C.SDL_Sensor) SensorID // sensor_get_instance_id gets the instance ID of a sensor. // diff --git a/stdinc.c.v b/stdinc.c.v index ec93ed33..b6a19a51 100644 --- a/stdinc.c.v +++ b/stdinc.c.v @@ -316,8 +316,8 @@ pub fn ultoa(value u32, str &char, radix int) &char { return C.SDL_ultoa(value, str, radix) } -fn C.SDL_lltoa(value C.Sint64, str &char, radix int) &char -pub fn lltoa(value C.Sint64, str &char, radix int) &char { +fn C.SDL_lltoa(value i64, str &char, radix int) &char +pub fn lltoa(value i64, str &char, radix int) &char { return C.SDL_lltoa(value, str, radix) } @@ -346,8 +346,8 @@ pub fn strtoul(str &char, endp &&char, base int) u32 { return C.SDL_strtoul(str, endp, base) } -fn C.SDL_strtoll(str &char, endp &&char, base int) C.Sint64 -pub fn strtoll(str &char, endp &&char, base int) C.Sint64 { +fn C.SDL_strtoll(str &char, endp &&char, base int) i64 +pub fn strtoll(str &char, endp &&char, base int) i64 { return C.SDL_strtoll(str, endp, base) } diff --git a/surface.c.v b/surface.c.v index b8d1ed39..bce33a6d 100644 --- a/surface.c.v +++ b/surface.c.v @@ -518,14 +518,14 @@ pub fn set_yuv_conversion_mode(mode YUVConversionMode) { C.SDL_SetYUVConversionMode(C.SDL_YUV_CONVERSION_MODE(int(mode))) } -fn C.SDL_GetYUVConversionMode() C.SDL_YUV_CONVERSION_MODE +fn C.SDL_GetYUVConversionMode() YUVConversionMode // get_yuv_conversion_mode gets the YUV conversion mode pub fn get_yuv_conversion_mode() YUVConversionMode { return unsafe { YUVConversionMode(int(C.SDL_GetYUVConversionMode())) } } -fn C.SDL_GetYUVConversionModeForResolution(width int, height int) C.SDL_YUV_CONVERSION_MODE +fn C.SDL_GetYUVConversionModeForResolution(width int, height int) YUVConversionMode // get_yuv_conversion_mode_for_resolution gets the YUV conversion mode, returning the correct mode for the resolution when // the current conversion mode is SDL_YUV_CONVERSION_AUTOMATIC diff --git a/thread.c.v b/thread.c.v index c996d353..849f2340 100644 --- a/thread.c.v +++ b/thread.c.v @@ -119,14 +119,14 @@ pub fn get_thread_name(pthread &Thread) &char { return C.SDL_GetThreadName(pthread) } -fn C.SDL_ThreadID() C.SDL_threadID +fn C.SDL_ThreadID() ThreadID // thread_id gets the thread identifier for the current thread. pub fn thread_id() ThreadID { return ThreadID(u32(C.SDL_ThreadID())) } -fn C.SDL_GetThreadID(thrd &C.SDL_Thread) C.SDL_threadID +fn C.SDL_GetThreadID(thrd &C.SDL_Thread) ThreadID // get_thread_id gets the thread identifier for the specified thread. // @@ -194,7 +194,7 @@ pub fn detach_thread(thrd &Thread) { C.SDL_DetachThread(thrd) } -fn C.SDL_TLSCreate() C.SDL_TLSID +fn C.SDL_TLSCreate() TLSID // tls_create create an identifier that is globally visible to all threads but refers to data that is thread-specific. // diff --git a/timer.c.v b/timer.c.v index 9acddf2a..309675ae 100644 --- a/timer.c.v +++ b/timer.c.v @@ -69,7 +69,7 @@ pub fn delay(ms u32) { C.SDL_Delay(ms) } -fn C.SDL_AddTimer(interval u32, callback C.SDL_TimerCallback, param voidptr) C.SDL_TimerID +fn C.SDL_AddTimer(interval u32, callback C.SDL_TimerCallback, param voidptr) TimerID // add_timer adds a new timer to the pool of timers already running. // diff --git a/touch.c.v b/touch.c.v index 9a4cf861..71cf0695 100644 --- a/touch.c.v +++ b/touch.c.v @@ -55,7 +55,7 @@ pub fn get_touch_device(index int) TouchID { return C.SDL_GetTouchDevice(index) } -fn C.SDL_GetTouchDeviceType(touch_id TouchID) C.SDL_TouchDeviceType +fn C.SDL_GetTouchDeviceType(touch_id TouchID) TouchDeviceType // get_touch_device_type gets the type of the given touch device. pub fn get_touch_device_type(touch_id TouchID) TouchDeviceType { diff --git a/video.c.v b/video.c.v index 2b1809ab..d5a664d7 100644 --- a/video.c.v +++ b/video.c.v @@ -389,7 +389,7 @@ pub fn get_display_dpi(display_index int, ddpi &f32, hdpi &f32, vdpi &f32) int { return C.SDL_GetDisplayDPI(display_index, ddpi, hdpi, vdpi) } -fn C.SDL_GetDisplayOrientation(display_index int) C.SDL_DisplayOrientation +fn C.SDL_GetDisplayOrientation(display_index int) DisplayOrientation // get_display_orientation gets the orientation of a display // @@ -1260,7 +1260,7 @@ pub fn gl_get_attribute(attr GLattr, value &int) int { return C.SDL_GL_GetAttribute(C.SDL_GLattr(int(attr)), value) } -fn C.SDL_GL_CreateContext(window &C.SDL_Window) C.SDL_GLContext +fn C.SDL_GL_CreateContext(window &C.SDL_Window) GLContext // gl_create_context creates an OpenGL context for use with an OpenGL window, and make it // current. @@ -1286,7 +1286,7 @@ pub fn gl_get_current_window() &Window { return C.SDL_GL_GetCurrentWindow() } -fn C.SDL_GL_GetCurrentContext() C.SDL_GLContext +fn C.SDL_GL_GetCurrentContext() GLContext // gl_get_current_context gets the currently active OpenGL context. pub fn gl_get_current_context() GLContext {