Merge branch 'tizen_base' of ssh://review.tizen.org:29418/platform/upstream/libxml2...
[platform/upstream/libxml2.git] / Makefile.am
1 ## Process this file with automake to produce Makefile.in
2
3 ACLOCAL_AMFLAGS = -I m4
4
5 SUBDIRS = include . doc example xstc $(PYTHON_SUBDIR)
6
7 DIST_SUBDIRS = include . doc example python xstc
8
9 AM_CPPFLAGS = -I$(top_builddir)/include -I$(srcdir)/include
10
11 AM_CFLAGS = $(THREAD_CFLAGS) $(Z_CFLAGS) $(LZMA_CFLAGS)
12
13 check_PROGRAMS=testSchemas testRelax testSAX testHTML testXPath testURI \
14                testThreads testC14N testAutomata testRegexp \
15                testReader testapi testModule runtest runsuite testchar \
16                testdict runxmlconf testrecurse testlimits
17
18 bin_PROGRAMS = xmllint xmlcatalog
19
20 bin_SCRIPTS=xml2-config
21
22 lib_LTLIBRARIES = libxml2.la
23 libxml2_la_LIBADD = $(ICU_LIBS) $(THREAD_LIBS) $(Z_LIBS) $(LZMA_LIBS) $(ICONV_LIBS) $(M_LIBS) $(WIN32_EXTRA_LIBADD)
24
25 if USE_VERSION_SCRIPT
26 LIBXML2_VERSION_SCRIPT = $(VERSION_SCRIPT_FLAGS)$(srcdir)/libxml2.syms
27 else
28 LIBXML2_VERSION_SCRIPT =
29 endif
30
31 libxml2_la_LDFLAGS = $(CYGWIN_EXTRA_LDFLAGS) $(WIN32_EXTRA_LDFLAGS) \
32                      $(LIBXML2_VERSION_SCRIPT) \
33                      -version-info $(LIBXML_VERSION_INFO) \
34                      $(MODULE_PLATFORM_LIBS)
35
36 if WITH_SAX1_SOURCES
37 docb_sources = DOCBparser.c
38 else
39 docb_sources =
40 endif
41
42 if WITH_TRIO_SOURCES
43 trio_sources = triostr.c trio.c
44 else
45 trio_sources =
46 endif
47
48 libxml2_la_SOURCES = SAX.c entities.c encoding.c error.c parserInternals.c  \
49                 parser.c tree.c hash.c list.c xmlIO.c xmlmemory.c uri.c  \
50                 valid.c xlink.c HTMLparser.c HTMLtree.c debugXML.c xpath.c  \
51                 xpointer.c xinclude.c nanohttp.c nanoftp.c \
52                 $(docb_sources) \
53                 catalog.c globals.c threads.c c14n.c xmlstring.c buf.c \
54                 xmlregexp.c xmlschemas.c xmlschemastypes.c xmlunicode.c \
55                 $(trio_sources) \
56                 xmlreader.c relaxng.c dict.c SAX2.c \
57                 xmlwriter.c legacy.c chvalid.c pattern.c xmlsave.c \
58                 xmlmodule.c schematron.c xzlib.c
59
60 DEPS = $(top_builddir)/libxml2.la
61 LDADDS = $(STATIC_BINARIES) $(top_builddir)/libxml2.la $(THREAD_LIBS) $(Z_LIBS) $(LZMA_LIBS) $(ICONV_LIBS) $(M_LIBS) $(WIN32_EXTRA_LIBADD)
62
63
64 man_MANS = xml2-config.1 libxml.3
65
66 m4datadir = $(datadir)/aclocal
67 m4data_DATA = libxml.m4
68
69 runtest_SOURCES=runtest.c
70 runtest_LDFLAGS = 
71 runtest_DEPENDENCIES = $(DEPS)
72 runtest_LDADD= $(BASE_THREAD_LIBS) $(RDL_LIBS) $(LDADDS)
73
74 testrecurse_SOURCES=testrecurse.c
75 testrecurse_LDFLAGS = 
76 testrecurse_DEPENDENCIES = $(DEPS)
77 testrecurse_LDADD= $(BASE_THREAD_LIBS) $(RDL_LIBS) $(LDADDS)
78
79 testlimits_SOURCES=testlimits.c
80 testlimits_LDFLAGS = 
81 testlimits_DEPENDENCIES = $(DEPS)
82 testlimits_LDADD= $(BASE_THREAD_LIBS) $(RDL_LIBS) $(LDADDS)
83
84 testchar_SOURCES=testchar.c
85 testchar_LDFLAGS = 
86 testchar_DEPENDENCIES = $(DEPS)
87 testchar_LDADD= $(RDL_LIBS) $(LDADDS)
88
89 testdict_SOURCES=testdict.c
90 testdict_LDFLAGS = 
91 testdict_DEPENDENCIES = $(DEPS)
92 testdict_LDADD= $(RDL_LIBS) $(LDADDS)
93
94 runsuite_SOURCES=runsuite.c
95 runsuite_LDFLAGS = 
96 runsuite_DEPENDENCIES = $(DEPS)
97 runsuite_LDADD= $(RDL_LIBS) $(LDADDS)
98
99 xmllint_SOURCES=xmllint.c
100 xmllint_LDFLAGS = 
101 xmllint_DEPENDENCIES = $(DEPS)
102 xmllint_LDADD=  $(RDL_LIBS) $(LDADDS)
103
104 testSAX_SOURCES=testSAX.c
105 testSAX_LDFLAGS = 
106 testSAX_DEPENDENCIES = $(DEPS)
107 testSAX_LDADD= $(LDADDS)
108
109 testHTML_SOURCES=testHTML.c
110 testHTML_LDFLAGS = 
111 testHTML_DEPENDENCIES = $(DEPS)
112 testHTML_LDADD= $(LDADDS)
113
114 xmlcatalog_SOURCES=xmlcatalog.c
115 xmlcatalog_LDFLAGS = 
116 xmlcatalog_DEPENDENCIES = $(DEPS)
117 xmlcatalog_LDADD = $(RDL_LIBS) $(LDADDS)
118
119 testXPath_SOURCES=testXPath.c
120 testXPath_LDFLAGS = 
121 testXPath_DEPENDENCIES = $(DEPS)
122 testXPath_LDADD= $(LDADDS)
123
124 testC14N_SOURCES=testC14N.c
125 testC14N_LDFLAGS = 
126 testC14N_DEPENDENCIES = $(DEPS)
127 testC14N_LDADD= $(LDADDS)
128
129 if THREADS_W32
130 testThreads_SOURCES = testThreadsWin32.c
131 else
132 testThreads_SOURCES = testThreads.c
133 endif
134 testThreads_LDFLAGS = 
135 testThreads_DEPENDENCIES = $(DEPS)
136 testThreads_LDADD= $(BASE_THREAD_LIBS) $(LDADDS)
137
138 testURI_SOURCES=testURI.c
139 testURI_LDFLAGS = 
140 testURI_DEPENDENCIES = $(DEPS)
141 testURI_LDADD= $(LDADDS)
142
143 testRegexp_SOURCES=testRegexp.c
144 testRegexp_LDFLAGS = 
145 testRegexp_DEPENDENCIES = $(DEPS)
146 testRegexp_LDADD= $(LDADDS)
147
148 testAutomata_SOURCES=testAutomata.c
149 testAutomata_LDFLAGS = 
150 testAutomata_DEPENDENCIES = $(DEPS)
151 testAutomata_LDADD= $(LDADDS)
152
153 testSchemas_SOURCES=testSchemas.c
154 testSchemas_LDFLAGS = 
155 testSchemas_DEPENDENCIES = $(DEPS)
156 testSchemas_LDADD= $(LDADDS)
157
158 testRelax_SOURCES=testRelax.c
159 testRelax_LDFLAGS = 
160 testRelax_DEPENDENCIES = $(DEPS)
161 testRelax_LDADD= $(LDADDS)
162
163 testReader_SOURCES=testReader.c
164 testReader_LDFLAGS = 
165 testReader_DEPENDENCIES = $(DEPS)
166 testReader_LDADD= $(LDADDS)
167
168 testModule_SOURCES=testModule.c
169 testModule_LDFLAGS = 
170 testModule_DEPENDENCIES = $(DEPS)
171 testModule_LDADD= $(LDADDS)
172
173 noinst_LTLIBRARIES = testdso.la
174 testdso_la_SOURCES = testdso.c
175 testdso_la_LDFLAGS = -module -no-undefined -avoid-version -rpath $(libdir)
176
177 # that one forces the rebuild when "make rebuild" is run on doc/
178 rebuild_testapi:
179         -@(if [ "$(PYTHON)" != "" ] ; then \
180             $(PYTHON) $(srcdir)/gentest.py $(srcdir) ; fi )
181
182 # that one is just to make sure it is rebuilt if missing
183 # but adding the dependances generate mess
184 testapi.c: $(srcdir)/gentest.py
185         -@(if [ "$(PYTHON)" != "" ] ; then \
186             $(PYTHON) $(srcdir)/gentest.py $(srcdir) ; fi )
187
188 BUILT_SOURCES = testapi.c
189
190 testapi_SOURCES=testapi.c
191 testapi_LDFLAGS = 
192 testapi_DEPENDENCIES = $(DEPS)
193 testapi_LDADD= $(LDADDS)
194
195 runxmlconf_SOURCES=runxmlconf.c
196 runxmlconf_LDFLAGS = 
197 runxmlconf_DEPENDENCIES = $(DEPS)
198 runxmlconf_LDADD= $(LDADDS)
199
200 #testOOM_SOURCES=testOOM.c testOOMlib.h testOOMlib.c
201 #testOOM_LDFLAGS = 
202 #testOOM_DEPENDENCIES = $(DEPS)
203 #testOOM_LDADD= $(LDADDS)
204
205 runtests: runtest$(EXEEXT) testrecurse$(EXEEXT) testapi$(EXEEXT) \
206           testchar$(EXEEXT) testdict$(EXEEXT) runxmlconf$(EXEEXT)
207         [ -d test   ] || $(LN_S) $(srcdir)/test   .
208         [ -d result ] || $(LN_S) $(srcdir)/result .
209         $(CHECKER) ./runtest$(EXEEXT) && \
210             $(CHECKER) ./testrecurse$(EXEEXT) && \
211             ASAN_OPTIONS="$$ASAN_OPTIONS:detect_leaks=0" $(CHECKER) ./testapi$(EXEEXT) && \
212             $(CHECKER) ./testchar$(EXEEXT) && \
213             $(CHECKER) ./testdict$(EXEEXT) && \
214             $(CHECKER) ./runxmlconf$(EXEEXT)
215         @(if [ "$(PYTHON_SUBDIR)" != "" ] ; then cd python ; \
216             $(MAKE) tests ; fi)
217
218 check: all runtests
219
220 check-valgrind valgrind: all
221         @echo '## Running the regression tests under Valgrind'
222         @echo '## Go get a cup of coffee it is gonna take a while ...'
223         $(MAKE) CHECKER='valgrind -q' runtests
224
225 asan:
226         @echo '## rebuilding for ASAN'
227         ./configure CFLAGS="-fsanitize=address,undefined -Wformat -Werror=format-security -Werror=array-bounds -g" CXXFLAGS="-fsanitize=address,undefined -Wformat -Werror=format-security -Werror=array-bounds -g" LDFLAGS="-fsanitize=address,undefined" CC="clang" CXX="clang++" --disable-shared ; OptimOff  ; $(MAKE) clean ; $(MAKE)
228
229 testall : tests SVGtests SAXtests
230
231 tests: XMLtests XMLenttests NStests IDtests Errtests APItests $(READER_TEST) $(TEST_SAX) $(TEST_PUSH) $(TEST_HTML) $(TEST_PHTML) $(TEST_VALID) URItests $(TEST_PATTERN) $(TEST_XPATH) $(TEST_XPTR) $(TEST_XINCLUDE) $(TEST_C14N) $(TEST_DEBUG) $(TEST_CATALOG) $(TEST_REGEXPS) $(TEST_SCHEMAS) $(TEST_SCHEMATRON) $(TEST_THREADS) Timingtests $(TEST_VTIME) $(PYTHON_TESTS) $(TEST_MODULES)
232         @(if [ "$(PYTHON_SUBDIR)" != "" ] ; then cd python ; \
233             $(MAKE) -s tests ; fi)
234         @(cd doc/examples ; $(MAKE) -s tests)
235
236 APItests: testapi$(EXEEXT)
237         @echo "## Running the API regression tests this may take a little while"
238         -@(ASAN_OPTIONS="$$ASAN_OPTIONS:detect_leaks=0" $(CHECKER) $(top_builddir)/testapi -q)
239
240 HTMLtests : testHTML$(EXEEXT)
241         @(echo > .memdump)
242         @echo "## HTML regression tests"
243         -@(for i in $(srcdir)/test/HTML/* ; do \
244           name=`basename $$i`; \
245           if [ ! -d $$i ] ; then \
246           if [ ! -f $(srcdir)/result/HTML/$$name ] ; then \
247               echo New test file $$name ; \
248               $(CHECKER) $(top_builddir)/testHTML $$i > $(srcdir)/result/HTML/$$name 2>$(srcdir)/result/HTML/$$name.err ; \
249           else \
250               log=`$(CHECKER) $(top_builddir)/testHTML $$i > result.$$name 2> error.$$name ; \
251               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
252               diff $(srcdir)/result/HTML/$$name result.$$name ; \
253               diff -b $(srcdir)/result/HTML/$$name.err error.$$name ; \
254               $(CHECKER) $(top_builddir)/testHTML result.$$name > result2.$$name 2>error.$$name ; \
255               diff result.$$name result2.$$name` ; \
256               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
257               rm result.$$name result2.$$name error.$$name ; \
258           fi ; fi ; done)
259
260 HTMLPushtests : testHTML$(EXEEXT)
261         @echo "## Push HTML regression tests"
262         -@(for i in $(srcdir)/test/HTML/* ; do \
263           name=`basename $$i`; \
264           if [ ! -d $$i ] ; then \
265           if [ ! -f $(srcdir)/result/HTML/$$name ] ; then \
266               echo New test file $$name ; \
267               $(CHECKER) $(top_builddir)/testHTML --push $$i > $(srcdir)/result/HTML/$$name 2>$(srcdir)/result/HTML/$$name.err ; \
268           else \
269               log=`$(CHECKER) $(top_builddir)/testHTML --push $$i > result.$$name 2> error.$$name ; \
270               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
271               diff $(srcdir)/result/HTML/$$name result.$$name ; \
272               cut -b 1-15 $(srcdir)/result/HTML/$$name.err > errorcut.$$name; \
273               cut -b 1-15 error.$$name > errorcut2.$$name; \
274               diff -b errorcut.$$name errorcut2.$$name ; \
275               $(CHECKER) $(top_builddir)/testHTML --push result.$$name > result2.$$name 2>error.$$name ; \
276               diff result.$$name result2.$$name` ; \
277               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
278               rm result.$$name result2.$$name error.$$name errorcut.$$name errorcut2.$$name ; \
279           fi ; fi ; done)
280         @echo "## HTML SAX regression tests"
281         -@(for i in $(srcdir)/test/HTML/* ; do \
282           name=`basename $$i`; \
283           if [ ! -d $$i ] ; then \
284           if [ ! -f $(srcdir)/result/HTML/$$name.sax ] ; then \
285               echo New test file $$name ; \
286               $(CHECKER) $(top_builddir)/testHTML --sax $$i > $(srcdir)/result/HTML/$$name.sax ; \
287           else \
288               log=`$(CHECKER) $(top_builddir)/testHTML --sax $$i > result.$$name.sax ; \
289               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
290               diff $(srcdir)/result/HTML/$$name.sax result.$$name.sax` ; \
291               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
292               rm result.$$name.sax ; \
293           fi ; fi ; done)
294         @echo "## Push HTML SAX regression tests"
295         -@(for i in $(srcdir)/test/HTML/* ; do \
296           name=`basename $$i`; \
297           if [ ! -d $$i ] ; then \
298           if [ ! -f $(srcdir)/result/HTML/$$name ] ; then \
299               echo New test file $$name ; \
300               $(CHECKER) $(top_builddir)/testHTML --push --sax $$i > $(srcdir)/result/HTML/$$name.sax ; \
301           else \
302               log=`$(CHECKER) $(top_builddir)/testHTML --push --sax $$i 2>&1 > result.$$name.sax ; \
303               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
304               diff $(srcdir)/result/HTML/$$name.sax result.$$name.sax` ; \
305               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
306               rm result.$$name.sax ; \
307           fi ; fi ; done)
308
309 XMLtests : xmllint$(EXEEXT)
310         @(echo > .memdump)
311         @echo "## XML regression tests"
312         -@(for i in $(srcdir)/test/* ; do \
313           name=`basename $$i`; \
314           if [ ! -d $$i ] ; then \
315           if [ ! -f $(srcdir)/result/$$name ] ; then \
316               echo New test file $$name ; \
317               $(CHECKER) $(top_builddir)/xmllint $$i > $(srcdir)/result/$$name ; \
318               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
319           else \
320               log=`$(CHECKER) $(top_builddir)/xmllint $$i 2>&1 > result.$$name ; \
321               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
322               diff $(srcdir)/result/$$name result.$$name ; \
323               $(CHECKER) $(top_builddir)/xmllint result.$$name 2>&1 > result2.$$name | grep -v 'failed to load external entity' ; \
324               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
325               diff result.$$name result2.$$name` ;\
326               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
327               rm result.$$name result2.$$name ; \
328           fi ; fi ; done)
329         @echo "## XML regression tests on memory"
330         -@(for i in $(srcdir)/test/* ; do \
331           name=`basename $$i`; \
332           if [ ! -d $$i ] ; then \
333           if [ ! -f $(srcdir)/result/$$name ] ; then \
334               echo New test file $$name ; \
335               $(CHECKER) $(top_builddir)/xmllint --memory $$i > $(srcdir)/result/$$name ; \
336               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
337           else \
338               log=`$(CHECKER) $(top_builddir)/xmllint --memory $$i 2>&1 > result.$$name ; \
339               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
340               diff $(srcdir)/result/$$name result.$$name ; \
341               $(CHECKER) $(top_builddir)/xmllint --memory result.$$name 2>&1 > result2.$$name | grep -v 'failed to load external entity' ; \
342               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"`; \
343               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
344               diff result.$$name result2.$$name ; \
345               rm result.$$name result2.$$name ; \
346           fi ; fi ; done)
347
348 XMLPushtests: xmllint$(EXEEXT)
349         @(echo > .memdump)
350         @echo "## XML push regression tests"
351         -@(for i in $(srcdir)/test/* ; do \
352           name=`basename $$i`; \
353           if [ ! -d $$i ] ; then \
354           if [ ! -f $(srcdir)/result/$$name ] ; then \
355               echo New test file $$name ; \
356               $(CHECKER) $(top_builddir)/xmllint --push $$i > $(srcdir)/result/$$name ; \
357               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
358           else \
359               log=`$(CHECKER) $(top_builddir)/xmllint --push $$i 2>&1 > result.$$name ; \
360               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
361               diff $(srcdir)/result/$$name result.$$name ; \
362               $(CHECKER) $(top_builddir)/xmllint --push result.$$name 2>&1 > result2.$$name | grep -v 'failed to load external entity' ; \
363               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
364               diff result.$$name result2.$$name` ; \
365               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
366               rm result.$$name result2.$$name ; \
367           fi ; fi ; done)
368
369 NStests : xmllint$(EXEEXT)
370         @(echo > .memdump)
371         @echo "## XML Namespaces regression tests"
372         -@(for i in $(srcdir)/test/namespaces/* ; do \
373           name=`basename $$i`; \
374           if [ ! -d $$i ] ; then \
375           if [ ! -f $(srcdir)/result/namespaces/$$name ] ; then \
376               echo New test file $$name ; \
377               $(CHECKER) $(top_builddir)/xmllint $$i \
378                  2> $(srcdir)/result/namespaces/$$name.err \
379                  > $(srcdir)/result/namespaces/$$name ; \
380               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
381           else \
382               log=`$(CHECKER) $(top_builddir)/xmllint $$i 2> error.$$name > result.$$name ; \
383               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
384               diff $(srcdir)/result/namespaces/$$name result.$$name ; \
385               diff $(srcdir)/result/namespaces/$$name.err error.$$name`; \
386               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
387               rm result.$$name error.$$name ; \
388           fi ; fi ; done)
389
390 IDtests : xmllint$(EXEEXT) testXPath$(EXEEXT)
391         @(echo > .memdump)
392         @echo "## xml:id regression tests"
393         -@(for i in $(srcdir)/test/xmlid/id_*.xml ; do \
394           name=`basename $$i`; \
395           if [ ! -d $$i ] ; then \
396           if [ ! -f $(srcdir)/result/xmlid/$$name ] ; then \
397               echo New test file $$name ; \
398               $(CHECKER) $(top_builddir)/testXPath -i $$i "id('bar')" \
399                  2> $(srcdir)/result/xmlid/$$name.err \
400                  > $(srcdir)/result/xmlid/$$name ; \
401               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
402           else \
403               log=`$(CHECKER) $(top_builddir)/testXPath -i $$i "id('bar')" 2> error.$$name > result.$$name ; \
404               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
405               diff $(srcdir)/result/xmlid/$$name result.$$name ; \
406               diff $(srcdir)/result/xmlid/$$name.err error.$$name` ; \
407               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
408               rm result.$$name error.$$name ; \
409           fi ; fi ; done)
410
411 Errtests : xmllint$(EXEEXT)
412         @(echo > .memdump)
413         @echo "## Error cases regression tests"
414         -@(for i in $(srcdir)/test/errors/*.xml ; do \
415           name=`basename $$i`; \
416           if [ ! -d $$i ] ; then \
417           if [ ! -f $(srcdir)/result/errors/$$name ] ; then \
418               echo New test file $$name ; \
419               $(CHECKER) $(top_builddir)/xmllint $$i \
420                  2> $(srcdir)/result/errors/$$name.err \
421                  > $(srcdir)/result/errors/$$name ; \
422               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
423           else \
424               log=`$(CHECKER) $(top_builddir)/xmllint $$i 2> error.$$name > result.$$name ; \
425               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
426               diff $(srcdir)/result/errors/$$name result.$$name ; \
427               diff $(srcdir)/result/errors/$$name.err error.$$name` ; \
428               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
429               rm result.$$name error.$$name ; \
430           fi ; fi ; done)
431         @echo "## Error cases regression tests (old 1.0)"
432         -@(for i in $(srcdir)/test/errors10/*.xml ; do \
433           name=`basename $$i`; \
434           if [ ! -d $$i ] ; then \
435           if [ ! -f $(srcdir)/result/errors10/$$name ] ; then \
436               echo New test file $$name ; \
437               $(CHECKER) $(top_builddir)/xmllint --oldxml10 $$i \
438                  2> $(srcdir)/result/errors10/$$name.err \
439                  > $(srcdir)/result/errors10/$$name ; \
440               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
441           else \
442               log=`$(CHECKER) $(top_builddir)/xmllint --oldxml10 $$i 2> error.$$name > result.$$name ; \
443               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
444               diff $(srcdir)/result/errors10/$$name result.$$name ; \
445               diff $(srcdir)/result/errors10/$$name.err error.$$name` ; \
446               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
447               rm result.$$name error.$$name ; \
448           fi ; fi ; done)
449         @echo "## Error cases stream regression tests"
450         -@(for i in $(srcdir)/test/errors/*.xml ; do \
451           name=`basename $$i`; \
452           if [ ! -d $$i ] ; then \
453           if [ ! -f $(srcdir)/result/errors/$$name.str ] ; then \
454               echo New test file $$name ; \
455               $(CHECKER) $(top_builddir)/xmllint --stream $$i \
456                  2> $(srcdir)/result/errors/$$name.str \
457                  > /dev/null ; \
458               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
459           else \
460               log=`$(CHECKER) $(top_builddir)/xmllint --stream $$i 2> error.$$name > /dev/null ; \
461               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
462               diff $(srcdir)/result/errors/$$name.str error.$$name` ; \
463               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
464               rm error.$$name ; \
465           fi ; fi ; done)
466
467 Docbtests : xmllint$(EXEEXT)
468
469 XMLenttests : xmllint$(EXEEXT)
470         @(echo > .memdump)
471         @echo "## XML entity subst regression tests"
472         -@(for i in $(srcdir)/test/* ; do \
473           name=`basename $$i`; \
474           if [ ! -d $$i ] ; then \
475           if [ ! -f $(srcdir)/result/noent/$$name ] ; then \
476               echo New test file $$name ; \
477               $(CHECKER) $(top_builddir)/xmllint --noent $$i > $(srcdir)/result/noent/$$name ; \
478               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
479           else \
480               log=`$(CHECKER) $(top_builddir)/xmllint --noent $$i 2>&1 > result.$$name ; \
481               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
482               diff $(srcdir)/result/noent/$$name result.$$name ; \
483               $(CHECKER) $(top_builddir)/xmllint --noent result.$$name 2>&1 > result2.$$name ; \
484               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
485               diff result.$$name result2.$$name` ; \
486               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
487               rm result.$$name result2.$$name ; \
488           fi ; fi ; done)
489
490 URItests : testURI$(EXEEXT)
491         @(echo > .memdump)
492         @echo "## URI module regression tests"
493         -@(for i in $(srcdir)/test/URI/*.data ; do \
494           name=`basename $$i`; \
495           if [ ! -d $$i ] ; then \
496           if [ ! -f $(srcdir)/result/URI/$$name ] ; then \
497               echo New test file $$name ; \
498               $(CHECKER) $(top_builddir)/testURI -base 'http://foo.com/path/to/index.html?orig#help' < $$i > $(srcdir)/result/URI/$$name ; \
499               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
500           else \
501               log=`$(CHECKER) $(top_builddir)/testURI -base 'http://foo.com/path/to/index.html?orig#help' < $$i 2>&1 > result.$$name ; \
502               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
503               diff $(srcdir)/result/URI/$$name result.$$name` ; \
504               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
505               rm result.$$name ; \
506           fi ; fi ; done)
507         -@(for i in $(srcdir)/test/URI/*.uri ; do \
508           name=`basename $$i`; \
509           if [ ! -d $$i ] ; then \
510           if [ ! -f $(srcdir)/result/URI/$$name ] ; then \
511               echo New test file $$name ; \
512               $(CHECKER) $(top_builddir)/testURI < $$i > $(srcdir)/result/URI/$$name ; \
513               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
514           else \
515               log=`$(CHECKER) $(top_builddir)/testURI < $$i 2>&1 > result.$$name ; \
516               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
517               diff $(srcdir)/result/URI/$$name result.$$name` ; \
518               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
519               rm result.$$name ; \
520           fi ; fi ; done)
521
522 XPathtests : testXPath$(EXEEXT)
523         @(echo > .memdump)
524         @echo "## XPath regression tests"
525         -@(if [ "`$(top_builddir)/testXPath | grep 'support not compiled in'`" != "" ] ; \
526           then echo Skipping debug not compiled in ; exit 0 ; fi ; \
527           for i in $(srcdir)/test/XPath/expr/* ; do \
528           name=`basename $$i`; \
529           if [ ! -d $$i ] ; then \
530           if [ ! -f $(srcdir)/result/XPath/expr/$$name ] ; then \
531               echo New test file $$name ; \
532               $(CHECKER) $(top_builddir)/testXPath -f --expr $$i > $(srcdir)/result/XPath/expr/$$name 2> /dev/null ; \
533               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
534           else \
535               log=`$(CHECKER) $(top_builddir)/testXPath -f --expr $$i > result.$$name 2> /dev/null ; \
536               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
537               diff $(srcdir)/result/XPath/expr/$$name result.$$name` ; \
538               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
539               rm result.$$name ; \
540           fi ; fi ; done ; \
541           for i in $(srcdir)/test/XPath/docs/* ; do \
542           if [ ! -d $$i ] ; then \
543           doc=`basename $$i`; \
544           for j in $(srcdir)/test/XPath/tests/$$doc* ; do \
545           if [ ! -f $$j ] ; then continue ; fi ; \
546           name=`basename $$j`; \
547           if [ ! -d $$j ] ; then \
548           if [ ! -f $(srcdir)/result/XPath/tests/$$name ] ; then \
549               echo New test file $$name ; \
550               $(CHECKER) $(top_builddir)/testXPath -f -i $$i $$j > $(srcdir)/result/XPath/tests/$$name ; \
551               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
552           else \
553               log=`$(CHECKER) $(top_builddir)/testXPath -f -i $$i $$j > result.$$name ; \
554               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
555               diff $(srcdir)/result/XPath/tests/$$name result.$$name` ; \
556               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
557               rm result.$$name ; \
558           fi ; fi ; done ; fi ; done)
559
560 XPtrtests : testXPath$(EXEEXT)
561         @(echo > .memdump)
562         @echo "## XPointer regression tests"
563         -@(if [ "`$(top_builddir)/testXPath | grep 'support not compiled in'`" != "" ] ; \
564           then echo Skipping debug not compiled in ; exit 0 ; fi ; \
565           for i in $(srcdir)/test/XPath/docs/* ; do \
566           if [ ! -d $$i ] ; then \
567           doc=`basename $$i`; \
568           for j in $(srcdir)/test/XPath/xptr/$$doc* ; do \
569           if [ ! -f $$j ] ; then continue ; fi ; \
570           name=`basename $$j`; \
571           if [ ! -d $$j ] ; then \
572           if [ ! -f $(srcdir)/result/XPath/xptr/$$name ] ; then \
573               echo New test file $$name ; \
574               $(CHECKER) $(top_builddir)/testXPath -xptr -f -i $$i $$j > $(srcdir)/result/XPath/xptr/$$name 2> /dev/null ; \
575               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
576           else \
577               log=`$(CHECKER) $(top_builddir)/testXPath -xptr -f -i $$i $$j > result.$$name 2> /dev/null ; \
578               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
579               diff $(srcdir)/result/XPath/xptr/$$name result.$$name` ; \
580               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
581               rm result.$$name ; \
582           fi ; fi ; done ; fi ; done)
583
584 XIncludetests : xmllint$(EXEEXT)
585         @(echo > .memdump)
586         @echo "## XInclude regression tests"
587         -@(for i in $(srcdir)/test/XInclude/docs/* ; do \
588           name=`basename $$i`; \
589           if [ ! -d $$i ] ; then \
590           if [ ! -f $(srcdir)/result/XInclude/$$name ] ; then \
591               echo New test file $$name ; \
592               $(CHECKER) $(top_builddir)/xmllint --nowarning --xinclude $$i > $(srcdir)/result/XInclude/$$name 2> $(srcdir)/result/XInclude/$$name.err ; \
593               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
594           else \
595               log=`$(CHECKER) $(top_builddir)/xmllint --nowarning --xinclude $$i > result.$$name 2>error.$$name ; \
596               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
597               diff $(srcdir)/result/XInclude/$$name result.$$name ; \
598               diff $(srcdir)/result/XInclude/$$name.err error.$$name` ; \
599               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
600               rm result.$$name error.$$name ; \
601           fi ; fi ; done)
602         -@(for i in $(srcdir)/test/XInclude/docs/* ; do \
603           name=`basename $$i`; \
604           if [ ! -d $$i ] ; then \
605           if [ ! -f $(srcdir)/result/XInclude/$$name ] ; then \
606               echo New test file $$name ; \
607               $(CHECKER) $(top_builddir)/xmllint --nowarning --noxincludenode $$i > $(srcdir)/result/XInclude/$$name 2> $(srcdir)/result/XInclude/$$name.err ; \
608               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
609           else \
610               log=`$(CHECKER) $(top_builddir)/xmllint --nowarning --noxincludenode $$i > result.$$name 2>error.$$name ; \
611               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
612               diff $(srcdir)/result/XInclude/$$name result.$$name ; \
613               diff $(srcdir)/result/XInclude/$$name.err error.$$name` ; \
614               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
615               rm result.$$name error.$$name ; \
616           fi ; fi ; done)
617         @(echo > .memdump)
618         @echo "## XInclude xmlReader regression tests"
619         -@(for i in $(srcdir)/test/XInclude/docs/* ; do \
620           name=`basename $$i`; \
621           if [ ! -d $$i ] ; then \
622           if [ ! -f $(srcdir)/result/XInclude/$$name.rdr ] ; then \
623               echo New test file $$name ; \
624               $(CHECKER) $(top_builddir)/xmllint --nowarning --xinclude --stream --debug $$i > $(srcdir)/result/XInclude/$$name.rdr ; \
625               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
626           else \
627               log=`$(CHECKER) $(top_builddir)/xmllint --nowarning --xinclude --stream --debug $$i > result.$$name 2>error.$$name ; \
628               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
629               diff $(srcdir)/result/XInclude/$$name.err error.$$name ; \
630               diff $(srcdir)/result/XInclude/$$name.rdr result.$$name` ; \
631               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
632               rm result.$$name error.$$name ; \
633           fi ; fi ; done)
634         -@(for i in $(srcdir)/test/XInclude/docs/* ; do \
635           name=`basename $$i`; \
636           if [ ! -d $$i ] ; then \
637           if [ ! -f $(srcdir)/result/XInclude/$$name.rdr ] ; then \
638               echo New test file $$name ; \
639               $(CHECKER) $(top_builddir)/xmllint --nowarning --noxincludenode --stream --debug $$i > $(srcdir)/result/XInclude/$$name.rdr ; \
640               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
641           else \
642               log=`$(CHECKER) $(top_builddir)/xmllint --nowarning --xinclude --stream --debug $$i > result.$$name 2>error.$$name ; \
643               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
644               diff $(srcdir)/result/XInclude/$$name.err error.$$name ; \
645               diff $(srcdir)/result/XInclude/$$name.rdr result.$$name` ; \
646               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
647               rm result.$$name error.$$name ; \
648           fi ; fi ; done)
649
650 Scripttests : xmllint$(EXEEXT)
651         @(echo > .memdump)
652         @echo "## Scripts regression tests"
653         @echo "## Some of the base computations may be different if srcdir != ."
654         -@(for i in $(srcdir)/test/scripts/*.script ; do \
655           name=`basename $$i .script`; \
656           xml=$(srcdir)/test/scripts/`basename $$i .script`.xml; \
657           if [ -f $$xml ] ; then \
658           if [ ! -f $(srcdir)/result/scripts/$$name ] ; then \
659               echo New test file $$name ; \
660               $(CHECKER) $(top_builddir)/xmllint --shell $$xml < $$i > $(srcdir)/result/scripts/$$name 2> $(srcdir)/result/scripts/$$name.err ; \
661               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
662           else \
663               log=`$(CHECKER) $(top_builddir)/xmllint --shell $$xml < $$i > result.$$name 2> result.$$name.err ; \
664               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
665               diff $(srcdir)/result/scripts/$$name result.$$name ; \
666               diff $(srcdir)/result/scripts/$$name.err result.$$name.err` ; \
667               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
668               rm result.$$name result.$$name.err ; \
669           fi ; fi ; done)
670
671 Catatests : xmlcatalog$(EXEEXT)
672         @(echo > .memdump)
673         @echo "## Catalog regression tests"
674         -@(for i in $(srcdir)/test/catalogs/*.script ; do \
675           name=`basename $$i .script`; \
676           xml=$(srcdir)/test/catalogs/`basename $$i .script`.xml; \
677           if [ -f $$xml ] ; then \
678           if [ ! -f $(srcdir)/result/catalogs/$$name ] ; then \
679               echo New test file $$name ; \
680               $(CHECKER) $(top_builddir)/xmlcatalog --shell $$xml < $$i 2>&1 > $(srcdir)/result/catalogs/$$name ; \
681               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
682           else \
683               log=`$(CHECKER) $(top_builddir)/xmlcatalog --shell $$xml < $$i 2>&1 > result.$$name ; \
684               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
685               diff $(srcdir)/result/catalogs/$$name result.$$name` ; \
686               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
687               rm result.$$name ; \
688           fi ; fi ; done)
689         -@(for i in $(srcdir)/test/catalogs/*.script ; do \
690           name=`basename $$i .script`; \
691           sgml=$(srcdir)/test/catalogs/`basename $$i .script`.sgml; \
692           if [ -f $$sgml ] ; then \
693           if [ ! -f $(srcdir)/result/catalogs/$$name ] ; then \
694               echo New test file $$name ; \
695               $(CHECKER) $(top_builddir)/xmlcatalog --shell $$sgml < $$i > $(srcdir)/result/catalogs/$$name ; \
696               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
697           else \
698               log=`$(CHECKER) $(top_builddir)/xmlcatalog --shell $$sgml < $$i > result.$$name ; \
699               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
700               diff $(srcdir)/result/catalogs/$$name result.$$name` ; \
701               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
702               rm result.$$name ; \
703           fi ; fi ; done)
704         @echo "## Add and del operations on XML Catalogs"
705         -@($(CHECKER) $(top_builddir)/xmlcatalog --create --noout $(srcdir)/result/catalogs/mycatalog; \
706         grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
707         $(CHECKER) $(top_builddir)/xmlcatalog --noout --add public Pubid sysid $(srcdir)/result/catalogs/mycatalog; \
708         grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
709         $(CHECKER) $(top_builddir)/xmlcatalog --noout --add public Pubid2 sysid2 $(srcdir)/result/catalogs/mycatalog; \
710         grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
711         $(CHECKER) $(top_builddir)/xmlcatalog --noout --add public Pubid3 sysid3 $(srcdir)/result/catalogs/mycatalog; \
712         grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
713         diff result/catalogs/mycatalog.full $(srcdir)/result/catalogs/mycatalog; \
714         grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
715         $(CHECKER) $(top_builddir)/xmlcatalog --noout --del sysid $(srcdir)/result/catalogs/mycatalog; \
716         grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
717         $(CHECKER) $(top_builddir)/xmlcatalog --noout --del sysid3 $(srcdir)/result/catalogs/mycatalog; \
718         grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
719         $(CHECKER) $(top_builddir)/xmlcatalog --noout --del sysid2 $(srcdir)/result/catalogs/mycatalog; \
720         grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
721         diff result/catalogs/mycatalog.empty $(srcdir)/result/catalogs/mycatalog; \
722         grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
723         rm -f $(srcdir)/result/catalogs/mycatalog)
724
725 SVGtests : xmllint$(EXEEXT)
726         @echo "## SVG parsing regression tests"
727         -@(for i in $(srcdir)/test/SVG/* ; do \
728           name=`basename $$i`; \
729           if [ ! -d $$i ] ; then \
730           if [ ! -f $(srcdir)/result/SVG/$$name ] ; then \
731               echo New test file $$name ; \
732               $(CHECKER) $(top_builddir)/xmllint $$i > $(srcdir)/result/SVG/$$name ; \
733               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
734           else \
735               echo Testing $$name ; \
736               $(CHECKER) $(top_builddir)/xmllint $$i > result.$$name ; \
737               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
738               diff $(srcdir)/result/SVG/$$name result.$$name ; \
739               $(CHECKER) $(top_builddir)/xmllint result.$$name > result2.$$name ; \
740               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
741               diff result.$$name result2.$$name ; \
742               rm result.$$name result2.$$name ; \
743           fi ; fi ; done)
744
745 Threadtests : testThreads$(EXEEXT)
746         @echo "## Threaded regression tests"
747         -@($(CHECKER) $(top_builddir)/testThreads ; \
748            grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"; \
749            exit 0)
750
751 Readertests : xmllint$(EXEEXT)
752         @(echo > .memdump)
753         @echo "## Reader regression tests"
754         -@(for i in $(srcdir)/test/* ; do \
755           name=`basename $$i`; \
756           if [ ! -d $$i ] ; then \
757           if [ ! -f $(srcdir)/result/$$name.rdr ] ; then \
758               echo New test file $$name ; \
759               $(CHECKER) $(top_builddir)/xmllint --nonet --debug --stream $$i > $(srcdir)/result/$$name.rdr 2>/dev/null ; \
760               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
761           else \
762               log=`$(CHECKER) $(top_builddir)/xmllint --nonet --debug --stream $$i > result.$$name 2>/dev/null ; \
763               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
764               diff $(srcdir)/result/$$name.rdr result.$$name` ; \
765               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
766               rm result.$$name ; \
767           fi ; fi ; done)
768         @echo "## Reader on memory regression tests"
769         -@(for i in $(srcdir)/test/* ; do \
770           name=`basename $$i`; \
771           if [ ! -d $$i ] ; then \
772           if [ ! -f $(srcdir)/result/$$name.rdr ] ; then \
773               echo New test file $$name ; \
774               $(CHECKER) $(top_builddir)/xmllint --memory --nonet --debug --stream $$i > $(srcdir)/result/$$name.rdr 2>/dev/null ; \
775               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
776           else \
777               log=`$(CHECKER) $(top_builddir)/xmllint --memory --nonet --debug --stream $$i > result.$$name 2>/dev/null ; \
778               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
779               diff $(srcdir)/result/$$name.rdr result.$$name` ; \
780               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
781               rm result.$$name ; \
782           fi ; fi ; done)
783         @(echo > .memdump)
784         @echo "## Walker regression tests"
785         -@(for i in $(srcdir)/test/* ; do \
786           name=`basename $$i`; \
787           if [ ! -d $$i ] ; then \
788           if [ ! -f $(srcdir)/result/$$name.rdr ] ; then \
789               echo New test file $$name ; \
790               $(CHECKER) $(top_builddir)/xmllint --nonet --debug --walker $$i > $(srcdir)/result/$$name.rdr 2>/dev/null ; \
791               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
792           else \
793               log=`$(CHECKER) $(top_builddir)/xmllint --nonet --debug --walker $$i > result.$$name 2>/dev/null ; \
794               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
795               diff $(srcdir)/result/$$name.rdr result.$$name` ; \
796               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
797               rm result.$$name ; \
798           fi ; fi ; done)
799         @echo "## Reader entities substitution regression tests"
800         -@(for i in $(srcdir)/test/* ; do \
801           name=`basename $$i`; \
802           if [ ! -d $$i ] ; then \
803           if [ ! -f $(srcdir)/result/$$name.rde ] ; then \
804               echo New test file $$name ; \
805               $(CHECKER) $(top_builddir)/xmllint --noent --nonet --debug --stream $$i > $(srcdir)/result/$$name.rde 2>/dev/null ; \
806               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
807           else \
808               log=`$(CHECKER) $(top_builddir)/xmllint --noent --nonet --debug --stream $$i > result.$$name 2>/dev/null ; \
809               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
810               diff $(srcdir)/result/$$name.rde result.$$name` ; \
811               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
812               rm result.$$name ; \
813           fi ; fi ; done)
814
815 SAXtests : testSAX$(EXEEXT)
816         @(echo > .memdump)
817         @echo "## SAX1 callbacks regression tests"
818         -@(for i in $(srcdir)/test/* ; do \
819           name=`basename $$i`; \
820           if [ ! -d $$i ] ; then \
821           if [ ! -f $(srcdir)/result/$$name.sax ] ; then \
822               echo New test file $$name ; \
823               $(CHECKER) $(top_builddir)/testSAX $$i > $(srcdir)/result/$$name.sax 2> /dev/null ; \
824               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
825           else \
826               log=`$(CHECKER) $(top_builddir)/testSAX $$i > result.$$name 2> /dev/null ; \
827               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
828               diff $(srcdir)/result/$$name.sax result.$$name` ; \
829               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
830               rm result.$$name ; \
831           fi ; fi ; done)
832         @echo "## SAX2 callbacks regression tests"
833         -@(for i in $(srcdir)/test/* ; do \
834           name=`basename $$i`; \
835           if [ ! -d $$i ] ; then \
836           if [ ! -f $(srcdir)/result/$$name.sax2 ] ; then \
837               echo New test file $$name ; \
838               $(CHECKER) $(top_builddir)/testSAX --sax2 $$i > $(srcdir)/result/$$name.sax2 2> /dev/null ; \
839               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
840           else \
841               log=`$(CHECKER) $(top_builddir)/testSAX --sax2 $$i > result.$$name 2> /dev/null ; \
842               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
843               diff $(srcdir)/result/$$name.sax2 result.$$name` ; \
844               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
845               rm result.$$name ; \
846           fi ; fi ; done)
847         @echo "## SAX2 callbacks regression tests with entity substitution"
848         -@(for i in $(srcdir)/test/* ; do \
849           name=`basename $$i`; \
850           if [ ! -d $$i ] ; then \
851           if [ ! -f $(srcdir)/result/noent/$$name.sax2 ] ; then \
852               echo New test file $$name ; \
853               $(CHECKER) $(top_builddir)/testSAX --sax2 --noent $$i > $(srcdir)/result/noent/$$name.sax2 2> /dev/null ; \
854               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
855           else \
856               log=`$(CHECKER) $(top_builddir)/testSAX --sax2 --noent $$i > result.$$name 2> /dev/null ; \
857               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
858               diff $(srcdir)/result/noent/$$name.sax2 result.$$name` ; \
859               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
860               rm result.$$name ; \
861           fi ; fi ; done)
862
863 Validtests : xmllint$(EXEEXT)
864         @(echo > .memdump)
865         @echo "## Valid documents regression tests"
866         -@(for i in $(srcdir)/test/VCM/* ; do \
867           name=`basename $$i`; \
868           if [ ! -d $$i ] ; then \
869               log=`$(CHECKER) $(top_builddir)/xmllint --valid --noout --nowarning $$i ; \
870               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0"`;\
871               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
872           fi ; done ; exit 0)
873         @echo "## Validity checking regression tests"
874         -@(for i in $(srcdir)/test/VC/* ; do \
875           name=`basename $$i`; \
876           if [ ! -d $$i ] ; then \
877           if [ ! -f $(srcdir)/result/VC/$$name ] ; then \
878               echo New test file $$name ; \
879               $(CHECKER) $(top_builddir)/xmllint --noout --valid $$i 2> $(srcdir)/result/VC/$$name ; \
880               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
881           else \
882               log=`$(CHECKER) $(top_builddir)/xmllint --noout --valid $$i 2> result.$$name ; \
883               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
884               diff $(srcdir)/result/VC/$$name result.$$name` ; \
885               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
886               rm result.$$name ; \
887           fi ; fi ; done)
888         @echo "## General documents valid regression tests"
889         -@(for i in $(srcdir)/test/valid/* ; do \
890           name=`basename $$i`; \
891           if [ ! -d $$i ] ; then \
892           if [ ! -f $(srcdir)/result/valid/$$name ] ; then \
893               echo New test file $$name ; \
894               $(CHECKER) $(top_builddir)/xmllint --valid $$i > $(srcdir)/result/valid/$$name 2>$(srcdir)/result/valid/$$name.err ; \
895               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
896           else \
897               log=`$(CHECKER) $(top_builddir)/xmllint --valid $$i > result.$$name 2>error.$$name ; \
898               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
899               diff $(srcdir)/result/valid/$$name result.$$name ; \
900               diff $(srcdir)/result/valid/$$name.err error.$$name` ; \
901               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
902               rm result.$$name error.$$name ; \
903           fi ; fi ; done)
904
905 Regexptests: testRegexp$(EXEEXT)
906         @(echo > .memdump)
907         @echo "## Regexp regression tests"
908         -@(for i in $(srcdir)/test/regexp/* ; do \
909           name=`basename $$i`; \
910           if [ ! -d $$i ] ; then \
911           if [ ! -f $(srcdir)/result/regexp/$$name ] ; then \
912               echo New test file $$name ; \
913               $(CHECKER) $(top_builddir)/testRegexp -i $$i > $(srcdir)/result/regexp/$$name; \
914               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
915           else \
916               log=`$(CHECKER) $(top_builddir)/testRegexp -i $$i 2>&1 > result.$$name ; \
917               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
918               diff $(srcdir)/result/regexp/$$name result.$$name` ; \
919               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
920               rm result.$$name ; \
921           fi ; fi ; done)
922         @echo "## Formal expresssions regression tests"
923         -@(for i in $(srcdir)/test/expr/* ; do \
924           name=`basename $$i`; \
925           if [ ! -d $$i ] ; then \
926           if [ ! -f $(srcdir)/result/expr/$$name ] ; then \
927               echo New test file $$name ; \
928               $(CHECKER) $(top_builddir)/testRegexp --expr -i $$i > $(srcdir)/result/expr/$$name; \
929               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
930           else \
931               log=`$(CHECKER) $(top_builddir)/testRegexp --expr -i $$i 2>&1 > result.$$name ; \
932               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
933               diff $(srcdir)/result/expr/$$name result.$$name` ; \
934               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
935               rm result.$$name ; \
936           fi ; fi ; done)
937
938 Automatatests: testAutomata$(EXEEXT)
939         @(echo > .memdump)
940         @echo "## Automata regression tests"
941         -@(for i in $(srcdir)/test/automata/* ; do \
942           name=`basename $$i`; \
943           if [ ! -d $$i ] ; then \
944           if [ ! -f $(srcdir)/result/automata/$$name ] ; then \
945               echo New test file $$name ; \
946               $(CHECKER) $(top_builddir)/testAutomata $$i > $(srcdir)/result/automata/$$name; \
947               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
948           else \
949               log=`$(CHECKER) $(top_builddir)/testAutomata $$i 2>&1 > result.$$name ; \
950               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
951               diff $(srcdir)/result/automata/$$name result.$$name` ; \
952               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
953               rm result.$$name ; \
954           fi ; fi ; done)
955
956 dba100000.xml: dbgenattr.pl
957         @echo "## generating dba100000.xml"
958         @($(PERL) $(top_srcdir)/dbgenattr.pl 100000 > dba100000.xml)
959
960 Timingtests: xmllint$(EXEEXT) dba100000.xml
961         @echo "## Timing tests to try to detect performance"
962         @echo "## as well a memory usage breakage when streaming"
963         @echo "## 1/ using the file interface"
964         @echo "## 2/ using the memory interface"
965         @echo "## 3/ repeated DOM parsing"
966         @echo "## 4/ repeated DOM validation"
967         -@($(top_builddir)/xmllint --stream --timing dba100000.xml; \
968            MEM=`cat .memdump | grep "MEMORY ALLOCATED" | awk '{ print $$7}'`;\
969            if [ "$$MEM" != "" ] ; then echo Using $$MEM bytes ; fi ; \
970            grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
971            exit 0)
972         -@($(top_builddir)/xmllint --stream --timing --memory dba100000.xml; \
973            MEM=`cat .memdump | grep "MEMORY ALLOCATED" | awk '{ print $$7}'`;\
974            if [ "$$MEM" != "" ] ; then echo Using $$MEM bytes ; fi ; \
975            grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
976            exit 0)
977         -@($(top_builddir)/xmllint --noout --timing --repeat $(srcdir)/test/valid/REC-xml-19980210.xml; \
978            MEM=`cat .memdump | grep "MEMORY ALLOCATED" | awk '{ print $$7}'`;\
979            if [ "$$MEM" != "" ] ; then echo Using $$MEM bytes ; fi ; \
980            grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
981            exit 0)
982
983 VTimingtests: xmllint$(EXEEXT)
984         -@($(top_builddir)/xmllint --noout --timing --valid --repeat $(srcdir)/test/valid/REC-xml-19980210.xml; \
985            MEM=`cat .memdump | grep "MEMORY ALLOCATED" | awk '{ print $$7}'`;\
986            if [ "$$MEM" != "" ] ; then echo Using $$MEM bytes ; fi ; \
987            grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
988            exit 0)
989
990 C14Ntests : testC14N$(EXEEXT)
991         @echo "## C14N and XPath regression tests"
992         -@(for m in with-comments without-comments 1-1-without-comments exc-without-comments ; do \
993             for i in $(srcdir)/test/c14n/$$m/*.xml ; do  \
994                 if [ ! -d $$i ] ; then \
995                     name=`basename $$i .xml`; \
996                     cmdline="$(CHECKER) $(top_builddir)/testC14N --$$m $$i"; \
997                     if [ -f $(srcdir)/test/c14n/$$m/$$name.xpath ] ; then \
998                         cmdline="$$cmdline $(srcdir)/test/c14n/$$m/$$name.xpath"; \
999                         if [ -f $(srcdir)/test/c14n/$$m/$$name.ns ] ; then \
1000                             cmdline="$$cmdline '`cat $(srcdir)/test/c14n/$$m/$$name.ns`'"; \
1001                         fi; \
1002                     fi; \
1003                     $$cmdline > $(srcdir)/test/c14n/test.tmp 2> /dev/null; \
1004                     if [ $$? -eq 0 ]; then \
1005                         diff  $(srcdir)/result/c14n/$$m/$$name $(srcdir)/test/c14n/test.tmp; \
1006                         if [ $$? -ne 0 ]; then \
1007                             echo "Test $$m/$$name failed"; \
1008                             cat $(srcdir)/test/c14n/test.tmp; \
1009                         fi; \
1010                     else \
1011                         echo "C14N failed"; \
1012                     fi; \
1013                     grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
1014                 fi; \
1015                 rm -f $(srcdir)/test/c14n/test.tmp; \
1016             done; \
1017         done)
1018
1019 Schemastests: testSchemas$(EXEEXT)
1020         @(echo > .memdump)
1021         @echo "## Schemas regression tests"
1022         -@(for i in $(srcdir)/test/schemas/*_*.xsd ; do \
1023           name=`basename $$i | sed 's+_.*++'`; \
1024           sno=`basename $$i | sed 's+.*_\(.*\).xsd+\1+'`; \
1025           for j in $(srcdir)/test/schemas/"$$name"_*.xml ; do \
1026               if [ -f $$j ] ; then \
1027               xno=`basename $$j | sed 's+.*_\(.*\).xml+\1+'`; \
1028               if [ ! -f $(srcdir)/result/schemas/"$$name"_"$$sno"_"$$xno" ]; \
1029               then \
1030                   echo New test file "$$name"_"$$sno"_"$$xno" ; \
1031                   $(CHECKER) $(top_builddir)/testSchemas $$i $$j \
1032                     > $(srcdir)/result/schemas/"$$name"_"$$sno"_"$$xno" \
1033                     2> $(srcdir)/result/schemas/"$$name"_"$$sno"_"$$xno".err; \
1034                   grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
1035               else \
1036                   log=`$(CHECKER) $(top_builddir)/testSchemas $$i $$j \
1037                     > res.$$name 2> err.$$name;\
1038                   grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
1039                   diff $(srcdir)/result/schemas/"$$name"_"$$sno"_"$$xno" \
1040                        res.$$name;\
1041                   diff $(srcdir)/result/schemas/"$$name"_"$$sno"_"$$xno".err \
1042                        err.$$name;\
1043                   grep Unimplemented err.$$name`; \
1044                   if [ -n "$$log" ] ; then echo "$$name"_"$$sno"_"$$xno" result ; echo "$$log" ; fi ; \
1045                   rm res.$$name err.$$name ; \
1046                fi ; fi ;\
1047           done; done)
1048
1049 Relaxtests: xmllint$(EXEEXT)
1050         @(echo > .memdump)
1051         @echo "## Relax-NG regression tests"
1052         -@(for i in $(srcdir)/test/relaxng/*.rng ; do \
1053           name=`basename $$i | sed 's+\.rng++'`; \
1054           if [ ! -f $(srcdir)/result/relaxng/"$$name"_valid ] ; then \
1055               echo New schemas $$name ; \
1056               $(CHECKER) $(top_builddir)/xmllint$(EXEEXT) --noout --relaxng $(srcdir)/test/relaxng/tutorA.rng $$i \
1057                       > $(srcdir)/result/relaxng/"$$name"_valid \
1058                       2> $(srcdir)/result/relaxng/"$$name"_err; \
1059               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
1060           else \
1061               log=`$(CHECKER) $(top_builddir)/xmllint$(EXEEXT) --noout --relaxng $(srcdir)/test/relaxng/tutorA.rng $$i \
1062               > res.$$name 2> err.$$name;\
1063               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
1064               diff $(srcdir)/result/relaxng/"$$name"_valid \
1065                    res.$$name;\
1066               diff $(srcdir)/result/relaxng/"$$name"_err \
1067                    err.$$name | grep -v "error detected at";\
1068               grep Unimplemented err.$$name`; \
1069               if [ -n "$$log" ] ; then echo schemas $$name result ; echo "$$log" ; fi ; \
1070               rm res.$$name err.$$name ; \
1071           fi; \
1072           for j in $(srcdir)/test/relaxng/"$$name"_*.xml ; do \
1073               if [ -f $$j ] ; then \
1074               xno=`basename $$j | sed 's+.*_\(.*\).xml+\1+'`; \
1075               if [ ! -f $(srcdir)/result/relaxng/"$$name"_"$$xno" ]; \
1076               then \
1077                   echo New test file "$$name"_"$$xno" ; \
1078                   $(CHECKER) $(top_builddir)/xmllint$(EXEEXT) --noout --relaxng $$i $$j \
1079                     > $(srcdir)/result/relaxng/"$$name"_"$$xno" \
1080                     2> $(srcdir)/result/relaxng/"$$name"_"$$xno".err; \
1081                   grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
1082               else \
1083                   log=`$(CHECKER) $(top_builddir)/xmllint$(EXEEXT) --noout --relaxng $$i $$j \
1084                     > res.$$name 2> err.$$name;\
1085                   grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
1086                   diff $(srcdir)/result/relaxng/"$$name"_"$$xno" \
1087                        res.$$name;\
1088                   diff $(srcdir)/result/relaxng/"$$name"_"$$xno".err \
1089                        err.$$name | grep -v "error detected at";\
1090                   grep Unimplemented err.$$name`; \
1091                   if [ -n "$$log" ] ; then echo "$$name"_"$$xno" result ; echo "$$log" ; fi ; \
1092                   rm res.$$name err.$$name ; \
1093                fi ; fi ; \
1094           done; done)
1095         @echo "## Relax-NG streaming regression tests"
1096         -@(for i in $(srcdir)/test/relaxng/*.rng ; do \
1097           name=`basename $$i | sed 's+\.rng++'`; \
1098           for j in $(srcdir)/test/relaxng/"$$name"_*.xml ; do \
1099               if [ -f $$j ] ; then \
1100               xno=`basename $$j | sed 's+.*_\(.*\).xml+\1+'`; \
1101               if [ ! -f $(srcdir)/result/relaxng/"$$name"_"$$xno" ]; \
1102               then \
1103                   echo New test file "$$name"_"$$xno" ; \
1104                   $(CHECKER) $(top_builddir)/xmllint$(EXEEXT) --noout --relaxng $$i $$j \
1105                     > $(srcdir)/result/relaxng/"$$name"_"$$xno" \
1106                     2> $(srcdir)/result/relaxng/"$$name"_"$$xno".err; \
1107                   grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
1108               else \
1109                   log=`$(CHECKER) $(top_builddir)/xmllint$(EXEEXT) --noout --stream --relaxng $$i $$j \
1110                     > res.$$name 2> err.$$name;\
1111                   grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
1112                   diff $(srcdir)/result/relaxng/"$$name"_"$$xno" res.$$name;\
1113                   if [ "$$name" != "tutor10_1" -a "$$name" != "tutor10_2" -a "$$name" != "tutor3_2" -a "$$name" != "307377" -a "$$name" != "tutor8_2" ] ; then \
1114                       diff $(srcdir)/result/relaxng/"$$name"_"$$xno".err \
1115                            err.$$name | grep -v "error detected at";\
1116                   fi ; grep Unimplemented err.$$name`; \
1117                   if [ -n "$$log" ] ; then echo "$$name"_"$$xno" result ; echo "$$log" ; fi ; \
1118                   rm res.$$name err.$$name ; \
1119                fi ; fi ; \
1120           done; done)
1121
1122 Schematrontests: xmllint$(EXEEXT)
1123         @(echo > .memdump)
1124         @echo "## Schematron regression tests"
1125         -@(for i in $(srcdir)/test/schematron/*.sct ; do \
1126           name=`basename $$i | sed 's+\.sct++'`; \
1127           for j in $(srcdir)/test/schematron/"$$name"_*.xml ; do \
1128               if [ -f $$j ] ; then \
1129               xno=`basename $$j | sed 's+.*_\(.*\).xml+\1+'`; \
1130               if [ ! -f $(srcdir)/result/schematron/"$$name"_"$$xno" ]; \
1131               then \
1132                   echo New test file "$$name"_"$$xno" ; \
1133                   $(CHECKER) $(top_builddir)/xmllint$(EXEEXT) --schematron $$i $$j \
1134                     > $(srcdir)/result/schematron/"$$name"_"$$xno" \
1135                     2> $(srcdir)/result/schematron/"$$name"_"$$xno".err; \
1136                   grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
1137               else \
1138                   log=`$(CHECKER) $(top_builddir)/xmllint$(EXEEXT) --schematron $$i $$j \
1139                     > res.$$name 2> err.$$name;\
1140                   grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
1141                   diff $(srcdir)/result/schematron/"$$name"_"$$xno" \
1142                        res.$$name;\
1143                   diff $(srcdir)/result/schematron/"$$name"_"$$xno".err \
1144                        err.$$name | grep -v "error detected at";\
1145                   grep Unimplemented err.$$name`; \
1146                   if [ -n "$$log" ] ; then echo "$$name"_"$$xno" result ; echo "$$log" ; fi ; \
1147                   rm res.$$name err.$$name ; \
1148                fi ; fi ; \
1149           done; done)
1150
1151 RelaxNGPythonTests:
1152         @(if [ -x $(PYTHON) ] ; then \
1153             PYTHONPATH=$(top_builddir)/python:$(top_builddir)/python/.libs:$$PYTHONPATH ; \
1154             export PYTHONPATH; \
1155             LD_LIBRARY_PATH="$(top_builddir)/.libs:$$LD_LIBRARY_PATH" ; \
1156             export LD_LIBRARY_PATH; \
1157             echo "## Relax-NG Python based test suite 1" ; \
1158             $(CHECKER) $(PYTHON) $(srcdir)/check-relaxng-test-suite.py ; \
1159             echo "## Relax-NG Python based test suite 2" ; \
1160             $(CHECKER) $(PYTHON) $(srcdir)/check-relaxng-test-suite2.py ; \
1161           fi)
1162
1163 SchemasPythonTests:
1164         @(if [ -x $(PYTHON) ] ; then \
1165             PYTHONPATH=$(top_builddir)/python:$(top_builddir)/python/.libs:$$PYTHONPATH; \
1166             export PYTHONPATH; \
1167             LD_LIBRARY_PATH="$(top_builddir)/.libs:$$LD_LIBRARY_PATH" ; \
1168             export LD_LIBRARY_PATH; \
1169             echo "## XML Schemas datatypes Python based test suite" ; \
1170             echo "## It is normal to see 11 errors reported" ; \
1171             $(CHECKER) $(PYTHON) $(srcdir)/check-xsddata-test-suite.py ; \
1172           fi)
1173         @(if [ -x $(PYTHON) -a -d xstc ] ; then cd xstc ; $(MAKE) CHECKER="$(CHECKER)" pytests ; fi)
1174
1175 Patterntests: xmllint$(EXEEXT)
1176         @(echo > .memdump)
1177         @echo "## Pattern regression tests"
1178         -@(for i in $(srcdir)/test/pattern/*.pat ; do \
1179           name=`basename $$i .pat`; \
1180           if [ -f $(srcdir)/test/pattern/$$name.xml ] ; then \
1181           if [ ! -f $(srcdir)/result/pattern/$$name ] ; then \
1182               rm -f result.$$name ; \
1183               echo New test file $$name ; \
1184               for pat in `cat $$i` ; do \
1185               $(CHECKER) $(top_builddir)/xmllint --walker --pattern $$pat $(srcdir)/test/pattern/$$name.xml >> $(srcdir)/result/pattern/$$name ; \
1186               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
1187               done ;\
1188           else \
1189               rm -f result.$$name ; \
1190               lst=`cat $$i` ; \
1191               log=`for pat in $$lst ; do $(CHECKER) $(top_builddir)/xmllint --walker --pattern $$pat $(srcdir)/test/pattern/$$name.xml 2>&1 >> result.$$name ; \
1192               grep "MORY ALLO" .memdump  | grep -v "MEMORY ALLOCATED : 0";\
1193               done ;\
1194               diff $(srcdir)/result/pattern/$$name result.$$name` ; \
1195               if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
1196               rm result.$$name ; \
1197           fi ; fi ; done ;)
1198
1199 ModuleTests: testModule$(EXEEXT) testdso.la
1200         @echo "## Module tests"
1201         @(./testModule$(EXEEXT))
1202
1203 cleanup:
1204         -@(find . -name .\#\* -exec rm {} \;)
1205         -@(find . -name \*.gcda -o -name \*.gcno -exec rm -f {} \;)
1206         -@(find . -name \*.orig -o -name \*.rej -o -name \*.old -exec rm -f {} \;)
1207
1208 dist-hook: cleanup libxml2.spec
1209         -cp libxml2.spec $(distdir)
1210         (cd $(srcdir) ; tar -cf - --exclude CVS --exclude .svn --exclude .git win32 macos os400 vms VxWorks bakefile test result) | (cd $(distdir); tar xf -)
1211
1212 dist-source: distdir
1213         $(AMTAR) -chof - --exclude Tests --exclude test --exclude result $(distdir) | GZIP=$(GZIP_ENV) gzip -c >`echo "$(distdir)" | sed "s+libxml2+libxml2-sources+"`.tar.gz
1214
1215 dist-test: distdir
1216         (mkdir -p $(distdir))
1217         (cd $(srcdir) ; tar -cf - --exclude CVS --exclude .svn --exclude .git xstc/Tests) | (cd $(distdir); tar xf -)
1218         tar -cf - $(distdir)/test $(distdir)/result $(distdir)/xstc/Tests  $(distdir)/Makefile.tests $(distdir)/README $(distdir)/README.tests $(distdir)/AUTHORS $(distdir)/testapi.c $(distdir)/runtest.c $(distdir)/runsuite.c | GZIP=$(GZIP_ENV) gzip -c >`echo "$(distdir)" | sed "s+libxml2+libxml2-tests+"`.tar.gz
1219         @(rm -rf $(distdir)/xstc/Test)
1220
1221 cleantar:
1222         @(rm -f libxml*.tar.gz COPYING.LIB)
1223
1224 rpm: cleanup cleantar
1225         @(unset CDPATH ; $(MAKE) dist-source dist && rpmbuild -ta $(distdir).tar.gz)
1226
1227 ## We create xml2Conf.sh here and not from configure because we want
1228 ## to get the paths expanded correctly.  Macros like srcdir are given
1229 ## the value NONE in configure if the user doesn't specify them (this
1230 ## is an autoconf feature, not a bug).
1231
1232 xml2Conf.sh: xml2Conf.sh.in Makefile
1233 ## Use sed and then mv to avoid problems if the user interrupts.
1234         sed -e 's?\@XML_LIBDIR\@?$(XML_LIBDIR)?g' \
1235             -e 's?\@XML_INCLUDEDIR\@?$(XML_INCLUDEDIR)?g' \
1236             -e 's?\@VERSION\@?$(VERSION)?g' \
1237             -e 's?\@XML_LIBS\@?$(XML_LIBS)?g' \
1238                < $(srcdir)/xml2Conf.sh.in > xml2Conf.tmp \
1239         && mv xml2Conf.tmp xml2Conf.sh
1240
1241 CLEANFILES = runxmlconf.log test.out xml2Conf.sh *.gcda *.gcno *.res
1242 DISTCLEANFILES = COPYING missing.lst
1243
1244 confexecdir=$(libdir)
1245 confexec_DATA = xml2Conf.sh
1246 CVS_EXTRA_DIST=
1247 EXTRA_DIST = xml2-config.in xml2Conf.sh.in libxml.spec.in libxml2.spec \
1248              libxml.m4 Copyright check-xml-test-suite.py gentest.py \
1249              check-relaxng-test-suite.py check-relaxng-test-suite2.py \
1250              check-xsddata-test-suite.py check-xinclude-test-suite.py \
1251              example/Makefile.am example/gjobread.c example/gjobs.xml \
1252              $(man_MANS) libxml-2.0.pc.in libxml-2.0-uninstalled.pc.in \
1253              libxml2-config.cmake.in autogen.sh \
1254              trionan.c trionan.h triostr.c triostr.h trio.c trio.h \
1255              triop.h triodef.h libxml.h elfgcchack.h xzlib.h buf.h \
1256              enc.h save.h testThreadsWin32.c genUnicode.py TODO_SCHEMAS \
1257              dbgen.pl dbgenattr.pl regressions.py regressions.xml \
1258              README.tests Makefile.tests libxml2.syms timsort.h \
1259              README.zOS \
1260              $(CVS_EXTRA_DIST)
1261
1262
1263 pkgconfigdir = $(libdir)/pkgconfig
1264 pkgconfig_DATA = libxml-2.0.pc
1265
1266 cmakedir = $(libdir)/cmake/libxml2
1267 cmake_DATA = libxml2-config.cmake
1268
1269 #
1270 # Install the tests program sources as examples 
1271 #
1272 BASE_DIR=$(datadir)/doc
1273 DOC_MODULE=libxml2-$(VERSION)
1274 EXAMPLES_DIR=$(BASE_DIR)/$(DOC_MODULE)/examples
1275
1276 install-data-local: 
1277         $(MKDIR_P) $(DESTDIR)$(BASE_DIR)/$(DOC_MODULE)
1278         -$(INSTALL) -m 0644 $(srcdir)/Copyright $(DESTDIR)$(BASE_DIR)/$(DOC_MODULE)
1279         $(MKDIR_P) $(DESTDIR)$(EXAMPLES_DIR)
1280         -$(INSTALL) -m 0644 $(srcdir)/xmllint.c $(DESTDIR)$(EXAMPLES_DIR)
1281         -$(INSTALL) -m 0644 $(srcdir)/testSAX.c $(DESTDIR)$(EXAMPLES_DIR)
1282         -$(INSTALL) -m 0644 $(srcdir)/testHTML.c $(DESTDIR)$(EXAMPLES_DIR)
1283         -$(INSTALL) -m 0644 $(srcdir)/testXPath.c $(DESTDIR)$(EXAMPLES_DIR)
1284
1285 uninstall-local:
1286         rm -f $(DESTDIR)$(EXAMPLES_DIR)/testXPath.c
1287         rm -f $(DESTDIR)$(EXAMPLES_DIR)/testHTML.c
1288         rm -f $(DESTDIR)$(EXAMPLES_DIR)/testSAX.c
1289         rm -f $(DESTDIR)$(EXAMPLES_DIR)/xmllint.c
1290         rm -rf $(DESTDIR)$(EXAMPLES_DIR)
1291         rm -f $(DESTDIR)$(BASE_DIR)/$(DOC_MODULE)/Copyright
1292         rm -rf $(DESTDIR)$(BASE_DIR)/$(DOC_MODULE)
1293
1294 tst: tst.c
1295         $(CC) $(CFLAGS) -Iinclude -o tst tst.c .libs/libxml2.a -lpthread -lm -lz -llzma
1296
1297 sparse: clean
1298         $(MAKE) CC=cgcc
1299
1300 #
1301 # Coverage support, largely borrowed from libvirt
1302 # Both binaries comes from the lcov package in Fedora
1303 #
1304 LCOV = /usr/bin/lcov
1305 GENHTML = /usr/bin/genhtml
1306
1307 cov: clean-cov
1308         if [ "`echo $(LDFLAGS) | grep coverage`" = "" ] ; then \
1309             echo not configured with coverage; exit 1 ; fi
1310         if [ ! -x $(LCOV) -o ! -x $(GENHTML) ] ; then \
1311             echo Need $(LCOV) and $(GENHTML) excecutables; exit 1 ; fi
1312         -@($(MAKE) check)
1313         -@(./runsuite$(EXEEXT))
1314         mkdir $(top_builddir)/coverage
1315         $(LCOV) -c -o $(top_builddir)/coverage/libxml2.info.tmp -d $(top_srcdir)
1316         $(LCOV) -r $(top_builddir)/coverage/libxml2.info.tmp -o $(top_builddir)/coverage/libxml2.info *usr*
1317         rm $(top_builddir)/coverage/libxml2.info.tmp
1318         $(GENHTML) -s -t "libxml2" -o $(top_builddir)/coverage --legend $(top_builddir)/coverage/libxml2.info
1319         echo "Coverage report is in $(top_builddir)/coverage/index.html"
1320
1321 clean-cov:
1322         rm -rf $(top_builddir)/coverage
1323