fix: make breakout.cpp clang compliant

This commit is contained in:
Krzysztof Rudnicki 2023-07-06 19:43:08 +02:00
parent a88c7a2cab
commit d857bf7016
7 changed files with 114 additions and 62 deletions

View File

@ -1,5 +1,5 @@
--- ---
Checks: '*,-llvmlibc-implementation-in-namespace' Checks: '*,-altera-unroll-loops, -cppcoreguidelines-pro-type-reinterpret-cast,-llvmlibc-implementation-in-namespace,-llvmlibc-callee-namespace, -llvmlibc-restrict-system-libc-headers, -modernize-use-trailing-return-type'
WarningsAsErrors: '' WarningsAsErrors: ''
HeaderFilterRegex: '' HeaderFilterRegex: ''
AnalyzeTemporaryDtors: false AnalyzeTemporaryDtors: false

BIN
breakout/breakout Executable file → Normal file

Binary file not shown.

View File

@ -1,9 +1,11 @@
// Copyright [2023] Krzysztof Rudnicki // Copyright [2023] Krzysztof Rudnicki
#ifndef HOME_KUCHY_ENGINEER_THESIS_WUT_BREAKOUT_BREAKOUT_CPP #ifndef HOME_KUCHY_ENGINEER_THESIS_WUT_BREAKOUT_BREAKOUT_CPP
#define HOME_KUCHY_ENGINEER_THESIS_WUT_BREAKOUT_BREAKOUT_CPP #define HOME_KUCHY_ENGINEER_THESIS_WUT_BREAKOUT_BREAKOUT_CPP
#include <GLFW/glfw3.h> #include <GLFW/glfw3.h>
#include <array>
#include <iostream>
#include "../dependencies/include/glad/glad.h" #include "../dependencies/include/glad/glad.h"
#include "./game.hpp" #include "./game.hpp"
#include "./resourceManager.hpp" #include "./resourceManager.hpp"
@ -23,7 +25,7 @@ Game &getBreakoutInstance() {
return Breakout; return Breakout;
} }
int main(int /*argc*/, char * /*argv*/[]) { void initGLFW() {
glfwInit(); glfwInit();
glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 3); glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 3);
glfwWindowHint(GLFW_CONTEXT_VERSION_MINOR, 3); glfwWindowHint(GLFW_CONTEXT_VERSION_MINOR, 3);
@ -32,79 +34,130 @@ int main(int /*argc*/, char * /*argv*/[]) {
glfwWindowHint(GLFW_OPENGL_FORWARD_COMPAT, GL_TRUE); glfwWindowHint(GLFW_OPENGL_FORWARD_COMPAT, GL_TRUE);
#endif #endif
glfwWindowHint(GLFW_RESIZABLE, 0); glfwWindowHint(GLFW_RESIZABLE, 0);
}
GLFWwindow *window = glfwCreateWindow(SCREEN_WIDTH, SCREEN_HEIGHT, "Breakout", int failedGLAD() {
nullptr, nullptr); // we are forced to use reinterpret_cast since there is no standard-compliant
glfwMakeContextCurrent(window); // way to convert a void* (which is what glfwGetProcAddress returns) to a
// function pointer in C++
// glad: load all OpenGL function pointers
// ---------------------------------------
if (gladLoadGLLoader(reinterpret_cast<GLADloadproc>(glfwGetProcAddress)) == if (gladLoadGLLoader(reinterpret_cast<GLADloadproc>(glfwGetProcAddress)) ==
0) { 0) {
std::cout << "Failed to initialize GLAD" << std::endl; std::cout << "Failed to initialize GLAD" << std::endl;
return -1; return -1;
} }
return 0;
}
glfwSetKeyCallback(window, bugprone-easily-swappable-parameters std::pair<double, double> calculate_delta_time(double deltaTime,
double lastFrame) {
// calculate delta time
// -------------------- // --------------------
glViewport(0, 0, SCREEN_WIDTH, SCREEN_HEIGHT); double const currentFrame = glfwGetTime();
glEnable(GL_BLEND); deltaTime = currentFrame - lastFrame;
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); lastFrame = currentFrame;
glfwPollEvents();
return std::make_pair(deltaTime, lastFrame);
}
// initialize game void main_loop_render(Game Breakout) {
// --------------- // render
Breakout.Init(); glClearColor(0.0F, 0.0F, 0.0F, 1.0F);
glClear(GL_COLOR_BUFFER_BIT);
Breakout.Render();
}
void main_loop_inside(GLFWwindow *window, double deltaTime, double lastFrame,
Game Breakout) {
const std::pair<double, double> times =
calculate_delta_time(deltaTime, lastFrame);
deltaTime = times.first;
lastFrame = times.second;
// manage user input
Breakout.ProcessInput(deltaTime);
// update game state
Breakout.Update(deltaTime);
main_loop_render(Breakout);
glfwSwapBuffers(window);
}
void main_loop(GLFWwindow *window, const Game &Breakout) {
// deltaTime variables // deltaTime variables
// ------------------- const double deltaTime = 0.0F;
float deltaTime = 0.0F; const double lastFrame = 0.0F;
float lastFrame = 0.0F; // We do not comply with altera-unroll-loops
// since each loop iteration is dependent on the previous one.
while (glfwWindowShouldClose(window) == 0) { while (glfwWindowShouldClose(window) == 0) {
// calculate delta time main_loop_inside(window, deltaTime, lastFrame, Breakout);
// --------------------
float const currentFrame = glfwGetTime();
deltaTime = currentFrame - lastFrame;
lastFrame = currentFrame;
glfwPollEvents();
// manage user input
// -----------------
Breakout.ProcessInput(deltaTime);
// update game state
// -----------------
Breakout.Update(deltaTime);
// render
// ------
glClearColor(0.0F, 0.0F, 0.0F, 1.0F);
glClear(GL_COLOR_BUFFER_BIT);
Breakout.Render();
glfwSwapBuffers(window);
} }
}
int delete_resources() {
// delete all resources as loaded using the resource manager // delete all resources as loaded using the resource manager
// ---------------------------------------------------------
ResourceManager::Clear(); ResourceManager::Clear();
glfwTerminate(); glfwTerminate();
return 0; return 0;
} }
void key_callback(GLFWwindow *window, int key, int /*scancode*/, int action, void gl_magic(GLFWwindow *window) {
int /*mode*/) { glfwSetKeyCallback(window, key_callback);
glViewport(0, 0, SCREEN_WIDTH, SCREEN_HEIGHT);
glEnable(GL_BLEND);
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
}
int main(int /*argc*/, char * /*argv*/[]) {
initGLFW();
GLFWwindow *window = glfwCreateWindow(SCREEN_WIDTH, SCREEN_HEIGHT, "Breakout",
nullptr, nullptr);
glfwMakeContextCurrent(window);
if (failedGLAD() != 0) {
return -1;
}
gl_magic(window);
Game Breakout = getBreakoutInstance();
// initialize game
Breakout.Init();
main_loop(window, Breakout);
return delete_resources();
}
void exit_window(GLFWwindow *window, const int key, const int action) {
// when a user presses the escape key, we set the // when a user presses the escape key, we set the
// WindowShouldClose property to true, closing the application // WindowShouldClose property to true, closing the application
if (key == GLFW_KEY_ESCAPE && action == GLFW_PRESS) { if (key == GLFW_KEY_ESCAPE && action == GLFW_PRESS) {
glfwSetWindowShouldClose(window, 1); glfwSetWindowShouldClose(window, 1);
} }
if (key >= 0 && key < 1024) { }
if (action == GLFW_PRESS) {
Breakout.Keys[key] = true; void key_callback_happy(const std::pair<int, int> action_key) {
} else if (action == GLFW_RELEASE) { Game Breakout = getBreakoutInstance();
Breakout.Keys[key] = false; if (action_key.first == GLFW_PRESS) {
Breakout.Keys.at(action_key.second) = true;
} else if (action_key.first == GLFW_RELEASE) {
Breakout.Keys.at(action_key.second) = false;
}
}
void key_callback_sad(int key) {
std::cerr << "key_callback_sad Error! key is out of range!" << key
<< std::endl;
}
// Assume Breakout.Keys is of type KeyArray
void key_callback(GLFWwindow *window, int key, int /*scancode*/, int action,
int /*mode*/) {
// Define the array type for keys
const int MAX_KEYS_TRACKED = 1024;
using KeyArray = std::array<bool, MAX_KEYS_TRACKED>;
exit_window(window, key, action);
if (key >= 0 && key < MAX_KEYS_TRACKED) {
try {
key_callback_happy(std::pair<int, int>(action, key));
} catch (const std::out_of_range &e) {
key_callback_sad(key);
} }
} }
} }

