diff --git a/flatpak/0001-CMakeLists.txt.patch b/flatpak/0001-CMakeLists.txt.patch index 7a55e56..178dae2 100644 --- a/flatpak/0001-CMakeLists.txt.patch +++ b/flatpak/0001-CMakeLists.txt.patch @@ -42,12 +42,13 @@ endif() endif() endif() -@@ -1814,24 +1804,14 @@ +@@ -1814,24 +1804,19 @@ install(FILES ${CMAKE_ADD_TARGET_DIR}/../SE1_10b.gro DESTINATION "${CMAKE_INSTALL_PREFIX}/share/${INTERNAL_NAME}" PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ) - install(FILES "${CMAKE_ADD_TARGET_DIR}/../${INTERNAL_NAME}.desktop" -+ install(FILES "${CMAKE_ADD_TARGET_DIR}/../${INTERNAL_NAME}.desktop" RENAME "io.itch.tx00100xt.SeriousSamClassic-VK.${INTERNAL_NAME}.desktop" ++ if(INTERNAL_NAME STREQUAL "serioussam") ++ install(FILES "${CMAKE_ADD_TARGET_DIR}/../${INTERNAL_NAME}.desktop" RENAME "io.itch.tx00100xt.SeriousSamClassic-VK.desktop" DESTINATION "${CMAKE_INSTALL_PREFIX}//share/applications" PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ) - set(A 16) @@ -65,7 +66,11 @@ - DESTINATION "${CMAKE_INSTALL_PREFIX}/share/icons/hicolor/${X}x${X}/apps" RENAME "${INTERNAL_NAME}.png" - PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ) - endforeach() -+ ++ else() ++ install(FILES "${CMAKE_ADD_TARGET_DIR}/../${INTERNAL_NAME}.desktop" RENAME "io.itch.tx00100xt.SeriousSamClassic-VK.SE.desktop" ++ DESTINATION "${CMAKE_INSTALL_PREFIX}//share/applications" ++ PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ) ++ endif() + install(FILES ${CMAKE_ADD_TARGET_DIR}/../${INTERNAL_NAME}.png + DESTINATION "${CMAKE_INSTALL_PREFIX}/share/icons/hicolor/256x256/apps" RENAME "io.itch.tx00100xt.SeriousSamClassic-VK.${INTERNAL_NAME}.png" + PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ) @@ -117,12 +122,13 @@ endif() endif() endif() -@@ -1814,24 +1804,14 @@ +@@ -1814,24 +1804,19 @@ install(FILES ${CMAKE_ADD_TARGET_DIR}/../SE1_10b.gro DESTINATION "${CMAKE_INSTALL_PREFIX}/share/${INTERNAL_NAME}" PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ) - install(FILES "${CMAKE_ADD_TARGET_DIR}/../${INTERNAL_NAME}.desktop" -+ install(FILES "${CMAKE_ADD_TARGET_DIR}/../${INTERNAL_NAME}.desktop" RENAME "io.itch.tx00100xt.SeriousSamClassic-VK.${INTERNAL_NAME}.desktop" ++ if(INTERNAL_NAME STREQUAL "serioussam") ++ install(FILES "${CMAKE_ADD_TARGET_DIR}/../${INTERNAL_NAME}.desktop" RENAME "io.itch.tx00100xt.SeriousSamClassic-VK.desktop" DESTINATION "${CMAKE_INSTALL_PREFIX}//share/applications" PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ) - set(A 16) @@ -140,9 +146,13 @@ - DESTINATION "${CMAKE_INSTALL_PREFIX}/share/icons/hicolor/${X}x${X}/apps" RENAME "${INTERNAL_NAME}.png" - PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ) - endforeach() -+ ++ else() ++ install(FILES "${CMAKE_ADD_TARGET_DIR}/../${INTERNAL_NAME}.desktop" RENAME "io.itch.tx00100xt.SeriousSamClassic-VK.SE.desktop" ++ DESTINATION "${CMAKE_INSTALL_PREFIX}//share/applications" ++ PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ) ++ endif() + install(FILES ${CMAKE_ADD_TARGET_DIR}/../${INTERNAL_NAME}.png -+ DESTINATION "${CMAKE_INSTALL_PREFIX}/share/icons/hicolor/256x256/apps" RENAME "io.itch.tx00100xt.SeriousSamClassic-VK.${INTERNAL_NAME}.png" ++ DESTINATION "${CMAKE_INSTALL_PREFIX}/share/icons/hicolor/256x256/apps" RENAME "io.itch.tx00100xt.SeriousSamClassic-VK.png" + PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ) + endif() diff --git a/flatpak/0002-Engine.cpp.patch b/flatpak/0002-Engine.cpp.patch index 43194d0..49e8939 100644 --- a/flatpak/0002-Engine.cpp.patch +++ b/flatpak/0002-Engine.cpp.patch @@ -115,7 +115,7 @@ + InfoMessage(TRANS("No game files were found in /app/pkg/share/%s/\n or %s\nThe home directory will be searched."),(const char *) strGameID,(const char *) _fnmUserDir); #else - InfoMessage(TRANS("No game files were found in /usr/share/%s/\n or %s\nThe home directory will be searched."),(const char *) strGameID,(const char *) _fnmUserDir); -+ InfoMessage(TRANS("No game files were found in /app/share/%s/\n or %s\nThe home directory will be searched."),(const char *) strGameID,(const char *) _fnmUserDir); ++ InfoMessage(TRANS("No game files were found in %s\nThe home directory will be searched."),(const char *) _fnmUserDir); #endif struct passwd *pw = getpwuid(getuid()); const char *_homedir = pw->pw_dir; @@ -130,7 +130,7 @@ + FatalError(TRANSV("Failed to search game data!\nPlease put the game data in the paths:\n/app/pkg/share/%s/\n or %s\n or somewhere in your home directory\nSee the log for more details.\nGame log is here: %s/SeriousSam.log"),(const char *) strGameID,(const char *) _fnmUserDir,(const char *) _fnmUserDir); #else - FatalError(TRANSV("Failed to search game data!\nPlease put the game data in the paths:\n/usr/share/%s/\n or %s\n or somewhere in your home directory\nSee the log for more details.\nGame log is here: ~/.local/share/Serious-Engine/%s/SeriousSam.log"),(const char *) strGameID,(const char *) _fnmUserDir,(const char *) strGameID); -+ FatalError(TRANSV("Failed to search game data!\nPlease put the game data in the paths:\n/app/share/%s/\n or %s\n or somewhere in your home directory\nSee the log for more details.\nGame log is here: %s/SeriousSam.log"),(const char *) strGameID,(const char *) _fnmUserDir,(const char *) _fnmUserDir); ++ FatalError(TRANSV("Failed to search game data!\nPlease put the game data in the path:\n%s\n \nSee the log for more details.\nGame log is here: %s/SeriousSam.log"),(const char *) _fnmUserDir,(const char *) _fnmUserDir); #endif } } @@ -260,7 +260,7 @@ + InfoMessage(TRANS("No game files were found in /app/pkg/share/%s/\n or %s\nThe home directory will be searched."),(const char *) strGameID,(const char *) _fnmUserDir); #else - InfoMessage(TRANS("No game files were found in /usr/share/%s/\n or %s\nThe home directory will be searched."),(const char *) strGameID,(const char *) _fnmUserDir); -+ InfoMessage(TRANS("No game files were found in /app/share/%s/\n or %s\nThe home directory will be searched."),(const char *) strGameID,(const char *) _fnmUserDir); ++ InfoMessage(TRANS("No game files were found in %s\nThe home directory will be searched."),(const char *) _fnmUserDir); #endif struct passwd *pw = getpwuid(getuid()); const char *_homedir = pw->pw_dir; @@ -275,7 +275,7 @@ + FatalError(TRANSV("Failed to search game data!\nPlease put the game data in the paths:\n/app/pkg/share/%s/\n or %s\n or somewhere in your home directory\nSee the log for more details.\nGame log is here: %s/SeriousSam.log"),(const char *) strGameID,(const char *) _fnmUserDir,(const char *) _fnmUserDir); #else - FatalError(TRANSV("Failed to search game data!\nPlease put the game data in the paths:\n/usr/share/%s/\n or %s\n or somewhere in your home directory\nSee the log for more details.\nGame log is here: ~/.local/share/Serious-Engine/%s/SeriousSam.log"),(const char *) strGameID,(const char *) _fnmUserDir,(const char *) strGameID); -+ FatalError(TRANSV("Failed to search game data!\nPlease put the game data in the paths:\n/app/share/%s/\n or %s\n or somewhere in your home directory\nSee the log for more details.\nGame log is here: %s/SeriousSam.log"),(const char *) strGameID,(const char *) _fnmUserDir,(const char *) _fnmUserDir); ++ FatalError(TRANSV("Failed to search game data!\nPlease put the game data in the path:\n%s\n \nSee the log for more details.\nGame log is here: %s/SeriousSam.log"),(const char *) _fnmUserDir,(const char *) _fnmUserDir); #endif } } diff --git a/flatpak/0003-desktop-file.patch b/flatpak/0003-desktop-file.patch index 05e4006..9412498 100644 --- a/flatpak/0003-desktop-file.patch +++ b/flatpak/0003-desktop-file.patch @@ -5,7 +5,7 @@ Exec=serioussam TryExec=serioussam -Icon=serioussam -+Icon=io.itch.tx00100xt.SeriousSamClassic-VK.serioussam ++Icon=io.itch.tx00100xt.SeriousSamClassic-VK Categories=Application;Game; --- a/SamTSE/serioussamse.desktop 2024-01-25 13:57:23.483929853 +0300 +++ a/SamTSE/serioussamse.desktop 2024-01-25 14:00:54.558511402 +0300 @@ -14,5 +14,5 @@ Exec=serioussamse TryExec=serioussamse -Icon=serioussam -+Icon=io.itch.tx00100xt.SeriousSamClassic-VK.serioussamse ++Icon=io.itch.tx00100xt.SeriousSamClassic-VK Categories=Application;Game; diff --git a/flatpak/io.itch.tx00100xt.SeriousSamClassic-VK.metainfo.xml b/flatpak/io.itch.tx00100xt.SeriousSamClassic-VK.metainfo.xml new file mode 100644 index 0000000..a3471a9 --- /dev/null +++ b/flatpak/io.itch.tx00100xt.SeriousSamClassic-VK.metainfo.xml @@ -0,0 +1,68 @@ + + + + + io.itch.tx00100xt.SeriousSamClassic-VK + SeriousSamClassic-VK + SeriousSamClassic-VK is a Serious-Engine GPL source port + CC0-1.0 + GPL-2.0 + + Alexander Pavlov + t.x00100x.t@yandex.ru + + https://github.com/tx00100xt/SeriousSamClassic-VK + https://github.com/tx00100xt/SeriousSamClassic-VK/wiki + https://github.com/tx00100xt/SeriousSamClassic-VK + + io.itch.tx00100xt.SeriousSamClassic-VK.desktop + io.itch.tx00100xt.SeriousSamClassic-VK.SE.desktop + + +

SeriousSamClassic-VK is open source game engine version developed by Croteam for Serious Sam Classic with Vulkan support(Windows, Linux, FreeBSD, Raspberry Pi OS, macOS). Based on https://github.com/sultim-t/Serious-Engine-Vk and linux port https://github.com/icculus/Serious-Engine, but it should work on (or be easily portable to) any system that supports Vulkan and SDL2. +

+

Note that while the Serious-Engine source code has been released under GPL, you still need to legally own the game and provide Serious Sam Classic The First Encounter and Serious Sam Classic The Second Encounter the game data to play. See the How to Install section for more information. +

+
+ + + + https://github.com/tx00100xt/SeriousSamClassic-VK/raw/main/Images/samvulkan_1.png + SeriousSamClassic-VK running on Linux with XPLUS Mod. Metropolis. + + + https://github.com/tx00100xt/SeriousSamClassic-VK/raw/main/Images/samvulkan_2.png + SeriousSamClassic-VK running on Linux with XPLUS Mod. Alley Of Sphinxes. + + + https://github.com/tx00100xt/SeriousSamClassic-VK/raw/main/Images/samvulkan_3.png + SeriousSamClassic-VK running on Linux with XPLUS Mod. Alley Of Sphinxes. + + + https://github.com/tx00100xt/SeriousSamClassic-VK/raw/main/Images/samvulkan_4.png + SeriousSamClassic-VK running on Linux with XPLUS Mod. Sierra de chiapas. + + + https://github.com/tx00100xt/SeriousSamClassic-VK/raw/main/Images/samvulkan_5.png + SeriousSamClassic-VK running on Linux with XPLUS Mod. Land of the Damned. + + + https://github.com/tx00100xt/SeriousSamClassic-VK/raw/main/Images/samvulkan_6.png + SeriousSamClassic-VK running on Linux with XPLUS Mod. The Grand Cathedral. + + + + + moderate + none + mild + mild + intense + + + + + + +
+ diff --git a/flatpak/io.itch.tx00100xt.SeriousSamClassic-VK.png b/flatpak/io.itch.tx00100xt.SeriousSamClassic-VK.png new file mode 100644 index 0000000..b8924f6 Binary files /dev/null and b/flatpak/io.itch.tx00100xt.SeriousSamClassic-VK.png differ diff --git a/flatpak/io.itch.tx00100xt.SeriousSamClassic-VK.yaml b/flatpak/io.itch.tx00100xt.SeriousSamClassic-VK.yaml new file mode 100644 index 0000000..2ddbfb2 --- /dev/null +++ b/flatpak/io.itch.tx00100xt.SeriousSamClassic-VK.yaml @@ -0,0 +1,41 @@ +app-id: io.itch.tx00100xt.SeriousSamClassic-VK +runtime: org.freedesktop.Platform +sdk: org.freedesktop.Sdk +runtime-version: '23.08' +command: serioussam + +finish-args: + - --socket=wayland + - --socket=fallback-x11 + - --device=dri + - --share=ipc + - --share=network + - --socket=pulseaudio + +cleanup: + - '*.la' + - '*.a' + +modules: + + - name: serioussam + buildsystem: cmake-ninja + config-opts: + - -DCMAKE_BUILD_TYPE=RelWithDebInfo + post-install: + - install -Dm 644 io.itch.tx00100xt.SeriousSamClassic-VK.metainfo.xml -t /app/share/metainfo + - install -Dm 644 io.itch.tx00100xt.SeriousSamClassic-VK.png -t /app/share/icons/hicolor/128x128/apps/ + sources: + - type: archive + url: https://github.com/tx00100xt/SeriousSamClassic-VK/archive/refs/tags/1.10.6d.tar.gz + sha256: 768ea6a42e6506ab4619771932032a392c6e3e64be9ecc694b02a172b767b2fa + - type: patch + path: 0001-CMakeLists.txt.patch + - type: patch + path: 0002-Engine.cpp.patch + - type: patch + path: 0003-desktop-file.patch + - type: file + path: io.itch.tx00100xt.SeriousSamClassic-VK.metainfo.xml + - type: file + path: io.itch.tx00100xt.SeriousSamClassic-VK.png