-
Notifications
You must be signed in to change notification settings - Fork 34
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
freecad mac app bundle ie. FreeCAD.app
runtime issue, cannot find the runtime dependency pyside2
#278
Comments
error messages after launching the
|
Hi @ipatch, |
i haven't done any work with the freecad tap or specifically this issue in a week or so. the holidays caught up with me so my time has been limited. if you're trying to install freecad using the tap provided formula ie. install all the freecad dependencies first
manually link [email protected] and [email protected]
then build freecad from source using the tap provided formula
|
I am currently looking at it. My build is broken on Mac, and still try to figuring out from where it comes. |
This PR #5316 in FreeCAD shall be helping a lot |
|
I'm able to build app bundle by using this workaround. However, when I tried to run it, it shows the following error.
Is there any solution to this issue? |
do you mind opening a new issue, just copy and paste what you go here? and can you post your brew setup, ie. the output of your are you using |
Thanks for the prompt response! I compiled it on my M1 laptop. After the successful build, here is my steps:
My
|
little update on this issue. i think the simple solution to getting the cmake build process to properly locate the pyside2 installation is to prepend the pyside installation bin to the path while running cmake. i tested a couple of cases where i had the pyside bin directory prepended (top entry) in my
when i add pyside2 to my path with the following,
and...
i see the below in the cmake report output...
not sure if this will resolve all the runtime related issues with pyside but seems like a step in the right direction. |
and i think this will help us with keg only deps in the freecad formula ie. pyside2 being keg only because of it's upstream pyside6 counterpart, so if this works then hopefully |
should help in getting closer to having |
another little update on this. a quick way to see if shiboken and pyside are setup properly for a cmake build is to open a pythone repl
import shiboken2
import PySide2
from PySide2 import QtCore i was running into some edge cases yesterday where i was able to import PySide2 but was not able to load any of the accompanying qt modules. i made certain that my shiboken2 and pyside2 installation are not linked. i got a build going right now (non mac bundle) that seems to have picked up on my shiboken and pyside installations on a m1 mac. however i did have to add a and if i understand everything correctly, running the so not entirely sure i can add the a little q/a about the |
feeling confident this issue should be resolved with the below commit if anybody experiences any issues feel to search the open issues and leave comment if something comes up or if your issue is completely separate, please open a new issue. i believe adding the below lines to the freecad.rb formula resolved this issue at least in all my local testing. homebrew-freecad/Formula/freecad.rb Lines 139 to 141 in addab68
|
did a the quick fix is to manually create one quick test is to run the below cmd.
should open the the python3 REPL that is installed via homebrew and which freecad relies upon, and then attempt to import both shiboken2 and pyside2 with the below commands
got my bottle installation of freecad v0.20.1 going. obviously this far from perfect, and more work will be required to get all this ironed out for future bottled releases. |
little update on this, attempting to build a FreeCAD.app bundle built around python v3.12 and at v5 (jan 12 2025) using the freecad v1.0.0 git tag. presently after running
to resolve the above mentioned defined in this comment the below snippet can be added to the offending
and
|
the below snippet the previous mentioned set(FC_BUNDLE_PY312_DIR "${HOMEBREW_PREFIX}/opt/fc_bundle_py312/lib/python3.12/site-packages")
file(GLOB HOMEBREW_PTH_FILES
"${PYTHON_DIR}/site-packages/homebrew*.pth"
"${FC_BUNDLE_PY312_DIR}/*.pth")
message(STATUS "--ipatch:------------------------------------")
message(STATUS "HOMEBREW_PTH_FILES is set to: ${HOMEBREW_PTH_FILES}")
# NOTE: iaptch, no pth files are detected due to non existent dir
message(STATUS "--ipatch:------------------------------------")
foreach(PTH_FILE ${HOMEBREW_PTH_FILES})
file(READ ${PTH_FILE} ADDITIONAL_DIR)
string(STRIP "${ADDITIONAL_DIR}" ADDITIONAL_DIR)
string(FIND "${ADDITIONAL_DIR}" "${HOMEBREW_PREFIX}/Cellar" POSITION)
string(LENGTH "${ADDITIONAL_DIR}" DIR_LENGTH)
string(SUBSTRING "${ADDITIONAL_DIR}" ${POSITION} ${DIR_LENGTH}-${POSITION} DIR_TAIL)
string(REGEX MATCHALL "^([/A-Za-z0-9_.@-]+)" CLEAR_TAIL ${DIR_TAIL})
string(REGEX REPLACE "^${HOMEBREW_PREFIX}/Cellar/([A-Za-z0-9_]+).*$" "\\1" LIB_NAME ${CLEAR_TAIL})
string(REGEX REPLACE ".*libexec(.*)/site-packages" "libexec/${LIB_NAME}\\1" NEW_SITE_DIR ${CLEAR_TAIL})
install(DIRECTORY ${CLEAR_TAIL} DESTINATION ${CMAKE_INSTALL_PREFIX}/${NEW_SITE_DIR})
#update the paths of the .pth files copied into the bundle
get_filename_component(PTH_FILENAME ${PTH_FILE} NAME)
install(CODE
"file(WRITE
${CMAKE_INSTALL_LIBDIR}/${PYTHON_DIR_BASENAME}/site-packages/${PTH_FILENAME}
\"../../../${NEW_SITE_DIR}/site-packages\"
)"
)
endforeach(PTH_FILE) yields something like, ╭─chris ssh mac-mini-fpa in /Users/chris/code/freecad-git/builds/1.0.0_py312
╰─λ fd --hidden --no-ignore --follow site-packages ../../installs/1.0.0/FreeCAD.app/ 0 (4.178s)
../../installs/1.0.0/FreeCAD.app/Contents/Users/chris/homebrew/Cellar/[email protected]_py312/4.0.3_1/lib/python3.12/site-packages/
../../installs/1.0.0/FreeCAD.app/Contents/lib/python3.12/site-packages/
╭─chris ssh mac-mini-fpa in /Users/chris/code/freecad-git/builds/1.0.0_py312
╰─λ l ../../installs/1.0.0/FreeCAD.app/Contents/lib/python3.12/site-packages/freecad-py-modules.pth 0 (0.056s)
-rw-rw-rw-@ 1 chris staff 108B Jan 12 18:13 ../../installs/1.0.0/FreeCAD.app/Contents/lib/python3.12/site-packages/freecad-py-modules.pth
╭─chris ssh mac-mini-fpa in /Users/chris/code/freecad-git/builds/1.0.0_py312
╰─λ cat ../../installs/1.0.0/FreeCAD.app/Contents/lib/python3.12/site-packages/freecad-py-modules.pth 0 (0.017s)
../../..//Users/chris/homebrew/Cellar/[email protected]_py312/4.0.3_1/lib/python3.12/site-packages//site-packages⏎
╭─chris ssh mac-mini-fpa in /Users/chris/code/freecad-git/builds/1.0.0_py312
╰─λ # TODO: update cmake logic for mac app bundling to properly copy the necessary python modules into the app bundle 0 (0.010s)
╭─chris ssh mac-mini-fpa in /Users/chris/code/freecad-git/builds/1.0.0_py312
╰─λ # NOTE: maybe first just attempt to manually copy the modules 0 (0.010s)
╭─chris ssh mac-mini-fpa in /Users/chris/code/freecad-git/builds/1.0.0_py312
╰─λ 0 (0.010s)
which is no good. |
presently running
brew install freecad
should either install freecad from one of the provided bottles for catalina or big sur. if running a different OS ie. mojave or monterey then freecad will have to be build from source locally.so depending how the dependencies are setup ie.
[email protected]
freecad will fail to load the pyside2 runtime dep when launching the FreeCAD gui when double clicking the app bundle. ie.FreeCAD.app
.presently, either
pyside@2
or the tap provided[email protected]
need to be manually linked before runningand the runtime issue should be resolved, but haven't fully tested.
the CI, cmake scripts or
freecad.rb
formula file need to be updated to support (finding) the install of pyside in order to copy the necessary dependencies into theFreeCAD.app
bundle.as mentioned in a prior comment ie.
#237 (comment)
it may be possible to tweak the freecad gui launch script to specify the path to the pyside2 installation. once again, i haven't fully tested this locally on my machine or with the CI/CD (github actions yet)
The text was updated successfully, but these errors were encountered: