[Scons-users] InstallVersionedLibrary sometimes fails when symlinking
Managan, Rob
managan1 at llnl.gov
Mon Jun 24 14:24:02 EDT 2013
Andrew,
I will try to take a look at this week. I should disclose that I know
almost nothing about the Package builder so I will be relying heavily on
your notesÅ .
Thanks for the feedback!
*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-
Rob Managan email managan at llnl.gov
LLNL phone: 925-423-0903
P.O. Box 808, L-095 FAX: 925-422-3389
Livermore, CA 94551-0808
On 6/24/13 11:13 AM, "Andrew C. Morrow" <andrew.c.morrow at gmail.com> wrote:
>Hi Rob -
>
>I found some time to experiment with this again. I've posted my
>example project to:
>https://github.com/acmorrow/scons-versioned-lib-demo
>
>There are a few issues:
>
>1) I don't see that the issue with rebuilding the symlink in the
>install or build directory if it is manually removed is fixed.
>2) The change to _INSTALL_TARGETS.extend needs, I think, to place its
>arguments in brackets (see README and or NOTE 2)
>3) Because InstallVersionedLib doesn't return all of the artifacts (I
>think) there is no way to apply different tags to each artifact (e.g.
>the dev link goes in a -dev package, and the hard file and soname
>symlink go in the main package). See (README or NOTEs 1 and 3).
>
>Also, there appears to be an issue with how Package works with targz,
>since it always encodes the variant directory and packaging directory
>into the tarfiles, instead of capturing only the $PREFIX path. FWIW, I
>also think it would be useful to instruct Package to not include any
>of the $PREFIX, for cases where the project is relocatable in the
>filesystem due to all targets having proper $ORIGIN settings in RPATH,
>etc. Just a thought. Perhaps there is already a way to do this.
>
>Thanks,
>Andrew
>
>
>
>On Tue, Jun 18, 2013 at 11:51 AM, Managan, Rob <managan1 at llnl.gov> wrote:
>> I just got a test added and made a pull request. Your email had me look
>>at
>> this again and I just updated the fork to include a potential fix.
>>
>> Please try it out and is there a way to make a simple test case?
>>
>> *-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-
>> Rob Managan email managan at llnl.gov
>> LLNL phone: 925-423-0903
>> P.O. Box 808, L-095 FAX: 925-422-3389
>> Livermore, CA 94551-0808
>>
>>
>>
>>
>>
>> On 6/18/13 5:34 AM, "Andrew C. Morrow" <andrew.c.morrow at gmail.com>
>>wrote:
>>
>>>Hi Rob -
>>>
>>>Any update on the dependency tracking issues with
>>>InstallVersionedLibrary?
>>>
>>>Thanks,
>>>Andrew
>>>
>>>
>>>On Mon, Jun 3, 2013 at 11:41 AM, Managan, Rob <managan1 at llnl.gov> wrote:
>>>> Hi Andrew,
>>>>
>>>> Good catch. They probably are not cleaned as well. Let me see what is
>>>> involved to fix that.
>>>>
>>>> Rob
>>>>
>>>> *-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-
>>>> Rob Managan email managan at llnl.gov
>>>> LLNL phone: 925-423-0903
>>>> P.O. Box 808, L-095 FAX: 925-422-3389
>>>> Livermore, CA 94551-0808
>>>>
>>>>
>>>> On 6/2/13 10:13 AM, "Andrew C. Morrow" <andrew.c.morrow at gmail.com>
>>>>wrote:
>>>>
>>>>
>>>> This is most likely related to the above, but it also appears that the
>>>> installed symlinks are not captured by FindInstalledFiles, which means
>>>>that
>>>> Package (if I'm reading it correctly) won't package the symlinks.
>>>>
>>>> Thanks,
>>>> Andrew
>>>>
>>>>
>>>>
>>>> On Sat, Jun 1, 2013 at 2:09 PM, Andrew C. Morrow
>>>><andrew.c.morrow at gmail.com>
>>>> wrote:
>>>>>
>>>>>
>>>>> Hi Rob -
>>>>>
>>>>> Sorry it took me a couple days to get back to this. I just tried out
>>>>>your
>>>>> branch. The good news is that the issue with the build failing due to
>>>>>errors
>>>>> while symlinking is fixed, so that is a big help.
>>>>>
>>>>> While experimenting with the fix though, I've noticed another issue.
>>>>>Using
>>>>> the same test case as before:
>>>>>
>>>>> $ python $MYSCONS/script/scons.py --prefix=$(pwd)/install install
>>>>> SCons import failed. Trying to run from source directory
>>>>> scons: Reading SConscript files ...
>>>>> scons: done reading SConscript files.
>>>>> scons: Building targets ...
>>>>> Install file: "build/foo.hpp" as "install/include/foo.hpp"
>>>>> g++ -o build/foo.os -c -fPIC build/foo.cpp
>>>>> g++ -o build/libfoo.0.1.2.dylib -dynamiclib -current_version 0.1.2
>>>>> -compatibility_version 0.1.2 -undefined dynamic_lookup build/foo.os
>>>>> Install file: "build/libfoo.0.1.2.dylib" as
>>>>> "install/lib/libfoo.0.1.2.dylib"
>>>>> scons: done building targets.
>>>>>
>>>>> Everything builds OK. Lets remove the symlink in the install
>>>>>directory:
>>>>>
>>>>> $ rm install/lib/libfoo.dylib
>>>>>
>>>>> Rerunning the build claims install is up to date:
>>>>>
>>>>> $ python $MYSCONS/script/scons.py --prefix=$(pwd)/install install
>>>>> SCons import failed. Trying to run from source directory
>>>>> scons: Reading SConscript files ...
>>>>> scons: done reading SConscript files.
>>>>> scons: Building targets ...
>>>>> scons: `install' is up to date.
>>>>> scons: done building targets.
>>>>>
>>>>> And the file was not re-created:
>>>>>
>>>>> $ ls install/lib/libfoo.dylib
>>>>> ls: install/lib/libfoo.dylib: No such file or directory
>>>>>
>>>>> The same effect is observed removing libfoo.dylib from the build
>>>>> directory. So it appears that there are some dependency edges that
>>>>>are
>>>>>not
>>>>> being captured correctly.
>>>>>
>>>>> Thanks,
>>>>> Andrew
>>>>>
>>>>>
>>>>>
>>>>> On Thu, May 30, 2013 at 2:08 PM, Managan, Rob <managan1 at llnl.gov>
>>>>>wrote:
>>>>>>
>>>>>> Andrew,
>>>>>>
>>>>>> I have a proposed fix at
>>>>>>https://bitbucket.org/managan/scons_versionedlib
>>>>>> .
>>>>>> Let me know if it works for you.
>>>>>> I added code to delete any existing symlink before creating them
>>>>>>again.
>>>>>> That was how it failed for me even if the error message seemed to
>>>>>>say
>>>>>> something else. I also made sure the symlinks in the install
>>>>>>directory were
>>>>>> set up the same as in the build directory. Not sure how that ever
>>>>>>was
>>>>>> different.
>>>>>>
>>>>>> I need to add a test case before generating a pull request but this
>>>>>> should be good to go.
>>>>>>
>>>>>> Rob
>>>>>>
>>>>>> *-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-
>>>>>> Rob Managan email managan at llnl.gov
>>>>>> LLNL phone: 925-423-0903
>>>>>> P.O. Box 808, L-095 FAX: 925-422-3389
>>>>>> Livermore, CA 94551-0808
>>>>>>
>>>>>>
>>>>>> On 5/27/13 10:46 PM, "William Deegan" <bill at baddogconsulting.com>
>>>>>>wrote:
>>>>>>
>>>>>> Andrew,
>>>>>>
>>>>>> On May 27, 2013, at 10:04 PM, Andrew C. Morrow
>>>>>> <andrew.c.morrow at gmail.com> wrote:
>>>>>>
>>>>>>
>>>>>> On Mon, May 27, 2013 at 11:03 PM, William Deegan
>>>>>> <bill at baddogconsulting.com> wrote:
>>>>>>>
>>>>>>> Andrew,
>>>>>>>
>>>>>>> Were you able to repro this? If so, should I file a ticket?
>>>>>>>
>>>>>>>
>>>>>>> Unfortunately, very busy IRL at the moment so haven't had a chance
>>>>>>>to
>>>>>>> try it out.
>>>>>>> Lots of work leading up to a conference, once that's over (6/6)
>>>>>>>I'll
>>>>>>> have some time to take a look at this.
>>>>>>
>>>>>>
>>>>>> Sounds good. I just wanted to make sure it didn't get missed. Built
>>>>>>in
>>>>>> support for versioned shared libraries is a really useful feature
>>>>>>and
>>>>>>I'd
>>>>>> very much like to use it. I'm sure I'm not the only one.
>>>>>>
>>>>>>>
>>>>>>>
>>>>>>>
>>>>>>> Also, is there some documentation on the SCons bugfix and release
>>>>>>>cycle?
>>>>>>> I've noticed that there are only infrequently 'z +1' releases of
>>>>>>>SCons
>>>>>>> x.y.z. If the problem with InstallVersionedLibrary is legitimate,
>>>>>>>should I
>>>>>>> expect to see a fix in a to-be-released-somewhat-soonish SCons
>>>>>>>2.3.1
>>>>>>>bugfix
>>>>>>> release, or longer term in some future SCons 2.4 release?
>>>>>>>
>>>>>>>
>>>>>>>
>>>>>>> SCons is a volunteer run open source project.
>>>>>>> If you want to ensure that a fix is made, you'll either have to
>>>>>>>submit a
>>>>>>> fix, hope that someone in the community picks up the issue and
>>>>>>>fixes
>>>>>>>it, or
>>>>>>> finance a consultant to resolve the issue for you.
>>>>>>
>>>>>>
>>>>>> I'm aware of the nature of the project. Still, this is a feature
>>>>>> documented in the SCons manual pages. Someone loved this feature
>>>>>>enough to
>>>>>> shepherd it through development, code review, testing,
>>>>>>documentation,
>>>>>>and
>>>>>> release.
>>>>>>
>>>>>>
>>>>>> Though all of this is true, that doesn't guarantee that the
>>>>>>developer
>>>>>>of
>>>>>> any feature is immediately available to address a bug.
>>>>>>
>>>>>>
>>>>>>>
>>>>>>> In general we will release a new version either when something
>>>>>>>notable
>>>>>>> has been fixed or if there's been a sufficient number of small
>>>>>>>fixes.
>>>>>>> If a fix is submitted for your issue (assuming it's not user error
>>>>>>> (which from a cursory glance it doesn't look like it is)), then it
>>>>>>>would be
>>>>>>> in the next release.
>>>>>>
>>>>>>
>>>>>> Right, but "next release" at which revision level, and on (roughly)
>>>>>>what
>>>>>> time scale? Without some insight into the release process, intended
>>>>>> schedule, defect triage process, backport policy, etc., it is
>>>>>>difficult to
>>>>>> reason about whether I should abandon my attempts to use this new
>>>>>>feature or
>>>>>> not. Even if I were to debug this particular issue and submit a
>>>>>>patch
>>>>>>as you
>>>>>> have suggested, the adoption of that fix into a published release
>>>>>>may
>>>>>>not
>>>>>> mesh with my own release schedule. I'm not complaining - I merely
>>>>>>want to
>>>>>> better understand: If I or someone else submitted a patch tonight,
>>>>>>would it
>>>>>> likely land in a 2.3.1 release in one month, or in a 2.4.0 in 6
>>>>>>months, or
>>>>>> something else entirely?
>>>>>>
>>>>>>
>>>>>> If this is a bug in an existing feature (and assuming the fix
>>>>>>doesn't
>>>>>> require breaking compatability), then the fix would show in the next
>>>>>>minor
>>>>>> release published after a fix is accepted.
>>>>>> This likely means 2.3.1, however if other less trivial (assuming the
>>>>>>fix
>>>>>> is fairly trivial) changes have already landed in the main branch,
>>>>>>then it
>>>>>> might appear in the 2.4.0 branch.
>>>>>> There is not direct correlation between a 2.3.1 release or a 2.4.0
>>>>>> release and a timeline.
>>>>>>
>>>>>>
>>>>>>
>>>>>>>
>>>>>>> Also keep in mind all the work is done in a public mercurial repo
>>>>>>>hosted
>>>>>>> on bitbucket, so as soon as anyone published a fix you can try it
>>>>>>>against
>>>>>>> your build, and use that code if it resolves your issue.
>>>>>>
>>>>>>
>>>>>> That works well for projects that I plan to build for myself.
>>>>>>However,
>>>>>> for open source projects which use SCons as the publicly facing
>>>>>>build
>>>>>>system
>>>>>> it is not a realistic solution to require downstream consumers to
>>>>>>use
>>>>>>the
>>>>>> SCons mainline or manually patch their SCons installs. Such projects
>>>>>>are
>>>>>> constrained to use the demonstrably working subset of the official
>>>>>>SCons
>>>>>> releases that make their way into distribution and language package
>>>>>> repositories. Potentially, a project could drag in the entire slug
>>>>>>of
>>>>>>fixed
>>>>>> code and redefine the InstallVersionedLibrary, but this has
>>>>>>different
>>>>>> problems.
>>>>>>
>>>>>>
>>>>>> Fair enough.
>>>>>> Note however that SCons can be run in place with a scons-local
>>>>>>package,
>>>>>> so you could unpackage a build scons-local package from the latest
>>>>>>code and
>>>>>> check that into your project until such time as the needed fix is
>>>>>>released.
>>>>>>
>>>>>> Hope that helps.
>>>>>>
>>>>>> In the meantime, it looks like Rob is hot on the trail of this
>>>>>>issue.. so
>>>>>> stay tuned.
>>>>>>
>>>>>> -Bill
>>>>>>
>>>>>> _______________________________________________
>>>>>> Scons-users mailing list
>>>>>> Scons-users at scons.org
>>>>>> http://four.pairlist.net/mailman/listinfo/scons-users
>>>>>>
>>>>>
>>>>
>>>>
>>>> _______________________________________________
>>>> Scons-users mailing list
>>>> Scons-users at scons.org
>>>> http://four.pairlist.net/mailman/listinfo/scons-users
>>>>
>>>_______________________________________________
>>>Scons-users mailing list
>>>Scons-users at scons.org
>>>http://four.pairlist.net/mailman/listinfo/scons-users
>>
>> _______________________________________________
>> Scons-users mailing list
>> Scons-users at scons.org
>> http://four.pairlist.net/mailman/listinfo/scons-users
>_______________________________________________
>Scons-users mailing list
>Scons-users at scons.org
>http://four.pairlist.net/mailman/listinfo/scons-users
More information about the Scons-users
mailing list