RetroShare/build_scripts/OSX/MacOS_X_InstallGuide.md

210 lines
6.5 KiB
Markdown
Raw Normal View History

2016-07-16 23:10:00 +02:00
# Compilation on MacOS
2016-10-04 23:27:40 +02:00
2016-07-16 23:10:00 +02:00
## Qt Installation
2016-10-04 23:27:40 +02:00
2016-07-16 23:10:00 +02:00
Install Qt via: [Qt Download](http://www.qt.io/download/)
2016-10-04 23:27:40 +02:00
2016-07-16 23:10:00 +02:00
Use default options. And add Qt Script support.
2016-10-04 23:27:40 +02:00
2016-07-16 23:10:00 +02:00
Add to the PATH environment variable by editing your *~/.profile* file.
2021-03-27 13:42:47 +01:00
export PATH="/users/$USER/Qt/5.14.1/clang_64/bin:$PATH"
2016-10-04 23:27:40 +02:00
2018-02-04 10:37:45 +01:00
Depends on which version of Qt you use.
2016-10-04 23:27:40 +02:00
2021-04-02 23:00:10 +02:00
## Get RetroShare
In Qt Creator Projects -> New -> Import Project -> Git Clone -> Choose
Add Repository and Continoue
Repository: https://github.com/RetroShare/RetroShare.git
via Terminal:
cd <your development directory>
git clone https://github.com/RetroShare/RetroShare.git retroshare
via GitHub Desktop: [GitHub Desktop Download](https://central.github.com/deployments/desktop/desktop/latest/darwin)
In GitHub Desktop -> Clone Repository -> URL
Add Repository URL: https://github.com/RetroShare/RetroShare.git and Clone
2023-11-26 18:07:06 +01:00
## ***Get XCode & MacOSX SDK***
2016-07-16 23:10:00 +02:00
2023-11-26 18:07:06 +01:00
Install XCode following this guide: [XCode](http://guide.macports.org/#installing.xcode)
2023-11-29 12:36:23 +01:00
To identify the correct version of Xcode to install, you need to know which OS you are running. Go to the [x] menu -> "About This Mac" and read the macOS version number.
If you are running the macOS Catalina >= 10.15, you can install Xcode directly from App Store using the instructions below.
You can find older versions of Xcode at [Apple Developer Downloads](https://developer.apple.com/downloads/). Find the appropriate .xip file for your macOS version
To install from App Store:
Select [x] menu - > "App Store…".
Search for Xcode. Download and install.
Once Xcode has installed, you must drag the XCode icon into your Applications folder. After you have done this, open Xcode from the Applications folder by double-clicking on the icon and then follow the remaining instructions below.
2023-11-26 18:07:06 +01:00
Install XCode command line developer tools:
2016-10-04 23:27:40 +02:00
2023-11-26 18:07:06 +01:00
$xcode-select --install
2016-10-04 23:27:40 +02:00
2016-07-16 23:10:00 +02:00
Start XCode to get it updated and to able C compiler to create executables.
2016-10-04 23:27:40 +02:00
2023-11-26 18:07:06 +01:00
Get Your MacOSX SDK if missing: [MacOSX-SDKs](https://github.com/phracker/MacOSX-SDKs)
## ***Choose if you use MacPort or HomeBrew***
### MacPort Installation
Install MacPort following this guide: [MacPort](http://guide.macports.org/#installing.xcode)
2016-07-16 23:10:00 +02:00
#### Install libraries
2016-10-04 23:27:40 +02:00
2021-03-26 12:06:10 +01:00
$ sudo port -v selfupdate
$ sudo port install openssl
$ sudo port install miniupnpc
$ sudo port install libmicrohttpd
2016-10-04 23:27:40 +02:00
For VOIP Plugin:
2021-03-26 12:06:10 +01:00
$ sudo port install speex-devel
$ sudo port install opencv
2021-04-02 12:29:21 +02:00
$ sudo port install ffmpeg
2016-10-04 23:27:40 +02:00
2016-07-16 23:10:00 +02:00
### HOMEBREW Installation
Install HomeBrew following this guide: [HomeBrew](http://brew.sh/)
#### Install libraries
2021-03-26 12:06:10 +01:00
$ brew install openssl
$ brew install miniupnpc
$ brew install libmicrohttpd
$ brew install rapidjson
$ brew install sqlcipher
2016-10-04 23:27:40 +02:00
2016-07-16 23:10:00 +02:00
If you have error in linking, run this:
$sudo chown -R $(whoami) /usr/local/lib/pkgconfig
For VOIP Plugin:
2016-10-04 23:27:40 +02:00
2021-03-26 12:06:10 +01:00
$ brew install speex
$ brew install speexdsp
2021-04-02 12:02:01 +02:00
$ brew install opencv
2021-03-26 12:06:10 +01:00
$ brew install ffmpeg
2016-07-16 23:10:00 +02:00
2021-03-27 13:42:47 +01:00
For FeedReader Plugin:
2021-04-02 12:45:19 +02:00
$ brew install libxslt
2021-03-27 13:42:47 +01:00
2016-07-16 23:10:00 +02:00
## Last Settings
2021-04-03 11:24:49 +02:00
In QtCreator Projects -> Manage Kits > Version Control > Git:
2016-07-16 23:10:00 +02:00
2021-04-03 11:24:49 +02:00
select "Pull with rebase"
In QtCreator Projects -> Build -> Build Settings -> Build Environment -> Add this path:
2021-03-26 12:06:10 +01:00
2021-04-03 11:24:49 +02:00
/usr/local/bin
2021-03-26 12:06:10 +01:00
2021-04-03 11:24:49 +02:00
In QtCreator Projects -> Build -> Build Settings -> Build Steps -> Add Additional arguments:
2021-03-26 17:36:01 +01:00
"CONFIG+=rs_autologin" "CONFIG+=rs_use_native_dialogs"
2021-03-26 12:06:10 +01:00
## Set your Mac OS SDK version
2023-12-05 12:46:06 +01:00
Edit retroshare.pri and set your installed sdk version example for 11.1 -> rs_macos11.1 (line 135:)
2021-03-26 12:06:10 +01:00
macx:CONFIG *= rs_macos11.1
rs_macos10.8:CONFIG -= rs_macos11.1
rs_macos10.9:CONFIG -= rs_macos11.1
rs_macos10.10:CONFIG -= rs_macos11.1
rs_macos10.12:CONFIG -= rs_macos11.1
rs_macos10.13:CONFIG -= rs_macos11.1
rs_macos10.14:CONFIG -= rs_macos11.1
rs_macos10.15:CONFIG -= rs_macos11.1
## Link Include & Libraries
2023-11-29 15:32:16 +01:00
When required edit your retroshare.pri macx-* section, check if the Include and Lib path are correct (macx-* section)
2021-03-26 12:06:10 +01:00
INCLUDEPATH += "/usr/local/opt/openssl/include"
QMAKE_LIBDIR += "/usr/local/opt/openssl/lib"
QMAKE_LIBDIR += "/usr/local/opt/sqlcipher/lib"
QMAKE_LIBDIR += "/usr/local/opt/miniupnpc/lib"
alternative via Terminal
2023-11-26 18:07:06 +01:00
$ qmake
INCLUDEPATH+="/usr/local/opt/openssl/include" \
QMAKE_LIBDIR+="/usr/local/opt/openssl/lib" \
QMAKE_LIBDIR+="/usr/local/opt/sqlcipher/lib" \
QMAKE_LIBDIR+="/usr/local/opt/miniupnpc/lib" \
CONFIG+=rs_autologin \
CONFIG+=rs_use_native_dialogs \
CONFIG+=release \
..
2021-03-27 13:42:47 +01:00
2016-10-04 23:27:40 +02:00
2023-11-26 18:07:06 +01:00
With plugins:
2021-04-02 12:02:01 +02:00
$ qmake \
INCLUDEPATH+="/usr/local/opt/openssl/include" QMAKE_LIBDIR+="/usr/local/opt/openssl/lib" \
QMAKE_LIBDIR+="/usr/local/opt/sqlcipher/lib" \
QMAKE_LIBDIR+="/usr/local/opt/miniupnpc/lib" \
INCLUDEPATH+="/usr/local/opt/opencv/include/opencv4" QMAKE_LIBDIR+="/usr/local/opt/opencv/lib" \
INCLUDEPATH+="/usr/local/opt/speex/include" QMAKE_LIBDIR+="/usr/local/opt/speex/lib/" \
INCLUDEPATH+="/usr/local/opt/speexdsp/include" QMAKE_LIBDIR+="/usr/local/opt/speexdsp/lib/" \
INCLUDEPATH+="/usr/local/opt/libxslt/include" QMAKE_LIBDIR+="/usr/local/opt/libxslt/lib" \
QMAKE_LIBDIR+="/usr/local/opt/ffmpeg/lib" \
LIBS+=-lopencv_videoio \
CONFIG+=retroshare_plugins \
CONFIG+=rs_autologin \
CONFIG+=rs_use_native_dialogs \
CONFIG+=release \
..
## Compile RetroShare
You can now compile RetroShare into Qt Creator or with Terminal
2016-10-04 23:27:40 +02:00
2023-11-26 18:07:06 +01:00
$ cd /path/to/retroshare
$ qmake ..
$ make
2016-10-04 23:27:40 +02:00
2016-07-16 23:10:00 +02:00
You can change Target and SDK in *./retroshare.pri:82* changing value of QMAKE_MACOSX_DEPLOYMENT_TARGET and QMAKE_MAC_SDK
2021-03-26 12:06:10 +01:00
You can find the compiled application at *./retroshare/retroshare-gui/src/retroshare.app*
2021-04-02 12:45:19 +02:00
2023-11-26 18:07:06 +01:00
## Issues
If you have issues with openssl (Undefined symbols for architecture x86_64) try to add to *~/.profile* file this or via Terminal
export PATH="/usr/local/opt/openssl/bin:$PATH"
export LDFLAGS="-L/usr/local/opt/openssl/lib"
export CPPFLAGS="-I/usr/local/opt/openssl/include"
export PKG_CONFIG_PATH="/usr/local/opt/openssl/lib/pkgconfig"
For Qt Creator -> QtCreator Projects -> Build -> Build Settings -> Build Steps -> Add Additional arguments:
LDFLAGS="-L/usr/local/opt/openssl/lib"
CPPFLAGS="-I/usr/local/opt/openssl/include"
2021-04-02 12:45:19 +02:00
## Copy Plugins
$ cp \
./plugins/FeedReader/lib/libFeedReader.dylib \
./plugins/VOIP/lib/libVOIP.dylib \
./plugins/RetroChess/lib/libRetroChess.dylib \
./retroshare-gui/src/RetroShare.app/Contents/Resources/