From: Luiz Augusto von Dentz <luiz.von.dentz@xxxxxxxxx> --- profiles/audio/player.c | 37 ++++++++++++++++++++++++++++++++++++- 1 file changed, 36 insertions(+), 1 deletion(-) diff --git a/profiles/audio/player.c b/profiles/audio/player.c index deae112..371487c 100644 --- a/profiles/audio/player.c +++ b/profiles/audio/player.c @@ -856,7 +856,42 @@ static struct media_folder *media_player_find_folder(struct media_player *mp, static DBusMessage *media_folder_change_folder(DBusConnection *conn, DBusMessage *msg, void *data) { - return btd_error_failed(msg, strerror(ENOTSUP)); + struct media_player *mp = data; + struct media_folder *folder = mp->scope; + struct player_callback *cb = mp->cb; + const char *path; + int err; + + if (!dbus_message_get_args(msg, NULL, + DBUS_TYPE_OBJECT_PATH, &path, + DBUS_TYPE_INVALID)) + return btd_error_failed(msg, strerror(EINVAL)); + + if (folder->msg != NULL) + return btd_error_failed(msg, strerror(EINVAL)); + + folder = media_player_find_folder(mp, path); + if (folder == NULL) + return btd_error_failed(msg, strerror(EINVAL)); + + if (mp->scope == folder) + goto done; + + if (folder == mp->playlist || folder == mp->folder) { + media_player_change_scope(mp, folder); + goto done; + } + + if (cb->cbs->change_folder == NULL) + return btd_error_failed(msg, strerror(ENOTSUP)); + + err = cb->cbs->change_folder(mp, folder->item->name, folder->item->uid, + cb->user_data); + if (err < 0) + return btd_error_failed(msg, strerror(-err)); + +done: + return g_dbus_create_reply(msg, DBUS_TYPE_INVALID); } static gboolean folder_name_exists(const GDBusPropertyTable *property, -- 1.8.1.4 -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html