mirror of
https://github.com/fish-shell/fish-shell
synced 2024-11-14 08:58:01 +00:00
31 lines
994 B
C
31 lines
994 B
C
|
/** \file iothread.h
|
||
|
Handles IO that may hang.
|
||
|
*/
|
||
|
|
||
|
#ifndef FISH_IOTHREAD_H
|
||
|
#define FISH_IOTHREAD_H
|
||
|
|
||
|
/**
|
||
|
Runs a command on a thread.
|
||
|
|
||
|
\param handler The function to execute on a background thread. Accepts an arbitrary context pointer, and returns an int, which is passed to the completionCallback.
|
||
|
\param completionCallback The function to execute on the main thread once the background thread is complete. Accepts an int (the return value of handler) and the context.
|
||
|
\param context A arbitary context pointer to pass to the handler and completion callback.
|
||
|
\return A sequence number, currently not very useful.
|
||
|
*/
|
||
|
int iothread_perform(int (*handler)(void *), void (*completionCallback)(void *, int), void *context);
|
||
|
|
||
|
/**
|
||
|
Gets the fd on which to listen for completion callbacks.
|
||
|
|
||
|
\return A file descriptor on which to listen for completion callbacks.
|
||
|
*/
|
||
|
int iothread_port(void);
|
||
|
|
||
|
/**
|
||
|
Services one iothread competion callback.
|
||
|
*/
|
||
|
void iothread_service_completion(void);
|
||
|
|
||
|
#endif
|