-
Microsoft Visual Studio 2017 or Visual Studio Community 2017 Choose ... also install Windows SDK Version 8.1
or
- Cppcheck a static code analysis tool for the C and C++.
If using Visual Studio, also download Visual Studio integration add-in for Cppcheck
- mpg123
- OpenAL-Soft
- wxWidgets 3.1.2 or higher
- FreeType Included
- gw2dattools Included
- gw2formats Included
- libogg Included
- libvorbis Included
- libwebp Included
- OpenGL Mathematics Included
- The OpenGL Extension Wrangler Library Included
- TinyXML2 Included
- Visual Leak Detector (for use with Visual Studio only)
If you want to use Visual Leak Detector, remove the comment for #include <vld.h>
in Gw2Browser.cpp
.
-
Crate a directory for source code some where, for example,
C:\DEV
. -
Open Git Bash window and change directory to the one you create above.
-
Use this command to download the source code.
git clone --recursive https://github.com/kytulendu/Gw2Browser.git
This will download Gw2Browser and all included library source code.
-
Download mpg123 binaries from here, choose the lastest Win32 or Win64 file and extract it to the same directory that Gw2Browser directory is in. Or download the source code and build it your self.
-
Download OpenAL-Soft binaries from here, extract it to the same directory that Gw2Browser directory is in. Or download the source code and build it your self.
-
Download wxWidgets source code from here, choose
wxWidgets-3.1.2.zip
orwxWidgets-3.1.2.7z
and extract it to the same directory that Gw2Browser directory is in. Or download and use the binaries.
Note: The library and source code directory must be in directory like this. The ROOT is the directory you created in Getting the source code.
[ROOT]
|
+--Gw2Browser
| |
| +--src
| +--...
|
+--mpg123
|
+--openal-soft
| |
| +--bin
| +--include
| +--lib
| +--...
|
+--wxWidgets-3.1.2
+--include
+--src
+--...
- Use solution file corresponding with your VS version in directory
wxWidgets-3.1.2/build/msw
. For example, VS2017 iswx_vc15.sln
, if there is no corresponding solution file for your newer VS, just open the higest version of solution file available.
-
Open a
x64 Native Tools Command Prompt for VS 2017
orx86 Native Tools Command Prompt for VS 2017
and change it's directory to mpg123's directory. -
Rename export definition file by using this command.
ren libmpg123-0.dll.def libmpg123-0.def
-
Build the library.
for 64 bit binary, use this command.
lib /MACHINE:X64 /DEF:libmpg123-0.def /OUT:libmpg123-0.lib
for 32 bit binary, use this command.
lib /DEF:libmpg123-0.def /OUT:libmpg123-0.lib
-
Open
x64 Native Tools Command Prompt for VS 2017
If you want to compile 32 bit library, usex86 Native Tools Command Prompt for VS 2017
instread. -
Change directory to
Gw2Browser/extern/libweb
-
Use this command to compile libwebp
nmake /f Makefile.vc CFG=debug-static RTLIBCFG=dynamic OBJDIR=obj nmake /f Makefile.vc CFG=release-static RTLIBCFG=dynamic OBJDIR=obj
-
Create vc2017 directory in
Gw2Browser/extern/freetype/builds/windows
-
Copy all content from vc2010 directory to vc2017 directory
-
Open
freetype.sln
solution file inGw2Browser/extern/freetype/builds/windows/vc2017
If it ask for upgrade project file, choose Windows SDK Version to8.1
, then click "Ok" to upgrade it. -
Choose
Debug Static
orRelease Static
configuration and choose to Win32 for 32 bit build or x64 for 64 bit build from two dropdown box in Visual Studio toolbar. -
Press F7 or in MenuBar -> Build -> Build Solution to compile freetype.
-
Create vc14 directory in
Gw2Browser/extern/glew/build
-
Copy all content from vc12 directory to vc15 directory
-
Open
glew.sln
solution file inGw2Browser/extern/glew/build/vc15
If it ask for upgrade project file, choose Windows SDK Version to8.1
, then click "Ok" to upgrade it. -
Right click "glew_static" project in "Solution Explorer" at the left and choose "Properties".
-
In "Configuration:" dropdown box, choose "Debug" and in "Platform:" dropdown box, choose "All Platforms"
-
In "Configuration Properties" -> "C/C++" -> "Code Generation" In "Runtime Library" box, Choose "Multi-threaded Debug DLL (/MDd)"
-
Click "Apply" button.
-
In "Configuration:" dropdown box, choose "Release" and in "Platform:" dropdown box, choose "All Platforms"
-
In "Configuration Properties" -> "C/C++" -> "Code Generation" In "Runtime Library" box, Choose "Multi-threaded DLL (/MD)"
-
Click "Apply" button then click "OK".
-
Choose Debug or Release configuration and choose to Win32 for 32 bit build or x64 for 64 bit build from two dropdown box in Visual Studio toolbar.
-
Press F7 or in MenuBar -> Build -> Build Solution to compile libogg.
-
Create VS2017 directory in
Gw2Browser/extern/libogg/win32
-
Copy all content from VS2015 directory to VS2017 directory
-
Open
libogg_static.sln
solution file inGw2Browser/extern/libogg/win32/VS2017
If it ask for upgrade project file, choose Windows SDK Version to8.1
, then click "Ok" to upgrade it. -
Right click "libogg_static" project in "Solution Explorer" at the left and choose "Properties".
-
In "Configuration:" dropdown box, choose "Debug" and in "Platform:" dropdown box, choose "All Platforms"
-
In "Configuration Properties" -> "C/C++" -> "Code Generation" In "Runtime Library" box, Choose "Multi-threaded Debug DLL (/MDd)"
-
Click "Apply" button.
-
In "Configuration:" dropdown box, choose "Release" and in "Platform:" dropdown box, choose "All Platforms"
-
In "Configuration Properties" -> "C/C++" -> "Code Generation" In "Runtime Library" box, Choose "Multi-threaded DLL (/MD)"
-
Click "Apply" button then click "OK".
-
Choose Debug or Release configuration and choose to Win32 for 32 bit build or x64 for 64 bit build from two dropdown box in Visual Studio toolbar.
-
Press F7 or in MenuBar -> Build -> Build Solution to compile libogg.
-
Create VS2017 directory in
Gw2Browser/extern/libvorbis/win32
-
Copy all content from VS2010 directory to VS2017 directory
-
Open
vorbis_static.sln
solution file inGw2Browser/extern/libvorbis/win32/VS2015
If it ask for upgrade project file, choose Windows SDK Version to8.1
, then click "Ok" to upgrade it. -
Choose Debug or Release configuration and choose to Win32 for 32 bit build or x64 for 64 bit build from two dropdown box in Visual Studio toolbar.
-
Press F7 or in MenuBar -> Build -> Build Solution to compile libogg.
-
Open
Gw2Browser.sln
solution file inGw2Browser/prj
. -
Choose Debug or Release configuration and choose to Win32 for 32 bit build or x64 for 64 bit build from two dropdown box in Visual Studio toolbar.
-
Press F7 or in MenuBar -> Build -> Build Solution to compile Gw2Browser.
-
Copy
soft_oal.dll
fromopenal-soft/bin/Win32
oropenal-soft/bin/Win64
directory toGw2Browser/bin
and rename it toOpenAL32.dll
-
Copy
libmpg123-0.dll
from mpg123 directory toGw2Browser/bin
Download MinGW-w64 and install it to any location, for example C:\mingw-64
,
choose Version to 8.1.0 rev 0
, choose Architecture to x86_64 or i686
, choose Threads to POSIX
(important).
You must also add MinGW-w64 to your path.
for example set your path to %path%;C:\mingw-w64\x86_64-8.1.0-posix-seh-rt_v6-rev0\mingw64\bin
-
Open
libmpg123-0.dll.def
with any text editor, like Notepad++ and insert this to the first line.LIBRARY libmpg123-0.dll
It will look some thing like this.
LIBRARY libmpg123-0.dll EXPORTS mpg123_add_string ...
-
Open Git Bash command line window and change directory to mpg123 directory and use these command.
dlltool -d libmpg123-0.dll.def -l libmpg123-0.a
-
Open Git Bash command line window and change directory to
wxWidgets-3.1.2/build/msw
and use these command.mingw32-make -j 4 -f makefile.gcc BUILD=debug SHARED=1
If it give error, re-type it again. Wait for it to finish, then use these command.
mingw32-make -j 4 -f makefile.gcc BUILD=release SHARED=1
This will build wxWidgets in debug and release configuration as a dynamiclink library. If you want static library, remove
SHARED=1
from the commandline. But you have to change library search path in CodeBlocks project file fromgcc_dll
togcc_lib
.mingw32-make -j 4 -f makefile.gcc BUILD=debug mingw32-make -j 4 -f makefile.gcc BUILD=release
-
If you need to rebuild, use "clean" target first.
mingw32-make -j 4 -f makefile.gcc BUILD=debug SHARED=1 clean mingw32-make -j 4 -f makefile.gcc BUILD=release SHARED=1 clean mingw32-make -j 4 -f makefile.gcc BUILD=debug clean mingw32-make -j 4 -f makefile.gcc BUILD=release clean
-
Open Command Prompt and change directory to
Gw2Browser/extern/glew
and use these commandcmake -G "MinGW Makefiles" ./build/cmake mingw32-make
-
Open Command Prompt and change directory to
Gw2Browser/extern/libogg
and use these commandmkdir build cd build cmake -G "MinGW Makefiles" .. -DBUILD_SHARED_LIBS=ON mingw32-make
-
Open Command Prompt and change directory to
Gw2Browser/extern/libvorbis
and use these commandmkdir build cd build cmake -G "MinGW Makefiles" .. -DBUILD_SHARED_LIBS=ON -DOGG_INCLUDE_DIRS="E:/DEV/Gw2Browser/extern/libogg/include" -DOGG_LIBRARIES="E:/DEV/Gw2Browser/extern/libogg/build/libogg.dll.a" mingw32-make
-
Open Command Prompt and change directory to
Gw2Browser/extern/libwebp
and use these commandmkdir build cd build cmake -G "MinGW Makefiles" .. -DBUILD_SHARED_LIBS=ON mingw32-make
-
Open Command Prompt and change directory to
Gw2Browser/extern/freetype
and use these commandmkdir build cd build cmake -G "MinGW Makefiles" .. mingw32-make
-
Open Command Prompt and change directory to
Gw2Browser/extern/tinyxml2
and use these commandmkdir build cd build cmake -G "MinGW Makefiles" .. mingw32-make
-
Open workspace file
Gw2Browser.workspace
inGw2Browser/prj
with CodeBlocks. -
Compile Gw2Browser by right click and select Gw2Browser as active project, choose debug or release build, then click the gear button in toolbar or press CTRL+F9 key or in MenuBar -> Build -> Build.
-
Copy these dll files from MinGW-w64 install directory to
Gw2Browser/bin
libgcc_s_seh-1.dll libgomp-1.dll libstdc++-6.dll libwinpthread-1.dll
-
Copy
soft_oal.dll
fromopenal-soft/bin/Win32
oropenal-soft/bin/Win64
directory toGw2Browser/bin
and rename it toOpenAL32.dll
-
Copy
libmpg123-0.dll
from mpg123 directory toGw2Browser/bin
-
Copy
glew32.dll1 from
Gw2Browser/extern/glew/bindirectory to
Gw2Browser/bin` -
Copy
libtinyxml2.dll
fromGw2Browser/extern/tinyxml2/build
directory toGw2Browser/bin
-
Copy
libogg.dll
fromGw2Browser/extern/libogg/build
directory toGw2Browser/bin
-
Copy
libvorbis.dll
andlibvorbisfile.dll
fromGw2Browser/extern/libvorbis/build/lib
directory toGw2Browser/bin
-
Copy
libwebpdecoder.dll
fromGw2Browser/extern/libwebp/build
directory toGw2Browser/bin
-
Copy following dll files from
wxWidgets/lib/gcc_dll
directory toGw2Browser/bin
wxbase312u_gcc_custom.dll wxmsw312u_adv_gcc_custom.dll wxmsw312u_aui_gcc_custom.dll wxmsw312u_core_gcc_custom.dll wxmsw312u_gl_gcc_custom.dll
If debug build, also copy these dll files.
wxbase312ud_gcc_custom.dll wxmsw312ud_adv_gcc_custom.dll wxmsw312ud_aui_gcc_custom.dll wxmsw312ud_core_gcc_custom.dll wxmsw312ud_gl_gcc_custom.dll
For this guide, I was using Kubuntu 18.04, but this guide also work with any Linux distribution that was Debian based.
-
Download wxWidgets 3.1 source code from here, choose wxWidgets-3.1.2.tar.bz2 and extract it to somewhere, for example, your home directory. If your Linux distribution have wxWidgets 3.1 package, you can skip this and use a command like below command to install wxWidgets 3.1.
sudo apt install libwxbase3.1-dev libwxgtk3.1-dev
Or download wxWidgets's repository using this command.
git clone https://github.com/wxWidgets/wxWidgets.git
-
Open a terminal window, the directory would be in your home directory.
-
Install git by using this command. You can skip this step if you have already install git.
sudo apt install git git-gui
-
Use this command to install required library and tools.
sudo apt install build-essential codeblocks cmake cmake-gui libwebp-dev libglew-dev libopenal-dev libmpg123-dev libvorbis-dev libogg-dev libfreetype6 libfreetype6-dev libtinyxml2-dev
-
Use this command to download the source code.
git clone --recursive https://github.com/kytulendu/Gw2Browser.git
This will download Gw2Browser and all included library source code, although we won't use most of the library that was included in the repo.
-
If your system have wxWidgets 3.1 package, you can skip this step.
-
Open a terminal window and change directory to wxWidgets source code directory you have extracted.
-
Make a directory using this command
mkdir gtk-build
-
Change directory to the directory you make previously, in this case, gtk-build directory.
cd gtk-build
-
Use this command to config the build script and wait for it to finish.
../configure --enable-unicode --enable-debug --with-opengl
-
Use this command to compile wxWidgets source code.
make
or
make -j 4
-
When finished, use this command to install wxWidgets
sudo make install
-
After that use this command
sudo ldconfig
-
Open a terminal window and change directory to extern/gw2dattools source code directory you have extracted.
-
Make a directory using this command
mkdir build
-
Change directory to the directory you make previously, in this case, build directory.
cd build
-
Use this command to and wait for it to finish.
cmake ..
-
Use this command to compile gw2dattools source code.
make
or
make -j 4
-
When finished, use this command to install gw2dattools
sudo make install
-
Open a terminal window and change directory to extern/gw2formats source code directory you have extracted.
-
Make a directory using this command
mkdir build
-
Change directory to the directory you make previously, in this case, build directory.
cd build
-
Use this command to and wait for it to finish.
cmake ..
-
Use this command to compile gw2formats source code.
make
or
make -j 4
-
When finished, use this command to install gw2formats
sudo make install
-
Open workspace file Gw2Browser-linux.workspace in Gw2Browser/prj/ with CodeBlocks.
-
Compile Gw2Browser by right click and select Gw2Browser as active project, choose debug or release build, then click the gear button in toolbar or press CTRL+F9 key or in MenuBar -> Build -> Build.
Todo