logging 0.7.1 → 0.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/History.txt +9 -1
- data/Manifest.txt +3 -4
- data/Rakefile +8 -7
- data/lib/logging.rb +2 -2
- data/lib/logging/appender.rb +1 -1
- data/lib/logging/appenders/console.rb +1 -1
- data/lib/logging/appenders/email.rb +3 -2
- data/lib/logging/appenders/file.rb +1 -1
- data/lib/logging/appenders/growl.rb +1 -1
- data/lib/logging/appenders/io.rb +1 -1
- data/lib/logging/appenders/rolling_file.rb +3 -3
- data/lib/logging/appenders/syslog.rb +1 -1
- data/lib/logging/config/yaml_configurator.rb +1 -1
- data/lib/logging/layout.rb +1 -1
- data/lib/logging/layouts/basic.rb +1 -1
- data/lib/logging/layouts/pattern.rb +1 -1
- data/lib/logging/log_event.rb +1 -1
- data/lib/logging/logger.rb +59 -17
- data/lib/logging/repository.rb +15 -1
- data/lib/logging/root_logger.rb +6 -4
- data/lib/logging/utils.rb +1 -1
- data/tasks/ann.rake +20 -15
- data/tasks/bones.rake +7 -26
- data/tasks/gem.rake +49 -36
- data/tasks/git.rake +41 -0
- data/tasks/notes.rake +28 -0
- data/tasks/post_load.rake +19 -10
- data/tasks/{doc.rake → rdoc.rake} +10 -7
- data/tasks/rubyforge.rake +12 -11
- data/tasks/setup.rb +122 -81
- data/tasks/test.rake +6 -6
- data/test/appenders/test_console.rb +1 -1
- data/test/appenders/test_email.rb +4 -2
- data/test/appenders/test_file.rb +1 -1
- data/test/appenders/test_growl.rb +1 -1
- data/test/appenders/test_io.rb +1 -1
- data/test/appenders/test_rolling_file.rb +1 -1
- data/test/appenders/test_syslog.rb +1 -1
- data/test/benchmark.rb +1 -1
- data/test/config/test_yaml_configurator.rb +1 -1
- data/test/layouts/test_basic.rb +1 -1
- data/test/layouts/test_pattern.rb +1 -1
- data/test/setup.rb +3 -8
- data/test/test_appender.rb +1 -1
- data/test/test_layout.rb +1 -1
- data/test/test_log_event.rb +1 -1
- data/test/test_logger.rb +88 -11
- data/test/test_logging.rb +1 -1
- data/test/test_repository.rb +5 -1
- data/test/test_root_logger.rb +1 -1
- data/test/test_utils.rb +1 -1
- metadata +15 -7
- data/lib/logging/stelan/lockfile.rb +0 -530
- data/tasks/annotations.rake +0 -22
- data/tasks/svn.rake +0 -44
    
        data/tasks/bones.rake
    CHANGED
    
    | @@ -1,40 +1,21 @@ | |
| 1 | 
            -
            # $Id | 
| 1 | 
            +
            # $Id$
         | 
| 2 2 |  | 
| 3 | 
            -
             | 
| 4 | 
            -
            require 'stringio'
         | 
| 3 | 
            +
            if HAVE_BONES
         | 
| 5 4 |  | 
| 6 5 | 
             
            namespace :bones do
         | 
| 7 6 |  | 
| 8 7 | 
             
              desc 'Show the PROJ open struct'
         | 
| 9 8 | 
             
              task :debug do |t|
         | 
| 10 | 
            -
                atr = if  | 
| 9 | 
            +
                atr = if t.application.top_level_tasks.length == 2
         | 
| 11 10 | 
             
                  t.application.top_level_tasks.pop
         | 
| 12 11 | 
             
                end
         | 
| 13 | 
            -
                sio = StringIO.new
         | 
| 14 | 
            -
                sep = "\n" + ' '*27
         | 
| 15 | 
            -
                fmt = "%23s => %s"
         | 
| 16 12 |  | 
| 17 | 
            -
                if atr
         | 
| 18 | 
            -
             | 
| 19 | 
            -
                  sio.seek 0
         | 
| 20 | 
            -
                  val = sio.read
         | 
| 21 | 
            -
                  val = val.split("\n").join(sep)
         | 
| 22 | 
            -
             | 
| 23 | 
            -
                  puts fmt % [atr, val]
         | 
| 24 | 
            -
                else
         | 
| 25 | 
            -
                  h = PROJ.instance_variable_get(:@table)
         | 
| 26 | 
            -
                  h.keys.map {|k| k.to_s}.sort.each do |k|
         | 
| 27 | 
            -
                    sio.truncate 0
         | 
| 28 | 
            -
                    PP.pp(h[k.to_sym], sio, 49)
         | 
| 29 | 
            -
                    sio.seek 0
         | 
| 30 | 
            -
                    val = sio.read
         | 
| 31 | 
            -
                    val = val.split("\n").join(sep)
         | 
| 32 | 
            -
             | 
| 33 | 
            -
                    puts fmt % [k, val]
         | 
| 34 | 
            -
                  end
         | 
| 35 | 
            -
                end
         | 
| 13 | 
            +
                if atr then Bones::Debug.show_attr(PROJ, atr)
         | 
| 14 | 
            +
                else Bones::Debug.show PROJ end
         | 
| 36 15 | 
             
              end
         | 
| 37 16 |  | 
| 38 17 | 
             
            end  # namespace :bones
         | 
| 39 18 |  | 
| 19 | 
            +
            end  # HAVE_BONES
         | 
| 20 | 
            +
             | 
| 40 21 | 
             
            # EOF
         | 
    
        data/tasks/gem.rake
    CHANGED
    
    | @@ -4,84 +4,86 @@ require 'rake/gempackagetask' | |
