List Info

Thread: qcc toolset




qcc toolset
user name
2006-02-20 16:16:58
On Friday 17 February 2006 19:00, Jim Douglas wrote:
> Vladimir Prus wrote:
> > Jim,
> > a quick port of qcc toolset is attached.
> >
> > Can you test it? The testing instructions are
available at:
> >
> >   http://zigzag.cs.msu.su/boost.build/wiki/TestingNewToo
lset
>
......
> *****************
> 1. The "-Wc,-fPIC" option should be
"-Wl,-fPIC". c = compiler, l = linker
> ****************
>
> I have modified qcc.jam, and it is attached. Note that
the spurious
> "-Wall" is still there. I cannot trace
where it is coming from. 

gcc.jam has:

  flags gcc.compile OPTIONS <warnings>off : -w ;
  flags gcc.compile OPTIONS <warnings>all : -Wall ;

and qcc.jam inherits those definitions. I've comitted the
attached patch to 
fix this.

> The 
> results are now:
>
> ...updated 2 targets...
> ...found 9 targets...
> ...updating 2 targets...
> qcc.compile.c++ bin/qcc/debug/hello.o
>
>      "QCC"  -Wc,-ftemplate-depth-100 -O0
-Wall -Wc,-fno-inline -Wc,-Wall
> -Wc,-fPIC -gstabs+   -c -o
"bin/qcc/debug/hello.o" "hello.cpp"
>
> qcc.link bin/qcc/debug/hello
>
>      "QCC"    -o
"bin/qcc/debug/hello"
"bin/qcc/debug/hello.o"
> -Wl,-fPIC -gstabs+
>
> ...updated 2 targets...

Ok. Did you try the 'library' test, or tried running the
V2 test_all.py 
script? Did you try running C++ Boost regression tests?

> You will have seen that there are several
qcc-*-tools.jam files in the
> bbv1 directory. How do I invoke the variations that
these files offer?
> The current file just gives me the default options.

Please take a look at:

   https://zigzag.cs.msu.su/boost.build/wiki/BoostRegre
ssionsV2

It looks like you'd need to specify proper "-V"
options when configuring the 
toolset.

Thanks,
Volodya


_______________________________________________
Unsubscribe & other changes: http://lists.boost.org/mailman/listinfo.cgi/boost-build
qcc toolset
user name
2006-02-22 09:48:39
Volodya,

Having spent some time trying to get your version of qcc.jam
working I 
have taken the executive decision to revert to my original
plan and 
produce qcc.jam as a sibling of gcc.jam and, not as a child
if gcc.jam.

Although qcc is based on gcc the command sets are *so*
different and I 
found myself overloading almost every statement. In addition
I would 
have needed to modify some of the platform conditional logic
in gcc.jam 
which I did not want to do. I trust you will not be offended
at this 
decision.

The file is attached and it runs the hello & libraries
test but there 
are errors with test_all.py.

I have also started a run of the regression tests but I
stopped when I 
saw that there is a problem with qcc.link. I need to add
'libm' to each 
of the linking rules because it has been omitted from the
default search 
list on this platform.  I have tried adding this as FINDLIBS
and 
FINDLIBS-SA but it does not always show up in the right
places.

The current (development only - not committed to cvs) file
is attached. 
Can you advise?

Thanks
Jim
#  Copyright (c) 2001 David Abrahams.
#  Copyright (c) 2002-2003 Rene Rivera.
#  Copyright (c) 2002-2003 Vladimir Prus.
#
#  Use, modification and distribution is subject to the
Boost Software
#  License Version 1.0. (See accompanying file
LICENSE_1_0.txt or
#  http://www.boost
.org/LICENSE_1_0.txt)

import toolset : flags ;
import property ;
import generators ;
import os ;
import type ;
import feature ;
import "class" : new ;
import set ;
import common ;
import errors ;

feature.extend toolset : qcc ;

import unix ;
toolset.inherit-generators qcc : unix : unix.link
unix.link.dll ;
generators.override builtin.lib-generator : qcc.prebuilt ;
toolset.inherit-flags qcc : unix ;
toolset.inherit-rules qcc : unix ;



