Bumped version in configure.ac to 1.5.6 (assuming that "1.5f" is
the next version released). Updated files in mk/autoconf and mk/jam with copies from CS; fixes a GLU detection issue on MinGW. Set msvc/bullet_ico.ico as the default application icon. Disabled exceptions for gcc builds.
This commit is contained in:
@@ -1,151 +1,164 @@
|
||||
#============================================================================
|
||||
# Rules for compiling applications
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
# Use a more sensible and typical mode for executables than Jam's default.
|
||||
if "$(EXEMODE)" = "711" { EXEMODE = "+x" ; }
|
||||
|
||||
## Application appname : sources [ : options ]
|
||||
## Build an application out of sourcefiles. All sourcefiles will be passed
|
||||
## to the Objects rule which tries to compile them into object-files. You
|
||||
## can create rules for your own filetypes with the UserObject rule. Header
|
||||
## files will just be ignored. They are only used for MSVC projectfile
|
||||
## generation.
|
||||
## Possible options are "noinstall" if you don't want a default install
|
||||
## target to be created and "console" if you're building a console
|
||||
## application (an application without any graphical output which is
|
||||
## intended to be used on commandline)
|
||||
## Some notes: You should not add the .exe extension to the appname - jam
|
||||
## will do that on win32.
|
||||
## Options:
|
||||
## console: Create a console application
|
||||
## noinstall: Do not set up a default installation targets.
|
||||
## independent: The target will not be made a dependency of the apps and
|
||||
## all target.
|
||||
## nohelp: Do not invoke Help for this target.
|
||||
## notest: Do not set up unit-testing support for this target.
|
||||
## nomanifest: (Win32/MSVC) Don't generate manifest for application.
|
||||
rule Application
|
||||
{
|
||||
# check options
|
||||
CheckOptions noinstall console independent nohelp notest nomanifest : $(3) : $(<) ;
|
||||
|
||||
local target = [ ConstructApplicationTarget $(<) : $(3) ] ;
|
||||
local sources = [ DoSourceGrist $(>) ] ;
|
||||
local objects = [ CompileObjects $(sources) ] ;
|
||||
|
||||
$(<)_TYPE = application ;
|
||||
$(<)_OBJECTS = $(objects) ;
|
||||
$(<)_SOURCES = $(sources) ;
|
||||
$(<)_TARGET = $(target) ;
|
||||
|
||||
# create target clean rule
|
||||
Always $(<)clean ;
|
||||
NotFile $(<)clean ;
|
||||
Clean $(<)clean : $(objects) ; # create target clean rule
|
||||
|
||||
# so 'jam foo' works when it's really foo.exe (Windows) or foo.app (MacOS/X)
|
||||
if $(target) != $(<)
|
||||
{
|
||||
Depends $(<) : $(target) ;
|
||||
NotFile $(<) ;
|
||||
}
|
||||
|
||||
# make dependency on apps target
|
||||
if ! [ IsElem independent : $(3) ]
|
||||
{
|
||||
Depends apps : $(<) ;
|
||||
}
|
||||
|
||||
# construct Install target
|
||||
if ! [ IsElem noinstall : $(3) ]
|
||||
{
|
||||
local install_opts ;
|
||||
if [ IsElem console : $(3) ]
|
||||
{
|
||||
install_opts += console ;
|
||||
}
|
||||
SystemInstallApplication $(target) : : $(install_opts) ;
|
||||
}
|
||||
|
||||
# Link
|
||||
MakeLocate $(target) : $(LOCATE.TARGETS) ;
|
||||
SystemLinkApplication $(<) : $(objects) : $(3) ;
|
||||
|
||||
CFlags $(<) : $(APPLICATION.CFLAGS) ;
|
||||
LFlags $(<) : $(LINKLIBS) $(APPLICATION.LFLAGS) ;
|
||||
|
||||
if ! [ IsElem nohelp : $(3) ]
|
||||
{
|
||||
local desc = [ Description $(<) ] ;
|
||||
if ! $(desc) { desc = "$(<) application" ; }
|
||||
Help $(<) : "Build the $(desc)" ;
|
||||
}
|
||||
|
||||
if ! [ IsElem notest : $(options) ]
|
||||
{
|
||||
# @@@ Disabled for now; see docs/todo_jam.txt
|
||||
#UnitTest $(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
## ShellScript scriptname : rule [ : options ]
|
||||
## Build a shell script by invoking `rule', the script creation rule, which
|
||||
## is passed `scriptname' and `options'.
|
||||
## Options:
|
||||
## noinstall: Do not set up a default installation target.
|
||||
## nohelp: Do not invoke Help for this target.
|
||||
rule ShellScript
|
||||
{
|
||||
CheckOptions noinstall nohelp : $(3) : $(<) ;
|
||||
|
||||
Always $(<)clean ;
|
||||
NotFile $(<)clean ;
|
||||
Clean clean : $(<) ;
|
||||
Clean $(<)clean : $(<) ;
|
||||
Depends apps : $(<) ;
|
||||
MakeLocate $(<) : $(LOCATE.TARGETS) ;
|
||||
|
||||
if ! [ IsElem noinstall : $(3) ]
|
||||
{
|
||||
Depends install_bin : [ DoInstall $(<) : $(bindir) : $(INSTALL_PROGRAM) ] ;
|
||||
}
|
||||
|
||||
$(2) $(<) : $(3) ;
|
||||
|
||||
MODE on $(<) = $(EXEMODE) ;
|
||||
SUBDIR on $(<) = $(SUBDIR) ;
|
||||
Chmod $(<) ;
|
||||
|
||||
if ! [ IsElem nohelp : $(3) ]
|
||||
{
|
||||
local desc = [ Description $(<) ] ;
|
||||
if ! $(desc) { desc = "$(<) script" ; }
|
||||
Help $(<) : "Build the $(desc)" ;
|
||||
}
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# private part
|
||||
|
||||
# Construct pseudo target apps which is used instead of the pseudo target exe
|
||||
# in Jambase
|
||||
Depends exe : apps ;
|
||||
NotFile apps ;
|
||||
Help apps : "Build all applications" ;
|
||||
#============================================================================
|
||||
# Rules for compiling applications
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
# Use a more sensible and typical mode for executables than Jam's default.
|
||||
if "$(EXEMODE)" = "711" { EXEMODE = "+x" ; }
|
||||
|
||||
## Application appname : sources [ : options ]
|
||||
## Build an application out of sourcefiles. All sourcefiles will be passed
|
||||
## to the Objects rule which tries to compile them into object-files. You
|
||||
## can create rules for your own filetypes with the UserObject rule. Header
|
||||
## files will just be ignored. They are only used for MSVC projectfile
|
||||
## generation.
|
||||
## Possible options are "noinstall" if you don't want a default install
|
||||
## target to be created and "console" if you're building a console
|
||||
## application (an application without any graphical output which is
|
||||
## intended to be used on commandline)
|
||||
## Some notes: You should not add the .exe extension to the appname - jam
|
||||
## will do that on win32.
|
||||
## Options:
|
||||
## console: Create a console application
|
||||
## noinstall: Do not set up a default installation targets.
|
||||
## independent: The target will not be made a dependency of the apps and
|
||||
## all target.
|
||||
## nohelp: Do not invoke Help for this target.
|
||||
## notest: Do not set up unit-testing support for this target.
|
||||
## nomanifest: (Win32/MSVC) Don't generate manifest for application.
|
||||
rule Application
|
||||
{
|
||||
# check options
|
||||
CheckOptions noinstall console independent nohelp notest nomanifest : $(3) : $(<) ;
|
||||
|
||||
local target = [ ConstructApplicationTarget $(<) : $(3) ] ;
|
||||
local sources = [ DoSourceGrist $(>) ] ;
|
||||
local objects = [ CompileObjects $(sources) ] ;
|
||||
|
||||
$(<)_TYPE = application ;
|
||||
$(<)_OBJECTS = $(objects) ;
|
||||
$(<)_SOURCES = $(sources) ;
|
||||
$(<)_TARGET = $(target) ;
|
||||
|
||||
# so 'jam foo' works when it's really foo.exe (Windows) or foo.app (MacOS/X)
|
||||
if $(target) != $(<)
|
||||
{
|
||||
Depends $(<) : $(target) ;
|
||||
NotFile $(<) ;
|
||||
}
|
||||
|
||||
# make dependency on apps target
|
||||
if ! [ IsElem independent : $(3) ]
|
||||
{
|
||||
Depends apps : $(<) ;
|
||||
}
|
||||
|
||||
# construct Install target
|
||||
if ! [ IsElem noinstall : $(3) ]
|
||||
{
|
||||
local install_opts ;
|
||||
if [ IsElem console : $(3) ]
|
||||
{
|
||||
install_opts += console ;
|
||||
}
|
||||
SystemInstallApplication $(target) : : $(install_opts) ;
|
||||
}
|
||||
|
||||
# Link
|
||||
MakeLocate $(target) : $(LOCATE.TARGETS) ;
|
||||
SystemLinkApplication $(<) : $(objects) : $(3) ;
|
||||
|
||||
local cleanextra ;
|
||||
if $(LINK.DEBUG.INFO.SEPARATE) = "yes"
|
||||
{
|
||||
local debugfile = [ SplitDebugInfo $(target) ] ;
|
||||
cleanextra += $(debugfile) ;
|
||||
if ! [ IsElem noinstall : $(3) ]
|
||||
{
|
||||
NoCare $(debugfile) ;
|
||||
Depends install_bin : [ DoInstall $(debugfile) : $(bindir) : $(INSTALL_DATA) ] ;
|
||||
}
|
||||
}
|
||||
|
||||
CFlags $(<) : $(APPLICATION.CFLAGS) ;
|
||||
LFlags $(<) : $(LINKLIBS) $(APPLICATION.LFLAGS) ;
|
||||
|
||||
# create target clean rule
|
||||
Always $(<)clean ;
|
||||
NotFile $(<)clean ;
|
||||
Clean $(<)clean : $(objects) $(cleanextra) ;
|
||||
Clean clean : $(cleanextra) ;
|
||||
|
||||
if ! [ IsElem nohelp : $(3) ]
|
||||
{
|
||||
local desc = [ Description $(<) ] ;
|
||||
if ! $(desc) { desc = "$(<) application" ; }
|
||||
Help $(<) : "Build the $(desc)" ;
|
||||
}
|
||||
|
||||
if ! [ IsElem notest : $(options) ]
|
||||
{
|
||||
# @@@ Disabled for now; see docs/todo_jam.txt
|
||||
#UnitTest $(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
## ShellScript scriptname : rule [ : options ]
|
||||
## Build a shell script by invoking `rule', the script creation rule, which
|
||||
## is passed `scriptname' and `options'.
|
||||
## Options:
|
||||
## noinstall: Do not set up a default installation target.
|
||||
## nohelp: Do not invoke Help for this target.
|
||||
rule ShellScript
|
||||
{
|
||||
CheckOptions noinstall nohelp : $(3) : $(<) ;
|
||||
|
||||
Always $(<)clean ;
|
||||
NotFile $(<)clean ;
|
||||
Clean clean : $(<) ;
|
||||
Clean $(<)clean : $(<) ;
|
||||
Depends apps : $(<) ;
|
||||
MakeLocate $(<) : $(LOCATE.TARGETS) ;
|
||||
|
||||
if ! [ IsElem noinstall : $(3) ]
|
||||
{
|
||||
Depends install_bin : [ DoInstall $(<) : $(bindir) : $(INSTALL_PROGRAM) ] ;
|
||||
}
|
||||
|
||||
$(2) $(<) : $(3) ;
|
||||
|
||||
MODE on $(<) = $(EXEMODE) ;
|
||||
SUBDIR on $(<) = $(SUBDIR) ;
|
||||
Chmod $(<) ;
|
||||
|
||||
if ! [ IsElem nohelp : $(3) ]
|
||||
{
|
||||
local desc = [ Description $(<) ] ;
|
||||
if ! $(desc) { desc = "$(<) script" ; }
|
||||
Help $(<) : "Build the $(desc)" ;
|
||||
}
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# private part
|
||||
|
||||
# Construct pseudo target apps which is used instead of the pseudo target exe
|
||||
# in Jambase
|
||||
Depends exe : apps ;
|
||||
NotFile apps ;
|
||||
Help apps : "Build all applications" ;
|
||||
|
||||
@@ -1,50 +1,50 @@
|
||||
#============================================================================
|
||||
# Rules for handling assembler files
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
if $(CMD.NASM)
|
||||
{
|
||||
|
||||
rule NasmRule
|
||||
{
|
||||
local object = [ DoObjectGrist [ PrefixSuffix $(>)_ : $(<) : $(SUFOBJ) ] ] ;
|
||||
Nasm $(object) : $(<) ;
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType NasmRule : .asm ;
|
||||
|
||||
rule Nasm
|
||||
{
|
||||
Depends $(<) : $(>) ;
|
||||
NASM.FLAGS on $(<) += $(NASM.FLAGS) ;
|
||||
# NASM doesn't scan for headers in current dir of the files, so add the dir of
|
||||
# the file to the -I flags
|
||||
local includeflags = [ FIncludes $(SEARCH_SOURCE)/$(<:D) $(SUBDIRHDRS) $(HDRS) ] ;
|
||||
# NASM requires that -I paths have a trailing slash.
|
||||
INCLUDEFLAGS on $(<) = $(includeflags)$(SLASH) ;
|
||||
}
|
||||
|
||||
NASM.HDRPATTERN = "^[ ]*%[ ]*include[ ]*[<\"]([^\">]*)[\">].*$" ;
|
||||
RegisterHeaderRule HeaderRule : $(NASM.HDRPATTERN) : .asm .ash ;
|
||||
|
||||
actions Nasm
|
||||
{
|
||||
$(CMD.NASM) $(NASM.FLAGS) $(INCLUDEFLAGS) -o $(<) $(>)
|
||||
}
|
||||
}
|
||||
#============================================================================
|
||||
# Rules for handling assembler files
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
if $(CMD.NASM)
|
||||
{
|
||||
|
||||
rule NasmRule
|
||||
{
|
||||
local object = [ DoObjectGrist [ PrefixSuffix $(>)_ : $(<) : $(SUFOBJ) ] ] ;
|
||||
Nasm $(object) : $(<) ;
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType NasmRule : .asm ;
|
||||
|
||||
rule Nasm
|
||||
{
|
||||
Depends $(<) : $(>) ;
|
||||
NASM.FLAGS on $(<) += $(NASM.FLAGS) ;
|
||||
# NASM doesn't scan for headers in current dir of the files, so add the dir of
|
||||
# the file to the -I flags
|
||||
local includeflags = [ FIncludes $(SEARCH_SOURCE)/$(<:D) $(SUBDIRHDRS) $(HDRS) ] ;
|
||||
# NASM requires that -I paths have a trailing slash.
|
||||
INCLUDEFLAGS on $(<) = $(includeflags)$(SLASH) ;
|
||||
}
|
||||
|
||||
NASM.HDRPATTERN = "^[ ]*%[ ]*include[ ]*[<\"]([^\">]*)[\">].*$" ;
|
||||
RegisterHeaderRule HeaderRule : $(NASM.HDRPATTERN) : .asm .ash ;
|
||||
|
||||
actions Nasm
|
||||
{
|
||||
$(CMD.NASM) $(NASM.FLAGS) $(INCLUDEFLAGS) -o $(<) $(>)
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,165 +1,165 @@
|
||||
#============================================================================
|
||||
# Rules for flex and bison
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
if $(CMD.FLEX)
|
||||
{
|
||||
# Some versions of Flex-generated files want to include <unistd.h> which is
|
||||
# not normally available on Windows, so we need to protect it. We also
|
||||
# filter out CVS `Header' keywords in order to prevent CVS from thinking that
|
||||
# the file has changed simply because the Header information is different.
|
||||
FLEX.SED_SCRIPT =
|
||||
"'s/\\([ ]*#[ ]*include[ ][ ]*<unistd.h>\\)/#ifndef WIN32\\
|
||||
\\1\\
|
||||
#endif/;/\$Header:/d'" ;
|
||||
|
||||
# Compilers such as MSVC do not like #line directives. Since the generated
|
||||
# file might get stored in CVS and used by MSVC users (even if generated on
|
||||
# Unix, for instance), we want to suppress #line directives in all cases.
|
||||
FLEX.FLAGS += -L ;
|
||||
|
||||
rule FlexRule
|
||||
{
|
||||
local object ;
|
||||
local cfile = [ DoObjectGrist $(<:S=.c) ] ;
|
||||
|
||||
MakeLocate $(cfile) : $(LOCATE_TARGET) ;
|
||||
SEARCH on $(cfile) = $(LOCATE_TARGET) ;
|
||||
|
||||
Flex $(cfile) : $(<) ;
|
||||
object = [ CompileObjects $(cfile) : $(>) ] ;
|
||||
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType FlexRule : .l ;
|
||||
|
||||
rule Flex++Rule
|
||||
{
|
||||
local object ;
|
||||
local cppfile = [ DoObjectGrist $(<:S=.cpp) ] ;
|
||||
|
||||
MakeLocate $(cppfile) : $(LOCATE_TARGET) ;
|
||||
SEARCH on $(cppfile) = $(LOCATE_TARGET) ;
|
||||
|
||||
Flex $(cppfile) : $(<) ;
|
||||
object = [ CompileObjects $(cppfile) : $(>) ] ;
|
||||
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType Flex++Rule : .ll ;
|
||||
|
||||
rule Flex
|
||||
{
|
||||
Depends $(<) : $(>) ;
|
||||
FLEX.FLAGS on $(<) += $(FLEX.FLAGS) ;
|
||||
}
|
||||
|
||||
# Use -t and output redirection to avoid flex choosing undesirable names for
|
||||
# its output files. Also apply FLEX.SED_SCRIPT.
|
||||
actions Flex
|
||||
{
|
||||
$(CMD.FLEX) -t $(FLEX.FLAGS) $(>) | $(SED) $(FLEX.SED_SCRIPT) > $(<)
|
||||
}
|
||||
}
|
||||
|
||||
if $(CMD.BISON)
|
||||
{
|
||||
rule BisonRule
|
||||
{
|
||||
local object ;
|
||||
local cfile = [ DoObjectGrist $(<:S=.c) ] ;
|
||||
local headerfile = [ DoObjectGrist $(<:S=.h) ] ;
|
||||
|
||||
# Jam's header file scannning doesn't use grist so we have to workaround
|
||||
# this here.
|
||||
Includes $(headerfile:G=$(SOURCE_GRIST:E)!$(SUBVARIANT:J=!)) : $(headerfile) ;
|
||||
|
||||
MakeLocate $(cfile) $(headerfile) : $(LOCATE_TARGET) ;
|
||||
|
||||
BISON.FLAGS on $(cfile) =
|
||||
[ on [ DoSourceGrist $(<:S=.c) ] GetVar BISON.FLAGS ] ;
|
||||
Bison $(cfile) : $(<) ;
|
||||
# Work around for jam warning about independant target when we put both
|
||||
# headerfile and cppfile in the bison line...
|
||||
Includes $(cppfile) : $(headerfile) ;
|
||||
object = [ CompileObjects $(cfile) : $(>) ] ;
|
||||
SEARCH on $(cfile) = $(LOCATE_TARGET) ;
|
||||
SEARCH on $(headerfile) = $(LOCATE_TARGET) ;
|
||||
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType BisonRule : .y ;
|
||||
|
||||
rule Bison++Rule
|
||||
{
|
||||
local object ;
|
||||
local cppfile = [ DoObjectGrist $(<:S=.cpp) ] ;
|
||||
local headerfile = [ DoObjectGrist $(<:S=.hpp) ] ;
|
||||
|
||||
# Jam's header file scannning doesn't use grist so we have to workaround
|
||||
# this here.
|
||||
Includes $(headerfile:G=$(SOURCE_GRIST:E)!$(SUBVARIANT:J=!)) : $(headerfile) ;
|
||||
|
||||
MakeLocate $(cppfile) : $(LOCATE_TARGET) ;
|
||||
MakeLocate $(headerfile) : $(LOCATE_TARGET) ;
|
||||
|
||||
BISON.FLAGS on $(cppfile) =
|
||||
[ on [ DoSourceGrist $(<:S=.cpp) ] GetVar BISON.FLAGS ] ;
|
||||
Bison $(cppfile) : $(<) ;
|
||||
# Work around for jam warning about independant target when we put both
|
||||
# headerfile and cppfile in the bison line...
|
||||
Includes $(cppfile) : $(headerfile) ;
|
||||
object = [ CompileObjects $(cppfile) : $(>) ] ;
|
||||
SEARCH on $(cppfile) = $(LOCATE_TARGET) ;
|
||||
SEARCH on $(headerfile) = $(LOCATE_TARGET) ;
|
||||
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType Bison++Rule : .yy ;
|
||||
|
||||
rule Bison
|
||||
{
|
||||
Depends $(<) : $(>) ;
|
||||
BISON.FLAGS on $(<) += $(BISON.FLAGS) ;
|
||||
}
|
||||
rule BisonFlags
|
||||
{
|
||||
local target ;
|
||||
|
||||
if $(<:S) = .yy
|
||||
{
|
||||
target = [ DoSourceGrist $(<:S=.cpp) $(<:S=.hpp) ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
target = [ DoSourceGrist $(<:S=.c) $(<:S=.h) ] ;
|
||||
}
|
||||
BISON.FLAGS on $(target) += $(>) ;
|
||||
}
|
||||
|
||||
# Compilers such as MSVC do not like #line directives. Since the generated
|
||||
# file might get stored in CVS and used by MSVC users (even if generated on
|
||||
# Unix, for instance), we want to suppress #line directives in all cases.
|
||||
BISON.FLAGS += --no-lines ;
|
||||
|
||||
actions Bison
|
||||
{
|
||||
$(CMD.BISON) -d $(BISON.FLAGS) -o $(<[1]) $(>)
|
||||
}
|
||||
}
|
||||
#============================================================================
|
||||
# Rules for flex and bison
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
if $(CMD.FLEX)
|
||||
{
|
||||
# Some versions of Flex-generated files want to include <unistd.h> which is
|
||||
# not normally available on Windows, so we need to protect it. We also
|
||||
# filter out CVS `Header' keywords in order to prevent CVS from thinking that
|
||||
# the file has changed simply because the Header information is different.
|
||||
FLEX.SED_SCRIPT =
|
||||
"'s/\\([ ]*#[ ]*include[ ][ ]*<unistd.h>\\)/#ifndef WIN32\\
|
||||
\\1\\
|
||||
#endif/;/\$Header:/d'" ;
|
||||
|
||||
# Compilers such as MSVC do not like #line directives. Since the generated
|
||||
# file might get stored in CVS and used by MSVC users (even if generated on
|
||||
# Unix, for instance), we want to suppress #line directives in all cases.
|
||||
FLEX.FLAGS += -L ;
|
||||
|
||||
rule FlexRule
|
||||
{
|
||||
local object ;
|
||||
local cfile = [ DoObjectGrist $(<:S=.c) ] ;
|
||||
|
||||
MakeLocate $(cfile) : $(LOCATE_TARGET) ;
|
||||
SEARCH on $(cfile) = $(LOCATE_TARGET) ;
|
||||
|
||||
Flex $(cfile) : $(<) ;
|
||||
object = [ CompileObjects $(cfile) : $(>) ] ;
|
||||
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType FlexRule : .l ;
|
||||
|
||||
rule Flex++Rule
|
||||
{
|
||||
local object ;
|
||||
local cppfile = [ DoObjectGrist $(<:S=.cpp) ] ;
|
||||
|
||||
MakeLocate $(cppfile) : $(LOCATE_TARGET) ;
|
||||
SEARCH on $(cppfile) = $(LOCATE_TARGET) ;
|
||||
|
||||
Flex $(cppfile) : $(<) ;
|
||||
object = [ CompileObjects $(cppfile) : $(>) ] ;
|
||||
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType Flex++Rule : .ll ;
|
||||
|
||||
rule Flex
|
||||
{
|
||||
Depends $(<) : $(>) ;
|
||||
FLEX.FLAGS on $(<) += $(FLEX.FLAGS) ;
|
||||
}
|
||||
|
||||
# Use -t and output redirection to avoid flex choosing undesirable names for
|
||||
# its output files. Also apply FLEX.SED_SCRIPT.
|
||||
actions Flex
|
||||
{
|
||||
$(CMD.FLEX) -t $(FLEX.FLAGS) $(>) | $(SED) $(FLEX.SED_SCRIPT) > $(<)
|
||||
}
|
||||
}
|
||||
|
||||
if $(CMD.BISON)
|
||||
{
|
||||
rule BisonRule
|
||||
{
|
||||
local object ;
|
||||
local cfile = [ DoObjectGrist $(<:S=.c) ] ;
|
||||
local headerfile = [ DoObjectGrist $(<:S=.h) ] ;
|
||||
|
||||
# Jam's header file scannning doesn't use grist so we have to workaround
|
||||
# this here.
|
||||
Includes $(headerfile:G=$(SOURCE_GRIST:E)!$(SUBVARIANT:J=!)) : $(headerfile) ;
|
||||
|
||||
MakeLocate $(cfile) $(headerfile) : $(LOCATE_TARGET) ;
|
||||
|
||||
BISON.FLAGS on $(cfile) =
|
||||
[ on [ DoSourceGrist $(<:S=.c) ] GetVar BISON.FLAGS ] ;
|
||||
Bison $(cfile) : $(<) ;
|
||||
# Work around for jam warning about independant target when we put both
|
||||
# headerfile and cppfile in the bison line...
|
||||
Includes $(cppfile) : $(headerfile) ;
|
||||
object = [ CompileObjects $(cfile) : $(>) ] ;
|
||||
SEARCH on $(cfile) = $(LOCATE_TARGET) ;
|
||||
SEARCH on $(headerfile) = $(LOCATE_TARGET) ;
|
||||
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType BisonRule : .y ;
|
||||
|
||||
rule Bison++Rule
|
||||
{
|
||||
local object ;
|
||||
local cppfile = [ DoObjectGrist $(<:S=.cpp) ] ;
|
||||
local headerfile = [ DoObjectGrist $(<:S=.hpp) ] ;
|
||||
|
||||
# Jam's header file scannning doesn't use grist so we have to workaround
|
||||
# this here.
|
||||
Includes $(headerfile:G=$(SOURCE_GRIST:E)!$(SUBVARIANT:J=!)) : $(headerfile) ;
|
||||
|
||||
MakeLocate $(cppfile) : $(LOCATE_TARGET) ;
|
||||
MakeLocate $(headerfile) : $(LOCATE_TARGET) ;
|
||||
|
||||
BISON.FLAGS on $(cppfile) =
|
||||
[ on [ DoSourceGrist $(<:S=.cpp) ] GetVar BISON.FLAGS ] ;
|
||||
Bison $(cppfile) : $(<) ;
|
||||
# Work around for jam warning about independant target when we put both
|
||||
# headerfile and cppfile in the bison line...
|
||||
Includes $(cppfile) : $(headerfile) ;
|
||||
object = [ CompileObjects $(cppfile) : $(>) ] ;
|
||||
SEARCH on $(cppfile) = $(LOCATE_TARGET) ;
|
||||
SEARCH on $(headerfile) = $(LOCATE_TARGET) ;
|
||||
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType Bison++Rule : .yy ;
|
||||
|
||||
rule Bison
|
||||
{
|
||||
Depends $(<) : $(>) ;
|
||||
BISON.FLAGS on $(<) += $(BISON.FLAGS) ;
|
||||
}
|
||||
rule BisonFlags
|
||||
{
|
||||
local target ;
|
||||
|
||||
if $(<:S) = .yy
|
||||
{
|
||||
target = [ DoSourceGrist $(<:S=.cpp) $(<:S=.hpp) ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
target = [ DoSourceGrist $(<:S=.c) $(<:S=.h) ] ;
|
||||
}
|
||||
BISON.FLAGS on $(target) += $(>) ;
|
||||
}
|
||||
|
||||
# Compilers such as MSVC do not like #line directives. Since the generated
|
||||
# file might get stored in CVS and used by MSVC users (even if generated on
|
||||
# Unix, for instance), we want to suppress #line directives in all cases.
|
||||
BISON.FLAGS += --no-lines ;
|
||||
|
||||
actions Bison
|
||||
{
|
||||
$(CMD.BISON) -d $(BISON.FLAGS) -o $(<[1]) $(>)
|
||||
}
|
||||
}
|
||||
|
||||
165
mk/jam/build.jam
165
mk/jam/build.jam
@@ -1,82 +1,83 @@
|
||||
#============================================================================
|
||||
# Main rules file - Includes all important rulefiles in correct order
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
# Enable if you want debug messages.
|
||||
JAM_DEBUG ?= 1 ;
|
||||
|
||||
jamrulesdir = $(TOP)/mk/jam ;
|
||||
|
||||
# Utility and compatibility rules used by all other scripts.
|
||||
include $(jamrulesdir)/jamcompatibility.jam ;
|
||||
include $(jamrulesdir)/subdir.jam ;
|
||||
include $(jamrulesdir)/property.jam ;
|
||||
|
||||
# This needs to be included before _and_ after all other includes (except the
|
||||
# super low-level utility files above) since it optionally overrides built-in
|
||||
# rules to glean information about targets being defined.
|
||||
include $(jamrulesdir)/dump.jam ;
|
||||
|
||||
include $(jamrulesdir)/options.jam ;
|
||||
include $(jamrulesdir)/variant.jam ;
|
||||
include $(jamrulesdir)/resource.jam ;
|
||||
|
||||
include $(jamrulesdir)/helper.jam ;
|
||||
include $(jamrulesdir)/help.jam ;
|
||||
include $(jamrulesdir)/groups.jam ;
|
||||
include $(jamrulesdir)/install.jam ;
|
||||
include $(jamrulesdir)/clean.jam ;
|
||||
|
||||
include $(jamrulesdir)/objects.jam ;
|
||||
include $(jamrulesdir)/compiler.jam ;
|
||||
include $(jamrulesdir)/objectivec.jam ;
|
||||
include $(jamrulesdir)/assembler.jam ;
|
||||
include $(jamrulesdir)/bisonflex.jam ;
|
||||
include $(jamrulesdir)/swig.jam ;
|
||||
|
||||
include $(jamrulesdir)/flags.jam ;
|
||||
include $(jamrulesdir)/library.jam ;
|
||||
include $(jamrulesdir)/static.jam ;
|
||||
include $(jamrulesdir)/application.jam ;
|
||||
include $(jamrulesdir)/plugin.jam ;
|
||||
include $(jamrulesdir)/docs.jam ;
|
||||
include $(jamrulesdir)/unittest.jam ;
|
||||
|
||||
# Include OS specific rules
|
||||
switch $(TARGET.OS)
|
||||
{
|
||||
case WIN32 :
|
||||
include $(jamrulesdir)/win32.jam ;
|
||||
case MACOS_X :
|
||||
include $(jamrulesdir)/macosx.jam ;
|
||||
case UNIX :
|
||||
include $(jamrulesdir)/unix.jam ;
|
||||
case * :
|
||||
echo "WARNING: TARGET.OS not defined. Using unix" ;
|
||||
include $(jamrulesdir)/unix.jam ;
|
||||
}
|
||||
|
||||
# This needs to be included after all others because it overrides some of the
|
||||
# earlier defined rules when enabled. It even overrides Win32 rules, so it
|
||||
# needs to be after platform-specific includes, as well.
|
||||
include $(jamrulesdir)/msvcgen.jam ;
|
||||
|
||||
# This needs to included be before _and_ after all other includes since it
|
||||
# optionally overrides rules defined earlier.
|
||||
include $(jamrulesdir)/dump.jam ;
|
||||
#============================================================================
|
||||
# Main rules file - Includes all important rulefiles in correct order
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
# Enable if you want debug messages.
|
||||
JAM_DEBUG ?= 1 ;
|
||||
|
||||
jamrulesdir = $(TOP)/mk/jam ;
|
||||
|
||||
# Utility and compatibility rules used by all other scripts.
|
||||
include $(jamrulesdir)/jamcompatibility.jam ;
|
||||
include $(jamrulesdir)/subdir.jam ;
|
||||
include $(jamrulesdir)/property.jam ;
|
||||
|
||||
# This needs to be included before _and_ after all other includes (except the
|
||||
# super low-level utility files above) since it optionally overrides built-in
|
||||
# rules to glean information about targets being defined.
|
||||
include $(jamrulesdir)/dump.jam ;
|
||||
|
||||
include $(jamrulesdir)/options.jam ;
|
||||
include $(jamrulesdir)/variant.jam ;
|
||||
include $(jamrulesdir)/resource.jam ;
|
||||
|
||||
include $(jamrulesdir)/helper.jam ;
|
||||
include $(jamrulesdir)/help.jam ;
|
||||
include $(jamrulesdir)/groups.jam ;
|
||||
include $(jamrulesdir)/install.jam ;
|
||||
include $(jamrulesdir)/clean.jam ;
|
||||
|
||||
include $(jamrulesdir)/objects.jam ;
|
||||
include $(jamrulesdir)/compiler.jam ;
|
||||
include $(jamrulesdir)/objectivec.jam ;
|
||||
include $(jamrulesdir)/assembler.jam ;
|
||||
include $(jamrulesdir)/bisonflex.jam ;
|
||||
include $(jamrulesdir)/swig.jam ;
|
||||
include $(jamrulesdir)/strip.jam ;
|
||||
|
||||
include $(jamrulesdir)/flags.jam ;
|
||||
include $(jamrulesdir)/library.jam ;
|
||||
include $(jamrulesdir)/static.jam ;
|
||||
include $(jamrulesdir)/application.jam ;
|
||||
include $(jamrulesdir)/plugin.jam ;
|
||||
include $(jamrulesdir)/docs.jam ;
|
||||
include $(jamrulesdir)/unittest.jam ;
|
||||
|
||||
# Include OS specific rules
|
||||
switch $(TARGET.OS)
|
||||
{
|
||||
case WIN32 :
|
||||
include $(jamrulesdir)/win32.jam ;
|
||||
case MACOS_X :
|
||||
include $(jamrulesdir)/macosx.jam ;
|
||||
case UNIX :
|
||||
include $(jamrulesdir)/unix.jam ;
|
||||
case * :
|
||||
echo "WARNING: TARGET.OS not defined. Using unix" ;
|
||||
include $(jamrulesdir)/unix.jam ;
|
||||
}
|
||||
|
||||
# This needs to be included after all others because it overrides some of the
|
||||
# earlier defined rules when enabled. It even overrides Win32 rules, so it
|
||||
# needs to be after platform-specific includes, as well.
|
||||
include $(jamrulesdir)/msvcgen.jam ;
|
||||
|
||||
# This needs to included be before _and_ after all other includes since it
|
||||
# optionally overrides rules defined earlier.
|
||||
include $(jamrulesdir)/dump.jam ;
|
||||
|
||||
@@ -1,37 +1,37 @@
|
||||
#============================================================================
|
||||
# Rules for cleaning build detritus.
|
||||
# Copyright (C)2003 by Eric Sunshine <sunshine@sunshineco.com>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
# CleanDir <tag> : <dir> ...
|
||||
# Forcibly delete a set of directories, even if they are not empty.
|
||||
# Tag is one of the standard targets used with the "Clean" rule, such as
|
||||
# "clean" or "distclean".
|
||||
rule CleanDir
|
||||
{
|
||||
Always $(<) ;
|
||||
NotFile $(<) ;
|
||||
NoCare $(>) ;
|
||||
}
|
||||
|
||||
actions piecemeal together existing CleanDir
|
||||
{
|
||||
$(DELTREE) $(>)
|
||||
}
|
||||
|
||||
Help clean : "Remove all built targets from project" ;
|
||||
#============================================================================
|
||||
# Rules for cleaning build detritus.
|
||||
# Copyright (C)2003 by Eric Sunshine <sunshine@sunshineco.com>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
# CleanDir <tag> : <dir> ...
|
||||
# Forcibly delete a set of directories, even if they are not empty.
|
||||
# Tag is one of the standard targets used with the "Clean" rule, such as
|
||||
# "clean" or "distclean".
|
||||
rule CleanDir
|
||||
{
|
||||
Always $(<) ;
|
||||
NotFile $(<) ;
|
||||
NoCare $(>) ;
|
||||
}
|
||||
|
||||
actions piecemeal together existing CleanDir
|
||||
{
|
||||
$(DELTREE) $(>)
|
||||
}
|
||||
|
||||
Help clean : "Remove all built targets from project" ;
|
||||
|
||||
@@ -1,76 +1,76 @@
|
||||
#============================================================================
|
||||
# Rules for C and C++ files
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
if $(CMD.CC)
|
||||
{
|
||||
|
||||
rule CcRule
|
||||
{
|
||||
local object =
|
||||
[ DoObjectGrist [ PrefixSuffix $(>)_ : $(<) : $(SUFOBJ) ] ] ;
|
||||
Cc $(object) : $(<) ;
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType CcRule : .c ;
|
||||
RegisterHeaderRule HeaderRule : $(HDRPATTERN) : .c ;
|
||||
|
||||
rule Cc
|
||||
{
|
||||
Depends $(<) : $(>) ;
|
||||
|
||||
CCFLAGS on $(<) += $(CCFLAGS) $(SUBDIRCCFLAGS) ;
|
||||
CCHDRS on $(<) = [ on $(<) FIncludes $(HDRS) ] ;
|
||||
CCDEFS on $(<) = [ on $(<) FDefines $(DEFINES) ] ;
|
||||
}
|
||||
|
||||
actions Cc
|
||||
{
|
||||
$(CMD.CC) -c -o $(<) $(CCHDRS) $(CCFLAGS) $(CCDEFS) $(>)
|
||||
}
|
||||
} # end if $(CMD.CC)
|
||||
|
||||
if $(CMD.C++)
|
||||
{
|
||||
|
||||
rule C++Rule
|
||||
{
|
||||
local object =
|
||||
[ DoObjectGrist [ PrefixSuffix $(>)_ : $(<) : $(SUFOBJ) ] ] ;
|
||||
C++ $(object) : $(<) ;
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType C++Rule : .cpp .cc .c++ ;
|
||||
RegisterHeaderRule HeaderRule : $(HDRPATTERN) : .cpp .cc .c++ ;
|
||||
|
||||
rule C++
|
||||
{
|
||||
Depends $(<) : $(>) ;
|
||||
|
||||
C++FLAGS on $(<) += $(C++FLAGS) $(SUBDIRC++FLAGS) ;
|
||||
CCHDRS on $(<) = [ on $(<) FIncludes $(HDRS) ] ;
|
||||
CCDEFS on $(<) = [ on $(<) FDefines $(DEFINES) ] ;
|
||||
}
|
||||
|
||||
actions C++
|
||||
{
|
||||
$(CMD.C++) -c -o $(<) $(CCHDRS) $(C++FLAGS) $(CCDEFS) $(>)
|
||||
}
|
||||
} # end if $(CMD:C++)
|
||||
|
||||
#============================================================================
|
||||
# Rules for C and C++ files
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
if $(CMD.CC)
|
||||
{
|
||||
|
||||
rule CcRule
|
||||
{
|
||||
local object =
|
||||
[ DoObjectGrist [ PrefixSuffix $(>)_ : $(<) : $(SUFOBJ) ] ] ;
|
||||
Cc $(object) : $(<) ;
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType CcRule : .c ;
|
||||
RegisterHeaderRule HeaderRule : $(HDRPATTERN) : .c ;
|
||||
|
||||
rule Cc
|
||||
{
|
||||
Depends $(<) : $(>) ;
|
||||
|
||||
CCFLAGS on $(<) += $(CCFLAGS) $(SUBDIRCCFLAGS) ;
|
||||
CCHDRS on $(<) = [ on $(<) FIncludes $(HDRS) ] ;
|
||||
CCDEFS on $(<) = [ on $(<) FDefines $(DEFINES) ] ;
|
||||
}
|
||||
|
||||
actions Cc
|
||||
{
|
||||
$(CMD.CC) -c -o $(<) $(CCHDRS) $(CCFLAGS) $(CCDEFS) $(>)
|
||||
}
|
||||
} # end if $(CMD.CC)
|
||||
|
||||
if $(CMD.C++)
|
||||
{
|
||||
|
||||
rule C++Rule
|
||||
{
|
||||
local object =
|
||||
[ DoObjectGrist [ PrefixSuffix $(>)_ : $(<) : $(SUFOBJ) ] ] ;
|
||||
C++ $(object) : $(<) ;
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType C++Rule : .cpp .cc .c++ ;
|
||||
RegisterHeaderRule HeaderRule : $(HDRPATTERN) : .cpp .cc .c++ ;
|
||||
|
||||
rule C++
|
||||
{
|
||||
Depends $(<) : $(>) ;
|
||||
|
||||
C++FLAGS on $(<) += $(C++FLAGS) $(SUBDIRC++FLAGS) ;
|
||||
CCHDRS on $(<) = [ on $(<) FIncludes $(HDRS) ] ;
|
||||
CCDEFS on $(<) = [ on $(<) FDefines $(DEFINES) ] ;
|
||||
}
|
||||
|
||||
actions C++
|
||||
{
|
||||
$(CMD.C++) -c -o $(<) $(CCHDRS) $(C++FLAGS) $(CCDEFS) $(>)
|
||||
}
|
||||
} # end if $(CMD:C++)
|
||||
|
||||
|
||||
1376
mk/jam/docs.jam
1376
mk/jam/docs.jam
File diff suppressed because it is too large
Load Diff
256
mk/jam/dump.jam
256
mk/jam/dump.jam
@@ -1,128 +1,128 @@
|
||||
#==============================================================================
|
||||
# Utility functions for collecting information about the Jam environment.
|
||||
# Copyright (C)2004 by Eric Sunshine <sunshine@sunshineco.com>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#==============================================================================
|
||||
|
||||
#------------------------------------------------------------------------------
|
||||
# When the target "dumptargets" is invoked, dump the top-level, user-visible
|
||||
# build targets as a whitespace-delimited list to the file named by the Jam
|
||||
# variable DUMPTARGETS_FILE. Example:
|
||||
#
|
||||
# jam -sDUMPTARGETS_FILE=targets.txt dumptargets
|
||||
#
|
||||
# This output might be useful, for instance, when composing documentation (via
|
||||
# some automated mechanism) which lists the targets visible to the user.
|
||||
#
|
||||
# IMPLEMENTATION NOTES
|
||||
#
|
||||
# The emitted target names are collected from several locations:
|
||||
#
|
||||
# - All single-word arguments to NotFile composed of ._- and alphanumerics.
|
||||
#
|
||||
# - Targets defined by the Application rule. Unlike other rules (Plugin,
|
||||
# Library, etc.) which compose a top-level pseudo-target using NotFile
|
||||
# (which is thus caught by the above case), on Unix, the Application rule
|
||||
# does not invoke NotFile since the top-level target has the same name as
|
||||
# the generated executable.
|
||||
#
|
||||
# - Targets defined by the ShellScript rule, since the emitted shell scripts
|
||||
# have the same name as the top-level target.
|
||||
#
|
||||
# Collection occurs in two phases. This file must be included by build.jam
|
||||
# before any other utility *.jam files are included, and it must also be
|
||||
# included after all other utility *.jam files are included. In the first
|
||||
# phase, the NotFile rule is re-defined so that we can catch pseudo-targets
|
||||
# created by the other utility *.jam files (we must re-define NotFile before
|
||||
# they are included), as well as any NotFile pseudo-targets created by Jamfiles
|
||||
# throughout the project. In the second phase, the Application and ShellScript
|
||||
# rules are re-defined (we must do so after application.jam has defined the
|
||||
# implementations which we override). These overrides allow us to catch
|
||||
# application and shell-script targets which project-wide Jamfiles define.
|
||||
#------------------------------------------------------------------------------
|
||||
if $(DUMPTARGETS_FILE)
|
||||
{
|
||||
# Jam does not support arithmetic, so we fake it with Roman numerals.
|
||||
DUMPTARGETS_PASS ?= "" ;
|
||||
DUMPTARGETS_PASS = "$(DUMPTARGETS_PASS)I" ;
|
||||
|
||||
switch $(DUMPTARGETS_PASS)
|
||||
{
|
||||
case I :
|
||||
|
||||
actions InitPseudoTargets
|
||||
{
|
||||
$(RM) $(<)
|
||||
}
|
||||
|
||||
rule DumpPseudoTargets
|
||||
{
|
||||
NotFile $(<) ;
|
||||
Always $(<) ;
|
||||
Depends $(<) : $(>) ;
|
||||
Always $(>) ;
|
||||
InitPseudoTargets $(>) ;
|
||||
}
|
||||
|
||||
DumpPseudoTargets dumptargets : "$(DUMPTARGETS_FILE)" ;
|
||||
|
||||
actions together piecemeal EmitPseudoTarget
|
||||
{
|
||||
echo "$(>)" >> $(<)
|
||||
}
|
||||
|
||||
rule PossiblePseudoTarget
|
||||
{
|
||||
# NoCare and Includes are not actually required; they are used here merely to
|
||||
# avoid Jam's "using independent target" warning. Note, however, that Jam
|
||||
# 2.4 and BoostJam try building the target despite the fact that we NoCare
|
||||
# about it. (Presumably this is because the targets have updating actions,
|
||||
# and those actions override the NoCare.) Consequently, we have to put up
|
||||
# with the "using independent target" warnings for these older Jam versions.
|
||||
NoCare $(<) ;
|
||||
if $(JAMVERSION) != 2.4 { Includes dumptargets : $(<) ; }
|
||||
|
||||
local i ;
|
||||
for i in $(<)
|
||||
{
|
||||
local s = [ Match ^([A-Za-z0-9_.-]+)$ : $(i) ] ;
|
||||
if $(s)
|
||||
{
|
||||
EmitPseudoTarget "$(DUMPTARGETS_FILE)" : $(i) ;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
rule NotFile
|
||||
{
|
||||
PossiblePseudoTarget $(<) ;
|
||||
}
|
||||
|
||||
case II :
|
||||
|
||||
rule Application
|
||||
{
|
||||
PossiblePseudoTarget $(<) $(<)clean ;
|
||||
}
|
||||
|
||||
rule ShellScript
|
||||
{
|
||||
PossiblePseudoTarget $(<) $(<)clean ;
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
#==============================================================================
|
||||
# Utility functions for collecting information about the Jam environment.
|
||||
# Copyright (C)2004 by Eric Sunshine <sunshine@sunshineco.com>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#==============================================================================
|
||||
|
||||
#------------------------------------------------------------------------------
|
||||
# When the target "dumptargets" is invoked, dump the top-level, user-visible
|
||||
# build targets as a whitespace-delimited list to the file named by the Jam
|
||||
# variable DUMPTARGETS_FILE. Example:
|
||||
#
|
||||
# jam -sDUMPTARGETS_FILE=targets.txt dumptargets
|
||||
#
|
||||
# This output might be useful, for instance, when composing documentation (via
|
||||
# some automated mechanism) which lists the targets visible to the user.
|
||||
#
|
||||
# IMPLEMENTATION NOTES
|
||||
#
|
||||
# The emitted target names are collected from several locations:
|
||||
#
|
||||
# - All single-word arguments to NotFile composed of ._- and alphanumerics.
|
||||
#
|
||||
# - Targets defined by the Application rule. Unlike other rules (Plugin,
|
||||
# Library, etc.) which compose a top-level pseudo-target using NotFile
|
||||
# (which is thus caught by the above case), on Unix, the Application rule
|
||||
# does not invoke NotFile since the top-level target has the same name as
|
||||
# the generated executable.
|
||||
#
|
||||
# - Targets defined by the ShellScript rule, since the emitted shell scripts
|
||||
# have the same name as the top-level target.
|
||||
#
|
||||
# Collection occurs in two phases. This file must be included by build.jam
|
||||
# before any other utility *.jam files are included, and it must also be
|
||||
# included after all other utility *.jam files are included. In the first
|
||||
# phase, the NotFile rule is re-defined so that we can catch pseudo-targets
|
||||
# created by the other utility *.jam files (we must re-define NotFile before
|
||||
# they are included), as well as any NotFile pseudo-targets created by Jamfiles
|
||||
# throughout the project. In the second phase, the Application and ShellScript
|
||||
# rules are re-defined (we must do so after application.jam has defined the
|
||||
# implementations which we override). These overrides allow us to catch
|
||||
# application and shell-script targets which project-wide Jamfiles define.
|
||||
#------------------------------------------------------------------------------
|
||||
if $(DUMPTARGETS_FILE)
|
||||
{
|
||||
# Jam does not support arithmetic, so we fake it with Roman numerals.
|
||||
DUMPTARGETS_PASS ?= "" ;
|
||||
DUMPTARGETS_PASS = "$(DUMPTARGETS_PASS)I" ;
|
||||
|
||||
switch $(DUMPTARGETS_PASS)
|
||||
{
|
||||
case I :
|
||||
|
||||
actions InitPseudoTargets
|
||||
{
|
||||
$(RM) $(<)
|
||||
}
|
||||
|
||||
rule DumpPseudoTargets
|
||||
{
|
||||
NotFile $(<) ;
|
||||
Always $(<) ;
|
||||
Depends $(<) : $(>) ;
|
||||
Always $(>) ;
|
||||
InitPseudoTargets $(>) ;
|
||||
}
|
||||
|
||||
DumpPseudoTargets dumptargets : "$(DUMPTARGETS_FILE)" ;
|
||||
|
||||
actions together piecemeal EmitPseudoTarget
|
||||
{
|
||||
echo "$(>)" >> $(<)
|
||||
}
|
||||
|
||||
rule PossiblePseudoTarget
|
||||
{
|
||||
# NoCare and Includes are not actually required; they are used here merely to
|
||||
# avoid Jam's "using independent target" warning. Note, however, that Jam
|
||||
# 2.4 and BoostJam try building the target despite the fact that we NoCare
|
||||
# about it. (Presumably this is because the targets have updating actions,
|
||||
# and those actions override the NoCare.) Consequently, we have to put up
|
||||
# with the "using independent target" warnings for these older Jam versions.
|
||||
NoCare $(<) ;
|
||||
if $(JAMVERSION) != 2.4 { Includes dumptargets : $(<) ; }
|
||||
|
||||
local i ;
|
||||
for i in $(<)
|
||||
{
|
||||
local s = [ Match ^([A-Za-z0-9_.-]+)$ : $(i) ] ;
|
||||
if $(s)
|
||||
{
|
||||
EmitPseudoTarget "$(DUMPTARGETS_FILE)" : $(i) ;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
rule NotFile
|
||||
{
|
||||
PossiblePseudoTarget $(<) ;
|
||||
}
|
||||
|
||||
case II :
|
||||
|
||||
rule Application
|
||||
{
|
||||
PossiblePseudoTarget $(<) $(<)clean ;
|
||||
}
|
||||
|
||||
rule ShellScript
|
||||
{
|
||||
PossiblePseudoTarget $(<) $(<)clean ;
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
344
mk/jam/flags.jam
344
mk/jam/flags.jam
@@ -1,172 +1,172 @@
|
||||
#============================================================================
|
||||
# Rules for specifying compiler and linker flags
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
## LinkWith target : libs
|
||||
## Link an application with libraries. The specified libraries should have
|
||||
## build rules in the same project. For external libraries use the
|
||||
## ExternalLibs rule. Specify the library names without any extensions or
|
||||
## the leading "lib".
|
||||
rule LinkWith
|
||||
{
|
||||
local rawlibs = [ ResolveLibs $(>) ] ;
|
||||
|
||||
if ( $($(<)_TYPE) = library ) && ( "$($(<)_SHARED)" = "" )
|
||||
{
|
||||
# LibDepends for shared libs invokes LinkWith, so prevent recursion
|
||||
LibDepends $(<) : $(rawlibs) ;
|
||||
}
|
||||
|
||||
local i libs ;
|
||||
for i in $(rawlibs)
|
||||
{
|
||||
libs += [ ConstructLibraryLinkTarget $(i) : $($(i)_SHARED) ] ;
|
||||
}
|
||||
|
||||
Depends $($(<)_TARGET) : $(libs) ;
|
||||
NEEDLIBS on $($(<)_TARGET) += $(libs) ;
|
||||
$(<).NEEDLIBS += $(rawlibs) ;
|
||||
|
||||
LFlags $(<) : $($($(rawlibs).EXTERNALLIBS).LFLAGS) ;
|
||||
}
|
||||
|
||||
## CFlags target : flags [ : options ]
|
||||
## Sets cflags on all sourcefiles of a library, plugin or application target
|
||||
## This rule affects c++ and c compiler flags.
|
||||
rule CFlags
|
||||
{
|
||||
CheckOptions nostatic : $(3) : $(<) ;
|
||||
|
||||
CCFLAGS on $($(<)_OBJECTS) += $(>) ;
|
||||
C++FLAGS on $($(<)_OBJECTS) += $(>) ;
|
||||
|
||||
UnitTestCFlags $(<) : $(>) : $(3) ;
|
||||
}
|
||||
|
||||
## MergeLFlags flags1 : flags2
|
||||
## Merge two arrays of linker flags. Removes duplicate entries, however,
|
||||
## ensures that the correct relative right-to-left order of both flag arrays
|
||||
## is kept.
|
||||
rule MergeLFlags
|
||||
{
|
||||
local result = ;
|
||||
local libs2 = $(2) ;
|
||||
for l in $(1)
|
||||
{
|
||||
if [ IsElem $(l) : $(libs2) ]
|
||||
{
|
||||
# If a flag from set 1 is in set 2, add all flags from start of set 2
|
||||
# to the occurance of the flag to result.
|
||||
while "$(libs2[1])" != "" && $(libs2[1]) != $(l)
|
||||
{
|
||||
result += $(libs2[1]) ;
|
||||
libs2 = $(libs2[2-]) ;
|
||||
}
|
||||
result += $(libs2[1]) ;
|
||||
libs2 = $(libs2[2-]) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
# Just add the flag.
|
||||
result += $(l) ;
|
||||
}
|
||||
}
|
||||
result += $(libs2) ;
|
||||
return $(result) ;
|
||||
}
|
||||
|
||||
## LFlags target : flags [ : options ]
|
||||
## Sets linker flags for a library, plugin or application target
|
||||
rule LFlags
|
||||
{
|
||||
CheckOptions nostatic : $(3) : $(<) ;
|
||||
|
||||
NotFile $(>) ;
|
||||
NEEDLIBS on $($(<)_TARGET) += $(>) ;
|
||||
$(<).LFLAGS += $(>) ;
|
||||
|
||||
UnitTestLFlags $(<) : $(>) : $(3) ;
|
||||
}
|
||||
|
||||
## ExternalLibs target : identifiers
|
||||
## Specify a dependency between 'target' and the external libraries
|
||||
## indicated by 'identifiers'. If 'target' is an application or plugin,
|
||||
## then it is linked against the indicated external libraries. If 'target'
|
||||
## is a library, then its dependency upon 'identifiers' is noted, and
|
||||
## applications or plugins which link against 'target' will also be linked
|
||||
## against the libraries indicated by 'identifiers'. 'identifiers' is a
|
||||
## list of base names of a set of variables which provide build tool
|
||||
## information about each external library. In particular, assuming that
|
||||
## `ident' is one element of `identifiers', the value of $(ident).CFLAGS
|
||||
## should provide compiler flags needed for the external library indicated
|
||||
## by 'ident'; and $(ident).LFLAGS should provide linker flags for the
|
||||
## library.
|
||||
rule ExternalLibs
|
||||
{
|
||||
local extlib ;
|
||||
for extlib in $(>)
|
||||
{
|
||||
CFlags $(<) : $($(extlib).CFLAGS) ;
|
||||
LFlags $(<) : $($(extlib).LFLAGS) ;
|
||||
|
||||
$(<).EXTERNALLIBS += $(extlib) ;
|
||||
}
|
||||
}
|
||||
|
||||
## ExtraObjects target : objectfiles [ : options ]
|
||||
## Link additional object files with a target.
|
||||
## Options:
|
||||
## inheritcflags: The mentioned object files will inherit compiler flags
|
||||
## assigned to target's normal object files (in addition to any flags
|
||||
## already set manually).
|
||||
rule ExtraObjects
|
||||
{
|
||||
CheckOptions inheritcflags : $(3) : $(<) ;
|
||||
if [ IsElem inheritcflags : $(3) ]
|
||||
{
|
||||
$(<)_OBJECTS += $(>) ;
|
||||
}
|
||||
EXTRAOBJECTS on $($(<)_TARGET) += $(>) ;
|
||||
Depends $($(<)_TARGET) : $(>) ;
|
||||
Clean $(<)clean : $(>) ;
|
||||
Clean clean : $(>) ;
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# private part
|
||||
|
||||
## ResolveLibs libs
|
||||
## Given a list of libraries, augment the list by adding other libraries
|
||||
## upon which the given libraries depend. Dependencies between libraries
|
||||
## are specified via LibDepends (or LinkWith when the target is a library).
|
||||
## The returned list is ordered such that it is suitable for Unix linkers
|
||||
## which are sensitive to the order of libraries in the invocation
|
||||
## statement.
|
||||
rule ResolveLibs
|
||||
{
|
||||
local i libs ;
|
||||
for i in $(<)
|
||||
{
|
||||
libs += $(i) $($(i)_depends) ;
|
||||
}
|
||||
# We must eliminate the duplicates in reverse order in order to ensure that
|
||||
# we do not destroy the overall library ordering since Unix linkers are
|
||||
# order-sensitive.
|
||||
return [ Reverse [ RemoveDups [ Reverse $(libs) ] ] ] ;
|
||||
}
|
||||
#============================================================================
|
||||
# Rules for specifying compiler and linker flags
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
## LinkWith target : libs
|
||||
## Link an application with libraries. The specified libraries should have
|
||||
## build rules in the same project. For external libraries use the
|
||||
## ExternalLibs rule. Specify the library names without any extensions or
|
||||
## the leading "lib".
|
||||
rule LinkWith
|
||||
{
|
||||
local rawlibs = [ ResolveLibs $(>) ] ;
|
||||
|
||||
if ( $($(<)_TYPE) = library ) && ( "$($(<)_SHARED)" = "" )
|
||||
{
|
||||
# LibDepends for shared libs invokes LinkWith, so prevent recursion
|
||||
LibDepends $(<) : $(rawlibs) ;
|
||||
}
|
||||
|
||||
local i libs ;
|
||||
for i in $(rawlibs)
|
||||
{
|
||||
libs += [ ConstructLibraryLinkTarget $(i) : $($(i)_SHARED) ] ;
|
||||
}
|
||||
|
||||
Depends $($(<)_TARGET) : $(libs) ;
|
||||
NEEDLIBS on $($(<)_TARGET) += $(libs) ;
|
||||
$(<).NEEDLIBS += $(rawlibs) ;
|
||||
|
||||
LFlags $(<) : $($($(rawlibs).EXTERNALLIBS).LFLAGS) ;
|
||||
}
|
||||
|
||||
## CFlags target : flags [ : options ]
|
||||
## Sets cflags on all sourcefiles of a library, plugin or application target
|
||||
## This rule affects c++ and c compiler flags.
|
||||
rule CFlags
|
||||
{
|
||||
CheckOptions nostatic : $(3) : $(<) ;
|
||||
|
||||
CCFLAGS on $($(<)_OBJECTS) += $(>) ;
|
||||
C++FLAGS on $($(<)_OBJECTS) += $(>) ;
|
||||
|
||||
UnitTestCFlags $(<) : $(>) : $(3) ;
|
||||
}
|
||||
|
||||
## MergeLFlags flags1 : flags2
|
||||
## Merge two arrays of linker flags. Removes duplicate entries, however,
|
||||
## ensures that the correct relative right-to-left order of both flag arrays
|
||||
## is kept.
|
||||
rule MergeLFlags
|
||||
{
|
||||
local result = ;
|
||||
local libs2 = $(2) ;
|
||||
for l in $(1)
|
||||
{
|
||||
if [ IsElem $(l) : $(libs2) ]
|
||||
{
|
||||
# If a flag from set 1 is in set 2, add all flags from start of set 2
|
||||
# to the occurance of the flag to result.
|
||||
while "$(libs2[1])" != "" && $(libs2[1]) != $(l)
|
||||
{
|
||||
result += $(libs2[1]) ;
|
||||
libs2 = $(libs2[2-]) ;
|
||||
}
|
||||
result += $(libs2[1]) ;
|
||||
libs2 = $(libs2[2-]) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
# Just add the flag.
|
||||
result += $(l) ;
|
||||
}
|
||||
}
|
||||
result += $(libs2) ;
|
||||
return $(result) ;
|
||||
}
|
||||
|
||||
## LFlags target : flags [ : options ]
|
||||
## Sets linker flags for a library, plugin or application target
|
||||
rule LFlags
|
||||
{
|
||||
CheckOptions nostatic : $(3) : $(<) ;
|
||||
|
||||
NotFile $(>) ;
|
||||
NEEDLIBS on $($(<)_TARGET) += $(>) ;
|
||||
$(<).LFLAGS += $(>) ;
|
||||
|
||||
UnitTestLFlags $(<) : $(>) : $(3) ;
|
||||
}
|
||||
|
||||
## ExternalLibs target : identifiers
|
||||
## Specify a dependency between 'target' and the external libraries
|
||||
## indicated by 'identifiers'. If 'target' is an application or plugin,
|
||||
## then it is linked against the indicated external libraries. If 'target'
|
||||
## is a library, then its dependency upon 'identifiers' is noted, and
|
||||
## applications or plugins which link against 'target' will also be linked
|
||||
## against the libraries indicated by 'identifiers'. 'identifiers' is a
|
||||
## list of base names of a set of variables which provide build tool
|
||||
## information about each external library. In particular, assuming that
|
||||
## `ident' is one element of `identifiers', the value of $(ident).CFLAGS
|
||||
## should provide compiler flags needed for the external library indicated
|
||||
## by 'ident'; and $(ident).LFLAGS should provide linker flags for the
|
||||
## library.
|
||||
rule ExternalLibs
|
||||
{
|
||||
local extlib ;
|
||||
for extlib in $(>)
|
||||
{
|
||||
CFlags $(<) : $($(extlib).CFLAGS) ;
|
||||
LFlags $(<) : $($(extlib).LFLAGS) ;
|
||||
|
||||
$(<).EXTERNALLIBS += $(extlib) ;
|
||||
}
|
||||
}
|
||||
|
||||
## ExtraObjects target : objectfiles [ : options ]
|
||||
## Link additional object files with a target.
|
||||
## Options:
|
||||
## inheritcflags: The mentioned object files will inherit compiler flags
|
||||
## assigned to target's normal object files (in addition to any flags
|
||||
## already set manually).
|
||||
rule ExtraObjects
|
||||
{
|
||||
CheckOptions inheritcflags : $(3) : $(<) ;
|
||||
if [ IsElem inheritcflags : $(3) ]
|
||||
{
|
||||
$(<)_OBJECTS += $(>) ;
|
||||
}
|
||||
EXTRAOBJECTS on $($(<)_TARGET) += $(>) ;
|
||||
Depends $($(<)_TARGET) : $(>) ;
|
||||
Clean $(<)clean : $(>) ;
|
||||
Clean clean : $(>) ;
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# private part
|
||||
|
||||
## ResolveLibs libs
|
||||
## Given a list of libraries, augment the list by adding other libraries
|
||||
## upon which the given libraries depend. Dependencies between libraries
|
||||
## are specified via LibDepends (or LinkWith when the target is a library).
|
||||
## The returned list is ordered such that it is suitable for Unix linkers
|
||||
## which are sensitive to the order of libraries in the invocation
|
||||
## statement.
|
||||
rule ResolveLibs
|
||||
{
|
||||
local i libs ;
|
||||
for i in $(<)
|
||||
{
|
||||
libs += $(i) $($(i)_depends) ;
|
||||
}
|
||||
# We must eliminate the duplicates in reverse order in order to ensure that
|
||||
# we do not destroy the overall library ordering since Unix linkers are
|
||||
# order-sensitive.
|
||||
return [ Reverse [ RemoveDups [ Reverse $(libs) ] ] ] ;
|
||||
}
|
||||
|
||||
@@ -1,61 +1,61 @@
|
||||
#============================================================================
|
||||
# Rules for building compile groups
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
COMPILE_GROUPS = ;
|
||||
|
||||
## CompileGroups target : groups
|
||||
## Adds a target to a list of compile groups. A compile group is a virtual
|
||||
## target which combines several targets. This is useful for things like a
|
||||
## creating a target which compiles all image loaders, all renderers, etc.
|
||||
rule CompileGroups
|
||||
{
|
||||
local _i ;
|
||||
|
||||
for _i in $(>)
|
||||
{
|
||||
Depends $(_i) : $(<) ;
|
||||
Depends $(_i)clean : $(<)clean ;
|
||||
|
||||
if ! [ IsElem $(_i) : $(COMPILE_GROUPS) ]
|
||||
{
|
||||
NotFile $(_i) ;
|
||||
Echo "Warning: $(_i) not registered via RegisterCompileGroups" ;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
## RegisterCompileGroups
|
||||
## Registers compile groups. You must specify all compile groups here before
|
||||
## can use them.
|
||||
rule RegisterCompileGroups
|
||||
{
|
||||
NotFile $(<) ;
|
||||
COMPILE_GROUPS += $(<) ;
|
||||
|
||||
local i ;
|
||||
for i in $(<)
|
||||
{
|
||||
local desc = [ Description $(i) ] ;
|
||||
if $(desc)
|
||||
{
|
||||
Help $(i) : "Build the $(desc)" ;
|
||||
}
|
||||
}
|
||||
}
|
||||
#============================================================================
|
||||
# Rules for building compile groups
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
COMPILE_GROUPS = ;
|
||||
|
||||
## CompileGroups target : groups
|
||||
## Adds a target to a list of compile groups. A compile group is a virtual
|
||||
## target which combines several targets. This is useful for things like a
|
||||
## creating a target which compiles all image loaders, all renderers, etc.
|
||||
rule CompileGroups
|
||||
{
|
||||
local _i ;
|
||||
|
||||
for _i in $(>)
|
||||
{
|
||||
Depends $(_i) : $(<) ;
|
||||
Depends $(_i)clean : $(<)clean ;
|
||||
|
||||
if ! [ IsElem $(_i) : $(COMPILE_GROUPS) ]
|
||||
{
|
||||
NotFile $(_i) ;
|
||||
Echo "Warning: $(_i) not registered via RegisterCompileGroups" ;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
## RegisterCompileGroups
|
||||
## Registers compile groups. You must specify all compile groups here before
|
||||
## can use them.
|
||||
rule RegisterCompileGroups
|
||||
{
|
||||
NotFile $(<) ;
|
||||
COMPILE_GROUPS += $(<) ;
|
||||
|
||||
local i ;
|
||||
for i in $(<)
|
||||
{
|
||||
local desc = [ Description $(i) ] ;
|
||||
if $(desc)
|
||||
{
|
||||
Help $(i) : "Build the $(desc)" ;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
170
mk/jam/help.jam
170
mk/jam/help.jam
@@ -1,85 +1,85 @@
|
||||
#============================================================================
|
||||
# Rules for collecting and emitting descriptions about targets
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
# Copyright (C)2004 by Eric Sunshine <sunshine@sunshineco.com>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
## Description target [ : description ]
|
||||
## Provides access to the description of 'target'. The description may be
|
||||
## used by other rules, such as those which generate project files, or which
|
||||
## present informative messages to the user regarding 'target'. If invoked
|
||||
## with two arguments, then it sets the description of 'target'. If invoked
|
||||
## with one argument, then it returns the description of 'target'. You
|
||||
## should invoke this rule to set the description before invoking other
|
||||
## rules which might need access to target's description, such as the
|
||||
## Application, Library, and Plugin rules. As a convenience, several generic
|
||||
## rules, such as Application, Library, and Plugin will automatically invoke
|
||||
## the Help rule for 'target' using the provided 'description'.
|
||||
rule Description
|
||||
{
|
||||
local desc = $(>) ;
|
||||
if $(desc)
|
||||
{
|
||||
$(<)_description = $(desc) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
desc = $($(<)_description) ;
|
||||
}
|
||||
return $(desc) ;
|
||||
}
|
||||
|
||||
|
||||
## Help target : description
|
||||
## Specify the 'description' to emit for 'target' when the user invokes "jam
|
||||
## help".
|
||||
rule Help
|
||||
{
|
||||
local target = $(<) ;
|
||||
local desc = $(>) ;
|
||||
|
||||
if ! $(target) { target = "" ; }
|
||||
if ! $(desc) { desc = "" ; }
|
||||
|
||||
# target width:20, description width:54
|
||||
local target_pad = " " ;
|
||||
local target_pat = "...................." ;
|
||||
local desc_pad = " " ;
|
||||
local desc_pat = "......................................................" ;
|
||||
|
||||
local m = Match ; # Indirect invocation allows variables in pattern regex.
|
||||
local target_str = [ $(m) "($(target_pat)).*" : "$(target)$(target_pad)" ] ;
|
||||
local desc_str = [ $(m) "($(desc_pat)).*" : "$(desc)$(desc_pad)" ] ;
|
||||
local help = "jam $(target_str) $(desc_str)" ;
|
||||
|
||||
target = $(target:G=help) ;
|
||||
Depends help : $(target) ;
|
||||
NotFile $(help) ;
|
||||
PrintHelp $(target) : $(help) ;
|
||||
Always $(target) ;
|
||||
NotFile $(target) ;
|
||||
}
|
||||
|
||||
actions quietly PrintHelp
|
||||
{
|
||||
echo "$(>)"
|
||||
}
|
||||
|
||||
NotFile help ;
|
||||
Always help ;
|
||||
Help all : "Build the entire project" ;
|
||||
#============================================================================
|
||||
# Rules for collecting and emitting descriptions about targets
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
# Copyright (C)2004 by Eric Sunshine <sunshine@sunshineco.com>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
## Description target [ : description ]
|
||||
## Provides access to the description of 'target'. The description may be
|
||||
## used by other rules, such as those which generate project files, or which
|
||||
## present informative messages to the user regarding 'target'. If invoked
|
||||
## with two arguments, then it sets the description of 'target'. If invoked
|
||||
## with one argument, then it returns the description of 'target'. You
|
||||
## should invoke this rule to set the description before invoking other
|
||||
## rules which might need access to target's description, such as the
|
||||
## Application, Library, and Plugin rules. As a convenience, several generic
|
||||
## rules, such as Application, Library, and Plugin will automatically invoke
|
||||
## the Help rule for 'target' using the provided 'description'.
|
||||
rule Description
|
||||
{
|
||||
local desc = $(>) ;
|
||||
if $(desc)
|
||||
{
|
||||
$(<)_description = $(desc) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
desc = $($(<)_description) ;
|
||||
}
|
||||
return $(desc) ;
|
||||
}
|
||||
|
||||
|
||||
## Help target : description
|
||||
## Specify the 'description' to emit for 'target' when the user invokes "jam
|
||||
## help".
|
||||
rule Help
|
||||
{
|
||||
local target = $(<) ;
|
||||
local desc = $(>) ;
|
||||
|
||||
if ! $(target) { target = "" ; }
|
||||
if ! $(desc) { desc = "" ; }
|
||||
|
||||
# target width:20, description width:54
|
||||
local target_pad = " " ;
|
||||
local target_pat = "...................." ;
|
||||
local desc_pad = " " ;
|
||||
local desc_pat = "......................................................" ;
|
||||
|
||||
local m = Match ; # Indirect invocation allows variables in pattern regex.
|
||||
local target_str = [ $(m) "($(target_pat)).*" : "$(target)$(target_pad)" ] ;
|
||||
local desc_str = [ $(m) "($(desc_pat)).*" : "$(desc)$(desc_pad)" ] ;
|
||||
local help = "jam $(target_str) $(desc_str)" ;
|
||||
|
||||
target = $(target:G=help) ;
|
||||
Depends help : $(target) ;
|
||||
NotFile $(help) ;
|
||||
PrintHelp $(target) : $(help) ;
|
||||
Always $(target) ;
|
||||
NotFile $(target) ;
|
||||
}
|
||||
|
||||
actions quietly PrintHelp
|
||||
{
|
||||
echo "$(>)"
|
||||
}
|
||||
|
||||
NotFile help ;
|
||||
Always help ;
|
||||
Help all : "Build the entire project" ;
|
||||
|
||||
1188
mk/jam/helper.jam
1188
mk/jam/helper.jam
File diff suppressed because it is too large
Load Diff
@@ -1,213 +1,213 @@
|
||||
#============================================================================
|
||||
# Rules for installation
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
# Copyright (C)2004 by Eric Sunshine <sunshine@sunshineco.com>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
INSTALL ?= "install" ;
|
||||
INSTALL_PROGRAM ?= $(INSTALL) ;
|
||||
INSTALL_DATA ?= "$(INSTALL) -m 644" ;
|
||||
|
||||
# set some paths
|
||||
appdatadir ?= [ ConcatDirs $(datadir) $(PACKAGE_NAME) ] ;
|
||||
appdocdir ?= [ ConcatDirs $(datadir) doc $(PACKAGE_NAME)-$(PACKAGE_VERSION) ] ;
|
||||
appconfdir ?= [ ConcatDirs $(sysconfdir) $(PACKAGE_NAME) ] ;
|
||||
appincdir ?= [ ConcatDirs $(includedir) $(PACKAGE_NAME) ] ;
|
||||
plugindir ?= [ ConcatDirs $(libdir) $(PACKAGE_NAME) ] ;
|
||||
|
||||
rule GristInstall
|
||||
{
|
||||
local i, files ;
|
||||
for i in $(<)
|
||||
{
|
||||
if $(i:G) { files += $(i) ; }
|
||||
else { files += $(i:G=$(SUBDIR)) ; }
|
||||
}
|
||||
return $(files) ;
|
||||
}
|
||||
|
||||
## InstallHeader headername [ : subdir ]
|
||||
## DoInstall a header file into the includedir directory. A subdirectory
|
||||
## relative to the includedir can be specified.
|
||||
rule InstallHeader
|
||||
{
|
||||
local files = [ GristInstall $(<) ] ;
|
||||
SEARCH on $(files) = $(SUBDIR) ;
|
||||
Depends install_include : [ DoInstall $(files) : $(appincdir) $(2) ] ;
|
||||
}
|
||||
|
||||
## InstallData files [ : subdir ]
|
||||
## Installs data files
|
||||
rule InstallData
|
||||
{
|
||||
local files = [ GristInstall $(<) ] ;
|
||||
SEARCH on $(files) = $(SUBDIR) ;
|
||||
Depends install_data : [ DoInstall $(files) : $(appdatadir) $(2) ] ;
|
||||
}
|
||||
|
||||
## InstallConfig files [ : subdir ]
|
||||
## Installs configuration files
|
||||
rule InstallConfig
|
||||
{
|
||||
local files = [ GristInstall $(<) ] ;
|
||||
SEARCH on $(files) = $(SUBDIR) ;
|
||||
Depends install_config : [ DoInstall $(files) : $(appconfdir) $(2) ] ;
|
||||
}
|
||||
|
||||
## InstallDoc files [ : subdir ]
|
||||
## Installs documentation files
|
||||
rule InstallDoc
|
||||
{
|
||||
local files = [ GristInstall $(<) ] ;
|
||||
SEARCH on $(files) = $(SUBDIR) ;
|
||||
Depends install_doc : [ DoInstall $(files) : $(appdocdir) $(2) ] ;
|
||||
}
|
||||
|
||||
## InstallMan files
|
||||
## Installs Unix manual files
|
||||
rule InstallMan
|
||||
{
|
||||
local files = [ GristInstall $(<) ] ;
|
||||
SEARCH on $(files) = $(SUBDIR) ;
|
||||
|
||||
local i ;
|
||||
for i in $(files)
|
||||
{
|
||||
local dir = $(mandir) ;
|
||||
switch $(i:S)
|
||||
{
|
||||
case .1 : dir += man1 ;
|
||||
case .2 : dir += man2 ;
|
||||
case .3 : dir += man3 ;
|
||||
case .4 : dir += man4 ;
|
||||
case .5 : dir += man5 ;
|
||||
case .6 : dir += man6 ;
|
||||
case .7 : dir += man7 ;
|
||||
case .8 : dir += man8 ;
|
||||
case .9 : dir += man9 ;
|
||||
case * :
|
||||
echo "WARNING: manfile has no *.[0-9] ending." ;
|
||||
}
|
||||
Depends install_man : [ DoInstall $(i) : $(dir) ] ;
|
||||
}
|
||||
}
|
||||
|
||||
## InstallProgram files [ : directories ]
|
||||
## Installs program files (executable or shell script). This is a
|
||||
## convenience wrapper for DoInstall when the resources to be installed is
|
||||
## of an invocable nature. It sets SEARCH on `files', and uses
|
||||
## $(INSTALL_PROGRAM) to perform the actual installation. Unlike
|
||||
## SystemInstallApplication, it does not assume that all such targets should
|
||||
## be installed into $(bindir); instead, you can provide `directories' to
|
||||
## specify the installation location. If `directories' is not given, then
|
||||
## $(bindir) is assumed. Also, unlike SystemInstallApplication, this rule
|
||||
## does not have any platform-specific knowledge (such as how to install a
|
||||
## Cocoa application wrapper on MacOS/X). Always use
|
||||
## SystemInstallApplication for installation of full-fledged applications. A
|
||||
## typical use for InstallProgram would be to install an already-existing
|
||||
## shell script. This differs from the ShellScript rule which both creates a
|
||||
## shell script from scratch at build time, and arranges for it to be
|
||||
## installed. Like DoInstall, this rule returns the names of the installed
|
||||
## targets, so it is convenient to use the results as the input for another
|
||||
## rule, such as Depends.
|
||||
rule InstallProgram
|
||||
{
|
||||
local files = [ GristInstall $(1) ] ;
|
||||
local dir = $(2) ;
|
||||
if ! $(dir) { dir = $(bindir) ; }
|
||||
SEARCH on $(files) = $(SUBDIR) ;
|
||||
return [ DoInstall $(files) : $(dir) : $(INSTALL_PROGRAM) ] ;
|
||||
}
|
||||
|
||||
## DoInstall sourcenames : directories [ : installapp : [ postinstallrules ]]
|
||||
## Creates a new install target for the given sources named by
|
||||
## `sourcenames'. `directories' is a list of directory components
|
||||
## indicating the installation directory for `sourcename'. `installapp' is
|
||||
## the actual program to run to install the sources. If not specified, then
|
||||
## $(INSTALL_DATA) is used. If the optional `postinstallrules' is provided,
|
||||
## it is a list of Jam rules to invoke on the installed target after it is
|
||||
## installed. Each rule is invoked with the installed target as the first
|
||||
## argument, and the source target as the second. An obvious instance where
|
||||
## `postinstallrules' proves useful is when the Ranlib rule should be
|
||||
## invoked on just-installed static library (.a) files. The DoInstall rule
|
||||
## returns the names of the installed targets, so it is convenient to use
|
||||
## the results as the input for another rule. For example:
|
||||
## Depends install : [ DoInstall $(docfiles) : $(installdocdir) ] ;
|
||||
## (Implementation Note: We did not name this rule Install, because Jambase
|
||||
## already defines an action named Install :-/)
|
||||
rule DoInstall
|
||||
{
|
||||
local targets target i dir gdir ;
|
||||
dir = [ ConcatDirs $(DESTDIR) $(2) ] ;
|
||||
|
||||
gdir = $(dir:G=dir) ;
|
||||
MkDir $(gdir) ;
|
||||
|
||||
for i in $(1)
|
||||
{
|
||||
target = $(i:BSR=$(dir):G=install) ;
|
||||
targets += $(target) ;
|
||||
Depends $(target) : $(gdir) $(i) ;
|
||||
Install1 $(target) : $(i) ;
|
||||
|
||||
if "$(3)"
|
||||
{
|
||||
INSTALL_APP on $(target) = $(3) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
INSTALL_APP on $(target) = $(INSTALL_DATA) ;
|
||||
}
|
||||
|
||||
if "$(4)"
|
||||
{
|
||||
local postrule ;
|
||||
for postrule in $(4)
|
||||
{
|
||||
$(postrule) $(target) : $(i) ;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Always $(targets) ;
|
||||
return $(targets) ;
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
|
||||
INSTALLTARGETS = install_bin install_plugin install_lib install_include
|
||||
install_data install_config install_doc ;
|
||||
|
||||
Always install $(INSTALLTARGETS) ;
|
||||
NotFile install $(INSTALLTARGETS) ;
|
||||
Depends install : $(INSTALLTARGETS) ;
|
||||
|
||||
if ! $(PACKAGE_INSTALL_NAME) { PACKAGE_INSTALL_NAME = $(PACKAGE_LONGNAME) ; }
|
||||
if ! $(PACKAGE_INSTALL_NAME) { PACKAGE_INSTALL_NAME = $(PACKAGE_NAME) ; }
|
||||
if ! $(PACKAGE_INSTALL_NAME) { PACKAGE_INSTALL_NAME = "the project" ; }
|
||||
Help install : "Install $(PACKAGE_INSTALL_NAME)" ;
|
||||
|
||||
actions Install1
|
||||
{
|
||||
$(INSTALL_APP) $(INSTALLFLAGS) $(>) $(<)
|
||||
}
|
||||
|
||||
actions CopyDirs
|
||||
{
|
||||
$(DEEPCOPY) $(>) $(<)
|
||||
}
|
||||
#============================================================================
|
||||
# Rules for installation
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
# Copyright (C)2004 by Eric Sunshine <sunshine@sunshineco.com>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
INSTALL ?= "install" ;
|
||||
INSTALL_PROGRAM ?= $(INSTALL) ;
|
||||
INSTALL_DATA ?= "$(INSTALL) -m 644" ;
|
||||
|
||||
# set some paths
|
||||
appdatadir ?= [ ConcatDirs $(datadir) $(PACKAGE_NAME) ] ;
|
||||
appdocdir ?= [ ConcatDirs $(datadir) doc $(PACKAGE_NAME)-$(PACKAGE_VERSION) ] ;
|
||||
appconfdir ?= [ ConcatDirs $(sysconfdir) $(PACKAGE_NAME) ] ;
|
||||
appincdir ?= [ ConcatDirs $(includedir) $(PACKAGE_NAME) ] ;
|
||||
plugindir ?= [ ConcatDirs $(libdir) $(PACKAGE_NAME) ] ;
|
||||
|
||||
rule GristInstall
|
||||
{
|
||||
local i, files ;
|
||||
for i in $(<)
|
||||
{
|
||||
if $(i:G) { files += $(i) ; }
|
||||
else { files += $(i:G=$(SUBDIR)) ; }
|
||||
}
|
||||
return $(files) ;
|
||||
}
|
||||
|
||||
## InstallHeader headername [ : subdir ]
|
||||
## DoInstall a header file into the includedir directory. A subdirectory
|
||||
## relative to the includedir can be specified.
|
||||
rule InstallHeader
|
||||
{
|
||||
local files = [ GristInstall $(<) ] ;
|
||||
SEARCH on $(files) = $(SUBDIR) ;
|
||||
Depends install_include : [ DoInstall $(files) : $(appincdir) $(2) ] ;
|
||||
}
|
||||
|
||||
## InstallData files [ : subdir ]
|
||||
## Installs data files
|
||||
rule InstallData
|
||||
{
|
||||
local files = [ GristInstall $(<) ] ;
|
||||
SEARCH on $(files) = $(SUBDIR) ;
|
||||
Depends install_data : [ DoInstall $(files) : $(appdatadir) $(2) ] ;
|
||||
}
|
||||
|
||||
## InstallConfig files [ : subdir ]
|
||||
## Installs configuration files
|
||||
rule InstallConfig
|
||||
{
|
||||
local files = [ GristInstall $(<) ] ;
|
||||
SEARCH on $(files) = $(SUBDIR) ;
|
||||
Depends install_config : [ DoInstall $(files) : $(appconfdir) $(2) ] ;
|
||||
}
|
||||
|
||||
## InstallDoc files [ : subdir ]
|
||||
## Installs documentation files
|
||||
rule InstallDoc
|
||||
{
|
||||
local files = [ GristInstall $(<) ] ;
|
||||
SEARCH on $(files) = $(SUBDIR) ;
|
||||
Depends install_doc : [ DoInstall $(files) : $(appdocdir) $(2) ] ;
|
||||
}
|
||||
|
||||
## InstallMan files
|
||||
## Installs Unix manual files
|
||||
rule InstallMan
|
||||
{
|
||||
local files = [ GristInstall $(<) ] ;
|
||||
SEARCH on $(files) = $(SUBDIR) ;
|
||||
|
||||
local i ;
|
||||
for i in $(files)
|
||||
{
|
||||
local dir = $(mandir) ;
|
||||
switch $(i:S)
|
||||
{
|
||||
case .1 : dir += man1 ;
|
||||
case .2 : dir += man2 ;
|
||||
case .3 : dir += man3 ;
|
||||
case .4 : dir += man4 ;
|
||||
case .5 : dir += man5 ;
|
||||
case .6 : dir += man6 ;
|
||||
case .7 : dir += man7 ;
|
||||
case .8 : dir += man8 ;
|
||||
case .9 : dir += man9 ;
|
||||
case * :
|
||||
echo "WARNING: manfile has no *.[0-9] ending." ;
|
||||
}
|
||||
Depends install_man : [ DoInstall $(i) : $(dir) ] ;
|
||||
}
|
||||
}
|
||||
|
||||
## InstallProgram files [ : directories ]
|
||||
## Installs program files (executable or shell script). This is a
|
||||
## convenience wrapper for DoInstall when the resources to be installed is
|
||||
## of an invocable nature. It sets SEARCH on `files', and uses
|
||||
## $(INSTALL_PROGRAM) to perform the actual installation. Unlike
|
||||
## SystemInstallApplication, it does not assume that all such targets should
|
||||
## be installed into $(bindir); instead, you can provide `directories' to
|
||||
## specify the installation location. If `directories' is not given, then
|
||||
## $(bindir) is assumed. Also, unlike SystemInstallApplication, this rule
|
||||
## does not have any platform-specific knowledge (such as how to install a
|
||||
## Cocoa application wrapper on MacOS/X). Always use
|
||||
## SystemInstallApplication for installation of full-fledged applications. A
|
||||
## typical use for InstallProgram would be to install an already-existing
|
||||
## shell script. This differs from the ShellScript rule which both creates a
|
||||
## shell script from scratch at build time, and arranges for it to be
|
||||
## installed. Like DoInstall, this rule returns the names of the installed
|
||||
## targets, so it is convenient to use the results as the input for another
|
||||
## rule, such as Depends.
|
||||
rule InstallProgram
|
||||
{
|
||||
local files = [ GristInstall $(1) ] ;
|
||||
local dir = $(2) ;
|
||||
if ! $(dir) { dir = $(bindir) ; }
|
||||
SEARCH on $(files) = $(SUBDIR) ;
|
||||
return [ DoInstall $(files) : $(dir) : $(INSTALL_PROGRAM) ] ;
|
||||
}
|
||||
|
||||
## DoInstall sourcenames : directories [ : installapp : [ postinstallrules ]]
|
||||
## Creates a new install target for the given sources named by
|
||||
## `sourcenames'. `directories' is a list of directory components
|
||||
## indicating the installation directory for `sourcename'. `installapp' is
|
||||
## the actual program to run to install the sources. If not specified, then
|
||||
## $(INSTALL_DATA) is used. If the optional `postinstallrules' is provided,
|
||||
## it is a list of Jam rules to invoke on the installed target after it is
|
||||
## installed. Each rule is invoked with the installed target as the first
|
||||
## argument, and the source target as the second. An obvious instance where
|
||||
## `postinstallrules' proves useful is when the Ranlib rule should be
|
||||
## invoked on just-installed static library (.a) files. The DoInstall rule
|
||||
## returns the names of the installed targets, so it is convenient to use
|
||||
## the results as the input for another rule. For example:
|
||||
## Depends install : [ DoInstall $(docfiles) : $(installdocdir) ] ;
|
||||
## (Implementation Note: We did not name this rule Install, because Jambase
|
||||
## already defines an action named Install :-/)
|
||||
rule DoInstall
|
||||
{
|
||||
local targets target i dir gdir ;
|
||||
dir = [ ConcatDirs $(DESTDIR) $(2) ] ;
|
||||
|
||||
gdir = $(dir:G=dir) ;
|
||||
MkDir $(gdir) ;
|
||||
|
||||
for i in $(1)
|
||||
{
|
||||
target = $(i:BSR=$(dir):G=install) ;
|
||||
targets += $(target) ;
|
||||
Depends $(target) : $(gdir) $(i) ;
|
||||
Install1 $(target) : $(i) ;
|
||||
|
||||
if "$(3)"
|
||||
{
|
||||
INSTALL_APP on $(target) = $(3) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
INSTALL_APP on $(target) = $(INSTALL_DATA) ;
|
||||
}
|
||||
|
||||
if "$(4)"
|
||||
{
|
||||
local postrule ;
|
||||
for postrule in $(4)
|
||||
{
|
||||
$(postrule) $(target) : $(i) ;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Always $(targets) ;
|
||||
return $(targets) ;
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
|
||||
INSTALLTARGETS = install_bin install_plugin install_lib install_include
|
||||
install_data install_config install_doc ;
|
||||
|
||||
Always install $(INSTALLTARGETS) ;
|
||||
NotFile install $(INSTALLTARGETS) ;
|
||||
Depends install : $(INSTALLTARGETS) ;
|
||||
|
||||
if ! $(PACKAGE_INSTALL_NAME) { PACKAGE_INSTALL_NAME = $(PACKAGE_LONGNAME) ; }
|
||||
if ! $(PACKAGE_INSTALL_NAME) { PACKAGE_INSTALL_NAME = $(PACKAGE_NAME) ; }
|
||||
if ! $(PACKAGE_INSTALL_NAME) { PACKAGE_INSTALL_NAME = "the project" ; }
|
||||
Help install : "Install $(PACKAGE_INSTALL_NAME)" ;
|
||||
|
||||
actions Install1
|
||||
{
|
||||
$(INSTALL_APP) $(INSTALLFLAGS) $(>) $(<)
|
||||
}
|
||||
|
||||
actions CopyDirs
|
||||
{
|
||||
$(DEEPCOPY) $(>) $(<)
|
||||
}
|
||||
|
||||
@@ -1,349 +1,349 @@
|
||||
#============================================================================
|
||||
# Several hacks to make the build compatible with certain old/broken jam
|
||||
# versions
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
# BoostJam is evil: It is compatible to Jam 2.4 but has a version number 3.1,
|
||||
# we try to detect BoostJam with the ARGV extension.
|
||||
if $(ARGV[0])
|
||||
{
|
||||
# BoostJam hacks.
|
||||
JAMVERSION = 2.4 ;
|
||||
rule FIncludes
|
||||
{
|
||||
return -I$(<) ;
|
||||
}
|
||||
rule FDefines
|
||||
{
|
||||
return -D$(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
if $(JAMVERSION) < 2.4
|
||||
{
|
||||
EXIT "Error: This buildsystem requires jam version 2.4 or later." ;
|
||||
}
|
||||
|
||||
# All scripts invoked by the build system expect a Bourne or compatible shell.
|
||||
# Reject C-shell and its variants (such as tcsh). Unfortunately, this is a bit
|
||||
# of an ugly hack. It would be nicer to perform this logic at the very end of
|
||||
# this file as a last-minute assertion. Unfortunately, however, it seems that
|
||||
# references to $(SHELL) in any of the included files get bound at the point
|
||||
# of reference, thus we need to perform this filtering as early as possible.
|
||||
# Furthermore, on Windows, if the MSYS installation path contains a space (such
|
||||
# as "c:\Program Files\msys"), the space will cause `actions' to fail which
|
||||
# employ $(SHELL) indirectly through some other variable. Therefore, handle
|
||||
# this case as well.
|
||||
if [ Match (csh) : $(SHELL) ] || $(SHELL[2])
|
||||
{
|
||||
SHELL = "/bin/sh" ;
|
||||
}
|
||||
|
||||
# Jam 2.4's SubDir rule had some problems and misses the useful SUBDIRRULES
|
||||
# extension. So we override it here with a better version (from jam 2.5rc3).
|
||||
# Likewise, 2.4 is missing FReverse and FStrip, which are needed by SubDir and
|
||||
# other custom rules we define.
|
||||
if $(JAMVERSION) = 2.4
|
||||
{
|
||||
|
||||
rule FReverse
|
||||
{
|
||||
# FReverse a1 a2 a3 ... ;
|
||||
# return ... a3 a2 a1 ;
|
||||
|
||||
if $(1) { return [ FReverse $(1[2-]) ] $(1[1]) ; }
|
||||
}
|
||||
|
||||
rule FStripCommon
|
||||
{
|
||||
# FStripCommon v1 : v2 ;
|
||||
|
||||
# Strip common initial elements of variables v1 and v2.
|
||||
# Modifies the variable values themselves.
|
||||
|
||||
if $($(<)[1]) && $($(<)[1]) = $($(>)[1])
|
||||
{
|
||||
$(<) = $($(<)[2-]) ;
|
||||
$(>) = $($(>)[2-]) ;
|
||||
FStripCommon $(<) : $(>) ;
|
||||
}
|
||||
}
|
||||
|
||||
rule SubDir
|
||||
{
|
||||
#
|
||||
# SubDir TOP d1 d2 ... ;
|
||||
#
|
||||
# Support for a project tree spanning multiple directories.
|
||||
#
|
||||
# SubDir declares a Jamfile's location in a project tree, setting
|
||||
# Jambase variables (SEARCH_SOURCE, LOCATE_TARGET) so that source
|
||||
# files can be found.
|
||||
#
|
||||
# TOP is a user-select variable name for root of the tree, and
|
||||
# d1 d2 ... are the directory elements that lead from the root
|
||||
# of the tree to the directory of the Jamfile.
|
||||
#
|
||||
# TOP can be set externally, but normally the first SubDir call
|
||||
# computes TOP as the path up from the current directory; the
|
||||
# path contains one ../ for each of d1 d2 ...
|
||||
#
|
||||
# SubDir reads once the project-specific rules file Jamrules
|
||||
# in the TOP directory, if present. This can be overridden
|
||||
# with the variable TOPRULES.
|
||||
#
|
||||
# SubDir supports multiple, overlaid project trees: SubDir
|
||||
# invocations with different TOPs can appear in the same Jamfile.
|
||||
# The location established by the first SubDir call is used set
|
||||
# the TOPs for the subsequent SubDir calls.
|
||||
#
|
||||
# SubDir's public variables:
|
||||
#
|
||||
# $(TOP) = path from CWD to root.
|
||||
# $(SUBDIR) = path from CWD to the directory SubDir names.
|
||||
# $(SUBDIR_TOKENS) = path from $(TOP) to $(SUBDIR) as dir names
|
||||
# $(SEARCH_SOURCE) = $(SUBDIR)
|
||||
# $(LOCATE_SOURCE) = $(ALL_LOCATE_TARGET) $(SUBDIR)
|
||||
# $(LOCATE_TARGET) = $(ALL_LOCATE_TARGET) $(SUBDIR)
|
||||
# $(SOURCE_GRIST) = $(SUBDIR_TOKENS) with !'s
|
||||
#
|
||||
|
||||
local _top = $(<[1]) ;
|
||||
local _tokens = $(<[2-]) ;
|
||||
|
||||
#
|
||||
# First time through sets up relative root and includes Jamrules.
|
||||
#
|
||||
|
||||
if ! $(_top)
|
||||
{
|
||||
Exit SubDir syntax error ;
|
||||
}
|
||||
|
||||
if ! $($(_top)-SET)
|
||||
{
|
||||
$(_top)-SET = true ;
|
||||
|
||||
# First time we've seen this TOP.
|
||||
# We'll initialize a number of internal variables:
|
||||
#
|
||||
# $(TOP-UP) = directories from ROOT to a common point
|
||||
# $(TOP-DOWN) = directories from common point to TOP
|
||||
# $(TOP-ROOT) = root directory for UP/DOWN -- normally CWD
|
||||
# $(SUBDIR_UP) = current value of $(TOP-UP)
|
||||
# $(SUBDIR_DOWN) = current value of $(TOP-DOWN)
|
||||
# $(SUBDIR_ROOT) = current value of $(TOP-ROOT)
|
||||
#
|
||||
|
||||
if $($(_top))
|
||||
{
|
||||
# TOP externally set.
|
||||
# We'll ignore the relative (UP/DOWN) path that
|
||||
# got us here, and instead remember the hard ROOT.
|
||||
|
||||
$(_top)-UP = ;
|
||||
$(_top)-DOWN = ;
|
||||
$(_top)-ROOT = $($(_top)) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
# TOP not preset.
|
||||
|
||||
# Establishing a new TOP. In the simplest case,
|
||||
# (SUBDIR_UP/SUBDIR_DOWN/SUBDIR_ROOT unset), it's
|
||||
# merely a certain number of directories down from
|
||||
# the current directory, and FSubDirPath will set
|
||||
# TOP to a path consisting of ../ for each of the
|
||||
# elements of _tokens, because that represents how
|
||||
# far below TOP the current directory sits.
|
||||
#
|
||||
# In the more complicated case, the starting directory
|
||||
# isn't the directory of jam's invocation but an
|
||||
# location established by previous SubDir call. The
|
||||
# starting directory is SUBDIR_UP directories up from
|
||||
# SUBDIR_ROOT, and then SUBDIR_DOWN directories down
|
||||
# from that. If SUBDIR_ROOT is not set, that means
|
||||
# SUBDIR_DOWN and SUBDIR_UP represent the path from
|
||||
# the directory of jam's invocation.
|
||||
#
|
||||
# In the most complicated case, the _tokens also
|
||||
# represents directories down, because TOP is being
|
||||
# estalished in a directory other than TOP's root.
|
||||
# Hopefully, _tokens and SUBDIR_DOWN represent the
|
||||
# same final directory, relative to the new TOP and
|
||||
# the previous SubDIr's TOP. To find the new TOP,
|
||||
# we have to chop off any common directories from
|
||||
# then ends of _tokens and SUBDIR_DOWN. To do so,
|
||||
# we reverse each of them, call FStripCommon to
|
||||
# remove the initial common elements, and then
|
||||
# reverse them again. After this process, if
|
||||
# both _tokens and SUBDIR_DOWN have elements, it
|
||||
# means the directory names estalished by the two
|
||||
# SubDir calls don't match, and a warning is issued.
|
||||
# All hell will likely break loose at this point,
|
||||
# since the whole SubDir scheme relies on the SubDir
|
||||
# calls accurately naming the current directory.
|
||||
|
||||
# Strip common trailing elements of _tokens and SUBDIR_DOWN.
|
||||
|
||||
_tokens = [ FReverse $(_tokens) ] ;
|
||||
SUBDIR_DOWN = [ FReverse $(SUBDIR_DOWN) ] ;
|
||||
FStripCommon _tokens : SUBDIR_DOWN ;
|
||||
SUBDIR_DOWN = [ FReverse $(SUBDIR_DOWN) ] ;
|
||||
_tokens = [ FReverse $(_tokens) ] ;
|
||||
|
||||
if $(SUBDIR_DOWN) && $(_tokens)
|
||||
{
|
||||
Echo Warning: SubDir $(<) misplaced! ;
|
||||
}
|
||||
|
||||
# We'll remember the relative (UP/DOWN) path that
|
||||
# got us here, plus any hard ROOT starting point
|
||||
# for the UP/DOWN. If TOP is never set externally,
|
||||
# ROOT will always be "" (directory of jam's invocation).
|
||||
|
||||
$(_top)-UP = $(SUBDIR_UP) $(_tokens) ;
|
||||
$(_top)-DOWN = $(SUBDIR_DOWN) ;
|
||||
$(_top)-ROOT = $(SUBDIR_ROOT:E="") ;
|
||||
$(_top) = [ FSubDirPath $(_top) ] ;
|
||||
}
|
||||
|
||||
# Set subdir vars for the inclusion of the Jamrules,
|
||||
# just in case they have SubDir rules of their own.
|
||||
# Note that SUBDIR_DOWN is empty: it's all the way
|
||||
# up where the Jamrules live. These gets overrided
|
||||
# just after the inclusion.
|
||||
|
||||
SUBDIR_UP = $($(_top)-UP) ;
|
||||
SUBDIR_DOWN = ;
|
||||
SUBDIR_ROOT = $($(_top)-ROOT) ;
|
||||
|
||||
# Include $(TOPRULES) or $(TOP)/Jamrules.
|
||||
# Include $(TOPRULES) if set.
|
||||
# Otherwise include $(TOP)/Jamrules if present.
|
||||
|
||||
if $($(_top)RULES) {
|
||||
include $($(_top)RULES) ;
|
||||
} else {
|
||||
NoCare $(JAMRULES:R=$($(_top)):G=$(_top)) ;
|
||||
include $(JAMRULES:R=$($(_top)):G=$(_top)) ;
|
||||
}
|
||||
}
|
||||
|
||||
# Get path from $(TOP) to named directory.
|
||||
# Save dir tokens for other potential uses.
|
||||
|
||||
SUBDIR_UP = $($(_top)-UP) ;
|
||||
SUBDIR_DOWN = $($(_top)-DOWN) $(_tokens) ;
|
||||
SUBDIR_ROOT = $($(_top)-ROOT) ;
|
||||
SUBDIR_TOKENS = $(SUBDIR_DOWN) ;
|
||||
|
||||
SUBDIR = [ FSubDirPath $(<) ] ;
|
||||
|
||||
# Now set up SEARCH_SOURCE, LOCATE_TARGET, SOURCE_GRIST
|
||||
# These can be reset if needed. For example, if the source
|
||||
# directory should not hold object files, LOCATE_TARGET can
|
||||
# subsequently be redefined.
|
||||
|
||||
SEARCH_SOURCE = $(SUBDIR) ;
|
||||
LOCATE_SOURCE = $(ALL_LOCATE_TARGET) $(SUBDIR) ;
|
||||
LOCATE_TARGET = $(ALL_LOCATE_TARGET) $(SUBDIR) ;
|
||||
SOURCE_GRIST = [ FGrist $(SUBDIR_TOKENS) ] ;
|
||||
|
||||
# Reset per-directory ccflags, hdrs, etc,
|
||||
# listed in SUBDIRRESET.
|
||||
# Note use of variable expanded assignment var
|
||||
|
||||
SUBDIR$(SUBDIRRESET) = ;
|
||||
|
||||
# Invoke user-specific SubDir extensions,
|
||||
# rule names listed in SUBDIRRULES.
|
||||
# Note use of variable expanded rule invocation
|
||||
|
||||
$(SUBDIRRULES) $(<) ;
|
||||
}
|
||||
|
||||
rule FSubDirPath
|
||||
{
|
||||
# FSubDirPath TOP d1 ... ;
|
||||
|
||||
# Returns path to named directory.
|
||||
|
||||
# If jam is invoked in a subdirectory of the TOP, then we
|
||||
# need to prepend a ../ for every level we must climb up
|
||||
# (TOP-UP), and then append the directory names we must
|
||||
# climb down (TOP-DOWN), plus the named directories d1 ...
|
||||
# If TOP was set externally, or computed from another TOP
|
||||
# that was, we'll have to reroot the whole thing at TOP-ROOT.
|
||||
|
||||
local _r = [ FRelPath $($(<[1])-UP) : $($(<[1])-DOWN) $(<[2-]) ] ;
|
||||
|
||||
return $(_r:R=$($(<[1])-ROOT)) ;
|
||||
}
|
||||
|
||||
rule SubInclude
|
||||
{
|
||||
# SubInclude TOP d1 ... ;
|
||||
#
|
||||
# Include a subdirectory's Jamfile.
|
||||
|
||||
# We use SubDir to get there, in case the included Jamfile
|
||||
# either doesn't have its own SubDir (naughty) or is a subtree
|
||||
# with its own TOP.
|
||||
|
||||
if ! $($(<[1]))
|
||||
{
|
||||
Exit SubInclude $(<[1]) without prior SubDir $(<[1]) ;
|
||||
}
|
||||
|
||||
SubDir $(<) ;
|
||||
|
||||
include $(JAMFILE:D=$(SUBDIR)) ;
|
||||
}
|
||||
|
||||
rule SubRules
|
||||
{
|
||||
# SubRules TOP d1 ... : Other-TOP ;
|
||||
#
|
||||
# Read another tree's Jamrules, by giving it's path according
|
||||
# to this tree and it's own name.
|
||||
|
||||
if ! $($(<[1]))
|
||||
{
|
||||
Exit SubRules $(<[1]) without prior SubDir $(<[1]) ;
|
||||
}
|
||||
|
||||
SubDir $(<) ;
|
||||
SubDir $(>) ;
|
||||
}
|
||||
|
||||
## Now we try to fix up the already messed settings
|
||||
## XXX We can only hope that Jam 2.4 users don't try starting Jam from
|
||||
## subdirectories
|
||||
TOP-SET = true ;
|
||||
TOP-UP = ;
|
||||
TOP-DOWN = ;
|
||||
TOP-ROOT = $(TOP) ;
|
||||
SUBDIR_UP = $(TOP-UP) ;
|
||||
SUBDIR_DOWN = ;
|
||||
SUBDIR_ROOT = $(TOP-ROOT) ;
|
||||
|
||||
#SubDir TOP ;
|
||||
|
||||
} # end if $(JAMVERSION) = 2.4
|
||||
#============================================================================
|
||||
# Several hacks to make the build compatible with certain old/broken jam
|
||||
# versions
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
# BoostJam is evil: It is compatible to Jam 2.4 but has a version number 3.1,
|
||||
# we try to detect BoostJam with the ARGV extension.
|
||||
if $(ARGV[0])
|
||||
{
|
||||
# BoostJam hacks.
|
||||
JAMVERSION = 2.4 ;
|
||||
rule FIncludes
|
||||
{
|
||||
return -I$(<) ;
|
||||
}
|
||||
rule FDefines
|
||||
{
|
||||
return -D$(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
if $(JAMVERSION) < 2.4
|
||||
{
|
||||
EXIT "Error: This buildsystem requires jam version 2.4 or later." ;
|
||||
}
|
||||
|
||||
# All scripts invoked by the build system expect a Bourne or compatible shell.
|
||||
# Reject C-shell and its variants (such as tcsh). Unfortunately, this is a bit
|
||||
# of an ugly hack. It would be nicer to perform this logic at the very end of
|
||||
# this file as a last-minute assertion. Unfortunately, however, it seems that
|
||||
# references to $(SHELL) in any of the included files get bound at the point
|
||||
# of reference, thus we need to perform this filtering as early as possible.
|
||||
# Furthermore, on Windows, if the MSYS installation path contains a space (such
|
||||
# as "c:\Program Files\msys"), the space will cause `actions' to fail which
|
||||
# employ $(SHELL) indirectly through some other variable. Therefore, handle
|
||||
# this case as well.
|
||||
if [ Match (csh) : $(SHELL) ] || $(SHELL[2])
|
||||
{
|
||||
SHELL = "/bin/sh" ;
|
||||
}
|
||||
|
||||
# Jam 2.4's SubDir rule had some problems and misses the useful SUBDIRRULES
|
||||
# extension. So we override it here with a better version (from jam 2.5rc3).
|
||||
# Likewise, 2.4 is missing FReverse and FStrip, which are needed by SubDir and
|
||||
# other custom rules we define.
|
||||
if $(JAMVERSION) = 2.4
|
||||
{
|
||||
|
||||
rule FReverse
|
||||
{
|
||||
# FReverse a1 a2 a3 ... ;
|
||||
# return ... a3 a2 a1 ;
|
||||
|
||||
if $(1) { return [ FReverse $(1[2-]) ] $(1[1]) ; }
|
||||
}
|
||||
|
||||
rule FStripCommon
|
||||
{
|
||||
# FStripCommon v1 : v2 ;
|
||||
|
||||
# Strip common initial elements of variables v1 and v2.
|
||||
# Modifies the variable values themselves.
|
||||
|
||||
if $($(<)[1]) && $($(<)[1]) = $($(>)[1])
|
||||
{
|
||||
$(<) = $($(<)[2-]) ;
|
||||
$(>) = $($(>)[2-]) ;
|
||||
FStripCommon $(<) : $(>) ;
|
||||
}
|
||||
}
|
||||
|
||||
rule SubDir
|
||||
{
|
||||
#
|
||||
# SubDir TOP d1 d2 ... ;
|
||||
#
|
||||
# Support for a project tree spanning multiple directories.
|
||||
#
|
||||
# SubDir declares a Jamfile's location in a project tree, setting
|
||||
# Jambase variables (SEARCH_SOURCE, LOCATE_TARGET) so that source
|
||||
# files can be found.
|
||||
#
|
||||
# TOP is a user-select variable name for root of the tree, and
|
||||
# d1 d2 ... are the directory elements that lead from the root
|
||||
# of the tree to the directory of the Jamfile.
|
||||
#
|
||||
# TOP can be set externally, but normally the first SubDir call
|
||||
# computes TOP as the path up from the current directory; the
|
||||
# path contains one ../ for each of d1 d2 ...
|
||||
#
|
||||
# SubDir reads once the project-specific rules file Jamrules
|
||||
# in the TOP directory, if present. This can be overridden
|
||||
# with the variable TOPRULES.
|
||||
#
|
||||
# SubDir supports multiple, overlaid project trees: SubDir
|
||||
# invocations with different TOPs can appear in the same Jamfile.
|
||||
# The location established by the first SubDir call is used set
|
||||
# the TOPs for the subsequent SubDir calls.
|
||||
#
|
||||
# SubDir's public variables:
|
||||
#
|
||||
# $(TOP) = path from CWD to root.
|
||||
# $(SUBDIR) = path from CWD to the directory SubDir names.
|
||||
# $(SUBDIR_TOKENS) = path from $(TOP) to $(SUBDIR) as dir names
|
||||
# $(SEARCH_SOURCE) = $(SUBDIR)
|
||||
# $(LOCATE_SOURCE) = $(ALL_LOCATE_TARGET) $(SUBDIR)
|
||||
# $(LOCATE_TARGET) = $(ALL_LOCATE_TARGET) $(SUBDIR)
|
||||
# $(SOURCE_GRIST) = $(SUBDIR_TOKENS) with !'s
|
||||
#
|
||||
|
||||
local _top = $(<[1]) ;
|
||||
local _tokens = $(<[2-]) ;
|
||||
|
||||
#
|
||||
# First time through sets up relative root and includes Jamrules.
|
||||
#
|
||||
|
||||
if ! $(_top)
|
||||
{
|
||||
Exit SubDir syntax error ;
|
||||
}
|
||||
|
||||
if ! $($(_top)-SET)
|
||||
{
|
||||
$(_top)-SET = true ;
|
||||
|
||||
# First time we've seen this TOP.
|
||||
# We'll initialize a number of internal variables:
|
||||
#
|
||||
# $(TOP-UP) = directories from ROOT to a common point
|
||||
# $(TOP-DOWN) = directories from common point to TOP
|
||||
# $(TOP-ROOT) = root directory for UP/DOWN -- normally CWD
|
||||
# $(SUBDIR_UP) = current value of $(TOP-UP)
|
||||
# $(SUBDIR_DOWN) = current value of $(TOP-DOWN)
|
||||
# $(SUBDIR_ROOT) = current value of $(TOP-ROOT)
|
||||
#
|
||||
|
||||
if $($(_top))
|
||||
{
|
||||
# TOP externally set.
|
||||
# We'll ignore the relative (UP/DOWN) path that
|
||||
# got us here, and instead remember the hard ROOT.
|
||||
|
||||
$(_top)-UP = ;
|
||||
$(_top)-DOWN = ;
|
||||
$(_top)-ROOT = $($(_top)) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
# TOP not preset.
|
||||
|
||||
# Establishing a new TOP. In the simplest case,
|
||||
# (SUBDIR_UP/SUBDIR_DOWN/SUBDIR_ROOT unset), it's
|
||||
# merely a certain number of directories down from
|
||||
# the current directory, and FSubDirPath will set
|
||||
# TOP to a path consisting of ../ for each of the
|
||||
# elements of _tokens, because that represents how
|
||||
# far below TOP the current directory sits.
|
||||
#
|
||||
# In the more complicated case, the starting directory
|
||||
# isn't the directory of jam's invocation but an
|
||||
# location established by previous SubDir call. The
|
||||
# starting directory is SUBDIR_UP directories up from
|
||||
# SUBDIR_ROOT, and then SUBDIR_DOWN directories down
|
||||
# from that. If SUBDIR_ROOT is not set, that means
|
||||
# SUBDIR_DOWN and SUBDIR_UP represent the path from
|
||||
# the directory of jam's invocation.
|
||||
#
|
||||
# In the most complicated case, the _tokens also
|
||||
# represents directories down, because TOP is being
|
||||
# estalished in a directory other than TOP's root.
|
||||
# Hopefully, _tokens and SUBDIR_DOWN represent the
|
||||
# same final directory, relative to the new TOP and
|
||||
# the previous SubDIr's TOP. To find the new TOP,
|
||||
# we have to chop off any common directories from
|
||||
# then ends of _tokens and SUBDIR_DOWN. To do so,
|
||||
# we reverse each of them, call FStripCommon to
|
||||
# remove the initial common elements, and then
|
||||
# reverse them again. After this process, if
|
||||
# both _tokens and SUBDIR_DOWN have elements, it
|
||||
# means the directory names estalished by the two
|
||||
# SubDir calls don't match, and a warning is issued.
|
||||
# All hell will likely break loose at this point,
|
||||
# since the whole SubDir scheme relies on the SubDir
|
||||
# calls accurately naming the current directory.
|
||||
|
||||
# Strip common trailing elements of _tokens and SUBDIR_DOWN.
|
||||
|
||||
_tokens = [ FReverse $(_tokens) ] ;
|
||||
SUBDIR_DOWN = [ FReverse $(SUBDIR_DOWN) ] ;
|
||||
FStripCommon _tokens : SUBDIR_DOWN ;
|
||||
SUBDIR_DOWN = [ FReverse $(SUBDIR_DOWN) ] ;
|
||||
_tokens = [ FReverse $(_tokens) ] ;
|
||||
|
||||
if $(SUBDIR_DOWN) && $(_tokens)
|
||||
{
|
||||
Echo Warning: SubDir $(<) misplaced! ;
|
||||
}
|
||||
|
||||
# We'll remember the relative (UP/DOWN) path that
|
||||
# got us here, plus any hard ROOT starting point
|
||||
# for the UP/DOWN. If TOP is never set externally,
|
||||
# ROOT will always be "" (directory of jam's invocation).
|
||||
|
||||
$(_top)-UP = $(SUBDIR_UP) $(_tokens) ;
|
||||
$(_top)-DOWN = $(SUBDIR_DOWN) ;
|
||||
$(_top)-ROOT = $(SUBDIR_ROOT:E="") ;
|
||||
$(_top) = [ FSubDirPath $(_top) ] ;
|
||||
}
|
||||
|
||||
# Set subdir vars for the inclusion of the Jamrules,
|
||||
# just in case they have SubDir rules of their own.
|
||||
# Note that SUBDIR_DOWN is empty: it's all the way
|
||||
# up where the Jamrules live. These gets overrided
|
||||
# just after the inclusion.
|
||||
|
||||
SUBDIR_UP = $($(_top)-UP) ;
|
||||
SUBDIR_DOWN = ;
|
||||
SUBDIR_ROOT = $($(_top)-ROOT) ;
|
||||
|
||||
# Include $(TOPRULES) or $(TOP)/Jamrules.
|
||||
# Include $(TOPRULES) if set.
|
||||
# Otherwise include $(TOP)/Jamrules if present.
|
||||
|
||||
if $($(_top)RULES) {
|
||||
include $($(_top)RULES) ;
|
||||
} else {
|
||||
NoCare $(JAMRULES:R=$($(_top)):G=$(_top)) ;
|
||||
include $(JAMRULES:R=$($(_top)):G=$(_top)) ;
|
||||
}
|
||||
}
|
||||
|
||||
# Get path from $(TOP) to named directory.
|
||||
# Save dir tokens for other potential uses.
|
||||
|
||||
SUBDIR_UP = $($(_top)-UP) ;
|
||||
SUBDIR_DOWN = $($(_top)-DOWN) $(_tokens) ;
|
||||
SUBDIR_ROOT = $($(_top)-ROOT) ;
|
||||
SUBDIR_TOKENS = $(SUBDIR_DOWN) ;
|
||||
|
||||
SUBDIR = [ FSubDirPath $(<) ] ;
|
||||
|
||||
# Now set up SEARCH_SOURCE, LOCATE_TARGET, SOURCE_GRIST
|
||||
# These can be reset if needed. For example, if the source
|
||||
# directory should not hold object files, LOCATE_TARGET can
|
||||
# subsequently be redefined.
|
||||
|
||||
SEARCH_SOURCE = $(SUBDIR) ;
|
||||
LOCATE_SOURCE = $(ALL_LOCATE_TARGET) $(SUBDIR) ;
|
||||
LOCATE_TARGET = $(ALL_LOCATE_TARGET) $(SUBDIR) ;
|
||||
SOURCE_GRIST = [ FGrist $(SUBDIR_TOKENS) ] ;
|
||||
|
||||
# Reset per-directory ccflags, hdrs, etc,
|
||||
# listed in SUBDIRRESET.
|
||||
# Note use of variable expanded assignment var
|
||||
|
||||
SUBDIR$(SUBDIRRESET) = ;
|
||||
|
||||
# Invoke user-specific SubDir extensions,
|
||||
# rule names listed in SUBDIRRULES.
|
||||
# Note use of variable expanded rule invocation
|
||||
|
||||
$(SUBDIRRULES) $(<) ;
|
||||
}
|
||||
|
||||
rule FSubDirPath
|
||||
{
|
||||
# FSubDirPath TOP d1 ... ;
|
||||
|
||||
# Returns path to named directory.
|
||||
|
||||
# If jam is invoked in a subdirectory of the TOP, then we
|
||||
# need to prepend a ../ for every level we must climb up
|
||||
# (TOP-UP), and then append the directory names we must
|
||||
# climb down (TOP-DOWN), plus the named directories d1 ...
|
||||
# If TOP was set externally, or computed from another TOP
|
||||
# that was, we'll have to reroot the whole thing at TOP-ROOT.
|
||||
|
||||
local _r = [ FRelPath $($(<[1])-UP) : $($(<[1])-DOWN) $(<[2-]) ] ;
|
||||
|
||||
return $(_r:R=$($(<[1])-ROOT)) ;
|
||||
}
|
||||
|
||||
rule SubInclude
|
||||
{
|
||||
# SubInclude TOP d1 ... ;
|
||||
#
|
||||
# Include a subdirectory's Jamfile.
|
||||
|
||||
# We use SubDir to get there, in case the included Jamfile
|
||||
# either doesn't have its own SubDir (naughty) or is a subtree
|
||||
# with its own TOP.
|
||||
|
||||
if ! $($(<[1]))
|
||||
{
|
||||
Exit SubInclude $(<[1]) without prior SubDir $(<[1]) ;
|
||||
}
|
||||
|
||||
SubDir $(<) ;
|
||||
|
||||
include $(JAMFILE:D=$(SUBDIR)) ;
|
||||
}
|
||||
|
||||
rule SubRules
|
||||
{
|
||||
# SubRules TOP d1 ... : Other-TOP ;
|
||||
#
|
||||
# Read another tree's Jamrules, by giving it's path according
|
||||
# to this tree and it's own name.
|
||||
|
||||
if ! $($(<[1]))
|
||||
{
|
||||
Exit SubRules $(<[1]) without prior SubDir $(<[1]) ;
|
||||
}
|
||||
|
||||
SubDir $(<) ;
|
||||
SubDir $(>) ;
|
||||
}
|
||||
|
||||
## Now we try to fix up the already messed settings
|
||||
## XXX We can only hope that Jam 2.4 users don't try starting Jam from
|
||||
## subdirectories
|
||||
TOP-SET = true ;
|
||||
TOP-UP = ;
|
||||
TOP-DOWN = ;
|
||||
TOP-ROOT = $(TOP) ;
|
||||
SUBDIR_UP = $(TOP-UP) ;
|
||||
SUBDIR_DOWN = ;
|
||||
SUBDIR_ROOT = $(TOP-ROOT) ;
|
||||
|
||||
#SubDir TOP ;
|
||||
|
||||
} # end if $(JAMVERSION) = 2.4
|
||||
|
||||
@@ -1,314 +1,323 @@
|
||||
#============================================================================
|
||||
# Rules for library creation
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
# Suppress ar's noisy report that it created the archive we asked it to create.
|
||||
if $(AR) && $(AR[2]) = ru { AR = $(AR[1]) ruc ; }
|
||||
|
||||
## Library libname : sources [ : options ]
|
||||
## Build a library out of sourcefiles. All sourcefiles will be passed
|
||||
## to the Objects rule which tries to compile them into object-files. You
|
||||
## can create rules for your own filetypes with the UserObject rule. Header
|
||||
## files will just be ignored. They are only used for MSVC projectfile
|
||||
## generation.
|
||||
## Available options are 'shared' if you want to build a shared library on
|
||||
## platforms which support that. You can specify the 'noinstall' option if
|
||||
## you don't want an install target generated.
|
||||
## Don't specify any extensions for the library name, also leave out the
|
||||
## leading "lib".
|
||||
## Options:
|
||||
## noinstall: Do not set up a default installation target.
|
||||
## independent: The target will not be made a dependency of the libs and
|
||||
## all targets.
|
||||
## shared: Create as a shared library on supported platforms.
|
||||
## nohelp: Do not invoke Help for this target.
|
||||
## notest: Do not set up unit-testing support for this target.
|
||||
## optional: Affects handling of the library in cs-config; it is only
|
||||
## reported as available when actually built.
|
||||
rule Library
|
||||
{
|
||||
local options = $(3) ;
|
||||
CheckOptions noinstall independent shared nohelp notest optional : $(options) : $(<) ;
|
||||
|
||||
local target = [ ConstructLibraryTarget $(<) : $(options) ] ;
|
||||
local sources = [ DoSourceGrist $(>) ] ;
|
||||
local objects ;
|
||||
local i ;
|
||||
for i in $(sources)
|
||||
{
|
||||
if $(i:S) = $(SUFOBJ)
|
||||
{
|
||||
objects += $(i) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
objects += [ CompileObjects $(i) ] ;
|
||||
}
|
||||
}
|
||||
|
||||
$(<)_TYPE = library ;
|
||||
$(<)_OBJECTS = $(objects) ;
|
||||
$(<)_SOURCES = $(sources) ;
|
||||
$(<)_TARGET = $(target) ;
|
||||
|
||||
# create target clean rule
|
||||
Always $(<)clean ;
|
||||
NotFile $(<)clean ;
|
||||
Clean $(<)clean : $(objects) ; # create target clean rule
|
||||
|
||||
# so 'jam foo' works when it's really foo.exe (Windows) or foo.app (MacOS/X)
|
||||
if $(target) != $(<)
|
||||
{
|
||||
Depends $(<) : $(target) ;
|
||||
NotFile $(<) ;
|
||||
}
|
||||
|
||||
# library depends on its member objects
|
||||
if ! [ IsElem independent : $(options) ]
|
||||
{
|
||||
if $(KEEPOBJS)
|
||||
{
|
||||
Depends obj : $(objects) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
Depends libs : $(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
if ( ! [ IsElem shared : $(options) ] ) || ( $(BUILD_SHARED_LIBS) != "yes" )
|
||||
{
|
||||
$(<)_SHARED = "" ;
|
||||
LibraryStatic $(<) : $(objects) : [ Filter $(options) : shared ] :
|
||||
$(target) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
$(<)_SHARED = "shared" ;
|
||||
LibraryShared $(<) : $(objects) : $(options) : $(target) ;
|
||||
}
|
||||
CFlags $(<) : $(LIBRARY.CFLAGS) ;
|
||||
LFlags $(<) : $(LIBRARY.LFLAGS) ;
|
||||
|
||||
if ! [ IsElem nohelp : $(options) ]
|
||||
{
|
||||
local desc = [ Description $(<) ] ;
|
||||
if ! $(desc) { desc = "$(<) library" ; }
|
||||
Help $(<) : "Build the $(desc)" ;
|
||||
}
|
||||
|
||||
if ! [ IsElem notest : $(options) ]
|
||||
{
|
||||
UnitTest $(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
## LibDepends libname : dependant libraries
|
||||
## Make Library dependant on other libraries. This will tell the build
|
||||
## system that your library uses functions from other libraries in the
|
||||
## project. Note that a library shouldn't be linked with any external
|
||||
## library that should be done by the final application which uses the
|
||||
## library.
|
||||
rule LibDepends
|
||||
{
|
||||
$(<)_depends += $(>) ;
|
||||
|
||||
if "$($(<)_SHARED)"
|
||||
{
|
||||
LinkWith $(<) : $(>) ;
|
||||
}
|
||||
|
||||
UnitTestLibDepends $(<) : $(>) ;
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# private part
|
||||
|
||||
# LibraryStatic libname : sources : options : decoratedtarget
|
||||
rule LibraryStatic
|
||||
{
|
||||
local objects = $(>) ;
|
||||
local options = $(3) ;
|
||||
local target = $(4) ;
|
||||
|
||||
# Set LOCATE for the library and its contents. The bound
|
||||
# value shows up as $(NEEDLIBS) on the Link actions.
|
||||
# For compatibility, we only do this if the library doesn't
|
||||
# already have a path.
|
||||
if ! $(target:D)
|
||||
{
|
||||
MakeLocate $(target) $(target)($(objects:BS)) : $(LOCATE.OBJECTS)/libs ;
|
||||
}
|
||||
|
||||
if $(NOARSCAN)
|
||||
{
|
||||
# If we can't scan the library to timestamp its contents,
|
||||
# we have to just make the library depend directly on the
|
||||
# on-disk object files.
|
||||
Depends $(target) : $(objects) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
# If we can scan the library, we make the library depend
|
||||
# on its members and each member depend on the on-disk
|
||||
# object file.
|
||||
Depends $(target) : $(target)($(objects:BS)) ;
|
||||
|
||||
local i ;
|
||||
for i in $(objects)
|
||||
{
|
||||
Depends $(target)($(i:BS)) : $(i) ;
|
||||
}
|
||||
}
|
||||
|
||||
# Generate install rules
|
||||
if ! [ IsElem noinstall : $(options) ]
|
||||
{
|
||||
if "$(RANLIB)"
|
||||
{
|
||||
Depends install_lib : [ DoInstall $(target) : $(libdir) : : Ranlib ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
Depends install_lib : [ DoInstall $(target) : $(libdir) ] ;
|
||||
}
|
||||
|
||||
# Add to global library list
|
||||
if [ IsElem optional : $(options) ]
|
||||
{
|
||||
INSTALLEDLIBS_OPTIONAL += $(<) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
INSTALLEDLIBS += $(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
if $(CRELIB)
|
||||
{
|
||||
CreLib $(target) : $(objects[1]) ;
|
||||
}
|
||||
|
||||
Archive $(target) : $(objects) ;
|
||||
Clean $(<)clean : $(target) ;
|
||||
Depends clean : $(<)clean ;
|
||||
|
||||
if $(RANLIB)
|
||||
{
|
||||
Ranlib $(target) ;
|
||||
}
|
||||
|
||||
# If we can't scan the library, we have to leave the .o's around.
|
||||
if ! ( $(NOARSCAN) || $(NOARUPDATE) || $(KEEPOBJS) )
|
||||
{
|
||||
RmTemps $(target) : $(objects) ;
|
||||
}
|
||||
}
|
||||
|
||||
# LibraryStatic libname : sources : options : decoratedtarget
|
||||
rule LibraryShared
|
||||
{
|
||||
local objects = $(>) ;
|
||||
local options = $(3) ;
|
||||
local target = $(4) ;
|
||||
local linklib = [ ConstructSharedLibraryLinkLib $(<) : $(options) ] ;
|
||||
local deplibs ;
|
||||
|
||||
local i ;
|
||||
for i in $(LIBDEPENDS)
|
||||
{
|
||||
deplibs += [ ConstructLibraryLinkTarget $(i) : $(options) ] ;
|
||||
}
|
||||
|
||||
# Generate install rules
|
||||
if ! [ IsElem noinstall : $(options) ]
|
||||
{
|
||||
if $(TARGET.OS) != WIN32
|
||||
{
|
||||
Depends install_lib : [ DoInstall $(target) : $(libdir) ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
Depends install_lib : [ DoInstall $(target) : $(bindir) ] ;
|
||||
Depends install_lib : [ DoInstall $(linklib) : $(libdir) ] ;
|
||||
}
|
||||
|
||||
# Add to global library list
|
||||
if [ IsElem optional : $(options) ]
|
||||
{
|
||||
INSTALLEDLIBS_OPTIONAL += $(<) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
INSTALLEDLIBS += $(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
Depends $(<) : $(linklib) ;
|
||||
if $(linklib) != $(target)
|
||||
{
|
||||
Depends $(linklib) : $(target) ;
|
||||
MakeLocate $(linklib) : $(LOCATE.OBJECTS)/libs ;
|
||||
SEARCH on $(linklib) = $(LOCATE.OBJECTS)/libs ;
|
||||
}
|
||||
Depends $(target) : $(objects) ;
|
||||
Clean $(<)clean : $(linklib) $(target) ;
|
||||
Depends clean : $(<)clean ;
|
||||
Depends $(target) : $(deplibs) ;
|
||||
|
||||
CFlags $(<) : [ FDefines CS_$(<:U)_LIB ] ;
|
||||
LFlags $(<) : $(LINKLIBS) ;
|
||||
|
||||
SystemLinkSharedLibrary $(target) : $(objects) $(deplibs) : $(linklib) ;
|
||||
}
|
||||
|
||||
rule ConstructLibraryTarget
|
||||
{
|
||||
if ( ! [ IsElem shared : $(>) ] ) || ( $(BUILD_SHARED_LIBS) != "yes" )
|
||||
{
|
||||
return [ ConstructStaticLibraryTarget $(<) : [ Filter $(>) : shared ] ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
return [ ConstructSharedLibraryTarget $(<) : $(>) ] ;
|
||||
}
|
||||
}
|
||||
|
||||
rule ConstructLibraryLinkTarget
|
||||
{
|
||||
if ( ! [ IsElem shared : $(>) ] ) || ( $(BUILD_SHARED_LIBS) != "yes" )
|
||||
{
|
||||
return [ ConstructStaticLibraryTarget $(<) : [ Filter $(>) : shared ] ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
return [ ConstructSharedLibraryLinkLib $(<) : $(>) ] ;
|
||||
}
|
||||
}
|
||||
|
||||
actions together Ranlib
|
||||
{
|
||||
$(RANLIB) $(<)
|
||||
}
|
||||
|
||||
# Construct pseudo target libs which is used instead of the pseudo target lib
|
||||
# in Jambase
|
||||
Depends lib : libs ;
|
||||
NotFile libs ;
|
||||
Help libs : "Build all link libraries" ;
|
||||
#============================================================================
|
||||
# Rules for library creation
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
# Suppress ar's noisy report that it created the archive we asked it to create.
|
||||
if $(AR) && $(AR[2]) = ru { AR = $(AR[1]) ruc ; }
|
||||
|
||||
## Library libname : sources [ : options ]
|
||||
## Build a library out of sourcefiles. All sourcefiles will be passed
|
||||
## to the Objects rule which tries to compile them into object-files. You
|
||||
## can create rules for your own filetypes with the UserObject rule. Header
|
||||
## files will just be ignored. They are only used for MSVC projectfile
|
||||
## generation.
|
||||
## Available options are 'shared' if you want to build a shared library on
|
||||
## platforms which support that. You can specify the 'noinstall' option if
|
||||
## you don't want an install target generated.
|
||||
## Don't specify any extensions for the library name, also leave out the
|
||||
## leading "lib".
|
||||
## Options:
|
||||
## noinstall: Do not set up a default installation target.
|
||||
## independent: The target will not be made a dependency of the libs and
|
||||
## all targets.
|
||||
## shared: Create as a shared library on supported platforms.
|
||||
## nohelp: Do not invoke Help for this target.
|
||||
## notest: Do not set up unit-testing support for this target.
|
||||
## optional: Affects handling of the library in cs-config; it is only
|
||||
## reported as available when actually built.
|
||||
rule Library
|
||||
{
|
||||
local options = $(3) ;
|
||||
CheckOptions noinstall independent shared nohelp notest optional : $(options) : $(<) ;
|
||||
|
||||
local target = [ ConstructLibraryTarget $(<) : $(options) ] ;
|
||||
local sources = [ DoSourceGrist $(>) ] ;
|
||||
local objects ;
|
||||
local i ;
|
||||
for i in $(sources)
|
||||
{
|
||||
if $(i:S) = $(SUFOBJ)
|
||||
{
|
||||
objects += $(i) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
objects += [ CompileObjects $(i) ] ;
|
||||
}
|
||||
}
|
||||
|
||||
$(<)_TYPE = library ;
|
||||
$(<)_OBJECTS = $(objects) ;
|
||||
$(<)_SOURCES = $(sources) ;
|
||||
$(<)_TARGET = $(target) ;
|
||||
|
||||
# so 'jam foo' works when it's really foo.exe (Windows) or foo.app (MacOS/X)
|
||||
if $(target) != $(<)
|
||||
{
|
||||
Depends $(<) : $(target) ;
|
||||
NotFile $(<) ;
|
||||
}
|
||||
|
||||
# library depends on its member objects
|
||||
if ! [ IsElem independent : $(options) ]
|
||||
{
|
||||
if $(KEEPOBJS)
|
||||
{
|
||||
Depends obj : $(objects) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
Depends libs : $(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
if ( ! [ IsElem shared : $(options) ] ) || ( $(BUILD_SHARED_LIBS) != "yes" )
|
||||
{
|
||||
$(<)_SHARED = "" ;
|
||||
LibraryStatic $(<) : $(objects) : [ Filter $(options) : shared ] :
|
||||
$(target) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
$(<)_SHARED = "shared" ;
|
||||
LibraryShared $(<) : $(objects) : $(options) : $(target) ;
|
||||
}
|
||||
CFlags $(<) : $(LIBRARY.CFLAGS) ;
|
||||
LFlags $(<) : $(LIBRARY.LFLAGS) ;
|
||||
|
||||
# create target clean rule
|
||||
Always $(<)clean ;
|
||||
NotFile $(<)clean ;
|
||||
Clean $(<)clean : $(objects) $($(<)_CLEANEXTRA) ;
|
||||
Clean clean : $($(<)_CLEANEXTRA) ;
|
||||
|
||||
if ! [ IsElem nohelp : $(options) ]
|
||||
{
|
||||
local desc = [ Description $(<) ] ;
|
||||
if ! $(desc) { desc = "$(<) library" ; }
|
||||
Help $(<) : "Build the $(desc)" ;
|
||||
}
|
||||
|
||||
if ! [ IsElem notest : $(options) ]
|
||||
{
|
||||
UnitTest $(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
## LibDepends libname : dependant libraries
|
||||
## Make Library dependant on other libraries. This will tell the build
|
||||
## system that your library uses functions from other libraries in the
|
||||
## project. Note that a library shouldn't be linked with any external
|
||||
## library that should be done by the final application which uses the
|
||||
## library.
|
||||
rule LibDepends
|
||||
{
|
||||
$(<)_depends += $(>) ;
|
||||
|
||||
if "$($(<)_SHARED)"
|
||||
{
|
||||
LinkWith $(<) : $(>) ;
|
||||
}
|
||||
|
||||
UnitTestLibDepends $(<) : $(>) ;
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# private part
|
||||
|
||||
# LibraryStatic libname : sources : options : decoratedtarget
|
||||
rule LibraryStatic
|
||||
{
|
||||
local objects = $(>) ;
|
||||
local options = $(3) ;
|
||||
local target = $(4) ;
|
||||
|
||||
# Set LOCATE for the library and its contents. The bound
|
||||
# value shows up as $(NEEDLIBS) on the Link actions.
|
||||
# For compatibility, we only do this if the library doesn't
|
||||
# already have a path.
|
||||
if ! $(target:D)
|
||||
{
|
||||
MakeLocate $(target) $(target)($(objects:BS)) : $(LOCATE.OBJECTS)/libs ;
|
||||
}
|
||||
|
||||
if $(NOARSCAN)
|
||||
{
|
||||
# If we can't scan the library to timestamp its contents,
|
||||
# we have to just make the library depend directly on the
|
||||
# on-disk object files.
|
||||
Depends $(target) : $(objects) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
# If we can scan the library, we make the library depend
|
||||
# on its members and each member depend on the on-disk
|
||||
# object file.
|
||||
Depends $(target) : $(target)($(objects:BS)) ;
|
||||
|
||||
local i ;
|
||||
for i in $(objects)
|
||||
{
|
||||
Depends $(target)($(i:BS)) : $(i) ;
|
||||
}
|
||||
}
|
||||
|
||||
# Generate install rules
|
||||
if ! [ IsElem noinstall : $(options) ]
|
||||
{
|
||||
if "$(RANLIB)"
|
||||
{
|
||||
Depends install_lib : [ DoInstall $(target) : $(libdir) : : Ranlib ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
Depends install_lib : [ DoInstall $(target) : $(libdir) ] ;
|
||||
}
|
||||
|
||||
# Add to global library list
|
||||
if [ IsElem optional : $(options) ]
|
||||
{
|
||||
INSTALLEDLIBS_OPTIONAL += $(<) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
INSTALLEDLIBS += $(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
if $(CRELIB)
|
||||
{
|
||||
CreLib $(target) : $(objects[1]) ;
|
||||
}
|
||||
|
||||
Archive $(target) : $(objects) ;
|
||||
|
||||
if $(RANLIB)
|
||||
{
|
||||
Ranlib $(target) ;
|
||||
}
|
||||
|
||||
# If we can't scan the library, we have to leave the .o's around.
|
||||
if ! ( $(NOARSCAN) || $(NOARUPDATE) || $(KEEPOBJS) )
|
||||
{
|
||||
RmTemps $(target) : $(objects) ;
|
||||
}
|
||||
}
|
||||
|
||||
# LibraryStatic libname : sources : options : decoratedtarget
|
||||
rule LibraryShared
|
||||
{
|
||||
local objects = $(>) ;
|
||||
local options = $(3) ;
|
||||
local target = $(4) ;
|
||||
local linklib = [ ConstructSharedLibraryLinkLib $(<) : $(options) ] ;
|
||||
local deplibs ;
|
||||
|
||||
local i ;
|
||||
for i in $(LIBDEPENDS)
|
||||
{
|
||||
deplibs += [ ConstructLibraryLinkTarget $(i) : $(options) ] ;
|
||||
}
|
||||
|
||||
# Generate install rules
|
||||
if ! [ IsElem noinstall : $(options) ]
|
||||
{
|
||||
if $(TARGET.OS) != WIN32
|
||||
{
|
||||
Depends install_lib : [ DoInstall $(target) : $(libdir) ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
Depends install_lib : [ DoInstall $(target) : $(bindir) ] ;
|
||||
Depends install_lib : [ DoInstall $(linklib) : $(libdir) ] ;
|
||||
}
|
||||
|
||||
# Add to global library list
|
||||
if [ IsElem optional : $(options) ]
|
||||
{
|
||||
INSTALLEDLIBS_OPTIONAL += $(<) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
INSTALLEDLIBS += $(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
Depends $(<) : $(linklib) ;
|
||||
if $(linklib) != $(target)
|
||||
{
|
||||
Depends $(linklib) : $(target) ;
|
||||
MakeLocate $(linklib) : $(LOCATE.OBJECTS)/libs ;
|
||||
SEARCH on $(linklib) = $(LOCATE.OBJECTS)/libs ;
|
||||
}
|
||||
Depends $(target) : $(objects) ;
|
||||
$(<)_CLEANEXTRA += $(target) ;
|
||||
Depends $(target) : $(deplibs) ;
|
||||
|
||||
CFlags $(<) : [ FDefines CS_$(<:U)_LIB ] ;
|
||||
LFlags $(<) : $(LINKLIBS) ;
|
||||
|
||||
SystemLinkSharedLibrary $(target) : $(objects) $(deplibs) : $(linklib) ;
|
||||
|
||||
if $(LINK.DEBUG.INFO.SEPARATE) = "yes"
|
||||
{
|
||||
local debugfile = [ SplitDebugInfo $(target) ] ;
|
||||
$(<)_CLEANEXTRA += $(debugfile) ;
|
||||
if ! [ IsElem noinstall : $(options) ]
|
||||
{
|
||||
NoCare $(debugfile) ;
|
||||
Depends install_lib : [ DoInstall $(debugfile) : $(libdir) : $(INSTALL_DATA) ] ;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
rule ConstructLibraryTarget
|
||||
{
|
||||
if ( ! [ IsElem shared : $(>) ] ) || ( $(BUILD_SHARED_LIBS) != "yes" )
|
||||
{
|
||||
return [ ConstructStaticLibraryTarget $(<) : [ Filter $(>) : shared ] ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
return [ ConstructSharedLibraryTarget $(<) : $(>) ] ;
|
||||
}
|
||||
}
|
||||
|
||||
rule ConstructLibraryLinkTarget
|
||||
{
|
||||
if ( ! [ IsElem shared : $(>) ] ) || ( $(BUILD_SHARED_LIBS) != "yes" )
|
||||
{
|
||||
return [ ConstructStaticLibraryTarget $(<) : [ Filter $(>) : shared ] ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
return [ ConstructSharedLibraryLinkLib $(<) : $(>) ] ;
|
||||
}
|
||||
}
|
||||
|
||||
actions together Ranlib
|
||||
{
|
||||
$(RANLIB) $(<)
|
||||
}
|
||||
|
||||
# Construct pseudo target libs which is used instead of the pseudo target lib
|
||||
# in Jambase
|
||||
Depends lib : libs ;
|
||||
NotFile libs ;
|
||||
Help libs : "Build all link libraries" ;
|
||||
|
||||
@@ -1,354 +1,354 @@
|
||||
#==============================================================================
|
||||
# Jam configuration and actions for MacOS/X
|
||||
# Copyright (C) 2003-2005 by Eric Sunshine <sunshine@sunshineco.com>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#==============================================================================
|
||||
SHELL ?= "/bin/sh" ;
|
||||
|
||||
MACOSX_ENVIRONMENT = "export MACOSX_DEPLOYMENT_TARGET=10.2" ;
|
||||
PLUGIN.LFLAGS += "-bundle" ;
|
||||
# We use the ugly -Wl form, which does not contain embedded whitespace (unlike
|
||||
# "-framework AppKit"), to help external projects which use the result of
|
||||
# "cs-config --libs" in conjunction with GNU libtool, since libtool likes to
|
||||
# re-arrange arguments, not realizing that "-framwork" and "AppKit" need to
|
||||
# stay together.
|
||||
LINKLIBS += "-Wl,-framework,AppKit" "-Wl,-framework,Foundation" ;
|
||||
|
||||
# Jambase in Jam 2.4 has a bug where it incorrectly defines RANLIB as "" for
|
||||
# MacOS/X, and this bogus value will override a RANLIB set via ?= in Jamconfig,
|
||||
# by a configure script, thus we must give RANLIB an appropriate value here if
|
||||
# we find that it has the bogus value. Jam 2.5 does not contain this bug.
|
||||
# Furthermore, MacOS/X Panther expects us to use the -s option with ranlib.
|
||||
if ! $(RANLIB) { RANLIB = "ranlib" ; }
|
||||
RANLIB += "-s" ;
|
||||
|
||||
# Experience seems to indicate that library scanning misbehaves on MacOS/X with
|
||||
# Jam 2.4, consequently we disable it.
|
||||
NOARSCAN = true ;
|
||||
|
||||
#------------------------------------------------------------------------------
|
||||
# Public rules.
|
||||
#------------------------------------------------------------------------------
|
||||
|
||||
# ConstructApplicationTarget target : options
|
||||
# Constructs the application target name.
|
||||
rule ConstructApplicationTarget
|
||||
{
|
||||
return $(<) ;
|
||||
}
|
||||
|
||||
# ConstructStaticLibraryTarget target : options
|
||||
# Constructs the static library target name.
|
||||
rule ConstructStaticLibraryTarget
|
||||
{
|
||||
return lib$(<)$(SUFLIB) ;
|
||||
}
|
||||
|
||||
# ConstructSharedLibraryTarget target : options
|
||||
# Constructs the shared library target name.
|
||||
rule ConstructSharedLibraryTarget
|
||||
{
|
||||
return lib$(<).$(PACKAGE_VERSION).dylib ;
|
||||
}
|
||||
|
||||
# ConstructSharedLibraryLinkLib target : options
|
||||
# Constructs the name of a shared library against which some other target
|
||||
# links.
|
||||
rule ConstructSharedLibraryLinkLib
|
||||
{
|
||||
return lib$(<).$(PACKAGE_VERSION).dylib ;
|
||||
}
|
||||
|
||||
# ConstructPluginTarget target : options
|
||||
# Constructs the plugin target name.
|
||||
rule ConstructPluginTarget
|
||||
{
|
||||
return $(<).csbundle ;
|
||||
}
|
||||
|
||||
# SystemLinkApplication target : objects : options
|
||||
# Apply appropriate rule to link the application based upon the options.
|
||||
rule SystemLinkApplication
|
||||
{
|
||||
local target = $($(<)_TARGET) ;
|
||||
Depends $(target) : $(>) ;
|
||||
if [ IsElem console : $(3) ]
|
||||
{
|
||||
LinkApplicationConsole $(target) : $(>) ;
|
||||
Clean clean : $(target) ;
|
||||
Clean $(<)clean : $(target) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
CreateApplicationWrapper $(target) : $(>) ;
|
||||
CleanDir clean : [ Wrapper $(<) : app ] ;
|
||||
CleanDir $(<)clean : [ Wrapper $(<) : app ] ;
|
||||
}
|
||||
}
|
||||
|
||||
# SystemInstallApplication target : subdirs : options
|
||||
# Apply appropriate rule to install the application based upon the options.
|
||||
rule SystemInstallApplication
|
||||
{
|
||||
if [ IsElem console : $(3) ]
|
||||
{
|
||||
Depends install_bin :
|
||||
[ DoInstall $(<) : $(bindir) $(2) : $(INSTALL_PROGRAM) ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
InstallApplicationGUI $(<) : $(bindir) $(2) ;
|
||||
}
|
||||
}
|
||||
|
||||
# SystemInstallPlugin target : subdirs : options
|
||||
# Apply appropriate rule to install the plugin based upon the options.
|
||||
rule SystemInstallPlugin
|
||||
{
|
||||
Depends install_plugin :
|
||||
[ DoInstall $(<) : $(plugindir) $(2) : $(INSTALL_PROGRAM) ] ;
|
||||
}
|
||||
|
||||
# SystemLinkPlugin target : objects : options
|
||||
# Link a plugin module and handle meta-data appropriately.
|
||||
rule SystemLinkPlugin
|
||||
{
|
||||
local target = $($(<)_TARGET) ;
|
||||
Depends $(target) : $(>) ;
|
||||
LinkPlugin $(target) : $(>) ;
|
||||
PluginMetaData $(<) : $($(<)_METAFILE) : $(3) ;
|
||||
Clean clean : $(target) ;
|
||||
Clean $(<)clean : $(target) ;
|
||||
}
|
||||
|
||||
# LinkPlugin plugin : objects
|
||||
# Link a plugin module from a set of object files.
|
||||
actions LinkPlugin bind NEEDLIBS bind EXTRAOBJECTS
|
||||
{
|
||||
$(MACOSX_ENVIRONMENT)
|
||||
$(CMD.LINK) -bundle -o $(<) $(>) $(EXTRAOBJECTS) $(NEEDLIBS) $(LINKLIBS)
|
||||
}
|
||||
|
||||
# LinkApplicationConsole exe : objects
|
||||
# Link a console (non-GUI) appliation from a set of object files.
|
||||
actions LinkApplicationConsole bind NEEDLIBS bind EXTRAOBJECTS
|
||||
{
|
||||
$(MACOSX_ENVIRONMENT)
|
||||
$(CMD.LINK) -o $(<) $(>) $(EXTRAOBJECTS) $(NEEDLIBS) $(LINKLIBS)
|
||||
}
|
||||
|
||||
# CreateApplicationWrapper basename : objects
|
||||
# Create a complete, though minimal, application wrapper given a set of
|
||||
# object files. The rules ApplicationIconDefault and ApplicationIcon
|
||||
# control the icon associated with the application wrapper.
|
||||
rule CreateApplicationWrapper
|
||||
{
|
||||
WrapFile $(<) : $(<) : Contents MacOS : AppExe : $(>) ;
|
||||
WrapFile $(<) : PkgInfo : Contents : AppPkgInfo : $(>) ;
|
||||
WrapFile $(<) : version.plist : Contents : AppVersionPlist : $(>) ;
|
||||
WrapFile $(<) : Info.plist : Contents : AppInfoPlist : $(>) ;
|
||||
WrapFile $(<) : InfoPlist.strings : Contents Resources English.lproj :
|
||||
AppInfoPlistStrings : $(>) ;
|
||||
|
||||
local icon = [ ApplicationIcon macosx : $(<) ] ;
|
||||
if ! $(icon)
|
||||
{
|
||||
local apptype = gui ;
|
||||
if [ IsElem console : $(>) ] { apptype = console ; }
|
||||
icon = [ ApplicationIconDefault macosx : $(apptype) ] ;
|
||||
}
|
||||
if $(icon)
|
||||
{
|
||||
$(<)_APPICON = $(icon) ;
|
||||
AppIcon $(<) : $(icon) ;
|
||||
}
|
||||
}
|
||||
|
||||
# Wrapper basename : suffix [ : pathcomponents ]
|
||||
# Returns wrapper name in the directory specified by pathcomponents for
|
||||
# the given basename. If pathcomponents is omitted, LOCATE.TARGETS is
|
||||
# used.
|
||||
rule Wrapper
|
||||
{
|
||||
local dir ;
|
||||
if $(3) { dir = [ FDirName $(3) ] ; }
|
||||
else { dir = $(LOCATE.TARGETS) ; }
|
||||
return [ FDirName $(dir) $(1).$(2) ] ;
|
||||
}
|
||||
|
||||
# WrapFile basename : file : pathcomponents : rule [ : objects : [ suffix ] ]
|
||||
# Generate a file within a wrapper. pathcomponents is a list of names
|
||||
# which compose the relative path within the wrapper where file should be
|
||||
# placed. pathcomponents may be the empty list if the file should reside
|
||||
# at the top-level of the wrapper. rule is rule/action which should be
|
||||
# invoked to generate file. rule is invoked with arguments
|
||||
# <basename.suffix/pathcomponents/file>, <objects>, and <basename>.
|
||||
# objects is an optional list of files from which file should be built. It
|
||||
# may be omitted if file does not depend upon any other files. suffix is
|
||||
# the extension of the wrapper (not of file). If suffix is omitted, "app"
|
||||
# is assumed.
|
||||
#
|
||||
# Implementation note: If basename and file are the same, then we do not
|
||||
# grist file. (Obviously, we also do not want to set the file dependent
|
||||
# upon itself.) The reason we do not grist file in this case is that the
|
||||
# LinkWith, and LFlags rules associate the variables NEEDLIBS and
|
||||
# LINKLIBS with the ungristed name, therefore in order to get access to
|
||||
# these variables at AppExe action time, we must use the same (ungristed)
|
||||
# name. It is otherwise impossible to gain access to those variables.
|
||||
# This is an unfortunate hack which pollutes the otherwise general-purpose
|
||||
# WrapFile rule.
|
||||
rule WrapFile
|
||||
{
|
||||
local suffix ;
|
||||
if $(6) { suffix = $(6) ; } else { suffix = app ; }
|
||||
local target = $(2) ;
|
||||
if $(target) != $(1)
|
||||
{
|
||||
target = $(target:G=$(1)) ;
|
||||
Depends $(1) : $(target) ;
|
||||
}
|
||||
local dir = [ FDirName [ Wrapper $(1) : $(suffix) ] $(3) ] ;
|
||||
MakeLocate $(target) : $(dir) ;
|
||||
if $(5) { Depends $(target) : $(5) ; }
|
||||
BASENAME on $(target) = $(1) ;
|
||||
$(4) $(target) : $(5) : $(1) ;
|
||||
|
||||
Clean clean : [ FDirName $(dir) $(target) ] ;
|
||||
Clean $(1)clean : [ FDirName $(dir) $(target) ] ;
|
||||
}
|
||||
|
||||
# LinkApplication exe : objects
|
||||
actions AppExe bind NEEDLIBS bind EXTRAOBJECTS
|
||||
{
|
||||
$(MACOSX_ENVIRONMENT)
|
||||
$(CMD.LINK) -o $(<) $(>) $(EXTRAOBJECTS) $(NEEDLIBS) $(LINKLIBS)
|
||||
}
|
||||
|
||||
# AppPkgInfo file
|
||||
actions AppPkgInfo
|
||||
{
|
||||
echo 'APPL????' > $(<) ;
|
||||
}
|
||||
|
||||
# AppInfoPlistStrings file
|
||||
actions AppInfoPlistStrings
|
||||
{
|
||||
cat << EOT > $(<)
|
||||
CFBundleName = "$(BASENAME)";
|
||||
CFBundleShortVersionString = "$(PACKAGE_VERSION)";
|
||||
CFBundleGetInfoString = "$(BASENAME), $(PACKAGE_VERSION)";
|
||||
EOT
|
||||
}
|
||||
|
||||
# AppVersionPlist file
|
||||
actions AppVersionPlist
|
||||
{
|
||||
cat << EOT > $(<)
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!DOCTYPE plist SYSTEM "file://localhost/System/Library/DTDs/PropertyList.dtd">
|
||||
<plist version="0.9">
|
||||
<dict>
|
||||
<key>CFBundleShortVersionString</key>
|
||||
<string>$(PACKAGE_VERSION)</string>
|
||||
<key>CFBundleVersion</key>
|
||||
<string>$(PACKAGE_VERSION)</string>
|
||||
<key>ProjectName</key>
|
||||
<string>$(BASENAME)</string>
|
||||
</dict>
|
||||
</plist>
|
||||
EOT
|
||||
}
|
||||
|
||||
# AppInfoPlist filename : placeholder : basename
|
||||
# Implementation Note: $(BASENAME)_APPICON might be empty in the actions of
|
||||
# this rule, if the client did not specify a default icon or a
|
||||
# target-specific icon, in which case we need to omit both the
|
||||
# CFBundleIconFile key and value. To accomplish this, the key and value
|
||||
# are placed on a single line with no intervening whitespace. When Jam
|
||||
# interpolates a variable, if the variable is empty, it removes all
|
||||
# adjacent text (the key and value, in this case) which is just what we
|
||||
# desire.
|
||||
actions AppInfoPlist
|
||||
{
|
||||
cat << EOT > $(<)
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!DOCTYPE plist SYSTEM "file://localhost/System/Library/DTDs/PropertyList.dtd">
|
||||
<plist version="0.9">
|
||||
<dict>
|
||||
<key>CFBundleDevelopmentRegion</key>
|
||||
<string>English</string>
|
||||
<key>CFBundleName</key>
|
||||
<string>$(BASENAME)</string>
|
||||
<key>CFBundleExecutable</key>
|
||||
<string>$(BASENAME)</string>
|
||||
<key>CFBundleIconFile</key><string>$($(BASENAME)_APPICON)</string>
|
||||
<key>CFBundleInfoDictionaryVersion</key>
|
||||
<string>6.0</string>
|
||||
<key>CFBundlePackageType</key>
|
||||
<string>APPL</string>
|
||||
<key>CFBundleSignature</key>
|
||||
<string>????</string>
|
||||
<key>CFBundleVersion</key>
|
||||
<string>0</string>
|
||||
<key>CFBundleShortVersionString</key>
|
||||
<string>$(PACKAGE_VERSION)</string>
|
||||
<key>NSPrincipalClass</key>
|
||||
<string>NSApplication</string>
|
||||
</dict>
|
||||
</plist>
|
||||
EOT
|
||||
}
|
||||
|
||||
# AppIcon <basename> : <icon>
|
||||
# Copy an icon into the wrapper. It is assumed that some other agent has
|
||||
# already set SEARCH on the icon, if necessary.
|
||||
rule AppIcon
|
||||
{
|
||||
local icon = $(>:G=$(<)) ;
|
||||
Depends $(<) : $(icon) ;
|
||||
Depends $(icon) : $(>) ;
|
||||
MakeLocate $(icon) :
|
||||
[ FDirName [ Wrapper $(<) : app ] Contents Resources ] ;
|
||||
Copy $(icon) : $(>) ;
|
||||
Clean clean : $(icon) ;
|
||||
Clean $(<)clean : $(icon) ;
|
||||
}
|
||||
|
||||
# InstallApplicationGUI app : installdirs
|
||||
# Install a GUI application. Unlike applications on other platforms which
|
||||
# exist as a single executable file, on MacOS/X, an application is wrapped
|
||||
# in a directory hierarchy, thus a deep copy is needed (i.e. the typical
|
||||
# Install rule does not work).
|
||||
rule InstallApplicationGUI
|
||||
{
|
||||
local wrapper = $(<).app ;
|
||||
Depends $(wrapper) : $(<) ;
|
||||
SEARCH on $(wrapper) = $(LOCATE.TARGETS) ;
|
||||
|
||||
# Yuck! Internal knowledge of how DoInstall composes 'dir' and 'target'.
|
||||
local dir = [ ConcatDirs $(DESTDIR) $(2) ] ;
|
||||
local target = $(wrapper:BSR=$(dir):G=install) ;
|
||||
|
||||
InstallApplicationWrapperPrepare $(target) ;
|
||||
Depends install_bin :
|
||||
[ DoInstall $(wrapper) : $(2) : "$(DEEPCOPY)" ] ;
|
||||
}
|
||||
|
||||
actions InstallApplicationWrapperPrepare
|
||||
{
|
||||
$(DELTREE) $(<) ;
|
||||
}
|
||||
#==============================================================================
|
||||
# Jam configuration and actions for MacOS/X
|
||||
# Copyright (C) 2003-2005 by Eric Sunshine <sunshine@sunshineco.com>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#==============================================================================
|
||||
SHELL ?= "/bin/sh" ;
|
||||
|
||||
MACOSX_ENVIRONMENT = "export MACOSX_DEPLOYMENT_TARGET=10.2" ;
|
||||
PLUGIN.LFLAGS += "-bundle" ;
|
||||
# We use the ugly -Wl form, which does not contain embedded whitespace (unlike
|
||||
# "-framework AppKit"), to help external projects which use the result of
|
||||
# "cs-config --libs" in conjunction with GNU libtool, since libtool likes to
|
||||
# re-arrange arguments, not realizing that "-framwork" and "AppKit" need to
|
||||
# stay together.
|
||||
LINKLIBS += "-Wl,-framework,AppKit" "-Wl,-framework,Foundation" ;
|
||||
|
||||
# Jambase in Jam 2.4 has a bug where it incorrectly defines RANLIB as "" for
|
||||
# MacOS/X, and this bogus value will override a RANLIB set via ?= in Jamconfig,
|
||||
# by a configure script, thus we must give RANLIB an appropriate value here if
|
||||
# we find that it has the bogus value. Jam 2.5 does not contain this bug.
|
||||
# Furthermore, MacOS/X Panther expects us to use the -s option with ranlib.
|
||||
if ! $(RANLIB) { RANLIB = "ranlib" ; }
|
||||
RANLIB += "-s" ;
|
||||
|
||||
# Experience seems to indicate that library scanning misbehaves on MacOS/X with
|
||||
# Jam 2.4, consequently we disable it.
|
||||
NOARSCAN = true ;
|
||||
|
||||
#------------------------------------------------------------------------------
|
||||
# Public rules.
|
||||
#------------------------------------------------------------------------------
|
||||
|
||||
# ConstructApplicationTarget target : options
|
||||
# Constructs the application target name.
|
||||
rule ConstructApplicationTarget
|
||||
{
|
||||
return $(<) ;
|
||||
}
|
||||
|
||||
# ConstructStaticLibraryTarget target : options
|
||||
# Constructs the static library target name.
|
||||
rule ConstructStaticLibraryTarget
|
||||
{
|
||||
return lib$(<)$(SUFLIB) ;
|
||||
}
|
||||
|
||||
# ConstructSharedLibraryTarget target : options
|
||||
# Constructs the shared library target name.
|
||||
rule ConstructSharedLibraryTarget
|
||||
{
|
||||
return lib$(<).$(PACKAGE_VERSION).dylib ;
|
||||
}
|
||||
|
||||
# ConstructSharedLibraryLinkLib target : options
|
||||
# Constructs the name of a shared library against which some other target
|
||||
# links.
|
||||
rule ConstructSharedLibraryLinkLib
|
||||
{
|
||||
return lib$(<).$(PACKAGE_VERSION).dylib ;
|
||||
}
|
||||
|
||||
# ConstructPluginTarget target : options
|
||||
# Constructs the plugin target name.
|
||||
rule ConstructPluginTarget
|
||||
{
|
||||
return $(<).csbundle ;
|
||||
}
|
||||
|
||||
# SystemLinkApplication target : objects : options
|
||||
# Apply appropriate rule to link the application based upon the options.
|
||||
rule SystemLinkApplication
|
||||
{
|
||||
local target = $($(<)_TARGET) ;
|
||||
Depends $(target) : $(>) ;
|
||||
if [ IsElem console : $(3) ]
|
||||
{
|
||||
LinkApplicationConsole $(target) : $(>) ;
|
||||
Clean clean : $(target) ;
|
||||
Clean $(<)clean : $(target) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
CreateApplicationWrapper $(target) : $(>) ;
|
||||
CleanDir clean : [ Wrapper $(<) : app ] ;
|
||||
CleanDir $(<)clean : [ Wrapper $(<) : app ] ;
|
||||
}
|
||||
}
|
||||
|
||||
# SystemInstallApplication target : subdirs : options
|
||||
# Apply appropriate rule to install the application based upon the options.
|
||||
rule SystemInstallApplication
|
||||
{
|
||||
if [ IsElem console : $(3) ]
|
||||
{
|
||||
Depends install_bin :
|
||||
[ DoInstall $(<) : $(bindir) $(2) : $(INSTALL_PROGRAM) ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
InstallApplicationGUI $(<) : $(bindir) $(2) ;
|
||||
}
|
||||
}
|
||||
|
||||
# SystemInstallPlugin target : subdirs : options
|
||||
# Apply appropriate rule to install the plugin based upon the options.
|
||||
rule SystemInstallPlugin
|
||||
{
|
||||
Depends install_plugin :
|
||||
[ DoInstall $(<) : $(plugindir) $(2) : $(INSTALL_PROGRAM) ] ;
|
||||
}
|
||||
|
||||
# SystemLinkPlugin target : objects : options
|
||||
# Link a plugin module and handle meta-data appropriately.
|
||||
rule SystemLinkPlugin
|
||||
{
|
||||
local target = $($(<)_TARGET) ;
|
||||
Depends $(target) : $(>) ;
|
||||
LinkPlugin $(target) : $(>) ;
|
||||
PluginMetaData $(<) : $($(<)_METAFILE) : $(3) ;
|
||||
Clean clean : $(target) ;
|
||||
Clean $(<)clean : $(target) ;
|
||||
}
|
||||
|
||||
# LinkPlugin plugin : objects
|
||||
# Link a plugin module from a set of object files.
|
||||
actions LinkPlugin bind NEEDLIBS bind EXTRAOBJECTS
|
||||
{
|
||||
$(MACOSX_ENVIRONMENT)
|
||||
$(CMD.LINK) -bundle -o $(<) $(>) $(EXTRAOBJECTS) $(NEEDLIBS) $(LINKLIBS)
|
||||
}
|
||||
|
||||
# LinkApplicationConsole exe : objects
|
||||
# Link a console (non-GUI) appliation from a set of object files.
|
||||
actions LinkApplicationConsole bind NEEDLIBS bind EXTRAOBJECTS
|
||||
{
|
||||
$(MACOSX_ENVIRONMENT)
|
||||
$(CMD.LINK) -o $(<) $(>) $(EXTRAOBJECTS) $(NEEDLIBS) $(LINKLIBS)
|
||||
}
|
||||
|
||||
# CreateApplicationWrapper basename : objects
|
||||
# Create a complete, though minimal, application wrapper given a set of
|
||||
# object files. The rules ApplicationIconDefault and ApplicationIcon
|
||||
# control the icon associated with the application wrapper.
|
||||
rule CreateApplicationWrapper
|
||||
{
|
||||
WrapFile $(<) : $(<) : Contents MacOS : AppExe : $(>) ;
|
||||
WrapFile $(<) : PkgInfo : Contents : AppPkgInfo : $(>) ;
|
||||
WrapFile $(<) : version.plist : Contents : AppVersionPlist : $(>) ;
|
||||
WrapFile $(<) : Info.plist : Contents : AppInfoPlist : $(>) ;
|
||||
WrapFile $(<) : InfoPlist.strings : Contents Resources English.lproj :
|
||||
AppInfoPlistStrings : $(>) ;
|
||||
|
||||
local icon = [ ApplicationIcon macosx : $(<) ] ;
|
||||
if ! $(icon)
|
||||
{
|
||||
local apptype = gui ;
|
||||
if [ IsElem console : $(>) ] { apptype = console ; }
|
||||
icon = [ ApplicationIconDefault macosx : $(apptype) ] ;
|
||||
}
|
||||
if $(icon)
|
||||
{
|
||||
$(<)_APPICON = $(icon) ;
|
||||
AppIcon $(<) : $(icon) ;
|
||||
}
|
||||
}
|
||||
|
||||
# Wrapper basename : suffix [ : pathcomponents ]
|
||||
# Returns wrapper name in the directory specified by pathcomponents for
|
||||
# the given basename. If pathcomponents is omitted, LOCATE.TARGETS is
|
||||
# used.
|
||||
rule Wrapper
|
||||
{
|
||||
local dir ;
|
||||
if $(3) { dir = [ FDirName $(3) ] ; }
|
||||
else { dir = $(LOCATE.TARGETS) ; }
|
||||
return [ FDirName $(dir) $(1).$(2) ] ;
|
||||
}
|
||||
|
||||
# WrapFile basename : file : pathcomponents : rule [ : objects : [ suffix ] ]
|
||||
# Generate a file within a wrapper. pathcomponents is a list of names
|
||||
# which compose the relative path within the wrapper where file should be
|
||||
# placed. pathcomponents may be the empty list if the file should reside
|
||||
# at the top-level of the wrapper. rule is rule/action which should be
|
||||
# invoked to generate file. rule is invoked with arguments
|
||||
# <basename.suffix/pathcomponents/file>, <objects>, and <basename>.
|
||||
# objects is an optional list of files from which file should be built. It
|
||||
# may be omitted if file does not depend upon any other files. suffix is
|
||||
# the extension of the wrapper (not of file). If suffix is omitted, "app"
|
||||
# is assumed.
|
||||
#
|
||||
# Implementation note: If basename and file are the same, then we do not
|
||||
# grist file. (Obviously, we also do not want to set the file dependent
|
||||
# upon itself.) The reason we do not grist file in this case is that the
|
||||
# LinkWith, and LFlags rules associate the variables NEEDLIBS and
|
||||
# LINKLIBS with the ungristed name, therefore in order to get access to
|
||||
# these variables at AppExe action time, we must use the same (ungristed)
|
||||
# name. It is otherwise impossible to gain access to those variables.
|
||||
# This is an unfortunate hack which pollutes the otherwise general-purpose
|
||||
# WrapFile rule.
|
||||
rule WrapFile
|
||||
{
|
||||
local suffix ;
|
||||
if $(6) { suffix = $(6) ; } else { suffix = app ; }
|
||||
local target = $(2) ;
|
||||
if $(target) != $(1)
|
||||
{
|
||||
target = $(target:G=$(1)) ;
|
||||
Depends $(1) : $(target) ;
|
||||
}
|
||||
local dir = [ FDirName [ Wrapper $(1) : $(suffix) ] $(3) ] ;
|
||||
MakeLocate $(target) : $(dir) ;
|
||||
if $(5) { Depends $(target) : $(5) ; }
|
||||
BASENAME on $(target) = $(1) ;
|
||||
$(4) $(target) : $(5) : $(1) ;
|
||||
|
||||
Clean clean : [ FDirName $(dir) $(target) ] ;
|
||||
Clean $(1)clean : [ FDirName $(dir) $(target) ] ;
|
||||
}
|
||||
|
||||
# LinkApplication exe : objects
|
||||
actions AppExe bind NEEDLIBS bind EXTRAOBJECTS
|
||||
{
|
||||
$(MACOSX_ENVIRONMENT)
|
||||
$(CMD.LINK) -o $(<) $(>) $(EXTRAOBJECTS) $(NEEDLIBS) $(LINKLIBS)
|
||||
}
|
||||
|
||||
# AppPkgInfo file
|
||||
actions AppPkgInfo
|
||||
{
|
||||
echo 'APPL????' > $(<) ;
|
||||
}
|
||||
|
||||
# AppInfoPlistStrings file
|
||||
actions AppInfoPlistStrings
|
||||
{
|
||||
cat << EOT > $(<)
|
||||
CFBundleName = "$(BASENAME)";
|
||||
CFBundleShortVersionString = "$(PACKAGE_VERSION)";
|
||||
CFBundleGetInfoString = "$(BASENAME), $(PACKAGE_VERSION)";
|
||||
EOT
|
||||
}
|
||||
|
||||
# AppVersionPlist file
|
||||
actions AppVersionPlist
|
||||
{
|
||||
cat << EOT > $(<)
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!DOCTYPE plist SYSTEM "file://localhost/System/Library/DTDs/PropertyList.dtd">
|
||||
<plist version="0.9">
|
||||
<dict>
|
||||
<key>CFBundleShortVersionString</key>
|
||||
<string>$(PACKAGE_VERSION)</string>
|
||||
<key>CFBundleVersion</key>
|
||||
<string>$(PACKAGE_VERSION)</string>
|
||||
<key>ProjectName</key>
|
||||
<string>$(BASENAME)</string>
|
||||
</dict>
|
||||
</plist>
|
||||
EOT
|
||||
}
|
||||
|
||||
# AppInfoPlist filename : placeholder : basename
|
||||
# Implementation Note: $(BASENAME)_APPICON might be empty in the actions of
|
||||
# this rule, if the client did not specify a default icon or a
|
||||
# target-specific icon, in which case we need to omit both the
|
||||
# CFBundleIconFile key and value. To accomplish this, the key and value
|
||||
# are placed on a single line with no intervening whitespace. When Jam
|
||||
# interpolates a variable, if the variable is empty, it removes all
|
||||
# adjacent text (the key and value, in this case) which is just what we
|
||||
# desire.
|
||||
actions AppInfoPlist
|
||||
{
|
||||
cat << EOT > $(<)
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!DOCTYPE plist SYSTEM "file://localhost/System/Library/DTDs/PropertyList.dtd">
|
||||
<plist version="0.9">
|
||||
<dict>
|
||||
<key>CFBundleDevelopmentRegion</key>
|
||||
<string>English</string>
|
||||
<key>CFBundleName</key>
|
||||
<string>$(BASENAME)</string>
|
||||
<key>CFBundleExecutable</key>
|
||||
<string>$(BASENAME)</string>
|
||||
<key>CFBundleIconFile</key><string>$($(BASENAME)_APPICON)</string>
|
||||
<key>CFBundleInfoDictionaryVersion</key>
|
||||
<string>6.0</string>
|
||||
<key>CFBundlePackageType</key>
|
||||
<string>APPL</string>
|
||||
<key>CFBundleSignature</key>
|
||||
<string>????</string>
|
||||
<key>CFBundleVersion</key>
|
||||
<string>0</string>
|
||||
<key>CFBundleShortVersionString</key>
|
||||
<string>$(PACKAGE_VERSION)</string>
|
||||
<key>NSPrincipalClass</key>
|
||||
<string>NSApplication</string>
|
||||
</dict>
|
||||
</plist>
|
||||
EOT
|
||||
}
|
||||
|
||||
# AppIcon <basename> : <icon>
|
||||
# Copy an icon into the wrapper. It is assumed that some other agent has
|
||||
# already set SEARCH on the icon, if necessary.
|
||||
rule AppIcon
|
||||
{
|
||||
local icon = $(>:G=$(<)) ;
|
||||
Depends $(<) : $(icon) ;
|
||||
Depends $(icon) : $(>) ;
|
||||
MakeLocate $(icon) :
|
||||
[ FDirName [ Wrapper $(<) : app ] Contents Resources ] ;
|
||||
Copy $(icon) : $(>) ;
|
||||
Clean clean : $(icon) ;
|
||||
Clean $(<)clean : $(icon) ;
|
||||
}
|
||||
|
||||
# InstallApplicationGUI app : installdirs
|
||||
# Install a GUI application. Unlike applications on other platforms which
|
||||
# exist as a single executable file, on MacOS/X, an application is wrapped
|
||||
# in a directory hierarchy, thus a deep copy is needed (i.e. the typical
|
||||
# Install rule does not work).
|
||||
rule InstallApplicationGUI
|
||||
{
|
||||
local wrapper = $(<).app ;
|
||||
Depends $(wrapper) : $(<) ;
|
||||
SEARCH on $(wrapper) = $(LOCATE.TARGETS) ;
|
||||
|
||||
# Yuck! Internal knowledge of how DoInstall composes 'dir' and 'target'.
|
||||
local dir = [ ConcatDirs $(DESTDIR) $(2) ] ;
|
||||
local target = $(wrapper:BSR=$(dir):G=install) ;
|
||||
|
||||
InstallApplicationWrapperPrepare $(target) ;
|
||||
Depends install_bin :
|
||||
[ DoInstall $(wrapper) : $(2) : "$(DEEPCOPY)" ] ;
|
||||
}
|
||||
|
||||
actions InstallApplicationWrapperPrepare
|
||||
{
|
||||
$(DELTREE) $(<) ;
|
||||
}
|
||||
|
||||
3110
mk/jam/msvcgen.jam
3110
mk/jam/msvcgen.jam
File diff suppressed because it is too large
Load Diff
@@ -1,80 +1,80 @@
|
||||
#============================================================================
|
||||
# Rules for compiling Objective-C and Objective-C++ files
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
if $(CMD.OBJC)
|
||||
{
|
||||
|
||||
rule ObjCRule
|
||||
{
|
||||
local object = [ DoObjectGrist [ PrefixSuffix $(>)_ : $(<) : $(SUFOBJ) ] ] ;
|
||||
ObjC $(object) : $(<) ;
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType ObjCRule : .m ;
|
||||
RegisterHeaderRule HeaderRule : $(HDRPATTERN) : .m ;
|
||||
|
||||
rule ObjC
|
||||
{
|
||||
Depends $(<) : $(>) ;
|
||||
|
||||
CCFLAGS on $(<) += $(CCFLAGS) $(SUBDIRCCFLAGS) ;
|
||||
OBJCFLAGS on $(<) += $(OBJCFLAGS) ;
|
||||
CCHDRS on $(<) = [ on $(<) FIncludes $(HDRS) ] ;
|
||||
CCDEFS on $(<) = [ on $(<) FDefines $(DEFINES) ] ;
|
||||
}
|
||||
|
||||
actions ObjC
|
||||
{
|
||||
$(CMD.OBJC) -c -o $(<) $(CCHDRS) $(CCFLAGS) $(OBJCFLAGS) $(CCDEFS) $(>)
|
||||
}
|
||||
}
|
||||
|
||||
if $(CMD.OBJC++)
|
||||
{
|
||||
rule ObjC++Rule
|
||||
{
|
||||
local object = [ DoObjectGrist [ PrefixSuffix $(>)_ : $(<) : $(SUFOBJ) ] ] ;
|
||||
ObjC++ $(object) : $(<) ;
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType ObjC++Rule : .mm .M ;
|
||||
RegisterHeaderRule HeaderRule : $(HDRPATTERN) : .mm .M ;
|
||||
|
||||
rule ObjC++
|
||||
{
|
||||
Depends $(<) : $(>) ;
|
||||
|
||||
# Ugly hack: Apple's gcc4 does not accept -fvisibility-inlines-hidden in
|
||||
# Objective-C++ mode. Ideally, this issue should be resolved by the
|
||||
# configure script, but it does not currently distinguish between flags
|
||||
# intended for the C++ compiler and those intended for the Objective-C++
|
||||
# compiler.
|
||||
local rejects = -fvisibility-inlines-hidden ;
|
||||
C++FLAGS on $(<) += [ Filter $(C++FLAGS) $(SUBDIRC++FLAGS) : $(rejects) ] ;
|
||||
OBJC++FLAGS on $(<) += [ Filter $(OBJC++FLAGS) : $(rejects) ] ;
|
||||
CCHDRS on $(<) = [ on $(<) FIncludes $(HDRS) ] ;
|
||||
CCDEFS on $(<) = [ on $(<) FDefines $(DEFINES) ] ;
|
||||
}
|
||||
|
||||
actions ObjC++
|
||||
{
|
||||
$(CMD.OBJC++) -c -o $(<) $(CCHDRS) $(C++FLAGS) $(OBJC++FLAGS) $(CCDEFS) $(>)
|
||||
}
|
||||
}
|
||||
#============================================================================
|
||||
# Rules for compiling Objective-C and Objective-C++ files
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
if $(CMD.OBJC)
|
||||
{
|
||||
|
||||
rule ObjCRule
|
||||
{
|
||||
local object = [ DoObjectGrist [ PrefixSuffix $(>)_ : $(<) : $(SUFOBJ) ] ] ;
|
||||
ObjC $(object) : $(<) ;
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType ObjCRule : .m ;
|
||||
RegisterHeaderRule HeaderRule : $(HDRPATTERN) : .m ;
|
||||
|
||||
rule ObjC
|
||||
{
|
||||
Depends $(<) : $(>) ;
|
||||
|
||||
CCFLAGS on $(<) += $(CCFLAGS) $(SUBDIRCCFLAGS) ;
|
||||
OBJCFLAGS on $(<) += $(OBJCFLAGS) ;
|
||||
CCHDRS on $(<) = [ on $(<) FIncludes $(HDRS) ] ;
|
||||
CCDEFS on $(<) = [ on $(<) FDefines $(DEFINES) ] ;
|
||||
}
|
||||
|
||||
actions ObjC
|
||||
{
|
||||
$(CMD.OBJC) -c -o $(<) $(CCHDRS) $(CCFLAGS) $(OBJCFLAGS) $(CCDEFS) $(>)
|
||||
}
|
||||
}
|
||||
|
||||
if $(CMD.OBJC++)
|
||||
{
|
||||
rule ObjC++Rule
|
||||
{
|
||||
local object = [ DoObjectGrist [ PrefixSuffix $(>)_ : $(<) : $(SUFOBJ) ] ] ;
|
||||
ObjC++ $(object) : $(<) ;
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType ObjC++Rule : .mm .M ;
|
||||
RegisterHeaderRule HeaderRule : $(HDRPATTERN) : .mm .M ;
|
||||
|
||||
rule ObjC++
|
||||
{
|
||||
Depends $(<) : $(>) ;
|
||||
|
||||
# Ugly hack: Apple's gcc4 does not accept -fvisibility-inlines-hidden in
|
||||
# Objective-C++ mode. Ideally, this issue should be resolved by the
|
||||
# configure script, but it does not currently distinguish between flags
|
||||
# intended for the C++ compiler and those intended for the Objective-C++
|
||||
# compiler.
|
||||
local rejects = -fvisibility-inlines-hidden ;
|
||||
C++FLAGS on $(<) += [ Filter $(C++FLAGS) $(SUBDIRC++FLAGS) : $(rejects) ] ;
|
||||
OBJC++FLAGS on $(<) += [ Filter $(OBJC++FLAGS) : $(rejects) ] ;
|
||||
CCHDRS on $(<) = [ on $(<) FIncludes $(HDRS) ] ;
|
||||
CCDEFS on $(<) = [ on $(<) FDefines $(DEFINES) ] ;
|
||||
}
|
||||
|
||||
actions ObjC++
|
||||
{
|
||||
$(CMD.OBJC++) -c -o $(<) $(CCHDRS) $(C++FLAGS) $(OBJC++FLAGS) $(CCDEFS) $(>)
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,250 +1,250 @@
|
||||
#============================================================================
|
||||
# Rules for compiling a set of sources to object files
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
# These are slightly modified versions of the Object and Objects rules from
|
||||
# jam. The problem with the original rules in Jambase is the handling of
|
||||
# custom file types. The solution with the UserObject rule is monolithic, you
|
||||
# can only have 1 such rule. Thus we construct a more flexible toolkit here
|
||||
# which let's you register rules for certain filetypes.
|
||||
|
||||
## RegisterFileType Rulename : extensions
|
||||
## Register a rule which is used to compile a filetype into object
|
||||
## files. The registered rule is called with the name of the
|
||||
## sourcefile as argument and should return a list of objectfiles which are
|
||||
## created. You should set the grist of the object files by using the
|
||||
## DoObjectGrist function.
|
||||
rule RegisterFileType
|
||||
{
|
||||
local suffix ;
|
||||
for suffix in $(>)
|
||||
{
|
||||
FILETYPE_$(suffix) = $(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
## RegisterHeaderRule rulename : regexpattern : extensions
|
||||
## Registers a rule and a regular expression which will be used for header
|
||||
## file scanning of the specified extensions.
|
||||
rule RegisterHeaderRule
|
||||
{
|
||||
local suffix ;
|
||||
for suffix in $(3)
|
||||
{
|
||||
HDRRULE_$(suffix) = $(<) ;
|
||||
HDRPATTERN_$(suffix) = $(>) ;
|
||||
}
|
||||
}
|
||||
|
||||
## CompileObjects sources [: objectfileprefix]
|
||||
## Compile a set of sourcefiles into objectfiles (extension: SUFOBJ,
|
||||
## usually .o). This rule takes care of setting the SEARCH and LOCATE
|
||||
## variables to the values of $(SEARCH_SOURCE) and $(LOCATE_TARGET).
|
||||
## The Application, Plugin and Library rules already use this rule
|
||||
## internally. You should only use this rule if you have to avoid the
|
||||
## Application, Plugin or Library rules.
|
||||
rule CompileObjects
|
||||
{
|
||||
local source ;
|
||||
local targets ;
|
||||
|
||||
# Search the source
|
||||
SEARCH on $(<) = $(SEARCH_SOURCE) ;
|
||||
|
||||
for source in $(<)
|
||||
{
|
||||
# compile the sourcefile to targetfile
|
||||
targets += [ CompileObject $(source) : $(>) ] ;
|
||||
}
|
||||
|
||||
# locate the targets
|
||||
MakeLocate $(targets) : $(LOCATE_TARGET) ;
|
||||
|
||||
return $(targets) ;
|
||||
}
|
||||
|
||||
## PrefixSuffix [prefix] : filename : suffix
|
||||
## Replaces the suffix of 'filename' with 'suffix' and prepends 'prefix' to
|
||||
## it.
|
||||
rule PrefixSuffix
|
||||
{
|
||||
local prefix = $(1) ;
|
||||
local name = $(2) ;
|
||||
local suffix = $(3) ;
|
||||
if ! $(prefix) { prefix = "" ; }
|
||||
return $(name:B=$(prefix)$(name:B):S=$(suffix)) ;
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# private part
|
||||
|
||||
# helper rule: Compiles a source file to an object file. Does header file
|
||||
# scanning, sets LOCATE and SEARCH for source and target, grists the files
|
||||
# with the current subdir and searches for the correct registered rule.
|
||||
rule CompileObject
|
||||
{
|
||||
# handle #includes for source: Jam scans for headers with
|
||||
# the regexp pattern $(HDRSCAN) and then invokes $(HDRRULE)
|
||||
# with the scanned file as the target and the found headers
|
||||
# as the sources. HDRSEARCH is the value of SEARCH used for
|
||||
# the found header files. Finally, if jam must deal with
|
||||
# header files of the same name in different directories,
|
||||
# they can be distinguished with HDRGRIST.
|
||||
|
||||
# $(SEARCH_SOURCE:E) is where cc first looks for #include
|
||||
# "foo.h" files. If the source file is in a distant directory,
|
||||
# look there. Else, look in "" (the current directory).
|
||||
if $(HDRRULE_$(<:S))
|
||||
{
|
||||
HDRSEARCH on $(<) =
|
||||
$(SEARCH_SOURCE:E) $(SUBDIRHDRS) $(HDRS) $(STDHDRS) ;
|
||||
HDRGRIST on $(<) = $(HDRGRIST) ;
|
||||
HDRRULE on $(<) = $(HDRRULE_$(<:S)) ;
|
||||
HDRSCAN on $(<) = $(HDRPATTERN_$(<:S)) ;
|
||||
}
|
||||
|
||||
local targets ;
|
||||
# Invoke filetype specific rule
|
||||
if $(FILETYPE_$(<:S))
|
||||
{
|
||||
targets = [ $(FILETYPE_$(<:S)) $(<) : $(>) ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
echo Warning: no rules for file type $(<:S) defined (at file $(<)). ;
|
||||
}
|
||||
|
||||
if $(targets)
|
||||
{
|
||||
# construct clean target
|
||||
Clean clean : $(targets) ;
|
||||
|
||||
# Save HDRS for -I$(HDRS) on compile.
|
||||
# We shouldn't need -I$(SEARCH_SOURCE) as cc can find headers
|
||||
# in the .c file's directory, but generated .c files (from
|
||||
# yacc, lex, etc) are located in $(LOCATE_TARGET), possibly
|
||||
# different from $(SEARCH_SOURCE).
|
||||
HDRS on $(<) = $(SEARCH_SOURCE) $(SUBDIRHDRS) $(HDRS) ;
|
||||
|
||||
# propagate target specific-defines
|
||||
DEFINES on $(<) += $(DEFINES) ;
|
||||
}
|
||||
|
||||
return $(targets) ;
|
||||
}
|
||||
|
||||
## HeaderRule source : headers
|
||||
## This rule is the default header rule used by the objects rules. You
|
||||
## might register custom rules with the RegisterHeaderRule rule.
|
||||
rule HeaderRule
|
||||
{
|
||||
# N.B. This rule is called during binding, potentially after
|
||||
# the fate of many targets has been determined, and must be
|
||||
# used with caution: don't add dependencies to unrelated
|
||||
# targets, and don't set variables on $(<).
|
||||
|
||||
# Tell Jam that anything depending on $(<) also depends on $(>),
|
||||
# set SEARCH so Jam can find the headers, but then say we don't
|
||||
# care if we can't actually find the headers (they may have been
|
||||
# within ifdefs),
|
||||
local s = $(>:G=$(HDRGRIST:E)) ;
|
||||
|
||||
Includes $(<) : $(s) ;
|
||||
SEARCH on $(s) = $(HDRSEARCH) ;
|
||||
NoCare $(s) ;
|
||||
|
||||
local i ;
|
||||
for i in $(s)
|
||||
{
|
||||
HDRGRIST on $(i) = $(HDRGRIST) ;
|
||||
HDRSEARCH on $(i) = $(HDRSEARCH) ;
|
||||
HDRRULE on $(i) = [ on $(<) GetVar HDRRULE ] ;
|
||||
HDRSCAN on $(i) = [ on $(<) GetVar HDRPATTERN ] ;
|
||||
}
|
||||
}
|
||||
|
||||
if $(JAMVERSION) < 2.5
|
||||
{
|
||||
## XXX XXX XXX a bug in jam 2.4 let's the version above fail. I'll let this
|
||||
## non-optimal version in here until jam 2.5 is out.
|
||||
|
||||
rule HeaderRule
|
||||
{
|
||||
local s = $(>:G=$(HDRGRIST:E)) ;
|
||||
|
||||
Includes $(<) : $(s) ;
|
||||
SEARCH on $(s) = $(HDRSEARCH) ;
|
||||
NoCare $(s) ;
|
||||
|
||||
local i ;
|
||||
for i in $(s)
|
||||
{
|
||||
if $(HDRRULE_$(i:S))
|
||||
{
|
||||
HDRGRIST on $(i) = $(HDRGRIST) ;
|
||||
HDRSEARCH on $(i) = $(HDRSEARCH) ;
|
||||
HDRRULE on $(i) = $(HDRRULE_$(i:S)) ;
|
||||
HDRSCAN on $(i) = $(HDRPATTERN_$(i:S)) ;
|
||||
}
|
||||
else if $(JAM_DEBUG)
|
||||
{
|
||||
#echo "No Header rule for $(i:S) file $(i) " ;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
} # end of if $(JAMVERSION) < 1.5
|
||||
|
||||
# Dummy rule: .o files are used as is.
|
||||
rule UseObjectFile
|
||||
{
|
||||
return $(<) ;
|
||||
}
|
||||
RegisterFileType UseObjectFile : .o ;
|
||||
|
||||
# Ignore header files.
|
||||
rule UseHeaderFile
|
||||
{
|
||||
return ;
|
||||
}
|
||||
RegisterFileType UseHeaderFile : .h .hpp ;
|
||||
RegisterHeaderRule HeaderRule : $(HDRPATTERN) : .h .hpp .inc ;
|
||||
|
||||
# Generates a grist suitable for output objects based on
|
||||
# SUBVARIANT and SUBDIR variable.
|
||||
rule DoObjectGrist
|
||||
{
|
||||
return $(<:G=$(SOURCE_GRIST:E)!$(SUBVARIANT:J=!)) ;
|
||||
}
|
||||
|
||||
# Generates a grist suitable for source files based on SUBDIR variable.
|
||||
# Doesn't change an existing grist.
|
||||
rule DoSourceGrist
|
||||
{
|
||||
local gristed ;
|
||||
for g in $(<)
|
||||
{
|
||||
local grist ;
|
||||
if $(g:G)
|
||||
{
|
||||
grist = $(g:G) ;
|
||||
}
|
||||
gristed += $(g:G=$(grist:E=$(SOURCE_GRIST:E))) ;
|
||||
}
|
||||
return $(gristed) ;
|
||||
}
|
||||
#============================================================================
|
||||
# Rules for compiling a set of sources to object files
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
# These are slightly modified versions of the Object and Objects rules from
|
||||
# jam. The problem with the original rules in Jambase is the handling of
|
||||
# custom file types. The solution with the UserObject rule is monolithic, you
|
||||
# can only have 1 such rule. Thus we construct a more flexible toolkit here
|
||||
# which let's you register rules for certain filetypes.
|
||||
|
||||
## RegisterFileType Rulename : extensions
|
||||
## Register a rule which is used to compile a filetype into object
|
||||
## files. The registered rule is called with the name of the
|
||||
## sourcefile as argument and should return a list of objectfiles which are
|
||||
## created. You should set the grist of the object files by using the
|
||||
## DoObjectGrist function.
|
||||
rule RegisterFileType
|
||||
{
|
||||
local suffix ;
|
||||
for suffix in $(>)
|
||||
{
|
||||
FILETYPE_$(suffix) = $(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
## RegisterHeaderRule rulename : regexpattern : extensions
|
||||
## Registers a rule and a regular expression which will be used for header
|
||||
## file scanning of the specified extensions.
|
||||
rule RegisterHeaderRule
|
||||
{
|
||||
local suffix ;
|
||||
for suffix in $(3)
|
||||
{
|
||||
HDRRULE_$(suffix) = $(<) ;
|
||||
HDRPATTERN_$(suffix) = $(>) ;
|
||||
}
|
||||
}
|
||||
|
||||
## CompileObjects sources [: objectfileprefix]
|
||||
## Compile a set of sourcefiles into objectfiles (extension: SUFOBJ,
|
||||
## usually .o). This rule takes care of setting the SEARCH and LOCATE
|
||||
## variables to the values of $(SEARCH_SOURCE) and $(LOCATE_TARGET).
|
||||
## The Application, Plugin and Library rules already use this rule
|
||||
## internally. You should only use this rule if you have to avoid the
|
||||
## Application, Plugin or Library rules.
|
||||
rule CompileObjects
|
||||
{
|
||||
local source ;
|
||||
local targets ;
|
||||
|
||||
# Search the source
|
||||
SEARCH on $(<) = $(SEARCH_SOURCE) ;
|
||||
|
||||
for source in $(<)
|
||||
{
|
||||
# compile the sourcefile to targetfile
|
||||
targets += [ CompileObject $(source) : $(>) ] ;
|
||||
}
|
||||
|
||||
# locate the targets
|
||||
MakeLocate $(targets) : $(LOCATE_TARGET) ;
|
||||
|
||||
return $(targets) ;
|
||||
}
|
||||
|
||||
## PrefixSuffix [prefix] : filename : suffix
|
||||
## Replaces the suffix of 'filename' with 'suffix' and prepends 'prefix' to
|
||||
## it.
|
||||
rule PrefixSuffix
|
||||
{
|
||||
local prefix = $(1) ;
|
||||
local name = $(2) ;
|
||||
local suffix = $(3) ;
|
||||
if ! $(prefix) { prefix = "" ; }
|
||||
return $(name:B=$(prefix)$(name:B):S=$(suffix)) ;
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# private part
|
||||
|
||||
# helper rule: Compiles a source file to an object file. Does header file
|
||||
# scanning, sets LOCATE and SEARCH for source and target, grists the files
|
||||
# with the current subdir and searches for the correct registered rule.
|
||||
rule CompileObject
|
||||
{
|
||||
# handle #includes for source: Jam scans for headers with
|
||||
# the regexp pattern $(HDRSCAN) and then invokes $(HDRRULE)
|
||||
# with the scanned file as the target and the found headers
|
||||
# as the sources. HDRSEARCH is the value of SEARCH used for
|
||||
# the found header files. Finally, if jam must deal with
|
||||
# header files of the same name in different directories,
|
||||
# they can be distinguished with HDRGRIST.
|
||||
|
||||
# $(SEARCH_SOURCE:E) is where cc first looks for #include
|
||||
# "foo.h" files. If the source file is in a distant directory,
|
||||
# look there. Else, look in "" (the current directory).
|
||||
if $(HDRRULE_$(<:S))
|
||||
{
|
||||
HDRSEARCH on $(<) =
|
||||
$(SEARCH_SOURCE:E) $(SUBDIRHDRS) $(HDRS) $(STDHDRS) ;
|
||||
HDRGRIST on $(<) = $(HDRGRIST) ;
|
||||
HDRRULE on $(<) = $(HDRRULE_$(<:S)) ;
|
||||
HDRSCAN on $(<) = $(HDRPATTERN_$(<:S)) ;
|
||||
}
|
||||
|
||||
local targets ;
|
||||
# Invoke filetype specific rule
|
||||
if $(FILETYPE_$(<:S))
|
||||
{
|
||||
targets = [ $(FILETYPE_$(<:S)) $(<) : $(>) ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
echo Warning: no rules for file type $(<:S) defined (at file $(<)). ;
|
||||
}
|
||||
|
||||
if $(targets)
|
||||
{
|
||||
# construct clean target
|
||||
Clean clean : $(targets) ;
|
||||
|
||||
# Save HDRS for -I$(HDRS) on compile.
|
||||
# We shouldn't need -I$(SEARCH_SOURCE) as cc can find headers
|
||||
# in the .c file's directory, but generated .c files (from
|
||||
# yacc, lex, etc) are located in $(LOCATE_TARGET), possibly
|
||||
# different from $(SEARCH_SOURCE).
|
||||
HDRS on $(<) = $(SEARCH_SOURCE) $(SUBDIRHDRS) $(HDRS) ;
|
||||
|
||||
# propagate target specific-defines
|
||||
DEFINES on $(<) += $(DEFINES) ;
|
||||
}
|
||||
|
||||
return $(targets) ;
|
||||
}
|
||||
|
||||
## HeaderRule source : headers
|
||||
## This rule is the default header rule used by the objects rules. You
|
||||
## might register custom rules with the RegisterHeaderRule rule.
|
||||
rule HeaderRule
|
||||
{
|
||||
# N.B. This rule is called during binding, potentially after
|
||||
# the fate of many targets has been determined, and must be
|
||||
# used with caution: don't add dependencies to unrelated
|
||||
# targets, and don't set variables on $(<).
|
||||
|
||||
# Tell Jam that anything depending on $(<) also depends on $(>),
|
||||
# set SEARCH so Jam can find the headers, but then say we don't
|
||||
# care if we can't actually find the headers (they may have been
|
||||
# within ifdefs),
|
||||
local s = $(>:G=$(HDRGRIST:E)) ;
|
||||
|
||||
Includes $(<) : $(s) ;
|
||||
SEARCH on $(s) = $(HDRSEARCH) ;
|
||||
NoCare $(s) ;
|
||||
|
||||
local i ;
|
||||
for i in $(s)
|
||||
{
|
||||
HDRGRIST on $(i) = $(HDRGRIST) ;
|
||||
HDRSEARCH on $(i) = $(HDRSEARCH) ;
|
||||
HDRRULE on $(i) = [ on $(<) GetVar HDRRULE ] ;
|
||||
HDRSCAN on $(i) = [ on $(<) GetVar HDRPATTERN ] ;
|
||||
}
|
||||
}
|
||||
|
||||
if $(JAMVERSION) < 2.5
|
||||
{
|
||||
## XXX XXX XXX a bug in jam 2.4 let's the version above fail. I'll let this
|
||||
## non-optimal version in here until jam 2.5 is out.
|
||||
|
||||
rule HeaderRule
|
||||
{
|
||||
local s = $(>:G=$(HDRGRIST:E)) ;
|
||||
|
||||
Includes $(<) : $(s) ;
|
||||
SEARCH on $(s) = $(HDRSEARCH) ;
|
||||
NoCare $(s) ;
|
||||
|
||||
local i ;
|
||||
for i in $(s)
|
||||
{
|
||||
if $(HDRRULE_$(i:S))
|
||||
{
|
||||
HDRGRIST on $(i) = $(HDRGRIST) ;
|
||||
HDRSEARCH on $(i) = $(HDRSEARCH) ;
|
||||
HDRRULE on $(i) = $(HDRRULE_$(i:S)) ;
|
||||
HDRSCAN on $(i) = $(HDRPATTERN_$(i:S)) ;
|
||||
}
|
||||
else if $(JAM_DEBUG)
|
||||
{
|
||||
#echo "No Header rule for $(i:S) file $(i) " ;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
} # end of if $(JAMVERSION) < 1.5
|
||||
|
||||
# Dummy rule: .o files are used as is.
|
||||
rule UseObjectFile
|
||||
{
|
||||
return $(<) ;
|
||||
}
|
||||
RegisterFileType UseObjectFile : .o ;
|
||||
|
||||
# Ignore header files.
|
||||
rule UseHeaderFile
|
||||
{
|
||||
return ;
|
||||
}
|
||||
RegisterFileType UseHeaderFile : .h .hpp ;
|
||||
RegisterHeaderRule HeaderRule : $(HDRPATTERN) : .h .hpp .inc ;
|
||||
|
||||
# Generates a grist suitable for output objects based on
|
||||
# SUBVARIANT and SUBDIR variable.
|
||||
rule DoObjectGrist
|
||||
{
|
||||
return $(<:G=$(SOURCE_GRIST:E)!$(SUBVARIANT:J=!)) ;
|
||||
}
|
||||
|
||||
# Generates a grist suitable for source files based on SUBDIR variable.
|
||||
# Doesn't change an existing grist.
|
||||
rule DoSourceGrist
|
||||
{
|
||||
local gristed ;
|
||||
for g in $(<)
|
||||
{
|
||||
local grist ;
|
||||
if $(g:G)
|
||||
{
|
||||
grist = $(g:G) ;
|
||||
}
|
||||
gristed += $(g:G=$(grist:E=$(SOURCE_GRIST:E))) ;
|
||||
}
|
||||
return $(gristed) ;
|
||||
}
|
||||
|
||||
@@ -1,38 +1,38 @@
|
||||
#============================================================================
|
||||
# Rule for setting options at targets
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# private rule - please specify the options in Application, Plugin or Library
|
||||
# rule and don't use this rule here directly.
|
||||
|
||||
## CheckOptions candidates : Options : target
|
||||
rule CheckOptions
|
||||
{
|
||||
local i ;
|
||||
|
||||
for i in $(>)
|
||||
{
|
||||
if ! [ IsElem $(i) : $(<) ]
|
||||
{
|
||||
echo "WARNING: Unknown option $(i) specified at $(3)." ;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#============================================================================
|
||||
# Rule for setting options at targets
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# private rule - please specify the options in Application, Plugin or Library
|
||||
# rule and don't use this rule here directly.
|
||||
|
||||
## CheckOptions candidates : Options : target
|
||||
rule CheckOptions
|
||||
{
|
||||
local i ;
|
||||
|
||||
for i in $(>)
|
||||
{
|
||||
if ! [ IsElem $(i) : $(<) ]
|
||||
{
|
||||
echo "WARNING: Unknown option $(i) specified at $(3)." ;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -1,166 +1,179 @@
|
||||
#============================================================================
|
||||
# Rules for plugin creation
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
SUFMETA ?= .csplugin ;
|
||||
GRISTMETA ?= pluginmeta ;
|
||||
|
||||
## Plugin pluginname : sources [ : options ]
|
||||
## Build a plugin out of sourcefiles. All sourcefiles will be passed
|
||||
## to the Objects rule which tries to compile them into object-files. You
|
||||
## can create rules for your own filetypes with the UserObject rule. Header
|
||||
## files will just be ignored. They are only used for MSVC projectfile
|
||||
## generator.
|
||||
## You can specify the noinstall option if you don't want that an install
|
||||
## target is created.
|
||||
## Options:
|
||||
## noinstall: Don't setup a default installation target.
|
||||
## independent: The target will not be made a dependency of the plugins
|
||||
## and all target.
|
||||
## nohelp: Do not invoke Help for this target.
|
||||
## notest: Do not set up unit-testing support for this target.
|
||||
rule Plugin
|
||||
{
|
||||
# check options
|
||||
CheckOptions noinstall independent nohelp notest : $(3) : $(<) ;
|
||||
|
||||
local metafile ;
|
||||
metafile = [ FAppendSuffix $(<) : $(SUFMETA) ] ;
|
||||
SEARCH on $(metafile) = $(SEARCH_SOURCE) ;
|
||||
|
||||
local target = [ ConstructPluginTarget $(<) : $(3) ] ;
|
||||
local sources = [ DoSourceGrist $(>) ] ;
|
||||
local objects = [ CompileObjects $(sources) ] ;
|
||||
|
||||
$(<)_TYPE = plugin ;
|
||||
$(<)_OBJECTS = $(objects) ;
|
||||
$(<)_SOURCES = $(sources) ;
|
||||
$(<)_TARGET = $(target) ;
|
||||
$(<)_METAFILE = $(metafile) ;
|
||||
|
||||
# create target clean rule
|
||||
Always $(<)clean ;
|
||||
NotFile $(<)clean ;
|
||||
Clean $(<)clean : $(objects) ; # create target clean rule
|
||||
|
||||
# Create a target for eventual static linking
|
||||
if ! $(NO_STATIC_LINKING)
|
||||
{
|
||||
SubVariant static ;
|
||||
local staticreginfoobject = [ BuildStaticRegFile $(<) : $(statictarget) ] ;
|
||||
|
||||
# Add objects to the list of candidates for potential inclusion in a
|
||||
# monolithic static library containing objects for all plugins (useful for
|
||||
# statically linking the plugins into an application if the client so
|
||||
# desires).
|
||||
local staticobjects = [ CompileObjects $(sources) : $(<) ] ;
|
||||
|
||||
local obj_remain = $(objects) ;
|
||||
local staticobj_remain = $(staticobjects) ;
|
||||
|
||||
while $(obj_remain)
|
||||
{
|
||||
local obj = $(obj_remain[1]) ;
|
||||
local staticobj = $(staticobj_remain[1]) ;
|
||||
|
||||
STATICPLUGINS.OBJECTS.$(staticobj) = $(obj) ;
|
||||
|
||||
obj_remain = $(obj_remain[2-]) ;
|
||||
staticobj_remain = $(staticobj_remain[2-]) ;
|
||||
}
|
||||
|
||||
MakeLocate $(staticobjects) : $(LOCATE_TARGET) ;
|
||||
STATICPLUGINS.OBJECTS.$(<) += $(staticreginfoobject) ;
|
||||
STATICPLUGINS.OBJECTS.$(<) += $(staticobjects) ;
|
||||
STATICPLUGINS.SUBTARGETS += $(<) ;
|
||||
|
||||
SubVariant ;
|
||||
}
|
||||
|
||||
# so 'jam foo' works when it's really foo.dll (Windows) or foo.csbundle
|
||||
# (MacOS/X)
|
||||
if $(target) != $(<)
|
||||
{
|
||||
Depends $(<) : $(target) ;
|
||||
NotFile $(<) ;
|
||||
}
|
||||
|
||||
if ! [ IsElem independent : $(3) ]
|
||||
{
|
||||
Depends plugins : $(<) ;
|
||||
}
|
||||
|
||||
# construct install target
|
||||
if ! [ IsElem noinstall : $(3) ]
|
||||
{
|
||||
SystemInstallPlugin $(target) ;
|
||||
}
|
||||
|
||||
# Link
|
||||
MakeLocate $(target) : $(LOCATE.TARGETS) ;
|
||||
SystemLinkPlugin $(<) : $(objects) : $(3) ;
|
||||
|
||||
CFlags $(<) : $(PLUGIN.CFLAGS) : nostatic ;
|
||||
LFlags $(<) : $(LINKLIBS) $(PLUGIN.LFLAGS) : nostatic ;
|
||||
|
||||
if ! [ IsElem nohelp : $(3) ]
|
||||
{
|
||||
local desc = [ Description $(<) ] ;
|
||||
if ! $(desc) { desc = "$(<) plugin" ; }
|
||||
Help $(<) : "Build the $(desc)" ;
|
||||
}
|
||||
|
||||
if ! [ IsElem notest : $(options) ]
|
||||
{
|
||||
# @@@ Disabled for now; see docs/todo_jam.txt
|
||||
#UnitTest $(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# private rules
|
||||
|
||||
# PluginMetaData pluginname : metafile [ : options ]
|
||||
# Copy a plugin's meta file so that it resides alongside the generated
|
||||
# plugin module. This utility rule may be used by SystemLinkPlugin rules
|
||||
# which employ the default behavior of having a plugin's meta-data file
|
||||
# reside alongside the plugin executable (as opposed to bundling the
|
||||
# metadata directly into the plugin).
|
||||
# Options:
|
||||
# noinstall: Don't setup a default installation target.
|
||||
rule PluginMetaData
|
||||
{
|
||||
local target = $(>:G=$(GRISTMETA)) ;
|
||||
Depends $(<) : $(target) ;
|
||||
Depends $(target) : $(>) ;
|
||||
MakeLocate $(target) : $(LOCATE.TARGETS) ;
|
||||
Copy $(target) : $(>) ;
|
||||
Clean clean : $(target) ;
|
||||
Clean $(<)clean : $(target) ;
|
||||
|
||||
if ! [ IsElem noinstall : $(3) ]
|
||||
{
|
||||
Depends install_plugin : [ DoInstall $(target) : $(plugindir) ] ;
|
||||
}
|
||||
}
|
||||
|
||||
# Construct pseudo target plugins
|
||||
Depends exe : plugins ;
|
||||
NotFile plugins ;
|
||||
Help plugins : "Build all plugin modules" ;
|
||||
#============================================================================
|
||||
# Rules for plugin creation
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
SUFMETA ?= .csplugin ;
|
||||
GRISTMETA ?= pluginmeta ;
|
||||
|
||||
## Plugin pluginname : sources [ : options ]
|
||||
## Build a plugin out of sourcefiles. All sourcefiles will be passed
|
||||
## to the Objects rule which tries to compile them into object-files. You
|
||||
## can create rules for your own filetypes with the UserObject rule. Header
|
||||
## files will just be ignored. They are only used for MSVC projectfile
|
||||
## generator.
|
||||
## You can specify the noinstall option if you don't want that an install
|
||||
## target is created.
|
||||
## Options:
|
||||
## noinstall: Don't setup a default installation target.
|
||||
## independent: The target will not be made a dependency of the plugins
|
||||
## and all target.
|
||||
## nohelp: Do not invoke Help for this target.
|
||||
## notest: Do not set up unit-testing support for this target.
|
||||
rule Plugin
|
||||
{
|
||||
# check options
|
||||
CheckOptions noinstall independent nohelp notest : $(3) : $(<) ;
|
||||
|
||||
local metafile ;
|
||||
metafile = [ FAppendSuffix $(<) : $(SUFMETA) ] ;
|
||||
SEARCH on $(metafile) = $(SEARCH_SOURCE) ;
|
||||
|
||||
local target = [ ConstructPluginTarget $(<) : $(3) ] ;
|
||||
local sources = [ DoSourceGrist $(>) ] ;
|
||||
local objects = [ CompileObjects $(sources) ] ;
|
||||
|
||||
$(<)_TYPE = plugin ;
|
||||
$(<)_OBJECTS = $(objects) ;
|
||||
$(<)_SOURCES = $(sources) ;
|
||||
$(<)_TARGET = $(target) ;
|
||||
$(<)_METAFILE = $(metafile) ;
|
||||
|
||||
# Create a target for eventual static linking
|
||||
if ! $(NO_STATIC_LINKING)
|
||||
{
|
||||
SubVariant static ;
|
||||
local staticreginfoobject = [ BuildStaticRegFile $(<) : $(statictarget) ] ;
|
||||
|
||||
# Add objects to the list of candidates for potential inclusion in a
|
||||
# monolithic static library containing objects for all plugins (useful for
|
||||
# statically linking the plugins into an application if the client so
|
||||
# desires).
|
||||
local staticobjects = [ CompileObjects $(sources) : $(<) ] ;
|
||||
|
||||
local obj_remain = $(objects) ;
|
||||
local staticobj_remain = $(staticobjects) ;
|
||||
|
||||
while $(obj_remain)
|
||||
{
|
||||
local obj = $(obj_remain[1]) ;
|
||||
local staticobj = $(staticobj_remain[1]) ;
|
||||
|
||||
STATICPLUGINS.OBJECTS.$(staticobj) = $(obj) ;
|
||||
|
||||
obj_remain = $(obj_remain[2-]) ;
|
||||
staticobj_remain = $(staticobj_remain[2-]) ;
|
||||
}
|
||||
|
||||
MakeLocate $(staticobjects) : $(LOCATE_TARGET) ;
|
||||
STATICPLUGINS.OBJECTS.$(<) += $(staticreginfoobject) ;
|
||||
STATICPLUGINS.OBJECTS.$(<) += $(staticobjects) ;
|
||||
STATICPLUGINS.SUBTARGETS += $(<) ;
|
||||
|
||||
SubVariant ;
|
||||
}
|
||||
|
||||
# so 'jam foo' works when it's really foo.dll (Windows) or foo.csbundle
|
||||
# (MacOS/X)
|
||||
if $(target) != $(<)
|
||||
{
|
||||
Depends $(<) : $(target) ;
|
||||
NotFile $(<) ;
|
||||
}
|
||||
|
||||
if ! [ IsElem independent : $(3) ]
|
||||
{
|
||||
Depends plugins : $(<) ;
|
||||
}
|
||||
|
||||
# construct install target
|
||||
if ! [ IsElem noinstall : $(3) ]
|
||||
{
|
||||
SystemInstallPlugin $(target) ;
|
||||
}
|
||||
|
||||
# Link
|
||||
MakeLocate $(target) : $(LOCATE.TARGETS) ;
|
||||
SystemLinkPlugin $(<) : $(objects) : $(3) ;
|
||||
|
||||
local cleanextra ;
|
||||
if $(LINK.DEBUG.INFO.SEPARATE) = "yes"
|
||||
{
|
||||
local debugfile = [ SplitDebugInfo $(target) ] ;
|
||||
cleanextra += $(debugfile) ;
|
||||
if ! [ IsElem noinstall : $(3) ]
|
||||
{
|
||||
NoCare $(debugfile) ;
|
||||
Depends install_plugin : [ DoInstall $(debugfile) : $(plugindir) : $(INSTALL_DATA) ] ;
|
||||
}
|
||||
}
|
||||
|
||||
CFlags $(<) : $(PLUGIN.CFLAGS) : nostatic ;
|
||||
LFlags $(<) : $(LINKLIBS) $(PLUGIN.LFLAGS) : nostatic ;
|
||||
|
||||
# create target clean rule
|
||||
Always $(<)clean ;
|
||||
NotFile $(<)clean ;
|
||||
Clean $(<)clean : $(objects) $(cleanextra) ;
|
||||
Clean clean : $(cleanextra) ;
|
||||
|
||||
if ! [ IsElem nohelp : $(3) ]
|
||||
{
|
||||
local desc = [ Description $(<) ] ;
|
||||
if ! $(desc) { desc = "$(<) plugin" ; }
|
||||
Help $(<) : "Build the $(desc)" ;
|
||||
}
|
||||
|
||||
if ! [ IsElem notest : $(options) ]
|
||||
{
|
||||
# @@@ Disabled for now; see docs/todo_jam.txt
|
||||
#UnitTest $(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# private rules
|
||||
|
||||
# PluginMetaData pluginname : metafile [ : options ]
|
||||
# Copy a plugin's meta file so that it resides alongside the generated
|
||||
# plugin module. This utility rule may be used by SystemLinkPlugin rules
|
||||
# which employ the default behavior of having a plugin's meta-data file
|
||||
# reside alongside the plugin executable (as opposed to bundling the
|
||||
# metadata directly into the plugin).
|
||||
# Options:
|
||||
# noinstall: Don't setup a default installation target.
|
||||
rule PluginMetaData
|
||||
{
|
||||
local target = $(>:G=$(GRISTMETA)) ;
|
||||
Depends $(<) : $(target) ;
|
||||
Depends $(target) : $(>) ;
|
||||
MakeLocate $(target) : $(LOCATE.TARGETS) ;
|
||||
Copy $(target) : $(>) ;
|
||||
Clean clean : $(target) ;
|
||||
Clean $(<)clean : $(target) ;
|
||||
|
||||
if ! [ IsElem noinstall : $(3) ]
|
||||
{
|
||||
Depends install_plugin : [ DoInstall $(target) : $(plugindir) ] ;
|
||||
}
|
||||
}
|
||||
|
||||
# Construct pseudo target plugins
|
||||
Depends exe : plugins ;
|
||||
NotFile plugins ;
|
||||
Help plugins : "Build all plugin modules" ;
|
||||
|
||||
@@ -1,58 +1,58 @@
|
||||
#==============================================================================
|
||||
# Generic property-bag mechanism.
|
||||
# Copyright (C) 2004 by Eric Sunshine <sunshine@sunshineco.com>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#==============================================================================
|
||||
|
||||
# Property bag : name
|
||||
# Returns the value of property 'name' in container 'bag' if present, else
|
||||
# returns a null value. 'bag' and 'name' should be simple identifiers
|
||||
# composed of alphanumeric characters and underscore, and with an alphabetic
|
||||
# or an underscore as the first character.
|
||||
rule Property
|
||||
{
|
||||
local p = [ _PropertyName $(<) : $(>) ] ;
|
||||
return $($(p)) ;
|
||||
}
|
||||
|
||||
# SetProperty bag : name [ : value ]
|
||||
# Add property 'name' to container 'bag'. If 'value' is not provided, sets
|
||||
# the property to "true".
|
||||
rule SetProperty
|
||||
{
|
||||
local p = [ _PropertyName $(<) : $(>) ] ;
|
||||
local v = $(3) ;
|
||||
if ! $(v) { v = "true" ; }
|
||||
$(p) = $(v) ;
|
||||
}
|
||||
|
||||
# ClearProperty bag : name
|
||||
# Remove property 'name' from container 'bag'.
|
||||
rule ClearProperty
|
||||
{
|
||||
local p = [ _PropertyName $(<) : $(>) ] ;
|
||||
$(p) = "" ;
|
||||
}
|
||||
|
||||
|
||||
#------------------------------------------------------------------------------
|
||||
# Private utilitiy rules.
|
||||
#------------------------------------------------------------------------------
|
||||
rule _PropertyName
|
||||
{
|
||||
return "__property_$(<)_$(>)" ;
|
||||
}
|
||||
#==============================================================================
|
||||
# Generic property-bag mechanism.
|
||||
# Copyright (C) 2004 by Eric Sunshine <sunshine@sunshineco.com>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#==============================================================================
|
||||
|
||||
# Property bag : name
|
||||
# Returns the value of property 'name' in container 'bag' if present, else
|
||||
# returns a null value. 'bag' and 'name' should be simple identifiers
|
||||
# composed of alphanumeric characters and underscore, and with an alphabetic
|
||||
# or an underscore as the first character.
|
||||
rule Property
|
||||
{
|
||||
local p = [ _PropertyName $(<) : $(>) ] ;
|
||||
return $($(p)) ;
|
||||
}
|
||||
|
||||
# SetProperty bag : name [ : value ]
|
||||
# Add property 'name' to container 'bag'. If 'value' is not provided, sets
|
||||
# the property to "true".
|
||||
rule SetProperty
|
||||
{
|
||||
local p = [ _PropertyName $(<) : $(>) ] ;
|
||||
local v = $(3) ;
|
||||
if ! $(v) { v = "true" ; }
|
||||
$(p) = $(v) ;
|
||||
}
|
||||
|
||||
# ClearProperty bag : name
|
||||
# Remove property 'name' from container 'bag'.
|
||||
rule ClearProperty
|
||||
{
|
||||
local p = [ _PropertyName $(<) : $(>) ] ;
|
||||
$(p) = "" ;
|
||||
}
|
||||
|
||||
|
||||
#------------------------------------------------------------------------------
|
||||
# Private utilitiy rules.
|
||||
#------------------------------------------------------------------------------
|
||||
rule _PropertyName
|
||||
{
|
||||
return "__property_$(<)_$(>)" ;
|
||||
}
|
||||
|
||||
@@ -1,109 +1,109 @@
|
||||
#============================================================================
|
||||
# Rules for handling additional resources.
|
||||
# Platform-specific Jam files may override these if needed.
|
||||
#
|
||||
# Copyright (C)2004 by Eric Sunshine <sunshine@sunshineco.com>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
## ApplicationIconDefault platform : type [ : icon [ : pathcomponents ]]
|
||||
## If invoked with three or more arguments, specifies the default icon for
|
||||
## applications of the specified type for the given platform, which may be
|
||||
## 'macosx', 'win32', or 'unix'. Type should be 'all', 'gui', or 'console'.
|
||||
## If pathcomponents is omitted, SEARCH_SOURCE is used. This setting can be
|
||||
## overriden for an individual application with the ApplicationIcon rule.
|
||||
## This rule must be invoked before invoking any Application rules if it is
|
||||
## to have any effect. If invoked with two arguments, returns the default
|
||||
## icon (if any) for the given platform and type.
|
||||
rule ApplicationIconDefault
|
||||
{
|
||||
local platform = $(1) ;
|
||||
local type = $(2) ;
|
||||
local icon = $(3) ;
|
||||
local iconpath = $(4) ;
|
||||
local key = default_$(platform)_$(type) ;
|
||||
|
||||
if $(icon)
|
||||
{
|
||||
SetProperty appicon : $(key) : $(icon) ;
|
||||
if $(iconpath)
|
||||
{
|
||||
SEARCH on $(icon) = [ ConcatDirs $(iconpath) ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
SEARCH on $(icon) = $(SEARCH_SOURCE) ;
|
||||
}
|
||||
}
|
||||
|
||||
local result = [ Property appicon : $(key) ] ;
|
||||
if ! $(result) && $(type) != all
|
||||
{
|
||||
result = [ Property appicon : default_$(platform)_all ] ;
|
||||
}
|
||||
return $(result) ;
|
||||
}
|
||||
|
||||
## ApplicationIcon platform : basename [ : icon [ : pathcomponents ]]
|
||||
## If invoked with three or more arguments, specifies the icon for the
|
||||
## application given by basename for the indicated platform, which may be
|
||||
## 'macosx', 'win32', or 'unix'. If pathcomponents is omitted,
|
||||
## SEARCH_SOURCE is used. If this rule is not invoked, then the icon
|
||||
## specified via ApplicationIconDefault is used, if any. This rule must be
|
||||
## invoked before the Application rule to which this icon will apply. If
|
||||
## invoked with two arguments, returns the icon (if any) explicitly
|
||||
## registered for basename for the given platform.
|
||||
rule ApplicationIcon
|
||||
{
|
||||
local platform = $(1) ;
|
||||
local target = $(2) ;
|
||||
local icon = $(3) ;
|
||||
local iconpath = $(4) ;
|
||||
local key = app_$(platform)_$(target) ;
|
||||
|
||||
if $(icon)
|
||||
{
|
||||
SetProperty appicon : $(key) : $(icon) ;
|
||||
if $(iconpath)
|
||||
{
|
||||
SEARCH on $(icon) = [ ConcatDirs $(iconpath) ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
SEARCH on $(icon) = $(SEARCH_SOURCE) ;
|
||||
}
|
||||
|
||||
# An ugly but effective way to detect incorrect usage.
|
||||
if $($(target)_TARGET)
|
||||
{
|
||||
Echo "Warning: `ApplicationIcon:$(target):$(icon)' incorrectly invoked"
|
||||
"after Application rule." ;
|
||||
}
|
||||
}
|
||||
|
||||
return [ Property appicon : $(key) ] ;
|
||||
}
|
||||
|
||||
## Win32Resource basename : rcfiles
|
||||
## Specify .rc files for the target known as basename. The .rc files should
|
||||
## already have SEARCH set appropriately.
|
||||
rule Win32Resource { }
|
||||
|
||||
## Win32RcFlags basename : rcfiles
|
||||
## Specify flags passed to the resource compiler when compiling resources
|
||||
## for the target known as basename.
|
||||
rule Win32RcFlags { }
|
||||
#============================================================================
|
||||
# Rules for handling additional resources.
|
||||
# Platform-specific Jam files may override these if needed.
|
||||
#
|
||||
# Copyright (C)2004 by Eric Sunshine <sunshine@sunshineco.com>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
## ApplicationIconDefault platform : type [ : icon [ : pathcomponents ]]
|
||||
## If invoked with three or more arguments, specifies the default icon for
|
||||
## applications of the specified type for the given platform, which may be
|
||||
## 'macosx', 'win32', or 'unix'. Type should be 'all', 'gui', or 'console'.
|
||||
## If pathcomponents is omitted, SEARCH_SOURCE is used. This setting can be
|
||||
## overriden for an individual application with the ApplicationIcon rule.
|
||||
## This rule must be invoked before invoking any Application rules if it is
|
||||
## to have any effect. If invoked with two arguments, returns the default
|
||||
## icon (if any) for the given platform and type.
|
||||
rule ApplicationIconDefault
|
||||
{
|
||||
local platform = $(1) ;
|
||||
local type = $(2) ;
|
||||
local icon = $(3) ;
|
||||
local iconpath = $(4) ;
|
||||
local key = default_$(platform)_$(type) ;
|
||||
|
||||
if $(icon)
|
||||
{
|
||||
SetProperty appicon : $(key) : $(icon) ;
|
||||
if $(iconpath)
|
||||
{
|
||||
SEARCH on $(icon) = [ ConcatDirs $(iconpath) ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
SEARCH on $(icon) = $(SEARCH_SOURCE) ;
|
||||
}
|
||||
}
|
||||
|
||||
local result = [ Property appicon : $(key) ] ;
|
||||
if ! $(result) && $(type) != all
|
||||
{
|
||||
result = [ Property appicon : default_$(platform)_all ] ;
|
||||
}
|
||||
return $(result) ;
|
||||
}
|
||||
|
||||
## ApplicationIcon platform : basename [ : icon [ : pathcomponents ]]
|
||||
## If invoked with three or more arguments, specifies the icon for the
|
||||
## application given by basename for the indicated platform, which may be
|
||||
## 'macosx', 'win32', or 'unix'. If pathcomponents is omitted,
|
||||
## SEARCH_SOURCE is used. If this rule is not invoked, then the icon
|
||||
## specified via ApplicationIconDefault is used, if any. This rule must be
|
||||
## invoked before the Application rule to which this icon will apply. If
|
||||
## invoked with two arguments, returns the icon (if any) explicitly
|
||||
## registered for basename for the given platform.
|
||||
rule ApplicationIcon
|
||||
{
|
||||
local platform = $(1) ;
|
||||
local target = $(2) ;
|
||||
local icon = $(3) ;
|
||||
local iconpath = $(4) ;
|
||||
local key = app_$(platform)_$(target) ;
|
||||
|
||||
if $(icon)
|
||||
{
|
||||
SetProperty appicon : $(key) : $(icon) ;
|
||||
if $(iconpath)
|
||||
{
|
||||
SEARCH on $(icon) = [ ConcatDirs $(iconpath) ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
SEARCH on $(icon) = $(SEARCH_SOURCE) ;
|
||||
}
|
||||
|
||||
# An ugly but effective way to detect incorrect usage.
|
||||
if $($(target)_TARGET)
|
||||
{
|
||||
Echo "Warning: `ApplicationIcon:$(target):$(icon)' incorrectly invoked"
|
||||
"after Application rule." ;
|
||||
}
|
||||
}
|
||||
|
||||
return [ Property appicon : $(key) ] ;
|
||||
}
|
||||
|
||||
## Win32Resource basename : rcfiles
|
||||
## Specify .rc files for the target known as basename. The .rc files should
|
||||
## already have SEARCH set appropriately.
|
||||
rule Win32Resource { }
|
||||
|
||||
## Win32RcFlags basename : rcfiles
|
||||
## Specify flags passed to the resource compiler when compiling resources
|
||||
## for the target known as basename.
|
||||
rule Win32RcFlags { }
|
||||
|
||||
@@ -1,353 +1,353 @@
|
||||
#============================================================================
|
||||
# Utility rules for static builds without plugins
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
# all private
|
||||
|
||||
rule GenerateStaticPluginBoilerplate
|
||||
{
|
||||
ResponseFile $(<) :
|
||||
"// This file is automatically generated."
|
||||
"#include \"cssysdef.h\""
|
||||
"#include \"csutil/scf.h\""
|
||||
""
|
||||
"// Put static linking stuff into own section."
|
||||
"// The idea is that this allows the section to be swapped out but not"
|
||||
"// swapped in again b/c something else in it was needed."
|
||||
"#if !defined(CS_DEBUG) && defined(CS_COMPILER_MSVC)"
|
||||
"#pragma const_seg(\".CSmetai\")"
|
||||
"#pragma comment(linker, \"/section:.CSmetai,r\")"
|
||||
"#pragma code_seg(\".CSmeta\")"
|
||||
"#pragma comment(linker, \"/section:.CSmeta,er\")"
|
||||
"#pragma comment(linker, \"/merge:.CSmetai=.CSmeta\")"
|
||||
"#endif"
|
||||
: notfile ;
|
||||
}
|
||||
|
||||
rule GenerateStaticPluginInstantiation
|
||||
{
|
||||
GenerateStaticPluginBoilerplate $(<) ;
|
||||
ResponseFile $(<) : "SCF_USE_STATIC_PLUGIN($(>:B))" : notfile ;
|
||||
}
|
||||
|
||||
rule GenerateStaticPluginRegistration
|
||||
{
|
||||
GenerateStaticPluginBoilerplate $(<) ;
|
||||
GenerateStaticPluginRegistration1 $(<) : $(>) ;
|
||||
}
|
||||
|
||||
rule BuildStaticRegFile
|
||||
{
|
||||
local statictarget = $(>) ;
|
||||
# prepare source files
|
||||
local sources = [ DoObjectGrist _$(<)_static_reg.cpp ] ;
|
||||
local object = [ CompileObject $(sources) ] ;
|
||||
|
||||
MakeLocate $(sources) : $(LOCATE_TARGET) ;
|
||||
MakeLocate $(object) : $(LOCATE_TARGET) ;
|
||||
|
||||
local metalist metafile i ;
|
||||
for i in $(<)
|
||||
{
|
||||
metafile = $($(i)_METAFILE) ;
|
||||
metalist += $(metafile) ;
|
||||
Depends $(sources) : $(metafile) ;
|
||||
}
|
||||
|
||||
GenerateStaticPluginRegistration $(sources) : $(metalist) ;
|
||||
Clean $(statictarget)clean : $(sources) ;
|
||||
Clean $(statictarget)clean : $(object) ;
|
||||
return $(object) ;
|
||||
}
|
||||
|
||||
rule BuildStaticUseFile
|
||||
{
|
||||
local statictarget = $(2) ;
|
||||
local package = $(3) ;
|
||||
# prepare source files
|
||||
local sources ;
|
||||
if $(3)
|
||||
{
|
||||
sources = [ DoObjectGrist _cs_static_use_$(package).cpp ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
sources = [ DoObjectGrist _cs_static_use.cpp ] ;
|
||||
}
|
||||
local object = [ CompileObject $(sources) ] ;
|
||||
|
||||
MakeLocate $(sources) : $(LOCATE_TARGET) ;
|
||||
SEARCH on $(sources) = $(LOCATE_TARGET) ;
|
||||
MakeLocate $(object) : $(LOCATE_TARGET) ;
|
||||
|
||||
C++FLAGS on $(object) += $($($(>).EXTERNALLIBS).CFLAGS) ;
|
||||
|
||||
GenerateStaticPluginInstantiation $(sources) : $(<) ;
|
||||
Clean $(statictarget)clean : $(sources) ;
|
||||
Clean $(statictarget)clean : $(object) ;
|
||||
return $(object) ;
|
||||
}
|
||||
|
||||
## LinkStaticPlugins target : plugins [: optionalplugins] [: package]
|
||||
## Builds the plugins in 'plugins' (and 'optionalplugins') statically into
|
||||
## 'target'. Can be used both for static plugins from the local project or
|
||||
## an external project. In the latter case, the project's static plugin
|
||||
## library has to have been built, also, the "<package>.STATICDEPS"
|
||||
## variable must contain a path to a specially generated Jamfile that
|
||||
## contains information about the plugins provided by as well as external
|
||||
## dependencies. The static plugins library for both local and external
|
||||
## package must be explicitly linked into 'target'.
|
||||
rule LinkStaticPlugins
|
||||
{
|
||||
local package target plugins optplugins ;
|
||||
# Fetch the parameters
|
||||
target = $(1) ;
|
||||
plugins = $(2) ;
|
||||
optplugins = $(3) ;
|
||||
package = $(4) ;
|
||||
|
||||
if $(package)
|
||||
{
|
||||
# External static plugins.
|
||||
# First include static plugin info
|
||||
if ! $(HAVE_STATICDEPS.$(package))
|
||||
{
|
||||
include $($(package).STATICDEPS) ;
|
||||
HAVE_STATICDEPS.$(package) = yes ;
|
||||
}
|
||||
local lflags p ;
|
||||
# Collect optional plugins
|
||||
for p in $(optplugins)
|
||||
{
|
||||
if [ IsElem $(p) : $(STATICPLUGINS.AVAILABLE) ]
|
||||
{
|
||||
plugins += $(p) ;
|
||||
}
|
||||
}
|
||||
# Grab flags
|
||||
for p in $(plugins)
|
||||
{
|
||||
NotFile $(p) ;
|
||||
CFlags $(target) : $(STATICPLUGIN.$(p).CFLAGS) ;
|
||||
lflags = [ MergeLFlags $(lflags) : $(STATICPLUGIN.$(p).LFLAGS) ] ;
|
||||
}
|
||||
LFlags $(target) : $(lflags) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
# Local static plugins
|
||||
local lflags libs p ;
|
||||
# Collect optional plugins
|
||||
for p in $(optplugins)
|
||||
{
|
||||
if $($(p)_TARGET)
|
||||
{
|
||||
plugins += $(p) ;
|
||||
}
|
||||
}
|
||||
# Grab flags
|
||||
for p in $(plugins)
|
||||
{
|
||||
lflags += [ Filter $($(p).LFLAGS) : $(LINKLIBS) $(PLUGIN.LFLAGS) ] ;
|
||||
libs += $($(p).NEEDLIBS) ;
|
||||
}
|
||||
LFlags $(target) : [ Reverse [ RemoveDups [ Reverse $(lflags) ] ] ] ;
|
||||
LinkWith $(target) : [ Reverse [ RemoveDups [ Reverse $(libs) ] ] ] ;
|
||||
}
|
||||
|
||||
# construct initialization sourcefile
|
||||
local staticobject = [ BuildStaticUseFile $(plugins) : $(target) : $(package) ] ;
|
||||
ExtraObjects $(target) : $(staticobject) : inheritcflags ;
|
||||
}
|
||||
|
||||
## StaticPluginLibrary name [: rejects]
|
||||
## Create a library that monolithically contains statically linkable
|
||||
## versions of all plugins, and also provides a target to install this
|
||||
## library ("install_staticplugins") as well as resources to facilitate the
|
||||
## use of that library from external projects. Also, most plugins will
|
||||
## probably themselves depend on other libraries; while those are correctly
|
||||
## linked in with the static plugins, they are not built or installed when
|
||||
## the static plugin library is.
|
||||
## This library is intended to be used together with the
|
||||
## "LinkStaticPlugins" rule.
|
||||
rule StaticPluginLibrary
|
||||
{
|
||||
local name = $(<) ;
|
||||
local rejects = $(>) ;
|
||||
local t ;
|
||||
|
||||
local targets = $(STATICPLUGINS.SUBTARGETS) ;
|
||||
if $(rejects)
|
||||
{
|
||||
targets = [ Filter $(targets) : $(rejects) ] ;
|
||||
}
|
||||
local objects ;
|
||||
for t in $(targets)
|
||||
{
|
||||
objects += $(STATICPLUGINS.OBJECTS.$(t)) ;
|
||||
}
|
||||
|
||||
# Set up library
|
||||
Library $(name) : $(objects) : noinstall notest independent nohelp ;
|
||||
SEARCH on $(name) += $(LOCATE_TARGET) ;
|
||||
MsvcDefine $(name) : $(STATICPLUGINS.MSVC_DEFINES) ;
|
||||
CFlags $(name) :
|
||||
[ FDefines CS_STATIC_LINKED ]
|
||||
: nostatic ;
|
||||
|
||||
# Copy a variety of flags
|
||||
local o ;
|
||||
for o in $(objects)
|
||||
{
|
||||
local sourceobj = $(STATICPLUGINS.OBJECTS.$(o)) ;
|
||||
if $(sourceobj)
|
||||
{
|
||||
CCFLAGS on $(o) += [ on $(sourceobj) GetVar CCFLAGS ] ;
|
||||
C++FLAGS on $(o) += [ on $(sourceobj) GetVar C++FLAGS ] ;
|
||||
}
|
||||
}
|
||||
|
||||
# Write out needed CFLAGS, LFLAGS
|
||||
STATICPLUGINS.DEPENDENCIES = $(name).jam ;
|
||||
MakeLocate $(STATICPLUGINS.DEPENDENCIES) : $(LOCATE.OBJECTS)/libs ;
|
||||
for t in $(targets)
|
||||
{
|
||||
WriteDependencies $(STATICPLUGINS.DEPENDENCIES) : $(t) : $(name) ;
|
||||
}
|
||||
Depends $(name) : $(STATICPLUGINS.DEPENDENCIES) ;
|
||||
Clean $(name)clean : $(STATICPLUGINS.DEPENDENCIES) ;
|
||||
|
||||
# Install targets
|
||||
Depends install_staticplugins :
|
||||
[ DoInstall [ ConstructLibraryTarget $(name) ] : $(libdir) ] ;
|
||||
Depends install_staticplugins : $(STATICPLUGINS.DEPENDENCIES) ;
|
||||
Depends install_staticplugins :
|
||||
[ DoInstall $(STATICPLUGINS.DEPENDENCIES) : $(libdir) ] ;
|
||||
Depends install_staticplugins : install_libs ;
|
||||
|
||||
INSTALLEDLIBS_OPTIONAL += $(name) ;
|
||||
|
||||
# Collect library dependencies. The idea is to built all libs needed by the
|
||||
# static plugins when "jam staticplugins" is invoked.
|
||||
for t in $(targets)
|
||||
{
|
||||
local deplibs ;
|
||||
if $($(t).NEEDLIBS)
|
||||
{
|
||||
deplibs += $($(t).NEEDLIBS) ;
|
||||
}
|
||||
deplibs = [ RemoveDups $(deplibs) ] ;
|
||||
Depends staticplugins : $(deplibs) ;
|
||||
}
|
||||
Help staticplugins :
|
||||
"Build the library with static versions of all plugins" ;
|
||||
Depends staticplugins : libs $(name) ;
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
|
||||
# Write out CFLAGS, LFLAGS needed by a plugin
|
||||
rule WriteDependencies
|
||||
{
|
||||
local cflags ;
|
||||
local lflags ;
|
||||
local depfile = $(<) ;
|
||||
local plugin = $(>) ;
|
||||
local name = $(3) ;
|
||||
local depfile_gristed = $(depfile:G=$(plugin)) ;
|
||||
MakeLocate $(depfile_gristed) : [ on $(depfile) GetVar LOCATE ] ;
|
||||
|
||||
# Collect flags
|
||||
lflags += -l$(name) ;
|
||||
local libs = [ ResolveLibs $($(plugin).NEEDLIBS) ] ;
|
||||
lflags += -l$(libs) ;
|
||||
|
||||
local l ;
|
||||
for l in $($(plugin).EXTERNALLIBS)
|
||||
{
|
||||
cflags += $($(l).CFLAGS) ;
|
||||
lflags += [ Filter $($(l).LFLAGS) : $(LINKLIBS) $(PLUGIN.LFLAGS) ] ;
|
||||
}
|
||||
lflags += [ Filter $($(plugin).LFLAGS) : $(LINKLIBS) $(PLUGIN.LFLAGS) ] ;
|
||||
CFLAGS on $(depfile_gristed) = "$(cflags)" ;
|
||||
LFLAGS on $(depfile_gristed) = "$(lflags)" ;
|
||||
|
||||
if $($(depfile).FIRSTTIME) != "yes"
|
||||
{
|
||||
WriteDepFlags1 $(depfile_gristed) : $(plugin) ;
|
||||
$(depfile).FIRSTTIME = "yes" ;
|
||||
}
|
||||
else
|
||||
{
|
||||
WriteDepFlags2 $(depfile_gristed) : $(plugin) ;
|
||||
}
|
||||
Depends $(depfile) : $(depfile_gristed) ;
|
||||
}
|
||||
|
||||
actions WriteDepFlags1
|
||||
{
|
||||
cat << EOT > $(<)
|
||||
STATICPLUGINS.AVAILABLE += $(>) ;
|
||||
STATICPLUGIN.$(>).CFLAGS = $(CFLAGS) ;
|
||||
STATICPLUGIN.$(>).LFLAGS = $(LFLAGS) ;
|
||||
EOT
|
||||
}
|
||||
|
||||
actions WriteDepFlags2
|
||||
{
|
||||
cat << EOT >> $(<)
|
||||
STATICPLUGINS.AVAILABLE += $(>) ;
|
||||
STATICPLUGIN.$(>).CFLAGS = $(CFLAGS) ;
|
||||
STATICPLUGIN.$(>).LFLAGS = $(LFLAGS) ;
|
||||
EOT
|
||||
}
|
||||
|
||||
actions piecemeal GenerateStaticPluginRegistration1
|
||||
{
|
||||
echo 'namespace csStaticPluginInit' >> $(<)
|
||||
echo '{' >> $(<)
|
||||
for x in $(>)
|
||||
do
|
||||
n=`basename $x $(SUFMETA)`
|
||||
echo "static char const metainfo_${n}[] =" >> $(<)
|
||||
$(SED) 's:\\:\\\\:g;s:":\\":g;s:\(.*\):"\1":' < $x >>$(<)
|
||||
echo ";" >> $(<)
|
||||
$(SED) '/<implementation>/!d;s:[ ]*<implementation>\(..*\)</implementation>: #ifndef \1_FACTORY_REGISTER_DEFINED \
|
||||
#define \1_FACTORY_REGISTER_DEFINED \
|
||||
SCF_DEFINE_FACTORY_FUNC_REGISTRATION(\1) \
|
||||
#endif:g' < $x >> $(<)
|
||||
done
|
||||
echo '' >> $(<)
|
||||
for x in $(>)
|
||||
do
|
||||
n=`basename $x $(SUFMETA)`
|
||||
echo "class ${n}" >> $(<)
|
||||
echo "{" >> $(<)
|
||||
echo "SCF_REGISTER_STATIC_LIBRARY($n,metainfo_${n})" >>$(<)
|
||||
$(SED) '/<implementation>/!d;s:[ ]*<implementation>\(..*\)</implementation>: #ifndef \1_FACTORY_REGISTERED \
|
||||
#define \1_FACTORY_REGISTERED \
|
||||
\1_StaticInit \1_static_init__; \
|
||||
#endif:g' < $x >> $(<)
|
||||
echo "public:" >> $(<)
|
||||
echo " ${n}();" >> $(<)
|
||||
echo "};" >> $(<)
|
||||
echo "$n::$n() {}" >> $(<)
|
||||
echo "" >> $(<)
|
||||
done
|
||||
echo '}' >> $(<)
|
||||
}
|
||||
#============================================================================
|
||||
# Utility rules for static builds without plugins
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
# all private
|
||||
|
||||
rule GenerateStaticPluginBoilerplate
|
||||
{
|
||||
ResponseFile $(<) :
|
||||
"// This file is automatically generated."
|
||||
"#include \"cssysdef.h\""
|
||||
"#include \"csutil/scf.h\""
|
||||
""
|
||||
"// Put static linking stuff into own section."
|
||||
"// The idea is that this allows the section to be swapped out but not"
|
||||
"// swapped in again b/c something else in it was needed."
|
||||
"#if !defined(CS_DEBUG) && defined(CS_COMPILER_MSVC)"
|
||||
"#pragma const_seg(\".CSmetai\")"
|
||||
"#pragma comment(linker, \"/section:.CSmetai,r\")"
|
||||
"#pragma code_seg(\".CSmeta\")"
|
||||
"#pragma comment(linker, \"/section:.CSmeta,er\")"
|
||||
"#pragma comment(linker, \"/merge:.CSmetai=.CSmeta\")"
|
||||
"#endif"
|
||||
: notfile ;
|
||||
}
|
||||
|
||||
rule GenerateStaticPluginInstantiation
|
||||
{
|
||||
GenerateStaticPluginBoilerplate $(<) ;
|
||||
ResponseFile $(<) : "SCF_USE_STATIC_PLUGIN($(>:B))" : notfile ;
|
||||
}
|
||||
|
||||
rule GenerateStaticPluginRegistration
|
||||
{
|
||||
GenerateStaticPluginBoilerplate $(<) ;
|
||||
GenerateStaticPluginRegistration1 $(<) : $(>) ;
|
||||
}
|
||||
|
||||
rule BuildStaticRegFile
|
||||
{
|
||||
local statictarget = $(>) ;
|
||||
# prepare source files
|
||||
local sources = [ DoObjectGrist _$(<)_static_reg.cpp ] ;
|
||||
local object = [ CompileObject $(sources) ] ;
|
||||
|
||||
MakeLocate $(sources) : $(LOCATE_TARGET) ;
|
||||
MakeLocate $(object) : $(LOCATE_TARGET) ;
|
||||
|
||||
local metalist metafile i ;
|
||||
for i in $(<)
|
||||
{
|
||||
metafile = $($(i)_METAFILE) ;
|
||||
metalist += $(metafile) ;
|
||||
Depends $(sources) : $(metafile) ;
|
||||
}
|
||||
|
||||
GenerateStaticPluginRegistration $(sources) : $(metalist) ;
|
||||
Clean $(statictarget)clean : $(sources) ;
|
||||
Clean $(statictarget)clean : $(object) ;
|
||||
return $(object) ;
|
||||
}
|
||||
|
||||
rule BuildStaticUseFile
|
||||
{
|
||||
local statictarget = $(2) ;
|
||||
local package = $(3) ;
|
||||
# prepare source files
|
||||
local sources ;
|
||||
if $(3)
|
||||
{
|
||||
sources = [ DoObjectGrist _cs_static_use_$(package).cpp ] ;
|
||||
}
|
||||
else
|
||||
{
|
||||
sources = [ DoObjectGrist _cs_static_use.cpp ] ;
|
||||
}
|
||||
local object = [ CompileObject $(sources) ] ;
|
||||
|
||||
MakeLocate $(sources) : $(LOCATE_TARGET) ;
|
||||
SEARCH on $(sources) = $(LOCATE_TARGET) ;
|
||||
MakeLocate $(object) : $(LOCATE_TARGET) ;
|
||||
|
||||
C++FLAGS on $(object) += $($($(>).EXTERNALLIBS).CFLAGS) ;
|
||||
|
||||
GenerateStaticPluginInstantiation $(sources) : $(<) ;
|
||||
Clean $(statictarget)clean : $(sources) ;
|
||||
Clean $(statictarget)clean : $(object) ;
|
||||
return $(object) ;
|
||||
}
|
||||
|
||||
## LinkStaticPlugins target : plugins [: optionalplugins] [: package]
|
||||
## Builds the plugins in 'plugins' (and 'optionalplugins') statically into
|
||||
## 'target'. Can be used both for static plugins from the local project or
|
||||
## an external project. In the latter case, the project's static plugin
|
||||
## library has to have been built, also, the "<package>.STATICDEPS"
|
||||
## variable must contain a path to a specially generated Jamfile that
|
||||
## contains information about the plugins provided by as well as external
|
||||
## dependencies. The static plugins library for both local and external
|
||||
## package must be explicitly linked into 'target'.
|
||||
rule LinkStaticPlugins
|
||||
{
|
||||
local package target plugins optplugins ;
|
||||
# Fetch the parameters
|
||||
target = $(1) ;
|
||||
plugins = $(2) ;
|
||||
optplugins = $(3) ;
|
||||
package = $(4) ;
|
||||
|
||||
if $(package)
|
||||
{
|
||||
# External static plugins.
|
||||
# First include static plugin info
|
||||
if ! $(HAVE_STATICDEPS.$(package))
|
||||
{
|
||||
include $($(package).STATICDEPS) ;
|
||||
HAVE_STATICDEPS.$(package) = yes ;
|
||||
}
|
||||
local lflags p ;
|
||||
# Collect optional plugins
|
||||
for p in $(optplugins)
|
||||
{
|
||||
if [ IsElem $(p) : $(STATICPLUGINS.AVAILABLE) ]
|
||||
{
|
||||
plugins += $(p) ;
|
||||
}
|
||||
}
|
||||
# Grab flags
|
||||
for p in $(plugins)
|
||||
{
|
||||
NotFile $(p) ;
|
||||
CFlags $(target) : $(STATICPLUGIN.$(p).CFLAGS) ;
|
||||
lflags = [ MergeLFlags $(lflags) : $(STATICPLUGIN.$(p).LFLAGS) ] ;
|
||||
}
|
||||
LFlags $(target) : $(lflags) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
# Local static plugins
|
||||
local lflags libs p ;
|
||||
# Collect optional plugins
|
||||
for p in $(optplugins)
|
||||
{
|
||||
if $($(p)_TARGET)
|
||||
{
|
||||
plugins += $(p) ;
|
||||
}
|
||||
}
|
||||
# Grab flags
|
||||
for p in $(plugins)
|
||||
{
|
||||
lflags += [ Filter $($(p).LFLAGS) : $(LINKLIBS) $(PLUGIN.LFLAGS) ] ;
|
||||
libs += $($(p).NEEDLIBS) ;
|
||||
}
|
||||
LFlags $(target) : [ Reverse [ RemoveDups [ Reverse $(lflags) ] ] ] ;
|
||||
LinkWith $(target) : [ Reverse [ RemoveDups [ Reverse $(libs) ] ] ] ;
|
||||
}
|
||||
|
||||
# construct initialization sourcefile
|
||||
local staticobject = [ BuildStaticUseFile $(plugins) : $(target) : $(package) ] ;
|
||||
ExtraObjects $(target) : $(staticobject) : inheritcflags ;
|
||||
}
|
||||
|
||||
## StaticPluginLibrary name [: rejects]
|
||||
## Create a library that monolithically contains statically linkable
|
||||
## versions of all plugins, and also provides a target to install this
|
||||
## library ("install_staticplugins") as well as resources to facilitate the
|
||||
## use of that library from external projects. Also, most plugins will
|
||||
## probably themselves depend on other libraries; while those are correctly
|
||||
## linked in with the static plugins, they are not built or installed when
|
||||
## the static plugin library is.
|
||||
## This library is intended to be used together with the
|
||||
## "LinkStaticPlugins" rule.
|
||||
rule StaticPluginLibrary
|
||||
{
|
||||
local name = $(<) ;
|
||||
local rejects = $(>) ;
|
||||
local t ;
|
||||
|
||||
local targets = $(STATICPLUGINS.SUBTARGETS) ;
|
||||
if $(rejects)
|
||||
{
|
||||
targets = [ Filter $(targets) : $(rejects) ] ;
|
||||
}
|
||||
local objects ;
|
||||
for t in $(targets)
|
||||
{
|
||||
objects += $(STATICPLUGINS.OBJECTS.$(t)) ;
|
||||
}
|
||||
|
||||
# Set up library
|
||||
Library $(name) : $(objects) : noinstall notest independent nohelp ;
|
||||
SEARCH on $(name) += $(LOCATE_TARGET) ;
|
||||
MsvcDefine $(name) : $(STATICPLUGINS.MSVC_DEFINES) ;
|
||||
CFlags $(name) :
|
||||
[ FDefines CS_STATIC_LINKED ]
|
||||
: nostatic ;
|
||||
|
||||
# Copy a variety of flags
|
||||
local o ;
|
||||
for o in $(objects)
|
||||
{
|
||||
local sourceobj = $(STATICPLUGINS.OBJECTS.$(o)) ;
|
||||
if $(sourceobj)
|
||||
{
|
||||
CCFLAGS on $(o) += [ on $(sourceobj) GetVar CCFLAGS ] ;
|
||||
C++FLAGS on $(o) += [ on $(sourceobj) GetVar C++FLAGS ] ;
|
||||
}
|
||||
}
|
||||
|
||||
# Write out needed CFLAGS, LFLAGS
|
||||
STATICPLUGINS.DEPENDENCIES = $(name).jam ;
|
||||
MakeLocate $(STATICPLUGINS.DEPENDENCIES) : $(LOCATE.OBJECTS)/libs ;
|
||||
for t in $(targets)
|
||||
{
|
||||
WriteDependencies $(STATICPLUGINS.DEPENDENCIES) : $(t) : $(name) ;
|
||||
}
|
||||
Depends $(name) : $(STATICPLUGINS.DEPENDENCIES) ;
|
||||
Clean $(name)clean : $(STATICPLUGINS.DEPENDENCIES) ;
|
||||
|
||||
# Install targets
|
||||
Depends install_staticplugins :
|
||||
[ DoInstall [ ConstructLibraryTarget $(name) ] : $(libdir) ] ;
|
||||
Depends install_staticplugins : $(STATICPLUGINS.DEPENDENCIES) ;
|
||||
Depends install_staticplugins :
|
||||
[ DoInstall $(STATICPLUGINS.DEPENDENCIES) : $(libdir) ] ;
|
||||
Depends install_staticplugins : install_libs ;
|
||||
|
||||
INSTALLEDLIBS_OPTIONAL += $(name) ;
|
||||
|
||||
# Collect library dependencies. The idea is to built all libs needed by the
|
||||
# static plugins when "jam staticplugins" is invoked.
|
||||
for t in $(targets)
|
||||
{
|
||||
local deplibs ;
|
||||
if $($(t).NEEDLIBS)
|
||||
{
|
||||
deplibs += $($(t).NEEDLIBS) ;
|
||||
}
|
||||
deplibs = [ RemoveDups $(deplibs) ] ;
|
||||
Depends staticplugins : $(deplibs) ;
|
||||
}
|
||||
Help staticplugins :
|
||||
"Build the library with static versions of all plugins" ;
|
||||
Depends staticplugins : libs $(name) ;
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
|
||||
# Write out CFLAGS, LFLAGS needed by a plugin
|
||||
rule WriteDependencies
|
||||
{
|
||||
local cflags ;
|
||||
local lflags ;
|
||||
local depfile = $(<) ;
|
||||
local plugin = $(>) ;
|
||||
local name = $(3) ;
|
||||
local depfile_gristed = $(depfile:G=$(plugin)) ;
|
||||
MakeLocate $(depfile_gristed) : [ on $(depfile) GetVar LOCATE ] ;
|
||||
|
||||
# Collect flags
|
||||
lflags += -l$(name) ;
|
||||
local libs = [ ResolveLibs $($(plugin).NEEDLIBS) ] ;
|
||||
lflags += -l$(libs) ;
|
||||
|
||||
local l ;
|
||||
for l in $($(plugin).EXTERNALLIBS)
|
||||
{
|
||||
cflags += $($(l).CFLAGS) ;
|
||||
lflags += [ Filter $($(l).LFLAGS) : $(LINKLIBS) $(PLUGIN.LFLAGS) ] ;
|
||||
}
|
||||
lflags += [ Filter $($(plugin).LFLAGS) : $(LINKLIBS) $(PLUGIN.LFLAGS) ] ;
|
||||
CFLAGS on $(depfile_gristed) = "$(cflags)" ;
|
||||
LFLAGS on $(depfile_gristed) = "$(lflags)" ;
|
||||
|
||||
if $($(depfile).FIRSTTIME) != "yes"
|
||||
{
|
||||
WriteDepFlags1 $(depfile_gristed) : $(plugin) ;
|
||||
$(depfile).FIRSTTIME = "yes" ;
|
||||
}
|
||||
else
|
||||
{
|
||||
WriteDepFlags2 $(depfile_gristed) : $(plugin) ;
|
||||
}
|
||||
Depends $(depfile) : $(depfile_gristed) ;
|
||||
}
|
||||
|
||||
actions WriteDepFlags1
|
||||
{
|
||||
cat << EOT > $(<)
|
||||
STATICPLUGINS.AVAILABLE += $(>) ;
|
||||
STATICPLUGIN.$(>).CFLAGS = $(CFLAGS) ;
|
||||
STATICPLUGIN.$(>).LFLAGS = $(LFLAGS) ;
|
||||
EOT
|
||||
}
|
||||
|
||||
actions WriteDepFlags2
|
||||
{
|
||||
cat << EOT >> $(<)
|
||||
STATICPLUGINS.AVAILABLE += $(>) ;
|
||||
STATICPLUGIN.$(>).CFLAGS = $(CFLAGS) ;
|
||||
STATICPLUGIN.$(>).LFLAGS = $(LFLAGS) ;
|
||||
EOT
|
||||
}
|
||||
|
||||
actions piecemeal GenerateStaticPluginRegistration1
|
||||
{
|
||||
echo 'namespace csStaticPluginInit' >> $(<)
|
||||
echo '{' >> $(<)
|
||||
for x in $(>)
|
||||
do
|
||||
n=`basename $x $(SUFMETA)`
|
||||
echo "static char const metainfo_${n}[] =" >> $(<)
|
||||
$(SED) 's:\\:\\\\:g;s:":\\":g;s:\(.*\):"\1":' < $x >>$(<)
|
||||
echo ";" >> $(<)
|
||||
$(SED) '/<implementation>/!d;s:[ ]*<implementation>\(..*\)</implementation>: #ifndef \1_FACTORY_REGISTER_DEFINED \
|
||||
#define \1_FACTORY_REGISTER_DEFINED \
|
||||
SCF_DEFINE_FACTORY_FUNC_REGISTRATION(\1) \
|
||||
#endif:g' < $x >> $(<)
|
||||
done
|
||||
echo '' >> $(<)
|
||||
for x in $(>)
|
||||
do
|
||||
n=`basename $x $(SUFMETA)`
|
||||
echo "class ${n}" >> $(<)
|
||||
echo "{" >> $(<)
|
||||
echo "SCF_REGISTER_STATIC_LIBRARY($n,metainfo_${n})" >>$(<)
|
||||
$(SED) '/<implementation>/!d;s:[ ]*<implementation>\(..*\)</implementation>: #ifndef \1_FACTORY_REGISTERED \
|
||||
#define \1_FACTORY_REGISTERED \
|
||||
\1_StaticInit \1_static_init__; \
|
||||
#endif:g' < $x >> $(<)
|
||||
echo "public:" >> $(<)
|
||||
echo " ${n}();" >> $(<)
|
||||
echo "};" >> $(<)
|
||||
echo "$n::$n() {}" >> $(<)
|
||||
echo "" >> $(<)
|
||||
done
|
||||
echo '}' >> $(<)
|
||||
}
|
||||
|
||||
36
mk/jam/strip.jam
Normal file
36
mk/jam/strip.jam
Normal file
@@ -0,0 +1,36 @@
|
||||
#============================================================================
|
||||
# Rules for stripping binaries
|
||||
# Copyright (C)2006 by Frank Richter
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
## SplitDebugInfo binary
|
||||
## Strips the debugging information into a separate external file.
|
||||
rule SplitDebugInfo
|
||||
{
|
||||
local binary = $(1) ;
|
||||
DoSplitDebugInfo $(binary) ;
|
||||
return $(binary).dbg ;
|
||||
}
|
||||
|
||||
actions DoSplitDebugInfo
|
||||
{
|
||||
$(CMD.OBJCOPY) --only-keep-debug $(<) $(<).dbg
|
||||
$(CMD.OBJCOPY) --strip-unneeded $(<)
|
||||
$(CMD.OBJCOPY) --add-gnu-debuglink=$(<).dbg $(<)
|
||||
if [ "$(CHMOD)" ] ; then $(CHMOD) a-x $(<).dbg ; fi
|
||||
}
|
||||
@@ -1,109 +1,109 @@
|
||||
#============================================================================
|
||||
# Work around problems the SubDir rule of Jambase
|
||||
# (until jampeople accept my patches :-/ )
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
LOCATE.OBJECTS ?= $(BUILDTOP)/out/$(OSFULL[1]:L) ;
|
||||
LOCATE.TARGETS ?= $(BUILDTOP) ;
|
||||
LOCATE.DOCS ?= $(BUILDTOP)/out/docs ;
|
||||
|
||||
SUBDIRRULES += FixSubDirPath ;
|
||||
|
||||
CMD.MKDIR ?= mkdir ;
|
||||
CMD.MKDIRS ?= "$(CMD.MKDIR) -p" ;
|
||||
|
||||
rule FixSubDirPath
|
||||
{
|
||||
LOCATE_SOURCE = [ FDirName $(LOCATE.OBJECTS) $(SUBDIR_TOKENS) ] ;
|
||||
LOCATE_TARGET = [ FDirName $(LOCATE.OBJECTS) $(SUBDIR_TOKENS) ] ;
|
||||
}
|
||||
|
||||
# Fix bug in Jambase where SubInclude in the middle of a Jamfile made it break.
|
||||
rule SubInclude
|
||||
{
|
||||
if ! $($(<[1]))
|
||||
{
|
||||
Exit SubInclude $(<[1]) without prior SubDir $(<[1]) ;
|
||||
}
|
||||
|
||||
local save_SUBDIR_TOKENS = $(SUBDIR_TOKENS) ;
|
||||
|
||||
SubDir $(<) ;
|
||||
|
||||
include $(JAMFILE:D=$(SUBDIR)) ;
|
||||
|
||||
SubDir $(<[1]) $(save_SUBDIR_TOKENS) ;
|
||||
}
|
||||
|
||||
# This MakeLocate rule differs from the Jambase one in that it also works with
|
||||
# files being in subdirectories.
|
||||
rule MakeLocate
|
||||
{
|
||||
# MakeLocate targets : directory ;
|
||||
|
||||
# Sets special variable LOCATE on targets, and arranges
|
||||
# with MkDir to create target directory.
|
||||
|
||||
# Note we grist the directory name with 'dir',
|
||||
# so that directory path components and other
|
||||
# targets don't conflict.
|
||||
|
||||
if $(>) && $(>) != ""
|
||||
{
|
||||
local i ;
|
||||
for i in $(<)
|
||||
{
|
||||
LOCATE on $(i) = $(>) ;
|
||||
|
||||
local targetfile = $(i:R=$(>)) ;
|
||||
local targetdir = $(targetfile:D) ;
|
||||
if ! $(targetdir) { targetdir = "." ; }
|
||||
targetdir = $(targetdir:G=dir) ;
|
||||
Depends $(i) : $(targetdir) ;
|
||||
MkDir $(targetdir) ;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
# The default MkDir rule in Jambase has problems when paths contains a sequence
|
||||
# of multiple slashes (ie. bla////fup). We solve these problems and greatly
|
||||
# simply this rule by using the "mkdir -p" or mkdirs command.
|
||||
rule MkDir
|
||||
{
|
||||
# MkDir directory ;
|
||||
|
||||
# Make a directory and all its parent directories.
|
||||
|
||||
# Ignore timestamps on directories: we only care if they
|
||||
# exist.
|
||||
|
||||
NoUpdate $(<) ;
|
||||
|
||||
# don't create the dir multiple times
|
||||
if ! $($(<)-mkdir)
|
||||
{
|
||||
$(<)-mkdir = true ;
|
||||
MkDir1 $(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
actions MkDir1
|
||||
{
|
||||
$(CMD.MKDIRS) "$(<)"
|
||||
}
|
||||
#============================================================================
|
||||
# Work around problems the SubDir rule of Jambase
|
||||
# (until jampeople accept my patches :-/ )
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
LOCATE.OBJECTS ?= $(BUILDTOP)/out/$(OSFULL[1]:L) ;
|
||||
LOCATE.TARGETS ?= $(BUILDTOP) ;
|
||||
LOCATE.DOCS ?= $(BUILDTOP)/out/docs ;
|
||||
|
||||
SUBDIRRULES += FixSubDirPath ;
|
||||
|
||||
CMD.MKDIR ?= mkdir ;
|
||||
CMD.MKDIRS ?= "$(CMD.MKDIR) -p" ;
|
||||
|
||||
rule FixSubDirPath
|
||||
{
|
||||
LOCATE_SOURCE = [ FDirName $(LOCATE.OBJECTS) $(SUBDIR_TOKENS) ] ;
|
||||
LOCATE_TARGET = [ FDirName $(LOCATE.OBJECTS) $(SUBDIR_TOKENS) ] ;
|
||||
}
|
||||
|
||||
# Fix bug in Jambase where SubInclude in the middle of a Jamfile made it break.
|
||||
rule SubInclude
|
||||
{
|
||||
if ! $($(<[1]))
|
||||
{
|
||||
Exit SubInclude $(<[1]) without prior SubDir $(<[1]) ;
|
||||
}
|
||||
|
||||
local save_SUBDIR_TOKENS = $(SUBDIR_TOKENS) ;
|
||||
|
||||
SubDir $(<) ;
|
||||
|
||||
include $(JAMFILE:D=$(SUBDIR)) ;
|
||||
|
||||
SubDir $(<[1]) $(save_SUBDIR_TOKENS) ;
|
||||
}
|
||||
|
||||
# This MakeLocate rule differs from the Jambase one in that it also works with
|
||||
# files being in subdirectories.
|
||||
rule MakeLocate
|
||||
{
|
||||
# MakeLocate targets : directory ;
|
||||
|
||||
# Sets special variable LOCATE on targets, and arranges
|
||||
# with MkDir to create target directory.
|
||||
|
||||
# Note we grist the directory name with 'dir',
|
||||
# so that directory path components and other
|
||||
# targets don't conflict.
|
||||
|
||||
if $(>) && $(>) != ""
|
||||
{
|
||||
local i ;
|
||||
for i in $(<)
|
||||
{
|
||||
LOCATE on $(i) = $(>) ;
|
||||
|
||||
local targetfile = $(i:R=$(>)) ;
|
||||
local targetdir = $(targetfile:D) ;
|
||||
if ! $(targetdir) { targetdir = "." ; }
|
||||
targetdir = $(targetdir:G=dir) ;
|
||||
Depends $(i) : $(targetdir) ;
|
||||
MkDir $(targetdir) ;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
# The default MkDir rule in Jambase has problems when paths contains a sequence
|
||||
# of multiple slashes (ie. bla////fup). We solve these problems and greatly
|
||||
# simply this rule by using the "mkdir -p" or mkdirs command.
|
||||
rule MkDir
|
||||
{
|
||||
# MkDir directory ;
|
||||
|
||||
# Make a directory and all its parent directories.
|
||||
|
||||
# Ignore timestamps on directories: we only care if they
|
||||
# exist.
|
||||
|
||||
NoUpdate $(<) ;
|
||||
|
||||
# don't create the dir multiple times
|
||||
if ! $($(<)-mkdir)
|
||||
{
|
||||
$(<)-mkdir = true ;
|
||||
MkDir1 $(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
actions MkDir1
|
||||
{
|
||||
$(CMD.MKDIRS) "$(<)"
|
||||
}
|
||||
|
||||
450
mk/jam/swig.jam
450
mk/jam/swig.jam
@@ -1,225 +1,225 @@
|
||||
#============================================================================
|
||||
# Rules for swig
|
||||
# Copyright (C)2004 by Eric Sunshine <sunshine@sunshineco.com>
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
if $(CMD.SWIG)
|
||||
{
|
||||
# Post-processing of the Swig-generated C++ file.
|
||||
#
|
||||
# (1) We need to ensure that <stdint.h> defines INT64_C() and cousins, which
|
||||
# means that the __STDC_CONSTANT_MACROS and __STDC_LIMIT_MACROS macros must
|
||||
# be defined before <stdint.h> is included. In some Python installations,
|
||||
# Python.h includes <stdint.h>, and Swig-generated output includes Python.h
|
||||
# before we ever have a chance to define the __STDC_* macros. There is no
|
||||
# Swig-supported mechanism allowing us to insert these #defines before
|
||||
# Python.h is included, so we post-process the output file.
|
||||
#
|
||||
# (2) We #undefine _DEBUG, to ensure that python23.lib is used by MSVC
|
||||
# instead of python23_d.lib.
|
||||
#
|
||||
# (3) Delete any lines containing the CVS `Header' keyword to ensure that CVS
|
||||
# does not consider the file changed simply because `Header' expansion
|
||||
# differs.
|
||||
#
|
||||
# (4) Swig 1.3.22 for Perl emits illegal expressions `new (sometype)[n]'
|
||||
# rather than `new sometype[n]' (at least gcc considers it illegal),
|
||||
# therefore, we transform the expression by dropping the parentheses.
|
||||
#
|
||||
# (5) cs_pyth.cpp contains a macro "#define SWIG_init init_cspace". However,
|
||||
# cs_pyth.cpp may reside in a shared lib, so we rather want the name
|
||||
# SWIG_init and define init_cspace as a simple forwared ourselves.
|
||||
#
|
||||
# (6) perl.h includes dirent.h on some configurations which conflicts with
|
||||
# the CS definitions of dirent, opendir, etc. So define _DIRENT_H_ to
|
||||
# make dirent.h skip its body. This is hackish but no better solution
|
||||
# has been found.
|
||||
#
|
||||
# (Despite the fact that these customizations might seem project-specific,
|
||||
# they should be safe for all projects.)
|
||||
SWIG.SED_SCRIPT =
|
||||
"'s/\\([ ]*#[ ]*include[ ][ ]*[<\"]Python.h[>\"]\\)/\\
|
||||
#ifndef __STDC_CONSTANT_MACROS\\
|
||||
#define __STDC_CONSTANT_MACROS\\
|
||||
#endif\\
|
||||
#ifndef __STDC_LIMIT_MACROS\\
|
||||
#define __STDC_LIMIT_MACROS\\
|
||||
#endif\\
|
||||
#ifndef DEBUG_PYTHON\\
|
||||
#undef _DEBUG\\
|
||||
#endif\\
|
||||
\\1/g
|
||||
/\$Header:/d
|
||||
s/new[ ][ ]*(\\([^)][^)]*\\))[ ]*\\[/new \\1 [/g
|
||||
s/[ ]*#[ ]*define[ ][ ]*SWIG_init[ ]*init_\\(.*\\)/#define SWIG_init SWIG_init_\\1/g
|
||||
s/\\([ ]*#[ ]*include[ ][ ]*[<\"]perl.h[>\"]\\)/\\
|
||||
#ifndef _DIRENT_H_\\
|
||||
#define _DIRENT_H_\\
|
||||
#endif\\
|
||||
\\1/g'" ;
|
||||
|
||||
## Swig targets : swigfile : language [ : swigflags [ : swigincdirs
|
||||
## [ : swigfiledir [ : frozendirs [ : tag [ : outdir ]]]]]]
|
||||
## Given a Swig input file `swigfile', generate `targets' for scripting
|
||||
## language `language'. The first element of `targets' should name the
|
||||
## generated C or C++ file, and the remaining optional elements should name
|
||||
## any other language-specific scripting files which Swig will generate.
|
||||
## For instance, the files widgets.cpp and widgets.py might be emitted by
|
||||
## Swig for the input file widgets.i. The generated files are placed in
|
||||
## $(LOCATE_TARGET). `swigflags' specifies additional flags to pass to
|
||||
## Swig. `swigincdirs' is a list of additional directories which Swig
|
||||
## should search for files which it includes. `swigfiledir' specifies the
|
||||
## location of `swigfile' if it does not reside in the present source
|
||||
## directory. This rule defines top-level targets named "$(tag)swig",
|
||||
## which generates `targets' on-demand; and "$(tag)swigclean", which
|
||||
## deletes the generated files. `tag' is a simple identifier out of which
|
||||
## top-level pseudo-targets names are constructed. If `tag' is not
|
||||
## provided, then `language' is used instead. If `frozentargdirs' is
|
||||
## provided, then an additional top-level target named "$(tag)freeze" is
|
||||
## defined, which copies the generated files to the specified directories.
|
||||
## If `frozentargdirs' contains only one element, then all generated files
|
||||
## are copied to that directory. If it contains two elements, then the
|
||||
## first element of `targets' is copied to the first element of
|
||||
## `frozentargdirs', and all remaining elements of `targets' are copied to
|
||||
## the second element of `frozentargdirs'. `outdir', if provided, is a list
|
||||
## of path components which specify a subdirectory in which Swig should
|
||||
## place the language-specific support files, rather than placing them in
|
||||
## $(LOCATE_TARGET). This might be useful, for instance, when Swig is in
|
||||
## Java mode, and the .java files must be placed in a directory hierarchy
|
||||
## which reflects the full package name.
|
||||
rule Swig
|
||||
{
|
||||
local target = $(1[1]) ;
|
||||
local othertargets = $(1[2-]) ;
|
||||
local swigfile = $(2) ;
|
||||
local language = $(3) ;
|
||||
local swigflags = $(4) ;
|
||||
local swigincdirs = $(5) ;
|
||||
local swigfiledir = $(6) ;
|
||||
local frozentargetdir = $(7[1]) ;
|
||||
local frozenotherdir = $(7[2-]) ;
|
||||
local tag = $(8) ;
|
||||
local outdir = $(9) ;
|
||||
|
||||
if ! $(frozenotherdir) { frozenotherdir = $(frozentargetdir) ; }
|
||||
if ! $(tag) { tag = $(language) ; }
|
||||
if ! $(outdir) { outdir = $(LOCATE_TARGET) ; }
|
||||
|
||||
Depends $(target) : $(swigfile) ;
|
||||
MakeLocate $(target) : $(LOCATE_TARGET) ;
|
||||
if $(othertargets)
|
||||
{
|
||||
MakeLocate $(othertargets) : $(outdir) ;
|
||||
|
||||
# If any target, such as an install target, depends upon the other files,
|
||||
# we force them to be built with a dependency upon the target.
|
||||
Depends $(othertargets) : $(target) ;
|
||||
}
|
||||
|
||||
SWIG.FLAGS on $(target) +=
|
||||
$(SWIG.FLAGS) -$(language) $(swigflags) -I$(swigincdirs)
|
||||
-outdir [ ConcatDirs $(outdir) ] ;
|
||||
|
||||
# Allow Swig input file to reside at location other than $(SEARCH_SOURCE).
|
||||
if $(swigfiledir)
|
||||
{
|
||||
SEARCH on $(swigfile) = $(swigfiledir) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
SEARCH on $(swigfile) = $(SEARCH_SOURCE) ;
|
||||
}
|
||||
|
||||
# Scan for special Swig includes.
|
||||
HDRGRIST on $(swigfile) = $(HDRGRIST) ;
|
||||
HDRSEARCH on $(swigfile) =
|
||||
$(SEARCH_SOURCE:E) $(SUBDIRHDRS) $(HDRS) $(STDHDRS) ;
|
||||
HDRRULE on $(swigfile) = HeaderRule ;
|
||||
HDRSCAN on $(swigfile) = $(SWIG.HDRPATTERN) ;
|
||||
|
||||
RunSwig $(target) : $(swigfile) ;
|
||||
Depends $(tag)swig : $(target) ;
|
||||
NotFile $(tag)swig ;
|
||||
Always $(tag)swig ;
|
||||
Help $(tag)swig : "Generate Swig files for $(tag)" ;
|
||||
|
||||
Clean $(tag)swigclean : $(target) $(othertargets) ;
|
||||
Depends clean : $(tag)swigclean ;
|
||||
|
||||
if $(frozentargetdir)
|
||||
{
|
||||
local frozen_target = $(target:G=$(tag)freeze) ;
|
||||
MakeLocate $(frozen_target) : $(frozentargetdir) ;
|
||||
Depends $(frozen_target) : $(target) ;
|
||||
Copy $(frozen_target) : $(target) ;
|
||||
Depends $(tag)freeze : $(frozen_target) ;
|
||||
|
||||
if $(othertargets)
|
||||
{
|
||||
local frozen_other = $(othertargets:G=$(tag)freeze) ;
|
||||
MakeLocate $(frozen_other) : $(frozenotherdir) ;
|
||||
Depends $(frozen_other) : $(othertargets) ;
|
||||
Copy $(frozen_other) : $(othertargets) ;
|
||||
Depends $(tag)freeze : $(frozen_other) ;
|
||||
}
|
||||
|
||||
NotFile $(tag)freeze ;
|
||||
Help $(tag)freeze : "Copy generated Swig files to source directory" ;
|
||||
}
|
||||
}
|
||||
|
||||
actions RunSwig
|
||||
{
|
||||
$(CMD.SWIG) $(SWIG.FLAGS) -o $(<) $(>)
|
||||
$(SED) $(SWIG.SED_SCRIPT) < $(<) > $(<).sed
|
||||
$(RM) $(<)
|
||||
$(MV) $(<).sed $(<)
|
||||
}
|
||||
|
||||
SWIG.SIMPLE.LANGUAGE ?= python ;
|
||||
SWIG.SIMPLE.EXT ?= py ;
|
||||
SWIG.SIMPLE.FLAGS ?= -c++ -shadow ;
|
||||
|
||||
## SimpleSwig swigfile
|
||||
## Given a Swig input file (.i), invokes Swig to generate a .cpp file with
|
||||
## the same basename, and a script file with the same basename.
|
||||
## SWIG.SIMPLE.LANGUAGE specifies the language for which Swig should emit a
|
||||
## binding; SWIG.SIMPLE.EXT indicates the file extension of the generated
|
||||
## script file; SWIG.SIMPLE.FLAGS specifies additional flags for Swig.
|
||||
rule SimpleSwig
|
||||
{
|
||||
local object = [ DoObjectGrist $(<:S=$(SUFOBJ)) ] ;
|
||||
local cppfile = $(<:S=.cpp) ;
|
||||
local script = $(<:S=.$(SWIG.SIMPLE.EXT)) ;
|
||||
|
||||
C++ $(object) : $(cppfile) ;
|
||||
Swig $(cppfile) $(script) : $(<) : $(SWIG.SIMPLE.LANGUAGE) :
|
||||
$(SWIG.SIMPLE.FLAGS) ;
|
||||
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType SimpleSwig : .i ;
|
||||
|
||||
if ! $(NO_SWIG_HEADER_SCANNING)
|
||||
{
|
||||
SWIG.HDRPATTERN =
|
||||
"^[ ]*[%#][ ]*include[ ]*[<\"]([^\">]*)[\">].*$" ;
|
||||
RegisterHeaderRule HeaderRule : $(SWIG.HDRPATTERN) : .i ;
|
||||
}
|
||||
}
|
||||
#============================================================================
|
||||
# Rules for swig
|
||||
# Copyright (C)2004 by Eric Sunshine <sunshine@sunshineco.com>
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
if $(CMD.SWIG)
|
||||
{
|
||||
# Post-processing of the Swig-generated C++ file.
|
||||
#
|
||||
# (1) We need to ensure that <stdint.h> defines INT64_C() and cousins, which
|
||||
# means that the __STDC_CONSTANT_MACROS and __STDC_LIMIT_MACROS macros must
|
||||
# be defined before <stdint.h> is included. In some Python installations,
|
||||
# Python.h includes <stdint.h>, and Swig-generated output includes Python.h
|
||||
# before we ever have a chance to define the __STDC_* macros. There is no
|
||||
# Swig-supported mechanism allowing us to insert these #defines before
|
||||
# Python.h is included, so we post-process the output file.
|
||||
#
|
||||
# (2) We #undefine _DEBUG, to ensure that python23.lib is used by MSVC
|
||||
# instead of python23_d.lib.
|
||||
#
|
||||
# (3) Delete any lines containing the CVS `Header' keyword to ensure that CVS
|
||||
# does not consider the file changed simply because `Header' expansion
|
||||
# differs.
|
||||
#
|
||||
# (4) Swig 1.3.22 for Perl emits illegal expressions `new (sometype)[n]'
|
||||
# rather than `new sometype[n]' (at least gcc considers it illegal),
|
||||
# therefore, we transform the expression by dropping the parentheses.
|
||||
#
|
||||
# (5) cs_pyth.cpp contains a macro "#define SWIG_init init_cspace". However,
|
||||
# cs_pyth.cpp may reside in a shared lib, so we rather want the name
|
||||
# SWIG_init and define init_cspace as a simple forwared ourselves.
|
||||
#
|
||||
# (6) perl.h includes dirent.h on some configurations which conflicts with
|
||||
# the CS definitions of dirent, opendir, etc. So define _DIRENT_H_ to
|
||||
# make dirent.h skip its body. This is hackish but no better solution
|
||||
# has been found.
|
||||
#
|
||||
# (Despite the fact that these customizations might seem project-specific,
|
||||
# they should be safe for all projects.)
|
||||
SWIG.SED_SCRIPT =
|
||||
"'s/\\([ ]*#[ ]*include[ ][ ]*[<\"]Python.h[>\"]\\)/\\
|
||||
#ifndef __STDC_CONSTANT_MACROS\\
|
||||
#define __STDC_CONSTANT_MACROS\\
|
||||
#endif\\
|
||||
#ifndef __STDC_LIMIT_MACROS\\
|
||||
#define __STDC_LIMIT_MACROS\\
|
||||
#endif\\
|
||||
#ifndef DEBUG_PYTHON\\
|
||||
#undef _DEBUG\\
|
||||
#endif\\
|
||||
\\1/g
|
||||
/\$Header:/d
|
||||
s/new[ ][ ]*(\\([^)][^)]*\\))[ ]*\\[/new \\1 [/g
|
||||
s/[ ]*#[ ]*define[ ][ ]*SWIG_init[ ]*init_\\(.*\\)/#define SWIG_init SWIG_init_\\1/g
|
||||
s/\\([ ]*#[ ]*include[ ][ ]*[<\"]perl.h[>\"]\\)/\\
|
||||
#ifndef _DIRENT_H_\\
|
||||
#define _DIRENT_H_\\
|
||||
#endif\\
|
||||
\\1/g'" ;
|
||||
|
||||
## Swig targets : swigfile : language [ : swigflags [ : swigincdirs
|
||||
## [ : swigfiledir [ : frozendirs [ : tag [ : outdir ]]]]]]
|
||||
## Given a Swig input file `swigfile', generate `targets' for scripting
|
||||
## language `language'. The first element of `targets' should name the
|
||||
## generated C or C++ file, and the remaining optional elements should name
|
||||
## any other language-specific scripting files which Swig will generate.
|
||||
## For instance, the files widgets.cpp and widgets.py might be emitted by
|
||||
## Swig for the input file widgets.i. The generated files are placed in
|
||||
## $(LOCATE_TARGET). `swigflags' specifies additional flags to pass to
|
||||
## Swig. `swigincdirs' is a list of additional directories which Swig
|
||||
## should search for files which it includes. `swigfiledir' specifies the
|
||||
## location of `swigfile' if it does not reside in the present source
|
||||
## directory. This rule defines top-level targets named "$(tag)swig",
|
||||
## which generates `targets' on-demand; and "$(tag)swigclean", which
|
||||
## deletes the generated files. `tag' is a simple identifier out of which
|
||||
## top-level pseudo-targets names are constructed. If `tag' is not
|
||||
## provided, then `language' is used instead. If `frozentargdirs' is
|
||||
## provided, then an additional top-level target named "$(tag)freeze" is
|
||||
## defined, which copies the generated files to the specified directories.
|
||||
## If `frozentargdirs' contains only one element, then all generated files
|
||||
## are copied to that directory. If it contains two elements, then the
|
||||
## first element of `targets' is copied to the first element of
|
||||
## `frozentargdirs', and all remaining elements of `targets' are copied to
|
||||
## the second element of `frozentargdirs'. `outdir', if provided, is a list
|
||||
## of path components which specify a subdirectory in which Swig should
|
||||
## place the language-specific support files, rather than placing them in
|
||||
## $(LOCATE_TARGET). This might be useful, for instance, when Swig is in
|
||||
## Java mode, and the .java files must be placed in a directory hierarchy
|
||||
## which reflects the full package name.
|
||||
rule Swig
|
||||
{
|
||||
local target = $(1[1]) ;
|
||||
local othertargets = $(1[2-]) ;
|
||||
local swigfile = $(2) ;
|
||||
local language = $(3) ;
|
||||
local swigflags = $(4) ;
|
||||
local swigincdirs = $(5) ;
|
||||
local swigfiledir = $(6) ;
|
||||
local frozentargetdir = $(7[1]) ;
|
||||
local frozenotherdir = $(7[2-]) ;
|
||||
local tag = $(8) ;
|
||||
local outdir = $(9) ;
|
||||
|
||||
if ! $(frozenotherdir) { frozenotherdir = $(frozentargetdir) ; }
|
||||
if ! $(tag) { tag = $(language) ; }
|
||||
if ! $(outdir) { outdir = $(LOCATE_TARGET) ; }
|
||||
|
||||
Depends $(target) : $(swigfile) ;
|
||||
MakeLocate $(target) : $(LOCATE_TARGET) ;
|
||||
if $(othertargets)
|
||||
{
|
||||
MakeLocate $(othertargets) : $(outdir) ;
|
||||
|
||||
# If any target, such as an install target, depends upon the other files,
|
||||
# we force them to be built with a dependency upon the target.
|
||||
Depends $(othertargets) : $(target) ;
|
||||
}
|
||||
|
||||
SWIG.FLAGS on $(target) +=
|
||||
$(SWIG.FLAGS) -$(language) $(swigflags) -I$(swigincdirs)
|
||||
-outdir [ ConcatDirs $(outdir) ] ;
|
||||
|
||||
# Allow Swig input file to reside at location other than $(SEARCH_SOURCE).
|
||||
if $(swigfiledir)
|
||||
{
|
||||
SEARCH on $(swigfile) = $(swigfiledir) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
SEARCH on $(swigfile) = $(SEARCH_SOURCE) ;
|
||||
}
|
||||
|
||||
# Scan for special Swig includes.
|
||||
HDRGRIST on $(swigfile) = $(HDRGRIST) ;
|
||||
HDRSEARCH on $(swigfile) =
|
||||
$(SEARCH_SOURCE:E) $(SUBDIRHDRS) $(HDRS) $(STDHDRS) ;
|
||||
HDRRULE on $(swigfile) = HeaderRule ;
|
||||
HDRSCAN on $(swigfile) = $(SWIG.HDRPATTERN) ;
|
||||
|
||||
RunSwig $(target) : $(swigfile) ;
|
||||
Depends $(tag)swig : $(target) ;
|
||||
NotFile $(tag)swig ;
|
||||
Always $(tag)swig ;
|
||||
Help $(tag)swig : "Generate Swig files for $(tag)" ;
|
||||
|
||||
Clean $(tag)swigclean : $(target) $(othertargets) ;
|
||||
Depends clean : $(tag)swigclean ;
|
||||
|
||||
if $(frozentargetdir)
|
||||
{
|
||||
local frozen_target = $(target:G=$(tag)freeze) ;
|
||||
MakeLocate $(frozen_target) : $(frozentargetdir) ;
|
||||
Depends $(frozen_target) : $(target) ;
|
||||
Copy $(frozen_target) : $(target) ;
|
||||
Depends $(tag)freeze : $(frozen_target) ;
|
||||
|
||||
if $(othertargets)
|
||||
{
|
||||
local frozen_other = $(othertargets:G=$(tag)freeze) ;
|
||||
MakeLocate $(frozen_other) : $(frozenotherdir) ;
|
||||
Depends $(frozen_other) : $(othertargets) ;
|
||||
Copy $(frozen_other) : $(othertargets) ;
|
||||
Depends $(tag)freeze : $(frozen_other) ;
|
||||
}
|
||||
|
||||
NotFile $(tag)freeze ;
|
||||
Help $(tag)freeze : "Copy generated Swig files to source directory" ;
|
||||
}
|
||||
}
|
||||
|
||||
actions RunSwig
|
||||
{
|
||||
$(CMD.SWIG) $(SWIG.FLAGS) -o $(<) $(>)
|
||||
$(SED) $(SWIG.SED_SCRIPT) < $(<) > $(<).sed
|
||||
$(RM) $(<)
|
||||
$(MV) $(<).sed $(<)
|
||||
}
|
||||
|
||||
SWIG.SIMPLE.LANGUAGE ?= python ;
|
||||
SWIG.SIMPLE.EXT ?= py ;
|
||||
SWIG.SIMPLE.FLAGS ?= -c++ -shadow ;
|
||||
|
||||
## SimpleSwig swigfile
|
||||
## Given a Swig input file (.i), invokes Swig to generate a .cpp file with
|
||||
## the same basename, and a script file with the same basename.
|
||||
## SWIG.SIMPLE.LANGUAGE specifies the language for which Swig should emit a
|
||||
## binding; SWIG.SIMPLE.EXT indicates the file extension of the generated
|
||||
## script file; SWIG.SIMPLE.FLAGS specifies additional flags for Swig.
|
||||
rule SimpleSwig
|
||||
{
|
||||
local object = [ DoObjectGrist $(<:S=$(SUFOBJ)) ] ;
|
||||
local cppfile = $(<:S=.cpp) ;
|
||||
local script = $(<:S=.$(SWIG.SIMPLE.EXT)) ;
|
||||
|
||||
C++ $(object) : $(cppfile) ;
|
||||
Swig $(cppfile) $(script) : $(<) : $(SWIG.SIMPLE.LANGUAGE) :
|
||||
$(SWIG.SIMPLE.FLAGS) ;
|
||||
|
||||
return $(object) ;
|
||||
}
|
||||
RegisterFileType SimpleSwig : .i ;
|
||||
|
||||
if ! $(NO_SWIG_HEADER_SCANNING)
|
||||
{
|
||||
SWIG.HDRPATTERN =
|
||||
"^[ ]*[%#][ ]*include[ ]*[<\"]([^\">]*)[\">].*$" ;
|
||||
RegisterHeaderRule HeaderRule : $(SWIG.HDRPATTERN) : .i ;
|
||||
}
|
||||
}
|
||||
|
||||
1152
mk/jam/unittest.jam
1152
mk/jam/unittest.jam
File diff suppressed because it is too large
Load Diff
310
mk/jam/unix.jam
310
mk/jam/unix.jam
@@ -1,151 +1,159 @@
|
||||
#============================================================================
|
||||
# Jam configuration and actions for Unix (GNU/Linux, BSD, Darwin, etc.)
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
SHELL ?= "/bin/sh" ;
|
||||
|
||||
# Only use nasm on x86 for now...
|
||||
NASM.FLAGS += -f elf ;
|
||||
|
||||
PLUGIN.CFLAGS += $(COMPILER.C++FLAGS.PIC) ;
|
||||
LIBRARY.CFLAGS += $(COMPILER.C++FLAGS.PIC) ;
|
||||
|
||||
# The BFD tag name under which to embed meta-information into a plugin module.
|
||||
# This much match the name expected by csGetPluginMetadata() (bfdplugins.cpp).
|
||||
SECTION_TAG_NAME ?= .crystalspace ;
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# platform specific rules
|
||||
|
||||
## ConstructApplicationTarget target : options
|
||||
## Constructs the application target name (ie. foo.exe for foo)
|
||||
rule ConstructApplicationTarget
|
||||
{
|
||||
return $(<) ;
|
||||
}
|
||||
rule ConstructStaticLibraryTarget
|
||||
{
|
||||
return lib$(<)$(SUFLIB) ;
|
||||
}
|
||||
rule ConstructSharedLibraryTarget
|
||||
{
|
||||
return lib$(<).so.$(PACKAGE_VERSION) ;
|
||||
}
|
||||
rule ConstructSharedLibraryLinkLib
|
||||
{
|
||||
return lib$(<).so.$(PACKAGE_VERSION) ;
|
||||
}
|
||||
rule ConstructPluginTarget
|
||||
{
|
||||
return $(<).so ;
|
||||
}
|
||||
|
||||
# SystemLinkApplication target : objects : options
|
||||
# do system specific actions needed for linking the application and construct
|
||||
# correct clean targets.
|
||||
rule SystemLinkApplication
|
||||
{
|
||||
local target = $($(<)_TARGET) ;
|
||||
|
||||
Depends $(target) : $(>) ;
|
||||
LinkApplication $(target) : $(>) ;
|
||||
# setup clean rules
|
||||
Clean clean : $(target) ;
|
||||
Clean $(<)clean : $(target) ;
|
||||
}
|
||||
|
||||
rule SystemInstallApplication
|
||||
{
|
||||
Depends install_bin :
|
||||
[ DoInstall $(<) : $(bindir) $(2) : $(INSTALL_PROGRAM) ] ;
|
||||
}
|
||||
|
||||
rule SystemInstallPlugin
|
||||
{
|
||||
Depends install_plugin : [ DoInstall $(<) : $(plugindir) $(2) :
|
||||
$(INSTALL_PROGRAM) ] ;
|
||||
}
|
||||
|
||||
# Put the meta data into the object file headers
|
||||
rule ObjTagMetaData
|
||||
{
|
||||
Depends $(<) : $(>) ;
|
||||
}
|
||||
actions ObjTagMetaData
|
||||
{
|
||||
$(CMD.OBJCOPY) --add-section $(SECTION_TAG_NAME)=$(>) $(<)
|
||||
}
|
||||
|
||||
# SystemLinkPlugin target : objects : options
|
||||
# do system specific actions needed for linking the plugin and construct
|
||||
# correct clean targets.
|
||||
rule SystemLinkPlugin
|
||||
{
|
||||
local target = $($(<)_TARGET) ;
|
||||
|
||||
Depends $(target) : $(>) ;
|
||||
LinkPlugin $(target) : $(>) ;
|
||||
if $(EMBED_META) = "yes" && $(OBJCOPY.AVAILABLE) = "yes"
|
||||
{
|
||||
ObjTagMetaData $(target) : $($(<)_METAFILE) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
PluginMetaData $(<) : $($(<)_METAFILE) : $(3) ;
|
||||
}
|
||||
# setup clean rules
|
||||
Clean clean : $(target) ;
|
||||
Clean $(<)clean : $(target) ;
|
||||
}
|
||||
|
||||
rule SystemLinkSharedLibrary
|
||||
{
|
||||
LFlags $(<) : $(LINKLIBS) ;
|
||||
Depends $(<) : $(>) ;
|
||||
LinkSharedLibrary $(<) : $(>) : $(3) ;
|
||||
|
||||
Clean clean : $(<) ;
|
||||
Clean $(<)clean : $(<) ;
|
||||
}
|
||||
|
||||
actions LinkApplication bind NEEDLIBS bind EXTRAOBJECTS
|
||||
{
|
||||
$(CMD.LINK) -o $(<) $(>) $(EXTRAOBJECTS) $(NEEDLIBS) $(LINKLIBS)
|
||||
}
|
||||
|
||||
if $(PLUGIN.LFLAGS.USE_SONAME) = "yes"
|
||||
{
|
||||
actions LinkPlugin bind NEEDLIBS bind EXTRAOBJECTS
|
||||
{
|
||||
$(CMD.LINK) -o $(<) $(>) $(EXTRAOBJECTS) $(NEEDLIBS) $(LINKLIBS) \
|
||||
-Wl,-soname,$(<:BS)
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
actions LinkPlugin bind NEEDLIBS bind EXTRAOBJECTS
|
||||
{
|
||||
$(CMD.LINK) -o $(<) $(>) $(EXTRAOBJECTS) $(NEEDLIBS) $(LINKLIBS)
|
||||
}
|
||||
}
|
||||
|
||||
actions LinkSharedLibrary bind NEEDLIBS bind EXTRAOBJECTS
|
||||
{
|
||||
$(CMD.LINK) -shared -o $(<) $(>) $(EXTRAOBJECTS) $(NEEDLIBS) $(LINKLIBS) \
|
||||
-Wl,-soname,$(<:BS)
|
||||
}
|
||||
#============================================================================
|
||||
# Jam configuration and actions for Unix (GNU/Linux, BSD, Darwin, etc.)
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
SHELL ?= "/bin/sh" ;
|
||||
|
||||
# Only use nasm on x86 for now...
|
||||
NASM.FLAGS += -f elf ;
|
||||
|
||||
PLUGIN.CFLAGS += $(COMPILER.C++FLAGS.PIC) ;
|
||||
LIBRARY.CFLAGS += $(COMPILER.C++FLAGS.PIC) ;
|
||||
|
||||
# The BFD tag name under which to embed meta-information into a plugin module.
|
||||
# This much match the name expected by csGetPluginMetadata() (bfdplugins.cpp).
|
||||
SECTION_TAG_NAME ?= .crystalspace ;
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# platform specific rules
|
||||
|
||||
## ConstructApplicationTarget target : options
|
||||
## Constructs the application target name (ie. foo.exe for foo)
|
||||
rule ConstructApplicationTarget
|
||||
{
|
||||
return $(<) ;
|
||||
}
|
||||
rule ConstructStaticLibraryTarget
|
||||
{
|
||||
return lib$(<)$(SUFLIB) ;
|
||||
}
|
||||
rule ConstructSharedLibraryTarget
|
||||
{
|
||||
return lib$(<).so.$(PACKAGE_VERSION) ;
|
||||
}
|
||||
rule ConstructSharedLibraryLinkLib
|
||||
{
|
||||
return lib$(<).so.$(PACKAGE_VERSION) ;
|
||||
}
|
||||
rule ConstructPluginTarget
|
||||
{
|
||||
return $(<).so ;
|
||||
}
|
||||
|
||||
# SystemLinkApplication target : objects : options
|
||||
# do system specific actions needed for linking the application and construct
|
||||
# correct clean targets.
|
||||
rule SystemLinkApplication
|
||||
{
|
||||
local target = $($(<)_TARGET) ;
|
||||
|
||||
Depends $(target) : $(>) ;
|
||||
LinkApplication $(target) : $(>) ;
|
||||
# setup clean rules
|
||||
Clean clean : $(target) ;
|
||||
Clean $(<)clean : $(target) ;
|
||||
}
|
||||
|
||||
rule SystemInstallApplication
|
||||
{
|
||||
Depends install_bin :
|
||||
[ DoInstall $(<) : $(bindir) $(2) : $(INSTALL_PROGRAM) ] ;
|
||||
}
|
||||
|
||||
rule SystemInstallPlugin
|
||||
{
|
||||
Depends install_plugin : [ DoInstall $(<) : $(plugindir) $(2) :
|
||||
$(INSTALL_PROGRAM) ] ;
|
||||
}
|
||||
|
||||
# Put the meta data into the object file headers
|
||||
rule ObjTagMetaData
|
||||
{
|
||||
Depends $(<) : $(>) ;
|
||||
}
|
||||
actions ObjTagMetaData
|
||||
{
|
||||
$(CMD.OBJCOPY) --add-section $(SECTION_TAG_NAME)=$(>) $(<)
|
||||
}
|
||||
|
||||
# SystemLinkPlugin target : objects : options
|
||||
# do system specific actions needed for linking the plugin and construct
|
||||
# correct clean targets.
|
||||
rule SystemLinkPlugin
|
||||
{
|
||||
local target = $($(<)_TARGET) ;
|
||||
|
||||
Depends $(target) : $(>) ;
|
||||
LinkPlugin $(target) : $(>) ;
|
||||
if $(EMBED_META) = "yes" && $(OBJCOPY.AVAILABLE) = "yes"
|
||||
{
|
||||
ObjTagMetaData $(target) : $($(<)_METAFILE) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
PluginMetaData $(<) : $($(<)_METAFILE) : $(3) ;
|
||||
}
|
||||
# setup clean rules
|
||||
Clean clean : $(target) ;
|
||||
Clean $(<)clean : $(target) ;
|
||||
}
|
||||
|
||||
rule SystemLinkSharedLibrary
|
||||
{
|
||||
LFlags $(<) : $(LINKLIBS) ;
|
||||
Depends $(<) : $(>) ;
|
||||
local response = $(<).resp ;
|
||||
MakeLocate $(response) : $(LOCATE.OBJECTS)/libs ;
|
||||
ResponseFile $(response) : $(>) ;
|
||||
# @@@ FIXME: response files are only supported on newer binutils
|
||||
# But quite useful to avoid blowing jam's 10240 max action length.
|
||||
#Depends $(response) : $(>) ;
|
||||
#Depends $(<) : $(response) ;
|
||||
#LinkSharedLibrary $(<) : $(response) ;
|
||||
LinkSharedLibrary $(<) : $(>) ;
|
||||
|
||||
Clean clean : $(<) ;
|
||||
Clean $(<)clean : $(<) ;
|
||||
}
|
||||
|
||||
actions LinkApplication bind NEEDLIBS bind EXTRAOBJECTS
|
||||
{
|
||||
$(CMD.LINK) -o $(<) $(>) $(EXTRAOBJECTS) $(NEEDLIBS) $(LINKLIBS)
|
||||
}
|
||||
|
||||
if $(PLUGIN.LFLAGS.USE_SONAME) = "yes"
|
||||
{
|
||||
actions LinkPlugin bind NEEDLIBS bind EXTRAOBJECTS
|
||||
{
|
||||
$(CMD.LINK) -o $(<) $(>) $(EXTRAOBJECTS) $(NEEDLIBS) $(LINKLIBS) \
|
||||
-Wl,-soname,$(<:BS)
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
actions LinkPlugin bind NEEDLIBS bind EXTRAOBJECTS
|
||||
{
|
||||
$(CMD.LINK) -o $(<) $(>) $(EXTRAOBJECTS) $(NEEDLIBS) $(LINKLIBS)
|
||||
}
|
||||
}
|
||||
|
||||
actions LinkSharedLibrary bind NEEDLIBS bind EXTRAOBJECTS
|
||||
{
|
||||
$(CMD.LINK) -shared -o $(<) $(>) $(EXTRAOBJECTS) $(NEEDLIBS) $(LINKLIBS) \
|
||||
-Wl,-soname,$(<:BS)
|
||||
}
|
||||
|
||||
@@ -1,58 +1,58 @@
|
||||
#============================================================================
|
||||
# Setup of compiler/linker flags for debug/optimize mode
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
if ! $(VARIANT)
|
||||
{
|
||||
VARIANT = $(MODE) ;
|
||||
}
|
||||
|
||||
if $(VARIANT) != "debug" && $(VARIANT) != "optimize" && $(VARIANT) != "profile"
|
||||
{
|
||||
exit "Invalid modus set, please set VARIANT to debug, profile or optimize" ;
|
||||
}
|
||||
|
||||
# Set modus related flags
|
||||
CCFLAGS += $(COMPILER.CFLAGS) $(COMPILER.CFLAGS.$(VARIANT)) ;
|
||||
C++FLAGS += $(COMPILER.CFLAGS) $(COMPILER.C++FLAGS)
|
||||
$(COMPILER.CFLAGS.$(VARIANT)) $(COMPILER.C++FLAGS.$(VARIANT)) ;
|
||||
LINKLIBS += $(COMPILER.LFLAGS) $(COMPILER.LFLAGS.$(VARIANT)) ;
|
||||
LOCATE.OBJECTS = $(LOCATE.OBJECTS)/$(VARIANT) ;
|
||||
|
||||
## SubVariant variantname
|
||||
## Specify subvariant which are placed in separate compilation directories.
|
||||
SUBVARIANT ?= "" ;
|
||||
SAVED_LOCATE_TARGET = "" ;
|
||||
rule SubVariant
|
||||
{
|
||||
if ! $(<)
|
||||
{
|
||||
SUBVARIANT = $(SUBVARIANT[2]) ;
|
||||
SUBVARIANT ?= "" ;
|
||||
LOCATE_TARGET = $(SAVED_LOCATE_TARGET[1]) ;
|
||||
SAVED_LOCATE_TARGET = $(SAVED_LOCATE_TARGET[2-]) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
SUBVARIANT = $(<) $(SUBVARIANT) ;
|
||||
SAVED_LOCATE_TARGET = $(LOCATE_TARGET) $(SAVED_LOCATE_TARGET) ;
|
||||
LOCATE_TARGET = $(LOCATE_TARGET)/$(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
#============================================================================
|
||||
# Setup of compiler/linker flags for debug/optimize mode
|
||||
# Copyright (C)2003 by Matze Braun <matzebraun@users.sourceforge.net>
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU Library General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
|
||||
# License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Library General Public License
|
||||
# along with this library; if not, write to the Free Software Foundation,
|
||||
# Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#============================================================================
|
||||
|
||||
if ! $(VARIANT)
|
||||
{
|
||||
VARIANT = $(MODE) ;
|
||||
}
|
||||
|
||||
if $(VARIANT) != "debug" && $(VARIANT) != "optimize" && $(VARIANT) != "profile"
|
||||
{
|
||||
exit "Invalid modus set, please set VARIANT to debug, profile or optimize" ;
|
||||
}
|
||||
|
||||
# Set modus related flags
|
||||
CCFLAGS += $(COMPILER.CFLAGS) $(COMPILER.CFLAGS.$(VARIANT)) ;
|
||||
C++FLAGS += $(COMPILER.CFLAGS) $(COMPILER.C++FLAGS)
|
||||
$(COMPILER.CFLAGS.$(VARIANT)) $(COMPILER.C++FLAGS.$(VARIANT)) ;
|
||||
LINKLIBS += $(COMPILER.LFLAGS) $(COMPILER.LFLAGS.$(VARIANT)) ;
|
||||
LOCATE.OBJECTS = $(LOCATE.OBJECTS)/$(VARIANT) ;
|
||||
|
||||
## SubVariant variantname
|
||||
## Specify subvariant which are placed in separate compilation directories.
|
||||
SUBVARIANT ?= "" ;
|
||||
SAVED_LOCATE_TARGET = "" ;
|
||||
rule SubVariant
|
||||
{
|
||||
if ! $(<)
|
||||
{
|
||||
SUBVARIANT = $(SUBVARIANT[2]) ;
|
||||
SUBVARIANT ?= "" ;
|
||||
LOCATE_TARGET = $(SAVED_LOCATE_TARGET[1]) ;
|
||||
SAVED_LOCATE_TARGET = $(SAVED_LOCATE_TARGET[2-]) ;
|
||||
}
|
||||
else
|
||||
{
|
||||
SUBVARIANT = $(<) $(SUBVARIANT) ;
|
||||
SAVED_LOCATE_TARGET = $(LOCATE_TARGET) $(SAVED_LOCATE_TARGET) ;
|
||||
LOCATE_TARGET = $(LOCATE_TARGET)/$(<) ;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
1126
mk/jam/win32.jam
1126
mk/jam/win32.jam
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user