1 ## Process this file with automake to produce Makefile.in
3 ACLOCAL_AMFLAGS = -I m4
5 SUBDIRS = include . doc example xstc $(PYTHON_SUBDIR)
7 DIST_SUBDIRS = include . doc example python xstc
9 AM_CPPFLAGS = -I$(top_builddir)/include -I$(srcdir)/include
11 AM_CFLAGS = $(THREAD_CFLAGS) $(Z_CFLAGS) $(LZMA_CFLAGS)
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
18 bin_PROGRAMS = xmllint xmlcatalog
20 bin_SCRIPTS=xml2-config
22 lib_LTLIBRARIES = libxml2.la
23 libxml2_la_LIBADD = $(ICU_LIBS) $(THREAD_LIBS) $(Z_LIBS) $(LZMA_LIBS) $(ICONV_LIBS) $(M_LIBS) $(WIN32_EXTRA_LIBADD)
26 LIBXML2_VERSION_SCRIPT = $(VERSION_SCRIPT_FLAGS)$(srcdir)/libxml2.syms
28 LIBXML2_VERSION_SCRIPT =
31 libxml2_la_LDFLAGS = $(CYGWIN_EXTRA_LDFLAGS) $(WIN32_EXTRA_LDFLAGS) \
32 $(LIBXML2_VERSION_SCRIPT) \
33 -version-info $(LIBXML_VERSION_INFO) \
34 $(MODULE_PLATFORM_LIBS)
37 docb_sources = DOCBparser.c
43 trio_sources = triostr.c trio.c
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 \
53 catalog.c globals.c threads.c c14n.c xmlstring.c buf.c \
54 xmlregexp.c xmlschemas.c xmlschemastypes.c xmlunicode.c \
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
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)
64 man_MANS = xml2-config.1 libxml.3
66 m4datadir = $(datadir)/aclocal
67 m4data_DATA = libxml.m4
69 runtest_SOURCES=runtest.c
71 runtest_DEPENDENCIES = $(DEPS)
72 runtest_LDADD= $(BASE_THREAD_LIBS) $(RDL_LIBS) $(LDADDS)
74 testrecurse_SOURCES=testrecurse.c
76 testrecurse_DEPENDENCIES = $(DEPS)
77 testrecurse_LDADD= $(BASE_THREAD_LIBS) $(RDL_LIBS) $(LDADDS)
79 testlimits_SOURCES=testlimits.c
81 testlimits_DEPENDENCIES = $(DEPS)
82 testlimits_LDADD= $(BASE_THREAD_LIBS) $(RDL_LIBS) $(LDADDS)
84 testchar_SOURCES=testchar.c
86 testchar_DEPENDENCIES = $(DEPS)
87 testchar_LDADD= $(RDL_LIBS) $(LDADDS)
89 testdict_SOURCES=testdict.c
91 testdict_DEPENDENCIES = $(DEPS)
92 testdict_LDADD= $(RDL_LIBS) $(LDADDS)
94 runsuite_SOURCES=runsuite.c
96 runsuite_DEPENDENCIES = $(DEPS)
97 runsuite_LDADD= $(RDL_LIBS) $(LDADDS)
99 xmllint_SOURCES=xmllint.c
101 xmllint_DEPENDENCIES = $(DEPS)
102 xmllint_LDADD= $(RDL_LIBS) $(LDADDS)
104 testSAX_SOURCES=testSAX.c
106 testSAX_DEPENDENCIES = $(DEPS)
107 testSAX_LDADD= $(LDADDS)
109 testHTML_SOURCES=testHTML.c
111 testHTML_DEPENDENCIES = $(DEPS)
112 testHTML_LDADD= $(LDADDS)
114 xmlcatalog_SOURCES=xmlcatalog.c
116 xmlcatalog_DEPENDENCIES = $(DEPS)
117 xmlcatalog_LDADD = $(RDL_LIBS) $(LDADDS)
119 testXPath_SOURCES=testXPath.c
121 testXPath_DEPENDENCIES = $(DEPS)
122 testXPath_LDADD= $(LDADDS)
124 testC14N_SOURCES=testC14N.c
126 testC14N_DEPENDENCIES = $(DEPS)
127 testC14N_LDADD= $(LDADDS)
130 testThreads_SOURCES = testThreadsWin32.c
132 testThreads_SOURCES = testThreads.c
134 testThreads_LDFLAGS =
135 testThreads_DEPENDENCIES = $(DEPS)
136 testThreads_LDADD= $(BASE_THREAD_LIBS) $(LDADDS)
138 testURI_SOURCES=testURI.c
140 testURI_DEPENDENCIES = $(DEPS)
141 testURI_LDADD= $(LDADDS)
143 testRegexp_SOURCES=testRegexp.c
145 testRegexp_DEPENDENCIES = $(DEPS)
146 testRegexp_LDADD= $(LDADDS)
148 testAutomata_SOURCES=testAutomata.c
149 testAutomata_LDFLAGS =
150 testAutomata_DEPENDENCIES = $(DEPS)
151 testAutomata_LDADD= $(LDADDS)
153 testSchemas_SOURCES=testSchemas.c
154 testSchemas_LDFLAGS =
155 testSchemas_DEPENDENCIES = $(DEPS)
156 testSchemas_LDADD= $(LDADDS)
158 testRelax_SOURCES=testRelax.c
160 testRelax_DEPENDENCIES = $(DEPS)
161 testRelax_LDADD= $(LDADDS)
163 testReader_SOURCES=testReader.c
165 testReader_DEPENDENCIES = $(DEPS)
166 testReader_LDADD= $(LDADDS)
168 testModule_SOURCES=testModule.c
170 testModule_DEPENDENCIES = $(DEPS)
171 testModule_LDADD= $(LDADDS)
173 noinst_LTLIBRARIES = testdso.la
174 testdso_la_SOURCES = testdso.c
175 testdso_la_LDFLAGS = -module -no-undefined -avoid-version -rpath $(libdir)
177 # that one forces the rebuild when "make rebuild" is run on doc/
179 -@(if [ "$(PYTHON)" != "" ] ; then \
180 $(PYTHON) $(srcdir)/gentest.py $(srcdir) ; fi )
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 )
188 BUILT_SOURCES = testapi.c
190 testapi_SOURCES=testapi.c
192 testapi_DEPENDENCIES = $(DEPS)
193 testapi_LDADD= $(LDADDS)
195 runxmlconf_SOURCES=runxmlconf.c
197 runxmlconf_DEPENDENCIES = $(DEPS)
198 runxmlconf_LDADD= $(LDADDS)
200 #testOOM_SOURCES=testOOM.c testOOMlib.h testOOMlib.c
202 #testOOM_DEPENDENCIES = $(DEPS)
203 #testOOM_LDADD= $(LDADDS)
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 ; \
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
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)
229 testall : tests SVGtests SAXtests
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)
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)
240 HTMLtests : testHTML$(EXEEXT)
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 ; \
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 ; \
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 ; \
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 ; \
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 ; \
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 ; \
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 ; \
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 ; \
309 XMLtests : xmllint$(EXEEXT)
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"; \
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 ; \
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"; \
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 ; \
348 XMLPushtests: xmllint$(EXEEXT)
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"; \
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 ; \
369 NStests : xmllint$(EXEEXT)
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"; \
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 ; \
390 IDtests : xmllint$(EXEEXT) testXPath$(EXEEXT)
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"; \
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 ; \
411 Errtests : xmllint$(EXEEXT)
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"; \
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 ; \
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"; \
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 ; \
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 \
458 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
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 ; \
467 Docbtests : xmllint$(EXEEXT)
469 XMLenttests : xmllint$(EXEEXT)
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"; \
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 ; \
490 URItests : testURI$(EXEEXT)
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"; \
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 ; \
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"; \
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 ; \
522 XPathtests : testXPath$(EXEEXT)
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";\
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 ; \
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";\
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 ; \
558 fi ; fi ; done ; fi ; done)
560 XPtrtests : testXPath$(EXEEXT)
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"; \
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 ; \
582 fi ; fi ; done ; fi ; done)
584 XIncludetests : xmllint$(EXEEXT)
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";\
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 ; \
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";\
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 ; \
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";\
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 ; \
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";\
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 ; \
650 Scripttests : xmllint$(EXEEXT)
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";\
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 ; \
671 Catatests : xmlcatalog$(EXEEXT)
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";\
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 ; \
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";\
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 ; \
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)
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";\
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 ; \
745 Threadtests : testThreads$(EXEEXT)
746 @echo "## Threaded regression tests"
747 -@($(CHECKER) $(top_builddir)/testThreads ; \
748 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0"; \
751 Readertests : xmllint$(EXEEXT)
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";\
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 ; \
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";\
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 ; \
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";\
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 ; \
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";\
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 ; \
815 SAXtests : testSAX$(EXEEXT)
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";\
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 ; \
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";\
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 ; \
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";\
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 ; \
863 Validtests : xmllint$(EXEEXT)
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 ; \
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";\
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 ; \
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";\
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 ; \
905 Regexptests: testRegexp$(EXEEXT)
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";\
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 ; \
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";\
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 ; \
938 Automatatests: testAutomata$(EXEEXT)
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";\
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 ; \
956 dba100000.xml: dbgenattr.pl
957 @echo "## generating dba100000.xml"
958 @($(PERL) $(top_srcdir)/dbgenattr.pl 100000 > dba100000.xml)
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";\
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";\
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";\
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";\
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`'"; \
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; \
1011 echo "C14N failed"; \
1013 grep "MORY ALLO" .memdump | grep -v "MEMORY ALLOCATED : 0";\
1015 rm -f $(srcdir)/test/c14n/test.tmp; \
1019 Schemastests: testSchemas$(EXEEXT)
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" ]; \
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";\
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" \
1041 diff $(srcdir)/result/schemas/"$$name"_"$$sno"_"$$xno".err \
1043 grep Unimplemented err.$$name`; \
1044 if [ -n "$$log" ] ; then echo "$$name"_"$$sno"_"$$xno" result ; echo "$$log" ; fi ; \
1045 rm res.$$name err.$$name ; \
1049 Relaxtests: xmllint$(EXEEXT)
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";\
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 \
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 ; \
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" ]; \
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";\
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" \
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 ; \
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" ]; \
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";\
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 ; \
1122 Schematrontests: xmllint$(EXEEXT)
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" ]; \
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";\
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" \
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 ; \
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 ; \
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 ; \
1173 @(if [ -x $(PYTHON) -a -d xstc ] ; then cd xstc ; $(MAKE) CHECKER="$(CHECKER)" pytests ; fi)
1175 Patterntests: xmllint$(EXEEXT)
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";\
1189 rm -f result.$$name ; \
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";\
1194 diff $(srcdir)/result/pattern/$$name result.$$name` ; \
1195 if [ -n "$$log" ] ; then echo $$name result ; echo "$$log" ; fi ; \
1196 rm result.$$name ; \
1199 ModuleTests: testModule$(EXEEXT) testdso.la
1200 @echo "## Module tests"
1201 @(./testModule$(EXEEXT))
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 {} \;)
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 -)
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
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)
1222 @(rm -f libxml*.tar.gz COPYING.LIB)
1224 rpm: cleanup cleantar
1225 @(unset CDPATH ; $(MAKE) dist-source dist && rpmbuild -ta $(distdir).tar.gz)
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).
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
1241 CLEANFILES = runxmlconf.log test.out xml2Conf.sh *.gcda *.gcno *.res
1242 DISTCLEANFILES = COPYING missing.lst
1244 confexecdir=$(libdir)
1245 confexec_DATA = xml2Conf.sh
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 \
1263 pkgconfigdir = $(libdir)/pkgconfig
1264 pkgconfig_DATA = libxml-2.0.pc
1266 cmakedir = $(libdir)/cmake/libxml2
1267 cmake_DATA = libxml2-config.cmake
1270 # Install the tests program sources as examples
1272 BASE_DIR=$(datadir)/doc
1273 DOC_MODULE=libxml2-$(VERSION)
1274 EXAMPLES_DIR=$(BASE_DIR)/$(DOC_MODULE)/examples
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)
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)
1295 $(CC) $(CFLAGS) -Iinclude -o tst tst.c .libs/libxml2.a -lpthread -lm -lz -llzma
1301 # Coverage support, largely borrowed from libvirt
1302 # Both binaries comes from the lcov package in Fedora
1304 LCOV = /usr/bin/lcov
1305 GENHTML = /usr/bin/genhtml
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
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"
1322 rm -rf $(top_builddir)/coverage