С большим трудом, потом и кровью мне удалось скомпилировать QScintilla2 (https://www.riverbankcomputing.com/software/qscintilla/download) для использования в дистрибутиве Anaconda Python (2.5.0; Python 2.7.11; PyQt4) в Mac OS X El Capitan.
После компиляции и установки всего в папках Qt4Qt5 и Python без ошибок и предупреждений все оказалось в правильном месте в Anaconda.
Однако, когда я пытаюсь импортировать qscintilla2 с помощью
import PyQt4.Qsci
Я получаю следующую ошибку:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ImportError: dlopen(/Users/daniel/anaconda/lib/python2.7/site-packages/PyQt4/Qsci.so, 2): Library not loaded: @rpath/./libQtGui.4.dylib
Referenced from: /Users/daniel/anaconda/lib/python2.7/site-packages/PyQt4/Qsci.so
Reason: image not found
Таким образом, модуль не может найти libQtGui.4.dylib.
Я немного почитал о переменной @rpath в отличном блоге https://mikeash.com/pyblog/friday-qa-2009-11-06-linking-and-install-names.html и в итоге узнал, что мне нужно использовать otool
и install_name_tool
в моих попытках решить эту проблему.
Если я запускаю otool -L
, я получаю следующий вывод:
Qsci.so:
libQsci.dylib (compatibility version 0.0.0, current version 0.0.0)
/Users/daniel/anaconda/lib/libqscintilla2.11.dylib (compatibility version 11.3.0, current version 11.3.0)
@rpath/./libQtGui.4.dylib (compatibility version 4.8.0, current version 4.8.7)
@rpath/./libQtCore.4.dylib (compatibility version 4.8.0, current version 4.8.7)
/usr/lib/libstdc++.6.dylib (compatibility version 7.0.0, current version 104.1.0)
/usr/lib/libSystem.B.dylib (compatibility version 1.0.0, current version 1226.10.1)
и otool -l дает мне
Qsci.so:
Load command 0
cmd LC_SEGMENT_64
cmdsize 632
segname __TEXT
vmaddr 0x0000000000000000
vmsize 0x000000000009b000
fileoff 0
filesize 634880
maxprot 0x00000007
initprot 0x00000005
nsects 7
flags 0x0
Section
sectname __text
segname __TEXT
addr 0x0000000000002450
size 0x000000000006bcf6
offset 9296
align 2^4 (16)
reloff 0
nreloc 0
flags 0x80000400
reserved1 0
reserved2 0
Section
sectname __stubs
segname __TEXT
addr 0x000000000006e146
size 0x0000000000001956
offset 450886
align 2^1 (2)
reloff 0
nreloc 0
flags 0x80000408
reserved1 0 (index into indirect symbol table)
reserved2 6 (size of stubs)
Section
sectname __stub_helper
segname __TEXT
addr 0x000000000006fa9c
size 0x00000000000032ac
offset 457372
align 2^2 (4)
reloff 0
nreloc 0
flags 0x80000400
reserved1 0
reserved2 0
Section
sectname __const
segname __TEXT
addr 0x0000000000072d50
size 0x0000000000008e47
offset 470352
align 2^4 (16)
reloff 0
nreloc 0
flags 0x00000000
reserved1 0
reserved2 0
Section
sectname __cstring
segname __TEXT
addr 0x000000000007bb97
size 0x0000000000000f62
offset 506775
align 2^0 (1)
reloff 0
nreloc 0
flags 0x00000002
reserved1 0
reserved2 0
Section
sectname __unwind_info
segname __TEXT
addr 0x000000000007cafc
size 0x00000000000014b4
offset 510716
align 2^2 (4)
reloff 0
nreloc 0
flags 0x00000000
reserved1 0
reserved2 0
Section
sectname __eh_frame
segname __TEXT
addr 0x000000000007dfb0
size 0x000000000001d048
offset 516016
align 2^3 (8)
reloff 0
nreloc 0
flags 0x00000000
reserved1 0
reserved2 0
Load command 1
cmd LC_SEGMENT_64
cmdsize 632
segname __DATA
vmaddr 0x000000000009b000
vmsize 0x0000000000027000
fileoff 634880
filesize 159744
maxprot 0x00000007
initprot 0x00000003
nsects 7
flags 0x0
Section
sectname __dyld
segname __DATA
addr 0x000000000009b000
size 0x0000000000000010
offset 634880
align 2^3 (8)
reloff 0
nreloc 0
flags 0x00000000
reserved1 0
reserved2 0
Section
sectname __got
segname __DATA
addr 0x000000000009b010
size 0x0000000000000030
offset 634896
align 2^3 (8)
reloff 0
nreloc 0
flags 0x00000006
reserved1 1081 (index into indirect symbol table)
reserved2 0
Section
sectname __la_symbol_ptr
segname __DATA
addr 0x000000000009b040
size 0x00000000000021c8
offset 634944
align 2^3 (8)
reloff 0
nreloc 0
flags 0x00000007
reserved1 1087 (index into indirect symbol table)
reserved2 0
Section
sectname __const
segname __DATA
addr 0x000000000009d210
size 0x00000000000050f8
offset 643600
align 2^4 (16)
reloff 0
nreloc 0
flags 0x00000000
reserved1 0
reserved2 0
Section
sectname __data
segname __DATA
addr 0x00000000000a2310
size 0x000000000001f091
offset 664336
align 2^4 (16)
reloff 0
nreloc 0
flags 0x00000000
reserved1 0
reserved2 0
Section
sectname __bss
segname __DATA
addr 0x00000000000c13b0
size 0x0000000000000430
offset 0
align 2^4 (16)
reloff 0
nreloc 0
flags 0x00000001
reserved1 0
reserved2 0
Section
sectname __common
segname __DATA
addr 0x00000000000c17e0
size 0x0000000000000030
offset 0
align 2^3 (8)
reloff 0
nreloc 0
flags 0x00000001
reserved1 0
reserved2 0
Load command 2
cmd LC_SEGMENT_64
cmdsize 72
segname __LINKEDIT
vmaddr 0x00000000000c2000
vmsize 0x0000000000063000
fileoff 794624
filesize 402904
maxprot 0x00000007
initprot 0x00000001
nsects 0
flags 0x0
Load command 3
cmd LC_ID_DYLIB
cmdsize 40
name libQsci.dylib (offset 24)
time stamp 1 Thu Jan 1 01:00:01 1970
current version 0.0.0
compatibility version 0.0.0
Load command 4
cmd LC_SYMTAB
cmdsize 24
symoff 863408
nsyms 5494
stroff 964424
strsize 233104
Load command 5
cmd LC_DYSYMTAB
cmdsize 80
ilocalsym 0
nlocalsym 2227
iextdefsym 2227
nextdefsym 2034
iundefsym 4261
nundefsym 1233
tocoff 0
ntoc 0
modtaboff 0
nmodtab 0
extrefsymoff 0
nextrefsyms 0
indirectsymoff 955752
nindirectsyms 2168
extreloff 951312
nextrel 555
locreloff 794624
nlocrel 7955
Load command 6
cmd LC_UUID
cmdsize 24
uuid 888BE029-40E0-3D69-83D4-B236B57ADFD4
Load command 7
cmd LC_VERSION_MIN_MACOSX
cmdsize 16
version 10.5
sdk 10.11
Load command 8
cmd LC_LOAD_DYLIB
cmdsize 80
name /Users/daniel/anaconda/lib/libqscintilla2.11.dylib (offset 24)
time stamp 2 Thu Jan 1 01:00:02 1970
current version 11.3.0
compatibility version 11.3.0
Load command 9
cmd LC_LOAD_DYLIB
cmdsize 56
name @rpath/./libQtGui.4.dylib (offset 24)
time stamp 2 Thu Jan 1 01:00:02 1970
current version 4.8.7
compatibility version 4.8.0
Load command 10
cmd LC_LOAD_DYLIB
cmdsize 56
name @rpath/./libQtCore.4.dylib (offset 24)
time stamp 2 Thu Jan 1 01:00:02 1970
current version 4.8.7
compatibility version 4.8.0
Load command 11
cmd LC_LOAD_DYLIB
cmdsize 56
name /usr/lib/libstdc++.6.dylib (offset 24)
time stamp 2 Thu Jan 1 01:00:02 1970
current version 104.1.0
compatibility version 7.0.0
Load command 12
cmd LC_LOAD_DYLIB
cmdsize 56
name /usr/lib/libSystem.B.dylib (offset 24)
time stamp 2 Thu Jan 1 01:00:02 1970
current version 1226.10.1
compatibility version 1.0.0
Load command 13
cmd LC_FUNCTION_STARTS
cmdsize 16
dataoff 858264
datasize 5144
Load command 14
cmd LC_DATA_IN_CODE
cmdsize 16
dataoff 863408
datasize 0
Насколько я вижу, в этом модуле нет записи @rpath (или, по крайней мере, я должен был найти команду LC_RPATH?). Я могу установить это, конечно, с помощью install_name_tool впоследствии, но это то, где я застреваю.
Я не понимаю, что в этой ситуации считается @loader_path и @executable_path для модуля Qsci.so. Он расположен в
/Users/daniel/anaconda/lib/python2.7/site-packages/PyQt4/Qsci.so
но это, кажется, прямая ссылка на
/Users/daniel/anaconda/lib/libqscintilla2.11.dylib
Так будет ли /Users/daniel/anaconda/lib/python2.7/site-packages/PyQt4/ или /Users/daniel/anaconda/lib/ @loader_path в этом случае? Я предполагаю, что @executable_path просто указывает на путь интерпретатора Python, который находится в /Users/daniel/anaconda/bin, но поправьте меня, если я ошибаюсь.
И libQtGui.4.dylib, и libQtCore.4.dylib расположены по адресу
/Users/daniel/anaconda/lib/
Я попытался добавить то, что я считаю правильным @rpaths, вручную с помощью
install_name_tool -add_rpath @loader_path/../../ Qsci.so
install_name_tool -add_rpath @loader_path/../lib Qsci.so
первая запись предполагает, что папка, содержащая Qsci.so, является @loader_path, а вторая - libqscintilla2.11.dylib, но безрезультатно...
Если я добавлю абсолютный путь к @rpath с помощью
install_name_tool -add_rpath /Users/daniel/anaconda/lib Qsci.so
это решает проблему, поэтому я знаю, что это проблема rpath. Однако мне нужны относительные местоположения, поскольку я планирую упаковать приложение, как только получу это правильно.
Спасибо за любую помощь в этом, и мои извинения, что этот пост стал намного длиннее, чем предполагалось!