diff --git a/.github/workflows/deploy_netlify.yml b/.github/workflows/deploy_netlify.yml new file mode 100644 index 0000000..c27f966 --- /dev/null +++ b/.github/workflows/deploy_netlify.yml @@ -0,0 +1,38 @@ +name: deploy_netflify + +on: + push: + branches: [ "master" ] + +jobs: + build-web: + runs-on: ubuntu-latest + steps: + - name: Checkout + uses: actions/checkout@master + + - name: Setup emsdk + uses: mymindstorm/setup-emsdk@v11 + + - name: Cmake Build + run: | + embuilder build zlib + # embuilder build zlib --lto + # embuilder build zlib --lto=thin + cmake --preset emsdk -DEM_USE_THREADS=ON + cmake --build --preset emsdk --parallel 4 + + - name: Deploy to Netlify + uses: nwtgck/actions-netlify@v1.2 + with: + publish-dir: build/emsdk/bin + production-branch: master + github-token: ${{ secrets.GITHUB_TOKEN }} + deploy-message: "Deploy from GitHub Actions" + enable-pull-request-comment: false + enable-commit-comment: false + overwrites-pull-request-comment: false + env: + NETLIFY_AUTH_TOKEN: ${{ secrets.NETLIFY_AUTH_TOKEN }} + NETLIFY_SITE_ID: ${{ secrets.NETLIFY_SITE_ID }} + timeout-minutes: 1 diff --git a/.github/workflows/deploy_pages.yml b/.github/workflows/deploy_pages.yml new file mode 100644 index 0000000..7ef1624 --- /dev/null +++ b/.github/workflows/deploy_pages.yml @@ -0,0 +1,32 @@ +# gh pages build does not use threads / mutex's +# this offers wider browser support. +name: deploy_pages + +on: + push: + branches: [ "master" ] + +jobs: + build-web: + runs-on: ubuntu-latest + steps: + - name: Checkout + uses: actions/checkout@master + + - name: Setup emsdk + uses: mymindstorm/setup-emsdk@v11 + + - name: Cmake Build + run: | + embuilder build zlib + # embuilder build zlib --lto + # embuilder build zlib --lto=thin + cmake --preset emsdk + cmake --build --preset emsdk --parallel 4 + + - name: Deploy + uses: JamesIves/github-pages-deploy-action@v4 + with: + branch: gh-pages # The branch the action should deploy to. + folder: build/emsdk/bin # The folder the action should deploy. + single-commit: true # Start branch with no history diff --git a/.gitignore b/.gitignore index 98ded3e..d8eeb4a 100644 --- a/.gitignore +++ b/.gitignore @@ -19,5 +19,3 @@ imgui.ini CMakeUserPresets.json rtc.md n64-emu -deploy_netlify.yml -deploy_pages.yml diff --git a/CMakeLists.txt b/CMakeLists.txt index 12501d1..a1bbe5b 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -48,6 +48,23 @@ else() message(STATUS "cant find clangd: not generating compile_commands.json") endif() +if (LTO) + include(CheckIPOSupported) + check_ipo_supported(RESULT ipo_supported OUTPUT ipo_error) + if (ipo_supported) + message(STATUS "IPO / LTO enabled for ALL targets") + set(CMAKE_INTERPROCEDURAL_OPTIMIZATION TRUE) + else() + message(STATUS "IPO / LTO not supported") + endif() +endif() + +# these needs to be globally set otherwise a link error happens when +# using std::filesystem::recursive_directory_iterator +if (EMSCRIPTEN AND EM_USE_THREADS) + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -pthread") +endif() + message(STATUS "SYSTEM: ${CMAKE_SYSTEM_NAME}") message(STATUS "COMPILER: ${CMAKE_CXX_COMPILER_ID}") diff --git a/CMakePresets.json b/CMakePresets.json index 3b06828..8baeb80 100644 --- a/CMakePresets.json +++ b/CMakePresets.json @@ -12,6 +12,7 @@ "binaryDir": "${sourceDir}/build/${presetName}", "cacheVariables": { "CMAKE_BUILD_TYPE": "Release", + "LTO": true, "SINGLE_FILE": true, "IMGUI": true } @@ -48,6 +49,7 @@ "binaryDir": "${sourceDir}/build/${presetName}", "cacheVariables": { "CMAKE_BUILD_TYPE": "Release", + "LTO": true, "SINGLE_FILE": true, "SDL2": true } @@ -69,6 +71,7 @@ "toolchainFile": "$env{VCPKG_INSTALLATION_ROOT}/scripts/buildsystems/vcpkg.cmake", "cacheVariables": { "CMAKE_BUILD_TYPE": "Release", + "LTO": true, "SINGLE_FILE": true, "SDL2": true } @@ -92,6 +95,7 @@ "toolchainFile": "$env{EMSDK}/upstream/emscripten/cmake/Modules/Platform/Emscripten.cmake", "cacheVariables": { "CMAKE_BUILD_TYPE": "Release", + "LTO": true, "SINGLE_FILE": true } }, diff --git a/assets/web/README.md b/assets/web/README.md deleted file mode 100644 index f3e23bb..0000000 --- a/assets/web/README.md +++ /dev/null @@ -1,25 +0,0 @@ -# Your Favicon Package - -This package was generated with [RealFaviconGenerator](https://realfavicongenerator.net/) [v0.16](https://realfavicongenerator.net/change_log#v0.16) - -## Install instructions - -To install this package: - -Extract this package in the root of your web site. If your site is http://www.example.com, you should be able to access a file named http://www.example.com/favicon.ico. - -Insert the following code in the `head` section of your pages: - - - - - - - - - - - - - -*Optional* - Check your favicon with the [favicon checker](https://realfavicongenerator.net/favicon_checker) \ No newline at end of file diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index f32caff..b63f3b5 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -46,54 +46,51 @@ endif() list(APPEND clang_flags -Wall - # -Wextra + -Wextra -Wfatal-errors - # -Wpedantic - -fno-rtti -fno-exceptions - # -Wshadow - # -Wdouble-promotion - # -Wformat=2 - # -Wundef - # -Wmissing-include-dirs - # -Wstrict-aliasing - # -Wstrict-overflow=5 - # -Walloca - # -Wwrite-strings - # -Wdate-time - # -Wpacked - # -Wnested-externs - # -Wcast-qual - # -Wcast-align - # -Wunused-macros - # -Wreserved-id-macro - # -Wbad-function-cast - # -Wbitfield-enum-conversion - - # -Wextra-semi-stmt - # -Wold-style-cast - # -Wcovered-switch-default - - # -Wno-unused-parameter - # -Wno-unused-variable - # -Wextra-semi-stmt - # -Wold-style-cast + -Wpedantic + -Wshadow + -Wdouble-promotion + -Wformat=2 + -Wundef + -Wmissing-include-dirs + -Wstrict-aliasing + -Wstrict-overflow=5 + -Walloca + -Wwrite-strings + -Wdate-time + -Wpacked + -Wnested-externs + -Wcast-qual + -Wcast-align + -Wunused-macros + -Wreserved-id-macro + -Wbad-function-cast + -Wbitfield-enum-conversion + + -Wextra-semi-stmt + -Wold-style-cast + -Wcovered-switch-default + + -fno-rtti + -fno-exceptions # # can try enabling this just to see what breaks (still compiles as of clang 11) # # be sure to enable (well, disable) the below flags else a *lot* of "errors" - # # -Weverything - # -Wno-c++98-compat - # -Wno-c++98-compat-pedantic - # -Wno-c++20-compat - # -Wno-missing-braces # false positive - # -Wno-unused-parameter - # -Wno-unused-variable - # -Wno-conversion - # -Wno-sign-conversion - # -Wno-missing-prototypes - # -Wno-padded - # -Wno-switch-enum + -Weverything + -Wno-c++98-compat + -Wno-c++98-compat-pedantic + -Wno-c++20-compat + -Wno-missing-braces # false positive + -Wno-conversion + -Wno-sign-conversion + -Wno-missing-prototypes + -Wno-padded + -Wno-switch-enum -Wno-unknown-attributes + -Wno-unused-parameter + -Wno-unused-variable ) if (CMAKE_BUILD_TYPE STREQUAL "Debug") @@ -120,27 +117,8 @@ endif() include(CheckCXXCompilerFlag) include(CheckLinkerFlag) -include(CheckIPOSupported) include(FetchContent) -function(target_apply_lto target) - check_ipo_supported(RESULT ipo_supported OUTPUT ipo_error) - if (ipo_supported) - message(STATUS "IPO / LTO enabled for target: ${target}") - set_property(TARGET ${target} PROPERTY INTERPROCEDURAL_OPTIMIZATION TRUE) - else() - message(STATUS "IPO / LTO not supported: <${ipo_error}>") - endif() -endfunction() - -function(target_apply_lto_in_release target) - if (CMAKE_BUILD_TYPE STREQUAL "Release" OR CMAKE_BUILD_TYPE STREQUAL "RelWithDebInfo" OR CMAKE_BUILD_TYPE STREQUAL "MinSizeRel") - target_apply_lto(${target}) - else() - message(STATUS "IPO / LTO not enabled in debug build") - endif() -endfunction() - function(target_add_compiler_flag target flag scope) # check_cxx_compiler_flag() adds a macro to the test.c file such that # it'll look like # will be shown as "#define COMPILER_SUPPORTS_-Wdouble-promotion" diff --git a/src/core/CMakeLists.txt b/src/core/CMakeLists.txt index 9a54b8b..89d5a9e 100644 --- a/src/core/CMakeLists.txt +++ b/src/core/CMakeLists.txt @@ -72,7 +72,3 @@ target_compile_definitions(GBA PRIVATE ) set_target_properties(GBA PROPERTIES CXX_STANDARD 23) - -# enable LTO (only in release builds) -# this greatly reduces template bloat as well -target_apply_lto_in_release(GBA) diff --git a/src/frontend/CMakeLists.txt b/src/frontend/CMakeLists.txt index 337beaa..bb0a673 100644 --- a/src/frontend/CMakeLists.txt +++ b/src/frontend/CMakeLists.txt @@ -10,7 +10,6 @@ set_target_properties(frontend_base PROPERTIES CXX_STANDARD 23) target_add_common_cflags(frontend_base PRIVATE) -target_apply_lto_in_release(frontend_base) include(FetchContent) Set(FETCHCONTENT_QUIET FALSE) @@ -29,7 +28,7 @@ set(FOUND_MINIZIP FALSE) # set(DISABLE_INSTALL_TOOLS ON) # find_package(minizip CONFIG) # if (DEFINED minizip_FOUND) -# target_link_libraries(frontend_base PUBLIC minizip::minizip) +# target_link_libraries(frontend_base PRIVATE minizip::minizip) # set(FOUND_MINIZIP TRUE) # message(STATUS "using vcpkg minizip") @@ -42,8 +41,8 @@ set(FOUND_MINIZIP FALSE) find_path(minizip_inc minizip) if (minizip_lib AND minizip_inc) - target_link_libraries(frontend_base PUBLIC ${minizip_lib}) - target_include_directories(frontend_base PUBLIC ${minizip_inc}) + target_link_libraries(frontend_base PRIVATE ${minizip_lib}) + target_include_directories(frontend_base PRIVATE ${minizip_inc}) # this has to be linked after minizip! find_package(ZLIB REQUIRED) @@ -70,13 +69,13 @@ if (NOT FOUND_MINIZIP) ${minizip_SOURCE_DIR}/contrib/minizip/unzip.c ) - target_include_directories(minizip PUBLIC ${minizip_SOURCE_DIR}/contrib/minizip/) + target_include_directories(minizip PRIVATE ${minizip_SOURCE_DIR}/contrib/minizip/) # need the paths to be minizip/unzip.h target_include_directories(minizip PUBLIC ${minizip_SOURCE_DIR}/contrib/) find_package(ZLIB REQUIRED) - target_link_libraries(minizip PUBLIC ZLIB::ZLIB) - target_link_libraries(frontend_base PUBLIC minizip) + target_link_libraries(minizip PRIVATE ZLIB::ZLIB) + target_link_libraries(frontend_base PRIVATE minizip) message(STATUS "using github minizip") endif() diff --git a/src/frontend/emscripten/CMakeLists.txt b/src/frontend/emscripten/CMakeLists.txt index ecc4858..837721b 100644 --- a/src/frontend/emscripten/CMakeLists.txt +++ b/src/frontend/emscripten/CMakeLists.txt @@ -7,7 +7,6 @@ add_executable(notorious_beeg_EMSDK main.cpp) target_link_libraries(notorious_beeg_EMSDK PRIVATE sdl2_base) target_add_common_cflags(notorious_beeg_EMSDK PRIVATE) -target_apply_lto_in_release(notorious_beeg_EMSDK) set_target_properties(notorious_beeg_EMSDK PROPERTIES RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin" @@ -25,16 +24,20 @@ option(EM_USE_THREADS option(EMRUN "build with emrun support, used for testing" OFF) if (EM_USE_THREADS) - target_link_options(notorious_beeg_EMSDK PRIVATE "-pthread") + # set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -pthread") + # target_link_options(notorious_beeg_EMSDK PRIVATE "-pthread") + # target_compile_options(notorious_beeg_EMSDK PRIVATE "-pthread") + target_compile_definitions(notorious_beeg_EMSDK PRIVATE EM_THREADS=1) endif() if (EMRUN) target_link_options(notorious_beeg_EMSDK PRIVATE "--emrun") + target_compile_definitions(notorious_beeg_EMSDK PRIVATE EMRUN=1) endif() file(COPY "${CMAKE_SOURCE_DIR}/assets/buttons" DESTINATION "${CMAKE_CURRENT_BINARY_DIR}/assets") file(COPY "${CMAKE_SOURCE_DIR}/assets/menu" DESTINATION "${CMAKE_CURRENT_BINARY_DIR}/assets") -file(COPY "${CMAKE_SOURCE_DIR}/assets/web" DESTINATION "${CMAKE_CURRENT_BINARY_DIR}") +file(COPY "${CMAKE_SOURCE_DIR}/assets/web/" DESTINATION "${CMAKE_BINARY_DIR}/bin/") file(COPY "${CMAKE_CURRENT_SOURCE_DIR}/netlify.toml" DESTINATION "${CMAKE_BINARY_DIR}/bin/") target_link_options(notorious_beeg_EMSDK PRIVATE diff --git a/src/frontend/emscripten/main.cpp b/src/frontend/emscripten/main.cpp index 9b8b83c..1a2bd18 100644 --- a/src/frontend/emscripten/main.cpp +++ b/src/frontend/emscripten/main.cpp @@ -11,15 +11,11 @@ #include #include #include -#include -#include -#include -#include #include #include // intellisense is having a bad day, i cba to fix it -#if 1 +#if 0 #include #include #include @@ -85,9 +81,6 @@ constexpr auto get_touch_id_asset(TouchID id) case TouchID_BACK: return "assets/menu/back.png"; case TouchID_IMPORT: return "assets/menu/import.png"; case TouchID_EXPORT: return "assets/menu/export.png"; - // case TouchID_FULLSCREEN: return "assets/buttons/fullscreen.png"; - // case TouchID_AUDIO: return "assets/buttons/volume_on.png"; - // case TouchID_FASTFORWARD: return "assets/buttons/fastForward.png"; case TouchID_FULLSCREEN: return "assets/buttons/larger.png"; case TouchID_AUDIO: return "assets/buttons/musicOn.png"; case TouchID_FASTFORWARD: return "assets/buttons/fastForward.png"; @@ -136,87 +129,7 @@ struct ButtonEventData }; std::uint32_t ROM_LOAD_EVENT = 0; - -// returns the number of files zipped -auto zip_saves() -> std::size_t -{ - // auto zfile = zipOpen2_64(nullptr, APPEND_STATUS_CREATE, nullptr, &def); - auto zfile = zipOpen64("TotalGBA_saves.zip", APPEND_STATUS_CREATE); - if (!zfile) - { - std::printf("failed to zip open in memory\n"); - return 0; - } - - // const char* folders[] = { "/save", "/state" }; - const char* folders[] = { "/save" }; - std::size_t count{}; - - for (auto& folder : folders) - { - for (auto& entry : std::filesystem::recursive_directory_iterator{folder}) - { - if (entry.is_regular_file()) - { - // get the fullpath - const auto path = entry.path().string(); - std::ifstream fs{path, std::ios::binary}; - - if (fs.good()) - { - // read file into buffer - const auto file_size = entry.file_size(); - std::vector buffer(file_size); - fs.read(buffer.data(), buffer.size()); - - // open the file inside the zip - if (ZIP_OK != zipOpenNewFileInZip(zfile, - path.c_str(), // filepath - nullptr, // info, optional - nullptr, 0, // extrafield and size, optional - nullptr, 0, // extrafield-global and size, optional - "TotalGBA", // comment, optional - Z_DEFLATED, // mode - Z_DEFAULT_COMPRESSION // level - )) { - std::printf("failed to open file in zip: %s\n", path.c_str()); - continue; - } - - // write out the entire file - if (Z_OK != zipWriteInFileInZip(zfile, buffer.data(), buffer.size())) - { - std::printf("failed to write file in zip: %s\n", path.c_str()); - } - else - { - count++; - } - - // don't forget to close when done! - if (Z_OK != zipCloseFileInZip(zfile)) - { - std::printf("failed to close file in zip: %s\n", path.c_str()); - } - } - else - { - std::printf("failed to open file %s\n", path.c_str()); - } - } - } - } - - zipClose(zfile, "TotalGBA"); - - // if (mzmem.buf) - // { - // hacky_ptr = mzmem.buf; - // return mzmem.size; - // } - - return count; -} +std::uint32_t FLUSH_SAVE_EVENT = 0; struct App final : frontend::sdl2::Sdl2Base { @@ -332,6 +245,7 @@ auto em_loop(void* user) -> void app->step(); } +#ifdef EM_THREADS auto sdl2_sram_timer_callback(Uint32 interval, void* user) -> Uint32 { auto app = static_cast(user); @@ -340,13 +254,16 @@ auto sdl2_sram_timer_callback(Uint32 interval, void* user) -> Uint32 std::scoped_lock lock{app->core_mutex}; app->savegame(""); } - // std::printf("callback!\n"); + // std::printf("callback! %u\n", interval); return interval; } +#endif auto sdl2_audio_callback(void* user, Uint8* data, int len) -> void { auto app = static_cast(user); + // this may cause a race condition if not built with threads + // as the audio may still be ran on its own thread... app->fill_audio_data_from_stream(data, len); } @@ -430,7 +347,13 @@ App::App(int argc, char** argv) : frontend::sdl2::Sdl2Base(argc, argv) } } - sram_sync_timer = SDL_AddTimer(1000 * 3, sdl2_sram_timer_callback, this); + // SDL_timers fire instantly without pthread support! + #ifdef EM_THREADS + sram_sync_timer = SDL_AddTimer(1000 * 3, sdl2_sram_timer_callback, this); + #else + FLUSH_SAVE_EVENT = SDL_RegisterEvents(1); + EM_ASM( setInterval(_em_flush_save, 1000 * 3); ); + #endif // set fullscreen // set_window_size_from_renderer(); @@ -802,6 +725,14 @@ auto App::on_user_event(SDL_UserEvent& e) -> void delete data; } + else if (e.type == FLUSH_SAVE_EVENT) + { + if (has_rom) + { + std::scoped_lock lock{core_mutex}; + savegame(""); + } + } } auto App::on_controlleraxis_event(const SDL_ControllerAxisEvent& e) -> void @@ -1193,9 +1124,16 @@ EMSCRIPTEN_KEEPALIVE auto em_load_rom_data(const char* name, uint8_t* data, int SDL_PushEvent(&event); } +EMSCRIPTEN_KEEPALIVE auto em_flush_save() -> void +{ + SDL_Event event{}; + event.user.type = FLUSH_SAVE_EVENT; + SDL_PushEvent(&event); +} + EMSCRIPTEN_KEEPALIVE auto em_zip_all_saves() -> std::size_t { - const auto result = zip_saves(); + const auto result = frontend::Base::zipall("/save", "TotalGBA_saves.zip"); if (!result) { SDL_ShowSimpleMessageBox(SDL_MESSAGEBOX_INFORMATION, "No save files found!", "Try saving in game first\n\nIf you know there was a save file created, please contact me about the bug!", nullptr); diff --git a/src/frontend/frontend_base.cpp b/src/frontend/frontend_base.cpp index efa78af..0c50c5a 100644 --- a/src/frontend/frontend_base.cpp +++ b/src/frontend/frontend_base.cpp @@ -123,9 +123,12 @@ auto minizip_testerror_file_func([[maybe_unused]] void* opaque, [[maybe_unused]] return 0; } -#if 0 -auto zipall_internal(zipFile zf, const std::string& folder) -> void +// returns the number of files zipped +[[nodiscard]] +auto zipall_internal(zipFile zf, const std::string& folder) -> std::size_t { + std::size_t count{}; + // for (auto& folder : folders) { for (auto& entry : std::filesystem::recursive_directory_iterator{folder}) @@ -162,6 +165,10 @@ auto zipall_internal(zipFile zf, const std::string& folder) -> void { std::printf("failed to write file in zip: %s\n", path.c_str()); } + else + { + count++; + } // don't forget to close when done! if (Z_OK != zipCloseFileInZip(zf)) @@ -176,8 +183,9 @@ auto zipall_internal(zipFile zf, const std::string& folder) -> void } } } + + return count; } -#endif // basic rom loading from zip, will flesh this out more soon auto loadzip_internal(unzFile zf) -> std::vector @@ -290,50 +298,18 @@ auto Base::dumpfile(const std::string& path, std::span data) return false; } -#if 0 -auto Base::zipall(const std::string& folder, const std::string& output) -> bool +auto Base::zipall(const std::string& folder, const std::string& output) -> std::size_t { - if (auto zfile = zipOpen64(nullptr, APPEND_STATUS_CREATE)) + if (auto zfile = zipOpen64(output.c_str(), APPEND_STATUS_CREATE)) { - zipall_internal(zfile, folder); + const auto count = zipall_internal(zfile, folder); zipClose(zfile, "TotalGBA"); // todo: error handling! - return true; + return count; } - return false; -} - -auto Base::zipall_mem(const std::string& folder) -> std::vector -{ - MzMem mzmem{ - .buf = nullptr, - .size = 0, - .offset = 0, - .read_only = false, - }; - - auto def = zlib_filefunc64; - def.opaque = &mzmem; - - if (auto zfile = zipOpen2_64(nullptr, APPEND_STATUS_CREATE, nullptr, &def)) - { - zipall_internal(zfile, folder); - zipClose(zfile, "TotalGBA"); - - if (mzmem.buf) - { - // wasteful code. it's this way because of how the js calls into c - std::vector buf; - buf.resize(mzmem.size); - std::free(mzmem.buf); - return buf; - } - } - - return {}; + return 0; } -#endif auto Base::loadzip(const std::string& path) -> std::vector { @@ -509,7 +485,7 @@ auto Base::savegame(const std::string& path) -> bool // is save isn't dirty, then return early if (!gameboy_advance.is_save_dirty()) { - return true; + return false; } const auto save_path = create_save_path(path); diff --git a/src/frontend/frontend_base.hpp b/src/frontend/frontend_base.hpp index af61728..2b493ea 100644 --- a/src/frontend/frontend_base.hpp +++ b/src/frontend/frontend_base.hpp @@ -4,6 +4,7 @@ #pragma once #include +#include #include #include #include @@ -22,8 +23,10 @@ struct Base virtual auto loop() -> void = 0; static auto dumpfile(const std::string& path, std::span data) -> bool; - static auto zipall(const std::string& folder, const std::string& output) -> bool; + static auto zipall(const std::string& folder, const std::string& output) -> std::size_t; + #if 0 static auto zipall_mem(const std::string& folder) -> std::vector; + #endif static auto loadzip(const std::string& path) -> std::vector; static auto loadfile(const std::string& path) -> std::vector; static auto loadfile_mem(const std::string& path, std::span data) -> std::vector; diff --git a/src/frontend/imgui/CMakeLists.txt b/src/frontend/imgui/CMakeLists.txt index 2d70ef2..9ee24ca 100644 --- a/src/frontend/imgui/CMakeLists.txt +++ b/src/frontend/imgui/CMakeLists.txt @@ -48,8 +48,6 @@ target_link_libraries(imgui_base PUBLIC imgui) target_link_libraries(imgui_base PRIVATE imgui_club) # target_add_common_cflags(imgui_base PRIVATE) -target_apply_lto_in_release(imgui) -target_apply_lto_in_release(imgui_base) option(DUMP_AUDIO "dump audio to a file" OFF) option(SPEED_TEST "run uncapped fps, used for perf test" OFF) diff --git a/src/frontend/imgui/backend/sdl2/CMakeLists.txt b/src/frontend/imgui/backend/sdl2/CMakeLists.txt index 2d2b279..a8f4d95 100644 --- a/src/frontend/imgui/backend/sdl2/CMakeLists.txt +++ b/src/frontend/imgui/backend/sdl2/CMakeLists.txt @@ -17,5 +17,3 @@ set_target_properties(notorious_beeg_IMGUI_SDL2 PROPERTIES RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin" CXX_STANDARD 23 ) - -target_apply_lto_in_release(notorious_beeg_IMGUI_SDL2) diff --git a/src/frontend/sdl2/CMakeLists.txt b/src/frontend/sdl2/CMakeLists.txt index 6a35193..ce3fbed 100644 --- a/src/frontend/sdl2/CMakeLists.txt +++ b/src/frontend/sdl2/CMakeLists.txt @@ -7,7 +7,6 @@ add_executable(notorious_beeg_SDL2 main.cpp) target_link_libraries(notorious_beeg_SDL2 PRIVATE sdl2_base) target_add_common_cflags(notorious_beeg_SDL2 PRIVATE) -target_apply_lto_in_release(notorious_beeg_SDL2) set_target_properties(notorious_beeg_SDL2 PROPERTIES RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin" diff --git a/src/frontend/sdl2_base/CMakeLists.txt b/src/frontend/sdl2_base/CMakeLists.txt index bd1a971..1117b27 100644 --- a/src/frontend/sdl2_base/CMakeLists.txt +++ b/src/frontend/sdl2_base/CMakeLists.txt @@ -14,4 +14,3 @@ set_target_properties(sdl2_base PROPERTIES CXX_STANDARD 23) target_add_common_cflags(sdl2_base PRIVATE) -target_apply_lto_in_release(sdl2_base)