summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog5
-rw-r--r--ext/extmk.rb15
-rw-r--r--lib/mkmf.rb22
3 files changed, 38 insertions, 4 deletions
diff --git a/ChangeLog b/ChangeLog
index 127b14417b..0a3191ccf7 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Sat Oct 22 23:54:07 2005 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * ext/extmk.rb, lib/mkmf.rb (with_config): support --with-extension
+ options. [ruby-dev:27449]
+
Sat Oct 22 13:26:57 2005 Nobuyoshi Nakada <nobu@ruby-lang.org>
* object.c (sym_inspect), parse.y (parser_yylex, rb_symname_p): check
diff --git a/ext/extmk.rb b/ext/extmk.rb
index 5d85d2d97b..23be23c293 100644
--- a/ext/extmk.rb
+++ b/ext/extmk.rb
@@ -353,10 +353,25 @@ exts = $static_ext.sort_by {|t, i| i}.collect {|t, i| t}
if $extension
exts |= $extension.select {|d| File.directory?("#{ext_prefix}/#{d}")}
else
+ withes, withouts = %w[--with --without].collect {|w|
+ if not (w = %w[-extensions -ext].collect {|opt|arg_config(w+opt)}).any?
+ proc {false}
+ elsif (w = w.grep(String)).empty?
+ proc {true}
+ else
+ w.collect {|opt| opt.split(/,/)}.flatten.method(:any?)
+ end
+ }
+ cond = proc {|ext|
+ cond1 = proc {|n| File.fnmatch(n, ext, File::FNM_PATHNAME)}
+ withes.call(&cond1) or !withouts.call(&cond1)
+ }
exts |= Dir.glob("#{ext_prefix}/*/**/extconf.rb").collect {|d|
d = File.dirname(d)
d.slice!(0, ext_prefix.length + 1)
d
+ }.find_all {|ext|
+ with_config(ext, &cond)
}.sort
end
diff --git a/lib/mkmf.rb b/lib/mkmf.rb
index 9fe0d9bbfa..6150b59c9a 100644
--- a/lib/mkmf.rb
+++ b/lib/mkmf.rb
@@ -793,11 +793,25 @@ def arg_config(config, *defaults, &block)
$configure_args.fetch(config.tr('_', '-'), *defaults, &block)
end
-def with_config(config, *defaults, &block)
- unless /^--with[-_]/ =~ config
- config = '--with-' + config
+def with_config(config, *defaults)
+ config = config.sub(/^--with[-_]/, '')
+ val = arg_config("--with-"+config) do
+ if arg_config("--without-"+config)
+ false
+ elsif block_given?
+ yield(config, *defaults)
+ else
+ break *defaults
+ end
+ end
+ case val
+ when "yes"
+ true
+ when "no"
+ false
+ else
+ val
end
- arg_config(config, *defaults, &block)
end
def enable_config(config, *defaults)