PDI 1.7.1

the PDI data interface

pdi.h
1/*******************************************************************************
2* Copyright (C) 2015-2021 Commissariat a l'energie atomique et aux energies alternatives (CEA)
3* All rights reserved.
4*
5* Redistribution and use in source and binary forms, with or without
6* modification, are permitted provided that the following conditions are met:
7* * Redistributions of source code must retain the above copyright
8* notice, this list of conditions and the following disclaimer.
9* * Redistributions in binary form must reproduce the above copyright
10* notice, this list of conditions and the following disclaimer in the
11* documentation and/or other materials provided with the distribution.
12* * Neither the name of CEA nor the names of its contributors may be used to
13* endorse or promote products derived from this software without specific
14* prior written permission.
15*
16* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
22* THE SOFTWARE.
23******************************************************************************/
24
55#ifndef PDI_H_
56#define PDI_H_
57
58#include <paraconf.h>
59
60#include <pdi/export.h>
61#include <pdi/version.h>
62
63#ifdef __cplusplus
64extern "C" {
65#endif
66
73typedef enum PDI_status_e {
75 PDI_OK = 0,
96
98
104typedef void (*PDI_errfunc_f)(PDI_status_t status, const char* message, void* context);
105
108typedef struct PDI_errhandler_s {
111
113 void* context;
114
116
119extern const PDI_errhandler_t PDI_EXPORT PDI_ASSERT_HANDLER;
120
123extern const PDI_errhandler_t PDI_EXPORT PDI_WARN_HANDLER;
124
127extern const PDI_errhandler_t PDI_EXPORT PDI_NULL_HANDLER;
128
129
132const char PDI_EXPORT* PDI_errmsg(void);
133
142
144
156PDI_status_t PDI_EXPORT PDI_init(PC_tree_t conf);
157
161PDI_status_t PDI_EXPORT PDI_finalize(void);
162
170PDI_status_t PDI_EXPORT PDI_version(unsigned long* provided, unsigned long expected);
171
173
181typedef enum PDI_inout_e {
189 PDI_INOUT = 3
190
192
207PDI_status_t PDI_EXPORT PDI_share(const char* name, void* data, PDI_inout_t access);
208
217PDI_status_t PDI_EXPORT PDI_access(const char* name, void** buffer, PDI_inout_t inout);
218
226PDI_status_t PDI_EXPORT PDI_release(const char* name);
227
235PDI_status_t PDI_EXPORT PDI_reclaim(const char* name);
236
241PDI_status_t PDI_EXPORT PDI_event(const char* event);
242
250PDI_status_t PDI_EXPORT PDI_expose(const char* name, void* data, PDI_inout_t access);
251
267PDI_status_t PDI_EXPORT PDI_multi_expose(const char* event_name, const char* name, void* data, PDI_inout_t access, ...);
268
269#ifdef PDI_WITH_DEPRECATED
270
285PDI_status_t PDI_DEPRECATED_EXPORT PDI_transaction_begin(const char* name);
286
297PDI_status_t PDI_DEPRECATED_EXPORT PDI_transaction_end(void);
298
299#endif // PDI_WITH_DEPRECATED
300
302
303#ifdef __cplusplus
304} // extern C
305#endif
306
307
308#endif // PDI_H_
PDI_status_t PDI_release(const char *name)
Releases ownership of a data shared with PDI.
PDI_status_t PDI_share(const char *name, void *data, PDI_inout_t access)
Shares some data with PDI.
PDI_inout_t
Access directions.
Definition: pdi.h:181
PDI_status_t PDI_access(const char *name, void **buffer, PDI_inout_t inout)
Requests for PDI to access a data buffer.
PDI_status_t PDI_event(const char *event)
Triggers a PDI "event".
PDI_status_t PDI_expose(const char *name, void *data, PDI_inout_t access)
Shortly exposes some data to PDI.
PDI_status_t PDI_reclaim(const char *name)
Reclaims ownership of a data buffer shared with PDI.
PDI_status_t PDI_multi_expose(const char *event_name, const char *name, void *data, PDI_inout_t access,...)
Performs multiple exposes at once.
@ PDI_OUT
data transfer from the main code to PDI
Definition: pdi.h:187
@ PDI_INOUT
data transfer in both direction
Definition: pdi.h:189
@ PDI_IN
data tranfer from PDI to the main code
Definition: pdi.h:185
@ PDI_NONE
No data transfert.
Definition: pdi.h:183
PDI_errfunc_f func
The function to handle the error (none if NULL)
Definition: pdi.h:110
void * context
the context that will be provided to the function
Definition: pdi.h:113
PDI_errhandler_t PDI_errhandler(PDI_errhandler_t handler)
Sets the error handler to use.
const PDI_errhandler_t PDI_ASSERT_HANDLER
Prints the error message and aborts if the status is invalid.
const PDI_errhandler_t PDI_NULL_HANDLER
Does nothing.
PDI_status_t
Error codes of PDI.
Definition: pdi.h:73
const char * PDI_errmsg(void)
Return a human-readabe message describing the last error that occured in PDI.
const PDI_errhandler_t PDI_WARN_HANDLER
Prints the error message and continue if the status is invalid.
void(* PDI_errfunc_f)(PDI_status_t status, const char *message, void *context)
Type of a callback function used when an error occurs.
Definition: pdi.h:104
@ PDI_UNAVAILABLE
on an input call, no such data is available
Definition: pdi.h:77
@ PDI_ERR_VALUE
A value expression is invalid.
Definition: pdi.h:81
@ PDI_ERR_STATE
A call to a function has been made at a wrong time (e.g.
Definition: pdi.h:91
@ PDI_ERR_CONFIG
The configuration file is invalid.
Definition: pdi.h:79
@ PDI_OK
everything went well
Definition: pdi.h:75
@ PDI_ERR_TYPE
Invalid type error.
Definition: pdi.h:95
@ PDI_ERR_SYSTEM
A system error occured (OS, etc.)
Definition: pdi.h:87
@ PDI_ERR_IMPL
Implementation limitation (typically an unimplemented feature)
Definition: pdi.h:85
@ PDI_ERR_PLUGIN
Tried to load a non-existing plugin.
Definition: pdi.h:83
@ PDI_ERR_RIGHT
A conflict of onwership over a content has been raised.
Definition: pdi.h:93
Definition of an error handler.
Definition: pdi.h:108
PDI_status_t PDI_init(PC_tree_t conf)
Initializes PDI.
PDI_status_t PDI_finalize(void)
Finalizes PDI.
PDI_status_t PDI_version(unsigned long *provided, unsigned long expected)
Checks PDI API version.