Compile and Install Ubuntu: Difference between revisions
| Line 78: | Line 78: | ||
| </source> | </source> | ||
| * In case the compilation of gdal and proj4 is not required, install the following packages <source lang="bash"> | |||
| sudo apt-get install libproj-dev gdal-bin libgdal-dev | |||
| </source> | |||
| * create a directory as a simple user where all source code is going to be stored -- in this example, a directory named <source lang="bash" enclose="none">src</source> under <source lang="bash" enclose="none">/usr/local</source> is created <source lang="bash"> | * create a directory as a simple user where all source code is going to be stored -- in this example, a directory named <source lang="bash" enclose="none">src</source> under <source lang="bash" enclose="none">/usr/local</source> is created <source lang="bash"> | ||
| sudo mkdir /usr/local/src | sudo mkdir /usr/local/src | ||
Revision as of 15:53, 10 May 2013
Very Important notes
- Pre-compiled packages and backports are available from UbuntuGIS via their ppa.launchpad repositories. This is by far the simplest and fastest solution. Please prefer it over the manual way described below.
- To build an updated version of GRASS or support libraries unmodified, in most cases it will be easier to use an automated build tool such as pbuilder, debuild or cowbuilder. See the debian/directory in the source code for details.
- Some things change fast and therefore it is expected that the instructions might fail. Please inform the grass-user list in case something just does not work (like for example non-available dependecies/packages from the repositories) or update this page respectively.
- GRASS version 6.5 exists for development purposes, testing features to-be backported to version 6.4. As such it may include unstable code and is not intended for production and end-users.
- An alternate method is to use the DebianGIS packaging scripts, which enable a lot of this to happen automatically (see debian/README.debian in the GRASS Subversion source code repository). Specifically, this command will get you 90% of the way there: sudo apt-get build-dep grass 
- (you'll need to have the deb-src lines active in your /etc/apt/sources.list file)
Hints
- Usually, the installation of compiled code is done by using the maketool. Alternatively, this can be done by using the checkinstall tool (i.e.,sudo checkinstallinstead ofsudo make install) which eases off removal of packages. If checkinstall fails to deliver, please note some related bugs: 78455 and 599163. Useful information on using checkinstall: Compiling things on Ubuntu the Easy Way.
- In multi-core processors, the compilation performance can be boosted by using  -j  switches (e.g. make -j2ormake -j3or evenmake -j4) which specify the number of jobs (commands) to run simultaneously.
Dependencies
Current stable Ubuntu version
The following dependencies concern Ubuntu Quantal Quetzal (12.10)
- First, update the system from the repositoriessudo apt-get update && sudo apt-get upgrade 
- then, install SQLite, SVN and dependencies for compiling PROJ, GEOS, GDAL/OGR, GRASS, GDAL-GRASS-PLUGIN; the following action will also install various dependencies (listed in the command line as The following extra packages will be installed:...):
# this is a single command, please copy-paste it entirely into the terminal:
sudo apt-get install \
  build-essential \
  flex make bison gcc libgcc1 g++ cmake ccache \
  python python-dev python-qt4 python-qt4-dev \
  python-opengl \
  python-wxversion python-wxtools python-wxgtk2.8 \
  python-dateutil libgsl0-dev python-numpy \
  wx2.8-headers wx-common libwxgtk2.8-dev libwxgtk2.8-dbg \
  libwxbase2.8-dev  libwxbase2.8-dbg \
  libncurses5-dev \
  zlib1g-dev gettext \
  libtiff-dev libpnglite-dev \
  tcl8.5-dev tk8.5-dev \
  libcairo2 libcairo2-dev \
  sqlite3 libsqlite3-dev \
  libpq-dev \
  libreadline6 libreadline6-dev libfreetype6-dev \
  txt2tags \
  libfftw3-3 libfftw3-dev \
  libqt4-core libqt4-dbg libqt4-dev libqt4-gui libqt4-sql libqt4-qt3support \
  lsb-qt4 qt4-designer qt4-dev-tools qt4-doc qt4-qtconfig \
  libapt-pkg-perl resolvconf \
  libjasper-dev \
  ruby \
  subversion \
  ffmpeg ffmpeg2theora \
  libffmpegthumbnailer-dev \
  libavcodec-dev \
  libxmu-dev \
  libavformat-dev libswscale-dev \
  checkinstall \
  libglu1-mesa-dev libxmu-dev
- for mysql support, libmysqlclient-devis requiredsudo apt-get install libmysqlclient-dev 
- for netcdf support, netcdf-binandlibnetcdf-devis requiredsudo apt-get install netcdf-bin libnetcdf-dev 
- In case the compilation of gdal and proj4 is not required, install the following packages sudo apt-get install libproj-dev gdal-bin libgdal-dev 
- create a directory as a simple user where all source code is going to be stored -- in this example, a directory named srcunder/usr/localis createdsudo mkdir /usr/local/src 
- take over directories ownerships (replace below the terms userid and groupid with a real userid):sudo chown userid:groupid /usr/local/src 
- similarly, grant rwx(read-write-execute) permissions for our userid and groupid onto thesrcdirectory:sudo chmod ug+rwx /usr/local/src 
Earlier Ubuntu versions
For earlier Ubuntu versions, watch out for dependency differences! Modify the dependency list given above as instructed below.
- for Ubuntu Precise Pangolin (12.04), change the following dependencies:
- libpnglite-dev --> libpngwriter-dev
- libtiff5-dev --> libtiff4-dev
 
- for Ubuntu Maverick Meerkat (10.10) or later, change the following dependencies:
- libpngwriter-dev --> libpngwriter0-dev
- libcairo-dev --> libcairo2-dev
- fftw3 --> libfftw3-3
- fftw3-dev --> libfftw3-dev
 
- for Ubuntu Lucid Lynx (10.04) or later, also install: sudo apt-get install libhdf4-alt-dev libhdf4-0-alt 
- for earlier Ubuntu versions, also install: sudo apt-get install libhdf4g-dev libhdf4g-run 
Using pre-compiled dev Packages for PROJ.4, GEOS and GDAL
PROJ.4
Install the dev package (possibly without support for datumgrid):
sudo apt-get install libproj-dev
- In the call to ./configurefor GRASS, replace--with-proj-share=/usr/local/share/proj/by--with-proj-share=/usr/share/proj/
GEOS
Install the dev package:
sudo apt-get install libgeos-dev
- In the call to ./configurefor GRASS, replace--with-geos=/usr/local/bin/geos-configby--with-geos=/usr/bin/geos-config
GDAL
Install the dev package (possibly without support for datumgrid):
sudo apt-get install libgdal-dev
- Install also the required extra packages (note the message: The following extra packages will be installed:)
- Look out for packages to be removed by this operation -- this is most likely caused by incompatible package versions. Fix these problems in advance using commands like the following: sudo apt-get install <package>=<required.version> 
GRASS-GIS
Jump to sub-section GRASS-GIS below
Compile from source
PROJ4
- within the directory /usr/local/src(create it if it does not exist) checkoutprojfrom its Subversion repository:svn co http://svn.osgeo.org/metacrs/proj/branches/4.8/proj/ 
- get proj-datumgrid-1.5.zip from proj' trac and move it under proj/nad
wget http://download.osgeo.org/proj/proj-datumgrid-1.5.zip
mv proj-datumgrid-1.5.zip /usr/local/src/proj/nad
cd /usr/local/src/proj/nad
- decompress it unzip proj-datumgrid-1.5.zip
- go back to the projdirectorycd /usr/local/src/proj 
- if required, clean previous configuration & compilation make distclean
- simple configure, compile and install ./configure && make && sudo make install 
-  or 
./configure && make -j2  &&  sudo checkinstall
- ensure that /usr/local/libis added to/etc/ld.so.confand afterwards runsudo ldconfig
- finally, go back to the parent directory simply by instructingcd .. 
GEOS
- download geos-3.3.5.tar.bz2 from http://trac.osgeo.org/geos using wgetwget http://download.osgeo.org/geos/geos-3.3.5.tar.bz2
- move to the "source-code" directory and decompress
cd /usr/local/src/
bunzip2 geos-3.3.5.tar.bz2
tar xvf  geos-3.3.5.tar
- if required, clean previous configuration & compilation  make distclean
- move to geos directory  cd geos-3.3.5 
- simple configure, compile and install ./configure && make && sudo make install 
-  or 
./configure  && make -j2  &&  sudo checkinstall
- do not forget to execute sudo ldconfig
GDAL
Note, GDAL must be compiled without GRASS support
- download the current stable version svn checkout https://svn.osgeo.org/gdal/branches/1.9/gdal gdal_stable 
- enter in the gdal_stabledirectorycd /usr/local/src/gdal_stable 
- optionally, update the source code svn up
- if required, clean previous configurations/compilations make distclean
- a simple configuration without any parameters will detect and support various installed libraries ./configure 
- skip to the compile and install step or check the following customised configuration example
CFLAGS="-g -Wall" LDFLAGS="-s" ./configure \
--with-png=internal \
--with-libtiff=internal \
--with-geotiff=internal \
--with-jpeg=internal \
--with-gif=internal \
--with-ecw=yes \
--with-expat=yes \
--with-sqlite3=yes \
--with-geos=yes \
--with-python \
--with-libz=internal \
--with-netcdf \
--with-sqlite \
--with-threads=yes \
--without-grass  \
--without-ogdi \
--with-pg=/usr/bin/pg_config \
--with-xerces=yes
- compile, install & ldconfig make -j2 && sudo make install && sudo ldconfig 
-  or 
make -j2  &&  sudo checkinstall  &&  sudo ldconfig
GRASS GIS
Getting GRASS' source code
- get current state of the 6.4.x release branch version (stable) svn co https://svn.osgeo.org/grass/grass/branches/releasebranch_6_4 grass64_release 
To download under development versions use
- for GRASS 6.5  (Note: GRASS version 6.5 is not intended for end-users! It exists for development purposes which should rather take place for GRASS 7.) svn checkout https://svn.osgeo.org/grass/grass/branches/develbranch_6 grass6_devel 
- for GRASS 7 svn checkout https://svn.osgeo.org/grass/grass/trunk grass_trunk 
- for subsequent updates execute svn up
Configure, Compile and Install
- if required, clean previous configuration & compilation (not needed the first time) make distclean
- example configuration (which can/should be adjusted according to specific needs):
./configure \
--enable-largefile=yes \
--with-nls \
--with-cxx \
--with-proj-share=/usr/local/share/proj/ \
--with-geos=/usr/local/bin/geos-config \
--with-python=yes \
--with-wxwidgets \
--with-cairo \
--with-tcltk-includes="/usr/include/tcl8.5/" \
--with-opengl-libs=/usr/include/GL \
--with-motif \
--with-ffmpeg=yes --with-ffmpeg-includes="/usr/include/libavcodec /usr/include/libavformat /usr/include/libswscale" \
--with-freetype=yes --with-freetype-includes="/usr/include/freetype2/" \
--with-postgres=yes \
--with-postgresql=yes --with-postgres-includes="/usr/include/postgresql" \
--with-sqlite=yes \
--with-mysql=yes --with-mysql-includes="/usr/include/mysql" \
--with-odbc=yes
- 
Note, the above configuration uses the 
Proj4 and GEOS packages compiled from the source. In the case that pre-compiled versions from the repository are required, remove the above corresponding lines to use the "defaults", i.e. --with-proj-share=/usr/share/proj \
--with-geos=/usr/bin/geos-config \
- compile & install make -j2 && sudo make install && sudo ldconfig 
-  or 
make -j2  &&  sudo checkinstall  &&  sudo ldconfig
GDAL-GRASS-Plugin
- get the plugin from OSGeo's Download Server: http://download.osgeo.org/gdal/gdal-grass-1.4.3.tar.gz using wgetwget http://download.osgeo.org/gdal/gdal-grass-1.4.3.tar.gz 
- create   /etc/ld.so.conf.d/grass6.confor add in/etc/ld.so.confthe GRASS library path, i.e./usr/local/src/grass64_release/lib
- optionally, clean previous configurations/compilationsmake distclean 
- configure -- point to GRASS installation/binaries
 ./configure \
 --prefix=/usr/local \
 --with-gdal=/usr/local/bin/gdal-config \
 --with-grass=/geo/osgeo/src/grass64_release/dist.x86_64-unknown-linux-gnu/ \
 --with-autoload="/usr/local/lib/gdalplugins/" \
 --with-ld-shared="g++ -shared"
- for GRASS 6.5, replace the respective line above, depending on where the source code in question is stored, with something like--with-grass=/usr/local/grass-6.5.svn/
- for GRASS 7, replace with --with-grass=/usr/local/grass_trunk/
- compile & install using checkinstallmake -j2 && sudo checkinstall 
Post compilation/installation control
- For a recommended quick-check read the Troubleshooting section at Compile_and_install_GDAL-GRASS_plugin
- in case of errors in future compilation attempts, remember to remove program binaries and files created with the "configuration" from previous compilations with
make distclean
- another common mistake is compiling a module against some GRASS version and then try to run it through another GRASS version. The solution is to recompile the affected module or, in case there are multiple GRASS installations, set up properly LD_LIBRARY_PATH paths.
Removal of GRASS
To get rid of a GRASS binaries installation, delete
- /usr/local/grass-6.4.0svn(directory, binaries location)
- /usr/local/bin/grass64(file)
- /usr/local/bin/gem64(file)
- /home/username/.grassrc6(file)
If wanted, delete also the complete source code:
- /usr/local/src/grass_64svn(directory, source code location)
To remove grass (or any other package) which was installed by checkinstall, use dpkg, e.g.
sudo dpkg -r grass64 # package name defined at installation is importantPackaging of GRASS
- See the debian/README.debian file in the GRASS source code for directions on rolling your own packages.
For details about the auto-nightly-builds and after-market supplied packages from UbuntuGIS, please refer to the Ubuntu Packaging wiki page.