[PyQt] pyqtdeploy-build: Errors building for macx

Phil Thompson phil at riverbankcomputing.com
Wed Jan 10 16:39:17 GMT 2018


These should both be fixed - tested on macOS and Linux but not Windows.

Phil

> On 10 Jan 2018, at 1:12 am, Patrick Stinson <patrickkidd at gmail.com> wrote:
> 
> Looks like darwin64.S is not included in the Xcode target. If I add it it resolves the symbols, but then leads to even more problems:
> 
> ld: warning: could not create compact unwind for _ffi_call_unix64: does not use RBP or RSP based frame
> duplicate symbol _ffi_closure_free in:
>     /Users/patrick/dev/pkdiagram/build/osx/Family Diagram.build/Debug/Family Diagram.build/Objects-normal/x86_64/closures.o
>     /Users/patrick/dev/pkdiagram/build/osx/Family Diagram.build/Debug/Family Diagram.build/Objects-normal/x86_64/malloc_closure.o
> duplicate symbol _ffi_closure_alloc in:
>     /Users/patrick/dev/pkdiagram/build/osx/Family Diagram.build/Debug/Family Diagram.build/Objects-normal/x86_64/closures.o
>     /Users/patrick/dev/pkdiagram/build/osx/Family Diagram.build/Debug/Family Diagram.build/Objects-normal/x86_64/malloc_closure.o
> ld: 2 duplicate symbols for architecture x86_64
> 
> It looks like the setup for including python module sources (for ctypes I think?) are kind of a mess?
> 
> -P
> 
>> On Jan 9, 2018, at 1:40 PM, Patrick Stinson <patrickkidd at gmail.com> wrote:
>> 
>> There are compile errors for a project which includes xml.parsers.expat. For some reason xmlparse.c does not recognize that <stdlib.h> should include HAVE_ARC4RANDOM_BUF for macOS, resulting in the following compile error:
>> 
>> 
>> #if !defined(HAVE_GETRANDOM) && !defined(HAVE_SYSCALL_GETRANDOM) \
>>     && !defined(HAVE_ARC4RANDOM_BUF) && !defined(HAVE_ARC4RANDOM) \
>>     && !defined(XML_DEV_URANDOM) \
>>     && !defined(_WIN32) \
>>     && !defined(XML_POOR_ENTROPY)
>> # error  \
>>     You do not have support for any sources of high quality entropy \
>>     enabled.  For end user security, that is probably not what you want. \
>>     \
>>     Your options include: \
>>       * Linux + glibc >=2.25 (getrandom): HAVE_GETRANDOM, \
>>       * Linux + glibc <2.25 (syscall SYS_getrandom): HAVE_SYSCALL_GETRANDOM, \
>>       * BSD / macOS >=10.7 (arc4random_buf): HAVE_ARC4RANDOM_BUF, \
>>       * BSD / macOS <10.7 (arc4random): HAVE_ARC4RANDOM, \
>>       * libbsd (arc4random_buf): HAVE_ARC4RANDOM_BUF + HAVE_LIBBSD, \
>>       * libbsd (arc4random): HAVE_ARC4RANDOM + HAVE_LIBBSD, \
>>       * Linux / BSD / macOS (/dev/urandom): XML_DEV_URANDOM \
>>       * Windows (RtlGenRandom): _WIN32. \
>>     \
>>     If insist on not using any of these, bypass this error by defining \
>>     XML_POOR_ENTROPY; you have been warned. \
>>     \
>>     If you have reasons to patch this detection code away or need changes \
>>     to the build system, please open a bug.  Thank you!
>> #endif
>> 
>> I have attached a bare-bones skeleton which imports qt and xml.parsers.expat.
>> 
>> If I add #define HAVE_ARC4RANDOM_BUF (which should be available via stdlib.h on macos) then the file compiles but I get the following (unrelated) linker errors:
>> 
>> Undefined symbols for architecture x86_64:
>>   "_ffi_call_unix64", referenced from:
>>       _ffi_call in x86-ffi64.o
>>   "_ffi_closure_unix64", referenced from:
>>       _ffi_prep_closure in x86-ffi64.o
>>      (maybe you meant: _ffi_closure_unix64_inner)
>> ld: symbol(s) not found for architecture x86_64
>> clang: error: linker command failed with exit code 1 (use -v to see invocation)
>> 
>> 
>> I have had little success figuring out what the story is on those ffi symbols.
>> 
>> <pyqt-skel.zip>
> 
> _______________________________________________
> PyQt mailing list    PyQt at riverbankcomputing.com
> https://www.riverbankcomputing.com/mailman/listinfo/pyqt



More information about the PyQt mailing list