Document gfx_context.c

This commit is contained in:
twinaphex 2015-01-09 23:32:32 +01:00
parent 2162e9b998
commit 4d7d58930c
3 changed files with 110 additions and 31 deletions

View File

@ -63,7 +63,7 @@ static int find_resampler_driver_index(const char *ident)
/** /**
* find_prev_resampler_driver: * find_prev_resampler_driver:
* *
* Find previous driver in resampler driver array. * Finds previous driver in resampler driver array.
**/ **/
void find_prev_resampler_driver(void) void find_prev_resampler_driver(void)
{ {
@ -80,7 +80,7 @@ void find_prev_resampler_driver(void)
/** /**
* find_next_resampler_driver: * find_next_resampler_driver:
* *
* Find next driver in resampler driver array. * Finds next driver in resampler driver array.
**/ **/
void find_next_resampler_driver(void) void find_next_resampler_driver(void)
{ {

View File

@ -61,7 +61,7 @@ static const gfx_ctx_driver_t *gfx_ctx_drivers[] = {
&gfx_ctx_bbqnx, &gfx_ctx_bbqnx,
#endif #endif
#if defined(IOS) || defined(OSX) #if defined(IOS) || defined(OSX)
/* < Don't use __APPLE__ as it breaks basic SDL builds */ /* Don't use __APPLE__ as it breaks basic SDL builds. */
&gfx_ctx_apple, &gfx_ctx_apple,
#endif #endif
#if (defined(HAVE_SDL) || defined(HAVE_SDL2)) && defined(HAVE_OPENGL) #if (defined(HAVE_SDL) || defined(HAVE_SDL2)) && defined(HAVE_OPENGL)
@ -74,18 +74,33 @@ static const gfx_ctx_driver_t *gfx_ctx_drivers[] = {
NULL NULL
}; };
static int find_gfx_ctx_driver_index(const char *drv) /**
* find_gfx_ctx_driver_index:
* @ident : Identifier of resampler driver to find.
*
* Finds graphics context driver index by @ident name.
*
* Returns: graphics context driver index if driver was found, otherwise
* -1.
**/
static int find_gfx_ctx_driver_index(const char *ident)
{ {
unsigned i; unsigned i;
for (i = 0; gfx_ctx_drivers[i]; i++) for (i = 0; gfx_ctx_drivers[i]; i++)
if (strcasecmp(drv, gfx_ctx_drivers[i]->ident) == 0) if (strcasecmp(ident, gfx_ctx_drivers[i]->ident) == 0)
return i; return i;
return -1; return -1;
} }
/**
* find_prev_context_driver:
*
* Finds previous driver in graphics context driver array.
**/
void find_prev_gfx_context_driver(void) void find_prev_gfx_context_driver(void)
{ {
int i = find_gfx_ctx_driver_index(g_settings.video.context_driver); int i = find_gfx_ctx_driver_index(g_settings.video.context_driver);
if (i > 0) if (i > 0)
{ {
strlcpy(g_settings.video.context_driver, gfx_ctx_drivers[i - 1]->ident, strlcpy(g_settings.video.context_driver, gfx_ctx_drivers[i - 1]->ident,
@ -95,9 +110,15 @@ void find_prev_gfx_context_driver(void)
RARCH_WARN("Couldn't find any previous video context driver.\n"); RARCH_WARN("Couldn't find any previous video context driver.\n");
} }
/**
* find_next_context_driver:
*
* Finds next driver in graphics context driver array.
**/
void find_next_context_driver(void) void find_next_context_driver(void)
{ {
int i = find_gfx_ctx_driver_index(g_settings.video.context_driver); int i = find_gfx_ctx_driver_index(g_settings.video.context_driver);
if (i >= 0 && gfx_ctx_drivers[i + 1]) if (i >= 0 && gfx_ctx_drivers[i + 1])
{ {
strlcpy(g_settings.video.context_driver, gfx_ctx_drivers[i + 1]->ident, strlcpy(g_settings.video.context_driver, gfx_ctx_drivers[i + 1]->ident,
@ -107,9 +128,24 @@ void find_next_context_driver(void)
RARCH_WARN("Couldn't find any next video context driver.\n"); RARCH_WARN("Couldn't find any next video context driver.\n");
} }
static const gfx_ctx_driver_t *ctx_init(void *data, /**
* gfx_ctx_init:
* @data : Input data.
* @ctx : Graphics context driver to initialize.
* @ident : Identifier of graphics context driver to find.
* @api : API of higher-level graphics API.
* @major : Major version number of higher-level graphics API.
* @minor : Minor version number of higher-level graphics API.
* @hw_render_ctx : Request a graphics context driver capable of
* hardware rendering?
*
* Initialize graphics context driver.
*
* Returns: graphics context driver if successfully initialized, otherwise NULL.
**/
static const gfx_ctx_driver_t *gfx_ctx_init(void *data,
const gfx_ctx_driver_t *ctx, const gfx_ctx_driver_t *ctx,
const char *drv, const char *ident,
enum gfx_ctx_api api, unsigned major, enum gfx_ctx_api api, unsigned major,
unsigned minor, bool hw_render_ctx) unsigned minor, bool hw_render_ctx)
{ {
@ -126,15 +162,27 @@ static const gfx_ctx_driver_t *ctx_init(void *data,
return ctx; return ctx;
} }
else
{ RARCH_ERR("Failed to bind API (#%u, version %u.%u) on context driver \"%s\".\n",
RARCH_ERR("Failed to bind API (#%u, version %u.%u) on context driver \"%s\".\n", (unsigned)api, major, minor, ctx->ident);
(unsigned)api, major, minor, ctx->ident);
}
return NULL; return NULL;
} }
/**
* gfx_ctx_find_driver:
* @data : Input data.
* @ident : Identifier of graphics context driver to find.
* @api : API of higher-level graphics API.
* @major : Major version number of higher-level graphics API.
* @minor : Minor version number of higher-level graphics API.
* @hw_render_ctx : Request a graphics context driver capable of
* hardware rendering?
*
* Finds first suitable graphics context driver and initializes.
*
* Returns: graphics context driver if found, otherwise NULL.
**/
static const gfx_ctx_driver_t *gfx_ctx_find_driver(void *data, static const gfx_ctx_driver_t *gfx_ctx_find_driver(void *data,
const char *ident, const char *ident,
enum gfx_ctx_api api, unsigned major, enum gfx_ctx_api api, unsigned major,
@ -144,29 +192,37 @@ static const gfx_ctx_driver_t *gfx_ctx_find_driver(void *data,
int i = find_gfx_ctx_driver_index(ident); int i = find_gfx_ctx_driver_index(ident);
if (i >= 0) if (i >= 0)
{ return gfx_ctx_init(data, gfx_ctx_drivers[i], ident,
return ctx_init(data, gfx_ctx_drivers[i], ident,
api, major, minor, hw_render_ctx); api, major, minor, hw_render_ctx);
}
else
{
for (i = 0; gfx_ctx_drivers[i]; i++)
{
ctx = ctx_init(data, gfx_ctx_drivers[i], ident,
api, major, minor, hw_render_ctx);
if (ctx)
return ctx;
}
return NULL; for (i = 0; gfx_ctx_drivers[i]; i++)
{
ctx = gfx_ctx_init(data, gfx_ctx_drivers[i], ident,
api, major, minor, hw_render_ctx);
if (ctx)
return ctx;
} }
return NULL;
} }
/**
* gfx_ctx_init_first:
* @data : Input data.
* @ident : Identifier of graphics context driver to find.
* @api : API of higher-level graphics API.
* @major : Major version number of higher-level graphics API.
* @minor : Minor version number of higher-level graphics API.
* @hw_render_ctx : Request a graphics context driver capable of
* hardware rendering?
*
* Finds first suitable graphics context driver and initializes.
*
* Returns: graphics context driver if found, otherwise NULL.
**/
const gfx_ctx_driver_t *gfx_ctx_init_first(void *data, const gfx_ctx_driver_t *gfx_ctx_init_first(void *data,
const char *drv, const char *ident, enum gfx_ctx_api api, unsigned major,
enum gfx_ctx_api api, unsigned major,
unsigned minor, bool hw_render_ctx) unsigned minor, bool hw_render_ctx)
{ {
return gfx_ctx_find_driver(data, drv, api, major, minor, hw_render_ctx); return gfx_ctx_find_driver(data, ident, api, major, minor, hw_render_ctx);
} }

View File

@ -147,12 +147,35 @@ extern const gfx_ctx_driver_t gfx_ctx_apple;
extern const gfx_ctx_driver_t gfx_ctx_emscripten; extern const gfx_ctx_driver_t gfx_ctx_emscripten;
extern const gfx_ctx_driver_t gfx_ctx_null; extern const gfx_ctx_driver_t gfx_ctx_null;
/* Finds first suitable driver and initializes. */ /**
const gfx_ctx_driver_t *gfx_ctx_init_first(void *data, const char *driver, * gfx_ctx_init_first:
* @data : Input data.
* @ident : Identifier of graphics context driver to find.
* @api : API of higher-level graphics API.
* @major : Major version number of higher-level graphics API.
* @minor : Minor version number of higher-level graphics API.
* @hw_render_ctx : Request a graphics context driver capable of
* hardware rendering?
*
* Finds first suitable graphics context driver and initializes.
*
* Returns: graphics context driver if found, otherwise NULL.
**/
const gfx_ctx_driver_t *gfx_ctx_init_first(void *data, const char *ident,
enum gfx_ctx_api api, unsigned major, unsigned minor, bool hw_render_ctx); enum gfx_ctx_api api, unsigned major, unsigned minor, bool hw_render_ctx);
/**
* find_next_context_driver:
*
* Finds next driver in graphics context driver array.
**/
void find_next_context_driver(void); void find_next_context_driver(void);
/**
* find_prev_context_driver:
*
* Finds previous driver in graphics context driver array.
**/
void find_prev_gfx_context_driver(void); void find_prev_gfx_context_driver(void);
#ifdef __cplusplus #ifdef __cplusplus