From 6a231e4b414bc0fde02b4b6a66929302bd8ce6f6 Mon Sep 17 00:00:00 2001 From: John Arbash Meinel Date: Wed, 1 Feb 2012 09:27:49 +0100 Subject: [PATCH] Some updates to make the code compatible with VC 9 (2008) VC 9 doesn't support late variable declarations, and doesn't have inttypes so we need some direct definitions of a couple of more types. --- .gitignore | 4 +++- json_inttypes.h | 3 +++ json_object.c | 7 +++++-- json_util.c | 9 ++++++--- printbuf.c | 2 +- 5 files changed, 18 insertions(+), 7 deletions(-) diff --git a/.gitignore b/.gitignore index a4cab254b2..6acd8193eb 100644 --- a/.gitignore +++ b/.gitignore @@ -21,4 +21,6 @@ test1 test2 test4 testSubDir -test_parse_int64 \ No newline at end of file +test_parse_int64 +Debug +Release diff --git a/json_inttypes.h b/json_inttypes.h index 1cbafc21f4..1f3e4d2992 100644 --- a/json_inttypes.h +++ b/json_inttypes.h @@ -5,6 +5,9 @@ #if defined(_MSC_VER) && _MSC_VER < 1600 /* Anything less than Visual Studio C++ 10 is missing stdint.h and inttypes.h */ +typedef __int32 int32_t; +#define INT32_MIN ((int32_t)_I32_MIN) +#define INT32_MAX ((int32_t)_I32_MAX) typedef __int64 int64_t; #define PRId64 "I64d" #define SCNd64 "I64d" diff --git a/json_object.c b/json_object.c index bc09d658ee..65c1f6c08a 100644 --- a/json_object.c +++ b/json_object.c @@ -321,10 +321,13 @@ struct json_object* json_object_new_int(int32_t i) int32_t json_object_get_int(struct json_object *jso) { + int64_t cint64; + enum json_type o_type; + if(!jso) return 0; - enum json_type o_type = jso->o_type; - int64_t cint64 = jso->o.c_int64; + o_type = jso->o_type; + cint64 = jso->o.c_int64; if (o_type == json_type_string) { diff --git a/json_util.c b/json_util.c index dab3d8c957..c6db882ee9 100644 --- a/json_util.c +++ b/json_util.c @@ -130,13 +130,15 @@ int json_object_to_file(char *filename, struct json_object *obj) int json_parse_int64(const char *buf, int64_t *retval) { int64_t num64; + const char *buf_skip_space; + int orig_has_neg; if (sscanf(buf, "%" SCNd64, &num64) != 1) { MC_DEBUG("Failed to parse, sscanf != 1\n"); return 1; } - const char *buf_skip_space = buf; - int orig_has_neg = 0; + buf_skip_space = buf; + orig_has_neg = 0; // Skip leading spaces while (isspace((int)*buf_skip_space) && *buf_skip_space) buf_skip_space++; @@ -156,6 +158,7 @@ int json_parse_int64(const char *buf, int64_t *retval) char buf_cmp[100]; char *buf_cmp_start = buf_cmp; int recheck_has_neg = 0; + int buf_cmp_len; snprintf(buf_cmp_start, sizeof(buf_cmp), "%" PRId64, num64); if (*buf_cmp_start == '-') { @@ -164,7 +167,7 @@ int json_parse_int64(const char *buf, int64_t *retval) } // No need to skip leading spaces or zeros here. - int buf_cmp_len = strlen(buf_cmp_start); + buf_cmp_len = strlen(buf_cmp_start); /** * If the sign is different, or * some of the digits are different, or diff --git a/printbuf.c b/printbuf.c index 6ed1e94481..e8902c844b 100644 --- a/printbuf.c +++ b/printbuf.c @@ -65,7 +65,7 @@ int printbuf_memappend(struct printbuf *p, const char *buf, int size) return size; } -#if !HAVE_VSNPRINTF && defined(WIN32) +#if !HAVE_VSNPRINTF && defined(_MSC_VER) # define vsnprintf _vsnprintf #elif !HAVE_VSNPRINTF /* !HAVE_VSNPRINTF */ # error Need vsnprintf!