Rakefile in json_pure-1.1.9 vs Rakefile in json_pure-1.2.0

- old
+ new

@@ -1,20 +1,26 @@ begin require 'rake/gempackagetask' +rescue LoadError +end + +begin require 'rake/extensiontask' rescue LoadError + puts "WARNING: rake-compiler is not installed. You will not be able to build the json gem until you install it." end + require 'rake/clean' CLOBBER.include Dir['benchmarks/data/*.{dat,log}'] require 'rbconfig' include Config MAKE = ENV['MAKE'] || %w[gmake make].find { |c| system(c, '-v') } PKG_NAME = 'json' PKG_VERSION = File.read('VERSION').chomp -PKG_FILES = FileList["**/*"].exclude(/CVS|pkg|tmp|coverage|Makefile/).exclude(/\.(so|bundle|o|#{CONFIG['DLEXT']})$/) +PKG_FILES = FileList["**/*"].exclude(/CVS|pkg|tmp|coverage|Makefile|\.nfs\./).exclude(/\.(so|bundle|o|#{CONFIG['DLEXT']})$/) EXT_ROOT_DIR = 'ext/json/ext' EXT_PARSER_DIR = "#{EXT_ROOT_DIR}/parser" EXT_PARSER_DL = "#{EXT_ROOT_DIR}/parser.#{CONFIG['DLEXT']}" EXT_PARSER_SRC = "#{EXT_PARSER_DIR}/parser.c" PKG_FILES << EXT_PARSER_SRC @@ -26,13 +32,23 @@ RAGEL_PATH = "#{EXT_PARSER_DIR}/parser.rl" CLEAN.include FileList['diagrams/*.*'], 'doc', 'coverage', 'tmp', FileList["ext/**/{Makefile,mkmf.log}"], FileList["{ext,lib}/**/*.{so,bundle,#{CONFIG['DLEXT']},o,obj,pdb,lib,manifest,exp,def}"] +def myruby(*args, &block) + @myruby ||= File.join(CONFIG['bindir'], CONFIG['ruby_install_name']) + options = (Hash === args.last) ? args.pop : {} + if args.length > 1 then + sh(*([@myruby] + args + [options]), &block) + else + sh("#{@myruby} #{args.first}", options, &block) + end +end + desc "Installing library (pure)" task :install_pure => :version do - ruby 'install.rb' + myruby 'install.rb' end task :install_ext_really do sitearchdir = CONFIG["sitearchdir"] cd 'ext' do @@ -46,27 +62,31 @@ desc "Installing library (extension)" task :install_ext => [ :compile_ext, :install_pure, :install_ext_really ] desc "Installing library (extension)" -task :install => :install_ext +if RUBY_PLATFORM =~ /java/ + task :install => :install_pure +else + task :install => :install_ext +end desc "Compiling extension" task :compile_ext => [ EXT_PARSER_DL, EXT_GENERATOR_DL ] file EXT_PARSER_DL => EXT_PARSER_SRC do cd EXT_PARSER_DIR do - ruby 'extconf.rb' - system MAKE + myruby 'extconf.rb' + sh MAKE end cp "#{EXT_PARSER_DIR}/parser.#{CONFIG['DLEXT']}", EXT_ROOT_DIR end file EXT_GENERATOR_DL => EXT_GENERATOR_SRC do cd EXT_GENERATOR_DIR do - ruby 'extconf.rb' - system MAKE + myruby 'extconf.rb' + sh MAKE end cp "#{EXT_GENERATOR_DIR}/generator.#{CONFIG['DLEXT']}", EXT_ROOT_DIR end desc "Generate parser with ragel" @@ -77,41 +97,41 @@ end file EXT_PARSER_SRC => RAGEL_PATH do cd EXT_PARSER_DIR do if RAGEL_CODEGEN == 'ragel' - system "ragel parser.rl -G2 -o parser.c" + sh "ragel parser.rl -G2 -o parser.c" else - system "ragel -x parser.rl | #{RAGEL_CODEGEN} -G2" + sh "ragel -x parser.rl | #{RAGEL_CODEGEN} -G2" end end end desc "Generate diagrams of ragel parser (ps)" task :ragel_dot_ps do root = 'diagrams' specs = [] File.new(RAGEL_PATH).grep(/^\s*machine\s*(\S+);\s*$/) { specs << $1 } - for s in specs + for s in specs if RAGEL_DOTGEN == 'ragel' - system "ragel #{RAGEL_PATH} -S#{s} -p -V | dot -Tps -o#{root}/#{s}.ps" + sh "ragel #{RAGEL_PATH} -S#{s} -p -V | dot -Tps -o#{root}/#{s}.ps" else - system "ragel -x #{RAGEL_PATH} -S#{s} | #{RAGEL_DOTGEN} -p|dot -Tps -o#{root}/#{s}.ps" + sh "ragel -x #{RAGEL_PATH} -S#{s} | #{RAGEL_DOTGEN} -p|dot -Tps -o#{root}/#{s}.ps" end end end desc "Generate diagrams of ragel parser (png)" task :ragel_dot_png do root = 'diagrams' specs = [] File.new(RAGEL_PATH).grep(/^\s*machine\s*(\S+);\s*$/) { specs << $1 } - for s in specs + for s in specs if RAGEL_DOTGEN == 'ragel' - system "ragel #{RAGEL_PATH} -S#{s} -p -V | dot -Tpng -o#{root}/#{s}.png" + sh "ragel #{RAGEL_PATH} -S#{s} -p -V | dot -Tpng -o#{root}/#{s}.png" else - system "ragel -x #{RAGEL_PATH} -S#{s} | #{RAGEL_DOTGEN} -p|dot -Tpng -o#{root}/#{s}.png" + sh "ragel -x #{RAGEL_PATH} -S#{s} | #{RAGEL_DOTGEN} -p|dot -Tpng -o#{root}/#{s}.png" end end end desc "Generate diagrams of ragel parser" @@ -119,41 +139,41 @@ desc "Testing library (pure ruby)" task :test_pure => :clean do ENV['JSON'] = 'pure' ENV['RUBYOPT'] = "-Iext:lib #{ENV['RUBYOPT']}" - system "testrb #{Dir['tests/*.rb'] * ' '}" + myruby "-S testrb #{Dir['./tests/*.rb'] * ' '}" end desc "Testing library (extension)" task :test_ext => :compile_ext do ENV['JSON'] = 'ext' ENV['RUBYOPT'] = "-Iext:lib #{ENV['RUBYOPT']}" - system "testrb #{Dir['tests/*.rb'] * ' '}" + myruby "-S testrb #{Dir['./tests/*.rb'] * ' '}" end desc "Testing library (pure ruby and extension)" task :test => [ :test_pure, :test_ext ] desc "Benchmarking parser" task :benchmark_parser do ENV['RUBYOPT'] = "-Ilib:ext #{ENV['RUBYOPT']}" - ruby 'benchmarks/parser_benchmark.rb' + myruby 'benchmarks/parser_benchmark.rb' end desc "Benchmarking generator" task :benchmark_generator do ENV['RUBYOPT'] = "-Ilib:ext #{ENV['RUBYOPT']}" - ruby 'benchmarks/generator_benchmark.rb' + myruby 'benchmarks/generator_benchmark.rb' end desc "Benchmarking library" task :benchmark => [ :benchmark_parser, :benchmark_generator ] desc "Create RDOC documentation" task :doc => [ :version, EXT_PARSER_SRC ] do - system "rdoc -o doc -m doc-main.txt doc-main.txt lib/json.rb #{FileList['lib/json/**/*.rb']} #{EXT_PARSER_SRC} #{EXT_GENERATOR_SRC}" + sh "rdoc -o doc -m README README lib/json.rb #{FileList['lib/json/**/*.rb']} #{EXT_PARSER_SRC} #{EXT_GENERATOR_SRC}" end if defined?(Gem) and defined?(Rake::GemPackageTask) and defined?(Rake::ExtensionTask) spec_pure = Gem::Specification.new do |s| s.name = 'json_pure' @@ -168,24 +188,24 @@ s.bindir = "bin" s.executables = [ "edit_json.rb", "prettify_json.rb" ] s.default_executable = "edit_json.rb" s.has_rdoc = true - s.extra_rdoc_files << 'doc-main.txt' + s.extra_rdoc_files << 'README' s.rdoc_options << - '--title' << 'JSON -- A JSON implemention' << '--main' << 'doc-main.txt' + '--title' << 'JSON -- A JSON implemention' << '--main' << 'README' s.test_files.concat Dir['tests/*.rb'] s.author = "Florian Frank" s.email = "flori@ping.de" s.homepage = "http://json.rubyforge.org" s.rubyforge_project = "json" end Rake::GemPackageTask.new(spec_pure) do |pkg| pkg.need_tar = true - pkg.package_files += PKG_FILES + pkg.package_files = PKG_FILES end spec_ext = Gem::Specification.new do |s| s.name = 'json' s.version = PKG_VERSION @@ -203,13 +223,13 @@ s.bindir = "bin" s.executables = [ "edit_json.rb", "prettify_json.rb" ] s.default_executable = "edit_json.rb" s.has_rdoc = true - s.extra_rdoc_files << 'doc-main.txt' + s.extra_rdoc_files << 'README' s.rdoc_options << - '--title' << 'JSON -- A JSON implemention' << '--main' << 'doc-main.txt' + '--title' << 'JSON -- A JSON implemention' << '--main' << 'README' s.test_files.concat Dir['tests/*.rb'] s.author = "Florian Frank" s.email = "flori@ping.de" s.homepage = "http://json.rubyforge.org" @@ -227,11 +247,11 @@ ext.cross_compile = true ext.cross_platform = 'i386-mswin32' ext.ext_dir = 'ext/json/ext/parser' ext.lib_dir = 'lib/json/ext' end - + Rake::ExtensionTask.new do |ext| ext.name = 'generator' ext.gem_spec = spec_ext ext.cross_compile = true ext.cross_platform = 'i386-mswin32' @@ -257,11 +277,11 @@ end end desc "Build all gems and archives for a new release." task :release => [ :clean, :version, :cross, :native, :gem ] do - system "#$0 clean native gem" - system "#$0 clean package" + sh "#$0 clean native gem" + sh "#$0 clean package" end desc "Compile in the the source directory" task :default => [ :version, :compile_ext ]