forked from osmocom/wireshark
775bbbcded
A while back Graham pointed out the SPDX project (spdx.org), which is working on standardizing license specifications: https://www.wireshark.org/lists/wireshark-dev/201509/msg00119.html Appendix V of the specification describes a short identifier (SPDX-License-Identifier) that you can use in place of boilerplate in your source files: https://spdx.org/spdx-specification-21-web-version#h.twlc0ztnng3b Start the conversion process with our top-level C and C++ files. Change-Id: Iba1d835776714deb6285e2181e8ca17f95221878 Reviewed-on: https://code.wireshark.org/review/24302 Reviewed-by: Gerald Combs <gerald@wireshark.org> Petri-Dish: Gerald Combs <gerald@wireshark.org> Reviewed-by: Balint Reczey <balint@balintreczey.hu> Tested-by: Petri Dish Buildbot Reviewed-by: Michael Mann <mmann78@netscape.net>
134 lines
3.8 KiB
C
134 lines
3.8 KiB
C
/* conditions.h
|
|
* Header for condition handler.
|
|
*
|
|
* Wireshark - Network traffic analyzer
|
|
* By Gerald Combs <gerald@wireshark.org>
|
|
* Copyright 1998 Gerald Combs
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0+
|
|
*/
|
|
|
|
#ifndef CONDITIONS_H
|
|
#define CONDITIONS_H
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <glib.h>
|
|
|
|
/* forward declaration for type 'condition' */
|
|
typedef struct condition condition;
|
|
|
|
/* condition evaluation handler type */
|
|
typedef gboolean (*_cnd_eval)(condition *, va_list);
|
|
|
|
/* condition reset handler type */
|
|
typedef void (*_cnd_reset)(condition *);
|
|
|
|
/* condition class constructor type */
|
|
typedef condition *(*_cnd_constr)(condition *, va_list);
|
|
|
|
/* condition class destructor type */
|
|
typedef void (*_cnd_destr)(condition *);
|
|
|
|
/*
|
|
* Conditions must be created with this function. They can be created for
|
|
* registered classes only.
|
|
*
|
|
* parameter: const char * - Identification of a registered condition class.
|
|
* ... - Any number of class specific initial values.
|
|
* returns: Pointer to a initialized condition of the particular class on
|
|
* success or NULL on failure.
|
|
*/
|
|
condition *cnd_new(const char *, ...);
|
|
|
|
/*
|
|
* Conditions must be deleted with this function when not used anymore.
|
|
*
|
|
* parameter: condition * - Pointer to a condition created with 'cnd_new()'.
|
|
* returns: -
|
|
*/
|
|
void cnd_delete(condition *);
|
|
|
|
/*
|
|
* Call this function to check whether or not a particular condition is true.
|
|
*
|
|
* parameter: condition * - Pointer to an initialized condition.
|
|
* ... - Any number of condition specific arguments.
|
|
* returns: TRUE - Condition is true.
|
|
* FALSE - Condition is false.
|
|
*/
|
|
gboolean cnd_eval(condition *, ...);
|
|
|
|
/*
|
|
* Call this function to reset this condition to its initial state, i.e. the
|
|
* state it was in right after creation.
|
|
*
|
|
* parameter: condition * - Pointer to an initialized condition.
|
|
* returns: -
|
|
*/
|
|
void cnd_reset(condition *);
|
|
|
|
/*
|
|
* Register a new conditon class.
|
|
* New conditions of this class can be created by calling 'cnd_new()' and
|
|
* supplying the appropriate class id.
|
|
*
|
|
* parameter: const char * - The class id.
|
|
* _cnd_constr - User supplied constructor function for this
|
|
* class.
|
|
* _cnd_destr - User supplied destructor function for this
|
|
* class.
|
|
* _cnd_eval - User supplied evaluation handler function for this
|
|
class.
|
|
* _cnd_reset - User supplied reset handler for this class.
|
|
* returns: TRUE - Success.
|
|
* FALSE - Failure.
|
|
*/
|
|
gboolean cnd_register_class(const char *,
|
|
_cnd_constr,
|
|
_cnd_destr,
|
|
_cnd_eval,
|
|
_cnd_reset);
|
|
|
|
/*
|
|
* Unregister a previously registered conditon class. After unregistration
|
|
* of a class it is no longer possible to create conditions of this kind by
|
|
* calling 'cnd_new()'.
|
|
*
|
|
* parameter: const char * - An identification for this condition class.
|
|
* returns: -
|
|
*/
|
|
void cnd_unregister_class(const char *);
|
|
|
|
/*
|
|
* This function returns the user data of the condition.
|
|
*
|
|
* parameter: condition * - Pointer to an initialized condition.
|
|
* returns: void * - Pointer to user data of this condition.
|
|
*/
|
|
void* cnd_get_user_data(condition*);
|
|
|
|
/*
|
|
* This function sets the user data of the condition.
|
|
*
|
|
* parameter: condition * - Pointer to an initialized condition.
|
|
* void * - Pointer to user specified data structure.
|
|
* returns: -
|
|
*/
|
|
void cnd_set_user_data(condition *, void *);
|
|
|
|
#endif /* CONDITIONS_H */
|
|
|
|
/*
|
|
* Editor modelines - http://www.wireshark.org/tools/modelines.html
|
|
*
|
|
* Local variables:
|
|
* c-basic-offset: 4
|
|
* tab-width: 8
|
|
* indent-tabs-mode: nil
|
|
* End:
|
|
*
|
|
* vi: set shiftwidth=4 tabstop=8 expandtab:
|
|
* :indentSize=4:tabSize=8:noTabs=true:
|
|
*/
|