1 | #ifndef foomainloopsignalhfoo |
2 | #define foomainloopsignalhfoo |
3 | |
4 | /*** |
5 | This file is part of PulseAudio. |
6 | |
7 | Copyright 2004-2008 Lennart Poettering |
8 | Copyright 2006 Pierre Ossman <ossman@cendio.se> for Cendio AB |
9 | |
10 | PulseAudio is free software; you can redistribute it and/or modify |
11 | it under the terms of the GNU Lesser General Public License as published |
12 | by the Free Software Foundation; either version 2.1 of the License, |
13 | or (at your option) any later version. |
14 | |
15 | PulseAudio is distributed in the hope that it will be useful, but |
16 | WITHOUT ANY WARRANTY; without even the implied warranty of |
17 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
18 | General Public License for more details. |
19 | |
20 | You should have received a copy of the GNU Lesser General Public License |
21 | along with PulseAudio; if not, see <http://www.gnu.org/licenses/>. |
22 | ***/ |
23 | |
24 | #include <pulse/mainloop-api.h> |
25 | #include <pulse/cdecl.h> |
26 | |
27 | PA_C_DECL_BEGIN |
28 | |
29 | /** \file |
30 | * UNIX signal support for main loops. In contrast to other |
31 | * main loop event sources such as timer and IO events, UNIX signal |
32 | * support requires modification of the global process |
33 | * environment. Due to this the generic main loop abstraction layer as |
34 | * defined in \ref mainloop-api.h doesn't have direct support for UNIX |
35 | * signals. However, you may hook signal support into an abstract main loop via the routines defined herein. |
36 | */ |
37 | |
38 | /** An opaque UNIX signal event source object */ |
39 | typedef struct pa_signal_event pa_signal_event; |
40 | |
41 | /** Callback prototype for signal events */ |
42 | typedef void (*pa_signal_cb_t) (pa_mainloop_api *api, pa_signal_event*e, int sig, void *userdata); |
43 | |
44 | /** Destroy callback prototype for signal events */ |
45 | typedef void (*pa_signal_destroy_cb_t) (pa_mainloop_api *api, pa_signal_event*e, void *userdata); |
46 | |
47 | /** Initialize the UNIX signal subsystem and bind it to the specified main loop */ |
48 | int pa_signal_init(pa_mainloop_api *api); |
49 | |
50 | /** Cleanup the signal subsystem */ |
51 | void pa_signal_done(void); |
52 | |
53 | /** Create a new UNIX signal event source object */ |
54 | pa_signal_event* pa_signal_new(int sig, pa_signal_cb_t callback, void *userdata); |
55 | |
56 | /** Free a UNIX signal event source object */ |
57 | void pa_signal_free(pa_signal_event *e); |
58 | |
59 | /** Set a function that is called when the signal event source is destroyed. Use this to free the userdata argument if required */ |
60 | void pa_signal_set_destroy(pa_signal_event *e, pa_signal_destroy_cb_t callback); |
61 | |
62 | PA_C_DECL_END |
63 | |
64 | #endif |
65 | |