summaryrefslogtreecommitdiff
blob: a49b589bf43b38adb67c7333daa6e687f342d7fe (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
/*
* Copyright (C) 2010 Robin H.Johnson, Ovechko Kostyantyn <fastinetserver@gmail.com>.
*
* Project: IDFetch.
* Developer: Ovechko Kostyantyn Olexandrovich (Kharkiv State Technical University of Construction and Architecture, Ukraine).
* Mentor: Robin H. Johnson (Gentoo Linux: Developer, Trustee & Infrastructure Lead).
* Mentoring organization: Gentoo Linux.
* Sponsored by GSOC 2010.
*
* This file is part of Segget.
*
* Segget is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* Segget is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with Segget; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/

#include "stats.h"

Tstats stats;

void Tstats::inc_dld_distfiles_count(){
	try{
		dld_distfiles_count++;
		if ((settings.del_pkg_list_when_dld_finished) and (dld_distfiles_count>distfiles_count)){
			//delete pkg.list file;
			if(remove((settings.pkg_list_dir+"/pkg.list").c_str()) != 0 )
				error_log("Error in stats.cpp: inc_dld_distfiles_count(): Can't delete:"+settings.pkg_list_dir+"/pkg.list");
			else
				debug(settings.pkg_list_dir+"/pkg.list"+" deleted" );
		}
	}catch(...){
		error_log("Error in stats.cpp: show_totals()");
	}
}

void Tstats::show_totals(){
	try{
		ulong show_last_time_interval=1;
		ulong show_total_size=1;
		if (last_time_interval>1)
			show_last_time_interval=last_time_interval;
		if (total_size>1)
			show_total_size=total_size;
		struct timeval now_timee;
		gettimeofday(&now_timee,NULL);
		string eta_str;
		if (avg_total_speed==0){
			eta_str=" ETA: inf";
		}else{
			eta_str=" ETA: "+secsToString((total_size-dld_size)/avg_total_speed);
		}

			string avg_speed_str=" AVG speed: "+speedToString(avg_total_speed);

		msg_total("Total CON:" 
			+field("",					active_connections_counter,2)+"/"
			+field("",					settings.max_connections,2)
//			+field(" PKGs:",			pkg_count,4)
//			+field(" = DFs:",			dld_distfiles_count,4)
			+" = DF:"+toString(dld_distfiles_count)
			+field("/",				distfiles_count,4)
			+" = Sg:"+toString(dld_segments_count)
			+field("/",				segments_count,5)
//			+field(" = Size:",			dld_size/1000,7)
			+" = Size:"+toString(dld_size/1000)
			+field("(",				((double)dld_size/show_total_size)*100,3)+"%)"
//			+field("/",				total_size/1000,7)+" Kb "
			+"/"+toString(total_size/1000)+"Kb"
			+" Total spd: "+speedToString(total_bytes_per_last_interval*1000/show_last_time_interval)
			+avg_speed_str
			+eta_str
		//			+" Secs:"+toString(now_timee.tv_sec)
		//			+" usecs:"+toString(now_timee.tv_usec)
			);
		reset_previous_time();
	}catch(...){
		error_log("Error in stats.cpp: show_totals()");
	}
}

void Tstats::reset_previous_time(){
	try{
		gettimeofday(&previous_time,NULL);
	}catch(...){
		error_log("Error in stats.cpp: reset_previous_time()");
	}
}