Build Qt 5 PostgreSQL Plugin for Android

From Qt Wiki
Revision as of 06:26, 24 February 2015 by Maintenance script (talk | contribs)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search

h1. Overview

Building postgresql plugin is pretty straight forward.

If you don't want to build them yourself you can download the plugin "here":https://drive.google.com/open?id=0ByPpOAN5EsHKfmgwRTFvQUl5Z1NvUnlYMHptTEs0d2xEc24xZ19Jb0ZDMTBpb3JDQ014ZkU. All you need to do is copy libqsqlpsql.so into /path/to/qt/android_armv7/plugins/sqldrivers/. It's statically linked to libpq!

Setting up Enviroment Variables

Compiling only libpq should work fine with android-9 which is what qt-android is currently compiled with.

export ANDROID_NDK_ROOT=&quot;/path/to/android/ndk&amp;quot;<br />SR=&quot;$ANDROID_NDK_ROOT/platforms/android-9/arch-arm&amp;quot;<br />BR=&quot;$ANDROID_NDK_ROOT/toolchains/arm-linux-androideabi-4.8/prebuilt/linux-x86_64/bin/arm-linux-androideabi-&quot;

Downloading

Posgresql source can be downloaded from http://www.postgresql.org/ftp/source/ These instructions are only tested on the 9.4.1. Once downloaded extract.

Building

cd into the postgresql directory and run configure

STRIP=&quot;$BR&amp;quot;strip RANLIB=&quot;$BR&amp;quot;ranlib OBJDUMP=&quot;$BR&amp;quot;objdump AR=&quot;$BR&amp;quot;ar CC=&quot;$BR&amp;quot;gcc CFLAGS=sysroot=$SR CPP=&quot;$BR&amp;quot;cpp CPPFLAGS=$CFLAGS  ./configure prefix=$SR/usr host=arm-linux-androideabi target=arm-linux-androideabi build=&quot;$CHOST&amp;quot; without-readline

Since android requires that .so files end in .so and not with a version number copy and replace two things in src/Makefile.shlib

"lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION).$(SO_MINOR_VERSION)" with "lib$(NAME)$(DLSUFFIX)" and "lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION)" with "lib$(NAME)$(DLSUFFIX)"

sed -e 's/lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION).$(SO_MINOR_VERSION)/lib$(NAME)$(DLSUFFIX)/g' -i src/Makefile.shlib<br />sed -e 's/lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION)/lib$(NAME)$(DLSUFFIX)/g' -i src/Makefile.shlib

Next run make. For the driver we only need libpq.

make -C src/interfaces/libpq<code>

= Building the plugin =

Next download the source for Qt 5 if you don't have it. We only base http://download.qt.io/archive/qt/5.4/5.4.0/submodules/qtbase-opensource-src-5.4.0.tar.xz After downloading and extracting cd into &quot;qtbase-opensource-src-5.4.0/src/plugins/sqldrivers/psql/&amp;quot;

Run qmake followed by make<br />

qmake "INCLUDEPATH+=/path/to/postgresql-9.4.1/src/interfaces/libpq /path/to/postgresql-9.4.1/src/include&quot; "LIBS+=-L/path/to/postgresql-9.4.1/src/interfaces/libpq/ -lpq&quot;
make install

= Build your Android App =

Finally to build your android app you'll need to add libpq.so. Add this line to your .pro file<br />

ANDROID_EXTRA_LIBS=/path/to/postgresql-9.4.1/src/interfaces/libpq/libpq.so