2013-01-15 13 views
9

मैं एक निष्पादन "पूछताछ" कहा जाता संकलन कर रहा हूँ के साथ उपयोग करने के बाद ldd में एक पुस्तकालय लापता:जीसीसी -l

 
g++ -o built/bin/interrogate -Lbuilt/lib -Lbuilt/tmp -L/usr/X11R6/lib \ 
built/tmp/interrogate_composite1.o built/tmp/interrogate_composite2.o \ 
-lp3cppParser -lp3dtool -lp3dtoolconfig -lp3pystub -pthread -ldl 

संकलन के बाद, जब मैं निष्पादन को निष्पादित करने का प्रयास करें:

 
$ LD_LIBRARY_PATH=built/lib built/bin/interrogate 
built/bin/interrogate: symbol lookup error: built/lib/libp3dtool.so.1.8: undefined symbol: _Py_NoneStruct 

यह प्रतीक libp3pystub.so द्वारा प्रदान की गई है, लेकिन पूछताछ निष्पादन इस पुस्तकालय के लिए किसी भी संदर्भ नहीं है (मैं -lp3pystub इस्तेमाल किया था):

 
$ LD_LIBRARY_PATH=built/lib ldd built/bin/interrogate 
    linux-vdso.so.1 => (0x00007fff2016a000) 
    libp3dtool.so.1.8 => built/lib/libp3dtool.so.1.8 (0x00007f498d57a000) 
    libp3dtoolconfig.so.1.8 => built/lib/libp3dtoolconfig.so.1.8 (0x00007f498d51b000) 
    libstdc++.so.6 => /usr/lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007f498d1f2000) 
    libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007f498cfdc000) 
    libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007f498cdbf000) 
    libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f498c9ff000) 
    libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007f498c7fb000) 
    libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007f498c4ff000) 
    /lib64/ld-linux-x86-64.so.2 (0x00007f498d5bc000) 

मैं स्वयं libp3pystub.so लोड हैं, निष्पादन योग्य काम करता है:

 
$ LD_PRELOAD=built/lib/libp3pystub.so LD_LIBRARY_PATH=built/lib built/bin/interrogate 

Usage: 
    interrogate [opts] file.C [file.C ...] 
    interrogate -h 

मेरा प्रश्न है: क्यों पुस्तकालय मैं -lp3pystub साथ जोड़ दिया है interrogate निष्पादन द्वारा संदर्भित नहीं है?

उत्तर

10

मुझे वास्तव में मेरा जवाब मिल गया है। मैं उबंटू पर संकलन कर रहा था, और उन्होंने एक डिफ़ॉल्ट अनुकूलन झंडे जोड़े: -Wl,--as-needed। यह अनुकूलन जांचता है कि मुख्य निष्पादन योग्य में -l के साथ पारित पुस्तकालयों से कोई प्रतीक उपयोग नहीं किया जाता है, तो उन्हें हटा दिया जाएगा।

और यही वह जगह है जहां मेरी त्रुटि थी: _Py_NoneStruct सीधे पूछताछ द्वारा उपयोग नहीं किया जाता है, लेकिन किसी अन्य साझा लाइब्रेरी द्वारा। तो मुझे मैन्युअल रूप से निर्दिष्ट करना होगा कि p3pystub की आवश्यकता है।

एक संभव ठीक होगा:

 
$ g++ -o built/bin/interrogate -Lbuilt/lib -Lbuilt/tmp -L/usr/X11R6/lib \ 
built/tmp/interrogate_composite1.o built/tmp/interrogate_composite2.o \ 
-Wl,--no-as-needed -lp3cppParser -lp3dtool -lp3dtoolconfig -lp3pystub \ 
-pthread -ldl 

और फिर मैं सही ढंग से ldd उत्पादन में पुस्तकालय मिल गया:

$ LD_LIBRARY_PATH=built/lib ldd built/bin/interrogate 
    linux-vdso.so.1 => (0x00007fff0edff000) 
    libp3dtool.so.1.8 => built/lib/libp3dtool.so.1.8 (0x00007fa1c36be000) 
    libp3dtoolconfig.so.1.8 => built/lib/libp3dtoolconfig.so.1.8 (0x00007fa1c365f000) 
>>> libp3pystub.so.1.8 => built/lib/libp3pystub.so.1.8 (0x00007fa1c3658000) 
    libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007fa1c342f000) 
    libstdc++.so.6 => /usr/lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007fa1c312c000) 
    libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007fa1c2e2f000) 
    libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007fa1c2c19000) 
    libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007fa1c29fc000) 
    libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fa1c263c000) 
    /lib64/ld-linux-x86-64.so.2 (0x00007fa1c3700000) 

संदर्भ: https://wiki.ubuntu.com/NattyNarwhal/ToolchainTransition