]> git.sesse.net Git - nbtscanner/blob - stats.c
Import nbtscanner 0.1.2.
[nbtscanner] / stats.c
1 /*
2  * nbtscanner -- a tool for scanning large networks for SMB servers.
3  *
4  * stats.c: Running statistics.
5  * Copyright (C) 2000 Steinar H. Gunderson
6  *
7  * Large amounts of code adapted from Samba (http://www.samba.org/)
8  * Copyright (C) Andrew Tridgell 1994-1998, and others.
9  *
10  * This program is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation; either version 2 of the License, or
13  * (at your option) any later version.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License
21  * along with this program; if not, write to the Free Software
22  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
23  */
24
25 #include "stats.h"
26 #include "configfile.h"
27 #include "util.h"
28
29 #include <stdio.h>
30 #include <sys/time.h>
31
32 int num_recv;
33 int num_recv_retries;
34 int num_failed;
35 int num_sent;
36 int num_sent_total;
37 enum statuses status;
38
39 struct timeval last_stats;
40
41 void init_stats()
42 {
43         num_recv = 0;
44         num_recv_retries = 0;
45         num_failed = 0;
46         num_sent = 0;
47         num_sent_total = 0;
48         status = SCANNING;
49
50         gettimeofday(&last_stats, NULL);
51 }
52
53 void print_stats(int force)
54 {
55         struct timeval now;
56
57         gettimeofday(&now, NULL);
58         if (verbosity >= 3 && (mydifftime(last_stats, now) > 1000 || force == 1)) {
59                 fprintf(stderr, "%s: Received %5u/%5u/%5u (%5u failed) (avg. "
60                                 "retries/succ.: %3.2f)\r",
61                         (status == SCANNING) ? "Scanning" : "Retrying",
62                         num_recv, num_sent, num_sent_total, num_failed, 
63                         (float)num_recv_retries / (float)num_recv);
64
65                 gettimeofday(&last_stats, NULL);
66         }
67 }
68