| 4 4 |  | 
| 5 5 | 
             
            namespace :gem do
         | 
| 6 6 |  | 
| 7 | 
            -
              PROJ. | 
| 7 | 
            +
              PROJ.gem._spec = Gem::Specification.new do |s|
         | 
| 8 8 | 
             
                s.name = PROJ.name
         | 
| 9 9 | 
             
                s.version = PROJ.version
         | 
| 10 10 | 
             
                s.summary = PROJ.summary
         | 
| 11 11 | 
             
                s.authors = Array(PROJ.authors)
         | 
| 12 12 | 
             
                s.email = PROJ.email
         | 
| 13 13 | 
             
                s.homepage = Array(PROJ.url).first
         | 
| 14 | 
            -
                s.rubyforge_project = PROJ. | 
| 15 | 
            -
                s.post_install_message = PROJ.post_install_message
         | 
| 14 | 
            +
                s.rubyforge_project = PROJ.rubyforge.name
         | 
| 16 15 |  | 
| 17 16 | 
             
                s.description = PROJ.description
         | 
| 18 17 |  | 
| 19 | 
            -
                PROJ.dependencies.each do |dep|
         | 
| 18 | 
            +
                PROJ.gem.dependencies.each do |dep|
         | 
| 20 19 | 
             
                  s.add_dependency(*dep)
         | 
| 21 20 | 
             
                end
         | 
| 22 21 |  | 
| 23 | 
            -
                s.files = PROJ.files
         | 
| 24 | 
            -
                s.executables = PROJ.executables.map {|fn| File.basename(fn)}
         | 
| 25 | 
            -
                s.extensions = PROJ.files.grep %r/extconf\.rb$/
         | 
| 22 | 
            +
                s.files = PROJ.gem.files
         | 
| 23 | 
            +
                s.executables = PROJ.gem.executables.map {|fn| File.basename(fn)}
         | 
| 24 | 
            +
                s.extensions = PROJ.gem.files.grep %r/extconf\.rb$/
         | 
| 26 25 |  | 
| 27 26 | 
             
                s.bindir = 'bin'
         | 
| 28 27 | 
             
                dirs = Dir["{#{PROJ.libs.join(',')}}"]
         | 
| 29 28 | 
             
                s.require_paths = dirs unless dirs.empty?
         | 
