From 0c9d291c5ac28f4dcee5be413c069ec2a0b4d440 Mon Sep 17 00:00:00 2001 From: Lyle Johnson <lyle@lylejohnson.name> Date: Tue, 15 Sep 2009 11:55:54 -0500 Subject: [PATCH] Removed stuff related to making the Win32 installer --- README.win32.txt | 23 - Rakefile | 44 +- install.rb | 1585 -------------------------------- pre-config.rb.erb | 111 --- scripts/FXRuby.iss.erb | 81 -- scripts/make-installers.rb.erb | 84 -- scripts/make-win32-tarball.sh | 5 - scripts/opengl-cygwin.iss | 74 -- scripts/opengl.iss | 74 -- 9 files changed, 3 insertions(+), 2078 deletions(-) delete mode 100755 README.win32.txt delete mode 100755 install.rb delete mode 100755 pre-config.rb.erb delete mode 100755 scripts/FXRuby.iss.erb delete mode 100755 scripts/make-installers.rb.erb delete mode 100755 scripts/make-win32-tarball.sh delete mode 100755 scripts/opengl-cygwin.iss delete mode 100755 scripts/opengl.iss diff --git a/README.win32.txt b/README.win32.txt deleted file mode 100755 index 88cdfc0..0000000 --- a/README.win32.txt +++ /dev/null @@ -1,23 +0,0 @@ -This binary distribution of FXRuby is specifically -packaged to work with the latest One-Click Ruby -Installer, available for download from this page: - -http://rubyforge.org/projects/rubyinstaller - -This distribution should contain just about everything -you'd want to get started working with FXRuby; the -documentation is installed under: - -C:\ruby\doc\ruby\FXRuby - -the sample programs are installed under: - -C:\ruby\samples\FXRuby - -and the libraries are installed under: - -C:\ruby\lib\ruby\site_ruby\1.8 - -This distribution doesn't include the C++ source code -used to build FXRuby. For that you should download the -full source code distribution from the FXRuby home page. diff --git a/Rakefile b/Rakefile index 13e5524..b6ae0fb 100755 --- a/Rakefile +++ b/Rakefile @@ -43,19 +43,6 @@ def setversions(filename) end end -desc "Create INNO Setup installer scripts from templates" -task :create_installer_scripts do - output_filenames = { - "FXRuby-ruby1.8.6-i386-msvcrt.iss" => ["1.8", "ruby186", "i386-msvcrt"] - } - template = ERB.new(File.open("scripts/FXRuby.iss.erb", "rb").read) - output_filenames.each do |output_filename, info| - File.open(output_filename, "wb") do |output_file| - output_file.write(template.result(binding)) - end - end -end - desc "Update the web site." task :website => [:doap] do system %{scp -Cq doc/*.css lyle@rubyforge.org:/var/www/gforge-projects/fxruby/1.6/doc} @@ -76,21 +63,15 @@ task :doap => [:setversions] do end desc "Set versions" -task :setversions => [ :create_installer_scripts ] do - setversions("pre-config.rb") +task :setversions do setversions("doap.rdf") - setversions("scripts/make-installers.rb") end DISTFILES = [ "ANNOUNCE", "LICENSE", "README", - "README.win32.txt", - "pre-config.rb", - "install.rb", "doap.rdf", - "FXRuby-ruby1.8.6-i386-msvcrt.iss", "Rakefile", "index.html", "doc/*.css", @@ -109,15 +90,12 @@ DISTFILES = [ "ext/fox16/*.cpp", "ext/fox16/include/*.h", "swig-interfaces/README", - "swig-interfaces/Makefile", - "swig-interfaces/swig.sed", "swig-interfaces/*.i", "tests/README", "tests/*.rb", "tests/*.ps", "rdoc-sources/*.rb", - "rdoc-sources/README.rdoc", - "scripts/make-installers.rb" + "rdoc-sources/README.rdoc" ] def distdir @@ -178,22 +156,6 @@ task :scintilla do ruby "scripts/iface.rb -i c:/src/fxscintilla-1.71/scintilla/include/Scintilla.iface -o lib/fox16/scintilla.rb" end -desc "Build Win32 installer using INNO Setup" -task :build_win32_installer => [:compile] do - iss_script_name = nil - case VERSION - when /1.8.2/ - iss_script_name = "FXRuby-ruby1.8.2-i386-msvcrt.iss" - when /1.8.4/ - iss_script_name = "FXRuby-ruby1.8.4-i386-msvcrt.iss" - when /1.8.5/ - iss_script_name = "FXRuby-ruby1.8.5-i386-msvcrt.iss" - when /1.8.6/ - iss_script_name = "FXRuby-ruby1.8.6-i386-msvcrt.iss" - end - system(ISCC, iss_script_name) -end - desc "Build Win32 binary Gem" task :build_win32_gem => [:compile] do spec = create_gemspec @@ -203,7 +165,7 @@ task :build_win32_gem => [:compile] do end desc "Build Win32 binary installer and Gem" -task :release_win32 => [:build_win32_installer, :build_win32_gem] do +task :release_win32 => [:build_win32_gem] do end task :generate_kwargs_lib do diff --git a/install.rb b/install.rb deleted file mode 100755 index 424a5f3..0000000 --- a/install.rb +++ /dev/null @@ -1,1585 +0,0 @@ -# -# setup.rb -# -# Copyright (c) 2000-2005 Minero Aoki -# -# This program is free software. -# You can distribute/modify this program under the terms of -# the GNU LGPL, Lesser General Public License version 2.1. -# - -unless Enumerable.method_defined?(:map) # Ruby 1.4.6 - module Enumerable - alias map collect - end -end - -unless File.respond_to?(:read) # Ruby 1.6 - def File.read(fname) - open(fname) {|f| - return f.read - } - end -end - -unless Errno.const_defined?(:ENOTEMPTY) # Windows? - module Errno - class ENOTEMPTY - # We do not raise this exception, implementation is not needed. - end - end -end - -def File.binread(fname) - open(fname, 'rb') {|f| - return f.read - } -end - -# for corrupted Windows' stat(2) -def File.dir?(path) - File.directory?((path[-1,1] == '/') ? path : path + '/') -end - - -class ConfigTable - - include Enumerable - - def initialize(rbconfig) - @rbconfig = rbconfig - @items = [] - @table = {} - # options - @install_prefix = nil - @config_opt = nil - @verbose = true - @no_harm = false - end - - attr_accessor :install_prefix - attr_accessor :config_opt - - attr_writer :verbose - - def verbose? - @verbose - end - - attr_writer :no_harm - - def no_harm? - @no_harm - end - - def [](key) - lookup(key).resolve(self) - end - - def []=(key, val) - lookup(key).set val - end - - def names - @items.map {|i| i.name } - end - - def each(&block) - @items.each(&block) - end - - def key?(name) - @table.key?(name) - end - - def lookup(name) - @table[name] or setup_rb_error "no such config item: #{name}" - end - - def add(item) - @items.push item - @table[item.name] = item - end - - def remove(name) - item = lookup(name) - @items.delete_if {|i| i.name == name } - @table.delete_if {|name, i| i.name == name } - item - end - - def load_script(path, inst = nil) - if File.file?(path) - MetaConfigEnvironment.new(self, inst).instance_eval File.read(path), path - end - end - - def savefile - '.config' - end - - def load_savefile - begin - File.foreach(savefile()) do |line| - k, v = *line.split(/=/, 2) - self[k] = v.strip - end - rescue Errno::ENOENT - setup_rb_error $!.message + "\n#{File.basename($0)} config first" - end - end - - def save - @items.each {|i| i.value } - File.open(savefile(), 'w') {|f| - @items.each do |i| - f.printf "%s=%s\n", i.name, i.value if i.value? and i.value - end - } - end - - def load_standard_entries - standard_entries(@rbconfig).each do |ent| - add ent - end - end - - def standard_entries(rbconfig) - c = rbconfig - - rubypath = File.join(c['bindir'], c['ruby_install_name'] + c['EXEEXT']) - - major = c['MAJOR'].to_i - minor = c['MINOR'].to_i - teeny = c['TEENY'].to_i - version = "#{major}.#{minor}" - - # ruby ver. >= 1.4.4? - newpath_p = ((major >= 2) or - ((major == 1) and - ((minor >= 5) or - ((minor == 4) and (teeny >= 4))))) - - if c['rubylibdir'] - # V > 1.6.3 - libruby = "#{c['prefix']}/lib/ruby" - librubyver = c['rubylibdir'] - librubyverarch = c['archdir'] - siteruby = c['sitedir'] - siterubyver = c['sitelibdir'] - siterubyverarch = c['sitearchdir'] - elsif newpath_p - # 1.4.4 <= V <= 1.6.3 - libruby = "#{c['prefix']}/lib/ruby" - librubyver = "#{c['prefix']}/lib/ruby/#{version}" - librubyverarch = "#{c['prefix']}/lib/ruby/#{version}/#{c['arch']}" - siteruby = c['sitedir'] - siterubyver = "$siteruby/#{version}" - siterubyverarch = "$siterubyver/#{c['arch']}" - else - # V < 1.4.4 - libruby = "#{c['prefix']}/lib/ruby" - librubyver = "#{c['prefix']}/lib/ruby/#{version}" - librubyverarch = "#{c['prefix']}/lib/ruby/#{version}/#{c['arch']}" - siteruby = "#{c['prefix']}/lib/ruby/#{version}/site_ruby" - siterubyver = siteruby - siterubyverarch = "$siterubyver/#{c['arch']}" - end - parameterize = lambda {|path| - path.sub(/\A#{Regexp.quote(c['prefix'])}/, '$prefix') - } - - if arg = c['configure_args'].split.detect {|arg| /--with-make-prog=/ =~ arg } - makeprog = arg.sub(/'/, '').split(/=/, 2)[1] - else - makeprog = 'make' - end - - [ - ExecItem.new('installdirs', 'std/site/home', - 'std: install under libruby; site: install under site_ruby; home: install under $HOME')\ - {|val, table| - case val - when 'std' - table['rbdir'] = '$librubyver' - table['sodir'] = '$librubyverarch' - when 'site' - table['rbdir'] = '$siterubyver' - table['sodir'] = '$siterubyverarch' - when 'home' - setup_rb_error '$HOME was not set' unless ENV['HOME'] - table['prefix'] = ENV['HOME'] - table['rbdir'] = '$libdir/ruby' - table['sodir'] = '$libdir/ruby' - end - }, - PathItem.new('prefix', 'path', c['prefix'], - 'path prefix of target environment'), - PathItem.new('bindir', 'path', parameterize.call(c['bindir']), - 'the directory for commands'), - PathItem.new('libdir', 'path', parameterize.call(c['libdir']), - 'the directory for libraries'), - PathItem.new('datadir', 'path', parameterize.call(c['datadir']), - 'the directory for shared data'), - PathItem.new('mandir', 'path', parameterize.call(c['mandir']), - 'the directory for man pages'), - PathItem.new('sysconfdir', 'path', parameterize.call(c['sysconfdir']), - 'the directory for system configuration files'), - PathItem.new('localstatedir', 'path', parameterize.call(c['localstatedir']), - 'the directory for local state data'), - PathItem.new('libruby', 'path', libruby, - 'the directory for ruby libraries'), - PathItem.new('librubyver', 'path', librubyver, - 'the directory for standard ruby libraries'), - PathItem.new('librubyverarch', 'path', librubyverarch, - 'the directory for standard ruby extensions'), - PathItem.new('siteruby', 'path', siteruby, - 'the directory for version-independent aux ruby libraries'), - PathItem.new('siterubyver', 'path', siterubyver, - 'the directory for aux ruby libraries'), - PathItem.new('siterubyverarch', 'path', siterubyverarch, - 'the directory for aux ruby binaries'), - PathItem.new('rbdir', 'path', '$siterubyver', - 'the directory for ruby scripts'), - PathItem.new('sodir', 'path', '$siterubyverarch', - 'the directory for ruby extentions'), - PathItem.new('rubypath', 'path', rubypath, - 'the path to set to #! line'), - ProgramItem.new('rubyprog', 'name', rubypath, - 'the ruby program using for installation'), - ProgramItem.new('makeprog', 'name', makeprog, - 'the make program to compile ruby extentions'), - SelectItem.new('shebang', 'all/ruby/never', 'ruby', - 'shebang line (#!) editing mode'), - BoolItem.new('without-ext', 'yes/no', 'no', - 'does not compile/install ruby extentions') - ] - end - private :standard_entries - - def load_multipackage_entries - multipackage_entries().each do |ent| - add ent - end - end - - def multipackage_entries - [ - PackageSelectionItem.new('with', 'name,name...', '', 'ALL', - 'package names that you want to install'), - PackageSelectionItem.new('without', 'name,name...', '', 'NONE', - 'package names that you do not want to install') - ] - end - private :multipackage_entries - - ALIASES = { - 'std-ruby' => 'librubyver', - 'stdruby' => 'librubyver', - 'rubylibdir' => 'librubyver', - 'archdir' => 'librubyverarch', - 'site-ruby-common' => 'siteruby', # For backward compatibility - 'site-ruby' => 'siterubyver', # For backward compatibility - 'bin-dir' => 'bindir', - 'bin-dir' => 'bindir', - 'rb-dir' => 'rbdir', - 'so-dir' => 'sodir', - 'data-dir' => 'datadir', - 'ruby-path' => 'rubypath', - 'ruby-prog' => 'rubyprog', - 'ruby' => 'rubyprog', - 'make-prog' => 'makeprog', - 'make' => 'makeprog' - } - - def fixup - ALIASES.each do |ali, name| - @table[ali] = @table[name] - end - @items.freeze - @table.freeze - @options_re = /\A--(#{@table.keys.join('|')})(?:=(.*))?\z/ - end - - def parse_opt(opt) - m = @options_re.match(opt) or setup_rb_error "config: unknown option #{opt}" - m.to_a[1,2] - end - - def dllext - @rbconfig['DLEXT'] - end - - def value_config?(name) - lookup(name).value? - end - - class Item - def initialize(name, template, default, desc) - @name = name.freeze - @template = template - @value = default - @default = default - @description = desc - end - - attr_reader :name - attr_reader :description - - attr_accessor :default - alias help_default default - - def help_opt - "--#{@name}=#{@template}" - end - - def value? - true - end - - def value - @value - end - - def resolve(table) - @value.gsub(%r<\$([^/]+)>) { table[$1] } - end - - def set(val) - @value = check(val) - end - - private - - def check(val) - setup_rb_error "config: --#{name} requires argument" unless val - val - end - end - - class BoolItem < Item - def config_type - 'bool' - end - - def help_opt - "--#{@name}" - end - - private - - def check(val) - return 'yes' unless val - case val - when /\Ay(es)?\z/i, /\At(rue)?\z/i then 'yes' - when /\An(o)?\z/i, /\Af(alse)\z/i then 'no' - else - setup_rb_error "config: --#{@name} accepts only yes/no for argument" - end - end - end - - class PathItem < Item - def config_type - 'path' - end - - private - - def check(path) - setup_rb_error "config: --#{@name} requires argument" unless path - path[0,1] == '$' ? path : File.expand_path(path) - end - end - - class ProgramItem < Item - def config_type - 'program' - end - end - - class SelectItem < Item - def initialize(name, selection, default, desc) - super - @ok = selection.split('/') - end - - def config_type - 'select' - end - - private - - def check(val) - unless @ok.include?(val.strip) - setup_rb_error "config: use --#{@name}=#{@template} (#{val})" - end - val.strip - end - end - - class ExecItem < Item - def initialize(name, selection, desc, &block) - super name, selection, nil, desc - @ok = selection.split('/') - @action = block - end - - def config_type - 'exec' - end - - def value? - false - end - - def resolve(table) - setup_rb_error "$#{name()} wrongly used as option value" - end - - undef set - - def evaluate(val, table) - v = val.strip.downcase - unless @ok.include?(v) - setup_rb_error "invalid option --#{@name}=#{val} (use #{@template})" - end - @action.call v, table - end - end - - class PackageSelectionItem < Item - def initialize(name, template, default, help_default, desc) - super name, template, default, desc - @help_default = help_default - end - - attr_reader :help_default - - def config_type - 'package' - end - - private - - def check(val) - unless File.dir?("packages/#{val}") - setup_rb_error "config: no such package: #{val}" - end - val - end - end - - class MetaConfigEnvironment - def initialize(config, installer) - @config = config - @installer = installer - end - - def config_names - @config.names - end - - def config?(name) - @config.key?(name) - end - - def bool_config?(name) - @config.lookup(name).config_type == 'bool' - end - - def path_config?(name) - @config.lookup(name).config_type == 'path' - end - - def value_config?(name) - @config.lookup(name).config_type != 'exec' - end - - def add_config(item) - @config.add item - end - - def add_bool_config(name, default, desc) - @config.add BoolItem.new(name, 'yes/no', default ? 'yes' : 'no', desc) - end - - def add_path_config(name, default, desc) - @config.add PathItem.new(name, 'path', default, desc) - end - - def set_config_default(name, default) - @config.lookup(name).default = default - end - - def remove_config(name) - @config.remove(name) - end - - # For only multipackage - def packages - raise '[setup.rb fatal] multi-package metaconfig API packages() called for single-package; contact application package vendor' unless @installer - @installer.packages - end - - # For only multipackage - def declare_packages(list) - raise '[setup.rb fatal] multi-package metaconfig API declare_packages() called for single-package; contact application package vendor' unless @installer - @installer.packages = list - end - end - -end # class ConfigTable - - -# This module requires: #verbose?, #no_harm? -module FileOperations - - def mkdir_p(dirname, prefix = nil) - dirname = prefix + File.expand_path(dirname) if prefix - $stderr.puts "mkdir -p #{dirname}" if verbose? - return if no_harm? - - # Does not check '/', it's too abnormal. - dirs = File.expand_path(dirname).split(%r<(?=/)>) - if /\A[a-z]:\z/i =~ dirs[0] - disk = dirs.shift - dirs[0] = disk + dirs[0] - end - dirs.each_index do |idx| - path = dirs[0..idx].join('') - Dir.mkdir path unless File.dir?(path) - end - end - - def rm_f(path) - $stderr.puts "rm -f #{path}" if verbose? - return if no_harm? - force_remove_file path - end - - def rm_rf(path) - $stderr.puts "rm -rf #{path}" if verbose? - return if no_harm? - remove_tree path - end - - def remove_tree(path) - if File.symlink?(path) - remove_file path - elsif File.dir?(path) - remove_tree0 path - else - force_remove_file path - end - end - - def remove_tree0(path) - Dir.foreach(path) do |ent| - next if ent == '.' - next if ent == '..' - entpath = "#{path}/#{ent}" - if File.symlink?(entpath) - remove_file entpath - elsif File.dir?(entpath) - remove_tree0 entpath - else - force_remove_file entpath - end - end - begin - Dir.rmdir path - rescue Errno::ENOTEMPTY - # directory may not be empty - end - end - - def move_file(src, dest) - force_remove_file dest - begin - File.rename src, dest - rescue - File.open(dest, 'wb') {|f| - f.write File.binread(src) - } - File.chmod File.stat(src).mode, dest - File.unlink src - end - end - - def force_remove_file(path) - begin - remove_file path - rescue - end - end - - def remove_file(path) - File.chmod 0777, path - File.unlink path - end - - def install(from, dest, mode, prefix = nil) - $stderr.puts "install #{from} #{dest}" if verbose? - return if no_harm? - - realdest = prefix ? prefix + File.expand_path(dest) : dest - realdest = File.join(realdest, File.basename(from)) if File.dir?(realdest) - str = File.binread(from) - if diff?(str, realdest) - verbose_off { - rm_f realdest if File.exist?(realdest) - } - File.open(realdest, 'wb') {|f| - f.write str - } - File.chmod mode, realdest - - File.open("#{objdir_root()}/InstalledFiles", 'a') {|f| - if prefix - f.puts realdest.sub(prefix, '') - else - f.puts realdest - end - } - end - end - - def diff?(new_content, path) - return true unless File.exist?(path) - new_content != File.binread(path) - end - - def command(*args) - $stderr.puts args.join(' ') if verbose? - system(*args) or raise RuntimeError, - "system(#{args.map{|a| a.inspect }.join(' ')}) failed" - end - - def ruby(*args) - command config('rubyprog'), *args - end - - def make(task = nil) - command(*[config('makeprog'), task].compact) - end - - def extdir?(dir) - File.exist?("#{dir}/MANIFEST") or File.exist?("#{dir}/extconf.rb") - end - - def files_of(dir) - Dir.open(dir) {|d| - return d.select {|ent| File.file?("#{dir}/#{ent}") } - } - end - - DIR_REJECT = %w( . .. CVS SCCS RCS CVS.adm .svn ) - - def directories_of(dir) - Dir.open(dir) {|d| - return d.select {|ent| File.dir?("#{dir}/#{ent}") } - DIR_REJECT - } - end - -end - - -# This module requires: #srcdir_root, #objdir_root, #relpath -module HookScriptAPI - - def get_config(key) - @config[key] - end - - alias config get_config - - # obsolete: use metaconfig to change configuration - def set_config(key, val) - @config[key] = val - end - - # - # srcdir/objdir (works only in the package directory) - # - - def curr_srcdir - "#{srcdir_root()}/#{relpath()}" - end - - def curr_objdir - "#{objdir_root()}/#{relpath()}" - end - - def srcfile(path) - "#{curr_srcdir()}/#{path}" - end - - def srcexist?(path) - File.exist?(srcfile(path)) - end - - def srcdirectory?(path) - File.dir?(srcfile(path)) - end - - def srcfile?(path) - File.file?(srcfile(path)) - end - - def srcentries(path = '.') - Dir.open("#{curr_srcdir()}/#{path}") {|d| - return d.to_a - %w(. ..) - } - end - - def srcfiles(path = '.') - srcentries(path).select {|fname| - File.file?(File.join(curr_srcdir(), path, fname)) - } - end - - def srcdirectories(path = '.') - srcentries(path).select {|fname| - File.dir?(File.join(curr_srcdir(), path, fname)) - } - end - -end - - -class ToplevelInstaller - - Version = '3.4.1' - Copyright = 'Copyright (c) 2000-2005 Minero Aoki' - - TASKS = [ - [ 'all', 'do config, setup, then install' ], - [ 'config', 'saves your configurations' ], - [ 'show', 'shows current configuration' ], - [ 'setup', 'compiles ruby extentions and others' ], - [ 'install', 'installs files' ], - [ 'test', 'run all tests in test/' ], - [ 'clean', "does `make clean' for each extention" ], - [ 'distclean',"does `make distclean' for each extention" ] - ] - - def ToplevelInstaller.invoke - config = ConfigTable.new(load_rbconfig()) - config.load_standard_entries - config.load_multipackage_entries if multipackage? - config.fixup - klass = (multipackage?() ? ToplevelInstallerMulti : ToplevelInstaller) - klass.new(File.dirname($0), config).invoke - end - - def ToplevelInstaller.multipackage? - File.dir?(File.dirname($0) + '/packages') - end - - def ToplevelInstaller.load_rbconfig - if arg = ARGV.detect {|arg| /\A--rbconfig=/ =~ arg } - ARGV.delete(arg) - load File.expand_path(arg.split(/=/, 2)[1]) - $".push 'rbconfig.rb' - else - require 'rbconfig' - end - ::Config::CONFIG - end - - def initialize(ardir_root, config) - @ardir = File.expand_path(ardir_root) - @config = config - # cache - @valid_task_re = nil - end - - def config(key) - @config[key] - end - - def inspect - "#<#{self.class} #{__id__()}>" - end - - def invoke - run_metaconfigs - case task = parsearg_global() - when nil, 'all' - parsearg_config - init_installers - exec_config - exec_setup - exec_install - else - case task - when 'config', 'test' - ; - when 'clean', 'distclean' - @config.load_savefile if File.exist?(@config.savefile) - else - @config.load_savefile - end - __send__ "parsearg_#{task}" - init_installers - __send__ "exec_#{task}" - end - end - - def run_metaconfigs - @config.load_script "#{@ardir}/metaconfig" - end - - def init_installers - @installer = Installer.new(@config, @ardir, File.expand_path('.')) - end - - # - # Hook Script API bases - # - - def srcdir_root - @ardir - end - - def objdir_root - '.' - end - - def relpath - '.' - end - - # - # Option Parsing - # - - def parsearg_global - while arg = ARGV.shift - case arg - when /\A\w+\z/ - setup_rb_error "invalid task: #{arg}" unless valid_task?(arg) - return arg - when '-q', '--quiet' - @config.verbose = false - when '--verbose' - @config.verbose = true - when '--help' - print_usage $stdout - exit 0 - when '--version' - puts "#{File.basename($0)} version #{Version}" - exit 0 - when '--copyright' - puts Copyright - exit 0 - else - setup_rb_error "unknown global option '#{arg}'" - end - end - nil - end - - def valid_task?(t) - valid_task_re() =~ t - end - - def valid_task_re - @valid_task_re ||= /\A(?:#{TASKS.map {|task,desc| task }.join('|')})\z/ - end - - def parsearg_no_options - unless ARGV.empty? - task = caller(0).first.slice(%r<`parsearg_(\w+)'>, 1) - setup_rb_error "#{task}: unknown options: #{ARGV.join(' ')}" - end - end - - alias parsearg_show parsearg_no_options - alias parsearg_setup parsearg_no_options - alias parsearg_test parsearg_no_options - alias parsearg_clean parsearg_no_options - alias parsearg_distclean parsearg_no_options - - def parsearg_config - evalopt = [] - set = [] - @config.config_opt = [] - while i = ARGV.shift - if /\A--?\z/ =~ i - @config.config_opt = ARGV.dup - break - end - name, value = *@config.parse_opt(i) - if @config.value_config?(name) - @config[name] = value - else - evalopt.push [name, value] - end - set.push name - end - evalopt.each do |name, value| - @config.lookup(name).evaluate value, @config - end - # Check if configuration is valid - set.each do |n| - @config[n] if @config.value_config?(n) - end - end - - def parsearg_install - @config.no_harm = false - @config.install_prefix = '' - while a = ARGV.shift - case a - when '--no-harm' - @config.no_harm = true - when /\A--prefix=/ - path = a.split(/=/, 2)[1] - path = File.expand_path(path) unless path[0,1] == '/' - @config.install_prefix = path - else - setup_rb_error "install: unknown option #{a}" - end - end - end - - def print_usage(out) - out.puts 'Typical Installation Procedure:' - out.puts " $ ruby #{File.basename $0} config" - out.puts " $ ruby #{File.basename $0} setup" - out.puts " # ruby #{File.basename $0} install (may require root privilege)" - out.puts - out.puts 'Detailed Usage:' - out.puts " ruby #{File.basename $0} <global option>" - out.puts " ruby #{File.basename $0} [<global options>] <task> [<task options>]" - - fmt = " %-24s %s\n" - out.puts - out.puts 'Global options:' - out.printf fmt, '-q,--quiet', 'suppress message outputs' - out.printf fmt, ' --verbose', 'output messages verbosely' - out.printf fmt, ' --help', 'print this message' - out.printf fmt, ' --version', 'print version and quit' - out.printf fmt, ' --copyright', 'print copyright and quit' - out.puts - out.puts 'Tasks:' - TASKS.each do |name, desc| - out.printf fmt, name, desc - end - - fmt = " %-24s %s [%s]\n" - out.puts - out.puts 'Options for CONFIG or ALL:' - @config.each do |item| - out.printf fmt, item.help_opt, item.description, item.help_default - end - out.printf fmt, '--rbconfig=path', 'rbconfig.rb to load',"running ruby's" - out.puts - out.puts 'Options for INSTALL:' - out.printf fmt, '--no-harm', 'only display what to do if given', 'off' - out.printf fmt, '--prefix=path', 'install path prefix', '' - out.puts - end - - # - # Task Handlers - # - - def exec_config - @installer.exec_config - @config.save # must be final - end - - def exec_setup - @installer.exec_setup - end - - def exec_install - @installer.exec_install - end - - def exec_test - @installer.exec_test - end - - def exec_show - @config.each do |i| - printf "%-20s %s\n", i.name, i.value if i.value? - end - end - - def exec_clean - @installer.exec_clean - end - - def exec_distclean - @installer.exec_distclean - end - -end # class ToplevelInstaller - - -class ToplevelInstallerMulti < ToplevelInstaller - - include FileOperations - - def initialize(ardir_root, config) - super - @packages = directories_of("#{@ardir}/packages") - raise 'no package exists' if @packages.empty? - @root_installer = Installer.new(@config, @ardir, File.expand_path('.')) - end - - def run_metaconfigs - @config.load_script "#{@ardir}/metaconfig", self - @packages.each do |name| - @config.load_script "#{@ardir}/packages/#{name}/metaconfig" - end - end - - attr_reader :packages - - def packages=(list) - raise 'package list is empty' if list.empty? - list.each do |name| - raise "directory packages/#{name} does not exist"\ - unless File.dir?("#{@ardir}/packages/#{name}") - end - @packages = list - end - - def init_installers - @installers = {} - @packages.each do |pack| - @installers[pack] = Installer.new(@config, - "#{@ardir}/packages/#{pack}", - "packages/#{pack}") - end - with = extract_selection(config('with')) - without = extract_selection(config('without')) - @selected = @installers.keys.select {|name| - (with.empty? or with.include?(name)) \ - and not without.include?(name) - } - end - - def extract_selection(list) - a = list.split(/,/) - a.each do |name| - setup_rb_error "no such package: #{name}" unless @installers.key?(name) - end - a - end - - def print_usage(f) - super - f.puts 'Inluded packages:' - f.puts ' ' + @packages.sort.join(' ') - f.puts - end - - # - # Task Handlers - # - - def exec_config - run_hook 'pre-config' - each_selected_installers {|inst| inst.exec_config } - run_hook 'post-config' - @config.save # must be final - end - - def exec_setup - run_hook 'pre-setup' - each_selected_installers {|inst| inst.exec_setup } - run_hook 'post-setup' - end - - def exec_install - run_hook 'pre-install' - each_selected_installers {|inst| inst.exec_install } - run_hook 'post-install' - end - - def exec_test - run_hook 'pre-test' - each_selected_installers {|inst| inst.exec_test } - run_hook 'post-test' - end - - def exec_clean - rm_f @config.savefile - run_hook 'pre-clean' - each_selected_installers {|inst| inst.exec_clean } - run_hook 'post-clean' - end - - def exec_distclean - rm_f @config.savefile - run_hook 'pre-distclean' - each_selected_installers {|inst| inst.exec_distclean } - run_hook 'post-distclean' - end - - # - # lib - # - - def each_selected_installers - Dir.mkdir 'packages' unless File.dir?('packages') - @selected.each do |pack| - $stderr.puts "Processing the package `#{pack}' ..." if verbose? - Dir.mkdir "packages/#{pack}" unless File.dir?("packages/#{pack}") - Dir.chdir "packages/#{pack}" - yield @installers[pack] - Dir.chdir '../..' - end - end - - def run_hook(id) - @root_installer.run_hook id - end - - # module FileOperations requires this - def verbose? - @config.verbose? - end - - # module FileOperations requires this - def no_harm? - @config.no_harm? - end - -end # class ToplevelInstallerMulti - - -class Installer - - FILETYPES = %w( bin lib ext data conf man ) - - include FileOperations - include HookScriptAPI - - def initialize(config, srcroot, objroot) - @config = config - @srcdir = File.expand_path(srcroot) - @objdir = File.expand_path(objroot) - @currdir = '.' - end - - def inspect - "#<#{self.class} #{File.basename(@srcdir)}>" - end - - def noop(rel) - end - - # - # Hook Script API base methods - # - - def srcdir_root - @srcdir - end - - def objdir_root - @objdir - end - - def relpath - @currdir - end - - # - # Config Access - # - - # module FileOperations requires this - def verbose? - @config.verbose? - end - - # module FileOperations requires this - def no_harm? - @config.no_harm? - end - - def verbose_off - begin - save, @config.verbose = @config.verbose?, false - yield - ensure - @config.verbose = save - end - end - - # - # TASK config - # - - def exec_config - exec_task_traverse 'config' - end - - alias config_dir_bin noop - alias config_dir_lib noop - - def config_dir_ext(rel) - extconf if extdir?(curr_srcdir()) - end - - alias config_dir_data noop - alias config_dir_conf noop - alias config_dir_man noop - - def extconf - ruby "#{curr_srcdir()}/extconf.rb", *@config.config_opt - end - - # - # TASK setup - # - - def exec_setup - exec_task_traverse 'setup' - end - - def setup_dir_bin(rel) - files_of(curr_srcdir()).each do |fname| - update_shebang_line "#{curr_srcdir()}/#{fname}" - end - end - - alias setup_dir_lib noop - - def setup_dir_ext(rel) - make if extdir?(curr_srcdir()) - end - - alias setup_dir_data noop - alias setup_dir_conf noop - alias setup_dir_man noop - - def update_shebang_line(path) - return if no_harm? - return if config('shebang') == 'never' - old = Shebang.load(path) - if old - $stderr.puts "warning: #{path}: Shebang line includes too many args. It is not portable and your program may not work." if old.args.size > 1 - new = new_shebang(old) - return if new.to_s == old.to_s - else - return unless config('shebang') == 'all' - new = Shebang.new(config('rubypath')) - end - $stderr.puts "updating shebang: #{File.basename(path)}" if verbose? - open_atomic_writer(path) {|output| - File.open(path, 'rb') {|f| - f.gets if old # discard - output.puts new.to_s - output.print f.read - } - } - end - - def new_shebang(old) - if /\Aruby/ =~ File.basename(old.cmd) - Shebang.new(config('rubypath'), old.args) - elsif File.basename(old.cmd) == 'env' and old.args.first == 'ruby' - Shebang.new(config('rubypath'), old.args[1..-1]) - else - return old unless config('shebang') == 'all' - Shebang.new(config('rubypath')) - end - end - - def open_atomic_writer(path, &block) - tmpfile = File.basename(path) + '.tmp' - begin - File.open(tmpfile, 'wb', &block) - File.rename tmpfile, File.basename(path) - ensure - File.unlink tmpfile if File.exist?(tmpfile) - end - end - - class Shebang - def Shebang.load(path) - line = nil - File.open(path) {|f| - line = f.gets - } - return nil unless /\A#!/ =~ line - parse(line) - end - - def Shebang.parse(line) - cmd, *args = *line.strip.sub(/\A\#!/, '').split(' ') - new(cmd, args) - end - - def initialize(cmd, args = []) - @cmd = cmd - @args = args - end - - attr_reader :cmd - attr_reader :args - - def to_s - "#! #{@cmd}" + (@args.empty? ? '' : " #{@args.join(' ')}") - end - end - - # - # TASK install - # - - def exec_install - rm_f 'InstalledFiles' - exec_task_traverse 'install' - end - - def install_dir_bin(rel) - install_files targetfiles(), "#{config('bindir')}/#{rel}", 0755 - end - - def install_dir_lib(rel) - install_files libfiles(), "#{config('rbdir')}/#{rel}", 0644 - end - - def install_dir_ext(rel) - return unless extdir?(curr_srcdir()) - install_files rubyextentions('.'), - "#{config('sodir')}/#{File.dirname(rel)}", - 0555 - end - - def install_dir_data(rel) - install_files targetfiles(), "#{config('datadir')}/#{rel}", 0644 - end - - def install_dir_conf(rel) - # FIXME: should not remove current config files - # (rename previous file to .old/.org) - install_files targetfiles(), "#{config('sysconfdir')}/#{rel}", 0644 - end - - def install_dir_man(rel) - install_files targetfiles(), "#{config('mandir')}/#{rel}", 0644 - end - - def install_files(list, dest, mode) - mkdir_p dest, @config.install_prefix - list.each do |fname| - install fname, dest, mode, @config.install_prefix - end - end - - def libfiles - glob_reject(%w(*.y *.output), targetfiles()) - end - - def rubyextentions(dir) - ents = glob_select("*.#{@config.dllext}", targetfiles()) - if ents.empty? - setup_rb_error "no ruby extention exists: 'ruby #{$0} setup' first" - end - ents - end - - def targetfiles - mapdir(existfiles() - hookfiles()) - end - - def mapdir(ents) - ents.map {|ent| - if File.exist?(ent) - then ent # objdir - else "#{curr_srcdir()}/#{ent}" # srcdir - end - } - end - - # picked up many entries from cvs-1.11.1/src/ignore.c - JUNK_FILES = %w( - core RCSLOG tags TAGS .make.state - .nse_depinfo #* .#* cvslog.* ,* .del-* *.olb - *~ *.old *.bak *.BAK *.orig *.rej _$* *$ - - *.org *.in .* - ) - - def existfiles - glob_reject(JUNK_FILES, (files_of(curr_srcdir()) | files_of('.'))) - end - - def hookfiles - %w( pre-%s post-%s pre-%s.rb post-%s.rb ).map {|fmt| - %w( config setup install clean ).map {|t| sprintf(fmt, t) } - }.flatten - end - - def glob_select(pat, ents) - re = globs2re([pat]) - ents.select {|ent| re =~ ent } - end - - def glob_reject(pats, ents) - re = globs2re(pats) - ents.reject {|ent| re =~ ent } - end - - GLOB2REGEX = { - '.' => '\.', - '$' => '\$', - '#' => '\#', - '*' => '.*' - } - - def globs2re(pats) - /\A(?:#{ - pats.map {|pat| pat.gsub(/[\.\$\#\*]/) {|ch| GLOB2REGEX[ch] } }.join('|') - })\z/ - end - - # - # TASK test - # - - TESTDIR = 'test' - - def exec_test - unless File.directory?('test') - $stderr.puts 'no test in this package' if verbose? - return - end - $stderr.puts 'Running tests...' if verbose? - begin - require 'test/unit' - rescue LoadError - setup_rb_error 'test/unit cannot loaded. You need Ruby 1.8 or later to invoke this task.' - end - runner = Test::Unit::AutoRunner.new(true) - runner.to_run << TESTDIR - runner.run - end - - # - # TASK clean - # - - def exec_clean - exec_task_traverse 'clean' - rm_f @config.savefile - rm_f 'InstalledFiles' - end - - alias clean_dir_bin noop - alias clean_dir_lib noop - alias clean_dir_data noop - alias clean_dir_conf noop - alias clean_dir_man noop - - def clean_dir_ext(rel) - return unless extdir?(curr_srcdir()) - make 'clean' if File.file?('Makefile') - end - - # - # TASK distclean - # - - def exec_distclean - exec_task_traverse 'distclean' - rm_f @config.savefile - rm_f 'InstalledFiles' - end - - alias distclean_dir_bin noop - alias distclean_dir_lib noop - - def distclean_dir_ext(rel) - return unless extdir?(curr_srcdir()) - make 'distclean' if File.file?('Makefile') - end - - alias distclean_dir_data noop - alias distclean_dir_conf noop - alias distclean_dir_man noop - - # - # Traversing - # - - def exec_task_traverse(task) - run_hook "pre-#{task}" - FILETYPES.each do |type| - if type == 'ext' and config('without-ext') == 'yes' - $stderr.puts 'skipping ext/* by user option' if verbose? - next - end - traverse task, type, "#{task}_dir_#{type}" - end - run_hook "post-#{task}" - end - - def traverse(task, rel, mid) - dive_into(rel) { - run_hook "pre-#{task}" - __send__ mid, rel.sub(%r[\A.*?(?:/|\z)], '') - directories_of(curr_srcdir()).each do |d| - traverse task, "#{rel}/#{d}", mid - end - run_hook "post-#{task}" - } - end - - def dive_into(rel) - return unless File.dir?("#{@srcdir}/#{rel}") - - dir = File.basename(rel) - Dir.mkdir dir unless File.dir?(dir) - prevdir = Dir.pwd - Dir.chdir dir - $stderr.puts '---> ' + rel if verbose? - @currdir = rel - yield - Dir.chdir prevdir - $stderr.puts '<--- ' + rel if verbose? - @currdir = File.dirname(rel) - end - - def run_hook(id) - path = [ "#{curr_srcdir()}/#{id}", - "#{curr_srcdir()}/#{id}.rb" ].detect {|cand| File.file?(cand) } - return unless path - begin - instance_eval File.read(path), path, 1 - rescue - raise if $DEBUG - setup_rb_error "hook #{path} failed:\n" + $!.message - end - end - -end # class Installer - - -class SetupError < StandardError; end - -def setup_rb_error(msg) - raise SetupError, msg -end - -if $0 == __FILE__ - begin - ToplevelInstaller.invoke - rescue SetupError - raise if $DEBUG - $stderr.puts $!.message - $stderr.puts "Try 'ruby #{$0} --help' for detailed usage." - exit 1 - end -end diff --git a/pre-config.rb.erb b/pre-config.rb.erb deleted file mode 100755 index 0fd088b..0000000 --- a/pre-config.rb.erb +++ /dev/null @@ -1,111 +0,0 @@ -# Which directories to search? -def search_directories - dirs = [ - "/usr/include/fox-1.6", - "/usr/local/include/fox-1.6", - "/sw/include/fox-1.6", - "/opt/local/include/fox-1.6" - ] - ARGV.each do |arg| - if arg =~ /--with-fox-include/ - option, value = arg.split('=') - dirs = [ value ] + dirs - dirs.uniq! # remove duplicates - end - end - dirs -end - -# Return true if found in any of the search directories -def fox_include_files_found? - search_directories.each do |path| - filename = File.join(path, "fxver.h") - return true if FileTest.exist?(filename) - end - false -end - -# Read installed FOX version info from fxver.h include file -def read_fox_version(filename) - foxMajor, foxMinor, foxLevel = nil, nil, nil - File.foreach(filename) do |line| - if line =~ /FOX_MAJOR/ - foxMajor = line.split()[2] - elsif line =~ /FOX_MINOR/ - foxMinor = line.split()[2] - elsif line =~ /FOX_LEVEL/ - foxLevel = line.split()[2] - end - end - [foxMajor, foxMinor, foxLevel] -end - -# Returns a string (e.g. "1.0.36") indicating the installed version of FOX. -def installed_fox_version - search_directories.each do |path| - filename = File.join(path, "fxver.h") - if FileTest.exist?(filename) - foxMajor, foxMinor, foxLevel = read_fox_version(filename) - return [foxMajor, foxMinor, foxLevel].join('.') - end - end - raise RuntimeError, "couldn't find FOX header files" -end - -# -# Confirm that FOX is installed; check for an "fxver.h" -# include file in the directory specified via the -# --with-fox-include command line argument (if any), -# as well as /usr/include/fox-1.6, /usr/local/include/fox-1.6 and -# /sw/include/fox-1.6. -# -unless fox_include_files_found? - puts "" - puts " **********************************************************************" - puts " * Hey! *" - puts " * Where is FOX installed? *" - puts " * *" - puts " * I couldn't locate 'fxver.h' in any of the following directories: *" - puts " * *" - search_directories.each { |incdir| puts " * #{incdir}" } - puts " * *" - puts " * Please specify the locations for the FOX header files and library *" - puts " * using the --with-fox-include and --with-fox-lib options to *" - puts " * extconf.rb as described in the FXRuby installation instructions. *" - puts " **********************************************************************" - puts "" - exit -end - -# -# Stable releases of FXRuby (i.e. FXRuby-1.0.x) should go with stable releases -# of FOX (i.e. fox-1.0.x) but it's only necessary for the major and minor version -# numbers to match. For example, FXRuby-1.0.22 should work fine with fox-1.0.40. -# -# Development releases of FXRuby (e.g. FXRuby-1.1.65) must go with a specific -# development version of FOX, usually the one with the same version number -# (e.g. fox-1.1.65). All three version numbers must match. -# - -instMajor, instMinor, instLevel = installed_fox_version().split('.') -thisMajor, thisMinor, thisLevel = "<%= FOX_VERSION %>".split('.') - -expecting_stable_fox_release = ((thisMinor.to_i % 2) == 0) -if expecting_stable_fox_release - if (instMinor != thisMinor) - puts "" - puts " ********************************************************" - puts " * This version of FXRuby (<%= PKG_VERSION %>) must be built against" - puts " * one of the stable releases of FOX, but it appears that" - puts " * you have a development version of FOX (version #{installed_fox_version})" - puts " * installed instead. Please download and install one of" - puts " * the stable releases of FOX first, and then try again." - puts " ********************************************************" - puts "" - exit - end -else - # Minor version number is odd, so it's a development release - raise RuntimeError unless ((instMajor == thisMajor) && (instMinor == thisMinor) && (instLevel == thisLevel)) -end - diff --git a/scripts/FXRuby.iss.erb b/scripts/FXRuby.iss.erb deleted file mode 100755 index 2a468a1..0000000 --- a/scripts/FXRuby.iss.erb +++ /dev/null @@ -1,81 +0,0 @@ -; Script generated by the Inno Setup Script Wizard. -; SEE THE DOCUMENTATION FOR DETAILS ON CREATING INNO SETUP SCRIPT FILES! - -[Setup] -AppName=FXRuby -AppVerName=FXRuby <%= PKG_VERSION %> -AppPublisherURL=<%= FXRUBY_HOME_URL %> -AppSupportURL=<%= FXRUBY_HOME_URL %> -AppUpdatesURL=<%= FXRUBY_HOME_URL %> -DefaultDirName=C:\ruby -DefaultGroupName=FXRuby -AllowNoIcons=no -LicenseFile=LICENSE -InfoBeforeFile=README.win32.txt -OutputDir=. -OutputBaseFilename=FXRuby-<%= PKG_VERSION %>-<%= info[1] %> - -[Files] -; readme files -Source: "LICENSE"; DestDir: "{app}\doc\FXRuby"; Flags: ignoreversion -Source: "README.win32.txt"; DestDir: "{app}\doc\FXRuby"; Flags: ignoreversion -Source: "README"; DestDir: "{app}\doc\FXRuby"; Flags: ignoreversion -; HTML documentation files -Source: "doc\*.html"; DestDir: "{app}\doc\FXRuby\doc"; Flags: ignoreversion -Source: "doc\images\*.png"; DestDir: "{app}\doc\FXRuby\doc\images"; Flags: ignoreversion -; unit tests -Source: "tests\README"; DestDir: "{app}\doc\FXRuby\tests"; Flags: ignoreversion -Source: "tests\*.rb"; DestDir: "{app}\doc\FXRuby\tests"; Flags: ignoreversion -Source: "tests\*.ps"; DestDir: "{app}\doc\FXRuby\tests"; Flags: ignoreversion -; main extension shared library -Source: "ext\fox16\fox16.so"; DestDir: "{app}\lib\ruby\site_ruby\<%= info[0] %>\<%= info[2] %>; Flags: ignoreversion -; library files -Source: "lib\fox16\*.rb"; DestDir: "{app}\lib\ruby\site_ruby\<%= info[0] %>\fox16"; Flags: ignoreversion -; samples -Source: "examples\README"; DestDir: "{app}\samples\FXRuby"; Flags: ignoreversion -Source: "examples\babelfish.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "babelfish.rbw"; Flags: ignoreversion -Source: "examples\bounce.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "bounce.rbw"; Flags: ignoreversion -Source: "examples\browser.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "browser.rbw"; Flags: ignoreversion -Source: "examples\button.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "button.rbw"; Flags: ignoreversion -Source: "examples\datatarget.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "datatarget.rbw"; Flags: ignoreversion -Source: "examples\dctest.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "dctest.rbw"; Flags: ignoreversion -Source: "examples\dialog.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "dialog.rbw"; Flags: ignoreversion -Source: "examples\dilbert.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "dilbert.rbw"; Flags: ignoreversion -Source: "examples\dirlist.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "dirlist.rbw"; Flags: ignoreversion -Source: "examples\dragdrop.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "dragdrop.rbw"; Flags: ignoreversion -Source: "examples\dragsource.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "dragsource.rbw"; Flags: ignoreversion -Source: "examples\dropsite.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "dropsite.rbw"; Flags: ignoreversion -Source: "examples\foursplit.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "foursplit.rbw"; Flags: ignoreversion -Source: "examples\gltest.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "gltest.rbw"; Flags: ignoreversion -Source: "examples\glviewer.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "glviewer.rbw"; Flags: ignoreversion -Source: "examples\groupbox.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "groupbox.rbw"; Flags: ignoreversion -Source: "examples\header.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "header.rbw"; Flags: ignoreversion -Source: "examples\hello.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "hello.rbw"; Flags: ignoreversion -Source: "examples\hello2.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "hello2.rbw"; Flags: ignoreversion -Source: "examples\iconlist.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "iconlist.rbw"; Flags: ignoreversion -Source: "examples\image.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "image.rbw"; Flags: ignoreversion -Source: "examples\imageviewer.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "imageviewer.rbw"; Flags: ignoreversion -Source: "examples\inputs.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "inputs.rbw"; Flags: ignoreversion -Source: "examples\mditest.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "mditest.rbw"; Flags: ignoreversion -Source: "examples\pig.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "pig.rbw"; Flags: ignoreversion -Source: "examples\iRAA.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "iRAA.rb"; Flags: ignoreversion -Source: "examples\RAA.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "RAA.rb"; Flags: ignoreversion -Source: "examples\raabrowser.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "raabrowser.rbw"; Flags: ignoreversion -Source: "examples\ratio.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "ratio.rbw"; Flags: ignoreversion -Source: "examples\scintilla-test.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "scintilla-test.rbw"; Flags: ignoreversion -Source: "examples\scribble.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "scribble.rbw"; Flags: ignoreversion -Source: "examples\scribble-orig.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "scribble-orig.rbw"; Flags: ignoreversion -Source: "examples\shutter.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "shutter.rbw"; Flags: ignoreversion -Source: "examples\splitter.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "splitter.rbw"; Flags: ignoreversion -Source: "examples\styledtext.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "styledtext.rbw"; Flags: ignoreversion -Source: "examples\tabbook.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "tabbook.rbw"; Flags: ignoreversion -Source: "examples\table.rb"; DestDir: "{app}\samples\FXRuby"; DestName: "table.rbw"; Flags: ignoreversion -; textedit example files -Source: "examples\textedit\commands.rb"; DestDir: "{app}\samples\FXRuby\textedit"; Flags: ignoreversion -Source: "examples\textedit\helpwindow.rb"; DestDir: "{app}\samples\FXRuby\textedit"; Flags: ignoreversion -Source: "examples\textedit\prefdialog.rb"; DestDir: "{app}\samples\FXRuby\textedit"; Flags: ignoreversion -Source: "examples\textedit\textedit.rb"; DestDir: "{app}\samples\FXRuby\textedit"; DestName: "textedit.rbw"; Flags: ignoreversion -; icons for samples -Source: "examples\icons\*.ico"; DestDir: "{app}\samples\FXRuby\icons"; Flags: ignoreversion -Source: "examples\icons\*.png"; DestDir: "{app}\samples\FXRuby\icons"; Flags: ignoreversion - diff --git a/scripts/make-installers.rb.erb b/scripts/make-installers.rb.erb deleted file mode 100755 index 7e7de01..0000000 --- a/scripts/make-installers.rb.erb +++ /dev/null @@ -1,84 +0,0 @@ -require 'ftools' -require 'net/ftp' - -# Arguments passed to config stage of setup -config_args = [ - "--make-prog=nmake", - "--", - "--with-fox-include=c:\\src\\fox-1.6.4\\include", - "--with-fox-lib=c:\\src\\fox-1.6.4\\lib", - "--with-fxscintilla-include=c:\\src\\fxscintilla-1.63-fox1.6\\include", - "--with-fxscintilla-lib=c:\\src\\fxscintilla-1.63-fox1.6\\lib" -] - -# Inno Setup command-line compiler -ISCC = "C:\\Progra~1\\InnoSe~1\\ISCC.exe" - -def untar(fxruby_version) - tarfile = "../ftp/FXRuby-#{fxruby_version}.tar.gz" - dirname1 = "FXRuby-#{fxruby_version}" - dirname2 = "FXRuby-#{fxruby_version}-ruby#{VERSION}" - if File.exists? dirname1 - system("rm", "-r", dirname1) - end - if File.exists? dirname2 - system("rm", "-r", dirname2) - end - system("tar", "xzf", tarfile) - puts "File.mv(#{dirname1}, #{dirname2})" - File.mv(dirname1, dirname2) -end - -def copy_installer_script(fxruby_version) - iss_filename = nil - case VERSION - when /1.6/ - iss_filename = "FXRuby-ruby1.6-i586-mswin32.iss" - when /1.8.2/ - iss_filename = "FXRuby-ruby1.8.2-i386-msvcrt.iss" - when /1.8.4/ - iss_filename = "FXRuby-ruby1.8.4-i386-msvcrt.iss" - end - dir = "FXRuby-#{fxruby_version}-ruby#{VERSION}" - [iss_filename, dir] -end - -def do_config(args) - ruby = "C:\\ruby-#{VERSION}\\bin\\ruby.exe" - system(ruby, "install.rb", "config", *args) -end - -def do_setup - ruby = "C:\\ruby-#{VERSION}\\bin\\ruby.exe" - system(ruby, "install.rb", "setup") -end - -def do_inno_setup(scriptname) - system(ISCC, scriptname) -end - -def do_upload(fxruby_version) - file = nil - case VERSION - when /1.6.8/ - file = "FXRuby-#{fxruby_version}-ruby168.exe" - when /1.8.2/ - file = "FXRuby-#{fxruby_version}-ruby182.exe" - when /1.8.4/ - file = "FXRuby-#{fxruby_version}-ruby184.exe" - end - ftp = Net::FTP.open('upload.sourceforge.net', 'ftp', 'lyle@rubyforge.org') - ftp.putbinaryfile(file, "/incoming/" + file) - ftp.close -end - -if __FILE__ == $0 - fxruby_version = "<%= PKG_VERSION %>" - untar(fxruby_version) - iss_filename, dir = copy_installer_script(fxruby_version) - Dir.chdir(dir) - do_config(config_args) - do_setup - do_inno_setup(iss_filename) -# do_upload(fxruby_version) -end diff --git a/scripts/make-win32-tarball.sh b/scripts/make-win32-tarball.sh deleted file mode 100755 index dd0dad7..0000000 --- a/scripts/make-win32-tarball.sh +++ /dev/null @@ -1,5 +0,0 @@ -tar cvzf FXRuby-1.0.28-ruby1.8.1.tar.gz \ - doc/FXRuby \ - lib/ruby/site_ruby/1.8/i386-msvcrt/fox.so \ - lib/ruby/site_ruby/1.8/fox \ - samples/FXRuby diff --git a/scripts/opengl-cygwin.iss b/scripts/opengl-cygwin.iss deleted file mode 100755 index da508c6..0000000 --- a/scripts/opengl-cygwin.iss +++ /dev/null @@ -1,74 +0,0 @@ -; Script generated by the Inno Setup Script Wizard. -; SEE THE DOCUMENTATION FOR DETAILS ON CREATING INNO SETUP SCRIPT FILES! - -[Setup] -AppName=Ruby/OpenGL -AppVerName=Ruby/OpenGL 0.32b -AppPublisher=Yoshiyuki Kusano -AppPublisherURL=http://www2.giganet.net/~yoshi -AppSupportURL=http://www2.giganet.net/~yoshi -AppUpdatesURL=http://www2.giganet.net/~yoshi -DefaultDirName=C:\ruby -DefaultGroupName=Ruby/OpenGL -AllowNoIcons=no -OutputDir=. -OutputBaseFilename=rbogl-0.32b-cygwin32 -; uncomment the following line if you want your installation to run on NT 3.51 too. -; MinVersion=4,3.51 - -[Files] -; main extension files -Source: "opengl.so"; DestDir: "{app}\lib\ruby\site_ruby\1.6\i386-cygwin"; CopyMode: alwaysoverwrite -Source: "glut.so"; DestDir: "{app}\lib\ruby\site_ruby\1.6\i386-cygwin"; CopyMode: alwaysoverwrite -; documents -Source: "ChangeLog"; DestDir: "{app}\doc\ruby\opengl"; CopyMode: alwaysoverwrite -Source: "README.EUC"; DestDir: "{app}\doc\ruby\opengl"; CopyMode: alwaysoverwrite -; samples -Source: "sample\aaindex.rb"; DestDir: "{app}\samples\opengl"; DestName: "aaindex.rbw"; CopyMode: alwaysoverwrite -Source: "sample\aapoly.rb"; DestDir: "{app}\samples\opengl"; DestName: "aapoly.rbw"; CopyMode: alwaysoverwrite -Source: "sample\aargb.rb"; DestDir: "{app}\samples\opengl"; DestName: "aargb.rbw"; CopyMode: alwaysoverwrite -Source: "sample\accanti.rb"; DestDir: "{app}\samples\opengl"; DestName: "accanti.rbw"; CopyMode: alwaysoverwrite -Source: "sample\accpersp.rb"; DestDir: "{app}\samples\opengl"; DestName: "accpersp.rbw"; CopyMode: alwaysoverwrite -Source: "sample\alpha.rb"; DestDir: "{app}\samples\opengl"; DestName: "alpha.rbw"; CopyMode: alwaysoverwrite -Source: "sample\alpha3D.rb"; DestDir: "{app}\samples\opengl"; DestName: "alpha3D.rbw"; CopyMode: alwaysoverwrite -Source: "sample\bezcurve.rb"; DestDir: "{app}\samples\opengl"; DestName: "bezcurve.rbw"; CopyMode: alwaysoverwrite -Source: "sample\bezmesh.rb"; DestDir: "{app}\samples\opengl"; DestName: "bezmesh.rbw"; CopyMode: alwaysoverwrite -Source: "sample\checker.rb"; DestDir: "{app}\samples\opengl"; DestName: "checker.rbw"; CopyMode: alwaysoverwrite -Source: "sample\clip.rb"; DestDir: "{app}\samples\opengl"; DestName: "clip.rbw"; CopyMode: alwaysoverwrite -Source: "sample\colormat.rb"; DestDir: "{app}\samples\opengl"; DestName: "colormat.rbw"; CopyMode: alwaysoverwrite -Source: "sample\cube.rb"; DestDir: "{app}\samples\opengl"; DestName: "cube.rbw"; CopyMode: alwaysoverwrite -Source: "sample\depthcue.rb"; DestDir: "{app}\samples\opengl"; DestName: "depthcue.rbw"; CopyMode: alwaysoverwrite -Source: "sample\dof.rb"; DestDir: "{app}\samples\opengl"; DestName: "dof.rbw"; CopyMode: alwaysoverwrite -Source: "sample\double.rb"; DestDir: "{app}\samples\opengl"; DestName: "double.rbw"; CopyMode: alwaysoverwrite -Source: "sample\drawf.rb"; DestDir: "{app}\samples\opengl"; DestName: "drawf.rbw"; CopyMode: alwaysoverwrite -Source: "sample\feedback.rb"; DestDir: "{app}\samples\opengl"; DestName: "feedback.rbw"; CopyMode: alwaysoverwrite -Source: "sample\fog.rb"; DestDir: "{app}\samples\opengl"; DestName: "fog.rbw"; CopyMode: alwaysoverwrite -Source: "sample\font.rb"; DestDir: "{app}\samples\opengl"; DestName: "font.rbw"; CopyMode: alwaysoverwrite -Source: "sample\hello.rb"; DestDir: "{app}\samples\opengl"; DestName: "hello.rbw"; CopyMode: alwaysoverwrite -Source: "sample\image.rb"; DestDir: "{app}\samples\opengl"; DestName: "image.rbw"; CopyMode: alwaysoverwrite -Source: "sample\jitter.rb"; DestDir: "{app}\samples\opengl"; DestName: "jitter.rbw"; CopyMode: alwaysoverwrite -Source: "sample\lines.rb"; DestDir: "{app}\samples\opengl"; DestName: "lines.rbw"; CopyMode: alwaysoverwrite -Source: "sample\list.rb"; DestDir: "{app}\samples\opengl"; DestName: "list.rbw"; CopyMode: alwaysoverwrite -Source: "sample\material.rb"; DestDir: "{app}\samples\opengl"; DestName: "material.rbw"; CopyMode: alwaysoverwrite -Source: "sample\mipmap.rb"; DestDir: "{app}\samples\opengl"; DestName: "mipmap.rbw"; CopyMode: alwaysoverwrite -Source: "sample\model.rb"; DestDir: "{app}\samples\opengl"; DestName: "model.rbw"; CopyMode: alwaysoverwrite -Source: "sample\movelight.rb"; DestDir: "{app}\samples\opengl"; DestName: "movelight.rbw"; CopyMode: alwaysoverwrite -Source: "sample\pickdepth.rb"; DestDir: "{app}\samples\opengl"; DestName: "pickdepth.rbw"; CopyMode: alwaysoverwrite -Source: "sample\plane.rb"; DestDir: "{app}\samples\opengl"; DestName: "plane.rbw"; CopyMode: alwaysoverwrite -Source: "sample\planet.rb"; DestDir: "{app}\samples\opengl"; DestName: "planet.rbw"; CopyMode: alwaysoverwrite -Source: "sample\quadric.rb"; DestDir: "{app}\samples\opengl"; DestName: "quadric.rbw"; CopyMode: alwaysoverwrite -Source: "sample\robot.rb"; DestDir: "{app}\samples\opengl"; DestName: "robot.rbw"; CopyMode: alwaysoverwrite -Source: "sample\select.rb"; DestDir: "{app}\samples\opengl"; DestName: "select.rbw"; CopyMode: alwaysoverwrite -Source: "sample\smooth.rb"; DestDir: "{app}\samples\opengl"; DestName: "smooth.rbw"; CopyMode: alwaysoverwrite -Source: "sample\stencil.rb"; DestDir: "{app}\samples\opengl"; DestName: "stencil.rbw"; CopyMode: alwaysoverwrite -Source: "sample\stroke.rb"; DestDir: "{app}\samples\opengl"; DestName: "stroke.rbw"; CopyMode: alwaysoverwrite -Source: "sample\surface.rb"; DestDir: "{app}\samples\opengl"; DestName: "surface.rbw"; CopyMode: alwaysoverwrite -Source: "sample\teaambient.rb"; DestDir: "{app}\samples\opengl"; DestName: "teaambient.rbw"; CopyMode: alwaysoverwrite -Source: "sample\teapots.rb"; DestDir: "{app}\samples\opengl"; DestName: "teapots.rbw"; CopyMode: alwaysoverwrite -Source: "sample\tess.rb"; DestDir: "{app}\samples\opengl"; DestName: "tess.rbw"; CopyMode: alwaysoverwrite -Source: "sample\texbind.rb"; DestDir: "{app}\samples\opengl"; DestName: "texbind.rbw"; CopyMode: alwaysoverwrite -Source: "sample\texgen.rb"; DestDir: "{app}\samples\opengl"; DestName: "texgen.rbw"; CopyMode: alwaysoverwrite -Source: "sample\texturesurf.rb"; DestDir: "{app}\samples\opengl"; DestName: "texturesurf.rbw"; CopyMode: alwaysoverwrite -Source: "sample\varray.rb"; DestDir: "{app}\samples\opengl"; DestName: "varray.rbw"; CopyMode: alwaysoverwrite -Source: "sample\wrap.rb"; DestDir: "{app}\samples\opengl"; DestName: "wrap.rbw"; CopyMode: alwaysoverwrite - diff --git a/scripts/opengl.iss b/scripts/opengl.iss deleted file mode 100755 index ff73d44..0000000 --- a/scripts/opengl.iss +++ /dev/null @@ -1,74 +0,0 @@ -; Script generated by the Inno Setup Script Wizard. -; SEE THE DOCUMENTATION FOR DETAILS ON CREATING INNO SETUP SCRIPT FILES! - -[Setup] -AppName=Ruby/OpenGL -AppVerName=Ruby/OpenGL 0.32b -AppPublisher=Yoshiyuki Kusano -AppPublisherURL=http://www2.giganet.net/~yoshi -AppSupportURL=http://www2.giganet.net/~yoshi -AppUpdatesURL=http://www2.giganet.net/~yoshi -DefaultDirName=C:\ruby -DefaultGroupName=Ruby/OpenGL -AllowNoIcons=no -OutputDir=. -OutputBaseFilename=rbogl-0.32b-mswin32 -; uncomment the following line if you want your installation to run on NT 3.51 too. -; MinVersion=4,3.51 - -[Files] -; main extension files -Source: "opengl.so"; DestDir: "{app}\lib\ruby\site_ruby\1.6\i586-mswin32"; CopyMode: alwaysoverwrite -Source: "glut.so"; DestDir: "{app}\lib\ruby\site_ruby\1.6\i586-mswin32"; CopyMode: alwaysoverwrite -; documents -Source: "ChangeLog"; DestDir: "{app}\doc\ruby\opengl"; CopyMode: alwaysoverwrite -Source: "README.EUC"; DestDir: "{app}\doc\ruby\opengl"; CopyMode: alwaysoverwrite -; samples -Source: "sample\aaindex.rb"; DestDir: "{app}\samples\opengl"; DestName: "aaindex.rbw"; CopyMode: alwaysoverwrite -Source: "sample\aapoly.rb"; DestDir: "{app}\samples\opengl"; DestName: "aapoly.rbw"; CopyMode: alwaysoverwrite -Source: "sample\aargb.rb"; DestDir: "{app}\samples\opengl"; DestName: "aargb.rbw"; CopyMode: alwaysoverwrite -Source: "sample\accanti.rb"; DestDir: "{app}\samples\opengl"; DestName: "accanti.rbw"; CopyMode: alwaysoverwrite -Source: "sample\accpersp.rb"; DestDir: "{app}\samples\opengl"; DestName: "accpersp.rbw"; CopyMode: alwaysoverwrite -Source: "sample\alpha.rb"; DestDir: "{app}\samples\opengl"; DestName: "alpha.rbw"; CopyMode: alwaysoverwrite -Source: "sample\alpha3D.rb"; DestDir: "{app}\samples\opengl"; DestName: "alpha3D.rbw"; CopyMode: alwaysoverwrite -Source: "sample\bezcurve.rb"; DestDir: "{app}\samples\opengl"; DestName: "bezcurve.rbw"; CopyMode: alwaysoverwrite -Source: "sample\bezmesh.rb"; DestDir: "{app}\samples\opengl"; DestName: "bezmesh.rbw"; CopyMode: alwaysoverwrite -Source: "sample\checker.rb"; DestDir: "{app}\samples\opengl"; DestName: "checker.rbw"; CopyMode: alwaysoverwrite -Source: "sample\clip.rb"; DestDir: "{app}\samples\opengl"; DestName: "clip.rbw"; CopyMode: alwaysoverwrite -Source: "sample\colormat.rb"; DestDir: "{app}\samples\opengl"; DestName: "colormat.rbw"; CopyMode: alwaysoverwrite -Source: "sample\cube.rb"; DestDir: "{app}\samples\opengl"; DestName: "cube.rbw"; CopyMode: alwaysoverwrite -Source: "sample\depthcue.rb"; DestDir: "{app}\samples\opengl"; DestName: "depthcue.rbw"; CopyMode: alwaysoverwrite -Source: "sample\dof.rb"; DestDir: "{app}\samples\opengl"; DestName: "dof.rbw"; CopyMode: alwaysoverwrite -Source: "sample\double.rb"; DestDir: "{app}\samples\opengl"; DestName: "double.rbw"; CopyMode: alwaysoverwrite -Source: "sample\drawf.rb"; DestDir: "{app}\samples\opengl"; DestName: "drawf.rbw"; CopyMode: alwaysoverwrite -Source: "sample\feedback.rb"; DestDir: "{app}\samples\opengl"; DestName: "feedback.rbw"; CopyMode: alwaysoverwrite -Source: "sample\fog.rb"; DestDir: "{app}\samples\opengl"; DestName: "fog.rbw"; CopyMode: alwaysoverwrite -Source: "sample\font.rb"; DestDir: "{app}\samples\opengl"; DestName: "font.rbw"; CopyMode: alwaysoverwrite -Source: "sample\hello.rb"; DestDir: "{app}\samples\opengl"; DestName: "hello.rbw"; CopyMode: alwaysoverwrite -Source: "sample\image.rb"; DestDir: "{app}\samples\opengl"; DestName: "image.rbw"; CopyMode: alwaysoverwrite -Source: "sample\jitter.rb"; DestDir: "{app}\samples\opengl"; DestName: "jitter.rbw"; CopyMode: alwaysoverwrite -Source: "sample\lines.rb"; DestDir: "{app}\samples\opengl"; DestName: "lines.rbw"; CopyMode: alwaysoverwrite -Source: "sample\list.rb"; DestDir: "{app}\samples\opengl"; DestName: "list.rbw"; CopyMode: alwaysoverwrite -Source: "sample\material.rb"; DestDir: "{app}\samples\opengl"; DestName: "material.rbw"; CopyMode: alwaysoverwrite -Source: "sample\mipmap.rb"; DestDir: "{app}\samples\opengl"; DestName: "mipmap.rbw"; CopyMode: alwaysoverwrite -Source: "sample\model.rb"; DestDir: "{app}\samples\opengl"; DestName: "model.rbw"; CopyMode: alwaysoverwrite -Source: "sample\movelight.rb"; DestDir: "{app}\samples\opengl"; DestName: "movelight.rbw"; CopyMode: alwaysoverwrite -Source: "sample\pickdepth.rb"; DestDir: "{app}\samples\opengl"; DestName: "pickdepth.rbw"; CopyMode: alwaysoverwrite -Source: "sample\plane.rb"; DestDir: "{app}\samples\opengl"; DestName: "plane.rbw"; CopyMode: alwaysoverwrite -Source: "sample\planet.rb"; DestDir: "{app}\samples\opengl"; DestName: "planet.rbw"; CopyMode: alwaysoverwrite -Source: "sample\quadric.rb"; DestDir: "{app}\samples\opengl"; DestName: "quadric.rbw"; CopyMode: alwaysoverwrite -Source: "sample\robot.rb"; DestDir: "{app}\samples\opengl"; DestName: "robot.rbw"; CopyMode: alwaysoverwrite -Source: "sample\select.rb"; DestDir: "{app}\samples\opengl"; DestName: "select.rbw"; CopyMode: alwaysoverwrite -Source: "sample\smooth.rb"; DestDir: "{app}\samples\opengl"; DestName: "smooth.rbw"; CopyMode: alwaysoverwrite -Source: "sample\stencil.rb"; DestDir: "{app}\samples\opengl"; DestName: "stencil.rbw"; CopyMode: alwaysoverwrite -Source: "sample\stroke.rb"; DestDir: "{app}\samples\opengl"; DestName: "stroke.rbw"; CopyMode: alwaysoverwrite -Source: "sample\surface.rb"; DestDir: "{app}\samples\opengl"; DestName: "surface.rbw"; CopyMode: alwaysoverwrite -Source: "sample\teaambient.rb"; DestDir: "{app}\samples\opengl"; DestName: "teaambient.rbw"; CopyMode: alwaysoverwrite -Source: "sample\teapots.rb"; DestDir: "{app}\samples\opengl"; DestName: "teapots.rbw"; CopyMode: alwaysoverwrite -Source: "sample\tess.rb"; DestDir: "{app}\samples\opengl"; DestName: "tess.rbw"; CopyMode: alwaysoverwrite -Source: "sample\texbind.rb"; DestDir: "{app}\samples\opengl"; DestName: "texbind.rbw"; CopyMode: alwaysoverwrite -Source: "sample\texgen.rb"; DestDir: "{app}\samples\opengl"; DestName: "texgen.rbw"; CopyMode: alwaysoverwrite -Source: "sample\texturesurf.rb"; DestDir: "{app}\samples\opengl"; DestName: "texturesurf.rbw"; CopyMode: alwaysoverwrite -Source: "sample\varray.rb"; DestDir: "{app}\samples\opengl"; DestName: "varray.rbw"; CopyMode: alwaysoverwrite -Source: "sample\wrap.rb"; DestDir: "{app}\samples\opengl"; DestName: "wrap.rbw"; CopyMode: alwaysoverwrite - -- GitLab