merb-builder 0.9.7 → 0.9.8
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.
- data/LICENSE +1 -1
- data/Rakefile +27 -8
- data/lib/merb-builder/template.rb +9 -2
- data/spec/builder_spec.rb +1 -1
- data/spec/controllers/views/partial_builder/_partial_builder.xml.builder +1 -1
- data/spec/controllers/views/partial_builder/index.xml.builder +1 -1
- data/spec/spec_helper.rb +0 -1
- metadata +3 -3
data/LICENSE
CHANGED
data/Rakefile
CHANGED
@@ -2,6 +2,7 @@ require 'rubygems'
|
|
2
2
|
require 'rake/gempackagetask'
|
3
3
|
require "extlib"
|
4
4
|
require 'merb-core/tasks/merb_rake_helper'
|
5
|
+
require "spec/rake/spectask"
|
5
6
|
|
6
7
|
##############################################################################
|
7
8
|
# Package && release
|
@@ -16,7 +17,7 @@ GEM_EMAIL = "jonathan@daikini.com"
|
|
16
17
|
|
17
18
|
GEM_NAME = "merb-builder"
|
18
19
|
PKG_BUILD = ENV['PKG_BUILD'] ? '.' + ENV['PKG_BUILD'] : ''
|
19
|
-
GEM_VERSION = (Merb::MORE_VERSION rescue "0.9.
|
20
|
+
GEM_VERSION = (Merb::MORE_VERSION rescue "0.9.8") + PKG_BUILD
|
20
21
|
|
21
22
|
RELEASE_NAME = "REL #{GEM_VERSION}"
|
22
23
|
|
@@ -34,7 +35,7 @@ spec = Gem::Specification.new do |s|
|
|
34
35
|
s.author = GEM_AUTHOR
|
35
36
|
s.email = GEM_EMAIL
|
36
37
|
s.homepage = PROJECT_URL
|
37
|
-
s.add_dependency('merb-core', '>= 0.9.
|
38
|
+
s.add_dependency('merb-core', '>= 0.9.8')
|
38
39
|
s.add_dependency('builder', '>= 2.0.0')
|
39
40
|
s.require_path = 'lib'
|
40
41
|
s.files = %w(LICENSE README Rakefile TODO) + Dir.glob("{lib,spec}/**/*")
|
@@ -45,15 +46,33 @@ Rake::GemPackageTask.new(spec) do |pkg|
|
|
45
46
|
end
|
46
47
|
|
47
48
|
desc "Install the gem"
|
48
|
-
task :install
|
49
|
-
|
49
|
+
task :install do
|
50
|
+
Merb::RakeHelper.install(GEM_NAME, :version => GEM_VERSION)
|
50
51
|
end
|
51
52
|
|
52
|
-
|
53
|
+
desc "Uninstall the gem"
|
54
|
+
task :uninstall do
|
55
|
+
Merb::RakeHelper.uninstall(GEM_NAME, :version => GEM_VERSION)
|
56
|
+
end
|
53
57
|
|
54
|
-
|
55
|
-
|
56
|
-
|
58
|
+
desc "Create a gemspec file"
|
59
|
+
task :gemspec do
|
60
|
+
File.open("#{GEM_NAME}.gemspec", "w") do |file|
|
61
|
+
file.puts spec.to_ruby
|
57
62
|
end
|
63
|
+
end
|
58
64
|
|
65
|
+
desc "Run all examples (or a specific spec with TASK=xxxx)"
|
66
|
+
Spec::Rake::SpecTask.new('spec') do |t|
|
67
|
+
t.spec_opts = ["-cfs"]
|
68
|
+
t.spec_files = begin
|
69
|
+
if ENV["TASK"]
|
70
|
+
ENV["TASK"].split(',').map { |task| "spec/**/#{task}_spec.rb" }
|
71
|
+
else
|
72
|
+
FileList['spec/**/*_spec.rb']
|
73
|
+
end
|
74
|
+
end
|
59
75
|
end
|
76
|
+
|
77
|
+
desc 'Default: run spec examples'
|
78
|
+
task :default => 'spec'
|
@@ -7,14 +7,21 @@ module Merb::Template
|
|
7
7
|
# ==== Parameters
|
8
8
|
# path<String>:: Path to the template file.
|
9
9
|
# name<~to_s>:: The name of the template method.
|
10
|
+
# locals<Array[Symbol]>:: A list of locals to assign from the args passed into the compiled template.
|
10
11
|
# mod<Class, Module>::
|
11
12
|
# The class or module wherein this method should be defined.
|
12
|
-
def self.compile_template(io, name, mod)
|
13
|
+
def self.compile_template(io, name, locals, mod)
|
13
14
|
path = File.expand_path(io.path)
|
14
15
|
method = mod.is_a?(Module) ? :module_eval : :instance_eval
|
16
|
+
assigns = locals.inject([]) do |a, l|
|
17
|
+
a << "#{l} = _locals[#{l.inspect}];"
|
18
|
+
end.join
|
15
19
|
mod.send(method, %{
|
16
|
-
def #{name}
|
20
|
+
def #{name}(_locals={})
|
17
21
|
@_engine = 'builder'
|
22
|
+
|
23
|
+
#{assigns}
|
24
|
+
|
18
25
|
config = (Merb.config[:builder] || {}).inject({}) do |c, (k, v)|
|
19
26
|
c[k.to_sym] = v
|
20
27
|
c
|
data/spec/builder_spec.rb
CHANGED
@@ -12,7 +12,7 @@ describe "Builder" do
|
|
12
12
|
c.body.should == @xml.target!
|
13
13
|
end
|
14
14
|
|
15
|
-
it "should be able to render partial Builder templates" do
|
15
|
+
it "should be able to render partial Builder templates and use locals" do
|
16
16
|
c = dispatch_to(PartialBuilder, :index, :format => "xml")
|
17
17
|
@xml.hello "World"
|
18
18
|
c.body.should == @xml.target!
|
@@ -1 +1 @@
|
|
1
|
-
xml.hello
|
1
|
+
xml.hello world
|
@@ -1,2 +1,2 @@
|
|
1
1
|
xml.instruct!
|
2
|
-
xml << partial(:partial_builder)
|
2
|
+
xml << partial(:partial_builder, :world => "World")
|
data/spec/spec_helper.rb
CHANGED
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: merb-builder
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.9.
|
4
|
+
version: 0.9.8
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Jonathan Younger
|
@@ -9,7 +9,7 @@ autorequire:
|
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
11
|
|
12
|
-
date: 2008-
|
12
|
+
date: 2008-10-06 00:00:00 +03:00
|
13
13
|
default_executable:
|
14
14
|
dependencies:
|
15
15
|
- !ruby/object:Gem::Dependency
|
@@ -20,7 +20,7 @@ dependencies:
|
|
20
20
|
requirements:
|
21
21
|
- - ">="
|
22
22
|
- !ruby/object:Gem::Version
|
23
|
-
version: 0.9.
|
23
|
+
version: 0.9.8
|
24
24
|
version:
|
25
25
|
- !ruby/object:Gem::Dependency
|
26
26
|
name: builder
|