sdl initializing and deinitializing with temp code

This commit is contained in:
herbglitch 2022-10-29 16:08:41 -06:00
parent df8c7f7ff1
commit c0780b7188
9 changed files with 102 additions and 41 deletions

View file

@ -1,13 +1,16 @@
#ifndef ARC_ENGINE_H_ #ifndef ARC_ENGINE_H_
#define ARC_ENGINE_H_ #define ARC_ENGINE_H_
#ifdef __cplusplus
extern "C" {
#endif
#include "arc/graphics/window.h" #include "arc/graphics/window.h"
#include "arc/graphics/renderer.h" #include "arc/graphics/renderer.h"
typedef struct ARC_EngineData { typedef struct ARC_EngineData {
ARC_Window *window; ARC_Window *window;
ARC_Renderer *renderer; ARC_Renderer *renderer;
} ARC_EngineData; } ARC_EngineData;
//NOTE: most work below is temp, and will change once I figure out a better way to write this header //NOTE: most work below is temp, and will change once I figure out a better way to write this header
@ -24,4 +27,8 @@ void ARC_EngineData_Destroy(ARC_EngineData *data);
*/ */
void ARC_Engine_Run(ARC_EngineData *data); void ARC_Engine_Run(ARC_EngineData *data);
#ifdef __cplusplus
}
#endif
#endif // !ARC_ENGINE_H_ #endif // !ARC_ENGINE_H_

View file

@ -1,6 +1,10 @@
#ifndef ARC_GRAPHICS_RENDERER_H_ #ifndef ARC_GRAPHICS_RENDERER_H_
#define ARC_GRAPHICS_RENDERER_H_ #define ARC_GRAPHICS_RENDERER_H_
#ifdef __cplusplus
extern "C" {
#endif
typedef struct ARC_Renderer ARC_Renderer; typedef struct ARC_Renderer ARC_Renderer;
typedef struct ARC_RenderInfo ARC_RenderInfo; typedef struct ARC_RenderInfo ARC_RenderInfo;
@ -11,14 +15,24 @@ typedef struct ARC_RenderInfo ARC_RenderInfo;
* @note the parameter data is determined by which graphics library you are using * @note the parameter data is determined by which graphics library you are using
* please refer to the graphics library section to see what needs to be passed * please refer to the graphics library section to see what needs to be passed
* *
* @param renderer ARC_Window to initialize * @param renderer ARC_Renderer to initialize
* @param data Data to create ARC_Window * @param info Info on how to create ARC_Window
*/ */
void ARC_Renderer_Create(ARC_Renderer **renderer, void *data); void ARC_Renderer_Create(ARC_Renderer **renderer, ARC_RenderInfo *data);
/** /**
* @brief destroys ARC_Renderer type * @brief destroys ARC_Renderer type
*
* @param renderer ARC_Renderer to destory
*/ */
void ARC_Renderer_Destroy(ARC_Renderer *renderer); void ARC_Renderer_Destroy(ARC_Renderer *renderer);
void ARC_Renderer_Clear(ARC_Renderer *renderer);
void ARD_Renderer_Render(ARC_Renderer *renderer);
#ifdef __cplusplus
}
#endif
#endif // !ARC_GRAPHICS_RENDERER_H_ #endif // !ARC_GRAPHICS_RENDERER_H_

View file

@ -3,7 +3,18 @@
#ifdef ARC_SDL #ifdef ARC_SDL
#ifdef __cplusplus
extern "C" {
#endif
#include <SDL.h> #include <SDL.h>
#include "arc/graphics/renderer.h"
#include "arc/graphics/window.h"
// Temp till I figure out a better solution
struct ARC_Renderer {
SDL_Renderer *renderer;
};
/** /**
* @brief struct for info needed to create SDL_Renderer * @brief struct for info needed to create SDL_Renderer
@ -12,10 +23,14 @@
*/ */
struct ARC_RenderInfo { struct ARC_RenderInfo {
ARC_Window *window; SDL_Window *window;
int index; int index;
Uint32 flags; Uint32 flags;
} ARC_RenderInfo; };
#ifdef __cplusplus
}
#endif
#endif // ARC_SDL #endif // ARC_SDL

View file

