Issue #195: use uselocale() instead of setlocale() in json_tokener to behave better in threaded environments.

This commit is contained in:
Eric Haszlakiewicz
2016-07-30 21:34:58 -04:00
parent 7d637362b7
commit 4091b9c87e
3 changed files with 45 additions and 11 deletions

View File

@@ -21,11 +21,22 @@ int main(int argc, char **argv)
printf("No locale\n");
#endif
char buf1[10], buf2[10];
// Should result in "0,1", if the locale is installed.
// Regardless of what it generates, we check that it's
// consistent below.
(void)snprintf(buf1, sizeof(buf1), "%f", 0.1);
MC_SET_DEBUG(1);
new_obj = json_tokener_parse("[1.2,3.4,123456.78,5.0,2.3e10]");
printf("new_obj.to_string()=%s\n", json_object_to_json_string(new_obj));
printf("new_obj.to_string()=%s\n", json_object_to_json_string_ext(new_obj,JSON_C_TO_STRING_NOZERO));
json_object_put(new_obj);
(void)snprintf(buf2, sizeof(buf2), "%f", 0.1);
if (strcmp(buf1, buf2) != 0)
printf("ERROR: Original locale not restored \"%s\" != \"%s\"",
buf1, buf2);
}