diff --git a/ChangeLog b/ChangeLog index f622cca6da..3cfa419cbd 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,10 @@ +Thu Mar 24 23:10:44 2005 Nobuyoshi Nakada + + * lib/mkmf.rb (macro_defined?): try to compile for an old compiler + which doesn't bail out at #error directive. [ruby-dev:25818] + + * lib/mkmf.rb (check_sizeof): refine logging messages. + Wed Mar 23 19:08:10 2005 GOTOU Yuuzou * lib/webrick/utils.rb (WEBrick::Utils.create_listeners): diff --git a/lib/mkmf.rb b/lib/mkmf.rb index 3266abace1..82a10535a2 100644 --- a/lib/mkmf.rb +++ b/lib/mkmf.rb @@ -458,10 +458,11 @@ end def macro_defined?(macro, src, opt = "", &b) src = src.sub(/[^\n]\z/, "\\&\n") - try_cpp(src + <<"SRC", opt, &b) + try_compile(src + <<"SRC", opt, &b) /*top*/ #ifndef #{macro} # error +>>>>>> #{macro} undefined <<<<<< #endif SRC end @@ -688,12 +689,18 @@ def check_sizeof(type, header = nil, &b) expr = "sizeof(#{type})" m = "checking size of #{type}... " message "%s", m - Logging::message "check_sizeof: %s--------------------\n", m - if size = try_constant(expr, header, &b) - $defs.push(format("-DSIZEOF_%s=%d", type.upcase.tr_s("^A-Z0-9_", "_"), size)) + a = size = nil + Logging::postpone do + if size = try_constant(expr, header, &b) + $defs.push(format("-DSIZEOF_%s=%d", type.upcase.tr_s("^A-Z0-9_", "_"), size)) + a = "#{size}\n" + else + a = "failed\n" + end + "check_sizeof: #{m}-------------------- #{a}\n" end - message(a = size ? "#{size}\n" : "failed\n") - Logging::message "-------------------- %s\n", a + message(a) + Logging::message "--------------------\n\n" size end