Простое решение - сохранить список функций для вызова, а в обработчике сигналов просто выполнить итерацию по этому списку, вызывая каждую функцию.
Примерно так:
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
#include <unistd.h>
typedef void (*event_callback_t)();
struct event_handler_node
{
event_callback_t callback;
struct event_handler_node *next;
};
void add_event_handler(struct event_handler_node **list_head,
event_callback_t callback)
{
struct event_handler_node *node = malloc(sizeof(struct event_handler_node));
node->callback = callback;
if (*list_head != NULL)
node->next = *list_head;
*list_head = node;
}
void call_all_event_handlers(struct event_handler_node *list_head)
{
struct event_handler_node *node;
for (node = list_head; node != NULL; node = node->next)
{
(*node->callback)();
}
}
struct event_handler_node *signal_callbacks = NULL;
void signal_handler(int signum)
{
call_all_event_handlers(signal_callbacks);
}
void my_callback()
{
printf("Hello from callback!\n");
}
int main()
{
/* Add a callback to the list */
add_event_handler(&signal_callbacks, my_callback);
/* Set signal handler for a signal */
signal(SIGUSR1, signal_handler);
/* Invoke the signal handler */
kill(getpid(), SIGUSR1);
return 1;
}
Примечание: Нет обработки ошибок и освобождения выделенной памяти. Это оставлено в качестве упражнения для читателя. : -)