Opened 16 years ago

Closed 12 years ago

Last modified 11 years ago

#322 closed defect (fixed)

Bindings build problem on OS X

Reported by: Tom Owned by: Dan
Priority: normal Milestone: 1.2.17
Component: Xapian-bindings (Python) Version: SVN trunk
Severity: normal Keywords:
Cc: Blocked By:
Blocking: Operating System: Mac OS X

Description

There seems to be a bug in the current libtool which omits xapian-core/.libs from the search path when linking the bindings (python anyway). If there is no libxapian in /usr/... it will fail with a missing image error, otherwise it will attempt to link against it, which is probably a bad thing.

As a workaround, use DYLD_LIBRARY_PATH to force the linker, e.g.

DYLD_LIBRARY_PATH=/Users/maky/src/xapian/xapian-core/.libs make

Attachments (2)

xapian-bindings-osx-uninstpath.patch (1.6 KB ) - added by Richard Boulton 14 years ago.
Potential, but unpleasant, solution
osx-xapian-bindings-intree.patch (3.4 KB ) - added by Olly Betts 12 years ago.
More sophisticated approach

Download all attachments as: .zip

Change History (19)

comment:1 by Olly Betts, 15 years ago

At least users building from tarballs are likely to build and install xapian-core before trying to build the bindings, so mostly this affects developers building from SVN.

But (if this hasn't been fixed by changes since) it would be good to resolve this. If it's a libtool issue, it'd be good to get a fix in the next release.

Tom: are you still seeing this?

comment:2 by James Aylett, 15 years ago

I can confirm this is still an issue with trunk as of [13285]. It only affects the python bindings (php5, csharp, java-swig, ruby, tcl8 all work fine on my machine; I don't have the guile builddeps installed).

comment:3 by Olly Betts, 15 years ago

Milestone: 1.2.x

We should try to fix this, but it only affects builds against uninstalled xapian-core, which is not a common case for end users, so not a 1.2.0 blocker.

comment:4 by Olly Betts, 15 years ago

Hmm, looked at this and it's unclear to me what is going wrong.

James/Tom: Are you running make check or just make? If the later, then Python runs the module to create .pyc and .pyo files, whereas the other bindings only try to run it on make check, so that might explain the difference.

The web suggests OS X only gained rpath support fairly recently, so it might be libtool doesn't support it yet. Within itself, I think libtool can use DYLD_LIBRARY_PATH but it can't for this case as it isn't involved in running Python as things stand.

comment:5 by Olly Betts, 15 years ago

Component: Xapian-bindingsXapian-bindings (Python)
Owner: changed from Olly Betts to Richard Boulton

by Richard Boulton, 14 years ago

Potential, but unpleasant, solution

comment:6 by Richard Boulton, 14 years ago

To answer the question in comment 4, the python bindings were failing on make, whereas the other bindings were failing only on make check.

The attached patch contains a possible solution to this; ie, set DYLD_LIBRARY_PATH directly, to point to the location that the xapian core library would be found when running an uninstalled SVN build. This seems rather horrible, but I implemented it for python to check the theory, and with the patch applied both "make" and "make check" succeed for OSX.

I tried to see if libtool has got anywhere with implementing this, but with no success. I think our options are either to apply a hack similar to that attached, or to upgrade to a version of libtool which fixes the problem (which may involve creating such a version of libtool!).

comment:7 by Olly Betts, 14 years ago

Aside from the ugliness, there's one flaw I can see with the patch - just because ../../xapian-core/.libs exists doesn't mean that it's what we're currently trying to build against - I could check out an SVN tree, build it, make distclean in the bindings, and rebuild then against a different xapian-core.

That's clearly less bad than quietly using a library installed under /usr, but if DYLD_LIBRARY_PATH is meaningful on other platforms, we should narrow this hack to only take effect on Mac OS X. Looking at libtool.m4, libtool only tries to use DYLD_LIBRARY_PATH on darwin or rhapsody, so we're probably OK.

Even if we go with this hack for now, we should try to get libtool fixed too.

comment:8 by Olly Betts, 14 years ago

Milestone: 1.2.x1.2.4

Thinking about this some more, the issue here is caused by us going behind libtool's back, and copying _xapian.so from the .libs subdirectory.

Perhaps we ought to take the libtool-supported route to this (which is what we currently do for Java) and use something like this:

PYTHONPATH="xapian:$PYTHONPATH" ../libtool --mode=execute -dlopen _xapian.la python -c 'import _xapian'

Does that work on OS X?

Marking for 1.2.4 - if this approach works, we should apply it for the next release.

comment:9 by Olly Betts, 14 years ago

Richard reported on IRC that the -dlopen didn't help find the right libxapian (from xapian-core).

I wonder why the other bindings work but Python doesn't...

comment:10 by Richard Boulton, 14 years ago

The other bindings don't work - it's just that only the python bindings try running the generated bindings on "make" - all the bindings fail in the same way when their "make check" targets are run.

comment:11 by Olly Betts, 14 years ago

Milestone: 1.2.41.2.x

r15151 sets DYLD_LIBRARY_PATH on OS X (only) to point into where an uninstalled libxapian would be in a combined tree from an SVN/git checkout. That's as good as we are likely to get right now, and the rest of this ticket is "suitable for 1.2.x".

comment:12 by Olly Betts, 12 years ago

I've spotted a more sophisticated approach which should work for any uninstalled xapian-core, not just an SVN/git tree, and also won't try to build against ../xapian-core/.libs just because it exists.

Can someone with OS X test the attached patch please?

comment:13 by Olly Betts, 12 years ago

Updated patch, with minor improvements.

by Olly Betts, 12 years ago

More sophisticated approach

comment:14 by Olly Betts, 12 years ago

I realised I could do some rudimentary testing by faking $host and $host_os, and have fixed a few issues that uncovered. Updated patch attached.

comment:15 by Olly Betts, 12 years ago

Milestone: 1.2.x1.3.1
Owner: changed from Richard Boulton to Dan

Dan offered to test this, so assigning to him.

Also marking for 1.3.1 (I'll backport if it's easy, though this issue mainly affects people building from SVN or git, so it matters most for trunk).

comment:16 by Olly Betts, 12 years ago

Resolution: fixed
Status: newclosed

Patch applied to trunk in r17032 - I've not been able to test it, but faking $host and $host_os allows reasonable testing, and it would be good to resolve this long-standing issue.

I think at this point in 1.2's release cycle, backporting this doesn't make much sense, as people aren't likely to be don't much development work on 1.2. If OS X developers feel differently, I'm happy to reconsider if someone can actually confirm the latest patch works as intended on OS X.

comment:17 by Olly Betts, 11 years ago

Milestone: 1.3.11.2.17

This is useful for the buildbot, so backported to 1.2 branch in r17792.

Note: See TracTickets for help on using tickets.