X-Git-Url: https://git.distorted.org.uk/~mdw/disorder/blobdiff_plain/c9467b7a34160c4e25580a2dc82087c5ae0bb2d0..19007e89957054b4af8667f85c0ec8d95f2001d6:/lib/eclient.c diff --git a/lib/eclient.c b/lib/eclient.c index 676aa06..ba743ec 100644 --- a/lib/eclient.c +++ b/lib/eclient.c @@ -440,7 +440,7 @@ void disorder_eclient_polled(disorder_eclient *c, unsigned mode) { /* Queue up a byte to send */ if(c->state == state_log && c->output.nvec == 0 - && time(&now) - c->last_prod > LOG_PROD_INTERVAL) { + && xtime(&now) - c->last_prod > LOG_PROD_INTERVAL) { put(c, "x", 1); c->last_prod = now; } @@ -1132,6 +1132,28 @@ int disorder_eclient_play(disorder_eclient *c, "play", track, (char *)0); } +int disorder_eclient_playafter(disorder_eclient *c, + const char *target, + int ntracks, + const char **tracks, + disorder_eclient_no_response *completed, + void *v) { + struct vector vec; + int n; + + if(!target) + target = ""; + vector_init(&vec); + vector_append(&vec, (char *)"playafter"); + vector_append(&vec, (char *)target); + for(n = 0; n < ntracks; ++n) + vector_append(&vec, (char *)tracks[n]); + stash_command_vector(c, 0/*queuejump*/, no_response_opcallback, completed, v, + -1, 0, vec.nvec, vec.vec); + disorder_eclient_polled(c, 0); + return 0; +} + int disorder_eclient_pause(disorder_eclient *c, disorder_eclient_no_response *completed, void *v) {