X-Git-Url: https://git.octo.it/?p=rrdtool.git;a=blobdiff_plain;f=src%2Frrd_last.c;h=7fb3cb884344f8c76119d9b7b7c860b092afbcc2;hp=996a6eb16b72ed9cb1b4d85d91140f23a6accead;hb=e5b05bec82bbff5db8add4e58dd6f0fcf2670291;hpb=ce30e9e1379022835687aa08b7712e27372e05ec diff --git a/src/rrd_last.c b/src/rrd_last.c index 996a6eb..7fb3cb8 100644 --- a/src/rrd_last.c +++ b/src/rrd_last.c @@ -1,5 +1,5 @@ /***************************************************************************** - * RRDtool 1.4.1 Copyright by Tobi Oetiker, 1997-2009 + * RRDtool 1.4.3 Copyright by Tobi Oetiker, 1997-2010 ***************************************************************************** * rrd_last.c ***************************************************************************** @@ -15,6 +15,8 @@ time_t rrd_last( { char *opt_daemon = NULL; int status; + time_t lastupdate; + int flushfirst = 1; optind = 0; opterr = 0; /* initialize getopt */ @@ -24,10 +26,11 @@ time_t rrd_last( int option_index = 0; static struct option long_options[] = { {"daemon", required_argument, 0, 'd'}, + {"noflush", no_argument, 0, 'F'}, {0, 0, 0, 0} }; - opt = getopt_long(argc, argv, "d:", long_options, &option_index); + opt = getopt_long(argc, argv, "d:F", long_options, &option_index); if (opt == EOF) break; @@ -44,8 +47,12 @@ time_t rrd_last( } break; + case 'F': + flushfirst = 0; + break; + default: - rrd_set_error ("Usage: rrdtool %s [--daemon ] ", + rrd_set_error ("Usage: rrdtool %s [--daemon [--noflush]] ", argv[0]); return (-1); break; @@ -53,16 +60,24 @@ time_t rrd_last( } /* while (42) */ if ((argc - optind) != 1) { - rrd_set_error ("Usage: rrdtool %s [--daemon ] ", + rrd_set_error ("Usage: rrdtool %s [--daemon [--noflush]] ", argv[0]); return (-1); } + if(flushfirst) { status = rrdc_flush_if_daemon(opt_daemon, argv[optind]); - if (opt_daemon) free(opt_daemon); if (status) return (-1); + } + + rrdc_connect (opt_daemon); + if (rrdc_is_connected (opt_daemon)) + lastupdate = rrdc_last (argv[optind]); + + else + lastupdate = rrd_last_r(argv[optind]); - return (rrd_last_r (argv[optind])); + return (lastupdate); } time_t rrd_last_r(