Archive:Getting Started/Build/Mac OS X: Difference between revisions

From KDE TechBase
m (Reverted edits by KennethMartinez (talk) to last revision by AnneW)
 
(17 intermediate revisions by 5 users not shown)
Line 1: Line 1:
__NOINDEX__
{{improve}}
{{improve}}
{{Note|
{{Note|
Line 6: Line 7:
*Note: You may wish to do all of this inside a directory name that ends in ''.noindex'' or ''.build'' to keep spotlight from indexing all of your temporary build-files as you build them.
*Note: You may wish to do all of this inside a directory name that ends in ''.noindex'' or ''.build'' to keep spotlight from indexing all of your temporary build-files as you build them.


<code>mkdir ~/kde4.build
<syntaxhighlight lang="text">mkdir ~/kde4.build
cd ~/kde4.build</code>
cd ~/kde4.build</syntaxhighlight>
 
== MacPorts or Fink ==
The best method for currently installing KDE on Mac is to use either Macports or Fink to build at least the system requirements and then also install their stable KDE, or build your own development KDE using on top of their base.
 
You can find out more information on the [[/MacPorts| KDE on MacPorts]] page.


== Setting Up Your Build Environment ==
== Setting Up Your Build Environment ==
Variables must be set to build KDE successfully, and are noted below
Variables must be set to build KDE successfully, and are noted below
*Note: Replace /opt/kde4-deps with the location of your 3rd-party tools, and add your cmake location if you compiled from source
*Note: Replace /opt/kde4-deps with the location of your 3rd-party tools, and add your cmake location if you compiled from source
<code>export PATH="/opt/qt4/bin:/opt/kde4/bin:/opt/kde4-deps/bin:$PATH"
<syntaxhighlight lang="text">export PATH="/opt/qt4/bin:/opt/kde4/bin:/opt/kde4-deps/bin:~/.local/bin/:$PATH"
export CMAKE_LIBRARY_PATH="/opt/kde4-deps/lib"
export CMAKE_LIBRARY_PATH="/opt/kde4-deps/lib"
export CMAKE_INCLUDE_PATH="/opt/kde4-deps/include"
export CMAKE_INCLUDE_PATH="/opt/kde4-deps/include"
export PKG_CONFIG_PATH="/opt/qt4/lib/"</code>
export PKG_CONFIG_PATH="/opt/qt4/lib/:/opt/kde4-deps/lib/pkgconfig/"
</syntaxhighlight>


You might want to put those in your ~/.bash_profile
You might want to put those in your ~/.bash_profile
Line 21: Line 28:
* For Fink users: If your ''Distribution'' line in ''/sw/etc/fink.conf'' is 10.4-transitional, instead of 10.4, make sure you run ''sudo gcc_select 3.3'' before proceeding with any compiling, or you will end up with binary-incompatible c++ code!
* For Fink users: If your ''Distribution'' line in ''/sw/etc/fink.conf'' is 10.4-transitional, instead of 10.4, make sure you run ''sudo gcc_select 3.3'' before proceeding with any compiling, or you will end up with binary-incompatible c++ code!
* For others: run ''sudo gcc_select 4.0'' if you want to be compatible with the pre-made installers.
* For others: run ''sudo gcc_select 4.0'' if you want to be compatible with the pre-made installers.


== Required Third Party Tools ==
== Required Third Party Tools ==
The following third party tools are required for successfully building KDE on OSX. Also, here are some [[Getting_Started/Build/KDE4/LFS| good tips for installing from source]].
The following third party tools are required for successfully building KDE on OSX. Also, here are some [[Getting_Started/Build/KDE4/LFS| good tips for installing from source]]. I assume you have OS X 10.5 or 10.6 installed, otherwise you would have some more dependencies.
* [http://developer.apple.com/technologies/xcode.html XCode]
* [http://developer.apple.com/technologies/xcode.html XCode]
* [http://www.gnu.org/software/libtool/libtool.html libtool]
* [http://www.gnu.org/software/libtool/libtool.html libtool]
<code>cd ~/kde4.build
<syntaxhighlight lang="text">cd ~/kde4.build
curl http://ftp.gnu.org/gnu/libtool/libtool-2.2.tar.gz -O
curl http://ftp.gnu.org/gnu/libtool/libtool-2.2.tar.gz -O
tar xfz libtool-2.2.tar.gz  
tar xfz libtool-2.2.tar.gz  
Line 34: Line 40:
./configure --prefix=/opt/kde4-deps
./configure --prefix=/opt/kde4-deps
make
make
sudo make install</code>
sudo make install</syntaxhighlight>
* [http://www.xmlsoft.org/downloads.html libxml2 and libxslt]
* [http://www.xmlsoft.org/downloads.html libxml2 and libxslt]
<code>cd ~/kde4.build
<syntaxhighlight lang="text">cd ~/kde4.build
curl ftp://xmlsoft.org/libxml2/libxml2-sources-2.7.7.tar.gz -O
curl ftp://xmlsoft.org/libxml2/libxml2-sources-2.7.7.tar.gz -O
tar xfz libxml2-sources-*.tar.gz
tar xfz libxml2-sources-*.tar.gz
Line 51: Line 57:
make
make
sudo make install
sudo make install
</code>
</syntaxhighlight>
* [http://www.linuxfromscratch.org/blfs/view/svn/pst/DocBook.html DocBook XML DTD-4.5 and DocBook XSL Stylesheets-1.75.2]
<syntaxhighlight lang="text">cd ~/kde4.build
mkdir docbook
cd docbooj
curl http://www.docbook.org/xml/4.5/docbook-xml-4.5.zip -O
unzip docbook-xml-4.5.zip
# RUN ALL THE COMMANDS AT http://www.linuxfromscratch.org/blfs/view/svn/pst/DocBook.html AS ROOT
# DOWNLOAD THE FILE AT http://www.linuxfromscratch.org/blfs/view/svn/pst/docbook-xsl.html
sudo tar xfj docbook-xsl-1.75.2.tar.bz2
cd docbook-xsl-1.75.2
# RUN ALL THE COMMANDS THERE AS ROOT</syntaxhighlight>
* [http://www.gtk.org/gtk-doc/download.html gtk-doc]
<syntaxhighlight lang="text">cd ~/kde4.build
curl http://ftp.gnome.org/pub/GNOME/sources/gtk-doc/1.15/gtk-doc-1.15.tar.gz -O -L
tar xfz gtk-doc-*.tar.gz
cd gtk-doc-1.15
./configure --prefix=/opt/kde4-deps/</syntaxhighlight>
* [http://www.gtk.org/download.html glib2]
* [http://www.gtk.org/download.html glib2]
<code></code>
<syntaxhighlight lang="text">git clone git://git.gnome.org/glib
cd glib/
./autogen.sh --prefix=/opt/kde4-deps/ ## THIS IS WHERE I GET STUCK (entriken 2010-08-20)</syntaxhighlight>
* shared-mime-info
* AGG
* AGG
* giflib or libungif
* giflib or libungif
Line 65: Line 91:
* PCRE
* PCRE
* Strigi
* Strigi
* shared-mime-info
* pkgconfig
* pkgconfig
* subversion (to check out the kde sources)
* dbus
* dbus


== Qt/Mac Open Source Edition ==
== Qt/Mac Open Source Edition ==
Get the Qt/Mac source code from http://qt.nokia.com/downloads/qt-for-open-source-cpp-development-on-mac-os-x
Get the Qt/Mac source code from http://qt.nokia.com/downloads/sdk-mac-os-cpp
 
<code>curl http://get.qt.nokia.com/qt/source/qt-everywhere-opensource-src-4.6.3.tar.gz -O
tar xfz qt-everywhere-opensource-src-*.tar.gz</code>
 
Patches are required for a successful build.  Download the qt-copy patches through KDE's svn:
<code>svn co svn://anonsvn.kde.org/home/kde/trunk/qt-copy/patches/</code>
and apply the patches:
<code>cd qt-mac-opensource-4*
for patch in /path/to/patches/*.diff; do patch -p0 < $patch; done
</code>
Note: when applying patches you will get errors when processing x11 specific files (i.e. files that match the pattern *_x11.{h,cpp}), simply skip those patches.


And finally, compile qt-mac:
The latest version has QtDBus and should work with KDE for Mac. Get it here: http://download.qt.nokia.com/qtsdk/qt-sdk-mac-opensource-2010.04.dmg
<code>./configure -prefix /opt/qt4 -qt-gif
make all install</code>


Please note: The Qt/Mac binary edition available from ftp.trolltech.com will '''not''' work,
(statement make by entriken and unverified 2010-08-20)
because it does not contain the QtDBus module! (tested with 4.3.2)


== CMake ==
== CMake ==
Get the latest CMake from http://www.cmake.org/cmake/resources/software.html#latest and install:
Get the latest CMake from http://www.cmake.org/cmake/resources/software.html#latest and install:


<code>curl http://www.cmake.org/files/v2.8/cmake-2.8.2.tar.gz -O
<syntaxhighlight lang="text">cd ~/kde4.build
curl http://www.cmake.org/files/v2.8/cmake-2.8.2.tar.gz -O
tar xfz cmake-*.tar.gz
tar xfz cmake-*.tar.gz
cd cmake-*
cd cmake-*
./configure --prefix=/opt/kde4-deps
./configure --prefix=/opt/kde4-deps
make all
make all
sudo make install</code>
sudo make install</syntaxhighlight>


== Building kdelibs ==
== Building kdelibs ==
kdelibs must be checked out of svn locally to be built:
kdelibs must be checked out of svn locally to be built:
<code>cd ~/kde4.build
<syntaxhighlight lang="text">cd ~/kde4.build
svn co svn://anonsvn.kde.org/home/kde/trunk/KDE/kdelibs</code>
svn co svn://anonsvn.kde.org/home/kde/trunk/KDE/kdelibs</syntaxhighlight>
And then compiled by performing the following:
And then compiled by performing the following:
<code>mkdir kdelibs.build
<syntaxhighlight lang="text">mkdir kdelibs.build
cd kdelibs.build
cd kdelibs.build
cmake ../kdelibs -DCMAKE_INSTALL_PREFIX=/opt/kde4
cmake ../kdelibs -DCMAKE_INSTALL_PREFIX=/opt/kde4
make all install</code>
make all install</syntaxhighlight>


== Troubleshooting ==
== Troubleshooting ==
If kdelibs fails to compile successfully, check the build status for the latest Nightly Builds and Continuous Builds at http://public.kitware.com/dashboard.php?name=kde
If kdelibs fails to compile successfully, check the build status for the latest Nightly Builds and Continuous Builds at http://public.kitware.com/dashboard.php?name=kde


Information about getting and compiling the dependencies can be found at [[Getting_Started/Build/KDE4]] and [[Getting_Started/Build/KDE4/Prerequisites]] (pages are Linux focused, but can be useful)
Information about getting and compiling the dependencies can be found at [[Getting_Started/Build]] (pages are Linux focused, but can be useful)
 


== Further Reading ==
== Further Reading ==

Latest revision as of 15:52, 31 July 2012

Warning
This section needs improvements: Please help us to

cleanup confusing sections and fix sections which contain a todo


Note
If you're interested in just checking things out, binaries for kdelibs and parts of KDE in general are available at http://kde.mac.org and are generated semi-regularly.


  • Note: You may wish to do all of this inside a directory name that ends in .noindex or .build to keep spotlight from indexing all of your temporary build-files as you build them.
mkdir ~/kde4.build
cd ~/kde4.build

MacPorts or Fink

The best method for currently installing KDE on Mac is to use either Macports or Fink to build at least the system requirements and then also install their stable KDE, or build your own development KDE using on top of their base.

You can find out more information on the KDE on MacPorts page.

Setting Up Your Build Environment

Variables must be set to build KDE successfully, and are noted below

  • Note: Replace /opt/kde4-deps with the location of your 3rd-party tools, and add your cmake location if you compiled from source
export PATH="/opt/qt4/bin:/opt/kde4/bin:/opt/kde4-deps/bin:~/.local/bin/:$PATH"
export CMAKE_LIBRARY_PATH="/opt/kde4-deps/lib"
export CMAKE_INCLUDE_PATH="/opt/kde4-deps/include"
export PKG_CONFIG_PATH="/opt/qt4/lib/:/opt/kde4-deps/lib/pkgconfig/"

You might want to put those in your ~/.bash_profile

  • For Fink users: If your Distribution line in /sw/etc/fink.conf is 10.4-transitional, instead of 10.4, make sure you run sudo gcc_select 3.3 before proceeding with any compiling, or you will end up with binary-incompatible c++ code!
  • For others: run sudo gcc_select 4.0 if you want to be compatible with the pre-made installers.

Required Third Party Tools

The following third party tools are required for successfully building KDE on OSX. Also, here are some good tips for installing from source. I assume you have OS X 10.5 or 10.6 installed, otherwise you would have some more dependencies.

cd ~/kde4.build
curl http://ftp.gnu.org/gnu/libtool/libtool-2.2.tar.gz -O
tar xfz libtool-2.2.tar.gz 
cd libtool-2.2
ls
./configure --prefix=/opt/kde4-deps
make
sudo make install
cd ~/kde4.build
curl ftp://xmlsoft.org/libxml2/libxml2-sources-2.7.7.tar.gz -O
tar xfz libxml2-sources-*.tar.gz
cd libxml2-2.7.7
./configure --prefix=/opt/kde4-deps/
make
sudo make install

cd ~/kde4.build
curl ftp://xmlsoft.org/libxml2/libxslt-1.1.26.tar.gz -O
tar xfz libxslt-*.tar.gz
cd libxslt-1.1.26
./configure --prefix=/opt/kde4-deps/
make
sudo make install
cd ~/kde4.build
mkdir docbook
cd docbooj
curl http://www.docbook.org/xml/4.5/docbook-xml-4.5.zip -O
unzip docbook-xml-4.5.zip
# RUN ALL THE COMMANDS AT http://www.linuxfromscratch.org/blfs/view/svn/pst/DocBook.html AS ROOT
# DOWNLOAD THE FILE AT http://www.linuxfromscratch.org/blfs/view/svn/pst/docbook-xsl.html
sudo tar xfj docbook-xsl-1.75.2.tar.bz2
cd docbook-xsl-1.75.2
# RUN ALL THE COMMANDS THERE AS ROOT
cd ~/kde4.build
curl http://ftp.gnome.org/pub/GNOME/sources/gtk-doc/1.15/gtk-doc-1.15.tar.gz -O -L
tar xfz gtk-doc-*.tar.gz
cd gtk-doc-1.15
./configure --prefix=/opt/kde4-deps/
git clone git://git.gnome.org/glib
cd glib/
./autogen.sh --prefix=/opt/kde4-deps/ ## THIS IS WHERE I GET STUCK (entriken 2010-08-20)
  • shared-mime-info
  • AGG
  • giflib or libungif
  • libart_lgpl
  • libidn
  • libjpeg
  • libmng
  • libpng
  • libusb
  • OpenEXR
  • PCRE
  • Strigi
  • pkgconfig
  • dbus

Qt/Mac Open Source Edition

Get the Qt/Mac source code from http://qt.nokia.com/downloads/sdk-mac-os-cpp

The latest version has QtDBus and should work with KDE for Mac. Get it here: http://download.qt.nokia.com/qtsdk/qt-sdk-mac-opensource-2010.04.dmg

(statement make by entriken and unverified 2010-08-20)

CMake

Get the latest CMake from http://www.cmake.org/cmake/resources/software.html#latest and install:

cd ~/kde4.build
curl http://www.cmake.org/files/v2.8/cmake-2.8.2.tar.gz -O
tar xfz cmake-*.tar.gz
cd cmake-*
./configure --prefix=/opt/kde4-deps
make all
sudo make install

Building kdelibs

kdelibs must be checked out of svn locally to be built:

cd ~/kde4.build
svn co svn://anonsvn.kde.org/home/kde/trunk/KDE/kdelibs

And then compiled by performing the following:

mkdir kdelibs.build
cd kdelibs.build
cmake ../kdelibs -DCMAKE_INSTALL_PREFIX=/opt/kde4
make all install

Troubleshooting

If kdelibs fails to compile successfully, check the build status for the latest Nightly Builds and Continuous Builds at http://public.kitware.com/dashboard.php?name=kde

Information about getting and compiling the dependencies can be found at Getting_Started/Build (pages are Linux focused, but can be useful)

Further Reading

For more general information on using CMake, see the CMake Tutorial.