1# 2# This makefile contains some basic commands for building PETSc. 3# See bmake/common for additional commands. 4# 5 6PETSC_DIR = . 7 8CFLAGS = 9SOURCEC = 10SOURCEF = 11SOURCEH = Changes Machines Readme maint/addlinks \ 12 maint/builddist FAQ Installation Performance BugReporting\ 13 maint/buildlinks maint/wwwman maint/xclude maint/crontab\ 14 bmake/common bmake/*/base* maint/autoftp docs/www/sec/* 15OBJSC = 16OBJSF = 17LIBBASE = libpetscvec 18DIRS = src include docs 19 20include $(PETSC_DIR)/bmake/$(PETSC_ARCH)/base 21 22# Builds PETSc libraries for a given BOPT and architecture 23all: chkpetsc_dir 24 -$(RM) -f $(PDIR)/*.a 25 -@echo "Beginning to compile libraries in all directories" 26 -@echo "Using compiler: $(CC) $(CFLAGS) $(COPTFLAGS)" 27 -@echo "Using PETSc flags: $(PETSCFLAGS) $(PCONF)" 28 -@echo "Using configuration flags: $(CONF)" 29 -@echo "Using include paths: $(PETSC_INCLUDE)" 30 -@echo "------------------------------------------" 31 -@$(OMAKE) BOPT=$(BOPT) PETSC_ARCH=$(PETSC_ARCH) \ 32 ACTION=libfast tree 33 -@cd $(PETSC_DIR)/src/sys/src ; $(OMAKE) PETSC_ARCH=$(PETSC_ARCH) rs6000_time 34 $(RANLIB) $(PDIR)/*.a 35 -@echo "Completed building libraries" 36 -@echo "------------------------------------------" 37 38# Builds PETSc test examples for a given BOPT and architecture 39testexamples: chkpetsc_dir 40 -@echo "Beginning to compile and run test examples" 41 -@echo "Using compiler: $(CC) $(CFLAGS) $(COPTFLAGS)" 42 -@echo "Using PETSc flags: $(PETSCFLAGS) $(PCONF)" 43 -@echo "Using include paths: $(PETSC_INCLUDE)" 44 -@echo "Using linker: $(CLINKER)" 45 -@echo "Using libraries: $(PETSC_LIB)" 46 -@echo "------------------------------------------" 47 -@echo "Due to different numerical round-off on certain" 48 -@echo "machines some of the numbers may not match exactly." 49 -@echo "------------------------------------------" 50 -@$(OMAKE) BOPT=$(BOPT) PETSC_ARCH=$(PETSC_ARCH) \ 51 ACTION=testexamples_1 tree 52 -@echo "Completed compiling and running test examples" 53 -@echo "------------------------------------------" 54 55# Builds PETSc test examples for a given BOPT and architecture 56testexamples_uni: chkpetsc_dir 57 -@echo "Beginning to compile and run uniprocessor test examples" 58 -@echo "Using compiler: $(CC) $(CFLAGS) $(COPTFLAGS)" 59 -@echo "Using linker: $(CLINKER)" 60 -@echo "Using PETSc flags: $(PETSCFLAGS) $(PCONF)" 61 -@echo "Using include paths: $(PETSC_INCLUDE)" 62 -@echo "Using libraries: $(PETSC_LIB)" 63 -@echo "------------------------------------------" 64 -@echo "Due to different numerical round-off on certain" 65 -@echo "machines some of the numbers may not match exactly." 66 -@echo "------------------------------------------" 67 -@$(OMAKE) BOPT=$(BOPT) PETSC_ARCH=$(PETSC_ARCH) \ 68 ACTION=testexamples_4 tree 69 -@echo "Completed compiling and running uniprocessor test examples" 70 -@echo "------------------------------------------" 71 72# Builds PETSc test examples for a given BOPT and architecture 73testfortran: chkpetsc_dir 74 -@echo "Beginning to compile and run Fortran test examples" 75 -@echo "Using compiler: $(FC) $(FFLAGS) $(FOPTFLAGS)" 76 -@echo "Using linker: $(FLINKER)" 77 -@echo "Using libraries: $(PETSC_FORTRAN_LIB) $(PETSC_LIB)" 78 -@echo "------------------------------------------" 79 -@$(OMAKE) BOPT=$(BOPT) PETSC_ARCH=$(PETSC_ARCH) \ 80 ACTION=testexamples_3 tree 81 -@echo "Completed compiling and running Fortran test examples" 82 -@echo "------------------------------------------" 83 84# 85# Builds PETSc Fortran interface libary 86# Note: libfast cannot run on .F files on certain machines, so we 87# use lib and check for errors here. 88fortran: chkpetsc_dir 89 -$(RM) -f $(PDIR)/libpetscfortran.a 90 -@echo "Beginning to compile Fortran interface library" 91 -@echo "Using C/C++ compiler: $(CC) $(CFLAGS) $(COPTFLAGS)" 92 -@echo "Using Fortran compiler: $(FC) $(FFLAGS) $(FOPTFLAGS)" 93 -@echo "------------------------------------------" 94 -@cd src/fortran/custom; \ 95 $(OMAKE) BOPT=$(BOPT) PETSC_ARCH=$(PETSC_ARCH) lib > trashz 2>&1; \ 96 grep -v clog trashz | grep -v "information sections" | \ 97 egrep -i '(Error|warning|Can)' >> /dev/null;\ 98 if [ "$$?" != 1 ]; then \ 99 cat trashz ; fi; $(RM) trashz 100 -@cd src/fortran/auto; \ 101 $(OMAKE) BOPT=$(BOPT) PETSC_ARCH=$(PETSC_ARCH) libfast 102 $(RANLIB) $(PDIR)/libpetscfortran.a 103 -@echo "Completed compiling Fortran interface library" 104 -@echo "------------------------------------------" 105 106ranlib: 107 $(RANLIB) $(PDIR)/*.a 108 109# Deletes PETSc libraries 110deletelibs: 111 -$(RM) -f $(PDIR)/*.a $(PDIR)/complex/* $(PDIR)/c++/* 112 113# Deletes man pages (xman version) 114deletemanpages: 115 $(RM) -f $(PETSC_DIR)/Keywords $(PETSC_DIR)/docs/man/man*/* 116 117# Deletes man pages (HTML version) 118deletewwwpages: 119 $(RM) -f $(PETSC_DIR)/docs/www/man*/* $(PETSC_DIR)/docs/www/www.cit \ 120 $(PETSC_DIR)/docs/www/man*.html 121 122# Deletes man pages (LaTeX version) 123deletelatexpages: 124 $(RM) -f $(PETSC_DIR)/docs/tex/rsum/*sum*.tex 125 126# To access the tags in emacs, type M-x visit-tags-table and specify 127# the file petsc/TAGS. Then, to move to where a PETSc function is 128# defined, enter M-. and the function name. To search for a string 129# and move to the first occurrence, use M-x tags-search and the string. 130# To locate later occurrences, use M-, 131 132# Builds all etags files 133alletags: 134 -make etags_complete 135 -make etags 136 -make etags_noexamples 137 -make etags_makefiles 138 139# Builds the basic etags file. This should be employed by most users. 140etags: 141 $(RM) TAGS 142 etags -f TAGS src/*/impls/*/*.h src/*/impls/*/*/*.h 143 etags -a -f TAGS src/*/examples/*.c src/*/examples/*/*.c 144 etags -a -f TAGS src/*/*.h src/*/*/*.h src/*/interface/*.c 145 etags -a -f TAGS src/*/src/*.c src/*/impls/*/*.c 146 etags -a -f TAGS src/*/impls/*/*/*.c src/benchmarks/*.c 147 etags -a -f TAGS src/contrib/*/*.c src/contrib/*/src/*.c 148 etags -a -f TAGS src/contrib/*/examples/*.c 149 etags -a -f TAGS src/contrib/*/src/*.h src/contrib/*/examples/*.F 150 etags -a -f TAGS include/*.h include/pinclude/*.h bmake/common 151 etags -a -f TAGS include/FINCLUDE/*.h 152 etags -a -f TAGS src/*/impls/*.c src/*/utils/*.c 153 etags -a -f TAGS makefile src/*/src/makefile 154 etags -a -f TAGS src/*/interface/makefile src/makefile 155 etags -a -f TAGS src/*/impls/makefile src/*/impls/*/makefile 156 etags -a -f TAGS src/*/utils/makefile src/*/examples/makefile 157 etags -a -f TAGS src/*/examples/*/makefile 158 etags -a -f TAGS src/*/makefile src/*/impls/*/*/makefile 159 etags -a -f TAGS src/contrib/*/makefile src/contrib/*/src/makefile 160 etags -a -f TAGS src/fortran/makefile src/fortran/auto/makefile 161 etags -a -f TAGS src/fortran/custom/makefile 162 etags -a -f TAGS include/makefile include/*/makefile 163 etags -a -f TAGS bmake/common bmake/*/base* 164 etags -a -f TAGS src/fortran/custom/*.c src/fortran/auto/*.c src/benchmarks/*.c 165 etags -a -f TAGS src/*/examples/*.F src/*/examples/*.f src/fortran/custom/*.F 166 chmod g+w TAGS 167 168# Builds complete etags list; only for PETSc developers. 169etags_complete: 170 $(RM) TAGS_COMPLETE 171 etags -f TAGS_COMPLETE src/*/impls/*/*.h src/*/impls/*/*/*.h 172 etags -a -f TAGS_COMPLETE src/*/examples/*.c src/*/examples/*/*.c 173 etags -a -f TAGS_COMPLETE src/*/*.h src/*/*/*.h src/*/interface/*.c 174 etags -a -f TAGS_COMPLETE src/*/src/*.c src/*/impls/*/*.c 175 etags -a -f TAGS_COMPLETE src/*/impls/*/*/*.c src/benchmarks/*.c 176 etags -a -f TAGS_COMPLETE src/contrib/*/*.c src/contrib/*/src/*.c 177 etags -a -f TAGS_COMPLETE src/contrib/*/examples/*.c 178 etags -a -f TAGS_COMPLETE src/contrib/*/src/*.h src/contrib/*/examples/*.F 179 etags -a -f TAGS_COMPLETE include/*.h include/pinclude/*.h bmake/common 180 etags -a -f TAGS_COMPLETE include/FINCLUDE/*.h 181 etags -a -f TAGS_COMPLETE src/*/impls/*.c src/*/utils/*.c 182 etags -a -f TAGS_COMPLETE makefile src/*/src/makefile 183 etags -a -f TAGS_COMPLETE src/*/interface/makefile src/makefile 184 etags -a -f TAGS_COMPLETE src/*/impls/makefile src/*/impls/*/makefile 185 etags -a -f TAGS_COMPLETE src/*/utils/makefile src/*/examples/makefile 186 etags -a -f TAGS_COMPLETE src/*/examples/*/makefile 187 etags -a -f TAGS_COMPLETE src/*/makefile src/*/impls/*/*/makefile 188 etags -a -f TAGS_COMPLETE src/contrib/*/makefile src/contrib/*/src/makefile 189 etags -a -f TAGS_COMPLETE src/fortran/makefile src/fortran/auto/makefile 190 etags -a -f TAGS_COMPLETE src/fortran/custom/makefile 191 etags -a -f TAGS_COMPLETE include/makefile include/*/makefile 192 etags -a -f TAGS_COMPLETE bmake/common bmake/*/base* 193 etags -a -f TAGS_COMPLETE src/fortran/custom/*.c src/fortran/auto/*.c src/benchmarks/*.c 194 etags -a -f TAGS_COMPLETE src/*/examples/*.F src/*/examples/*.f src/fortran/custom/*.F 195 etags -a -f TAGS_COMPLETE docs/tex/manual/routin.tex docs/tex/manual/manual.tex 196 etags -a -f TAGS_COMPLETE docs/tex/manual/manual_tex.tex 197 etags -a -f TAGS_COMPLETE docs/tex/manual/intro.tex docs/tex/manual/part1.tex 198 etags -a -f TAGS_COMPLETE docs/tex/manual/part2.tex 199 etags -a -f TAGS_COMPLETE docs/tex/manual/intro.tex docs/makefile 200 chmod g+w TAGS_COMPLETE 201 202# Builds the etags file that excludes the examples directories 203etags_noexamples: 204 $(RM) TAGS_NO_EXAMPLES 205 etags -f TAGS_NO_EXAMPLES src/*/impls/*/*.h src/*/impls/*/*/*.h 206 etags -a -f TAGS_NO_EXAMPLES src/*/*.h src/*/*/*.h src/*/interface/*.c 207 etags -a -f TAGS_NO_EXAMPLES src/*/src/*.c src/*/impls/*/*.c 208 etags -a -f TAGS_NO_EXAMPLES src/*/impls/*/*/*.c 209 etags -a -f TAGS_NO_EXAMPLES src/contrib/*/*.c src/contrib/*/src/*.c 210 etags -a -f TAGS_NO_EXAMPLES src/contrib/*/src/*.h 211 etags -a -f TAGS_NO_EXAMPLES include/*.h include/pinclude/*.h 212 etags -a -f TAGS_NO_EXAMPLES include/FINCLUDE/*.h 213 etags -a -f TAGS_NO_EXAMPLES bmake/common 214 etags -a -f TAGS_NO_EXAMPLES src/*/impls/*.c src/*/utils/*.c 215 etags -a -f TAGS_NO_EXAMPLES makefile src/*/src/makefile 216 etags -a -f TAGS_NO_EXAMPLES src/*/interface/makefile src/makefile 217 etags -a -f TAGS_NO_EXAMPLES src/*/impls/makefile src/*/impls/*/makefile 218 etags -a -f TAGS_NO_EXAMPLES src/*/utils/makefile 219 etags -a -f TAGS_NO_EXAMPLES src/*/makefile src/*/impls/*/*/makefile 220 etags -a -f TAGS_NO_EXAMPLES src/contrib/*/makefile src/contrib/*/src/makefile 221 etags -a -f TAGS_NO_EXAMPLES src/fortran/makefile src/fortran/auto/makefile 222 etags -a -f TAGS_NO_EXAMPLES src/fortran/custom/makefile 223 etags -a -f TAGS_NO_EXAMPLES include/makefile include/*/makefile 224 etags -a -f TAGS_NO_EXAMPLES bmake/common bmake/*/base* 225 etags -a -f TAGS_NO_EXAMPLES src/fortran/auto/*.c 226 etags -a -f TAGS_NO_EXAMPLES src/fortran/custom/*.c src/fortran/custom/*.F 227 etags -a -f TAGS_NO_EXAMPLES docs/tex/manual/routin.tex 228 etags -a -f TAGS_NO_EXAMPLES docs/tex/manual/manual.tex 229 etags -a -f TAGS_NO_EXAMPLES docs/tex/manual/intro.tex 230 etags -a -f TAGS_NO_EXAMPLES docs/tex/manual/part1.tex 231 etags -a -f TAGS_NO_EXAMPLES docs/tex/manual/part2.tex 232 etags -a -f TAGS_NO_EXAMPLES docs/makefile 233 chmod g+w TAGS_NO_EXAMPLES 234 235# Builds the etags file for makefiles 236etags_makefiles: 237 $(RM) TAGS_MAKEFILES 238 etags -a -f TAGS_MAKEFILES bmake/common 239 etags -a -f TAGS_MAKEFILES makefile src/*/src/makefile 240 etags -a -f TAGS_MAKEFILES src/*/interface/makefile src/makefile 241 etags -a -f TAGS_MAKEFILES src/*/impls/makefile src/*/impls/*/makefile 242 etags -a -f TAGS_MAKEFILES src/*/utils/makefile src/*/interface/makefile 243 etags -a -f TAGS_MAKEFILES src/*/makefile src/*/impls/*/*/makefile 244 etags -a -f TAGS_MAKEFILES src/*/examples/makefile src/*/examples/*/makefile 245 etags -a -f TAGS_MAKEFILES src/fortran/makefile src/fortran/auto/makefile 246 etags -a -f TAGS_MAKEFILES src/contrib/*/makefile src/contrib/*/src/makefile 247 etags -a -f TAGS_MAKEFILES src/fortran/custom/makefile 248 etags -a -f TAGS_MAKEFILES include/makefile include/*/makefile 249 etags -a -f TAGS_MAKEFILES bmake/common bmake/*/base* 250 etags -a -f TAGS_MAKEFILES docs/makefile 251 chmod g+w TAGS_MAKEFILES 252 253# ------------------------------------------------------------------ 254# 255# All remaining actions are intended for PETSc developers only. 256# PETSc users should not generally need to use these commands. 257# 258 259# Builds all versions of the man pages 260allmanpages: deletemanpages allwwwpages alllatexpages 261 -make ACTION=manpages tree 262 -cd src/fortran/custom; make manpages 263 -cd docs/man; catman -W . 264allwwwpages: deletewwwpages 265 -make ACTION=wwwpages_buildcite tree 266 -cd src/fortran/custom; make wwwpages_buildcite 267 -cd src/fortran/custom; make wwwpages 268 -make ACTION=wwwpages tree 269 -maint/wwwman 270 271alllatexpages: deletelatexpages 272 -make ACTION=latexpages tree 273 -cd src/fortran/custom; make latexpages 274 275# Builds Fortran stub files 276allfortranstubs: 277 -@include/finclude/generateincludes 278 -@$(RM) -f $(PETSC_DIR)/src/fortran/auto/*.c 279 -make ACTION=fortranstubs tree 280 chmod g+w $(PETSC_DIR)/src/fortran/auto/*.c 281