diff options
author | Xavier Roche <xroche@users.noreply.github.com> | 2012-03-19 12:51:31 +0000 |
---|---|---|
committer | Xavier Roche <xroche@users.noreply.github.com> | 2012-03-19 12:51:31 +0000 |
commit | 25adbdabb47499fe641c7bd9595024ff82667058 (patch) | |
tree | 4200bb5e746bc1c0606de615ec99f0a247d4d9ba /src/httrack-library.h | |
parent | ad5b7acc19290ff91e0f42a0de448a26760fcf99 (diff) |
httrack 3.30.1
Diffstat (limited to 'src/httrack-library.h')
-rw-r--r-- | src/httrack-library.h | 154 |
1 files changed, 151 insertions, 3 deletions
diff --git a/src/httrack-library.h b/src/httrack-library.h index 13ecb46..aeea70f 100644 --- a/src/httrack-library.h +++ b/src/httrack-library.h @@ -42,9 +42,157 @@ Please visit our Website: http://www.httrack.com #include "htsopt.h" #include "htswrap.h" -int hts_init(void); -int hts_main(int argc, char **argv); +/* Main functions */ +HTSEXT_API int hts_init(void); +HTSEXT_API int hts_uninit(void); +HTSEXT_API int hts_main(int argc, char **argv); + +/* Wrapper functions */ +HTSEXT_API int htswrap_init(void); +HTSEXT_API int htswrap_add(char* name,void* fct); +HTSEXT_API int htswrap_free(void); +HTSEXT_API unsigned long int htswrap_read(char* name); +HTSEXT_API const char* hts_is_available(void); + +/* Other functions */ +HTSEXT_API int hts_resetvar(void); +HTSEXT_API int hts_buildtopindex(httrackp* opt,char* path,char* binpath); + +/* Catch-URL */ +HTSEXT_API T_SOC catch_url_init_std(int* port_prox,char* adr_prox); +HTSEXT_API T_SOC catch_url_init(int* port,char* adr); +HTSEXT_API int catch_url(T_SOC soc,char* url,char* method,char* data); + +/* State */ +HTSEXT_API int hts_is_parsing(int flag); +HTSEXT_API int hts_is_testing(void); +HTSEXT_API int hts_is_exiting(void); +HTSEXT_API int hts_setopt(httrackp* opt); +HTSEXT_API int hts_addurl(char** url); +HTSEXT_API int hts_resetaddurl(void); +HTSEXT_API int copy_htsopt(httrackp* from, httrackp* to); +HTSEXT_API char* hts_errmsg(void); +HTSEXT_API int hts_setpause(int); // pause transfer +HTSEXT_API int hts_request_stop(int force); +HTSEXT_API char* hts_cancel_file(char * s); +HTSEXT_API void hts_cancel_test(void); +HTSEXT_API void hts_cancel_parsing(void); +HTSEXT_API char* hts_cancel_file(char * s); +HTSEXT_API void hts_cancel_test(void); +HTSEXT_API void hts_cancel_parsing(void); + +/* Tools */ +HTSEXT_API int structcheck(char* s); +HTSEXT_API void infostatuscode(char* msg,int statuscode); +HTSEXT_API HTS_INLINE TStamp mtime_local(void); +HTSEXT_API void qsec2str(char *st,TStamp t); +HTSEXT_API char* int2char(int n); +HTSEXT_API char* int2bytes(LLint n); +HTSEXT_API char* int2bytessec(long int n); +HTSEXT_API char** int2bytes2(LLint n); +HTSEXT_API char* jump_identification(char*); +HTSEXT_API char* jump_normalized(char*); +HTSEXT_API char* jump_toport(char*); +HTSEXT_API char* fil_normalized(char* source, char* dest); +HTSEXT_API char* adr_normalized(char* source, char* dest); +HTSEXT_API char* hts_rootdir(char* file); + +/* Escaping URLs */ +HTSEXT_API void unescape_amp(char* s); +HTSEXT_API void escape_spc_url(char* s); +HTSEXT_API void escape_in_url(char* s); +HTSEXT_API void escape_uri(char* s); +HTSEXT_API void escape_uri_utf(char* s); +HTSEXT_API void escape_check_url(char* s); +HTSEXT_API char* escape_check_url_addr(char* s); +HTSEXT_API void x_escape_http(char* s,int mode); +HTSEXT_API char* unescape_http(char* s); +HTSEXT_API char* unescape_http_unharm(char* s, int no_high); +HTSEXT_API char* antislash_unescaped(char* s); +HTSEXT_API void escape_remove_control(char* s); + +/* Portable directory API */ + +typedef struct find_handle_struct find_handle_struct; +typedef find_handle_struct* find_handle; +typedef struct topindex_chain { + char name[2048]; /* path */ + struct topindex_chain* next; /* next element */ +} topindex_chain ; +HTSEXT_API find_handle hts_findfirst(char* path); +HTSEXT_API int hts_findnext(find_handle find); +HTSEXT_API int hts_findclose(find_handle find); +HTSEXT_API char* hts_findgetname(find_handle find); +HTSEXT_API int hts_findgetsize(find_handle find); +HTSEXT_API int hts_findisdir(find_handle find); +HTSEXT_API int hts_findisfile(find_handle find); +HTSEXT_API int hts_findissystem(find_handle find); + +/* Wrapper functions types (commented) : */ +/* +typedef void (* t_hts_htmlcheck_init)(void); +typedef void (* t_hts_htmlcheck_uninit)(void); +typedef int (* t_hts_htmlcheck_start)(httrackp* opt); +typedef int (* t_hts_htmlcheck_end)(void); +typedef int (* t_hts_htmlcheck_chopt)(httrackp* opt); +typedef int (* t_hts_htmlcheck)(char* html,int len,char* url_adresse,char* url_fichier); +typedef char* (* t_hts_htmlcheck_query)(char* question); +typedef char* (* t_hts_htmlcheck_query2)(char* question); +typedef char* (* t_hts_htmlcheck_query3)(char* question); +typedef int (* t_hts_htmlcheck_loop)(lien_back* back,int back_max,int back_index,int lien_tot,int lien_ntot,int stat_time,hts_stat_struct* stats); +typedef int (* t_hts_htmlcheck_check)(char* adr,char* fil,int status); +typedef void (* t_hts_htmlcheck_pause)(char* lockfile); +typedef void (* t_hts_htmlcheck_filesave)(char* file); +typedef int (* t_hts_htmlcheck_linkdetected)(char* link); +typedef int (* t_hts_htmlcheck_xfrstatus)(lien_back* back); +typedef int (* t_hts_htmlcheck_savename)(char* adr_complete,char* fil_complete,char* referer_adr,char* referer_fil,char* save); +typedef int (* t_hts_htmlcheck_sendhead)(char* buff, char* adr, char* fil, char* referer_adr, char* referer_fil, htsblk* outgoing); +typedef int (* t_hts_htmlcheck_receivehead)(char* buff, char* adr, char* fil, char* referer_adr, char* referer_fil, htsblk* incoming); +*/ +/* Wrapper functions names : */ +/* + hts_htmlcheck_init = (t_hts_htmlcheck_init) htswrap_read("init"); +Log: "engine: init" + + hts_htmlcheck_uninit = (t_hts_htmlcheck_uninit) htswrap_read("free"); +Log: "engine: free" + + hts_htmlcheck_start = (t_hts_htmlcheck_start) htswrap_read("start"); +Log: "engine: start" + + hts_htmlcheck_end = (t_hts_htmlcheck_end) htswrap_read("end"); +Log: "engine: end" + + hts_htmlcheck_chopt = (t_hts_htmlcheck_chopt) htswrap_read("change-options"); +Log: "engine: change-options" + + hts_htmlcheck = (t_hts_htmlcheck) htswrap_read("check-html"); +Log: "check-html: <url>" + + hts_htmlcheck_query = (t_hts_htmlcheck_query) htswrap_read("query"); + hts_htmlcheck_query2 = (t_hts_htmlcheck_query2) htswrap_read("query2"); + hts_htmlcheck_query3 = (t_hts_htmlcheck_query3) htswrap_read("query3"); + hts_htmlcheck_loop = (t_hts_htmlcheck_loop) htswrap_read("loop"); + hts_htmlcheck_check = (t_hts_htmlcheck_check) htswrap_read("check-link"); +Log: none + + hts_htmlcheck_pause = (t_hts_htmlcheck_pause) htswrap_read("pause"); +Log: "pause: <lockfile>" + + hts_htmlcheck_filesave = (t_hts_htmlcheck_filesave) htswrap_read("save-file"); + hts_htmlcheck_linkdetected = (t_hts_htmlcheck_linkdetected) htswrap_read("link-detected"); +Log: none + + hts_htmlcheck_xfrstatus = (t_hts_htmlcheck_xfrstatus) htswrap_read("transfer-status"); +Log: + "engine: transfer-status: link updated: <url> -> <file>" + | "engine: transfer-status: link added: <url> -> <file>" + | "engine: transfer-status: link recorded: <url> -> <file>" + | "engine: transfer-status: link link error (<errno>, '<err_msg>'): <url>" + hts_htmlcheck_savename = (t_hts_htmlcheck_savename ) htswrap_read("save-name"); +Log: + "engine: save-name: local name: <url> -> <file>" +*/ #endif - |