|  |  |  | MateVFS - Filesystem Abstraction library | |
|---|---|---|---|---|
| Top | Description | ||||
| mate-vfs-module-callbackmate-vfs-module-callback — functions used by apps if they want to answer to callback invocations by mate-vfs modules | 
void (*MateVFSModuleCallback) (gconstpointer in,gsize in_size,gpointer out,gsize out_size,gpointer callback_data); void (*MateVFSModuleCallbackResponse) (gpointer response_data); void (*MateVFSAsyncModuleCallback) (gconstpointer in,gsize in_size,gpointer out,gsize out_size,gpointer callback_data,MateVFSModuleCallbackResponse response,gpointer response_data); void mate_vfs_module_callback_set_default (const char *callback_name,MateVFSModuleCallback callback,gpointer callback_data,GDestroyNotify destroy_notify); void mate_vfs_module_callback_push (const char *callback_name,MateVFSModuleCallback callback,gpointer callback_data,GDestroyNotify destroy_notify); void mate_vfs_module_callback_pop (const char *callback_name); void mate_vfs_async_module_callback_set_default (const char *callback_name,MateVFSAsyncModuleCallback callback,gpointer callback_data,GDestroyNotify destroy_notify); void mate_vfs_async_module_callback_push (const char *callback_name,MateVFSAsyncModuleCallback callback,gpointer callback_data,GDestroyNotify destroy_notify); void mate_vfs_async_module_callback_pop (const char *callback_name);
void (*MateVFSModuleCallback) (gconstpointer in,gsize in_size,gpointer out,gsize out_size,gpointer callback_data);
Modules use a MateVFSModuleCallback to send data to client applications and request data from them synchronously.
The format of in and out is determined by the callback name.
| 
 | data passed from module to application. | 
| 
 | size of inbytes. | 
| 
 | data passed from application to module. | 
| 
 | size of outin bytes. | 
| 
 | user data passed when connecting the callback. | 
void                (*MateVFSModuleCallbackResponse)   (gpointer response_data);
This is the type of the response function passed to a
MateVFSAsyncModuleCallback(). It should be called when the async
callback has completed.
| 
 | pass the response data argument originally passed to the async callback. | 
void (*MateVFSAsyncModuleCallback) (gconstpointer in,gsize in_size,gpointer out,gsize out_size,gpointer callback_data,MateVFSModuleCallbackResponse response,gpointer response_data);
Modules use a MateVFSModuleCallback to send data to client applications and request data from them asynchronously.
The application is expected to invoke the response with response_data
when it is able to satisfy the request.
The format of in and out is determined by the callback name.
| 
 | data passed from module to application. | 
| 
 | size of inbytes. | 
| 
 | data passed from application to module. | 
| 
 | size of outin bytes. | 
| 
 | user data passed when connecting the callback. | 
| 
 | MateVFSModuleCallbackResponse that must be invoked when the request is satisfied. | 
| 
 | data that must be passed to responsewhen the request is satisfied. | 
void mate_vfs_module_callback_set_default (const char *callback_name,MateVFSModuleCallback callback,gpointer callback_data,GDestroyNotify destroy_notify);
Set the default callback for callback_name to
callback. callback will be called with callback_data on the
same thread as the mate-vfs operation that invokes it. The default
value is shared for all threads, but setting it is thread-safe.
Use this function if you want to set a handler to be used by your
whole application. You can use mate_vfs_module_callback_push() to
set a callback function that will temporarily override the default
on the current thread instead. Or you can also use
mate_vfs_async_module_callback_set_default() to set an async
callback function.
Note: destroy_notify may be called on any thread - it is not
guaranteed to be called on the main thread.
| 
 | name of the module callback to set. | 
| 
 | function to call when the callbackis invoked. | 
| 
 | data to pass to callback. | 
| 
 | function to call when callback_datais to be freed. | 
void mate_vfs_module_callback_push (const char *callback_name,MateVFSModuleCallback callback,gpointer callback_data,GDestroyNotify destroy_notify);
Set callback as a temprary handler for callback_name. callback
will be called with callback_data on the same thread as the
mate-vfs operation that invokes it. The temporary handler is set
per-thread.
mate_vfs_module_callback_pop() removes the most recently set
temporary handler. The temporary handlers are treated as a first-in
first-out stack.
Use this function to set a temporary callback handler for a single
call or a few calls. You can use
mate_vfs_module_callback_set_default() to set a callback function
that will establish a permanent global setting for all threads
instead.
Note: destroy_notify may be called on any thread - it is not
guaranteed to be called on the main thread.
| 
 | name of the module callback to set temporarily. | 
| 
 | function to call when the callbackis invoked. | 
| 
 | data to pass to callback. | 
| 
 | function to call when callback_datais to be freed. | 
void                mate_vfs_module_callback_pop       (const char *callback_name);
| 
 | 
void mate_vfs_async_module_callback_set_default (const char *callback_name,MateVFSAsyncModuleCallback callback,gpointer callback_data,GDestroyNotify destroy_notify);
Set the default async callback for callback_name to
callback. callback will be called with callback_data
from a callback on the main thread. It will be passed a response
function which should be called to signal completion of the callback.
The callback function itself may return in the meantime.
The default value is shared for all threads, but setting it is thread-safe.
Use this function if you want to globally set a callback handler for use with async operations.
You can use mate_vfs_async_module_callback_push() to set an async
callback function that will temporarily override the default on the
current thread instead. Or you can also use
mate_vfs_module_callback_set_default() to set a regular callback
function.
Note: destroy_notify may be called on any thread - it is not
guaranteed to be called on the main thread.
| 
 | name of the async module callback to set. | 
| 
 | function to call when callbackis invoked. | 
| 
 | data to pass to callback. | 
| 
 | function to call when callback_datais to be freed. | 
void mate_vfs_async_module_callback_push (const char *callback_name,MateVFSAsyncModuleCallback callback,gpointer callback_data,GDestroyNotify destroy_notify);
Set callback as a temprary async handler for
callback_name. callback will be called with callback_data
from a callback on the main thread. It will be passed a response
function which should be called to signal completion of the
callback. The callback function itself may return in the meantime.
The temporary async handler is set per-thread.
mate_vfs_async_module_callback_pop() removes the most recently set
temporary handler. The temporary async handlers are
treated as a first-in first-out stack.
Use this function to set a temporary async callback handler for a
single call or a few calls. You can use
mate_vfs_async_module_callback_set_default() to set an async
callback function that will establish a permanent global setting
for all threads instead.
Note: destroy_notify may be called on any thread - it is not
guaranteed to be called on the main thread.
| 
 | name of the module callback to set temporarily. | 
| 
 | function to call when callbackis invoked. | 
| 
 | data to pass to callback. | 
| 
 | function to call when callback_datais to be freed. | 
void                mate_vfs_async_module_callback_pop (const char *callback_name);
Remove the temporary async handler for callback_name most recently
set with mate_vfs_async_module_callback_push().  If another
temporary async handler was previously set on the same thread, it
becomes the current handler. Otherwise, the default async handler,
if any, becomes current.
The temporary async handlers are treated as a first-in first-out stack.
| 
 | name of the module callback to remove a temporary handler for. |