mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* ext/dbm/extconf.rb (dblib): prefer recent GDBM over older GDBM.
(have_declared_libvar): new function to check a declared variable exists in a library. (have_undeclared_libvar): renamed from renamed from have_libvar. (headers.db_check2): check that GDBM version variable if GDBM header is choosen. * ext/dbm/dbm.c (Init_dbm): use HAVE_DECLARED_LIBVAR_GDBM_VERSION and HAVE_UNDECLARED_LIBVAR_GDBM_VERSION macro. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@34679 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
4c1ea85dd8
commit
fc0111cce1
3 changed files with 80 additions and 32 deletions
12
ChangeLog
12
ChangeLog
|
@ -1,3 +1,15 @@
|
||||||
|
Sat Feb 18 18:43:13 2012 Tanaka Akira <akr@fsij.org>
|
||||||
|
|
||||||
|
* ext/dbm/extconf.rb (dblib): prefer recent GDBM over older GDBM.
|
||||||
|
(have_declared_libvar): new function to check a declared variable
|
||||||
|
exists in a library.
|
||||||
|
(have_undeclared_libvar): renamed from renamed from have_libvar.
|
||||||
|
(headers.db_check2): check that GDBM version variable if GDBM header
|
||||||
|
is choosen.
|
||||||
|
|
||||||
|
* ext/dbm/dbm.c (Init_dbm): use HAVE_DECLARED_LIBVAR_GDBM_VERSION and
|
||||||
|
HAVE_UNDECLARED_LIBVAR_GDBM_VERSION macro.
|
||||||
|
|
||||||
Sat Feb 18 13:53:01 2012 Tanaka Akira <akr@fsij.org>
|
Sat Feb 18 13:53:01 2012 Tanaka Akira <akr@fsij.org>
|
||||||
|
|
||||||
* test/dbm/test_dbm.rb (test_dbmfile_suffix): DBM::VERSION should
|
* test/dbm/test_dbm.rb (test_dbmfile_suffix): DBM::VERSION should
|
||||||
|
|
|
@ -1082,10 +1082,10 @@ Init_dbm(void)
|
||||||
#if defined(HAVE_DB_VERSION)
|
#if defined(HAVE_DB_VERSION)
|
||||||
/* The version of the dbm library, if using Berkeley DB */
|
/* The version of the dbm library, if using Berkeley DB */
|
||||||
rb_define_const(rb_cDBM, "VERSION", rb_str_new2(db_version(NULL, NULL, NULL)));
|
rb_define_const(rb_cDBM, "VERSION", rb_str_new2(db_version(NULL, NULL, NULL)));
|
||||||
#elif defined(HAVE_GDBM_VERSION)
|
#elif defined(HAVE_DECLARED_LIBVAR_GDBM_VERSION)
|
||||||
/* since gdbm 1.9 */
|
/* since gdbm 1.9 */
|
||||||
rb_define_const(rb_cDBM, "VERSION", rb_str_new2(gdbm_version));
|
rb_define_const(rb_cDBM, "VERSION", rb_str_new2(gdbm_version));
|
||||||
#elif defined(HAVE_LIBVAR_GDBM_VERSION)
|
#elif defined(HAVE_UNDECLARED_LIBVAR_GDBM_VERSION)
|
||||||
/* ndbm.h doesn't declare gdbm_version until gdbm 1.8.3.
|
/* ndbm.h doesn't declare gdbm_version until gdbm 1.8.3.
|
||||||
* See extconf.rb for more information. */
|
* See extconf.rb for more information. */
|
||||||
{
|
{
|
||||||
|
|
|
@ -5,7 +5,7 @@ dir_config("dbm")
|
||||||
if dblib = with_config("dbm-type", nil)
|
if dblib = with_config("dbm-type", nil)
|
||||||
dblib = dblib.split(/[ ,]+/)
|
dblib = dblib.split(/[ ,]+/)
|
||||||
else
|
else
|
||||||
dblib = %w(libc db db2 db1 db5 db4 db3 gdbm gdbm_compat qdbm)
|
dblib = %w(libc db db2 db1 db5 db4 db3 gdbm_compat gdbm qdbm)
|
||||||
end
|
end
|
||||||
|
|
||||||
headers = {
|
headers = {
|
||||||
|
@ -16,8 +16,8 @@ headers = {
|
||||||
"db3" => ["db3/db.h", "db3.h", "db.h"],
|
"db3" => ["db3/db.h", "db3.h", "db.h"],
|
||||||
"db4" => ["db4/db.h", "db4.h", "db.h"],
|
"db4" => ["db4/db.h", "db4.h", "db.h"],
|
||||||
"db5" => ["db5/db.h", "db5.h", "db.h"],
|
"db5" => ["db5/db.h", "db5.h", "db.h"],
|
||||||
"gdbm" => ["gdbm-ndbm.h", "ndbm.h", "gdbm/ndbm.h"], # gdbm until 1.8.0
|
|
||||||
"gdbm_compat" => ["gdbm-ndbm.h", "ndbm.h", "gdbm/ndbm.h"], # gdbm since 1.8.1
|
"gdbm_compat" => ["gdbm-ndbm.h", "ndbm.h", "gdbm/ndbm.h"], # gdbm since 1.8.1
|
||||||
|
"gdbm" => ["gdbm-ndbm.h", "ndbm.h", "gdbm/ndbm.h"], # gdbm until 1.8.0
|
||||||
"qdbm" => ["relic.h", "qdbm/relic.h"],
|
"qdbm" => ["relic.h", "qdbm/relic.h"],
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -39,13 +39,35 @@ def headers.db_check(db, hdr)
|
||||||
result
|
result
|
||||||
end
|
end
|
||||||
|
|
||||||
def have_libvar(var, headers = nil, opt = "", &b)
|
def have_declared_libvar(var, headers = nil, opt = "", &b)
|
||||||
checking_for checking_message([*var].compact.join(' '), headers, opt) do
|
checking_for checking_message([*var].compact.join(' '), headers, opt) do
|
||||||
try_libvar(var, headers, opt, &b)
|
try_declared_libvar(var, headers, opt, &b)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def try_libvar(var, headers = nil, opt = "", &b)
|
def try_declared_libvar(var, headers = nil, opt = "", &b)
|
||||||
|
if try_link(<<"SRC", opt, &b)
|
||||||
|
#{cpp_include(headers)}
|
||||||
|
/*top*/
|
||||||
|
int main(int argc, char *argv[]) {
|
||||||
|
void *conftest_var = &#{var};
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
SRC
|
||||||
|
$defs.push(format("-DHAVE_DECLARED_LIBVAR_%s", var.tr_cpp))
|
||||||
|
true
|
||||||
|
else
|
||||||
|
false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def have_undeclared_libvar(var, headers = nil, opt = "", &b)
|
||||||
|
checking_for checking_message([*var].compact.join(' '), headers, opt) do
|
||||||
|
try_undeclared_libvar(var, headers, opt, &b)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def try_undeclared_libvar(var, headers = nil, opt = "", &b)
|
||||||
var, type = *var
|
var, type = *var
|
||||||
if try_link(<<"SRC", opt, &b)
|
if try_link(<<"SRC", opt, &b)
|
||||||
#{cpp_include(headers)}
|
#{cpp_include(headers)}
|
||||||
|
@ -57,7 +79,7 @@ int main(int argc, char *argv[]) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
SRC
|
SRC
|
||||||
$defs.push(format("-DHAVE_LIBVAR_%s", var.tr_cpp))
|
$defs.push(format("-DHAVE_UNDECLARED_LIBVAR_%s", var.tr_cpp))
|
||||||
true
|
true
|
||||||
else
|
else
|
||||||
false
|
false
|
||||||
|
@ -66,6 +88,9 @@ end
|
||||||
|
|
||||||
|
|
||||||
def headers.db_check2(db, hdr)
|
def headers.db_check2(db, hdr)
|
||||||
|
$defs.push(%{-DRUBYDBM_DBM_HEADER='"#{hdr}"'})
|
||||||
|
$defs.push(%{-DRUBYDBM_DBM_TYPE='"#{db}"'})
|
||||||
|
|
||||||
hsearch = nil
|
hsearch = nil
|
||||||
|
|
||||||
case db
|
case db
|
||||||
|
@ -103,47 +128,58 @@ def headers.db_check2(db, hdr)
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Berkeley DB's ndbm.h (since 1.85 at least) includes db.h and
|
||||||
|
# it defines _DB_H_.
|
||||||
|
have_db_header_macro = have_macro('_DB_H_', hdr, hsearch)
|
||||||
|
|
||||||
|
# Recent GDBM's ndbm.h, since 1.9, includes gdbm.h and it defines _GDBM_H_.
|
||||||
|
# ndbm compatibility layer of GDBM is provided by libgdbm (until 1.8.0)
|
||||||
|
# and libgdbm_compat (since 1.8.1).
|
||||||
|
have_gdbm_header_macro = have_macro('_GDBM_H_', hdr, hsearch)
|
||||||
|
|
||||||
|
# 4.3BSD's ndbm.h defines _DBM_IOERR.
|
||||||
|
# The original ndbm is provided by libc in 4.3BSD.
|
||||||
|
have_ndbm_header_macro = have_macro('_DBM_IOERR', hdr, hsearch)
|
||||||
|
|
||||||
# ndbm.h is provided by the original (4.3BSD) dbm,
|
# ndbm.h is provided by the original (4.3BSD) dbm,
|
||||||
# Berkeley DB 1 in libc of 4.4BSD and
|
# Berkeley DB 1 in libc of 4.4BSD and
|
||||||
# ndbm compatibility layer of gdbm.
|
# ndbm compatibility layer of gdbm.
|
||||||
# So, try to check header/library mismatch.
|
# So, try to check header/library mismatch.
|
||||||
#
|
#
|
||||||
# Assumption: There are no insane environment which libc provides ndbm
|
|
||||||
# functions but ndbm.h is not for that.
|
|
||||||
#
|
|
||||||
if hdr == 'ndbm.h' && db != 'libc'
|
if hdr == 'ndbm.h' && db != 'libc'
|
||||||
# Berkeley DB's ndbm.h (since 1.85 at least) includes db.h and
|
if /\Adb\d?\z/ !~ db && have_db_header_macro
|
||||||
# it defines _DB_H_.
|
|
||||||
if /\Adb\d?\z/ !~ db && have_macro('_DB_H_', hdr, hsearch)
|
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
# Recent GDBM's ndbm.h, since 1.9, includes gdbm.h and it defines _GDBM_H_.
|
if /\Agdbm/ !~ db && have_gdbm_header_macro
|
||||||
# ndbm compatibility layer of GDBM is provided by libgdbm (until 1.8.0)
|
|
||||||
# and libgdbm_compat (since 1.8.1).
|
|
||||||
if /\Agdbm/ !~ db && have_macro('_GDBM_H_', hdr, hsearch)
|
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
# 4.3BSD's ndbm.h defines _DBM_IOERR.
|
if have_ndbm_header_macro
|
||||||
# The original ndbm is provided by libc in 4.3BSD.
|
|
||||||
if have_macro('_DBM_IOERR', hdr, hsearch)
|
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
case db
|
# Berkeley DB
|
||||||
when /\Adb\d?\z/
|
|
||||||
have_func('db_version((int *)0, (int *)0, (int *)0)', hdr, hsearch)
|
have_func('db_version((int *)0, (int *)0, (int *)0)', hdr, hsearch)
|
||||||
when /\Agdbm/
|
|
||||||
have_var("gdbm_version", hdr, hsearch)
|
# GDBM
|
||||||
# gdbm_version is not declared by ndbm.h until gdbm 1.8.3.
|
have_gdbm_variable = have_declared_libvar("gdbm_version", hdr, hsearch)
|
||||||
# We can't include ndbm.h and gdbm.h because they both define datum type.
|
# gdbm_version is available since very old version (gdbm 1.5 at least).
|
||||||
|
# However it is not declared by ndbm.h until gdbm 1.8.3.
|
||||||
|
# We can't include both ndbm.h and gdbm.h because they both define datum type.
|
||||||
# ndbm.h includes gdbm.h and gdbm_version is declared since gdbm 1.9.
|
# ndbm.h includes gdbm.h and gdbm_version is declared since gdbm 1.9.
|
||||||
have_libvar(["gdbm_version", "char *"], hdr, hsearch)
|
have_gdbm_variable |= have_undeclared_libvar(["gdbm_version", "char *"], hdr, hsearch)
|
||||||
when /\Aqdbm\z/
|
|
||||||
|
# QDBM
|
||||||
have_var("dpversion", hdr, hsearch)
|
have_var("dpversion", hdr, hsearch)
|
||||||
|
|
||||||
|
# detect mismatch between GDBM header and other library.
|
||||||
|
# If GDBM header is included, GDBM library should be linked.
|
||||||
|
if have_gdbm_header_macro && !have_gdbm_variable
|
||||||
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
if hsearch
|
if hsearch
|
||||||
$defs << hsearch
|
$defs << hsearch
|
||||||
@defs = hsearch
|
@defs = hsearch
|
||||||
|
|
Loading…
Reference in a new issue