summaryrefslogtreecommitdiff
path: root/libtest
diff options
context:
space:
mode:
authorXavier Roche <xroche@users.noreply.github.com>2012-03-19 12:55:42 +0000
committerXavier Roche <xroche@users.noreply.github.com>2012-03-19 12:55:42 +0000
commit844ecc37072d515513177c65a8c9dc35c9cdfc1a (patch)
tree733b1fe039c0c37095a594b66d5076f3f5a0153d /libtest
parent25adbdabb47499fe641c7bd9595024ff82667058 (diff)
httrack 3.33.16
Diffstat (limited to 'libtest')
-rw-r--r--libtest/Makefile.am40
-rw-r--r--libtest/Makefile.in273
-rwxr-xr-xlibtest/callbacks-example-baselinks.c91
-rwxr-xr-xlibtest/callbacks-example-contentfilter.c120
-rwxr-xr-xlibtest/callbacks-example-displayheader.c57
-rwxr-xr-xlibtest/callbacks-example-filename.c64
-rwxr-xr-xlibtest/callbacks-example-filename2.c100
-rwxr-xr-xlibtest/callbacks-example-filenameiisbug.c54
-rwxr-xr-xlibtest/callbacks-example-listlinks.c (renamed from libtest/callbacks-example.c)6
9 files changed, 783 insertions, 22 deletions
diff --git a/libtest/Makefile.am b/libtest/Makefile.am
index 9bd2fe7..878c05b 100644
--- a/libtest/Makefile.am
+++ b/libtest/Makefile.am
@@ -1,5 +1,41 @@
exemplesdir = $(datadir)/httrack/libtest
-exemples_DATA = *.c *.h *.txt *.dsp *.dsw
-
+exemples_DATA = example.* *.c *.h *.txt
EXTRA_DIST = $(exemples_DATA)
+
+INCLUDES = \
+ @DEFAULT_CFLAGS@ \
+ @THREADS_CFLAGS@ \
+ @V6_FLAG@ \
+ @LFS_FLAG@ \
+ -DPREFIX=\""$(prefix)"\" \
+ -DSYSCONFDIR=\""$(sysconfdir)"\" \
+ -DDATADIR=\""$(datadir)"\" \
+ -DLIBDIR=\""$(libdir)"\"
+
+AM_CPPFLAGS = -I../src
+AM_LDFLAGS = -L../src
+
+# Examples
+libbaselinks_la_SOURCES = callbacks-example-baselinks.c
+libbaselinks_la_LIBADD = $(THREADS_LIBS) $(SOCKET_LIBS) -lhttrack
+libbaselinks_la_LDFLAGS = -version-info 1:0:0
+libcontentfilter_la_SOURCES = callbacks-example-contentfilter.c
+libcontentfilter_la_LIBADD = $(THREADS_LIBS) $(SOCKET_LIBS) -lhttrack
+libcontentfilter_la_LDFLAGS = -version-info 1:0:0
+libdisplayheader_la_SOURCES = callbacks-example-displayheader.c
+libdisplayheader_la_LIBADD = $(THREADS_LIBS) $(SOCKET_LIBS) -lhttrack
+libdisplayheader_la_LDFLAGS = -version-info 1:0:0
+libfilename_la_SOURCES = callbacks-example-filename.c
+libfilename_la_LIBADD = $(THREADS_LIBS) $(SOCKET_LIBS) -lhttrack
+libfilename_la_LDFLAGS = -version-info 1:0:0
+libfilename2_la_SOURCES = callbacks-example-filename2.c
+libfilename2_la_LIBADD = $(THREADS_LIBS) $(SOCKET_LIBS) -lhttrack
+libfilename2_la_LDFLAGS = -version-info 1:0:0
+libfilenameiisbug_la_SOURCES = callbacks-example-filenameiisbug.c
+libfilenameiisbug_la_LIBADD = $(THREADS_LIBS) $(SOCKET_LIBS) -lhttrack
+libfilenameiisbug_la_LDFLAGS = -version-info 1:0:0
+liblistlinks_la_SOURCES = callbacks-example-listlinks.c
+liblistlinks_la_LIBADD = $(THREADS_LIBS) $(SOCKET_LIBS) -lhttrack
+liblistlinks_la_LDFLAGS = -version-info 1:0:0
+pkglib_LTLIBRARIES = libbaselinks.la libcontentfilter.la libdisplayheader.la libfilename.la libfilename2.la libfilenameiisbug.la liblistlinks.la
diff --git a/libtest/Makefile.in b/libtest/Makefile.in
index 701bef3..1722c77 100644
--- a/libtest/Makefile.in
+++ b/libtest/Makefile.in
@@ -69,6 +69,7 @@ INSTALL_SCRIPT = @INSTALL_SCRIPT@
INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
LDFLAGS = @LDFLAGS@
LFS_FLAG = @LFS_FLAG@
+LIBOBJS = @LIBOBJS@
LIBS = @LIBS@
LIBTOOL = @LIBTOOL@
LN_S = @LN_S@
@@ -134,25 +135,201 @@ sysconfdir = @sysconfdir@
target_alias = @target_alias@
exemplesdir = $(datadir)/httrack/libtest
-exemples_DATA = *.c *.h *.txt *.dsp *.dsw
-
+exemples_DATA = example.* *.c *.h *.txt
EXTRA_DIST = $(exemples_DATA)
+
+INCLUDES = \
+ @DEFAULT_CFLAGS@ \
+ @THREADS_CFLAGS@ \
+ @V6_FLAG@ \
+ @LFS_FLAG@ \
+ -DPREFIX=\""$(prefix)"\" \
+ -DSYSCONFDIR=\""$(sysconfdir)"\" \
+ -DDATADIR=\""$(datadir)"\" \
+ -DLIBDIR=\""$(libdir)"\"
+
+
+AM_CPPFLAGS = -I../src
+AM_LDFLAGS = -L../src
+
+# Examples
+libbaselinks_la_SOURCES = callbacks-example-baselinks.c
+libbaselinks_la_LIBADD = $(THREADS_LIBS) $(SOCKET_LIBS) -lhttrack
+libbaselinks_la_LDFLAGS = -version-info 1:0:0
+libcontentfilter_la_SOURCES = callbacks-example-contentfilter.c
+libcontentfilter_la_LIBADD = $(THREADS_LIBS) $(SOCKET_LIBS) -lhttrack
+libcontentfilter_la_LDFLAGS = -version-info 1:0:0
+libdisplayheader_la_SOURCES = callbacks-example-displayheader.c
+libdisplayheader_la_LIBADD = $(THREADS_LIBS) $(SOCKET_LIBS) -lhttrack
+libdisplayheader_la_LDFLAGS = -version-info 1:0:0
+libfilename_la_SOURCES = callbacks-example-filename.c
+libfilename_la_LIBADD = $(THREADS_LIBS) $(SOCKET_LIBS) -lhttrack
+libfilename_la_LDFLAGS = -version-info 1:0:0
+libfilename2_la_SOURCES = callbacks-example-filename2.c
+libfilename2_la_LIBADD = $(THREADS_LIBS) $(SOCKET_LIBS) -lhttrack
+libfilename2_la_LDFLAGS = -version-info 1:0:0
+libfilenameiisbug_la_SOURCES = callbacks-example-filenameiisbug.c
+libfilenameiisbug_la_LIBADD = $(THREADS_LIBS) $(SOCKET_LIBS) -lhttrack
+libfilenameiisbug_la_LDFLAGS = -version-info 1:0:0
+liblistlinks_la_SOURCES = callbacks-example-listlinks.c
+liblistlinks_la_LIBADD = $(THREADS_LIBS) $(SOCKET_LIBS) -lhttrack
+liblistlinks_la_LDFLAGS = -version-info 1:0:0
+pkglib_LTLIBRARIES = libbaselinks.la libcontentfilter.la libdisplayheader.la libfilename.la libfilename2.la libfilenameiisbug.la liblistlinks.la
subdir = libtest
mkinstalldirs = $(SHELL) $(top_srcdir)/mkinstalldirs
CONFIG_HEADER = $(top_builddir)/config.h
CONFIG_CLEAN_FILES =
-DIST_SOURCES =
+LTLIBRARIES = $(pkglib_LTLIBRARIES)
+
+libbaselinks_la_DEPENDENCIES =
+am_libbaselinks_la_OBJECTS = callbacks-example-baselinks.lo
+libbaselinks_la_OBJECTS = $(am_libbaselinks_la_OBJECTS)
+libcontentfilter_la_DEPENDENCIES =
+am_libcontentfilter_la_OBJECTS = callbacks-example-contentfilter.lo
+libcontentfilter_la_OBJECTS = $(am_libcontentfilter_la_OBJECTS)
+libdisplayheader_la_DEPENDENCIES =
+am_libdisplayheader_la_OBJECTS = callbacks-example-displayheader.lo
+libdisplayheader_la_OBJECTS = $(am_libdisplayheader_la_OBJECTS)
+libfilename_la_DEPENDENCIES =
+am_libfilename_la_OBJECTS = callbacks-example-filename.lo
+libfilename_la_OBJECTS = $(am_libfilename_la_OBJECTS)
+libfilename2_la_DEPENDENCIES =
+am_libfilename2_la_OBJECTS = callbacks-example-filename2.lo
+libfilename2_la_OBJECTS = $(am_libfilename2_la_OBJECTS)
+libfilenameiisbug_la_DEPENDENCIES =
+am_libfilenameiisbug_la_OBJECTS = callbacks-example-filenameiisbug.lo
+libfilenameiisbug_la_OBJECTS = $(am_libfilenameiisbug_la_OBJECTS)
+liblistlinks_la_DEPENDENCIES =
+am_liblistlinks_la_OBJECTS = callbacks-example-listlinks.lo
+liblistlinks_la_OBJECTS = $(am_liblistlinks_la_OBJECTS)
+
+DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir)
+depcomp = $(SHELL) $(top_srcdir)/depcomp
+am__depfiles_maybe = depfiles
+@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/callbacks-example-baselinks.Plo \
+@AMDEP_TRUE@ ./$(DEPDIR)/callbacks-example-contentfilter.Plo \
+@AMDEP_TRUE@ ./$(DEPDIR)/callbacks-example-displayheader.Plo \
+@AMDEP_TRUE@ ./$(DEPDIR)/callbacks-example-filename.Plo \
+@AMDEP_TRUE@ ./$(DEPDIR)/callbacks-example-filename2.Plo \
+@AMDEP_TRUE@ ./$(DEPDIR)/callbacks-example-filenameiisbug.Plo \
+@AMDEP_TRUE@ ./$(DEPDIR)/callbacks-example-listlinks.Plo
+COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
+ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
+LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) \
+ $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
+CCLD = $(CC)
+LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
+ $(AM_LDFLAGS) $(LDFLAGS) -o $@
+DIST_SOURCES = $(libbaselinks_la_SOURCES) $(libcontentfilter_la_SOURCES) \
+ $(libdisplayheader_la_SOURCES) $(libfilename_la_SOURCES) \
+ $(libfilename2_la_SOURCES) $(libfilenameiisbug_la_SOURCES) \
+ $(liblistlinks_la_SOURCES)
DATA = $(exemples_DATA)
DIST_COMMON = Makefile.am Makefile.in
+SOURCES = $(libbaselinks_la_SOURCES) $(libcontentfilter_la_SOURCES) $(libdisplayheader_la_SOURCES) $(libfilename_la_SOURCES) $(libfilename2_la_SOURCES) $(libfilenameiisbug_la_SOURCES) $(liblistlinks_la_SOURCES)
+
all: all-am
.SUFFIXES:
+.SUFFIXES: .c .lo .o .obj
$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ Makefile.am $(top_srcdir)/configure.in $(ACLOCAL_M4)
cd $(top_srcdir) && \
$(AUTOMAKE) --gnu libtest/Makefile
Makefile: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.in $(top_builddir)/config.status
cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)
+pkglibLTLIBRARIES_INSTALL = $(INSTALL)
+install-pkglibLTLIBRARIES: $(pkglib_LTLIBRARIES)
+ @$(NORMAL_INSTALL)
+ $(mkinstalldirs) $(DESTDIR)$(pkglibdir)
+ @list='$(pkglib_LTLIBRARIES)'; for p in $$list; do \
+ if test -f $$p; then \
+ f="`echo $$p | sed -e 's|^.*/||'`"; \
+ echo " $(LIBTOOL) --mode=install $(pkglibLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) $$p $(DESTDIR)$(pkglibdir)/$$f"; \
+ $(LIBTOOL) --mode=install $(pkglibLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) $$p $(DESTDIR)$(pkglibdir)/$$f; \
+ else :; fi; \
+ done
+
+uninstall-pkglibLTLIBRARIES:
+ @$(NORMAL_UNINSTALL)
+ @list='$(pkglib_LTLIBRARIES)'; for p in $$list; do \
+ p="`echo $$p | sed -e 's|^.*/||'`"; \
+ echo " $(LIBTOOL) --mode=uninstall rm -f $(DESTDIR)$(pkglibdir)/$$p"; \
+ $(LIBTOOL) --mode=uninstall rm -f $(DESTDIR)$(pkglibdir)/$$p; \
+ done
+
+clean-pkglibLTLIBRARIES:
+ -test -z "$(pkglib_LTLIBRARIES)" || rm -f $(pkglib_LTLIBRARIES)
+ @list='$(pkglib_LTLIBRARIES)'; for p in $$list; do \
+ dir="`echo $$p | sed -e 's|/[^/]*$$||'`"; \
+ test "$$dir" = "$$p" && dir=.; \
+ echo "rm -f \"$${dir}/so_locations\""; \
+ rm -f "$${dir}/so_locations"; \
+ done
+libbaselinks.la: $(libbaselinks_la_OBJECTS) $(libbaselinks_la_DEPENDENCIES)
+ $(LINK) -rpath $(pkglibdir) $(libbaselinks_la_LDFLAGS) $(libbaselinks_la_OBJECTS) $(libbaselinks_la_LIBADD) $(LIBS)
+libcontentfilter.la: $(libcontentfilter_la_OBJECTS) $(libcontentfilter_la_DEPENDENCIES)
+ $(LINK) -rpath $(pkglibdir) $(libcontentfilter_la_LDFLAGS) $(libcontentfilter_la_OBJECTS) $(libcontentfilter_la_LIBADD) $(LIBS)
+libdisplayheader.la: $(libdisplayheader_la_OBJECTS) $(libdisplayheader_la_DEPENDENCIES)
+ $(LINK) -rpath $(pkglibdir) $(libdisplayheader_la_LDFLAGS) $(libdisplayheader_la_OBJECTS) $(libdisplayheader_la_LIBADD) $(LIBS)
+libfilename.la: $(libfilename_la_OBJECTS) $(libfilename_la_DEPENDENCIES)
+ $(LINK) -rpath $(pkglibdir) $(libfilename_la_LDFLAGS) $(libfilename_la_OBJECTS) $(libfilename_la_LIBADD) $(LIBS)
+libfilename2.la: $(libfilename2_la_OBJECTS) $(libfilename2_la_DEPENDENCIES)
+ $(LINK) -rpath $(pkglibdir) $(libfilename2_la_LDFLAGS) $(libfilename2_la_OBJECTS) $(libfilename2_la_LIBADD) $(LIBS)
+libfilenameiisbug.la: $(libfilenameiisbug_la_OBJECTS) $(libfilenameiisbug_la_DEPENDENCIES)
+ $(LINK) -rpath $(pkglibdir) $(libfilenameiisbug_la_LDFLAGS) $(libfilenameiisbug_la_OBJECTS) $(libfilenameiisbug_la_LIBADD) $(LIBS)
+liblistlinks.la: $(liblistlinks_la_OBJECTS) $(liblistlinks_la_DEPENDENCIES)
+ $(LINK) -rpath $(pkglibdir) $(liblistlinks_la_LDFLAGS) $(liblistlinks_la_OBJECTS) $(liblistlinks_la_LIBADD) $(LIBS)
+
+mostlyclean-compile:
+ -rm -f *.$(OBJEXT) core *.core
+
+distclean-compile:
+ -rm -f *.tab.c
+
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/callbacks-example-baselinks.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/callbacks-example-contentfilter.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/callbacks-example-displayheader.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/callbacks-example-filename.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/callbacks-example-filename2.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/callbacks-example-filenameiisbug.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/callbacks-example-listlinks.Plo@am__quote@
+
+distclean-depend:
+ -rm -rf ./$(DEPDIR)
+
+.c.o:
+@am__fastdepCC_TRUE@ if $(COMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" \
+@am__fastdepCC_TRUE@ -c -o $@ `test -f '$<' || echo '$(srcdir)/'`$<; \
+@am__fastdepCC_TRUE@ then mv "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; \
+@am__fastdepCC_TRUE@ else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; \
+@am__fastdepCC_TRUE@ fi
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+@am__fastdepCC_FALSE@ $(COMPILE) -c `test -f '$<' || echo '$(srcdir)/'`$<
+
+.c.obj:
+@am__fastdepCC_TRUE@ if $(COMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" \
+@am__fastdepCC_TRUE@ -c -o $@ `if test -f '$<'; then $(CYGPATH_W) '$<'; else $(CYGPATH_W) '$(srcdir)/$<'`; \
+@am__fastdepCC_TRUE@ then mv "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; \
+@am__fastdepCC_TRUE@ else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; \
+@am__fastdepCC_TRUE@ fi
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+@am__fastdepCC_FALSE@ $(COMPILE) -c `if test -f '$<'; then $(CYGPATH_W) '$<'; else $(CYGPATH_W) '$(srcdir)/$<'`
+
+.c.lo:
+@am__fastdepCC_TRUE@ if $(LTCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" \
+@am__fastdepCC_TRUE@ -c -o $@ `test -f '$<' || echo '$(srcdir)/'`$<; \
+@am__fastdepCC_TRUE@ then mv "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; \
+@am__fastdepCC_TRUE@ else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; \
+@am__fastdepCC_TRUE@ fi
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+@am__fastdepCC_FALSE@ $(LTCOMPILE) -c -o $@ `test -f '$<' || echo '$(srcdir)/'`$<
mostlyclean-libtool:
-rm -f *.lo
@@ -181,12 +358,60 @@ uninstall-exemplesDATA:
echo " rm -f $(DESTDIR)$(exemplesdir)/$$f"; \
rm -f $(DESTDIR)$(exemplesdir)/$$f; \
done
+
+ETAGS = etags
+ETAGSFLAGS =
+
+CTAGS = ctags
+CTAGSFLAGS =
+
tags: TAGS
-TAGS:
-ctags: CTAGS
-CTAGS:
+ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
+ list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
+ unique=`for i in $$list; do \
+ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+ done | \
+ $(AWK) ' { files[$$0] = 1; } \
+ END { for (i in files) print i; }'`; \
+ mkid -fID $$unique
+
+TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
+ $(TAGS_FILES) $(LISP)
+ tags=; \
+ here=`pwd`; \
+ list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
+ unique=`for i in $$list; do \
+ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+ done | \
+ $(AWK) ' { files[$$0] = 1; } \
+ END { for (i in files) print i; }'`; \
+ test -z "$(ETAGS_ARGS)$$tags$$unique" \
+ || $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+ $$tags $$unique
+ctags: CTAGS
+CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
+ $(TAGS_FILES) $(LISP)
+ tags=; \
+ here=`pwd`; \
+ list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
+ unique=`for i in $$list; do \
+ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+ done | \
+ $(AWK) ' { files[$$0] = 1; } \
+ END { for (i in files) print i; }'`; \
+ test -z "$(CTAGS_ARGS)$$tags$$unique" \
+ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
+ $$tags $$unique
+
+GTAGS:
+ here=`$(am__cd) $(top_builddir) && pwd` \
+ && cd $(top_srcdir) \
+ && gtags -i $(GTAGS_ARGS) $$here
+
+distclean-tags:
+ -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
top_distdir = ..
@@ -219,10 +444,10 @@ distdir: $(DISTFILES)
done
check-am: all-am
check: check-am
-all-am: Makefile $(DATA)
+all-am: Makefile $(LTLIBRARIES) $(DATA)
installdirs:
- $(mkinstalldirs) $(DESTDIR)$(exemplesdir)
+ $(mkinstalldirs) $(DESTDIR)$(pkglibdir) $(DESTDIR)$(exemplesdir)
install: install-am
install-exec: install-exec-am
@@ -250,11 +475,13 @@ maintainer-clean-generic:
@echo "it deletes files that may require special tools to rebuild."
clean: clean-am
-clean-am: clean-generic clean-libtool mostlyclean-am
+clean-am: clean-generic clean-libtool clean-pkglibLTLIBRARIES \
+ mostlyclean-am
distclean: distclean-am
-distclean-am: clean-am distclean-generic distclean-libtool
+distclean-am: clean-am distclean-compile distclean-depend \
+ distclean-generic distclean-libtool distclean-tags
dvi: dvi-am
@@ -266,7 +493,7 @@ info-am:
install-data-am: install-exemplesDATA
-install-exec-am:
+install-exec-am: install-pkglibLTLIBRARIES
install-info: install-info-am
@@ -280,7 +507,8 @@ maintainer-clean-am: distclean-am maintainer-clean-generic
mostlyclean: mostlyclean-am
-mostlyclean-am: mostlyclean-generic mostlyclean-libtool
+mostlyclean-am: mostlyclean-compile mostlyclean-generic \
+ mostlyclean-libtool
pdf: pdf-am
@@ -290,17 +518,22 @@ ps: ps-am
ps-am:
-uninstall-am: uninstall-exemplesDATA uninstall-info-am
+uninstall-am: uninstall-exemplesDATA uninstall-info-am \
+ uninstall-pkglibLTLIBRARIES
-.PHONY: all all-am check check-am clean clean-generic clean-libtool \
- distclean distclean-generic distclean-libtool distdir dvi \
- dvi-am info info-am install install-am install-data \
- install-data-am install-exec install-exec-am \
- install-exemplesDATA install-info install-info-am install-man \
+.PHONY: CTAGS GTAGS all all-am check check-am clean clean-generic \
+ clean-libtool clean-pkglibLTLIBRARIES ctags distclean \
+ distclean-compile distclean-depend distclean-generic \
+ distclean-libtool distclean-tags distdir dvi dvi-am info \
+ info-am install install-am install-data install-data-am \
+ install-exec install-exec-am install-exemplesDATA install-info \
+ install-info-am install-man install-pkglibLTLIBRARIES \
install-strip installcheck installcheck-am installdirs \
maintainer-clean maintainer-clean-generic mostlyclean \
- mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \
- uninstall uninstall-am uninstall-exemplesDATA uninstall-info-am
+ mostlyclean-compile mostlyclean-generic mostlyclean-libtool pdf \
+ pdf-am ps ps-am tags uninstall uninstall-am \
+ uninstall-exemplesDATA uninstall-info-am \
+ uninstall-pkglibLTLIBRARIES
# Tell versions [3.59,3.63) of GNU make to not export all variables.
# Otherwise a system limit (for SysV at least) may be exceeded.
diff --git a/libtest/callbacks-example-baselinks.c b/libtest/callbacks-example-baselinks.c
new file mode 100755
index 0000000..9f6eb11
--- /dev/null
+++ b/libtest/callbacks-example-baselinks.c
@@ -0,0 +1,91 @@
+/*
+ HTTrack external callbacks example : enforce a constant base href
+ Can be useful to make copies of site's archives using site's URL base href as root reference
+ .c file
+
+ How to use:
+ - compile this file as a module (callback.so or callback.dll)
+ example:
+ (with gcc)
+ gcc -O -g3 -Wall -D_REENTRANT -DINET6 -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -shared -o callback.so callbacks-example.c
+ or (with visual c++)
+ cl -LD -nologo -W3 -Zi -Zp4 -DWIN32 -Fe"callback.dll" callbacks-example.c
+ - use the --wrapper option in httrack:
+ httrack --wrapper check-html=callback:process_file
+ --wrapper link-detected=callback:check_detectedlink
+*/
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+
+#include "httrack-library.h"
+
+/* "External" */
+#ifdef _WIN32
+#define EXTERNAL_FUNCTION __declspec(dllexport)
+#else
+#define EXTERNAL_FUNCTION
+#endif
+
+/* Function definitions */
+EXTERNAL_FUNCTION int process_file(char* html, int len, char* url_adresse, char* url_fichier);
+EXTERNAL_FUNCTION int check_detectedlink(char* link);
+EXTERNAL_FUNCTION int check_detectedlink_init(char* initString);
+EXTERNAL_FUNCTION int check_detectedlink_exit(void);
+
+static char base[HTS_URLMAXSIZE + 2] = "";
+
+/*
+"check-html" callback
+typedef int (* t_hts_htmlcheck)(char* html,int len,char* url_adresse,char* url_fichier);
+*/
+EXTERNAL_FUNCTION int process_file(char* html, int len, char* url_adresse, char* url_fichier) {
+ /* Disable base href, if any */
+ char* prevBase = strstr(html, "<BASE HREF=\"");
+ if (prevBase != NULL) {
+ prevBase[1] = 'X';
+ }
+ return 1; /* success */
+}
+
+/*
+"link-detected" callback
+typedef int (* t_hts_htmlcheck_linkdetected)(char* link);
+*/
+EXTERNAL_FUNCTION int check_detectedlink(char* link) {
+ if (!base[0]) {
+ fprintf(stderr, "** ERROR! check_detectedlink_init() was not called by httrack - you are probably using an old version (<3.31) or called the wrapper with bad arguments\n");
+ fprintf(stderr, "** bailing out..\n");
+ exit(1);
+ }
+ /* The incoming (read/write) buffer is at least HTS_URLMAXSIZE bytes long */
+ if (strncmp(link, "http://", 7) == 0 || strncmp(link, "https://", 8) == 0) {
+ char temp[HTS_URLMAXSIZE * 2];
+ strcpy(temp, base);
+ strcat(temp, link);
+ strcpy(link, temp);
+ }
+ return 1; /* success */
+}
+
+/* <wrappername>_init() will be called, if exists, upon startup */
+EXTERNAL_FUNCTION int check_detectedlink_init(char* initString) {
+ fprintf(stderr, "Plugged..\n");
+ if (initString != NULL && *initString != '\0' && strlen(initString) < HTS_URLMAXSIZE / 2) {
+ strcpy(base, initString);
+ fprintf(stderr, "Using root '%s'\n", base);
+ return 1; /* success */
+ } else {
+ fprintf(stderr, "** callback error: arguments expected or bad arguments\n");
+ fprintf(stderr, "usage: httrack --wrapper save-name=callback:mysavename,base\n");
+ fprintf(stderr, "example: httrack --wrapper save-name=callback:mysavename,http://www.example.com/\n");
+ return 0; /* failed */
+ }
+}
+
+/* <wrappername>_exit() will be called, if exists, upon exit */
+EXTERNAL_FUNCTION int check_detectedlink_exit(void) {
+ fprintf(stderr, "Unplugged ..\n");
+ return 1; /* success (result ignored anyway in xx_exit) */
+}
diff --git a/libtest/callbacks-example-contentfilter.c b/libtest/callbacks-example-contentfilter.c
new file mode 100755
index 0000000..54ee9c0
--- /dev/null
+++ b/libtest/callbacks-example-contentfilter.c
@@ -0,0 +1,120 @@
+/*
+ HTTrack external callbacks example : crawling html pages depending on content
+ Example of <wrappername>_init and <wrappername>_exit call (httrack >> 3.31)
+ .c file
+
+ How to use:
+ - compile this file as a module (callback.so or callback.dll)
+ example:
+ (with gcc)
+ gcc -O -g3 -Wall -D_REENTRANT -DINET6 -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -shared -o callback.so callbacks-example-contentfilter.c
+ or (with visual c++)
+ cl -LD -nologo -W3 -Zi -Zp4 -DWIN32 -Fe"callback.dll" callbacks-example-contentfilter.c
+ - use the --wrapper option in httrack:
+ httrack --wrapper save-name=callback:process,string[,string..]
+*/
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+
+/* "External" */
+#ifdef _WIN32
+#define EXTERNAL_FUNCTION __declspec(dllexport)
+#else
+#define EXTERNAL_FUNCTION
+#endif
+
+/* Function definitions */
+EXTERNAL_FUNCTION int process(char* html, int len, char* address, char* filename);
+EXTERNAL_FUNCTION int wrapper_init(char* module, char* initString);
+EXTERNAL_FUNCTION int wrapper_exit(void);
+
+/* TOLOWER */
+#define TOLOWER_(a) (a >= 'A' && a <= 'Z') ? (a + ('a' - 'A')) : a
+#define TOLOWER(a) ( TOLOWER_( (a) ) )
+
+/*
+ This sample just crawls pages that contains certain keywords, and skips the other ones
+*/
+
+static char stringfilter[8192];
+static char* stringfilters[128];
+static int initialized = 0;
+
+/*
+"check-html" callback
+from htsdefines.h:
+typedef int (* t_hts_htmlcheck)(char* html,int len,char* address,char* filename);
+*/
+EXTERNAL_FUNCTION int process(char* html, int len, char* address, char* filename) {
+ int i = 0;
+ int getIt = 0;
+ char* pos;
+ if (!initialized) {
+ fprintf(stderr, "** ERROR! process_init() was not called by httrack - you are probably using an old version (<3.31)\n");
+ fprintf(stderr, "** bailing out..\n");
+ exit(1);
+ }
+ if (strcmp(address, "primary") == 0 && strcmp(filename, "/primary") == 0) /* primary page (list of links) */
+ return 1;
+ while(stringfilters[i] != NULL && ! getIt) {
+ if ( ( pos = strstr(html, stringfilters[i]) ) != NULL) {
+ int j;
+ getIt = 1;
+ fprintf(stderr, "** callback info: found '%s' keyword in '%s%s', crawling this page!\n", stringfilters[i], address, filename);
+ fprintf(stderr, "** details:\n(..)");
+ for(j = 0; j < 72 && pos[j] ; j++) {
+ if (pos[j] > 32)
+ fprintf(stderr, "%c", pos[j]);
+ else
+ fprintf(stderr, "?");
+ }
+ fprintf(stderr, "(..)\n");
+ }
+ i++;
+ }
+ if (getIt) {
+ return 1; /* success */
+ } else {
+ fprintf(stderr, "** callback info: won't parse '%s%s' (no specified keywords found)\n", address, filename);
+ return 0; /* this page sucks, don't parse it */
+ }
+}
+
+/* <wrappername>_init() will be called, if exists, upon startup */
+EXTERNAL_FUNCTION int wrapper_init(char* module, char* initString) {
+ char* a = stringfilter;
+ int i = 0;
+ fprintf(stderr, "** info: wrapper_init(%s, %s) called!\n", module, initString);
+ fprintf(stderr, "** callback example: crawling pages only if specific keywords are found\n");
+ if (initString == NULL || *initString == '\0') {
+ fprintf(stderr, "** callback error: arguments expected or bad arguments\n");
+ fprintf(stderr, "usage: httrack --wrapper save-name=callback:process,stringtofind,stringtofind..\n");
+ fprintf(stderr, "example: httrack --wrapper save-name=callback:process,apple,orange,lemon\n");
+ return 0;
+ }
+
+ /* stringfilters = split(initString, ','); */
+ strcpy(stringfilter, initString);
+ while(a != NULL) {
+ stringfilters[i] = a;
+ a = strchr(a, ',');
+ if (a != NULL) {
+ *a = '\0';
+ a ++;
+ }
+ fprintf(stderr, "** callback info: will crawl pages with '%s' in them\n", stringfilters[i]);
+ i++;
+ }
+ stringfilters[i++] = NULL;
+ initialized = 1; /* we're ok */
+ return 1; /* success */
+}
+
+/* <wrappername>_exit() will be called, if exists, upon exit */
+EXTERNAL_FUNCTION int wrapper_exit(void) {
+ fprintf(stderr, "** info: wrapper_exit() called!\n");
+ initialized = 0;
+ return 1; /* success (result ignored anyway in xx_exit) */
+}
diff --git a/libtest/callbacks-example-displayheader.c b/libtest/callbacks-example-displayheader.c
new file mode 100755
index 0000000..1f9c471
--- /dev/null
+++ b/libtest/callbacks-example-displayheader.c
@@ -0,0 +1,57 @@
+/*
+ HTTrack external callbacks example : display all incoming request headers
+ Example of <wrappername>_init and <wrappername>_exit call (httrack >> 3.31)
+ .c file
+
+ How to use:
+ - compile this file as a module (callback.so or callback.dll)
+ example:
+ (with gcc)
+ gcc -O -g3 -Wall -D_REENTRANT -DINET6 -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -shared -o callback.so callbacks-example-contentfilter.c
+ or (with visual c++)
+ cl -LD -nologo -W3 -Zi -Zp4 -DWIN32 -Fe"callback.dll" callbacks-example-displayheader.c
+ - use the --wrapper option in httrack:
+ httrack --wrapper save-name=callback:process,string[,string..]
+*/
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+
+#include "httrack-library.h"
+
+/* "External" */
+#ifdef _WIN32
+#define EXTERNAL_FUNCTION __declspec(dllexport)
+#else
+#define EXTERNAL_FUNCTION
+#endif
+
+/* Function definitions */
+EXTERNAL_FUNCTION int process(char* buff, char* adr, char* fil, char* referer_adr, char* referer_fil, void* incoming);
+EXTERNAL_FUNCTION int wrapper_init(char* module, char* initString);
+EXTERNAL_FUNCTION int wrapper_exit(void);
+
+/*
+"receive-header" callback
+from htsdefines.h:
+typedef int (* t_hts_htmlcheck_receivehead)(char* buff, char* adr, char* fil, char* referer_adr, char* referer_fil, htsblk* incoming);
+*/
+EXTERNAL_FUNCTION int process(char* buff, char* adr, char* fil, char* referer_adr, char* referer_fil, void* incoming) {
+ printf("[ %s%s ]\n%s\n", adr, fil, buff);
+ return 1; /* success */
+}
+
+/* <wrappername>_init() will be called, if exists, upon startup */
+static char* thisModule = NULL;
+EXTERNAL_FUNCTION int wrapper_init(char* module, char* initString) {
+ fprintf(stderr, "Plugged %s\n", module);
+ thisModule = module;
+ return 1; /* success */
+}
+
+/* <wrappername>_exit() will be called, if exists, upon exit */
+EXTERNAL_FUNCTION int wrapper_exit(void) {
+ fprintf(stderr, "Unplugged %s\n", thisModule);
+ return 1; /* success (result ignored anyway in xx_exit) */
+}
diff --git a/libtest/callbacks-example-filename.c b/libtest/callbacks-example-filename.c
new file mode 100755
index 0000000..0755b4d
--- /dev/null
+++ b/libtest/callbacks-example-filename.c
@@ -0,0 +1,64 @@
+/*
+ HTTrack external callbacks example : changing the destination filename
+ .c file
+
+ How to use:
+ - compile this file as a module (callback.so or callback.dll)
+ example:
+ (with gcc)
+ gcc -O -g3 -Wall -D_REENTRANT -DINET6 -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -shared -o callback.so callbacks-example-filename.c
+ or (with visual c++)
+ cl -LD -nologo -W3 -Zi -Zp4 -DWIN32 -Fe"callback.dll" callbacks-example-filename.c
+ - use the --wrapper option in httrack:
+ httrack --wrapper save-name=callback:mysavename
+*/
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+
+/* "External" */
+#ifdef _WIN32
+#define EXTERNAL_FUNCTION __declspec(dllexport)
+#else
+#define EXTERNAL_FUNCTION
+#endif
+
+/* Function definitions */
+EXTERNAL_FUNCTION int mysavename(char* adr_complete, char* fil_complete, char* referer_adr, char* referer_fil, char* save);
+
+/* TOLOWER */
+#define TOLOWER_(a) (a >= 'A' && a <= 'Z') ? (a + ('a' - 'A')) : a
+#define TOLOWER(a) ( TOLOWER_( (a) ) )
+
+/*
+ This sample just changes the destination filenames to ROT-13 equivalent ; that is,
+ a -> n
+ b -> o
+ c -> p
+ d -> q
+ ..
+ n -> a
+ o -> b
+ ..
+
+ <parent> -> <link>
+ This sample can be improved, for example, to make a map of a website.
+*/
+
+/*
+"check-html" callback
+from htsdefines.h:
+typedef int (* t_hts_htmlcheck_savename)(char* adr_complete,char* fil_complete,char* referer_adr,char* referer_fil,char* save);
+*/
+EXTERNAL_FUNCTION int mysavename(char* adr_complete, char* fil_complete, char* referer_adr, char* referer_fil, char* save) {
+ char* a = save;
+ while(*a) {
+ char c = TOLOWER(*a);
+ if (c >= 'a' && c <= 'z')
+ *a = ( ( ( c - 'a' ) + 13 ) % 26 ) + 'a'; // ROT-13
+ a++;
+ }
+
+ return 1; /* success */
+}
diff --git a/libtest/callbacks-example-filename2.c b/libtest/callbacks-example-filename2.c
new file mode 100755
index 0000000..ded2e8f
--- /dev/null
+++ b/libtest/callbacks-example-filename2.c
@@ -0,0 +1,100 @@
+/*
+ HTTrack external callbacks example : changing the destination filename
+ Example of <wrappername>_init and <wrappername>_exit call (httrack >> 3.31)
+ .c file
+
+ How to use:
+ - compile this file as a module (callback.so or callback.dll)
+ example:
+ (with gcc)
+ gcc -O -g3 -Wall -D_REENTRANT -DINET6 -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -shared -o callback.so callbacks-example-filename.c
+ or (with visual c++)
+ cl -LD -nologo -W3 -Zi -Zp4 -DWIN32 -Fe"callback.dll" callbacks-example-filename.c
+ - use the --wrapper option in httrack:
+ httrack --wrapper save-name=callback:mysavename,string1,string2
+*/
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+
+/* "External" */
+#ifdef _WIN32
+#define EXTERNAL_FUNCTION __declspec(dllexport)
+#else
+#define EXTERNAL_FUNCTION
+#endif
+
+/* Function definitions */
+EXTERNAL_FUNCTION int mysavename(char* adr_complete, char* fil_complete, char* referer_adr, char* referer_fil, char* save);
+EXTERNAL_FUNCTION int wrapper_init(char* module, char* initString);
+EXTERNAL_FUNCTION int wrapper_exit(void);
+
+/* TOLOWER */
+#define TOLOWER_(a) (a >= 'A' && a <= 'Z') ? (a + ('a' - 'A')) : a
+#define TOLOWER(a) ( TOLOWER_( (a) ) )
+
+/*
+ This sample just replaces all occurences of "string1" into "string2"
+ string1 and string2 are passed in the callback string:
+ httrack --wrapper save-name=callback:mysavename,string1,string2 ..
+*/
+
+static char string1[256];
+static char string2[256];
+static int initialized = 0;
+
+/*
+"check-html" callback
+from htsdefines.h:
+typedef int (* t_hts_htmlcheck_savename)(char* adr_complete,char* fil_complete,char* referer_adr,char* referer_fil,char* save);
+*/
+EXTERNAL_FUNCTION int mysavename(char* adr_complete, char* fil_complete, char* referer_adr, char* referer_fil, char* save) {
+ char* buff = strdup(save);
+ char* a = buff;
+ char* b = save;
+ if (!initialized) {
+ fprintf(stderr, "** ERROR! mysavename_init() was not called by httrack - you are probably using an old version (<3.31)\n");
+ fprintf(stderr, "** bailing out..\n");
+ exit(1);
+ }
+ *b = '\0'; /* the "save" variable points to a buffer with "sufficient" space */
+ while(*a) {
+ if (strncmp(a, string1, (int)strlen(string1)) == 0) {
+ strcat(b, string2);
+ b += strlen(b);
+ a += strlen(string1);
+ } else {
+ *b++ = *a++;
+ *b = '\0';
+ }
+ }
+ free(buff);
+ return 1; /* success */
+}
+
+/* <wrappername>_init() will be called, if exists, upon startup */
+EXTERNAL_FUNCTION int wrapper_init(char* module, char* initString) {
+ char* pos;
+ fprintf(stderr, "** info: wrapper_init(%s, %s) called!\n", module, initString);
+ fprintf(stderr, "** callback example: changing destination filename word by another one\n");
+ if (initString == NULL || *initString == '\0' || (pos = strchr(initString, ',') ) == NULL) {
+ fprintf(stderr, "** callback error: arguments expected or bad arguments\n");
+ fprintf(stderr, "usage: httrack --wrapper save-name=callback:mysavename,string1,string2\n");
+ fprintf(stderr, "example: httrack --wrapper save-name=callback:mysavename,foo,bar\n");
+ return 0;
+ }
+ string1[0] = string1[1] = '\0';
+ strncat(string1, initString, pos - initString);
+ strcpy(string2, pos + 1);
+ fprintf(stderr, "** callback info: will replace %s by %s in filenames!\n", string1, string2);
+ initialized = 1; /* we're ok */
+ return 1; /* success */
+}
+
+/* <wrappername>_exit() will be called, if exists, upon exit */
+EXTERNAL_FUNCTION int wrapper_exit(void) {
+ fprintf(stderr, "** info: wrapper_exit() called!\n");
+ initialized = 0;
+ return 1; /* success (result ignored anyway in xx_exit) */
+}
diff --git a/libtest/callbacks-example-filenameiisbug.c b/libtest/callbacks-example-filenameiisbug.c
new file mode 100755
index 0000000..eb162d9
--- /dev/null
+++ b/libtest/callbacks-example-filenameiisbug.c
@@ -0,0 +1,54 @@
+/*
+ HTTrack external callbacks example : changing folder names ending with ".com"
+ with ".c0m" as a workaround of IIS bug (see KB 275601)
+
+ How to use:
+ - compile this file as a module (callback.so or callback.dll)
+ example:
+ (with gcc)
+ gcc -O -g3 -Wall -D_REENTRANT -DINET6 -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -shared -o callback.so callbacks-example-filename.c
+ or (with visual c++)
+ cl -LD -nologo -W3 -Zi -Zp4 -DWIN32 -Fe"callback.dll" callbacks-example-filename.c
+ - use the --wrapper option in httrack:
+ httrack --wrapper save-name=callback:mysavename
+*/
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+
+/* "External" */
+#ifdef _WIN32
+#define EXTERNAL_FUNCTION __declspec(dllexport)
+#else
+#define EXTERNAL_FUNCTION
+#endif
+
+/* Function definitions */
+EXTERNAL_FUNCTION int mysavename(char* adr_complete, char* fil_complete, char* referer_adr, char* referer_fil, char* save);
+
+/*
+ Replaces all "offending" IIS extensions (exe, dll..) with "nice" ones
+*/
+/*
+"check-html" callback
+from htsdefines.h:
+typedef int (* t_hts_htmlcheck_savename)(char* adr_complete,char* fil_complete,char* referer_adr,char* referer_fil,char* save);
+*/
+EXTERNAL_FUNCTION int mysavename(char* adr_complete, char* fil_complete, char* referer_adr, char* referer_fil, char* save) {
+ static const char* iisBogus[] = { ".com", ".exe", ".dll", ".sh", NULL };
+ static const char* iisBogusReplace[] = { ".c0m", ".ex3", ".dl1", ".5h", NULL }; /* MUST be the same sizes */
+ char* a;
+ for(a = save ; *a != '\0' ; a++) {
+ int i;
+ for(i = 0 ; iisBogus[i] != NULL ; i++) {
+ int j;
+ for(j = 0 ; iisBogus[i][j] == a[j] && iisBogus[i][j] != '\0' ; j++);
+ if (iisBogus[i][j] == '\0' && ( a[j] == '\0' || a[j] == '/' || a[j] == '\\' ) ) {
+ strncpy(a, iisBogusReplace[i], strlen(iisBogusReplace[i]));
+ break;
+ }
+ }
+ }
+ return 1; /* success */
+}
diff --git a/libtest/callbacks-example.c b/libtest/callbacks-example-listlinks.c
index 3364969..26c2055 100755
--- a/libtest/callbacks-example.c
+++ b/libtest/callbacks-example-listlinks.c
@@ -26,6 +26,12 @@
#define EXTERNAL_FUNCTION
#endif
+/* Function definitions */
+EXTERNAL_FUNCTION int process_file(char* html, int len, char* url_adresse, char* url_fichier);
+EXTERNAL_FUNCTION int check_detectedlink(char* link);
+EXTERNAL_FUNCTION int check_loop(void* back,int back_max,int back_index,int lien_tot,int lien_ntot,int stat_time,void* stats);
+EXTERNAL_FUNCTION int check_void(void);
+
/*
This sample just lists all links in documents with the parent link:
<parent> -> <link>