/*= -*- c-basic-offset: 4; indent-tabs-mode: nil; -*- * * $Id$ * * Copyright (C) 2000, 2001 by Martin Pool * * This program 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. * * This program 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 this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include #include #include #include #include #include #include #include "rsync.h" #include "trace.h" /* * TODO: Other things to show in statistics: * * Number of input and output bytes. * * Number of times we blocked waiting for input or output. * * Number of blocks. */ int rs_log_stats(rs_stats_t const *stats) { char buf[1000]; rs_format_stats(stats, buf, sizeof buf - 1); rs_log(HS_LOG_INFO, "%s", buf); return 0; } /** * \brief Return a human-readable representation of statistics. * * The string is truncated if it does not fit. 100 characters should * be sufficient space. * * \param stats Statistics from an encoding or decoding operation. * * \param buf Buffer to receive result. * \param size Size of buffer. * \return buf */ char * rs_format_stats(rs_stats_t const * stats, char *buf, size_t size) { char const *op = stats->op; int len; if (!op) op = "noop"; len = snprintf(buf, size, "%s ", op); if (stats->lit_cmds) { len += snprintf(buf+len, size-len, "literal[%d cmds, %d bytes] ", stats->lit_cmds, stats->lit_bytes); } if (stats->sig_cmds) { len += snprintf(buf+len, size-len, "signature[%d cmds, %d bytes] ", stats->sig_cmds, stats->sig_bytes); } if (stats->copy_cmds || stats->false_matches) { len += snprintf(buf+len, size-len, "copy[%d cmds, %d bytes, %d false]", stats->copy_cmds, stats->copy_bytes, stats->false_matches); } return buf; }