Babeltrace 2 C API 2.1.0
Open-source trace manipulation framework
|
Source, filter, and sink component classes (non-development).
A component class is the class of a component:
You can instantiate a given component class many times, with different initialization parameters, to create many components with the bt_graph_add_*_component*()
functions (see Graph).
There are two ways to obtain a component class:
Borrow one from a plugin.
Note that, as of Babeltrace 2.0, you cannot access a the plugin of component class, if any.
A component class is a shared object: get a new reference with bt_component_class_get_ref() and put an existing reference with bt_component_class_put_ref().
The common C type of a component class is bt_component_class.
There are three types of component classes:
A source component class instance (a source component) message iterator emits fresh messages.
The specific type of a source component class is bt_component_class_source and its type enumerator is BT_COMPONENT_CLASS_TYPE_SOURCE.
Upcast the bt_component_class_source type to the bt_component_class type with bt_component_class_source_as_component_class_const().
Get a new source component class reference with Use bt_component_class_source_get_ref() and put an existing one with bt_component_class_source_put_ref().
A filter component class instance (a filter component) message iterator emits fresh and transformed messages. It can also discard existing messages.
The specific type of a filter component class is bt_component_class_filter and its type enumerator is BT_COMPONENT_CLASS_TYPE_FILTER.
Upcast the bt_component_class_filter type to the bt_component_class type with bt_component_class_filter_as_component_class_const().
Get a new filter component class reference with bt_component_class_filter_get_ref() and put an existing one with bt_component_class_filter_put_ref().
A sink component class instance (a sink component) consumes messages from a source or filter message iterator.
The specific type of a filter component class is bt_component_class_sink and its type enumerator is BT_COMPONENT_CLASS_TYPE_SINK.
Upcast the bt_component_class_sink type to the bt_component_class type with bt_component_class_sink_as_component_class_const().
Get a new sink component class reference with bt_component_class_sink_get_ref() and put an existing one with bt_component_class_sink_put_ref().
Get the type enumerator of the class of a component with bt_component_class_get_type(). You can also use the bt_component_class_is_source(), bt_component_class_is_filter(), and bt_component_class_is_sink() helper functions.
A component class has the following common properties:
Name of the component class.
Within a plugin, for a given component class type, each component class has a unique name.
Get the name of a component class with bt_component_class_get_name().
Textual description of the component class.
Get the description of a component class with bt_component_class_get_description().
Help text of the component class.
Get the help text of a component class with bt_component_class_get_help().
Type query | |
enum | bt_component_class_type { BT_COMPONENT_CLASS_TYPE_SOURCE , BT_COMPONENT_CLASS_TYPE_FILTER , BT_COMPONENT_CLASS_TYPE_SINK } |
Component class type enumerators. More... | |
typedef enum bt_component_class_type | bt_component_class_type |
Component class type enumerators. | |
bt_component_class_type | bt_component_class_get_type (const bt_component_class *component_class) |
Returns the type enumerator of the component class component_class. | |
static bt_bool | bt_component_class_is_source (const bt_component_class *component_class) |
Returns whether or not the component class component_class is a source component class. | |
static bt_bool | bt_component_class_is_filter (const bt_component_class *component_class) |
Returns whether or not the component class component_class is a filter component class. | |
static bt_bool | bt_component_class_is_sink (const bt_component_class *component_class) |
Returns whether or not the component class component_class is a sink component class. | |
Types | |
typedef struct bt_component_class | bt_component_class |
Component class. | |
typedef struct bt_component_class_source | bt_component_class_source |
Source component class. | |
typedef struct bt_component_class_filter | bt_component_class_filter |
Filter component class. | |
typedef struct bt_component_class_sink | bt_component_class_sink |
Sink component class. | |
Properties | |
const char * | bt_component_class_get_name (const bt_component_class *component_class) |
Returns the name of the component class component_class. | |
const char * | bt_component_class_get_description (const bt_component_class *component_class) |
Returns the description of the component class component_class. | |
const char * | bt_component_class_get_help (const bt_component_class *component_class) |
Returns the help text of the component class component_class. | |
Common reference count | |
void | bt_component_class_get_ref (const bt_component_class *component_class) |
Increments the reference count of the component class component_class. | |
void | bt_component_class_put_ref (const bt_component_class *component_class) |
Decrements the reference count of the component class component_class. | |
#define | BT_COMPONENT_CLASS_PUT_REF_AND_RESET(_component_class) |
Decrements the reference count of the component class _component_class, and then sets _component_class to NULL . | |
#define | BT_COMPONENT_CLASS_MOVE_REF(_dst, _src) |
Decrements the reference count of the component class _dst, sets _dst to _src, and then sets _src to NULL . | |
Source component class upcast | |
static const bt_component_class * | bt_component_class_source_as_component_class_const (const bt_component_class_source *component_class) |
Upcasts the source component class component_class to the common bt_component_class type. | |
Source component class reference count | |
void | bt_component_class_source_get_ref (const bt_component_class_source *component_class) |
Increments the reference count of the source component class component_class. | |
void | bt_component_class_source_put_ref (const bt_component_class_source *component_class) |
Decrements the reference count of the source component class component_class. | |
#define | BT_COMPONENT_CLASS_SOURCE_PUT_REF_AND_RESET(_component_class) |
Decrements the reference count of the source component class _component_class, and then sets _component_class to NULL . | |
#define | BT_COMPONENT_CLASS_SOURCE_MOVE_REF(_dst, _src) |
Decrements the reference count of the source component class _dst, sets _dst to _src, and then sets _src to NULL . | |
Filter component class upcast | |
static const bt_component_class * | bt_component_class_filter_as_component_class_const (const bt_component_class_filter *component_class) |
Upcasts the filter component class component_class to the common bt_component_class type. | |
Filter component class reference count | |
void | bt_component_class_filter_get_ref (const bt_component_class_filter *component_class) |
Increments the reference count of the filter component class component_class. | |
void | bt_component_class_filter_put_ref (const bt_component_class_filter *component_class) |
Decrements the reference count of the filter component class component_class. | |
#define | BT_COMPONENT_CLASS_FILTER_PUT_REF_AND_RESET(_component_class) |
Decrements the reference count of the filter component class _component_class, and then sets _component_class to NULL . | |
#define | BT_COMPONENT_CLASS_FILTER_MOVE_REF(_dst, _src) |
Decrements the reference count of the filter component class _dst, setsc _dst to _src, and then sets _src to NULL . | |
Sink component class upcast | |
static const bt_component_class * | bt_component_class_sink_as_component_class_const (const bt_component_class_sink *component_class) |
Upcasts the sink component class component_class to the common bt_component_class type. | |
Sink component class reference count | |
void | bt_component_class_sink_get_ref (const bt_component_class_sink *component_class) |
Increments the reference count of the sink component class component_class. | |
void | bt_component_class_sink_put_ref (const bt_component_class_sink *component_class) |
Decrements the reference count of the sink component class component_class. | |
#define | BT_COMPONENT_CLASS_SINK_PUT_REF_AND_RESET(_component_class) |
Decrements the reference count of the sink component class _component_class, and then sets _component_class to NULL . | |
#define | BT_COMPONENT_CLASS_SINK_MOVE_REF(_dst, _src) |
Decrements the reference count of the sink component class _dst, sets _dst to _src, and then sets _src to NULL . | |
#define BT_COMPONENT_CLASS_PUT_REF_AND_RESET | ( | _component_class | ) |
Decrements the reference count of the component class _component_class, and then sets _component_class to NULL
.
_component_class | Component class of which to decrement the reference count. Can contain |
#define BT_COMPONENT_CLASS_MOVE_REF | ( | _dst, | |
_src ) |
Decrements the reference count of the component class _dst, sets _dst to _src, and then sets _src to NULL
.
This macro effectively moves a component class reference from the expression _src to the expression _dst, putting the existing _dst reference.
_dst | Destination expression. Can contain |
_src | Source expression. Can contain |
#define BT_COMPONENT_CLASS_SOURCE_PUT_REF_AND_RESET | ( | _component_class | ) |
Decrements the reference count of the source component class _component_class, and then sets _component_class to NULL
.
_component_class | Source component class of which to decrement the reference count. Can contain |
#define BT_COMPONENT_CLASS_SOURCE_MOVE_REF | ( | _dst, | |
_src ) |
Decrements the reference count of the source component class _dst, sets _dst to _src, and then sets _src to NULL
.
This macro effectively moves a source component class reference from the expression _src to the expression _dst, putting the existing _dst reference.
_dst | Destination expression. Can contain |
_src | Source expression. Can contain |
#define BT_COMPONENT_CLASS_FILTER_PUT_REF_AND_RESET | ( | _component_class | ) |
Decrements the reference count of the filter component class _component_class, and then sets _component_class to NULL
.
_component_class | Filter component class of which to decrement the reference count. Can contain |
#define BT_COMPONENT_CLASS_FILTER_MOVE_REF | ( | _dst, | |
_src ) |
Decrements the reference count of the filter component class _dst, setsc _dst to _src, and then sets _src to NULL
.
This macro effectively moves a filter component class reference from the expression _src to the expression _dst, putting the existing _dst reference.
_dst | Destination expression. Can contain |
_src | Source expression. Can contain |
#define BT_COMPONENT_CLASS_SINK_PUT_REF_AND_RESET | ( | _component_class | ) |
Decrements the reference count of the sink component class _component_class, and then sets _component_class to NULL
.
_component_class | Sink component class of which to decrement the reference count. Can contain |
#define BT_COMPONENT_CLASS_SINK_MOVE_REF | ( | _dst, | |
_src ) |
Decrements the reference count of the sink component class _dst, sets _dst to _src, and then sets _src to NULL
.
This macro effectively moves a sink component class reference from the expression _src to the expression _dst, putting the existing _dst reference.
_dst | Destination expression. Can contain |
_src | Source expression. Can contain |
|
extern |
Returns the type enumerator of the component class component_class.
[in] | component_class | Component class of which to get the type enumerator. |
NULL
.
|
inlinestatic |
Returns whether or not the component class component_class is a source component class.
[in] | component_class | Component class to check. |
NULL
.
|
inlinestatic |
Returns whether or not the component class component_class is a filter component class.
[in] | component_class | Component class to check. |
NULL
.
|
inlinestatic |
Returns whether or not the component class component_class is a sink component class.
[in] | component_class | Component class to check. |
NULL
.
|
extern |
Returns the name of the component class component_class.
See the name property.
[in] | component_class | Component class of which to get the name. |
Name of component_class.
The returned pointer remains valid as long as component_class exists.
NULL
.
|
extern |
Returns the description of the component class component_class.
See the description property.
[in] | component_class | Component class of which to get the description. |
Description of component_class, or NULL
if none.
The returned pointer remains valid as long as component_class exists.
NULL
.
|
extern |
Returns the help text of the component class component_class.
See the help text property.
[in] | component_class | Component class of which to get the help text. |
Help text of component_class, or NULL
if none.
The returned pointer remains valid as long as component_class exists.
NULL
.
|
extern |
Increments the reference count of the component class component_class.
[in] | component_class | Component class of which to increment the reference count. Can be |
|
extern |
Decrements the reference count of the component class component_class.
[in] | component_class | Component class of which to decrement the reference count. Can be |
|
inlinestatic |
Upcasts the source component class component_class to the common bt_component_class type.
[in] | component_class | Source component class to upcast. Can be |
|
extern |
Increments the reference count of the source component class component_class.
[in] | component_class | Source component class of which to increment the reference count. Can be |
|
extern |
Decrements the reference count of the source component class component_class.
[in] | component_class | Source component class of which to decrement the reference count. Can be |
|
inlinestatic |
Upcasts the filter component class component_class to the common bt_component_class type.
[in] | component_class | Filter component class to upcast. Can be |
|
extern |
Increments the reference count of the filter component class component_class.
[in] | component_class | Filter component class of which to increment the reference count. Can be |
|
extern |
Decrements the reference count of the filter component class component_class.
[in] | component_class | Filter component class of which to decrement the reference count. Can be |
|
inlinestatic |
Upcasts the sink component class component_class to the common bt_component_class type.
[in] | component_class | Sink component class to upcast. Can be |
|
extern |
Increments the reference count of the sink component class component_class.
[in] | component_class | Sink component class of which to increment the reference count. Can be |
|
extern |
Decrements the reference count of the sink component class component_class.
[in] | component_class | Sink component class of which to decrement the reference count. Can be |