2021-07-03 05:07:57 +01:00
<!DOCTYPE HTML>
< html >
< head >
< meta http-equiv = "Content-Type" content = "text/html;charset=US-ASCII" >
2021-08-17 07:47:37 +01:00
< meta name = "generator" content = "ZealOS V1.00" >
2021-07-03 05:07:57 +01:00
< style type = "text/css" >
2021-07-29 03:20:15 +01:00
body {background-color:#fef1f0;}
.cF0{color:#000000;background-color:#fef1f0;}
.cF1{color:#0148a4;background-color:#fef1f0;}
.cF2{color:#3b7901;background-color:#fef1f0;}
.cF3{color:#057c7e;background-color:#fef1f0;}
.cF4{color:#bb2020;background-color:#fef1f0;}
.cF5{color:#9e42ae;background-color:#fef1f0;}
.cF6{color:#b57901;background-color:#fef1f0;}
.cF7{color:#b2b6af;background-color:#fef1f0;}
.cF8{color:#555753;background-color:#fef1f0;}
.cF9{color:#678fbb;background-color:#fef1f0;}
.cFA{color:#82bc49;background-color:#fef1f0;}
.cFB{color:#0097a2;background-color:#fef1f0;}
.cFC{color:#e26a6a;background-color:#fef1f0;}
.cFD{color:#c671bc;background-color:#fef1f0;}
.cFE{color:#c7ab00;background-color:#fef1f0;}
.cFF{color:#fef1f0;background-color:#fef1f0;}
2021-07-03 05:07:57 +01:00
< / style >
< / head >
< body >
2021-07-05 01:12:38 +01:00
< pre style = "font-family:monospace;font-size:12pt" >
2021-07-04 23:11:34 +01:00
< a name = "l1" > < / a > < span class = cF0 > #< / span > < span class = cF1 > define< / span > < span class = cF0 > DOWNLOAD_FILE1 < / span > < span class = cF6 > " TOS_Distro.ISO" < / span > < span class = cF0 >
< a name = "l2" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > DOWNLOAD_FILE1_SIZE < / span > < span class = cFE > 16000000< / span > < span class = cF0 >
2021-07-03 05:07:57 +01:00
< a name = "l3" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l4" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > HOURS_MAX (< / span > < span class = cFE > 24< / span > < span class = cF0 > *< / span > < span class = cFE > 3< / span > < span class = cF0 > )
2021-07-03 05:07:57 +01:00
< a name = "l5" > < / a >
< a name = "l6" > < / a > < / span > < span class = cF1 > class< / span > < span class = cF0 > LogStruct
< a name = "l7" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l8" > < / a > LogStruct *next, *last;
< a name = "l9" > < / a > LogStruct *ip_num_left, *ip_num_right;
< a name = "l10" > < / a > < / span > < span class = cF9 > U32< / span > < span class = cF0 > ip_num, code;
< a name = "l11" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > size;
< a name = "l12" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > *file, *link;
< a name = "l13" > < / a > < / span > < span class = cF9 > CDate< / span > < span class = cF0 > datetime;
2021-07-03 05:07:57 +01:00
< a name = "l14" > < / a > };
< a name = "l15" > < / a >
< a name = "l16" > < / a > < / span > < span class = cF1 > class< / span > < span class = cF0 > LinkStruct
< a name = "l17" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l18" > < / a > LinkStruct *left, *right;
< a name = "l19" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > *link, *file;
< a name = "l20" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > count;
2021-07-03 05:07:57 +01:00
< a name = "l21" > < / a > };
< a name = "l22" > < / a >
< a name = "l23" > < / a > < / span > < span class = cF1 > class< / span > < span class = cF0 > BlockedStruct
< a name = "l24" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l25" > < / a > BlockedStruct *next, *last;
< a name = "l26" > < / a > < / span > < span class = cF9 > U32< / span > < span class = cF0 > ip_num;
2021-07-03 05:07:57 +01:00
< a name = "l27" > < / a > };
< a name = "l28" > < / a >
< a name = "l29" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > LogStructDel(LogStruct *tmplg)
< a name = "l30" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l31" > < / a > < / span > < span class = cF5 > Free< / span > < span class = cF0 > (tmplg-> file);
< a name = "l32" > < / a > < / span > < span class = cF5 > Free< / span > < span class = cF0 > (tmplg-> link);
< a name = "l33" > < / a > < / span > < span class = cF5 > Free< / span > < span class = cF0 > (tmplg);
2021-07-03 05:07:57 +01:00
< a name = "l34" > < / a > }
< a name = "l35" > < / a >
< a name = "l36" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > ParseSingleLogFile(LogStruct *head, < / span > < span class = cF1 > U8< / span > < span class = cF0 > *name, < / span > < span class = cF9 > CDate< / span > < span class = cF0 > *_dstart, < / span > < span class = cF9 > CDate< / span > < span class = cF0 > *_dend)
< a name = "l37" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l38" > < / a > < / span > < span class = cF9 > CDoc< / span > < span class = cF0 > *doc = < / span > < span class = cF5 > DocRead< / span > < span class = cF0 > (name, < / span > < span class = cF3 > DOCF_PLAIN_TEXT_TABS< / span > < span class = cF0 > | < / span > < span class = cF3 > DOCF_DBL_DOLLARS< / span > < span class = cF0 > | < / span > < span class = cF3 > DOCF_NO_CURSOR< / span > < span class = cF0 > );
< a name = "l39" > < / a > < / span > < span class = cF9 > CDocEntry< / span > < span class = cF0 > *doc_e = doc-> head.next;
< a name = "l40" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > *src, *src2, *mon_list = < / span > < span class = cF5 > Define< / span > < span class = cF0 > (< / span > < span class = cF6 > " ST_MONTHS" < / span > < span class = cF0 > );
< a name = "l41" > < / a > LogStruct *tmplg;
< a name = "l42" > < / a > < / span > < span class = cF9 > CDateStruct< / span > < span class = cF0 > ds;
< a name = "l43" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > i;
2021-07-03 05:07:57 +01:00
< a name = "l44" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l45" > < / a > < / span > < span class = cF6 > " %$Q\n" < / span > < span class = cF0 > , name;
< a name = "l46" > < / a > < / span > < span class = cF1 > while< / span > < span class = cF0 > (doc_e != doc)
< a name = "l47" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l48" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (doc_e-> type_u8 == < / span > < span class = cF3 > DOCT_TEXT< / span > < span class = cF0 > )
< a name = "l49" > < / a > {
< a name = "l50" > < / a > tmplg = < / span > < span class = cF5 > CAlloc< / span > < span class = cF0 > (< / span > < span class = cF1 > sizeof< / span > < span class = cF7 > (< / span > < span class = cF0 > LogStruct< / span > < span class = cF7 > )< / span > < span class = cF0 > );
< a name = "l51" > < / a > < / span > < span class = cF1 > try< / span > < span class = cF0 >
< a name = "l52" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l53" > < / a > src = doc_e-> tag;
< a name = "l54" > < / a > tmplg-> ip_num.u8[< / span > < span class = cFE > 3< / span > < span class = cF0 > ] = < / span > < span class = cF5 > Str2I64< / span > < span class = cF0 > (src, < / span > < span class = cFE > 10< / span > < span class = cF0 > , & src);
< a name = "l55" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (*src++ != < / span > < span class = cF6 > '.'< / span > < span class = cF0 > ) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l56" > < / a > tmplg-> ip_num.u8[< / span > < span class = cFE > 2< / span > < span class = cF0 > ] = < / span > < span class = cF5 > Str2I64< / span > < span class = cF0 > (src, < / span > < span class = cFE > 10< / span > < span class = cF0 > , & src);
< a name = "l57" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (*src++ != < / span > < span class = cF6 > '.'< / span > < span class = cF0 > ) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l58" > < / a > tmplg-> ip_num.u8[< / span > < span class = cFE > 1< / span > < span class = cF0 > ] = < / span > < span class = cF5 > Str2I64< / span > < span class = cF0 > (src, < / span > < span class = cFE > 10< / span > < span class = cF0 > , & src);
< a name = "l59" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (*src++ != < / span > < span class = cF6 > '.'< / span > < span class = cF0 > ) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l60" > < / a > tmplg-> ip_num.u8[< / span > < span class = cFE > 0< / span > < span class = cF0 > ] = < / span > < span class = cF5 > Str2I64< / span > < span class = cF0 > (src, < / span > < span class = cFE > 10< / span > < span class = cF0 > , & src);
2021-07-03 05:07:57 +01:00
< a name = "l61" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l62" > < / a > < / span > < span class = cF1 > do< / span > < span class = cF0 > < / span > < span class = cF1 > if< / span > < span class = cF0 > (!*src) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l63" > < / a > < / span > < span class = cF1 > while< / span > < span class = cF0 > (*src++ != < / span > < span class = cF6 > '['< / span > < span class = cF0 > );
< a name = "l64" > < / a > < / span > < span class = cF5 > MemSet< / span > < span class = cF0 > (& ds, < / span > < span class = cFE > 0< / span > < span class = cF0 > , < / span > < span class = cF1 > sizeof< / span > < span class = cF7 > (< / span > < span class = cF9 > CDateStruct< / span > < span class = cF7 > )< / span > < span class = cF0 > );
< a name = "l65" > < / a > ds.day_of_mon = < / span > < span class = cF5 > Str2I64< / span > < span class = cF0 > (src, < / span > < span class = cFE > 10< / span > < span class = cF0 > , & src);
< a name = "l66" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (*src++ != < / span > < span class = cF6 > '/'< / span > < span class = cF0 > ) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l67" > < / a > src2 = src;
< a name = "l68" > < / a > < / span > < span class = cF1 > do< / span > < span class = cF0 > < / span > < span class = cF1 > if< / span > < span class = cF0 > (!*src2) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l69" > < / a > < / span > < span class = cF1 > while< / span > < span class = cF0 > (*src2++ != < / span > < span class = cF6 > '/'< / span > < span class = cF0 > );
< a name = "l70" > < / a > * --src2 = < / span > < span class = cFE > 0< / span > < span class = cF0 > ;
< a name = "l71" > < / a > ds.mon = < / span > < span class = cFE > 1< / span > < span class = cF0 > + < / span > < span class = cF5 > ListMatch< / span > < span class = cF0 > (src, mon_list, < / span > < span class = cF3 > LMF_IGNORE_CASE< / span > < span class = cF0 > );
< a name = "l72" > < / a > src = ++src2;
< a name = "l73" > < / a > ds.year = < / span > < span class = cF5 > Str2I64< / span > < span class = cF0 > (src, < / span > < span class = cFE > 10< / span > < span class = cF0 > , & src);
< a name = "l74" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (*src++ != < / span > < span class = cF6 > ':'< / span > < span class = cF0 > ) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l75" > < / a > ds.hour = < / span > < span class = cF5 > Str2I64< / span > < span class = cF0 > (src, < / span > < span class = cFE > 10< / span > < span class = cF0 > , & src);
< a name = "l76" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (*src++ != < / span > < span class = cF6 > ':'< / span > < span class = cF0 > ) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l77" > < / a > ds.min = < / span > < span class = cF5 > Str2I64< / span > < span class = cF0 > (src, < / span > < span class = cFE > 10< / span > < span class = cF0 > , & src);
< a name = "l78" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (*src++ != < / span > < span class = cF6 > ':'< / span > < span class = cF0 > ) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l79" > < / a > ds.sec = < / span > < span class = cF5 > Str2I64< / span > < span class = cF0 > (src, < / span > < span class = cFE > 10< / span > < span class = cF0 > , & src);
< a name = "l80" > < / a > tmplg-> datetime = < / span > < span class = cF5 > Struct2Date< / span > < span class = cF0 > (& ds);
< a name = "l81" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (*src++ != < / span > < span class = cF3 > CH_SPACE< / span > < span class = cF0 > ) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l82" > < / a > i = < / span > < span class = cF5 > Str2I64< / span > < span class = cF0 > (src, < / span > < span class = cFE > 10< / span > < span class = cF0 > , & src);
< a name = "l83" > < / a > tmplg-> datetime -= (i / < / span > < span class = cFE > 100< / span > < span class = cF0 > + i % < / span > < span class = cFE > 100< / span > < span class = cF0 > / < / span > < span class = cFE > 60< / span > < span class = cF0 > .< / span > < span class = cFE > 0< / span > < span class = cF0 > ) * < / span > < span class = cF3 > CDATE_FREQ< / span > < span class = cF0 > * < / span > < span class = cFE > 60< / span > < span class = cF0 > * < / span > < span class = cFE > 60< / span > < span class = cF0 > ;
< a name = "l84" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (!< / span > < span class = cF7 > (< / span > < span class = cF5 > Str2Date< / span > < span class = cF0 > (< / span > < span class = cF6 > " 1/1/2017" < / span > < span class = cF0 > ) < = tmplg-> datetime < < / span > < span class = cF5 > Str2Date< / span > < span class = cF0 > (< / span > < span class = cF6 > " 1/1/2050" < / span > < span class = cF0 > )< / span > < span class = cF7 > )< / span > < span class = cF0 > )
< a name = "l85" > < / a > < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l86" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (tmplg-> datetime < *_dstart) *_dstart = tmplg-> datetime;
< a name = "l87" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (tmplg-> datetime > *_dend) *_dend = tmplg-> datetime;
2021-07-03 05:07:57 +01:00
< a name = "l88" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l89" > < / a > < / span > < span class = cF1 > do< / span > < span class = cF0 > < / span > < span class = cF1 > if< / span > < span class = cF0 > (!*src) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l90" > < / a > < / span > < span class = cF1 > while< / span > < span class = cF0 > (*src++ != < / span > < span class = cF6 > ']'< / span > < span class = cF0 > );
2021-07-03 05:07:57 +01:00
< a name = "l91" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l92" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (*src++ != < / span > < span class = cF3 > CH_SPACE< / span > < span class = cF0 > ) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l93" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (*src++ != < / span > < span class = cF6 > '\" '< / span > < span class = cF0 > ) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l94" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (!< / span > < span class = cF5 > StrNCompare< / span > < span class = cF7 > (< / span > < span class = cF0 > src, < / span > < span class = cF6 > " GET " < / span > < span class = cF0 > , < / span > < span class = cFE > 4< / span > < span class = cF7 > )< / span > < span class = cF0 > )
< a name = "l95" > < / a > {
< a name = "l96" > < / a > src2 = src += < / span > < span class = cFE > 4< / span > < span class = cF0 > ;
< a name = "l97" > < / a > < / span > < span class = cF1 > do< / span > < span class = cF0 > < / span > < span class = cF1 > if< / span > < span class = cF0 > (!*src2) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l98" > < / a > < / span > < span class = cF1 > while< / span > < span class = cF0 > (*src2++ != < / span > < span class = cF3 > CH_SPACE< / span > < span class = cF0 > );
< a name = "l99" > < / a > * --src2 = < / span > < span class = cFE > 0< / span > < span class = cF0 > ;
< a name = "l100" > < / a > tmplg-> file = < / span > < span class = cF5 > StrNew< / span > < span class = cF0 > (src);
< a name = "l101" > < / a > src = ++src2;
2021-07-03 05:07:57 +01:00
< a name = "l102" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l103" > < / a > < / span > < span class = cF1 > do< / span > < span class = cF0 > < / span > < span class = cF1 > if< / span > < span class = cF0 > (!*src) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l104" > < / a > < / span > < span class = cF1 > while< / span > < span class = cF0 > (*src++ != < / span > < span class = cF6 > '\" '< / span > < span class = cF0 > );
2021-07-03 05:07:57 +01:00
< a name = "l105" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l106" > < / a > tmplg-> code = < / span > < span class = cF5 > Str2I64< / span > < span class = cF0 > (src, < / span > < span class = cFE > 10< / span > < span class = cF0 > , & src);
< a name = "l107" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (*src++ != < / span > < span class = cF3 > CH_SPACE< / span > < span class = cF0 > ) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l108" > < / a > tmplg-> size = < / span > < span class = cF5 > Str2I64< / span > < span class = cF0 > (src, < / span > < span class = cFE > 10< / span > < span class = cF0 > , & src);
< a name = "l109" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (*src++ != < / span > < span class = cF3 > CH_SPACE< / span > < span class = cF0 > ) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
2021-07-03 05:07:57 +01:00
< a name = "l110" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l111" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (*src++ != < / span > < span class = cF6 > '\" '< / span > < span class = cF0 > ) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l112" > < / a > src2 = src;
< a name = "l113" > < / a > < / span > < span class = cF1 > do< / span > < span class = cF0 > < / span > < span class = cF1 > if< / span > < span class = cF0 > (!*src2) < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l114" > < / a > < / span > < span class = cF1 > while< / span > < span class = cF0 > (*src2++ != < / span > < span class = cF6 > '\" '< / span > < span class = cF0 > );
< a name = "l115" > < / a > * --src2 = < / span > < span class = cFE > 0< / span > < span class = cF0 > ;
< a name = "l116" > < / a > tmplg-> link = < / span > < span class = cF5 > StrNew< / span > < span class = cF0 > (src);
< a name = "l117" > < / a > src = ++src2;
2021-07-03 05:07:57 +01:00
< a name = "l118" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l119" > < / a > < / span > < span class = cF5 > QueueInsert< / span > < span class = cF0 > (tmplg, head-> last);
< a name = "l120" > < / a > }
< a name = "l121" > < / a > < / span > < span class = cF1 > else< / span > < span class = cF0 > < / span > < span class = cF1 > if< / span > < span class = cF0 > (!< / span > < span class = cF5 > StrNCompare< / span > < span class = cF7 > (< / span > < span class = cF0 > src, < / span > < span class = cF6 > " HEAD " < / span > < span class = cF0 > , < / span > < span class = cFE > 5< / span > < span class = cF7 > )< / span > < span class = cF0 > )
< a name = "l122" > < / a > {
< a name = "l123" > < / a > LogStructDel(tmplg);
< a name = "l124" > < / a > }
< a name = "l125" > < / a > < / span > < span class = cF1 > else< / span > < span class = cF0 >
< a name = "l126" > < / a > < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l127" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l128" > < / a > < / span > < span class = cF1 > catch< / span > < span class = cF0 >
< a name = "l129" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l130" > < / a > < / span > < span class = cF5 > Fs< / span > < span class = cF0 > -> catch_except = < / span > < span class = cF3 > TRUE< / span > < span class = cF0 > ;
< a name = "l131" > < / a > < / span > < span class = cF6 > " %$Q\n" < / span > < span class = cF0 > , doc_e-> tag;
< a name = "l132" > < / a > LogStructDel(tmplg);
< a name = "l133" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l134" > < / a > }
< a name = "l135" > < / a > doc_e = doc_e-> next;
< a name = "l136" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l137" > < / a > < / span > < span class = cF5 > DocDel< / span > < span class = cF0 > (doc);
2021-07-03 05:07:57 +01:00
< a name = "l138" > < / a > }
< a name = "l139" > < / a >
< a name = "l140" > < / a > LogStruct *ParseLogFiles(< / span > < span class = cF1 > U8< / span > < span class = cF0 > *files_find_mask, < / span > < span class = cF9 > CDate< / span > < span class = cF0 > *_dstart, < / span > < span class = cF9 > CDate< / span > < span class = cF0 > *_dend)
< a name = "l141" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l142" > < / a > LogStruct *head = < / span > < span class = cF5 > CAlloc< / span > < span class = cF0 > (< / span > < span class = cF1 > sizeof< / span > < span class = cF7 > (< / span > < span class = cF0 > LogStruct< / span > < span class = cF7 > )< / span > < span class = cF0 > );
< a name = "l143" > < / a > < / span > < span class = cF9 > CDirEntry< / span > < span class = cF0 > *tmpde = < / span > < span class = cF5 > FilesFind< / span > < span class = cF0 > (files_find_mask), *tmpde1 = tmpde;
2021-07-03 05:07:57 +01:00
< a name = "l144" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l145" > < / a > < / span > < span class = cF5 > QueueInit< / span > < span class = cF0 > (head);
< a name = "l146" > < / a > < / span > < span class = cF1 > while< / span > < span class = cF0 > (tmpde)
< a name = "l147" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l148" > < / a > ParseSingleLogFile(head, tmpde-> full_name, _dstart, _dend);
< a name = "l149" > < / a > tmpde = tmpde-> next;
< a name = "l150" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l151" > < / a > < / span > < span class = cF5 > DirTreeDel< / span > < span class = cF0 > (tmpde1);
2021-07-03 05:07:57 +01:00
< a name = "l152" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l153" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > head;
2021-07-03 05:07:57 +01:00
< a name = "l154" > < / a > }
< a name = "l155" > < / a >
< a name = "l156" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > LogListDel(LogStruct *head)
< a name = "l157" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l158" > < / a > LogStruct *tmplg = head-> next, *tmplg1;
2021-07-03 05:07:57 +01:00
< a name = "l159" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l160" > < / a > < / span > < span class = cF1 > while< / span > < span class = cF0 > (tmplg != head)
< a name = "l161" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l162" > < / a > tmplg1 = tmplg-> next;
< a name = "l163" > < / a > LogStructDel(tmplg);
< a name = "l164" > < / a > tmplg = tmplg1;
< a name = "l165" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
2021-07-03 05:07:57 +01:00
< a name = "l166" > < / a > }
< a name = "l167" > < / a >
< a name = "l168" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > BlockedStructAdd(BlockedStruct *head, < / span > < span class = cF9 > U32< / span > < span class = cF0 > ip_num)
< a name = "l169" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l170" > < / a > BlockedStruct *tmpb = < / span > < span class = cF5 > CAlloc< / span > < span class = cF0 > (< / span > < span class = cF1 > sizeof< / span > < span class = cF7 > (< / span > < span class = cF0 > BlockedStruct< / span > < span class = cF7 > )< / span > < span class = cF0 > );
2021-07-03 05:07:57 +01:00
< a name = "l171" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l172" > < / a > tmpb-> ip_num = ip_num;
< a name = "l173" > < / a > < / span > < span class = cF5 > QueueInsert< / span > < span class = cF0 > (tmpb, head-> last);
2021-07-03 05:07:57 +01:00
< a name = "l174" > < / a > }
< a name = "l175" > < / a >
< a name = "l176" > < / a > < / span > < span class = cF1 > Bool< / span > < span class = cF0 > IsBlocked(BlockedStruct *head, < / span > < span class = cF9 > U32< / span > < span class = cF0 > ip_num)
< a name = "l177" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l178" > < / a > BlockedStruct *tmpb = head-> next;
2021-07-03 05:07:57 +01:00
< a name = "l179" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l180" > < / a > < / span > < span class = cF1 > while< / span > < span class = cF0 > (tmpb != head)
< a name = "l181" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l182" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (tmpb-> ip_num == ip_num)
< a name = "l183" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > < / span > < span class = cF3 > TRUE< / span > < span class = cF0 > ;
< a name = "l184" > < / a > tmpb = tmpb-> next;
< a name = "l185" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
2021-07-03 05:07:57 +01:00
< a name = "l186" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l187" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > < / span > < span class = cF3 > FALSE< / span > < span class = cF0 > ;
2021-07-03 05:07:57 +01:00
< a name = "l188" > < / a > }
< a name = "l189" > < / a >
< a name = "l190" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > BlockIPNuip(LogStruct *head)
< a name = "l191" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l192" > < / a > BlockedStruct blocked_head;
< a name = "l193" > < / a > LogStruct *tmplg = head-> next, *tmplg1;
2021-07-03 05:07:57 +01:00
< a name = "l194" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l195" > < / a > < / span > < span class = cF5 > QueueInit< / span > < span class = cF0 > (& blocked_head);
2021-07-03 05:07:57 +01:00
< a name = "l196" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l197" > < / a > BlockedStructAdd(& blocked_head, < / span > < span class = cFE > 68< / span > < span class = cF0 > < < < / span > < span class = cFE > 24< / span > < span class = cF0 > + < / span > < span class = cFE > 227< / span > < span class = cF0 > < < < / span > < span class = cFE > 16< / span > < span class = cF0 > + < / span > < span class = cFE > 61< / span > < span class = cF0 > < < < / span > < span class = cFE > 8< / span > < span class = cF0 > + < / span > < span class = cFE > 6< / span > < span class = cF0 > );
2021-07-03 05:07:57 +01:00
< a name = "l198" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l199" > < / a > < / span > < span class = cF2 > //pass 1: collect robot list< / span > < span class = cF0 >
< a name = "l200" > < / a > < / span > < span class = cF1 > while< / span > < span class = cF0 > (tmplg != head)
< a name = "l201" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l202" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (< / span > < span class = cF5 > StrIMatch< / span > < span class = cF7 > (< / span > < span class = cF6 > " ROBOT" < / span > < span class = cF0 > , tmplg-> file< / span > < span class = cF7 > )< / span > < span class = cF0 > & & !IsBlocked< / span > < span class = cF7 > (< / span > < span class = cF0 > & blocked_head, tmplg-> ip_num< / span > < span class = cF7 > )< / span > < span class = cF0 > )
< a name = "l203" > < / a > BlockedStructAdd(& blocked_head, tmplg-> ip_num);
< a name = "l204" > < / a > tmplg = tmplg-> next;
< a name = "l205" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
2021-07-03 05:07:57 +01:00
< a name = "l206" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l207" > < / a > < / span > < span class = cF2 > //pass 2: removed blocked ip_nuip< / span > < span class = cF0 >
< a name = "l208" > < / a > tmplg = head-> next;
< a name = "l209" > < / a > < / span > < span class = cF1 > while< / span > < span class = cF0 > (tmplg != head)
< a name = "l210" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l211" > < / a > tmplg1 = tmplg-> next;
< a name = "l212" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (IsBlocked< / span > < span class = cF7 > (< / span > < span class = cF0 > & blocked_head, tmplg-> ip_num< / span > < span class = cF7 > )< / span > < span class = cF0 > )
< a name = "l213" > < / a > {
< a name = "l214" > < / a > < / span > < span class = cF5 > QueueRemove< / span > < span class = cF0 > (tmplg);
< a name = "l215" > < / a > LogStructDel(tmplg);
< a name = "l216" > < / a > }
< a name = "l217" > < / a > tmplg = tmplg1;
< a name = "l218" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
2021-07-03 05:07:57 +01:00
< a name = "l219" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l220" > < / a > < / span > < span class = cF5 > QueueDel< / span > < span class = cF0 > (& blocked_head);
2021-07-03 05:07:57 +01:00
< a name = "l221" > < / a > }
< a name = "l222" > < / a >
< a name = "l223" > < / a > < / span > < span class = cF1 > Bool< / span > < span class = cF0 > IsDownLoad(LogStruct *tmplg)
< a name = "l224" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l225" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (< / span > < span class = cF5 > StrMatch< / span > < span class = cF7 > (< / span > < span class = cF0 > DOWNLOAD_FILE1, tmplg-> file< / span > < span class = cF7 > )< / span > < span class = cF0 > & & tmplg-> size > = DOWNLOAD_FILE1_SIZE)
< a name = "l226" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > < / span > < span class = cF3 > TRUE< / span > < span class = cF0 > ;
< a name = "l227" > < / a > < / span > < span class = cF1 > else< / span > < span class = cF0 >
< a name = "l228" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > < / span > < span class = cF3 > FALSE< / span > < span class = cF0 > ;
2021-07-03 05:07:57 +01:00
< a name = "l229" > < / a > }
< a name = "l230" > < / a >
< a name = "l231" > < / a > < / span > < span class = cF1 > Bool< / span > < span class = cF0 > IsIndex(LogStruct *tmplg)
< a name = "l232" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l233" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (!< / span > < span class = cF5 > StrCompare< / span > < span class = cF7 > (< / span > < span class = cF0 > tmplg-> file, < / span > < span class = cF6 > " /index.html" < / span > < span class = cF7 > )< / span > < span class = cF0 > || !< / span > < span class = cF5 > StrCompare< / span > < span class = cF7 > (< / span > < span class = cF0 > tmplg-> file, < / span > < span class = cF6 > " /" < / span > < span class = cF7 > )< / span > < span class = cF0 > )
< a name = "l234" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > < / span > < span class = cF3 > TRUE< / span > < span class = cF0 > ;
< a name = "l235" > < / a > < / span > < span class = cF1 > else< / span > < span class = cF0 >
< a name = "l236" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > < / span > < span class = cF3 > FALSE< / span > < span class = cF0 > ;
2021-07-03 05:07:57 +01:00
< a name = "l237" > < / a > }
< a name = "l238" > < / a >
< a name = "l239" > < / a > < / span > < span class = cF1 > Bool< / span > < span class = cF0 > IsKeeper(LogStruct *tmplg, < / span > < span class = cF9 > CDate< / span > < span class = cF0 > dstart, < / span > < span class = cF9 > CDate< / span > < span class = cF0 > dend)
< a name = "l240" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l241" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (dstart < = tmplg-> datetime < = dend & &
< a name = "l242" > < / a > !< / span > < span class = cF5 > StrOcc< / span > < span class = cF7 > (< / span > < span class = cF0 > tmplg-> file, < / span > < span class = cF6 > '?'< / span > < span class = cF7 > )< / span > < span class = cF0 > & &
< a name = "l243" > < / a > < / span > < span class = cF5 > StrLen< / span > < span class = cF7 > (< / span > < span class = cF0 > tmplg-> file< / span > < span class = cF7 > )< / span > < span class = cF0 > > < / span > < span class = cFE > 2< / span > < span class = cF0 > & &
< a name = "l244" > < / a > < / span > < span class = cF6 > 'A'< / span > < span class = cF0 > < = tmplg-> file[< / span > < span class = cFE > 1< / span > < span class = cF0 > ] < = < / span > < span class = cF6 > 'Z'< / span > < span class = cF0 > & &
< a name = "l245" > < / a > tmplg-> size & &
< a name = "l246" > < / a > tmplg-> file[< / span > < span class = cF5 > StrLen< / span > < span class = cF7 > (< / span > < span class = cF0 > tmplg-> file< / span > < span class = cF7 > )< / span > < span class = cF0 > - < / span > < span class = cFE > 1< / span > < span class = cF0 > ] != < / span > < span class = cF6 > '/'< / span > < span class = cF0 > & &
< a name = "l247" > < / a > < / span > < span class = cF7 > (< / span > < span class = cF5 > StrLen< / span > < span class = cF0 > (tmplg-> file) < < / span > < span class = cFE > 3< / span > < span class = cF0 > || < / span > < span class = cF5 > MemCompare< / span > < span class = cF0 > (& tmplg-> file[< / span > < span class = cFE > 1< / span > < span class = cF0 > ], < / span > < span class = cF6 > " Wb" < / span > < span class = cF0 > , < / span > < span class = cFE > 2< / span > < span class = cF0 > )< / span > < span class = cF7 > )< / span > < span class = cF0 > & &
< a name = "l248" > < / a > < / span > < span class = cF7 > (< / span > < span class = cF5 > StrLen< / span > < span class = cF0 > (tmplg-> file) < < / span > < span class = cFE > 7< / span > < span class = cF0 > || < / span > < span class = cF5 > MemCompare< / span > < span class = cF0 > (& tmplg-> file[< / span > < span class = cFE > 1< / span > < span class = cF0 > ], < / span > < span class = cF6 > " Family" < / span > < span class = cF0 > , < / span > < span class = cFE > 6< / span > < span class = cF0 > )< / span > < span class = cF7 > )< / span > < span class = cF0 > )
< a name = "l249" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l250" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > < / span > < span class = cF3 > TRUE< / span > < span class = cF0 > ;
2021-07-03 05:07:57 +01:00
< a name = "l251" > < / a >
< a name = "l252" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 > < / span > < span class = cF1 > else< / span > < span class = cF0 >
2021-07-04 23:11:34 +01:00
< a name = "l253" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > < / span > < span class = cF3 > FALSE< / span > < span class = cF0 > ;
2021-07-03 05:07:57 +01:00
< a name = "l254" > < / a > }
< a name = "l255" > < / a >
< a name = "l256" > < / a > < / span > < span class = cF1 > Bool< / span > < span class = cF0 > IPNumTreeAdd(LogStruct **_head, LogStruct *tmplg)
< a name = "l257" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l258" > < / a > LogStruct *head;
2021-07-03 05:07:57 +01:00
< a name = "l259" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l260" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (< / span > < span class = cF5 > UnusedStack< / span > < span class = cF0 > < < / span > < span class = cFE > 0x200< / span > < span class = cF0 > )
< a name = "l261" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l262" > < / a > < / span > < span class = cF5 > PrintErr< / span > < span class = cF0 > (< / span > < span class = cF6 > " Stack Overflow" < / span > < span class = cF0 > );
< a name = "l263" > < / a > < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l264" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l265" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (head = *_head)
< a name = "l266" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l267" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (tmplg-> ip_num == head-> ip_num)
< a name = "l268" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > < / span > < span class = cF3 > TRUE< / span > < span class = cF0 > ;
< a name = "l269" > < / a > < / span > < span class = cF1 > else< / span > < span class = cF0 > < / span > < span class = cF1 > if< / span > < span class = cF0 > (tmplg-> ip_num < head-> ip_num)
< a name = "l270" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > IPNumTreeAdd(& head-> ip_num_left, tmplg);
< a name = "l271" > < / a > < / span > < span class = cF1 > else< / span > < span class = cF0 >
< a name = "l272" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > IPNumTreeAdd(& head-> ip_num_right, tmplg);
< a name = "l273" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l274" > < / a > < / span > < span class = cF1 > else< / span > < span class = cF0 >
< a name = "l275" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l276" > < / a > tmplg-> ip_num_left = < / span > < span class = cF3 > NULL< / span > < span class = cF0 > ;
< a name = "l277" > < / a > tmplg-> ip_num_right = < / span > < span class = cF3 > NULL< / span > < span class = cF0 > ;
< a name = "l278" > < / a > *_head = tmplg;
2021-07-03 05:07:57 +01:00
< a name = "l279" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l280" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > < / span > < span class = cF3 > FALSE< / span > < span class = cF0 > ;
< a name = "l281" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
2021-07-03 05:07:57 +01:00
< a name = "l282" > < / a > }
< a name = "l283" > < / a >
< a name = "l284" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > LinkTreeAdd(LinkStruct **_root, LogStruct *tmplg)
< a name = "l285" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l286" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > i;
< a name = "l287" > < / a > LinkStruct *root, *tmplk;
2021-07-03 05:07:57 +01:00
< a name = "l288" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l289" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (< / span > < span class = cF5 > UnusedStack< / span > < span class = cF0 > < < / span > < span class = cFE > 0x200< / span > < span class = cF0 > )
< a name = "l290" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l291" > < / a > < / span > < span class = cF5 > PrintErr< / span > < span class = cF0 > (< / span > < span class = cF6 > " Stack Overflow" < / span > < span class = cF0 > );
< a name = "l292" > < / a > < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l293" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l294" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (root = *_root)
< a name = "l295" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l296" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (!< / span > < span class = cF7 > (< / span > < span class = cF0 > i = < / span > < span class = cF5 > StrCompare< / span > < span class = cF0 > (tmplg-> link, root-> link)< / span > < span class = cF7 > )< / span > < span class = cF0 > )
< a name = "l297" > < / a > root-> count++;
< a name = "l298" > < / a > < / span > < span class = cF1 > else< / span > < span class = cF0 > < / span > < span class = cF1 > if< / span > < span class = cF0 > (i < < / span > < span class = cFE > 0< / span > < span class = cF0 > )
< a name = "l299" > < / a > LinkTreeAdd(& root-> left, tmplg);
< a name = "l300" > < / a > < / span > < span class = cF1 > else< / span > < span class = cF0 >
< a name = "l301" > < / a > LinkTreeAdd(& root-> right, tmplg);
< a name = "l302" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l303" > < / a > < / span > < span class = cF1 > else< / span > < span class = cF0 >
< a name = "l304" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l305" > < / a > tmplk = < / span > < span class = cF5 > CAlloc< / span > < span class = cF0 > (< / span > < span class = cF1 > sizeof< / span > < span class = cF7 > (< / span > < span class = cF0 > LinkStruct< / span > < span class = cF7 > )< / span > < span class = cF0 > );
< a name = "l306" > < / a > tmplk-> link = tmplg-> link;
< a name = "l307" > < / a > tmplk-> count = < / span > < span class = cFE > 1< / span > < span class = cF0 > ;
< a name = "l308" > < / a > *_root = tmplk;
< a name = "l309" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
2021-07-03 05:07:57 +01:00
< a name = "l310" > < / a > }
< a name = "l311" > < / a >
< a name = "l312" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > FileTreeAdd(LinkStruct **_root, LogStruct *tmplg)
< a name = "l313" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l314" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > i;
< a name = "l315" > < / a > LinkStruct *root, *tmplk;
< a name = "l316" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (< / span > < span class = cF5 > UnusedStack< / span > < span class = cF0 > < < / span > < span class = cFE > 0x200< / span > < span class = cF0 > )
< a name = "l317" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l318" > < / a > < / span > < span class = cF5 > PrintErr< / span > < span class = cF0 > (< / span > < span class = cF6 > " Stack Overflow" < / span > < span class = cF0 > );
< a name = "l319" > < / a > < / span > < span class = cF5 > throw< / span > < span class = cF0 > ;
< a name = "l320" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l321" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (root = *_root)
< a name = "l322" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l323" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (!< / span > < span class = cF7 > (< / span > < span class = cF0 > i = < / span > < span class = cF5 > StrCompare< / span > < span class = cF0 > (tmplg-> file, root-> file)< / span > < span class = cF7 > )< / span > < span class = cF0 > )
< a name = "l324" > < / a > root-> count++;
< a name = "l325" > < / a > < / span > < span class = cF1 > else< / span > < span class = cF0 > < / span > < span class = cF1 > if< / span > < span class = cF0 > (i < < / span > < span class = cFE > 0< / span > < span class = cF0 > )
< a name = "l326" > < / a > FileTreeAdd(& root-> left, tmplg);
< a name = "l327" > < / a > < / span > < span class = cF1 > else< / span > < span class = cF0 >
< a name = "l328" > < / a > FileTreeAdd(& root-> right, tmplg);
< a name = "l329" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l330" > < / a > < / span > < span class = cF1 > else< / span > < span class = cF0 >
< a name = "l331" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l332" > < / a > tmplk = < / span > < span class = cF5 > CAlloc< / span > < span class = cF0 > (< / span > < span class = cF1 > sizeof< / span > < span class = cF7 > (< / span > < span class = cF0 > LinkStruct< / span > < span class = cF7 > )< / span > < span class = cF0 > );
< a name = "l333" > < / a > tmplk-> file = tmplg-> file;
< a name = "l334" > < / a > tmplk-> count = < / span > < span class = cFE > 1< / span > < span class = cF0 > ;
< a name = "l335" > < / a > *_root = tmplk;
< a name = "l336" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
2021-07-03 05:07:57 +01:00
< a name = "l337" > < / a > }
< a name = "l338" > < / a >
< a name = "l339" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > LinkTreeDel(LinkStruct *root)
< a name = "l340" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l341" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (root)
< a name = "l342" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l343" > < / a > LinkTreeDel(root-> left);
< a name = "l344" > < / a > LinkTreeDel(root-> right);
< a name = "l345" > < / a > < / span > < span class = cF5 > Free< / span > < span class = cF0 > (root);
< a name = "l346" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
2021-07-03 05:07:57 +01:00
< a name = "l347" > < / a > }
< a name = "l348" > < / a >
< a name = "l349" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > LinkTreeTraverse(LinkStruct *root)
< a name = "l350" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l351" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (root)
< a name = "l352" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l353" > < / a > LinkTreeTraverse(root-> left);
< a name = "l354" > < / a > < / span > < span class = cF6 > " %3d:%$Q\n" < / span > < span class = cF0 > , root-> count, root-> link;
< a name = "l355" > < / a > LinkTreeTraverse(root-> right);
< a name = "l356" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
2021-07-03 05:07:57 +01:00
< a name = "l357" > < / a > }
< a name = "l358" > < / a >
< a name = "l359" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > FileTreeDel(LinkStruct *root)
< a name = "l360" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l361" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (root)
< a name = "l362" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l363" > < / a > FileTreeDel(root-> left);
< a name = "l364" > < / a > FileTreeDel(root-> right);
< a name = "l365" > < / a > < / span > < span class = cF5 > Free< / span > < span class = cF0 > (root);
< a name = "l366" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
2021-07-03 05:07:57 +01:00
< a name = "l367" > < / a > }
< a name = "l368" > < / a >
< a name = "l369" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > FileTreeTraverse(LinkStruct *root)
< a name = "l370" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l371" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (root)
< a name = "l372" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l373" > < / a > FileTreeTraverse(root-> left);
< a name = "l374" > < / a > < / span > < span class = cF6 > " %3d:%$Q\n" < / span > < span class = cF0 > , root-> count, root-> file;
< a name = "l375" > < / a > FileTreeTraverse(root-> right);
< a name = "l376" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
2021-07-03 05:07:57 +01:00
< a name = "l377" > < / a > }
< a name = "l378" > < / a >
< a name = "l379" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > DownLoadRep(LogStruct *head, < / span > < span class = cF9 > CDate< / span > < span class = cF0 > dstart, < / span > < span class = cF9 > CDate< / span > < span class = cF0 > dend)
< a name = "l380" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l381" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > i, j, count, dups,
< a name = "l382" > < / a > hours_start, hours_end, *hour_counts, *dup_counts,
< a name = "l383" > < / a > days_start, days_end, *day_counts, *day_dup_counts;
< a name = "l384" > < / a > LogStruct *tmplg = head-> next, *dup_head = < / span > < span class = cF3 > NULL< / span > < span class = cF0 > ;
< a name = "l385" > < / a > LinkStruct *link_root = < / span > < span class = cF3 > NULL< / span > < span class = cF0 > ;
< a name = "l386" > < / a > < / span > < span class = cF9 > CDateStruct< / span > < span class = cF0 > ds;
2021-07-03 05:07:57 +01:00
< a name = "l387" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l388" > < / a > i = dstart * < / span > < span class = cFE > 24< / span > < span class = cF0 > ;
< a name = "l389" > < / a > hours_start = i.u32[< / span > < span class = cFE > 1< / span > < span class = cF0 > ];
< a name = "l390" > < / a > i = dend * < / span > < span class = cFE > 24< / span > < span class = cF0 > ;
< a name = "l391" > < / a > hours_end = i.u32[< / span > < span class = cFE > 1< / span > < span class = cF0 > ];
2021-07-03 05:07:57 +01:00
< a name = "l392" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l393" > < / a > days_start = (dstart + < / span > < span class = cFB > local_time_offset< / span > < span class = cF0 > ) > > < / span > < span class = cFE > 32< / span > < span class = cF0 > ;
< a name = "l394" > < / a > days_end = (dend + < / span > < span class = cFB > local_time_offset< / span > < span class = cF0 > ) > > < / span > < span class = cFE > 32< / span > < span class = cF0 > ;
2021-07-03 05:07:57 +01:00
< a name = "l395" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l396" > < / a > hour_counts = < / span > < span class = cF5 > CAlloc< / span > < span class = cF0 > (< / span > < span class = cF7 > (< / span > < span class = cF0 > hours_end - hours_start + < / span > < span class = cFE > 1< / span > < span class = cF7 > )< / span > < span class = cF0 > * < / span > < span class = cF1 > sizeof< / span > < span class = cF7 > (< / span > < span class = cF9 > I64< / span > < span class = cF7 > )< / span > < span class = cF0 > );
< a name = "l397" > < / a > dup_counts = < / span > < span class = cF5 > CAlloc< / span > < span class = cF0 > (< / span > < span class = cF7 > (< / span > < span class = cF0 > hours_end - hours_start + < / span > < span class = cFE > 1< / span > < span class = cF7 > )< / span > < span class = cF0 > * < / span > < span class = cF1 > sizeof< / span > < span class = cF7 > (< / span > < span class = cF9 > I64< / span > < span class = cF7 > )< / span > < span class = cF0 > );
< a name = "l398" > < / a > day_counts = < / span > < span class = cF5 > CAlloc< / span > < span class = cF0 > (< / span > < span class = cF7 > (< / span > < span class = cF0 > days_end - days_start + < / span > < span class = cFE > 1< / span > < span class = cF7 > )< / span > < span class = cF0 > * < / span > < span class = cF1 > sizeof< / span > < span class = cF7 > (< / span > < span class = cF9 > I64< / span > < span class = cF7 > )< / span > < span class = cF0 > );
< a name = "l399" > < / a > day_dup_counts = < / span > < span class = cF5 > CAlloc< / span > < span class = cF0 > (< / span > < span class = cF7 > (< / span > < span class = cF0 > days_end - days_start + < / span > < span class = cFE > 1< / span > < span class = cF7 > )< / span > < span class = cF0 > * < / span > < span class = cF1 > sizeof< / span > < span class = cF7 > (< / span > < span class = cF9 > I64< / span > < span class = cF7 > )< / span > < span class = cF0 > );
< a name = "l400" > < / a > dups = count = < / span > < span class = cFE > 0< / span > < span class = cF0 > ;
< a name = "l401" > < / a > < / span > < span class = cF1 > while< / span > < span class = cF0 > (tmplg != head)
< a name = "l402" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l403" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (IsKeeper< / span > < span class = cF7 > (< / span > < span class = cF0 > tmplg, dstart, dend< / span > < span class = cF7 > )< / span > < span class = cF0 > & & IsDownLoad< / span > < span class = cF7 > (< / span > < span class = cF0 > tmplg< / span > < span class = cF7 > )< / span > < span class = cF0 > )
< a name = "l404" > < / a > {
< a name = "l405" > < / a > i = tmplg-> datetime * < / span > < span class = cFE > 24< / span > < span class = cF0 > ;
< a name = "l406" > < / a > hour_counts[i.u32[< / span > < span class = cFE > 1< / span > < span class = cF0 > ] - hours_start]++;
< a name = "l407" > < / a > day_counts[(tmplg-> datetime + < / span > < span class = cFB > local_time_offset< / span > < span class = cF0 > ) > > < / span > < span class = cFE > 32< / span > < span class = cF0 > - days_start]++;
< a name = "l408" > < / a > count++;
< a name = "l409" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (IPNumTreeAdd< / span > < span class = cF7 > (< / span > < span class = cF0 > & dup_head, tmplg< / span > < span class = cF7 > )< / span > < span class = cF0 > )
< a name = "l410" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l411" > < / a > day_dup_counts[(tmplg-> datetime + < / span > < span class = cFB > local_time_offset< / span > < span class = cF0 > ) > > < / span > < span class = cFE > 32< / span > < span class = cF0 > - days_start]++;
< a name = "l412" > < / a > dup_counts[i.u32[< / span > < span class = cFE > 1< / span > < span class = cF0 > ] - hours_start]++;
< a name = "l413" > < / a > dups++;
< a name = "l414" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l415" > < / a > LinkTreeAdd(& link_root, tmplg);
< a name = "l416" > < / a > }
< a name = "l417" > < / a > tmplg = tmplg-> next;
< a name = "l418" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
2021-07-03 05:07:57 +01:00
< a name = "l419" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l420" > < / a > < / span > < span class = cF6 > " \n\nDownloads of /TOS_Distro.ISO\n" < / span > < span class = cF0 > ;
< a name = "l421" > < / a > < / span > < span class = cF1 > for< / span > < span class = cF0 > (i = dstart; i < = dend; i += < / span > < span class = cFE > 1< / span > < span class = cF0 > < < < / span > < span class = cFE > 32< / span > < span class = cF0 > )
< a name = "l422" > < / a > < / span > < span class = cF6 > " %D Dups:%5d Total:%5d Uniques:%5d\n" < / span > < span class = cF0 > , i,
< a name = "l423" > < / a > day_dup_counts[(i + < / span > < span class = cFB > local_time_offset< / span > < span class = cF0 > ) > > < / span > < span class = cFE > 32< / span > < span class = cF0 > - days_start],
< a name = "l424" > < / a > day_counts[(i + < / span > < span class = cFB > local_time_offset< / span > < span class = cF0 > ) > > < / span > < span class = cFE > 32< / span > < span class = cF0 > - days_start],
< a name = "l425" > < / a > day_counts[(i + < / span > < span class = cFB > local_time_offset< / span > < span class = cF0 > ) > > < / span > < span class = cFE > 32< / span > < span class = cF0 > - days_start] - day_dup_counts[(i + < / span > < span class = cFB > local_time_offset< / span > < span class = cF0 > ) > > < / span > < span class = cFE > 32< / span > < span class = cF0 > - days_start];
2021-07-03 05:07:57 +01:00
< a name = "l426" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l427" > < / a > < / span > < span class = cF6 > " \n\nDownloads of /TOS_Distro.ISO\n" < / span > < span class = cF0 >
< a name = "l428" > < / a > < / span > < span class = cF6 > " '-' is a dup. '+' is not a dup.\n" < / span > < span class = cF0 > ;
< a name = "l429" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (hours_end - hours_start > = HOURS_MAX)
< a name = "l430" > < / a > i = hours_end - HOURS_MAX + < / span > < span class = cFE > 1< / span > < span class = cF0 > ;
< a name = "l431" > < / a > < / span > < span class = cF1 > else< / span > < span class = cF0 >
< a name = "l432" > < / a > i = hours_start;
< a name = "l433" > < / a > < / span > < span class = cF1 > for< / span > < span class = cF0 > (; i < = hours_end; i++)
< a name = "l434" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l435" > < / a > < / span > < span class = cF5 > Date2Struct< / span > < span class = cF0 > (& ds, i < < < / span > < span class = cFE > 32< / span > < span class = cF0 > / < / span > < span class = cFE > 24< / span > < span class = cF0 > + < / span > < span class = cFB > local_time_offset< / span > < span class = cF0 > );
< a name = "l436" > < / a > < / span > < span class = cF6 > " %D %02d: " < / span > < span class = cF0 > , i < < < / span > < span class = cFE > 32< / span > < span class = cF0 > / < / span > < span class = cFE > 24< / span > < span class = cF0 > , ds.hour;
< a name = "l437" > < / a > < / span > < span class = cF1 > for< / span > < span class = cF0 > (j = < / span > < span class = cFE > 0< / span > < span class = cF0 > ; j < dup_counts[i - hours_start]; j++)
< a name = "l438" > < / a > < / span > < span class = cF6 > '-'< / span > < span class = cF0 > ;
< a name = "l439" > < / a > < / span > < span class = cF1 > for< / span > < span class = cF0 > (; j < hour_counts[i - hours_start]; j++)
< a name = "l440" > < / a > < / span > < span class = cF6 > '+'< / span > < span class = cF0 > ;
< a name = "l441" > < / a > < / span > < span class = cF6 > '\n'< / span > < span class = cF0 > ;
< a name = "l442" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l443" > < / a > < / span > < span class = cF6 > " Total:%d Dups:%d Uniques:%d\n" < / span > < span class = cF0 > , count, dups, count - dups;
2021-07-03 05:07:57 +01:00
< a name = "l444" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l445" > < / a > < / span > < span class = cF6 > " \n\nDownloads of /TOS_Distro.ISO\n" < / span > < span class = cF0 > ;
< a name = "l446" > < / a > LinkTreeTraverse(link_root);
< a name = "l447" > < / a > < / span > < span class = cF6 > '\n'< / span > < span class = cF0 > ;
2021-07-03 05:07:57 +01:00
< a name = "l448" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l449" > < / a > LinkTreeDel(link_root);
< a name = "l450" > < / a > < / span > < span class = cF5 > Free< / span > < span class = cF0 > (hour_counts);
< a name = "l451" > < / a > < / span > < span class = cF5 > Free< / span > < span class = cF0 > (dup_counts);
< a name = "l452" > < / a > < / span > < span class = cF5 > Free< / span > < span class = cF0 > (day_counts);
< a name = "l453" > < / a > < / span > < span class = cF5 > Free< / span > < span class = cF0 > (day_dup_counts);
2021-07-03 05:07:57 +01:00
< a name = "l454" > < / a > }
< a name = "l455" > < / a >
< a name = "l456" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > FileRep(LogStruct *head, < / span > < span class = cF9 > CDate< / span > < span class = cF0 > dstart, < / span > < span class = cF9 > CDate< / span > < span class = cF0 > dend)
< a name = "l457" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l458" > < / a > LogStruct *tmplg = head-> next;
< a name = "l459" > < / a > LinkStruct *file_root = < / span > < span class = cF3 > NULL< / span > < span class = cF0 > ;
2021-07-03 05:07:57 +01:00
< a name = "l460" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l461" > < / a > < / span > < span class = cF1 > while< / span > < span class = cF0 > (tmplg != head)
< a name = "l462" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l463" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (IsKeeper< / span > < span class = cF7 > (< / span > < span class = cF0 > tmplg, dstart, dend< / span > < span class = cF7 > )< / span > < span class = cF0 > )
< a name = "l464" > < / a > FileTreeAdd(& file_root, tmplg);
< a name = "l465" > < / a > tmplg = tmplg-> next;
< a name = "l466" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l467" > < / a > < / span > < span class = cF6 > " \n\nFile Hits\n" < / span > < span class = cF0 > ;
< a name = "l468" > < / a > FileTreeTraverse(file_root);
< a name = "l469" > < / a > < / span > < span class = cF6 > '\n'< / span > < span class = cF0 > ;
< a name = "l470" > < / a > FileTreeDel(file_root);
2021-07-03 05:07:57 +01:00
< a name = "l471" > < / a > }
< a name = "l472" > < / a >
< a name = "l473" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > IndexRep(LogStruct *head, < / span > < span class = cF9 > CDate< / span > < span class = cF0 > dstart, < / span > < span class = cF9 > CDate< / span > < span class = cF0 > dend)
< a name = "l474" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l475" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > i, j, count, dups,
< a name = "l476" > < / a > hours_start, hours_end, *hour_counts, *dup_counts,
< a name = "l477" > < / a > days_start, days_end, *day_counts, *day_dup_counts;
< a name = "l478" > < / a > LogStruct *tmplg = head-> next, *dup_head = < / span > < span class = cF3 > NULL< / span > < span class = cF0 > ;
< a name = "l479" > < / a > LinkStruct *link_root = < / span > < span class = cF3 > NULL< / span > < span class = cF0 > ;
< a name = "l480" > < / a > < / span > < span class = cF9 > CDateStruct< / span > < span class = cF0 > ds;
2021-07-03 05:07:57 +01:00
< a name = "l481" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l482" > < / a > i = dstart * < / span > < span class = cFE > 24< / span > < span class = cF0 > ;
< a name = "l483" > < / a > hours_start = i.u32[< / span > < span class = cFE > 1< / span > < span class = cF0 > ];
< a name = "l484" > < / a > i = dend * < / span > < span class = cFE > 24< / span > < span class = cF0 > ;
< a name = "l485" > < / a > hours_end = i.u32[< / span > < span class = cFE > 1< / span > < span class = cF0 > ];
2021-07-03 05:07:57 +01:00
< a name = "l486" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l487" > < / a > days_start = (dstart + < / span > < span class = cFB > local_time_offset< / span > < span class = cF0 > ) > > < / span > < span class = cFE > 32< / span > < span class = cF0 > ;
< a name = "l488" > < / a > days_end = (dend + < / span > < span class = cFB > local_time_offset< / span > < span class = cF0 > ) > > < / span > < span class = cFE > 32< / span > < span class = cF0 > ;
2021-07-03 05:07:57 +01:00
< a name = "l489" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l490" > < / a > hour_counts = < / span > < span class = cF5 > CAlloc< / span > < span class = cF0 > (< / span > < span class = cF7 > (< / span > < span class = cF0 > hours_end - hours_start + < / span > < span class = cFE > 1< / span > < span class = cF7 > )< / span > < span class = cF0 > * < / span > < span class = cF1 > sizeof< / span > < span class = cF7 > (< / span > < span class = cF9 > I64< / span > < span class = cF7 > )< / span > < span class = cF0 > );
< a name = "l491" > < / a > dup_counts = < / span > < span class = cF5 > CAlloc< / span > < span class = cF0 > (< / span > < span class = cF7 > (< / span > < span class = cF0 > hours_end - hours_start + < / span > < span class = cFE > 1< / span > < span class = cF7 > )< / span > < span class = cF0 > * < / span > < span class = cF1 > sizeof< / span > < span class = cF7 > (< / span > < span class = cF9 > I64< / span > < span class = cF7 > )< / span > < span class = cF0 > );
< a name = "l492" > < / a > day_counts = < / span > < span class = cF5 > CAlloc< / span > < span class = cF0 > (< / span > < span class = cF7 > (< / span > < span class = cF0 > days_end - days_start + < / span > < span class = cFE > 1< / span > < span class = cF7 > )< / span > < span class = cF0 > * < / span > < span class = cF1 > sizeof< / span > < span class = cF7 > (< / span > < span class = cF9 > I64< / span > < span class = cF7 > )< / span > < span class = cF0 > );
< a name = "l493" > < / a > day_dup_counts = < / span > < span class = cF5 > CAlloc< / span > < span class = cF0 > (< / span > < span class = cF7 > (< / span > < span class = cF0 > days_end - days_start + < / span > < span class = cFE > 1< / span > < span class = cF7 > )< / span > < span class = cF0 > * < / span > < span class = cF1 > sizeof< / span > < span class = cF7 > (< / span > < span class = cF9 > I64< / span > < span class = cF7 > )< / span > < span class = cF0 > );
< a name = "l494" > < / a > dups = count = < / span > < span class = cFE > 0< / span > < span class = cF0 > ;
< a name = "l495" > < / a > < / span > < span class = cF1 > while< / span > < span class = cF0 > (tmplg != head)
< a name = "l496" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l497" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (IsKeeper< / span > < span class = cF7 > (< / span > < span class = cF0 > tmplg, dstart, dend< / span > < span class = cF7 > )< / span > < span class = cF0 > & & IsIndex< / span > < span class = cF7 > (< / span > < span class = cF0 > tmplg< / span > < span class = cF7 > )< / span > < span class = cF0 > )
< a name = "l498" > < / a > {
< a name = "l499" > < / a > i = tmplg-> datetime * < / span > < span class = cFE > 24< / span > < span class = cF0 > ;
< a name = "l500" > < / a > hour_counts[i.u32[< / span > < span class = cFE > 1< / span > < span class = cF0 > ] - hours_start]++;
< a name = "l501" > < / a > day_counts[(tmplg-> datetime + < / span > < span class = cFB > local_time_offset< / span > < span class = cF0 > ) > > < / span > < span class = cFE > 32< / span > < span class = cF0 > - days_start]++;
< a name = "l502" > < / a > count++;
< a name = "l503" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (IPNumTreeAdd< / span > < span class = cF7 > (< / span > < span class = cF0 > & dup_head, tmplg< / span > < span class = cF7 > )< / span > < span class = cF0 > )
< a name = "l504" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l505" > < / a > day_dup_counts[(tmplg-> datetime + < / span > < span class = cFB > local_time_offset< / span > < span class = cF0 > ) > > < / span > < span class = cFE > 32< / span > < span class = cF0 > - days_start]++;
< a name = "l506" > < / a > dup_counts[i.u32[< / span > < span class = cFE > 1< / span > < span class = cF0 > ] - hours_start]++;
< a name = "l507" > < / a > dups++;
< a name = "l508" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l509" > < / a > LinkTreeAdd(& link_root, tmplg);
< a name = "l510" > < / a > }
< a name = "l511" > < / a > tmplg = tmplg-> next;
< a name = "l512" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
2021-07-03 05:07:57 +01:00
< a name = "l513" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l514" > < / a > < / span > < span class = cF6 > " \n\nHits on /index.html\n" < / span > < span class = cF0 >
< a name = "l515" > < / a > < / span > < span class = cF6 > " '-' is a dup. '+' is not a dup.\n" < / span > < span class = cF0 > ;
< a name = "l516" > < / a > < / span > < span class = cF1 > for< / span > < span class = cF0 > (i = dstart; i < = dend; i += < / span > < span class = cFE > 1< / span > < span class = cF0 > < < < / span > < span class = cFE > 32< / span > < span class = cF0 > )
< a name = "l517" > < / a > < / span > < span class = cF6 > " %D Dups:%5d Total:%5d Uniques:%5d\n" < / span > < span class = cF0 > , i,
< a name = "l518" > < / a > day_dup_counts[(i + < / span > < span class = cFB > local_time_offset< / span > < span class = cF0 > ) > > < / span > < span class = cFE > 32< / span > < span class = cF0 > - days_start],
< a name = "l519" > < / a > day_counts[(i + < / span > < span class = cFB > local_time_offset< / span > < span class = cF0 > ) > > < / span > < span class = cFE > 32< / span > < span class = cF0 > - days_start],
< a name = "l520" > < / a > day_counts[(i + < / span > < span class = cFB > local_time_offset< / span > < span class = cF0 > ) > > < / span > < span class = cFE > 32< / span > < span class = cF0 > - days_start] - day_dup_counts[(i + < / span > < span class = cFB > local_time_offset< / span > < span class = cF0 > ) > > < / span > < span class = cFE > 32< / span > < span class = cF0 > - days_start];
2021-07-03 05:07:57 +01:00
< a name = "l521" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l522" > < / a > < / span > < span class = cF6 > " \n\nHits on /index.html\n" < / span > < span class = cF0 > ;
< a name = "l523" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (hours_end - hours_start > = HOURS_MAX)
< a name = "l524" > < / a > i = hours_end - HOURS_MAX + < / span > < span class = cFE > 1< / span > < span class = cF0 > ;
< a name = "l525" > < / a > < / span > < span class = cF1 > else< / span > < span class = cF0 >
< a name = "l526" > < / a > i = hours_start;
< a name = "l527" > < / a > < / span > < span class = cF1 > for< / span > < span class = cF0 > (; i < = hours_end; i++)
< a name = "l528" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l529" > < / a > < / span > < span class = cF5 > Date2Struct< / span > < span class = cF0 > (& ds, i < < < / span > < span class = cFE > 32< / span > < span class = cF0 > / < / span > < span class = cFE > 24< / span > < span class = cF0 > + < / span > < span class = cFB > local_time_offset< / span > < span class = cF0 > );
< a name = "l530" > < / a > < / span > < span class = cF6 > " %D %02d: " < / span > < span class = cF0 > , i < < < / span > < span class = cFE > 32< / span > < span class = cF0 > / < / span > < span class = cFE > 24< / span > < span class = cF0 > , ds.hour;
< a name = "l531" > < / a > < / span > < span class = cF1 > for< / span > < span class = cF0 > (j = < / span > < span class = cFE > 0< / span > < span class = cF0 > ; j < dup_counts[i - hours_start];j++)
< a name = "l532" > < / a > < / span > < span class = cF6 > '-'< / span > < span class = cF0 > ;
< a name = "l533" > < / a > < / span > < span class = cF1 > for< / span > < span class = cF0 > (; j < hour_counts[i - hours_start]; j++)
< a name = "l534" > < / a > < / span > < span class = cF6 > '+'< / span > < span class = cF0 > ;
< a name = "l535" > < / a > < / span > < span class = cF6 > '\n'< / span > < span class = cF0 > ;
< a name = "l536" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l537" > < / a > < / span > < span class = cF6 > " Total:%d Dups:%d Uniques:%d\n" < / span > < span class = cF0 > , count, dups, count - dups;
2021-07-03 05:07:57 +01:00
< a name = "l538" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l539" > < / a > < / span > < span class = cF6 > " \n\nHits on /index.html\n" < / span > < span class = cF0 > ;
< a name = "l540" > < / a > LinkTreeTraverse(link_root);
< a name = "l541" > < / a > < / span > < span class = cF6 > '\n'< / span > < span class = cF0 > ;
2021-07-03 05:07:57 +01:00
< a name = "l542" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l543" > < / a > LinkTreeDel(link_root);
< a name = "l544" > < / a > < / span > < span class = cF5 > Free< / span > < span class = cF0 > (hour_counts);
< a name = "l545" > < / a > < / span > < span class = cF5 > Free< / span > < span class = cF0 > (dup_counts);
< a name = "l546" > < / a > < / span > < span class = cF5 > Free< / span > < span class = cF0 > (day_counts);
< a name = "l547" > < / a > < / span > < span class = cF5 > Free< / span > < span class = cF0 > (day_dup_counts);
2021-07-03 05:07:57 +01:00
< a name = "l548" > < / a > }
< a name = "l549" > < / a >
< a name = "l550" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > WebLogRep(< / span > < span class = cF1 > U8< / span > < span class = cF0 > *mask, < / span > < span class = cF1 > U8< / span > < span class = cF0 > *output_filename)
< a name = "l551" > < / a > {
2021-07-04 23:11:34 +01:00
< a name = "l552" > < / a > LogStruct *head;
< a name = "l553" > < / a > < / span > < span class = cF9 > CDate< / span > < span class = cF0 > dstart = < / span > < span class = cF3 > I64_MAX< / span > < span class = cF0 > , dend = < / span > < span class = cF3 > I64_MIN< / span > < span class = cF0 > ;
2021-07-03 05:07:57 +01:00
< a name = "l554" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l555" > < / a > < / span > < span class = cF5 > DocMax< / span > < span class = cF0 > ;
2021-07-03 05:07:57 +01:00
< a name = "l556" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l557" > < / a > head = ParseLogFiles(mask, & dstart, & dend);
< a name = "l558" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (dstart > dend)
< a name = "l559" > < / a > < / span > < span class = cF5 > PrintErr< / span > < span class = cF0 > (< / span > < span class = cF6 > " No Data.\n" < / span > < span class = cF0 > );
< a name = "l560" > < / a > < / span > < span class = cF1 > else< / span > < span class = cF0 >
< a name = "l561" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l562" > < / a > dstart = < / span > < span class = cF5 > DateGet< / span > < span class = cF0 > (< / span > < span class = cF6 > " Start(%D):" < / span > < span class = cF0 > , dstart);
< a name = "l563" > < / a > dend = < / span > < span class = cF5 > DateGet< / span > < span class = cF0 > (< / span > < span class = cF6 > " End (%D):" < / span > < span class = cF0 > , dend);
< a name = "l564" > < / a > BlockIPNuip(head);
2021-07-03 05:07:57 +01:00
< a name = "l565" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l566" > < / a > < / span > < span class = cF5 > DocClear< / span > < span class = cF0 > ;
< a name = "l567" > < / a > < / span > < span class = cF6 > " $WW,0$" < / span > < span class = cF0 > ;
< a name = "l568" > < / a > IndexRep(head, dstart, dend);
< a name = "l569" > < / a > FileRep(head, dstart, dend);
< a name = "l570" > < / a > DownLoadRep(head, dstart, dend);
2021-07-03 05:07:57 +01:00
< a name = "l571" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l572" > < / a > < / span > < span class = cF5 > StrCopy< / span > < span class = cF0 > (< / span > < span class = cF5 > DocPut< / span > < span class = cF0 > -> filename.name, output_filename);
< a name = "l573" > < / a > < / span > < span class = cF5 > DocWrite< / span > < span class = cF0 > (< / span > < span class = cF5 > DocPut< / span > < span class = cF0 > , < / span > < span class = cF3 > TRUE< / span > < span class = cF0 > );
2021-07-03 05:07:57 +01:00
< a name = "l574" > < / a >
2021-07-04 23:11:34 +01:00
< a name = "l575" > < / a > < / span > < span class = cF6 > " $WW,1$" < / span > < span class = cF0 > ;
< a name = "l576" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l577" > < / a > LogListDel(head);
2021-07-03 05:07:57 +01:00
< a name = "l578" > < / a > }
< a name = "l579" > < / a >
< a name = "l580" > < / a > #< / span > < span class = cF1 > if< / span > < span class = cF0 > < / span > < span class = cF3 > __CMD_LINE__< / span > < span class = cF0 >
< a name = "l581" > < / a > < / span > < span class = cF5 > Cd< / span > < span class = cF0 > (< / span > < span class = cF3 > __DIR__< / span > < span class = cF0 > );;
< a name = "l582" > < / a > WebLogRep(< / span > < span class = cF6 > " *.log*" < / span > < span class = cF0 > , < / span > < span class = cF6 > " ~/DemoWebLog.DD" < / span > < span class = cF0 > );
< a name = "l583" > < / a > #< / span > < span class = cF1 > endif< / span > < span class = cF0 >
< / span > < / pre > < / body >
< / html >