@ -1,16 +1,25 @@
#ifndef ARC_SDL_RENDERER_H_ #ifndef ARC_SDL_WINDOW_H_
#define ARC_SDL_RENDERER_H_ #define ARC_SDL_WINDOW_H_
#ifdef ARC_SDL #ifdef ARC_SDL
#ifdef __cplusplus
extern "C" {
#endif
#include <SDL.h> #include <SDL.h>
#include "arc/graphics/window.h"
// Temp till I figure out a better solution
struct ARC_Window {
SDL_Window *window;
};
/** /**
* @brief struct for info needed to create SDL_Window * @brief struct for info needed to create SDL_Window
* *
* @note this is what needs to be passed into the data parameter for ARC_Window_Create * @note this is what needs to be passed into the data parameter for ARC_Window_Create
*/ */
struct ARC_WindowInfo { struct ARC_WindowInfo {
char *title; char *title;
int x; int x;
@ -18,8 +27,12 @@ struct ARC_WindowInfo {
int w; int w;
int h; int h;
Uint32 flags; Uint32 flags;
} ARC_WindowInfo; };
#ifdef __cplusplus
}
#endif
#endif // ARC_SDL #endif // ARC_SDL
#endif // ARC_SDL_RENDERER_H_ #endif // ARC_SDL_WINDOW_H_

View file

@ -12,9 +12,9 @@ typedef struct ARC_WindowInfo ARC_WindowInfo;
* please refer to the graphics library section to see what needs to be passed * please refer to the graphics library section to see what needs to be passed
* *
* @param window ARC_Window to initialize * @param window ARC_Window to initialize
* @param data Data to create ARC_Window * @param info Info on how to create ARC_Window
*/ */
void ARC_Window_Create(ARC_Window **window, void *data); void ARC_Window_Create(ARC_Window **window, ARC_WindowInfo *info);
/** /**
* @brief destroys ARC_Window type * @brief destroys ARC_Window type

View file

@ -27,7 +27,7 @@ extern "C" {
#ifdef ARC_DEBUG #ifdef ARC_DEBUG
# include <stdio.h> # include <stdio.h>
# define ARC_DEBUG_LOG(ERR, STR, ...) printf("[ERROR %d] " STR "\n", ERR, __VA_ARGS__) # define ARC_DEBUG_LOG(ERR, STR, ...) printf("[ERROR %d] " STR "\n", ERR, __VA_ARGS__)
# define ARC_DEBUG_ERR(STR) printf("[ERROR %d]" STR "\n", ERR) # define ARC_DEBUG_ERR(STR) printf("[ERROR %d]" STR "\n", arc_errno)
#else #else
# define ARC_DEBUG_LOG(ERR, STR, ...) # define ARC_DEBUG_LOG(ERR, STR, ...)
# define ARC_DEBUG_ERR(STR) # define ARC_DEBUG_ERR(STR)

View file

@ -1,11 +1,15 @@
#include "arc/engine/engine.h" #include "arc/engine/engine.h"
#include <SDL_video.h>
#include <stdlib.h> #include <stdlib.h>
#include "arc/graphics/window.h"
#include "arc/graphics/renderer.h"
//NOTE: this is very temp, mostly to get smthn running so I can test out different ideas //NOTE: this is very temp, mostly to get smthn running so I can test out different ideas
#ifdef ARC_SDL #ifdef ARC_SDL
#include <SDL.h> #include <SDL.h>
#include "arc/graphics/sdl/rerderer.h" #include "arc/graphics/sdl/window.h"
#endif #include "arc/graphics/sdl/renderer.h"
#endif // ARC_SDL
void ARC_EngineData_Create(ARC_EngineData **data){ void ARC_EngineData_Create(ARC_EngineData **data){
*data = (ARC_EngineData *)malloc(sizeof(ARC_EngineData)); *data = (ARC_EngineData *)malloc(sizeof(ARC_EngineData));
@ -17,25 +21,29 @@ void ARC_EngineData_Create(ARC_EngineData **data){
#ifdef ARC_SDL #ifdef ARC_SDL
if(SDL_Init(SDL_INIT_VIDEO) < 0){ if(SDL_Init(SDL_INIT_VIDEO) < 0){
printf("Error: initializing SDL\nSDL Error: ", SDL_GetError()); printf("Error: initializing SDL\nSDL Error: %s\n", SDL_GetError());
free(*data); free(*data);
return; return;
} }
windowInfo = { "title", SDL_WINDOWPOS_CENTERED, SDL_WINDOWPOS_CENTERED, 1920, 1080, 0 }; windowInfo = (ARC_WindowInfo){ "title", SDL_WINDOWPOS_UNDEFINED, SDL_WINDOWPOS_UNDEFINED, 1920, 1080, 0 };
renderInfo = { (*data)->window, -1, SDL_RENDERER_ACCELERATED }
#endif // ARC_SDL #endif // ARC_SDL
ARC_Window_Create(&((*data)->window), &windowInfo); ARC_Window_Create(&((*data)->window), &windowInfo);
//TODO: handle arc_errno errors here //TODO: handle arc_errno errors here
#ifdef ARC_SDL
renderInfo = (ARC_RenderInfo){ (SDL_Window *)(*data)->window->window, -1, SDL_RENDERER_ACCELERATED };
#endif // ARC_SDL
ARC_Renderer_Create(&((*data)->renderer), &renderInfo); ARC_Renderer_Create(&((*data)->renderer), &renderInfo);
//TODO: handle arc_errno errors here //TODO: handle arc_errno errors here
} }
void ARC_EngineData_Destroy(ARC_EngineData *data){ void ARC_EngineData_Destroy(ARC_EngineData *data){
#ifdef ARC_SDL #ifdef ARC_SDL
ARC_Window_Destroy( data->window );
ARC_Renderer_Destroy(data->renderer); ARC_Renderer_Destroy(data->renderer);
ARC_Renderer_Destroy(data->window);
#endif // ARC_SDL #endif // ARC_SDL
} }

View file

@ -1,20 +1,21 @@
#ifdef ARC_SDL #ifdef ARC_SDL
#include "arc/graphics/renderer.h" #include "arc/graphics/renderer.h"
#include "arc/graphics/sdl/renderer.h"
#include <SDL.h>
#include <stdlib.h>
#include "arc/graphics/window.h" #include "arc/graphics/window.h"
#include "arc/std/errno.h" #include "arc/std/errno.h"
typedef SDL_Renderer ARC_Renderer; void ARC_Renderer_Create(ARC_Renderer **renderer, ARC_RenderInfo *info){
if(!info){
ARC_Renderer_Create(ARC_Renderer **renderer, void *data){
if(!data){
arc_errno = ARC_ERRNO_NULL; arc_errno = ARC_ERRNO_NULL;
ARC_DEBUG_ERR(arc_errno, "ARC_Renderer_Create(**renderer, NULL)"); ARC_DEBUG_ERR("ARC_Renderer_Create(**renderer, NULL)");
return; return;
} }
ARC_RenderInfo *info = (ARC_RenderInfo *)data; *renderer = (ARC_Renderer *)malloc(sizeof(ARC_Renderer));
(*renderer)->renderer = SDL_CreateRenderer((SDL_Window *)info->window, info->index, info->flags);
*renderer = SDL_CreateRenderer(info->window, info->index, info->flags);
if(!renderer){ if(!renderer){
arc_errno = ARC_ERRNO_NULL; arc_errno = ARC_ERRNO_NULL;
@ -23,7 +24,8 @@ ARC_Renderer_Create(ARC_Renderer **renderer, void *data){
} }
void ARC_Renderer_Destroy(ARC_Renderer *renderer){ void ARC_Renderer_Destroy(ARC_Renderer *renderer){
SDL_DestroyRenderer((SDL_Renderer *) renderer); SDL_DestroyRenderer((SDL_Renderer *) renderer->renderer);
free(renderer);
} }
#endif //ARC_SDL #endif //ARC_SDL

View file

@ -1,28 +1,30 @@
#ifdef ARC_SDL #ifdef ARC_SDL
#include "arc/graphics/window.h" #include "arc/graphics/window.h"
#include "arc/graphics/sdl/window.h"
#include <SDL.h>
#include "arc/std/errno.h" #include "arc/std/errno.h"
typedef SDL_Window ARC_Window; void ARC_Window_Create(ARC_Window **window, ARC_WindowInfo *info){
if(!info){
void ARC_Window_Create(ARC_Window **window, void *data){
if(!data){
arc_errno = ARC_ERRNO_NULL; arc_errno = ARC_ERRNO_NULL;
ARC_DEBUG_ERR(arc_errno, "ARC_Window_Create(**window, NULL)"); ARC_DEBUG_ERR("ARC_Window_Create(**window, NULL)");
return; return;
} }
ARC_WindowInfo *info = (ARC_WindowInfo *)data; // (*window)->window = SDL_CreateWindow((const char *)info->title, info->x, info->y, info->w, info->h, info->flags);
*window = (ARC_Window *)malloc(sizeof(ARC_Window));
(*window)->window = SDL_CreateWindow((const char *)info->title, info->x, info->y, info->w, info->h, info->flags);
*window = SDL_CreateWindow((const char *)info->title, info->x, info->y, info->w, info->h, info->flags); if(!(*window)->window){
if(!window){
arc_errno = ARC_ERRNO_NULL; arc_errno = ARC_ERRNO_NULL;
ARC_DEBUG_LOG(arc_errno, "SDL_CreateWindow(%s, %d, %d, %d, %d, %x);", info->title, info->x, info->y, info->w, info->h, info->flags); ARC_DEBUG_LOG(arc_errno, "SDL_CreateWindow(%s, %d, %d, %d, %d, %x);", info->title, info->x, info->y, info->w, info->h, info->flags);
} }
} }
void ARC_Window_Destroy(ARC_Window *window){ void ARC_Window_Destroy(ARC_Window *window){
SDL_DestroyWindow((SDL_Window *) window); SDL_DestroyWindow((SDL_Window *) window->window);
free(window);
} }
#endif //ARC_SDL #endif //ARC_SDL