| 
									
										
										
										
											2013-12-12 17:10:49 +01:00
										 |  |  | Building Subsurface from Source | 
					
						
							|  |  |  | =============================== | 
					
						
							| 
									
										
										
										
											2013-10-08 18:29:04 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-02 18:33:39 -07:00
										 |  |  | Subsurface uses quite a few open source libraries and frameworks to do its | 
					
						
							| 
									
										
										
										
											2017-09-02 14:40:58 +03:00
										 |  |  | job. The most important ones include libdivecomputer, Qt, libxml2, libxslt, | 
					
						
							|  |  |  | libsqlite3, libzip, libgrantlee5 and libgit2. | 
					
						
							| 
									
										
										
										
											2013-12-12 17:10:49 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | Below are instructions for building Subsurface under some popular | 
					
						
							|  |  |  | Linux distributions, for building Subsurface using Homebrew on a Mac, | 
					
						
							|  |  |  | and for cross-building Subsurface for Windows. The lack of a working | 
					
						
							|  |  |  | package management system for Windows makes it really painful to build | 
					
						
							| 
									
										
										
										
											2015-02-17 13:18:05 -08:00
										 |  |  | Subsurface natively under Windows, so we don't support that at all. | 
					
						
							| 
									
										
										
										
											2013-12-12 17:10:49 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-04 07:42:29 -08:00
										 |  |  | All of the prebuilt binaries that we provide (right now Windows, Mac, | 
					
						
							|  |  |  | Ubuntu/Debian/LinuxMint, and openSUSE/Fedora) are built using our own | 
					
						
							| 
									
										
										
										
											2017-09-02 14:40:58 +03:00
										 |  |  | custom "flavors" of libdivecomputer. You can get these from | 
					
						
							| 
									
										
										
										
											2014-12-14 13:11:37 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-21 16:23:03 +02:00
										 |  |  | https://github.com/Subsurface-divelog/libdc.git | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | If you have cloned subsurface it is easier, | 
					
						
							|  |  |  | locate yourself in the subsurface repo, and do: | 
					
						
							|  |  |  | git submoule init | 
					
						
							|  |  |  | git submodule update | 
					
						
							| 
									
										
										
										
											2014-12-14 13:11:37 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-02 18:33:39 -07:00
										 |  |  | Those branches won't have a pretty history and will include ugly merges, | 
					
						
							|  |  |  | but they should always allow a fast forward pull that tracks what we believe | 
					
						
							|  |  |  | developers should build against. | 
					
						
							| 
									
										
										
										
											2015-08-26 11:44:56 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | In contrast to that both repositories also have Subsurface-clean branches. | 
					
						
							|  |  |  | These should allow distros to see which patches we have applied on top of | 
					
						
							|  |  |  | upstream. They will receive force pushes as we rebase to newer versions of | 
					
						
							|  |  |  | upstream so they are not ideal for ongoing development (but they are of | 
					
						
							|  |  |  | course easy to use for distributions as they always build "from scratch", | 
					
						
							|  |  |  | anyway). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-14 13:11:37 -08:00
										 |  |  | The rationale for this is that we have no intention of forking either of | 
					
						
							|  |  |  | these two projects. We simply are adding a few patches on top of their | 
					
						
							| 
									
										
										
										
											2015-08-26 11:44:56 -07:00
										 |  |  | latest versions and want to do so in a manner that is both easy for our | 
					
						
							|  |  |  | developers who try to keep them updated frequently, and anyone packaging | 
					
						
							|  |  |  | Subsurface or trying to understand what we have done relative to their | 
					
						
							|  |  |  | respective upstreams. | 
					
						
							| 
									
										
										
										
											2014-12-14 13:11:37 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-02 18:33:39 -07:00
										 |  |  | At this point Qt5 is required, Qt5.4 or newer is recommended and on the | 
					
						
							|  |  |  | Mac, in order to get native Bluetooth support, Qt5.5 is necessary. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Similarly, in order for our cloud storage to be fully functional you need | 
					
						
							|  |  |  | libgit2 0.23 or newer. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Finally, as of Subsurface 4.5 we have switched our build system to cmake. | 
					
						
							|  |  |  | qmake based builds are no longer supported. | 
					
						
							| 
									
										
										
										
											2015-04-09 15:46:25 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-12 17:10:49 +01:00
										 |  |  | Build options for Subsurface | 
					
						
							|  |  |  | ---------------------------- | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-09 15:46:25 -07:00
										 |  |  | The following options are recognized when passed to cmake: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  -DCMAKE_BUILD_TYPE=Release	create a release build | 
					
						
							|  |  |  |  -DCMAKE_BUILD_TYPE=Debug	create a debug build | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The Makefile that was created using cmake can be forced into a much more | 
					
						
							|  |  |  | verbose mode by calling | 
					
						
							| 
									
										
										
										
											2013-12-12 17:10:49 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-09 15:46:25 -07:00
										 |  |  |  make VERBOSE=1 | 
					
						
							| 
									
										
										
										
											2013-12-12 17:10:49 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-02 18:33:39 -07:00
										 |  |  | Many more variables are support, the easiest way to interact with them is | 
					
						
							|  |  |  | to call | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  ccmake . | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | in your build directory. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-09 17:35:15 -08:00
										 |  |  | Building the development version of Subsurface under Linux | 
					
						
							|  |  |  | ---------------------------------------------------------- | 
					
						
							| 
									
										
										
										
											2013-10-08 18:29:04 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-14 13:11:37 -08:00
										 |  |  | On Fedora you need | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | sudo yum install git gcc-c++ make autoconf automake libtool cmake \ | 
					
						
							|  |  |  | 	libzip-devel libxml2-devel libxslt-devel libsqlite3x-devel \ | 
					
						
							| 
									
										
										
										
											2016-06-18 14:18:20 +03:00
										 |  |  | 	libudev-devel libusbx-devel libcurl-devel libssh2-devel\ | 
					
						
							| 
									
										
										
										
											2014-12-14 13:11:37 -08:00
										 |  |  | 	qt5-qtbase-devel qt5-qtdeclarative-devel qt5-qtscript-devel \ | 
					
						
							| 
									
										
										
										
											2015-07-07 06:14:13 -07:00
										 |  |  | 	qt5-qtwebkit-devel qt5-qtsvg-devel qt5-qttools-devel \ | 
					
						
							| 
									
										
										
										
											2015-11-24 14:29:15 +00:00
										 |  |  | 	qt5-qtconnectivity-devel qt5-qtlocation-devel | 
					
						
							| 
									
										
										
										
											2015-06-11 12:02:22 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | Note that beginning with Fedora 22, you should be using the dnf command instead | 
					
						
							|  |  |  | as yum is being deprecated. | 
					
						
							| 
									
										
										
										
											2014-12-14 13:11:37 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-15 14:53:04 -08:00
										 |  |  | Package names are sadly different on OpenSUSE | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | sudo zypper install git gcc-c++ make autoconf automake libtool cmake libzip-devel \ | 
					
						
							| 
									
										
										
										
											2016-06-18 14:18:20 +03:00
										 |  |  | 	libxml2-devel libxslt-devel sqlite3-devel libusb-1_0-devel \ | 
					
						
							| 
									
										
										
										
											2014-12-15 14:53:04 -08:00
										 |  |  | 	libqt5-linguist-devel libqt5-qttools-devel libQt5WebKitWidgets-devel \ | 
					
						
							|  |  |  | 	libqt5-qtbase-devel libQt5WebKit5-devel libqt5-qtsvg-devel \ | 
					
						
							| 
									
										
										
										
											2015-07-07 06:14:13 -07:00
										 |  |  | 	libqt5-qtscript-devel libqt5-qtdeclarative-devel \ | 
					
						
							| 
									
										
										
										
											2015-12-16 06:34:03 -08:00
										 |  |  | 	libqt5-qtconnectivity-devel libqt5-qtlocation-devel libcurl-devel | 
					
						
							| 
									
										
										
										
											2014-12-15 14:53:04 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-20 07:19:05 +01:00
										 |  |  | On Debian Stretch this seems to work | 
					
						
							| 
									
										
										
										
											2014-12-15 14:53:04 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-07 17:20:27 +02:00
										 |  |  | sudo apt-get install git g++ make autoconf automake libtool cmake pkg-config \ | 
					
						
							| 
									
										
										
										
											2014-12-15 14:53:04 -08:00
										 |  |  | 	libxml2-dev libxslt1-dev libzip-dev libsqlite3-dev \ | 
					
						
							| 
									
										
										
										
											2016-06-18 14:18:20 +03:00
										 |  |  | 	libusb-1.0-0-dev libssl-dev \ | 
					
						
							| 
									
										
										
										
											2014-12-27 18:04:14 +01:00
										 |  |  | 	qt5-default qt5-qmake qtchooser qttools5-dev-tools libqt5svg5-dev \ | 
					
						
							|  |  |  | 	libqt5webkit5-dev libqt5qml5 libqt5quick5 libqt5declarative5 \ | 
					
						
							| 
									
										
										
										
											2015-07-07 06:14:13 -07:00
										 |  |  | 	qtscript5-dev libssh2-1-dev libcurl4-openssl-dev qttools5-dev \ | 
					
						
							| 
									
										
										
										
											2016-12-04 05:33:56 +09:00
										 |  |  | 	qtconnectivity5-dev qtlocation5-dev qtpositioning5-dev \ | 
					
						
							| 
									
										
										
										
											2017-10-22 19:11:54 -04:00
										 |  |  | 	libcrypto++-dev libssl-dev qml-module-qtpositioning qml-module-qtlocation \ | 
					
						
							|  |  |  | 	qml-module-qtquick2 | 
					
						
							| 
									
										
										
										
											2013-12-12 17:10:49 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-20 07:19:05 +01:00
										 |  |  | Package names for Ubuntu 16.10 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | sudo apt-get install git g++ make autoconf automake libtool cmake pkg-config \ | 
					
						
							|  |  |  | 	libxml2-dev libxslt1-dev libzip-dev libsqlite3-dev \ | 
					
						
							|  |  |  | 	libusb-1.0-0-dev libssl-dev \ | 
					
						
							|  |  |  | 	qt5-default qt5-qmake qtchooser qttools5-dev-tools libqt5svg5-dev \ | 
					
						
							|  |  |  | 	libqt5webkit5-dev libqt5qml5 libqt5quick5 qtdeclarative5-dev \ | 
					
						
							|  |  |  | 	qtscript5-dev libssh2-1-dev libcurl4-openssl-dev qttools5-dev \ | 
					
						
							|  |  |  | 	qtconnectivity5-dev qtlocation5-dev qtpositioning5-dev \ | 
					
						
							| 
									
										
										
										
											2017-10-22 19:11:54 -04:00
										 |  |  | 	libcrypto++-dev libssl-dev qml-module-qtpositioning qml-module-qtlocation \ | 
					
						
							|  |  |  | 	qml-module-qtquick2 | 
					
						
							| 
									
										
										
										
											2017-02-20 07:19:05 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-17 23:23:22 -08:00
										 |  |  | On PCLinuxOS you appear to need the following packages | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | su -c "apt-get install -y autoconf automake cmake libtool gcc-c++ git \ | 
					
						
							|  |  |  | lib64usb1.0-devel lib64zip-devel lib64qt5webkitwidgets-devel qttools5 \ | 
					
						
							|  |  |  | qttranslations5 lib64qt5xml-devel lib64qt5test-devel lib64qtscript-devel \ | 
					
						
							| 
									
										
										
										
											2015-07-07 06:14:13 -07:00
										 |  |  | lib64qt5svg-devel lib64qt5concurrent-devel lib64qt5bluetooth-devel" | 
					
						
							| 
									
										
										
										
											2013-10-08 18:29:04 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-18 00:17:02 -08:00
										 |  |  | In order to build Subsurface, use the supplied build script. This should | 
					
						
							| 
									
										
										
										
											2015-07-07 06:14:13 -07:00
										 |  |  | work on most systems that have all the prerequisite packages installed. | 
					
						
							| 
									
										
										
										
											2015-02-17 13:18:05 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | You should have Subsurface sources checked out in a sane place, something | 
					
						
							|  |  |  | like this: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | mkdir -p ~/src | 
					
						
							|  |  |  | cd ~/src | 
					
						
							| 
									
										
										
										
											2017-04-15 12:33:38 +02:00
										 |  |  | git clone https://github.com/Subsurface-divelog/subsurface.git | 
					
						
							| 
									
										
										
										
											2015-02-17 13:18:05 -08:00
										 |  |  | ./subsurface/scripts/build.sh # <- this step will take quite a while as it | 
					
						
							|  |  |  |                               #    compiles a handful of libraries before | 
					
						
							|  |  |  | 			      #    building Subsurface | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Now you can run Subsurface like this: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-15 12:52:51 -04:00
										 |  |  | cd ~/src/subsurface/build | 
					
						
							| 
									
										
										
										
											2015-10-13 20:05:47 -07:00
										 |  |  | ./subsurface | 
					
						
							| 
									
										
										
										
											2015-02-17 13:18:05 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-09 20:48:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-04 09:17:42 -07:00
										 |  |  | Note: on many Linux versions (for example on Kubuntu 15.04) the user must | 
					
						
							|  |  |  | belong to the dialout group. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | You may need to run something like | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | sudo usermod -a -G dialout username | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | with your correct username and log out and log in again for that to take | 
					
						
							|  |  |  | effect. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-04 17:00:30 +01:00
										 |  |  | If you get errors like: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-13 20:05:47 -07:00
										 |  |  | ./subsurface: error while loading shared libraries: libGrantlee_Templates.so.5: cannot open shared object file: No such file or directory | 
					
						
							| 
									
										
										
										
											2015-07-04 17:00:30 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | You can run the following command: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-04 09:17:42 -07:00
										 |  |  | sudo ldconfig ~/src/install-root/lib | 
					
						
							| 
									
										
										
										
											2015-07-04 17:00:30 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-14 13:11:37 -08:00
										 |  |  | Building Subsurface under MacOSX (using Homebrew) | 
					
						
							|  |  |  | ------------------------------------------------- | 
					
						
							| 
									
										
										
										
											2013-10-08 18:29:04 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-01 13:55:20 +01:00
										 |  |  | 0) You need to have XCode installed. The first time (and possibly after updating OSX) | 
					
						
							|  |  |  | you need to run | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | $ xcode-select --install | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-08 18:29:04 -07:00
										 |  |  | 1)  Install Homebrew | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-16 14:47:00 -07:00
										 |  |  | $ ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)" | 
					
						
							| 
									
										
										
										
											2013-10-08 18:29:04 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 2) Install needed dependencies | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-23 11:50:36 -04:00
										 |  |  | $ brew install asciidoc libzip cmake libusb pkg-config automake libtool hidapi curl libssh2 | 
					
						
							| 
									
										
										
										
											2013-10-08 18:29:04 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-23 11:50:36 -04:00
										 |  |  | 3) Download and install Qt | 
					
						
							| 
									
										
										
										
											2013-10-08 18:29:04 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-16 17:42:55 -07:00
										 |  |  | You can build Qt from source or use the prebuilt binaries for Mac. Start | 
					
						
							|  |  |  | by downloading the online installer: | 
					
						
							| 
									
										
										
										
											2014-12-25 23:44:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-16 17:42:55 -07:00
										 |  |  | $ curl -L -o ~/Downloads/qt-unified-mac-x64-online.dmg \ | 
					
						
							|  |  |  | 	http://download.qt.io/official_releases/online_installers/qt-unified-mac-x64-online.dmg | 
					
						
							|  |  |  | $ open ~/Downloads/qt-unified-mac-x64-online.dmg | 
					
						
							| 
									
										
										
										
											2014-12-25 23:44:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-16 17:42:55 -07:00
										 |  |  | Double click on the Qt installer shown in the Finder window. | 
					
						
							| 
									
										
										
										
											2014-12-25 23:44:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-16 17:42:55 -07:00
										 |  |  | In the installer, chose an install folder (the build script we are using | 
					
						
							|  |  |  | below assumes that you accept the default of /home/<your username>/Qt), in | 
					
						
							|  |  |  | "Select components" select the most recent version and (if you want to | 
					
						
							|  |  |  | build Qt from source) be sure you also install the "Source Components". | 
					
						
							|  |  |  | To save time and disk space you can unselect Android and IOS packages | 
					
						
							|  |  |  | as well as QtWebEngine, Qt3D, Qt Canvas 3D and the Qt Extras. | 
					
						
							| 
									
										
										
										
											2014-12-25 23:44:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-16 17:42:55 -07:00
										 |  |  | If you want to build from source (which takes a very long time and a lot of disk) | 
					
						
							| 
									
										
										
										
											2014-12-25 23:44:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-23 11:50:36 -04:00
										 |  |  | $ cd ~/Qt/5.9.2/Src/ | 
					
						
							| 
									
										
										
										
											2014-12-25 23:44:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-16 17:42:55 -07:00
										 |  |  | $ ./configure -prefix /usr/local -opensource | 
					
						
							| 
									
										
										
										
											2014-12-25 23:44:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-09 12:56:15 -07:00
										 |  |  | $ make -j4 | 
					
						
							| 
									
										
										
										
											2013-10-08 18:29:04 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-09 12:56:15 -07:00
										 |  |  | $ make install | 
					
						
							| 
									
										
										
										
											2013-10-08 18:29:04 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-16 17:42:55 -07:00
										 |  |  | 5) run the build script | 
					
						
							| 
									
										
										
										
											2014-12-25 23:44:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-16 17:42:55 -07:00
										 |  |  | cd ~/src | 
					
						
							|  |  |  | bash subsurface/scripts/build.sh | 
					
						
							| 
									
										
										
										
											2013-10-08 18:29:04 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-09 15:46:25 -07:00
										 |  |  | After the above is done, Subsurface.app will be available in the | 
					
						
							| 
									
										
										
										
											2015-08-16 17:42:55 -07:00
										 |  |  | subsurface/build directory. You can run Subsurface with the command | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | $ open subsurface/build/Subsurface.app | 
					
						
							| 
									
										
										
										
											2013-10-08 18:29:04 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-16 17:42:55 -07:00
										 |  |  | or you can move this folder to /Applications to install Subsurface for | 
					
						
							|  |  |  | every user. | 
					
						
							| 
									
										
										
										
											2013-10-08 18:29:04 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-26 17:21:13 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-08 18:29:04 -07:00
										 |  |  | Cross-building Subsurface on Linux for Windows | 
					
						
							|  |  |  | ---------------------------------------------- | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Subsurface builds nicely with MinGW - the official builds are done as | 
					
						
							| 
									
										
										
										
											2015-10-13 20:05:47 -07:00
										 |  |  | cross builds under Linux (currently on Ubuntu 14.04). A shell script to do | 
					
						
							| 
									
										
										
										
											2013-10-08 18:29:04 -07:00
										 |  |  | that (plus the .nsi file to create the installer with makensis) are | 
					
						
							| 
									
										
										
										
											2013-12-12 17:10:49 +01:00
										 |  |  | included in the packaging/windows directory. | 
					
						
							| 
									
										
										
										
											2013-10-08 18:29:04 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-13 20:05:47 -07:00
										 |  |  | Please read through the explanations and instructions in | 
					
						
							|  |  |  | packaging/windows/mxe-based-build.sh if you want to build the Windows | 
					
						
							|  |  |  | version on your Linux system. | 
					
						
							| 
									
										
										
										
											2014-12-15 18:19:21 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-08 18:29:04 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | Building Subsurface on Windows | 
					
						
							|  |  |  | ------------------------------ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-15 18:19:21 -08:00
										 |  |  | This is NOT RECOMMENDED. To the best of our knowledge there is one single | 
					
						
							| 
									
										
										
										
											2015-02-12 02:38:08 +02:00
										 |  |  | person who regularly does this. The Subsurface team does not provide support | 
					
						
							| 
									
										
										
										
											2015-10-13 20:05:47 -07:00
										 |  |  | for Windows binary build from sources natively under Windows... | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 10:06:37 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | Building Subsurface for Android | 
					
						
							| 
									
										
										
										
											2015-10-13 20:05:47 -07:00
										 |  |  | ------------------------------- | 
					
						
							| 
									
										
										
										
											2015-08-18 10:06:37 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | To compile the mobile version you will need: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | -Qt for Android (this can be downloaded from: http://www.qt.io/download-open-source/) | 
					
						
							|  |  |  | -Android SDK | 
					
						
							|  |  |  | -Android NDK | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | In the packaging/android folder, open the build.sh file and add the paths to the SDK, | 
					
						
							|  |  |  | NDK and Qt for android at the top. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | After that, you can run: ./subsurface/packaging/android/build.sh | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | This will generate an apk file in ./subsurface-mobile-build-arm/bin |