mirror of
https://github.com/tristanpenman/valijson.git
synced 2025-01-21 02:00:34 +01:00
Fix build issues and compiler warnings with MSVC 2013
This commit is contained in:
parent
9b3779a57b
commit
9216f5f6f1
@ -1,6 +1,7 @@
|
|||||||
cmake_minimum_required (VERSION 2.6)
|
cmake_minimum_required (VERSION 2.6)
|
||||||
project (valijson)
|
project (valijson)
|
||||||
|
|
||||||
|
add_definitions(-DBOOST_ALL_DYN_LINK)
|
||||||
set(Boost_USE_STATIC_LIBS OFF)
|
set(Boost_USE_STATIC_LIBS OFF)
|
||||||
set(Boost_USE_MULTITHREADED ON)
|
set(Boost_USE_MULTITHREADED ON)
|
||||||
set(Boost_USE_STATIC_RUNTIME OFF)
|
set(Boost_USE_STATIC_RUNTIME OFF)
|
||||||
@ -15,6 +16,7 @@ add_library(jsoncpp
|
|||||||
)
|
)
|
||||||
|
|
||||||
# Build local gtest
|
# Build local gtest
|
||||||
|
set(gtest_force_shared_crt ON)
|
||||||
add_subdirectory(thirdparty/gtest-1.7.0)
|
add_subdirectory(thirdparty/gtest-1.7.0)
|
||||||
|
|
||||||
# Include path
|
# Include path
|
||||||
|
@ -132,7 +132,13 @@ inline AdapterType resolveJsonPointer(
|
|||||||
"out of bounds; actual token: " + referenceToken);
|
"out of bounds; actual token: " + referenceToken);
|
||||||
}
|
}
|
||||||
|
|
||||||
itr.advance(index);
|
if (index > std::numeric_limits<ptrdiff_t>::max()) {
|
||||||
|
throw std::runtime_error("Array index out of bounds; hard "
|
||||||
|
"limit is " + boost::lexical_cast<std::string>(
|
||||||
|
std::numeric_limits<ptrdiff_t>::max()));
|
||||||
|
}
|
||||||
|
|
||||||
|
itr.advance(static_cast<ptrdiff_t>(index));
|
||||||
|
|
||||||
// Recursively process the remaining tokens
|
// Recursively process the remaining tokens
|
||||||
return resolveJsonPointer(*itr, jsonPointer, jsonPointerNext);
|
return resolveJsonPointer(*itr, jsonPointer, jsonPointerNext);
|
||||||
|
@ -24,8 +24,13 @@ inline bool loadFile(const std::string &path, std::string &dest)
|
|||||||
|
|
||||||
// Allocate space for file contents
|
// Allocate space for file contents
|
||||||
file.seekg(0, std::ios::end);
|
file.seekg(0, std::ios::end);
|
||||||
|
const std::streamoff offset = file.tellg();
|
||||||
|
if (offset < 0 || offset > std::numeric_limits<unsigned int>::max()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
dest.clear();
|
dest.clear();
|
||||||
dest.reserve(file.tellg());
|
dest.reserve(static_cast<unsigned int>(offset));
|
||||||
|
|
||||||
// Assign file contents to destination string
|
// Assign file contents to destination string
|
||||||
file.seekg(0, std::ios::beg);
|
file.seekg(0, std::ios::beg);
|
||||||
|
@ -21,7 +21,7 @@ inline bool loadDocument(const std::string &path, Json::Value &document)
|
|||||||
bool parsingSuccessful = reader.parse(file, document);
|
bool parsingSuccessful = reader.parse(file, document);
|
||||||
if (!parsingSuccessful) {
|
if (!parsingSuccessful) {
|
||||||
std::cerr << "Jsoncpp parser failed to parse the document:" << std::endl
|
std::cerr << "Jsoncpp parser failed to parse the document:" << std::endl
|
||||||
<< reader.getFormatedErrorMessages();
|
<< reader.getFormattedErrorMessages();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7,10 +7,14 @@
|
|||||||
|
|
||||||
#include <boost/property_tree/ptree.hpp>
|
#include <boost/property_tree/ptree.hpp>
|
||||||
|
|
||||||
#pragma clang diagnostic push
|
#if defined(__clang__)
|
||||||
#pragma clang diagnostic ignored "-Wshorten-64-to-32"
|
# pragma clang diagnostic push
|
||||||
#include <boost/property_tree/json_parser.hpp>
|
# pragma clang diagnostic ignored "-Wshorten-64-to-32"
|
||||||
#pragma clang diagnostic pop
|
# include <boost/property_tree/json_parser.hpp>
|
||||||
|
# pragma clang diagnostic pop
|
||||||
|
#else
|
||||||
|
# include <boost/property_tree/json_parser.hpp>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <boost/property_tree/detail/json_parser_error.hpp>
|
#include <boost/property_tree/detail/json_parser_error.hpp>
|
||||||
|
|
||||||
|
@ -22,7 +22,7 @@ inline bool loadDocument(const std::string &path, rapidjson::Document &document)
|
|||||||
if (document.HasParseError()) {
|
if (document.HasParseError()) {
|
||||||
std::cerr << "RapidJson failed to parse the document:" << std::endl;
|
std::cerr << "RapidJson failed to parse the document:" << std::endl;
|
||||||
std::cerr << "Parse error: " << document.GetParseError() << std::endl;
|
std::cerr << "Parse error: " << document.GetParseError() << std::endl;
|
||||||
std::cerr << "Near: " << file.substr(std::max(size_t(0), document.GetErrorOffset() - 20), 40) << std::endl;
|
std::cerr << "Near: " << file.substr((std::max)(size_t(0), document.GetErrorOffset() - 20), 40) << std::endl;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -651,7 +651,7 @@ public:
|
|||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
d = i;
|
d = static_cast<double>(i);
|
||||||
} else {
|
} else {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user