/[PAMELA software]/PamCut/makefile
ViewVC logotype

Annotation of /PamCut/makefile

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.9 - (hide annotations) (download)
Wed Mar 24 08:11:25 2010 UTC (14 years, 8 months ago) by pam-fi
Branch: MAIN
Changes since 1.8: +7 -1 lines
Exclusion flags documentation updated.

1 pam-fi 1.1 #
2     # ************ PamCut makefile ************
3     #
4     # Author: Nicola Mori
5     #
6     # This makefile will produce a cut library libPamCut.so. In the "Build options"
7     # section the various compilation options can be set; they will propagate to the
8     # whole project.
9     #
10    
11    
12     # ------------------------------- Build options ----------------------------#
13     #
14     # Normally you will not have the necessity to modify what lies below, if you
15     # correctly specified the names for the submakefiles in include.mk. Modify
16     # the options below to set optimization flags, compiler name and so on.
17     #
18    
19     # C++ compiler and linker
20     C++ = g++
21    
22     # Optimization flags.
23     # 1) Use -O, -O1, -O2, -O3 to optimize for speed or -g, -g1, -g2, -g3
24     # for debugging (slower execution).
25     # 2) Uncomment -DDEBUGPAMCUT to enable debug sections in the .cpp code (these sections must be included between
26     # "#ifdef DEBUGPAMCUT" and "#endif"). Note that if you
27     # use debug instructions also in the .h code (headers) you will also have to add -DDEBUGPAMCUT
28     # to the compiler options for the main analysis program.
29 pam-fi 1.7 # 3) Since this is a general compiler flag it can also be used, eg., to set the -m32 flag
30 pam-fi 1.1 OPTIMIZE = -g3 #-DDEBUGPAMCUT
31    
32 pam-fi 1.7 # Linker flags
33     # The flags defined here will be directly inserted into the linker invocation. Place here the
34     # -m32 flag, for example.
35     LINKERFLAGS =
36 pam-fi 1.4
37 pam-fi 1.1 # Library flags
38     # Pamela software is modular, so some libraries may not be available in some istallations.
39     # To avoid linking problems, here you can define flags to exclude those parts of the
40     # PamCut software which make use of unavailable libraries. Remember to place
41     # the code to be excluded between proper preprocessor directives. See the documentation or the cut
42     # TofNucleiZCut for an example.
43 pam-fi 1.6 # Since PamCut headers may refer to the optional libraries, it's important to define the same
44     # flags when compiling the analysis code. Otherwise, analysis code will include PamCut headers which,
45     # if no exclusion flag is set, will try to include optional software headers.
46 pam-fi 1.9 # Conversely, if you use optional libraries remember to tell it to the linker.
47     #
48     # Excluded cuts and actions:
49     # DNO_CALONUCLEI: CaloNucleiZCut
50     # NO_TRKNUCLEI: TrkNucleiZCut
51     # NO_TOFNUCLEI: TofNucleiZCut
52     # NO_CALOPRESAMPLER: ReprocessCaloAction
53 pam-fi 1.1
54 pam-fi 1.8 EXCLUSIONFLAGS = -DNO_CALONUCLEI -DNO_TRKNUCLEI -DNO_TOFNUCLEI #-DNO_CALOPRESAMPLER
55 pam-fi 1.1
56     # Put below the files on which every .cpp must depend on, ie., those files that,
57     # if modified, will trigger a complete recompilation of the project.
58     COMMONDEPS = makefile
59    
60     # The file include.mk contains the inclusion of all the sub-makefiles (subdir.mk)
61     # in the project. Includes for new cuts must be added there and not below...
62     -include include.mk
63    
64     #-------------------------------- Make body --------------------------------#
65     #
66     # Below the make commands are defined. There are no options to set in this section,
67     # so it has to be modified only in case of radical changes to the make procedure.
68    
69     # Remove command for clean
70     RM := rm -rf
71    
72     # Additional dependencies from headers of other software (PAMELA, ROOT)
73     ifneq ($(MAKECMDGOALS),clean)
74     ifneq ($(strip $(CPP_DEPS)),)
75     -include $(CPP_DEPS)
76     endif
77     endif
78    
79     # All Target
80 pam-fi 1.4 all: libPamCut.so
81     @echo
82     @echo "**** Compiler version and compilation host ****"
83     @$(C++) --version | grep GCC
84     @hostname
85     @echo
86    
87 pam-fi 1.1 # Tool invocations
88     libPamCut.so: $(OBJS) $(USER_OBJS)
89     @echo 'Building target: $@'
90     @echo 'Invoking: GCC C++ Linker'
91 pam-fi 1.7 $(C++) -shared $(LINKERFLAGS) -o"libPamCut.so" $(OBJS)
92 pam-fi 1.1 @echo 'Finished building target: $@'
93     @echo ' '
94    
95     # Other Targets
96     clean:
97     -$(RM) $(CPP_DEPS) $(OBJS) libPamCut.so
98     -@echo ' '
99    
100 pam-fi 1.3 distclean:
101     @rm -f ${PAM_LIB}/libPamCut.so
102     @rm -rf ${PAM_INC}/PamCut
103     @echo Installed files successfully removed.
104    
105     install:
106     @if [[ "${PAM_INC}" == "" || "${PAM_LIB}" == "" ]]; then \
107     echo Pamela environment not set. ; \
108     else \
109     rootdir=`pwd`; \
110     for file in `find -name "*.h"`; do \
111     dir=`dirname $${file} | sed 's/.\///'`; \
112     mkdir -p ${PAM_INC}/PamCut/$${dir}; \
113     cp -u $${file} ${PAM_INC}/PamCut/$${dir}; \
114     done; \
115     cp -u libPamCut.so ${PAM_LIB}; \
116     fi
117     @echo PamCut installed.
118    
119 pam-fi 1.4 .PHONY: all clean distclean install
120 pam-fi 1.3

  ViewVC Help
Powered by ViewVC 1.1.23