GEOS / Usage / Download Source Edit this page

Download Source

Release Date Release Download Link Changes
2021/11/02 3.10.1 geos-3.10.1.tar.bz2 Changes
2021/11/01 3.9.2 geos-3.9.2.tar.bz2 Changes
2021/04/10 3.8.2 geos-3.8.2.tar.bz2 Changes
2019/10/04 3.7.3 geos-3.7.3.tar.bz2 Changes
2020/12/11 3.6.5 geos-3.6.5.tar.bz2 Changes
2019/10/04 3.5.2 geos-3.5.2.tar.bz2 Changes

Build From Source

Build Requirements

  • CMake 3.13 or later.
  • C++11 compiler. We regularly test GCC, Clang and Microsoft Visual C++.
  • Doxygen to build the API documentation.


Builds with CMake are done “outside the tree” either in a build directory in the source tree or next to the tree.

# Unpack and setup build directory
tar xvfz geos-3.10.1.tar.bz2
cd geos-3.10.1
mkdir _build
cd _build
# Set up the build
cmake \
    -DCMAKE_BUILD_TYPE=Release \
    -DCMAKE_INSTALL_PREFIX=/usr/local \
# Run the build, test, install steps
make install

Build Options

The GEOS build can be customized using build options.

Option Default Note
CMAKE_BUILD_TYPE Release Use Debug to build with debug flags and optimizations off. Use Release for packaging and production installs. Use RelWithDebInfo for optimized build with debug symbols.
CMAKE_INSTALL_PREFIX /usr/local Set to install root. Librarys end up in ./libs headers in ./include
BUILD_DOCUMENTATION ON Attempt to find doxygen executable and build API docs
BUILD_SHARED_LIBS ON Build dynamically linkable libraries.
DISABLE_GEOS_INLINE OFF Turn off inlining. This is bad for performance, only do this if you cannot build to pass tests on your platform with inlining on.

Test Options

It is possible to run ctest directly. This gives access to ctest command line options (see ctest –help for a listing).

ctest --verbose

A list of GEOS test suites is obtained by running ctest --show-only:

$ ctest --show-only
# Test project /home/dan/dev/libgeos/cmake-build-debug
#  Test #1: test_geos_unit
#  Test #2: test_xmltester
#  Test #3: test_bug234
#  Test #4: test_sweep_line_speed

A subset of test suites can be run using a regular expression (and in this case, running 4 jobs in parallel):

$ ctest --tests-regex test_ --parallel 4