mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
CMake: Update jsoncpp to v1.8.4
This commit is contained in:
parent
2fae248dbe
commit
0b49fd3493
@ -1,6 +1,7 @@
|
|||||||
### 0.4.24 (unreleased)
|
### 0.4.24 (unreleased)
|
||||||
|
|
||||||
Features:
|
Features:
|
||||||
|
* Build System: Update internal dependency of jsoncpp to 1.8.4, which introduces more strictness and reduces memory usage.
|
||||||
* Optimizer: Remove unnecessary masking of the result of known short instructions (``ADDRESS``, ``CALLER``, ``ORIGIN`` and ``COINBASE``).
|
* Optimizer: Remove unnecessary masking of the result of known short instructions (``ADDRESS``, ``CALLER``, ``ORIGIN`` and ``COINBASE``).
|
||||||
* Type Checker: Make literals (without explicit type casting) an error for tight packing as experimental 0.5.0 feature.
|
* Type Checker: Make literals (without explicit type casting) an error for tight packing as experimental 0.5.0 feature.
|
||||||
|
|
||||||
|
@ -6,15 +6,9 @@ else()
|
|||||||
set(JSONCPP_CMAKE_COMMAND ${CMAKE_COMMAND})
|
set(JSONCPP_CMAKE_COMMAND ${CMAKE_COMMAND})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Disable implicit fallthrough warning in jsoncpp for gcc >= 7 until the upstream handles it properly
|
include(GNUInstallDirs)
|
||||||
if (("${CMAKE_CXX_COMPILER_ID}" MATCHES "GNU") AND CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 7.0)
|
|
||||||
set(JSONCCP_EXTRA_FLAGS -Wno-implicit-fallthrough)
|
|
||||||
else()
|
|
||||||
set(JSONCCP_EXTRA_FLAGS "")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
set(prefix "${CMAKE_BINARY_DIR}/deps")
|
set(prefix "${CMAKE_BINARY_DIR}/deps")
|
||||||
set(JSONCPP_LIBRARY "${prefix}/lib/${CMAKE_STATIC_LIBRARY_PREFIX}jsoncpp${CMAKE_STATIC_LIBRARY_SUFFIX}")
|
set(JSONCPP_LIBRARY "${prefix}/${CMAKE_INSTALL_LIBDIR}/${CMAKE_STATIC_LIBRARY_PREFIX}jsoncpp${CMAKE_STATIC_LIBRARY_SUFFIX}")
|
||||||
set(JSONCPP_INCLUDE_DIR "${prefix}/include")
|
set(JSONCPP_INCLUDE_DIR "${prefix}/include")
|
||||||
|
|
||||||
set(byproducts "")
|
set(byproducts "")
|
||||||
@ -25,9 +19,9 @@ endif()
|
|||||||
ExternalProject_Add(jsoncpp-project
|
ExternalProject_Add(jsoncpp-project
|
||||||
PREFIX "${prefix}"
|
PREFIX "${prefix}"
|
||||||
DOWNLOAD_DIR "${CMAKE_SOURCE_DIR}/deps/downloads"
|
DOWNLOAD_DIR "${CMAKE_SOURCE_DIR}/deps/downloads"
|
||||||
DOWNLOAD_NAME jsoncpp-1.7.7.tar.gz
|
DOWNLOAD_NAME jsoncpp-1.8.4.tar.gz
|
||||||
URL https://github.com/open-source-parsers/jsoncpp/archive/1.7.7.tar.gz
|
URL https://github.com/open-source-parsers/jsoncpp/archive/1.8.4.tar.gz
|
||||||
URL_HASH SHA256=087640ebcf7fbcfe8e2717a0b9528fff89c52fcf69fa2a18cc2b538008098f97
|
URL_HASH SHA256=c49deac9e0933bcb7044f08516861a2d560988540b23de2ac1ad443b219afdb6
|
||||||
CMAKE_COMMAND ${JSONCPP_CMAKE_COMMAND}
|
CMAKE_COMMAND ${JSONCPP_CMAKE_COMMAND}
|
||||||
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX=<INSTALL_DIR>
|
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX=<INSTALL_DIR>
|
||||||
-DCMAKE_C_COMPILER=${CMAKE_C_COMPILER}
|
-DCMAKE_C_COMPILER=${CMAKE_C_COMPILER}
|
||||||
|
@ -28,8 +28,8 @@
|
|||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
static_assert(
|
static_assert(
|
||||||
(JSONCPP_VERSION_MAJOR == 1) && (JSONCPP_VERSION_MINOR == 7) && (JSONCPP_VERSION_PATCH == 7),
|
(JSONCPP_VERSION_MAJOR == 1) && (JSONCPP_VERSION_MINOR == 8) && (JSONCPP_VERSION_PATCH == 4),
|
||||||
"Unexpected jsoncpp version: " JSONCPP_VERSION_STRING ". Expecting 1.7.7."
|
"Unexpected jsoncpp version: " JSONCPP_VERSION_STRING ". Expecting 1.8.4."
|
||||||
);
|
);
|
||||||
|
|
||||||
namespace dev
|
namespace dev
|
||||||
|
@ -32,7 +32,7 @@ REPO_ROOT="$(dirname "$0")"/..
|
|||||||
fi
|
fi
|
||||||
# Add dependencies
|
# Add dependencies
|
||||||
mkdir -p "$SOLDIR/deps/downloads/" 2>/dev/null || true
|
mkdir -p "$SOLDIR/deps/downloads/" 2>/dev/null || true
|
||||||
wget -O "$SOLDIR/deps/downloads/jsoncpp-1.7.7.tar.gz" https://github.com/open-source-parsers/jsoncpp/archive/1.7.7.tar.gz
|
wget -O "$SOLDIR/deps/downloads/jsoncpp-1.8.4.tar.gz" https://github.com/open-source-parsers/jsoncpp/archive/1.8.4.tar.gz
|
||||||
mkdir -p "$REPO_ROOT/upload"
|
mkdir -p "$REPO_ROOT/upload"
|
||||||
tar czf "$REPO_ROOT/upload/solidity_$versionstring.tar.gz" -C "$TEMPDIR" "solidity_$versionstring"
|
tar czf "$REPO_ROOT/upload/solidity_$versionstring.tar.gz" -C "$TEMPDIR" "solidity_$versionstring"
|
||||||
rm -r "$TEMPDIR"
|
rm -r "$TEMPDIR"
|
||||||
|
@ -76,7 +76,7 @@ mv solidity solc
|
|||||||
|
|
||||||
# Fetch jsoncpp dependency
|
# Fetch jsoncpp dependency
|
||||||
mkdir -p ./solc/deps/downloads/ 2>/dev/null || true
|
mkdir -p ./solc/deps/downloads/ 2>/dev/null || true
|
||||||
wget -O ./solc/deps/downloads/jsoncpp-1.7.7.tar.gz https://github.com/open-source-parsers/jsoncpp/archive/1.7.7.tar.gz
|
wget -O ./solc/deps/downloads/jsoncpp-1.8.4.tar.gz https://github.com/open-source-parsers/jsoncpp/archive/1.8.4.tar.gz
|
||||||
|
|
||||||
# Determine version
|
# Determine version
|
||||||
cd solc
|
cd solc
|
||||||
|
Loading…
Reference in New Issue
Block a user