1# 2# This makefile contains some basic commands for building PETSc. 3# See bmake/common for additional commands. 4# 5 6PETSC_DIR = . 7 8CFLAGS = -I$(PETSC_DIR)/include -I.. -I$(PETSC_DIR) $(CONF) $(PCONF) 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/sun4/* bmake/paragon/* bmake/linux/* \ 15 bmake/rs6000/* bmake/alpha/* bmake/IRIX/* bmake/IRIX64/* \ 16 bmake/hpux/* bmake/t3d/* bmake/freebsd/* bmake/solaris/* \ 17 maint/autoftp 18OBJSC = 19OBJSF = 20LIBBASE = libpetscvec 21DIRS = src include docs 22 23include $(PETSC_DIR)/bmake/$(PETSC_ARCH)/$(PETSC_ARCH) 24 25# Builds PETSc libraries for a given BOPT and architecture 26all: chkpetsc_dir 27 -$(RM) -f $(PDIR)/*.a 28 -@echo "Beginning to compile libraries in all directories" 29 -@echo "Using $(CC) $(PETSC_INCLUDE) $(CONF) $(PCONF) $(BASEOPT)" 30 -@echo "------------------------------------------" 31 -@$(OMAKE) BOPT=$(BOPT) PETSC_ARCH=$(PETSC_ARCH) \ 32 ACTION=libfast tree 33 $(RANLIB) $(PDIR)/*.a 34 -@echo "Completed building libraries" 35 -@echo "------------------------------------------" 36 37# Builds PETSc test examples for a given BOPT and architecture 38testexamples: chkpetsc_dir 39 -@echo "Beginning to compile and run test examples" 40 -@echo "Using compiler: $(CC) $(PETSC_INCLUDE) $(PCONF) $(BASEOPT)" 41 -@echo "Using linker: $(CLINKER)" 42 -@echo "Using libraries: $(PETSC_LIB)" 43 -@echo "------------------------------------------" 44 -@echo "Due to different numerical round-off on certain" 45 -@echo "machines some of the numbers may not match exactly." 46 -@echo "------------------------------------------" 47 -@$(OMAKE) BOPT=$(BOPT) PETSC_ARCH=$(PETSC_ARCH) \ 48 ACTION=testexamples_1 tree 49 -@echo "Completed compiling and running test examples" 50 -@echo "------------------------------------------" 51 52# Builds PETSc test examples for a given BOPT and architecture 53testfortran: chkpetsc_dir 54 -@echo "Beginning to compile and run Fortran test examples" 55 -@echo "Using compiler: $(FC) $(BASEOPTF)" 56 -@echo "Using linker: $(FLINKER)" 57 -@echo "Using libraries: $(PETSC_FORTRAN_LIB) $(PETSC_LIB)" 58 -@echo "------------------------------------------" 59 -@$(OMAKE) BOPT=$(BOPT) PETSC_ARCH=$(PETSC_ARCH) \ 60 ACTION=testexamples_3 tree 61 -@echo "Completed compiling and running Fortran test examples" 62 -@echo "------------------------------------------" 63 64# 65# Builds PETSc Fortran interface libary 66# Note: libfast cannot run on .F files on certain machines, so we 67# use lib and check for errors here. 68fortran: chkpetsc_dir 69 -$(RM) -f $(PDIR)/libpetscfortran.a 70 -@echo "Beginning to compile Fortran interface library" 71 -@echo "------------------------------------------" 72 -@cd src/fortran/custom; \ 73 $(OMAKE) BOPT=$(BOPT) PETSC_ARCH=$(PETSC_ARCH) lib > trashz 2>&1; \ 74 grep -v clog trashz | grep -v "information sections" | \ 75 egrep -i '(Error|warning|Can)' >> /dev/null;\ 76 if [ "$$?" != 1 ]; then \ 77 cat trashz ; fi; $(RM) trashz 78 -@cd src/fortran/auto; \ 79 $(OMAKE) BOPT=$(BOPT) PETSC_ARCH=$(PETSC_ARCH) libfast 80 $(RANLIB) $(PDIR)/libpetscfortran.a 81 -@echo "Completed compiling Fortran interface library" 82 -@echo "------------------------------------------" 83 84ranlib: 85 $(RANLIB) $(PDIR)/*.a 86 87# Deletes PETSc libraries 88deletelibs: 89 -$(RM) -f $(PDIR)/*.a $(PDIR)/complex/* $(PDIR)/c++/* 90 91# Deletes man pages (xman version) 92deletemanpages: 93 $(RM) -f $(PETSC_DIR)/Keywords $(PETSC_DIR)/docs/man/man*/* 94 95# Deletes man pages (HTML version) 96deletewwwpages: 97 $(RM) -f $(PETSC_DIR)/docs/www/man*/* $(PETSC_DIR)/docs/www/www.cit 98 99# Deletes man pages (LaTeX version) 100deletelatexpages: 101 $(RM) -f $(PETSC_DIR)/docs/tex/rsum/*sum*.tex 102 103# To access the tags in emacs, type M-x visit-tags-table and specify 104# the file petsc/TAGS. Then, to move to where a PETSc function is 105# defined, enter M-. and the function name. To search for a string 106# and move to the first occurrence, use M-x tags-search and the string. 107# To locate later occurrences, use M-, 108 109# Builds all etags files 110alletags: 111 -make etags 112 -make etags_noexamples 113 -make etags_makefiles 114 115# Builds the basic etags file. This should be employed by most users. 116etags: 117 $(RM) TAGS 118 etags -f TAGS src/*/impls/*/*.h src/*/impls/*/*/*.h 119 etags -a -f TAGS src/*/examples/*.c src/*/examples/*/*.c 120 etags -a -f TAGS src/*/*.h src/*/*/*.h src/*/interface/*.c 121 etags -a -f TAGS src/*/src/*.c src/*/impls/*/*.c 122 etags -a -f TAGS src/*/impls/*/*/*.c 123 etags -a -f TAGS include/*.h include/*include/*.h bmake/common 124 etags -a -f TAGS src/*/impls/*.c src/*/utils/*.c 125 etags -a -f TAGS makefile src/*/src/makefile 126 etags -a -f TAGS src/*/interface/makefile src/makefile 127 etags -a -f TAGS src/*/impls/makefile src/*/impls/*/makefile 128 etags -a -f TAGS src/*/utils/makefile src/*/examples/makefile 129 etags -a -f TAGS src/*/examples/*/makefile 130 etags -a -f TAGS src/*/makefile src/*/impls/*/*/makefile 131 etags -a -f TAGS src/fortran/makefile src/fortran/auto/makefile 132 etags -a -f TAGS src/fortran/custom/makefile 133 etags -a -f TAGS include/makefile include/*/makefile docs/makefile 134 etags -a -f TAGS bmake/common bmake/sun4/sun4* bmake/rs6000/rs6000* 135 etags -a -f TAGS bmake/solaris/solaris* 136 etags -a -f TAGS bmake/IRIX/IRIX* bmake/freebsd/freebsd* 137 etags -a -f TAGS bmake/hpux/hpux* bmake/alpha/alpha* 138 etags -a -f TAGS bmake/t3d/t3d* bmake/paragon/paragon* 139 etags -a -f TAGS docs/tex/routin.tex docs/tex/manual.tex docs/tex/manual_tex.tex 140 etags -a -f TAGS docs/tex/intro.tex docs/tex/part1.tex docs/tex/part2.tex 141 etags -a -f TAGS src/fortran/custom/*.c src/fortran/auto/*.c 142 etags -a -f TAGS src/*/examples/*.F src/fortran/custom/*.F 143 chmod g+w TAGS 144 145# Builds the etags file that excludes the examples directories 146etags_noexamples: 147 $(RM) TAGS_NO_EXAMPLES 148 etags -f TAGS_NO_EXAMPLES src/*/impls/*/*.h src/*/impls/*/*/*.h 149 etags -a -f TAGS_NO_EXAMPLES src/*/*.h src/*/*/*.h src/*/interface/*.c 150 etags -a -f TAGS_NO_EXAMPLES src/*/src/*.c src/*/impls/*/*.c 151 etags -a -f TAGS_NO_EXAMPLES src/*/impls/*/*/*.c 152 etags -a -f TAGS_NO_EXAMPLES include/*.h include/*include/*.h 153 etags -a -f TAGS_NO_EXAMPLES bmake/common 154 etags -a -f TAGS_NO_EXAMPLES src/*/impls/*.c src/*/utils/*.c 155 etags -a -f TAGS_NO_EXAMPLES makefile src/*/src/makefile 156 etags -a -f TAGS_NO_EXAMPLES src/*/interface/makefile src/makefile 157 etags -a -f TAGS_NO_EXAMPLES src/*/impls/makefile src/*/impls/*/makefile 158 etags -a -f TAGS_NO_EXAMPLES src/*/utils/makefile 159 etags -a -f TAGS_NO_EXAMPLES src/*/makefile src/*/impls/*/*/makefile 160 etags -a -f TAGS_NO_EXAMPLES src/fortran/makefile src/fortran/auto/makefile 161 etags -a -f TAGS_NO_EXAMPLES src/fortran/custom/makefile 162 etags -a -f TAGS_NO_EXAMPLES include/makefile include/*/makefile docs/makefile 163 etags -a -f TAGS_NO_EXAMPLES bmake/common bmake/sun4/sun4* 164 etags -a -f TAGS_NO_EXAMPLES bmake/rs6000/rs6000* 165 etags -a -f TAGS_NO_EXAMPLES bmake/solaris/solaris* 166 etags -a -f TAGS_NO_EXAMPLES bmake/IRIX/IRIX* bmake/freebsd/freebsd* 167 etags -a -f TAGS_NO_EXAMPLES bmake/hpux/hpux* bmake/alpha/alpha* 168 etags -a -f TAGS_NO_EXAMPLES bmake/t3d/t3d* bmake/paragon/paragon* 169 etags -a -f TAGS_NO_EXAMPLES docs/tex/routin.tex docs/tex/manual.tex 170 etags -a -f TAGS_NO_EXAMPLES docs/tex/intro.tex docs/tex/part1.tex 171 etags -a -f TAGS_NO_EXAMPLES src/fortran/auto/*.c 172 etags -a -f TAGS_NO_EXAMPLES src/fortran/custom/*.c src/fortran/custom/*.F 173 chmod g+w TAGS_NO_EXAMPLES 174 175# Builds the etags file for makefiles 176etags_makefiles: 177 $(RM) TAGS_MAKEFILES 178 etags -a -f TAGS_MAKEFILES bmake/common 179 etags -a -f TAGS_MAKEFILES makefile src/*/src/makefile 180 etags -a -f TAGS_MAKEFILES src/*/interface/makefile src/makefile 181 etags -a -f TAGS_MAKEFILES src/*/impls/makefile src/*/impls/*/makefile 182 etags -a -f TAGS_MAKEFILES src/*/utils/makefile src/*/interface/makefile 183 etags -a -f TAGS_MAKEFILES src/*/makefile src/*/impls/*/*/makefile 184 etags -a -f TAGS_MAKEFILES src/*/examples/makefile src/*/examples/*/makefile 185 etags -a -f TAGS_MAKEFILES src/fortran/makefile src/fortran/auto/makefile 186 etags -a -f TAGS_MAKEFILES src/fortran/custom/makefile 187 etags -a -f TAGS_MAKEFILES include/makefile include/*/makefile docs/makefile 188 etags -a -f TAGS_MAKEFILES bmake/common bmake/sun4/sun4* 189 etags -a -f TAGS_MAKEFILES bmake/rs6000/rs6000* 190 etags -a -f TAGS_MAKEFILES bmake/solaris/solaris* 191 etags -a -f TAGS_MAKEFILES bmake/IRIX/IRIX* bmake/freebsd/freebsd* 192 etags -a -f TAGS_MAKEFILES bmake/hpux/hpux* bmake/alpha/alpha* 193 etags -a -f TAGS_MAKEFILES bmake/t3d/t3d* bmake/paragon/paragon* 194 chmod g+w TAGS_MAKEFILES 195 196# ------------------------------------------------------------------ 197# 198# All remaining actions are intended for PETSc developers only. 199# PETSc users should not generally need to use these commands. 200# 201 202# Builds all versions of the man pages 203allmanpages: deletemanpages deletewwwpages deletelatexpages 204 -make ACTION=manpages tree 205 -make ACTION=wwwpages tree 206 -make ACTION=latexpages tree 207 -maint/wwwman 208 209alllatexpages: deletelatexpages 210 -make ACTION=latexpages tree 211 212# Builds Fortran stub files 213allfortranstubs: 214 -@$(RM) -f $(PETSC_DIR)/src/fortran/auto/*.c 215 -make ACTION=fortranstubs tree 216 chmod g+w $(PETSC_DIR)/src/fortran/auto/*.c 217 218