Boost logo

Boost-Build :

Subject: Re: [Boost-build] [Boost][build] Bjam ordering source $(>) list
From: Vladimir Prus (ghost_at_[hidden])
Date: 2009-06-27 05:24:25


On Saturday 27 June 2009 Steven Watanabe wrote:

> AMDG
>
> K. Noel Belcourt wrote:
> > On Jun 26, 2009, at 2:08 PM, Steven Watanabe wrote:
> >
> >> K. Noel Belcourt wrote:
> >>> Thanks for the push, I dug in a bit more to see how sources $(>) are
> >>> populated for the link action.
> >>>
> >>> In builtin.jam, linking-generator.generated-targets() is the place to
> >>> alter what ends up in $(>), and in what order. For my problem, I
> >>> separated the OBJ sources from all other sources so I could place the
> >>> OBJ before STATIC_LIB, etc... The fix turned out to work beautifully
> >>> as you can see here.
> >>> <snip>
> >>>
> >>> This patch moves all objects before non-objects and retains their
> >>> respective relative ordering, so as not to break the dependency
> >>> ordering.
> >>>
> >>> Anyone think this is this worth committing to Boost.Build?
> >>
> >> Maybe you can use unix-linking-generator which also
> >> makes sure that dependent libraries are placed in the correct order?
> >
> >
> > That would mean that generators that don't inherit from
> > unix-linking-generator wouldn't benefit from this change (e.g.
> > msvc-linking-generator), but I guess that doesn't really matter.
> >
> > Sure, I can move it into unix.jam.
>
> Any toolset that cares about library ordering ought to use
> unix-linking-generator AFAIK, the only reason that unix.jam
> exists at all is to make sure that libraries are placed in the correct
> location on the command line. The logic that's already there is
> opposite your patch, it finds all LIB targets and puts them after
> the other sources.

Right, that's where the magic is. I'd imagine that 'fortran linker'
should extend this unix-linking-generator, if possible.

- Volodya


Boost-Build list run by bdawes at acm.org, david.abrahams at rcn.com, gregod at cs.rpi.edu, cpdaniel at pacbell.net, john at johnmaddock.co.uk