Skip to content

Commit

Permalink
split wallet and wallet_api
Browse files Browse the repository at this point in the history
This speeds up building a lot when wallet2.h (or something it
includes) changes, since all the API includes wallet2.h
  • Loading branch information
moneromooo-monero committed Nov 16, 2017
1 parent dc6a801 commit 51895fd
Show file tree
Hide file tree
Showing 15 changed files with 104 additions and 40 deletions.
33 changes: 4 additions & 29 deletions src/wallet/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -33,21 +33,7 @@ set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib)
set(wallet_sources
wallet2.cpp
wallet_args.cpp
node_rpc_proxy.cpp
api/wallet.cpp
api/wallet_manager.cpp
api/transaction_info.cpp
api/transaction_history.cpp
api/pending_transaction.cpp
api/utils.cpp
api/address_book.cpp
api/subaddress.cpp
api/subaddress_account.cpp
api/unsigned_transaction.cpp)

set(wallet_api_headers
wallet2_api.h)

node_rpc_proxy.cpp)

set(wallet_private_headers
wallet2.h
Expand All @@ -56,23 +42,12 @@ set(wallet_private_headers
wallet_rpc_server.h
wallet_rpc_server_commands_defs.h
wallet_rpc_server_error_codes.h
node_rpc_proxy.h
api/wallet.h
api/wallet_manager.h
api/transaction_info.h
api/transaction_history.h
api/pending_transaction.h
api/common_defines.h
api/address_book.h
api/subaddress.h
api/subaddress_account.h
api/unsigned_transaction.h)
node_rpc_proxy.h)

