Merge pull request #78

5d498be removed extra line endings (Ilya Kitaev)
76c5c11 windows-build-x86: explained why stack is increased (Ilya Kitaev)
15bfc85 windows-build: increased stack for x86 build as libwallet allocates 2Mb of stack internally (Ilya Kitaev)
d7e03f9 build: fixed string comparsion (Ilya Kitaev)
d35a185 win-build: deploy different dlls for different platforms (Ilya Kitaev)
653e5f1 doc: fixed formatting issues (Ilya Kitaev)
7827417 doc: note regarding 3D acceleration in virtual machine (Ilya Kitaev)
4844bd3 build: added "debug" build option (Ilya Kitaev)
39d74f1 windows-build: added missed runtime dlls to x86 config (Ilya Kitaev)
2d0a4ca documentation: updated build steps (Ilya Kitaev)
82a6aff fix: missed dependency for x86 target (Ilya Kitaev)
35a677c Windows build documentation in progress (Ilya Kitaev)
This commit is contained in:
Riccardo Spagni 2016-10-24 10:37:18 +02:00
commit 63f24ff410
No known key found for this signature in database
GPG Key ID: 55432DF31CCD4FCD
5 changed files with 103 additions and 40 deletions

View File

@ -1,5 +1,3 @@
# Monero Core
Copyright (c) 2014-2016, The Monero Project Copyright (c) 2014-2016, The Monero Project
## Development Resources ## Development Resources
@ -144,4 +142,46 @@ TODO
### On Windows: ### On Windows:
TODO 1. Install [msys2](http://msys2.github.io/), follow the instructions on that page on how to update packages to the latest versions
2. Install monero dependencies as described in [monero documentation](https://github.com/monero-project/monero)
3. Install git:
```
pacman -S git
```
4. Install Qt5:
- if you need to build x86 application, install:
```
pacman -S mingw-w64-i686-qt5
```
- if you need to build x64 application, install:
```
pacman -S mingw-w64-x86_64-qt5
```
5. Open ```mingw``` shell. MSYS2 will install start menu items for both mingw32 and mingw64 environments, so
you need to open appropriate one:
```%MSYS_ROOT%\msys2_shell.cmd -mingw32``` for x86 targed
or
```%MSYS_ROOT%\msys2_shell.cmd -mingw64``` for x64 targed
Where ```%MSYS_ROOT%``` will be ```c:\msys32``` if your host OS is x86-based or ```c:\msys64``` if your host OS
is x64-based
6. Clone git repository:
```
git clone https://github.com/monero-project/monero-core.git
```
7. Build the project:
```
cd monero-core
./build.sh
```
8. Take result binary and dependencies in ```./build/release/bin```
**important: if you testing application within VirtualBox virtual machine, make sure 3D acceleration is enabled
in machine's settings:
Machine > Settings > Display > [v] Enable 3D Acceleration**

View File

@ -1,17 +1,28 @@
#!/bin/bash #!/bin/bash
BUILD_TYPE=$1
if [ -z $BUILD_TYPE ]; then
BUILD_TYPE=Release
fi
source ./utils.sh source ./utils.sh
pushd $(pwd) pushd $(pwd)
ROOT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" ROOT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
MONERO_DIR=monero MONERO_DIR=monero
if [ ! -d $MONERO_DIR ]; then if [ ! -d $MONERO_DIR ]; then
$SHELL get_libwallet_api.sh $SHELL get_libwallet_api.sh $BUILD_TYPE
fi fi
if [ ! -d build ]; then mkdir build; fi if [ ! -d build ]; then mkdir build; fi
CONFIG="CONFIG+=release" if [ "$BUILD_TYPE" == "Release" ]; then
CONFIG="CONFIG+=release";
else
CONFIG="CONFIG+=debug"
fi
platform=$(get_platform) platform=$(get_platform)
if [ "$platform" == "linux" ]; then if [ "$platform" == "linux" ]; then
@ -24,19 +35,6 @@ fi
cd build cd build
qmake ../monero-core.pro "$CONFIG" qmake ../monero-core.pro "$CONFIG"
make make
make deploy # make deploy
popd popd

View File

@ -84,13 +84,3 @@ fi
popd popd

View File

@ -73,6 +73,19 @@ win32 {
-lwsock32 \ -lwsock32 \
-lIphlpapi \ -lIphlpapi \
-lgdi32 -lgdi32
!contains(QMAKE_TARGET.arch, x86_64) {
message("x86 build")
## Windows x86 (32bit) specific build here
## there's 2Mb stack in libwallet allocated internally
## this fixes app crash for x86 Windows build
QMAKE_LFLAGS += -Wl,--stack,4194304
} else {
message("x64 build")
}
} }
linux { linux {

View File

@ -1,20 +1,42 @@
#!/bin/bash #!/bin/bash
ROOT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
source $ROOT_DIR/utils.sh
TARGET=$1 TARGET=$1
FILES="zlib1.dll libwinpthread-1.dll libtiff-5.dll libstdc++-6.dll libpng16-16.dll libpcre16-0.dll libpcre-1.dll libmng-2.dll liblzma-5.dll liblcms2-2.dll libjpeg-8.dll libjasper-1.dll libintl-8.dll libicuuc57.dll libicuin57.dll libicudt57.dll libiconv-2.dll libharfbuzz-0.dll libgraphite2.dll libglib-2.0-0.dll libgcc_s_seh-1.dll libfreetype-6.dll libbz2-1.dll" BUILD_TYPE=$2
if [[ -z $BUILD_TYPE ]]; then
BUILD_TYPE=Release
fi
if [[ "$BUILD_TYPE" == "Release" ]]; then
echo "Release build"
ICU_FILES="libicuuc57.dll libicuin57.dll libicudt57.dll"
else
echo "Debug build"
ICU_FILES="libicuucd57.dll libicuind57.dll libicudtd57.dll"
fi
FILES="zlib1.dll libwinpthread-1.dll libtiff-5.dll libstdc++-6.dll libpng16-16.dll libpcre16-0.dll libpcre-1.dll libmng-2.dll liblzma-5.dll liblcms2-2.dll libjpeg-8.dll libjasper-1.dll libintl-8.dll libiconv-2.dll libharfbuzz-0.dll libgraphite2.dll libglib-2.0-0.dll libfreetype-6.dll libbz2-1.dll"
platform=$(get_platform)
if [[ "$platform" == "mingw64" ]]; then
PLATFORM_FILES="libgcc_s_seh-1.dll"
elif [[ "$platform" == "mingw32" ]]; then
PLATFORM_FILES="libgcc_s_dw2-1.dll"
fi
for f in $FILES; do cp $MSYSTEM_PREFIX/bin/$f $TARGET; done for f in $FILES; do cp $MSYSTEM_PREFIX/bin/$f $TARGET; done
for f in $ICU_FILES; do cp $MSYSTEM_PREFIX/bin/$f $TARGET; done
for f in $PLATFORM_FILES; do cp $MSYSTEM_PREFIX/bin/$f $TARGET; done