X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~mdw/git/disorder/blobdiff_plain/c9467b7a34160c4e25580a2dc82087c5ae0bb2d0..f4604d0d467ae510f8167d3109e6fd05f57f1cde:/server/disorder-server.h diff --git a/server/disorder-server.h b/server/disorder-server.h index 60e97df..7a6b73a 100644 --- a/server/disorder-server.h +++ b/server/disorder-server.h @@ -1,6 +1,6 @@ /* * This file is part of DisOrder - * Copyright (C) 2008, 2009 Richard Kettlewell + * Copyright (C) 2008-2012 Richard Kettlewell * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -134,10 +134,13 @@ void recent_write(void); /* write the recently played list out. Calls @fatal@ on error. */ struct queue_entry *queue_add(const char *track, const char *submitter, - int where, enum track_origin origin); + int where, const char *target, + enum track_origin origin); #define WHERE_START 0 /* Add to head of queue */ #define WHERE_END 1 /* Add to end of queue */ #define WHERE_BEFORE_RANDOM 2 /* End, or before random track */ +#define WHERE_AFTER 3 /* After the target */ +#define WHERE_NOWHERE 4 /* Don't add to queue at all */ /* add an entry to the queue. Return a pointer to the new entry. */ void queue_remove(struct queue_entry *q, const char *who); @@ -176,13 +179,16 @@ void play(ev_source *ev); /* try to play something, if playing is enabled and nothing is playing * already */ +/** @brief Return true if @p represents a true flag */ +int flag_enabled(const char *s); + int playing_is_enabled(void); /* return true iff playing is enabled */ void enable_playing(const char *who, ev_source *ev); /* enable playing */ -void disable_playing(const char *who); +void disable_playing(const char *who, ev_source *ev); /* disable playing. */ int random_is_enabled(void); @@ -191,7 +197,7 @@ int random_is_enabled(void); void enable_random(const char *who, ev_source *ev); /* enable random play */ -void disable_random(const char *who); +void disable_random(const char *who, ev_source *ev); /* disable random play */ void scratch(const char *who, const char *id); @@ -228,7 +234,8 @@ void add_random_track(ev_source *ev); int server_start(ev_source *ev, int pf, size_t socklen, const struct sockaddr *sa, - const char *name); + const char *name, + int privileged); /* start listening. Return the fd. */ int server_stop(ev_source *ev, int fd); @@ -342,8 +349,6 @@ struct pbgc_params { int argc; /** @brief Player command */ const char **argv; - /** @brief Device to wait for or NULL */ - const char *waitdevice; /** @brief Raw track name */ const char *rawpath; }; @@ -369,6 +374,11 @@ int play_background(ev_source *ev, #define START_HARDFAIL 1 /**< @brief Track is broken. */ #define START_SOFTFAIL 2 /**< @brief Track OK, system (temporarily?) broken */ +void periodic_mount_check(ev_source *ev_); + +/** @brief How often to check for new (or old) filesystems */ +# define MOUNT_CHECK_INTERVAL 5 /* seconds */ + #endif /* DISORDER_SERVER_H */ /*