pannier 0.2.0 → 0.3.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.
- checksums.yaml +4 -4
- data/lib/pannier/app.rb +19 -0
- data/lib/pannier/logger.rb +20 -0
- data/lib/pannier/package.rb +20 -4
- data/lib/pannier/version.rb +1 -1
- metadata +4 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 73f6eeb9126643df23c6620c70188f9d5cc1ac3d
|
4
|
+
data.tar.gz: 1f32b050411a85102b150dc6a12d76e0719d86da
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: f1fb482e967a5112f6465eb2445e521b205901907a723c0606f5f452c1b28d31caa668e74402870f60f5e87eeba36a2a365de26f06bd5cd937988931f6cc698b
|
7
|
+
data.tar.gz: f3396f40dec19c4555ab9ece93bbc81f36599725b5b79e2a70b69cbd9076c3bdbd548659093481eef72bc4440db007e8b92770f218e9eaa72fa2ae468410b69b
|
data/lib/pannier/app.rb
CHANGED
@@ -2,6 +2,7 @@ require 'ostruct'
|
|
2
2
|
|
3
3
|
require 'pannier/dsl'
|
4
4
|
require 'pannier/environment'
|
5
|
+
require 'pannier/logger'
|
5
6
|
require 'pannier/manifest_writer'
|
6
7
|
require 'pannier/package'
|
7
8
|
|
@@ -25,6 +26,10 @@ module Pannier
|
|
25
26
|
@output_path = File.expand_path(path)
|
26
27
|
end
|
27
28
|
|
29
|
+
def set_logger(logger)
|
30
|
+
@logger = logger
|
31
|
+
end
|
32
|
+
|
28
33
|
def add_package(package)
|
29
34
|
@packages << package
|
30
35
|
end
|
@@ -37,6 +42,16 @@ module Pannier
|
|
37
42
|
@manifest_writer ||= ManifestWriter.new(self, @env)
|
38
43
|
end
|
39
44
|
|
45
|
+
def log(messages, options = {})
|
46
|
+
return unless @logger
|
47
|
+
indent = options.fetch(:indent) { 0 }
|
48
|
+
messages = Array(messages)
|
49
|
+
messages.each do |msg|
|
50
|
+
indent.times { msg.prepend(' ') }
|
51
|
+
@logger.debug(msg)
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
40
55
|
def process!
|
41
56
|
@packages.each(&:process!)
|
42
57
|
manifest_writer.write!(@input_path)
|
@@ -61,6 +76,10 @@ module Pannier
|
|
61
76
|
set_output(path)
|
62
77
|
end
|
63
78
|
|
79
|
+
def logger(logger = Pannier::Logger.new($stdout))
|
80
|
+
set_logger(logger)
|
81
|
+
end
|
82
|
+
|
64
83
|
def behavior(name, &block)
|
65
84
|
add_behavior(name, &block)
|
66
85
|
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
require 'logger'
|
2
|
+
|
3
|
+
module Pannier
|
4
|
+
class Logger < ::Logger
|
5
|
+
|
6
|
+
def initialize(*args)
|
7
|
+
super
|
8
|
+
@formatter = _formatter
|
9
|
+
end
|
10
|
+
|
11
|
+
private
|
12
|
+
|
13
|
+
def _formatter
|
14
|
+
proc do |severity, time, progname, msg|
|
15
|
+
msg + "\n"
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
end
|
20
|
+
end
|
data/lib/pannier/package.rb
CHANGED
@@ -64,11 +64,13 @@ module Pannier
|
|
64
64
|
end
|
65
65
|
|
66
66
|
def process!
|
67
|
-
|
68
|
-
|
69
|
-
|
67
|
+
process_with_logs! do
|
68
|
+
copy!
|
69
|
+
!@processors.empty? && @processors.each do |instructions|
|
70
|
+
send(*instructions)
|
71
|
+
end
|
72
|
+
write_files!
|
70
73
|
end
|
71
|
-
write_files!
|
72
74
|
end
|
73
75
|
|
74
76
|
def modify!(modifier)
|
@@ -139,5 +141,19 @@ module Pannier
|
|
139
141
|
|
140
142
|
end
|
141
143
|
|
144
|
+
private
|
145
|
+
|
146
|
+
def process_with_logs!(&block)
|
147
|
+
@app.log("Package #{name.inspect}", :indent => 2)
|
148
|
+
@app.log('-> Input', :indent => 4)
|
149
|
+
@app.log(@input_assets.map(&:path), :indent => 6)
|
150
|
+
|
151
|
+
block.call
|
152
|
+
|
153
|
+
@app.log('-> Output', :indent => 4)
|
154
|
+
@app.log(@output_assets.map(&:path), :indent => 6)
|
155
|
+
@app.log("\n")
|
156
|
+
end
|
157
|
+
|
142
158
|
end
|
143
159
|
end
|
data/lib/pannier/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: pannier
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.3.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Joe Corcoran
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2014-03-
|
11
|
+
date: 2014-03-10 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rack
|
@@ -213,6 +213,7 @@ files:
|
|
213
213
|
- lib/pannier/environment.rb
|
214
214
|
- lib/pannier/errors.rb
|
215
215
|
- lib/pannier/file_handler.rb
|
216
|
+
- lib/pannier/logger.rb
|
216
217
|
- lib/pannier/manifest_writer.rb
|
217
218
|
- lib/pannier/mounted.rb
|
218
219
|
- lib/pannier/mounted/app.rb
|
@@ -242,7 +243,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
242
243
|
version: '0'
|
243
244
|
requirements: []
|
244
245
|
rubyforge_project:
|
245
|
-
rubygems_version: 2.2.
|
246
|
+
rubygems_version: 2.2.1
|
246
247
|
signing_key:
|
247
248
|
specification_version: 4
|
248
249
|
summary: A simple, portable asset processing tool for Ruby web apps
|