SparkAppimageConfig.cmake 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. # SparkAppimageConfig.cmake
  2. # 1. 在使用时通过准备默认的 icon 与 SparkDesktopConfig.cmake 在生成 desktop 文件
  3. # 时进行借用 desktop 文件中的基本描述完成 spark-appimage.dekstop 文件的生成,
  4. # 并在使用 add_appimage 时完成所有逻辑判断与目标的定义
  5. # add_appimage_icon
  6. # add_appimage_desktop
  7. # add_appimage
  8. # 2. 在 add_appimage 中,我们判断了是否为 cmake 提供了 LINUXDEPLOYQT 宏,
  9. # 并获取此工具的真实路径。并继续判断了 APPIMAGETOOL 宏与该工具的真实路径。
  10. # 然后,创建一个目录,用于即将进行的 Appimage 打包。
  11. # 通过调用 target_linuxdeploy() 来完成 linuxdeploy 的目标创建
  12. # 通过调用 target_appimage() 来完成 appimage 的目标创建
  13. # 3. 对于 linuxdeploy 目标,大致上就是通过执行 linuxdeployqt 命令与 -appimage
  14. # 参数来创建可用于 Appimage 打包的内容结构,并且使用一些参数来处理相关库的依赖。
  15. # 其次就是,将 spark-appimage.desktop 复制为 default.desktop
  16. # 另一个就是 spark-appimage.png 复制为 default.png
  17. # 4. 对于 appimage 目标,大致上就是通过执行 appimagetool 命令将准备好打包的目录
  18. # 结构进行打包为 Appimage 可执行文件,其中为了避免可能缺失的文件,重复了对
  19. # default.desktop 文件与 default.png 文件的生成。
  20. # 这是一个依赖的 copy-desktop-appimage 目标,并先行执行
  21. # if ()
  22. set(APPIMAGE_OUTPUT "${CMAKE_BINARY_DIR}/appimage")
  23. set(APPIMAGE_ICON "${APPIMAGE_OUTPUT}/default.png")
  24. set(APPIMAGE_DESTKOP "${APPIMAGE_OUTPUT}/default.desktop")
  25. # set(LINUXDEPLOYQT)
  26. # set(APPIMAGETOOL)
  27. function(execute_linuxdeploy _PATH)
  28. execute_process(COMMAND ${LINUXDEPLOYQT}
  29. WORKING_DIRECTORY "${APPIMAGE_OUTPUT}"
  30. )
  31. endfunction(execute_linuxdeploy _PATH)
  32. function(target_linuxdeploy)
  33. add_custom_target(linuxdeploy pwd
  34. BYPRODUCTS appimage
  35. COMMAND cp ../${PROJECT_NAME} .
  36. COMMAND "${LINUXDEPLOYQT}" ${PROJECT_NAME} -appimage -unsupported-allow-new-glibc -verbose=3 -no-strip|| true
  37. COMMAND cp ../spark-appimage.desktop default.desktop
  38. COMMAND cp ../spark-appimage.png default.png
  39. WORKING_DIRECTORY "${APPIMAGE_OUTPUT}")
  40. endfunction(target_linuxdeploy)
  41. function(target_appimage)
  42. add_custom_target(copy-desktop-appimage
  43. COMMAND cp ../spark-appimage.desktop default.desktop
  44. COMMAND cp ../spark-appimage.png default.png
  45. WORKING_DIRECTORY "${APPIMAGE_OUTPUT}")
  46. add_custom_target(appimage pwd
  47. COMMAND ${APPIMAGETOOL} ${APPIMAGE_OUTPUT}
  48. WORKING_DIRECTORY "${CMAKE_BINARY_DIR}"
  49. DEPENDS copy-desktop-appimage)
  50. endfunction(target_appimage)
  51. function(add_appimage)
  52. # check linuxdeploy
  53. if(NOT DEFINED LINUXDEPLOYQT)
  54. message("AppImage> Not Found LINUXDEPLOYQT Variable!")
  55. return()
  56. endif(NOT DEFINED LINUXDEPLOYQT)
  57. if(CMAKE_VERSION VERSION_LESS 3.19 AND NOT EXISTS ${LINUXDEPLOYQT})
  58. message("> cmake version is less than 3.19")
  59. message(WARNING "!Relative paths are not supported!")
  60. else()
  61. file(REAL_PATH ${LINUXDEPLOYQT} LINUXDEPLOYQT_REAL_PATH)
  62. endif(CMAKE_VERSION VERSION_LESS 3.19 AND NOT EXISTS ${LINUXDEPLOYQT})
  63. message("AppImage> Found LINUXDEPLOYQT Variable: ${LINUXDEPLOYQT_REAL_PATH}")
  64. # check appimagetool
  65. if(NOT DEFINED APPIMAGETOOL)
  66. message("AppImage> Not Found APPIMAGETOOL Variable!")
  67. return()
  68. endif(NOT DEFINED APPIMAGETOOL)
  69. if(CMAKE_VERSION VERSION_LESS 3.19 AND NOT EXISTS ${LINUXDEPLOYQT})
  70. # execute_process(COMMAND realpath ${APPIMAGETOOL} OUTPUT_VARIABLE APPIMAGETOOL_REAL_PATH)
  71. message("> cmake version is less than 3.19")
  72. message(WARNING "!Relative paths are not supported!")
  73. else()
  74. file(REAL_PATH ${APPIMAGETOOL} APPIMAGETOOL_REAL_PATH)
  75. endif(CMAKE_VERSION VERSION_LESS 3.19 AND NOT EXISTS ${LINUXDEPLOYQT})
  76. message("AppImage> Found APPIMAGETOOL Variable: ${LINUXDEPLOYQT_REAL_PATH}")
  77. # do add_custome_target
  78. make_directory(${APPIMAGE_OUTPUT})
  79. target_linuxdeploy()
  80. target_appimage()
  81. endfunction(add_appimage)
  82. function(add_appimage_desktop)
  83. configure_file(cmake/spark-appimage.desktop.in
  84. ${CMAKE_BINARY_DIR}/spark-appimage.desktop @ONLY)
  85. endfunction(add_appimage_desktop)
  86. function(add_appimage_icon _ICON_PATH)
  87. if(CMAKE_VERSION VERSION_LESS 3.21)
  88. message("> cmake version is less than 3.21")
  89. configure_file(${_ICON_PATH} ${CMAKE_BINARY_DIR}/spark-appimage.png COPYONLY)
  90. else()
  91. file(COPY_FILE ${_ICON_PATH} ${CMAKE_BINARY_DIR}/spark-appimage.png)
  92. endif(CMAKE_VERSION VERSION_LESS 3.21)
  93. endfunction(add_appimage_icon _ICON_PATH)
  94. # 如果glic>=2.27,你就需要加上参数 -unsupported-allow-new-glibc (意思就是不再低版本发行版使用了)
  95. # 或 -unsupported-bundle-everything(大概的意思是尝试兼容,实际测试,到其他发行版直接用不了了,有可能是发行版的原因,还是建议用前者,虽然放弃了低版本)
  96. # -unsupported-bundle-everything
  97. # 捆绑所有依赖库,包括 ld-linux.so 加载器和 glibc。这将允许构建在较新系统上的应用程序在较旧的目标系统上运行,但不建议这样做,因为它会导致捆绑包超出所需的大小(并且可能到其他发行版无法使用)
  98. # -unsupported-allow-new-glibc
  99. # 允许 linuxdeployqt 在比仍受支持的最旧 Ubuntu LTS 版本更新的发行版上运行。这将导致 AppImage无法在所有仍受支持的发行版上运行,既不推荐也不测试或支持
  100. # ./linuxdeployqt-7-x86_64.AppImage 程序目录/程序 -appimage -unsupported-allow-new-glibc
  101. # ./linuxdeployqt-7-x86_64.AppImage 程序目录/程序 -appimage -unsupported-bundle-everything
  102. # 1. 在顶层构建中导入 Appimage 的构建
  103. # include(cmake/SparkAppimageConfig.cmake) # 导入来自 Spark 构建的 Appimage 构建
  104. # add_appimage_icon(assets/spark.png) # 添加到 Appimage 中的默认的图标
  105. # add_appimage_desktop() # 添加到 Appimage 中的默认desktop(使用来自 Spark 构建的 Desktop 构建中配置的信息(必须要求 spark-desktop))
  106. # add_appimage() # 应用对 Appimage 的构建
  107. # 2. 在 Makefile 进行构建目标构建 Appimage 的构建流 --
  108. # 在 Makefile 进行构建目标构建 Appimage (要求提供工具的绝对路径,然后可依次进行linuxdeployqt, genrate-appimage)
  109. # 来自于 https://github.com/probonopd/linuxdeployqt 的 linuxdeployqt
  110. # 来自于 https://github.com/AppImage/AppImageKit 的 appimagetool
  111. # 来自于 https://gitlink.org.cn/zinface/bundle-linuxdeployqt.git 托管存储的工具
  112. # 或指定你所想存放克隆项目的位置
  113. # BUNDLE_LINUXDEPLOYQT := $(shell pwd)/build/bundle-linuxdeployqt
  114. # download-bundle-linuxdeploytools:
  115. # -git clone https://gitlink.org.cn/zinface/bundle-linuxdeployqt.git $(BUNDLE_LINUXDEPLOYQT)
  116. # LINUXDEPLOYQT := "$(BUNDLE_LINUXDEPLOYQT)/linuxdeployqt-continuous-x86_64.AppImage"
  117. # APPIMAGETOOL := "$(BUNDLE_LINUXDEPLOYQT)/appimagetool-x86_64.AppImage"
  118. # linuxdeploy: release download-bundle-linuxdeploytools
  119. # cd build && cmake .. -DLINUXDEPLOYQT=$(LINUXDEPLOYQT) -DAPPIMAGETOOL=$(APPIMAGETOOL)
  120. # cd build && make linuxdeploy
  121. # genrate-appimage:
  122. # cd build && cmake .. -DLINUXDEPLOYQT=$(LINUXDEPLOYQT) -DAPPIMAGETOOL=$(APPIMAGETOOL)
  123. # cd build && make appimage