stanno collegando un (estensione Python) libreria che incorpora il motore di Matlab con il seguente comando (generato usando cmake)Collegamento a una libreria dinamica su un Mac con il percorso completo
c++ -mmacosx-version-min=10.6 -bundle -headerpad_max_install_names -o library.so library.o /Applications/MATLAB_R2009b.app/bin/maci64/libeng.dylib /Applications/MATLAB_R2009b.app/bin/maci64/libmx.dylib -framework Python
conseguente
$ otool -L library.so
library.so:
@loader_path/libeng.dylib (compatibility version 0.0.0, current version 0.0.0)
@loader_path/libmx.dylib (compatibility version 0.0.0, current version 0.0.0)
/System/Library/Frameworks/Python.framework/Versions/2.6/Python (compatibility version 2.6.0, current version 2.6.1)
/opt/local/lib/gcc44/libstdc++.6.dylib (compatibility version 7.0.0, current version 7.13.0)
/opt/local/lib/gcc44/libgcc_s.1.dylib (compatibility version 1.0.0, current version 1.0.0)
/usr/lib/libSystem.B.dylib (compatibility version 1.0.0, current version 125.0.0)
Tuttavia, quando si tenta di utilizzare la libreria, ottengo un messaggio di errore:
ImportError: dlopen(./library.so, 2): Library not loaded: @loader_path/libmex.dylib
Referenced from: ./library.so
Reason: image not found
credo il problema deriva dal fatto che il linker include i file matlab dylib nel formato @loader_path/libeng.dylib
anziché utilizzare il percorso completo, anche se fornisco il percorso completo a g++
. Come posso forzare il linker a utilizzare il percorso completo?
so una soluzione è quella di utilizzare
export DYLD_LIBRARY_PATH=/Applications/MATLAB_R2009b.app/bin/maci64:$DYLD_LIBRARY_PATH
che è dove i file di libreria risiedono, ma mi piacerebbe evitare che in quanto causa di alcuni altri problemi.
prega di fare riferimento la mia risposta a questo link [Add_libray] [1] [1]: http://stackoverflow.com/questions/4876740/xcode-keeps-searching-dylib-at-wrong- path/19245310 # 19245310 – itechnician