# Make the "o" suffix used for qcc toolset on
all
# platforms
type.set-generated-target-suffix OBJ : <toolset>qcc :
o ;
type.set-generated-target-suffix STATIC_LIB :
<toolset>qcc : a ;


# Initializes the qcc toolset for the given version.
# If necessary, command may be used to specify where the
compiler
# is located.
# The parameter 'options' is a space-delimited list of
options, each
# one being specified as <option-name>option-value.
Valid option names
# are: cxxflags, linkflags and linker-type. Accepted values
for linker-type
# are gnu and sun, gnu being the default.
# Example:
#   using qcc : 3.4 : : <cxxflags>foo
<linkflags>bar <linker-type>sun ;
rule init ( version ? : command * : options * )
{
    local condition = [ common.check-init-parameters qcc :
version $(version) ] ;
    
    local command = [ common.get-invocation-command qcc :
QCC : $(command) ] ;

    common.handle-options qcc : $(condition) : $(command) :
$(options) ;
}


generators.register-c-compiler qcc.compile.c++ : CPP : OBJ :
<toolset>qcc ;
generators.register-c-compiler qcc.compile.c : C : OBJ :
<toolset>qcc ;
generators.register-c-compiler qcc.compile.asm : ASM : OBJ :
<toolset>qcc ;


# Declare flags for compilation
flags qcc.compile OPTIONS <debug-symbols>on : -gstabs+
;

# Declare flags and action for compilation
flags qcc.compile OPTIONS <optimization>off : -O0 ;
flags qcc.compile OPTIONS <optimization>speed : -O3 ;
flags qcc.compile OPTIONS <optimization>space : -Os ;

flags qcc.compile OPTIONS <inlining>off :
-Wc,-fno-inline ;
flags qcc.compile OPTIONS <inlining>on :
-Wc,-Wno-inline ;
flags qcc.compile OPTIONS <inlining>full :
-Wc,-finline-functions -Wc,-Wno-inline ;

flags qcc.compile OPTIONS <warnings>off : -w ;
flags qcc.compile OPTIONS <warnings>all : -Wc,-Wall ;
flags qcc.compile OPTIONS <warnings-as-errors>on :
-Wc,-Werror ;

flags qcc.compile OPTIONS <profiling>on : -p ;

flags qcc.compile OPTIONS <cflags> ;
flags qcc.compile.c++ OPTIONS <cxxflags> ;
flags qcc.compile DEFINES <define> ;
flags qcc.compile INCLUDES <include> ;

flags qcc.compile OPTIONS <link>shared : -shared ;


actions compile.c++
{
    "$(CONFIG_COMMAND)" -Wc,-ftemplate-depth-100
$(OPTIONS) -D$(DEFINES) -I"$(INCLUDES)" -c -o
"$(<)" "$(>)" 
}

actions compile.c
{
    "$(CONFIG_COMMAND)" $(OPTIONS) -D$(DEFINES)
-I"$(INCLUDES)" -c -o "$(<)"
"$(>)" 
}

actions compile.asm
{
    "$(CONFIG_COMMAND)" $(OPTIONS) -D$(DEFINES)
-I"$(INCLUDES)" -c -o "$(<)"
"$(>)" 
}

# The class which check that we don't try to use
# the <runtime-link>static property while creating or
using shared library,
# since it's not supported by qcc/libc.
class qcc-linking-generator : unix-linking-generator
{
    rule generated-targets ( sources + : property-set :
project name ? )
    {
        if <runtime-link>static in [
$(property-set).raw ] 
        {
            local m ;
            if [ id ] = "qcc.link.dll"
            {
                m = "on qcc, DLL can't be build with
<runtime-link>static" ;
            }         
            if ! $(m) {                
                for local s in $(sources)
                {
                    local type = [ $(s).type ] ;
                    if $(type) &&  [ type.is-derived
$(type) SHARED_LIB ] 
                    {
                        m = "on qcc, using DLLS
together with the <runtime-link>static options is not
possible " ;
                    }                
                }                
            }
            if $(m)
            {
                errors.user-error $(m) :
                  "it's suggested to use
<runtime-link>static together with the
<link>static" ;
            }
            
        }
                        
        return [ unix-linking-generator.generated-targets 
            $(sources) : $(property-set) : $(project)
$(name) ] ;
    }    
}

