[前][次][番号順一覧][スレッド一覧]

ruby-changes:20589

From: drbrain <ko1@a...>
Date: Sat, 23 Jul 2011 15:05:50 +0900 (JST)
Subject: [ruby-changes:20589] drbrain:r32637 (ruby_1_9_3): * test/rake*: Remove dependencies on flexmock and session gems.

drbrain	2011-07-23 15:05:36 +0900 (Sat, 23 Jul 2011)

  New Revision: 32637

  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=32637

  Log:
    * test/rake*: Remove dependencies on flexmock and session gems.
      [Ruby 1.9 - Bug #4987]

  Modified files:
    branches/ruby_1_9_3/ChangeLog
    branches/ruby_1_9_3/test/rake/helper.rb
    branches/ruby_1_9_3/test/rake/test_rake_application.rb
    branches/ruby_1_9_3/test/rake/test_rake_file_utils.rb
    branches/ruby_1_9_3/test/rake/test_rake_functional.rb
    branches/ruby_1_9_3/test/rake/test_rake_task.rb
    branches/ruby_1_9_3/test/rake/test_rake_task_argument_parsing.rb
    branches/ruby_1_9_3/test/rake/test_rake_task_manager.rb
    branches/ruby_1_9_3/test/rake/test_rake_task_with_arguments.rb
    branches/ruby_1_9_3/test/rake/test_rake_test_task.rb
    branches/ruby_1_9_3/test/rake/test_rake_top_level_functions.rb

Index: ruby_1_9_3/ChangeLog
===================================================================
--- ruby_1_9_3/ChangeLog	(revision 32636)
+++ ruby_1_9_3/ChangeLog	(revision 32637)
@@ -1,5 +1,10 @@
-Fri Jul 22 21:53:24 2011  KOSAKI Motohiro  <kosaki.motohiro@g...>
+Sat Jul 23 14:38:28 2011  Eric Hodel  <drbrain@s...>
 
+	* test/rake*: Remove dependencies on flexmock and session gems.
+	  [Ruby 1.9 - Bug #4987]
+
+Fri Jul 22 21:46:54 2011  KOSAKI Motohiro  <kosaki.motohiro@g...>
+
 	* vm_insnhelper.c (vm_call_cfunc): added volatile for a workaround
 	  of cfp consistency error problem on OS X 10.7 (Lion). It's
 	  suspected llvm optimization bug.
Index: ruby_1_9_3/test/rake/test_rake_task_with_arguments.rb
===================================================================
--- ruby_1_9_3/test/rake/test_rake_task_with_arguments.rb	(revision 32636)
+++ ruby_1_9_3/test/rake/test_rake_task_with_arguments.rb	(revision 32637)
@@ -160,11 +160,14 @@
   end
 
   def test_values_at
-    t = task(:pre, [:a, :b, :c]) { |t, args|
+    t = task(:pre, [:a, :b, :c]) { |task, args|
       a, b, c = args.values_at(:a, :b, :c)
       assert_equal %w[1 2 3], [a, b, c]
     }
+
     t.invoke(*%w[1 2 3])
+
+    # HACK no assertions
   end
 end
 
Index: ruby_1_9_3/test/rake/test_rake_file_utils.rb
===================================================================
--- ruby_1_9_3/test/rake/test_rake_file_utils.rb	(revision 32636)
+++ ruby_1_9_3/test/rake/test_rake_file_utils.rb	(revision 32637)
@@ -119,33 +119,16 @@
   def test_sh
     shellcommand
 
-    verbose(false) { sh %{#{FileUtils::RUBY} shellcommand.rb} }
+    verbose(false) { sh %{#{Rake::TestCase::RUBY} shellcommand.rb} }
     assert true, "should not fail"
   end
 
-  # If the :sh method is invoked directly from a test unit instance
-  # (under mini/test), the mini/test version of fail is invoked rather
-  # than the kernel version of fail. So we run :sh from within a
-  # non-test class to avoid the problem.
-  class Sh
-    include FileUtils
-    def run(*args)
-      sh(*args)
-    end
-    def self.run(*args)
-      new.run(*args)
-    end
-    def self.ruby(*args)
-      Sh.run(RUBY, *args)
-    end
-  end
-
   def test_sh_with_a_single_string_argument
     check_expansion
 
     ENV['RAKE_TEST_SH'] = 'someval'
     verbose(false) {
-      sh %{#{FileUtils::RUBY} check_expansion.rb #{env_var} someval}
+      sh %{#{RUBY} check_expansion.rb #{env_var} someval}
     }
   end
 
@@ -154,7 +137,7 @@
     ENV['RAKE_TEST_SH'] = 'someval'
 
     verbose(false) {
-      Sh.ruby 'check_no_expansion.rb', env_var, 'someval'
+      sh RUBY, 'check_no_expansion.rb', env_var, 'someval'
     }
   end
 
@@ -162,7 +145,7 @@
     shellcommand
 
     assert_raises(RuntimeError) {
-      verbose(false) { Sh.run %{#{FileUtils::RUBY} shellcommand.rb 1} }
+      verbose(false) { sh %{#{RUBY} shellcommand.rb 1} }
     }
   end
 
@@ -171,12 +154,12 @@
 
     count = 0
     verbose(false) {
-      sh(%{#{FileUtils::RUBY} shellcommand.rb}) do |ok, res|
+      sh(%{#{RUBY} shellcommand.rb}) do |ok, res|
         assert(ok)
         assert_equal 0, res.exitstatus
         count += 1
       end
-      sh(%{#{FileUtils::RUBY} shellcommand.rb 1}) do |ok, res|
+      sh(%{#{RUBY} shellcommand.rb 1}) do |ok, res|
         assert(!ok)
         assert_equal 1, res.exitstatus
         count += 1
@@ -241,7 +224,9 @@
     ENV['RAKE_TEST_SH'] = 'someval'
 
     verbose(false) {
-      ruby %{check_expansion.rb #{env_var} someval}
+      replace_ruby {
+        ruby %{check_expansion.rb #{env_var} someval}
+      }
     }
   end
 
@@ -250,7 +235,9 @@
 
     ENV['RAKE_TEST_SH'] = 'someval'
     verbose(false) {
-      ruby 'check_no_expansion.rb', env_var, 'someval'
+      replace_ruby {
+        ruby 'check_no_expansion.rb', env_var, 'someval'
+      }
     }
   end
 
@@ -289,6 +276,16 @@
     CHECK_EXPANSION
   end
 
+  def replace_ruby
+    ruby = FileUtils::RUBY
+    FileUtils.send :remove_const, :RUBY
+    FileUtils.const_set :RUBY, RUBY
+    yield
+  ensure
+    FileUtils.send :remove_const, :RUBY
+    FileUtils.const_set:RUBY, ruby
+  end
+
   def shellcommand
     command 'shellcommand.rb', <<-SHELLCOMMAND
 #!/usr/bin/env ruby
Index: ruby_1_9_3/test/rake/test_rake_functional.rb
===================================================================
--- ruby_1_9_3/test/rake/test_rake_functional.rb	(revision 32636)
+++ ruby_1_9_3/test/rake/test_rake_functional.rb	(revision 32637)
@@ -1,39 +1,7 @@
-begin
-  old_verbose = $VERBOSE
-  $VERBOSE = nil
-  require 'session'
-rescue LoadError
-  if File::ALT_SEPARATOR
-    puts "Unable to run functional tests on MS Windows. Skipping."
-  else
-    puts "Unable to run functional tests -- please run \"gem install session\""
-  end
-ensure
-  $VERBOSE = old_verbose
-end
-
-if defined?(Session)
-  if File::ALT_SEPARATOR
-    puts "Unable to run functional tests on MS Windows. Skipping."
-  end
-end
-
 require File.expand_path('../helper', __FILE__)
 require 'fileutils'
+require 'open3'
 
-# Version 2.1.9 of session has a bug where the @debug instance
-# variable is not initialized, causing warning messages.  This snippet
-# of code fixes that problem.
-module Session
-  class AbstractSession
-    alias old_initialize initialize
-    def initialize(*args)
-      @debug = nil
-      old_initialize(*args)
-    end
-  end
-end if defined? Session
-
 class TestRakeFunctional < Rake::TestCase
 
   def setup
@@ -59,16 +27,14 @@
     rake
 
     assert_match(/^DEFAULT$/, @out)
-    assert_status
   end
 
   def test_rake_error_on_bad_task
     rakefile_default
 
-    rake "xyz"
+    rake '-t', 'xyz'
 
     assert_match(/rake aborted/, @err)
-    assert_status(1)
   end
 
   def test_env_available_at_top_scope
@@ -77,16 +43,14 @@
     rake "TESTTOPSCOPE=1"
 
     assert_match(/^TOPSCOPE$/, @out)
-    assert_status
   end
 
   def test_env_available_at_task_scope
     rakefile_default
 
-    rake "TESTTASKSCOPE=1 task_scope"
+    rake 'TESTTASKSCOPE=1', 'task_scope'
 
     assert_match(/^TASKSCOPE$/, @out)
-    assert_status
   end
 
   def test_multi_desc
@@ -283,8 +247,6 @@
     rake "--dry-run"
 
     refute_match(/No such file/, @out)
-
-    assert_status
   end
 
   # Test for the trace/dry_run bug found by Brian Chandler
@@ -298,7 +260,6 @@
     rake "--trace"
 
     refute_match(/No such file/, @out)
-    assert_status
   end
 
   def test_imports
@@ -309,7 +270,6 @@
     assert File.exist?(File.join(@tempdir, 'dynamic_deps')),
            "'dynamic_deps' file should exist"
     assert_match(/^FIRST$\s+^DYNAMIC$\s+^STATIC$\s+^OTHER$/, @out)
-    assert_status
   end
 
   def test_rules_chaining_to_file_task
@@ -319,7 +279,6 @@
 
     assert File.exist?(File.join(@tempdir, 'play.app')),
            "'play.app' file should exist"
-    assert_status
   end
 
   def test_file_creation_task
@@ -335,7 +294,7 @@
   def test_dash_f_with_no_arg_foils_rakefile_lookup
     rakefile_rakelib
 
-    rake "-I rakelib -rtest1 -f"
+    rake '-I', 'rakelib', '-rtest1', '-f'
 
     assert_match(/^TEST1$/, @out)
   end
@@ -343,8 +302,9 @@
   def test_dot_rake_files_can_be_loaded_with_dash_r
     rakefile_rakelib
 
-    rake "-I rakelib -rtest2 -f"
+    rake '-I', 'rakelib', '-rtest2', '-f'
 
+    assert_empty @err
     assert_match(/^TEST2$/, @out)
   end
 
@@ -412,22 +372,6 @@
     assert_match(/^PREPARE\nSCOPEDEP$/m, @out)
   end
 
-  def test_rake_returns_status_error_values
-    rakefile_statusreturn
-
-    rake "exit5"
-
-    assert_status 5
-  end
-
-  def test_rake_returns_no_status_error_on_normal_exit
-    rakefile_statusreturn
-
-    rake "normal"
-
-    assert_status 0
-  end
-
   def test_comment_before_task_acts_like_desc
     rakefile_comments
 
@@ -469,42 +413,38 @@
   end
 
   def test_file_list_is_requirable_separately
-    ruby "-rrake/file_list", "-e 'puts Rake::FileList[\"a\"].size'"
+    ruby '-rrake/file_list', '-e', 'puts Rake::FileList["a"].size'
     assert_equal "1\n", @out
-    assert_equal 0, @status
   end
 
   private
 
   # Run a shell Ruby command with command line options (using the
-  # default test options). Output is captured in @out, @err and
-  # @status.
+  # default test options). Output is captured in @out and @err
   def ruby(*option_list)
     run_ruby(@ruby_options + option_list)
   end
 
   # Run a command line rake with the give rake options.  Default
   # command line ruby options are included.  Output is captured in
-  # @out, @err and @status.
+  # @out and @err
   def rake(*rake_options)
     run_ruby @ruby_options + [@rake_path] + rake_options
   end
 
   # Low level ruby command runner ...
   def run_ruby(option_list)
-    shell = Session::Shell.new
-    command = "#{Gem.ruby} #{option_list.join ' '}"
-    puts "COMMAND: [#{command}]" if @verbose
-    @out, @err = shell.execute command
-    @status = shell.exit_status
-    puts "STATUS:  [#{@status}]" if @verbose
+    puts "COMMAND: [#{RUBY} #{option_list.join ' '}]" if @verbose
+
+    inn, out, err, wait = Open3.popen3(Gem.ruby, *option_list)
+    inn.close
+
+    @out = out.read
+    @err = err.read
+
     puts "OUTPUT:  [#{@out}]" if @verbose
     puts "ERROR:   [#{@err}]" if @verbose
     puts "PWD:     [#{Dir.pwd}]" if @verbose
-    shell.close
   end
 
-  def assert_status(expected_status=0)
-    assert_equal expected_status, @status
-  end
-end if defined?(Session)
+end
Index: ruby_1_9_3/test/rake/helper.rb
===================================================================
--- ruby_1_9_3/test/rake/helper.rb	(revision 32636)
+++ ruby_1_9_3/test/rake/helper.rb	(revision 32637)
@@ -1,15 +1,22 @@
 require 'rubygems'
-require 'minitest/unit'
-require 'flexmock/test_unit_integration'
+
+begin
+  gem 'minitest'
+rescue Gem::LoadError
+end
+
 require 'minitest/autorun'
 require 'rake'
 require 'tmpdir'
 require File.expand_path('../file_creation', __FILE__)
 
-class Rake::TestCase < MiniTest::Unit::TestCase
-  include FlexMock::ArgumentTypes
-  include FlexMock::MockContainer
+begin
+  require 'test/ruby/envutil'
+rescue LoadError
+  # for ruby trunk
+end
 
+class Rake::TestCase < MiniTest::Unit::TestCase
   include FileCreation
 
   include Rake::DSL
@@ -18,6 +25,8 @@
     include Rake::TaskManager
   end
 
+  RUBY = defined?(EnvUtil) ? EnvUtil.rubybin : Gem.ruby
+
   def setup
     ARGV.clear
 
@@ -43,11 +52,10 @@
 
     Rake.application = Rake::Application.new
     Rake::TaskManager.record_task_metadata = true
+    RakeFileUtils.verbose_flag = false
   end
 
   def teardown
-    flexmock_teardown
-
     Dir.chdir @orig_PWD
     FileUtils.rm_rf @tempdir
 
@@ -434,17 +442,6 @@
     end
   end
 
-  def rakefile_statusreturn
-    rakefile <<-STATUSRETURN
-task :exit5 do
-  exit(5)
-end
-
-task :normal do
-end
-    STATUSRETURN
-  end
-
   def rakefile_unittest
     rakefile '# Empty Rakefile for Unit Test'
 
@@ -494,7 +491,3 @@
 
 end
 
-# workarounds for 1.8
-$" << 'test/helper.rb'
-Test::Unit.run = true if Test::Unit.respond_to? :run=
-
Index: ruby_1_9_3/test/rake/test_rake_top_level_functions.rb
===================================================================
--- ruby_1_9_3/test/rake/test_rake_top_level_functions.rb	(revision 32636)
+++ ruby_1_9_3/test/rake/test_rake_top_level_functions.rb	(revision 32637)
@@ -5,28 +5,43 @@
   def setup
     super
 
-    @app = Rake.application
-    Rake.application = flexmock("app")
-    Rake.application.should_receive(:deprecate).
-      and_return { |old, new, call| @app.deprecate(old, new, call) }
-  end
+    @app = Object.new
 
-  def teardown
+    def @app.called
+      @called
+    end
+
+    def @app.method_missing(*a, &b)
+      @called ||= []
+      @called << [a, b]
+      nil
+    end
+
     Rake.application = @app
-
-    super
   end
 
   def test_namespace
-    Rake.application.should_receive(:in_namespace).with("xyz", any).once
-    namespace "xyz" do end
+    block = proc do end
+
+    namespace("xyz", &block) 
+
+    expected = [
+      [[:in_namespace, 'xyz'], block]
+    ]
+
+    assert_equal expected, @app.called
   end
 
   def test_import
-    Rake.application.should_receive(:add_import).with("x").once.ordered
-    Rake.application.should_receive(:add_import).with("y").once.ordered
-    Rake.application.should_receive(:add_import).with("z").once.ordered
     import('x', 'y', 'z')
+
+    expected = [
+      [[:add_import, 'x'], nil],
+      [[:add_import, 'y'], nil],
+      [[:add_import, 'z'], nil],
+    ]
+
+    assert_equal expected, @app.called
   end
 
   def test_when_writing
@@ -51,23 +66,43 @@
   end
 
   def test_missing_constants_task
-    Rake.application.should_receive(:const_warning).with(:Task).once
     Object.const_missing(:Task)
+
+    expected = [
+      [[:const_warning, :Task], nil]
+    ]
+
+    assert_equal expected, @app.called
   end
 
   def test_missing_constants_file_task
-    Rake.application.should_receive(:const_warning).with(:FileTask).once
     Object.const_missing(:FileTask)
+
+    expected = [
+      [[:const_warning, :FileTask], nil]
+    ]
+
+    assert_equal expected, @app.called
   end
 
   def test_missing_constants_file_creation_task
-    Rake.application.should_receive(:const_warning).with(:FileCreationTask).once
     Object.const_missing(:FileCreationTask)
+
+    expected = [
+      [[:const_warning, :FileCreationTask], nil]
+    ]
+
+    assert_equal expected, @app.called
   end
 
   def test_missing_constants_rake_app
-    Rake.application.should_receive(:const_warning).with(:RakeApp).once
     Object.const_missing(:RakeApp)
+
+    expected = [
+      [[:const_warning, :RakeApp], nil]
+    ]
+
+    assert_equal expected, @app.called
   end
 
   def test_missing_other_constant
Index: ruby_1_9_3/test/rake/test_rake_task_argument_parsing.rb
===================================================================
--- ruby_1_9_3/test/rake/test_rake_task_argument_parsing.rb	(revision 32636)
+++ ruby_1_9_3/test/rake/test_rake_task_argument_parsing.rb	(revision 32637)
@@ -51,38 +51,31 @@
   end
 
   def test_terminal_width_using_stty
-    app = Rake::Application.new
+    def @app.unix?() true end
+    def @app.dynamic_width_stty() 1235 end
+    def @app.dynamic_width_tput() 0 end
 
-    flexmock(app,
-      :unix? => true,
-      :dynamic_width_stty => 1235,
-      :dynamic_width_tput => 0)
-
-    assert_equal 1235, app.terminal_width
+    assert_equal 1235, @app.terminal_width
   end
 
   def test_terminal_width_using_tput
-    app = Rake::Application.new
-    flexmock(app,
-      :unix? => true,
-      :dynamic_width_stty => 0,
-      :dynamic_width_tput => 1236)
+    def @app.unix?() true end
+    def @app.dynamic_width_stty() 0 end
+    def @app.dynamic_width_tput() 1236 end
 
-    assert_equal 1236, app.terminal_width
+    assert_equal 1236, @app.terminal_width
   end
 
   def test_terminal_width_using_hardcoded_80
-    app = Rake::Application.new
-    flexmock(app, :unix? => false)
+    def @app.unix?() true end
 
-    assert_equal 80, app.terminal_width
+    assert_equal 80, @app.terminal_width
   end
 
   def test_terminal_width_with_failure
-    app = Rake::Application.new
-    flexmock(app).should_receive(:unix?).and_throw(RuntimeError)
+    def @app.unix?() raise end
 
-    assert_equal 80, app.terminal_width
+    assert_equal 80, @app.terminal_width
   end
 
   def test_no_rakeopt
Index: ruby_1_9_3/test/rake/test_rake_task_manager.rb
===================================================================
--- ruby_1_9_3/test/rake/test_rake_task_manager.rb	(revision 32636)
+++ ruby_1_9_3/test/rake/test_rake_task_manager.rb	(revision 32637)
@@ -19,6 +19,14 @@
     assert_equal @tm, t.application
   end
 
+  def test_index
+    e = assert_raises RuntimeError do
+      @tm['bad']
+    end
+
+    assert_equal "Don't know how to build task 'bad'", e.message
+  end
+
   def test_name_lookup
     t = @tm.define_task(Rake::Task, :t)
     assert_equal t, @tm[:t]
Index: ruby_1_9_3/test/rake/test_rake_test_task.rb
===================================================================
--- ruby_1_9_3/test/rake/test_rake_test_task.rb	(revision 32636)
+++ ruby_1_9_3/test/rake/test_rake_test_task.rb	(revision 32637)
@@ -93,7 +93,7 @@
       t.loader = :testrb
     end
 
-    flexmock(test_task).should_receive(:ruby_version).and_return('1.8.2')
+    def test_task.ruby_version() '1.8.2' end
 
     assert_match(/^-S testrb +".*"$/, test_task.run_code)
   end
@@ -103,7 +103,7 @@
       t.loader = :testrb
     end
 
-    flexmock(test_task).should_receive(:ruby_version).and_return('1.8.6')
+    def test_task.ruby_version() '1.8.6' end
 
     assert_match(/^-S testrb +$/, test_task.run_code)
   end
Index: ruby_1_9_3/test/rake/test_rake_task.rb
===================================================================
--- ruby_1_9_3/test/rake/test_rake_task.rb	(revision 32636)
+++ ruby_1_9_3/test/rake/test_rake_task.rb	(revision 32637)
@@ -208,10 +208,7 @@
     b = task :b
     c = task :c
 
-    faux_stamp = 100
-    flexmock(Time, :now => faux_stamp)
-
-    assert_equal faux_stamp, a.timestamp
+    assert_in_delta Time.now, a.timestamp, 0.1, 'computer too slow?'
   end
 
   def test_timestamp_returns_latest_prereq_timestamp
@@ -219,12 +216,11 @@
     b = task :b
     c = task :c
 
-    faux_stamp = 100
-    flexmock(Time, :now => faux_stamp-10)
-    flexmock(b, :timestamp => faux_stamp - 1)
-    flexmock(c, :timestamp => faux_stamp)
+    now = Time.now
+    def b.timestamp() Time.now + 10 end
+    def c.timestamp() Time.now + 5 end
 
-    assert_equal faux_stamp, a.timestamp
+    assert_in_delta now + 10, a.timestamp, 0.1, 'computer too slow?'
   end
 
   def test_investigation_output
Index: ruby_1_9_3/test/rake/test_rake_application.rb
===================================================================
--- ruby_1_9_3/test/rake/test_rake_application.rb	(revision 32636)
+++ ruby_1_9_3/test/rake/test_rake_application.rb	(revision 32637)
@@ -232,7 +232,9 @@
 
   def test_load_from_calculated_system_rakefile
     rakefile_default
-    flexmock(@app, :standard_system_dir => "__STD_SYS_DIR__")
+    def @app.standard_system_dir
+      "__STD_SYS_DIR__"
+    end
 
     ENV['RAKE_SYSTEM'] = nil
 
@@ -270,25 +272,28 @@
   end
 
   def test_loading_imports
-    mock = flexmock("loader")
-    mock.should_receive(:load).with("x.dummy").once
+    loader = util_loader
+
     @app.instance_eval do
-      add_loader("dummy", mock)
+      add_loader("dummy", loader)
       add_import("x.dummy")
       load_imports
     end
+
+    # HACK no assertions
   end
 
   def test_building_imported_files_on_demand
-    mock = flexmock("loader")
-    mock.should_receive(:load).with("x.dummy").once
-    mock.should_receive(:make_dummy).with_no_args.once
+    loader = util_loader
+
     @app.instance_eval do
-      intern(Rake::Task, "x.dummy").enhance do mock.make_dummy end
-        add_loader("dummy", mock)
+      intern(Rake::Task, "x.dummy").enhance do loader.make_dummy end
+      add_loader("dummy", loader)
       add_import("x.dummy")
       load_imports
     end
+
+    # HACK no assertions
   end
 
   def test_handle_options_should_strip_options_from_ARGV
@@ -399,5 +404,86 @@
     assert_match(/use 'b' instead/i, err)
     assert_match(/at c$/i, err)
   end
+
+  def test_standard_exception_handling_invalid_option
+    out, err = capture_io do
+      e = assert_raises SystemExit do
+        @app.standard_exception_handling do
+          raise OptionParser::InvalidOption, 'blah'
+        end
+      end
+
+      assert_equal 1, e.status
+    end
+
+    assert_empty out
+    assert_equal "invalid option: blah\n", err
+  end
+
+  def test_standard_exception_handling_other
+    out, err = capture_io do
+      e = assert_raises SystemExit do
+        @app.standard_exception_handling do
+          raise 'blah'
+        end
+      end
+
+      assert_equal 1, e.status
+    end
+
+    assert_empty out
+    assert_match "rake aborted!\n", err
+    assert_match "blah\n", err
+  end
+
+  def test_standard_exception_handling_system_exit
+    out, err (... truncated)

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

[前][次][番号順一覧][スレッド一覧]