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