xref: /petsc/makefile (revision 3638b69dbd64ba4780c119c4ea508ad72b54579c)
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