generators.register [ new qcc-linking-generator qcc.link :
LIB OBJ : EXE 
    : <toolset>qcc ] ;

generators.register [ new qcc-linking-generator qcc.link.dll
: LIB OBJ : SHARED_LIB 
    : <toolset>qcc ] ;

generators.override qcc.prebuilt : builtin.prebuilt ;
generators.override qcc.searched-lib-generator :
searched-lib-generator ;



# Declare flags for linking
# First, the common flags
flags qcc.link OPTIONS <debug-symbols>on : -gstabs+ ;
flags qcc.link OPTIONS <profiling>on : -p ;
flags qcc.link OPTIONS <linkflags> ;
flags qcc.link LINKPATH <library-path> ;
flags qcc.link FINDLIBS-ST <find-static-library> ;
flags qcc.link FINDLIBS-SA <find-shared-library> ;
flags qcc.link LIBRARIES <library-file> ;

flags qcc.link FINDLIBS-SA : m ;

# For <runtime-link>static we made sure there are no
dynamic libraries 
# in the link
flags qcc.link OPTIONS <runtime-link>static : -static
;


# Declare actions for linking
rule link ( targets * : sources * : properties * )
{
    SPACE on $(targets) = " " ;    
    # Serialize execution of the 'link' action, since
    # running N links in parallel is just slower.
    # For now, serialize only qcc links, it might be a good
    # idea to serialize all links.
    JAM_SEMAPHORE on $(targets) =
<s>qcc-link-semaphore ;
}

actions link bind LIBRARIES
{
    "$(CONFIG_COMMAND)"
-L"$(LINKPATH)"
-Wl,-R$(SPACE)-Wl,"$(RPATH)"
-Wl,-rpath-link$(SPACE)-Wl,"$(RPATH_LINK)" -o
"$(<)" "$(>)"
"$(LIBRARIES)" -l$(FINDLIBS-ST) -l$(FINDLIBS-SA)
$(OPTIONS) 
}


# Always remove archive and start again. Here's rationale
from
# Andre Hentz:
# I had a file, say a1.c, that was included into liba.a. 
# I moved a1.c to a2.c, updated my Jamfiles and rebuilt. 
# My program was crashing with absurd errors. 
# After some debugging I traced it back to the fact that
a1.o was *still* 
# in liba.a 
RM = [ common.rm-command ] ;

if [ os.name ] = NT
{
    RM = "if exist \"$(<[1])\" DEL
\"$(<[1])\""  ;
}


# Declare action for creating static libraries
# The 'r' letter means to add files to the archive with
replacement
# Since we remove archive, we don't care about replacement,
but
# there's no option "add without replacement".
# The 'c' letter means suppresses warning in case the
archive
#   does not exists yet. That warning is produced only on
#   some platforms, for whatever reasons.
actions piecemeal archive 
{
    $(RM) "$(<)"
    ar rc "$(<)" "$(>)"
}


rule link.dll ( targets * : sources * : properties * )
{
    SPACE on $(targets) = " " ;    
    JAM_SEMAPHORE on $(targets) =
<s>qcc-link-semaphore ;
}

# Differ from 'link' above only by -shared.
actions link.dll bind LIBRARIES
{
    "$(CONFIG_COMMAND)"
-L"$(LINKPATH)"
-Wl,-R$(SPACE)-Wl,"$(RPATH)" -o
"$(<)"
$(HAVE_SONAME)-Wl,-h$(SPACE)-Wl,$(<[1]=)
-shared "$(>)"  "$(LIBRARIES)"
-l$(FINDLIBS-ST) -l$(FINDLIBS-SA) $(OPTIONS)  
}

_______________________________________________
Unsubscribe & other changes: http://lists.boost.org/mailman/listinfo.cgi/boost-build
[1-2]

about | contact  Other archives ( Real Estate discussion Medical topics )