Add some options for configuration

This commit is contained in:
Shylie 2024-05-23 21:33:15 -04:00
parent 17ea6a7f0a
commit b2164b76cf
5 changed files with 45 additions and 13 deletions

View File

@ -5,9 +5,18 @@ project(glerminal
LANGUAGES C CXX LANGUAGES C CXX
) )
option(GLERMINAL_OPENGL_DEBUG_CONTEXT "" OFF)
set(GLERMINAL_GRID_WIDTH 40 CACHE STRING "")
set(GLERMINAL_GRID_HEIGHT 25 CACHE STRING "")
set(GLERMINAL_LAYER_COUNT 64 CACHE STRING "")
set(GLERMINAL_CELL_SCALE 4 CACHE STRING "")
configure_file(source/glerminal-config.h.in glerminal-config.h @ONLY)
add_subdirectory(glfw) add_subdirectory(glfw)
add_library(glerminal STATIC add_library(glerminal STATIC
${CMAKE_CURRENT_BINARY_DIR}/glerminal-config.h
include/glerminal.h include/glerminal.h
source/glerminal-private.h source/glerminal-private.h
@ -26,6 +35,7 @@ set_target_properties(glerminal
target_include_directories(glerminal target_include_directories(glerminal
PUBLIC PUBLIC
include include
${CMAKE_CURRENT_BINARY_DIR}
PRIVATE PRIVATE
source source
) )

View File

@ -1,18 +1,13 @@
#ifndef GLERMINAL_H #ifndef GLERMINAL_H
#define GLERMINAL_H #define GLERMINAL_H
#include <glerminal-config.h>
#ifdef __cplusplus #ifdef __cplusplus
extern "C" extern "C"
{ {
#endif #endif
enum
{
GRID_WIDTH = 40,
GRID_HEIGHT = 25,
LAYER_COUNT = 64
};
typedef void (*glerminal_init_cb)(); typedef void (*glerminal_init_cb)();
typedef void (*glerminal_main_cb)(float dt); typedef void (*glerminal_main_cb)(float dt);

View File

@ -0,0 +1,26 @@
#ifndef GLERMINAL_CONFIG_H
#define GLERMINAL_CONFIG_H
// THIS FILE IS CONFIGURED BY CMAKE
// MODIFY glerminal-config.h.in INSTEAD!
#ifdef __cplusplus
extern "C"
{
#endif
#cmakedefine GLERMINAL_OPENGL_DEBUG_CONTEXT
enum
{
GRID_WIDTH = @GLERMINAL_GRID_WIDTH@,
GRID_HEIGHT = @GLERMINAL_GRID_HEIGHT@,
LAYER_COUNT = @GLERMINAL_LAYER_COUNT@,
CELL_SCALE = @GLERMINAL_CELL_SCALE@
};
#ifdef __cplusplus
}
#endif
#endif//GLERMINAL_CONFIG_H

View File

@ -12,13 +12,14 @@
namespace glerminal namespace glerminal
{ {
constexpr unsigned int SCREEN_WIDTH = 1280;
constexpr unsigned int SCREEN_HEIGHT = 800;
constexpr unsigned int CELL_SIZE = 8; constexpr unsigned int CELL_SIZE = 8;
constexpr unsigned int LAYER_COUNT = ::LAYER_COUNT;
constexpr unsigned int GRID_WIDTH = ::GRID_WIDTH; constexpr unsigned int GRID_WIDTH = ::GRID_WIDTH;
constexpr unsigned int GRID_HEIGHT = ::GRID_HEIGHT; constexpr unsigned int GRID_HEIGHT = ::GRID_HEIGHT;
constexpr unsigned int LAYER_COUNT = ::LAYER_COUNT;
constexpr unsigned int CELL_SCALE = ::CELL_SCALE;
constexpr unsigned int GRID_AREA = GRID_WIDTH * GRID_HEIGHT; constexpr unsigned int GRID_AREA = GRID_WIDTH * GRID_HEIGHT;
constexpr unsigned int SCREEN_WIDTH = GRID_WIDTH * CELL_SIZE * CELL_SCALE;
constexpr unsigned int SCREEN_HEIGHT = GRID_HEIGHT * CELL_SIZE * CELL_SCALE;
class glerminal class glerminal
{ {

View File

@ -295,7 +295,7 @@ namespace glerminal
// need to think about how to handle resizing to ensure // need to think about how to handle resizing to ensure
// that the window stays an integer number of "tiles" large // that the window stays an integer number of "tiles" large
glfwWindowHint(GLFW_RESIZABLE, GLFW_FALSE); glfwWindowHint(GLFW_RESIZABLE, GLFW_FALSE);
#ifdef _DEBUG #ifdef GLERMINAL_OPENGL_DEBUG_CONTEXT
glfwWindowHint(GLFW_CONTEXT_DEBUG, GLFW_TRUE); glfwWindowHint(GLFW_CONTEXT_DEBUG, GLFW_TRUE);
#endif #endif
@ -308,7 +308,7 @@ namespace glerminal
} }
} }
#ifdef _DEBUG #ifdef GLERMINAL_OPENGL_DEBUG_CONTEXT
void glerminal::log(GLenum type, GLuint id, GLenum severity, const char* message) const void glerminal::log(GLenum type, GLuint id, GLenum severity, const char* message) const
{ {
glDebugMessageInsert(GL_DEBUG_SOURCE_THIRD_PARTY, type, id, severity, -1, message); glDebugMessageInsert(GL_DEBUG_SOURCE_THIRD_PARTY, type, id, severity, -1, message);
@ -325,7 +325,7 @@ namespace glerminal
throw std::runtime_error("Failed to initialize GLAD."); throw std::runtime_error("Failed to initialize GLAD.");
} }
#ifdef _DEBUG #ifdef GLERMINAL_OPENGL_DEBUG_CONTEXT
glEnable(GL_DEBUG_OUTPUT); glEnable(GL_DEBUG_OUTPUT);
glEnable(GL_DEBUG_OUTPUT_SYNCHRONOUS); glEnable(GL_DEBUG_OUTPUT_SYNCHRONOUS);
glDebugMessageCallback([](GLenum source, GLenum type, GLuint id, GLenum severity, GLsizei length, const GLchar* message, const void* userParam) glDebugMessageCallback([](GLenum source, GLenum type, GLuint id, GLenum severity, GLsizei length, const GLchar* message, const void* userParam)