2015-02-21 06:04:17 +01:00
|
|
|
|
|
|
|
#ifndef __LISTENER_H__
|
|
|
|
#define __LISTENER_H__
|
|
|
|
|
|
|
|
enum listener_event_type
|
|
|
|
{
|
2015-05-21 07:57:18 +02:00
|
|
|
/* The player has been started, stopped or seeked */
|
2015-05-18 20:12:18 +02:00
|
|
|
LISTENER_PLAYER = (1 << 0),
|
2017-01-08 00:24:40 +01:00
|
|
|
/* The current playback queue has been modified */
|
|
|
|
LISTENER_QUEUE = (1 << 1),
|
2015-05-21 07:57:18 +02:00
|
|
|
/* The volume has been changed */
|
2015-05-18 20:12:18 +02:00
|
|
|
LISTENER_VOLUME = (1 << 2),
|
2017-11-19 21:24:37 +01:00
|
|
|
/* Speaker status changes (enabled/disabled or verification status) */
|
2015-05-18 20:12:18 +02:00
|
|
|
LISTENER_SPEAKER = (1 << 3),
|
2015-05-21 07:57:18 +02:00
|
|
|
/* Options like repeat, random has been changed */
|
2015-05-18 20:12:18 +02:00
|
|
|
LISTENER_OPTIONS = (1 << 4),
|
2015-05-21 07:57:18 +02:00
|
|
|
/* The library has been modified */
|
2015-05-18 20:12:18 +02:00
|
|
|
LISTENER_DATABASE = (1 << 5),
|
2017-09-02 07:36:16 +02:00
|
|
|
/* A stored playlist has been modified (create, delete, add, rename) */
|
2017-08-09 18:19:20 +02:00
|
|
|
LISTENER_STORED_PLAYLIST = (1 << 6),
|
2017-08-06 17:39:32 +02:00
|
|
|
/* A library update has started or finished */
|
|
|
|
LISTENER_UPDATE = (1 << 7),
|
2017-08-16 21:32:46 +02:00
|
|
|
/* A pairing request has started or finished */
|
|
|
|
LISTENER_PAIRING = (1 << 8),
|
2017-08-26 09:16:27 +02:00
|
|
|
/* Spotify status changes (login, logout) */
|
|
|
|
LISTENER_SPOTIFY = (1 << 9),
|
2017-09-24 06:57:49 +02:00
|
|
|
/* Last.fm status changes (enable/disable scrobbling) */
|
|
|
|
LISTENER_LASTFM = (1 << 10),
|
2017-12-15 17:03:16 +01:00
|
|
|
/* Song rating changes */
|
|
|
|
LISTENER_RATING = (1 << 11),
|
2015-02-21 06:04:17 +01:00
|
|
|
};
|
|
|
|
|
2017-11-13 21:58:54 +01:00
|
|
|
typedef void (*notify)(short event_mask);
|
2015-02-21 06:04:17 +01:00
|
|
|
|
2015-05-21 07:57:18 +02:00
|
|
|
/*
|
|
|
|
* Registers the given callback function to the given event types.
|
|
|
|
* This function is not thread safe. Listeners must be added once at startup.
|
|
|
|
*
|
2020-05-24 20:26:18 +02:00
|
|
|
* @param notify_cb Callback function (should be a non-blocking function,
|
|
|
|
* especially when the event is from the player)
|
2017-11-13 21:58:54 +01:00
|
|
|
* @param event_mask Event mask, one or more of LISTENER_*
|
2015-05-21 07:57:18 +02:00
|
|
|
* @return 0 on success, -1 on failure
|
|
|
|
*/
|
2015-02-21 06:04:17 +01:00
|
|
|
int
|
2017-11-13 21:58:54 +01:00
|
|
|
listener_add(notify notify_cb, short event_mask);
|
2015-02-21 06:04:17 +01:00
|
|
|
|
2015-05-21 07:57:18 +02:00
|
|
|
/*
|
|
|
|
* Removes the given callback function
|
|
|
|
* This function is not thread safe. Listeners must be removed once at shutdown.
|
|
|
|
*
|
|
|
|
* @param notify_cb Callback function
|
|
|
|
* @return 0 on success, -1 if the callback was not registered
|
|
|
|
*/
|
2015-05-03 08:18:26 +02:00
|
|
|
int
|
|
|
|
listener_remove(notify notify_cb);
|
|
|
|
|
2015-05-21 07:57:18 +02:00
|
|
|
/*
|
|
|
|
* Calls the callback function of the registered listeners listening for the
|
|
|
|
* given type of event.
|
|
|
|
*
|
2020-05-24 20:26:18 +02:00
|
|
|
* @param event_mask Event mask, one or more of LISTENER_*
|
2015-05-21 07:57:18 +02:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
void
|
2020-05-24 20:26:18 +02:00
|
|
|
listener_notify(short event_mask);
|
2015-02-21 06:04:17 +01:00
|
|
|
|
|
|
|
#endif /* !__LISTENER_H__ */
|