| 30 29 |  | 
| 31 | 
            -
                incl = Regexp.new(PROJ. | 
| 32 | 
            -
                excl = PROJ. | 
| 30 | 
            +
                incl = Regexp.new(PROJ.rdoc.include.join('|'))
         | 
| 31 | 
            +
                excl = PROJ.rdoc.exclude.dup.concat %w[\.rb$ ^(\.\/|\/)?ext]
         | 
| 33 32 | 
             
                excl = Regexp.new(excl.join('|'))
         | 
| 34 | 
            -
                rdoc_files = PROJ.files.find_all do |fn|
         | 
| 33 | 
            +
                rdoc_files = PROJ.gem.files.find_all do |fn|
         | 
| 35 34 | 
             
                               case fn
         | 
| 36 35 | 
             
                               when excl; false
         | 
| 37 36 | 
             
                               when incl; true
         | 
| 38 37 | 
             
                               else false end
         | 
| 39 38 | 
             
                             end
         | 
| 40 | 
            -
                s.rdoc_options = PROJ. | 
| 39 | 
            +
                s.rdoc_options = PROJ.rdoc.opts + ['--main', PROJ.rdoc.main]
         | 
| 41 40 | 
             
                s.extra_rdoc_files = rdoc_files
         | 
| 42 41 | 
             
                s.has_rdoc = true
         | 
| 43 42 |  | 
| 44 | 
            -
                if test ?f, PROJ. | 
| 45 | 
            -
                  s.test_file = PROJ. | 
| 43 | 
            +
                if test ?f, PROJ.test.file
         | 
| 44 | 
            +
                  s.test_file = PROJ.test.file
         | 
| 46 45 | 
             
                else
         | 
| 47 | 
            -
                  s.test_files = PROJ. | 
| 46 | 
            +
                  s.test_files = PROJ.test.files.to_a
         | 
| 48 47 | 
             
                end
         | 
| 49 48 |  | 
| 50 49 | 
             
                # Do any extra stuff the user wants
         | 
| 51 | 
            -
             | 
| 52 | 
            -
             | 
| 53 | 
            -
             | 
| 54 | 
            -
             | 
| 55 | 
            -
             | 
| 56 | 
            -
             | 
| 57 | 
            -
             | 
| 58 | 
            -
             | 
| 59 | 
            -
              end
         | 
| 50 | 
            +
                PROJ.gem.extras.each do |msg, val|
         | 
| 51 | 
            +
                  case val
         | 
| 52 | 
            +
                  when Proc
         | 
| 53 | 
            +
                    val.call(s.send(msg))
         | 
| 54 | 
            +
                  else
         | 
| 55 | 
            +
                    s.send "#{msg}=", val
         | 
| 56 | 
            +
                  end
         | 
| 57 | 
            +
                end
         | 
| 58 | 
            +
              end  # Gem::Specification.new
         | 
| 59 | 
            +
             | 
| 60 | 
            +
              # A prerequisites task that all other tasks depend upon
         | 
| 61 | 
            +
              task :prereqs
         | 
| 60 62 |  | 
| 61 63 | 
             
              desc 'Show information about the gem'
         | 
| 62 | 
            -
              task :debug do
         | 
| 63 | 
            -
                puts PROJ. | 
| 64 | 
            +
              task :debug => 'gem:prereqs' do
         | 
| 65 | 
            +
                puts PROJ.gem._spec.to_ruby
         | 
| 64 66 | 
             
              end
         | 
| 65 67 |  | 
| 66 68 | 
             
              pkg = Rake::PackageTask.new(PROJ.name, PROJ.version) do |pkg|
         | 
| 67 | 
            -
                pkg.need_tar = PROJ.need_tar
         | 
| 68 | 
            -
                pkg.need_zip = PROJ.need_zip
         | 
| 69 | 
            -
                pkg.package_files += PROJ. | 
| 69 | 
            +
                pkg.need_tar = PROJ.gem.need_tar
         | 
| 70 | 
            +
                pkg.need_zip = PROJ.gem.need_zip
         | 
| 71 | 
            +
                pkg.package_files += PROJ.gem._spec.files
         | 
| 70 72 | 
             
              end
         | 
| 71 73 | 
             
              Rake::Task['gem:package'].instance_variable_set(:@full_comment, nil)
         | 
| 72 74 |  | 
| 73 | 
            -
              gem_file = if PROJ. | 
| 75 | 
            +
              gem_file = if PROJ.gem._spec.platform == Gem::Platform::RUBY
         | 
| 74 76 | 
             
                  "#{pkg.package_name}.gem"
         | 
| 75 77 | 
             
                else
         | 
| 76 | 
            -
                  "#{pkg.package_name}-#{PROJ. | 
| 78 | 
            +
                  "#{pkg.package_name}-#{PROJ.gem._spec.platform}.gem"
         | 
| 77 79 | 
             
                end
         | 
| 78 80 |  | 
| 79 81 | 
             
              desc "Build the gem file #{gem_file}"
         | 
| 80 | 
            -
              task :package => "#{pkg.package_dir}/#{gem_file}"
         | 
| 82 | 
            +
              task :package => ['gem:prereqs', "#{pkg.package_dir}/#{gem_file}"]
         | 
| 81 83 |  | 
| 82 | 
            -
              file "#{pkg.package_dir}/#{gem_file}" => [pkg.package_dir] + PROJ. | 
| 84 | 
            +
              file "#{pkg.package_dir}/#{gem_file}" => [pkg.package_dir] + PROJ.gem._spec.files do
         | 
| 83 85 | 
             
                when_writing("Creating GEM") {
         | 
| 84 | 
            -
                  Gem::Builder.new(PROJ. | 
| 86 | 
            +
                  Gem::Builder.new(PROJ.gem._spec).build
         | 
| 85 87 | 
             
                  verbose(true) {
         | 
| 86 88 | 
             
                    mv gem_file, "#{pkg.package_dir}/#{gem_file}"
         | 
| 87 89 | 
             
                  }
         | 
| @@ -89,18 +91,29 @@ namespace :gem do | |
| 89 91 | 
             
              end
         | 
| 90 92 |  | 
| 91 93 | 
             
              desc 'Install the gem'
         | 
| 92 | 
            -
              task :install => [:clobber, :package] do
         | 
| 93 | 
            -
                sh "#{SUDO} #{GEM} install pkg/#{PROJ. | 
| 94 | 
            +
              task :install => [:clobber, 'gem:package'] do
         | 
| 95 | 
            +
                sh "#{SUDO} #{GEM} install --local pkg/#{PROJ.gem._spec.full_name}"
         | 
| 96 | 
            +
             | 
| 97 | 
            +
                # use this version of the command for rubygems > 1.0.0
         | 
| 98 | 
            +
                #sh "#{SUDO} #{GEM} install --no-update-sources pkg/#{PROJ.gem._spec.full_name}"
         | 
| 94 99 | 
             
              end
         | 
| 95 100 |  | 
| 96 101 | 
             
              desc 'Uninstall the gem'
         | 
| 97 102 | 
             
              task :uninstall do
         | 
| 98 | 
            -
                 | 
| 103 | 
            +
                installed_list = Gem.source_index.find_name(PROJ.name)
         | 
| 104 | 
            +
                if installed_list and installed_list.collect { |s| s.version.to_s}.include?(PROJ.version) then
         | 
| 105 | 
            +
                  sh "#{SUDO} #{GEM} uninstall --version '#{PROJ.version}' --ignore-dependencies --executables #{PROJ.name}"
         | 
| 106 | 
            +
                end
         | 
| 99 107 | 
             
              end
         | 
| 100 108 |  | 
| 101 109 | 
             
              desc 'Reinstall the gem'
         | 
| 102 110 | 
             
              task :reinstall => [:uninstall, :install]
         | 
| 103 111 |  | 
| 112 | 
            +
              desc 'Cleanup the gem'
         | 
| 113 | 
            +
              task :cleanup do
         | 
| 114 | 
            +
                sh "#{SUDO} #{GEM} cleanup #{PROJ.gem._spec.name}"
         | 
| 115 | 
            +
              end
         | 
| 116 | 
            +
             | 
| 104 117 | 
             
            end  # namespace :gem
         | 
| 105 118 |  | 
| 106 119 | 
             
            desc 'Alias to gem:package'
         | 
    
        data/tasks/git.rake
    ADDED
    
    | @@ -0,0 +1,41 @@ | |
| 1 | 
            +
            # $Id$
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            if HAVE_GIT
         | 
| 4 | 
            +
             | 
| 5 | 
            +
            namespace :git do
         | 
| 6 | 
            +
             | 
| 7 | 
            +
              # A prerequisites task that all other tasks depend upon
         | 
| 8 | 
            +
              task :prereqs
         | 
| 9 | 
            +
             | 
| 10 | 
            +
              desc 'Show tags from the Git repository'
         | 
| 11 | 
            +
              task :show_tags => 'git:prereqs' do |t|
         | 
| 12 | 
            +
                puts %x/git tag/
         | 
| 13 | 
            +
              end
         | 
| 14 | 
            +
             | 
| 15 | 
            +
              desc 'Create a new tag in the Git repository'
         | 
| 16 | 
            +
              task :create_tag => 'git:prereqs' do |t|
         | 
| 17 | 
            +
                v = ENV['VERSION'] or abort 'Must supply VERSION=x.y.z'
         | 
| 18 | 
            +
                abort "Versions don't match #{v} vs #{PROJ.version}" if v != PROJ.version
         | 
| 19 | 
            +
             | 
| 20 | 
            +
                tag = "%s-%s" % [PROJ.name, PROJ.version]
         | 
| 21 | 
            +
                msg = "Creating tag for #{PROJ.name} version #{PROJ.version}"
         | 
| 22 | 
            +
             | 
| 23 | 
            +
                puts "Creating Git tag '#{tag}'"
         | 
| 24 | 
            +
                unless system "git tag -a -m '#{msg}' #{tag}"
         | 
| 25 | 
            +
                  abort "Tag creation failed"
         | 
| 26 | 
            +
                end
         | 
| 27 | 
            +
             | 
| 28 | 
            +
                if %x/git remote/ =~ %r/^origin\s*$/
         | 
| 29 | 
            +
                  unless system "git push origin #{tag}"
         | 
| 30 | 
            +
                    abort "Could not push tag to remote Git repository"
         | 
| 31 | 
            +
                  end
         | 
| 32 | 
            +
                end
         | 
| 33 | 
            +
              end
         | 
| 34 | 
            +
             | 
| 35 | 
            +
            end  # namespace :git
         | 
| 36 | 
            +
             | 
| 37 | 
            +
            #task 'gem:release' => 'git:create_tag'
         | 
| 38 | 
            +
             | 
| 39 | 
            +
            end  # if HAVE_GIT
         | 
| 40 | 
            +
             | 
| 41 | 
            +
            # EOF
         | 
    
        data/tasks/notes.rake
    ADDED
    
    | @@ -0,0 +1,28 @@ | |
| 1 | 
            +
            # $Id$
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            if HAVE_BONES
         | 
| 4 | 
            +
             | 
| 5 | 
            +
            desc "Enumerate all annotations"
         | 
| 6 | 
            +
            task :notes do |t|
         | 
| 7 | 
            +
              id = if t.application.top_level_tasks.length > 1
         | 
| 8 | 
            +
                t.application.top_level_tasks.slice!(1..-1).join(' ')
         | 
| 9 | 
            +
              end
         | 
| 10 | 
            +
              Bones::AnnotationExtractor.enumerate(
         | 
| 11 | 
            +
                  PROJ, PROJ.notes.tags.join('|'), id, :tag => true)
         | 
| 12 | 
            +
            end
         | 
| 13 | 
            +
             | 
| 14 | 
            +
            namespace :notes do
         | 
| 15 | 
            +
              PROJ.notes.tags.each do |tag|
         | 
| 16 | 
            +
                desc "Enumerate all #{tag} annotations"
         | 
| 17 | 
            +
                task tag.downcase.to_sym do |t|
         | 
| 18 | 
            +
                  id = if t.application.top_level_tasks.length > 1
         | 
| 19 | 
            +
                    t.application.top_level_tasks.slice!(1..-1).join(' ')
         | 
| 20 | 
            +
                  end
         | 
| 21 | 
            +
                  Bones::AnnotationExtractor.enumerate(PROJ, tag, id)
         | 
| 22 | 
            +
                end
         | 
| 23 | 
            +
              end
         | 
| 24 | 
            +
            end
         | 
| 25 | 
            +
             | 
| 26 | 
            +
            end  # if HAVE_BONES
         | 
| 27 | 
            +
             | 
| 28 | 
            +
            # EOF
         | 
    
        data/tasks/post_load.rake
    CHANGED
    
    | @@ -1,14 +1,23 @@ | |
| 1 | 
            -
            # $Id | 
| 1 | 
            +
            # $Id$
         | 
| 2 2 |  | 
| 3 3 | 
             
            # This file does not define any rake tasks. It is used to load some project
         | 
| 4 4 | 
             
            # settings if they are not defined by the user.
         | 
| 5 5 |  | 
| 6 | 
            -
            PROJ. | 
| 7 | 
            -
            PROJ.exclude << "^#{Regexp.escape(PROJ. | 
| 8 | 
            -
             | 
| 9 | 
            -
            PROJ. | 
| 10 | 
            -
             | 
| 11 | 
            -
             | 
| 6 | 
            +
            PROJ.rdoc.exclude << "^#{Regexp.escape(PROJ.manifest_file)}$"
         | 
| 7 | 
            +
            PROJ.exclude << ["^#{Regexp.escape(PROJ.ann.file)}$",
         | 
| 8 | 
            +
                             "^#{Regexp.escape(PROJ.rdoc.dir)}/",
         | 
| 9 | 
            +
                             "^#{Regexp.escape(PROJ.rcov.dir)}/"]
         | 
| 10 | 
            +
             | 
| 11 | 
            +
            flatten_arrays = lambda do |this,os|
         | 
| 12 | 
            +
                os.instance_variable_get(:@table).each do |key,val|
         | 
| 13 | 
            +
                  next if key == :dependencies
         | 
| 14 | 
            +
                  case val
         | 
| 15 | 
            +
                  when Array; val.flatten!
         | 
| 16 | 
            +
                  when OpenStruct; this.call(this,val)
         | 
| 17 | 
            +
                  end
         | 
| 18 | 
            +
                end
         | 
| 19 | 
            +
              end
         | 
| 20 | 
            +
            flatten_arrays.call(flatten_arrays,PROJ)
         | 
| 12 21 |  | 
| 13 22 | 
             
            PROJ.changes ||= paragraphs_of(PROJ.history_file, 0..1).join("\n\n")
         | 
| 14 23 |  | 
| @@ -16,15 +25,15 @@ PROJ.description ||= paragraphs_of(PROJ.readme_file, 'description').join("\n\n") | |
| 16 25 |  | 
| 17 26 | 
             
            PROJ.summary ||= PROJ.description.split('.').first
         | 
| 18 27 |  | 
| 19 | 
            -
            PROJ.files ||=
         | 
| 28 | 
            +
            PROJ.gem.files ||=
         | 
| 20 29 | 
             
              if test(?f, PROJ.manifest_file)
         | 
| 21 30 | 
             
                files = File.readlines(PROJ.manifest_file).map {|fn| fn.chomp.strip}
         | 
| 22 31 | 
             
                files.delete ''
         | 
| 23 32 | 
             
                files
         | 
| 24 33 | 
             
              else [] end
         | 
| 25 34 |  | 
| 26 | 
            -
            PROJ.executables ||= PROJ.files.find_all {|fn| fn =~ %r/^bin/}
         | 
| 35 | 
            +
            PROJ.gem.executables ||= PROJ.gem.files.find_all {|fn| fn =~ %r/^bin/}
         | 
| 27 36 |  | 
| 28 | 
            -
            PROJ. | 
| 37 | 
            +
            PROJ.rdoc.main ||= PROJ.readme_file
         | 
| 29 38 |  | 
| 30 39 | 
             
            # EOF
         | 
| @@ -6,12 +6,13 @@ namespace :doc do | |
| 6 6 |  | 
| 7 7 | 
             
              desc 'Generate RDoc documentation'
         | 
| 8 8 | 
             
              Rake::RDocTask.new do |rd|
         | 
| 9 | 
            -
                 | 
| 10 | 
            -
                rd. | 
| 9 | 
            +
                rdoc = PROJ.rdoc
         | 
| 10 | 
            +
                rd.main = rdoc.main
         | 
| 11 | 
            +
                rd.rdoc_dir = rdoc.dir
         | 
| 11 12 |  | 
| 12 | 
            -
                incl = Regexp.new( | 
| 13 | 
            -
                excl = Regexp.new( | 
| 14 | 
            -
                files = PROJ.files.find_all do |fn|
         | 
| 13 | 
            +
                incl = Regexp.new(rdoc.include.join('|'))
         | 
| 14 | 
            +
                excl = Regexp.new(rdoc.exclude.join('|'))
         | 
| 15 | 
            +
                files = PROJ.gem.files.find_all do |fn|
         | 
| 15 16 | 
             
                          case fn
         | 
| 16 17 | 
             
                          when excl; false
         | 
| 17 18 | 
             
                          when incl; true
         | 
| @@ -20,10 +21,12 @@ namespace :doc do | |
| 20 21 | 
             
                rd.rdoc_files.push(*files)
         | 
| 21 22 |  | 
| 22 23 | 
             
                title = "#{PROJ.name}-#{PROJ.version} Documentation"
         | 
| 23 | 
            -
             | 
| 24 | 
            +
             | 
| 25 | 
            +
                rf_name = PROJ.rubyforge.name
         | 
| 26 | 
            +
                title = "#{rf_name}'s " + title if rf_name.valid? and rf_name != title
         | 
| 24 27 |  | 
| 25 28 | 
             
                rd.options << "-t #{title}"
         | 
| 26 | 
            -
                rd.options.concat( | 
| 29 | 
            +
                rd.options.concat(rdoc.opts)
         | 
| 27 30 | 
             
              end
         | 
| 28 31 |  | 
| 29 32 | 
             
              desc 'Generate ri locally for testing'
         | 
    
        data/tasks/rubyforge.rake
    CHANGED
    
    | @@ -1,23 +1,24 @@ | |
| 1 1 | 
             
            # $Id$
         | 
| 2 2 |  | 
| 3 | 
            -
            if PROJ. | 
| 3 | 
            +
            if PROJ.rubyforge.name.valid? && HAVE_RUBYFORGE
         | 
| 4 4 |  | 
| 5 5 | 
             
            require 'rubyforge'
         | 
| 6 6 | 
             
            require 'rake/contrib/sshpublisher'
         | 
| 7 7 |  | 
| 8 8 | 
             
            namespace :gem do
         | 
| 9 9 | 
             
              desc 'Package and upload to RubyForge'
         | 
| 10 | 
            -
              task :release => [:clobber, :package] do |t|
         | 
| 10 | 
            +
              task :release => [:clobber, 'gem:package'] do |t|
         | 
| 11 11 | 
             
                v = ENV['VERSION'] or abort 'Must supply VERSION=x.y.z'
         | 
| 12 12 | 
             
                abort "Versions don't match #{v} vs #{PROJ.version}" if v != PROJ.version
         | 
| 13 | 
            -
                pkg = "pkg/#{PROJ. | 
| 13 | 
            +
                pkg = "pkg/#{PROJ.gem._spec.full_name}"
         | 
| 14 14 |  | 
| 15 15 | 
             
                if $DEBUG then
         | 
| 16 | 
            -
                  puts "release_id = rf.add_release #{PROJ. | 
| 17 | 
            -
                  puts "rf.add_file #{PROJ. | 
| 16 | 
            +
                  puts "release_id = rf.add_release #{PROJ.rubyforge.name.inspect}, #{PROJ.name.inspect}, #{PROJ.version.inspect}, \"#{pkg}.tgz\""
         | 
| 17 | 
            +
                  puts "rf.add_file #{PROJ.rubyforge.name.inspect}, #{PROJ.name.inspect}, release_id, \"#{pkg}.gem\""
         | 
| 18 18 | 
             
                end
         | 
| 19 19 |  | 
| 20 20 | 
             
                rf = RubyForge.new
         | 
| 21 | 
            +
                rf.configure
         | 
| 21 22 | 
             
                puts 'Logging in'
         | 
| 22 23 | 
             
                rf.login
         | 
| 23 24 |  | 
| @@ -26,12 +27,12 @@ namespace :gem do | |
| 26 27 | 
             
                c['release_changes'] = PROJ.changes if PROJ.changes
         | 
| 27 28 | 
             
                c['preformatted'] = true
         | 
| 28 29 |  | 
| 29 | 
            -
                files = [(PROJ.need_tar ? "#{pkg}.tgz" : nil),
         | 
| 30 | 
            -
                         (PROJ.need_zip ? "#{pkg}.zip" : nil),
         | 
| 30 | 
            +
                files = [(PROJ.gem.need_tar ? "#{pkg}.tgz" : nil),
         | 
| 31 | 
            +
                         (PROJ.gem.need_zip ? "#{pkg}.zip" : nil),
         | 
| 31 32 | 
             
                         "#{pkg}.gem"].compact
         | 
| 32 33 |  | 
| 33 34 | 
             
                puts "Releasing #{PROJ.name} v. #{PROJ.version}"
         | 
| 34 | 
            -
                rf.add_release PROJ. | 
| 35 | 
            +
                rf.add_release PROJ.rubyforge.name, PROJ.name, PROJ.version, *files
         | 
| 35 36 | 
             
              end
         | 
| 36 37 | 
             
            end  # namespace :gem
         | 
| 37 38 |  | 
| @@ -44,9 +45,9 @@ namespace :doc do | |
| 44 45 | 
             
                )
         | 
| 45 46 |  | 
| 46 47 | 
             
                host = "#{config['username']}@rubyforge.org"
         | 
| 47 | 
            -
                remote_dir = "/var/www/gforge-projects/#{PROJ. | 
| 48 | 
            -
                remote_dir << PROJ. | 
| 49 | 
            -
                local_dir = PROJ. | 
| 48 | 
            +
                remote_dir = "/var/www/gforge-projects/#{PROJ.rubyforge.name}/"
         | 
| 49 | 
            +
                remote_dir << PROJ.rdoc.remote_dir if PROJ.rdoc.remote_dir
         | 
| 50 | 
            +
                local_dir = PROJ.rdoc.dir
         | 
| 50 51 |  | 
| 51 52 | 
             
                Rake::SshDirPublisher.new(host, remote_dir, local_dir).upload
         | 
| 52 53 | 
             
              end
         | 
    
        data/tasks/setup.rb
    CHANGED
    
    | @@ -1,4 +1,4 @@ | |
| 1 | 
            -
            # $Id | 
| 1 | 
            +
            # $Id$
         | 
| 2 2 |  | 
| 3 3 | 
             
            require 'rubygems'
         | 
| 4 4 | 
             
            require 'rake'
         | 
| @@ -6,92 +6,117 @@ require 'rake/clean' | |
| 6 6 | 
             
            require 'fileutils'
         | 
| 7 7 | 
             
            require 'ostruct'
         | 
| 8 8 |  | 
| 9 | 
            -
             | 
| 10 | 
            -
             | 
| 11 | 
            -
            PROJ | 
| 12 | 
            -
             | 
| 13 | 
            -
             | 
| 14 | 
            -
             | 
| 15 | 
            -
             | 
| 16 | 
            -
             | 
| 17 | 
            -
             | 
| 18 | 
            -
             | 
| 19 | 
            -
             | 
| 20 | 
            -
             | 
| 21 | 
            -
             | 
| 22 | 
            -
             | 
| 23 | 
            -
             | 
| 24 | 
            -
             | 
| 25 | 
            -
             | 
| 26 | 
            -
             | 
| 27 | 
            -
             | 
| 28 | 
            -
             | 
| 29 | 
            -
             | 
| 30 | 
            -
             | 
| 31 | 
            -
             | 
| 32 | 
            -
             | 
| 33 | 
            -
             | 
| 34 | 
            -
             | 
| 35 | 
            -
             | 
| 36 | 
            -
             | 
| 37 | 
            -
             | 
| 38 | 
            -
             | 
| 39 | 
            -
             | 
| 40 | 
            -
             | 
| 41 | 
            -
             | 
| 42 | 
            -
             | 
| 43 | 
            -
             | 
| 44 | 
            -
             | 
| 45 | 
            -
             | 
| 46 | 
            -
             | 
| 47 | 
            -
             | 
| 48 | 
            -
             | 
| 49 | 
            -
             | 
| 50 | 
            -
             | 
| 51 | 
            -
             | 
| 52 | 
            -
             | 
| 53 | 
            -
             | 
| 9 | 
            +
            class OpenStruct; undef :gem; end
         | 
| 10 | 
            +
             | 
| 11 | 
            +
            PROJ = OpenStruct.new(
         | 
| 12 | 
            +
              # Project Defaults
         | 
| 13 | 
            +
              :name => nil,
         | 
| 14 | 
            +
              :summary => nil,
         | 
| 15 | 
            +
              :description => nil,
         | 
| 16 | 
            +
              :changes => nil,
         | 
| 17 | 
            +
              :authors => nil,
         | 
| 18 | 
            +
              :email => nil,
         | 
| 19 | 
            +
              :url => "\000",
         | 
| 20 | 
            +
              :version => ENV['VERSION'] || '0.0.0',
         | 
| 21 | 
            +
              :exclude => %w(tmp$ bak$ ~$ CVS \.svn/ \.git/ ^pkg/),
         | 
| 22 | 
            +
              :release_name => ENV['RELEASE'],
         | 
| 23 | 
            +
             | 
| 24 | 
            +
              # System Defaults
         | 
| 25 | 
            +
              :ruby_opts => %w(-w),
         | 
| 26 | 
            +
              :libs => [],
         | 
| 27 | 
            +
              :history_file => 'History.txt',
         | 
| 28 | 
            +
              :manifest_file => 'Manifest.txt',
         | 
| 29 | 
            +
              :readme_file => 'README.txt',
         | 
| 30 | 
            +
             | 
| 31 | 
            +
              # Announce
         | 
| 32 | 
            +
              :ann => OpenStruct.new(
         | 
| 33 | 
            +
                :file => 'announcement.txt',
         | 
| 34 | 
            +
                :text => nil,
         | 
| 35 | 
            +
                :paragraphs => [],
         | 
| 36 | 
            +
                :email => {
         | 
| 37 | 
            +
                  :from     => nil,
         | 
| 38 | 
            +
                  :to       => %w(ruby-talk@ruby-lang.org),
         | 
| 39 | 
            +
                  :server   => 'localhost',
         | 
| 40 | 
            +
                  :port     => 25,
         | 
| 41 | 
            +
                  :domain   => ENV['HOSTNAME'],
         | 
| 42 | 
            +
                  :acct     => nil,
         | 
| 43 | 
            +
                  :passwd   => nil,
         | 
| 44 | 
            +
                  :authtype => :plain
         | 
| 45 | 
            +
                }
         | 
| 46 | 
            +
              ),
         | 
| 47 | 
            +
             | 
| 48 | 
            +
              # Gem Packaging
         | 
| 49 | 
            +
              :gem => OpenStruct.new(
         | 
| 50 | 
            +
                :dependencies => [],
         | 
| 51 | 
            +
                :executables => nil,
         | 
| 52 | 
            +
                :extensions => FileList['ext/**/extconf.rb'],
         | 
| 53 | 
            +
                :files => nil,
         | 
| 54 | 
            +
                :need_tar => true,
         | 
| 55 | 
            +
                :need_zip => false,
         | 
| 56 | 
            +
                :extras => {}
         | 
| 57 | 
            +
              ),
         | 
| 58 | 
            +
             | 
| 59 | 
            +
              # File Annotations
         | 
| 60 | 
            +
              :notes => OpenStruct.new(
         | 
| 61 | 
            +
                :exclude => %w(^tasks/setup\.rb$),
         | 
| 62 | 
            +
                :extensions => %w(.txt .rb .erb) << '',
         | 
| 63 | 
            +
                :tags => %w(FIXME OPTIMIZE TODO)
         | 
| 64 | 
            +
              ),
         | 
| 65 | 
            +
             | 
| 66 | 
            +
              # Rcov
         | 
| 67 | 
            +
              :rcov => OpenStruct.new(
         | 
| 68 | 
            +
                :dir => 'coverage',
         | 
| 69 | 
            +
                :opts => %w[--sort coverage -T],
         | 
| 70 | 
            +
                :threshold => 90.0,
         | 
| 71 | 
            +
                :threshold_exact => false
         | 
| 72 | 
            +
              ),
         | 
| 73 | 
            +
             | 
| 74 | 
            +
              # Rdoc
         | 
| 75 | 
            +
              :rdoc => OpenStruct.new(
         | 
| 76 | 
            +
                :opts => [],
         | 
| 77 | 
            +
                :include => %w(^lib/ ^bin/ ^ext/ \.txt$),
         | 
| 78 | 
            +
                :exclude => %w(extconf\.rb$),
         | 
| 79 | 
            +
                :main => nil,
         | 
| 80 | 
            +
                :dir => 'doc',
         | 
| 81 | 
            +
                :remote_dir => nil
         | 
| 82 | 
            +
              ),
         | 
| 83 | 
            +
             | 
| 84 | 
            +
              # Rubyforge
         | 
| 85 | 
            +
              :rubyforge => OpenStruct.new(
         | 
| 86 | 
            +
                :name => "\000"
         | 
| 87 | 
            +
              ),
         | 
| 54 88 |  | 
| 55 | 
            -
            #  | 
| 56 | 
            -
             | 
| 57 | 
            -
             | 
| 58 | 
            -
             | 
| 59 | 
            -
             | 
| 60 | 
            -
             | 
| 61 | 
            -
             | 
| 62 | 
            -
             | 
| 63 | 
            -
             | 
| 64 | 
            -
             | 
| 65 | 
            -
             | 
| 66 | 
            -
             | 
| 67 | 
            -
             | 
| 68 | 
            -
             | 
| 69 | 
            -
             | 
| 70 | 
            -
             | 
| 71 | 
            -
             | 
| 72 | 
            -
             | 
| 73 | 
            -
             | 
| 74 | 
            -
             | 
| 75 | 
            -
             | 
| 76 | 
            -
             | 
| 77 | 
            -
            PROJ.ann_text = nil
         | 
| 78 | 
            -
            PROJ.ann_paragraphs = []
         | 
| 79 | 
            -
            PROJ.ann_email = {
         | 
| 80 | 
            -
              :from     => nil,
         | 
| 81 | 
            -
              :to       => %w(ruby-talk@ruby-lang.org),
         | 
| 82 | 
            -
              :server   => 'localhost',
         | 
| 83 | 
            -
              :port     => 25,
         | 
| 84 | 
            -
              :domain   => ENV['HOSTNAME'],
         | 
| 85 | 
            -
              :acct     => nil,
         | 
| 86 | 
            -
              :passwd   => nil,
         | 
| 87 | 
            -
              :authtype => :plain
         | 
| 88 | 
            -
            }
         | 
| 89 | 
            +
              # Rspec
         | 
| 90 | 
            +
              :spec => OpenStruct.new(
         | 
| 91 | 
            +
                :files => FileList['spec/**/*_spec.rb'],
         | 
| 92 | 
            +
                :opts => []
         | 
| 93 | 
            +
              ),
         | 
| 94 | 
            +
             | 
| 95 | 
            +
              # Subversion Repository
         | 
| 96 | 
            +
              :svn => OpenStruct.new(
         | 
| 97 | 
            +
                :root => nil,
         | 
| 98 | 
            +
                :path => '',
         | 
| 99 | 
            +
                :trunk => 'trunk',
         | 
| 100 | 
            +
                :tags => 'tags',
         | 
| 101 | 
            +
                :branches => 'branches'
         | 
| 102 | 
            +
              ),
         | 
| 103 | 
            +
             | 
| 104 | 
            +
              # Test::Unit
         | 
| 105 | 
            +
              :test => OpenStruct.new(
         | 
| 106 | 
            +
                :files => FileList['test/**/test_*.rb'],
         | 
| 107 | 
            +
                :file  => 'test/all.rb',
         | 
| 108 | 
            +
                :opts  => []
         | 
| 109 | 
            +
              )
         | 
| 110 | 
            +
            )
         | 
| 89 111 |  | 
| 90 112 | 
             
            # Load the other rake files in the tasks folder
         | 
| 91 113 | 
             
            rakefiles = Dir.glob('tasks/*.rake').sort
         | 
| 92 114 | 
             
            rakefiles.unshift(rakefiles.delete('tasks/post_load.rake')).compact!
         | 
| 93 115 | 
             
            import(*rakefiles)
         | 
| 94 116 |  | 
| 117 | 
            +
            # Setup the project libraries
         | 
| 118 | 
            +
            %w(lib ext).each {|dir| PROJ.libs << dir if test ?d, dir}
         | 
| 119 | 
            +
             | 
| 95 120 | 
             
            # Setup some constants
         | 
| 96 121 | 
             
            WIN32 = %r/djgpp|(cyg|ms|bcc)win|mingw/ =~ RUBY_PLATFORM unless defined? WIN32
         | 
| 97 122 |  | 
| @@ -105,6 +130,7 @@ def quiet( &block ) | |
| 105 130 | 
             
            ensure
         | 
| 106 131 | 
             
              STDOUT.reopen io.first
         | 
| 107 132 | 
             
              STDERR.reopen io.last
         | 
| 133 | 
            +
              $stdout, $stderr = STDOUT, STDERR
         | 
| 108 134 | 
             
            end
         | 
| 109 135 |  | 
| 110 136 | 
             
            DIFF = if WIN32 then 'diff.exe'
         | 
| @@ -120,6 +146,7 @@ SUDO = if WIN32 then '' | |
| 120 146 | 
             
                   end
         | 
| 121 147 |  | 
| 122 148 | 
             
            RCOV = WIN32 ? 'rcov.bat' : 'rcov'
         | 
| 149 | 
            +
            RDOC = WIN32 ? 'rdoc.bat' : 'rdoc'
         | 
| 123 150 | 
             
            GEM  = WIN32 ? 'gem.bat'  : 'gem'
         | 
| 124 151 |  | 
| 125 152 | 
             
            %w(rcov spec/rake/spectask rubyforge bones facets/ansicode).each do |lib|
         | 
| @@ -130,6 +157,10 @@ GEM  = WIN32 ? 'gem.bat'  : 'gem' | |
| 130 157 | 
             
                Object.instance_eval {const_set "HAVE_#{lib.tr('/','_').upcase}", false}
         | 
| 131 158 | 
             
              end
         | 
| 132 159 | 
             
            end
         | 
| 160 | 
            +
            HAVE_SVN = (Dir.entries(Dir.pwd).include?('.svn') and
         | 
| 161 | 
            +
                        system("svn --version 2>&1 > #{DEV_NULL}"))
         | 
| 162 | 
            +
            HAVE_GIT = (Dir.entries(Dir.pwd).include?('.git') and
         | 
| 163 | 
            +
                        system("git --version 2>&1 > #{DEV_NULL}"))
         | 
| 133 164 |  | 
| 134 165 | 
             
            # Reads a file at +path+ and spits out an array of the +paragraphs+
         | 
| 135 166 | 
             
            # specified.
         | 
| @@ -169,7 +200,7 @@ def depend_on( name, version = nil ) | |
| 169 200 | 
             
              spec = Gem.source_index.find_name(name).last
         | 
| 170 201 | 
             
              version = spec.version.to_s if version.nil? and !spec.nil?
         | 
| 171 202 |  | 
| 172 | 
            -
              PROJ.dependencies << case version
         | 
| 203 | 
            +
              PROJ.gem.dependencies << case version
         | 
| 173 204 | 
             
                when nil; [name]
         | 
| 174 205 | 
             
                when %r/^\d/; [name, ">= #{version}"]
         | 
| 175 206 | 
             
                else [name, version] end
         | 
| @@ -224,4 +255,14 @@ def manifest_files | |
| 224 255 | 
             
              files.sort!
         | 
| 225 256 | 
             
            end
         | 
| 226 257 |  | 
| 258 | 
            +
            # We need a "valid" method thtat determines if a string is suitable for use
         | 
| 259 | 
            +
            # in the gem specification.
         | 
| 260 | 
            +
            #
         | 
| 261 | 
            +
            class Object
         | 
| 262 | 
            +
              def valid?
         | 
| 263 | 
            +
                return !(self.empty? or self == "\000") if self.respond_to?(:to_str)
         | 
| 264 | 
            +
                return false
         | 
| 265 | 
            +
              end
         | 
| 266 | 
            +
            end
         | 
| 267 | 
            +
             | 
| 227 268 | 
             
            # EOF
         |