added gnutls backend and moved backend code into new files
[ircu2.10.12-pk.git] / include / s_stats.h
index 2298fa3c5cd0f7cc3062e26877009ed4c11c42db..417e5c2a2b7af4b10a7ccbd09c689e3f05858f99 100644 (file)
  * You should have received a copy of the GNU General Public License
  * along with this program; if not, write to the Free Software
  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- *
- * $Id$
+ */
+/** @file
+ * @brief Report configuration lines and other statistics from this server.
+ * @version $Id$
  */
 
 #ifndef INCLUDED_s_stats_h
@@ -32,27 +34,32 @@ struct Client;
 
 struct StatDesc;
 
-/* Source of /stats, stats descriptor, stats char, extra param (might be 0) */
-typedef void (*StatFunc)(struct Client *, struct StatDesc *, int, char *);
+/** Statistics callback function.
+ * @param[in] cptr Client requesting statistics.
+ * @param[in] sd Stats descriptor for request.
+ * @param[in] param Extra parameter from user (may be NULL).
+ */
+typedef void (*StatFunc)(struct Client *cptr, const struct StatDesc *sd, char *param);
 
+/** Statistics entry. */
 struct StatDesc
 {
-  char         sd_c;           /* stats character */
-  unsigned int sd_flags;       /* flags to control the stats */
-  enum Feature sd_control;     /* feature controlling stats */
-  StatFunc     sd_func;        /* function to dispatch to */
-  int          sd_funcdata;    /* extra data for the function */
-  char        *sd_desc;        /* descriptive text */
+  char         sd_c;           /**< stats character (or '\\0') */
+  char        *sd_name;        /**< full name for stats */
+  unsigned int sd_flags;       /**< flags to control the stats */
+  enum Feature sd_control;     /**< feature controlling stats */
+  StatFunc     sd_func;        /**< function to dispatch to */
+  int          sd_funcdata;    /**< extra data for the function */
+  char        *sd_desc;        /**< descriptive text */
 };
 
-#define STAT_FLAG_OPERONLY 0x01    /* Oper-only stat */
-#define STAT_FLAG_OPERFEAT 0x02    /* Oper-only if the feature is true */
-#define STAT_FLAG_CASESENS 0x04    /* Flag is case-sensitive */
-#define STAT_FLAG_VARPARAM 0x08    /* may have an extra parameter */
-
-extern struct StatDesc statsinfo[];
-extern struct StatDesc *statsmap[];
+#define STAT_FLAG_OPERONLY 0x01    /**< Oper-only stat */
+#define STAT_FLAG_OPERFEAT 0x02    /**< Oper-only if the feature is true */
+#define STAT_FLAG_LOCONLY  0x04    /**< Local user only */
+#define STAT_FLAG_CASESENS 0x08    /**< Flag is case-sensitive */
+#define STAT_FLAG_VARPARAM 0x10    /**< May have an extra parameter */
 
 extern void stats_init(void);
+const struct StatDesc *stats_find(const char *name_or_char);
 
 #endif /* INCLUDED_s_stats_h */