monero_private_headers(wallet
${wallet_private_headers})
monero_add_library(wallet
${wallet_sources}
${wallet_api_headers}
${wallet_private_headers})
target_link_libraries(wallet
PUBLIC
Expand Down Expand Up @@ -127,6 +102,7 @@ install(TARGETS wallet_rpc_server DESTINATION bin)
# build and install libwallet_merged only if we building for GUI
if (BUILD_GUI_DEPS)
set(libs_to_merge
wallet_api
wallet
cryptonote_core
cryptonote_basic
Expand All @@ -149,6 +125,5 @@ if (BUILD_GUI_DEPS)
install(TARGETS wallet_merged
ARCHIVE DESTINATION ${lib_folder})

install(FILES ${wallet_api_headers}
DESTINATION include/wallet)
add_subdirectory(api)
endif()
89 changes: 89 additions & 0 deletions src/wallet/api/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
# Copyright (c) 2014-2017, 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 (${PROJECT_SOURCE_DIR}/cmake/libutils.cmake)

set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib)

set(wallet_api_sources
wallet.cpp
wallet_manager.cpp
transaction_info.cpp
transaction_history.cpp
pending_transaction.cpp
utils.cpp
address_book.cpp
subaddress.cpp
subaddress_account.cpp
unsigned_transaction.cpp)

set(wallet_api_headers
wallet2_api.h)

set(wallet_api_private_headers
wallet.h
wallet_manager.h
transaction_info.h
transaction_history.h
pending_transaction.h
common_defines.h
address_book.h
subaddress.h
subaddress_account.h
unsigned_transaction.h)

monero_private_headers(wallet_api
${wallet_api_private_headers})
monero_add_library(wallet_api
${wallet_api_sources}
${wallet_api_headers}
${wallet_api_private_headers})
target_link_libraries(wallet_api
PUBLIC
wallet
common
cryptonote_core
mnemonics
${Boost_CHRONO_LIBRARY}
${Boost_SERIALIZATION_LIBRARY}
${Boost_FILESYSTEM_LIBRARY}
${Boost_SYSTEM_LIBRARY}
${Boost_THREAD_LIBRARY}
${Boost_REGEX_LIBRARY}
PRIVATE
${EXTRA_LIBRARIES})


if(IOS)
set(lib_folder lib-${ARCH})
else()
set(lib_folder lib)
endif()

install(FILES ${wallet_api_headers}
DESTINATION include/wallet)
2 changes: 1 addition & 1 deletion src/wallet/api/address_book.h
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@
//
// Parts of this file are originally copyright (c) 2012-2013 The Cryptonote developers

#include "wallet/wallet2_api.h"
#include "wallet/api/wallet2_api.h"
#include "wallet/wallet2.h"

namespace Monero {
Expand Down
2 changes: 1 addition & 1 deletion src/wallet/api/pending_transaction.h
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@
//
// Parts of this file are originally copyright (c) 2012-2013 The Cryptonote developers

#include "wallet/wallet2_api.h"
#include "wallet/api/wallet2_api.h"
#include "wallet/wallet2.h"

#include <string>
Expand Down
2 changes: 1 addition & 1 deletion src/wallet/api/subaddress.h
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@
// 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 "wallet/wallet2_api.h"
#include "wallet/api/wallet2_api.h"
#include "wallet/wallet2.h"

namespace Monero {
Expand Down
2 changes: 1 addition & 1 deletion src/wallet/api/subaddress_account.h
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@
// 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 "wallet/wallet2_api.h"
#include "wallet/api/wallet2_api.h"
#include "wallet/wallet2.h"

namespace Monero {
Expand Down
2 changes: 1 addition & 1 deletion src/wallet/api/transaction_history.h
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@
//
// Parts of this file are originally copyright (c) 2012-2013 The Cryptonote developers

#include "wallet/wallet2_api.h"
#include "wallet/api/wallet2_api.h"
#include <boost/thread/shared_mutex.hpp>

namespace Monero {
Expand Down
2 changes: 1 addition & 1 deletion src/wallet/api/transaction_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@
//
// Parts of this file are originally copyright (c) 2012-2013 The Cryptonote developers

#include "wallet/wallet2_api.h"
#include "wallet/api/wallet2_api.h"
#include <string>
#include <ctime>

Expand Down
2 changes: 1 addition & 1 deletion src/wallet/api/unsigned_transaction.h
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@
//
// Parts of this file are originally copyright (c) 2012-2013 The Cryptonote developers

#include "wallet/wallet2_api.h"
#include "wallet/api/wallet2_api.h"
#include "wallet/wallet2.h"

#include <string>
Expand Down
2 changes: 1 addition & 1 deletion src/wallet/api/wallet.h
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@
#ifndef WALLET_IMPL_H
#define WALLET_IMPL_H

#include "wallet/wallet2_api.h"
#include "wallet/api/wallet2_api.h"
#include "wallet/wallet2.h"

#include <string>
Expand Down
File renamed without changes.
2 changes: 1 addition & 1 deletion src/wallet/api/wallet_manager.h
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@
// Parts of this file are originally copyright (c) 2012-2013 The Cryptonote developers


#include "wallet/wallet2_api.h"
#include "wallet/api/wallet2_api.h"
#include <string>

namespace Monero {
Expand Down
1 change: 0 additions & 1 deletion src/wallet/wallet2.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,6 @@ using namespace epee;

#include "cryptonote_config.h"
#include "wallet2.h"
#include "wallet2_api.h"
#include "cryptonote_basic/cryptonote_format_utils.h"
#include "rpc/core_rpc_server_commands_defs.h"
#include "misc_language.h"
Expand Down
1 change: 1 addition & 0 deletions tests/libwallet_api_tests/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,7 @@ add_executable(libwallet_api_tests

target_link_libraries(libwallet_api_tests
PRIVATE
wallet_api
wallet
version
epee
Expand Down
2 changes: 1 addition & 1 deletion tests/libwallet_api_tests/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@

#include "gtest/gtest.h"

#include "wallet/wallet2_api.h"
#include "wallet/api/wallet2_api.h"
#include "wallet/wallet2.h"
#include "include_base_utils.h"
#include "common/util.h"
Expand Down

0 comments on commit 51895fd

Please sign in to comment.