wlang 2.2.3 → 3.0.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/CHANGELOG.md +16 -0
- data/Gemfile +1 -21
- data/Gemfile.lock +47 -37
- data/LICENCE.md +17 -19
- data/README.md +47 -29
- data/lib/wlang/compiler/grammar.citrus +6 -6
- data/lib/wlang/dialect.rb +1 -1
- data/lib/wlang/loader.rb +0 -1
- data/lib/wlang/scope/sinatra_scope.rb +6 -1
- data/lib/wlang/template.rb +14 -13
- data/lib/wlang/tilt/wlang_template.rb +3 -2
- data/lib/wlang/version.rb +3 -3
- data/spec/fixtures/templates/front_matter.wlang +4 -0
- data/spec/unit/compiler/test_to_ruby_code.rb +2 -2
- data/spec/unit/source/test_path.rb +3 -3
- data/spec/unit/source/test_template_content.rb +1 -1
- data/spec/unit/template/test_path.rb +2 -2
- data/spec/unit/template/test_to_ruby_code.rb +1 -1
- data/spec/unit/test_assumptions.rb +1 -1
- data/spec/unit/tilt/test_wlang_template.rb +0 -4
- data/tasks/test.rake +17 -0
- data/wlang.gemspec +7 -169
- metadata +63 -155
- data/spec/integration/sinatra/test_partials.rb +0 -35
- data/tasks/debug_mail.rake +0 -75
- data/tasks/debug_mail.txt +0 -13
- data/tasks/spec_test.rake +0 -71
- data/tasks/unit_test.rake +0 -76
- data/tasks/yard.rake +0 -51
- data/wlang.noespec +0 -45
@@ -1,35 +0,0 @@
|
|
1
|
-
require 'spec_helper'
|
2
|
-
require 'rack/test'
|
3
|
-
describe 'Integration with Sinatra for partials' do
|
4
|
-
include Rack::Test::Methods
|
5
|
-
|
6
|
-
let(:app){
|
7
|
-
sinatra_app do
|
8
|
-
set :accessible, "world"
|
9
|
-
set :views, fixtures_folder/'templates'
|
10
|
-
template :internal_partial do
|
11
|
-
"Hello ${who}!"
|
12
|
-
end
|
13
|
-
helpers do
|
14
|
-
def accessible; settings.accessible; end
|
15
|
-
end
|
16
|
-
get '/external' do
|
17
|
-
wlang ">{hello}", :locals => {:who => "sinatra"}
|
18
|
-
end
|
19
|
-
get '/internal' do
|
20
|
-
wlang ">{internal_partial}", :locals => {:who => "sinatra"}
|
21
|
-
end
|
22
|
-
end
|
23
|
-
}
|
24
|
-
|
25
|
-
it 'renders external partials correcty' do
|
26
|
-
get '/external'
|
27
|
-
last_response.body.should eq("Hello sinatra!")
|
28
|
-
end
|
29
|
-
|
30
|
-
it 'renders internal partials correcty' do
|
31
|
-
get '/internal'
|
32
|
-
last_response.body.should eq("Hello sinatra!")
|
33
|
-
end
|
34
|
-
|
35
|
-
end
|
data/tasks/debug_mail.rake
DELETED
@@ -1,75 +0,0 @@
|
|
1
|
-
# Installs a rake task for debuging the announcement mail.
|
2
|
-
#
|
3
|
-
# This file installs the 'rake debug_mail' that flushes an announcement mail
|
4
|
-
# for your library on the standard output. It is automatically generated
|
5
|
-
# by Noe from your .noespec file, and should therefore be configured there,
|
6
|
-
# under the variables/rake_tasks/debug_mail entry, as illustrated below:
|
7
|
-
#
|
8
|
-
# variables:
|
9
|
-
# rake_tasks:
|
10
|
-
# debug_mail:
|
11
|
-
# rx_changelog_sections: /^#/
|
12
|
-
# nb_changelog_sections: 1
|
13
|
-
# ...
|
14
|
-
#
|
15
|
-
# If you have specific needs requiring manual intervention on this file,
|
16
|
-
# don't forget to set safe-override to false in your noe specification:
|
17
|
-
#
|
18
|
-
# template-info:
|
19
|
-
# manifest:
|
20
|
-
# tasks/debug_mail.rake:
|
21
|
-
# safe-override: false
|
22
|
-
#
|
23
|
-
# The mail template used can be found in debug_mail.txt. That file may be
|
24
|
-
# changed to tune the mail you want to send. If you do so, don't forget to
|
25
|
-
# add a manifest entry in your .noespec file to avoid overriding you
|
26
|
-
# changes. The mail template uses wlang, with parentheses for block
|
27
|
-
# delimiters.
|
28
|
-
#
|
29
|
-
# template-info:
|
30
|
-
# manifest:
|
31
|
-
# tasks/debug_mail.txt:
|
32
|
-
# safe-override: false
|
33
|
-
#
|
34
|
-
desc "Debug the release announcement mail"
|
35
|
-
task :debug_mail do
|
36
|
-
begin
|
37
|
-
require 'wlang'
|
38
|
-
rescue LoadError
|
39
|
-
abort "wlang is not available. Try 'gem install wlang'"
|
40
|
-
end
|
41
|
-
require 'yaml'
|
42
|
-
|
43
|
-
# Check that a .noespec file exists
|
44
|
-
noespec_file = File.expand_path('../../wlang.noespec', __FILE__)
|
45
|
-
unless File.exists?(noespec_file)
|
46
|
-
raise "Unable to find .noespec project file, sorry."
|
47
|
-
end
|
48
|
-
|
49
|
-
# Load it as well as variables and options
|
50
|
-
noespec = YAML::load(File.read(noespec_file))
|
51
|
-
vars = noespec['variables'] || {}
|
52
|
-
|
53
|
-
# Changes are taken from CHANGELOG
|
54
|
-
logs = Dir[File.expand_path("../../CHANGELOG.*", __FILE__)]
|
55
|
-
unless logs.size == 1
|
56
|
-
abort "Unable to find a changelog file"
|
57
|
-
end
|
58
|
-
|
59
|
-
# Load interesting changesets
|
60
|
-
changes, end_found = [], 0
|
61
|
-
File.readlines(logs.first).select{|line|
|
62
|
-
if line =~ /^# /
|
63
|
-
break if end_found >= 1
|
64
|
-
end_found += 1
|
65
|
-
end
|
66
|
-
changes << line
|
67
|
-
}
|
68
|
-
vars['changes'] = changes.join
|
69
|
-
|
70
|
-
# WLang template
|
71
|
-
template = File.expand_path('../debug_mail.txt', __FILE__)
|
72
|
-
|
73
|
-
# Let's go!
|
74
|
-
$stdout << WLang::file_instantiate(template, vars, "wlang/active-text")
|
75
|
-
end
|
data/tasks/debug_mail.txt
DELETED
data/tasks/spec_test.rake
DELETED
@@ -1,71 +0,0 @@
|
|
1
|
-
# Installs a rake task for for running examples written using rspec.
|
2
|
-
#
|
3
|
-
# This file installs the 'rake spec_test' (aliased as 'rake spec') as well as
|
4
|
-
# extends 'rake test' to run spec tests, if any. It is automatically generated
|
5
|
-
# by Noe from your .noespec file, and should therefore be configured there,
|
6
|
-
# under the variables/rake_tasks/spec_test entry, as illustrated below:
|
7
|
-
#
|
8
|
-
# variables:
|
9
|
-
# rake_tasks:
|
10
|
-
# spec_test:
|
11
|
-
# pattern: spec/**/*_spec.rb
|
12
|
-
# verbose: true
|
13
|
-
# rspec_opts: [--color, --backtrace]
|
14
|
-
# ...
|
15
|
-
#
|
16
|
-
# If you have specific needs requiring manual intervention on this file,
|
17
|
-
# don't forget to set safe-override to false in your noe specification:
|
18
|
-
#
|
19
|
-
# template-info:
|
20
|
-
# manifest:
|
21
|
-
# tasks/spec_test.rake:
|
22
|
-
# safe-override: false
|
23
|
-
#
|
24
|
-
# This file has been written to conform to RSpec v2.4.0. More information about
|
25
|
-
# rspec and options of the rake task defined below can be found on
|
26
|
-
# http://relishapp.com/rspec
|
27
|
-
#
|
28
|
-
begin
|
29
|
-
require "rspec/core/rake_task"
|
30
|
-
desc "Run RSpec code examples"
|
31
|
-
RSpec::Core::RakeTask.new(:spec_test) do |t|
|
32
|
-
# Glob pattern to match files.
|
33
|
-
t.pattern = "spec/**/test_*.rb"
|
34
|
-
|
35
|
-
# Whether or not to fail Rake when an error occurs (typically when
|
36
|
-
# examples fail).
|
37
|
-
t.fail_on_error = true
|
38
|
-
|
39
|
-
# A message to print to stderr when there are failures.
|
40
|
-
t.failure_message = nil
|
41
|
-
|
42
|
-
# Use verbose output. If this is set to true, the task will print the
|
43
|
-
# executed spec command to stdout.
|
44
|
-
t.verbose = true
|
45
|
-
|
46
|
-
# Use rcov for code coverage?
|
47
|
-
t.rcov = false
|
48
|
-
|
49
|
-
# Path to rcov.
|
50
|
-
t.rcov_path = "rcov"
|
51
|
-
|
52
|
-
# Command line options to pass to rcov. See 'rcov --help' about this
|
53
|
-
t.rcov_opts = []
|
54
|
-
|
55
|
-
# Command line options to pass to ruby. See 'ruby --help' about this
|
56
|
-
t.ruby_opts = []
|
57
|
-
|
58
|
-
# Path to rspec
|
59
|
-
t.rspec_path = "rspec"
|
60
|
-
|
61
|
-
# Command line options to pass to rspec. See 'rspec --help' about this
|
62
|
-
t.rspec_opts = ["--color", "--backtrace"]
|
63
|
-
end
|
64
|
-
rescue LoadError => ex
|
65
|
-
task :spec_test do
|
66
|
-
abort 'rspec is not available. In order to run spec, you must: gem install rspec'
|
67
|
-
end
|
68
|
-
ensure
|
69
|
-
task :spec => [:spec_test]
|
70
|
-
task :test => [:spec_test]
|
71
|
-
end
|
data/tasks/unit_test.rake
DELETED
@@ -1,76 +0,0 @@
|
|
1
|
-
# Installs a rake task for for running unit tests.
|
2
|
-
#
|
3
|
-
# This file installs the 'rake unit_test' and extends 'rake test' to run unit
|
4
|
-
# tests, if any. It is automatically generated by Noe from your .noespec file,
|
5
|
-
# and should therefore be configured there, under the variables/rake_tasks/unit_test
|
6
|
-
# entry, as illustrated below:
|
7
|
-
#
|
8
|
-
# variables:
|
9
|
-
# rake_tasks:
|
10
|
-
# unit_test:
|
11
|
-
# pattern: test/test*.rb
|
12
|
-
# verbose: false
|
13
|
-
# warning: false
|
14
|
-
# ...
|
15
|
-
#
|
16
|
-
# If you have specific needs requiring manual intervention on this file,
|
17
|
-
# don't forget to set safe-override to false in your noe specification:
|
18
|
-
#
|
19
|
-
# template-info:
|
20
|
-
# manifest:
|
21
|
-
# tasks/unit_test.rake:
|
22
|
-
# safe-override: false
|
23
|
-
#
|
24
|
-
# More info about the TestTask and its options can be found on
|
25
|
-
# http://rake.rubyforge.org/classes/Rake/TestTask.html
|
26
|
-
#
|
27
|
-
begin
|
28
|
-
require 'rake/testtask'
|
29
|
-
desc "Run unit tests"
|
30
|
-
Rake::TestTask.new(:unit_test) do |t|
|
31
|
-
|
32
|
-
# List of directories to added to $LOAD_PATH before running the
|
33
|
-
# tests. (default is 'lib')
|
34
|
-
t.libs = ["lib"]
|
35
|
-
|
36
|
-
# True if verbose test output desired. (default is false)
|
37
|
-
t.verbose = false
|
38
|
-
|
39
|
-
# Test options passed to the test suite. An explicit TESTOPTS=opts
|
40
|
-
# on the command line will override this. (default is NONE)
|
41
|
-
t.options = nil
|
42
|
-
|
43
|
-
# Request that the tests be run with the warning flag set.
|
44
|
-
# E.g. warning=true implies "ruby -w" used to run the tests.
|
45
|
-
t.warning = false
|
46
|
-
|
47
|
-
# Glob pattern to match test files. (default is 'test/test*.rb')
|
48
|
-
t.pattern = "test/test_*.rb"
|
49
|
-
|
50
|
-
# Style of test loader to use. Options are:
|
51
|
-
#
|
52
|
-
# * :rake -- Rake provided test loading script (default).
|
53
|
-
# * :testrb -- Ruby provided test loading script.
|
54
|
-
# * :direct -- Load tests using command line loader.
|
55
|
-
#
|
56
|
-
t.loader = :rake
|
57
|
-
|
58
|
-
# Array of commandline options to pass to ruby when running test
|
59
|
-
# loader.
|
60
|
-
t.ruby_opts = []
|
61
|
-
|
62
|
-
# Explicitly define the list of test files to be included in a
|
63
|
-
# test. +list+ is expected to be an array of file names (a
|
64
|
-
# FileList is acceptable). If both +pattern+ and +test_files+ are
|
65
|
-
# used, then the list of test files is the union of the two.
|
66
|
-
t.test_files = nil
|
67
|
-
|
68
|
-
end
|
69
|
-
rescue LoadError => ex
|
70
|
-
task :unit_test do
|
71
|
-
abort "rake/testtask does not seem available...\n #{ex.message}"
|
72
|
-
end
|
73
|
-
ensure
|
74
|
-
desc "Run all tests"
|
75
|
-
task :test => [:unit_test]
|
76
|
-
end
|
data/tasks/yard.rake
DELETED
@@ -1,51 +0,0 @@
|
|
1
|
-
# Installs a rake task to generate API documentation using yard.
|
2
|
-
#
|
3
|
-
# This file installs the 'rake yard' task. It is automatically generated by Noe from
|
4
|
-
# your .noespec file, and should therefore be configured there, under the
|
5
|
-
# variables/rake_tasks/yard entry, as illustrated below:
|
6
|
-
#
|
7
|
-
# variables:
|
8
|
-
# rake_tasks:
|
9
|
-
# yard:
|
10
|
-
# files: lib/**/*.rb
|
11
|
-
# options: []
|
12
|
-
# ...
|
13
|
-
#
|
14
|
-
# If you have specific needs requiring manual intervention on this file,
|
15
|
-
# don't forget to set safe-override to false in your noe specification:
|
16
|
-
#
|
17
|
-
# template-info:
|
18
|
-
# manifest:
|
19
|
-
# tasks/yard.rake:
|
20
|
-
# safe-override: false
|
21
|
-
#
|
22
|
-
# This file has been written to conform to yard v0.6.4. More information about
|
23
|
-
# yard and the rake task installed below can be found on http://yardoc.org/
|
24
|
-
#
|
25
|
-
begin
|
26
|
-
require "yard"
|
27
|
-
desc "Generate yard documentation"
|
28
|
-
YARD::Rake::YardocTask.new(:yard) do |t|
|
29
|
-
# Array of options passed to yardoc commandline. See 'yardoc --help' about this
|
30
|
-
t.options = ["--output-dir", "doc/api", "-", "README.md", "CHANGELOG.md", "LICENCE.md"]
|
31
|
-
|
32
|
-
# Array of ruby source files (and any extra documentation files
|
33
|
-
# separated by '-')
|
34
|
-
t.files = ["lib/**/*.rb"]
|
35
|
-
|
36
|
-
# A proc to call before running the task
|
37
|
-
# t.before = proc{ }
|
38
|
-
|
39
|
-
# A proc to call after running the task
|
40
|
-
# r.after = proc{ }
|
41
|
-
|
42
|
-
# An optional lambda to run against all objects being generated.
|
43
|
-
# Any object that the lambda returns false for will be excluded
|
44
|
-
# from documentation.
|
45
|
-
# t.verifier = lambda{|obj| true}
|
46
|
-
end
|
47
|
-
rescue LoadError
|
48
|
-
task :yard do
|
49
|
-
abort 'yard is not available. In order to run yard, you must: gem install yard'
|
50
|
-
end
|
51
|
-
end
|
data/wlang.noespec
DELETED
@@ -1,45 +0,0 @@
|
|
1
|
-
template-info:
|
2
|
-
name: "rubygem.noe"
|
3
|
-
version: 2.0.0
|
4
|
-
links:
|
5
|
-
source: https://github.com/blambeau/noe
|
6
|
-
manifest:
|
7
|
-
lib/__lower__/loader.rb:
|
8
|
-
safe-override: false
|
9
|
-
variables:
|
10
|
-
lower:
|
11
|
-
wlang
|
12
|
-
upper:
|
13
|
-
WLang
|
14
|
-
version:
|
15
|
-
2.2.3
|
16
|
-
summary: |-
|
17
|
-
WLang is a powerful code generation and templating engine
|
18
|
-
description: |-
|
19
|
-
WLang is a general-purpose *code generation*/*templating engine*. It's main aim is to
|
20
|
-
help you generating web pages, sql queries, ruby code (that is, generating text in
|
21
|
-
general) without having to worry too much about html entities encoding, sql back
|
22
|
-
quoting, string escaping and the like. WLang proposes a generic engine that you can
|
23
|
-
easily extend to fit your needs. It also proposes standard instantiations of this
|
24
|
-
engine for common tasks such as rendering HTML web pages.
|
25
|
-
authors:
|
26
|
-
- {name: Bernard Lambeau, email: blambeau@gmail.com}
|
27
|
-
- {name: Louis Lambeau, email: llambeau@gmail.com}
|
28
|
-
links:
|
29
|
-
- http://github.com/blambeau/wlang
|
30
|
-
- http://rubygems.org/gems/wlang
|
31
|
-
- http://blambeau.github.com/wlang
|
32
|
-
- http://revision-zero.org/wlang
|
33
|
-
dependencies:
|
34
|
-
- {name: citrus, version: "~> 2.4.1", groups: [runtime]}
|
35
|
-
- {name: temple, version: "~> 0.6", groups: [runtime]}
|
36
|
-
- {name: quickl, version: "~> 0.4.3", groups: [runtime]}
|
37
|
-
- {name: path, version: "~> 1.3", groups: [runtime]}
|
38
|
-
- {name: backports, version: "~> 2.6", groups: [runtime]}
|
39
|
-
- {name: awesome_print, version: "~> 1.0.2", groups: [extra]}
|
40
|
-
- {name: tilt, version: "~> 1.3", groups: [development]}
|
41
|
-
- {name: rake, version: "~> 0.9.2", groups: [development]}
|
42
|
-
- {name: bundler, version: "~> 1.0", groups: [development]}
|
43
|
-
- {name: rspec, version: "~> 2.10.0", groups: [development]}
|
44
|
-
- {name: sinatra, version: ">= 1.4", groups: [development]}
|
45
|
-
- {name: rack-test, version: "~> 0.6", groups: [development]}
|