From cd279e5075e066e70701778ffc817778d7932383 Mon Sep 17 00:00:00 2001 From: Luiz Augusto von Dentz Date: Thu, 30 May 2013 20:09:01 +0300 Subject: [PATCH] tools/bluetooth-player: Add play command Add support for play command which can be used to resume the playback --- tools/bluetooth-player.c | 41 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) diff --git a/tools/bluetooth-player.c b/tools/bluetooth-player.c index d691d6760..ec33c52bf 100644 --- a/tools/bluetooth-player.c +++ b/tools/bluetooth-player.c @@ -26,6 +26,7 @@ #endif #include +#include #include #include #include @@ -75,12 +76,52 @@ static void cmd_quit(int argc, char *argv[]) g_main_loop_quit(main_loop); } +static bool check_default_player(void) +{ + if (!default_player) { + rl_printf("No default player available\n"); + return FALSE; + } + + return TRUE; +} + +static void play_reply(DBusMessage *message, void *user_data) +{ + DBusError error; + + dbus_error_init(&error); + + if (dbus_set_error_from_message(&error, message) == TRUE) { + rl_printf("Failed to play: %s\n", error.name); + dbus_error_free(&error); + return; + } + + rl_printf("Play successful\n"); +} + +static void cmd_play(int argc, char *argv[]) +{ + if (!check_default_player()) + return; + + if (g_dbus_proxy_method_call(default_player, "Play", NULL, play_reply, + NULL, NULL) == FALSE) { + rl_printf("Failed to play\n"); + return; + } + + rl_printf("Attempting to play\n"); +} + static const struct { const char *cmd; const char *arg; void (*func) (int argc, char *argv[]); const char *desc; } cmd_table[] = { + { "play", NULL, cmd_play, "Start playback" }, { "quit", NULL, cmd_quit, "Quit program" }, { "exit", NULL, cmd_quit }, { "help" }, -- 2.11.0