[Scons-dev] Bug #2849 is not fixed (64-bit MS Windows 7 fails to build with 32-bit Visual Express C++ 2010).

Edward d'Auvergne edward at nmr-relax.com
Mon Oct 22 04:44:29 EDT 2012


Hi,

The build script for my project (http://www.nmr-relax.com) is viewable at:

http://svn.gna.org/viewcvs/relax/trunk/sconstruct?view=log

Note this file is quite large. The building of Python C modules which
triggers this bug on MS Windows is essentially in the relax_fit()
method. On a side note, the main script additionally imports from the
modules in the 'scons' package
(http://svn.gna.org/viewcvs/relax/trunk/scons/). I will now check
what env['TARGET_ARCH'] is set to.

Cheers,

Edward




On 22 October 2012 03:51, William Deegan <bill at baddogconsulting.com> wrote:

> Edward,

>

> On Oct 18, 2012, at 7:03 AM, Edward d'Auvergne <edward at nmr-relax.com> wrote:

>

>> Hi,

>>

>> I have tested out Scons 2.2.0 and have noticed that bug #2849

>> (http://scons.tigris.org/issues/show_bug.cgi?id=2849) is still

>> present. I can see this also from the code:

>>

>> https://bitbucket.org/scons/scons/src/8764000345e06e326ef68fd0acf9366c1f3eb885/src/engine/SCons/Tool/MSCommon/vc.py?at=default

>>

>> in the lines:

>>

>> try_target_archs = [target_platform]

>> if not req_target_platform and target_platform in ('amd64','x86_64'):

>> try_target_archs.append('x86')

>>

>> The suggestion by Kyle Strand was to change to code from:

>>

>> try_target_archs = [target_platform]

>> if not req_target_platform and target_platform=='amd64'

>> try_target_archs.append('x86')

>>

>> to:

>>

>> try_target_archs = [target_platform]

>> if target_platform in ('amd64','x86_64'):

>> try_target_archs.append('x86')

>>

>> The key problem is that in this case is that 'req_target_platform' is

>> set to 'x86_64' when 32-bit C++ is used on 64-bit Windows (and no

>> 64-bit compiler is present). Taking out the 'req_target_platform'

>> check fixes the problem for Scons 2.2.0.

>

>

> Can you post your SConstruct/SConscript?

>

> env['TARGET_ARCH'] shouldn't have any default setting, this is what provides a value to req_target_platform.

> So in the case that a user explicitly requests a platform, we do not add any other platforms to be searched for.

>

> As far as I can tell that is the way the code is behaving.

> If you have an example showing a bug where TARGET_ARCH is not set, and it's not also trying 32bit, please let me know.

>

> Thanks,

> Bill

> _______________________________________________

> Scons-dev mailing list

> Scons-dev at scons.org

> http://two.pairlist.net/mailman/listinfo/scons-dev



More information about the Scons-dev mailing list