delete the AliSurvey objs after use
[u/mrichter/AliRoot.git] / share / alibtool
1 #!/bin/sh
2
3 # $Id$
4
5 #############################################################################
6 # alibtool - a shell script to help makeing modules for AliRoot Makefile
7 #############################################################################
8 #
9 # modification history
10 # $Log$
11 # Revision 1.11  2006/05/24 10:10:20  hristov
12 # Correct dependences for files from subdirecties (Matevz)
13 #
14 # Revision 1.10.4.1  2006/05/24 10:09:05  hristov
15 # Correct dependences for files from subdirecties (Matevz)
16 #
17 # Revision 1.10  2005/06/14 11:11:19  alibrary
18 # Always output at least one line
19 #
20 # Revision 1.9  2004/06/18 10:30:54  rdm
21 # fix typo in comment.
22 #
23 # Revision 1.8  2004/06/03 23:41:51  rdm
24 # wrap some insanely long lines into mulitple lines.
25 #
26 # Revision 1.7  2003/11/10 15:02:38  rdm
27 # re-direct warnings of rmkdepend about not found system include files
28 # to /dev/null. Only generate dependencies on ROOT and AliRoot, not on
29 # system or compiler specific files.
30 #
31 # Revision 1.6  2003/07/13 09:26:14  hristov
32 # Transition to NewIO
33 #
34 # Revision 1.5  2003/05/02 15:11:52  hristov
35 # Changes to avoid warnings (I.Hrivnacova)
36 #
37 # Revision 1.4  2002/10/14 14:57:45  hristov
38 # Merging the VirtualMC branch to the main development branch (HEAD)
39 #
40 # Revision 1.3.6.1  2002/07/09 12:24:49  alibrary
41 # Corrections for new MC
42 #
43 # Revision 1.3  2002/02/22 07:57:35  alibrary
44 # Reduce verbose output
45 #
46 # Revision 1.2  2001/11/14 17:52:48  hristov
47 # Updated version of the flat makefiles (J.-E.Revsbech)
48 #
49 # Revision 1.1  2001/10/09 13:45:57  hristov
50 # alibtool is added
51 #
52 #
53 # SYNOPSIS
54 # alibtool <command> <commandparameters>
55 #
56 # command must be one of the following:
57 #
58 #         mkmodule
59 #         depend
60 #         dependF
61 #
62 #
63 # DESCRIPTION
64 #
65 # This scipts is called with a primary command and a command parameter.
66 # It generates output on stdout, so normally it is called with a redirection,
67 # like:
68 #
69 #   alibtool mkmodule STEER > STEER/module.mk
70 #
71 # The command is one of the following:
72 #
73 # depend
74 #     Makes the dependencies for the file specified as second argument
75 #     (for c and cxx files)
76 #
77 # dependF
78 #     Makes the dependencies for the file specified as second argument
79 #     (for fortran files)
80 #
81 # mkmodule
82 #     Creates the module.mk for the the given directory specified as
83 #     the second argument
84 #
85 # MKMODULE
86 #
87 # When alibtool is called with the mkmodule command it searches the directory
88 # given as the second argument for files called *.pkg. If a file (possibly
89 # several) is found, it will create a file called module.mk based on these
90 # files. For example if running alibtool mkmodule STEER, it will search the
91 # STEER directory and create STEER/module.mk based on all .pkg files is
92 # STEER directory. If a file called libSTEER.pkg is found, then module.mk
93 # will have a section devoted to makeing library libSTEER.so with alle the
94 # sourcefiles specified in libSTEER.pkg. If a file called binSTEER.pkg is
95 # found the module.mk file will create an executable called STEER. Several
96 # *.pkg files can be placed in the same directory. The module.mk files is
97 # created on background of build/header.tpl and build/module.mk by variable
98 # substituion of variables @MODULE@ @PACKAGE@ and @TYPE@.
99 #
100 # PKG FILES
101 #
102 #
103 # The syntax for the pkg file is very simple. You specify the sources, headers
104 # and possibly extra include or link options. The *.pkg files is just
105 # inserted "as is" in the module.mk file, so normal Makefile syntax can
106 # be used. These variables can be specified: SRCS, FSRCS, CSRCS, HDRS, CHDRS,
107 # DHDR, EINCLUDE, ELIBS, ELIBSDIR, PACKFFLAGS, PACKCFLAGS, PACKCXXFLAGS.
108 # The first five is just the C++ sources, fortran sources, C sources,
109 # C++ headers and C headers. DHDR is the dictionary header and is the
110 # LinkDef file. EINCLUDE, ELIBS and ELIBSDIR is extra includedirs,
111 # libraries and library search paths. If for example a binary is to be
112 # linked against the variable ELIBSDIR would be set to lib/tgt_$ALICE_TARGET.
113 # Notice that -L and -l is not needed. If the PACKFFLAGS, PACKCFLAGS or
114 # PACKCXXFLAGS is not set it will be set to the default options (set in
115 # config/Makefile.$ALICE_TARGET. For example on Linux GEANT321 has to be
116 # compiled without -O options, so a line like
117 # PACKFFLAGS := $(filter-out -O%,$(FFLAGS))
118 # is needed.
119 #
120 #
121 # DEPEND
122
123 # If alibtool is called with the depend command it will generate a dependecy
124 # file for the sourcefile given as second argument. This only goes for C++
125 # and C files. If dependencies for fortran-fiels is needed, call alibtool
126 # with command dependF. The dependencies are made with rmkdepend.
127 #
128 #
129 # DEPENDF
130 #
131 # The same as depend, but for fortran files.
132 #
133 #C<
134 ###########################################################################
135  
136
137 MkDepend()
138 {
139 echo "#"
140 rmkdepend -f- -Y -w 3000 -- $* 2>/dev/null | sed -e "s@^\([^/]*\)\/\(.*\)\.o:@\1\/tgt_${ALICE_TARGET}\/\2.d \1\/tgt_${ALICE_TARGET}/\\2.o:@" -e 's@^#.*$@@' -e '/^$/d'
141 # rmkdepend -f- -Y -w 3000 -- $* 2>/dev/null | sed -e "s@^\(.*\)\/\(.*\)\.o:@\1\/tgt_${ALICE_TARGET}\/\2.d \1\/tgt_${ALICE_TARGET}/\\2.o:@" -e 's@^#.*$@@' -e '/^$/d'
142 }
143 MkDependF()
144 {
145 echo "#"
146 rmkdepend -f- -Y -w 3000 -- $* 2>/dev/null | sed -e "s@^\([^/]*\)\/\(.*\)\.o:@\1\/tgt_${ALICE_TARGET}\/\2.d \1\/tgt_${ALICE_TARGET}/\\2.o:@" -e 's@^#.*$@@' -e '/^$/d'
147 # rmkdepend -f- -Y -w 3000 -- $* 2>/dev/null | sed -e "s@^\(.*\)\/\(.*\)\.o:@\1\/tgt_${ALICE_TARGET}\/\2.d \1\/tgt_${ALICE_TARGET}/\\2.o:@" -e 's@^#.*$@@' -e '/^$/d'
148 }
149
150 MkModule()
151 {
152 module=$1
153 #This one gets all the library pkg files
154 tempo=`find ${module} -name "lib*.pkg"  | sed -e "sQ${module}/libQQ" -e "sQ\.pkgQQ"`
155
156 echo "#**************************************************************************";
157 echo "#**** This file is automatically generated from the mkmodules script  *****";
158 echo "#****          DO NOT EDIT!!                                          *****";
159 echo "#**************************************************************************";
160
161 for i in $tempo; do
162     package=$i;
163     type=lib;
164     MkModuleLib $package
165 done;
166
167 #This one gets all the binary(executable) pkg files
168 tempo=`find ${module} -name "bin*.pkg"  | sed -e "sQ${module}/binQQ" -e "sQ\.pkgQQ"`
169
170 for i in $tempo; do
171     package=$i;
172     type=bin;
173     MkModuleLib $package 
174 done;
175
176 #Now make general bottom for every module (Clean and so on)
177     cat build/clean.tpl | sed -e "sQ\@MODULE@Q${module}Qg"
178 }
179
180 MkModuleLib()
181 {
182     file=$module/$type$i.pkg
183     cat build/header.tpl | sed -e "sQ\@MODULE@Q${module}Qg"  -e "sQ@PACKAGE@Q${package}Qg" -e "sQ\@TYPE@Q${type}Qg"
184     echo;
185     cat $file;
186     echo;
187     cat build/module.tpl | sed -e "sQ\@MODULE@Q${module}Qg"  -e "sQ@PACKAGE@Q${package}Qg" -e "sQ\@TYPE@Q${type}Qg"
188
189 }
190
191 case $1 in
192 depend)
193     MkDepend $2
194     ;;
195 dependF)
196     MkDependF $2
197     ;;
198 mkmodule)
199     MkModule $2
200     ;;
201 esac;