Skip to content

Commit

Permalink
Merge pull request #13 from moneromooo-monero/blockchain
Browse files Browse the repository at this point in the history
Add lmdb to the cmake gunk, and use actual user directory for the blockchain location
  • Loading branch information
tewinget authored and warptangent committed Jan 5, 2015
2 parents 215e63b + 11129b9 commit e285ee5
Show file tree
Hide file tree
Showing 4 changed files with 69 additions and 6 deletions.
4 changes: 2 additions & 2 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -138,8 +138,8 @@ link_directories(${UNBOUND_LIBRARY_DIRS})
# Final setup for rapidjson
include_directories(external/rapidjson)

# TODO: make this find lmdb similarly to how unbound and boost are handled
set(LMDB_LIBRARIES "-llmdb")
find_package(LMDB REQUIRED)
include_directories(${LMDB_INCLUDE})

if(MSVC)
add_definitions("/bigobj /MP /W3 /GS- /D_CRT_SECURE_NO_WARNINGS /wd4996 /wd4345 /D_WIN32_WINNT=0x0600 /DWIN32_LEAN_AND_MEAN /DGTEST_HAS_TR1_TUPLE=0 /FIinline_c.h /D__SSE4_1__")
Expand Down
61 changes: 61 additions & 0 deletions cmake/FindLMDB.cmake
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
# Copyright (c) 2014, 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.

MESSAGE(STATUS "Looking for liblmdb")

FIND_PATH(LMDB_INCLUDE_DIR
NAMES lmdb.h
PATH_SUFFIXES include/ include/lmdb/
PATHS "${PROJECT_SOURCE_DIR}"
${LMDB_ROOT}
$ENV{LMDB_ROOT}
/usr/local/
/usr/
)

if(STATIC)
if(MINGW)
find_library(LMDB_LIBRARIES liblmdb.dll.a)
else()
find_library(LMDB_LIBRARIES liblmdb.a)
endif()
else()
find_library(LMDB_LIBRARIES lmdb)
endif()

IF(LMDB_INCLUDE_DIR)
MESSAGE(STATUS "Found liblmdb include (lmdb.h) in ${LMDB_INCLUDE_DIR}")
IF(LMDB_LIBRARIES)
MESSAGE(STATUS "Found liblmdb library")
set(LMDB_INCLUDE ${LMDB_INCLUDE_DIR})
set(LMDB_LIBRARY ${LMDB_LIBRARIES})
ELSE()
MESSAGE(FATAL_ERROR "${BoldRed}Could not find liblmdb library, please make sure you have installed liblmdb or liblmdb-dev or the equivalent${ColourReset}")
ENDIF()
ELSE()
MESSAGE(FATAL_ERROR "${BoldRed}Could not find liblmdb library, please make sure you have installed liblmdb or liblmdb-dev or the equivalent${ColourReset}")
ENDIF()
8 changes: 5 additions & 3 deletions src/blockchain_converter/blockchain_converter.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -52,20 +52,22 @@ struct fake_core

fake_core() : m_pool(dummy), dummy(m_pool), m_storage(&m_pool)
{
m_pool.init("/home/user/.bitmonero");
m_storage.init("/home/user/.bitmonero", false);
boost::filesystem::path default_data_path {tools::get_default_data_dir()};
m_pool.init(default_data_path.string());
m_storage.init(default_data_path.string(), false);
}
};

int main(int argc, char* argv[])
{
fake_core c;
boost::filesystem::path default_data_path {tools::get_default_data_dir()};

BlockchainDB *blockchain;

blockchain = new BlockchainLMDB();

blockchain->open("/home/user/.bitmonero");
blockchain->open(default_data_path.string());

for (uint64_t i = 0; i < c.m_storage.get_current_blockchain_height(); ++i)
{
Expand Down
2 changes: 1 addition & 1 deletion src/cryptonote_core/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -83,5 +83,5 @@ target_link_libraries(cryptonote_core
${Boost_FILESYSTEM_LIBRARY}
${Boost_SYSTEM_LIBRARY}
${Boost_THREAD_LIBRARY}
${LMDB_LIBRARIES}
${LMDB_LIBRARY}
${EXTRA_LIBRARIES})

0 comments on commit e285ee5

Please sign in to comment.