From ec70bb48acb4bc9cafafb6652ff4ec2e7af9f880 Mon Sep 17 00:00:00 2001 From: FoxMoss Date: Sat, 19 Oct 2024 13:03:39 -0500 Subject: [PATCH 1/2] feat: allow cmake built executable to be run anywhere --- ScuffedMinecraft/src/Application.cpp | 28 +++++++++++++++++++++++++--- ScuffedMinecraft/src/CMakeLists.txt | 6 +++++- 2 files changed, 30 insertions(+), 4 deletions(-) diff --git a/ScuffedMinecraft/src/Application.cpp b/ScuffedMinecraft/src/Application.cpp index 953a117..e8fbf25 100644 --- a/ScuffedMinecraft/src/Application.cpp +++ b/ScuffedMinecraft/src/Application.cpp @@ -2,6 +2,10 @@ #include "imgui_impl_glfw.h" #include "imgui_impl_opengl3.h" +#ifdef LINUX +#include +#endif + #include #include #define STB_IMAGE_IMPLEMENTATION @@ -56,8 +60,26 @@ float rectangleVertices[] = -1.0f, 1.0f, 0.0f, 1.0f }; -int main() -{ +int main (int argc, char *argv[]) { +#ifdef LINUX + char* resolved_path = realpath(argv[0],NULL); + if (resolved_path == NULL) { + printf("%s: Please do not place binary in PATH\n", argv[0]); + exit(1); + } + size_t resolved_length = strlen(resolved_path); + + // remove executable from path + for (size_t i = resolved_length; i > 0; i--) { + if (resolved_path[i] == '/' && resolved_path[i+1] != 0) { + resolved_path[i+1] = 0; + break; + } + } + chdir(resolved_path); + free(resolved_path); +#endif + // Initialize GLFW glfwInit(); glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 3); @@ -405,4 +427,4 @@ void mouse_callback(GLFWwindow* window, double xpos, double ypos) void scroll_callback(GLFWwindow* window, double xoffset, double yoffset) { camera.ProcessMouseScroll(yoffset); -} \ No newline at end of file +} diff --git a/ScuffedMinecraft/src/CMakeLists.txt b/ScuffedMinecraft/src/CMakeLists.txt index 0c4a1d8..c7683e3 100644 --- a/ScuffedMinecraft/src/CMakeLists.txt +++ b/ScuffedMinecraft/src/CMakeLists.txt @@ -4,7 +4,11 @@ add_executable(scuffed_mc Camera.cpp Planet.cpp WorldGen.cpp ../vendor/glad.c ) +if(LINUX) + add_compile_definitions(LINUX) +endif() + # make sure the program runs in the right place from visual studio set_target_properties(scuffed_mc PROPERTIES VS_DEBUGGER_WORKING_DIRECTORY "${CMAKE_SOURCE_DIR}/bin") -target_link_libraries(scuffed_mc imgui $,glfw3,glfw>) \ No newline at end of file +target_link_libraries(scuffed_mc imgui $,glfw3,glfw>) From cced9a2b95374822bd8084bc8de9efe6396ff8bb Mon Sep 17 00:00:00 2001 From: FoxMoss Date: Sat, 19 Oct 2024 18:42:28 -0500 Subject: [PATCH 2/2] feat: provide reasonable response to a lack of asset directory --- ScuffedMinecraft/src/Application.cpp | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/ScuffedMinecraft/src/Application.cpp b/ScuffedMinecraft/src/Application.cpp index e8fbf25..4324888 100644 --- a/ScuffedMinecraft/src/Application.cpp +++ b/ScuffedMinecraft/src/Application.cpp @@ -4,6 +4,9 @@ #ifdef LINUX #include +#include +#include +#include #endif #include @@ -73,9 +76,22 @@ int main (int argc, char *argv[]) { for (size_t i = resolved_length; i > 0; i--) { if (resolved_path[i] == '/' && resolved_path[i+1] != 0) { resolved_path[i+1] = 0; + resolved_length = i; break; } } + + char* assets_path = (char *)malloc(resolved_length + strlen("assets") + 2); + strcpy(assets_path, resolved_path); + strcpy(assets_path + resolved_length + 1, "assets"); + struct stat path_stat; + if(stat(assets_path, &path_stat) == -1 || !S_ISDIR(path_stat.st_mode)) { + printf("%s: Asset directory not found\n", argv[0]); + exit(1); + } + + free(assets_path); + chdir(resolved_path); free(resolved_path); #endif