/** @brief Main client */
disorder_eclient *client;
+/** @brief Log client */
+disorder_eclient *logclient;
+
/** @brief Last reported state
*
* This is updated by log_state().
/** @brief True if a NOP is in flight */
static int nop_in_flight;
+/** @brief True if an rtp-address command is in flight */
+static int rtp_address_in_flight;
+
/** @brief Global tooltip group */
GtkTooltips *tips;
+/** @brief True if RTP play is available
+ *
+ * This is a bit of a bodge...
+ */
+int rtp_supported;
+
+/** @brief True if RTP play is enabled */
+int rtp_is_running;
+
+/** @brief Linked list of functions to call when we reset login parameters */
+static struct reset_callback_node {
+ struct reset_callback_node *next;
+ reset_callback *callback;
+} *resets;
+
/* Window creation --------------------------------------------------------- */
/* Note that all the client operations kicked off from here will only complete
nop_in_flight = 1;
disorder_eclient_nop(client, nop_completed, 0);
}
+ if(rtp_supported) {
+ const int old_state = rtp_is_running;
+ rtp_is_running = rtp_running();
+ if(old_state != rtp_is_running)
+ control_monitor(0);
+ }
return TRUE; /* keep call me please */
}
+/** @brief Called when a rtp-address command succeeds */
+static void got_rtp_address(void attribute((unused)) *v,
+ int attribute((unused)) nvec,
+ char attribute((unused)) **vec) {
+ rtp_address_in_flight = 0;
+ rtp_supported = 1;
+ rtp_is_running = rtp_running();
+ control_monitor(0);
+}
+
+/** @brief Called when a rtp-address command fails */
+static void no_rtp_address(struct callbackdata attribute((unused)) *cbd,
+ int attribute((unused)) code,
+ const char attribute((unused)) *msg) {
+ rtp_address_in_flight = 0;
+ rtp_supported = 0;
+ rtp_is_running = 0;
+ control_monitor(0);
+}
+
+/** @brief Called to check whether RTP play is available */
+static void check_rtp_address(void) {
+ if(!rtp_address_in_flight) {
+ struct callbackdata *const cbd = xmalloc(sizeof *cbd);
+ cbd->onerror = no_rtp_address;
+ disorder_eclient_rtp_address(client, got_rtp_address, cbd);
+ }
+}
+
/* main -------------------------------------------------------------------- */
static const struct option options[] = {
exit(0);
}
+/* reset state */
+void reset(void) {
+ struct reset_callback_node *r;
+
+ /* reset the clients */
+ disorder_eclient_close(client);
+ disorder_eclient_close(logclient);
+ rtp_supported = 0;
+ for(r = resets; r; r = r->next)
+ r->callback();
+ /* Might be a new server so re-check */
+ check_rtp_address();
+}
+
+/** @brief Register a reset callback */
+void register_reset(reset_callback *callback) {
+ struct reset_callback_node *const r = xmalloc(sizeof *r);
+
+ r->next = resets;
+ r->callback = callback;
+ resets = r;
+}
+
int main(int argc, char **argv) {
int n;
- disorder_eclient *logclient;
mem_init();
/* garbage-collect PCRE's memory */
maybe_send_nop,
0/*data*/,
0/*notify*/);
+ register_reset(properties_reset);
/* Start monitoring the log */
disorder_eclient_log(logclient, &log_callbacks, 0);
+ /* See if RTP play supported */
+ check_rtp_address();
D(("enter main loop"));
MTAG("misc");
g_main_loop_run(mainloop);