Mercurial > repos > tabletprog
annotate modules/sdl.tp @ 329:eef8a5cea812
Use a smarter algorithm for calculating module init order and break some circular module dependencies in the standard library
author | Michael Pavone <pavone@retrodev.com> |
---|---|
date | Sat, 28 Mar 2015 13:26:03 -0700 |
parents | 4c669942c30d |
children | ead24192ed45 |
rev | line source |
---|---|
274
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
1 { |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
2 _helper <- #{ |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
3 llMessage: createWindow withVars: { |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
4 title <- string ptr |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
5 x <- obj_int32 ptr |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
6 y <- obj_int32 ptr |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
7 w <- obj_int32 ptr |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
8 h <- obj_int32 ptr |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
9 flags <- obj_uint32 ptr |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
10 makeWindow <- lambda ptr |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
11 windowOpaque <- cpointer ptr |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
12 win <- object ptr |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
13 } andCode: :title x y w h flags makeWindow { |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
14 windowOpaque <- make_object: (addr_of: cpointer_meta) NULL 0 |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
15 windowOpaque val!: (SDL_CreateWindow: (title data) (x num) (y num) (w num) (h num) (flags num)) |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
16 if: (windowOpaque val) { |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
17 win <- ccall: makeWindow 1 (windowOpaque castTo: (object ptr)) |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
18 mcall: value 2 option win |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
19 } else: { |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
20 mcall: none 1 option |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
21 } |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
22 } |
277
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
23 |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
24 llMessage: createRenderer withVars: { |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
25 window <- cpointer ptr |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
26 index <- obj_int32 ptr |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
27 flags <- obj_uint32 ptr |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
28 rendOpaque <- cpointer ptr |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
29 rend <- object ptr |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
30 makeRender <- lambda ptr |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
31 } andCode: :window index flags makeRender { |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
32 rendOpaque <- make_object: (addr_of: cpointer_meta) NULL 0 |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
33 rendOpaque val!: (SDL_CreateRenderer: (window val) (index num) (flags num)) |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
34 if: (rendOpaque val) { |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
35 rend <- ccall: makeRender 1 (rendOpaque castTo: (object ptr)) |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
36 mcall: value 2 option rend |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
37 } else: { |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
38 mcall: none 1 option |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
39 } |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
40 } |
278
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
41 |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
42 llMessage: loadBMP withVars: { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
43 filename <- string ptr |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
44 makeSurface <- lambda ptr |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
45 surfOpaque <- cpointer ptr |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
46 surf <- object ptr |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
47 } andCode: :filename makeSurface{ |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
48 surfOpaque <- make_object: (addr_of: cpointer_meta) NULL 0 |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
49 surfOpaque val!: (SDL_LoadBMP: (filename data)) |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
50 if: (surfOpaque val) { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
51 surf <- ccall: makeSurface 1 (surfOpaque castTo: (object ptr)) |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
52 mcall: value 2 option surf |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
53 } else: { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
54 mcall: none 1 option |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
55 } |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
56 } |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
57 |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
58 llMessage: createTextureFromSurface withVars: { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
59 rendOpaque <- cpointer ptr |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
60 surfOpaque <- cpointer ptr |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
61 makeTexture <- lambda ptr |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
62 texOpaque <- cpointer ptr |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
63 tex <- object ptr |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
64 } andCode: :rendOpaque surfOpaque makeTexture { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
65 texOpaque <- make_object: (addr_of: cpointer_meta) NULL 0 |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
66 texOpaque val!: (SDL_CreateTextureFromSurface: (rendOpaque val) (surfOpaque val)) |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
67 if: (texOpaque val) { |
291
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
68 tex <- ccall: makeTexture 2 (rendOpaque castTo: (object ptr)) (texOpaque castTo: (object ptr)) |
278
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
69 mcall: value 2 option tex |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
70 } else: { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
71 mcall: none 1 option |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
72 } |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
73 } |
318
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
74 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
75 llMessage: createTexture withVars: { |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
76 rendOpaque <- cpointer ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
77 format <- object ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
78 formatn <- obj_uint32 ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
79 access <- object ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
80 accessn <- obj_int32 ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
81 w <- object ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
82 wn <- obj_int32 ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
83 h <- object ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
84 hn <- obj_int32 ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
85 makeTexture <- lambda ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
86 texOpaque <- cpointer ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
87 tex <- object ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
88 } andCode: :rendOpaque format access w h makeTexture { |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
89 formatn <- (mcall: uint32 1 format) castTo: (obj_uint32 ptr) |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
90 accessn <- (mcall: int32 1 access) castTo: (obj_int32 ptr) |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
91 wn <- (mcall: int32 1 w) castTo: (obj_int32 ptr) |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
92 hn <- (mcall: int32 1 h) castTo: (obj_int32 ptr) |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
93 texOpaque <- make_object: (addr_of: cpointer_meta) NULL 0 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
94 texOpaque val!: (SDL_CreateTexture: (rendOpaque val) (formatn num) (accessn num) (wn num) (hn num)) |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
95 if: (texOpaque val) { |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
96 tex <- ccall: makeTexture 2 (rendOpaque castTo: (object ptr)) (texOpaque castTo: (object ptr)) |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
97 mcall: value 2 option tex |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
98 } else: { |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
99 mcall: none 1 option |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
100 } |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
101 } |
291
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
102 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
103 llMessage: pollEvent withVars: { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
104 constructor <- lambda ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
105 event <- SDL_Event |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
106 eventPtr <- cpointer ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
107 eventType <- obj_uint32 ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
108 timeStampO <- obj_uint32 ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
109 } andCode: :constructor { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
110 if: (SDL_PollEvent: (addr_of: event)) { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
111 eventType <- make_object: (addr_of: obj_uint32_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
112 timeStampO <- make_object: (addr_of: obj_uint32_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
113 eventType num!: ((addr_of: event) type) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
114 timeStampO num!: ((addr_of: ((addr_of: event) common)) timestamp) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
115 eventPtr <- make_object: (addr_of: cpointer_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
116 eventPtr val!: (addr_of: event) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
117 mcall: value 2 option (ccall: constructor 3 (eventType castTo: (object ptr)) ( |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
118 timeStampO castTo: (object ptr)) (eventPtr castTo: (object ptr))) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
119 } else: { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
120 mcall: none 1 option |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
121 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
122 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
123 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
124 llMessage: populateWindowEvent withVars: { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
125 eventPtr <- cpointer ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
126 empty <- object ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
127 winEvent <- SDL_WindowEvent ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
128 ou32 <- obj_uint32 ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
129 ou8 <- obj_uint8 ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
130 oi32 <- obj_int32 ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
131 } andCode: :eventPtr empty { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
132 winEvent <- eventPtr val |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
133 ou32 <- make_object: (addr_of: obj_uint32_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
134 ou32 num!: (winEvent windowID) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
135 mcall: windowID! 2 empty ou32 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
136 ou8 <- make_object: (addr_of: obj_uint8_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
137 ou8 num!: (winEvent event) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
138 mcall: event! 2 empty ou8 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
139 oi32 <- make_object: (addr_of: obj_int32_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
140 oi32 num!: (winEvent data1) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
141 mcall: data1! 2 empty oi32 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
142 oi32 <- make_object: (addr_of: obj_int32_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
143 oi32 num!: (winEvent data2) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
144 mcall: data2! 2 empty oi32 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
145 empty |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
146 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
147 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
148 llMessage: populateKeyEvent withVars: { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
149 eventPtr <- cpointer ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
150 empty <- object ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
151 keyEvent <- SDL_KeyboardEvent ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
152 ou32 <- obj_uint32 ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
153 ou16 <- obj_uint32 ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
154 ou8 <- obj_uint8 ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
155 } andCode: :eventPtr empty { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
156 keyEvent <- eventPtr val |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
157 ou32 <- make_object: (addr_of: obj_uint32_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
158 ou32 num!: (keyEvent windowID) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
159 mcall: windowID! 2 empty ou32 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
160 if: (keyEvent state) = SDL_PRESSED { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
161 mcall: pressed?! 2 empty true |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
162 } else: { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
163 mcall: pressed?! 2 empty false |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
164 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
165 ou8 <- make_object: (addr_of: obj_uint8_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
166 ou8 num!: (keyEvent repeat) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
167 mcall: repeat! 2 empty ou8 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
168 ou32 <- make_object: (addr_of: obj_uint32_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
169 ou32 num!: ((addr_of: (keyEvent keysym)) scancode) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
170 mcall: scanCode! 2 empty ou32 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
171 ou32 <- make_object: (addr_of: obj_uint32_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
172 ou32 num!: ((addr_of: (keyEvent keysym)) sym) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
173 mcall: keyCode! 2 empty ou32 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
174 ou16 <- make_object: (addr_of: obj_uint16_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
175 ou16 num!: ((addr_of: (keyEvent keysym)) mod) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
176 mcall: mod! 2 empty ou16 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
177 empty |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
178 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
179 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
180 llMessage: populateMouseButtonEvent withVars: { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
181 eventPtr <- cpointer ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
182 empty <- object ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
183 mouseButEvent <- SDL_MouseButtonEvent ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
184 ou32 <- obj_uint32 ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
185 ou8 <- obj_uint8 ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
186 oi32 <- obj_int32 ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
187 } andCode: :eventPtr empty { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
188 mouseButEvent <- eventPtr val |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
189 ou32 <- make_object: (addr_of: obj_uint32_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
190 ou32 num!: (mouseButEvent windowID) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
191 mcall: windowID! 2 empty ou32 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
192 ou32 <- make_object: (addr_of: obj_uint32_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
193 ou32 num!: (mouseButEvent which) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
194 mcall: mouseID! 2 empty ou32 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
195 ou8 <- make_object: (addr_of: obj_uint8_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
196 ou8 num!: (mouseButEvent button) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
197 mcall: button! 2 empty ou8 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
198 if: (mouseButEvent state) = SDL_PRESSED { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
199 mcall: pressed?! 2 empty true |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
200 } else: { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
201 mcall: pressed?! 2 empty false |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
202 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
203 ou8 <- make_object: (addr_of: obj_uint8_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
204 ou8 num!: (mouseButEvent clicks) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
205 mcall: clicks! 2 empty ou8 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
206 oi32 <- make_object: (addr_of: obj_int32_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
207 oi32 num!: (mouseButEvent x) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
208 mcall: x! 2 empty oi32 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
209 oi32 <- make_object: (addr_of: obj_int32_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
210 oi32 num!: (mouseButEvent y) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
211 mcall: y! 2 empty oi32 |
293
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
212 empty |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
213 } |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
214 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
215 llMessage: populateMouseMotionEvent withVars: { |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
216 eventPtr <- cpointer ptr |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
217 empty <- object ptr |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
218 mouseMotEvent <- SDL_MouseMotionEvent ptr |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
219 ou32 <- obj_uint32 ptr |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
220 oi32 <- obj_int32 ptr |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
221 } andCode: :eventPtr empty { |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
222 mouseMotEvent <- eventPtr val |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
223 ou32 <- make_object: (addr_of: obj_uint32_meta) NULL 0 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
224 ou32 num!: (mouseMotEvent windowID) |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
225 mcall: windowID! 2 empty ou32 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
226 ou32 <- make_object: (addr_of: obj_uint32_meta) NULL 0 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
227 ou32 num!: (mouseMotEvent which) |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
228 mcall: mouseID! 2 empty ou32 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
229 ou32 <- make_object: (addr_of: obj_uint32_meta) NULL 0 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
230 ou32 num!: (mouseMotEvent state) |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
231 mcall: buttonState! 2 empty ou32 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
232 oi32 <- make_object: (addr_of: obj_int32_meta) NULL 0 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
233 oi32 num!: (mouseMotEvent x) |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
234 mcall: x! 2 empty oi32 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
235 oi32 <- make_object: (addr_of: obj_int32_meta) NULL 0 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
236 oi32 num!: (mouseMotEvent y) |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
237 mcall: y! 2 empty oi32 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
238 oi32 <- make_object: (addr_of: obj_int32_meta) NULL 0 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
239 oi32 num!: (mouseMotEvent xrel) |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
240 mcall: xRel! 2 empty oi32 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
241 oi32 <- make_object: (addr_of: obj_int32_meta) NULL 0 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
242 oi32 num!: (mouseMotEvent yrel) |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
243 mcall: yRel! 2 empty oi32 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
244 empty |
291
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
245 } |
278
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
246 } |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
247 |
291
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
248 _constant <- macro: :name cname { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
249 quote: (llMessage: name withVars: { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
250 uintret <- obj_uint32 ptr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
251 } andCode: { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
252 uintret <- make_object: (addr_of: obj_uint32_meta) NULL 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
253 uintret num!: cname |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
254 uintret |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
255 }) |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
256 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
257 _subsystems <- #{ |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
258 _constant: timer SDL_INIT_TIMER |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
259 _constant: audio SDL_INIT_AUDIO |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
260 _constant: video SDL_INIT_VIDEO |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
261 _constant: joystick SDL_INIT_JOYSTICK |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
262 _constant: haptic SDL_INIT_HAPTIC |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
263 _constant: gameController SDL_INIT_GAMECONTROLLER |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
264 _constant: events SDL_INIT_EVENTS |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
265 _constant: everything SDL_INIT_EVERYTHING |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
266 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
267 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
268 _windowOpts <- #{ |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
269 _constant: fullscreen SDL_WINDOW_FULLSCREEN |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
270 _constant: fullscreenDesktop SDL_WINDOW_FULLSCREEN_DESKTOP |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
271 _constant: opengl SDL_WINDOW_OPENGL |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
272 _constant: hidden SDL_WINDOW_HIDDEN |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
273 _constant: borderless SDL_WINDOW_BORDERLESS |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
274 _constant: minimized SDL_WINDOW_MINIMIZED |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
275 _constant: maximized SDL_WINDOW_MAXIMIZED |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
276 _constant: inputGrabbed SDL_WINDOW_INPUT_GRABBED |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
277 _constant: allowHighDPI SDL_WINDOW_ALLOW_HIGHDPI |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
278 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
279 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
280 _renderOpts <- #{ |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
281 _constant: software SDL_RENDERER_SOFTWARE |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
282 _constant: accelerated SDL_RENDERER_ACCELERATED |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
283 _constant: presentVSYNC SDL_RENDERER_PRESENTVSYNC |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
284 _constant: targetTexture SDL_RENDERER_TARGETTEXTURE |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
285 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
286 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
287 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
288 _events <- #{ |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
289 _constant: quit SDL_QUIT |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
290 _constant: window SDL_WINDOWEVENT |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
291 _constant: sysWM SDL_SYSWMEVENT |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
292 _constant: keyDown SDL_KEYDOWN |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
293 _constant: keyUp SDL_KEYUP |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
294 _constant: textEditing SDL_TEXTEDITING |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
295 _constant: textInput SDL_TEXTINPUT |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
296 _constant: mouseMotion SDL_MOUSEMOTION |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
297 _constant: mouseDown SDL_MOUSEBUTTONDOWN |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
298 _constant: mouseUp SDL_MOUSEBUTTONUP |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
299 _constant: mouseWheel SDL_MOUSEWHEEL |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
300 _constant: joyAxis SDL_JOYAXISMOTION |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
301 _constant: joyBall SDL_JOYBALLMOTION |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
302 _constant: joyHat SDL_JOYHATMOTION |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
303 _constant: joyDown SDL_JOYBUTTONDOWN |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
304 _constant: joyUp SDL_JOYBUTTONUP |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
305 _constant: joyDeviceAdded SDL_JOYDEVICEADDED |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
306 _constant: joyDeviceRemoved SDL_JOYDEVICEREMOVED |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
307 _constant: controllerAxis SDL_CONTROLLERAXISMOTION |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
308 _constant: controllerDown SDL_CONTROLLERBUTTONDOWN |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
309 _constant: controllerUp SDL_CONTROLLERBUTTONUP |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
310 _constant: controllerDeviceAdded SDL_CONTROLLERDEVICEADDED |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
311 _constant: controllerDeviceRemoved SDL_CONTROLLERDEVICEREMOVED |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
312 _constant: controllerDeviceRemapped SDL_CONTROLLERDEVICEREMAPPED |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
313 _constant: dropFile SDL_DROPFILE |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
314 //TODO: Add mobile/touch/gesture events |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
315 } |
318
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
316 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
317 _textureAccess <- #{ |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
318 _constant: static SDL_TEXTUREACCESS_STATIC |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
319 _constant: streaming SDL_TEXTUREACCESS_STREAMING |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
320 _constant: target SDL_TEXTUREACCESS_TARGET |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
321 } |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
322 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
323 _pixelFormats <- #{ |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
324 _constant: unknown SDL_PIXELFORMAT_UNKNOWN |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
325 _constant: index1LSB SDL_PIXELFORMAT_INDEX1LSB |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
326 _constant: index1MSB SDL_PIXELFORMAT_INDEX1MSB |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
327 _constant: index4LSB SDL_PIXELFORMAT_INDEX4LSB |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
328 _constant: index4MSB SDL_PIXELFORMAT_INDEX4MSB |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
329 _constant: index8 SDL_PIXELFORMAT_INDEX8 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
330 _constant: rgb332 SDL_PIXELFORMAT_RGB332 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
331 _constant: rgb444 SDL_PIXELFORMAT_RGB444 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
332 _constant: rgb555 SDL_PIXELFORMAT_RGB555 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
333 _constant: bgr555 SDL_PIXELFORMAT_BGR555 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
334 _constant: argb4444 SDL_PIXELFORMAT_ARGB4444 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
335 _constant: bgra4444 SDL_PIXELFORMAT_BGRA4444 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
336 _constant: argb1555 SDL_PIXELFORMAT_ARGB1555 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
337 _constant: rgba5551 SDL_PIXELFORMAT_RGBA5551 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
338 _constant: abgr1555 SDL_PIXELFORMAT_ABGR1555 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
339 _constant: bgra5551 SDL_PIXELFORMAT_BGRA5551 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
340 _constant: rgb565 SDL_PIXELFORMAT_RGB565 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
341 _constant: bgr565 SDL_PIXELFORMAT_BGR565 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
342 _constant: rgb24 SDL_PIXELFORMAT_RGB24 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
343 _constant: bgr24 SDL_PIXELFORMAT_BGR24 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
344 _constant: rgb888 SDL_PIXELFORMAT_RGB888 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
345 _constant: rgbx8888 SDL_PIXELFORMAT_RGBX8888 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
346 _constant: bgr888 SDL_PIXELFORMAT_BGR888 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
347 _constant: bgrx8888 SDL_PIXELFORMAT_BGRX8888 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
348 _constant: argb8888 SDL_PIXELFORMAT_ARGB8888 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
349 _constant: rgba8888 SDL_PIXELFORMAT_RGBA8888 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
350 _constant: abgr8888 SDL_PIXELFORMAT_ABGR8888 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
351 _constant: bgra8888 SDL_PIXELFORMAT_BGRA8888 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
352 _constant: argb2101010 SDL_PIXELFORMAT_ARGB2101010 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
353 _constant: yv12 SDL_PIXELFORMAT_YV12 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
354 _constant: iyuv SDL_PIXELFORMAT_IYUV |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
355 _constant: yuy2 SDL_PIXELFORMAT_YUY2 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
356 _constant: uyvy SDL_PIXELFORMAT_UYVY |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
357 _constant: yvyu SDL_PIXELFORMAT_YVYU |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
358 } |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
359 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
360 _blendModes <- #{ |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
361 _constant: none SDL_BLENDMODE_NONE |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
362 _constant: blend SDL_BLENDMODE_BLEND |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
363 _constant: add SDL_BLENDMODE_ADD |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
364 _constant: mod SDL_BLENDMODE_MOD |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
365 } |
291
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
366 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
367 _eventConstructors <- dict hash |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
368 _eventConstructors set: (_events window) :typ tstamp eventPtr { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
369 _helper populateWindowEvent: eventPtr #{ |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
370 type <- typ |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
371 timeStamp <- tstamp |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
372 windowID <- 0u32 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
373 event <- 0u8 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
374 data1 <- 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
375 data2 <- 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
376 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
377 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
378 keyEvent <- :typ tstamp eventPtr { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
379 _helper populateKeyEvent: eventPtr #{ |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
380 type <- typ |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
381 timeStamp <- tstamp |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
382 windowID <- 0u32 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
383 pressed? <- false |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
384 repeat <- 0u8 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
385 scanCode <- 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
386 keyCode <- 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
387 mod <- 0u16 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
388 _constant: scanCodeMask SDLK_SCANCODE_MASK |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
389 keyChar <- { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
390 if: (keyCode and (self scanCodeMask)) = 0 { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
391 keyCode utf8 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
392 } else: { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
393 "" |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
394 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
395 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
396 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
397 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
398 _eventConstructors set: (_events keyDown) keyEvent |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
399 _eventConstructors set: (_events keyUp) keyEvent |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
400 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
401 mouseButtonEvent <- :typ tstamp eventPtr { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
402 _helper populateMouseButtonEvent: eventPtr #{ |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
403 type <- typ |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
404 timeStamp <- tstamp |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
405 windowID <- 0u32 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
406 mouseID <- 0u32 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
407 button <- 0u8 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
408 pressed? <- false |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
409 clicks <- 0u8 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
410 x <- 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
411 y <- 0 |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
412 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
413 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
414 _eventConstructors set: (_events mouseDown) mouseButtonEvent |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
415 _eventConstructors set: (_events mouseUp) mouseButtonEvent |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
416 |
293
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
417 _eventConstructors set: (_events mouseMotion) :typ tstamp eventPtr { |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
418 _helper populateMouseMotionEvent: eventPtr #{ |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
419 type <- typ |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
420 timeStamp <- tstamp |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
421 windowID <- 0u32 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
422 mouseID <- 0u32 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
423 buttonState <- 0u32 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
424 x <- 0 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
425 y <- 0 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
426 xRel <- 0 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
427 yRel <- 0 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
428 } |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
429 } |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
430 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
431 /* |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
432 _eventConstructors set: (_events mouseWheel) :type tstamp eventPtr { |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
433 _helper populateMouseWheelEvent: eventPtr #{ |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
434 type <- typ |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
435 timeStamp <- tstamp |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
436 windowID <- 0u32 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
437 mouseID <- 0u32 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
438 x <- 0 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
439 y <- 0 |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
440 } |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
441 } |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
442 */ |
2b045d5b673b
Add binding for sdl mouse motion event
Michael Pavone <pavone@retrodev.com>
parents:
291
diff
changeset
|
443 |
279
eb83863fd33e
Store renderer pointer in texture object since the texture can only be used with the renderer it was created with
Michael Pavone <pavone@retrodev.com>
parents:
278
diff
changeset
|
444 _makeTexture <- :rendptr texptr { |
278
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
445 #{ |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
446 includeSystemHeader: "SDL.h" |
279
eb83863fd33e
Store renderer pointer in texture object since the texture can only be used with the renderer it was created with
Michael Pavone <pavone@retrodev.com>
parents:
278
diff
changeset
|
447 llProperty: renderer withType: (SDL_Renderer ptr) |
278
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
448 llProperty: texture withType: (SDL_Texture ptr) |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
449 llMessage: opaque withVars: { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
450 ptr <- cpointer ptr |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
451 } andCode: { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
452 ptr <- make_object: (addr_of: cpointer_meta) NULL 0 |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
453 ptr val!: texture |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
454 ptr |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
455 } |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
456 llMessage: _ptr_init withVars: { |
279
eb83863fd33e
Store renderer pointer in texture object since the texture can only be used with the renderer it was created with
Michael Pavone <pavone@retrodev.com>
parents:
278
diff
changeset
|
457 rendptr <- cpointer ptr |
eb83863fd33e
Store renderer pointer in texture object since the texture can only be used with the renderer it was created with
Michael Pavone <pavone@retrodev.com>
parents:
278
diff
changeset
|
458 texptr <- cpointer ptr |
eb83863fd33e
Store renderer pointer in texture object since the texture can only be used with the renderer it was created with
Michael Pavone <pavone@retrodev.com>
parents:
278
diff
changeset
|
459 } andCode: :rendptr texptr{ |
eb83863fd33e
Store renderer pointer in texture object since the texture can only be used with the renderer it was created with
Michael Pavone <pavone@retrodev.com>
parents:
278
diff
changeset
|
460 renderer <- rendptr val |
eb83863fd33e
Store renderer pointer in texture object since the texture can only be used with the renderer it was created with
Michael Pavone <pavone@retrodev.com>
parents:
278
diff
changeset
|
461 texture <- texptr val |
278
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
462 self |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
463 } |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
464 |
279
eb83863fd33e
Store renderer pointer in texture object since the texture can only be used with the renderer it was created with
Michael Pavone <pavone@retrodev.com>
parents:
278
diff
changeset
|
465 llMessage: copy withVars: { |
278
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
466 intret <- obj_int32 ptr |
279
eb83863fd33e
Store renderer pointer in texture object since the texture can only be used with the renderer it was created with
Michael Pavone <pavone@retrodev.com>
parents:
278
diff
changeset
|
467 } andCode: { |
278
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
468 intret <- make_object: (addr_of: obj_int32_meta) NULL 0 |
279
eb83863fd33e
Store renderer pointer in texture object since the texture can only be used with the renderer it was created with
Michael Pavone <pavone@retrodev.com>
parents:
278
diff
changeset
|
469 intret num!: (SDL_RenderCopy: renderer texture NULL NULL) |
278
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
470 intret |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
471 } |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
472 |
283
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
473 llMessage: copyTo withVars: { |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
474 dst <- object ptr |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
475 dstOpaque <- cpointer ptr |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
476 intret <- obj_int32 ptr |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
477 } andCode: :dst { |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
478 dstOpaque <- (mcall: _rectPointer 1 dst) castTo: (cpointer ptr) |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
479 intret <- make_object: (addr_of: obj_int32_meta) NULL 0 |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
480 intret num!: (SDL_RenderCopy: renderer texture NULL (dstOpaque val)) |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
481 intret |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
482 } |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
483 |
284
99c18127da04
Add another SDL_RenderCopy binding in the form of copyRect:To
Michael Pavone <pavone@retrodev.com>
parents:
283
diff
changeset
|
484 llMessage: copyRect:To withVars: { |
99c18127da04
Add another SDL_RenderCopy binding in the form of copyRect:To
Michael Pavone <pavone@retrodev.com>
parents:
283
diff
changeset
|
485 src <- object ptr |
99c18127da04
Add another SDL_RenderCopy binding in the form of copyRect:To
Michael Pavone <pavone@retrodev.com>
parents:
283
diff
changeset
|
486 dst <- object ptr |
99c18127da04
Add another SDL_RenderCopy binding in the form of copyRect:To
Michael Pavone <pavone@retrodev.com>
parents:
283
diff
changeset
|
487 srcOpaque <- cpointer ptr |
99c18127da04
Add another SDL_RenderCopy binding in the form of copyRect:To
Michael Pavone <pavone@retrodev.com>
parents:
283
diff
changeset
|
488 dstOpaque <- cpointer ptr |
99c18127da04
Add another SDL_RenderCopy binding in the form of copyRect:To
Michael Pavone <pavone@retrodev.com>
parents:
283
diff
changeset
|
489 intret <- obj_int32 ptr |
99c18127da04
Add another SDL_RenderCopy binding in the form of copyRect:To
Michael Pavone <pavone@retrodev.com>
parents:
283
diff
changeset
|
490 } andCode: :src :dst { |
99c18127da04
Add another SDL_RenderCopy binding in the form of copyRect:To
Michael Pavone <pavone@retrodev.com>
parents:
283
diff
changeset
|
491 srcOpaque <- (mcall: _rectPointer 1 src) castTo: (cpointer ptr) |
99c18127da04
Add another SDL_RenderCopy binding in the form of copyRect:To
Michael Pavone <pavone@retrodev.com>
parents:
283
diff
changeset
|
492 dstOpaque <- (mcall: _rectPointer 1 dst) castTo: (cpointer ptr) |
99c18127da04
Add another SDL_RenderCopy binding in the form of copyRect:To
Michael Pavone <pavone@retrodev.com>
parents:
283
diff
changeset
|
493 intret <- make_object: (addr_of: obj_int32_meta) NULL 0 |
99c18127da04
Add another SDL_RenderCopy binding in the form of copyRect:To
Michael Pavone <pavone@retrodev.com>
parents:
283
diff
changeset
|
494 intret num!: (SDL_RenderCopy: renderer texture (srcOpaque val) (dstOpaque val)) |
99c18127da04
Add another SDL_RenderCopy binding in the form of copyRect:To
Michael Pavone <pavone@retrodev.com>
parents:
283
diff
changeset
|
495 intret |
99c18127da04
Add another SDL_RenderCopy binding in the form of copyRect:To
Michael Pavone <pavone@retrodev.com>
parents:
283
diff
changeset
|
496 } |
99c18127da04
Add another SDL_RenderCopy binding in the form of copyRect:To
Michael Pavone <pavone@retrodev.com>
parents:
283
diff
changeset
|
497 |
287
b01d7c1b4edd
Add binding for simple form of SDL_RenderCopyEx
Michael Pavone <pavone@retrodev.com>
parents:
285
diff
changeset
|
498 llMessage: copyTo:rotated withVars: { |
b01d7c1b4edd
Add binding for simple form of SDL_RenderCopyEx
Michael Pavone <pavone@retrodev.com>
parents:
285
diff
changeset
|
499 dst <- object ptr |
b01d7c1b4edd
Add binding for simple form of SDL_RenderCopyEx
Michael Pavone <pavone@retrodev.com>
parents:
285
diff
changeset
|
500 angle <- object ptr |
b01d7c1b4edd
Add binding for simple form of SDL_RenderCopyEx
Michael Pavone <pavone@retrodev.com>
parents:
285
diff
changeset
|
501 dstOpaque <- cpointer ptr |
b01d7c1b4edd
Add binding for simple form of SDL_RenderCopyEx
Michael Pavone <pavone@retrodev.com>
parents:
285
diff
changeset
|
502 anglef <- obj_float32 ptr |
b01d7c1b4edd
Add binding for simple form of SDL_RenderCopyEx
Michael Pavone <pavone@retrodev.com>
parents:
285
diff
changeset
|
503 intret <- obj_int32 ptr |
b01d7c1b4edd
Add binding for simple form of SDL_RenderCopyEx
Michael Pavone <pavone@retrodev.com>
parents:
285
diff
changeset
|
504 } andCode: :dst :angle { |
b01d7c1b4edd
Add binding for simple form of SDL_RenderCopyEx
Michael Pavone <pavone@retrodev.com>
parents:
285
diff
changeset
|
505 anglef <- (mcall: f32 1 angle) castTo: (obj_float32 ptr) |
b01d7c1b4edd
Add binding for simple form of SDL_RenderCopyEx
Michael Pavone <pavone@retrodev.com>
parents:
285
diff
changeset
|
506 dstOpaque <- (mcall: _rectPointer 1 dst) castTo: (cpointer ptr) |
b01d7c1b4edd
Add binding for simple form of SDL_RenderCopyEx
Michael Pavone <pavone@retrodev.com>
parents:
285
diff
changeset
|
507 intret <- make_object: (addr_of: obj_int32_meta) NULL 0 |
b01d7c1b4edd
Add binding for simple form of SDL_RenderCopyEx
Michael Pavone <pavone@retrodev.com>
parents:
285
diff
changeset
|
508 intret num!: (SDL_RenderCopyEx: renderer texture NULL (dstOpaque val) (anglef num) NULL SDL_FLIP_NONE) |
b01d7c1b4edd
Add binding for simple form of SDL_RenderCopyEx
Michael Pavone <pavone@retrodev.com>
parents:
285
diff
changeset
|
509 intret |
b01d7c1b4edd
Add binding for simple form of SDL_RenderCopyEx
Michael Pavone <pavone@retrodev.com>
parents:
285
diff
changeset
|
510 } |
b01d7c1b4edd
Add binding for simple form of SDL_RenderCopyEx
Michael Pavone <pavone@retrodev.com>
parents:
285
diff
changeset
|
511 |
318
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
512 llMessage: lockRect:with withVars: { |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
513 fun <- lambda ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
514 rectOpaque <- cpointer ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
515 pitch <- obj_int32 ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
516 bufsize <- obj_int32 ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
517 height <- obj_int32 ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
518 pixels <- cpointer ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
519 bytearr <- object ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
520 rect <- object ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
521 result <- int32_t |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
522 ret <- object ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
523 } andCode: :rect fun { |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
524 rectOpaque <- (mcall: _rectPointer 1 rect) castTo: (cpointer ptr) |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
525 pitch <- make_object: (addr_of: obj_int32_meta) NULL 0 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
526 pixels <- make_object: (addr_of: cpointer_meta) NULL 0 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
527 //TODO: Check return value |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
528 result <- SDL_LockTexture: texture (rectOpaque val) (addr_of: (pixels val)) (addr_of: (pitch num)) |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
529 if: result = 0 { |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
530 height <- (mcall: h 1 rect) castTo: (obj_int32 ptr) |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
531 bufsize <- make_object: (addr_of: obj_int32_meta) NULL 0 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
532 bufsize num!: (pitch num) * (height num) |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
533 bytearr <- mcall: fromOpaque:withSize 3 bytearray pixels bufsize |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
534 ret <- ccall: fun 2 bytearr pitch |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
535 SDL_UnlockTexture: texture |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
536 //TODO: Return value? |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
537 } else: { |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
538 ret <- false |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
539 } |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
540 ret |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
541 } |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
542 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
543 llMessage: blendMode! withVars: { |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
544 omode <- object ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
545 mode <- obj_uint32 ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
546 } andCode: :omode { |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
547 mode <- (mcall: uint32 1 omode) castTo: (obj_uint32 ptr) |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
548 SDL_SetTextureBlendMode: texture (mode num) |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
549 self |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
550 } |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
551 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
552 llMessage: blendMode withVars: { |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
553 mode <- obj_uint32 ptr |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
554 } andCode: { |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
555 mode <-make_object: (addr_of: obj_uint32_meta) NULL 0 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
556 SDL_GetTextureBlendMode: texture (addr_of: (mode num)) |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
557 mode |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
558 } |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
559 |
278
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
560 llMessage: destroy withVars: {} andCode: { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
561 SDL_DestroyTexture: texture |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
562 true |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
563 } |
279
eb83863fd33e
Store renderer pointer in texture object since the texture can only be used with the renderer it was created with
Michael Pavone <pavone@retrodev.com>
parents:
278
diff
changeset
|
564 } _ptr_init: rendptr texptr |
278
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
565 } |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
566 |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
567 _makeSurface <- :ptr { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
568 #{ |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
569 includeSystemHeader: "SDL.h" |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
570 llProperty: surface withType: (SDL_Surface ptr) |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
571 llMessage: opaque withVars: { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
572 ptr <- cpointer ptr |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
573 } andCode: { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
574 ptr <- make_object: (addr_of: cpointer_meta) NULL 0 |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
575 ptr val!: surface |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
576 ptr |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
577 } |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
578 llMessage: _ptr_init withVars: { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
579 ptr <- cpointer ptr |
318
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
580 } andCode: :ptr { |
278
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
581 surface <- ptr val |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
582 self |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
583 } |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
584 |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
585 asTexture <- :renderer { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
586 _helper createTextureFromSurface: (renderer opaque) opaque _makeTexture |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
587 } |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
588 |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
589 llMessage: free withVars: {} andCode: { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
590 SDL_FreeSurface: surface |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
591 true |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
592 } |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
593 } _ptr_init: ptr |
274
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
594 } |
277
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
595 |
274
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
596 #{ |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
597 includeSystemHeader: "SDL.h" |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
598 includeSystemHeader: "stdlib.h" |
277
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
599 |
274
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
600 llMessage: init withVars: { |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
601 flags <- obj_uint32 ptr |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
602 intret <- obj_int32 ptr |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
603 } andCode: :flags { |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
604 intret <- make_object: (addr_of: obj_int32_meta) NULL 0 |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
605 intret num!: (SDL_Init: (flags num)) |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
606 if: (intret num) { |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
607 atexit: SDL_Quit |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
608 } |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
609 intret |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
610 } |
277
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
611 |
274
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
612 llMessage: initSubSystem withVars: { |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
613 flags <- obj_uint32 ptr |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
614 intret <- obj_int32 ptr |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
615 } andCode: :flags { |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
616 intret <- make_object: (addr_of: obj_int32_meta) NULL 0 |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
617 intret num!: (SDL_InitSubSystem: (flags num)) |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
618 intret |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
619 } |
277
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
620 |
274
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
621 llMessage: quitSubSystem withVars: { |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
622 flags <- obj_uint32 ptr |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
623 } andCode: :flags { |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
624 SDL_QuitSubSystem: (flags num) |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
625 true |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
626 } |
277
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
627 |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
628 r:g:b:a <- :rc :gc :bc :ac { |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
629 #{ |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
630 r <- rc |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
631 g <- gc |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
632 b <- bc |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
633 a <- ac |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
634 } |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
635 } |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
636 |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
637 r:g:b <- :r :g :b { |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
638 r: r g: g b: b a: 255u8 |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
639 } |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
640 |
274
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
641 createWindow:pos:size:flags <- :title :x y :w h :flags{ |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
642 _helper createWindow: title x y w h flags :ptr { |
277
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
643 print: (string: ptr) . "\n" |
274
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
644 #{ |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
645 includeSystemHeader: "SDL.h" |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
646 llProperty: window withType: (SDL_Window ptr) |
277
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
647 llMessage: opaque withVars: { |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
648 op <- cpointer ptr |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
649 } andCode: { |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
650 op <- make_object: (addr_of: cpointer_meta) NULL 0 |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
651 op val!: window |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
652 op |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
653 } |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
654 |
274
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
655 llMessage: _ptr_init withVars: { |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
656 ptr <- cpointer ptr |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
657 } andCode: :ptr { |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
658 window <- ptr val |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
659 self |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
660 } |
277
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
661 |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
662 renderOpts <- { _renderOpts } |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
663 |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
664 createRenderer:flags <- :index :flags { |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
665 _helper createRenderer: (self opaque) index flags :ptr { |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
666 #{ |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
667 includeSystemHeader: "SDL.h" |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
668 llProperty: renderer withType: (SDL_Renderer ptr) |
278
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
669 llMessage: opaque withVars: { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
670 op <- cpointer ptr |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
671 } andCode: { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
672 op <- make_object: (addr_of: cpointer_meta) NULL 0 |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
673 op val!: renderer |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
674 op |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
675 } |
277
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
676 llMessage: _ptr_init withVars: { |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
677 ptr <- cpointer ptr |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
678 } andCode: :ptr { |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
679 renderer <- ptr val |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
680 self |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
681 } |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
682 |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
683 llMessage: drawColor! withVars: { |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
684 color <- object ptr |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
685 rc <- obj_uint8 ptr |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
686 gc <- obj_uint8 ptr |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
687 bc <- obj_uint8 ptr |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
688 ac <- obj_uint8 ptr |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
689 intret <- obj_int32 ptr |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
690 } andCode: :color { |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
691 intret <- make_object: (addr_of: obj_int32_meta) NULL 0 |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
692 rc <- (mcall: r 1 color) castTo: (obj_uint8 ptr) |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
693 gc <- (mcall: g 1 color) castTo: (obj_uint8 ptr) |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
694 bc <- (mcall: b 1 color) castTo: (obj_uint8 ptr) |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
695 ac <- (mcall: a 1 color) castTo: (obj_uint8 ptr) |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
696 intret num!: (SDL_SetRenderDrawColor: renderer (rc num) (gc num) (bc num) (ac num)) |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
697 intret |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
698 } |
318
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
699 |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
700 createTexture:access:width:height <- :format :access :w :h { |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
701 _helper createTexture: opaque format access w h _makeTexture |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
702 } |
277
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
703 |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
704 llMessage: clear withVars: { |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
705 intret <- obj_int32 ptr |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
706 } andCode: { |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
707 intret <- make_object: (addr_of: obj_int32_meta) NULL 0 |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
708 intret num!: (SDL_RenderClear: renderer) |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
709 intret |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
710 } |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
711 |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
712 llMessage: present withVars: {} andCode: { |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
713 SDL_RenderPresent: renderer |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
714 true |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
715 } |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
716 |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
717 llMessage: destroy withVars: {} andCode: { |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
718 SDL_DestroyRenderer: renderer |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
719 true |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
720 } |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
721 } _ptr_init: ptr |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
722 } |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
723 } |
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
724 |
274
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
725 llMessage: destroy withVars: { |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
726 } andCode: { |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
727 SDL_DestroyWindow: window |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
728 true |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
729 } |
277
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
730 } _ptr_init: ptr |
274
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
731 } |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
732 } |
277
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
733 |
278
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
734 loadBMP <- :filename { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
735 _helper loadBMP: filename _makeSurface |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
736 } |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
737 |
274
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
738 llMessage: delay withVars: { |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
739 ms <- obj_uint32 ptr |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
740 } andCode: :ms { |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
741 SDL_Delay: (ms num) |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
742 true |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
743 } |
277
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
744 |
278
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
745 llMessage: clearError withVars: {} andCode: { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
746 SDL_ClearError: |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
747 true |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
748 } |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
749 |
283
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
750 rect:size <- :x y :w h { |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
751 getter <- macro: :propName { |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
752 quote: (llMessage: propName withVars: { |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
753 intret <- obj_int32 ptr |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
754 } andCode: { |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
755 intret <- make_object: (addr_of: obj_int32_meta) NULL 0 |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
756 intret num!: ((addr_of: rect) propName) |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
757 intret |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
758 }) |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
759 } |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
760 setter <- macro: :propName { |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
761 quote: (llMessage: propName withVars: { |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
762 v <- obj_int32 ptr |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
763 } andCode: :v { |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
764 (addr_of: rect) propName: (v num) |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
765 self |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
766 }) |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
767 } |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
768 (((#{ |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
769 llProperty: rect withType: SDL_Rect |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
770 getter: x |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
771 setter: x! |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
772 getter: y |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
773 setter: y! |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
774 getter: w |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
775 setter: w! |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
776 getter: h |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
777 setter: h! |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
778 llMessage: _rectPointer withVars: { |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
779 retptr <- cpointer ptr |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
780 } andCode: { |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
781 retptr <- make_object: (addr_of: cpointer_meta) NULL 0 |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
782 retptr val!: (addr_of: (self rect)) |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
783 retptr |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
784 } |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
785 } x!: x) y!: y) w!: w) h!: h |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
786 } |
0ec4f1b68a38
Add copyTo method to texture that allows copying to a rectangular region on the renderer rather than stretching to fit the entire renderer
Michael Pavone <pavone@retrodev.com>
parents:
279
diff
changeset
|
787 |
278
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
788 llMessage: getError withVars: { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
789 str <- string ptr |
285
bb1539decd62
Fix const warning in sdl module
Michael Pavone <pavone@retrodev.com>
parents:
284
diff
changeset
|
790 rawstr <- const: (char ptr) |
278
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
791 } andCode: { |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
792 rawstr <- SDL_GetError: |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
793 str <- make_object: (addr_of: string_meta) NULL 0 |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
794 str bytes!: (strlen: rawstr) |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
795 str len!: (str bytes) |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
796 str data!: (GC_MALLOC: (str bytes) + 1) |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
797 memcpy: (str data) rawstr (str bytes) + 1 |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
798 str |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
799 } |
1205c7a43cb4
Add bindings for SDL_ClearError, SDL_GetError, SDL_LoadBMP, SDL_CreateTextureFromSurface and a partial binding for SDL_RendererCopy
Michael Pavone <pavone@retrodev.com>
parents:
277
diff
changeset
|
800 |
291
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
801 pollEvent <- { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
802 _helper pollEvent: :typ tstamp eventPtr { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
803 _eventConstructors ifget: typ :handler { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
804 handler: typ tstamp eventPtr |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
805 } else: { |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
806 //fallback event |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
807 #{ |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
808 type <- typ |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
809 timeStamp <- tstamp |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
810 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
811 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
812 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
813 } |
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
814 |
274
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
815 subsystems <- { _subsystems } |
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
816 windowOpts <- { _windowOpts } |
291
38bbbf74b735
Initial work on event support in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
287
diff
changeset
|
817 eventTypes <- { _events } |
318
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
818 textureAccess <- { _textureAccess } |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
819 pixelFormats <- { _pixelFormats } |
4c669942c30d
Add bindings for SDL_CreateTexture, SDL_LockTexture, SDL_SetBlendMode and SDL_GetBlendMode in SDL module
Michael Pavone <pavone@retrodev.com>
parents:
293
diff
changeset
|
820 blendModes <- { _blendModes } |
274
a923b5b7da3d
Initial work on an SDL2 binding
Michael Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
821 } |
277
2b58eafa360b
Add SDL bindings for creating a renderer, clearing it, presenting it and destroying it
Michael Pavone <pavone@retrodev.com>
parents:
274
diff
changeset
|
822 } |