diff options
Diffstat (limited to 'src/gfx.c')
-rw-r--r-- | src/gfx.c | 24 |
1 files changed, 17 insertions, 7 deletions
@@ -2,20 +2,20 @@ | |||
2 | 2 | ||
3 | #include "asset/asset_cache.h" | 3 | #include "asset/asset_cache.h" |
4 | #include "core/core_impl.h" | 4 | #include "core/core_impl.h" |
5 | #include "llr/llr_impl.h" | ||
5 | #include "renderer/imm_renderer_impl.h" | 6 | #include "renderer/imm_renderer_impl.h" |
6 | #include "renderer/renderer_impl.h" | 7 | #include "renderer/renderer_impl.h" |
7 | #include "scene/scene_memory.h" | 8 | #include "scene/scene_memory.h" |
8 | 9 | ||
9 | #include <log/log.h> | ||
10 | |||
11 | #include <assert.h> | 10 | #include <assert.h> |
12 | #include <stdlib.h> | 11 | #include <stdlib.h> |
13 | 12 | ||
14 | typedef struct Gfx { | 13 | typedef struct Gfx { |
15 | AssetCache asset_cache; | 14 | AssetCache asset_cache; |
16 | GfxCore gfxcore; | 15 | GfxCore gfxcore; |
17 | Renderer renderer; | 16 | LLR llr; |
18 | ImmRenderer imm_renderer; | 17 | ImmRenderer imm_renderer; |
18 | Renderer renderer; | ||
19 | } Gfx; | 19 | } Gfx; |
20 | 20 | ||
21 | Gfx* gfx_init(void) { | 21 | Gfx* gfx_init(void) { |
@@ -24,16 +24,20 @@ Gfx* gfx_init(void) { | |||
24 | return 0; | 24 | return 0; |
25 | } | 25 | } |
26 | gfx_init_gfxcore(&gfx->gfxcore); | 26 | gfx_init_gfxcore(&gfx->gfxcore); |
27 | if (!renderer_make(&gfx->renderer, &gfx->gfxcore)) { | 27 | if (!gfx_llr_make(&gfx->llr, &gfx->gfxcore)) { |
28 | gfx_destroy(&gfx); | 28 | gfx_destroy(&gfx); |
29 | return 0; | 29 | return 0; |
30 | } | 30 | } |
31 | if (!imm_renderer_make(&gfx->imm_renderer, &gfx->gfxcore)) { | 31 | if (!gfx_imm_make(&gfx->imm_renderer, &gfx->gfxcore, &gfx->llr)) { |
32 | // TODO: Add error logs to the initialization failure cases here and inside | 32 | // TODO: Add error logs to the initialization failure cases here and inside |
33 | // the renderers. | 33 | // the renderers. |
34 | gfx_destroy(&gfx); | 34 | gfx_destroy(&gfx); |
35 | return 0; | 35 | return 0; |
36 | } | 36 | } |
37 | if (!gfx_renderer_make(&gfx->renderer, &gfx->llr, &gfx->gfxcore)) { | ||
38 | gfx_destroy(&gfx); | ||
39 | return 0; | ||
40 | } | ||
37 | gfx_init_asset_cache(&gfx->asset_cache); | 41 | gfx_init_asset_cache(&gfx->asset_cache); |
38 | scene_mem_init(); | 42 | scene_mem_init(); |
39 | return gfx; | 43 | return gfx; |
@@ -45,8 +49,9 @@ void gfx_destroy(Gfx** gfx) { | |||
45 | } | 49 | } |
46 | scene_mem_destroy(); | 50 | scene_mem_destroy(); |
47 | gfx_destroy_asset_cache(&(*gfx)->asset_cache); | 51 | gfx_destroy_asset_cache(&(*gfx)->asset_cache); |
48 | renderer_destroy(&(*gfx)->renderer); | 52 | gfx_renderer_destroy(&(*gfx)->renderer); |
49 | imm_renderer_destroy(&(*gfx)->imm_renderer); | 53 | gfx_imm_destroy(&(*gfx)->imm_renderer); |
54 | gfx_llr_destroy(&(*gfx)->llr); | ||
50 | gfx_del_gfxcore(&(*gfx)->gfxcore); | 55 | gfx_del_gfxcore(&(*gfx)->gfxcore); |
51 | free(*gfx); | 56 | free(*gfx); |
52 | *gfx = 0; | 57 | *gfx = 0; |
@@ -67,6 +72,11 @@ ImmRenderer* gfx_get_imm_renderer(Gfx* gfx) { | |||
67 | return &gfx->imm_renderer; | 72 | return &gfx->imm_renderer; |
68 | } | 73 | } |
69 | 74 | ||
75 | LLR* gfx_get_llr(Gfx* gfx) { | ||
76 | assert(gfx); | ||
77 | return &gfx->llr; | ||
78 | } | ||
79 | |||
70 | AssetCache* gfx_get_asset_cache(Gfx* gfx) { | 80 | AssetCache* gfx_get_asset_cache(Gfx* gfx) { |
71 | assert(gfx); | 81 | assert(gfx); |
72 | return &gfx->asset_cache; | 82 | return &gfx->asset_cache; |