Skip to content

Commit

Permalink
Make default double serializer ignore userdata again
Browse files Browse the repository at this point in the history
The user might want to use the userdata for something different, so the
serializer should ignore it by default.

Explicitly setting the serializer to json_object_double_to_json_string will
still make it interpret the userdata as a format string.
  • Loading branch information
neocturne committed May 29, 2016
1 parent 7ae5c3f commit c2b004b
Show file tree
Hide file tree
Showing 6 changed files with 81 additions and 8 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@
/tests/test_parse
/tests/test_cast
/tests/test_charcase
/tests/test_double_serializer
/tests/test_locale
/tests/test_null
/tests/test_printbuf
Expand Down
34 changes: 27 additions & 7 deletions json_object.c
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@ static struct json_object* json_object_new(enum json_type o_type);

static json_object_to_json_string_fn json_object_object_to_json_string;
static json_object_to_json_string_fn json_object_boolean_to_json_string;
static json_object_to_json_string_fn json_object_double_to_json_string_default;
static json_object_to_json_string_fn json_object_int_to_json_string;
static json_object_to_json_string_fn json_object_string_to_json_string;
static json_object_to_json_string_fn json_object_array_to_json_string;
Expand Down Expand Up @@ -261,7 +262,7 @@ void json_object_set_serializer(json_object *jso,
jso->_to_json_string = &json_object_boolean_to_json_string;
break;
case json_type_double:
jso->_to_json_string = &json_object_double_to_json_string;
jso->_to_json_string = &json_object_double_to_json_string_default;
break;
case json_type_int:
jso->_to_json_string = &json_object_int_to_json_string;
Expand Down Expand Up @@ -643,10 +644,11 @@ int64_t json_object_get_int64(const struct json_object *jso)

/* json_object_double */

int json_object_double_to_json_string(struct json_object* jso,
struct printbuf *pb,
int level,
int flags)
static int json_object_double_to_json_string_format(struct json_object* jso,
struct printbuf *pb,
int level,
int flags,
const char *format)
{
char buf[128], *p, *q;
int size;
Expand All @@ -663,7 +665,7 @@ int json_object_double_to_json_string(struct json_object* jso,
size = snprintf(buf, sizeof(buf), "-Infinity");
else
size = snprintf(buf, sizeof(buf),
jso->_userdata ? (const char*) jso->_userdata : "%.17g", jso->o.c_double);
format ? format : "%.17g", jso->o.c_double);

p = strchr(buf, ',');
if (p) {
Expand All @@ -685,12 +687,30 @@ int json_object_double_to_json_string(struct json_object* jso,
return size;
}

static int json_object_double_to_json_string_default(struct json_object* jso,
struct printbuf *pb,
int level,
int flags)
{
return json_object_double_to_json_string_format(jso, pb, level, flags,
NULL);
}

int json_object_double_to_json_string(struct json_object* jso,
struct printbuf *pb,
int level,
int flags)
{
return json_object_double_to_json_string_format(jso, pb, level, flags,
jso->_userdata);
}

struct json_object* json_object_new_double(double d)
{
struct json_object *jso = json_object_new(json_type_double);
if (!jso)
return NULL;
jso->_to_json_string = &json_object_double_to_json_string;
jso->_to_json_string = &json_object_double_to_json_string_default;
jso->o.c_double = d;
return jso;
}
Expand Down
3 changes: 2 additions & 1 deletion tests/Makefile.am
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ TESTS+= testReplaceExisting.test
TESTS+= test_parse_int64.test
TESTS+= test_null.test
TESTS+= test_cast.test
TESTS+= test_double_serializer.test
TESTS+= test_parse.test
TESTS+= test_locale.test
TESTS+= test_charcase.test
Expand All @@ -22,7 +23,7 @@ check_PROGRAMS=
check_PROGRAMS += $(TESTS:.test=)

# Note: handled by test1.test
check_PROGRAMS += test1Formatted
check_PROGRAMS += test1Formatted
test1Formatted_SOURCES = test1.c parse_flags.c
test1Formatted_CPPFLAGS = -DTEST_FORMATTED

Expand Down
31 changes: 31 additions & 0 deletions tests/test_double_serializer.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
/*
* Tests if the format string for double serialization is handled correctly
*/

#include <stdio.h>
#include "config.h"

#include "json_object.h"
#include "json_object_private.h"

int main()
{
struct json_object *obj = json_object_new_double(0.5);

printf("Test default serializer:\n");
printf("obj.to_string(standard)=%s\n", json_object_to_json_string(obj));

printf("Test default serializer with custom userdata:\n");
obj->_userdata = "test";
printf("obj.to_string(userdata)=%s\n", json_object_to_json_string(obj));

printf("Test explicit serializer with custom userdata:\n");
json_object_set_serializer(obj, json_object_double_to_json_string, "test", NULL);
printf("obj.to_string(custom)=%s\n", json_object_to_json_string(obj));

printf("Test reset serializer:\n");
json_object_set_serializer(obj, NULL, NULL, NULL);
printf("obj.to_string(reset)=%s\n", json_object_to_json_string(obj));

json_object_put(obj);
}
8 changes: 8 additions & 0 deletions tests/test_double_serializer.expected
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
Test default serializer:
obj.to_string(standard)=0.5
Test default serializer with custom userdata:
obj.to_string(userdata)=0.5
Test explicit serializer with custom userdata:
obj.to_string(custom)=test
Test reset serializer:
obj.to_string(reset)=0.5
12 changes: 12 additions & 0 deletions tests/test_double_serializer.test
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
#!/bin/sh

# Common definitions
if test -z "$srcdir"; then
srcdir="${0%/*}"
test "$srcdir" = "$0" && srcdir=.
test -z "$srcdir" && srcdir=.
fi
. "$srcdir/test-defs.sh"

run_output_test test_double_serializer
exit $?

0 comments on commit c2b004b

Please sign in to comment.