Browse Source

Nicer build options.

cl-refactor
Gav Wood 10 years ago
parent
commit
4120e83bb6
  1. 187
      CMakeLists.txt
  2. 2
      test/CMakeLists.txt
  3. 2
      test/natspec.cpp

187
CMakeLists.txt

@ -15,23 +15,26 @@ list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake")
# Normally, set(...CACHE...) creates cache variables, but does not modify them. # Normally, set(...CACHE...) creates cache variables, but does not modify them.
function(createDefaultCacheConfig) function(createDefaultCacheConfig)
if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC") if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC")
set(SERPENT_DEFAULT OFF) set(DECENT_PLATFORM OFF)
else () else ()
set(SERPENT_DEFAULT ON) set(DECENT_PLATFORM ON)
endif () endif ()
set(HEADLESS OFF CACHE BOOL "Do not compile GUI (AlethZero)")
set(VMTRACE OFF CACHE BOOL "VM tracing and run-time checks (useful for cross-implementation VM debugging)") set(VMTRACE OFF CACHE BOOL "VM tracing and run-time checks (useful for cross-implementation VM debugging)")
set(PARANOIA OFF CACHE BOOL "Additional run-time checks") set(PARANOIA OFF CACHE BOOL "Additional run-time checks")
set(JSONRPC ON CACHE BOOL "Build with jsonprc. default on") set(JSONRPC ON CACHE BOOL "Build with jsonprc. default on")
set(EVMJIT OFF CACHE BOOL "Build a just-in-time compiler for EVM code (requires LLVM)")
set(FATDB OFF CACHE BOOL "Build with ability to list entries in the Trie. Doubles DB size, slows everything down, but good for looking at state diffs and trie contents.") set(FATDB OFF CACHE BOOL "Build with ability to list entries in the Trie. Doubles DB size, slows everything down, but good for looking at state diffs and trie contents.")
set(JUSTTESTS OFF CACHE BOOL "Build only for tests.")
set(SOLIDITY ON CACHE BOOL "Build the Solidity language components (required unless HEADLESS)")
set(SERPENT ${SERPENT_DEFAULT} CACHE BOOL "Build the Serpent language components (required unless HEADLESS)")
set(SDK ON CACHE BOOL "Build the SDK components")
set(USENPM OFF CACHE BOOL "Use npm to recompile ethereum.js if it was changed") set(USENPM OFF CACHE BOOL "Use npm to recompile ethereum.js if it was changed")
set(ETHASHCL OFF CACHE BOOL "Build in support for GPU mining via OpenCL")
set(PROFILING OFF CACHE BOOL "Build in support for profiling") set(PROFILING OFF CACHE BOOL "Build in support for profiling")
set(BUNDLE "full" CACHE STRING "Predefined bundle of software to build.")
set(SOLIDITY ON CACHE BOOL "Build the Solidity language components")
set(SERPENT ${DECENT_PLATFORM} CACHE BOOL "Build the Serpent language components")
set(TOOLS ON CACHE BOOL "Build the tools components")
set(NCURSES ${DECENT_PLATFORM} CACHE BOOL "Build the NCurses components")
set(GUI ON CACHE BOOL "Build GUI components (AlethZero, Mix)")
set(TESTS ON CACHE BOOL "Build the tests.")
set(EVMJIT OFF CACHE BOOL "Build just-in-time compiler for EVM code (requires LLVM)")
set(ETHASHCL OFF CACHE BOOL "Build in support for GPU mining via OpenCL")
endfunction() endfunction()
@ -61,8 +64,8 @@ function(configureProject)
add_definitions(-DETH_SOLIDITY) add_definitions(-DETH_SOLIDITY)
endif() endif()
if (HEADLESS OR JUSTTESTS) if (GUI)
add_definitions(-DETH_HEADLESS) add_definitions(-DETH_GUI)
endif() endif()
endfunction() endfunction()
@ -153,11 +156,6 @@ if (VMTRACE)
else () else ()
set(VMTRACE OFF) set(VMTRACE OFF)
endif () endif ()
if (ETHASHCL)
set(ETHASHCL ON)
else ()
set(ETHASHCL OFF)
endif()
if (EVMJIT) if (EVMJIT)
set(EVMJIT ON) set(EVMJIT ON)
else () else ()
@ -168,6 +166,23 @@ if (FATDB)
else () else ()
set(FATDB OFF) set(FATDB OFF)
endif() endif()
if (JSONRPC)
set(JSONRPC ON)
else ()
set(JSONRPC OFF)
endif ()
if (USENPM)
set(USENPM ON)
else ()
set(USENPM OFF)
endif ()
if (PROFILING)
set(PROFILING ON)
else ()
set(PROFILING OFF)
endif ()
if (SOLIDITY) if (SOLIDITY)
set(SOLIDITY ON) set(SOLIDITY ON)
else () else ()
@ -178,34 +193,66 @@ if (SERPENT)
else () else ()
set(SERPENT OFF) set(SERPENT OFF)
endif() endif()
if (HEADLESS) if (GUI)
set(HEADLESS ON) set(GUI ON)
else () else ()
set(HEADLESS OFF) set(GUI OFF)
endif () endif ()
if (JUSTTESTS) if (TESTS)
set(JUSTTESTS ON) set(TESTS ON)
else () else ()
set(JUSTTESTS OFF) set(TESTS OFF)
endif () endif ()
if (JSONRPC) if (TOOLS)
set(JSONRPC ON) set(TOOLS ON)
else () else ()
set(JSONRPC OFF) set(TOOLS OFF)
endif () endif ()
if (USENPM) if (ETHASHCL)
set(USENPM ON) set(ETHASHCL ON)
else () else ()
set(USENPM OFF) set(ETHASHCL OFF)
endif () endif()
if (PROFILING) if (NCURSES)
set(PROFILING ON) set(NCURSES ON)
else () else ()
set(PROFILING OFF) set(NCURSES OFF)
endif ()
if (BUNDLE STREQUAL "minimal")
set(SERPENT OFF)
set(SOLIDITY OFF)
set(USENPM OFF)
set(GUI OFF)
set(TESTS OFF)
set(TOOLS ON)
elseif (BUNDLE STREQUAL "full")
set(SERPENT ON)
set(SOLIDITY ON)
set(USENPM ON)
set(GUI ON)
set(TESTS ON)
set(TOOLS ON)
set(FATDB ON)
elseif (BUNDLE STREQUAL "tests")
set(SERPENT ON)
set(SOLIDITY ON)
set(USENPM OFF)
set(GUI OFF)
set(TESTS ON)
set(TOOLS OFF)
set(FATDB ON)
elseif (BUNDLE STREQUAL "user")
set(SERPENT OFF)
set(SOLIDITY OFF)
set(USENPM OFF)
set(GUI ON)
set(TESTS OFF)
set(TOOLS ON)
endif () endif ()
# Default CMAKE_BUILD_TYPE to "Release". # Default CMAKE_BUILD_TYPE to "Release".
set(CMAKE_BUILD_TYPE CACHE STRING "Relase") set(CMAKE_BUILD_TYPE CACHE STRING "Release")
if ("x${CMAKE_BUILD_TYPE}" STREQUAL "x") if ("x${CMAKE_BUILD_TYPE}" STREQUAL "x")
set(CMAKE_BUILD_TYPE "Release") set(CMAKE_BUILD_TYPE "Release")
endif () endif ()
@ -220,20 +267,23 @@ message("-----------------------------------------------------------------------
message("-- CMake Version ${CMAKE_VERSION}") message("-- CMake Version ${CMAKE_VERSION}")
message("-- Build type CMAKE_BUILD_TYPE ${CMAKE_BUILD_TYPE}") message("-- Build type CMAKE_BUILD_TYPE ${CMAKE_BUILD_TYPE}")
message("-- Target platform TARGET_PLATFORM ${TARGET_PLATFORM}") message("-- Target platform TARGET_PLATFORM ${TARGET_PLATFORM}")
message("-- Build bundle BUNDLE ${BUNDLE}")
message("------------------------------------------------------------------------ features")
message("-- Chromium support [auto-detected] ${ETH_HAVE_WEBENGINE}")
message("-- VM execution tracing VMTRACE ${VMTRACE}") message("-- VM execution tracing VMTRACE ${VMTRACE}")
message("-- Profiling support PROFILING ${PROFILING}") message("-- Profiling support PROFILING ${PROFILING}")
message("-- Additional (SLOW) database checking PARANOIA ${PARANOIA}") message("-- Additional (SLOW) database checking PARANOIA ${PARANOIA}")
message("-- Full database exploring FATDB ${FATDB}") message("-- Full database exploring FATDB ${FATDB}")
message("-- Build Javascript components from source USENPM ${USENPM}") message("-- JSON-RPC support JSONRPC ${JSONRPC}")
message("-- Build only headless components HEADLESS ${HEADLESS}") message("-- Javascript source building USENPM ${USENPM}")
message("-- Build only tests JUSTTESTS ${JUSTTESTS}") message("------------------------------------------------------------------------ components")
message("-- Build GUI components GUI ${GUI}")
message("-- Build NCurses components NCURSES ${NCURSES}")
message("-- Build tests TESTS ${TESTS}")
message("-- Build Solidity language components SOLIDITY ${SOLIDITY}") message("-- Build Solidity language components SOLIDITY ${SOLIDITY}")
message("-- Build Serpent language components SERPENT ${SERPENT}") message("-- Build Serpent language components SERPENT ${SERPENT}")
message("-- Build SDK components SDK ${SDK}") message("-- Build OpenCL components (experimental!) ETHASHCL ${ETHASHCL}")
message("-- Build OpenCL components ETHASHCL ${ETHASHCL}") message("-- Build LLVM-based JIT EVM (experimental!) EVMJIT ${EVMJIT}")
message("-- Build LLVM-based JIT EVM EVMJIT ${EVMJIT}")
message("-- Build with support for JSON-RPC JSONRPC ${JSONRPC}")
message("-- Build with support for Chromium ${ETH_HAVE_WEBENGINE}")
message("------------------------------------------------------------------------") message("------------------------------------------------------------------------")
message("") message("")
@ -261,18 +311,16 @@ add_subdirectory(libdevcore)
add_subdirectory(libevmcore) add_subdirectory(libevmcore)
add_subdirectory(liblll) add_subdirectory(liblll)
if (SDK) if (SERPENT)
if (SERPENT) add_subdirectory(libserpent)
add_subdirectory(libserpent) add_subdirectory(sc)
add_subdirectory(sc) endif ()
endif ()
if (SOLIDITY) if (SOLIDITY)
add_subdirectory(libsolidity) add_subdirectory(libsolidity)
endif ()
endif () endif ()
if (NOT JUSTTESTS) if (TOOLS)
add_subdirectory(lllc) add_subdirectory(lllc)
if (SOLIDITY) if (SOLIDITY)
add_subdirectory(solc) add_subdirectory(solc)
@ -297,12 +345,14 @@ endif ()
add_subdirectory(libethcore) add_subdirectory(libethcore)
add_subdirectory(libevm) add_subdirectory(libevm)
add_subdirectory(libethereum) add_subdirectory(libethereum)
add_subdirectory(libwebthree) add_subdirectory(libwebthree)
add_subdirectory(libtestutils)
add_subdirectory(test)
if (NOT JUSTTESTS) if (TESTS)
add_subdirectory(libtestutils)
add_subdirectory(test)
endif ()
if (TOOLS)
add_subdirectory(rlp) add_subdirectory(rlp)
add_subdirectory(abi) add_subdirectory(abi)
@ -312,27 +362,26 @@ if (NOT JUSTTESTS)
add_subdirectory(exp) add_subdirectory(exp)
endif () endif ()
# TODO check msvc endif()
if(NOT ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC"))
add_subdirectory(neth)
endif ()
if (NOT HEADLESS)
add_subdirectory(libnatspec) if (NCURSES)
add_subdirectory(libjsqrc) add_subdirectory(neth)
endif ()
if (ETH_HAVE_WEBENGINE) if (GUI)
add_subdirectory(alethzero)
# add_subdirectory(third) // reenable once not qtwebkit.
endif()
if (SDK) add_subdirectory(libnatspec)
add_subdirectory(mix) add_subdirectory(libjsqrc)
endif ()
if (ETH_HAVE_WEBENGINE)
add_subdirectory(alethzero)
# add_subdirectory(third) // reenable once not qtwebkit.
endif() endif()
if (SOLIDITY)
add_subdirectory(mix)
endif ()
endif() endif()
#unset(TARGET_PLATFORM CACHE) #unset(TARGET_PLATFORM CACHE)

2
test/CMakeLists.txt

@ -48,7 +48,7 @@ if (SOLIDITY)
target_link_libraries(testeth solidity) target_link_libraries(testeth solidity)
endif () endif ()
target_link_libraries(testeth testutils) target_link_libraries(testeth testutils)
if (NOT HEADLESS AND NOT JUSTTESTS) if (GUI AND NOT JUSTTESTS)
target_link_libraries(testeth webthree) target_link_libraries(testeth webthree)
target_link_libraries(testeth natspec) target_link_libraries(testeth natspec)
endif() endif()

2
test/natspec.cpp

@ -19,7 +19,7 @@
* @date 2015 * @date 2015
*/ */
#if !ETH_HEADLESS #if ETH_GUI
#include <boost/test/unit_test.hpp> #include <boost/test/unit_test.hpp>
#include <libdevcore/Log.h> #include <libdevcore/Log.h>

Loading…
Cancel
Save