Add database support to apr-util package (#4932)
This commit is contained in:
parent
d087eeacbd
commit
5ac10b90c5
@ -25,23 +25,93 @@
|
|||||||
from spack import *
|
from spack import *
|
||||||
|
|
||||||
|
|
||||||
class AprUtil(Package):
|
class AprUtil(AutotoolsPackage):
|
||||||
"""Apache Portable Runtime Utility"""
|
"""Apache Portable Runtime Utility"""
|
||||||
homepage = 'https://apr.apache.org/'
|
|
||||||
url = 'http://archive.apache.org/dist/apr/apr-util-1.5.4.tar.gz'
|
|
||||||
|
|
||||||
|
homepage = 'https://apr.apache.org/'
|
||||||
|
url = 'http://archive.apache.org/dist/apr/apr-util-1.6.0.tar.gz'
|
||||||
|
|
||||||
|
version('1.6.0', '3b03dbff60728a4f4c33f5d929e8b35a')
|
||||||
version('1.5.4', '866825c04da827c6e5f53daff5569f42')
|
version('1.5.4', '866825c04da827c6e5f53daff5569f42')
|
||||||
|
|
||||||
|
variant('crypto', default=True, description='Enable crypto support')
|
||||||
|
variant('gdbm', default=False, description='Enable GDBM support')
|
||||||
|
variant('pgsql', default=False, description='Enable PostgreSQL support')
|
||||||
|
variant('sqlite', default=False, description='Enable sqlite DBD driver')
|
||||||
|
variant('odbc', default=False, description='Enalbe ODBC support')
|
||||||
|
|
||||||
depends_on('apr')
|
depends_on('apr')
|
||||||
depends_on('expat')
|
depends_on('expat')
|
||||||
|
depends_on('libiconv')
|
||||||
|
|
||||||
def install(self, spec, prefix):
|
depends_on('openssl', when='+crypto')
|
||||||
|
depends_on('gdbm', when='+gdbm')
|
||||||
|
depends_on('postgresql', when='+pgsql')
|
||||||
|
depends_on('sqlite', when='+sqlite')
|
||||||
|
depends_on('unixodbc', when='+odbc')
|
||||||
|
|
||||||
# configure, build, install:
|
def configure_args(self):
|
||||||
options = ['--prefix=%s' % prefix]
|
spec = self.spec
|
||||||
options.append('--with-apr=%s' % spec['apr'].prefix)
|
|
||||||
options.append('--with-expat=%s' % spec['expat'].prefix)
|
|
||||||
|
|
||||||
configure(*options)
|
args = [
|
||||||
make()
|
'--with-apr={0}'.format(spec['apr'].prefix),
|
||||||
make('install')
|
'--with-expat={0}'.format(spec['expat'].prefix),
|
||||||
|
'--with-iconv={0}'.format(spec['libiconv'].prefix),
|
||||||
|
# TODO: Add support for the following database managers
|
||||||
|
'--without-ndbm',
|
||||||
|
'--without-berkeley-db',
|
||||||
|
'--without-mysql',
|
||||||
|
'--without-oracle',
|
||||||
|
]
|
||||||
|
|
||||||
|
if '+crypto' in spec:
|
||||||
|
args.extend([
|
||||||
|
'--with-crypto',
|
||||||
|
'--with-openssl={0}'.format(spec['openssl'].prefix),
|
||||||
|
])
|
||||||
|
else:
|
||||||
|
args.append('--without-crypto')
|
||||||
|
|
||||||
|
if '+gdbm' in spec:
|
||||||
|
args.append('--with-gdbm={0}'.format(spec['gdbm'].prefix))
|
||||||
|
else:
|
||||||
|
args.append('--without-gdbm')
|
||||||
|
|
||||||
|
if '+pgsql' in spec:
|
||||||
|
args.append('--with-pgsql={0}'.format(spec['postgresql'].prefix))
|
||||||
|
else:
|
||||||
|
args.append('--without-pgsql')
|
||||||
|
|
||||||
|
if '+sqlite' in spec:
|
||||||
|
if spec.satisfies('^sqlite@3.0:3.999'):
|
||||||
|
args.extend([
|
||||||
|
'--with-sqlite3={0}'.format(spec['sqlite'].prefix),
|
||||||
|
'--without-sqlite2',
|
||||||
|
])
|
||||||
|
elif spec.satisfies('^sqlite@2.0:2.999'):
|
||||||
|
args.extend([
|
||||||
|
'--with-sqlite2={0}'.format(spec['sqlite'].prefix),
|
||||||
|
'--without-sqlite3',
|
||||||
|
])
|
||||||
|
else:
|
||||||
|
args.extend([
|
||||||
|
'--without-sqlite2',
|
||||||
|
'--without-sqlite3',
|
||||||
|
])
|
||||||
|
|
||||||
|
if '+odbc' in spec:
|
||||||
|
args.append('--with-odbc={0}'.format(spec['unixodbc'].prefix))
|
||||||
|
else:
|
||||||
|
args.append('--without-odbc')
|
||||||
|
|
||||||
|
return args
|
||||||
|
|
||||||
|
def check(self):
|
||||||
|
# FIXME: Database driver tests fail, at least on macOS:
|
||||||
|
#
|
||||||
|
# Failed to load driver file apr_dbd_pgsql.so
|
||||||
|
# Failed to load driver file apr_dbd_sqlite3.so
|
||||||
|
# Failed to load driver file apr_dbd_odbc.so
|
||||||
|
|
||||||
|
# Tests occassionally fail when run in parallel
|
||||||
|
make('check', parallel=False)
|
||||||
|
Loading…
Reference in New Issue
Block a user