sprout 0.7.229 → 0.7.233

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of sprout might be problematic. Click here for more details.

data/lib/sprout.rb CHANGED
@@ -275,7 +275,7 @@ EOF
275
275
  raise UsageError.new("Could not retrieve requested executable from path: #{exe}")
276
276
  end
277
277
 
278
- if(File.exists?(exe) && !File.directory?(exe) && File.stat(exe).executable?)
278
+ if(File.exists?(exe) && !File.directory?(exe) && !File.stat(exe).executable?)
279
279
  File.chmod 0755, exe
280
280
  end
281
281
 
@@ -303,7 +303,7 @@ EOF
303
303
  end
304
304
  if(File.exists?(sprout_spec_path))
305
305
  # Ensure the requisite files get downloaded and unpacked
306
- Builder.build(sprout_spec_path, gem_file_cache(gem_spec.name, gem_spec.version))
306
+ Builder.build(sprout_spec_path, gem_spec.name, gem_spec.version)
307
307
  else
308
308
  return gem_spec
309
309
  end
@@ -6,7 +6,7 @@ module Sprout
6
6
  # Unpack downloaded files from a variety of common archive types.
7
7
  # This library should efficiently extract archived files
8
8
  # on OS X, Win XP, Vista, DOS, Cygwin, and Linux.
9
- #
9
+ #
10
10
  # It will attempt to infer the archive type by standard mime-type file
11
11
  # extensions, but if there is a file with no extension, the unpack_archive
12
12
  # method can be provided with an @archive_type symbol argument that is one
@@ -20,16 +20,16 @@ module Sprout
20
20
  # :dmg
21
21
  class ArchiveUnpacker #:nodoc:
22
22
  include Archive::Tar
23
-
23
+
24
24
  def unpack_archive(file_name, dir, force=false, archive_type=nil)
25
25
  archive_type ||= inferred_archive_type(file_name)
26
26
  suffix = suffix_for_archive_type(archive_type)
27
-
27
+
28
28
  unpacked = unpacked_file_name(file_name, dir, suffix)
29
29
  if(File.exists?(unpacked) && force)
30
30
  FileUtils.rm_rf(unpacked)
31
31
  end
32
-
32
+
33
33
  if(!File.exists?(unpacked))
34
34
  case archive_type.to_s
35
35
  when 'zip'
@@ -40,18 +40,15 @@ module Sprout
40
40
  unpack_dmg(file_name, dir)
41
41
  when 'exe'
42
42
  FileUtils.mkdir_p(dir)
43
- FileUtils.mv(file_name, dir)
44
- when 'swc'
45
- FileUtils.mkdir_p(dir)
46
- FileUtils.mv(file_name, dir)
47
- when 'rb'
43
+ File.mv(file_name, dir)
44
+ when 'swc' || 'rb'
48
45
  return
49
46
  else
50
47
  raise ArchiveUnpackerError.new("ArchiveUnpacker does not know how to unpack files of type: #{archive_type} for file_name: #{file_name}")
51
48
  end
52
49
  end
53
50
  end
54
-
51
+
55
52
  def unpack_zip(zip_file, dir)
56
53
  # Avoid the rubyzip Segmentation Fault bug
57
54
  # at least on os x...
@@ -73,12 +70,12 @@ module Sprout
73
70
  FileUtils.mkdir_p(File.dirname(fpath))
74
71
  # Disgusting, Gross Hack to fix DOS/Ruby Bug
75
72
  # That makes the zip library throw a ZipDestinationFileExistsError
76
- # When the zip archive includes two files whose names
73
+ # When the zip archive includes two files whose names
77
74
  # differ only by extension.
78
75
  # This bug actually appears in the File.exists? implementation
79
76
  # throwing false positives!
80
77
  # If you're going to use this code, be sure you extract
81
- # into a new, empty directory as existing files will be
78
+ # into a new, empty directory as existing files will be
82
79
  # clobbered...
83
80
  begin
84
81
  if(File.exists?(fpath) && !File.directory?(fpath))
@@ -104,30 +101,30 @@ module Sprout
104
101
  end
105
102
  end
106
103
  end
107
-
104
+
108
105
  def unpacked_file_name(file, dir, suffix=nil)
109
106
  basename = File.basename(file, suffix)
110
107
  path = File.expand_path(dir)
111
108
  return File.join(path, basename)
112
109
  end
113
-
110
+
114
111
  def unpack_targz(tgz_file, dir)
115
112
  if(!File.exists?(dir))
116
113
  FileUtils.makedirs(dir)
117
114
  end
118
115
  tar = Zlib::GzipReader.new(File.open(tgz_file, 'rb'))
119
116
  Minitar.unpack(tar, dir)
