forked from such-gitea/wownero
Compare commits
233 Commits
release-v0
...
release-v0
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
d184dc2f61 | ||
|
|
f786416ec3 | ||
|
|
71409e79e8 | ||
|
|
2ac0b34f9e | ||
|
|
6614678eee | ||
|
|
05e0624b81 | ||
|
|
466140f55e | ||
|
|
b4a39273d7 | ||
|
|
2c74551746 | ||
|
|
209c850471 | ||
|
|
c40ab9b5be | ||
|
|
ae681a9bb3 | ||
|
|
998bf82f24 | ||
|
|
0f61e39eea | ||
|
|
33743eb7ac | ||
|
|
46f3d3e975 | ||
|
|
2842f81b80 | ||
|
|
1b5cefac03 | ||
|
|
8fdd38c48c | ||
|
|
078c84ed72 | ||
|
|
99bf440290 | ||
|
|
4cec4db7f0 | ||
|
|
3b97d399b1 | ||
|
|
a23468af8c | ||
|
|
38c49b7a35 | ||
|
|
e4ddf841ee | ||
|
|
48b97fe5c7 | ||
|
|
9a99788660 | ||
|
|
c93ef4369c | ||
|
|
541c3b069a | ||
|
|
1ee249435e | ||
|
|
3f94fe0c4f | ||
|
|
af89312d24 | ||
|
|
6717051efd | ||
|
|
1d39aba9b8 | ||
|
|
8d5032a39f | ||
|
|
90e116ea3d | ||
|
|
5dfa3c1244 | ||
|
|
ca9ae12d5b | ||
|
|
dbaa1b9e68 | ||
|
|
28cdfd7c1c | ||
|
|
e7de8aa9dc | ||
|
|
9fb892adbe | ||
|
|
3553a9d8f5 | ||
|
|
2cc3960bfc | ||
|
|
0009b32f08 | ||
|
|
26ff420531 | ||
|
|
870b4138a6 | ||
|
|
683cde52f7 | ||
|
|
d498b2d791 | ||
|
|
df637cd08c | ||
|
|
46441d7c23 | ||
|
|
f82747320d | ||
|
|
d2ec59ca20 | ||
|
|
f44faf1b20 | ||
|
|
ff57e849d4 | ||
|
|
9e36058618 | ||
|
|
d658094761 | ||
|
|
d91f84f275 | ||
|
|
e51164f259 | ||
|
|
5a71ea66ef | ||
|
|
103ee1f2cc | ||
|
|
38b33944b5 | ||
|
|
b254539efb | ||
|
|
3ebc478967 | ||
|
|
31f9c9a3c9 | ||
|
|
9adc9b4a09 | ||
|
|
6c77e9e4ea | ||
|
|
cd0b5a1a4c | ||
|
|
31abdddd1b | ||
|
|
8746a9b379 | ||
|
|
de74b2590d | ||
|
|
32007ea554 | ||
|
|
e5bcff2def | ||
|
|
d52f27f568 | ||
|
|
84ca8550d2 | ||
|
|
2f4f8b1380 | ||
|
|
da885c041a | ||
|
|
37430e0a5b | ||
|
|
7bce433b89 | ||
|
|
f796a2dac4 | ||
|
|
111e25f10d | ||
|
|
dd2eca2126 | ||
|
|
4c5812b899 | ||
|
|
6ef6d5aa8b | ||
|
|
0b29a3e2c4 | ||
|
|
1f79072d19 | ||
|
|
c5d00f4e29 | ||
|
|
76a61ab006 | ||
|
|
9f9653cbc0 | ||
|
|
65940b75f7 | ||
|
|
0138a9a2b9 | ||
|
|
b0fda7c551 | ||
|
|
d50f2f5ac1 | ||
|
|
9a82e73e5d | ||
|
|
816c223a05 | ||
|
|
3c561f3bfc | ||
|
|
8cafa0bc1c | ||
|
|
dd280789cd | ||
|
|
fef9c01bb7 | ||
|
|
935831a7f9 | ||
|
|
d81e9178b8 | ||
|
|
d140d13603 | ||
|
|
87300a2f6a | ||
|
|
d41415ec48 | ||
|
|
4f8c3b771f | ||
|
|
7e339ea873 | ||
|
|
0acdc0fe0c | ||
|
|
35d09f896b | ||
|
|
64c7ced3ed | ||
|
|
e543d779d8 | ||
|
|
99533d4592 | ||
|
|
79d614652a | ||
|
|
59614f874a | ||
|
|
7ea53abfdf | ||
|
|
e3718d7c03 | ||
|
|
314e24d0ff | ||
|
|
fb3f6e723d | ||
|
|
ccaffcfbb5 | ||
|
|
6f53b0f14e | ||
|
|
b925e9417c | ||
|
|
b2cb640b11 | ||
|
|
3f4fc508ff | ||
|
|
c0691dfc25 | ||
|
|
1151ce6e6b | ||
|
|
880d14db91 | ||
|
|
d0953fb2b7 | ||
|
|
a9ef699472 | ||
|
|
bfd24d58c6 | ||
|
|
267e656d8b | ||
|
|
a17a81b3a7 | ||
|
|
e789d7c324 | ||
|
|
83072c2165 | ||
|
|
4411a412be | ||
|
|
2de45b2c0e | ||
|
|
2439d2a39d | ||
|
|
d85d908ddc | ||
|
|
6cbafa9dd9 | ||
|
|
842bcffbb8 | ||
|
|
c946a35985 | ||
|
|
41e12d4d29 | ||
|
|
c7d4338765 | ||
|
|
6c76c778e7 | ||
|
|
34daa571e3 | ||
|
|
70e4e4382e | ||
|
|
af2d19cf70 | ||
|
|
28477c75a3 | ||
|
|
f875a0312e | ||
|
|
0030100645 | ||
|
|
0c87b55670 | ||
|
|
70d90326a7 | ||
|
|
76c97e4dbc | ||
|
|
4422b14ac0 | ||
|
|
aad10a6cb0 | ||
|
|
ed5b588ca3 | ||
|
|
9eedf5f087 | ||
|
|
8ef2437e5d | ||
|
|
e2095e00ba | ||
|
|
b494943a10 | ||
|
|
d40acef20b | ||
|
|
36da8397f8 | ||
|
|
7bb6c00b5e | ||
|
|
f97b2edb3c | ||
|
|
1b0fe29ee3 | ||
|
|
c3fae517a4 | ||
|
|
442b30eee9 | ||
|
|
8f7add0a05 | ||
|
|
e1355ecd3e | ||
|
|
a44d54645e | ||
|
|
be87172237 | ||
|
|
4bd63dab9d | ||
|
|
a121320fc9 | ||
|
|
10d79d1848 | ||
|
|
9736a0a8b9 | ||
|
|
0ad6583329 | ||
|
|
636ffdc7a1 | ||
|
|
e55621dbd2 | ||
|
|
88735bd65b | ||
|
|
47f0f9b3f4 | ||
|
|
ecaf564d38 | ||
|
|
0ef925d131 | ||
|
|
0a1ca3a329 | ||
|
|
bdf6f05418 | ||
|
|
31a47b6638 | ||
|
|
76c2cb0771 | ||
|
|
9427077649 | ||
|
|
40d658a327 | ||
|
|
6c204bba0a | ||
|
|
4ba5309da0 | ||
|
|
751c6beca2 | ||
|
|
cf94656674 | ||
|
|
d984bd95d7 | ||
|
|
23b1e28b8d | ||
|
|
e33ff94cc0 | ||
|
|
e94ca47010 | ||
|
|
929e210ad2 | ||
|
|
9f2ea08a8e | ||
|
|
50fea66409 | ||
|
|
61d21bd236 | ||
|
|
ec18a0df32 | ||
|
|
2b66b27fe5 | ||
|
|
98031957e1 | ||
|
|
2d759a17a8 | ||
|
|
92f7de3d62 | ||
|
|
c786fb5a13 | ||
|
|
2e6174addd | ||
|
|
afc77b45ba | ||
|
|
48ef3ff466 | ||
|
|
e011f7ac47 | ||
|
|
1a8353dd90 | ||
|
|
28100fbd68 | ||
|
|
389d2bc53e | ||
|
|
79d38f3bdd | ||
|
|
8e428f8ef6 | ||
|
|
27c0af7295 | ||
|
|
7ae7796866 | ||
|
|
1104a17246 | ||
|
|
72904ee107 | ||
|
|
65d056aeae | ||
|
|
fbc506b1f5 | ||
|
|
54040da1a1 | ||
|
|
10b7f2b45f | ||
|
|
7759d52a25 | ||
|
|
5bf7ce14c5 | ||
|
|
7e93cdba07 | ||
|
|
c9bec32aa0 | ||
|
|
76c7878dea | ||
|
|
57e8fce462 | ||
|
|
b58f12e53e | ||
|
|
8ac7ba7d99 | ||
|
|
d9649d98cd | ||
|
|
61f3a191df | ||
|
|
675b879844 |
@@ -23,9 +23,9 @@ env:
|
|||||||
- DOCKER_PACKAGES="build-essential libtool cmake autotools-dev automake pkg-config bsdmainutils curl git ca-certificates ccache"
|
- DOCKER_PACKAGES="build-essential libtool cmake autotools-dev automake pkg-config bsdmainutils curl git ca-certificates ccache"
|
||||||
matrix:
|
matrix:
|
||||||
# ARM v7
|
# ARM v7
|
||||||
- HOST=arm-linux-gnueabihf PACKAGES="gperf g++-arm-linux-gnueabihf"
|
- HOST=arm-linux-gnueabihf PACKAGES="python3 gperf g++-arm-linux-gnueabihf"
|
||||||
# ARM v8
|
# ARM v8
|
||||||
- HOST=aarch64-linux-gnu PACKAGES="gperf g++-aarch64-linux-gnu"
|
- HOST=aarch64-linux-gnu PACKAGES="python3 gperf g++-aarch64-linux-gnu"
|
||||||
# i686 Win
|
# i686 Win
|
||||||
- HOST=i686-w64-mingw32 PACKAGES="python3 nsis g++-mingw-w64-i686"
|
- HOST=i686-w64-mingw32 PACKAGES="python3 nsis g++-mingw-w64-i686"
|
||||||
# i686 Linux
|
# i686 Linux
|
||||||
@@ -33,7 +33,7 @@ env:
|
|||||||
# Win64
|
# Win64
|
||||||
- HOST=x86_64-w64-mingw32 PACKAGES="cmake python3 nsis g++-mingw-w64-x86-64 wine-binfmt wine64 bc" RUN_TESTS=true
|
- HOST=x86_64-w64-mingw32 PACKAGES="cmake python3 nsis g++-mingw-w64-x86-64 wine-binfmt wine64 bc" RUN_TESTS=true
|
||||||
# x86_64 Linux
|
# x86_64 Linux
|
||||||
- HOST=x86_64-unknown-linux-gnu PACKAGES="gperf cmake python3-zmq protobuf-compiler libdbus-1-dev libharfbuzz-dev libprotobuf-dev" RUN_TESTS=true
|
- HOST=x86_64-unknown-linux-gnu PACKAGES="gperf cmake python3-zmq libdbus-1-dev libharfbuzz-dev" RUN_TESTS=true
|
||||||
# Cross-Mac
|
# Cross-Mac
|
||||||
- HOST=x86_64-apple-darwin11 PACKAGES="cmake imagemagick libcap-dev librsvg2-bin libz-dev libbz2-dev libtiff-tools python-dev python3-setuptools-git" OSX_SDK=10.11
|
- HOST=x86_64-apple-darwin11 PACKAGES="cmake imagemagick libcap-dev librsvg2-bin libz-dev libbz2-dev libtiff-tools python-dev python3-setuptools-git" OSX_SDK=10.11
|
||||||
|
|
||||||
@@ -52,6 +52,7 @@ before_script:
|
|||||||
- if [ -n "$OSX_SDK" -a ! -f contrib/depends/sdk-sources/MacOSX${OSX_SDK}.sdk.tar.gz ]; then curl --location --fail $SDK_URL/MacOSX${OSX_SDK}.sdk.tar.gz -o contrib/depends/sdk-sources/MacOSX${OSX_SDK}.sdk.tar.gz; fi
|
- if [ -n "$OSX_SDK" -a ! -f contrib/depends/sdk-sources/MacOSX${OSX_SDK}.sdk.tar.gz ]; then curl --location --fail $SDK_URL/MacOSX${OSX_SDK}.sdk.tar.gz -o contrib/depends/sdk-sources/MacOSX${OSX_SDK}.sdk.tar.gz; fi
|
||||||
- if [ -n "$OSX_SDK" -a -f contrib/depends/sdk-sources/MacOSX${OSX_SDK}.sdk.tar.gz ]; then tar -C contrib/depends/SDKs -xf contrib/depends/sdk-sources/MacOSX${OSX_SDK}.sdk.tar.gz; fi
|
- if [ -n "$OSX_SDK" -a -f contrib/depends/sdk-sources/MacOSX${OSX_SDK}.sdk.tar.gz ]; then tar -C contrib/depends/SDKs -xf contrib/depends/sdk-sources/MacOSX${OSX_SDK}.sdk.tar.gz; fi
|
||||||
- if [[ $HOST = *-mingw32 ]]; then $DOCKER_EXEC bash -c "update-alternatives --set $HOST-g++ \$(which $HOST-g++-posix)"; fi
|
- if [[ $HOST = *-mingw32 ]]; then $DOCKER_EXEC bash -c "update-alternatives --set $HOST-g++ \$(which $HOST-g++-posix)"; fi
|
||||||
|
- if [[ $HOST = *-mingw32 ]]; then $DOCKER_EXEC bash -c "update-alternatives --set $HOST-gcc \$(which $HOST-gcc-posix)"; fi
|
||||||
- if [ -z "$NO_DEPENDS" ]; then $DOCKER_EXEC bash -c "CONFIG_SHELL= make $MAKEJOBS -C contrib/depends HOST=$HOST $DEP_OPTS"; fi
|
- if [ -z "$NO_DEPENDS" ]; then $DOCKER_EXEC bash -c "CONFIG_SHELL= make $MAKEJOBS -C contrib/depends HOST=$HOST $DEP_OPTS"; fi
|
||||||
script:
|
script:
|
||||||
- git submodule init && git submodule update
|
- git submodule init && git submodule update
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
# Copyright (c) 2014-2018, The Monero Project
|
# Copyright (c) 2014-2019, The Monero Project
|
||||||
#
|
#
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
@@ -172,6 +172,15 @@ else()
|
|||||||
message(STATUS "Building without build tag")
|
message(STATUS "Building without build tag")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
# Update and init submodules by default
|
||||||
|
if(NOT MANUAL_SUBMODULES)
|
||||||
|
find_package(Git)
|
||||||
|
if(GIT_FOUND)
|
||||||
|
message(STATUS "Initializing submodules")
|
||||||
|
execute_process(COMMAND git "submodule" "update" "--init" "--recursive" WORKING_DIRECTORY ${CMAKE_SOURCE_DIR})
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
if(NOT MANUAL_SUBMODULES)
|
if(NOT MANUAL_SUBMODULES)
|
||||||
find_package(Git)
|
find_package(Git)
|
||||||
if(GIT_FOUND)
|
if(GIT_FOUND)
|
||||||
@@ -239,7 +248,7 @@ endif()
|
|||||||
set_property(GLOBAL PROPERTY USE_FOLDERS ON)
|
set_property(GLOBAL PROPERTY USE_FOLDERS ON)
|
||||||
enable_testing()
|
enable_testing()
|
||||||
|
|
||||||
option(BUILD_DOCUMENTATION "Build the Doxygen documentation." ON)
|
option(BUILD_DOCUMENTATION "Build the Doxygen documentation." OFF)
|
||||||
option(BUILD_TESTS "Build tests." OFF)
|
option(BUILD_TESTS "Build tests." OFF)
|
||||||
|
|
||||||
# Check whether we're on a 32-bit or 64-bit system
|
# Check whether we're on a 32-bit or 64-bit system
|
||||||
@@ -483,6 +492,14 @@ ExternalProject_Add(generate_translations_header
|
|||||||
include_directories("${CMAKE_CURRENT_BINARY_DIR}/translations")
|
include_directories("${CMAKE_CURRENT_BINARY_DIR}/translations")
|
||||||
add_subdirectory(external)
|
add_subdirectory(external)
|
||||||
|
|
||||||
|
# Final setup for miniupnpc
|
||||||
|
if(UPNP_STATIC OR IOS)
|
||||||
|
add_definitions("-DUPNP_STATIC")
|
||||||
|
else()
|
||||||
|
add_definitions("-DUPNP_DYNAMIC")
|
||||||
|
include_directories(${UPNP_INCLUDE})
|
||||||
|
endif()
|
||||||
|
|
||||||
# Final setup for libunbound
|
# Final setup for libunbound
|
||||||
include_directories(${UNBOUND_INCLUDE})
|
include_directories(${UNBOUND_INCLUDE})
|
||||||
link_directories(${UNBOUND_LIBRARY_DIRS})
|
link_directories(${UNBOUND_LIBRARY_DIRS})
|
||||||
@@ -592,9 +609,6 @@ else()
|
|||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${ARCH_FLAG}")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${ARCH_FLAG}")
|
||||||
|
|
||||||
set(WARNINGS "-Wall -Wextra -Wpointer-arith -Wundef -Wvla -Wwrite-strings -Wno-error=extra -Wno-error=deprecated-declarations -Wno-unused-parameter -Wno-unused-variable -Wno-error=unused-variable -Wno-error=undef -Wno-error=uninitialized")
|
set(WARNINGS "-Wall -Wextra -Wpointer-arith -Wundef -Wvla -Wwrite-strings -Wno-error=extra -Wno-error=deprecated-declarations -Wno-unused-parameter -Wno-unused-variable -Wno-error=unused-variable -Wno-error=undef -Wno-error=uninitialized")
|
||||||
if(NOT MINGW)
|
|
||||||
set(WARNINGS_AS_ERRORS_FLAG "-Werror")
|
|
||||||
endif()
|
|
||||||
if(CMAKE_C_COMPILER_ID STREQUAL "Clang")
|
if(CMAKE_C_COMPILER_ID STREQUAL "Clang")
|
||||||
if(ARM)
|
if(ARM)
|
||||||
set(WARNINGS "${WARNINGS} -Wno-error=inline-asm")
|
set(WARNINGS "${WARNINGS} -Wno-error=inline-asm")
|
||||||
@@ -689,6 +703,13 @@ else()
|
|||||||
set(LD_SECURITY_FLAGS "${LD_SECURITY_FLAGS} -Wl,-z,noexecheap")
|
set(LD_SECURITY_FLAGS "${LD_SECURITY_FLAGS} -Wl,-z,noexecheap")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(BACKCOMPAT)
|
||||||
|
add_definitions(-DFDELT_TYPE=long\ int)
|
||||||
|
add_linker_flag_if_supported(-Wl,--wrap=__divmoddi4 LD_BACKCOMPAT_FLAGS)
|
||||||
|
add_linker_flag_if_supported(-Wl,--wrap=glob LD_BACKCOMPAT_FLAGS)
|
||||||
|
message(STATUS "Using Lib C back compat flags: ${LD_BACKCOMPAT_FLAGS}")
|
||||||
|
endif()
|
||||||
|
|
||||||
# some windows linker bits
|
# some windows linker bits
|
||||||
if (WIN32)
|
if (WIN32)
|
||||||
add_linker_flag_if_supported(-Wl,--dynamicbase LD_SECURITY_FLAGS)
|
add_linker_flag_if_supported(-Wl,--dynamicbase LD_SECURITY_FLAGS)
|
||||||
@@ -701,7 +722,7 @@ else()
|
|||||||
|
|
||||||
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -std=c11 -D_GNU_SOURCE ${MINGW_FLAG} ${STATIC_ASSERT_FLAG} ${WARNINGS} ${C_WARNINGS} ${COVERAGE_FLAGS} ${PIC_FLAG} ${C_SECURITY_FLAGS}")
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -std=c11 -D_GNU_SOURCE ${MINGW_FLAG} ${STATIC_ASSERT_FLAG} ${WARNINGS} ${C_WARNINGS} ${COVERAGE_FLAGS} ${PIC_FLAG} ${C_SECURITY_FLAGS}")
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11 -D_GNU_SOURCE ${MINGW_FLAG} ${STATIC_ASSERT_CPP_FLAG} ${WARNINGS} ${CXX_WARNINGS} ${COVERAGE_FLAGS} ${PIC_FLAG} ${CXX_SECURITY_FLAGS}")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11 -D_GNU_SOURCE ${MINGW_FLAG} ${STATIC_ASSERT_CPP_FLAG} ${WARNINGS} ${CXX_WARNINGS} ${COVERAGE_FLAGS} ${PIC_FLAG} ${CXX_SECURITY_FLAGS}")
|
||||||
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} ${LD_SECURITY_FLAGS}")
|
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} ${LD_SECURITY_FLAGS} ${LD_BACKCOMPAT_FLAGS}")
|
||||||
|
|
||||||
# With GCC 6.1.1 the compiled binary malfunctions due to aliasing. Until that
|
# With GCC 6.1.1 the compiled binary malfunctions due to aliasing. Until that
|
||||||
# is fixed in the code (Issue #847), force compiler to be conservative.
|
# is fixed in the code (Issue #847), force compiler to be conservative.
|
||||||
|
|||||||
@@ -19,7 +19,8 @@ posted to #monero-dev on irc.freenode.net).
|
|||||||
|
|
||||||
Patches should be self contained. A good rule of thumb is to have
|
Patches should be self contained. A good rule of thumb is to have
|
||||||
one patch per separate issue, feature, or logical change. Also, no
|
one patch per separate issue, feature, or logical change. Also, no
|
||||||
other changes, such as random whitespace changes or reindentation.
|
other changes, such as random whitespace changes, reindentation,
|
||||||
|
or fixing typoes, spelling, or wording, unless user visible.
|
||||||
Following the code style of the particular chunk of code you're
|
Following the code style of the particular chunk of code you're
|
||||||
modifying is encouraged. Proper squashing should be done (eg, if
|
modifying is encouraged. Proper squashing should be done (eg, if
|
||||||
you're making a buggy patch, then a later patch to fix the bug,
|
you're making a buggy patch, then a later patch to fix the bug,
|
||||||
|
|||||||
17
Dockerfile
17
Dockerfile
@@ -20,7 +20,8 @@ RUN set -ex && \
|
|||||||
automake \
|
automake \
|
||||||
bzip2 \
|
bzip2 \
|
||||||
xsltproc \
|
xsltproc \
|
||||||
gperf
|
gperf \
|
||||||
|
unzip
|
||||||
|
|
||||||
WORKDIR /usr/local
|
WORKDIR /usr/local
|
||||||
|
|
||||||
@@ -147,6 +148,20 @@ RUN set -ex \
|
|||||||
&& make \
|
&& make \
|
||||||
&& make install
|
&& make install
|
||||||
|
|
||||||
|
# Protobuf
|
||||||
|
ARG PROTOBUF_VERSION=v3.6.1
|
||||||
|
ARG PROTOBUF_HASH=48cb18e5c419ddd23d9badcfe4e9df7bde1979b2
|
||||||
|
RUN set -ex \
|
||||||
|
&& git clone https://github.com/protocolbuffers/protobuf -b ${PROTOBUF_VERSION} \
|
||||||
|
&& cd protobuf \
|
||||||
|
&& test `git rev-parse HEAD` = ${PROTOBUF_HASH} || exit 1 \
|
||||||
|
&& git submodule update --init --recursive \
|
||||||
|
&& ./autogen.sh \
|
||||||
|
&& CFLAGS="-fPIC" CXXFLAGS="-fPIC" ./configure --enable-static --disable-shared \
|
||||||
|
&& make \
|
||||||
|
&& make install \
|
||||||
|
&& ldconfig
|
||||||
|
|
||||||
WORKDIR /src
|
WORKDIR /src
|
||||||
COPY . .
|
COPY . .
|
||||||
|
|
||||||
|
|||||||
2
LICENSE
2
LICENSE
@@ -1,4 +1,4 @@
|
|||||||
Copyright (c) 2014-2018, The Monero Project
|
Copyright (c) 2014-2019, The Monero Project
|
||||||
|
|
||||||
All rights reserved.
|
All rights reserved.
|
||||||
|
|
||||||
|
|||||||
10
Makefile
10
Makefile
@@ -1,4 +1,4 @@
|
|||||||
# Copyright (c) 2014-2018, The Monero Project
|
# Copyright (c) 2014-2019, The Monero Project
|
||||||
#
|
#
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
@@ -65,7 +65,7 @@ debug-test:
|
|||||||
|
|
||||||
debug-all:
|
debug-all:
|
||||||
mkdir -p $(builddir)/debug
|
mkdir -p $(builddir)/debug
|
||||||
cd $(builddir)/debug && cmake -D BUILD_TESTS=ON -D BUILD_SHARED_LIBS=OFF -D CMAKE_BUILD_TYPE=Debug $(topdir) && $(MAKE)
|
cd $(builddir)/debug && cmake -D BUILD_TESTS=OFF -D BUILD_SHARED_LIBS=OFF -D CMAKE_BUILD_TYPE=Debug $(topdir) && $(MAKE)
|
||||||
|
|
||||||
debug-static-all:
|
debug-static-all:
|
||||||
mkdir -p $(builddir)/debug
|
mkdir -p $(builddir)/debug
|
||||||
@@ -81,7 +81,7 @@ debug-static-win32:
|
|||||||
|
|
||||||
cmake-release:
|
cmake-release:
|
||||||
mkdir -p $(builddir)/release
|
mkdir -p $(builddir)/release
|
||||||
cd $(builddir)/release && cmake -D CMAKE_BUILD_TYPE=Release $(topdir)
|
cd $(builddir)/release && cmake -D BUILD_TESTS=OFF -D CMAKE_BUILD_TYPE=Release $(topdir)
|
||||||
|
|
||||||
release: cmake-release
|
release: cmake-release
|
||||||
cd $(builddir)/release && $(MAKE)
|
cd $(builddir)/release && $(MAKE)
|
||||||
@@ -92,11 +92,11 @@ release-test:
|
|||||||
|
|
||||||
release-all:
|
release-all:
|
||||||
mkdir -p $(builddir)/release
|
mkdir -p $(builddir)/release
|
||||||
cd $(builddir)/release && cmake -D BUILD_TESTS=ON -D CMAKE_BUILD_TYPE=release $(topdir) && $(MAKE)
|
cd $(builddir)/release && cmake -D BUILD_TESTS=OFF -D CMAKE_BUILD_TYPE=release $(topdir) && $(MAKE)
|
||||||
|
|
||||||
release-static:
|
release-static:
|
||||||
mkdir -p $(builddir)/release
|
mkdir -p $(builddir)/release
|
||||||
cd $(builddir)/release && cmake -D STATIC=ON -D ARCH="x86-64" -D BUILD_64=ON -D CMAKE_BUILD_TYPE=release $(topdir) && $(MAKE)
|
cd $(builddir)/release && cmake -D BUILD_TESTS=OFF -D STATIC=ON -D ARCH="x86-64" -D BUILD_64=ON -D CMAKE_BUILD_TYPE=release $(topdir) && $(MAKE)
|
||||||
|
|
||||||
coverage:
|
coverage:
|
||||||
mkdir -p $(builddir)/debug
|
mkdir -p $(builddir)/debug
|
||||||
|
|||||||
39
PKGBUILD
Normal file
39
PKGBUILD
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
# Maintainer: wowario <wowario at protonmail dot com>
|
||||||
|
# Contributor: wowario <wowario at protonmail dot com>
|
||||||
|
|
||||||
|
pkgbase=('wownero-git')
|
||||||
|
pkgname=('wownero-git')
|
||||||
|
_gitbranch='dev-v0.5'
|
||||||
|
pkgver=0.5.0.0
|
||||||
|
pkgrel=1
|
||||||
|
pkgdesc="a fairly launched privacy-centric meme coin with no premine and a finite supply"
|
||||||
|
license=('custom:Cryptonote')
|
||||||
|
arch=('x86_64')
|
||||||
|
url="http://wownero.org/"
|
||||||
|
depends=('boost-libs' 'zeromq' 'unbound' 'libusb')
|
||||||
|
makedepends=('git' 'cmake' 'boost')
|
||||||
|
provides=('wownero-git')
|
||||||
|
|
||||||
|
source=("${pkgname}"::"git+https://github.com/wownero/wownero#branch=${_gitbranch}")
|
||||||
|
|
||||||
|
sha256sums=('SKIP')
|
||||||
|
|
||||||
|
pkgver() {
|
||||||
|
cd "${srcdir}/${pkgname}"
|
||||||
|
printf "$(echo ${pkgver} | sed 's/\.r.*//').r%s.g%s" \
|
||||||
|
"$(git rev-list --count HEAD)" "$(git rev-parse --short HEAD)"
|
||||||
|
}
|
||||||
|
|
||||||
|
build() {
|
||||||
|
cd "${srcdir}/${pkgname}"
|
||||||
|
USE_SINGLE_BUILDDIR=1 make
|
||||||
|
}
|
||||||
|
|
||||||
|
package_wownero-git() {
|
||||||
|
install -Dm644 "${srcdir}/${pkgname}/LICENSE" "${pkgdir}/usr/share/licenses/${pkgname}/LICENSE"
|
||||||
|
install -Dm644 "${srcdir}/${pkgname}/utils/conf/wownerod.conf" "${pkgdir}/etc/wownerod.conf"
|
||||||
|
install -Dm644 "${srcdir}/${pkgname}/utils/systemd/wownerod.service" "${pkgdir}/usr/lib/systemd/system/wownerod.service"
|
||||||
|
install -Dm755 "${srcdir}/${pkgname}/build/release/bin/wownerod" "${pkgdir}/usr/bin/wownerod"
|
||||||
|
install -Dm755 "${srcdir}/${pkgname}/build/release/bin/wownero-wallet-cli" "${pkgdir}/usr/bin/wownero-wallet-cli"
|
||||||
|
install -Dm755 "${srcdir}/${pkgname}/build/release/bin/wownero-wallet-rpc" "${pkgdir}/usr/bin/wownero-wallet-rpc"
|
||||||
|
}
|
||||||
730
README.md
730
README.md
@@ -1,578 +1,107 @@
|
|||||||
# Monero
|
# ~~Mo~~Wownero - Such privacy! Many coins! Wow! 🐕
|
||||||
|
|
||||||
Copyright (c) 2014-2018 The Monero Project.
|
Copyright (c) 2014-2018 The Monero Project.
|
||||||
Portions Copyright (c) 2012-2013 The Cryptonote developers.
|
Portions Copyright (c) 2012-2013 The Cryptonote developers.
|
||||||
|
|
||||||
## Development resources
|
## Resources
|
||||||
|
|
||||||
- Web: [getmonero.org](https://getmonero.org)
|
- Web: [wownero.org](http://wownero.org)
|
||||||
- Forum: [forum.getmonero.org](https://forum.getmonero.org)
|
- Twitter: [@w0wn3r0](https://twitter.com/w0wn3r0)
|
||||||
- Mail: [dev@getmonero.org](mailto:dev@getmonero.org)
|
- Discord: [discord.gg/sQt74ep](https://discord.gg/sQt74ep)
|
||||||
- GitHub: [https://github.com/monero-project/monero](https://github.com/monero-project/monero)
|
- Reddit: [/r/wownero](https://www.reddit.com/r/wownero)
|
||||||
- IRC: [#monero-dev on Freenode](https://webchat.freenode.net/?randomnick=1&channels=%23monero-dev&prompt=1&uio=d4)
|
- Mail: [wownero@protonmail.com](mailto:wownero@protonmail.com)
|
||||||
|
- GitHub: [https://github.com/wownero/wownero](https://github.com/wownero/wownero)
|
||||||
|
- IRC: [#wownero on Freenode](https://kiwiirc.com/client/irc.freenode.net/?nick=suchchatter|?#wownero)
|
||||||
|
- Bitmessage Chan: wownero (`BM-2cSzWtrj2pzLva9GF1Jp2TYsnLjrnJpvba`)
|
||||||
|
- Network stats: [https://freeboard.io/board/c8mM2c](https://freeboard.io/board/c8mM2c)
|
||||||
|
- Wownero Funding System: [https://funding.wownero.com](https://funding.wownero.com)
|
||||||
|
- Keybase Chat Group: [https://keybase.io/team/wownero](https://keybase.io/team/wownero)
|
||||||
|
|
||||||
## Vulnerability response
|
Blockchain Explorers
|
||||||
|
- https://explore.wownero.com
|
||||||
- Our [Vulnerability Response Process](https://github.com/monero-project/meta/blob/master/VULNERABILITY_RESPONSE_PROCESS.md) encourages responsible disclosure
|
- https://explorer.wowkira.com
|
||||||
- We are also available via [HackerOne](https://hackerone.com/monero)
|
- http://explorer.wowne.ro
|
||||||
|
- http://wow4edxxxudchgj7.onion
|
||||||
## Research
|
- http://wow5eqtzqvsg5jctqzg5g7uk3u62sfqiacj5x6lo4by7bvnj6jkvubyd.onion
|
||||||
|
|
||||||
The [Monero Research Lab](https://src.getmonero.org/resources/research-lab/) is an open forum where the community coordinates research into Monero cryptography, protocols, fungibility, analysis, and more. We welcome collaboration and contributions from outside researchers! Because not all Lab work and publications are distributed as traditional preprints or articles, they may be easy to miss if you are conducting literature reviews for your own Monero research. You are encouraged to get in touch with our researchers if you have questions, wish to collaborate, or would like guidance to help avoid unnecessarily duplicating earlier or known work.
|
|
||||||
|
|
||||||
Our researchers are available on IRC in [#monero-research-lab on Freenode](https://webchat.freenode.net/?randomnick=1&channels=%23monero-research-lab&prompt=1&uio=d4) or by email:
|
|
||||||
|
|
||||||
- Sarang Noether, Ph.D.: [sarang@getmonero.org](mailto:sarang@getmonero.org) or [sarang.noether@protonmail.com](mailto:sarang.noether@protonmail.com); [research repository](https://github.com/SarangNoether/research-lab)
|
|
||||||
- Surae Noether (Brandon Goodell), Ph.D.: [surae@getmonero.org](mailto:surae@getmonero.org) or [surae.noether@protonmail.com](mailto:surae.noether@protonmail.com); [research repository](https://github.com/b-g-goodell/research-lab)
|
|
||||||
|
|
||||||
## Announcements
|
|
||||||
|
|
||||||
- You can subscribe to an [announcement listserv](https://lists.getmonero.org) to get critical announcements from the Monero core team. The announcement list can be very helpful for knowing when software updates are needed.
|
|
||||||
|
|
||||||
## Build
|
|
||||||
|
|
||||||
### IMPORTANT
|
|
||||||
|
|
||||||
These builds are of the master branch, which is used for active development and can be either unstable or incompatible with release software. Please compile release branches.
|
|
||||||
|
|
||||||
| Operating System | Processor | Status |
|
|
||||||
| --------------------- | -------- |--------|
|
|
||||||
| Ubuntu 16.04 | i686 | [](https://build.getmonero.org/builders/monero-static-ubuntu-i686)
|
|
||||||
| Ubuntu 16.04 | amd64 | [](https://build.getmonero.org/builders/monero-static-ubuntu-amd64)
|
|
||||||
| Ubuntu 16.04 | armv7 | [](https://build.getmonero.org/builders/monero-static-ubuntu-arm7)
|
|
||||||
| Debian Stable | armv8 | [](https://build.getmonero.org/builders/monero-static-debian-armv8)
|
|
||||||
| OSX 10.11 | amd64 | [](https://build.getmonero.org/builders/monero-static-osx-10.11)
|
|
||||||
| OSX 10.12 | amd64 | [](https://build.getmonero.org/builders/monero-static-osx-10.12)
|
|
||||||
| OSX 10.13 | amd64 | [](https://build.getmonero.org/builders/monero-static-osx-10.13)
|
|
||||||
| FreeBSD 11 | amd64 | [](https://build.getmonero.org/builders/monero-static-freebsd64)
|
|
||||||
| DragonFly BSD 4.6 | amd64 | [](https://build.getmonero.org/builders/monero-static-dragonflybsd-amd64)
|
|
||||||
| Windows (MSYS2/MinGW) | i686 | [](https://build.getmonero.org/builders/monero-static-win32)
|
|
||||||
| Windows (MSYS2/MinGW) | amd64 | [](https://build.getmonero.org/builders/monero-static-win64)
|
|
||||||
|
|
||||||
## Coverage
|
|
||||||
|
|
||||||
| Type | Status |
|
|
||||||
|-----------|--------|
|
|
||||||
| Coverity | [](https://scan.coverity.com/projects/9657/)
|
|
||||||
| Coveralls | [](https://coveralls.io/github/monero-project/monero?branch=master)
|
|
||||||
| License | [](https://opensource.org/licenses/BSD-3-Clause)
|
|
||||||
|
|
||||||
## Introduction
|
## Introduction
|
||||||
|
|
||||||
Monero is a private, secure, untraceable, decentralised digital currency. You are your bank, you control your funds, and nobody can trace your transfers unless you allow them to do so.
|
Wownero is a privacy-centric memecoin that was fairly launched on April 1, 2018 with no pre-mine, stealth-mine or ICO. Wownero has a maximum supply of around 184 million WOW with a slow and steady emission over 50 years. It is a fork of Monero, but with its own genesis block, so there is no degradation of privacy due to ring signatures using different participants for the same tx outputs on opposing forks.
|
||||||
|
|
||||||
**Privacy:** Monero uses a cryptographically sound system to allow you to send and receive funds without your transactions being easily revealed on the blockchain (the ledger of transactions that everyone has). This ensures that your purchases, receipts, and all transfers remain absolutely private by default.
|
|
||||||
|
|
||||||
**Security:** Using the power of a distributed peer-to-peer consensus network, every transaction on the network is cryptographically secured. Individual wallets have a 25 word mnemonic seed that is only displayed once, and can be written down to backup the wallet. Wallet files are encrypted with a passphrase to ensure they are useless if stolen.
|
|
||||||
|
|
||||||
**Untraceability:** By taking advantage of ring signatures, a special property of a certain type of cryptography, Monero is able to ensure that transactions are not only untraceable, but have an optional measure of ambiguity that ensures that transactions cannot easily be tied back to an individual user or computer.
|
|
||||||
|
|
||||||
## About this project
|
|
||||||
|
|
||||||
This is the core implementation of Monero. It is open source and completely free to use without restrictions, except for those specified in the license agreement below. There are no restrictions on anyone creating an alternative implementation of Monero that uses the protocol and network in a compatible manner.
|
|
||||||
|
|
||||||
As with many development projects, the repository on Github is considered to be the "staging" area for the latest changes. Before changes are merged into that branch on the main repository, they are tested by individual developers in their own branches, submitted as a pull request, and then subsequently tested by contributors who focus on testing and code reviews. That having been said, the repository should be carefully considered before using it in a production environment, unless there is a patch in the repository for a particular show-stopping issue you are experiencing. It is generally a better idea to use a tagged release for stability.
|
|
||||||
|
|
||||||
**Anyone is welcome to contribute to Monero's codebase!** If you have a fix or code change, feel free to submit it as a pull request directly to the "master" branch. In cases where the change is relatively small or does not affect other parts of the codebase it may be merged in immediately by any one of the collaborators. On the other hand, if the change is particularly large or complex, it is expected that it will be discussed at length either well in advance of the pull request being submitted, or even directly on the pull request.
|
|
||||||
|
|
||||||
## Supporting the project
|
|
||||||
|
|
||||||
Monero is a 100% community-sponsored endeavor. If you want to join our efforts, the easiest thing you can do is support the project financially. Both Monero and Bitcoin donations can be made to **donate.getmonero.org** if using a client that supports the [OpenAlias](https://openalias.org) standard. Alternatively you can send XMR to the Monero donation address via the `donate` command (type `help` in the command-line wallet for details).
|
|
||||||
|
|
||||||
The Monero donation address is: `44AFFq5kSiGBoZ4NMDwYtN18obc8AemS33DBLWs3H7otXft3XjrpDtQGv7SqSsaBYBb98uNbr2VBBEt7f2wfn3RVGQBEP3A` (viewkey: `f359631075708155cc3d92a32b75a7d02a5dcf27756707b47a2b31b21c389501`)
|
|
||||||
|
|
||||||
The Bitcoin donation address is: `1KTexdemPdxSBcG55heUuTjDRYqbC5ZL8H`
|
|
||||||
|
|
||||||
Core development funding and/or some supporting services are also graciously provided by sponsors:
|
|
||||||
|
|
||||||
[<img width="80" src="https://static.getmonero.org/images/sponsors/mymonero.png"/>](https://mymonero.com)
|
|
||||||
[<img width="150" src="https://static.getmonero.org/images/sponsors/kitware.png?1"/>](https://kitware.com)
|
|
||||||
[<img width="100" src="https://static.getmonero.org/images/sponsors/dome9.png"/>](https://dome9.com)
|
|
||||||
[<img width="150" src="https://static.getmonero.org/images/sponsors/araxis.png"/>](https://araxis.com)
|
|
||||||
[<img width="150" src="https://static.getmonero.org/images/sponsors/jetbrains.png"/>](https://www.jetbrains.com/)
|
|
||||||
[<img width="150" src="https://static.getmonero.org/images/sponsors/navicat.png"/>](https://www.navicat.com/)
|
|
||||||
[<img width="150" src="https://static.getmonero.org/images/sponsors/symas.png"/>](https://www.symas.com/)
|
|
||||||
|
|
||||||
There are also several mining pools that kindly donate a portion of their fees, [a list of them can be found on our Bitcointalk post](https://bitcointalk.org/index.php?topic=583449.0).
|
|
||||||
|
|
||||||
## License
|
|
||||||
|
|
||||||
See [LICENSE](LICENSE).
|
|
||||||
|
|
||||||
## Contributing
|
|
||||||
|
|
||||||
If you want to help out, see [CONTRIBUTING](CONTRIBUTING.md) for a set of guidelines.
|
|
||||||
|
|
||||||
## Scheduled software upgrades
|
## Scheduled software upgrades
|
||||||
|
|
||||||
Monero uses a fixed-schedule software upgrade (hard fork) mechanism to implement new features. This means that users of Monero (end users and service providers) should run current versions and upgrade their software on a regular schedule. Software upgrades occur during the months of April and October. The required software for these upgrades will be available prior to the scheduled date. Please check the repository prior to this date for the proper Monero software version. Below is the historical schedule and the projected schedule for the next upgrade.
|
Wownero uses a fixed-schedule software upgrade (hard fork) mechanism to implement new features. This means that users of Wownero (end users and service providers) should run current versions and upgrade their software on a regular schedule. The required software for these upgrades will be available prior to the scheduled date. Please check the repository prior to this date for the proper Wownero software version. Below is the historical schedule and the projected schedule for the next upgrade.
|
||||||
Dates are provided in the format YYYY-MM-DD.
|
Dates are provided in the format YYYY-MM-DD.
|
||||||
|
|
||||||
|
|
||||||
| Software upgrade block height | Date | Fork version | Minimum Monero version | Recommended Monero version | Details |
|
|
||||||
|
| Software upgrade block height | Date | Release Name | Minimum Wownero version | Recommended Wownero version | Details |
|
||||||
| ------------------------------ | -----------| ----------------- | ---------------------- | -------------------------- | ---------------------------------------------------------------------------------- |
|
| ------------------------------ | -----------| ----------------- | ---------------------- | -------------------------- | ---------------------------------------------------------------------------------- |
|
||||||
| 1009827 | 2016-03-22 | v2 | v0.9.4 | v0.9.4 | Allow only >= ringsize 3, blocktime = 120 seconds, fee-free blocksize 60 kb |
|
| 1 | 2018-04-01 | Awesome Akita | v0.1.0.0 | v0.1.0.0 | Cryptonight variant 1, ringsize >= 8, sorted inputs
|
||||||
| 1141317 | 2016-09-21 | v3 | v0.9.4 | v0.10.0 | Splits coinbase into denominations |
|
| 6969 | 2018-04-24 | Busty Brazzers | v0.2.0.0 | v0.2.0.0 | Bulletproofs, LWMA difficulty algorithm, ringsize >= 10, reduce unlock to 4
|
||||||
| 1220516 | 2017-01-05 | v4 | v0.10.1 | v0.10.2.1 | Allow normal and RingCT transactions |
|
| 53666 | 2018-10-06 | Cool Cage | v0.3.0.0 | v0.3.1.3 | Cryptonight variant 2, LWMA v2, ringsize = 22, MMS
|
||||||
| 1288616 | 2017-04-15 | v5 | v0.10.3.0 | v0.10.3.1 | Adjusted minimum blocksize and fee algorithm |
|
| 63469 | 2018-11-11 | Dank Doge | v0.4.0.0 | v0.4.0.0 | LWMA v4
|
||||||
| 1400000 | 2017-09-16 | v6 | v0.11.0.0 | v0.11.0.0 | Allow only RingCT transactions, allow only >= ringsize 5 |
|
| 81769 | 2019-02-19 | Erotic EggplantEmoji | v0.5.0.0 | v0.5.0.2 | Cryptonight/wow, LWMA v1 with N=144, Updated Bulletproofs, Fee Per Byte, Auto-churn
|
||||||
| 1546000 | 2018-04-06 | v7 | v0.12.0.0 | v0.12.3.0 | Cryptonight variant 1, ringsize >= 7, sorted inputs
|
|
||||||
| 1685555 | 2018-10-18 | v8 | v0.13.0.0 | v0.13.0.4 | max transaction size at half the penalty free block size, bulletproofs enabled, cryptonight variant 2, fixed ringsize [11](https://youtu.be/KOO5S4vxi0o)
|
|
||||||
| 1686275 | 2018-10-19 | v9 | v0.13.0.0 | v0.13.0.4 | bulletproofs required
|
|
||||||
| XXXXXXX | 2019-04-XX | XX | XXXXXXXXX | XXXXXXXXX | X
|
|
||||||
|
|
||||||
X's indicate that these details have not been determined as of commit date.
|
X's indicate that these details have not been determined as of commit date.
|
||||||
|
|
||||||
## Release staging schedule and protocol
|
## Release staging and Contributing
|
||||||
|
|
||||||
Approximately three months prior to a scheduled software upgrade, a branch from Master will be created with the new release version tag. Pull requests that address bugs should then be made to both Master and the new release branch. Pull requests that require extensive review and testing (generally, optimizations and new features) should *not* be made to the release branch.
|
**Anyone is welcome to contribute to Wownero's codebase!**
|
||||||
|
|
||||||
## Compiling Monero from source
|
If you have a fix or code change, feel free to submit it as a pull request. Ahead of a scheduled software upgrade, a development branch will be created with the new release version tag. Pull requests that address bugs should be made to Master. Pull requests that require review and testing (generally, optimizations and new features) should be made to the development branch. All pull requests will be considered safe until the US dollar valuation of 1 Wownero equals $1000. After this valuation has been reached, more research will be needed to introduce experimental cryptography and/or code into the codebase.
|
||||||
|
|
||||||
### Dependencies
|
## Installing from a package
|
||||||
|
|
||||||
The following table summarizes the tools and libraries required to build. A
|
|
||||||
few of the libraries are also included in this repository (marked as
|
|
||||||
"Vendored"). By default, the build uses the library installed on the system,
|
|
||||||
and ignores the vendored sources. However, if no library is found installed on
|
|
||||||
the system, then the vendored source will be built and used. The vendored
|
|
||||||
sources are also used for statically-linked builds because distribution
|
|
||||||
packages often include only shared library binaries (`.so`) but not static
|
|
||||||
library archives (`.a`).
|
|
||||||
|
|
||||||
| Dep | Min. version | Vendored | Debian/Ubuntu pkg | Arch pkg | Fedora | Optional | Purpose |
|
|
||||||
| ------------ | ------------- | -------- | ------------------ | ------------ | ----------------- | -------- | -------------- |
|
|
||||||
| GCC | 4.7.3 | NO | `build-essential` | `base-devel` | `gcc` | NO | |
|
|
||||||
| CMake | 3.5 | NO | `cmake` | `cmake` | `cmake` | NO | |
|
|
||||||
| pkg-config | any | NO | `pkg-config` | `base-devel` | `pkgconf` | NO | |
|
|
||||||
| Boost | 1.58 | NO | `libboost-all-dev` | `boost` | `boost-devel` | NO | C++ libraries |
|
|
||||||
| OpenSSL | basically any | NO | `libssl-dev` | `openssl` | `openssl-devel` | NO | sha256 sum |
|
|
||||||
| libzmq | 3.0.0 | NO | `libzmq3-dev` | `zeromq` | `cppzmq-devel` | NO | ZeroMQ library |
|
|
||||||
| OpenPGM | ? | NO | `libpgm-dev` | `libpgm` | `openpgm-devel` | NO | For ZeroMQ |
|
|
||||||
| libnorm[2] | ? | NO | `libnorm-dev` | | ` | YES | For ZeroMQ |
|
|
||||||
| libunbound | 1.4.16 | YES | `libunbound-dev` | `unbound` | `unbound-devel` | NO | DNS resolver |
|
|
||||||
| libsodium | ? | NO | `libsodium-dev` | `libsodium` | `libsodium-devel` | NO | cryptography |
|
|
||||||
| libunwind | any | NO | `libunwind8-dev` | `libunwind` | `libunwind-devel` | YES | Stack traces |
|
|
||||||
| liblzma | any | NO | `liblzma-dev` | `xz` | `xz-devel` | YES | For libunwind |
|
|
||||||
| libreadline | 6.3.0 | NO | `libreadline6-dev` | `readline` | `readline-devel` | YES | Input editing |
|
|
||||||
| ldns | 1.6.17 | NO | `libldns-dev` | `ldns` | `ldns-devel` | YES | SSL toolkit |
|
|
||||||
| expat | 1.1 | NO | `libexpat1-dev` | `expat` | `expat-devel` | YES | XML parsing |
|
|
||||||
| GTest | 1.5 | YES | `libgtest-dev`[1] | `gtest` | `gtest-devel` | YES | Test suite |
|
|
||||||
| Doxygen | any | NO | `doxygen` | `doxygen` | `doxygen` | YES | Documentation |
|
|
||||||
| Graphviz | any | NO | `graphviz` | `graphviz` | `graphviz` | YES | Documentation |
|
|
||||||
|
|
||||||
|
|
||||||
[1] On Debian/Ubuntu `libgtest-dev` only includes sources and headers. You must
|
|
||||||
build the library binary manually. This can be done with the following command ```sudo apt-get install libgtest-dev && cd /usr/src/gtest && sudo cmake . && sudo make && sudo mv libg* /usr/lib/ ```
|
|
||||||
[2] libnorm-dev is needed if your zmq library was built with libnorm, and not needed otherwise
|
|
||||||
|
|
||||||
Debian / Ubuntu one liner for all dependencies
|
|
||||||
``` sudo apt update && sudo apt install build-essential cmake pkg-config libboost-all-dev libssl-dev libzmq3-dev libunbound-dev libsodium-dev libunwind8-dev liblzma-dev libreadline6-dev libldns-dev libexpat1-dev doxygen graphviz libpgm-dev```
|
|
||||||
|
|
||||||
### Cloning the repository
|
|
||||||
|
|
||||||
Clone recursively to pull-in needed submodule(s):
|
|
||||||
|
|
||||||
`$ git clone --recursive https://github.com/monero-project/monero`
|
|
||||||
|
|
||||||
If you already have a repo cloned, initialize and update:
|
|
||||||
|
|
||||||
`$ cd monero && git submodule init && git submodule update`
|
|
||||||
|
|
||||||
### Build instructions
|
|
||||||
|
|
||||||
Monero uses the CMake build system and a top-level [Makefile](Makefile) that
|
|
||||||
invokes cmake commands as needed.
|
|
||||||
|
|
||||||
#### On Linux and OS X
|
|
||||||
|
|
||||||
* Install the dependencies
|
|
||||||
* Change to the root of the source code directory, change to the most recent release branch, and build:
|
|
||||||
|
|
||||||
cd monero
|
|
||||||
git checkout v0.13.0.4
|
|
||||||
make
|
|
||||||
|
|
||||||
*Optional*: If your machine has several cores and enough memory, enable
|
|
||||||
parallel build by running `make -j<number of threads>` instead of `make`. For
|
|
||||||
this to be worthwhile, the machine should have one core and about 2GB of RAM
|
|
||||||
available per thread.
|
|
||||||
|
|
||||||
*Note*: If cmake can not find zmq.hpp file on OS X, installing `zmq.hpp` from
|
|
||||||
https://github.com/zeromq/cppzmq to `/usr/local/include` should fix that error.
|
|
||||||
|
|
||||||
*Note*: The instructions above will compile the most stable release of the
|
|
||||||
Monero software. If you would like to use and test the most recent software,
|
|
||||||
use ```git checkout master```. The master branch may contain updates that are
|
|
||||||
both unstable and incompatible with release software, though testing is always
|
|
||||||
encouraged.
|
|
||||||
|
|
||||||
* The resulting executables can be found in `build/release/bin`
|
|
||||||
|
|
||||||
* Add `PATH="$PATH:$HOME/monero/build/release/bin"` to `.profile`
|
|
||||||
|
|
||||||
* Run Monero with `monerod --detach`
|
|
||||||
|
|
||||||
* **Optional**: build and run the test suite to verify the binaries:
|
|
||||||
|
|
||||||
make release-test
|
|
||||||
|
|
||||||
*NOTE*: `core_tests` test may take a few hours to complete.
|
|
||||||
|
|
||||||
* **Optional**: to build binaries suitable for debugging:
|
|
||||||
|
|
||||||
make debug
|
|
||||||
|
|
||||||
* **Optional**: to build statically-linked binaries:
|
|
||||||
|
|
||||||
make release-static
|
|
||||||
|
|
||||||
Dependencies need to be built with -fPIC. Static libraries usually aren't, so you may have to build them yourself with -fPIC. Refer to their documentation for how to build them.
|
|
||||||
|
|
||||||
* **Optional**: build documentation in `doc/html` (omit `HAVE_DOT=YES` if `graphviz` is not installed):
|
|
||||||
|
|
||||||
HAVE_DOT=YES doxygen Doxyfile
|
|
||||||
|
|
||||||
#### On the Raspberry Pi
|
|
||||||
|
|
||||||
Tested on a Raspberry Pi Zero with a clean install of minimal Raspbian Stretch (2017-09-07 or later) from https://www.raspberrypi.org/downloads/raspbian/. If you are using Raspian Jessie, [please see note in the following section](#note-for-raspbian-jessie-users).
|
|
||||||
|
|
||||||
* `apt-get update && apt-get upgrade` to install all of the latest software
|
|
||||||
|
|
||||||
* Install the dependencies for Monero from the 'Debian' column in the table above.
|
|
||||||
|
|
||||||
* Increase the system swap size:
|
|
||||||
```
|
|
||||||
sudo /etc/init.d/dphys-swapfile stop
|
|
||||||
sudo nano /etc/dphys-swapfile
|
|
||||||
CONF_SWAPSIZE=2048
|
|
||||||
sudo /etc/init.d/dphys-swapfile start
|
|
||||||
```
|
|
||||||
* If using an external hard disk without an external power supply, ensure it gets enough power to avoid hardware issues when syncing, by adding the line "max_usb_current=1" to /boot/config.txt
|
|
||||||
|
|
||||||
* Clone monero and checkout most recent release version:
|
|
||||||
```
|
|
||||||
git clone https://github.com/monero-project/monero.git
|
|
||||||
cd monero
|
|
||||||
git checkout tags/v0.13.0.4
|
|
||||||
```
|
|
||||||
* Build:
|
|
||||||
```
|
|
||||||
make release
|
|
||||||
```
|
|
||||||
* Wait 4-6 hours
|
|
||||||
|
|
||||||
* The resulting executables can be found in `build/release/bin`
|
|
||||||
|
|
||||||
* Add `PATH="$PATH:$HOME/monero/build/release/bin"` to `.profile`
|
|
||||||
|
|
||||||
* Run Monero with `monerod --detach`
|
|
||||||
|
|
||||||
* You may wish to reduce the size of the swap file after the build has finished, and delete the boost directory from your home directory
|
|
||||||
|
|
||||||
#### *Note for Raspbian Jessie users:*
|
|
||||||
|
|
||||||
If you are using the older Raspbian Jessie image, compiling Monero is a bit more complicated. The version of Boost available in the Debian Jessie repositories is too old to use with Monero, and thus you must compile a newer version yourself. The following explains the extra steps, and has been tested on a Raspberry Pi 2 with a clean install of minimal Raspbian Jessie.
|
|
||||||
|
|
||||||
* As before, `apt-get update && apt-get upgrade` to install all of the latest software, and increase the system swap size
|
|
||||||
|
|
||||||
```
|
|
||||||
sudo /etc/init.d/dphys-swapfile stop
|
|
||||||
sudo nano /etc/dphys-swapfile
|
|
||||||
CONF_SWAPSIZE=2048
|
|
||||||
sudo /etc/init.d/dphys-swapfile start
|
|
||||||
```
|
|
||||||
|
|
||||||
* Then, install the dependencies for Monero except `libunwind` and `libboost-all-dev`
|
|
||||||
|
|
||||||
* Install the latest version of boost (this may first require invoking `apt-get remove --purge libboost*` to remove a previous version if you're not using a clean install):
|
|
||||||
```
|
|
||||||
cd
|
|
||||||
wget https://sourceforge.net/projects/boost/files/boost/1.64.0/boost_1_64_0.tar.bz2
|
|
||||||
tar xvfo boost_1_64_0.tar.bz2
|
|
||||||
cd boost_1_64_0
|
|
||||||
./bootstrap.sh
|
|
||||||
sudo ./b2
|
|
||||||
```
|
|
||||||
* Wait ~8 hours
|
|
||||||
```
|
|
||||||
sudo ./bjam cxxflags=-fPIC cflags=-fPIC -a install
|
|
||||||
```
|
|
||||||
* Wait ~4 hours
|
|
||||||
|
|
||||||
* From here, follow the [general Raspberry Pi instructions](#on-the-raspberry-pi) from the "Clone monero and checkout most recent release version" step.
|
|
||||||
|
|
||||||
#### On Windows:
|
|
||||||
|
|
||||||
Binaries for Windows are built on Windows using the MinGW toolchain within
|
|
||||||
[MSYS2 environment](https://www.msys2.org). The MSYS2 environment emulates a
|
|
||||||
POSIX system. The toolchain runs within the environment and *cross-compiles*
|
|
||||||
binaries that can run outside of the environment as a regular Windows
|
|
||||||
application.
|
|
||||||
|
|
||||||
**Preparing the build environment**
|
|
||||||
|
|
||||||
* Download and install the [MSYS2 installer](https://www.msys2.org), either the 64-bit or the 32-bit package, depending on your system.
|
|
||||||
* Open the MSYS shell via the `MSYS2 Shell` shortcut
|
|
||||||
* Update packages using pacman:
|
|
||||||
|
|
||||||
pacman -Syuu
|
|
||||||
|
|
||||||
* Exit the MSYS shell using Alt+F4
|
|
||||||
* Edit the properties for the `MSYS2 Shell` shortcut changing "msys2_shell.bat" to "msys2_shell.cmd -mingw64" for 64-bit builds or "msys2_shell.cmd -mingw32" for 32-bit builds
|
|
||||||
* Restart MSYS shell via modified shortcut and update packages again using pacman:
|
|
||||||
|
|
||||||
pacman -Syuu
|
|
||||||
|
|
||||||
|
|
||||||
* Install dependencies:
|
|
||||||
|
|
||||||
To build for 64-bit Windows:
|
|
||||||
|
|
||||||
pacman -S mingw-w64-x86_64-toolchain make mingw-w64-x86_64-cmake mingw-w64-x86_64-boost mingw-w64-x86_64-openssl mingw-w64-x86_64-zeromq mingw-w64-x86_64-libsodium mingw-w64-x86_64-hidapi
|
|
||||||
|
|
||||||
To build for 32-bit Windows:
|
|
||||||
|
|
||||||
pacman -S mingw-w64-i686-toolchain make mingw-w64-i686-cmake mingw-w64-i686-boost mingw-w64-i686-openssl mingw-w64-i686-zeromq mingw-w64-i686-libsodium mingw-w64-i686-hidapi
|
|
||||||
|
|
||||||
* Open the MingW shell via `MinGW-w64-Win64 Shell` shortcut on 64-bit Windows
|
|
||||||
or `MinGW-w64-Win64 Shell` shortcut on 32-bit Windows. Note that if you are
|
|
||||||
running 64-bit Windows, you will have both 64-bit and 32-bit MinGW shells.
|
|
||||||
|
|
||||||
**Cloning**
|
|
||||||
|
|
||||||
* To git clone, run:
|
|
||||||
|
|
||||||
git clone --recursive https://github.com/monero-project/monero.git
|
|
||||||
|
|
||||||
**Building**
|
|
||||||
|
|
||||||
* Change to the cloned directory, run:
|
|
||||||
|
|
||||||
cd monero
|
|
||||||
|
|
||||||
* If you would like a specific [version/tag](https://github.com/monero-project/monero/tags), do a git checkout for that version. eg. 'v0.13.0.0'. If you dont care about the version and just want binaries from master, skip this step:
|
|
||||||
|
|
||||||
git checkout v0.13.0.4
|
|
||||||
|
|
||||||
* If you are on a 64-bit system, run:
|
|
||||||
|
|
||||||
make release-static-win64
|
|
||||||
|
|
||||||
* If you are on a 32-bit system, run:
|
|
||||||
|
|
||||||
make release-static-win32
|
|
||||||
|
|
||||||
* The resulting executables can be found in `build/release/bin`
|
|
||||||
|
|
||||||
* **Optional**: to build Windows binaries suitable for debugging on a 64-bit system, run:
|
|
||||||
|
|
||||||
make debug-static-win64
|
|
||||||
|
|
||||||
* **Optional**: to build Windows binaries suitable for debugging on a 32-bit system, run:
|
|
||||||
|
|
||||||
make debug-static-win32
|
|
||||||
|
|
||||||
* The resulting executables can be found in `build/debug/bin`
|
|
||||||
|
|
||||||
### On FreeBSD:
|
|
||||||
|
|
||||||
The project can be built from scratch by following instructions for Linux above. If you are running monero in a jail you need to add the flag: `allow.sysvipc=1` to your jail configuration, otherwise lmdb will throw the error message: `Failed to open lmdb environment: Function not implemented`.
|
|
||||||
|
|
||||||
We expect to add Monero into the ports tree in the near future, which will aid in managing installations using ports or packages.
|
|
||||||
|
|
||||||
### On OpenBSD:
|
|
||||||
|
|
||||||
#### OpenBSD < 6.2
|
|
||||||
|
|
||||||
This has been tested on OpenBSD 5.8.
|
|
||||||
|
|
||||||
You will need to add a few packages to your system. `pkg_add db cmake gcc gcc-libs g++ gtest`.
|
|
||||||
|
|
||||||
The doxygen and graphviz packages are optional and require the xbase set.
|
|
||||||
|
|
||||||
The Boost package has a bug that will prevent librpc.a from building correctly. In order to fix this, you will have to Build boost yourself from scratch. Follow the directions here (under "Building Boost"):
|
|
||||||
https://github.com/bitcoin/bitcoin/blob/master/doc/build-openbsd.md
|
|
||||||
|
|
||||||
You will have to add the serialization, date_time, and regex modules to Boost when building as they are needed by Monero.
|
|
||||||
|
|
||||||
To build: `env CC=egcc CXX=eg++ CPP=ecpp DEVELOPER_LOCAL_TOOLS=1 BOOST_ROOT=/path/to/the/boost/you/built make release-static-64`
|
|
||||||
|
|
||||||
#### OpenBSD >= 6.2
|
|
||||||
|
|
||||||
You will need to add a few packages to your system. `pkg_add cmake zeromq libiconv`.
|
|
||||||
|
|
||||||
The doxygen and graphviz packages are optional and require the xbase set.
|
|
||||||
|
|
||||||
|
|
||||||
Build the Boost library using clang. This guide is derived from: https://github.com/bitcoin/bitcoin/blob/master/doc/build-openbsd.md
|
|
||||||
|
|
||||||
We assume you are compiling with a non-root user and you have `doas` enabled.
|
|
||||||
|
|
||||||
Note: do not use the boost package provided by OpenBSD, as we are installing boost to `/usr/local`.
|
|
||||||
|
|
||||||
```
|
|
||||||
# Create boost building directory
|
|
||||||
mkdir ~/boost
|
|
||||||
cd ~/boost
|
|
||||||
|
|
||||||
# Fetch boost source
|
|
||||||
ftp -o boost_1_64_0.tar.bz2 https://netcologne.dl.sourceforge.net/project/boost/boost/1.64.0/boost_1_64_0.tar.bz2
|
|
||||||
|
|
||||||
# MUST output: (SHA256) boost_1_64_0.tar.bz2: OK
|
|
||||||
echo "7bcc5caace97baa948931d712ea5f37038dbb1c5d89b43ad4def4ed7cb683332 boost_1_64_0.tar.bz2" | sha256 -c
|
|
||||||
tar xfj boost_1_64_0.tar.bz2
|
|
||||||
|
|
||||||
# Fetch and apply boost patches, required for OpenBSD
|
|
||||||
ftp -o boost_test_impl_execution_monitor_ipp.patch https://raw.githubusercontent.com/openbsd/ports/bee9e6df517077a7269ff0dfd57995f5c6a10379/devel/boost/patches/patch-boost_test_impl_execution_monitor_ipp
|
|
||||||
ftp -o boost_config_platform_bsd_hpp.patch https://raw.githubusercontent.com/openbsd/ports/90658284fb786f5a60dd9d6e8d14500c167bdaa0/devel/boost/patches/patch-boost_config_platform_bsd_hpp
|
|
||||||
|
|
||||||
# MUST output: (SHA256) boost_config_platform_bsd_hpp.patch: OK
|
|
||||||
echo "1f5e59d1154f16ee1e0cc169395f30d5e7d22a5bd9f86358f738b0ccaea5e51d boost_config_platform_bsd_hpp.patch" | sha256 -c
|
|
||||||
# MUST output: (SHA256) boost_test_impl_execution_monitor_ipp.patch: OK
|
|
||||||
echo "30cec182a1437d40c3e0bd9a866ab5ddc1400a56185b7e671bb3782634ed0206 boost_test_impl_execution_monitor_ipp.patch" | sha256 -c
|
|
||||||
|
|
||||||
cd boost_1_64_0
|
|
||||||
patch -p0 < ../boost_test_impl_execution_monitor_ipp.patch
|
|
||||||
patch -p0 < ../boost_config_platform_bsd_hpp.patch
|
|
||||||
|
|
||||||
# Start building boost
|
|
||||||
echo 'using clang : : c++ : <cxxflags>"-fvisibility=hidden -fPIC" <linkflags>"" <archiver>"ar" <striper>"strip" <ranlib>"ranlib" <rc>"" : ;' > user-config.jam
|
|
||||||
./bootstrap.sh --without-icu --with-libraries=chrono,filesystem,program_options,system,thread,test,date_time,regex,serialization,locale --with-toolset=clang
|
|
||||||
./b2 toolset=clang cxxflags="-stdlib=libc++" linkflags="-stdlib=libc++" -sICONV_PATH=/usr/local
|
|
||||||
doas ./b2 -d0 runtime-link=shared threadapi=pthread threading=multi link=static variant=release --layout=tagged --build-type=complete --user-config=user-config.jam -sNO_BZIP2=1 -sICONV_PATH=/usr/local --prefix=/usr/local install
|
|
||||||
```
|
|
||||||
|
|
||||||
Build cppzmq
|
|
||||||
|
|
||||||
Build the cppzmq bindings.
|
|
||||||
|
|
||||||
We assume you are compiling with a non-root user and you have `doas` enabled.
|
|
||||||
|
|
||||||
```
|
|
||||||
# Create cppzmq building directory
|
|
||||||
mkdir ~/cppzmq
|
|
||||||
cd ~/cppzmq
|
|
||||||
|
|
||||||
# Fetch cppzmq source
|
|
||||||
ftp -o cppzmq-4.2.3.tar.gz https://github.com/zeromq/cppzmq/archive/v4.2.3.tar.gz
|
|
||||||
|
|
||||||
# MUST output: (SHA256) cppzmq-4.2.3.tar.gz: OK
|
|
||||||
echo "3e6b57bf49115f4ae893b1ff7848ead7267013087dc7be1ab27636a97144d373 cppzmq-4.2.3.tar.gz" | sha256 -c
|
|
||||||
tar xfz cppzmq-4.2.3.tar.gz
|
|
||||||
|
|
||||||
# Start building cppzmq
|
|
||||||
cd cppzmq-4.2.3
|
|
||||||
mkdir build
|
|
||||||
cd build
|
|
||||||
cmake ..
|
|
||||||
doas make install
|
|
||||||
```
|
|
||||||
|
|
||||||
Build monero: `env DEVELOPER_LOCAL_TOOLS=1 BOOST_ROOT=/usr/local make release-static`
|
|
||||||
|
|
||||||
### On Solaris:
|
|
||||||
|
|
||||||
The default Solaris linker can't be used, you have to install GNU ld, then run cmake manually with the path to your copy of GNU ld:
|
|
||||||
|
|
||||||
mkdir -p build/release
|
|
||||||
cd build/release
|
|
||||||
cmake -DCMAKE_LINKER=/path/to/ld -D CMAKE_BUILD_TYPE=Release ../..
|
|
||||||
cd ../..
|
|
||||||
|
|
||||||
Then you can run make as usual.
|
|
||||||
|
|
||||||
### On Linux for Android (using docker):
|
|
||||||
|
|
||||||
# Build image (for ARM 32-bit)
|
|
||||||
docker build -f utils/build_scripts/android32.Dockerfile -t monero-android .
|
|
||||||
# Build image (for ARM 64-bit)
|
|
||||||
docker build -f utils/build_scripts/android64.Dockerfile -t monero-android .
|
|
||||||
# Create container
|
|
||||||
docker create -it --name monero-android monero-android bash
|
|
||||||
# Get binaries
|
|
||||||
docker cp monero-android:/src/build/release/bin .
|
|
||||||
|
|
||||||
### Building portable statically linked binaries
|
|
||||||
|
|
||||||
By default, in either dynamically or statically linked builds, binaries target the specific host processor on which the build happens and are not portable to other processors. Portable binaries can be built using the following targets:
|
|
||||||
|
|
||||||
* ```make release-static-linux-x86_64``` builds binaries on Linux on x86_64 portable across POSIX systems on x86_64 processors
|
|
||||||
* ```make release-static-linux-i686``` builds binaries on Linux on x86_64 or i686 portable across POSIX systems on i686 processors
|
|
||||||
* ```make release-static-linux-armv8``` builds binaries on Linux portable across POSIX systems on armv8 processors
|
|
||||||
* ```make release-static-linux-armv7``` builds binaries on Linux portable across POSIX systems on armv7 processors
|
|
||||||
* ```make release-static-linux-armv6``` builds binaries on Linux portable across POSIX systems on armv6 processors
|
|
||||||
* ```make release-static-win64``` builds binaries on 64-bit Windows portable across 64-bit Windows systems
|
|
||||||
* ```make release-static-win32``` builds binaries on 64-bit or 32-bit Windows portable across 32-bit Windows systems
|
|
||||||
|
|
||||||
### Cross Compiling
|
|
||||||
|
|
||||||
You can also cross-compile static binaries on Linux for Windows and macOS with the `depends` system.
|
|
||||||
|
|
||||||
* ```make depends target=x86_64-linux-gnu``` for 64-bit linux binaries.
|
|
||||||
* ```make depends target=x86_64-w64-mingw32``` for 64-bit windows binaries. Requires: python3 g++-mingw-w64-x86-64 wine1.6 bc
|
|
||||||
* ```make depends target=x86_64-apple-darwin11``` for macOS binaries. Requires: cmake imagemagick libcap-dev librsvg2-bin libz-dev libbz2-dev libtiff-tools python-dev
|
|
||||||
* ```make depends target=i686-linux-gnu``` for 32-bit linux binaries. Requires: g++-multilib bc
|
|
||||||
* ```make depends target=i686-w64-mingw32``` for 32-bit windows binaries. Requires: python3 g++-mingw-w64-i686
|
|
||||||
* ```make depends target=arm-linux-gnueabihf``` for armv7 binaries. Requires: g++-arm-linux-gnueabihf
|
|
||||||
* ```make depends target=aarch64-linux-gnu``` for armv8 binaries. Requires: g++-aarch64-linux-gnu
|
|
||||||
|
|
||||||
The required packages are the names for each toolchain on apt. Depending on your distro, they may have different names.
|
|
||||||
|
|
||||||
Using `depends` might also be easier to compile Monero on Windows than using MSYS. Activate Windows Subsystem for Linux (WSL) with a distro (for example Ubuntu), install the apt build-essentials and follow the `depends` steps as depicted above.
|
|
||||||
|
|
||||||
## Installing Monero from a package
|
|
||||||
|
|
||||||
**DISCLAIMER: These packages are not part of this repository or maintained by this project's contributors, and as such, do not go through the same review process to ensure their trustworthiness and security.**
|
|
||||||
|
|
||||||
Packages are available for
|
Packages are available for
|
||||||
|
|
||||||
* Ubuntu and [snap supported](https://snapcraft.io/docs/core/install) systems, via a community contributed build.
|
* Arch Linux/Manjaro
|
||||||
|
|
||||||
snap install monero --beta
|
yay -S wownero-git
|
||||||
|
|
||||||
Installing a snap is very quick. Snaps are secure. They are isolated with all of their dependencies. Snaps also auto update when a new version is released.
|
* NixOS
|
||||||
|
|
||||||
* Arch Linux (via [AUR](https://aur.archlinux.org/)):
|
nix-shell -p altcoins.wownero
|
||||||
- Stable release: [`monero`](https://aur.archlinux.org/packages/monero)
|
|
||||||
- Bleeding edge: [`monero-git`](https://aur.archlinux.org/packages/monero-git)
|
|
||||||
|
|
||||||
* Void Linux:
|
* Ubuntu 18.04/Ubuntu 16.04/Debian 9/Debian 8 (amd64)
|
||||||
|
|
||||||
xbps-install -S monero
|
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys B09DF0E4B0C56A94
|
||||||
|
sudo add-apt-repository "deb http://ppa.wownero.com/ bionic main"
|
||||||
* GuixSD
|
sudo apt-get update
|
||||||
|
sudo apt-get install wownero
|
||||||
guix package -i monero
|
|
||||||
|
|
||||||
* Docker
|
|
||||||
|
|
||||||
# Build using all available cores
|
|
||||||
docker build -t monero .
|
|
||||||
|
|
||||||
# or build using a specific number of cores (reduce RAM requirement)
|
|
||||||
docker build --build-arg NPROC=1 -t monero .
|
|
||||||
|
|
||||||
# either run in foreground
|
|
||||||
docker run -it -v /monero/chain:/root/.bitmonero -v /monero/wallet:/wallet -p 18080:18080 monero
|
|
||||||
|
|
||||||
# or in background
|
|
||||||
docker run -it -d -v /monero/chain:/root/.bitmonero -v /monero/wallet:/wallet -p 18080:18080 monero
|
|
||||||
|
|
||||||
* The build needs 3 GB space.
|
|
||||||
* Wait one hour or more
|
|
||||||
|
|
||||||
Packaging for your favorite distribution would be a welcome contribution!
|
Packaging for your favorite distribution would be a welcome contribution!
|
||||||
|
|
||||||
## Running monerod
|
**DISCLAIMER: These packages are not part of this repository, and as such, do not go through the same review process to ensure their trustworthiness and security.**
|
||||||
|
|
||||||
|
|
||||||
|
## Building from Source
|
||||||
|
|
||||||
|
* Arch Linux/Manjaro
|
||||||
|
|
||||||
|
sudo pacman -Syu && sudo pacman -S base-devel cmake boost openssl zeromq libpgm unbound libsodium git
|
||||||
|
git clone https://github.com/wownero/wownero
|
||||||
|
cd wownero
|
||||||
|
make
|
||||||
|
|
||||||
|
|
||||||
|
* Debian/Ubuntu
|
||||||
|
|
||||||
|
sudo apt update && sudo apt install build-essential cmake pkg-config libboost-all-dev libssl-dev libzmq3-dev libunbound-dev libsodium-dev libpgm-dev git
|
||||||
|
git clone https://github.com/wownero/wownero
|
||||||
|
cd wownero
|
||||||
|
make
|
||||||
|
|
||||||
|
|
||||||
|
## Running Binaries
|
||||||
|
|
||||||
The build places the binary in `bin/` sub-directory within the build directory
|
The build places the binary in `bin/` sub-directory within the build directory
|
||||||
from which cmake was invoked (repository root by default). To run in
|
from which cmake was invoked (repository root by default). To run in
|
||||||
foreground:
|
foreground:
|
||||||
|
|
||||||
./bin/monerod
|
./bin/wownerod
|
||||||
|
|
||||||
To list all available options, run `./bin/monerod --help`. Options can be
|
To list all available options, run `./bin/wownerod --help`. Options can be
|
||||||
specified either on the command line or in a configuration file passed by the
|
specified either on the command line or in a configuration file passed by the
|
||||||
`--config-file` argument. To specify an option in the configuration file, add
|
`--config-file` argument. To specify an option in the configuration file, add
|
||||||
a line with the syntax `argumentname=value`, where `argumentname` is the name
|
a line with the syntax `argumentname=value`, where `argumentname` is the name
|
||||||
@@ -580,130 +109,39 @@ of the argument without the leading dashes, for example `log-level=1`.
|
|||||||
|
|
||||||
To run in background:
|
To run in background:
|
||||||
|
|
||||||
./bin/monerod --log-file monerod.log --detach
|
./bin/wownerod --log-file wownerod.log --detach
|
||||||
|
|
||||||
To run as a systemd service, copy
|
To run as a systemd service, copy
|
||||||
[monerod.service](utils/systemd/monerod.service) to `/etc/systemd/system/` and
|
[wownerod.service](utils/systemd/wownerod.service) to `/etc/systemd/system/` and
|
||||||
[monerod.conf](utils/conf/monerod.conf) to `/etc/`. The [example
|
[wownerod.conf](utils/conf/wownerod.conf) to `/etc/`. The [example
|
||||||
service](utils/systemd/monerod.service) assumes that the user `monero` exists
|
service](utils/systemd/wownerod.service) assumes that the user `wownero` exists
|
||||||
and its home is the data directory specified in the [example
|
and its home is the data directory specified in the [example
|
||||||
config](utils/conf/monerod.conf).
|
config](utils/conf/wownerod.conf).
|
||||||
|
|
||||||
If you're on Mac, you may need to add the `--max-concurrency 1` option to
|
Once node is synced to network, run the CLI wallet by entering:
|
||||||
monero-wallet-cli, and possibly monerod, if you get crashes refreshing.
|
|
||||||
|
|
||||||
## Internationalization
|
./bin/wownero-wallet-cli
|
||||||
|
|
||||||
See [README.i18n.md](README.i18n.md).
|
Type `help` in CLI wallet to see standard commands (for advanced options, type `help_advanced`).
|
||||||
|
|
||||||
## Using Tor
|
## Wownero Graphical Wallets
|
||||||
|
|
||||||
While Monero isn't made to integrate with Tor, it can be used wrapped with torsocks, by
|
* [Wownero-Light-Wallet](https://github.com/wownero/Wownero-Light-Wallet)
|
||||||
setting the following configuration parameters and environment variables:
|
|
||||||
|
|
||||||
* `--p2p-bind-ip 127.0.0.1` on the command line or `p2p-bind-ip=127.0.0.1` in
|

|
||||||
monerod.conf to disable listening for connections on external interfaces.
|
|
||||||
* `--no-igd` on the command line or `no-igd=1` in monerod.conf to disable IGD
|
|
||||||
(UPnP port forwarding negotiation), which is pointless with Tor.
|
|
||||||
* `DNS_PUBLIC=tcp` or `DNS_PUBLIC=tcp://x.x.x.x` where x.x.x.x is the IP of the
|
|
||||||
desired DNS server, for DNS requests to go over TCP, so that they are routed
|
|
||||||
through Tor. When IP is not specified, monerod uses the default list of
|
|
||||||
servers defined in [src/common/dns_utils.cpp](src/common/dns_utils.cpp).
|
|
||||||
* `TORSOCKS_ALLOW_INBOUND=1` to tell torsocks to allow monerod to bind to interfaces
|
|
||||||
to accept connections from the wallet. On some Linux systems, torsocks
|
|
||||||
allows binding to localhost by default, so setting this variable is only
|
|
||||||
necessary to allow binding to local LAN/VPN interfaces to allow wallets to
|
|
||||||
connect from remote hosts. On other systems, it may be needed for local wallets
|
|
||||||
as well.
|
|
||||||
* Do NOT pass `--detach` when running through torsocks with systemd, (see
|
|
||||||
[utils/systemd/monerod.service](utils/systemd/monerod.service) for details).
|
|
||||||
* If you use the wallet with a Tor daemon via the loopback IP (eg, 127.0.0.1:9050),
|
|
||||||
then use `--untrusted-daemon` unless it is your own hidden service.
|
|
||||||
|
|
||||||
Example command line to start monerod through Tor:
|
|
||||||
|
|
||||||
DNS_PUBLIC=tcp torsocks monerod --p2p-bind-ip 127.0.0.1 --no-igd
|
* [Wownerujo Android Wallet](https://github.com/wownero/wownerujo)
|
||||||
|
|
||||||
### Using Tor on Tails
|

|
||||||
|

|
||||||
|
|
||||||
TAILS ships with a very restrictive set of firewall rules. Therefore, you need
|
## Donating to Wownero Project
|
||||||
to add a rule to allow this connection too, in addition to telling torsocks to
|
|
||||||
allow inbound connections. Full example:
|
|
||||||
|
|
||||||
sudo iptables -I OUTPUT 2 -p tcp -d 127.0.0.1 -m tcp --dport 18081 -j ACCEPT
|
Developers are volunteers doing this mostly for shits and giggles. If you would like to support our shenanigans and stimulant addictions, please consider donating to [WFS proposals](https://funding.wownero.com/proposals) or the [dev slush fund](https://funding.wownero.com/donate).
|
||||||
DNS_PUBLIC=tcp torsocks ./monerod --p2p-bind-ip 127.0.0.1 --no-igd --rpc-bind-ip 127.0.0.1 \
|
|
||||||
--data-dir /home/amnesia/Persistent/your/directory/to/the/blockchain
|
|
||||||
|
|
||||||
## Debugging
|
Donations may also be sent to:
|
||||||
|
|
||||||
This section contains general instructions for debugging failed installs or problems encountered with Monero. First ensure you are running the latest version built from the Github repo.
|
XMR: `44SQVPGLufPasUcuUQSZiF5c9BFzjcP8ucDxzzFDgLf1VkCEFaidJ3u2AhSKMhPLKA3jc2iS8wQHFcaigM6fXmo6AnFRn5B`
|
||||||
|
|
||||||
### Obtaining stack traces and core dumps on Unix systems
|
BTC: `bc1qcw9zglp3fxyl25zswemw7jczlqryms2lsmu464`
|
||||||
|
|
||||||
We generally use the tool `gdb` (GNU debugger) to provide stack trace functionality, and `ulimit` to provide core dumps in builds which crash or segfault.
|
|
||||||
|
|
||||||
* To use gdb in order to obtain a stack trace for a build that has stalled:
|
|
||||||
|
|
||||||
Run the build.
|
|
||||||
|
|
||||||
Once it stalls, enter the following command:
|
|
||||||
|
|
||||||
```
|
|
||||||
gdb /path/to/monerod `pidof monerod`
|
|
||||||
```
|
|
||||||
|
|
||||||
Type `thread apply all bt` within gdb in order to obtain the stack trace
|
|
||||||
|
|
||||||
* If however the core dumps or segfaults:
|
|
||||||
|
|
||||||
Enter `ulimit -c unlimited` on the command line to enable unlimited filesizes for core dumps
|
|
||||||
|
|
||||||
Enter `echo core | sudo tee /proc/sys/kernel/core_pattern` to stop cores from being hijacked by other tools
|
|
||||||
|
|
||||||
Run the build.
|
|
||||||
|
|
||||||
When it terminates with an output along the lines of "Segmentation fault (core dumped)", there should be a core dump file in the same directory as monerod. It may be named just `core`, or `core.xxxx` with numbers appended.
|
|
||||||
|
|
||||||
You can now analyse this core dump with `gdb` as follows:
|
|
||||||
|
|
||||||
`gdb /path/to/monerod /path/to/dumpfile`
|
|
||||||
|
|
||||||
Print the stack trace with `bt`
|
|
||||||
|
|
||||||
* To run monero within gdb:
|
|
||||||
|
|
||||||
Type `gdb /path/to/monerod`
|
|
||||||
|
|
||||||
Pass command-line options with `--args` followed by the relevant arguments
|
|
||||||
|
|
||||||
Type `run` to run monerod
|
|
||||||
|
|
||||||
### Analysing memory corruption
|
|
||||||
|
|
||||||
There are two tools available:
|
|
||||||
|
|
||||||
* ASAN
|
|
||||||
|
|
||||||
Configure Monero with the -D SANITIZE=ON cmake flag, eg:
|
|
||||||
|
|
||||||
cd build/debug && cmake -D SANITIZE=ON -D CMAKE_BUILD_TYPE=Debug ../..
|
|
||||||
|
|
||||||
You can then run the monero tools normally. Performance will typically halve.
|
|
||||||
|
|
||||||
* valgrind
|
|
||||||
|
|
||||||
Install valgrind and run as `valgrind /path/to/monerod`. It will be very slow.
|
|
||||||
|
|
||||||
### LMDB
|
|
||||||
|
|
||||||
Instructions for debugging suspected blockchain corruption as per @HYC
|
|
||||||
|
|
||||||
There is an `mdb_stat` command in the LMDB source that can print statistics about the database but it's not routinely built. This can be built with the following command:
|
|
||||||
|
|
||||||
`cd ~/monero/external/db_drivers/liblmdb && make`
|
|
||||||
|
|
||||||
The output of `mdb_stat -ea <path to blockchain dir>` will indicate inconsistencies in the blocks, block_heights and block_info table.
|
|
||||||
|
|
||||||
The output of `mdb_dump -s blocks <path to blockchain dir>` and `mdb_dump -s block_info <path to blockchain dir>` is useful for indicating whether blocks and block_info contain the same keys.
|
|
||||||
|
|
||||||
These records are dumped as hex data, where the first line is the key and the second line is the data.
|
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
# Copyright (c) 2014-2018, The Monero Project
|
# Copyright (c) 2014-2019, The Monero Project
|
||||||
#
|
#
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
# Copyright (c) 2014-2018, The Monero Project
|
# Copyright (c) 2014-2019, The Monero Project
|
||||||
#
|
#
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
|
|||||||
@@ -1,14 +1,56 @@
|
|||||||
OPTION(USE_DEVICE_TREZOR "Trezor support compilation" ON)
|
OPTION(USE_DEVICE_TREZOR "Trezor support compilation" OFF)
|
||||||
OPTION(USE_DEVICE_TREZOR_LIBUSB "Trezor LibUSB compilation" ON)
|
OPTION(USE_DEVICE_TREZOR_LIBUSB "Trezor LibUSB compilation" OFF)
|
||||||
OPTION(USE_DEVICE_TREZOR_UDP_RELEASE "Trezor UdpTransport in release mode" OFF)
|
OPTION(USE_DEVICE_TREZOR_UDP_RELEASE "Trezor UdpTransport in release mode" OFF)
|
||||||
|
|
||||||
|
# Helper function to fix cmake < 3.6.0 FindProtobuf variables
|
||||||
|
function(_trezor_protobuf_fix_vars)
|
||||||
|
if(${CMAKE_VERSION} VERSION_LESS "3.6.0")
|
||||||
|
foreach(UPPER
|
||||||
|
PROTOBUF_SRC_ROOT_FOLDER
|
||||||
|
PROTOBUF_IMPORT_DIRS
|
||||||
|
PROTOBUF_DEBUG
|
||||||
|
PROTOBUF_LIBRARY
|
||||||
|
PROTOBUF_PROTOC_LIBRARY
|
||||||
|
PROTOBUF_INCLUDE_DIR
|
||||||
|
PROTOBUF_PROTOC_EXECUTABLE
|
||||||
|
PROTOBUF_LIBRARY_DEBUG
|
||||||
|
PROTOBUF_PROTOC_LIBRARY_DEBUG
|
||||||
|
PROTOBUF_LITE_LIBRARY
|
||||||
|
PROTOBUF_LITE_LIBRARY_DEBUG
|
||||||
|
)
|
||||||
|
if (DEFINED ${UPPER})
|
||||||
|
string(REPLACE "PROTOBUF_" "Protobuf_" Camel ${UPPER})
|
||||||
|
if (NOT DEFINED ${Camel})
|
||||||
|
set(${Camel} ${${UPPER}} PARENT_SCOPE)
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
endif()
|
||||||
|
endfunction()
|
||||||
|
|
||||||
# Use Trezor master switch
|
# Use Trezor master switch
|
||||||
if (USE_DEVICE_TREZOR)
|
if (USE_DEVICE_TREZOR)
|
||||||
# Protobuf is required to build protobuf messages for Trezor
|
# Protobuf is required to build protobuf messages for Trezor
|
||||||
include(FindProtobuf OPTIONAL)
|
include(FindProtobuf OPTIONAL)
|
||||||
find_package(Protobuf)
|
find_package(Protobuf)
|
||||||
if(NOT Protobuf_FOUND)
|
_trezor_protobuf_fix_vars()
|
||||||
|
|
||||||
|
# Protobuf handling the cache variables set in docker.
|
||||||
|
if(NOT Protobuf_FOUND AND NOT Protobuf_LIBRARY AND NOT Protobuf_PROTOC_EXECUTABLE AND NOT Protobuf_INCLUDE_DIR)
|
||||||
message(STATUS "Could not find Protobuf")
|
message(STATUS "Could not find Protobuf")
|
||||||
|
elseif(NOT Protobuf_LIBRARY OR NOT EXISTS "${Protobuf_LIBRARY}")
|
||||||
|
message(STATUS "Protobuf library not found: ${Protobuf_LIBRARY}")
|
||||||
|
unset(Protobuf_FOUND)
|
||||||
|
elseif(NOT Protobuf_PROTOC_EXECUTABLE OR NOT EXISTS "${Protobuf_PROTOC_EXECUTABLE}")
|
||||||
|
message(STATUS "Protobuf executable not found: ${Protobuf_PROTOC_EXECUTABLE}")
|
||||||
|
unset(Protobuf_FOUND)
|
||||||
|
elseif(NOT Protobuf_INCLUDE_DIR OR NOT EXISTS "${Protobuf_INCLUDE_DIR}")
|
||||||
|
message(STATUS "Protobuf include dir not found: ${Protobuf_INCLUDE_DIR}")
|
||||||
|
unset(Protobuf_FOUND)
|
||||||
|
else()
|
||||||
|
message(STATUS "Protobuf lib: ${Protobuf_LIBRARY}, inc: ${Protobuf_INCLUDE_DIR}, protoc: ${Protobuf_PROTOC_EXECUTABLE}")
|
||||||
|
set(Protobuf_INCLUDE_DIRS ${Protobuf_INCLUDE_DIR})
|
||||||
|
set(Protobuf_FOUND 1) # override found if all rquired info was provided by variables
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
else()
|
else()
|
||||||
@@ -37,9 +79,32 @@ if(Protobuf_FOUND AND USE_DEVICE_TREZOR)
|
|||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Try to build protobuf messages
|
# Protobuf compilation test
|
||||||
if(Protobuf_FOUND AND USE_DEVICE_TREZOR AND TREZOR_PYTHON)
|
if(Protobuf_FOUND AND USE_DEVICE_TREZOR AND TREZOR_PYTHON)
|
||||||
set(ENV{PROTOBUF_INCLUDE_DIRS} "${Protobuf_INCLUDE_DIRS}")
|
execute_process(COMMAND ${Protobuf_PROTOC_EXECUTABLE} -I "${CMAKE_SOURCE_DIR}/cmake" -I "${Protobuf_INCLUDE_DIR}" "${CMAKE_SOURCE_DIR}/cmake/test-protobuf.proto" --cpp_out ${CMAKE_BINARY_DIR} RESULT_VARIABLE RET OUTPUT_VARIABLE OUT ERROR_VARIABLE ERR)
|
||||||
|
if(RET)
|
||||||
|
message(STATUS "Protobuf test generation failed: ${OUT} ${ERR}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
try_compile(Protobuf_COMPILE_TEST_PASSED
|
||||||
|
"${CMAKE_BINARY_DIR}"
|
||||||
|
SOURCES
|
||||||
|
"${CMAKE_BINARY_DIR}/test-protobuf.pb.cc"
|
||||||
|
"${CMAKE_SOURCE_DIR}/cmake/test-protobuf.cpp"
|
||||||
|
CMAKE_FLAGS
|
||||||
|
"-DINCLUDE_DIRECTORIES=${Protobuf_INCLUDE_DIR};${CMAKE_BINARY_DIR}"
|
||||||
|
"-DCMAKE_CXX_STANDARD=11"
|
||||||
|
LINK_LIBRARIES ${Protobuf_LIBRARY}
|
||||||
|
OUTPUT_VARIABLE OUTPUT
|
||||||
|
)
|
||||||
|
if(NOT Protobuf_COMPILE_TEST_PASSED)
|
||||||
|
message(STATUS "Protobuf Compilation test failed: ${OUTPUT}.")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Try to build protobuf messages
|
||||||
|
if(Protobuf_FOUND AND USE_DEVICE_TREZOR AND TREZOR_PYTHON AND Protobuf_COMPILE_TEST_PASSED)
|
||||||
|
set(ENV{PROTOBUF_INCLUDE_DIRS} "${Protobuf_INCLUDE_DIR}")
|
||||||
set(ENV{PROTOBUF_PROTOC_EXECUTABLE} "${Protobuf_PROTOC_EXECUTABLE}")
|
set(ENV{PROTOBUF_PROTOC_EXECUTABLE} "${Protobuf_PROTOC_EXECUTABLE}")
|
||||||
execute_process(COMMAND ${TREZOR_PYTHON} tools/build_protob.py WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}/../src/device_trezor/trezor RESULT_VARIABLE RET OUTPUT_VARIABLE OUT ERROR_VARIABLE ERR)
|
execute_process(COMMAND ${TREZOR_PYTHON} tools/build_protob.py WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}/../src/device_trezor/trezor RESULT_VARIABLE RET OUTPUT_VARIABLE OUT ERROR_VARIABLE ERR)
|
||||||
if(RET)
|
if(RET)
|
||||||
@@ -47,9 +112,10 @@ if(Protobuf_FOUND AND USE_DEVICE_TREZOR AND TREZOR_PYTHON)
|
|||||||
"OUT: ${OUT}, ERR: ${ERR}."
|
"OUT: ${OUT}, ERR: ${ERR}."
|
||||||
"Please read src/device_trezor/trezor/tools/README.md")
|
"Please read src/device_trezor/trezor/tools/README.md")
|
||||||
else()
|
else()
|
||||||
message(STATUS "Trezor protobuf messages regenerated ${OUT}")
|
message(STATUS "Trezor protobuf messages regenerated out: \"${OUT}.\"")
|
||||||
set(DEVICE_TREZOR_READY 1)
|
set(DEVICE_TREZOR_READY 1)
|
||||||
add_definitions(-DDEVICE_TREZOR_READY=1)
|
add_definitions(-DDEVICE_TREZOR_READY=1)
|
||||||
|
add_definitions(-DPROTOBUF_INLINE_NOT_IN_HEADERS=0)
|
||||||
|
|
||||||
if(CMAKE_BUILD_TYPE STREQUAL "Debug")
|
if(CMAKE_BUILD_TYPE STREQUAL "Debug")
|
||||||
add_definitions(-DTREZOR_DEBUG=1)
|
add_definitions(-DTREZOR_DEBUG=1)
|
||||||
@@ -75,5 +141,26 @@ if(Protobuf_FOUND AND USE_DEVICE_TREZOR AND TREZOR_PYTHON)
|
|||||||
include_directories(${LibUSB_INCLUDE_DIRS})
|
include_directories(${LibUSB_INCLUDE_DIRS})
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
set(TREZOR_LIBUSB_LIBRARIES "")
|
||||||
|
if(LibUSB_COMPILE_TEST_PASSED)
|
||||||
|
list(APPEND TREZOR_LIBUSB_LIBRARIES ${LibUSB_LIBRARIES})
|
||||||
|
message(STATUS "Trezor compatible LibUSB found at: ${LibUSB_INCLUDE_DIRS}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if (BUILD_GUI_DEPS)
|
||||||
|
set(TREZOR_DEP_LIBS "")
|
||||||
|
set(TREZOR_DEP_LINKER "")
|
||||||
|
|
||||||
|
if (Protobuf_LIBRARY)
|
||||||
|
list(APPEND TREZOR_DEP_LIBS ${Protobuf_LIBRARY})
|
||||||
|
string(APPEND TREZOR_DEP_LINKER " -lprotobuf")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if (TREZOR_LIBUSB_LIBRARIES)
|
||||||
|
list(APPEND TREZOR_DEP_LIBS ${TREZOR_LIBUSB_LIBRARIES})
|
||||||
|
string(APPEND TREZOR_DEP_LINKER " -lusb-1.0")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
# Copyright (c) 2014-2018, The Monero Project
|
# Copyright (c) 2014-2019, The Monero Project
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
# Redistribution and use in source and binary forms, with or without modification, are
|
# Redistribution and use in source and binary forms, with or without modification, are
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
# Copyright (c) 2014-2018, The Monero Project
|
# Copyright (c) 2014-2019, The Monero Project
|
||||||
#
|
#
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
# Copyright (c) 2014-2018, The Monero Project
|
# Copyright (c) 2014-2019, The Monero Project
|
||||||
#
|
#
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2019, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
43
cmake/test-protobuf.cpp
Normal file
43
cmake/test-protobuf.cpp
Normal file
@@ -0,0 +1,43 @@
|
|||||||
|
// Copyright (c) 2014-2019, The Monero Project
|
||||||
|
//
|
||||||
|
// All rights reserved.
|
||||||
|
//
|
||||||
|
// Redistribution and use in source and binary forms, with or without modification, are
|
||||||
|
// permitted provided that the following conditions are met:
|
||||||
|
//
|
||||||
|
// 1. Redistributions of source code must retain the above copyright notice, this list of
|
||||||
|
// conditions and the following disclaimer.
|
||||||
|
//
|
||||||
|
// 2. Redistributions in binary form must reproduce the above copyright notice, this list
|
||||||
|
// of conditions and the following disclaimer in the documentation and/or other
|
||||||
|
// materials provided with the distribution.
|
||||||
|
//
|
||||||
|
// 3. Neither the name of the copyright holder nor the names of its contributors may be
|
||||||
|
// used to endorse or promote products derived from this software without specific
|
||||||
|
// prior written permission.
|
||||||
|
//
|
||||||
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
|
||||||
|
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||||
|
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
||||||
|
// THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
||||||
|
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
|
||||||
|
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
#include <iostream>
|
||||||
|
#include <google/protobuf/message.h>
|
||||||
|
#include <google/protobuf/unknown_field_set.h>
|
||||||
|
#include "test-protobuf.pb.h"
|
||||||
|
|
||||||
|
int main(int argc, char *argv[]) {
|
||||||
|
google::protobuf::UnknownFieldSet ufs;
|
||||||
|
ufs.ClearAndFreeMemory();
|
||||||
|
|
||||||
|
Success sc;
|
||||||
|
sc.set_message("test");
|
||||||
|
sc.SerializeToOstream(&std::cerr);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
7
cmake/test-protobuf.proto
Normal file
7
cmake/test-protobuf.proto
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
syntax = "proto2";
|
||||||
|
|
||||||
|
import "google/protobuf/descriptor.proto";
|
||||||
|
|
||||||
|
message Success {
|
||||||
|
optional string message = 1;
|
||||||
|
}
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2019, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2019, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
# Copyright (c) 2014-2018, The Monero Project
|
# Copyright (c) 2014-2019, The Monero Project
|
||||||
#
|
#
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
@@ -26,10 +26,5 @@
|
|||||||
# STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
|
# STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
|
||||||
# THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
# THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
# warnings are cleared only for GCC on Linux
|
|
||||||
if (NOT (MINGW OR APPLE OR FREEBSD OR OPENBSD OR DRAGONFLY))
|
|
||||||
add_compile_options("${WARNINGS_AS_ERRORS_FLAG}") # applies only to targets that follow
|
|
||||||
endif()
|
|
||||||
|
|
||||||
add_subdirectory(epee)
|
add_subdirectory(epee)
|
||||||
|
|
||||||
|
|||||||
@@ -3,9 +3,6 @@
|
|||||||
SOURCES_PATH ?= $(BASEDIR)/sources
|
SOURCES_PATH ?= $(BASEDIR)/sources
|
||||||
BASE_CACHE ?= $(BASEDIR)/built
|
BASE_CACHE ?= $(BASEDIR)/built
|
||||||
SDK_PATH ?= $(BASEDIR)/SDKs
|
SDK_PATH ?= $(BASEDIR)/SDKs
|
||||||
NO_QT ?=
|
|
||||||
NO_WALLET ?=
|
|
||||||
NO_UPNP ?=
|
|
||||||
FALLBACK_DOWNLOAD_PATH ?= https://bitcoincore.org/depends-sources
|
FALLBACK_DOWNLOAD_PATH ?= https://bitcoincore.org/depends-sources
|
||||||
|
|
||||||
BUILD = $(shell ./config.guess)
|
BUILD = $(shell ./config.guess)
|
||||||
@@ -97,17 +94,10 @@ $(host_arch)_$(host_os)_id_string+=$(shell $(host_CXX) --version 2>/dev/null)
|
|||||||
$(host_arch)_$(host_os)_id_string+=$(shell $(host_RANLIB) --version 2>/dev/null)
|
$(host_arch)_$(host_os)_id_string+=$(shell $(host_RANLIB) --version 2>/dev/null)
|
||||||
$(host_arch)_$(host_os)_id_string+=$(shell $(host_STRIP) --version 2>/dev/null)
|
$(host_arch)_$(host_os)_id_string+=$(shell $(host_STRIP) --version 2>/dev/null)
|
||||||
|
|
||||||
qt_packages_$(NO_QT) = $(qt_packages) $(qt_$(host_os)_packages) $(qt_$(host_arch)_$(host_os)_packages)
|
|
||||||
wallet_packages_$(NO_WALLET) = $(wallet_packages)
|
|
||||||
upnp_packages_$(NO_UPNP) = $(upnp_packages)
|
|
||||||
|
|
||||||
packages += $($(host_arch)_$(host_os)_packages) $($(host_os)_packages) $(qt_packages_) $(wallet_packages_) $(upnp_packages_)
|
packages += $($(host_arch)_$(host_os)_packages) $($(host_os)_packages)
|
||||||
native_packages += $($(host_arch)_$(host_os)_native_packages) $($(host_os)_native_packages)
|
native_packages += $($(host_arch)_$(host_os)_native_packages) $($(host_os)_native_packages)
|
||||||
|
|
||||||
ifneq ($(qt_packages_),)
|
|
||||||
native_packages += $(qt_native_packages)
|
|
||||||
endif
|
|
||||||
|
|
||||||
all_packages = $(packages) $(native_packages)
|
all_packages = $(packages) $(native_packages)
|
||||||
|
|
||||||
meta_depends = Makefile funcs.mk builders/default.mk hosts/default.mk hosts/$(host_os).mk builders/$(build_os).mk
|
meta_depends = Makefile funcs.mk builders/default.mk hosts/default.mk hosts/$(host_os).mk builders/$(build_os).mk
|
||||||
@@ -153,9 +143,6 @@ $(host_prefix)/share/config.site : config.site.in $(host_prefix)/.stamp_$(final_
|
|||||||
-e 's|@CPPFLAGS@|$(strip $(host_CPPFLAGS) $(host_$(release_type)_CPPFLAGS))|' \
|
-e 's|@CPPFLAGS@|$(strip $(host_CPPFLAGS) $(host_$(release_type)_CPPFLAGS))|' \
|
||||||
-e 's|@LDFLAGS@|$(strip $(host_LDFLAGS) $(host_$(release_type)_LDFLAGS))|' \
|
-e 's|@LDFLAGS@|$(strip $(host_LDFLAGS) $(host_$(release_type)_LDFLAGS))|' \
|
||||||
-e 's|@allow_host_packages@|$(ALLOW_HOST_PACKAGES)|' \
|
-e 's|@allow_host_packages@|$(ALLOW_HOST_PACKAGES)|' \
|
||||||
-e 's|@no_qt@|$(NO_QT)|' \
|
|
||||||
-e 's|@no_wallet@|$(NO_WALLET)|' \
|
|
||||||
-e 's|@no_upnp@|$(NO_UPNP)|' \
|
|
||||||
-e 's|@debug@|$(DEBUG)|' \
|
-e 's|@debug@|$(DEBUG)|' \
|
||||||
$< > $@
|
$< > $@
|
||||||
$(AT)touch $@
|
$(AT)touch $@
|
||||||
@@ -176,9 +163,6 @@ $(host_prefix)/share/toolchain.cmake : toolchain.cmake.in $(host_prefix)/.stamp_
|
|||||||
-e 's|@CPPFLAGS@|$(strip $(host_CPPFLAGS) $(host_$(release_type)_CPPFLAGS))|' \
|
-e 's|@CPPFLAGS@|$(strip $(host_CPPFLAGS) $(host_$(release_type)_CPPFLAGS))|' \
|
||||||
-e 's|@LDFLAGS@|$(strip $(host_LDFLAGS) $(host_$(release_type)_LDFLAGS))|' \
|
-e 's|@LDFLAGS@|$(strip $(host_LDFLAGS) $(host_$(release_type)_LDFLAGS))|' \
|
||||||
-e 's|@allow_host_packages@|$(ALLOW_HOST_PACKAGES)|' \
|
-e 's|@allow_host_packages@|$(ALLOW_HOST_PACKAGES)|' \
|
||||||
-e 's|@no_qt@|$(NO_QT)|' \
|
|
||||||
-e 's|@no_wallet@|$(NO_WALLET)|' \
|
|
||||||
-e 's|@no_upnp@|$(NO_UPNP)|' \
|
|
||||||
-e 's|@debug@|$(DEBUG)|' \
|
-e 's|@debug@|$(DEBUG)|' \
|
||||||
-e 's|@depends@|$(host_cmake)|' \
|
-e 's|@depends@|$(host_cmake)|' \
|
||||||
-e 's|@prefix@|$($(host_arch)_$(host_os)_prefix)|'\
|
-e 's|@prefix@|$($(host_arch)_$(host_os)_prefix)|'\
|
||||||
|
|||||||
@@ -12,11 +12,11 @@ For example:
|
|||||||
|
|
||||||
make HOST=x86_64-w64-mingw32 -j4
|
make HOST=x86_64-w64-mingw32 -j4
|
||||||
|
|
||||||
A prefix will be generated that's suitable for plugging into Bitcoin's
|
A toolchain will be generated that's suitable for plugging into Monero's
|
||||||
configure. In the above example, a dir named x86_64-w64-mingw32 will be
|
cmake. In the above example, a dir named x86_64-w64-mingw32 will be
|
||||||
created. To use it for Bitcoin:
|
created. To use it for Monero:
|
||||||
|
|
||||||
./configure --prefix=`pwd`/depends/x86_64-w64-mingw32
|
cmake -DCMAKE_TOOLCHAIN=`pwd`/contrib/depends/x86_64-w64-mingw32
|
||||||
|
|
||||||
Common `host-platform-triplets` for cross compilation are:
|
Common `host-platform-triplets` for cross compilation are:
|
||||||
|
|
||||||
@@ -35,16 +35,10 @@ The following can be set when running make: make FOO=bar
|
|||||||
BASE_CACHE: built packages will be placed here
|
BASE_CACHE: built packages will be placed here
|
||||||
SDK_PATH: Path where sdk's can be found (used by OSX)
|
SDK_PATH: Path where sdk's can be found (used by OSX)
|
||||||
FALLBACK_DOWNLOAD_PATH: If a source file can't be fetched, try here before giving up
|
FALLBACK_DOWNLOAD_PATH: If a source file can't be fetched, try here before giving up
|
||||||
NO_QT: Don't download/build/cache qt and its dependencies
|
|
||||||
NO_WALLET: Don't download/build/cache libs needed to enable the wallet
|
|
||||||
NO_UPNP: Don't download/build/cache packages needed for enabling upnp
|
|
||||||
DEBUG: disable some optimizations and enable more runtime checking
|
DEBUG: disable some optimizations and enable more runtime checking
|
||||||
HOST_ID_SALT: Optional salt to use when generating host package ids
|
HOST_ID_SALT: Optional salt to use when generating host package ids
|
||||||
BUILD_ID_SALT: Optional salt to use when generating build package ids
|
BUILD_ID_SALT: Optional salt to use when generating build package ids
|
||||||
|
|
||||||
If some packages are not built, for example `make NO_WALLET=1`, the appropriate
|
|
||||||
options will be passed to bitcoin's configure. In this case, `--disable-wallet`.
|
|
||||||
|
|
||||||
Additional targets:
|
Additional targets:
|
||||||
|
|
||||||
download: run 'make download' to fetch all sources without building them
|
download: run 'make download' to fetch all sources without building them
|
||||||
@@ -59,6 +53,16 @@ Download it from apple, or search for it on github. Create a new directoty calle
|
|||||||
directory and place the entire MacOSX10.11.sdk folder in it. The depends build will then pick it up automatically
|
directory and place the entire MacOSX10.11.sdk folder in it. The depends build will then pick it up automatically
|
||||||
(without requiring SDK_PATH).
|
(without requiring SDK_PATH).
|
||||||
|
|
||||||
|
|
||||||
|
#Mingw builds
|
||||||
|
|
||||||
|
Building for 32/64bit mingw requires switching alternatives to a posix mode
|
||||||
|
|
||||||
|
```bash
|
||||||
|
update-alternatives --set x86_64-w64-mingw32-g++ x86_64-w64-mingw32-g++-posix
|
||||||
|
update-alternatives --set x86_64-w64-mingw32-gcc x86_64-w64-mingw32-gcc-posix
|
||||||
|
```
|
||||||
|
|
||||||
### Other documentation
|
### Other documentation
|
||||||
|
|
||||||
- [description.md](description.md): General description of the depends system
|
- [description.md](description.md): General description of the depends system
|
||||||
|
|||||||
@@ -13,25 +13,6 @@ fi
|
|||||||
if test -z $with_qt_translationdir; then
|
if test -z $with_qt_translationdir; then
|
||||||
with_qt_translationdir=$depends_prefix/translations
|
with_qt_translationdir=$depends_prefix/translations
|
||||||
fi
|
fi
|
||||||
if test -z $with_qt_bindir && test -z "@no_qt@"; then
|
|
||||||
with_qt_bindir=$depends_prefix/native/bin
|
|
||||||
fi
|
|
||||||
if test -z $with_protoc_bindir && test -z "@no_qt@"; then
|
|
||||||
with_protoc_bindir=$depends_prefix/native/bin
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
||||||
if test -z $enable_wallet && test -n "@no_wallet@"; then
|
|
||||||
enable_wallet=no
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test -z $with_miniupnpc && test -n "@no_upnp@"; then
|
|
||||||
with_miniupnpc=no
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test -z $with_gui && test -n "@no_qt@"; then
|
|
||||||
with_gui=no
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test x@host_os@ = xdarwin; then
|
if test x@host_os@ = xdarwin; then
|
||||||
BREW=no
|
BREW=no
|
||||||
|
|||||||
@@ -1,31 +0,0 @@
|
|||||||
package=bdb
|
|
||||||
$(package)_version=4.8.30
|
|
||||||
$(package)_download_path=https://download.oracle.com/berkeley-db
|
|
||||||
$(package)_file_name=db-$($(package)_version).NC.tar.gz
|
|
||||||
$(package)_sha256_hash=12edc0df75bf9abd7f82f821795bcee50f42cb2e5f76a6a281b85732798364ef
|
|
||||||
$(package)_build_subdir=build_unix
|
|
||||||
|
|
||||||
define $(package)_set_vars
|
|
||||||
$(package)_config_opts=--disable-shared --enable-cxx --disable-replication
|
|
||||||
$(package)_config_opts_mingw32=--enable-mingw
|
|
||||||
$(package)_config_opts_linux=--with-pic
|
|
||||||
$(package)_cxxflags=-std=c++11
|
|
||||||
endef
|
|
||||||
|
|
||||||
define $(package)_preprocess_cmds
|
|
||||||
sed -i.old 's/__atomic_compare_exchange/__atomic_compare_exchange_db/' dbinc/atomic.h && \
|
|
||||||
sed -i.old 's/atomic_init/atomic_init_db/' dbinc/atomic.h mp/mp_region.c mp/mp_mvcc.c mp/mp_fget.c mutex/mut_method.c mutex/mut_tas.c && \
|
|
||||||
cp -f $(BASEDIR)/config.guess $(BASEDIR)/config.sub dist
|
|
||||||
endef
|
|
||||||
|
|
||||||
define $(package)_config_cmds
|
|
||||||
../dist/$($(package)_autoconf)
|
|
||||||
endef
|
|
||||||
|
|
||||||
define $(package)_build_cmds
|
|
||||||
$(MAKE) libdb_cxx-4.8.a libdb-4.8.a
|
|
||||||
endef
|
|
||||||
|
|
||||||
define $(package)_stage_cmds
|
|
||||||
$(MAKE) DESTDIR=$($(package)_staging_dir) install_lib install_include
|
|
||||||
endef
|
|
||||||
@@ -20,7 +20,7 @@ $(package)_archiver_$(host_os)=$($(package)_ar)
|
|||||||
$(package)_toolset_darwin=darwin
|
$(package)_toolset_darwin=darwin
|
||||||
$(package)_archiver_darwin=$($(package)_libtool)
|
$(package)_archiver_darwin=$($(package)_libtool)
|
||||||
$(package)_config_libraries=chrono,filesystem,program_options,system,thread,test,date_time,regex,serialization,locale
|
$(package)_config_libraries=chrono,filesystem,program_options,system,thread,test,date_time,regex,serialization,locale
|
||||||
$(package)_cxxflags=-std=c++11 -fvisibility=hidden
|
$(package)_cxxflags=-std=c++11
|
||||||
$(package)_cxxflags_linux=-fPIC
|
$(package)_cxxflags_linux=-fPIC
|
||||||
endef
|
endef
|
||||||
|
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ $(package)_sha256_hash=1f912c54035533fb4268809701d65c7468d00e292efbc31e644490845
|
|||||||
$(package)_patches=icu-001-dont-build-static-dynamic-twice.patch
|
$(package)_patches=icu-001-dont-build-static-dynamic-twice.patch
|
||||||
|
|
||||||
define $(package)_set_vars
|
define $(package)_set_vars
|
||||||
$(package)_build_opts=CFLAGS="$($(package)_cflags) $($(package)_cppflags) -DU_USING_ICU_NAMESPACE=0 --std=gnu++0x -DU_STATIC_IMPLEMENTATION -DU_COMBINED_IMPLEMENTATION -fPIC"
|
$(package)_build_opts=CFLAGS="$($(package)_cflags) $($(package)_cppflags) -DU_USING_ICU_NAMESPACE=0 --std=gnu++0x -DU_STATIC_IMPLEMENTATION -DU_COMBINED_IMPLEMENTATION -fPIC -DENABLE_STATIC=YES -DPGKDATA_MODE=static"
|
||||||
endef
|
endef
|
||||||
|
|
||||||
define $(package)_config_cmds
|
define $(package)_config_cmds
|
||||||
@@ -17,7 +17,7 @@ define $(package)_config_cmds
|
|||||||
sh ../source/runConfigureICU Linux &&\
|
sh ../source/runConfigureICU Linux &&\
|
||||||
make &&\
|
make &&\
|
||||||
cd ../buildb &&\
|
cd ../buildb &&\
|
||||||
sh ../source/$($(package)_autoconf) --enable-static=yes --enable-shared=yes --disable-layoutex --prefix=$(host_prefix) --with-cross-build=`pwd`/../builda &&\
|
sh ../source/$($(package)_autoconf) --enable-static=yes --disable-shared --disable-layout --disable-layoutex --disable-tests --disable-samples --prefix=$(host_prefix) --with-cross-build=`pwd`/../builda &&\
|
||||||
$(MAKE) $($(package)_build_opts)
|
$(MAKE) $($(package)_build_opts)
|
||||||
endef
|
endef
|
||||||
|
|
||||||
|
|||||||
@@ -1,30 +0,0 @@
|
|||||||
package=libevent
|
|
||||||
$(package)_version=2.1.8-stable
|
|
||||||
$(package)_download_path=https://github.com/libevent/libevent/archive/
|
|
||||||
$(package)_file_name=release-$($(package)_version).tar.gz
|
|
||||||
$(package)_sha256_hash=316ddb401745ac5d222d7c529ef1eada12f58f6376a66c1118eee803cb70f83d
|
|
||||||
|
|
||||||
define $(package)_preprocess_cmds
|
|
||||||
./autogen.sh
|
|
||||||
endef
|
|
||||||
|
|
||||||
define $(package)_set_vars
|
|
||||||
$(package)_config_opts=--disable-shared --disable-openssl --disable-libevent-regress --disable-samples
|
|
||||||
$(package)_config_opts_release=--disable-debug-mode
|
|
||||||
$(package)_config_opts_linux=--with-pic
|
|
||||||
endef
|
|
||||||
|
|
||||||
define $(package)_config_cmds
|
|
||||||
$($(package)_autoconf)
|
|
||||||
endef
|
|
||||||
|
|
||||||
define $(package)_build_cmds
|
|
||||||
$(MAKE)
|
|
||||||
endef
|
|
||||||
|
|
||||||
define $(package)_stage_cmds
|
|
||||||
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
|
||||||
endef
|
|
||||||
|
|
||||||
define $(package)_postprocess_cmds
|
|
||||||
endef
|
|
||||||
@@ -11,13 +11,21 @@ endef
|
|||||||
define $(package)_set_vars
|
define $(package)_set_vars
|
||||||
$(package)_config_opts=--disable-shared
|
$(package)_config_opts=--disable-shared
|
||||||
$(package)_config_opts_linux=--with-pic --disable-udev
|
$(package)_config_opts_linux=--with-pic --disable-udev
|
||||||
|
$(package)_config_opts_mingw32=--disable-udev
|
||||||
|
$(package)_config_opts_darwin=--disable-udev
|
||||||
endef
|
endef
|
||||||
|
|
||||||
define $(package)_config_cmds
|
ifneq ($(host_os),darwin)
|
||||||
cp -f $(BASEDIR)/config.guess config.guess &&\
|
define $(package)_config_cmds
|
||||||
cp -f $(BASEDIR)/config.sub config.sub &&\
|
cp -f $(BASEDIR)/config.guess config.guess &&\
|
||||||
$($(package)_autoconf)
|
cp -f $(BASEDIR)/config.sub config.sub &&\
|
||||||
endef
|
$($(package)_autoconf)
|
||||||
|
endef
|
||||||
|
else
|
||||||
|
define $(package)_config_cmds
|
||||||
|
$($(package)_autoconf)
|
||||||
|
endef
|
||||||
|
endif
|
||||||
|
|
||||||
define $(package)_build_cmd
|
define $(package)_build_cmd
|
||||||
$(MAKE)
|
$(MAKE)
|
||||||
@@ -27,5 +35,5 @@ define $(package)_stage_cmds
|
|||||||
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
||||||
endef
|
endef
|
||||||
|
|
||||||
define $(package)_postprocess_cmds cp -f lib/libusb-1.0.a lib/libusb.a
|
define $(package)_postprocess_cmds cp -f lib/libusb-1.0.a lib/libusb.a
|
||||||
endef
|
endef
|
||||||
|
|||||||
@@ -1,28 +0,0 @@
|
|||||||
package=miniupnpc
|
|
||||||
$(package)_version=2.0.20170509
|
|
||||||
$(package)_download_path=http://miniupnp.free.fr/files
|
|
||||||
$(package)_file_name=$(package)-$($(package)_version).tar.gz
|
|
||||||
$(package)_sha256_hash=d3c368627f5cdfb66d3ebd64ca39ba54d6ff14a61966dbecb8dd296b7039f16a
|
|
||||||
|
|
||||||
define $(package)_set_vars
|
|
||||||
$(package)_build_opts=CC="$($(package)_cc)"
|
|
||||||
$(package)_build_opts_darwin=OS=Darwin LIBTOOL="$($(package)_libtool)"
|
|
||||||
$(package)_build_opts_mingw32=-f Makefile.mingw
|
|
||||||
$(package)_build_env+=CFLAGS="$($(package)_cflags) $($(package)_cppflags)" AR="$($(package)_ar)"
|
|
||||||
endef
|
|
||||||
|
|
||||||
define $(package)_preprocess_cmds
|
|
||||||
mkdir dll && \
|
|
||||||
sed -e 's|MINIUPNPC_VERSION_STRING \"version\"|MINIUPNPC_VERSION_STRING \"$($(package)_version)\"|' -e 's|OS/version|$(host)|' miniupnpcstrings.h.in > miniupnpcstrings.h && \
|
|
||||||
sed -i.old "s|miniupnpcstrings.h: miniupnpcstrings.h.in wingenminiupnpcstrings|miniupnpcstrings.h: miniupnpcstrings.h.in|" Makefile.mingw
|
|
||||||
endef
|
|
||||||
|
|
||||||
define $(package)_build_cmds
|
|
||||||
$(MAKE) libminiupnpc.a $($(package)_build_opts)
|
|
||||||
endef
|
|
||||||
|
|
||||||
define $(package)_stage_cmds
|
|
||||||
mkdir -p $($(package)_staging_prefix_dir)/include/miniupnpc $($(package)_staging_prefix_dir)/lib &&\
|
|
||||||
install *.h $($(package)_staging_prefix_dir)/include/miniupnpc &&\
|
|
||||||
install libminiupnpc.a $($(package)_staging_prefix_dir)/lib
|
|
||||||
endef
|
|
||||||
28
contrib/depends/packages/native_protobuf.mk
Normal file
28
contrib/depends/packages/native_protobuf.mk
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
package=protobuf3
|
||||||
|
$(package)_version=3.6.1
|
||||||
|
$(package)_download_path=https://github.com/protocolbuffers/protobuf/releases/download/v$($(package)_version)/
|
||||||
|
$(package)_file_name=protobuf-cpp-$($(package)_version).tar.gz
|
||||||
|
$(package)_sha256_hash=b3732e471a9bb7950f090fd0457ebd2536a9ba0891b7f3785919c654fe2a2529
|
||||||
|
$(package)_cxxflags=-std=c++11
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts=--disable-shared --prefix=$(build_prefix)
|
||||||
|
$(package)_config_opts_linux=--with-pic
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
$($(package)_autoconf)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE) -C src libprotobuf.la all
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) -C src install install-libLTLIBRARIES install-nobase_includeHEADERS &&\
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install-pkgconfigDATA
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_postprocess_cmds
|
||||||
|
rm lib/libprotoc.a
|
||||||
|
endef
|
||||||
@@ -1,12 +1,10 @@
|
|||||||
packages:=boost openssl libevent zeromq cppzmq zlib expat ldns cppzmq readline libiconv qt hidapi
|
packages:=boost openssl zeromq cppzmq expat ldns cppzmq readline libiconv qt hidapi protobuf libusb
|
||||||
native_packages := native_ccache
|
native_packages := native_ccache native_protobuf
|
||||||
|
|
||||||
wallet_packages=bdb
|
|
||||||
|
|
||||||
darwin_native_packages = native_biplist native_ds_store native_mac_alias
|
darwin_native_packages = native_biplist native_ds_store native_mac_alias
|
||||||
darwin_packages = sodium-darwin
|
darwin_packages = sodium-darwin
|
||||||
|
|
||||||
linux_packages = eudev libusb
|
linux_packages = eudev
|
||||||
|
|
||||||
ifeq ($(host_os),linux)
|
ifeq ($(host_os),linux)
|
||||||
packages += unwind
|
packages += unwind
|
||||||
@@ -19,6 +17,5 @@ endif
|
|||||||
|
|
||||||
ifneq ($(build_os),darwin)
|
ifneq ($(build_os),darwin)
|
||||||
darwin_native_packages += native_cctools native_cdrkit native_libdmg-hfsplus
|
darwin_native_packages += native_cctools native_cdrkit native_libdmg-hfsplus
|
||||||
packages += readline
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
|||||||
@@ -4,7 +4,6 @@ $(package)_download_path=https://download.qt.io/archive/qt/5.7/5.7.1/submodules
|
|||||||
$(package)_suffix=opensource-src-$($(package)_version).tar.gz
|
$(package)_suffix=opensource-src-$($(package)_version).tar.gz
|
||||||
$(package)_file_name=qtbase-$($(package)_suffix)
|
$(package)_file_name=qtbase-$($(package)_suffix)
|
||||||
$(package)_sha256_hash=95f83e532d23b3ddbde7973f380ecae1bac13230340557276f75f2e37984e410
|
$(package)_sha256_hash=95f83e532d23b3ddbde7973f380ecae1bac13230340557276f75f2e37984e410
|
||||||
$(package)_dependencies=openssl zlib
|
|
||||||
$(package)_build_subdir=qtbase
|
$(package)_build_subdir=qtbase
|
||||||
$(package)_qt_libs=corelib
|
$(package)_qt_libs=corelib
|
||||||
$(package)_patches=pidlist_absolute.patch fix_qt_pkgconfig.patch qfixed-coretext.patch
|
$(package)_patches=pidlist_absolute.patch fix_qt_pkgconfig.patch qfixed-coretext.patch
|
||||||
@@ -62,14 +61,14 @@ $(package)_config_opts += -no-xrender
|
|||||||
$(package)_config_opts += -nomake examples
|
$(package)_config_opts += -nomake examples
|
||||||
$(package)_config_opts += -nomake tests
|
$(package)_config_opts += -nomake tests
|
||||||
$(package)_config_opts += -opensource
|
$(package)_config_opts += -opensource
|
||||||
$(package)_config_opts += -openssl-linked
|
$(package)_config_opts += -no-openssl
|
||||||
$(package)_config_opts += -optimized-qmake
|
$(package)_config_opts += -optimized-qmake
|
||||||
$(package)_config_opts += -pch
|
$(package)_config_opts += -pch
|
||||||
$(package)_config_opts += -pkg-config
|
$(package)_config_opts += -pkg-config
|
||||||
$(package)_config_opts += -qt-libpng
|
$(package)_config_opts += -no-libpng
|
||||||
$(package)_config_opts += -qt-libjpeg
|
$(package)_config_opts += -no-libjpeg
|
||||||
$(package)_config_opts += -qt-pcre
|
$(package)_config_opts += -qt-pcre
|
||||||
$(package)_config_opts += -system-zlib
|
$(package)_config_opts += -no-zlib
|
||||||
$(package)_config_opts += -reduce-exports
|
$(package)_config_opts += -reduce-exports
|
||||||
$(package)_config_opts += -static
|
$(package)_config_opts += -static
|
||||||
$(package)_config_opts += -silent
|
$(package)_config_opts += -silent
|
||||||
@@ -124,7 +123,6 @@ define $(package)_config_cmds
|
|||||||
export PKG_CONFIG_LIBDIR=$(host_prefix)/lib/pkgconfig && \
|
export PKG_CONFIG_LIBDIR=$(host_prefix)/lib/pkgconfig && \
|
||||||
export PKG_CONFIG_PATH=$(host_prefix)/share/pkgconfig && \
|
export PKG_CONFIG_PATH=$(host_prefix)/share/pkgconfig && \
|
||||||
./configure $($(package)_config_opts) && \
|
./configure $($(package)_config_opts) && \
|
||||||
echo "host_build: QT_CONFIG ~= s/system-zlib/zlib" >> mkspecs/qconfig.pri && \
|
|
||||||
echo "CONFIG += force_bootstrap" >> mkspecs/qconfig.pri && \
|
echo "CONFIG += force_bootstrap" >> mkspecs/qconfig.pri && \
|
||||||
$(MAKE) sub-src-clean && \
|
$(MAKE) sub-src-clean && \
|
||||||
cd ../qttranslations && ../qtbase/bin/qmake qttranslations.pro -o Makefile && \
|
cd ../qttranslations && ../qtbase/bin/qmake qttranslations.pro -o Makefile && \
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
package=sodium-darwin
|
package=sodium-darwin
|
||||||
$(package)_version=1.0.15
|
$(package)_version=1.0.16
|
||||||
$(package)_download_path=https://download.libsodium.org/libsodium/releases/
|
$(package)_download_path=https://download.libsodium.org/libsodium/releases/
|
||||||
$(package)_file_name=libsodium-$($(package)_version).tar.gz
|
$(package)_file_name=libsodium-$($(package)_version).tar.gz
|
||||||
$(package)_sha256_hash=fb6a9e879a2f674592e4328c5d9f79f082405ee4bb05cb6e679b90afe9e178f4
|
$(package)_sha256_hash=eeadc7e1e1bcef09680fb4837d448fbdf57224978f865ac1c16745868fbd0533
|
||||||
|
|
||||||
define $(package)_set_vars
|
define $(package)_set_vars
|
||||||
$(package)_build_opts_darwin=OS=Darwin LIBTOOL="$($(package)_libtool)"
|
$(package)_build_opts_darwin=OS=Darwin LIBTOOL="$($(package)_libtool)"
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
package=sodium
|
package=sodium
|
||||||
$(package)_version=1.0.15
|
$(package)_version=1.0.16
|
||||||
$(package)_download_path=https://download.libsodium.org/libsodium/releases/
|
$(package)_download_path=https://download.libsodium.org/libsodium/releases/
|
||||||
$(package)_file_name=libsodium-$($(package)_version).tar.gz
|
$(package)_file_name=libsodium-$($(package)_version).tar.gz
|
||||||
$(package)_sha256_hash=fb6a9e879a2f674592e4328c5d9f79f082405ee4bb05cb6e679b90afe9e178f4
|
$(package)_sha256_hash=eeadc7e1e1bcef09680fb4837d448fbdf57224978f865ac1c16745868fbd0533
|
||||||
$(package)_patches=fix-whitespace.patch
|
$(package)_patches=fix-whitespace.patch
|
||||||
|
|
||||||
define $(package)_set_vars
|
define $(package)_set_vars
|
||||||
|
|||||||
@@ -1,27 +0,0 @@
|
|||||||
package=zlib
|
|
||||||
$(package)_version=1.2.11
|
|
||||||
$(package)_download_path=https://www.zlib.net
|
|
||||||
$(package)_file_name=$(package)-$($(package)_version).tar.gz
|
|
||||||
$(package)_sha256_hash=c3e5e9fdd5004dcb542feda5ee4f0ff0744628baf8ed2dd5d66f8ca1197cb1a1
|
|
||||||
|
|
||||||
define $(package)_set_vars
|
|
||||||
$(package)_build_opts= CC="$($(package)_cc)"
|
|
||||||
$(package)_build_opts+=CFLAGS="$($(package)_cflags) $($(package)_cppflags) -fPIC"
|
|
||||||
$(package)_build_opts+=RANLIB="$($(package)_ranlib)"
|
|
||||||
$(package)_build_opts+=AR="$($(package)_ar)"
|
|
||||||
$(package)_build_opts_darwin+=AR="$($(package)_libtool)"
|
|
||||||
$(package)_build_opts_darwin+=ARFLAGS="-o"
|
|
||||||
endef
|
|
||||||
|
|
||||||
define $(package)_config_cmds
|
|
||||||
./configure --static --prefix=$(host_prefix)
|
|
||||||
endef
|
|
||||||
|
|
||||||
define $(package)_build_cmds
|
|
||||||
$(MAKE) $($(package)_build_opts) libz.a
|
|
||||||
endef
|
|
||||||
|
|
||||||
define $(package)_stage_cmds
|
|
||||||
$(MAKE) DESTDIR=$($(package)_staging_dir) install $($(package)_build_opts)
|
|
||||||
endef
|
|
||||||
|
|
||||||
@@ -5,8 +5,8 @@ index b29f769..ca008ae 100755
|
|||||||
@@ -591,7 +591,7 @@ MAKEFLAGS=
|
@@ -591,7 +591,7 @@ MAKEFLAGS=
|
||||||
PACKAGE_NAME='libsodium'
|
PACKAGE_NAME='libsodium'
|
||||||
PACKAGE_TARNAME='libsodium'
|
PACKAGE_TARNAME='libsodium'
|
||||||
PACKAGE_VERSION='1.0.15'
|
PACKAGE_VERSION='1.0.16'
|
||||||
-PACKAGE_STRING='libsodium 1.0.15'
|
-PACKAGE_STRING='libsodium 1.0.16'
|
||||||
+PACKAGE_STRING='libsodium'
|
+PACKAGE_STRING='libsodium'
|
||||||
PACKAGE_BUGREPORT='https://github.com/jedisct1/libsodium/issues'
|
PACKAGE_BUGREPORT='https://github.com/jedisct1/libsodium/issues'
|
||||||
PACKAGE_URL='https://github.com/jedisct1/libsodium'
|
PACKAGE_URL='https://github.com/jedisct1/libsodium'
|
||||||
|
|||||||
@@ -21,6 +21,12 @@ SET(LIBUNWIND_LIBRARY_DIRS @prefix@/lib)
|
|||||||
SET(LIBUSB-1.0_LIBRARY @prefix@/lib/libusb-1.0.a)
|
SET(LIBUSB-1.0_LIBRARY @prefix@/lib/libusb-1.0.a)
|
||||||
SET(LIBUDEV_LIBRARY @prefix@/lib/libudev.a)
|
SET(LIBUDEV_LIBRARY @prefix@/lib/libudev.a)
|
||||||
|
|
||||||
|
SET(Protobuf_FOUND 1)
|
||||||
|
SET(Protobuf_PROTOC_EXECUTABLE @prefix@/native/bin/protoc CACHE FILEPATH "Path to the native protoc")
|
||||||
|
SET(Protobuf_INCLUDE_DIR @prefix@/include CACHE PATH "Protobuf include dir")
|
||||||
|
SET(Protobuf_INCLUDE_DIRS @prefix@/include CACHE PATH "Protobuf include dir")
|
||||||
|
SET(Protobuf_LIBRARY @prefix@/lib/libprotobuf.a CACHE FILEPATH "Protobuf library")
|
||||||
|
|
||||||
SET(ZMQ_INCLUDE_PATH @prefix@/include)
|
SET(ZMQ_INCLUDE_PATH @prefix@/include)
|
||||||
SET(ZMQ_LIB @prefix@/lib/libzmq.a)
|
SET(ZMQ_LIB @prefix@/lib/libzmq.a)
|
||||||
|
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
# Copyright (c) 2014-2018, The Monero Project
|
# Copyright (c) 2014-2019, The Monero Project
|
||||||
#
|
#
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2019, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -230,35 +230,56 @@ namespace math_helper
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
template<int default_interval, bool start_immediate = true>
|
template<uint64_t scale, int default_interval, bool start_immediate = true>
|
||||||
class once_a_time_seconds
|
class once_a_time
|
||||||
{
|
{
|
||||||
|
uint64_t get_time() const
|
||||||
|
{
|
||||||
|
#ifdef _WIN32
|
||||||
|
FILETIME fileTime;
|
||||||
|
GetSystemTimeAsFileTime(&fileTime);
|
||||||
|
unsigned __int64 present = 0;
|
||||||
|
present |= fileTime.dwHighDateTime;
|
||||||
|
present = present << 32;
|
||||||
|
present |= fileTime.dwLowDateTime;
|
||||||
|
present /= 10; // mic-sec
|
||||||
|
#else
|
||||||
|
struct timeval tv;
|
||||||
|
gettimeofday(&tv, NULL);
|
||||||
|
return tv.tv_sec * 1000000 + tv.tv_usec;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
once_a_time_seconds():m_interval(default_interval)
|
once_a_time():m_interval(default_interval * scale)
|
||||||
{
|
{
|
||||||
m_last_worked_time = 0;
|
m_last_worked_time = 0;
|
||||||
if(!start_immediate)
|
if(!start_immediate)
|
||||||
time(&m_last_worked_time);
|
m_last_worked_time = get_time();
|
||||||
}
|
}
|
||||||
|
|
||||||
template<class functor_t>
|
template<class functor_t>
|
||||||
bool do_call(functor_t functr)
|
bool do_call(functor_t functr)
|
||||||
{
|
{
|
||||||
time_t current_time = 0;
|
uint64_t current_time = get_time();
|
||||||
time(¤t_time);
|
|
||||||
|
|
||||||
if(current_time - m_last_worked_time > m_interval)
|
if(current_time - m_last_worked_time > m_interval)
|
||||||
{
|
{
|
||||||
bool res = functr();
|
bool res = functr();
|
||||||
time(&m_last_worked_time);
|
m_last_worked_time = get_time();
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
time_t m_last_worked_time;
|
uint64_t m_last_worked_time;
|
||||||
time_t m_interval;
|
uint64_t m_interval;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
template<int default_interval, bool start_immediate = true>
|
||||||
|
class once_a_time_seconds: public once_a_time<1000000, default_interval, start_immediate> {};
|
||||||
|
template<int default_interval, bool start_immediate = true>
|
||||||
|
class once_a_time_milliseconds: public once_a_time<1000, default_interval, start_immediate> {};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -38,14 +38,21 @@
|
|||||||
#define MAX_LOG_FILE_SIZE 104850000 // 100 MB - 7600 bytes
|
#define MAX_LOG_FILE_SIZE 104850000 // 100 MB - 7600 bytes
|
||||||
#define MAX_LOG_FILES 50
|
#define MAX_LOG_FILES 50
|
||||||
|
|
||||||
#define MCFATAL(cat,x) CLOG(FATAL,cat) << x
|
#define MCLOG_TYPE(level, cat, type, x) do { \
|
||||||
#define MCERROR(cat,x) CLOG(ERROR,cat) << x
|
if (ELPP->vRegistry()->allowed(level, cat)) { \
|
||||||
#define MCWARNING(cat,x) CLOG(WARNING,cat) << x
|
el::base::Writer(level, __FILE__, __LINE__, ELPP_FUNC, type).construct(cat) << x; \
|
||||||
#define MCINFO(cat,x) CLOG(INFO,cat) << x
|
} \
|
||||||
#define MCDEBUG(cat,x) CLOG(DEBUG,cat) << x
|
} while (0)
|
||||||
#define MCTRACE(cat,x) CLOG(TRACE,cat) << x
|
|
||||||
#define MCLOG(level,cat,x) ELPP_WRITE_LOG(el::base::Writer, level, el::base::DispatchAction::NormalLog, cat) << x
|
#define MCLOG(level, cat, x) MCLOG_TYPE(level, cat, el::base::DispatchAction::NormalLog, x)
|
||||||
#define MCLOG_FILE(level,cat,x) ELPP_WRITE_LOG(el::base::Writer, level, el::base::DispatchAction::FileOnlyLog, cat) << x
|
#define MCLOG_FILE(level, cat, x) MCLOG_TYPE(level, cat, el::base::DispatchAction::FileOnlyLog, x)
|
||||||
|
|
||||||
|
#define MCFATAL(cat,x) MCLOG(el::Level::Fatal,cat, x)
|
||||||
|
#define MCERROR(cat,x) MCLOG(el::Level::Error,cat, x)
|
||||||
|
#define MCWARNING(cat,x) MCLOG(el::Level::Warning,cat, x)
|
||||||
|
#define MCINFO(cat,x) MCLOG(el::Level::Info,cat, x)
|
||||||
|
#define MCDEBUG(cat,x) MCLOG(el::Level::Debug,cat, x)
|
||||||
|
#define MCTRACE(cat,x) MCLOG(el::Level::Trace,cat, x)
|
||||||
|
|
||||||
#define MCLOG_COLOR(level,cat,color,x) MCLOG(level,cat,"\033[1;" color "m" << x << "\033[0m")
|
#define MCLOG_COLOR(level,cat,color,x) MCLOG(level,cat,"\033[1;" color "m" << x << "\033[0m")
|
||||||
#define MCLOG_RED(level,cat,x) MCLOG_COLOR(level,cat,"31",x)
|
#define MCLOG_RED(level,cat,x) MCLOG_COLOR(level,cat,"31",x)
|
||||||
|
|||||||
62
contrib/epee/include/net/buffer.h
Normal file
62
contrib/epee/include/net/buffer.h
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
// Copyright (c) 2018, The Monero Project
|
||||||
|
//
|
||||||
|
// All rights reserved.
|
||||||
|
//
|
||||||
|
// Redistribution and use in source and binary forms, with or without modification, are
|
||||||
|
// permitted provided that the following conditions are met:
|
||||||
|
//
|
||||||
|
// 1. Redistributions of source code must retain the above copyright notice, this list of
|
||||||
|
// conditions and the following disclaimer.
|
||||||
|
//
|
||||||
|
// 2. Redistributions in binary form must reproduce the above copyright notice, this list
|
||||||
|
// of conditions and the following disclaimer in the documentation and/or other
|
||||||
|
// materials provided with the distribution.
|
||||||
|
//
|
||||||
|
// 3. Neither the name of the copyright holder nor the names of its contributors may be
|
||||||
|
// used to endorse or promote products derived from this software without specific
|
||||||
|
// prior written permission.
|
||||||
|
//
|
||||||
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
|
||||||
|
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||||
|
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
||||||
|
// THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
||||||
|
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
|
||||||
|
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <vector>
|
||||||
|
#include "misc_log_ex.h"
|
||||||
|
#include "span.h"
|
||||||
|
|
||||||
|
#undef MONERO_DEFAULT_LOG_CATEGORY
|
||||||
|
#define MONERO_DEFAULT_LOG_CATEGORY "net.buffer"
|
||||||
|
|
||||||
|
//#define NET_BUFFER_LOG(x) MDEBUG(x)
|
||||||
|
#define NET_BUFFER_LOG(x) ((void)0)
|
||||||
|
|
||||||
|
namespace epee
|
||||||
|
{
|
||||||
|
namespace net_utils
|
||||||
|
{
|
||||||
|
class buffer
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
buffer(size_t reserve = 0): offset(0) { storage.reserve(reserve); }
|
||||||
|
|
||||||
|
void append(const void *data, size_t sz);
|
||||||
|
void erase(size_t sz) { NET_BUFFER_LOG("erasing " << sz << "/" << size()); CHECK_AND_ASSERT_THROW_MES(offset + sz <= storage.size(), "erase: sz too large"); offset += sz; if (offset == storage.size()) { storage.resize(0); offset = 0; } }
|
||||||
|
epee::span<const uint8_t> span(size_t sz) const { CHECK_AND_ASSERT_THROW_MES(sz <= size(), "span is too large"); return epee::span<const uint8_t>(storage.data() + offset, sz); }
|
||||||
|
// carve must keep the data in scope till next call, other API calls (such as append, erase) can invalidate the carved buffer
|
||||||
|
epee::span<const uint8_t> carve(size_t sz) { CHECK_AND_ASSERT_THROW_MES(sz <= size(), "span is too large"); offset += sz; return epee::span<const uint8_t>(storage.data() + offset - sz, sz); }
|
||||||
|
size_t size() const { return storage.size() - offset; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
std::vector<uint8_t> storage;
|
||||||
|
size_t offset;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -8,7 +8,7 @@
|
|||||||
// ! (how ever if in some wonderful juristdictions that is not the case, then why not make another sub-class withat that members and licence it as epee part)
|
// ! (how ever if in some wonderful juristdictions that is not the case, then why not make another sub-class withat that members and licence it as epee part)
|
||||||
// ! Working on above premise, IF this is valid in your juristdictions, then consider this code as released as:
|
// ! Working on above premise, IF this is valid in your juristdictions, then consider this code as released as:
|
||||||
|
|
||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2019, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2019, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -54,7 +54,7 @@
|
|||||||
bool handled = false; \
|
bool handled = false; \
|
||||||
if(false) return true; //just a stub to have "else if"
|
if(false) return true; //just a stub to have "else if"
|
||||||
|
|
||||||
#define MAP_URI2(pattern, callback) else if(std::string::npos != query_info.m_URI.find(pattern)) return callback(query_info, response_info, m_conn_context);
|
#define MAP_URI2(pattern, callback) else if(std::string::npos != query_info.m_URI.find(pattern)) return callback(query_info, response_info, &m_conn_context);
|
||||||
|
|
||||||
#define MAP_URI_AUTO_XML2(s_pattern, callback_f, command_type) //TODO: don't think i ever again will use xml - ambiguous and "overtagged" format
|
#define MAP_URI_AUTO_XML2(s_pattern, callback_f, command_type) //TODO: don't think i ever again will use xml - ambiguous and "overtagged" format
|
||||||
|
|
||||||
@@ -69,7 +69,7 @@
|
|||||||
uint64_t ticks1 = epee::misc_utils::get_tick_count(); \
|
uint64_t ticks1 = epee::misc_utils::get_tick_count(); \
|
||||||
boost::value_initialized<command_type::response> resp;\
|
boost::value_initialized<command_type::response> resp;\
|
||||||
MINFO(m_conn_context << "calling " << s_pattern); \
|
MINFO(m_conn_context << "calling " << s_pattern); \
|
||||||
if(!callback_f(static_cast<command_type::request&>(req), static_cast<command_type::response&>(resp))) \
|
if(!callback_f(static_cast<command_type::request&>(req), static_cast<command_type::response&>(resp), &m_conn_context)) \
|
||||||
{ \
|
{ \
|
||||||
LOG_ERROR("Failed to " << #callback_f << "()"); \
|
LOG_ERROR("Failed to " << #callback_f << "()"); \
|
||||||
response_info.m_response_code = 500; \
|
response_info.m_response_code = 500; \
|
||||||
@@ -92,12 +92,12 @@
|
|||||||
handled = true; \
|
handled = true; \
|
||||||
uint64_t ticks = misc_utils::get_tick_count(); \
|
uint64_t ticks = misc_utils::get_tick_count(); \
|
||||||
boost::value_initialized<command_type::request> req; \
|
boost::value_initialized<command_type::request> req; \
|
||||||
bool parse_res = epee::serialization::load_t_from_binary(static_cast<command_type::request&>(req), query_info.m_body); \
|
bool parse_res = epee::serialization::load_t_from_binary(static_cast<command_type::request&>(req), epee::strspan<uint8_t>(query_info.m_body)); \
|
||||||
CHECK_AND_ASSERT_MES(parse_res, false, "Failed to parse bin body data, body size=" << query_info.m_body.size()); \
|
CHECK_AND_ASSERT_MES(parse_res, false, "Failed to parse bin body data, body size=" << query_info.m_body.size()); \
|
||||||
uint64_t ticks1 = misc_utils::get_tick_count(); \
|
uint64_t ticks1 = misc_utils::get_tick_count(); \
|
||||||
boost::value_initialized<command_type::response> resp;\
|
boost::value_initialized<command_type::response> resp;\
|
||||||
MINFO(m_conn_context << "calling " << s_pattern); \
|
MINFO(m_conn_context << "calling " << s_pattern); \
|
||||||
if(!callback_f(static_cast<command_type::request&>(req), static_cast<command_type::response&>(resp))) \
|
if(!callback_f(static_cast<command_type::request&>(req), static_cast<command_type::response&>(resp), &m_conn_context)) \
|
||||||
{ \
|
{ \
|
||||||
LOG_ERROR("Failed to " << #callback_f << "()"); \
|
LOG_ERROR("Failed to " << #callback_f << "()"); \
|
||||||
response_info.m_response_code = 500; \
|
response_info.m_response_code = 500; \
|
||||||
@@ -182,7 +182,7 @@
|
|||||||
fail_resp.jsonrpc = "2.0"; \
|
fail_resp.jsonrpc = "2.0"; \
|
||||||
fail_resp.id = req.id; \
|
fail_resp.id = req.id; \
|
||||||
MINFO(m_conn_context << "Calling RPC method " << method_name); \
|
MINFO(m_conn_context << "Calling RPC method " << method_name); \
|
||||||
if(!callback_f(req.params, resp.result, fail_resp.error)) \
|
if(!callback_f(req.params, resp.result, fail_resp.error, &m_conn_context)) \
|
||||||
{ \
|
{ \
|
||||||
epee::serialization::store_t_to_json(static_cast<epee::json_rpc::error_response&>(fail_resp), response_info.m_body); \
|
epee::serialization::store_t_to_json(static_cast<epee::json_rpc::error_response&>(fail_resp), response_info.m_body); \
|
||||||
return true; \
|
return true; \
|
||||||
@@ -201,7 +201,7 @@
|
|||||||
fail_resp.jsonrpc = "2.0"; \
|
fail_resp.jsonrpc = "2.0"; \
|
||||||
fail_resp.id = req.id; \
|
fail_resp.id = req.id; \
|
||||||
MINFO(m_conn_context << "calling RPC method " << method_name); \
|
MINFO(m_conn_context << "calling RPC method " << method_name); \
|
||||||
if(!callback_f(req.params, resp.result, fail_resp.error, m_conn_context, response_info)) \
|
if(!callback_f(req.params, resp.result, fail_resp.error, response_info, &m_conn_context)) \
|
||||||
{ \
|
{ \
|
||||||
epee::serialization::store_t_to_json(static_cast<epee::json_rpc::error_response&>(fail_resp), response_info.m_body); \
|
epee::serialization::store_t_to_json(static_cast<epee::json_rpc::error_response&>(fail_resp), response_info.m_body); \
|
||||||
return true; \
|
return true; \
|
||||||
@@ -215,7 +215,7 @@
|
|||||||
{ \
|
{ \
|
||||||
PREPARE_OBJECTS_FROM_JSON(command_type) \
|
PREPARE_OBJECTS_FROM_JSON(command_type) \
|
||||||
MINFO(m_conn_context << "calling RPC method " << method_name); \
|
MINFO(m_conn_context << "calling RPC method " << method_name); \
|
||||||
if(!callback_f(req.params, resp.result)) \
|
if(!callback_f(req.params, resp.result, &m_conn_context)) \
|
||||||
{ \
|
{ \
|
||||||
epee::json_rpc::error_response fail_resp = AUTO_VAL_INIT(fail_resp); \
|
epee::json_rpc::error_response fail_resp = AUTO_VAL_INIT(fail_resp); \
|
||||||
fail_resp.jsonrpc = "2.0"; \
|
fail_resp.jsonrpc = "2.0"; \
|
||||||
|
|||||||
@@ -80,8 +80,8 @@ namespace levin
|
|||||||
template<class t_connection_context = net_utils::connection_context_base>
|
template<class t_connection_context = net_utils::connection_context_base>
|
||||||
struct levin_commands_handler
|
struct levin_commands_handler
|
||||||
{
|
{
|
||||||
virtual int invoke(int command, const std::string& in_buff, std::string& buff_out, t_connection_context& context)=0;
|
virtual int invoke(int command, const epee::span<const uint8_t> in_buff, std::string& buff_out, t_connection_context& context)=0;
|
||||||
virtual int notify(int command, const std::string& in_buff, t_connection_context& context)=0;
|
virtual int notify(int command, const epee::span<const uint8_t> in_buff, t_connection_context& context)=0;
|
||||||
virtual void callback(t_connection_context& context){};
|
virtual void callback(t_connection_context& context){};
|
||||||
|
|
||||||
virtual void on_connection_new(t_connection_context& context){};
|
virtual void on_connection_new(t_connection_context& context){};
|
||||||
|
|||||||
@@ -57,7 +57,7 @@ namespace levin
|
|||||||
bool is_connected();
|
bool is_connected();
|
||||||
bool disconnect();
|
bool disconnect();
|
||||||
|
|
||||||
virtual int invoke(int command, const std::string& in_buff, std::string& buff_out);
|
virtual int invoke(int command, const epee::span<const uint8_t> in_buff, std::string& buff_out);
|
||||||
virtual int notify(int command, const std::string& in_buff);
|
virtual int notify(int command, const std::string& in_buff);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
@@ -72,7 +72,7 @@ namespace levin
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
int invoke(int command, const std::string& in_buff, std::string& buff_out);
|
int invoke(int command, const epee::span<const uint8_t> in_buff, std::string& buff_out);
|
||||||
int notify(int command, const std::string& in_buff);
|
int notify(int command, const std::string& in_buff);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -74,7 +74,7 @@ levin_client_impl::~levin_client_impl()
|
|||||||
}
|
}
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
inline
|
inline
|
||||||
int levin_client_impl::invoke(int command, const std::string& in_buff, std::string& buff_out)
|
int levin_client_impl::invoke(int command, const epee::span<const uint8_t> in_buff, std::string& buff_out)
|
||||||
{
|
{
|
||||||
if(!is_connected())
|
if(!is_connected())
|
||||||
return -1;
|
return -1;
|
||||||
@@ -133,7 +133,7 @@ int levin_client_impl::notify(int command, const std::string& in_buff)
|
|||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
inline
|
inline
|
||||||
int levin_client_impl2::invoke(int command, const std::string& in_buff, std::string& buff_out)
|
int levin_client_impl2::invoke(int command, epee::span<const uint8_t>string& in_buff, std::string& buff_out)
|
||||||
{
|
{
|
||||||
if(!is_connected())
|
if(!is_connected())
|
||||||
return -1;
|
return -1;
|
||||||
|
|||||||
@@ -431,7 +431,7 @@ namespace levin
|
|||||||
}
|
}
|
||||||
CRITICAL_REGION_END();
|
CRITICAL_REGION_END();
|
||||||
|
|
||||||
LOG_PRINT_L4("LEVIN_PACKET_RECIEVED. [len=" << head.m_cb << ", flags=" << head.m_flags << ", is_cmd=" << head.m_have_to_return_data <<", cmd_id = " << head.m_command << ", pr_v=" << head.m_protocol_version << ", uid=" << string_tools::get_str_from_guid_a(head.m_id) << "]");
|
LOG_PRINT_L4("LEVIN_PACKET_RECEIVED. [len=" << head.m_cb << ", flags=" << head.m_flags << ", is_cmd=" << head.m_have_to_return_data <<", cmd_id = " << head.m_command << ", pr_v=" << head.m_protocol_version << ", uid=" << string_tools::get_str_from_guid_a(head.m_id) << "]");
|
||||||
|
|
||||||
if(is_request)
|
if(is_request)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -34,6 +34,7 @@
|
|||||||
#include <atomic>
|
#include <atomic>
|
||||||
|
|
||||||
#include "levin_base.h"
|
#include "levin_base.h"
|
||||||
|
#include "buffer.h"
|
||||||
#include "misc_language.h"
|
#include "misc_language.h"
|
||||||
#include "syncobj.h"
|
#include "syncobj.h"
|
||||||
#include "misc_os_dependent.h"
|
#include "misc_os_dependent.h"
|
||||||
@@ -85,11 +86,11 @@ public:
|
|||||||
uint64_t m_max_packet_size;
|
uint64_t m_max_packet_size;
|
||||||
uint64_t m_invoke_timeout;
|
uint64_t m_invoke_timeout;
|
||||||
|
|
||||||
int invoke(int command, const std::string& in_buff, std::string& buff_out, boost::uuids::uuid connection_id);
|
int invoke(int command, const epee::span<const uint8_t> in_buff, std::string& buff_out, boost::uuids::uuid connection_id);
|
||||||
template<class callback_t>
|
template<class callback_t>
|
||||||
int invoke_async(int command, const std::string& in_buff, boost::uuids::uuid connection_id, const callback_t &cb, size_t timeout = LEVIN_DEFAULT_TIMEOUT_PRECONFIGURED);
|
int invoke_async(int command, const epee::span<const uint8_t> in_buff, boost::uuids::uuid connection_id, const callback_t &cb, size_t timeout = LEVIN_DEFAULT_TIMEOUT_PRECONFIGURED);
|
||||||
|
|
||||||
int notify(int command, const std::string& in_buff, boost::uuids::uuid connection_id);
|
int notify(int command, const epee::span<const uint8_t> in_buff, boost::uuids::uuid connection_id);
|
||||||
bool close(boost::uuids::uuid connection_id);
|
bool close(boost::uuids::uuid connection_id);
|
||||||
bool update_connection_context(const t_connection_context& contxt);
|
bool update_connection_context(const t_connection_context& contxt);
|
||||||
bool request_callback(boost::uuids::uuid connection_id);
|
bool request_callback(boost::uuids::uuid connection_id);
|
||||||
@@ -143,7 +144,7 @@ public:
|
|||||||
config_type& m_config;
|
config_type& m_config;
|
||||||
t_connection_context& m_connection_context;
|
t_connection_context& m_connection_context;
|
||||||
|
|
||||||
std::string m_cache_in_buffer;
|
net_utils::buffer m_cache_in_buffer;
|
||||||
stream_state m_state;
|
stream_state m_state;
|
||||||
|
|
||||||
int32_t m_oponent_protocol_ver;
|
int32_t m_oponent_protocol_ver;
|
||||||
@@ -151,7 +152,7 @@ public:
|
|||||||
|
|
||||||
struct invoke_response_handler_base
|
struct invoke_response_handler_base
|
||||||
{
|
{
|
||||||
virtual bool handle(int res, const std::string& buff, connection_context& context)=0;
|
virtual bool handle(int res, const epee::span<const uint8_t> buff, connection_context& context)=0;
|
||||||
virtual bool is_timer_started() const=0;
|
virtual bool is_timer_started() const=0;
|
||||||
virtual void cancel()=0;
|
virtual void cancel()=0;
|
||||||
virtual bool cancel_timer()=0;
|
virtual bool cancel_timer()=0;
|
||||||
@@ -173,7 +174,7 @@ public:
|
|||||||
if(ec == boost::asio::error::operation_aborted)
|
if(ec == boost::asio::error::operation_aborted)
|
||||||
return;
|
return;
|
||||||
MINFO(con.get_context_ref() << "Timeout on invoke operation happened, command: " << command << " timeout: " << timeout);
|
MINFO(con.get_context_ref() << "Timeout on invoke operation happened, command: " << command << " timeout: " << timeout);
|
||||||
std::string fake;
|
epee::span<const uint8_t> fake;
|
||||||
cb(LEVIN_ERROR_CONNECTION_TIMEDOUT, fake, con.get_context_ref());
|
cb(LEVIN_ERROR_CONNECTION_TIMEDOUT, fake, con.get_context_ref());
|
||||||
con.close();
|
con.close();
|
||||||
con.finish_outer_call();
|
con.finish_outer_call();
|
||||||
@@ -191,7 +192,7 @@ public:
|
|||||||
bool m_timer_cancelled;
|
bool m_timer_cancelled;
|
||||||
uint64_t m_timeout;
|
uint64_t m_timeout;
|
||||||
int m_command;
|
int m_command;
|
||||||
virtual bool handle(int res, const std::string& buff, typename async_protocol_handler::connection_context& context)
|
virtual bool handle(int res, const epee::span<const uint8_t> buff, typename async_protocol_handler::connection_context& context)
|
||||||
{
|
{
|
||||||
if(!cancel_timer())
|
if(!cancel_timer())
|
||||||
return false;
|
return false;
|
||||||
@@ -207,7 +208,7 @@ public:
|
|||||||
{
|
{
|
||||||
if(cancel_timer())
|
if(cancel_timer())
|
||||||
{
|
{
|
||||||
std::string fake;
|
epee::span<const uint8_t> fake;
|
||||||
m_cb(LEVIN_ERROR_CONNECTION_DESTROYED, fake, m_con.get_context_ref());
|
m_cb(LEVIN_ERROR_CONNECTION_DESTROYED, fake, m_con.get_context_ref());
|
||||||
m_con.finish_outer_call();
|
m_con.finish_outer_call();
|
||||||
}
|
}
|
||||||
@@ -237,7 +238,7 @@ public:
|
|||||||
if(ec == boost::asio::error::operation_aborted)
|
if(ec == boost::asio::error::operation_aborted)
|
||||||
return;
|
return;
|
||||||
MINFO(con.get_context_ref() << "Timeout on invoke operation happened, command: " << command << " timeout: " << timeout);
|
MINFO(con.get_context_ref() << "Timeout on invoke operation happened, command: " << command << " timeout: " << timeout);
|
||||||
std::string fake;
|
epee::span<const uint8_t> fake;
|
||||||
cb(LEVIN_ERROR_CONNECTION_TIMEDOUT, fake, con.get_context_ref());
|
cb(LEVIN_ERROR_CONNECTION_TIMEDOUT, fake, con.get_context_ref());
|
||||||
con.close();
|
con.close();
|
||||||
con.finish_outer_call();
|
con.finish_outer_call();
|
||||||
@@ -265,6 +266,7 @@ public:
|
|||||||
m_pservice_endpoint(psnd_hndlr),
|
m_pservice_endpoint(psnd_hndlr),
|
||||||
m_config(config),
|
m_config(config),
|
||||||
m_connection_context(conn_context),
|
m_connection_context(conn_context),
|
||||||
|
m_cache_in_buffer(256 * 1024),
|
||||||
m_state(stream_state_head)
|
m_state(stream_state_head)
|
||||||
{
|
{
|
||||||
m_close_called = 0;
|
m_close_called = 0;
|
||||||
@@ -405,18 +407,11 @@ public:
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
std::string buff_to_invoke;
|
epee::span<const uint8_t> buff_to_invoke = m_cache_in_buffer.carve((std::string::size_type)m_current_head.m_cb);
|
||||||
if(m_cache_in_buffer.size() == m_current_head.m_cb)
|
|
||||||
buff_to_invoke.swap(m_cache_in_buffer);
|
|
||||||
else
|
|
||||||
{
|
|
||||||
buff_to_invoke.assign(m_cache_in_buffer, 0, (std::string::size_type)m_current_head.m_cb);
|
|
||||||
m_cache_in_buffer.erase(0, (std::string::size_type)m_current_head.m_cb);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool is_response = (m_oponent_protocol_ver == LEVIN_PROTOCOL_VER_1 && m_current_head.m_flags&LEVIN_PACKET_RESPONSE);
|
bool is_response = (m_oponent_protocol_ver == LEVIN_PROTOCOL_VER_1 && m_current_head.m_flags&LEVIN_PACKET_RESPONSE);
|
||||||
|
|
||||||
MDEBUG(m_connection_context << "LEVIN_PACKET_RECIEVED. [len=" << m_current_head.m_cb
|
MDEBUG(m_connection_context << "LEVIN_PACKET_RECEIVED. [len=" << m_current_head.m_cb
|
||||||
<< ", flags" << m_current_head.m_flags
|
<< ", flags" << m_current_head.m_flags
|
||||||
<< ", r?=" << m_current_head.m_have_to_return_data
|
<< ", r?=" << m_current_head.m_have_to_return_data
|
||||||
<<", cmd = " << m_current_head.m_command
|
<<", cmd = " << m_current_head.m_command
|
||||||
@@ -449,8 +444,8 @@ public:
|
|||||||
}else
|
}else
|
||||||
{
|
{
|
||||||
CRITICAL_REGION_BEGIN(m_local_inv_buff_lock);
|
CRITICAL_REGION_BEGIN(m_local_inv_buff_lock);
|
||||||
buff_to_invoke.swap(m_local_inv_buff);
|
m_local_inv_buff = std::string((const char*)buff_to_invoke.data(), buff_to_invoke.size());
|
||||||
buff_to_invoke.clear();
|
buff_to_invoke = epee::span<const uint8_t>((const uint8_t*)NULL, 0);
|
||||||
m_invoke_result_code = m_current_head.m_return_code;
|
m_invoke_result_code = m_current_head.m_return_code;
|
||||||
CRITICAL_REGION_END();
|
CRITICAL_REGION_END();
|
||||||
boost::interprocess::ipcdetail::atomic_write32(&m_invoke_buf_ready, 1);
|
boost::interprocess::ipcdetail::atomic_write32(&m_invoke_buf_ready, 1);
|
||||||
@@ -503,7 +498,7 @@ public:
|
|||||||
{
|
{
|
||||||
if(m_cache_in_buffer.size() < sizeof(bucket_head2))
|
if(m_cache_in_buffer.size() < sizeof(bucket_head2))
|
||||||
{
|
{
|
||||||
if(m_cache_in_buffer.size() >= sizeof(uint64_t) && *((uint64_t*)m_cache_in_buffer.data()) != SWAP64LE(LEVIN_SIGNATURE))
|
if(m_cache_in_buffer.size() >= sizeof(uint64_t) && *((uint64_t*)m_cache_in_buffer.span(8).data()) != SWAP64LE(LEVIN_SIGNATURE))
|
||||||
{
|
{
|
||||||
MWARNING(m_connection_context << "Signature mismatch, connection will be closed");
|
MWARNING(m_connection_context << "Signature mismatch, connection will be closed");
|
||||||
return false;
|
return false;
|
||||||
@@ -513,9 +508,9 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if BYTE_ORDER == LITTLE_ENDIAN
|
#if BYTE_ORDER == LITTLE_ENDIAN
|
||||||
bucket_head2& phead = *(bucket_head2*)m_cache_in_buffer.data();
|
bucket_head2& phead = *(bucket_head2*)m_cache_in_buffer.span(sizeof(bucket_head2)).data();
|
||||||
#else
|
#else
|
||||||
bucket_head2 phead = *(bucket_head2*)m_cache_in_buffer.data();
|
bucket_head2 phead = *(bucket_head2*)m_cache_in_buffer.span(sizeof(bucket_head2)).data();
|
||||||
phead.m_signature = SWAP64LE(phead.m_signature);
|
phead.m_signature = SWAP64LE(phead.m_signature);
|
||||||
phead.m_cb = SWAP64LE(phead.m_cb);
|
phead.m_cb = SWAP64LE(phead.m_cb);
|
||||||
phead.m_command = SWAP32LE(phead.m_command);
|
phead.m_command = SWAP32LE(phead.m_command);
|
||||||
@@ -530,7 +525,7 @@ public:
|
|||||||
}
|
}
|
||||||
m_current_head = phead;
|
m_current_head = phead;
|
||||||
|
|
||||||
m_cache_in_buffer.erase(0, sizeof(bucket_head2));
|
m_cache_in_buffer.erase(sizeof(bucket_head2));
|
||||||
m_state = stream_state_body;
|
m_state = stream_state_body;
|
||||||
m_oponent_protocol_ver = m_current_head.m_protocol_version;
|
m_oponent_protocol_ver = m_current_head.m_protocol_version;
|
||||||
if(m_current_head.m_cb > m_config.m_max_packet_size)
|
if(m_current_head.m_cb > m_config.m_max_packet_size)
|
||||||
@@ -562,7 +557,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
template<class callback_t>
|
template<class callback_t>
|
||||||
bool async_invoke(int command, const std::string& in_buff, const callback_t &cb, size_t timeout = LEVIN_DEFAULT_TIMEOUT_PRECONFIGURED)
|
bool async_invoke(int command, const epee::span<const uint8_t> in_buff, const callback_t &cb, size_t timeout = LEVIN_DEFAULT_TIMEOUT_PRECONFIGURED)
|
||||||
{
|
{
|
||||||
misc_utils::auto_scope_leave_caller scope_exit_handler = misc_utils::create_scope_leave_handler(
|
misc_utils::auto_scope_leave_caller scope_exit_handler = misc_utils::create_scope_leave_handler(
|
||||||
boost::bind(&async_protocol_handler::finish_outer_call, this));
|
boost::bind(&async_protocol_handler::finish_outer_call, this));
|
||||||
@@ -606,7 +601,7 @@ public:
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!m_pservice_endpoint->do_send(in_buff.data(), (int)in_buff.size()))
|
if(!m_pservice_endpoint->do_send(in_buff.data(), in_buff.size()))
|
||||||
{
|
{
|
||||||
LOG_ERROR_CC(m_connection_context, "Failed to do_send");
|
LOG_ERROR_CC(m_connection_context, "Failed to do_send");
|
||||||
err_code = LEVIN_ERROR_CONNECTION;
|
err_code = LEVIN_ERROR_CONNECTION;
|
||||||
@@ -623,7 +618,7 @@ public:
|
|||||||
|
|
||||||
if (LEVIN_OK != err_code)
|
if (LEVIN_OK != err_code)
|
||||||
{
|
{
|
||||||
std::string stub_buff;
|
epee::span<const uint8_t> stub_buff{(const uint8_t*)"", 0};
|
||||||
// Never call callback inside critical section, that can cause deadlock
|
// Never call callback inside critical section, that can cause deadlock
|
||||||
cb(err_code, stub_buff, m_connection_context);
|
cb(err_code, stub_buff, m_connection_context);
|
||||||
return false;
|
return false;
|
||||||
@@ -632,7 +627,7 @@ public:
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
int invoke(int command, const std::string& in_buff, std::string& buff_out)
|
int invoke(int command, const epee::span<const uint8_t> in_buff, std::string& buff_out)
|
||||||
{
|
{
|
||||||
misc_utils::auto_scope_leave_caller scope_exit_handler = misc_utils::create_scope_leave_handler(
|
misc_utils::auto_scope_leave_caller scope_exit_handler = misc_utils::create_scope_leave_handler(
|
||||||
boost::bind(&async_protocol_handler::finish_outer_call, this));
|
boost::bind(&async_protocol_handler::finish_outer_call, this));
|
||||||
@@ -662,7 +657,7 @@ public:
|
|||||||
return LEVIN_ERROR_CONNECTION;
|
return LEVIN_ERROR_CONNECTION;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!m_pservice_endpoint->do_send(in_buff.data(), (int)in_buff.size()))
|
if(!m_pservice_endpoint->do_send(in_buff.data(), in_buff.size()))
|
||||||
{
|
{
|
||||||
LOG_ERROR_CC(m_connection_context, "Failed to do_send");
|
LOG_ERROR_CC(m_connection_context, "Failed to do_send");
|
||||||
return LEVIN_ERROR_CONNECTION;
|
return LEVIN_ERROR_CONNECTION;
|
||||||
@@ -706,7 +701,7 @@ public:
|
|||||||
return m_invoke_result_code;
|
return m_invoke_result_code;
|
||||||
}
|
}
|
||||||
|
|
||||||
int notify(int command, const std::string& in_buff)
|
int notify(int command, const epee::span<const uint8_t> in_buff)
|
||||||
{
|
{
|
||||||
misc_utils::auto_scope_leave_caller scope_exit_handler = misc_utils::create_scope_leave_handler(
|
misc_utils::auto_scope_leave_caller scope_exit_handler = misc_utils::create_scope_leave_handler(
|
||||||
boost::bind(&async_protocol_handler::finish_outer_call, this));
|
boost::bind(&async_protocol_handler::finish_outer_call, this));
|
||||||
@@ -734,7 +729,7 @@ public:
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!m_pservice_endpoint->do_send(in_buff.data(), (int)in_buff.size()))
|
if(!m_pservice_endpoint->do_send(in_buff.data(), in_buff.size()))
|
||||||
{
|
{
|
||||||
LOG_ERROR_CC(m_connection_context, "Failed to do_send()");
|
LOG_ERROR_CC(m_connection_context, "Failed to do_send()");
|
||||||
return -1;
|
return -1;
|
||||||
@@ -839,7 +834,7 @@ int async_protocol_handler_config<t_connection_context>::find_and_lock_connectio
|
|||||||
}
|
}
|
||||||
//------------------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------------------
|
||||||
template<class t_connection_context>
|
template<class t_connection_context>
|
||||||
int async_protocol_handler_config<t_connection_context>::invoke(int command, const std::string& in_buff, std::string& buff_out, boost::uuids::uuid connection_id)
|
int async_protocol_handler_config<t_connection_context>::invoke(int command, const epee::span<const uint8_t> in_buff, std::string& buff_out, boost::uuids::uuid connection_id)
|
||||||
{
|
{
|
||||||
async_protocol_handler<t_connection_context>* aph;
|
async_protocol_handler<t_connection_context>* aph;
|
||||||
int r = find_and_lock_connection(connection_id, aph);
|
int r = find_and_lock_connection(connection_id, aph);
|
||||||
@@ -847,7 +842,7 @@ int async_protocol_handler_config<t_connection_context>::invoke(int command, con
|
|||||||
}
|
}
|
||||||
//------------------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------------------
|
||||||
template<class t_connection_context> template<class callback_t>
|
template<class t_connection_context> template<class callback_t>
|
||||||
int async_protocol_handler_config<t_connection_context>::invoke_async(int command, const std::string& in_buff, boost::uuids::uuid connection_id, const callback_t &cb, size_t timeout)
|
int async_protocol_handler_config<t_connection_context>::invoke_async(int command, const epee::span<const uint8_t> in_buff, boost::uuids::uuid connection_id, const callback_t &cb, size_t timeout)
|
||||||
{
|
{
|
||||||
async_protocol_handler<t_connection_context>* aph;
|
async_protocol_handler<t_connection_context>* aph;
|
||||||
int r = find_and_lock_connection(connection_id, aph);
|
int r = find_and_lock_connection(connection_id, aph);
|
||||||
@@ -896,7 +891,7 @@ void async_protocol_handler_config<t_connection_context>::set_handler(levin_comm
|
|||||||
}
|
}
|
||||||
//------------------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------------------
|
||||||
template<class t_connection_context>
|
template<class t_connection_context>
|
||||||
int async_protocol_handler_config<t_connection_context>::notify(int command, const std::string& in_buff, boost::uuids::uuid connection_id)
|
int async_protocol_handler_config<t_connection_context>::notify(int command, const epee::span<const uint8_t> in_buff, boost::uuids::uuid connection_id)
|
||||||
{
|
{
|
||||||
async_protocol_handler<t_connection_context>* aph;
|
async_protocol_handler<t_connection_context>* aph;
|
||||||
int r = find_and_lock_connection(connection_id, aph);
|
int r = find_and_lock_connection(connection_id, aph);
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
/// @author rfree (current maintainer in monero.cc project)
|
/// @author rfree (current maintainer in monero.cc project)
|
||||||
/// @brief implementaion for throttling of connection (count and rate-limit speed etc)
|
/// @brief implementaion for throttling of connection (count and rate-limit speed etc)
|
||||||
|
|
||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2019, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
/// @author rfree (current maintainer in monero.cc project)
|
/// @author rfree (current maintainer in monero.cc project)
|
||||||
/// @brief interface for throttling of connection (count and rate-limit speed etc)
|
/// @brief interface for throttling of connection (count and rate-limit speed etc)
|
||||||
|
|
||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2019, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -163,4 +163,12 @@ namespace epee
|
|||||||
static_assert(!has_padding<T>(), "source type may have padding");
|
static_assert(!has_padding<T>(), "source type may have padding");
|
||||||
return {reinterpret_cast<std::uint8_t*>(std::addressof(src)), sizeof(T)};
|
return {reinterpret_cast<std::uint8_t*>(std::addressof(src)), sizeof(T)};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//! make a span from a std::string
|
||||||
|
template<typename T>
|
||||||
|
span<const T> strspan(const std::string &s) noexcept
|
||||||
|
{
|
||||||
|
static_assert(std::is_same<T, char>() || std::is_same<T, unsigned char>() || std::is_same<T, int8_t>() || std::is_same<T, uint8_t>(), "Unexpected type");
|
||||||
|
return {reinterpret_cast<const T*>(s.data()), s.size()};
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -97,7 +97,7 @@ namespace epee
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
return serialization::load_t_from_binary(result_struct, pri->m_body);
|
return serialization::load_t_from_binary(result_struct, epee::strspan<uint8_t>(pri->m_body));
|
||||||
}
|
}
|
||||||
|
|
||||||
template<class t_request, class t_response, class t_transport>
|
template<class t_request, class t_response, class t_transport>
|
||||||
|
|||||||
@@ -28,6 +28,7 @@
|
|||||||
|
|
||||||
#include "portable_storage_template_helper.h"
|
#include "portable_storage_template_helper.h"
|
||||||
#include <boost/utility/value_init.hpp>
|
#include <boost/utility/value_init.hpp>
|
||||||
|
#include "span.h"
|
||||||
#include "net/levin_base.h"
|
#include "net/levin_base.h"
|
||||||
|
|
||||||
#undef MONERO_DEFAULT_LOG_CATEGORY
|
#undef MONERO_DEFAULT_LOG_CATEGORY
|
||||||
@@ -114,7 +115,7 @@ namespace epee
|
|||||||
const_cast<t_arg&>(out_struct).store(stg);//TODO: add true const support to searilzation
|
const_cast<t_arg&>(out_struct).store(stg);//TODO: add true const support to searilzation
|
||||||
std::string buff_to_send;
|
std::string buff_to_send;
|
||||||
stg.store_to_binary(buff_to_send);
|
stg.store_to_binary(buff_to_send);
|
||||||
int res = transport.invoke_async(command, buff_to_send, conn_id, [cb, command](int code, const std::string& buff, typename t_transport::connection_context& context)->bool
|
int res = transport.invoke_async(command, epee::strspan<uint8_t>(buff_to_send), conn_id, [cb, command](int code, const epee::span<const uint8_t> buff, typename t_transport::connection_context& context)->bool
|
||||||
{
|
{
|
||||||
t_result result_struct = AUTO_VAL_INIT(result_struct);
|
t_result result_struct = AUTO_VAL_INIT(result_struct);
|
||||||
if( code <=0 )
|
if( code <=0 )
|
||||||
@@ -156,7 +157,7 @@ namespace epee
|
|||||||
std::string buff_to_send;
|
std::string buff_to_send;
|
||||||
stg.store_to_binary(buff_to_send);
|
stg.store_to_binary(buff_to_send);
|
||||||
|
|
||||||
int res = transport.notify(command, buff_to_send, conn_id);
|
int res = transport.notify(command, epee::strspan<uint8_t>(buff_to_send), conn_id);
|
||||||
if(res <=0 )
|
if(res <=0 )
|
||||||
{
|
{
|
||||||
MERROR("Failed to notify command " << command << " return code " << res);
|
MERROR("Failed to notify command " << command << " return code " << res);
|
||||||
@@ -167,7 +168,7 @@ namespace epee
|
|||||||
//----------------------------------------------------------------------------------------------------
|
//----------------------------------------------------------------------------------------------------
|
||||||
//----------------------------------------------------------------------------------------------------
|
//----------------------------------------------------------------------------------------------------
|
||||||
template<class t_owner, class t_in_type, class t_out_type, class t_context, class callback_t>
|
template<class t_owner, class t_in_type, class t_out_type, class t_context, class callback_t>
|
||||||
int buff_to_t_adapter(int command, const std::string& in_buff, std::string& buff_out, callback_t cb, t_context& context )
|
int buff_to_t_adapter(int command, const epee::span<const uint8_t> in_buff, std::string& buff_out, callback_t cb, t_context& context )
|
||||||
{
|
{
|
||||||
serialization::portable_storage strg;
|
serialization::portable_storage strg;
|
||||||
if(!strg.load_from_binary(in_buff))
|
if(!strg.load_from_binary(in_buff))
|
||||||
@@ -197,7 +198,7 @@ namespace epee
|
|||||||
}
|
}
|
||||||
|
|
||||||
template<class t_owner, class t_in_type, class t_context, class callback_t>
|
template<class t_owner, class t_in_type, class t_context, class callback_t>
|
||||||
int buff_to_t_adapter(t_owner* powner, int command, const std::string& in_buff, callback_t cb, t_context& context)
|
int buff_to_t_adapter(t_owner* powner, int command, const epee::span<const uint8_t> in_buff, callback_t cb, t_context& context)
|
||||||
{
|
{
|
||||||
serialization::portable_storage strg;
|
serialization::portable_storage strg;
|
||||||
if(!strg.load_from_binary(in_buff))
|
if(!strg.load_from_binary(in_buff))
|
||||||
@@ -215,14 +216,14 @@ namespace epee
|
|||||||
}
|
}
|
||||||
|
|
||||||
#define CHAIN_LEVIN_INVOKE_MAP2(context_type) \
|
#define CHAIN_LEVIN_INVOKE_MAP2(context_type) \
|
||||||
int invoke(int command, const std::string& in_buff, std::string& buff_out, context_type& context) \
|
int invoke(int command, const epee::span<const uint8_t> in_buff, std::string& buff_out, context_type& context) \
|
||||||
{ \
|
{ \
|
||||||
bool handled = false; \
|
bool handled = false; \
|
||||||
return handle_invoke_map(false, command, in_buff, buff_out, context, handled); \
|
return handle_invoke_map(false, command, in_buff, buff_out, context, handled); \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define CHAIN_LEVIN_NOTIFY_MAP2(context_type) \
|
#define CHAIN_LEVIN_NOTIFY_MAP2(context_type) \
|
||||||
int notify(int command, const std::string& in_buff, context_type& context) \
|
int notify(int command, const epee::span<const uint8_t> in_buff, context_type& context) \
|
||||||
{ \
|
{ \
|
||||||
bool handled = false; std::string fake_str;\
|
bool handled = false; std::string fake_str;\
|
||||||
return handle_invoke_map(true, command, in_buff, fake_str, context, handled); \
|
return handle_invoke_map(true, command, in_buff, fake_str, context, handled); \
|
||||||
@@ -230,27 +231,27 @@ namespace epee
|
|||||||
|
|
||||||
|
|
||||||
#define CHAIN_LEVIN_INVOKE_MAP() \
|
#define CHAIN_LEVIN_INVOKE_MAP() \
|
||||||
int invoke(int command, const std::string& in_buff, std::string& buff_out, epee::net_utils::connection_context_base& context) \
|
int invoke(int command, const epee::span<const uint8_t> in_buff, std::string& buff_out, epee::net_utils::connection_context_base& context) \
|
||||||
{ \
|
{ \
|
||||||
bool handled = false; \
|
bool handled = false; \
|
||||||
return handle_invoke_map(false, command, in_buff, buff_out, context, handled); \
|
return handle_invoke_map(false, command, in_buff, buff_out, context, handled); \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define CHAIN_LEVIN_NOTIFY_MAP() \
|
#define CHAIN_LEVIN_NOTIFY_MAP() \
|
||||||
int notify(int command, const std::string& in_buff, epee::net_utils::connection_context_base& context) \
|
int notify(int command, const epee::span<const uint8_t> in_buff, epee::net_utils::connection_context_base& context) \
|
||||||
{ \
|
{ \
|
||||||
bool handled = false; std::string fake_str;\
|
bool handled = false; std::string fake_str;\
|
||||||
return handle_invoke_map(true, command, in_buff, fake_str, context, handled); \
|
return handle_invoke_map(true, command, in_buff, fake_str, context, handled); \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define CHAIN_LEVIN_NOTIFY_STUB() \
|
#define CHAIN_LEVIN_NOTIFY_STUB() \
|
||||||
int notify(int command, const std::string& in_buff, epee::net_utils::connection_context_base& context) \
|
int notify(int command, const epee::span<const uint8_t> in_buff, epee::net_utils::connection_context_base& context) \
|
||||||
{ \
|
{ \
|
||||||
return -1; \
|
return -1; \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define BEGIN_INVOKE_MAP2(owner_type) \
|
#define BEGIN_INVOKE_MAP2(owner_type) \
|
||||||
template <class t_context> int handle_invoke_map(bool is_notify, int command, const std::string& in_buff, std::string& buff_out, t_context& context, bool& handled) \
|
template <class t_context> int handle_invoke_map(bool is_notify, int command, const epee::span<const uint8_t> in_buff, std::string& buff_out, t_context& context, bool& handled) \
|
||||||
{ \
|
{ \
|
||||||
typedef owner_type internal_owner_type_name;
|
typedef owner_type internal_owner_type_name;
|
||||||
|
|
||||||
|
|||||||
@@ -29,6 +29,7 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
#include <boost/utility/string_ref.hpp>
|
||||||
|
|
||||||
namespace epee
|
namespace epee
|
||||||
{
|
{
|
||||||
@@ -36,6 +37,40 @@ namespace misc_utils
|
|||||||
{
|
{
|
||||||
namespace parse
|
namespace parse
|
||||||
{
|
{
|
||||||
|
// 1: digit
|
||||||
|
// 2: .eE (floating point)
|
||||||
|
// 4: alpha
|
||||||
|
// 8: whitespace
|
||||||
|
// 16: allowed in float but doesn't necessarily mean it's a float
|
||||||
|
static const constexpr uint8_t lut[256]={
|
||||||
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 8, 8, 8, 8, 8, 0, 0, // 16
|
||||||
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 32
|
||||||
|
8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 16, 0, 16, 18, 0, // 48
|
||||||
|
17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 0, 0, 0, 0, 0, 0, // 64
|
||||||
|
0, 4, 4, 4, 4, 22, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, // 80
|
||||||
|
4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 0, 0, 0, 0, 0, // 96
|
||||||
|
0, 4, 4, 4, 4, 22, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, // 112
|
||||||
|
4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 0, 0, 0, 0, 0, // 128
|
||||||
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
||||||
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
||||||
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
||||||
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
||||||
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
||||||
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
||||||
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
||||||
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
||||||
|
};
|
||||||
|
|
||||||
|
inline bool isspace(char c)
|
||||||
|
{
|
||||||
|
return lut[(uint8_t)c] & 8;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline bool isdigit(char c)
|
||||||
|
{
|
||||||
|
return lut[(uint8_t)c] & 1;
|
||||||
|
}
|
||||||
|
|
||||||
inline std::string transform_to_escape_sequence(const std::string& src)
|
inline std::string transform_to_escape_sequence(const std::string& src)
|
||||||
{
|
{
|
||||||
static const char escaped[] = "\b\f\n\r\t\v\"\\/";
|
static const char escaped[] = "\b\f\n\r\t\v\"\\/";
|
||||||
@@ -91,11 +126,15 @@ namespace misc_utils
|
|||||||
*/
|
*/
|
||||||
inline void match_string2(std::string::const_iterator& star_end_string, std::string::const_iterator buf_end, std::string& val)
|
inline void match_string2(std::string::const_iterator& star_end_string, std::string::const_iterator buf_end, std::string& val)
|
||||||
{
|
{
|
||||||
val.clear();
|
|
||||||
val.reserve(std::distance(star_end_string, buf_end));
|
|
||||||
bool escape_mode = false;
|
bool escape_mode = false;
|
||||||
std::string::const_iterator it = star_end_string;
|
std::string::const_iterator it = star_end_string;
|
||||||
++it;
|
++it;
|
||||||
|
std::string::const_iterator fi = it;
|
||||||
|
while (fi != buf_end && *fi != '\\' && *fi != '\"')
|
||||||
|
++fi;
|
||||||
|
val.assign(it, fi);
|
||||||
|
val.reserve(std::distance(star_end_string, buf_end));
|
||||||
|
it = fi;
|
||||||
for(;it != buf_end;it++)
|
for(;it != buf_end;it++)
|
||||||
{
|
{
|
||||||
if(escape_mode/*prev_ch == '\\'*/)
|
if(escape_mode/*prev_ch == '\\'*/)
|
||||||
@@ -155,25 +194,34 @@ namespace misc_utils
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
inline void match_number2(std::string::const_iterator& star_end_string, std::string::const_iterator buf_end, std::string& val, bool& is_float_val, bool& is_signed_val)
|
inline void match_number2(std::string::const_iterator& star_end_string, std::string::const_iterator buf_end, boost::string_ref& val, bool& is_float_val, bool& is_signed_val)
|
||||||
{
|
{
|
||||||
val.clear();
|
val.clear();
|
||||||
is_float_val = false;
|
uint8_t float_flag = 0;
|
||||||
for(std::string::const_iterator it = star_end_string;it != buf_end;it++)
|
is_signed_val = false;
|
||||||
|
size_t chars = 0;
|
||||||
|
std::string::const_iterator it = star_end_string;
|
||||||
|
if (it != buf_end && *it == '-')
|
||||||
{
|
{
|
||||||
if(isdigit(*it) || (it == star_end_string && *it == '-') || (val.size() && *it == '.' ) || (is_float_val && (*it == 'e' || *it == 'E' || *it == '-' || *it == '+' )) )
|
is_signed_val = true;
|
||||||
|
++chars;
|
||||||
|
++it;
|
||||||
|
}
|
||||||
|
for(;it != buf_end;it++)
|
||||||
|
{
|
||||||
|
const uint8_t flags = lut[(uint8_t)*it];
|
||||||
|
if (flags & 16)
|
||||||
{
|
{
|
||||||
if(!val.size() && *it == '-')
|
float_flag |= flags;
|
||||||
is_signed_val = true;
|
++chars;
|
||||||
if(*it == '.' )
|
|
||||||
is_float_val = true;
|
|
||||||
val.push_back(*it);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
val = boost::string_ref(&*star_end_string, chars);
|
||||||
if(val.size())
|
if(val.size())
|
||||||
{
|
{
|
||||||
star_end_string = --it;
|
star_end_string = --it;
|
||||||
|
is_float_val = !!(float_flag & 2);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -182,7 +230,7 @@ namespace misc_utils
|
|||||||
}
|
}
|
||||||
ASSERT_MES_AND_THROW("wrong number in json entry: " << std::string(star_end_string, buf_end));
|
ASSERT_MES_AND_THROW("wrong number in json entry: " << std::string(star_end_string, buf_end));
|
||||||
}
|
}
|
||||||
inline bool match_number(std::string::const_iterator& star_end_string, std::string::const_iterator buf_end, std::string& val)
|
inline bool match_number(std::string::const_iterator& star_end_string, std::string::const_iterator buf_end, boost::string_ref& val)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
@@ -195,15 +243,15 @@ namespace misc_utils
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
inline void match_word2(std::string::const_iterator& star_end_string, std::string::const_iterator buf_end, std::string& val)
|
inline void match_word2(std::string::const_iterator& star_end_string, std::string::const_iterator buf_end, boost::string_ref& val)
|
||||||
{
|
{
|
||||||
val.clear();
|
val.clear();
|
||||||
|
|
||||||
for(std::string::const_iterator it = star_end_string;it != buf_end;it++)
|
for(std::string::const_iterator it = star_end_string;it != buf_end;it++)
|
||||||
{
|
{
|
||||||
if(!isalpha(*it))
|
if (!(lut[(uint8_t)*it] & 4))
|
||||||
{
|
{
|
||||||
val.assign(star_end_string, it);
|
val = boost::string_ref(&*star_end_string, std::distance(star_end_string, it));
|
||||||
if(val.size())
|
if(val.size())
|
||||||
{
|
{
|
||||||
star_end_string = --it;
|
star_end_string = --it;
|
||||||
@@ -214,7 +262,7 @@ namespace misc_utils
|
|||||||
}
|
}
|
||||||
ASSERT_MES_AND_THROW("failed to match word number in json entry: " << std::string(star_end_string, buf_end));
|
ASSERT_MES_AND_THROW("failed to match word number in json entry: " << std::string(star_end_string, buf_end));
|
||||||
}
|
}
|
||||||
inline bool match_word(std::string::const_iterator& star_end_string, std::string::const_iterator buf_end, std::string& val)
|
inline bool match_word(std::string::const_iterator& star_end_string, std::string::const_iterator buf_end, boost::string_ref& val)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -35,6 +35,7 @@
|
|||||||
#include "portable_storage_to_json.h"
|
#include "portable_storage_to_json.h"
|
||||||
#include "portable_storage_from_json.h"
|
#include "portable_storage_from_json.h"
|
||||||
#include "portable_storage_val_converters.h"
|
#include "portable_storage_val_converters.h"
|
||||||
|
#include "span.h"
|
||||||
#include "int-util.h"
|
#include "int-util.h"
|
||||||
|
|
||||||
namespace epee
|
namespace epee
|
||||||
@@ -81,7 +82,8 @@ namespace epee
|
|||||||
|
|
||||||
//-------------------------------------------------------------------------------
|
//-------------------------------------------------------------------------------
|
||||||
bool store_to_binary(binarybuffer& target);
|
bool store_to_binary(binarybuffer& target);
|
||||||
bool load_from_binary(const binarybuffer& target);
|
bool load_from_binary(const epee::span<const uint8_t> target);
|
||||||
|
bool load_from_binary(const std::string& target) { return load_from_binary(epee::strspan<uint8_t>(target)); }
|
||||||
template<class trace_policy>
|
template<class trace_policy>
|
||||||
bool dump_as_xml(std::string& targetObj, const std::string& root_name = "");
|
bool dump_as_xml(std::string& targetObj, const std::string& root_name = "");
|
||||||
bool dump_as_json(std::string& targetObj, size_t indent = 0, bool insert_newlines = true);
|
bool dump_as_json(std::string& targetObj, size_t indent = 0, bool insert_newlines = true);
|
||||||
@@ -146,7 +148,7 @@ namespace epee
|
|||||||
CATCH_ENTRY("portable_storage::store_to_binary", false)
|
CATCH_ENTRY("portable_storage::store_to_binary", false)
|
||||||
}
|
}
|
||||||
inline
|
inline
|
||||||
bool portable_storage::load_from_binary(const binarybuffer& source)
|
bool portable_storage::load_from_binary(const epee::span<const uint8_t> source)
|
||||||
{
|
{
|
||||||
m_root.m_entries.clear();
|
m_root.m_entries.clear();
|
||||||
if(source.size() < sizeof(storage_block_header))
|
if(source.size() < sizeof(storage_block_header))
|
||||||
|
|||||||
@@ -31,7 +31,8 @@
|
|||||||
#include <boost/variant.hpp>
|
#include <boost/variant.hpp>
|
||||||
#include <boost/any.hpp>
|
#include <boost/any.hpp>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <list>
|
#include <vector>
|
||||||
|
#include <deque>
|
||||||
|
|
||||||
#define PORTABLE_STORAGE_SIGNATUREA 0x01011101
|
#define PORTABLE_STORAGE_SIGNATUREA 0x01011101
|
||||||
#define PORTABLE_STORAGE_SIGNATUREB 0x01020101 // bender's nightmare
|
#define PORTABLE_STORAGE_SIGNATUREB 0x01020101 // bender's nightmare
|
||||||
@@ -71,6 +72,9 @@ namespace epee
|
|||||||
{
|
{
|
||||||
struct section;
|
struct section;
|
||||||
|
|
||||||
|
template<typename T> struct entry_container { typedef std::vector<T> type; static void reserve(type &t, size_t n) { t.reserve(n); } };
|
||||||
|
template<> struct entry_container<bool> { typedef std::deque<bool> type; static void reserve(type &t, size_t n) {} };
|
||||||
|
|
||||||
/************************************************************************/
|
/************************************************************************/
|
||||||
/* */
|
/* */
|
||||||
/************************************************************************/
|
/************************************************************************/
|
||||||
@@ -119,8 +123,13 @@ namespace epee
|
|||||||
return m_array.back();
|
return m_array.back();
|
||||||
}
|
}
|
||||||
|
|
||||||
std::list<t_entry_type> m_array;
|
void reserve(size_t n)
|
||||||
mutable typename std::list<t_entry_type>::const_iterator m_it;
|
{
|
||||||
|
entry_container<t_entry_type>::reserve(m_array, n);
|
||||||
|
}
|
||||||
|
|
||||||
|
typename entry_container<t_entry_type>::type m_array;
|
||||||
|
mutable typename entry_container<t_entry_type>::type::const_iterator m_it;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -136,6 +136,7 @@ namespace epee
|
|||||||
//for pod types
|
//for pod types
|
||||||
array_entry_t<type_name> sa;
|
array_entry_t<type_name> sa;
|
||||||
size_t size = read_varint();
|
size_t size = read_varint();
|
||||||
|
sa.reserve(size);
|
||||||
//TODO: add some optimization here later
|
//TODO: add some optimization here later
|
||||||
while(size--)
|
while(size--)
|
||||||
sa.m_array.push_back(read<type_name>());
|
sa.m_array.push_back(read<type_name>());
|
||||||
|
|||||||
@@ -39,7 +39,7 @@ namespace epee
|
|||||||
{
|
{
|
||||||
namespace json
|
namespace json
|
||||||
{
|
{
|
||||||
#define CHECK_ISSPACE() if(!isspace(*it)){ ASSERT_MES_AND_THROW("Wrong JSON character at: " << std::string(it, buf_end));}
|
#define CHECK_ISSPACE() if(!epee::misc_utils::parse::isspace(*it)){ ASSERT_MES_AND_THROW("Wrong JSON character at: " << std::string(it, buf_end));}
|
||||||
|
|
||||||
/*inline void parse_error()
|
/*inline void parse_error()
|
||||||
{
|
{
|
||||||
@@ -114,11 +114,11 @@ namespace epee
|
|||||||
std::string val;
|
std::string val;
|
||||||
match_string2(it, buf_end, val);
|
match_string2(it, buf_end, val);
|
||||||
//insert text value
|
//insert text value
|
||||||
stg.set_value(name, val, current_section);
|
stg.set_value(name, std::move(val), current_section);
|
||||||
state = match_state_wonder_after_value;
|
state = match_state_wonder_after_value;
|
||||||
}else if (isdigit(*it) || *it == '-')
|
}else if (epee::misc_utils::parse::isdigit(*it) || *it == '-')
|
||||||
{//just a named number value started
|
{//just a named number value started
|
||||||
std::string val;
|
boost::string_ref val;
|
||||||
bool is_v_float = false;bool is_signed = false;
|
bool is_v_float = false;bool is_signed = false;
|
||||||
match_number2(it, buf_end, val, is_v_float, is_signed);
|
match_number2(it, buf_end, val, is_v_float, is_signed);
|
||||||
if(!is_v_float)
|
if(!is_v_float)
|
||||||
@@ -126,27 +126,27 @@ namespace epee
|
|||||||
if(is_signed)
|
if(is_signed)
|
||||||
{
|
{
|
||||||
errno = 0;
|
errno = 0;
|
||||||
int64_t nval = strtoll(val.c_str(), NULL, 10);
|
int64_t nval = strtoll(val.data(), NULL, 10);
|
||||||
if (errno) throw std::runtime_error("Invalid number: " + val);
|
if (errno) throw std::runtime_error("Invalid number: " + std::string(val));
|
||||||
stg.set_value(name, nval, current_section);
|
stg.set_value(name, nval, current_section);
|
||||||
}else
|
}else
|
||||||
{
|
{
|
||||||
errno = 0;
|
errno = 0;
|
||||||
uint64_t nval = strtoull(val.c_str(), NULL, 10);
|
uint64_t nval = strtoull(val.data(), NULL, 10);
|
||||||
if (errno) throw std::runtime_error("Invalid number: " + val);
|
if (errno) throw std::runtime_error("Invalid number: " + std::string(val));
|
||||||
stg.set_value(name, nval, current_section);
|
stg.set_value(name, nval, current_section);
|
||||||
}
|
}
|
||||||
}else
|
}else
|
||||||
{
|
{
|
||||||
errno = 0;
|
errno = 0;
|
||||||
double nval = strtod(val.c_str(), NULL);
|
double nval = strtod(val.data(), NULL);
|
||||||
if (errno) throw std::runtime_error("Invalid number: " + val);
|
if (errno) throw std::runtime_error("Invalid number: " + std::string(val));
|
||||||
stg.set_value(name, nval, current_section);
|
stg.set_value(name, nval, current_section);
|
||||||
}
|
}
|
||||||
state = match_state_wonder_after_value;
|
state = match_state_wonder_after_value;
|
||||||
}else if(isalpha(*it) )
|
}else if(isalpha(*it) )
|
||||||
{// could be null, true or false
|
{// could be null, true or false
|
||||||
std::string word;
|
boost::string_ref word;
|
||||||
match_word2(it, buf_end, word);
|
match_word2(it, buf_end, word);
|
||||||
if(boost::iequals(word, "null"))
|
if(boost::iequals(word, "null"))
|
||||||
{
|
{
|
||||||
@@ -203,13 +203,13 @@ namespace epee
|
|||||||
//mean array of strings
|
//mean array of strings
|
||||||
std::string val;
|
std::string val;
|
||||||
match_string2(it, buf_end, val);
|
match_string2(it, buf_end, val);
|
||||||
h_array = stg.insert_first_value(name, val, current_section);
|
h_array = stg.insert_first_value(name, std::move(val), current_section);
|
||||||
CHECK_AND_ASSERT_THROW_MES(h_array, " failed to insert values entry");
|
CHECK_AND_ASSERT_THROW_MES(h_array, " failed to insert values entry");
|
||||||
state = match_state_array_after_value;
|
state = match_state_array_after_value;
|
||||||
array_md = array_mode_string;
|
array_md = array_mode_string;
|
||||||
}else if (isdigit(*it) || *it == '-')
|
}else if (epee::misc_utils::parse::isdigit(*it) || *it == '-')
|
||||||
{//array of numbers value started
|
{//array of numbers value started
|
||||||
std::string val;
|
boost::string_ref val;
|
||||||
bool is_v_float = false;bool is_signed_val = false;
|
bool is_v_float = false;bool is_signed_val = false;
|
||||||
match_number2(it, buf_end, val, is_v_float, is_signed_val);
|
match_number2(it, buf_end, val, is_v_float, is_signed_val);
|
||||||
if(!is_v_float)
|
if(!is_v_float)
|
||||||
@@ -217,22 +217,22 @@ namespace epee
|
|||||||
if (is_signed_val)
|
if (is_signed_val)
|
||||||
{
|
{
|
||||||
errno = 0;
|
errno = 0;
|
||||||
int64_t nval = strtoll(val.c_str(), NULL, 10);
|
int64_t nval = strtoll(val.data(), NULL, 10);
|
||||||
if (errno) throw std::runtime_error("Invalid number: " + val);
|
if (errno) throw std::runtime_error("Invalid number: " + std::string(val));
|
||||||
h_array = stg.insert_first_value(name, nval, current_section);
|
h_array = stg.insert_first_value(name, nval, current_section);
|
||||||
}else
|
}else
|
||||||
{
|
{
|
||||||
errno = 0;
|
errno = 0;
|
||||||
uint64_t nval = strtoull(val.c_str(), NULL, 10);
|
uint64_t nval = strtoull(val.data(), NULL, 10);
|
||||||
if (errno) throw std::runtime_error("Invalid number: " + val);
|
if (errno) throw std::runtime_error("Invalid number: " + std::string(val));
|
||||||
h_array = stg.insert_first_value(name, nval, current_section);
|
h_array = stg.insert_first_value(name, nval, current_section);
|
||||||
}
|
}
|
||||||
CHECK_AND_ASSERT_THROW_MES(h_array, " failed to insert values section entry");
|
CHECK_AND_ASSERT_THROW_MES(h_array, " failed to insert values section entry");
|
||||||
}else
|
}else
|
||||||
{
|
{
|
||||||
errno = 0;
|
errno = 0;
|
||||||
double nval = strtod(val.c_str(), NULL);
|
double nval = strtod(val.data(), NULL);
|
||||||
if (errno) throw std::runtime_error("Invalid number: " + val);
|
if (errno) throw std::runtime_error("Invalid number: " + std::string(val));
|
||||||
h_array = stg.insert_first_value(name, nval, current_section);
|
h_array = stg.insert_first_value(name, nval, current_section);
|
||||||
CHECK_AND_ASSERT_THROW_MES(h_array, " failed to insert values section entry");
|
CHECK_AND_ASSERT_THROW_MES(h_array, " failed to insert values section entry");
|
||||||
}
|
}
|
||||||
@@ -245,7 +245,7 @@ namespace epee
|
|||||||
state = match_state_wonder_after_value;
|
state = match_state_wonder_after_value;
|
||||||
}else if(isalpha(*it) )
|
}else if(isalpha(*it) )
|
||||||
{// array of booleans
|
{// array of booleans
|
||||||
std::string word;
|
boost::string_ref word;
|
||||||
match_word2(it, buf_end, word);
|
match_word2(it, buf_end, word);
|
||||||
if(boost::iequals(word, "true"))
|
if(boost::iequals(word, "true"))
|
||||||
{
|
{
|
||||||
@@ -291,15 +291,15 @@ namespace epee
|
|||||||
{
|
{
|
||||||
std::string val;
|
std::string val;
|
||||||
match_string2(it, buf_end, val);
|
match_string2(it, buf_end, val);
|
||||||
bool res = stg.insert_next_value(h_array, val);
|
bool res = stg.insert_next_value(h_array, std::move(val));
|
||||||
CHECK_AND_ASSERT_THROW_MES(res, "failed to insert values");
|
CHECK_AND_ASSERT_THROW_MES(res, "failed to insert values");
|
||||||
state = match_state_array_after_value;
|
state = match_state_array_after_value;
|
||||||
}else CHECK_ISSPACE();
|
}else CHECK_ISSPACE();
|
||||||
break;
|
break;
|
||||||
case array_mode_numbers:
|
case array_mode_numbers:
|
||||||
if (isdigit(*it) || *it == '-')
|
if (epee::misc_utils::parse::isdigit(*it) || *it == '-')
|
||||||
{//array of numbers value started
|
{//array of numbers value started
|
||||||
std::string val;
|
boost::string_ref val;
|
||||||
bool is_v_float = false;bool is_signed_val = false;
|
bool is_v_float = false;bool is_signed_val = false;
|
||||||
match_number2(it, buf_end, val, is_v_float, is_signed_val);
|
match_number2(it, buf_end, val, is_v_float, is_signed_val);
|
||||||
bool insert_res = false;
|
bool insert_res = false;
|
||||||
@@ -308,21 +308,21 @@ namespace epee
|
|||||||
if (is_signed_val)
|
if (is_signed_val)
|
||||||
{
|
{
|
||||||
errno = 0;
|
errno = 0;
|
||||||
int64_t nval = strtoll(val.c_str(), NULL, 10);
|
int64_t nval = strtoll(val.data(), NULL, 10);
|
||||||
if (errno) throw std::runtime_error("Invalid number: " + val);
|
if (errno) throw std::runtime_error("Invalid number: " + std::string(val));
|
||||||
insert_res = stg.insert_next_value(h_array, nval);
|
insert_res = stg.insert_next_value(h_array, nval);
|
||||||
}else
|
}else
|
||||||
{
|
{
|
||||||
errno = 0;
|
errno = 0;
|
||||||
uint64_t nval = strtoull(val.c_str(), NULL, 10);
|
uint64_t nval = strtoull(val.data(), NULL, 10);
|
||||||
if (errno) throw std::runtime_error("Invalid number: " + val);
|
if (errno) throw std::runtime_error("Invalid number: " + std::string(val));
|
||||||
insert_res = stg.insert_next_value(h_array, nval);
|
insert_res = stg.insert_next_value(h_array, nval);
|
||||||
}
|
}
|
||||||
}else
|
}else
|
||||||
{
|
{
|
||||||
errno = 0;
|
errno = 0;
|
||||||
double nval = strtod(val.c_str(), NULL);
|
double nval = strtod(val.data(), NULL);
|
||||||
if (errno) throw std::runtime_error("Invalid number: " + val);
|
if (errno) throw std::runtime_error("Invalid number: " + std::string(val));
|
||||||
insert_res = stg.insert_next_value(h_array, nval);
|
insert_res = stg.insert_next_value(h_array, nval);
|
||||||
}
|
}
|
||||||
CHECK_AND_ASSERT_THROW_MES(insert_res, "Failed to insert next value");
|
CHECK_AND_ASSERT_THROW_MES(insert_res, "Failed to insert next value");
|
||||||
@@ -333,7 +333,7 @@ namespace epee
|
|||||||
case array_mode_booleans:
|
case array_mode_booleans:
|
||||||
if(isalpha(*it) )
|
if(isalpha(*it) )
|
||||||
{// array of booleans
|
{// array of booleans
|
||||||
std::string word;
|
boost::string_ref word;
|
||||||
match_word2(it, buf_end, word);
|
match_word2(it, buf_end, word);
|
||||||
if(boost::iequals(word, "true"))
|
if(boost::iequals(word, "true"))
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -84,7 +84,7 @@ namespace epee
|
|||||||
}
|
}
|
||||||
//-----------------------------------------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------------------------------------
|
||||||
template<class t_struct>
|
template<class t_struct>
|
||||||
bool load_t_from_binary(t_struct& out, const std::string& binary_buff)
|
bool load_t_from_binary(t_struct& out, const epee::span<const uint8_t> binary_buff)
|
||||||
{
|
{
|
||||||
portable_storage ps;
|
portable_storage ps;
|
||||||
bool rs = ps.load_from_binary(binary_buff);
|
bool rs = ps.load_from_binary(binary_buff);
|
||||||
@@ -95,6 +95,12 @@ namespace epee
|
|||||||
}
|
}
|
||||||
//-----------------------------------------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------------------------------------
|
||||||
template<class t_struct>
|
template<class t_struct>
|
||||||
|
bool load_t_from_binary(t_struct& out, const std::string& binary_buff)
|
||||||
|
{
|
||||||
|
return load_t_from_binary(out, epee::strspan<uint8_t>(binary_buff));
|
||||||
|
}
|
||||||
|
//-----------------------------------------------------------------------------------------------------------
|
||||||
|
template<class t_struct>
|
||||||
bool load_t_from_binary_file(t_struct& out, const std::string& binary_file)
|
bool load_t_from_binary_file(t_struct& out, const std::string& binary_file)
|
||||||
{
|
{
|
||||||
std::string f_buff;
|
std::string f_buff;
|
||||||
|
|||||||
@@ -40,8 +40,6 @@
|
|||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
#include <boost/uuid/uuid.hpp>
|
|
||||||
#include <boost/uuid/uuid_io.hpp>
|
|
||||||
#include <boost/lexical_cast.hpp>
|
#include <boost/lexical_cast.hpp>
|
||||||
#include <boost/algorithm/string/predicate.hpp>
|
#include <boost/algorithm/string/predicate.hpp>
|
||||||
#include "hex.h"
|
#include "hex.h"
|
||||||
@@ -83,50 +81,18 @@ namespace epee
|
|||||||
{
|
{
|
||||||
namespace string_tools
|
namespace string_tools
|
||||||
{
|
{
|
||||||
//----------------------------------------------------------------------------
|
|
||||||
inline std::string get_str_from_guid_a(const boost::uuids::uuid& rid)
|
|
||||||
{
|
|
||||||
return boost::lexical_cast<std::string>(rid);
|
|
||||||
}
|
|
||||||
//----------------------------------------------------------------------------
|
|
||||||
inline bool get_guid_from_string(OUT boost::uuids::uuid& inetifer, const std::string& str_id)
|
|
||||||
{
|
|
||||||
std::string local_str_id = str_id;
|
|
||||||
if(local_str_id.size() < 36)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if('{' == *local_str_id.begin())
|
|
||||||
local_str_id.erase(0, 1);
|
|
||||||
|
|
||||||
if('}' == *(--local_str_id.end()))
|
|
||||||
local_str_id.erase(--local_str_id.end());
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
inetifer = boost::lexical_cast<boost::uuids::uuid>(local_str_id);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
catch(...)
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
inline std::string buff_to_hex_nodelimer(const std::string& src)
|
inline std::string buff_to_hex_nodelimer(const std::string& src)
|
||||||
{
|
{
|
||||||
return to_hex::string(to_byte_span(to_span(src)));
|
return to_hex::string(to_byte_span(to_span(src)));
|
||||||
}
|
}
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
template<class CharT>
|
inline bool parse_hexstr_to_binbuff(const epee::span<const char> s, epee::span<char>& res)
|
||||||
bool parse_hexstr_to_binbuff(const std::basic_string<CharT>& s, std::basic_string<CharT>& res)
|
|
||||||
{
|
{
|
||||||
res.clear();
|
if (s.size() != res.size() * 2)
|
||||||
if (s.size() & 1)
|
return false;
|
||||||
return false;
|
|
||||||
try
|
unsigned char *dst = (unsigned char *)&res[0];
|
||||||
{
|
|
||||||
res.resize(s.size() / 2);
|
|
||||||
unsigned char *dst = (unsigned char *)res.data();
|
|
||||||
const unsigned char *src = (const unsigned char *)s.data();
|
const unsigned char *src = (const unsigned char *)s.data();
|
||||||
for(size_t i = 0; i < s.size(); i += 2)
|
for(size_t i = 0; i < s.size(); i += 2)
|
||||||
{
|
{
|
||||||
@@ -140,28 +106,15 @@ namespace string_tools
|
|||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
|
||||||
catch(...)
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
template<class t_pod_type>
|
inline bool parse_hexstr_to_binbuff(const std::string& s, std::string& res)
|
||||||
bool parse_tpod_from_hex_string(const std::string& str_hash, t_pod_type& t_pod)
|
|
||||||
{
|
{
|
||||||
static_assert(std::is_pod<t_pod_type>::value, "expected pod type");
|
if (s.size() & 1)
|
||||||
std::string buf;
|
|
||||||
bool res = epee::string_tools::parse_hexstr_to_binbuff(str_hash, buf);
|
|
||||||
if (!res || buf.size() != sizeof(t_pod_type))
|
|
||||||
{
|
|
||||||
return false;
|
return false;
|
||||||
}
|
res.resize(s.size() / 2);
|
||||||
else
|
epee::span<char> rspan((char*)&res[0], res.size());
|
||||||
{
|
return parse_hexstr_to_binbuff(epee::to_span(s), rspan);
|
||||||
buf.copy(reinterpret_cast<char *>(&t_pod), sizeof(t_pod_type));
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
PUSH_WARNINGS
|
PUSH_WARNINGS
|
||||||
@@ -360,17 +313,10 @@ POP_WARNINGS
|
|||||||
bool hex_to_pod(const std::string& hex_str, t_pod_type& s)
|
bool hex_to_pod(const std::string& hex_str, t_pod_type& s)
|
||||||
{
|
{
|
||||||
static_assert(std::is_pod<t_pod_type>::value, "expected pod type");
|
static_assert(std::is_pod<t_pod_type>::value, "expected pod type");
|
||||||
std::string hex_str_tr = trim(hex_str);
|
|
||||||
if(sizeof(s)*2 != hex_str.size())
|
if(sizeof(s)*2 != hex_str.size())
|
||||||
return false;
|
return false;
|
||||||
std::string bin_buff;
|
epee::span<char> rspan((char*)&s, sizeof(s));
|
||||||
if(!parse_hexstr_to_binbuff(hex_str_tr, bin_buff))
|
return parse_hexstr_to_binbuff(epee::to_span(hex_str), rspan);
|
||||||
return false;
|
|
||||||
if(bin_buff.size()!=sizeof(s))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
s = *(t_pod_type*)bin_buff.data();
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
template<class t_pod_type>
|
template<class t_pod_type>
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
# Copyright (c) 2014-2018, The Monero Project
|
# Copyright (c) 2014-2019, The Monero Project
|
||||||
#
|
#
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
@@ -27,7 +27,7 @@
|
|||||||
# THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
# THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
add_library(epee STATIC hex.cpp http_auth.cpp mlog.cpp net_utils_base.cpp string_tools.cpp wipeable_string.cpp memwipe.c
|
add_library(epee STATIC hex.cpp http_auth.cpp mlog.cpp net_utils_base.cpp string_tools.cpp wipeable_string.cpp memwipe.c
|
||||||
connection_basic.cpp network_throttle.cpp network_throttle-detail.cpp mlocker.cpp)
|
connection_basic.cpp network_throttle.cpp network_throttle-detail.cpp mlocker.cpp buffer.cpp)
|
||||||
if (USE_READLINE AND GNU_READLINE_FOUND)
|
if (USE_READLINE AND GNU_READLINE_FOUND)
|
||||||
add_library(epee_readline STATIC readline_buffer.cpp)
|
add_library(epee_readline STATIC readline_buffer.cpp)
|
||||||
endif()
|
endif()
|
||||||
|
|||||||
97
contrib/epee/src/buffer.cpp
Normal file
97
contrib/epee/src/buffer.cpp
Normal file
@@ -0,0 +1,97 @@
|
|||||||
|
// Copyright (c) 2018, The Monero Project
|
||||||
|
//
|
||||||
|
// All rights reserved.
|
||||||
|
//
|
||||||
|
// Redistribution and use in source and binary forms, with or without modification, are
|
||||||
|
// permitted provided that the following conditions are met:
|
||||||
|
//
|
||||||
|
// 1. Redistributions of source code must retain the above copyright notice, this list of
|
||||||
|
// conditions and the following disclaimer.
|
||||||
|
//
|
||||||
|
// 2. Redistributions in binary form must reproduce the above copyright notice, this list
|
||||||
|
// of conditions and the following disclaimer in the documentation and/or other
|
||||||
|
// materials provided with the distribution.
|
||||||
|
//
|
||||||
|
// 3. Neither the name of the copyright holder nor the names of its contributors may be
|
||||||
|
// used to endorse or promote products derived from this software without specific
|
||||||
|
// prior written permission.
|
||||||
|
//
|
||||||
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
|
||||||
|
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||||
|
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
||||||
|
// THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
||||||
|
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
|
||||||
|
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
#include <string.h>
|
||||||
|
#include "net/buffer.h"
|
||||||
|
|
||||||
|
#undef MONERO_DEFAULT_LOG_CATEGORY
|
||||||
|
#define MONERO_DEFAULT_LOG_CATEGORY "net.buffer"
|
||||||
|
|
||||||
|
namespace epee
|
||||||
|
{
|
||||||
|
namespace net_utils
|
||||||
|
{
|
||||||
|
|
||||||
|
void buffer::append(const void *data, size_t sz)
|
||||||
|
{
|
||||||
|
const size_t capacity = storage.capacity();
|
||||||
|
const size_t avail = capacity - storage.size();
|
||||||
|
|
||||||
|
CHECK_AND_ASSERT_THROW_MES(storage.size() < std::numeric_limits<size_t>::max() - sz, "Too much data to append");
|
||||||
|
|
||||||
|
// decide when to move
|
||||||
|
if (sz > avail)
|
||||||
|
{
|
||||||
|
// we have to reallocate or move
|
||||||
|
const bool move = size() + sz <= capacity;
|
||||||
|
if (move)
|
||||||
|
{
|
||||||
|
const size_t bytes = storage.size() - offset;
|
||||||
|
NET_BUFFER_LOG("appending " << sz << " from " << size() << " by moving " << bytes << " from offset " << offset << " first (forced)");
|
||||||
|
memmove(storage.data(), storage.data() + offset, bytes);
|
||||||
|
storage.resize(bytes);
|
||||||
|
offset = 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
NET_BUFFER_LOG("appending " << sz << " from " << size() << " by reallocating");
|
||||||
|
std::vector<uint8_t> new_storage;
|
||||||
|
size_t reserve = (((size() + sz) * 3 / 2) + 4095) & ~4095;
|
||||||
|
new_storage.reserve(reserve);
|
||||||
|
new_storage.resize(size());
|
||||||
|
memcpy(new_storage.data(), storage.data() + offset, storage.size() - offset);
|
||||||
|
offset = 0;
|
||||||
|
std::swap(storage, new_storage);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// we have space already
|
||||||
|
if (size() <= 4096 && offset > 4096 * 16 && offset >= capacity / 2)
|
||||||
|
{
|
||||||
|
// we have little to move, and we're far enough into the buffer that it's probably a win to move anyway
|
||||||
|
const size_t pos = storage.size() - offset;
|
||||||
|
NET_BUFFER_LOG("appending " << sz << " from " << size() << " by moving " << pos << " from offset " << offset << " first (unforced)");
|
||||||
|
memmove(storage.data(), storage.data() + offset, storage.size() - offset);
|
||||||
|
storage.resize(pos);
|
||||||
|
offset = 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
NET_BUFFER_LOG("appending " << sz << " from " << size() << " by writing to existing capacity");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// add the new data
|
||||||
|
storage.insert(storage.end(), (const uint8_t*)data, (const uint8_t*)data + sz);
|
||||||
|
|
||||||
|
NET_BUFFER_LOG("storage now " << offset << "/" << storage.size() << "/" << storage.capacity());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -2,7 +2,7 @@
|
|||||||
/// @author rfree (current maintainer in monero.cc project)
|
/// @author rfree (current maintainer in monero.cc project)
|
||||||
/// @brief base for connection, contains e.g. the ratelimit hooks
|
/// @brief base for connection, contains e.g. the ratelimit hooks
|
||||||
|
|
||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2019, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2019, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -40,6 +40,9 @@
|
|||||||
|
|
||||||
#include <atomic>
|
#include <atomic>
|
||||||
|
|
||||||
|
#undef MONERO_DEFAULT_LOG_CATEGORY
|
||||||
|
#define MONERO_DEFAULT_LOG_CATEGORY "mlocker"
|
||||||
|
|
||||||
// did an mlock operation previously fail? we only
|
// did an mlock operation previously fail? we only
|
||||||
// want to log an error once and be done with it
|
// want to log an error once and be done with it
|
||||||
static std::atomic<bool> previously_failed{ false };
|
static std::atomic<bool> previously_failed{ false };
|
||||||
|
|||||||
@@ -103,7 +103,7 @@ static const char *get_default_categories(int level)
|
|||||||
categories = "*:WARNING,net:FATAL,net.http:FATAL,net.p2p:FATAL,net.cn:FATAL,global:INFO,verify:FATAL,stacktrace:INFO,logging:INFO,msgwriter:INFO";
|
categories = "*:WARNING,net:FATAL,net.http:FATAL,net.p2p:FATAL,net.cn:FATAL,global:INFO,verify:FATAL,stacktrace:INFO,logging:INFO,msgwriter:INFO";
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
categories = "*:INFO,global:INFO,stacktrace:INFO,logging:INFO,msgwriter:INFO";
|
categories = "*:INFO,global:INFO,stacktrace:INFO,logging:INFO,msgwriter:INFO,perf.*:DEBUG";
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
categories = "*:DEBUG";
|
categories = "*:DEBUG";
|
||||||
|
|||||||
@@ -1,7 +1,9 @@
|
|||||||
|
|
||||||
#include "net/net_utils_base.h"
|
#include "net/net_utils_base.h"
|
||||||
#include "string_tools.h"
|
|
||||||
|
|
||||||
|
#include <boost/uuid/uuid_io.hpp>
|
||||||
|
|
||||||
|
#include "string_tools.h"
|
||||||
#include "net/local_ip.h"
|
#include "net/local_ip.h"
|
||||||
|
|
||||||
namespace epee { namespace net_utils
|
namespace epee { namespace net_utils
|
||||||
@@ -73,7 +75,7 @@ namespace epee { namespace net_utils
|
|||||||
std::string print_connection_context(const connection_context_base& ctx)
|
std::string print_connection_context(const connection_context_base& ctx)
|
||||||
{
|
{
|
||||||
std::stringstream ss;
|
std::stringstream ss;
|
||||||
ss << ctx.m_remote_address.str() << " " << epee::string_tools::get_str_from_guid_a(ctx.m_connection_id) << (ctx.m_is_income ? " INC":" OUT");
|
ss << ctx.m_remote_address.str() << " " << ctx.m_connection_id << (ctx.m_is_income ? " INC":" OUT");
|
||||||
return ss.str();
|
return ss.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
/// @author rfree (current maintainer in monero.cc project)
|
/// @author rfree (current maintainer in monero.cc project)
|
||||||
/// @brief implementaion for throttling of connection (count and rate-limit speed etc)
|
/// @brief implementaion for throttling of connection (count and rate-limit speed etc)
|
||||||
|
|
||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2019, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -26,7 +26,7 @@ Throttling work by:
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// Copyright (c) 2014-2018, The Monero Project
|
// Copyright (c) 2014-2019, The Monero Project
|
||||||
//
|
//
|
||||||
// All rights reserved.
|
// All rights reserved.
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -114,7 +114,7 @@ int rdln::readline_buffer::sync()
|
|||||||
int end = 0, point = 0;
|
int end = 0, point = 0;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (rl_end || *rl_prompt)
|
if (rl_end || (rl_prompt && *rl_prompt))
|
||||||
{
|
{
|
||||||
#if RL_READLINE_VERSION >= 0x0700
|
#if RL_READLINE_VERSION >= 0x0700
|
||||||
rl_clear_visible_line();
|
rl_clear_visible_line();
|
||||||
@@ -137,7 +137,7 @@ int rdln::readline_buffer::sync()
|
|||||||
while ( this->snextc() != EOF );
|
while ( this->snextc() != EOF );
|
||||||
|
|
||||||
#if RL_READLINE_VERSION < 0x0700
|
#if RL_READLINE_VERSION < 0x0700
|
||||||
if (end || *rl_prompt)
|
if (end || (rl_prompt && *rl_prompt))
|
||||||
{
|
{
|
||||||
rl_restore_prompt();
|
rl_restore_prompt();
|
||||||
rl_line_buffer = line;
|
rl_line_buffer = line;
|
||||||
|
|||||||
@@ -14,8 +14,8 @@ IF (MSVC)
|
|||||||
include_directories(SYSTEM platform/msvc)
|
include_directories(SYSTEM platform/msvc)
|
||||||
ELSE()
|
ELSE()
|
||||||
# set stuff for other systems
|
# set stuff for other systems
|
||||||
SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -std=c11 -Wall -Werror")
|
SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -std=c11 -Wall")
|
||||||
SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11 -Wall -Werror -Wno-reorder")
|
SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11 -Wall -Wno-reorder")
|
||||||
ENDIF()
|
ENDIF()
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -152,7 +152,7 @@ script: |
|
|||||||
for i in ${HOSTS}; do
|
for i in ${HOSTS}; do
|
||||||
export PATH=${BASEPREFIX}/${i}/native/bin:${ORIGPATH}
|
export PATH=${BASEPREFIX}/${i}/native/bin:${ORIGPATH}
|
||||||
mkdir build && cd build
|
mkdir build && cd build
|
||||||
cmake .. -DCMAKE_TOOLCHAIN_FILE=${BASEPREFIX}/${i}/share/toolchain.cmake
|
cmake .. -DCMAKE_TOOLCHAIN_FILE=${BASEPREFIX}/${i}/share/toolchain.cmake -DBACKCOMPAT=ON
|
||||||
make
|
make
|
||||||
DISTNAME=monero-${i}
|
DISTNAME=monero-${i}
|
||||||
mv bin ${DISTNAME}
|
mv bin ${DISTNAME}
|
||||||
|
|||||||
@@ -1,163 +0,0 @@
|
|||||||
#!/usr/bin/env python3
|
|
||||||
# Copyright (c) 2014 Wladimir J. van der Laan
|
|
||||||
# Distributed under the MIT software license, see the accompanying
|
|
||||||
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
||||||
'''
|
|
||||||
A script to check that the (Linux) executables produced by gitian only contain
|
|
||||||
allowed gcc, glibc and libstdc++ version symbols. This makes sure they are
|
|
||||||
still compatible with the minimum supported Linux distribution versions.
|
|
||||||
|
|
||||||
Example usage:
|
|
||||||
|
|
||||||
find ../gitian-builder/build -type f -executable | xargs python contrib/devtools/symbol-check.py
|
|
||||||
'''
|
|
||||||
import subprocess
|
|
||||||
import re
|
|
||||||
import sys
|
|
||||||
import os
|
|
||||||
|
|
||||||
# Debian 6.0.9 (Squeeze) has:
|
|
||||||
#
|
|
||||||
# - g++ version 4.4.5 (https://packages.debian.org/search?suite=default§ion=all&arch=any&searchon=names&keywords=g%2B%2B)
|
|
||||||
# - libc version 2.11.3 (https://packages.debian.org/search?suite=default§ion=all&arch=any&searchon=names&keywords=libc6)
|
|
||||||
# - libstdc++ version 4.4.5 (https://packages.debian.org/search?suite=default§ion=all&arch=any&searchon=names&keywords=libstdc%2B%2B6)
|
|
||||||
#
|
|
||||||
# Ubuntu 10.04.4 (Lucid Lynx) has:
|
|
||||||
#
|
|
||||||
# - g++ version 4.4.3 (http://packages.ubuntu.com/search?keywords=g%2B%2B&searchon=names&suite=lucid§ion=all)
|
|
||||||
# - libc version 2.11.1 (http://packages.ubuntu.com/search?keywords=libc6&searchon=names&suite=lucid§ion=all)
|
|
||||||
# - libstdc++ version 4.4.3 (http://packages.ubuntu.com/search?suite=lucid§ion=all&arch=any&keywords=libstdc%2B%2B&searchon=names)
|
|
||||||
#
|
|
||||||
# Taking the minimum of these as our target.
|
|
||||||
#
|
|
||||||
# According to GNU ABI document (http://gcc.gnu.org/onlinedocs/libstdc++/manual/abi.html) this corresponds to:
|
|
||||||
# GCC 4.4.0: GCC_4.4.0
|
|
||||||
# GCC 4.4.2: GLIBCXX_3.4.13, CXXABI_1.3.3
|
|
||||||
# (glibc) GLIBC_2_11
|
|
||||||
#
|
|
||||||
MAX_VERSIONS = {
|
|
||||||
'GCC': (4,4,0),
|
|
||||||
'CXXABI': (1,3,3),
|
|
||||||
'GLIBCXX': (3,4,13),
|
|
||||||
'GLIBC': (2,11)
|
|
||||||
}
|
|
||||||
# See here for a description of _IO_stdin_used:
|
|
||||||
# https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=634261#109
|
|
||||||
|
|
||||||
# Ignore symbols that are exported as part of every executable
|
|
||||||
IGNORE_EXPORTS = {
|
|
||||||
'_edata', '_end', '_init', '__bss_start', '_fini', '_IO_stdin_used', 'stdin', 'stdout', 'stderr'
|
|
||||||
}
|
|
||||||
READELF_CMD = os.getenv('READELF', '/usr/bin/readelf')
|
|
||||||
CPPFILT_CMD = os.getenv('CPPFILT', '/usr/bin/c++filt')
|
|
||||||
# Allowed NEEDED libraries
|
|
||||||
ALLOWED_LIBRARIES = {
|
|
||||||
# bitcoind and bitcoin-qt
|
|
||||||
'libgcc_s.so.1', # GCC base support
|
|
||||||
'libc.so.6', # C library
|
|
||||||
'libpthread.so.0', # threading
|
|
||||||
'libanl.so.1', # DNS resolve
|
|
||||||
'libm.so.6', # math library
|
|
||||||
'librt.so.1', # real-time (clock)
|
|
||||||
'ld-linux-x86-64.so.2', # 64-bit dynamic linker
|
|
||||||
'ld-linux.so.2', # 32-bit dynamic linker
|
|
||||||
# bitcoin-qt only
|
|
||||||
'libX11-xcb.so.1', # part of X11
|
|
||||||
'libX11.so.6', # part of X11
|
|
||||||
'libxcb.so.1', # part of X11
|
|
||||||
'libfontconfig.so.1', # font support
|
|
||||||
'libfreetype.so.6', # font parsing
|
|
||||||
'libdl.so.2' # programming interface to dynamic linker
|
|
||||||
}
|
|
||||||
|
|
||||||
class CPPFilt(object):
|
|
||||||
'''
|
|
||||||
Demangle C++ symbol names.
|
|
||||||
|
|
||||||
Use a pipe to the 'c++filt' command.
|
|
||||||
'''
|
|
||||||
def __init__(self):
|
|
||||||
self.proc = subprocess.Popen(CPPFILT_CMD, stdin=subprocess.PIPE, stdout=subprocess.PIPE, universal_newlines=True)
|
|
||||||
|
|
||||||
def __call__(self, mangled):
|
|
||||||
self.proc.stdin.write(mangled + '\n')
|
|
||||||
self.proc.stdin.flush()
|
|
||||||
return self.proc.stdout.readline().rstrip()
|
|
||||||
|
|
||||||
def close(self):
|
|
||||||
self.proc.stdin.close()
|
|
||||||
self.proc.stdout.close()
|
|
||||||
self.proc.wait()
|
|
||||||
|
|
||||||
def read_symbols(executable, imports=True):
|
|
||||||
'''
|
|
||||||
Parse an ELF executable and return a list of (symbol,version) tuples
|
|
||||||
for dynamic, imported symbols.
|
|
||||||
'''
|
|
||||||
p = subprocess.Popen([READELF_CMD, '--dyn-syms', '-W', executable], stdout=subprocess.PIPE, stderr=subprocess.PIPE, stdin=subprocess.PIPE, universal_newlines=True)
|
|
||||||
(stdout, stderr) = p.communicate()
|
|
||||||
if p.returncode:
|
|
||||||
raise IOError('Could not read symbols for %s: %s' % (executable, stderr.strip()))
|
|
||||||
syms = []
|
|
||||||
for line in stdout.splitlines():
|
|
||||||
line = line.split()
|
|
||||||
if len(line)>7 and re.match('[0-9]+:$', line[0]):
|
|
||||||
(sym, _, version) = line[7].partition('@')
|
|
||||||
is_import = line[6] == 'UND'
|
|
||||||
if version.startswith('@'):
|
|
||||||
version = version[1:]
|
|
||||||
if is_import == imports:
|
|
||||||
syms.append((sym, version))
|
|
||||||
return syms
|
|
||||||
|
|
||||||
def check_version(max_versions, version):
|
|
||||||
if '_' in version:
|
|
||||||
(lib, _, ver) = version.rpartition('_')
|
|
||||||
else:
|
|
||||||
lib = version
|
|
||||||
ver = '0'
|
|
||||||
ver = tuple([int(x) for x in ver.split('.')])
|
|
||||||
if not lib in max_versions:
|
|
||||||
return False
|
|
||||||
return ver <= max_versions[lib]
|
|
||||||
|
|
||||||
def read_libraries(filename):
|
|
||||||
p = subprocess.Popen([READELF_CMD, '-d', '-W', filename], stdout=subprocess.PIPE, stderr=subprocess.PIPE, stdin=subprocess.PIPE, universal_newlines=True)
|
|
||||||
(stdout, stderr) = p.communicate()
|
|
||||||
if p.returncode:
|
|
||||||
raise IOError('Error opening file')
|
|
||||||
libraries = []
|
|
||||||
for line in stdout.splitlines():
|
|
||||||
tokens = line.split()
|
|
||||||
if len(tokens)>2 and tokens[1] == '(NEEDED)':
|
|
||||||
match = re.match('^Shared library: \[(.*)\]$', ' '.join(tokens[2:]))
|
|
||||||
if match:
|
|
||||||
libraries.append(match.group(1))
|
|
||||||
else:
|
|
||||||
raise ValueError('Unparseable (NEEDED) specification')
|
|
||||||
return libraries
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
cppfilt = CPPFilt()
|
|
||||||
retval = 0
|
|
||||||
for filename in sys.argv[1:]:
|
|
||||||
# Check imported symbols
|
|
||||||
for sym,version in read_symbols(filename, True):
|
|
||||||
if version and not check_version(MAX_VERSIONS, version):
|
|
||||||
print('%s: symbol %s from unsupported version %s' % (filename, cppfilt(sym), version))
|
|
||||||
retval = 1
|
|
||||||
# Check exported symbols
|
|
||||||
for sym,version in read_symbols(filename, False):
|
|
||||||
if sym in IGNORE_EXPORTS:
|
|
||||||
continue
|
|
||||||
print('%s: export of symbol %s not allowed' % (filename, cppfilt(sym)))
|
|
||||||
retval = 1
|
|
||||||
# Check dependency libraries
|
|
||||||
for library_name in read_libraries(filename):
|
|
||||||
if library_name not in ALLOWED_LIBRARIES:
|
|
||||||
print('%s: NEEDED library %s is not allowed' % (filename, library_name))
|
|
||||||
retval = 1
|
|
||||||
|
|
||||||
sys.exit(retval)
|
|
||||||
|
|
||||||
|
|
||||||
@@ -1,8 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
if [ ! -d "$SNAP_USER_DATA/etc" ]; then
|
|
||||||
mkdir $SNAP_USER_DATA/etc/
|
|
||||||
cp -R $SNAP/etc/monerod.conf $SNAP_USER_DATA/etc/monerod.conf
|
|
||||||
fi
|
|
||||||
|
|
||||||
exec "$SNAP/bin/monerod" "$@"
|
|
||||||
Binary file not shown.
|
Before Width: | Height: | Size: 1.5 KiB After Width: | Height: | Size: 18 KiB |
@@ -1,31 +1,29 @@
|
|||||||
name: monero
|
name: wownero
|
||||||
version: 0.11.1.0-1
|
version: 0.5.0.0
|
||||||
summary: "Monero: the secure, private, untraceable cryptocurrency https://getmonero.org"
|
summary: "Wownero: the secure, private, untraceable cryptocurrency http://wownero.org"
|
||||||
description: |
|
description: |
|
||||||
Monero is a private, secure, untraceable, decentralised digital currency.
|
Wownero: a fairly launched privacy-centric meme coin with no premine and a finite supply.
|
||||||
You are your bank, you control your funds, and nobody can trace your transfers
|
|
||||||
unless you allow them to do so.
|
|
||||||
grade: devel
|
grade: devel
|
||||||
confinement: strict
|
confinement: strict
|
||||||
|
|
||||||
apps:
|
apps:
|
||||||
monerod:
|
wownerod:
|
||||||
daemon: forking
|
daemon: forking
|
||||||
command: |
|
command: |
|
||||||
monerod-wrapper --detach --data-dir ${SNAP_COMMON} --config-file ${SNAP_USER_DATA}/etc/monerod.conf
|
wownerod-wrapper --detach --data-dir ${SNAP_COMMON} --config-file ${SNAP_USER_DATA}/etc/wownerod.conf
|
||||||
plugs:
|
plugs:
|
||||||
- network
|
- network
|
||||||
- network-bind
|
- network-bind
|
||||||
monero-wallet-rpc:
|
wownero-wallet-rpc:
|
||||||
command: |
|
command: |
|
||||||
monero-wallet-rpc --log-file ${SNAP_USER_DATA}
|
wownero-wallet-rpc --log-file ${SNAP_USER_DATA}
|
||||||
plugs:
|
plugs:
|
||||||
- home
|
- home
|
||||||
- network
|
- network
|
||||||
- network-bind
|
- network-bind
|
||||||
monero-wallet-cli:
|
wownero-wallet-cli:
|
||||||
command: |
|
command: |
|
||||||
monero-wallet-cli --log-file ${SNAP_USER_DATA}
|
wownero-wallet-cli --log-file ${SNAP_USER_DATA}
|
||||||
plugs:
|
plugs:
|
||||||
- home
|
- home
|
||||||
- network
|
- network
|
||||||
@@ -71,8 +69,8 @@ parts:
|
|||||||
plugin: dump
|
plugin: dump
|
||||||
source: .
|
source: .
|
||||||
organize:
|
organize:
|
||||||
contrib/snap/monerod.conf: etc/monerod.conf
|
contrib/snap/wownerod.conf: etc/wownerod.conf
|
||||||
contrib/snap/monerod-wrapper: bin/monerod-wrapper
|
contrib/snap/wownerod-wrapper: bin/wownerod-wrapper
|
||||||
prime:
|
prime:
|
||||||
- etc
|
- etc
|
||||||
- bin
|
- bin
|
||||||
|
|||||||
8
contrib/snap/wownerod-wrapper
Executable file
8
contrib/snap/wownerod-wrapper
Executable file
@@ -0,0 +1,8 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
if [ ! -d "$SNAP_USER_DATA/etc" ]; then
|
||||||
|
mkdir $SNAP_USER_DATA/etc/
|
||||||
|
cp -R $SNAP/etc/wownerod.conf $SNAP_USER_DATA/etc/wownerod.conf
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec "$SNAP/bin/wownerod" "$@"
|
||||||
@@ -4,7 +4,7 @@
|
|||||||
# See 'monerod --help' for all available options.
|
# See 'monerod --help' for all available options.
|
||||||
|
|
||||||
# Overridden by snap:
|
# Overridden by snap:
|
||||||
# data-dir=/var/lib/monero
|
# data-dir=/var/lib/wownero
|
||||||
# log-file=/var/log/monero/monero.log
|
# log-file=/var/log/wownero/wownero.log
|
||||||
|
|
||||||
log-level=0
|
log-level=0
|
||||||
50
external/CMakeLists.txt
vendored
50
external/CMakeLists.txt
vendored
@@ -1,4 +1,4 @@
|
|||||||
# Copyright (c) 2014-2018, The Monero Project
|
# Copyright (c) 2014-2019, The Monero Project
|
||||||
#
|
#
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
@@ -34,22 +34,42 @@
|
|||||||
# We always compile if we are building statically to reduce static dependency issues...
|
# We always compile if we are building statically to reduce static dependency issues...
|
||||||
# ...except for FreeBSD, because FreeBSD is a special case that doesn't play well with
|
# ...except for FreeBSD, because FreeBSD is a special case that doesn't play well with
|
||||||
# others.
|
# others.
|
||||||
|
if(NOT IOS)
|
||||||
find_package(Miniupnpc REQUIRED)
|
find_package(Miniupnpc QUIET)
|
||||||
|
|
||||||
message(STATUS "Using in-tree miniupnpc")
|
|
||||||
add_subdirectory(miniupnp/miniupnpc)
|
|
||||||
set_property(TARGET libminiupnpc-static PROPERTY FOLDER "external")
|
|
||||||
if(MSVC)
|
|
||||||
set_property(TARGET libminiupnpc-static APPEND_STRING PROPERTY COMPILE_FLAGS " -wd4244 -wd4267")
|
|
||||||
elseif(NOT MSVC)
|
|
||||||
set_property(TARGET libminiupnpc-static APPEND_STRING PROPERTY COMPILE_FLAGS " -Wno-undef -Wno-unused-result -Wno-unused-value")
|
|
||||||
endif()
|
|
||||||
if(CMAKE_SYSTEM_NAME MATCHES "NetBSD")
|
|
||||||
set_property(TARGET libminiupnpc-static APPEND_STRING PROPERTY COMPILE_FLAGS " -D_NETBSD_SOURCE")
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(UPNP_LIBRARIES "libminiupnpc-static" PARENT_SCOPE)
|
# If we have the correct shared version and we're not building static, use it
|
||||||
|
if(STATIC OR IOS)
|
||||||
|
set(USE_SHARED_MINIUPNPC false)
|
||||||
|
elseif(MINIUPNP_FOUND AND MINIUPNPC_VERSION_1_7_OR_HIGHER)
|
||||||
|
set(USE_SHARED_MINIUPNPC true)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(USE_SHARED_MINIUPNPC)
|
||||||
|
message(STATUS "Using shared miniupnpc found at ${MINIUPNP_INCLUDE_DIR}")
|
||||||
|
|
||||||
|
set(UPNP_STATIC false PARENT_SCOPE)
|
||||||
|
set(UPNP_INCLUDE ${MINIUPNP_INCLUDE_DIR} PARENT_SCOPE)
|
||||||
|
set(UPNP_LIBRARIES ${MINIUPNP_LIBRARY} PARENT_SCOPE)
|
||||||
|
else()
|
||||||
|
if(STATIC)
|
||||||
|
message(STATUS "Using miniupnpc from local source tree for static build")
|
||||||
|
else()
|
||||||
|
message(STATUS "Using miniupnpc from local source tree (/external/miniupnp/miniupnpc)")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
add_subdirectory(miniupnp/miniupnpc)
|
||||||
|
|
||||||
|
set_property(TARGET libminiupnpc-static PROPERTY FOLDER "external")
|
||||||
|
if(MSVC)
|
||||||
|
set_property(TARGET libminiupnpc-static APPEND_STRING PROPERTY COMPILE_FLAGS " -wd4244 -wd4267")
|
||||||
|
elseif(NOT MSVC)
|
||||||
|
set_property(TARGET libminiupnpc-static APPEND_STRING PROPERTY COMPILE_FLAGS " -Wno-undef -Wno-unused-result -Wno-unused-value")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set(UPNP_STATIC true PARENT_SCOPE)
|
||||||
|
set(UPNP_LIBRARIES "libminiupnpc-static" PARENT_SCOPE)
|
||||||
|
endif()
|
||||||
|
|
||||||
find_package(Unbound)
|
find_package(Unbound)
|
||||||
|
|
||||||
|
|||||||
2
external/db_drivers/CMakeLists.txt
vendored
2
external/db_drivers/CMakeLists.txt
vendored
@@ -1,4 +1,4 @@
|
|||||||
# Copyright (c) 2014-2018, The Monero Project
|
# Copyright (c) 2014-2019, The Monero Project
|
||||||
#
|
#
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
|
|||||||
1
external/db_drivers/liblmdb/.gitignore
vendored
1
external/db_drivers/liblmdb/.gitignore
vendored
@@ -5,6 +5,7 @@ mdb_copy
|
|||||||
mdb_stat
|
mdb_stat
|
||||||
mdb_dump
|
mdb_dump
|
||||||
mdb_load
|
mdb_load
|
||||||
|
mdb_drop
|
||||||
*.lo
|
*.lo
|
||||||
*.[ao]
|
*.[ao]
|
||||||
*.so
|
*.so
|
||||||
|
|||||||
2
external/db_drivers/liblmdb/CMakeLists.txt
vendored
2
external/db_drivers/liblmdb/CMakeLists.txt
vendored
@@ -1,4 +1,4 @@
|
|||||||
# Copyright (c) 2014-2018, The Monero Project
|
# Copyright (c) 2014-2019, The Monero Project
|
||||||
#
|
#
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
|
|||||||
2
external/db_drivers/liblmdb/COPYRIGHT
vendored
2
external/db_drivers/liblmdb/COPYRIGHT
vendored
@@ -1,4 +1,4 @@
|
|||||||
Copyright 2011-2015 Howard Chu, Symas Corp.
|
Copyright 2011-2019 Howard Chu, Symas Corp.
|
||||||
All rights reserved.
|
All rights reserved.
|
||||||
|
|
||||||
Redistribution and use in source and binary forms, with or without
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
|||||||
2
external/db_drivers/liblmdb/Doxyfile
vendored
2
external/db_drivers/liblmdb/Doxyfile
vendored
@@ -253,7 +253,7 @@ IDL_PROPERTY_SUPPORT = YES
|
|||||||
# member in the group (if any) for the other members of the group. By default
|
# member in the group (if any) for the other members of the group. By default
|
||||||
# all members of a group must be documented explicitly.
|
# all members of a group must be documented explicitly.
|
||||||
|
|
||||||
DISTRIBUTE_GROUP_DOC = NO
|
DISTRIBUTE_GROUP_DOC = YES
|
||||||
|
|
||||||
# Set the SUBGROUPING tag to YES (the default) to allow class member groups of
|
# Set the SUBGROUPING tag to YES (the default) to allow class member groups of
|
||||||
# the same type (for instance a group of public functions) to be put as a
|
# the same type (for instance a group of public functions) to be put as a
|
||||||
|
|||||||
5
external/db_drivers/liblmdb/Makefile
vendored
5
external/db_drivers/liblmdb/Makefile
vendored
@@ -26,6 +26,7 @@ OPT = -O2 -g
|
|||||||
CFLAGS = $(THREADS) $(OPT) $(W) $(XCFLAGS)
|
CFLAGS = $(THREADS) $(OPT) $(W) $(XCFLAGS)
|
||||||
LDLIBS =
|
LDLIBS =
|
||||||
SOLIBS =
|
SOLIBS =
|
||||||
|
SOEXT = .so
|
||||||
prefix = /usr/local
|
prefix = /usr/local
|
||||||
exec_prefix = $(prefix)
|
exec_prefix = $(prefix)
|
||||||
bindir = $(exec_prefix)/bin
|
bindir = $(exec_prefix)/bin
|
||||||
@@ -37,7 +38,7 @@ mandir = $(datarootdir)/man
|
|||||||
########################################################################
|
########################################################################
|
||||||
|
|
||||||
IHDRS = lmdb.h
|
IHDRS = lmdb.h
|
||||||
ILIBS = liblmdb.a liblmdb.so
|
ILIBS = liblmdb.a liblmdb$(SOEXT)
|
||||||
IPROGS = mdb_stat mdb_copy mdb_dump mdb_load mdb_drop
|
IPROGS = mdb_stat mdb_copy mdb_dump mdb_load mdb_drop
|
||||||
IDOCS = mdb_stat.1 mdb_copy.1 mdb_dump.1 mdb_load.1 mdb_drop.1
|
IDOCS = mdb_stat.1 mdb_copy.1 mdb_dump.1 mdb_load.1 mdb_drop.1
|
||||||
PROGS = $(IPROGS) mtest mtest2 mtest3 mtest4 mtest5
|
PROGS = $(IPROGS) mtest mtest2 mtest3 mtest4 mtest5
|
||||||
@@ -63,7 +64,7 @@ test: all
|
|||||||
liblmdb.a: mdb.o midl.o
|
liblmdb.a: mdb.o midl.o
|
||||||
$(AR) rs $@ mdb.o midl.o
|
$(AR) rs $@ mdb.o midl.o
|
||||||
|
|
||||||
liblmdb.so: mdb.lo midl.lo
|
liblmdb$(SOEXT): mdb.lo midl.lo
|
||||||
# $(CC) $(LDFLAGS) -pthread -shared -Wl,-Bsymbolic -o $@ mdb.o midl.o $(SOLIBS)
|
# $(CC) $(LDFLAGS) -pthread -shared -Wl,-Bsymbolic -o $@ mdb.o midl.o $(SOLIBS)
|
||||||
$(CC) $(LDFLAGS) -pthread -shared -o $@ mdb.lo midl.lo $(SOLIBS)
|
$(CC) $(LDFLAGS) -pthread -shared -o $@ mdb.lo midl.lo $(SOLIBS)
|
||||||
|
|
||||||
|
|||||||
2
external/db_drivers/liblmdb/intro.doc
vendored
2
external/db_drivers/liblmdb/intro.doc
vendored
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright 2015 Howard Chu, Symas Corp.
|
* Copyright 2015-2018 Howard Chu, Symas Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|||||||
63
external/db_drivers/liblmdb/lmdb.h
vendored
63
external/db_drivers/liblmdb/lmdb.h
vendored
@@ -97,11 +97,12 @@
|
|||||||
* transactions. Each transaction belongs to one thread. See below.
|
* transactions. Each transaction belongs to one thread. See below.
|
||||||
* The #MDB_NOTLS flag changes this for read-only transactions.
|
* The #MDB_NOTLS flag changes this for read-only transactions.
|
||||||
*
|
*
|
||||||
* - Use an MDB_env* in the process which opened it, without fork()ing.
|
* - Use an MDB_env* in the process which opened it, not after fork().
|
||||||
*
|
*
|
||||||
* - Do not have open an LMDB database twice in the same process at
|
* - Do not have open an LMDB database twice in the same process at
|
||||||
* the same time. Not even from a plain open() call - close()ing it
|
* the same time. Not even from a plain open() call - close()ing it
|
||||||
* breaks flock() advisory locking.
|
* breaks fcntl() advisory locking. (It is OK to reopen it after
|
||||||
|
* fork() - exec*(), since the lockfile has FD_CLOEXEC set.)
|
||||||
*
|
*
|
||||||
* - Avoid long-lived transactions. Read transactions prevent
|
* - Avoid long-lived transactions. Read transactions prevent
|
||||||
* reuse of pages freed by newer write transactions, thus the
|
* reuse of pages freed by newer write transactions, thus the
|
||||||
@@ -135,7 +136,7 @@
|
|||||||
*
|
*
|
||||||
* @author Howard Chu, Symas Corporation.
|
* @author Howard Chu, Symas Corporation.
|
||||||
*
|
*
|
||||||
* @copyright Copyright 2011-2016 Howard Chu, Symas Corp. All rights reserved.
|
* @copyright Copyright 2011-2019 Howard Chu, Symas Corp. All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted only as authorized by the OpenLDAP
|
* modification, are permitted only as authorized by the OpenLDAP
|
||||||
@@ -167,6 +168,7 @@
|
|||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
|
#include <limits.h>
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
@@ -179,11 +181,30 @@ typedef int mdb_mode_t;
|
|||||||
typedef mode_t mdb_mode_t;
|
typedef mode_t mdb_mode_t;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef MDB_VL32
|
#ifdef _WIN32
|
||||||
typedef uint64_t mdb_size_t;
|
# define MDB_FMT_Z "I"
|
||||||
#define mdb_env_create mdb_env_create_vl32 /**< Prevent mixing with non-VL32 builds */
|
|
||||||
#else
|
#else
|
||||||
|
# define MDB_FMT_Z "z" /**< printf/scanf format modifier for size_t */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef MDB_VL32
|
||||||
|
/** Unsigned type used for mapsize, entry counts and page/transaction IDs.
|
||||||
|
*
|
||||||
|
* It is normally size_t, hence the name. Defining MDB_VL32 makes it
|
||||||
|
* uint64_t, but do not try this unless you know what you are doing.
|
||||||
|
*/
|
||||||
typedef size_t mdb_size_t;
|
typedef size_t mdb_size_t;
|
||||||
|
# define MDB_SIZE_MAX SIZE_MAX /**< max #mdb_size_t */
|
||||||
|
/** #mdb_size_t printf formats, \b t = one of [diouxX] without quotes */
|
||||||
|
# define MDB_PRIy(t) MDB_FMT_Z #t
|
||||||
|
/** #mdb_size_t scanf formats, \b t = one of [dioux] without quotes */
|
||||||
|
# define MDB_SCNy(t) MDB_FMT_Z #t
|
||||||
|
#else
|
||||||
|
typedef uint64_t mdb_size_t;
|
||||||
|
# define MDB_SIZE_MAX UINT64_MAX
|
||||||
|
# define MDB_PRIy(t) PRI##t##64
|
||||||
|
# define MDB_SCNy(t) SCN##t##64
|
||||||
|
# define mdb_env_create mdb_env_create_vl32 /**< Prevent mixing with non-VL32 builds */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/** An abstraction for a file handle.
|
/** An abstraction for a file handle.
|
||||||
@@ -322,7 +343,8 @@ typedef void (MDB_rel_func)(MDB_val *item, void *oldptr, void *newptr, void *rel
|
|||||||
#define MDB_REVERSEKEY 0x02
|
#define MDB_REVERSEKEY 0x02
|
||||||
/** use sorted duplicates */
|
/** use sorted duplicates */
|
||||||
#define MDB_DUPSORT 0x04
|
#define MDB_DUPSORT 0x04
|
||||||
/** numeric keys in native byte order: either unsigned int or size_t.
|
/** numeric keys in native byte order, either unsigned int or #mdb_size_t.
|
||||||
|
* (lmdb expects 32-bit int <= size_t <= 32/64-bit mdb_size_t.)
|
||||||
* The keys must all be of the same size. */
|
* The keys must all be of the same size. */
|
||||||
#define MDB_INTEGERKEY 0x08
|
#define MDB_INTEGERKEY 0x08
|
||||||
/** with #MDB_DUPSORT, sorted dup items have fixed size */
|
/** with #MDB_DUPSORT, sorted dup items have fixed size */
|
||||||
@@ -380,7 +402,7 @@ typedef enum MDB_cursor_op {
|
|||||||
MDB_GET_BOTH, /**< Position at key/data pair. Only for #MDB_DUPSORT */
|
MDB_GET_BOTH, /**< Position at key/data pair. Only for #MDB_DUPSORT */
|
||||||
MDB_GET_BOTH_RANGE, /**< position at key, nearest data. Only for #MDB_DUPSORT */
|
MDB_GET_BOTH_RANGE, /**< position at key, nearest data. Only for #MDB_DUPSORT */
|
||||||
MDB_GET_CURRENT, /**< Return key/data at current cursor position */
|
MDB_GET_CURRENT, /**< Return key/data at current cursor position */
|
||||||
MDB_GET_MULTIPLE, /**< Return key and up to a page of duplicate data items
|
MDB_GET_MULTIPLE, /**< Return up to a page of duplicate data items
|
||||||
from current cursor position. Move cursor to prepare
|
from current cursor position. Move cursor to prepare
|
||||||
for #MDB_NEXT_MULTIPLE. Only for #MDB_DUPFIXED */
|
for #MDB_NEXT_MULTIPLE. Only for #MDB_DUPFIXED */
|
||||||
MDB_LAST, /**< Position at last key/data item */
|
MDB_LAST, /**< Position at last key/data item */
|
||||||
@@ -389,7 +411,7 @@ typedef enum MDB_cursor_op {
|
|||||||
MDB_NEXT, /**< Position at next data item */
|
MDB_NEXT, /**< Position at next data item */
|
||||||
MDB_NEXT_DUP, /**< Position at next data item of current key.
|
MDB_NEXT_DUP, /**< Position at next data item of current key.
|
||||||
Only for #MDB_DUPSORT */
|
Only for #MDB_DUPSORT */
|
||||||
MDB_NEXT_MULTIPLE, /**< Return key and up to a page of duplicate data items
|
MDB_NEXT_MULTIPLE, /**< Return up to a page of duplicate data items
|
||||||
from next cursor position. Move cursor to prepare
|
from next cursor position. Move cursor to prepare
|
||||||
for #MDB_NEXT_MULTIPLE. Only for #MDB_DUPFIXED */
|
for #MDB_NEXT_MULTIPLE. Only for #MDB_DUPFIXED */
|
||||||
MDB_NEXT_NODUP, /**< Position at first data item of next key */
|
MDB_NEXT_NODUP, /**< Position at first data item of next key */
|
||||||
@@ -400,7 +422,7 @@ typedef enum MDB_cursor_op {
|
|||||||
MDB_SET, /**< Position at specified key */
|
MDB_SET, /**< Position at specified key */
|
||||||
MDB_SET_KEY, /**< Position at specified key, return key + data */
|
MDB_SET_KEY, /**< Position at specified key, return key + data */
|
||||||
MDB_SET_RANGE, /**< Position at first key greater than or equal to specified key. */
|
MDB_SET_RANGE, /**< Position at first key greater than or equal to specified key. */
|
||||||
MDB_PREV_MULTIPLE /**< Position at previous page and return key and up to
|
MDB_PREV_MULTIPLE /**< Position at previous page and return up to
|
||||||
a page of duplicate data items. Only for #MDB_DUPFIXED */
|
a page of duplicate data items. Only for #MDB_DUPFIXED */
|
||||||
} MDB_cursor_op;
|
} MDB_cursor_op;
|
||||||
|
|
||||||
@@ -458,8 +480,10 @@ typedef enum MDB_cursor_op {
|
|||||||
#define MDB_BAD_VALSIZE (-30781)
|
#define MDB_BAD_VALSIZE (-30781)
|
||||||
/** The specified DBI was changed unexpectedly */
|
/** The specified DBI was changed unexpectedly */
|
||||||
#define MDB_BAD_DBI (-30780)
|
#define MDB_BAD_DBI (-30780)
|
||||||
|
/** Unexpected problem - txn should abort */
|
||||||
|
#define MDB_PROBLEM (-30779)
|
||||||
/** The last defined error code */
|
/** The last defined error code */
|
||||||
#define MDB_LAST_ERRCODE MDB_BAD_DBI
|
#define MDB_LAST_ERRCODE MDB_PROBLEM
|
||||||
/** @} */
|
/** @} */
|
||||||
|
|
||||||
/** @brief Statistics for a database in the environment */
|
/** @brief Statistics for a database in the environment */
|
||||||
@@ -696,6 +720,7 @@ int mdb_env_copyfd(MDB_env *env, mdb_filehandle_t fd);
|
|||||||
* <li>#MDB_CP_COMPACT - Perform compaction while copying: omit free
|
* <li>#MDB_CP_COMPACT - Perform compaction while copying: omit free
|
||||||
* pages and sequentially renumber all pages in output. This option
|
* pages and sequentially renumber all pages in output. This option
|
||||||
* consumes more CPU and runs more slowly than the default.
|
* consumes more CPU and runs more slowly than the default.
|
||||||
|
* Currently it fails if the environment has suffered a page leak.
|
||||||
* </ul>
|
* </ul>
|
||||||
* @return A non-zero error value on failure and 0 on success.
|
* @return A non-zero error value on failure and 0 on success.
|
||||||
*/
|
*/
|
||||||
@@ -810,6 +835,10 @@ int mdb_env_get_flags(MDB_env *env, unsigned int *flags);
|
|||||||
int mdb_env_get_path(MDB_env *env, const char **path);
|
int mdb_env_get_path(MDB_env *env, const char **path);
|
||||||
|
|
||||||
/** @brief Return the filedescriptor for the given environment.
|
/** @brief Return the filedescriptor for the given environment.
|
||||||
|
*
|
||||||
|
* This function may be called after fork(), so the descriptor can be
|
||||||
|
* closed before exec*(). Other LMDB file descriptors have FD_CLOEXEC.
|
||||||
|
* (Until LMDB 0.9.18, only the lockfile had that.)
|
||||||
*
|
*
|
||||||
* @param[in] env An environment handle returned by #mdb_env_create()
|
* @param[in] env An environment handle returned by #mdb_env_create()
|
||||||
* @param[out] fd Address of a mdb_filehandle_t to contain the descriptor.
|
* @param[out] fd Address of a mdb_filehandle_t to contain the descriptor.
|
||||||
@@ -1112,14 +1141,16 @@ int mdb_txn_renew(MDB_txn *txn);
|
|||||||
* keys must be unique and may have only a single data item.
|
* keys must be unique and may have only a single data item.
|
||||||
* <li>#MDB_INTEGERKEY
|
* <li>#MDB_INTEGERKEY
|
||||||
* Keys are binary integers in native byte order, either unsigned int
|
* Keys are binary integers in native byte order, either unsigned int
|
||||||
* or size_t, and will be sorted as such.
|
* or #mdb_size_t, and will be sorted as such.
|
||||||
|
* (lmdb expects 32-bit int <= size_t <= 32/64-bit mdb_size_t.)
|
||||||
* The keys must all be of the same size.
|
* The keys must all be of the same size.
|
||||||
* <li>#MDB_DUPFIXED
|
* <li>#MDB_DUPFIXED
|
||||||
* This flag may only be used in combination with #MDB_DUPSORT. This option
|
* This flag may only be used in combination with #MDB_DUPSORT. This option
|
||||||
* tells the library that the data items for this database are all the same
|
* tells the library that the data items for this database are all the same
|
||||||
* size, which allows further optimizations in storage and retrieval. When
|
* size, which allows further optimizations in storage and retrieval. When
|
||||||
* all data items are the same size, the #MDB_GET_MULTIPLE and #MDB_NEXT_MULTIPLE
|
* all data items are the same size, the #MDB_GET_MULTIPLE, #MDB_NEXT_MULTIPLE
|
||||||
* cursor operations may be used to retrieve multiple items at once.
|
* and #MDB_PREV_MULTIPLE cursor operations may be used to retrieve multiple
|
||||||
|
* items at once.
|
||||||
* <li>#MDB_INTEGERDUP
|
* <li>#MDB_INTEGERDUP
|
||||||
* This option specifies that duplicate data items are binary integers,
|
* This option specifies that duplicate data items are binary integers,
|
||||||
* similar to #MDB_INTEGERKEY keys.
|
* similar to #MDB_INTEGERKEY keys.
|
||||||
@@ -1524,6 +1555,10 @@ int mdb_cursor_put(MDB_cursor *cursor, MDB_val *key, MDB_val *data,
|
|||||||
/** @brief Delete current key/data pair
|
/** @brief Delete current key/data pair
|
||||||
*
|
*
|
||||||
* This function deletes the key/data pair to which the cursor refers.
|
* This function deletes the key/data pair to which the cursor refers.
|
||||||
|
* This does not invalidate the cursor, so operations such as MDB_NEXT
|
||||||
|
* can still be used on it.
|
||||||
|
* Both MDB_NEXT and MDB_GET_CURRENT will return the same record after
|
||||||
|
* this operation.
|
||||||
* @param[in] cursor A cursor handle returned by #mdb_cursor_open()
|
* @param[in] cursor A cursor handle returned by #mdb_cursor_open()
|
||||||
* @param[in] flags Options for this operation. This parameter
|
* @param[in] flags Options for this operation. This parameter
|
||||||
* must be set to 0 or one of the values described here.
|
* must be set to 0 or one of the values described here.
|
||||||
|
|||||||
1679
external/db_drivers/liblmdb/mdb.c
vendored
1679
external/db_drivers/liblmdb/mdb.c
vendored
File diff suppressed because it is too large
Load Diff
5
external/db_drivers/liblmdb/mdb_copy.1
vendored
5
external/db_drivers/liblmdb/mdb_copy.1
vendored
@@ -1,5 +1,5 @@
|
|||||||
.TH MDB_COPY 1 "2014/06/20" "LMDB 0.9.14"
|
.TH MDB_COPY 1 "2017/07/31" "LMDB 0.9.70"
|
||||||
.\" Copyright 2012-2015 Howard Chu, Symas Corp. All Rights Reserved.
|
.\" Copyright 2012-2019 Howard Chu, Symas Corp. All Rights Reserved.
|
||||||
.\" Copying restrictions apply. See COPYRIGHT/LICENSE.
|
.\" Copying restrictions apply. See COPYRIGHT/LICENSE.
|
||||||
.SH NAME
|
.SH NAME
|
||||||
mdb_copy \- LMDB environment copy tool
|
mdb_copy \- LMDB environment copy tool
|
||||||
@@ -38,6 +38,7 @@ Write the library version number to the standard output, and exit.
|
|||||||
Compact while copying. Only current data pages will be copied; freed
|
Compact while copying. Only current data pages will be copied; freed
|
||||||
or unused pages will be omitted from the copy. This option will
|
or unused pages will be omitted from the copy. This option will
|
||||||
slow down the backup process as it is more CPU-intensive.
|
slow down the backup process as it is more CPU-intensive.
|
||||||
|
Currently it fails if the environment has suffered a page leak.
|
||||||
.TP
|
.TP
|
||||||
.BR \-n
|
.BR \-n
|
||||||
Open LDMB environment(s) which do not use subdirectories.
|
Open LDMB environment(s) which do not use subdirectories.
|
||||||
|
|||||||
2
external/db_drivers/liblmdb/mdb_copy.c
vendored
2
external/db_drivers/liblmdb/mdb_copy.c
vendored
@@ -1,6 +1,6 @@
|
|||||||
/* mdb_copy.c - memory-mapped database backup tool */
|
/* mdb_copy.c - memory-mapped database backup tool */
|
||||||
/*
|
/*
|
||||||
* Copyright 2012-2015 Howard Chu, Symas Corp.
|
* Copyright 2012-2018 Howard Chu, Symas Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|||||||
2
external/db_drivers/liblmdb/mdb_drop.1
vendored
2
external/db_drivers/liblmdb/mdb_drop.1
vendored
@@ -1,5 +1,5 @@
|
|||||||
.TH MDB_DROP 1 "2017/11/19" "LMDB 0.9.70"
|
.TH MDB_DROP 1 "2017/11/19" "LMDB 0.9.70"
|
||||||
.\" Copyright 2014-2017 Howard Chu, Symas Corp. All Rights Reserved.
|
.\" Copyright 2014-2018 Howard Chu, Symas Corp. All Rights Reserved.
|
||||||
.\" Copying restrictions apply. See COPYRIGHT/LICENSE.
|
.\" Copying restrictions apply. See COPYRIGHT/LICENSE.
|
||||||
.SH NAME
|
.SH NAME
|
||||||
mdb_drop \- LMDB database delete tool
|
mdb_drop \- LMDB database delete tool
|
||||||
|
|||||||
2
external/db_drivers/liblmdb/mdb_drop.c
vendored
2
external/db_drivers/liblmdb/mdb_drop.c
vendored
@@ -1,6 +1,6 @@
|
|||||||
/* mdb_drop.c - memory-mapped database delete tool */
|
/* mdb_drop.c - memory-mapped database delete tool */
|
||||||
/*
|
/*
|
||||||
* Copyright 2016-2017 Howard Chu, Symas Corp.
|
* Copyright 2016-2018 Howard Chu, Symas Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
|||||||
4
external/db_drivers/liblmdb/mdb_dump.1
vendored
4
external/db_drivers/liblmdb/mdb_dump.1
vendored
@@ -1,5 +1,5 @@
|
|||||||
.TH MDB_DUMP 1 "2014/06/20" "LMDB 0.9.14"
|
.TH MDB_DUMP 1 "2017/07/31" "LMDB 0.9.70"
|
||||||
.\" Copyright 2014-2015 Howard Chu, Symas Corp. All Rights Reserved.
|
.\" Copyright 2014-2017 Howard Chu, Symas Corp. All Rights Reserved.
|
||||||
.\" Copying restrictions apply. See COPYRIGHT/LICENSE.
|
.\" Copying restrictions apply. See COPYRIGHT/LICENSE.
|
||||||
.SH NAME
|
.SH NAME
|
||||||
mdb_dump \- LMDB environment export tool
|
mdb_dump \- LMDB environment export tool
|
||||||
|
|||||||
19
external/db_drivers/liblmdb/mdb_dump.c
vendored
19
external/db_drivers/liblmdb/mdb_dump.c
vendored
@@ -1,6 +1,6 @@
|
|||||||
/* mdb_dump.c - memory-mapped database dump tool */
|
/* mdb_dump.c - memory-mapped database dump tool */
|
||||||
/*
|
/*
|
||||||
* Copyright 2011-2015 Howard Chu, Symas Corp.
|
* Copyright 2011-2018 Howard Chu, Symas Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@@ -20,20 +20,7 @@
|
|||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
#include "lmdb.h"
|
#include "lmdb.h"
|
||||||
|
|
||||||
#ifdef _WIN32
|
#define Yu MDB_PRIy(u)
|
||||||
#define Z "I"
|
|
||||||
#else
|
|
||||||
#define Z "z"
|
|
||||||
#endif
|
|
||||||
#ifdef MDB_VL32
|
|
||||||
#ifdef _WIN32
|
|
||||||
#define Y "I64"
|
|
||||||
#else
|
|
||||||
#define Y "ll"
|
|
||||||
#endif
|
|
||||||
#else
|
|
||||||
#define Y Z
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define PRINT 1
|
#define PRINT 1
|
||||||
static int mode;
|
static int mode;
|
||||||
@@ -124,7 +111,7 @@ static int dumpit(MDB_txn *txn, MDB_dbi dbi, char *name)
|
|||||||
if (name)
|
if (name)
|
||||||
printf("database=%s\n", name);
|
printf("database=%s\n", name);
|
||||||
printf("type=btree\n");
|
printf("type=btree\n");
|
||||||
printf("mapsize=%" Y "u\n", info.me_mapsize);
|
printf("mapsize=%"Yu"\n", info.me_mapsize);
|
||||||
if (info.me_mapaddr)
|
if (info.me_mapaddr)
|
||||||
printf("mapaddr=%p\n", info.me_mapaddr);
|
printf("mapaddr=%p\n", info.me_mapaddr);
|
||||||
printf("maxreaders=%u\n", info.me_maxreaders);
|
printf("maxreaders=%u\n", info.me_maxreaders);
|
||||||
|
|||||||
4
external/db_drivers/liblmdb/mdb_load.1
vendored
4
external/db_drivers/liblmdb/mdb_load.1
vendored
@@ -1,5 +1,5 @@
|
|||||||
.TH MDB_LOAD 1 "2014/06/20" "LMDB 0.9.14"
|
.TH MDB_LOAD 1 "2015/09/30" "LMDB 0.9.17"
|
||||||
.\" Copyright 2014-2015 Howard Chu, Symas Corp. All Rights Reserved.
|
.\" Copyright 2014-2018 Howard Chu, Symas Corp. All Rights Reserved.
|
||||||
.\" Copying restrictions apply. See COPYRIGHT/LICENSE.
|
.\" Copying restrictions apply. See COPYRIGHT/LICENSE.
|
||||||
.SH NAME
|
.SH NAME
|
||||||
mdb_load \- LMDB environment import tool
|
mdb_load \- LMDB environment import tool
|
||||||
|
|||||||
51
external/db_drivers/liblmdb/mdb_load.c
vendored
51
external/db_drivers/liblmdb/mdb_load.c
vendored
@@ -1,6 +1,6 @@
|
|||||||
/* mdb_load.c - memory-mapped database load tool */
|
/* mdb_load.c - memory-mapped database load tool */
|
||||||
/*
|
/*
|
||||||
* Copyright 2011-2015 Howard Chu, Symas Corp.
|
* Copyright 2011-2018 Howard Chu, Symas Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@@ -25,7 +25,7 @@ static int mode;
|
|||||||
|
|
||||||
static char *subname = NULL;
|
static char *subname = NULL;
|
||||||
|
|
||||||
static size_t lineno;
|
static mdb_size_t lineno;
|
||||||
static int version;
|
static int version;
|
||||||
|
|
||||||
static int flags;
|
static int flags;
|
||||||
@@ -39,20 +39,7 @@ static MDB_envinfo info;
|
|||||||
static MDB_val kbuf, dbuf;
|
static MDB_val kbuf, dbuf;
|
||||||
static MDB_val k0buf;
|
static MDB_val k0buf;
|
||||||
|
|
||||||
#ifdef _WIN32
|
#define Yu MDB_PRIy(u)
|
||||||
#define Z "I"
|
|
||||||
#else
|
|
||||||
#define Z "z"
|
|
||||||
#endif
|
|
||||||
#ifdef MDB_VL32
|
|
||||||
#ifdef _WIN32
|
|
||||||
#define Y "I64"
|
|
||||||
#else
|
|
||||||
#define Y "ll"
|
|
||||||
#endif
|
|
||||||
#else
|
|
||||||
#define Y Z
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define STRLENOF(s) (sizeof(s)-1)
|
#define STRLENOF(s) (sizeof(s)-1)
|
||||||
|
|
||||||
@@ -84,7 +71,7 @@ static void readhdr(void)
|
|||||||
if (!strncmp(dbuf.mv_data, "VERSION=", STRLENOF("VERSION="))) {
|
if (!strncmp(dbuf.mv_data, "VERSION=", STRLENOF("VERSION="))) {
|
||||||
version=atoi((char *)dbuf.mv_data+STRLENOF("VERSION="));
|
version=atoi((char *)dbuf.mv_data+STRLENOF("VERSION="));
|
||||||
if (version > 3) {
|
if (version > 3) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: unsupported VERSION %d\n",
|
fprintf(stderr, "%s: line %"Yu": unsupported VERSION %d\n",
|
||||||
prog, lineno, version);
|
prog, lineno, version);
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
@@ -94,7 +81,7 @@ static void readhdr(void)
|
|||||||
if (!strncmp((char *)dbuf.mv_data+STRLENOF("FORMAT="), "print", STRLENOF("print")))
|
if (!strncmp((char *)dbuf.mv_data+STRLENOF("FORMAT="), "print", STRLENOF("print")))
|
||||||
mode |= PRINT;
|
mode |= PRINT;
|
||||||
else if (strncmp((char *)dbuf.mv_data+STRLENOF("FORMAT="), "bytevalue", STRLENOF("bytevalue"))) {
|
else if (strncmp((char *)dbuf.mv_data+STRLENOF("FORMAT="), "bytevalue", STRLENOF("bytevalue"))) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: unsupported FORMAT %s\n",
|
fprintf(stderr, "%s: line %"Yu": unsupported FORMAT %s\n",
|
||||||
prog, lineno, (char *)dbuf.mv_data+STRLENOF("FORMAT="));
|
prog, lineno, (char *)dbuf.mv_data+STRLENOF("FORMAT="));
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
@@ -105,7 +92,7 @@ static void readhdr(void)
|
|||||||
subname = strdup((char *)dbuf.mv_data+STRLENOF("database="));
|
subname = strdup((char *)dbuf.mv_data+STRLENOF("database="));
|
||||||
} else if (!strncmp(dbuf.mv_data, "type=", STRLENOF("type="))) {
|
} else if (!strncmp(dbuf.mv_data, "type=", STRLENOF("type="))) {
|
||||||
if (strncmp((char *)dbuf.mv_data+STRLENOF("type="), "btree", STRLENOF("btree"))) {
|
if (strncmp((char *)dbuf.mv_data+STRLENOF("type="), "btree", STRLENOF("btree"))) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: unsupported type %s\n",
|
fprintf(stderr, "%s: line %"Yu": unsupported type %s\n",
|
||||||
prog, lineno, (char *)dbuf.mv_data+STRLENOF("type="));
|
prog, lineno, (char *)dbuf.mv_data+STRLENOF("type="));
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
@@ -115,7 +102,7 @@ static void readhdr(void)
|
|||||||
if (ptr) *ptr = '\0';
|
if (ptr) *ptr = '\0';
|
||||||
i = sscanf((char *)dbuf.mv_data+STRLENOF("mapaddr="), "%p", &info.me_mapaddr);
|
i = sscanf((char *)dbuf.mv_data+STRLENOF("mapaddr="), "%p", &info.me_mapaddr);
|
||||||
if (i != 1) {
|
if (i != 1) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: invalid mapaddr %s\n",
|
fprintf(stderr, "%s: line %"Yu": invalid mapaddr %s\n",
|
||||||
prog, lineno, (char *)dbuf.mv_data+STRLENOF("mapaddr="));
|
prog, lineno, (char *)dbuf.mv_data+STRLENOF("mapaddr="));
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
@@ -123,9 +110,10 @@ static void readhdr(void)
|
|||||||
int i;
|
int i;
|
||||||
ptr = memchr(dbuf.mv_data, '\n', dbuf.mv_size);
|
ptr = memchr(dbuf.mv_data, '\n', dbuf.mv_size);
|
||||||
if (ptr) *ptr = '\0';
|
if (ptr) *ptr = '\0';
|
||||||
i = sscanf((char *)dbuf.mv_data+STRLENOF("mapsize="), "%" Y "u", &info.me_mapsize);
|
i = sscanf((char *)dbuf.mv_data+STRLENOF("mapsize="),
|
||||||
|
"%" MDB_SCNy(u), &info.me_mapsize);
|
||||||
if (i != 1) {
|
if (i != 1) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: invalid mapsize %s\n",
|
fprintf(stderr, "%s: line %"Yu": invalid mapsize %s\n",
|
||||||
prog, lineno, (char *)dbuf.mv_data+STRLENOF("mapsize="));
|
prog, lineno, (char *)dbuf.mv_data+STRLENOF("mapsize="));
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
@@ -135,7 +123,7 @@ static void readhdr(void)
|
|||||||
if (ptr) *ptr = '\0';
|
if (ptr) *ptr = '\0';
|
||||||
i = sscanf((char *)dbuf.mv_data+STRLENOF("maxreaders="), "%u", &info.me_maxreaders);
|
i = sscanf((char *)dbuf.mv_data+STRLENOF("maxreaders="), "%u", &info.me_maxreaders);
|
||||||
if (i != 1) {
|
if (i != 1) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: invalid maxreaders %s\n",
|
fprintf(stderr, "%s: line %"Yu": invalid maxreaders %s\n",
|
||||||
prog, lineno, (char *)dbuf.mv_data+STRLENOF("maxreaders="));
|
prog, lineno, (char *)dbuf.mv_data+STRLENOF("maxreaders="));
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
@@ -151,12 +139,12 @@ static void readhdr(void)
|
|||||||
if (!dbflags[i].bit) {
|
if (!dbflags[i].bit) {
|
||||||
ptr = memchr(dbuf.mv_data, '=', dbuf.mv_size);
|
ptr = memchr(dbuf.mv_data, '=', dbuf.mv_size);
|
||||||
if (!ptr) {
|
if (!ptr) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: unexpected format\n",
|
fprintf(stderr, "%s: line %"Yu": unexpected format\n",
|
||||||
prog, lineno);
|
prog, lineno);
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
} else {
|
} else {
|
||||||
*ptr = '\0';
|
*ptr = '\0';
|
||||||
fprintf(stderr, "%s: line %" Z "d: unrecognized keyword ignored: %s\n",
|
fprintf(stderr, "%s: line %"Yu": unrecognized keyword ignored: %s\n",
|
||||||
prog, lineno, (char *)dbuf.mv_data);
|
prog, lineno, (char *)dbuf.mv_data);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -166,7 +154,7 @@ static void readhdr(void)
|
|||||||
|
|
||||||
static void badend(void)
|
static void badend(void)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "%s: line %" Z "d: unexpected end of input\n",
|
fprintf(stderr, "%s: line %"Yu": unexpected end of input\n",
|
||||||
prog, lineno);
|
prog, lineno);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -224,7 +212,7 @@ badend:
|
|||||||
buf->mv_data = realloc(buf->mv_data, buf->mv_size*2);
|
buf->mv_data = realloc(buf->mv_data, buf->mv_size*2);
|
||||||
if (!buf->mv_data) {
|
if (!buf->mv_data) {
|
||||||
Eof = 1;
|
Eof = 1;
|
||||||
fprintf(stderr, "%s: line %" Z "d: out of memory, line too long\n",
|
fprintf(stderr, "%s: line %"Yu": out of memory, line too long\n",
|
||||||
prog, lineno);
|
prog, lineno);
|
||||||
return EOF;
|
return EOF;
|
||||||
}
|
}
|
||||||
@@ -259,7 +247,8 @@ badend:
|
|||||||
c2 += 2;
|
c2 += 2;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
c1++; c2++;
|
/* copies are redundant when no escapes were used */
|
||||||
|
*c1++ = *c2++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@@ -435,7 +424,7 @@ int main(int argc, char *argv[])
|
|||||||
|
|
||||||
rc = readline(&data, &dbuf);
|
rc = readline(&data, &dbuf);
|
||||||
if (rc) {
|
if (rc) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: failed to read key value\n", prog, lineno);
|
fprintf(stderr, "%s: line %"Yu": failed to read key value\n", prog, lineno);
|
||||||
goto txn_abort;
|
goto txn_abort;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -463,7 +452,7 @@ int main(int argc, char *argv[])
|
|||||||
if (batch == 100) {
|
if (batch == 100) {
|
||||||
rc = mdb_txn_commit(txn);
|
rc = mdb_txn_commit(txn);
|
||||||
if (rc) {
|
if (rc) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: txn_commit: %s\n",
|
fprintf(stderr, "%s: line %"Yu": txn_commit: %s\n",
|
||||||
prog, lineno, mdb_strerror(rc));
|
prog, lineno, mdb_strerror(rc));
|
||||||
goto env_close;
|
goto env_close;
|
||||||
}
|
}
|
||||||
@@ -487,7 +476,7 @@ int main(int argc, char *argv[])
|
|||||||
rc = mdb_txn_commit(txn);
|
rc = mdb_txn_commit(txn);
|
||||||
txn = NULL;
|
txn = NULL;
|
||||||
if (rc) {
|
if (rc) {
|
||||||
fprintf(stderr, "%s: line %" Z "d: txn_commit: %s\n",
|
fprintf(stderr, "%s: line %"Yu": txn_commit: %s\n",
|
||||||
prog, lineno, mdb_strerror(rc));
|
prog, lineno, mdb_strerror(rc));
|
||||||
goto env_close;
|
goto env_close;
|
||||||
}
|
}
|
||||||
|
|||||||
4
external/db_drivers/liblmdb/mdb_stat.1
vendored
4
external/db_drivers/liblmdb/mdb_stat.1
vendored
@@ -1,5 +1,5 @@
|
|||||||
.TH MDB_STAT 1 "2014/06/20" "LMDB 0.9.14"
|
.TH MDB_STAT 1 "2017/07/31" "LMDB 0.9.70"
|
||||||
.\" Copyright 2012-2015 Howard Chu, Symas Corp. All Rights Reserved.
|
.\" Copyright 2012-2019 Howard Chu, Symas Corp. All Rights Reserved.
|
||||||
.\" Copying restrictions apply. See COPYRIGHT/LICENSE.
|
.\" Copying restrictions apply. See COPYRIGHT/LICENSE.
|
||||||
.SH NAME
|
.SH NAME
|
||||||
mdb_stat \- LMDB environment status tool
|
mdb_stat \- LMDB environment status tool
|
||||||
|
|||||||
46
external/db_drivers/liblmdb/mdb_stat.c
vendored
46
external/db_drivers/liblmdb/mdb_stat.c
vendored
@@ -1,6 +1,6 @@
|
|||||||
/* mdb_stat.c - memory-mapped database status tool */
|
/* mdb_stat.c - memory-mapped database status tool */
|
||||||
/*
|
/*
|
||||||
* Copyright 2011-2015 Howard Chu, Symas Corp.
|
* Copyright 2011-2018 Howard Chu, Symas Corp.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@@ -17,20 +17,8 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include "lmdb.h"
|
#include "lmdb.h"
|
||||||
|
|
||||||
#ifdef _WIN32
|
#define Z MDB_FMT_Z
|
||||||
#define Z "I"
|
#define Yu MDB_PRIy(u)
|
||||||
#else
|
|
||||||
#define Z "z"
|
|
||||||
#endif
|
|
||||||
#ifdef MDB_VL32
|
|
||||||
#ifdef _WIN32
|
|
||||||
#define Y "I64"
|
|
||||||
#else
|
|
||||||
#define Y "ll"
|
|
||||||
#endif
|
|
||||||
#else
|
|
||||||
#define Y Z
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static void prstat(MDB_stat *ms)
|
static void prstat(MDB_stat *ms)
|
||||||
{
|
{
|
||||||
@@ -38,10 +26,10 @@ static void prstat(MDB_stat *ms)
|
|||||||
printf(" Page size: %u\n", ms->ms_psize);
|
printf(" Page size: %u\n", ms->ms_psize);
|
||||||
#endif
|
#endif
|
||||||
printf(" Tree depth: %u\n", ms->ms_depth);
|
printf(" Tree depth: %u\n", ms->ms_depth);
|
||||||
printf(" Branch pages: %"Y"u\n", ms->ms_branch_pages);
|
printf(" Branch pages: %"Yu"\n", ms->ms_branch_pages);
|
||||||
printf(" Leaf pages: %"Y"u\n", ms->ms_leaf_pages);
|
printf(" Leaf pages: %"Yu"\n", ms->ms_leaf_pages);
|
||||||
printf(" Overflow pages: %"Y"u\n", ms->ms_overflow_pages);
|
printf(" Overflow pages: %"Yu"\n", ms->ms_overflow_pages);
|
||||||
printf(" Entries: %"Y"u\n", ms->ms_entries);
|
printf(" Entries: %"Yu"\n", ms->ms_entries);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void usage(char *prog)
|
static void usage(char *prog)
|
||||||
@@ -138,11 +126,11 @@ int main(int argc, char *argv[])
|
|||||||
(void)mdb_env_info(env, &mei);
|
(void)mdb_env_info(env, &mei);
|
||||||
printf("Environment Info\n");
|
printf("Environment Info\n");
|
||||||
printf(" Map address: %p\n", mei.me_mapaddr);
|
printf(" Map address: %p\n", mei.me_mapaddr);
|
||||||
printf(" Map size: %"Y"u\n", mei.me_mapsize);
|
printf(" Map size: %"Yu"\n", mei.me_mapsize);
|
||||||
printf(" Page size: %u\n", mst.ms_psize);
|
printf(" Page size: %u\n", mst.ms_psize);
|
||||||
printf(" Max pages: %"Y"u\n", mei.me_mapsize / mst.ms_psize);
|
printf(" Max pages: %"Yu"\n", mei.me_mapsize / mst.ms_psize);
|
||||||
printf(" Number of pages used: %"Y"u\n", mei.me_last_pgno+1);
|
printf(" Number of pages used: %"Yu"\n", mei.me_last_pgno+1);
|
||||||
printf(" Last transaction ID: %"Y"u\n", mei.me_last_txnid);
|
printf(" Last transaction ID: %"Yu"\n", mei.me_last_txnid);
|
||||||
printf(" Max readers: %u\n", mei.me_maxreaders);
|
printf(" Max readers: %u\n", mei.me_maxreaders);
|
||||||
printf(" Number of readers used: %u\n", mei.me_numreaders);
|
printf(" Number of readers used: %u\n", mei.me_numreaders);
|
||||||
}
|
}
|
||||||
@@ -169,7 +157,7 @@ int main(int argc, char *argv[])
|
|||||||
if (freinfo) {
|
if (freinfo) {
|
||||||
MDB_cursor *cursor;
|
MDB_cursor *cursor;
|
||||||
MDB_val key, data;
|
MDB_val key, data;
|
||||||
size_t pages = 0, *iptr;
|
mdb_size_t pages = 0, *iptr;
|
||||||
|
|
||||||
printf("Freelist Status\n");
|
printf("Freelist Status\n");
|
||||||
dbi = 0;
|
dbi = 0;
|
||||||
@@ -189,7 +177,7 @@ int main(int argc, char *argv[])
|
|||||||
pages += *iptr;
|
pages += *iptr;
|
||||||
if (freinfo > 1) {
|
if (freinfo > 1) {
|
||||||
char *bad = "";
|
char *bad = "";
|
||||||
size_t pg, prev;
|
mdb_size_t pg, prev;
|
||||||
ssize_t i, j, span = 0;
|
ssize_t i, j, span = 0;
|
||||||
j = *iptr++;
|
j = *iptr++;
|
||||||
for (i = j, prev = 1; --i >= 0; ) {
|
for (i = j, prev = 1; --i >= 0; ) {
|
||||||
@@ -200,20 +188,20 @@ int main(int argc, char *argv[])
|
|||||||
pg += span;
|
pg += span;
|
||||||
for (; i >= span && iptr[i-span] == pg; span++, pg++) ;
|
for (; i >= span && iptr[i-span] == pg; span++, pg++) ;
|
||||||
}
|
}
|
||||||
printf(" Transaction %"Z"u, %"Z"d pages, maxspan %"Z"d%s\n",
|
printf(" Transaction %"Yu", %"Z"d pages, maxspan %"Z"d%s\n",
|
||||||
*(size_t *)key.mv_data, j, span, bad);
|
*(mdb_size_t *)key.mv_data, j, span, bad);
|
||||||
if (freinfo > 2) {
|
if (freinfo > 2) {
|
||||||
for (--j; j >= 0; ) {
|
for (--j; j >= 0; ) {
|
||||||
pg = iptr[j];
|
pg = iptr[j];
|
||||||
for (span=1; --j >= 0 && iptr[j] == pg+span; span++) ;
|
for (span=1; --j >= 0 && iptr[j] == pg+span; span++) ;
|
||||||
printf(span>1 ? " %9"Z"u[%"Z"d]\n" : " %9"Z"u\n",
|
printf(span>1 ? " %9"Yu"[%"Z"d]\n" : " %9"Yu"\n",
|
||||||
pg, span);
|
pg, span);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
mdb_cursor_close(cursor);
|
mdb_cursor_close(cursor);
|
||||||
printf(" Free pages: %"Z"u\n", pages);
|
printf(" Free pages: %"Yu"\n", pages);
|
||||||
}
|
}
|
||||||
|
|
||||||
rc = mdb_open(txn, subname, 0, &dbi);
|
rc = mdb_open(txn, subname, 0, &dbi);
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user