From 844ecc37072d515513177c65a8c9dc35c9cdfc1a Mon Sep 17 00:00:00 2001 From: Xavier Roche Date: Mon, 19 Mar 2012 12:55:42 +0000 Subject: httrack 3.33.16 --- libtest/Makefile.am | 40 ++++- libtest/Makefile.in | 273 ++++++++++++++++++++++++++--- libtest/callbacks-example-baselinks.c | 91 ++++++++++ libtest/callbacks-example-contentfilter.c | 120 +++++++++++++ libtest/callbacks-example-displayheader.c | 57 ++++++ libtest/callbacks-example-filename.c | 64 +++++++ libtest/callbacks-example-filename2.c | 100 +++++++++++ libtest/callbacks-example-filenameiisbug.c | 54 ++++++ libtest/callbacks-example-listlinks.c | 79 +++++++++ libtest/callbacks-example.c | 73 -------- 10 files changed, 856 insertions(+), 95 deletions(-) create mode 100755 libtest/callbacks-example-baselinks.c create mode 100755 libtest/callbacks-example-contentfilter.c create mode 100755 libtest/callbacks-example-displayheader.c create mode 100755 libtest/callbacks-example-filename.c create mode 100755 libtest/callbacks-example-filename2.c create mode 100755 libtest/callbacks-example-filenameiisbug.c create mode 100755 libtest/callbacks-example-listlinks.c delete mode 100755 libtest/callbacks-example.c (limited to 'libtest') 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 +#include +#include + +#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, "_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 */ + } +} + +/* _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 _init and _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 +#include +#include + +/* "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 */ + } +} + +/* _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 */ +} + +/* _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 _init and _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 +#include +#include + +#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 */ +} + +/* _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 */ +} + +/* _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 +#include +#include + +/* "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 + .. + + -> + 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 _init and _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 +#include +#include + +/* "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 */ +} + +/* _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 */ +} + +/* _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 +#include +#include + +/* "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-listlinks.c b/libtest/callbacks-example-listlinks.c new file mode 100755 index 0000000..26c2055 --- /dev/null +++ b/libtest/callbacks-example-listlinks.c @@ -0,0 +1,79 @@ +/* + HTTrack external callbacks example + .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 + --wrapper loop=callback:check_loop +*/ + +#include +#include +#include + +/* "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_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: + -> + This sample can be improved, for example, to make a map of a website. +*/ + +static char currentURLBeingParsed[2048]; + +/* +"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) { + printf("now parsing %s%s..\n", url_adresse, url_fichier); + strcpy(currentURLBeingParsed, url_adresse); + strcat(currentURLBeingParsed, url_fichier); + return 1; /* success */ +} + +/* +"link-detected" callback +typedef int (* t_hts_htmlcheck_linkdetected)(char* link); +*/ +EXTERNAL_FUNCTION int check_detectedlink(char* link) { + printf("[%s] -> [%s]\n", currentURLBeingParsed, link); + return 1; /* success */ +} + +/* +"loop" callback +typedef int (* t_hts_htmlcheck_loop)(void* back,int back_max,int back_index,int lien_tot,int lien_ntot,int stat_time,void* stats); +*/ +EXTERNAL_FUNCTION int check_loop(void* back,int back_max,int back_index,int lien_tot,int lien_ntot,int stat_time,void* stats) { + static int fun_animation=0; + printf("%c\r", "/-\\|"[(fun_animation++)%4]); + return 1; +} + +/* +a default callback for testing purpose +*/ +EXTERNAL_FUNCTION int check_void(void) { + printf("\n* * * default callback function called! * * *\n\n"); + return 1; +} diff --git a/libtest/callbacks-example.c b/libtest/callbacks-example.c deleted file mode 100755 index 3364969..0000000 --- a/libtest/callbacks-example.c +++ /dev/null @@ -1,73 +0,0 @@ -/* - HTTrack external callbacks example - .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 - --wrapper loop=callback:check_loop -*/ - -#include -#include -#include - -/* "External" */ -#ifdef _WIN32 -#define EXTERNAL_FUNCTION __declspec(dllexport) -#else -#define EXTERNAL_FUNCTION -#endif - -/* - This sample just lists all links in documents with the parent link: - -> - This sample can be improved, for example, to make a map of a website. -*/ - -static char currentURLBeingParsed[2048]; - -/* -"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) { - printf("now parsing %s%s..\n", url_adresse, url_fichier); - strcpy(currentURLBeingParsed, url_adresse); - strcat(currentURLBeingParsed, url_fichier); - return 1; /* success */ -} - -/* -"link-detected" callback -typedef int (* t_hts_htmlcheck_linkdetected)(char* link); -*/ -EXTERNAL_FUNCTION int check_detectedlink(char* link) { - printf("[%s] -> [%s]\n", currentURLBeingParsed, link); - return 1; /* success */ -} - -/* -"loop" callback -typedef int (* t_hts_htmlcheck_loop)(void* back,int back_max,int back_index,int lien_tot,int lien_ntot,int stat_time,void* stats); -*/ -EXTERNAL_FUNCTION int check_loop(void* back,int back_max,int back_index,int lien_tot,int lien_ntot,int stat_time,void* stats) { - static int fun_animation=0; - printf("%c\r", "/-\\|"[(fun_animation++)%4]); - return 1; -} - -/* -a default callback for testing purpose -*/ -EXTERNAL_FUNCTION int check_void(void) { - printf("\n* * * default callback function called! * * *\n\n"); - return 1; -} -- cgit v1.2.3