echoe 4.0 → 4.1

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.
Files changed (7) hide show
  1. data.tar.gz.sig +0 -0
  2. data/CHANGELOG +2 -0
  3. data/Rakefile +1 -1
  4. data/echoe.gemspec +4 -4
  5. data/lib/echoe.rb +36 -43
  6. metadata +2 -2
  7. metadata.gz.sig +0 -0
data.tar.gz.sig CHANGED
Binary file
data/CHANGELOG CHANGED
@@ -1,4 +1,6 @@
1
1
 
2
+ v4.1. Remove prompts until I can find a cursor library that's not GPL. Restore Rubyforge gem dependency, for the announce method.
3
+
2
4
  v4.0. Use gemcutter. Dump Rubyforge.
3
5
 
4
6
  v3.2. Sort manifest.
data/Rakefile CHANGED
@@ -7,7 +7,7 @@ Echoe.new('echoe') do |p|
7
7
  p.summary = 'A Rubygems packaging tool that provides Rake tasks for documentation, extension compiling, testing, and deployment.'
8
8
  p.url = 'http://blog.evanweaver.com/files/doc/fauna/echoe/'
9
9
  p.docs_host = 'blog.evanweaver.com:~/www/bax/public/files/doc/'
10
- p.runtime_dependencies = ['gemcutter', 'highline']
10
+ p.runtime_dependencies = ['gemcutter', 'rubyforge']
11
11
  p.development_dependencies = []
12
12
  p.retain_gemspec = true
13
13
  end
@@ -2,7 +2,7 @@
2
2
 
3
3
  Gem::Specification.new do |s|
4
4
  s.name = %q{echoe}
5
- s.version = "4.0"
5
+ s.version = "4.1"
6
6
 
7
7
  s.required_rubygems_version = Gem::Requirement.new(">= 1.2") if s.respond_to? :required_rubygems_version=
8
8
  s.authors = ["Evan Weaver"]
@@ -26,13 +26,13 @@ Gem::Specification.new do |s|
26
26
 
27
27
  if Gem::Version.new(Gem::RubyGemsVersion) >= Gem::Version.new('1.2.0') then
28
28
  s.add_runtime_dependency(%q<gemcutter>, [">= 0"])
29
- s.add_runtime_dependency(%q<highline>, [">= 0"])
29
+ s.add_runtime_dependency(%q<rubyforge>, [">= 0"])
30
30
  else
31
31
  s.add_dependency(%q<gemcutter>, [">= 0"])
32
- s.add_dependency(%q<highline>, [">= 0"])
32
+ s.add_dependency(%q<rubyforge>, [">= 0"])
33
33
  end
34
34
  else
35
35
  s.add_dependency(%q<gemcutter>, [">= 0"])
36
- s.add_dependency(%q<highline>, [">= 0"])
36
+ s.add_dependency(%q<rubyforge>, [">= 0"])
37
37
  end
38
38
  end
@@ -18,12 +18,11 @@ require 'open-uri'
18
18
  require "#{$HERE}/echoe/extensions"
19
19
 
20
20
  require 'rubygems'
21
+ require 'rubyforge'
21
22
  require 'rubygems/specification'
22
23
  require "#{$HERE}/echoe/rubygems"
23
24
  require 'rubygems_plugin'
24
25
 
25
- require 'highline/import'
26
-
27
26
  begin; require 'rcov/rcovtask'; rescue LoadError; end
28
27
  begin; require 'load_multi_rails_rake_tasks'; rescue LoadError; end
29
28
 
@@ -462,18 +461,14 @@ class Echoe
462
461
 
463
462
  desc 'Package and upload the release to Gemcutter'
464
463
  task :release => [:clean, :package] do |t|
465
-
466
- say "\n"
467
- if agree "Release #{name}-#{version} to Gemcutter? "
468
- pkg = "pkg/#{name}-#{version}"
469
- pkg_gem = pkg + ".gem"
470
- pkg_tar = pkg + ".tgz"
471
- pkg_tar_gz = pkg + ".tar.gz"
472
- pkg_zip = pkg + ".zip"
473
-
474
- puts "Releasing #{name} v. #{version}"
475
- Gem::Commands::PushCommand.new.invoke(pkg_gem)
476
- end
464
+ pkg = "pkg/#{name}-#{version}"
465
+ pkg_gem = pkg + ".gem"
466
+ pkg_tar = pkg + ".tgz"
467
+ pkg_tar_gz = pkg + ".tar.gz"
468
+ pkg_zip = pkg + ".zip"
469
+
470
+ puts "Releasing #{name} v. #{version} to Gemcutter."
471
+ Gem::Commands::PushCommand.new.invoke(pkg_gem)
477
472
  end
