public
Description: Piston is a utility that eases vendor branch management. This repository is a complete reimplementation of Piston to provide different backends, depending on the repositories and working copies you pistonize from.
Homepage: http://piston.rubyforge.org/
Clone URL: git://github.com/francois/piston.git
francois (author)
Fri May 09 06:56:17 -0700 2008
commit  b78d52bb13bc707c6af3eecd7a02a67d8f8ffd19
tree    75ee16aa7b6817958ab0264c021ced9987fcb53d
parent  29185f5c30acfc9ab36f661bd44d1429e0e8d336
piston / config / hoe.rb
100644 76 lines (64 sloc) 2.328 kb
1
2
3
4
5
6
7
8
9
10
11
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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
require "piston/version"
 
AUTHOR = "Francois Beausoleil"
EMAIL = "francois@teksol.info"
DESCRIPTION = "description of gem"
GEM_NAME = "piston"
 
RUBYFORGE_PROJECT = "piston"
HOMEPATH = "http://#{RUBYFORGE_PROJECT}.rubyforge.org"
DOWNLOAD_PATH = "http://rubyforge.org/projects/#{RUBYFORGE_PROJECT}"
 
@config_file = "~/.rubyforge/user-config.yml"
@config = nil
RUBYFORGE_USERNAME = "unknown"
def rubyforge_username
  unless @config
    begin
      @config = YAML.load(File.read(File.expand_path(@config_file)))
    rescue
      puts <<-EOS
ERROR: No rubyforge config file found: #{@config_file}
Run "rubyforge setup" to prepare your env for access to Rubyforge
- See http://newgem.rubyforge.org/rubyforge.html for more details
EOS
      exit
    end
  end
  RUBYFORGE_USERNAME.replace @config["username"]
end
 
 
REV = nil
# UNCOMMENT IF REQUIRED:
# REV = `svn info`.each {|line| if line =~ /^Revision:/ then k,v = line.split(': '); break v.chomp; else next; end} rescue nil
VERS = Piston::VERSION::STRING + (REV ? ".#{REV}" : "")
RDOC_OPTS = ["--quiet", "--title", "Piston Documentation",
    "--opname", "index.html",
    "--line-numbers",
    "--main", "README",
    "--inline-source"]
 
class Hoe
  def extra_deps
    @extra_deps.reject! { |x| Array(x).first == "hoe" }
    @extra_deps
  end
end
 
# Generate all the Rake tasks
# Run 'rake -T' to see list of generated tasks (from gem root directory)
hoe = Hoe.new(GEM_NAME, VERS) do |p|
  p.developer(AUTHOR, EMAIL)
  p.description = DESCRIPTION
  p.summary = DESCRIPTION
  p.url = HOMEPATH
  p.rubyforge_name = RUBYFORGE_PROJECT if RUBYFORGE_PROJECT
  p.test_globs = ["test/**/test_*.rb"]
  p.clean_globs |= ["**/.*.sw?", "*.gem", ".config", "**/.DS_Store"] #An array of file patterns to delete on clean.
  
  # == Optional
  p.changes = p.paragraphs_of("History.txt", 0..1).join("\n\n")
  p.extra_deps = [
    ["main", "~> 2.8.0"],
    ["open4", "~> 0.9.6"],
    ["log4r", "~> 1.0.5"]
  ]
 
  #p.spec_extras = {} # A hash of extra values to set in the gemspec.
  
end
 
CHANGES = hoe.paragraphs_of("History.txt", 0..1).join("\\n\\n")
PATH = (RUBYFORGE_PROJECT == GEM_NAME) ? RUBYFORGE_PROJECT : "#{RUBYFORGE_PROJECT}/#{GEM_NAME}"
hoe.remote_rdoc_dir = File.join(PATH.gsub(/^#{RUBYFORGE_PROJECT}\/?/,""), "rdoc")
hoe.rsync_args = "-av --delete --ignore-errors"