SUMMARY = "PostgreSQL is a powerful, open source relational database system." DESCRIPTION = "\ PostgreSQL is an advanced Object-Relational database management system \ (DBMS) that supports almost all SQL constructs (including \ transactions, subselects and user-defined types and functions). The \ postgresql package includes the client programs and libraries that \ you'll need to access a PostgreSQL DBMS server. These PostgreSQL \ client programs are programs that directly manipulate the internal \ structure of PostgreSQL databases on a PostgreSQL server. These client \ programs can be located on the same machine with the PostgreSQL \ server, or may be on a remote machine which accesses a PostgreSQL \ server over a network connection. This package contains the docs \ in HTML for the whole package, as well as command-line utilities for \ managing PostgreSQL databases on a PostgreSQL server. \ \ If you want to manipulate a PostgreSQL database on a local or remote \ PostgreSQL server, you need this package. You also need to install \ this package if you're installing the postgresql-server package. \ " HOMEPAGE = "http://www.postgresql.com" LICENSE = "BSD" DEPENDS = "zlib readline tzcode-native" INC_PR = "r0" ARM_INSTRUCTION_SET = "arm" SRC_URI = "http://ftp.postgresql.org/pub/source/v${PV}/${P}.tar.bz2 \ file://postgresql.init \ file://postgresql-bashprofile \ file://postgresql.pam \ " LEAD_SONAME = "libpq.so" # LDFLAGS for shared libraries export LDFLAGS_SL = "${LDFLAGS}" inherit autotools pkgconfig perlnative pythonnative useradd update-rc.d enable_pam = "${@base_contains('DISTRO_FEATURES', 'pam', 'pam', '', d)}" PACKAGECONFIG ??= "${enable_pam} openssl python uuid libxml tcl nls libxml perl" PACKAGECONFIG[pam] = "--with-pam,--without-pam,libpam," PACKAGECONFIG[openssl] = "--with-openssl,--without-openssl,openssl," PACKAGECONFIG[python] = "--with-python,--wsithout-python,python,python" PACKAGECONFIG[uuid] = "--with-ossp-uuid,--without-ossp-uuid,ossp-uuid," # when tcl native package is fixed change WORKDIR to STAGING_BINDIR_CROSS PACKAGECONFIG[tcl] = \ "--with-tcl --with-tclconfig=${STAGING_BINDIR_CROSS},--without-tcl,tcl," PACKAGECONFIG[nls] = "--enable-nls,--disable-nls,," PACKAGECONFIG[libxml] = "--with-libxml,--without-libxml,libxml2,libxml2" PACKAGECONFIG[perl] = "--with-perl,--without-perl,perl,perl" EXTRA_OECONF += "--enable-thread-safety --disable-rpath \ --datadir=${datadir}/${BPN} \ --sysconfdir=${sysconfdir}/${BPN} \ --without-krb5 \ " EXTRA_OECONF_sh4 += "--disable-spinlocks" EXTRA_OECONF_aarch64 += "--disable-spinlocks" PACKAGES_DYNAMIC += "^${PN}-plperl ^${PN}-plperl-dbg \ ^${PN}-pltcl ^${PN}-pltcl-dbg \ ^${PN}-plpython ^${PN}-plpython-dbg \ " python populate_packages_prepend() { def fill_more(name, dbg=True): if name is None or name.strip() == "": return fpack=d.getVar('PACKAGES') or "" fpack="${PN}-" + name + " " + fpack if dbg: fpack="${PN}-" + name + "-dbg" + " " + fpack d.setVar('PACKAGES', fpack) conf=(d.getVar('PACKAGECONFIG', True) or "").split() pack=d.getVar('PACKAGES') or "" bb.debug(1, "PACKAGECONFIG=%s" % conf) bb.debug(1, "PACKAGES1=%s" % pack ) if "perl" in conf : fill_more("plperl") if "tcl" in conf: fill_more("pltcl") if "python" in conf: fill_more("plpython") pack=d.getVar('PACKAGES', True) or "" bb.debug(1, "PACKAGES2=%s" % pack) } do_configure() { # do_configure_prepend # make sure configure finds python includdirs with these envs export BUILD_SYS=${BUILD_SYS} HOST_SYS=${HOST_SYS} \ STAGING_INCDIR=${STAGING_INCDIR} \ STAGING_LIBDIR=${STAGING_LIBDIR} # do_configure autotools_do_configure # do_configure_append # workaround perl package related bugs sed -i -e "s:-L/usr/local/lib:-L=/usr/local/lib:g" \ ${B}/src/Makefile.global LIBPNA="\${STAGING_LIBDIR_NATIVE}/perl-native" LIBNA="\${STAGING_LIBDIR_NATIVE}" BLIBNA="\${STAGING_BASE_LIBDIR_NATIVE}" sed -i -e "/^perl_archlibexp/s:${LIBPNA}:${STAGING_LIBDIR}:g" \ ${B}/src/Makefile.global sed -i -e "/^perl_privlibexp/s:${LIBPNA}:${STAGING_LIBDIR}:g" \ ${B}/src/Makefile.global # remove the rpath, replace with correct lib path sed -i \ -e "/^perl_embed_ldflags/s:-Wl,-rpath,${LIBNA}::g" \ -e "/^perl_embed_ldflags/s:-Wl,-rpath,${BLIBNA}::g" \ -e "/^perl_embed_ldflags/s:-Wl,-rpath-link,${LIBNA}::g" \ -e "/^perl_embed_ldflags/s:-Wl,-rpath-link,${BLIBNA}::g" \ -e "/^perl_embed_ldflags/s:${LIBPNA}:${STAGING_LIBDIR}:g" \ -e "/^perl_embed_ldflags/s:${LIBNA}:${STAGING_LIBDIR}:g" \ -e "/^perl_embed_ldflags/s:${BLIBNA}:${STAGING_BASELIBDIR}:g" \ ${B}/src/Makefile.global # workaround perl package's libperl.so problem # we are using perlnative so this perl should have same version perl_version=`perl -v 2>/dev/null | \ sed -n 's/This is perl.*v[a-z ]*\([0-9]\.[0-9][0-9.]*\).*$/\1/p'` if [ ! -h "${STAGING_LIBDIR}/perl/$perl_version/CORE/libperl.so" -a \ ! -h "${STAGING_LIBDIR}/libperl.so" ]; then ln -sf ../../../libperl.so.5 \ ${STAGING_LIBDIR}/perl/$perl_version/CORE/libperl.so fi } do_compile_append() { oe_runmake -C contrib all } # server needs to configure user and group usernum = "28" groupnum = "28" USERADD_PACKAGES = "${PN}" USERADD_PARAM_${PN} = "-M -g postgres -o -r -d ${localstatedir}/lib/${BPN} \ -s /bin/bash -c 'PostgreSQL Server' -u ${usernum} postgres" GROUPADD_PARAM_${PN} = "-g ${groupnum} -o -r postgres" INITSCRIPT_PACKAGES = "${PN}" INITSCRIPT_NAME = "${BPN}-server" INITSCRIPT_PARAMS = "start 64 . stop 36 0 1 2 3 4 5 6 ." do_install_append() { # install contrib oe_runmake DESTDIR=${D} -C contrib install # install tutorial install -d -m 0755 ${D}${libdir}/${BPN}/tutorial install ${B}/src/tutorial/* ${D}${libdir}/${BPN}/tutorial # install COPYRIGHT README HISTORY install -d -m 0755 ${D}${docdir}/${BPN} for i in ${B}/{COPYRIGHT,README,HISTORY} ${B}/doc/{KNOWN_BUGS,MISSING_FEATURES,README*,bug.template}; do [ -f $i ] && install $i ${D}${docdir}/${BPN} done # install dirs and server init install -d ${D}${sysconfdir}/init.d install -m 0755 ${WORKDIR}/${BPN}.init ${D}${sysconfdir}/init.d/${BPN}-server sed -i -e "s/^PGVERSION=.*$/PGVERSION=${PV}/g" ${D}${sysconfdir}/init.d/${BPN}-server install -d -m 700 ${D}${localstatedir}/lib/${BPN}/data install -d -m 700 ${D}${localstatedir}/lib/${BPN}/backups install -m 644 ${WORKDIR}/${BPN}-bashprofile ${D}${localstatedir}/lib/${BPN}/.bash_profile chown -R postgres:postgres ${D}${localstatedir}/lib/${BPN} # multiple server config directory install -d -m 700 ${D}${sysconfdir}/default/${BPN} if [ "${@d.getVar('enable_pam', True)}" = "pam" ]; then install -d ${D}${sysconfdir}/pam.d install -m 644 ${WORKDIR}/postgresql.pam ${D}${sysconfdir}/pam.d/postgresql fi } SSTATE_SCAN_FILES += "Makefile.global" PACKAGES =+ "${PN}-client ${PN}-server-dev ${PN}-timezone \ libecpg-compat-dbg libecpg-compat libecpg-compat-dev \ libecpg-dbg libecpg libecpg-dev libecpg-staticdev libecpg-doc \ libpq-dbg libpq libpq-dev libpq-staticdev \ libpgtypes-dbg libpgtypes libpgtypes-staticdev libpgtypes-dev \ ${PN}-contrib ${PN}-contrib-dbg \ " FILES_${PN} += "${sysconfdir}/init.d/${BPN}-server \ ${localstatedir}/lib/${BPN}/data ${localstatedir}/lib/${BPN}/backups \ ${localstatedir}/lib/${BPN}/.bash_profile ${sysconfdir}/default/${BPN} \ ${libdir}/${BPN}/dict_snowball.so ${libdir}/${BPN}/plpgsql.so \ ${libdir}/${BPN}/euc2004_sjis2004.so \ ${libdir}/${BPN}/libpqwalreceiver.so \ ${libdir}/${BPN}/*_and_*.so \ ${@'${sysconfdir}/pam.d/postgresql' \ if 'pam' == d.getVar('enable_pam', True) \ else ''} \ " FILES_${PN}-dbg += " ${libdir}/${BPN}/.debug/dict_snowball.so \ ${libdir}/${BPN}/.debug/plpgsql.so \ ${libdir}/${BPN}/.debug/euc2004_sjis2004.so \ ${libdir}/${BPN}/.debug/libpqwalreceiver.so \ ${libdir}/${BPN}/.debug/*_and_*.so \ " FILES_${PN}-client = "${bindir}/clusterdb \ ${bindir}/createdb \ ${bindir}/createlang \ ${bindir}/createuser \ ${bindir}/dropdb \ ${bindir}/droplang \ ${bindir}/dropuser \ ${bindir}/pg_dump \ ${bindir}/pg_dumpall \ ${bindir}/pg_restore \ ${bindir}/psql \ ${bindir}/reindexdb \ ${bindir}/vacuumdb \ ${bindir}/vacuumlo \ ${datadir}/${BPN}/psqlrc.sample" FILES_${PN}-client-doc = "${mandir}/man1/clusterdb.* \ ${mandir}/man1/createdb.* ${mandir}/man1/createlang.* \ ${mandir}/man1/createuser.* ${mandir}/man1/dropdb.* \ ${mandir}/man1/droplang.* ${mandir}/man1/dropuser.* \ ${mandir}/man1/pg_dump.* ${mandir}/man1/pg_dumpall.* \ ${mandir}/man1/pg_restore.* ${mandir}/man1/psql.* \ ${mandir}/man1/reindexdb.* ${mandir}/man1/vacuumdb.* \ ${mandir}/man7/* \ " FILES_${PN}-doc += "${docdir}/${BPN}/html ${libdir}/${BPN}/tutorial/ \ ${mandir}/man1/initdb.* ${mandir}/man1/pg_controldata.* \ ${mandir}/man1/pg_ctl.* ${mandir}/man1/pg_resetxlog.* \ ${mandir}/man1/postgres.* ${mandir}/man1/postmaster.* \ " FILES_${PN}-timezone = "${datadir}/${BPN}/timezone \ ${datadir}/${BPN}/timezonesets \ " RDEPENDS_${PN} += "${PN}-timezone" FILES_${PN}-server-dev = "${includedir}/${BPN}/server" FILES_libecpg = "${libdir}/libecpg*${SOLIBS}" FILES_libecpg-dbg = "${libdir}/.debug/libecpg*" FILES_libecpg-dev = "${libdir}/libecpg*${SOLIBSDEV} \ ${libdir}/libpgtypes*${SOLIBSDEV} \ ${includedir}/ecpg*.h ${includedir}/${BPN}/ecpg*.h \ ${includedir}/pgtypes*.h ${includedir}/${BPN}/informix \ ${includedir}/sql3types.h ${includedir}/sqlca.h" FILES_libecpg-doc = "${mandir}/man1/ecpg.*" FILES_libecpg-staticdev = "${libdir}/libecpg*.a" SECTION_libecpg-staticdev = "devel" RDEPENDS_libecpg-staticdev = "libecpg-dev (= ${EXTENDPKGV})" FILES_libpq = "${libdir}/libpq*${SOLIBS}" FILES_libpq-dbg = "${libdir}/.debug/libpq* ${libdir}/${BPN}/pgxs/src/test/regress/.debug/*" FILES_libpq-dev = "${libdir}/libpq*${SOLIBSDEV} \ ${includedir}" FILES_libpq-staticdev = "${libdir}/libpq*.a ${libdir}/libpgport.a" SECTION_libpq-staticdev = "devel" RDEPENDS_libpq-staticdev = "libpq-dev (= ${EXTENDPKGV})" FILES_libecpg-compat = "${libdir}/libecpg_compat*${SOLIBS}" FILES_libecpg-compat-dbg = "${libdir}/.debug/libecpg_compat*" FILES_libecpg-compat-dev = "${libdir}/libecpg_compat*${SOLIBS}" FILES_libpgtypes = "${libdir}/libpgtypes*${SOLIBS}" FILES_libpgtypes-dbg = "${libdir}/.debug/libpgtypes*" FILES_libpgtypes-staticdev = "${libdir}/libpgtypes*.a" FILES_libpgtypes-dev = "${libdir}/libpgtypes*${SOLIBS} ${includedir}/pgtypes*.h" FILES_${PN}-contrib = " ${bindir}/oid2name ${bindir}/pg_standby \ ${bindir}/pgbench ${bindir}/vacuumlo \ ${S}/contrib/spi/*.example \ ${libdir}/${BPN}/_int.so ${libdir}/${BPN}/adminpack.so \ ${libdir}/${BPN}/autoinc.so ${libdir}/${BPN}/auto_explain.so \ ${libdir}/${BPN}/auth_delay.so ${libdir}/${BPN}/btree_gin.so \ ${libdir}/${BPN}/btree_gist.so ${libdir}/${BPN}/.so \ ${libdir}/${BPN}/chkpass.so ${libdir}/${BPN}/citext.so \ ${libdir}/${BPN}/cube.so ${libdir}/${BPN}/dblink.so \ ${libdir}/${BPN}/dict_int.so ${libdir}/${BPN}/dict_xsyn.so \ ${libdir}/${BPN}/dummy_seclabel.so ${libdir}/${BPN}/earthdistance.so \ ${libdir}/${BPN}/file_fdw.so ${libdir}/${BPN}/fuzzystrmatch.so \ ${libdir}/${BPN}/hstore.so ${libdir}/${BPN}/insert_username.so \ ${libdir}/${BPN}/isn.so ${libdir}/${BPN}/lo.so \ ${libdir}/${BPN}/ltree.so ${libdir}/${BPN}/moddatetime.so \ ${libdir}/${BPN}/pageinspect.so ${libdir}/${BPN}/pg_buffercache.so \ ${libdir}/${BPN}/pg_freespacemap.so ${libdir}/${BPN}/pg_trgm.so \ ${libdir}/${BPN}/pgcrypto.so ${libdir}/${BPN}/pgrowlocks.so \ ${libdir}/${BPN}/pgstattuple.so ${libdir}/${BPN}/pg_stat_statements.so \ ${libdir}/${BPN}/refint.so ${libdir}/${BPN}/seg.so \ ${libdir}/${BPN}/sslinfo.so \ ${libdir}/${BPN}/tablefunc.so \ ${libdir}/${BPN}/test_parser.so ${libdir}/${BPN}/timetravel.so \ ${libdir}/${BPN}/tsearch2.so ${libdir}/${BPN}/uuid-ossp.so \ ${libdir}/${BPN}/pgxml.so ${libdir}/${BPN}/passwordcheck.so \ ${libdir}/${BPN}/pg_upgrade_support.so ${libdir}/${BPN}/.so \ ${libdir}/${BPN}/unaccent.so \ " FILES_${PN}-contrib-dbg = " \ ${libdir}/${BPN}/.debug/_int.so ${libdir}/${BPN}/.debug/adminpack.so \ ${libdir}/${BPN}/.debug/autoinc.so ${libdir}/${BPN}/.debug/auto_explain.so \ ${libdir}/${BPN}/.debug/auth_delay.so ${libdir}/${BPN}/.debug/btree_gin.so \ ${libdir}/${BPN}/.debug/btree_gist.so ${libdir}/${BPN}/.debug/.so \ ${libdir}/${BPN}/.debug/chkpass.so ${libdir}/${BPN}/.debug/citext.so \ ${libdir}/${BPN}/.debug/cube.so ${libdir}/${BPN}/.debug/dblink.so \ ${libdir}/${BPN}/.debug/dict_int.so ${libdir}/${BPN}/.debug/dict_xsyn.so \ ${libdir}/${BPN}/.debug/dummy_seclabel.so \ ${libdir}/${BPN}/.debug/earthdistance.so \ ${libdir}/${BPN}/.debug/file_fdw.so ${libdir}/${BPN}/.debug/fuzzystrmatch.so \ ${libdir}/${BPN}/.debug/hstore.so ${libdir}/${BPN}/.debug/insert_username.so \ ${libdir}/${BPN}/.debug/isn.so ${libdir}/${BPN}/.debug/lo.so \ ${libdir}/${BPN}/.debug/ltree.so ${libdir}/${BPN}/.debug/moddatetime.so \ ${libdir}/${BPN}/.debug/pageinspect.so \ ${libdir}/${BPN}/.debug/pg_buffercache.so \ ${libdir}/${BPN}/.debug/pg_freespacemap.so \ ${libdir}/${BPN}/.debug/pg_trgm.so \ ${libdir}/${BPN}/.debug/pgcrypto.so ${libdir}/${BPN}/.debug/pgrowlocks.so \ ${libdir}/${BPN}/.debug/pgstattuple.so \ ${libdir}/${BPN}/.debug/pg_stat_statements.so \ ${libdir}/${BPN}/.debug/refint.so ${libdir}/${BPN}/.debug/seg.so \ ${libdir}/${BPN}/.debug/sslinfo.so \ ${libdir}/${BPN}/.debug/tablefunc.so \ ${libdir}/${BPN}/.debug/test_parser.so ${libdir}/${BPN}/.debug/timetravel.so \ ${libdir}/${BPN}/.debug/tsearch2.so ${libdir}/${BPN}/.debug/uuid-ossp.so \ ${libdir}/${BPN}/.debug/pgxml.so ${libdir}/${BPN}/.debug/passwordcheck.so \ ${libdir}/${BPN}/.debug/pg_upgrade_support.so \ ${libdir}/${BPN}/.debug/unaccent.so \ " DESCRIPTION_${PN}-contrib = "The postgresql-contrib package contains \ contributed packages that are included in the PostgreSQL distribution." FILES_${PN}-pltcl = "${libdir}/${BPN}/pltcl.so ${bindir}/pltcl_delmod \ ${binddir}/pltcl_listmod ${bindir}/pltcl_loadmod \ ${datadir}/${BPN}/unknown.pltcl" FILES_${PN}-pltcl-dbg = "${libdir}/${BPN}/.debug/pltcl.so" SUMMARY_${PN}-pltcl = "The Tcl procedural language for PostgreSQL" DESCRIPTION_${PN}-pltcl = "PostgreSQL is an advanced Object-Relational \ database management system. The postgresql-pltcl package contains the PL/Tcl \ procedural language for the backend." FILES_${PN}-plperl = "${libdir}/${BPN}/plperl.so" FILES_${PN}-plperl-dbg = "${libdir}/${BPN}/.debug/plperl.so" SUMMARY_${PN}-plperl = "The Perl procedural language for PostgreSQL" DESCRIPTION_${PN}-plperl = "PostgreSQL is an advanced Object-Relational \ database management system. The postgresql-plperl package contains the \ PL/Perl procedural language for the backend." # In version 8, it will be plpython.so # In version 9, it might be plpython{2,3}.so depending on python2 or 3 FILES_${PN}-plpython = "${libdir}/${BPN}/plpython*.so" FILES_${PN}-plpython-dbg = "${libdir}/${BPN}/.debug/plpython*.so" SUMMARY_${PN}-plpython = "The Python procedural language for PostgreSQL" DESCRIPTION_${PN}-plpython = "PostgreSQL is an advanced Object-Relational \ database management system. The postgresql-plpython package contains \ the PL/Python procedural language for the backend."