478
473
 
479
474
  ### Extension building
@@ -579,41 +574,40 @@ class Echoe
579
574
 
580
575
  filename = "/tmp/#{name}_#{version}_announcement.txt"
581
576
 
582
- if !File.exist?(filename) or agree "Overwrite existing announcement file? "
583
- File.open(filename, 'w') do |f|
584
- f.write "Subject: #{name.capitalize} #{version}\n\n"
585
- f.write "#{name.capitalize} has been updated to #{version}. #{name.capitalize} is #{summary.uncapitalize}\n\n"
586
- unless changes.empty?
587
- f.write "Changes in this version: "
588
- if changes.include?("\n")
589
- f.write(changes)
590
- else
591
- f.write(changes.sub(/^\s*[\w\d\.]+\s+/, '').uncapitalize)
592
- end
593
- f.write("\n\n")
577
+ if File.exist?(filename)
578
+ puts "Announcement file already exists. Please delete #{filename.inspect} first."
579
+ exit(1)
580
+ end
581
+
582
+ File.open(filename, 'w') do |f|
583
+ f.write "Subject: #{name.capitalize} #{version}\n\n"
584
+ f.write "#{name.capitalize} has been updated to #{version}. #{name.capitalize} is #{summary.uncapitalize}\n\n"
585
+ unless changes.empty?
586
+ f.write "Changes in this version: "
587
+ if changes.include?("\n")
588
+ f.write(changes)
589
+ else
590
+ f.write(changes.sub(/^\s*[\w\d\.]+\s+/, '').uncapitalize)
594
591
  end
595
- f.write "More information is available at #{url} .\n\n" unless url.empty?
592
+ f.write("\n\n")
596
593
  end
594
+ f.write "More information is available at #{url} .\n\n" unless url.empty?
597
595
  end
598
596
 
599
- begin
600
- editor = ENV['EDITOR'] || 'nano'
601
- system("#{editor} #{filename}") or raise "Editor '#{editor}' failed to start"
602
- puts File.open(filename).read
603
- end while !agree "Done editing? "
597
+ editor = ENV['EDITOR'] || 'nano'
598
+ system("#{editor} #{filename}") or raise "Editor '#{editor}' failed to start"
599
+ puts File.open(filename).read
604
600
 
605
- if agree "Publish announcement to Rubyforge? "
606
- File.open(filename).readlines.detect { |line| line =~ /Subject: (.*)/ }
607
- subject = $1 or raise "Subject line seems to have disappeared"
601
+ File.open(filename).readlines.detect { |line| line =~ /Subject: (.*)/ }
602
+ subject = $1 or raise "Subject line seems to have disappeared"
608
603
 
609
- body = File.open(filename).readlines.reject { |line| line =~ /Subject: / }.join.gsub("\n\n\n", "\n\n")
604
+ body = File.open(filename).readlines.reject { |line| line =~ /Subject: / }.join.gsub("\n\n\n", "\n\n")
610
605
 
611
- rf = RubyForge.new.configure
612
- rf.login
613
- rf.post_news(project, subject, body)
614
- puts "Published."
615
- File.delete filename
616
- end
606
+ rf = RubyForge.new.configure
607
+ rf.login
608
+ rf.post_news(project, subject, body)
609
+ puts "Published announcement to Rubyforge."
610
+ File.delete filename
617
611
  end
618
612
 
619
613
  ### Clean
@@ -719,7 +713,6 @@ class Echoe
719
713
  end
720
714
  task :rcov => :coverage
721
715
  end
722
-
723
716
  end
724
717
  end
725
718
 
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: echoe
3
3
  version: !ruby/object:Gem::Version
4
- version: "4.0"
4
+ version: "4.1"
5
5
  platform: ruby
6
6
  authors:
7
7
  - Evan Weaver
@@ -44,7 +44,7 @@ dependencies:
44
44
  version: "0"
45
45
  version:
46
46
  - !ruby/object:Gem::Dependency
47
- name: highline
47
+ name: rubyforge
48
48
  type: :runtime
49
49
  version_requirement:
50
50
  version_requirements: !ruby/object:Gem::Requirement
metadata.gz.sig CHANGED
Binary file