PipeWire 1.0.7
Loading...
Searching...
No Matches
plugin.h
Go to the documentation of this file.
1/* Simple Plugin API */
2/* SPDX-FileCopyrightText: Copyright © 2018 Wim Taymans */
3/* SPDX-License-Identifier: MIT */
4
5#ifndef SPA_PLUGIN_H
6#define SPA_PLUGIN_H
7
8#ifdef __cplusplus
9extern "C" {
10#endif
11
12#include <spa/utils/defs.h>
13#include <spa/utils/dict.h>
14
25struct spa_handle {
27#define SPA_VERSION_HANDLE 0
28 uint32_t version;
29
43 int (*get_interface) (struct spa_handle *handle, const char *type, void **interface);
51 int (*clear) (struct spa_handle *handle);
52};
53
54#define spa_handle_get_interface(h,...) (h)->get_interface((h),__VA_ARGS__)
55#define spa_handle_clear(h) (h)->clear((h))
56
62 const char *type; /*< the type of the interface, can be
63 * used to get the interface */
64};
65
70struct spa_support {
71 const char *type; /*< the type of the support item */
72 void *data; /*< specific data for the item */
73};
74
76static inline void *spa_support_find(const struct spa_support *support,
77 uint32_t n_support,
78 const char *type)
79{
80 uint32_t i;
81 for (i = 0; i < n_support; i++) {
82 if (strcmp(support[i].type, type) == 0)
83 return support[i].data;
84 }
85 return NULL;
86}
87
88#define SPA_SUPPORT_INIT(type,data) ((struct spa_support) { (type), (data) })
89
90struct spa_handle_factory {
92#define SPA_VERSION_HANDLE_FACTORY 1
93 uint32_t version;
107 const char *name;
111 const struct spa_dict *info;
119 size_t (*get_size) (const struct spa_handle_factory *factory,
120 const struct spa_dict *params);
121
138 int (*init) (const struct spa_handle_factory *factory,
139 struct spa_handle *handle,
140 const struct spa_dict *info,
141 const struct spa_support *support,
142 uint32_t n_support);
143
156 int (*enum_interface_info) (const struct spa_handle_factory *factory,
157 const struct spa_interface_info **info,
158 uint32_t *index);
159};
160
161#define spa_handle_factory_get_size(h,...) (h)->get_size((h),__VA_ARGS__)
162#define spa_handle_factory_init(h,...) (h)->init((h),__VA_ARGS__)
163#define spa_handle_factory_enum_interface_info(h,...) (h)->enum_interface_info((h),__VA_ARGS__)
174typedef int (*spa_handle_factory_enum_func_t) (const struct spa_handle_factory **factory,
175 uint32_t *index);
176
177#define SPA_HANDLE_FACTORY_ENUM_FUNC_NAME "spa_handle_factory_enum"
178
188int spa_handle_factory_enum(const struct spa_handle_factory **factory, uint32_t *index);
189
190
191
192#define SPA_KEY_FACTORY_NAME "factory.name"
193#define SPA_KEY_FACTORY_AUTHOR "factory.author"
194#define SPA_KEY_FACTORY_DESCRIPTION "factory.description"
195#define SPA_KEY_FACTORY_USAGE "factory.usage"
197#define SPA_KEY_LIBRARY_NAME "library.name"
205#ifdef __cplusplus
206} /* extern "C" */
207#endif
209#endif /* SPA_PLUGIN_H */
spa/utils/defs.h
int(* spa_handle_factory_enum_func_t)(const struct spa_handle_factory **factory, uint32_t *index)
The function signature of the entry point in a plugin.
Definition plugin.h:182
static void * spa_support_find(const struct spa_support *support, uint32_t n_support, const char *type)
Find a support item of the given type.
Definition plugin.h:82
int spa_handle_factory_enum(const struct spa_handle_factory **factory, uint32_t *index)
The entry point in a plugin.
Definition dict.h:39
Definition plugin.h:97
int(* enum_interface_info)(const struct spa_handle_factory *factory, const struct spa_interface_info **info, uint32_t *index)
spa_handle_factory::enum_interface_info:
Definition plugin.h:164
uint32_t version
Definition plugin.h:101
const struct spa_dict * info
Extra information about the handles of this factory.
Definition plugin.h:119
size_t(* get_size)(const struct spa_handle_factory *factory, const struct spa_dict *params)
Get the size of handles from this factory.
Definition plugin.h:127
int(* init)(const struct spa_handle_factory *factory, struct spa_handle *handle, const struct spa_dict *info, const struct spa_support *support, uint32_t n_support)
Initialize an instance of this factory.
Definition plugin.h:146
Definition plugin.h:30
int(* get_interface)(struct spa_handle *handle, const char *type, void **interface)
Get the interface provided by handle with type.
Definition plugin.h:49
int(* clear)(struct spa_handle *handle)
Clean up the memory of handle.
Definition plugin.h:57
uint32_t version
Definition plugin.h:34
This structure lists the information about available interfaces on handles.
Definition plugin.h:67
const char * type
Definition plugin.h:68
Extra supporting infrastructure passed to the init() function of a factory.
Definition plugin.h:76
void * data
Definition plugin.h:78
const char * type
Definition plugin.h:77
spa/utils/dict.h