View File

@ -6,13 +6,11 @@
Game::Game(unsigned int width, unsigned int height) Game::Game(unsigned int width, unsigned int height)
: State(GAME_ACTIVE), Keys(), Width(width), Height(height) {} : State(GAME_ACTIVE), Keys(), Width(width), Height(height) {}
Game::~Game() = default;
void Game::Init() {} void Game::Init() {}
void Game::Update(float dt) {} void Game::Update(double dt) {}
void Game::ProcessInput(float dt) {} void Game::ProcessInput(double dt) {}
void Game::Render() {} void Game::Render() {}

View File

@ -1,6 +1,7 @@
// Copyright [2023] Krzysztof Rudnicki // Copyright [2023] Krzysztof Rudnicki
#ifndef HOME_KUCHY_ENGINEER_THESIS_WUT_BREAKOUT_GAME_HPP #ifndef HOME_KUCHY_ENGINEER_THESIS_WUT_BREAKOUT_GAME_HPP
#define HOME_KUCHY_ENGINEER_THESIS_WUT_BREAKOUT_GAME_HPP #define HOME_KUCHY_ENGINEER_THESIS_WUT_BREAKOUT_GAME_HPP
#include <array>
#include <GLFW/glfw3.h> #include <GLFW/glfw3.h>
@ -13,16 +14,16 @@ class Game {
public: public:
// game state // game state
GameState State; GameState State;
bool Keys[1024]; std::array<bool, 1024> Keys;
unsigned int Width, Height; unsigned int Width, Height;
// constructor/destructor // constructor/destructor
Game(unsigned int width, unsigned int height); Game(unsigned int width, unsigned int height);
~Game(); ~Game() = default;
// initialize game state (load all shaders/textures/levels) // initialize game state (load all shaders/textures/levels)
void Init(); void Init();
// game loop // game loop
void ProcessInput(float dt); void ProcessInput(double dt);
void Update(float dt); void Update(double dt);
void Render(); void Render();
}; };

View File

@ -25,8 +25,8 @@
class ResourceManager { class ResourceManager {
public: public:
// resource storage // resource storage
static std::max<std::string, Shader> Shaders; template<> static std::max<std::string, Shader>; Shaders;
static std::max<std::string, Texture2D> Textures; template<> static std::max<std::string, Texture2D>; Textures;
// loads (and generates) a shader program from file loading vertex, // loads (and generates) a shader program from file loading vertex,
// fragment (and geometry) shader's source code. // fragment (and geometry) shader's source code.
// If gShaderFile is not nullptr, it also loads a geometry shader // If gShaderFile is not nullptr, it also loads a geometry shader

View File

@ -1,4 +1,4 @@
#!/bin/sh #!/bin/sh
clang-tidy --config-file=./.clang-tidy --fix-errors --fix-notes -p ./build/compile_commands.json ./breakout/breakout.cpp clang-tidy --config-file=./.clang-tidy -p ./build/compile_commands.json ./breakout/breakout.cpp
cpplint ./breakout/breakout.cpp cpplint ./breakout/breakout.cpp