wtnabe (owner)

Revisions

gist: 79787 Download_button fork
public
Public Clone URL: git://gist.github.com/79787.git
Embed All Files: show embed
pear-support-capfile.rb #
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
# -*- mode: ruby; coding: utf-8 -*-
 
require 'hpricot'
require 'open-uri'
 
=begin
 
required configuration
 
set :package, {
:name => 'PACKAGE',
# $1 is used to specify the version number
:filename => /PACKAGE-(.*)\.tgz/,
:uri => 'http://example.com/path/to/yourpackage/'
}
 
=end
 
desc "force upgrade to latest version"
task :upgrade do
  package = UribasePackage.new( fetch( :package ) )
  if ( !package.installed? or package.current != package.latest )
    puts package.upgrade
  else
    puts 'no need to do.'
  end
end
 
desc "downgrade to previous version"
task :downgrade do
  package = UribasePackage.new( fetch( :package ) )
  if ( !package.installed? )
    puts "install first"
  elsif ( package.current == package.initial )
    puts "no need to do."
  else
    puts package.downgrade
  end
end
 
desc "install latest version"
task :install do
  package = UribasePackage.new( fetch( :package ) )
  if ( package.installed? )
    puts "no need to do."
  else
    puts package.install
  end
end
 
desc "list up Package packages"
task :list do
  puts UribasePackage.new( fetch( :package ) ).collect.join( "\n" )
end
 
desc "check current installed version"
task "check-current" do
  package = UribasePackage.new( fetch( :package ) )
  if ( package.installed? )
    puts package.current
  else
    puts "install first"
  end
end
 
desc "check latest version"
task "check-latest" do
  puts UribasePackage.new( fetch( :package ) ).latest
end
 
desc "uninstall Package"
task :uninstall do
  package = UribasePackage.new( fetch( :package ) )
  if ( package.installed? )
    package.uninstall
  else
    puts "no need to do."
  end
end
 
class UribasePackage
  APACHE_OPTION = 'C=N;O=A;V=1;F=0'
 
  def initialize( opt = {} )
    @base_uri ||= opt[:uri]
    @filename_re ||= opt[:filename]
    @name ||= opt[:name]
    @filelist = nil
    @current = nil
  end
 
  def collect
    if ( @filelist.nil? )
      u = URI.parse( @base_uri )
      u.query = "?#{APACHE_OPTION}"
      d = Hpricot( u.read )
      @filelist = d.search( 'a' ).map { |e|
        m = e.get_attribute( 'href' ).match( @filename_re )
        ( m.nil? ) ? nil : m.to_s
      }.compact
    end
 
    return @filelist
  end
 
  def current
    if ( @current.nil? )
      @current = pear_message.to_s.split( /\s+/ )[1] if installed?
    end
 
    return @current
  end
 
  def latest
    version( collect.last )
  end
 
  def initial
    version( collect.first )
  end
 
  def absolute_uri( package )
    return @base_uri + package
  end
 
  def installed?
    return ( pear_message.size > 0 ) ? true : nil
  end
 
  def pear_message
    StringIO.new( `pear list -c __uri` ).entries.grep( /\b#{@name}\b/ )
  end
 
  def version( filename )
    filename.match( @filename_re )[1]
  end
 
  def uri( filename )
    return @base_uri + filename
  end
 
  def install
    return `sudo pear install #{uri( latest_filename )}#`
  end
 
  def upgrade
    return `sudo pear upgrade #{uri( latest_filename )}`
  end
 
  def downgrade
    if ( prev_filename )
      return `sudo pear upgrade --force #{uri( prev_filename )}`
    end
  end
 
  def uninstall
    return `sudo pear uninstall __uri/#{@name}`
  end
 
  def prev_filename
    index = current_index
 
    return ( index == 0 ) ? nil : collect[index - 1]
  end
 
  def next_filename
    index = current_index
 
    return ( index == collect.size - 1 ) ? nil : collect[index + 1]
  end
 
  def latest_filename
    return collect.last
  end
 
  def current_index
    current_file = collect.map { |e|
      e.include?( current ) ? e : nil
    }.compact.to_s
 
    return collect.index( current_file )
  end
end