# Copyright 1999-2020 Gentoo Authors # Distributed under the terms of the GNU General Public License v2 EAPI="7" inherit eutils pax-utils multilib-minimal DESCRIPTION="Oracle 18c Instant Client with SDK" HOMEPAGE="https://www.oracle.com/technetwork/database/database-technologies/instant-client/overview/index.html" MY_SOVER=19.1 # the library soname found in the zip files IUSE="jdbc odbc precomp +sdk +sqlplus tools" REQUIRED_USE="precomp? ( sdk )" MY_PVM=$(ver_cut 1-2) MY_P="instantclient_$(ver_rs 1 _ ${MY_PVM})" MY_PV=$(ver_cut 1-4) MY_PVP=$(ver_cut 5) # p2 MY_PLAT_x86="Linux x86" MY_BITS_x86=32 MY_A_x86="${PN/oracle-/}-basic-linux-${MY_PV}.0dbru.zip" MY_A_x86_jdbc="${MY_A_x86/basic/jdbc}" MY_A_x86_odbc="${MY_A_x86/basic/odbc}" MY_A_x86_precomp="${MY_A_x86/basic/precomp}" MY_A_x86_sdk="${MY_A_x86/basic/sdk}" MY_A_x86_sqlplus="${MY_A_x86/basic/sqlplus}" MY_A_x86_tools="${MY_A_x86/basic/tools}" MY_PLAT_amd64="Linux x86-64" MY_BITS_amd64=64 MY_A_amd64="${PN/oracle-}-basic-linux.x64-${MY_PV}.0dbru.zip" MY_A_amd64_jdbc="${MY_A_amd64/basic/jdbc}" MY_A_amd64_odbc="${MY_A_amd64/basic/odbc}" MY_A_amd64_precomp="${MY_A_amd64/basic/precomp}" MY_A_amd64_sdk="${MY_A_amd64/basic/sdk}" MY_A_amd64_sqlplus="${MY_A_amd64/basic/sqlplus}" MY_A_amd64_tools="${MY_A_amd64/basic/tools}" if [[ ${MY_PVP} == p* ]] then MY_PVP=-${MY_PVP#p} # Updated 9/22/2017: instantclient-odbc-linux-12.2.0.1.0-2.zip MY_A_x86_odbc="${MY_A_x86_odbc%.zip}${MY_PVP}.zip" MY_A_amd64_odbc="${MY_A_amd64_odbc%.zip}${MY_PVP}.zip" fi SRC_URI=" abi_x86_32? ( ${MY_A_x86} jdbc? ( ${MY_A_x86_jdbc} ) odbc? ( ${MY_A_x86_odbc} ) precomp? ( ${MY_A_x86_precomp} ) !abi_x86_64? ( sdk? ( ${MY_A_x86_sdk} ) sqlplus? ( ${MY_A_x86_sqlplus} ) tools? ( ${MY_A_x86_tools} ) ) ) abi_x86_64? ( ${MY_A_amd64} jdbc? ( ${MY_A_amd64_jdbc} ) odbc? ( ${MY_A_amd64_odbc} ) precomp? ( ${MY_A_amd64_precomp} ) sdk? ( ${MY_A_amd64_sdk} ) sqlplus? ( ${MY_A_amd64_sqlplus} ) tools? ( ${MY_A_amd64_tools} ) ) " LICENSE="OTN" SLOT="0/${MY_SOVER}" KEYWORDS="~amd64 ~x86" RESTRICT="fetch splitdebug" DEPEND="app-arch/unzip" RDEPEND=" >=dev-libs/libaio-0.3.109-r5[${MULTILIB_USEDEP}] !/client/include, # querying 'sqlplus' for the version number, also see bug#652096. dosym ../../../.."${oracle_home}"/sdk/include /usr/include/oracle/${MY_PVM}/client eend $? fi if use sqlplus; then DOCS+=( SQLPLUS_README ) paxbins+=( sqlplus ) insinto "${oracle_home}"/sqlplus/admin doins glogin.sql dosym ../.."${oracle_home}"/bin/sqlplus /usr/bin/sqlplus fi if use tools; then DOCS+=( TOOLS_README ) paxbins+=( exp expdp imp impdp sqlldr wrc ) fi einfo "Installing binaries for ${MY_PLAT} ..." into "${oracle_home}" dobin ${paxbins[*]} ${scripts[*]} pushd "${ED}${oracle_home}/bin" >/dev/null || die pax-mark -c ${paxbins[*]#*/} || die popd >/dev/null || die eend $? einstalldocs # create path for tnsnames.ora insinto /etc/oracle doins "${FILESDIR}"/tnsnames.ora.sample # Add OCI libs to library path { echo "# ${EPREFIX}/etc/env.d/50${PN}" echo "# Do not edit this file, but 99${PN} instead" echo echo "ORACLE_HOME=${EPREFIX}${oracle_home}" echo "LDPATH=${ldpath}" echo "TNS_ADMIN=${EPREFIX}/etc/oracle/" } > "${T}"/50${PN} doenvd "${T}"/50${PN} # ensure ORACLE_HOME/lib exists [[ -e ${ED}${oracle_home}/lib/. ]] || dosym $(get_libdir) "${oracle_home#/}"/lib } pkg_preinst() { if [[ -r ${EROOT}/etc/env.d/99${PN} ]]; then cp "${EROOT}/etc/env.d/99${PN}" "${ED}/etc/env.d/" || die else { echo "# ${EPREFIX}/etc/env.d/99${PN}" echo "# Configure system-wide defaults for your Oracle Instant Client here" echo echo "#$(grep '^ORACLE_HOME=' "${ED}/etc/env.d/50${PN}")" echo "#$(grep '^TNS_ADMIN=' "${ED}/etc/env.d/50${PN}")" echo "#NLS_LANG=" } > "${ED}/etc/env.d/99${PN}" fi } pkg_postinst() { elog "${P} does not provide an sqlnet.ora" elog "configuration file, redirecting oracle diagnostics for database-" elog "and network-issues into ~USER/oradiag_USER/ instead." elog "It should be safe to ignore this message in sqlnet.log there:" elog " Directory does not exist for read/write [ORACLE_HOME/client/log] []" elog "See https://bugs.gentoo.org/show_bug.cgi?id=465252 for reference." elog "If you want to directly analyse low-level debug info or don't want" elog "to see it at all, so you really need an sqlnet.ora file, please" elog "consult http://search.oracle.com/search/search?q=sqlnet.ora" elog "" elog "TNS_ADMIN has been set to ${EPREFIX}/etc/oracle by default," elog "put your tnsnames.ora there or configure TNS_ADMIN" elog "to point to your user specific configuration." if use precomp; then elog "" elog "The proc precompiler uses the system library headers, which in" elog "turn include the headers of the used compiler." elog "To make proc work, please add the compiler header path of your" elog "preferred compiler to sys_include in:" elog " ${EPREFIX}/etc/oracle/pcscfg.cfg" elog "Remember to update this setting when you switch or update the" elog "compiler." elog "For gcc, the headers are usually found in a path matching the" elog "following pattern:" elog " ${EPREFIX}/usr/lib/gcc/*/*/include" elog "The exact details depend on the architecture and the version of" elog "the compiler to be used." fi ewarn "Please re-source your shell settings for ORACLE_HOME" ewarn " changes, such as: source ${EPREFIX}/etc/profile" }