120
-
121
- # Recurse and unpack gzipped children (Adobe did this double
117
+
118
+ # Recurse and unpack gzipped children (Adobe did this double
122
119
  # gzip with the Linux FlashPlayer for some reason)
123
120
  Dir.glob("#{dir}/**/*.tar.gz").each do |child|
124
- if(child != tgz_file)
121
+ if(child != tgz_file && dir != File.dirname(child))
125
122
  unpack_targz(child, File.dirname(child))
126
123
  end
127
124
  end
128
-
125
+
129
126
  end
130
-
127
+
131
128
  # This is actually not unpacking the FlashPlayer
132
129
  # Binary file as expected...
133
130
  # OSX is treated the player binary as if it is
@@ -144,10 +141,10 @@ module Sprout
144
141
  if(!File.exists?(full_mounted_path))
145
142
  system("hdiutil mount #{dmg_file}")
146
143
  end
147
-
144
+
148
145
  begin
149
146
  mounted_target = File.join(full_mounted_path, extracted_file)
150
-
147
+
151
148
  # Copy the DMG contents using system copy rather than ruby utils
152
149
  # Because OS X does something special with .app files that the
153
150
  # Ruby FileUtils and File classes break...
@@ -155,7 +152,7 @@ module Sprout
155
152
  # from = File.join(full_mounted_path, extracted_file)
156
153
  to = File.join(@user.downloads, @name.to_s, extracted_file)
157
154
  FileUtils.makedirs(File.dirname(to))
158
-
155
+
159
156
  if(File.exists?(from))
160
157
  `ditto '#{from}' '#{to}'`
161
158
  end
@@ -165,7 +162,7 @@ module Sprout
165
162
  end
166
163
  end
167
164
  end
168
-
165
+
169
166
  def suffix_for_archive_type(type)
170
167
  if(type == :targz)
171
168
  return '.tar.gz'
@@ -173,7 +170,7 @@ module Sprout
173
170
  return ".#{type.to_s}"
174
171
  end
175
172
  end
176
-
173
+
177
174
  def inferred_archive_type(file_name)
178
175
  if is_zip?(file_name)
179
176
  return :zip
@@ -192,34 +189,34 @@ module Sprout
192
189
  else
193
190
  return nil
194
191
  end
195
-
192
+
196
193
  end
197
-
194
+
198
195
  def is_zip?(file)
199
196
  return (file.split('.').pop == 'zip')
200
197
  end
201
-
198
+
202
199
  def is_targz?(file)
203
200
  parts = file.split('.')
204
201
  part = parts.pop
205
202
  return (part == 'tgz' || part == 'gz' && parts.pop == 'tar')
206
203
  end
207
-
204
+
208
205
  def is_gzip?(file)
209
206
  return (file.split('.').pop == 'gz')
210
207
  end
211
-
208
+
212
209
  def is_swc?(file)
213
210
  return (file.split('.').pop == 'swc')
214
211
  end
215
-
212
+
216
213
  def is_rb?(file)
217
214
  return (file.split('.').pop == 'rb')
218
215
  end
219
-
216
+
220
217
  def is_dmg?(file)
221
218
  return (file.split('.').pop == 'dmg')
222
- end
219
+ end
223
220
 
224
221
  def is_exe?(file)
225
222
  return (file.split('.').pop == 'exe')
@@ -9,7 +9,8 @@ module Sprout
9
9
  # archives that are identified in the spec
10
10
  class Builder # :nodoc:
11
11
 
12
- def self.build(file_targets_yaml, destination)
12
+ def self.build(file_targets_yaml, gem_name=nil, gem_version=nil)
13
+ destination = Builder.gem_file_cache(gem_name, gem_version)
13
14
  data = nil
14
15
 
15
16
  File.open(file_targets_yaml, 'r') do |f|
@@ -24,6 +25,8 @@ module Sprout
24
25
  # When authoring a sprout.spec for libraries or tools,
25
26
  # put the most specific RemoteFileTargets first, then
26
27
  # universals to catch unexpected platforms.
28
+ target.gem_name = gem_name
29
+ target.gem_version = gem_version
27
30
  if(target.platform == platform || target.platform == 'universal')
28
31
  target.install_path = FileUtils.mkdir_p(destination)
29
32
  target.resolve
@@ -34,6 +37,10 @@ module Sprout
34
37
  end
35
38
 
36
39
  private
40
+
41
+ def self.gem_file_cache(gem_name, gem_version)
42
+ Sprout.gem_file_cache(gem_name, gem_version)
43
+ end
37
44
 
38
45
  def self.platform
39
46
  @@platform ||= User.new.platform.to_s
@@ -5,6 +5,10 @@ module Sprout
5
5
 
6
6
  class RemoteFileTarget # :nodoc:
7
7
 
8
+
9
+ attr_accessor :gem_name
10
+ attr_accessor :gem_version
11
+
8
12
  attr_writer :archive_path
