From d809e9b8fc03a0a08060034c6ddbd4b4c4176399 Mon Sep 17 00:00:00 2001 From: Manuel Bachmann Date: Mon, 25 Jan 2016 14:48:02 +0100 Subject: [PATCH] Media Plugin list API now returns a JSON object We now return a JSON object instead of an arbitrary string with the "list" API. Signed-off-by: Manuel Bachmann --- plugins/media/media-rygel.c | 24 +++++++++++++++++++----- 1 file changed, 19 insertions(+), 5 deletions(-) diff --git a/plugins/media/media-rygel.c b/plugins/media/media-rygel.c index 9e94a9e7..be8cb96d 100644 --- a/plugins/media/media-rygel.c +++ b/plugins/media/media-rygel.c @@ -91,7 +91,8 @@ PUBLIC void _rygel_free (mediaCtxHandleT *ctx) { PUBLIC char* _rygel_list (mediaCtxHandleT *ctx) { dev_ctx_T *dev_ctx_c = (dev_ctx_T*)ctx->media_server; - char *raw, *start, *end, *title, *result = NULL; + json_object *json_o, *json_a; + char *raw, *start, *end, *id, *title; int length, i = 0; if (!dev_ctx_c) @@ -105,24 +106,37 @@ PUBLIC char* _rygel_list (mediaCtxHandleT *ctx) { if (!start) return NULL; - result = strdup(""); + json_o = json_object_new_object (); + json_a = json_object_new_array (); while (start) { + json_object *json_i, *json_id, *json_title; + start = strstr (start, ""); if (!start) break; end = strstr (start, ""); start += 10; length = end - start; + asprintf (&id, "%02d", i); + title = (char*) malloc (length+1); strncpy (title, start, length); title[length] = '\0'; - asprintf (&result, "%s%02d:%s::", result, i, title); + json_i = json_object_new_object (); + json_id = json_object_new_string (id); + json_title = json_object_new_string (title); + json_object_object_add (json_i, "id", json_id); + json_object_object_add (json_i, "title", json_title); + json_object_array_add (json_a, json_i); - free (title); i++; + free (id); free (title); + i++; } - return result; + json_object_object_add (json_o, "list", json_a); + + return (char*) json_object_to_json_string (json_o); } PUBLIC unsigned char _rygel_select (mediaCtxHandleT *ctx, unsigned int index) { -- 2.16.6