| 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 |  | 
|---|