diff options
author | nagai <nagai@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-05-05 10:08:52 +0000 |
---|---|---|
committer | nagai <nagai@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-05-05 10:08:52 +0000 |
commit | 2f2b25546a0fe197d2f41935ea7a8fbce9e58f20 (patch) | |
tree | 419afb2da4fe6f9d413a8384820a43d362f398f4 /ext | |
parent | 62e9fb85bd7b9701cd07c6d175874fe92d160c28 (diff) | |
download | ruby-2f2b25546a0fe197d2f41935ea7a8fbce9e58f20.tar.gz |
* ext/tk/extconf.rb: revert. enbugged by last commit.
([ruby-dev:41133], [ruby-dev:41134], [ruby-core:30010])
* ext/tk/README.tcltklib: ditto.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@27628 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext')
-rw-r--r-- | ext/tk/README.tcltklib | 2 | ||||
-rw-r--r-- | ext/tk/extconf.rb | 358 |
2 files changed, 60 insertions, 300 deletions
diff --git a/ext/tk/README.tcltklib b/ext/tk/README.tcltklib index 6f278a6dca..251348e91a 100644 --- a/ext/tk/README.tcltklib +++ b/ext/tk/README.tcltklib @@ -61,8 +61,6 @@ some or all of the following options. --with-tcl-lib=<dir> the directry contains 'libtcl<version>.so' --with-tk-lib=<dir> the directry contains 'libtk<version>.so' - --with-tcltk-drive=<drive> (Windows) drive letter for Tcl/Tk libraries. - --enable-mac-tcltk-framework (MacOS X) use Tcl/Tk framework (Obsolete. Please use '--enable-tcltk-framework'.) diff --git a/ext/tk/extconf.rb b/ext/tk/extconf.rb index 676c132a93..1bcda597b5 100644 --- a/ext/tk/extconf.rb +++ b/ext/tk/extconf.rb @@ -1,14 +1,12 @@ ############################################################## # extconf.rb for tcltklib -# release date: 2010-04-30 +# release date: 2010-03-26 ############################################################## require 'mkmf' -#$VERBOSE=true TkLib_Config = {} TkLib_Config['search_versions'] = - # %w[8.9 8.8 8.7 8.6 8.5 8.4 8.3 8.2 8.1 8.0 7.6 4.2] - %w[8.7 8.6 8.5 8.4 8.3 8.2 8.1 8.0] + %w[8.9 8.8 8.7 8.6 8.5 8.4 8.3 8.2 8.1 8.0 4.2] ############################################################## @@ -107,16 +105,6 @@ def is_win32? /mswin|mingw|cygwin|bccwin/ =~ RUBY_PLATFORM end -def win_drive - drive = with_config("windows-tcltk-drive", "c") - case(RUBY_PLATFORM) - when /cygwin/ - ["/cygdrive/#{drive}", "/cygdrive/[A-Za-z]"] - else - ["#{drive}:", "[A-Za-z]:"] - end -end - def is_macosx? /darwin/ =~ RUBY_PLATFORM end @@ -193,51 +181,14 @@ def get_shlib_path_head end if is_win32? - drive, drv_regexp = win_drive if TkLib_Config["ActiveTcl"] - path_head.concat [ - "#{drive}/ActiveTcl*", "#{drive}/Activetcl*", - "#{drive}/activeTcl*", "#{drive}/activetcl*", - "#{drive}/Program Files/ActiveTcl*", - "#{drive}/Program Files/Activetcl*", - "#{drive}/Program Files/activeTcl*", - "#{drive}/Program Files/activetcl*", - "/ActiveTcl*", "/Activetcl*", "/activeTcl*", "/activetcl*", - "/Program Files/ActiveTcl*", "/Program Files/Activetcl*", - "/Program Files/activeTcl*", "/Program Files/activetcl*" - ] + path_head.concat ["c:/ActiveTcl", "c:/Program Files/ActiveTcl"] end - path_head.concat [ - "#{drive}/Tcl*", "#{drive}/tcl*", - "#{drive}/Program Files/Tcl*", "#{drive}/Program Files/tcl*", - "/Tcl*", "/tcl*", "/Program Files/Tcl*", "/Program Files/tcl*" + "c:/Tcl", "c:/Program Files/Tcl", + "/Tcl", "/Program Files/Tcl" ] - - path_head.map!{|d| - [Dir.glob(d).sort.reverse, - Dir.glob(d.sub(%r|^(#{drv_regexp})?/([^/])|, '\1//\2')).sort.reverse] - }.flatten! - - ENV['PATH'].split(File::PATH_SEPARATOR).each{|dir| - path_head << dir - path_head << File.expand_path(File.join(dir, '..')) - if dir.gsub!(/\\/, '/') - path_head << dir - path_head << File.expand_path(File.join(dir, '..')) - end - if dir.sub!(%r|^(#{drv_regexp})?/([^/])|, '\1//\2') - path_head << dir - path_head << File.expand_path(File.join(dir, '..')) - end - } - - path_head |= path_head - path_head.each{|dir| - path_dirs << dir - dir = File.join(dir, "lib") - path_dirs << dir if File.directory?(dir) - } + path_head.each{|dir| path_dirs << "#{dir}"} else [ @@ -414,7 +365,7 @@ def parse_tclConfig(file) end def get_libpath(lib_flag, lib_spec) - # get libpath from {TCL,Tk}_LIB_FLAG and {TCL,Tk}_LIB_SPEC + # get libpath fro {TCL,Tk}_LIB_FLAG and {TCL,Tk}_LIB_SPEC libpath = lib_spec.gsub(/(#{lib_flag}|-L)/, "").strip end @@ -422,22 +373,19 @@ def get_tclConfig_dirs config_dir = [] if is_win32? - drive, drv_regexp = win_drive if TkLib_Config["ActiveTcl"] dirs = [] if TkLib_Config["ActiveTcl"].kind_of?(String) dirs << TkLib_Config["ActiveTcl"] end dirs.concat [ - "#{drive}/ActiveTcl*/lib", "#{drive}/Activetcl*/lib", - "#{drive}/activeTcl*/lib", "#{drive}/activetcl*/lib", - "#{drive}/Tcl*/lib", "#{drive}/tcl*/lib", - "#{drive}/Program Files/ActiveTcl*/lib", - "#{drive}/Program Files/Activetcl*/lib", - "#{drive}/Program Files/activeTcl*/lib", - "#{drive}/Program Files/activetcl*/lib", - "#{drive}/Program Files/Tcl*/lib", "#{drive}/Program Files/tcl*/lib", - "/ActiveTcl*/lib", "/Activetcl*/lib", + "c:/ActiveTcl*/lib", "c:/Activetcl*/lib", + "c:/activeTcl*/lib", "c:/activetcl*/lib", + "c:/Tcl*/lib", "c:/tcl*/lib", + "c:/Program Files/ActiveTcl*/lib", "c:/Program Files/Activetcl*/lib", + "c:/Program Files/activeTcl*/lib", "c:/Program Files/activetcl*/lib", + "c:/Program Files/Tcl*/lib", "c:/Program Files/tcl*/lib", + "/ActiveTcl*/lib", "/Activetcl*/lib", "/activeTcl*/lib", "/activetcl*/lib", "/Tcl*/lib", "/tcl*/lib", "/Program Files/ActiveTcl*/lib", "/Program Files/Activetcl*/lib", @@ -446,35 +394,21 @@ def get_tclConfig_dirs ] else dirs = [ - "#{drive}/Tcl*/lib", "#{drive}/tcl*/lib", - "#{drive}/Program Files/Tcl*/lib", "#{drive}/Program Files/tcl*/lib", - "/Tcl*/lib", "/tcl*/lib", + "c:/Tcl*/lib", "c:/tcl*/lib", + "c:/Program Files/Tcl*/lib", "c:/Program Files/tcl*/lib", + "/Tcl*/lib", "/tcl*/lib", "/Program Files/Tcl*/lib", "/Program Files/tcl*/lib" ] end - dirs.map!{|d| - [Dir.glob(d).sort.reverse, - Dir.glob(d.sub(%r|^(#{drv_regexp})?/([^/])|, '\1//\2')).sort.reverse] - }.flatten! + dirs.collect{|d| Dir.glob(d)}.flatten! + dirs |= dirs - ENV['PATH'].split(File::PATH_SEPARATOR).each{|dir| + ENV['PATH'].split(';').each{|dir| dirs << File.expand_path(File.join(dir, '..', 'lib')) dirs << dir dirs << File.expand_path(File.join(dir, '..')) - if dir.gsub!(/\\/, '/') - dirs << File.expand_path(File.join(dir, '..', 'lib')) - dirs << dir - dirs << File.expand_path(File.join(dir, '..')) - end - if dir.sub!(%r|^(#{drv_regexp})?/([^/])|, '\1//\2') - dirs << File.expand_path(File.join(dir, '..', 'lib')) - dirs << dir - dirs << File.expand_path(File.join(dir, '..')) - end } - dirs |= dirs - unless TkLib_Config["space-on-tk-libpath"] dirs.delete_if{|path| path =~ / /} end @@ -504,13 +438,13 @@ def get_tclConfig_dirs '/usr/local/opt', '/usr/local/pkg', '/usr/local/share', '/usr/local', '/usr/opt', '/usr/pkg', '/usr/share', '/usr/contrib', '/usr' ].map{|dir| - Dir.glob(dir + '/{TclTk,tcltk,Tcl,tcl,Tk,tk}[987]*/lib') - Dir.glob(dir + '/{TclTk,tcltk,Tcl,tcl,Tk,tk}[987]*') + Dir.glob(dir + '/{TclTk,tcltk,Tcl,tcl,Tk,tk}[87]*/lib') + Dir.glob(dir + '/{TclTk,tcltk,Tcl,tcl,Tk,tk}[87]*') Dir.glob(dir + '/{TclTk,tcltk,Tcl,tcl,Tk,tk}/lib') Dir.glob(dir + '/{TclTk,tcltk,Tcl,tcl,Tk,tk}') }.flatten! - ENV['PATH'].split(File::PATH_SEPARATOR).each{|dir| + ENV['PATH'].split(':').each{|dir| config_dir << File.expand_path(File.join(dir, '..', 'lib')) } @@ -573,11 +507,7 @@ def search_tclConfig(*paths) # libdir list or [tcl-libdir|file, tk-libdir|file] tcldir = tkdir = dir end - if enable_config("shared") == false - tails = ['Config.sh', 'config.sh', 'Config-shared.sh', 'config-shared.sh'] - else - tails = ['Config-shared.sh', 'config-shared.sh', 'Config.sh', 'config.sh'] - end + tails = ['Config-shared.sh', 'config-shared.sh', 'Config.sh', 'config.sh'] if File.file?(tcldir) tclcfg_files = [tcldir] * tails.length @@ -704,7 +634,7 @@ def get_tclConfig(tclConfig_file, tkConfig_file, tclConfig_dir, tkConfig_dir) TkLib_Config["tclConfig-dir"] = tclConfig_dir TkLib_Config["tkConfig-dir"] = tkConfig_dir - print("Search tclConfig.sh", (tclConfig_dir)? " (in #{tclConfig_dir})": "", + print("Search tclConfig.sh", (tclConfig_dir)? " (in #{tclConfig_dir})": "", " and tkConfig.sh", (tkConfig_dir)? " (in #{tkConfig_dir})": "", ".") if tclConfig_dir tclConfig, tkConfig = @@ -762,15 +692,15 @@ def check_shlib_search_path(paths) dirs = [] if !Dir.glob(head + "-*").empty? - dirs << head + "-#{ver}/lib" if !Dir.glob(head + "-[987].*").empty? - dirs << head + "-#{ver.delete('.')}/lib" if !Dir.glob(head + "-[987][0-9]*").empty? + dirs << head + "-#{ver}/lib" if !Dir.glob(head + "-[89].*").empty? + dirs << head + "-#{ver.delete('.')}/lib" if !Dir.glob(head + "-[89][0-9]*").empty? end if !Dir.glob(head + "[_-]*").empty? - dirs << head + "_#{ver}/lib" if !Dir.glob(head + "_[987].*").empty? - dirs << head + "-#{ver}/lib" if !Dir.glob(head + "-[987].*").empty? - dirs << head + "_#{ver.delete('.')}/lib" if !Dir.glob(head + "_[987][0-9]*").empty? - dirs << head + "-#{ver.delete('.')}/lib" if !Dir.glob(head + "-[987][0-9]*").empty? + dirs << head + "_#{ver}/lib" if !Dir.glob(head + "_[89].*").empty? + dirs << head + "-#{ver}/lib" if !Dir.glob(head + "-[89].*").empty? + dirs << head + "_#{ver.delete('.')}/lib" if !Dir.glob(head + "_[89][0-9]*").empty? + dirs << head + "-#{ver.delete('.')}/lib" if !Dir.glob(head + "-[89][0-9]*").empty? end dirs @@ -782,22 +712,17 @@ def check_shlib_search_path(paths) else # paths is a string with PATH environment style - path_list = paths.split(File::PATH_SEPARATOR) - #path_list = paths.split((is_win32?)? ';': ':') + path_list = paths.split((is_win32?)? ';': ':') end path_list = check_NG_path(path_list) if is_win32? # exist-dir only - drive, drv_regexp = win_drive path_list.each{|path| - path = path.strip; - #$LIBPATH |= [path] if File.directory?(path) - $LIBPATH |= [path.sub(%r|^(#{drv_regexp})?//|, '\1/')] unless Dir.glob(File.join(path, "*.{a,so,dll,lib}")).empty? + path = path.strip; $LIBPATH |= [path] if File.directory?(path) } else - # keep paths for searching dynamic libs path_list.each{|path| $LIBPATH |= [path.strip] } end end @@ -805,15 +730,12 @@ end def search_vers_on_path(vers, path, *heads) if enable_config("shared") == false exts = CONFIG['LIBEXT'] + ',' + CONFIG['DLEXT'] - exts << ",lib,dll" if is_win32? - exts << ",bundle,dylib" if is_macosx? || /nextstep|openstep|rhapsody/ =~ RUBY_PLATFORM else exts = CONFIG['DLEXT'] + ',' + CONFIG['LIBEXT'] - exts << ",dll,lib" if is_win32? - exts << ",dylib,bundle" if is_macosx? || /nextstep|openstep|rhapsody/ =~ RUBY_PLATFORM end + exts << ",dll,lib" if is_win32? + exts << ",bundle,dylib" if is_macosx? || /nextstep|openstep|rhapsody/ =~ RUBY_PLATFORM files = Dir.glob(File.join(path, "*{#{heads.join(',')}}*.{#{exts}}")) - files |= files vers.find_all{|ver| files.find{|f| f =~ /(#{ver}|#{ver.delete('.')})/} } end @@ -843,68 +765,10 @@ def find_tcl(tcllib, stubs, version, *opt_paths) "/usr/local/lib", "/usr/pkg/lib", "/usr/contrib/lib", "/usr/lib" ].find_all{|dir| File.directory?(dir)} - if TkLib_Config["ActiveTcl"].kind_of?(String) # glob path - default_paths.concat Dir.glob(TkLib_Config["ActiveTcl"]).sort.reverse.map{|d| d << "/lib"} - end - - if is_win32? - drive, drv_regexp = win_drive - if TkLib_Config["ActiveTcl"] - default_paths.concat [ - "#{drive}/ActiveTcl*", "#{drive}/Activetcl*", - "#{drive}/activeTcl*", "#{drive}/activetcl*", - "#{drive}/Program Files/ActiveTcl*", - "#{drive}/Program Files/Activetcl*", - "#{drive}/Program Files/activeTcl*", - "#{drive}/Program Files/activetcl*", - "/ActiveTcl*", "/Activetcl*", "/activeTcl*", "/activetcl*", - "/Program Files/ActiveTcl*", "/Program Files/Activetcl*", - "/Program Files/activeTcl*", "/Program Files/activetcl*" - ].map{|d| d << "/lib"} - end - default_paths.concat [ - "#{drive}/Tcl*", "#{drive}/tcl*", - "#{drive}/Program Files/Tcl*", "#{drive}/Program Files/tcl*", - "/Tcl*", "/tcl*", "/Program Files/Tcl*", "/Program Files/tcl*", - ].map{|d| d << "/lib"} - default_paths.map{|d| - [Dir.glob(d).sort.reverse, - Dir.glob(d.sub(%r|^(#{drv_regexp})?/([^/])|, '\1//\2')).sort.reverse] - }.flatten.find_all{|dir| File.directory?(dir)} - end - - env_paths = [] - ENV['PATH'].split(File::PATH_SEPARATOR).each{|dir| - env_paths << File.expand_path(File.join(dir, '..', 'lib')) - env_paths << dir - env_paths << File.expand_path(File.join(dir, '..')) - if is_win32? - if dir.gsub!(/\\/, '/') - env_paths << File.expand_path(File.join(dir, '..', 'lib')) - env_paths << dir - env_paths << File.expand_path(File.join(dir, '..')) - end - if dir.sub!(%r|^(#{drv_regexp})?/([^/])|, '\1//\2') - env_paths << File.expand_path(File.join(dir, '..', 'lib')) - env_paths << dir - env_paths << File.expand_path(File.join(dir, '..')) - end - end - } - - if is_win32? - env_paths = env_paths.find_all{|d| - not (Dir.glob(File.join(d, "*[Tt]cl*")) | Dir.glob(File.join(d.sub(%r|^(#{drv_regexp})?/([^/])|, '\1//\2'), "*[Tt]cl*"))).empty? - } - else - env_paths = env_paths.find_all{|d| - not (Dir.glob(File.join(d, "*[Tt]cl*"))).empty? - } - end - - default_paths.concat env_paths - - default_paths |= default_paths + default_paths.concat [ + "c:/Tcl/lib", "c:/Program Files/Tcl/lib", + "/Tcl/lib", "/Program Files/Tcl/lib" + ].find_all{|dir| File.directory?(dir)} unless TkLib_Config["space-on-tk-libpath"] default_paths.delete_if{|path| path =~ / /} @@ -947,12 +811,12 @@ def find_tcl(tcllib, stubs, version, *opt_paths) end end - ret = paths.find{|path| + ret = paths.map{|path| if tcllib print(".") - find_library(tcllib, func, path) + [path, find_library(tcllib, func, path)] else - search_vers_on_path(versions, path, lib, 'tcl').find{|ver| + st = search_vers_on_path(versions, path, lib, 'tcl').find{|ver| (print(".");find_library("#{lib}#{ver}", func, path)) or (print(".");find_library("#{lib}#{ver.delete('.')}", func, path)) or (print(".");find_library("#{lib}#{ver}g", func, path)) or @@ -962,11 +826,11 @@ def find_tcl(tcllib, stubs, version, *opt_paths) (print(".");find_library("tcl#{ver}g", func, path)) or (print(".");find_library("tcl#{ver.delete('.')}g", func, path)) } || (!version && (print(".");find_library(lib, func, path))) + [path, st] end } print("\n") # progress - print("Found a Tcl library at #{ret}.\n") if ret ret end @@ -1011,68 +875,10 @@ def find_tk(tklib, stubs, version, *opt_paths) "/usr/local/lib", "/usr/pkg/lib", "/usr/contrib/lib", "/usr/lib" ].find_all{|dir| File.directory?(dir)} - if TkLib_Config["ActiveTcl"].kind_of?(String) # glob path - default_paths.concat Dir.glob(TkLib_Config["ActiveTcl"]).sort.reverse.map{|d| d << "/lib"} - end - - if is_win32? - drive, drv_regexp = win_drive - if TkLib_Config["ActiveTcl"] - default_paths.concat [ - "#{drive}/ActiveTcl*", "#{drive}/Activetcl*", - "#{drive}/activeTcl*", "#{drive}/activetcl*", - "#{drive}/Program Files/ActiveTcl*", - "#{drive}/Program Files/Activetcl*", - "#{drive}/Program Files/activeTcl*", - "#{drive}/Program Files/activetcl*", - "/ActiveTcl*", "/Activetcl*", "/activeTcl*", "/activetcl*", - "/Program Files/ActiveTcl*", "/Program Files/Activetcl*", - "/Program Files/activeTcl*", "/Program Files/activetcl*" - ].map{|d| d << "/lib"} - end - default_paths.concat [ - "#{drive}/Tcl*", "#{drive}/tcl*", - "#{drive}/Program Files/Tcl*", "#{drive}/Program Files/tcl*", - "/Tcl*", "/tcl*", "/Program Files/Tcl*", "/Program Files/tcl*", - ].map{|d| d << "/lib"} - default_paths.map{|d| - [Dir.glob(d).sort.reverse, - Dir.glob(d.sub(%r|^(#{drv_regexp})?/([^/])|, '\1//\2')).sort.reverse] - }.flatten.find_all{|dir| File.directory?(dir)} - end - - env_paths = [] - ENV['PATH'].split(File::PATH_SEPARATOR).each{|dir| - env_paths << File.expand_path(File.join(dir, '..', 'lib')) - env_paths << dir - env_paths << File.expand_path(File.join(dir, '..')) - if is_win32? - if dir.gsub!(/\\/, '/') - env_paths << File.expand_path(File.join(dir, '..', 'lib')) - env_paths << dir - env_paths << File.expand_path(File.join(dir, '..')) - end - if dir.sub!(%r|^(#{drv_regexp})?/([^/])|, '\1//\2') - env_paths << File.expand_path(File.join(dir, '..', 'lib')) - env_paths << dir - env_paths << File.expand_path(File.join(dir, '..')) - end - end - } - - if is_win32? - env_paths = env_paths.find_all{|d| - not (Dir.glob(File.join(d, "*[Tt]k*")) | Dir.glob(File.join(d.sub(%r|^(#{drv_regexp})?/([^/])|, '\1//\2'), "*[Tt]k*"))).empty? - } - else - env_paths = env_paths.find_all{|d| - not (Dir.glob(File.join(d, "*[Tt]k*"))).empty? - } - end - - default_paths.concat env_paths - - default_paths |= default_paths + default_paths.concat [ + "c:/Tcl/lib", "c:/Program Files/Tcl/lib", + "/Tcl/lib", "/Program Files/Tcl/lib" + ].find_all{|dir| File.directory?(dir)} unless TkLib_Config["space-on-tk-libpath"] default_paths.delete_if{|path| path =~ / /} @@ -1114,12 +920,12 @@ def find_tk(tklib, stubs, version, *opt_paths) end end - ret = paths.find{|path| + ret = paths.map{|path| if tklib print(".") - find_library(tklib, func, path) + [path, find_library(tklib, func, path)] else - search_vers_on_path(versions, path, lib, 'tk').find{|ver| + st = search_vers_on_path(versions, path, lib, 'tk').find{|ver| (print(".");find_library("#{lib}#{ver}", func, path)) or (print(".");find_library("#{lib}#{ver.delete('.')}", func, path)) or (print(".");find_library("#{lib}#{ver}g", func, path)) or @@ -1129,22 +935,24 @@ def find_tk(tklib, stubs, version, *opt_paths) (print(".");find_library("tk#{ver}g", func, path)) or (print(".");find_library("tk#{ver.delete('.')}g", func, path)) } || (!version && (print(".");find_library(lib, func, path))) + [path, st] end } print("\n") # progress - print("Found a Tk library at #{ret}.\n") if ret ret end def find_tcltk_library(tcllib, tklib, stubs, tclversion, tkversion, tcl_opt_paths, tk_opt_paths) - unless find_tcl(tcllib, stubs, tclversion, *tcl_opt_paths) + ret = find_tcl(tcllib, stubs, tclversion, *tcl_opt_paths) + unless ret && ret.find{|path, val| val} puts("Warning:: cannot find Tcl library. tcltklib will not be compiled (tcltklib is disabled on your Ruby == Ruby/Tk will not work). Please check configure options.") return false end - unless find_tk(tklib, stubs, tkversion, *tk_opt_paths) + ret = find_tk(tklib, stubs, tkversion, *tk_opt_paths) + unless ret && ret.find{|path, val| val} puts("Warning:: cannot find Tk library. tcltklib will not be compiled (tcltklib is disabled on your Ruby == Ruby/Tk will not work). Please check configure options.") return false end @@ -1161,57 +969,10 @@ def find_tcltk_header(tclver, tkver) "/usr/include" ].find_all{|dir| File.directory?(dir)} - if TkLib_Config["ActiveTcl"].kind_of?(String) # glob path - base_dir.concat Dir.glob(TkLib_Config["ActiveTcl"]).sort.reverse.map{|d| d << "/include"} - end - - if is_win32? - drive, drv_regexp = win_drive - if TkLib_Config["ActiveTcl"] - base_dir.concat [ - "#{drive}/ActiveTcl*", "#{drive}/Activetcl*", - "#{drive}/activeTcl*", "#{drive}/activetcl*", - "#{drive}/Program Files/ActiveTcl*", - "#{drive}/Program Files/Activetcl*", - "#{drive}/Program Files/activeTcl*", - "#{drive}/Program Files/activetcl*", - "/ActiveTcl*", "/Activetcl*", "/activeTcl*", "/activetcl*", - "/Program Files/ActiveTcl*", "/Program Files/Activetcl*", - "/Program Files/activeTcl*", "/Program Files/activetcl*" - ].map{|d| d << "/include"} - end - - base_dir.concat [ - "#{drive}/Tcl*/include", "#{drive}/tcl*/include", - "#{drive}/Program Files/Tcl*/include", - "#{drive}/Program Files/tcl*/include", - "/Tcl*/include", "/tcl*/include", - "/Program Files/Tcl*/include", "/Program Files/tcl*/include", - ] - - base_dir.map{|d| - [Dir.glob(d).sort.reverse, - Dir.glob(d.sub(%r|^(#{drv_regexp})?/([^/])|, '\1//\2')).sort.reverse] - }.flatten.find_all{|dir| File.directory?(dir)} - - ENV['PATH'].split(File::PATH_SEPARATOR).each{|dir| - base_dir << File.expand_path(File.join(dir, '..', 'include')) - base_dir << dir - base_dir << File.expand_path(File.join(dir, '..')) - if dir.gsub!(/\\/, '/') - base_dir << File.expand_path(File.join(dir, '..', 'include')) - base_dir << dir - base_dir << File.expand_path(File.join(dir, '..')) - end - if dir.sub!(%r|^(#{drv_regexp})?/([^/])|, '\1//\2') - base_dir << File.expand_path(File.join(dir, '..', 'include')) - base_dir << dir - base_dir << File.expand_path(File.join(dir, '..')) - end - } - end - - base_dir |= base_dir + base_dir.concat [ + "c:/Tcl/include", "c:/Program Files/Tcl/include", + "/Tcl/include", "/Program Files/Tcl/include" + ].find_all{|dir| File.directory?(dir)} unless TkLib_Config["space-on-tk-libpath"] base_dir.delete_if{|path| path =~ / /} @@ -1607,6 +1368,7 @@ tcl_cfg_dir = File.dirname(TclConfig_Info['config_file_path']) rescue nil tk_ldir_list = [tk_ldir, tk_cfg_dir] tcl_ldir_list = [tcl_ldir, tcl_cfg_dir] + # check tk_shlib_search_path check_shlib_search_path(with_config('tk-shlib-search-path')) |