mirror of
https://github.com/rizinorg/cutter.git
synced 2025-01-07 04:25:25 +00:00
Run macos packaging in GHA. (#2529)
* Enable running of macOS packaging in GHA, most of the work done in dedbabde56
* Cleanup breakpad handling
* Have single version of main executable in folder expected by macOS and most tools instead of executable+symlink+shell script
* Handle Breakpad library lookup in more CMake way using FindBreakpad just like it's done on other platforms and packages
* Refactor error handling in some of the shell scripts to use `set -e` instead of `|| exit 1` for each command.
* Fix DMG background setup
This commit is contained in:
parent
276b53fd75
commit
29cbd06ab2
10
.github/workflows/ccpp.yml
vendored
10
.github/workflows/ccpp.yml
vendored
@ -165,9 +165,9 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
scripts/fetch_deps.sh
|
scripts/fetch_deps.sh
|
||||||
source cutter-deps/env.sh
|
source cutter-deps/env.sh
|
||||||
|
set -euo pipefail
|
||||||
export PATH=/usr/local/opt/llvm/bin:$PATH
|
export PATH=/usr/local/opt/llvm/bin:$PATH
|
||||||
source scripts/prepare_breakpad_macos.sh
|
source scripts/prepare_breakpad_macos.sh
|
||||||
export PKG_CONFIG_PATH="$CUSTOM_BREAKPAD_PREFIX/lib/pkgconfig:$CUSTOM_PYTHON_PREFIX/lib/pkgconfig:$PKG_CONFIG_PATH"
|
|
||||||
mkdir build
|
mkdir build
|
||||||
cd build
|
cd build
|
||||||
cmake \
|
cmake \
|
||||||
@ -180,9 +180,15 @@ jobs:
|
|||||||
-DCUTTER_ENABLE_CRASH_REPORTS=ON \
|
-DCUTTER_ENABLE_CRASH_REPORTS=ON \
|
||||||
-DCUTTER_USE_BUNDLED_RIZIN=ON \
|
-DCUTTER_USE_BUNDLED_RIZIN=ON \
|
||||||
-DCUTTER_ENABLE_PACKAGING=ON \
|
-DCUTTER_ENABLE_PACKAGING=ON \
|
||||||
-DBREAKPAD_FRAMEWORK_DIR="$BREAKPAD_FRAMEWORK_DIR" \
|
-DCUTTER_PACKAGE_DEPENDENCIES=ON \
|
||||||
|
-DCUTTER_ENABLE_DEPENDENCY_DOWNLOADS=ON \
|
||||||
|
-DCUTTER_PACKAGE_RZ_GHIDRA=ON \
|
||||||
|
-DCMAKE_FRAMEWORK_PATH="$BREAKPAD_FRAMEWORK_DIR" \
|
||||||
.. && \
|
.. && \
|
||||||
make -j4;
|
make -j4;
|
||||||
|
make package
|
||||||
|
export CUTTER_VERSION=$(python3 ../scripts/get_version.py)
|
||||||
|
echo PACKAGE_NAME=Cutter-${CUTTER_VERSION}-Darwin.dmg >> $GITHUB_ENV
|
||||||
- name: windows dependencies
|
- name: windows dependencies
|
||||||
if: contains(matrix.os, 'windows')
|
if: contains(matrix.os, 'windows')
|
||||||
shell: bash
|
shell: bash
|
||||||
|
@ -6,8 +6,16 @@ if(WIN32)
|
|||||||
set(CMAKE_INSTALL_DATAROOTDIR "./" CACHE PATH "Resource installation directory")
|
set(CMAKE_INSTALL_DATAROOTDIR "./" CACHE PATH "Resource installation directory")
|
||||||
set(CUTTER_INSTALL_DATADIR "${CMAKE_INSTALL_DATAROOTDIR}" CACHE PATH "Resource installation directory")
|
set(CUTTER_INSTALL_DATADIR "${CMAKE_INSTALL_DATAROOTDIR}" CACHE PATH "Resource installation directory")
|
||||||
elseif(APPLE)
|
elseif(APPLE)
|
||||||
include(GNUInstallDirs) #TODO: use appropriate paths for macOS
|
if (CUTTER_ENABLE_PACKAGING)
|
||||||
set(CUTTER_INSTALL_DATADIR "${CMAKE_INSTALL_DATAROOTDIR}/${CUTTER_DIR_NAME}" CACHE PATH "Resource installation directory")
|
set(CMAKE_INSTALL_INCLUDEDIR "include" CACHE PATH "Include install directory")
|
||||||
|
set(CMAKE_INSTALL_LIBDIR "lib" CACHE PATH "Library install directory")
|
||||||
|
set(CMAKE_INSTALL_DATAROOTDIR "./" CACHE PATH "Resource installation directory")
|
||||||
|
set(CMAKE_INSTALL_BINDIR "../MacOS" CACHE PATH "Executable install directory") # BUNDLE step sets prefix to Resources
|
||||||
|
set(CUTTER_INSTALL_DATADIR "${CMAKE_INSTALL_DATAROOTDIR}" CACHE PATH "Resource installation directory")
|
||||||
|
else()
|
||||||
|
include(GNUInstallDirs)
|
||||||
|
set(CUTTER_INSTALL_DATADIR "${CMAKE_INSTALL_DATAROOTDIR}/${CUTTER_DIR_NAME}" CACHE PATH "Resource installation directory")
|
||||||
|
endif()
|
||||||
else()
|
else()
|
||||||
include(GNUInstallDirs)
|
include(GNUInstallDirs)
|
||||||
set(CUTTER_INSTALL_DATADIR "${CMAKE_INSTALL_DATAROOTDIR}/${CUTTER_DIR_NAME}" CACHE PATH "Resource installation directory")
|
set(CUTTER_INSTALL_DATADIR "${CMAKE_INSTALL_DATAROOTDIR}/${CUTTER_DIR_NAME}" CACHE PATH "Resource installation directory")
|
||||||
|
@ -33,6 +33,11 @@ if(WIN32)
|
|||||||
set (Breakpad_LINK_LIBRARIES ${Breakpad_LIBRARIES})
|
set (Breakpad_LINK_LIBRARIES ${Breakpad_LIBRARIES})
|
||||||
|
|
||||||
set(Breakpad_LIBRARY_DIRS "")
|
set(Breakpad_LIBRARY_DIRS "")
|
||||||
|
elseif(APPLE)
|
||||||
|
find_library(Breakpad_LINK_LIBRARIES Breakpad REQUIRED)
|
||||||
|
set(Breakpad_LIBRARIES ${Breakpad_LINK_LIBRARIES})
|
||||||
|
# Assumes Breakpad is packed as Framework
|
||||||
|
set(Breakpad_INCLUDE_DIRS "${Breakpad_LINK_LIBRARIES}/Headers")
|
||||||
else()
|
else()
|
||||||
set(Breakpad_CMAKE_PREFIX_PATH_TEMP ${CMAKE_PREFIX_PATH})
|
set(Breakpad_CMAKE_PREFIX_PATH_TEMP ${CMAKE_PREFIX_PATH})
|
||||||
list(APPEND CMAKE_PREFIX_PATH "${CMAKE_CURRENT_SOURCE_DIR}/Breakpad/prefix")
|
list(APPEND CMAKE_PREFIX_PATH "${CMAKE_CURRENT_SOURCE_DIR}/Breakpad/prefix")
|
||||||
|
24
dist/CMakeLists.txt
vendored
24
dist/CMakeLists.txt
vendored
@ -45,16 +45,29 @@ if(APPLE)
|
|||||||
configure_file("${CMAKE_CURRENT_SOURCE_DIR}/macos/Info.plist.in" "${CMAKE_CURRENT_BINARY_DIR}/macos/Info.plist")
|
configure_file("${CMAKE_CURRENT_SOURCE_DIR}/macos/Info.plist.in" "${CMAKE_CURRENT_BINARY_DIR}/macos/Info.plist")
|
||||||
set(CPACK_BUNDLE_PLIST "${CMAKE_CURRENT_BINARY_DIR}/macos/Info.plist")
|
set(CPACK_BUNDLE_PLIST "${CMAKE_CURRENT_BINARY_DIR}/macos/Info.plist")
|
||||||
set(CPACK_BUNDLE_ICON "${CMAKE_CURRENT_SOURCE_DIR}/macos/cutter.icns")
|
set(CPACK_BUNDLE_ICON "${CMAKE_CURRENT_SOURCE_DIR}/macos/cutter.icns")
|
||||||
|
set(CPACK_DMG_BACKGROUND_IMAGE "${CMAKE_CURRENT_SOURCE_DIR}/macos/cutter_mac_app.png")
|
||||||
|
set(CPACK_DMG_DS_STORE "${CMAKE_CURRENT_SOURCE_DIR}/macos/DS_Store_ForDMGBackground")
|
||||||
|
|
||||||
|
|
||||||
find_program(MACDEPLOYQT_PATH macdeployqt HINTS "${Qt5_DIR}/../../../bin")
|
find_program(MACDEPLOYQT_PATH macdeployqt HINTS "${Qt5_DIR}/../../../bin")
|
||||||
if(NOT MACDEPLOYQT_PATH)
|
if(NOT MACDEPLOYQT_PATH)
|
||||||
message(FATAL_ERROR "Failed to find macdeployqt")
|
message(FATAL_ERROR "Failed to find macdeployqt")
|
||||||
endif()
|
endif()
|
||||||
set(CUTTER_SH_PATH "${CMAKE_CURRENT_SOURCE_DIR}/macos/Cutter.sh")
|
|
||||||
unset(ADJUST_RIZIN_LIBS)
|
unset(ADJUST_RIZIN_LIBS)
|
||||||
foreach(_lib ${RZ_LIBS})
|
foreach(_lib ${RZ_LIBS})
|
||||||
list(APPEND ADJUST_RIZIN_LIBS "${RIZIN_INSTALL_DIR}/lib/lib${_lib}.dylib")
|
list(APPEND ADJUST_RIZIN_LIBS "${RIZIN_INSTALL_DIR}/lib/lib${_lib}.dylib")
|
||||||
endforeach()
|
endforeach()
|
||||||
|
|
||||||
|
if(CUTTER_PACKAGE_DEPENDENCIES AND CUTTER_ENABLE_PYTHON)
|
||||||
|
set(EMBED_PYTHON_SH "${CMAKE_CURRENT_SOURCE_DIR}/appbundle_embed_python.sh")
|
||||||
|
set(PYTHON_FRAMEWORK_DIR "${CUTTER_DEPS}/python/Python.framework")
|
||||||
|
set(PYSIDE_PREFIX "${CUTTER_DEPS}/pyside")
|
||||||
|
configure_file("${CMAKE_CURRENT_SOURCE_DIR}/MacOSBundlePython.cmake.in"
|
||||||
|
"${CMAKE_CURRENT_BINARY_DIR}/MacOSBundlePython.cmake" @ONLY)
|
||||||
|
install(SCRIPT "${CMAKE_CURRENT_BINARY_DIR}/MacOSBundlePython.cmake")
|
||||||
|
endif()
|
||||||
|
|
||||||
configure_file("${CMAKE_CURRENT_SOURCE_DIR}/MacOSSetupBundle.cmake.in"
|
configure_file("${CMAKE_CURRENT_SOURCE_DIR}/MacOSSetupBundle.cmake.in"
|
||||||
"${CMAKE_CURRENT_BINARY_DIR}/MacOSSetupBundle.cmake" @ONLY)
|
"${CMAKE_CURRENT_BINARY_DIR}/MacOSSetupBundle.cmake" @ONLY)
|
||||||
install(SCRIPT "${CMAKE_CURRENT_BINARY_DIR}/MacOSSetupBundle.cmake")
|
install(SCRIPT "${CMAKE_CURRENT_BINARY_DIR}/MacOSSetupBundle.cmake")
|
||||||
@ -63,14 +76,7 @@ if(APPLE)
|
|||||||
list(APPEND RZ_GHIDRA_PREFIX_PATH "${QT_PREFIX}")
|
list(APPEND RZ_GHIDRA_PREFIX_PATH "${QT_PREFIX}")
|
||||||
set(RIZIN_INSTALL_PLUGDIR "share/rizin/plugins") # escaped backslash on purpose, should be evaluated later
|
set(RIZIN_INSTALL_PLUGDIR "share/rizin/plugins") # escaped backslash on purpose, should be evaluated later
|
||||||
|
|
||||||
if(CUTTER_ENABLE_PYTHON)
|
|
||||||
set(EMBED_PYTHON_SH "${CMAKE_CURRENT_SOURCE_DIR}/appbundle_embed_python.sh")
|
|
||||||
set(PYTHON_FRAMEWORK_DIR "${CUTTER_DEPS}/python/Python.framework")
|
|
||||||
set(PYSIDE_PREFIX "${CUTTER_DEPS}/pyside")
|
|
||||||
configure_file("${CMAKE_CURRENT_SOURCE_DIR}/MacOSBundlePython.cmake.in"
|
|
||||||
"${CMAKE_CURRENT_BINARY_DIR}/MacOSBundlePython.cmake" @ONLY)
|
|
||||||
install(SCRIPT "${CMAKE_CURRENT_BINARY_DIR}/MacOSBundlePython.cmake")
|
|
||||||
endif()
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
################################################
|
################################################
|
||||||
|
2
dist/MacOSBundlePython.cmake.in
vendored
2
dist/MacOSBundlePython.cmake.in
vendored
@ -12,7 +12,7 @@ execute_process(COMMAND
|
|||||||
"${EMBED_PYTHON_SH}"
|
"${EMBED_PYTHON_SH}"
|
||||||
"${PYTHON_FRAMEWORK_DIR}"
|
"${PYTHON_FRAMEWORK_DIR}"
|
||||||
"${BUNDLE_PATH}"
|
"${BUNDLE_PATH}"
|
||||||
"${BUNDLE_PATH}/MacOS/Cutter.bin"
|
"${BUNDLE_PATH}/Contents/MacOS/Cutter"
|
||||||
RESULT_VARIABLE SCRIPT_RESULT)
|
RESULT_VARIABLE SCRIPT_RESULT)
|
||||||
if(SCRIPT_RESULT)
|
if(SCRIPT_RESULT)
|
||||||
message(FATAL_ERROR "Failed to bundle python")
|
message(FATAL_ERROR "Failed to bundle python")
|
||||||
|
49
dist/MacOSSetupBundle.cmake.in
vendored
49
dist/MacOSSetupBundle.cmake.in
vendored
@ -1,8 +1,12 @@
|
|||||||
|
include(BundleUtilities)
|
||||||
|
|
||||||
set(MACDEPLOYQT_PATH "@MACDEPLOYQT_PATH@")
|
set(MACDEPLOYQT_PATH "@MACDEPLOYQT_PATH@")
|
||||||
set(INFO_PLIST_PATH "@CPACK_BUNDLE_PLIST@")
|
set(INFO_PLIST_PATH "@CPACK_BUNDLE_PLIST@")
|
||||||
set(CUTTER_SH_PATH "@CUTTER_SH_PATH@")
|
|
||||||
set(ADJUST_RIZIN_LIBS "@ADJUST_RIZIN_LIBS@")
|
set(ADJUST_RIZIN_LIBS "@ADJUST_RIZIN_LIBS@")
|
||||||
|
set(CUTTER_ENABLE_CRASH_REPORTS "@CUTTER_ENABLE_CRASH_REPORTS@")
|
||||||
|
set(Breakpad_LINK_LIBRARIES "@Breakpad_LINK_LIBRARIES@")
|
||||||
|
set(CUTTER_PACKAGE_DEPENDENCIES "@CUTTER_PACKAGE_DEPENDENCIES@")
|
||||||
|
set(CUTTER_ENABLE_PYTHON "@CUTTER_ENABLE_PYTHON@")
|
||||||
|
|
||||||
macro(run_or_die)
|
macro(run_or_die)
|
||||||
execute_process(${ARGV} RESULT_VARIABLE PROC_RESULT)
|
execute_process(${ARGV} RESULT_VARIABLE PROC_RESULT)
|
||||||
@ -13,25 +17,33 @@ endmacro()
|
|||||||
|
|
||||||
get_filename_component(BUNDLE_PATH "${CMAKE_INSTALL_PREFIX}/../.." ABSOLUTE)
|
get_filename_component(BUNDLE_PATH "${CMAKE_INSTALL_PREFIX}/../.." ABSOLUTE)
|
||||||
set(EXECUTABLE_DIR "${BUNDLE_PATH}/Contents/MacOS")
|
set(EXECUTABLE_DIR "${BUNDLE_PATH}/Contents/MacOS")
|
||||||
file(MAKE_DIRECTORY "${EXECUTABLE_DIR}")
|
set(FRAMEWORK_DIR "${BUNDLE_PATH}/Contents/Frameworks")
|
||||||
# Move the executable from Resources/bin/Cutter to MacOS/Cutter
|
|
||||||
# macdeployqt can't handle anything else
|
|
||||||
file(RENAME "${CMAKE_INSTALL_PREFIX}/bin/Cutter" "${EXECUTABLE_DIR}/Cutter")
|
|
||||||
# Make a symlink from the original location so CutterConfig.cmake won't be broken
|
|
||||||
run_or_die(COMMAND ${CMAKE_COMMAND} -E create_symlink "../../MacOS/Cutter.bin" "${CMAKE_INSTALL_PREFIX}/bin/Cutter")
|
|
||||||
|
|
||||||
# Copying the Info.plist will be done later again by CPack but we need it a bit earlier
|
# Copying the Info.plist will be done later again by CPack but we need it a bit earlier
|
||||||
# so macdeployqt has enough info.
|
# so macdeployqt has enough info.
|
||||||
file(COPY "${INFO_PLIST_PATH}" DESTINATION "${BUNDLE_PATH}/Contents")
|
file(COPY "${INFO_PLIST_PATH}" DESTINATION "${BUNDLE_PATH}/Contents")
|
||||||
|
|
||||||
|
# replace absolute path from build directory in rizin pkgconfig files with relative ones
|
||||||
|
file(GLOB RZ_PCFILES "${CMAKE_INSTALL_PREFIX}/lib/pkgconfig/rz_*.pc")
|
||||||
|
list(APPEND RZ_PCFILES "${CMAKE_INSTALL_PREFIX}/lib/pkgconfig/librz.pc")
|
||||||
|
foreach (_pcfile ${RZ_PCFILES})
|
||||||
|
file(READ "${_pcfile}" _text)
|
||||||
|
string(REGEX REPLACE "^prefix=[^\n]*\n" "prefix=\${pcfiledir}/../..\n" _text "${_text}")
|
||||||
|
file(WRITE "${_pcfile}" "${_text}")
|
||||||
|
endforeach()
|
||||||
# macdeployqt would put the rz libraries into Contents/Frameworks by default, but we want to have them
|
# macdeployqt would put the rz libraries into Contents/Frameworks by default, but we want to have them
|
||||||
# only in the prefix, so we fix the paths manually.
|
# only in the prefix, so we fix the paths manually.
|
||||||
foreach(_lib ${ADJUST_RIZIN_LIBS})
|
foreach(_lib ${ADJUST_RIZIN_LIBS})
|
||||||
get_filename_component(_lib "${_lib}" REALPATH)
|
get_filename_component(_lib "${_lib}" REALPATH)
|
||||||
get_filename_component(_name "${_lib}" NAME)
|
get_filename_component(_name "${_lib}" NAME)
|
||||||
|
# Cutter reference to lib
|
||||||
run_or_die(COMMAND install_name_tool
|
run_or_die(COMMAND install_name_tool
|
||||||
-change "${_lib}" "@rpath/${_name}"
|
-change "${_lib}" "@rpath/${_name}"
|
||||||
"${EXECUTABLE_DIR}/Cutter")
|
"${EXECUTABLE_DIR}/Cutter")
|
||||||
|
# lib LC_ID_DYLIB
|
||||||
|
run_or_die(COMMAND install_name_tool
|
||||||
|
-id "@rpath/${_name}"
|
||||||
|
"${CMAKE_INSTALL_PREFIX}/lib/${_name}")
|
||||||
# Fix every lib for every lib too
|
# Fix every lib for every lib too
|
||||||
foreach(_lib2 ${ADJUST_RIZIN_LIBS})
|
foreach(_lib2 ${ADJUST_RIZIN_LIBS})
|
||||||
get_filename_component(_lib2 "${_lib2}" REALPATH)
|
get_filename_component(_lib2 "${_lib2}" REALPATH)
|
||||||
@ -50,10 +62,17 @@ run_or_die(COMMAND install_name_tool
|
|||||||
-add_rpath "@executable_path/../Resources/lib"
|
-add_rpath "@executable_path/../Resources/lib"
|
||||||
"${EXECUTABLE_DIR}/Cutter")
|
"${EXECUTABLE_DIR}/Cutter")
|
||||||
|
|
||||||
set(MACDEPLOYQT_COMMAND "${MACDEPLOYQT_PATH}" "${BUNDLE_PATH}" "-libpath=${CMAKE_INSTALL_PREFIX}/lib")
|
set(MACDEPLOYQT_COMMAND "${MACDEPLOYQT_PATH}" "${BUNDLE_PATH}" "-verbose=2" "-libpath=${CMAKE_INSTALL_PREFIX}/lib")
|
||||||
message("Running macdeployqt \"${MACDEPLOYQT_COMMAND}\"")
|
message("Running macdeployqt \"${MACDEPLOYQT_COMMAND}\"")
|
||||||
run_or_die(COMMAND ${MACDEPLOYQT_COMMAND})
|
run_or_die(COMMAND ${MACDEPLOYQT_COMMAND}) # First run
|
||||||
run_or_die(COMMAND ${MACDEPLOYQT_COMMAND})
|
if (CUTTER_PACKAGE_DEPENDENCIES AND CUTTER_ENABLE_PYTHON)
|
||||||
|
file(REAL_PATH "${FRAMEWORK_DIR}/Python.framework/Python" _python_lib_path)
|
||||||
|
message("Python lib ${_python_lib_path}")
|
||||||
|
list(APPEND MACDEPLOYQT_COMMAND "-executable=${_python_lib_path}")
|
||||||
|
endif()
|
||||||
|
# Qt plugins are not getting deployed on first macdeployqt run. Runing twice helps.
|
||||||
|
# If python is added as additional executable in first run it also breaks plugin copying.
|
||||||
|
run_or_die(COMMAND ${MACDEPLOYQT_COMMAND}) # Second run
|
||||||
|
|
||||||
# Clean up the mess that macdeployqt made (duplicate rz libs, we only want the ones in the prefix)
|
# Clean up the mess that macdeployqt made (duplicate rz libs, we only want the ones in the prefix)
|
||||||
foreach(_lib ${ADJUST_RIZIN_LIBS})
|
foreach(_lib ${ADJUST_RIZIN_LIBS})
|
||||||
@ -62,8 +81,8 @@ foreach(_lib ${ADJUST_RIZIN_LIBS})
|
|||||||
file(REMOVE "${BUNDLE_PATH}/Contents/Frameworks/${_name}")
|
file(REMOVE "${BUNDLE_PATH}/Contents/Frameworks/${_name}")
|
||||||
endforeach()
|
endforeach()
|
||||||
|
|
||||||
# Replace main executable by Cutter.sh
|
if (CUTTER_ENABLE_CRASH_REPORTS)
|
||||||
file(RENAME "${EXECUTABLE_DIR}/Cutter" "${EXECUTABLE_DIR}/Cutter.bin")
|
message("Copying Breakpad ${Breakpad_LINK_LIBRARIES}")
|
||||||
file(COPY "${CUTTER_SH_PATH}" DESTINATION "${EXECUTABLE_DIR}")
|
set(_breakpad_lib "Versions/A/Breakpad")
|
||||||
file(RENAME "${EXECUTABLE_DIR}/Cutter.sh" "${EXECUTABLE_DIR}/Cutter")
|
copy_resolved_framework_into_bundle("${Breakpad_LINK_LIBRARIES}/${_breakpad_lib}" "${FRAMEWORK_DIR}/Breakpad.framework/${_breakpad_lib}")
|
||||||
|
endif()
|
||||||
|
33
dist/appbundle_embed_python.sh
vendored
33
dist/appbundle_embed_python.sh
vendored
@ -1,5 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -euo pipefail
|
||||||
if ! [[ $# -eq 3 ]]; then
|
if ! [[ $# -eq 3 ]]; then
|
||||||
echo "Usage: $0 [Python.framework] [AppBundle.app] [AppBundle.app/Contents/MacOS/Executable]"
|
echo "Usage: $0 [Python.framework] [AppBundle.app] [AppBundle.app/Contents/MacOS/Executable]"
|
||||||
exit 1
|
exit 1
|
||||||
@ -11,19 +12,24 @@ py_framework=$1
|
|||||||
appbundle=$2
|
appbundle=$2
|
||||||
executable=$3
|
executable=$3
|
||||||
|
|
||||||
echo "Embedding $py_framework into $appbundle"
|
echo "Embedding $py_framework into $appbundle | $executable"
|
||||||
|
|
||||||
mkdir -p "$appbundle/Contents/Frameworks" || exit 1
|
mkdir -p "$appbundle/Contents/Frameworks"
|
||||||
cp -a "$py_framework" "$appbundle/Contents/Frameworks/" || exit 1
|
if [ ! -d "$appbundle/Contents/Frameworks/Python.framework" ]
|
||||||
|
then
|
||||||
|
cp -a -n "$py_framework" "$appbundle/Contents/Frameworks/"
|
||||||
|
echo "Cleaning up embedded Python Framework"
|
||||||
|
cd "$appbundle/Contents/Frameworks/Python.framework"
|
||||||
|
find . | grep -E "(__pycache__|\.pyc|\.pyo$)" | xargs rm -rf
|
||||||
|
rm -r Versions/Current/Resources/* "Versions/Current/lib/$python_version/test" "Versions/Current/lib/$python_version/idlelib" "Versions/Current/lib/$python_version/curses" "Versions/Current/lib/$python_version/lib2to3" || echo "Couldn't remove something"
|
||||||
|
else
|
||||||
|
echo "Python.framework already exists, skipping copying"
|
||||||
|
cd "$appbundle/Contents/Frameworks/Python.framework"
|
||||||
|
fi
|
||||||
|
|
||||||
echo "Making executable $executable point to embedded Framework"
|
echo "Making executable $executable point to embedded Framework"
|
||||||
install_name_tool -change `otool -L "$executable" | sed -n "s/^[[:blank:]]*\([^[:blank:]]*Python\) (.*$/\1/p"` @executable_path/../Frameworks/Python.framework/Versions/Current/Python "$executable"
|
install_name_tool -change `otool -L "$executable" | sed -n "s/^[[:blank:]]*\([^[:blank:]]*Python\) (.*$/\1/p"` @executable_path/../Frameworks/Python.framework/Versions/Current/Python "$executable"
|
||||||
|
|
||||||
echo "Cleaning up embedded Python Framework"
|
|
||||||
cd "$appbundle/Contents/Frameworks/Python.framework" || exit 1
|
|
||||||
find . | grep -E "(__pycache__|\.pyc|\.pyo$)" | xargs rm -rf || exit 1
|
|
||||||
rm -r Versions/Current/Resources/* Versions/Current/lib/$python_version/test Versions/Current/lib/$python_version/idlelib Versions/Current/lib/$python_version/curses Versions/Current/lib/$python_version/lib2to3 || exit 1
|
|
||||||
|
|
||||||
echo "Checking if PySide2 is available"
|
echo "Checking if PySide2 is available"
|
||||||
|
|
||||||
pyside_prefix=$(pkg-config --variable=prefix pyside2)
|
pyside_prefix=$(pkg-config --variable=prefix pyside2)
|
||||||
@ -34,7 +40,12 @@ fi
|
|||||||
|
|
||||||
echo "PySide is at $pyside_prefix"
|
echo "PySide is at $pyside_prefix"
|
||||||
|
|
||||||
cp -va "$pyside_prefix/lib/$python_version/" "Versions/Current/lib/$python_version" || exit 1
|
if [ ! -d "Versions/Current/lib/$python_version/site-packages/PySide2" ]
|
||||||
cd .. # $appbundle/Contents/Frameworks
|
then
|
||||||
cp -va "$pyside_prefix/lib/"*.dylib . || exit 1
|
cp -va "$pyside_prefix/lib/$python_version/" "Versions/Current/lib/$python_version"
|
||||||
|
cd .. # $appbundle/Contents/Frameworks
|
||||||
|
cp -va "$pyside_prefix/lib/"*.dylib .
|
||||||
|
else
|
||||||
|
echo "site-packages/Pyside2 exists, skipping copying"
|
||||||
|
fi
|
||||||
|
|
||||||
|
9
dist/macos/Cutter.sh
vendored
9
dist/macos/Cutter.sh
vendored
@ -1,9 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
echo "Cutter Launch Script for macOS 🥞"
|
|
||||||
|
|
||||||
HERE=$(dirname "$0")
|
|
||||||
PREFIX=$HERE/../Resources
|
|
||||||
export DYLD_LIBRARY_PATH="$PREFIX/lib"
|
|
||||||
export DYLD_FRAMEWORK_PATH="$PREFIX/lib"
|
|
||||||
"$HERE/Cutter.bin" "$@"
|
|
BIN
dist/macos/DS_Store_ForDMGBackground
vendored
Normal file
BIN
dist/macos/DS_Store_ForDMGBackground
vendored
Normal file
Binary file not shown.
@ -1,22 +1,24 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
SCRIPTPATH=$(realpath "$(dirname "${BASH_SOURCE[0]}")")
|
SCRIPTPATH=$(realpath "$(dirname "${BASH_SOURCE[0]}")")
|
||||||
|
|
||||||
DIR="$SCRIPTPATH/.."
|
DIR="$SCRIPTPATH/.."
|
||||||
cd "$DIR" || exit 1
|
cd "$DIR"
|
||||||
BREAKPAD_FRAMEWORK_DIR="$DIR/breakpad/framework"
|
BREAKPAD_FRAMEWORK_DIR="$DIR/breakpad/framework"
|
||||||
BREAKPAD_DUMP_SYMS_DIR="$DIR/breakpad/bin"
|
BREAKPAD_DUMP_SYMS_DIR="$DIR/breakpad/bin"
|
||||||
git clone https://github.com/google/breakpad.git || exit 1
|
git clone https://github.com/google/breakpad.git
|
||||||
mkdir $BREAKPAD_FRAMEWORK_DIR
|
mkdir $BREAKPAD_FRAMEWORK_DIR
|
||||||
mkdir $BREAKPAD_DUMP_SYMS_DIR
|
mkdir $BREAKPAD_DUMP_SYMS_DIR
|
||||||
cd breakpad || exit 1
|
cd breakpad
|
||||||
git checkout 4d550cceca107f36c4bc1ea1126b7d32cc50f424 || exit 1
|
git checkout 4d550cceca107f36c4bc1ea1126b7d32cc50f424
|
||||||
git apply "$SCRIPTPATH/breakpad_macos.patch" || exit 1
|
git apply "$SCRIPTPATH/breakpad_macos.patch"
|
||||||
cd src/client/mac/ && xcodebuild -sdk macosx || exit 1
|
cd src/client/mac/ && xcodebuild -sdk macosx
|
||||||
cp -R build/Release/Breakpad.framework "$BREAKPAD_FRAMEWORK_DIR" || exit 1
|
cp -R build/Release/Breakpad.framework "$BREAKPAD_FRAMEWORK_DIR"
|
||||||
|
|
||||||
cd $DIR/breakpad || exit 1
|
cd $DIR/breakpad
|
||||||
cp -R src/. framework/Breakpad.framework/Headers || exit 1
|
cp -R src/. framework/Breakpad.framework/Headers
|
||||||
|
|
||||||
export BREAKPAD_FRAMEWORK_DIR=$BREAKPAD_FRAMEWORK_DIR
|
export BREAKPAD_FRAMEWORK_DIR=$BREAKPAD_FRAMEWORK_DIR
|
||||||
cd $DIR
|
cd $DIR
|
||||||
|
@ -74,15 +74,11 @@ if(CUTTER_ENABLE_CRASH_REPORTS)
|
|||||||
target_link_libraries(Cutter PRIVATE Threads::Threads)
|
target_link_libraries(Cutter PRIVATE Threads::Threads)
|
||||||
|
|
||||||
add_definitions(-DCUTTER_ENABLE_CRASH_REPORTS)
|
add_definitions(-DCUTTER_ENABLE_CRASH_REPORTS)
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -g ")
|
if (NOT WIN32)
|
||||||
if(DEFINED BREAKPAD_FRAMEWORK_DIR)
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -g ")
|
||||||
include_directories("${BREAKPAD_FRAMEWORK_DIR}/Breakpad.framework/Headers")
|
|
||||||
set_target_properties(Cutter PROPERTIES LINK_FLAGS "-Wl,-F${BREAKPAD_FRAMEWORK_DIR}")
|
|
||||||
target_link_libraries(Cutter PRIVATE "-framework Breakpad")
|
|
||||||
else()
|
|
||||||
find_package(Breakpad REQUIRED)
|
|
||||||
target_link_libraries(Cutter PRIVATE Breakpad::client)
|
|
||||||
endif()
|
endif()
|
||||||
|
find_package(Breakpad REQUIRED)
|
||||||
|
target_link_libraries(Cutter PRIVATE Breakpad::client)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
target_link_libraries(Cutter PUBLIC ${QT_PREFIX}::Core ${QT_PREFIX}::Widgets ${QT_PREFIX}::Gui PRIVATE ${QT_PREFIX}::Svg ${QT_PREFIX}::Network)
|
target_link_libraries(Cutter PUBLIC ${QT_PREFIX}::Core ${QT_PREFIX}::Widgets ${QT_PREFIX}::Gui PRIVATE ${QT_PREFIX}::Svg ${QT_PREFIX}::Network)
|
||||||
|
Loading…
Reference in New Issue
Block a user