(core_info.c) Cleanup
This commit is contained in:
parent
cd1d760a38
commit
ab8f3115da
102
core_info.c
102
core_info.c
|
@ -1321,6 +1321,7 @@ bool core_info_hw_api_supported(core_info_t *info)
|
||||||
unsigned j = 0;
|
unsigned j = 0;
|
||||||
bool found_major = false;
|
bool found_major = false;
|
||||||
bool found_minor = false;
|
bool found_minor = false;
|
||||||
|
bool found_match = false;
|
||||||
enum compare_op op = COMPARE_OP_GREATER_EQUAL;
|
enum compare_op op = COMPARE_OP_GREATER_EQUAL;
|
||||||
enum api_parse_state state = STATE_API_NAME;
|
enum api_parse_state state = STATE_API_NAME;
|
||||||
|
|
||||||
|
@ -1420,88 +1421,113 @@ bool core_info_hw_api_supported(core_info_t *info)
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
switch (sys_api)
|
||||||
if ((string_is_equal_noncase(api_str, "opengl") && sys_api == GFX_CTX_OPENGL_API) ||
|
{
|
||||||
(string_is_equal_noncase(api_str, "openglcompat") && sys_api == GFX_CTX_OPENGL_API) ||
|
case GFX_CTX_OPENGL_API:
|
||||||
(string_is_equal_noncase(api_str, "openglcompatibility") && sys_api == GFX_CTX_OPENGL_API))
|
if ( (string_is_equal_noncase(api_str, "opengl") )
|
||||||
|
|| (string_is_equal_noncase(api_str, "openglcompat"))
|
||||||
|
|| (string_is_equal_noncase(api_str, "openglcompatibility"))
|
||||||
|
)
|
||||||
{
|
{
|
||||||
/* system is running a core context while compat is requested */
|
/* system is running a core context while compat is requested */
|
||||||
if (sys_flags.flags & (1 << GFX_CTX_FLAGS_GL_CORE_CONTEXT))
|
if (sys_flags.flags & (1 << GFX_CTX_FLAGS_GL_CORE_CONTEXT))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
sscanf(sys_api_version_str, "%d.%d", &sys_api_version_major, &sys_api_version_minor);
|
sscanf(sys_api_version_str, "%d.%d",
|
||||||
|
&sys_api_version_major, &sys_api_version_minor);
|
||||||
|
|
||||||
if (core_info_compare_api_version(sys_api_version_major, sys_api_version_minor, major, minor, op))
|
found_match = true;
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
else if (string_is_equal_noncase(api_str, "openglcore") && sys_api == GFX_CTX_OPENGL_API)
|
else if (string_is_equal_noncase(api_str, "openglcore"))
|
||||||
{
|
{
|
||||||
sscanf(sys_api_version_str, "%d.%d", &sys_api_version_major, &sys_api_version_minor);
|
sscanf(sys_api_version_str, "%d.%d",
|
||||||
|
&sys_api_version_major, &sys_api_version_minor);
|
||||||
|
|
||||||
if (core_info_compare_api_version(sys_api_version_major, sys_api_version_minor, major, minor, op))
|
found_match = true;
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
else if (string_is_equal_noncase(api_str, "opengles") && sys_api == GFX_CTX_OPENGL_ES_API)
|
break;
|
||||||
|
case GFX_CTX_OPENGL_ES_API:
|
||||||
|
if (string_is_equal_noncase(api_str, "opengles"))
|
||||||
{
|
{
|
||||||
sscanf(sys_api_version_str, "OpenGL ES %d.%d", &sys_api_version_major, &sys_api_version_minor);
|
sscanf(sys_api_version_str, "OpenGL ES %d.%d",
|
||||||
|
&sys_api_version_major, &sys_api_version_minor);
|
||||||
|
|
||||||
if (core_info_compare_api_version(sys_api_version_major, sys_api_version_minor, major, minor, op))
|
found_match = true;
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
else if (string_is_equal_noncase(api_str, "direct3d8") && sys_api == GFX_CTX_DIRECT3D8_API)
|
break;
|
||||||
|
case GFX_CTX_DIRECT3D8_API:
|
||||||
|
if (string_is_equal_noncase(api_str, "direct3d8"))
|
||||||
{
|
{
|
||||||
sys_api_version_major = 8;
|
sys_api_version_major = 8;
|
||||||
sys_api_version_minor = 0;
|
sys_api_version_minor = 0;
|
||||||
|
|
||||||
if (core_info_compare_api_version(sys_api_version_major, sys_api_version_minor, major, minor, op))
|
found_match = true;
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
else if (string_is_equal_noncase(api_str, "direct3d9") && sys_api == GFX_CTX_DIRECT3D9_API)
|
break;
|
||||||
|
case GFX_CTX_DIRECT3D9_API:
|
||||||
|
if (string_is_equal_noncase(api_str, "direct3d9"))
|
||||||
{
|
{
|
||||||
sys_api_version_major = 9;
|
sys_api_version_major = 9;
|
||||||
sys_api_version_minor = 0;
|
sys_api_version_minor = 0;
|
||||||
|
|
||||||
if (core_info_compare_api_version(sys_api_version_major, sys_api_version_minor, major, minor, op))
|
found_match = true;
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
else if (string_is_equal_noncase(api_str, "direct3d10") && sys_api == GFX_CTX_DIRECT3D10_API)
|
break;
|
||||||
|
case GFX_CTX_DIRECT3D10_API:
|
||||||
|
if (string_is_equal_noncase(api_str, "direct3d10"))
|
||||||
{
|
{
|
||||||
sys_api_version_major = 10;
|
sys_api_version_major = 10;
|
||||||
sys_api_version_minor = 0;
|
sys_api_version_minor = 0;
|
||||||
|
|
||||||
if (core_info_compare_api_version(sys_api_version_major, sys_api_version_minor, major, minor, op))
|
found_match = true;
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
else if (string_is_equal_noncase(api_str, "direct3d11") && sys_api == GFX_CTX_DIRECT3D11_API)
|
case GFX_CTX_DIRECT3D11_API:
|
||||||
|
if (string_is_equal_noncase(api_str, "direct3d11"))
|
||||||
{
|
{
|
||||||
sys_api_version_major = 11;
|
sys_api_version_major = 11;
|
||||||
sys_api_version_minor = 0;
|
sys_api_version_minor = 0;
|
||||||
|
|
||||||
if (core_info_compare_api_version(sys_api_version_major, sys_api_version_minor, major, minor, op))
|
found_match = true;
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
else if (string_is_equal_noncase(api_str, "direct3d12") && sys_api == GFX_CTX_DIRECT3D12_API)
|
break;
|
||||||
|
case GFX_CTX_DIRECT3D12_API:
|
||||||
|
if (string_is_equal_noncase(api_str, "direct3d12"))
|
||||||
{
|
{
|
||||||
sys_api_version_major = 12;
|
sys_api_version_major = 12;
|
||||||
sys_api_version_minor = 0;
|
sys_api_version_minor = 0;
|
||||||
|
|
||||||
if (core_info_compare_api_version(sys_api_version_major, sys_api_version_minor, major, minor, op))
|
found_match = true;
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
else if (string_is_equal_noncase(api_str, "vulkan") && sys_api == GFX_CTX_VULKAN_API)
|
break;
|
||||||
|
case GFX_CTX_VULKAN_API:
|
||||||
|
if (string_is_equal_noncase(api_str, "vulkan"))
|
||||||
{
|
{
|
||||||
sscanf(sys_api_version_str, "%d.%d", &sys_api_version_major, &sys_api_version_minor);
|
sscanf(sys_api_version_str, "%d.%d",
|
||||||
|
&sys_api_version_major, &sys_api_version_minor);
|
||||||
|
|
||||||
if (core_info_compare_api_version(sys_api_version_major, sys_api_version_minor, major, minor, op))
|
found_match = true;
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
else if (string_is_equal_noncase(api_str, "metal") && sys_api == GFX_CTX_METAL_API)
|
break;
|
||||||
|
case GFX_CTX_METAL_API:
|
||||||
|
if (string_is_equal_noncase(api_str, "metal"))
|
||||||
{
|
{
|
||||||
sscanf(sys_api_version_str, "%d.%d", &sys_api_version_major, &sys_api_version_minor);
|
sscanf(sys_api_version_str, "%d.%d",
|
||||||
|
&sys_api_version_major, &sys_api_version_minor);
|
||||||
|
|
||||||
if (core_info_compare_api_version(sys_api_version_major, sys_api_version_minor, major, minor, op))
|
found_match = true;
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
case GFX_CTX_OPENVG_API:
|
||||||
|
/* TODO/FIXME - implement */
|
||||||
|
break;
|
||||||
|
case GFX_CTX_NONE:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (found_match)
|
||||||
|
if (core_info_compare_api_version(sys_api_version_major,
|
||||||
|
sys_api_version_minor, major, minor, op))
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
|
|
Loading…
Reference in New Issue