9
13
 
10
14
  # The string environment variable name to check before downloading anything.
@@ -65,8 +69,10 @@ module Sprout
65
69
  if(filename)
66
70
  self.downloaded_path = File.join(File.dirname(downloaded_path), filename)
67
71
  end
68
-
69
- if(url && (update || !File.exists?(downloaded_path)))
72
+
73
+ should_download = ( url && !File.exists?(installed_path) && !File.exists?(downloaded_path) )
74
+
75
+ if(should_download)
70
76
  content = download(url, update)
71
77
  FileUtils.makedirs(File.dirname(downloaded_path))
72
78
  FileUtils.touch(downloaded_path)
@@ -75,7 +81,7 @@ module Sprout
75
81
  end
76
82
  end
77
83
 
78
- if(!File.exists?(installed_path) || !File.exists?(File.join(installed_path, archive_path) ))
84
+ if(!File.exists?(installed_path) && !File.exists?(File.join(installed_path, archive_path)) )
79
85
  archive_root = File.join(install_path, 'archive')
80
86
  install(downloaded_path, archive_root, update, archive_type)
81
87
  end
@@ -130,13 +136,33 @@ module Sprout
130
136
  private
131
137
 
132
138
  def inferred_installed_path
133
- if(!environment.nil? && !ENV[environment].nil? && File.exists?(ENV[environment]))
134
- return ENV[environment]
135
- end
136
-
137
- return File.join(install_path, 'archive')
139
+ return environment_path || File.join(install_path, 'archive')
138
140
  end
139
141
 
142
+ def environment_path
143
+ path_for_environmental_name(inferred_env_name_with_version) || path_for_environmental_name(inferred_env_name) || path_for_environmental_name(environment)
144
+ end
145
+
146
+ def path_for_environmental_name(name)
147
+ if(name && ENV[name])
148
+ if(!File.exist?(ENV[name]))
149
+ raise UsageError.new("Found Environmental variable at: #{name} but no files found at: #{ENV[name]}")
150
+ end
151
+ ENV[name]
152
+ end
153
+ end
154
+
155
+ def inferred_env_name_with_version
156
+ return nil if (gem_version.nil? || gem_name.nil?)
157
+ version = gem_version.to_s.gsub('.', '_')
158
+ "#{inferred_env_name}_#{version}"
159
+ end
160
+
161
+ def inferred_env_name
162
+ return nil if gem_name.nil?
163
+ return gem_name.gsub('-', '_').upcase
164
+ end
165
+
140
166
  def download(url, update=false)
141
167
  loader = RemoteFileLoader.new
142
168
  loader.get_remote_file(url, update, md5)
@@ -144,6 +170,7 @@ module Sprout
144
170
 
145
171
  def install(from, to, force, archive_type=nil)
146
172
  unpacker = ArchiveUnpacker.new
173
+ #puts "Unpacking from: #{from} to: #{to} force: #{force} type: #{archive_type}"
147
174
  unpacker.unpack_archive(from, to, force, archive_type)
148
175
  end
149
176
 
@@ -3,7 +3,7 @@ module Sprout
3
3
  module VERSION #:nodoc:
4
4
  MAJOR = 0
5
5
  MINOR = 7
6
- TINY = 229
6
+ TINY = 233
7
7
 
8
8
  STRING = [MAJOR, MINOR, TINY].join('.')
9
9
  MAJOR_MINOR = [MAJOR, MINOR].join('.')
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: sprout
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.7.229
4
+ version: 0.7.233
5
5
  platform: ruby
6
6
  authors:
7
7
  - Luke Bayes
@@ -9,7 +9,7 @@ autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
11
 
12
- date: 2010-02-26 00:00:00 -08:00
12
+ date: 2010-03-03 00:00:00 -08:00
13
13
  default_executable: sprout
14
14
  dependencies:
15
15
  - !ruby/object:Gem::Dependency
@@ -95,7 +95,6 @@ extra_rdoc_files: []
95
95
  files:
96
96
  - MIT-LICENSE
97
97
  - rakefile.rb
98
- - TODO
99
98
  - samples/gem_wrap/rakefile.rb
100
99
  - bin/sprout
101
100
  - lib/platform.rb
data/TODO DELETED
@@ -1,12 +0,0 @@
1
-
2
- ---------------------------------
3
- In the interest of being a better member of our growing community,
4
- I have extracted the contents of this file to the googlecode site at:
5
-
6
- http://code.google.com/p/projectsprouts/issues/list?q=label:Beta1.0&can=2
7
-
8
- Please feel free to check over the available issues and see if any look appealing!
9
-
10
- If you're considering a contribution, please check in on our mailing list first just to be sure.
11
- (projectsprouts@googlegroups.com)
12
-