-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathmain_windows.c.v
72 lines (66 loc) · 2.7 KB
/
main_windows.c.v
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
// Copyright(C) 2021 Lars Pontoppidan. All rights reserved.
// Use of this source code is governed by an MIT license
// that can be found in the LICENSE file.
module sdl
//
// SDL_main.h
//
fn C.SDL_RegisterApp(name &char, style u32, h_inst voidptr) int
// register_app registers a win32 window class for SDL's use.
//
// This can be called to set the application window class at startup. It is
// safe to call this multiple times, as long as every call is eventually
// paired with a call to SDL_UnregisterApp, but a second registration attempt
// while a previous registration is still active will be ignored, other than
// to increment a counter.
//
// Most applications do not need to, and should not, call this directly; SDL
// will call it when initializing the video subsystem.
//
// `name` the window class name, in UTF-8 encoding. If NULL, SDL
// currently uses "SDL_app" but this isn't guaranteed.
// `style` the value to use in WNDCLASSEX::style. If `name` is NULL, SDL
// currently uses `(CS_BYTEALIGNCLIENT | CS_OWNDC)` regardless of
// what is specified here.
// `hInst` the HINSTANCE to use in WNDCLASSEX::hInstance. If zero, SDL
// will use `GetModuleHandle(NULL)` instead.
// returns 0 on success, -1 on error. SDL_GetError() may have details.
//
// NOTE This function is available since SDL 2.0.2.
pub fn register_app(name &char, style u32, h_inst voidptr) int {
return C.SDL_RegisterApp(name, style, h_inst)
}
fn C.SDL_UnregisterApp()
// unregister_app deregisters the win32 window class from an SDL_RegisterApp call.
//
// This can be called to undo the effects of SDL_RegisterApp.
//
// Most applications do not need to, and should not, call this directly; SDL
// will call it when deinitializing the video subsystem.
//
// It is safe to call this multiple times, as long as every call is eventually
// paired with a prior call to SDL_RegisterApp. The window class will only be
// deregistered when the registration counter in SDL_RegisterApp decrements to
// zero through calls to this function.
//
// NOTE This function is available since SDL 2.0.2.
pub fn unregister_app() {
C.SDL_UnregisterApp()
}
/*
TODO support GDK?
$if gdk ? {
fn C.SDL_GDKRunApp(main_function C.SDL_main_func, reserved voidptr) int
// Initialize and launch an SDL GDK application.
//
// `main_function` the SDL app's C-style main(), an SDL_main_func
// `reserved` reserved for future use; should be NULL
// returns 0 on success or -1 on failure; call SDL_GetError() to retrieve
// more information on the failure.
//
// NOTE This function is available since SDL 2.24.0.
gdk_run_app(main_function C.SDL_main_func, reserved voidptr) int {
return C.SDL_GDKRunApp(main_function, reserved)
}
}
*/