diff --git a/spec/spec-bootstrap.coffee b/spec/spec-bootstrap.coffee
index 4cf59faed..24f084725 100644
--- a/spec/spec-bootstrap.coffee
+++ b/spec/spec-bootstrap.coffee
@@ -1,16 +1,16 @@
+$$ = require 'template/builder'
nakedLoad 'jasmine'
nakedLoad 'jasmine-html'
nakedLoad 'jasmine-focused'
$ = require 'jquery'
-coffeekup = require 'coffeekup'
-$('head').append coffeekup.render ->
- link rel: "stylesheet", type: "text/css", href: "static/jasmine.css"
+$('head').append $$.render ->
+ @link rel: "stylesheet", type: "text/css", href: "static/jasmine.css"
-$('body').append coffeekup.render ->
- div id: 'jasmine_runner'
- div id: 'jasmine-content'
+$('body').append $$.render ->
+ @div id: 'jasmine_runner'
+ @div id: 'jasmine-content'
jasmineEnv = jasmine.getEnv()
trivialReporter = new jasmine.TrivialReporter(document, 'jasmine_runner')
diff --git a/vendor/coffeekup.coffee b/vendor/coffeekup.coffee
deleted file mode 100644
index 25ab73d88..000000000
--- a/vendor/coffeekup.coffee
+++ /dev/null
@@ -1,367 +0,0 @@
-# **CoffeeKup** lets you to write HTML templates in 100% pure
-# [CoffeeScript](http://coffeescript.org).
-#
-# You can run it on [node.js](http://nodejs.org) or the browser, or compile your
-# templates down to self-contained javascript functions, that will take in data
-# and options and return generated HTML on any JS runtime.
-#
-# The concept is directly stolen from the amazing
-# [Markaby](http://markaby.rubyforge.org/) by Tim Fletcher and why the lucky
-# stiff.
-
-coffeekup = module.exports
-coffee = require 'coffee-script'
-
-coffeekup.version = '0.3.1edge'
-
-# Values available to the `doctype` function inside a template.
-# Ex.: `doctype 'strict'`
-coffeekup.doctypes =
- 'default': ''
- '5': ''
- 'xml': ''
- 'transitional': ''
- 'strict': ''
- 'frameset': ''
- '1.1': '',
- 'basic': ''
- 'mobile': ''
- 'ce': ''
-
-# CoffeeScript-generated JavaScript may contain anyone of these; but when we
-# take a function to string form to manipulate it, and then recreate it through
-# the `Function()` constructor, it loses access to its parent scope and
-# consequently to any helpers it might need. So we need to reintroduce these
-# inside any "rewritten" function.
-coffeescript_helpers = """
- var __slice = Array.prototype.slice;
- var __hasProp = Object.prototype.hasOwnProperty;
- var __bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; };
- var __extends = function(child, parent) {
- for (var key in parent) { if (__hasProp.call(parent, key)) child[key] = parent[key]; }
- function ctor() { this.constructor = child; }
- ctor.prototype = parent.prototype; child.prototype = new ctor; child.__super__ = parent.prototype;
- return child; };
- var __indexOf = Array.prototype.indexOf || function(item) {
- for (var i = 0, l = this.length; i < l; i++) {
- if (this[i] === item) return i;
- } return -1; };
-""".replace /\n/g, ''
-
-# Private HTML element reference.
-# Please mind the gap (1 space at the beginning of each subsequent line).
-elements =
- # Valid HTML 5 elements requiring a closing tag.
- # Note: the `var` element is out for obvious reasons, please use `tag 'var'`.
- regular: 'a abbr address article aside audio b bdi bdo blockquote body button
- canvas caption cite code colgroup datalist dd del details dfn div dl dt em
- fieldset figcaption figure footer form h1 h2 h3 h4 h5 h6 head header hgroup
- html i iframe ins kbd label legend li map mark menu meter nav noscript object
- ol optgroup option output p pre progress q rp rt ruby s samp script section
- select small span strong style sub summary sup table tbody td textarea tfoot
- th thead time title tr u ul video'
-
- # Valid self-closing HTML 5 elements.
- void: 'area base br col command embed hr img input keygen link meta param
- source track wbr'
-
- obsolete: 'applet acronym bgsound dir frameset noframes isindex listing
- nextid noembed plaintext rb strike xmp big blink center font marquee multicol
- nobr spacer tt'
-
- obsolete_void: 'basefont frame'
-
-# Create a unique list of element names merging the desired groups.
-merge_elements = (args...) ->
- result = []
- for a in args
- for element in elements[a].split ' '
- result.push element unless element in result
- result
-
-# Public/customizable list of possible elements.
-# For each name in this list that is also present in the input template code,
-# a function with the same name will be added to the compiled template.
-coffeekup.tags = merge_elements 'regular', 'obsolete', 'void', 'obsolete_void'
-
-# Public/customizable list of elements that should be rendered self-closed.
-coffeekup.self_closing = merge_elements 'void', 'obsolete_void'
-
-# This is the basic material from which compiled templates will be formed.
-# It will be manipulated in its string form at the `coffeekup.compile` function
-# to generate the final template function.
-skeleton = (data = {}) ->
- # Whether to generate formatted HTML with indentation and line breaks, or
- # just the natural "faux-minified" output.
- data.format ?= off
-
- # Whether to autoescape all content or let you handle it on a case by case
- # basis with the `h` function.
- data.autoescape ?= off
-
- # Internal CoffeeKup stuff.
- __ck =
- buffer: []
-
- esc: (txt) ->
- if data.autoescape then h(txt) else String(txt)
-
- tabs: 0
-
- repeat: (string, count) -> Array(count + 1).join string
-
- indent: -> text @repeat(' ', @tabs) if data.format
-
- # Adapter to keep the builtin tag functions DRY.
- tag: (name, args) ->
- combo = [name]
- combo.push i for i in args
- tag.apply data, combo
-
- render_idclass: (str) ->
- classes = []
-
- for i in str.split '.'
- if '#' in i
- id = i.replace '#', ''
- else
- classes.push i unless i is ''
-
- text " id=\"#{id}\"" if id
-
- if classes.length > 0
- text " class=\""
- for c in classes
- text ' ' unless c is classes[0]
- text c
- text '"'
-
- render_attrs: (obj, prefix = '') ->
- for k, v of obj
- # `true` is rendered as `selected="selected"`.
- v = k if typeof v is 'boolean' and v
-
- # Functions are rendered in an executable form.
- v = "(#{v}).call(this);" if typeof v is 'function'
-
- # Prefixed attribute.
- if typeof v is 'object' and v not instanceof Array
- # `data: {icon: 'foo'}` is rendered as `data-icon="foo"`.
- @render_attrs(v, prefix + k + '-')
- # `undefined`, `false` and `null` result in the attribute not being rendered.
- else if v
- # strings, numbers, arrays and functions are rendered "as is".
- text " #{prefix + k}=\"#{@esc(v)}\""
-
- render_contents: (contents) ->
- switch typeof contents
- when 'string', 'number', 'boolean'
- text @esc(contents)
- when 'function'
- text '\n' if data.format
- @tabs++
- result = contents.call data
- if typeof result is 'string'
- @indent()
- text @esc(result)
- text '\n' if data.format
- @tabs--
- @indent()
-
- render_tag: (name, idclass, attrs, contents) ->
- @indent()
-
- text "<#{name}"
- @render_idclass(idclass) if idclass
- @render_attrs(attrs) if attrs
-
- if name in @self_closing
- text ' />'
- text '\n' if data.format
- else
- text '>'
-
- @render_contents(contents)
-
- text "#{name}>"
- text '\n' if data.format
-
- null
-
- tag = (name, args...) ->
- for a in args
- switch typeof a
- when 'function'
- contents = a
- when 'object'
- attrs = a
- when 'number', 'boolean'
- contents = a
- when 'string'
- if args.length is 1
- contents = a
- else
- if a is args[0]
- idclass = a
- else
- contents = a
-
- __ck.render_tag(name, idclass, attrs, contents)
-
- yieldkup = (f) ->
- temp_buffer = []
- old_buffer = __ck.buffer
- __ck.buffer = temp_buffer
- f()
- __ck.buffer = old_buffer
- temp_buffer.join ''
-
- h = (txt) ->
- String(txt).replace(/&/g, '&')
- .replace(//g, '>')
- .replace(/"/g, '"')
-
- doctype = (type = 'default') ->
- text __ck.doctypes[type]
- text '\n' if data.format
-
- text = (txt) ->
- __ck.buffer.push String(txt)
- null
-
- comment = (cmt) ->
- text ""
- text '\n' if data.format
-
- coffeescript = (param) ->
- switch typeof param
- # `coffeescript -> alert 'hi'` becomes:
- # ``
- when 'function'
- script "#{__ck.coffeescript_helpers}(#{param}).call(this);"
- # `coffeescript "alert 'hi'"` becomes:
- # ``
- when 'string'
- script type: 'text/coffeescript', -> param
- # `coffeescript src: 'script.coffee'` becomes:
- # ``
- when 'object'
- param.type = 'text/coffeescript'
- script param
-
- # Conditional IE comments.
- ie = (condition, contents) ->
- __ck.indent()
-
- text ""
- text '\n' if data.format
-
- null
-
-# Stringify the skeleton and unwrap it from its enclosing `function(){}`, then
-# add the CoffeeScript helpers.
-skeleton = String(skeleton)
- .replace(/function\s*\(.*\)\s*\{/, '')
- .replace(/return null;\s*\}$/, '')
-
-skeleton = coffeescript_helpers + skeleton
-
-# Compiles a template into a standalone JavaScript function.
-coffeekup.compile = (template, options = {}) ->
- # The template can be provided as either a function or a CoffeeScript string
- # (in the latter case, the CoffeeScript compiler must be available).
- if typeof template is 'function' then template = String(template)
- else if typeof template is 'string' and coffee?
- template = coffee.compile template, bare: yes
- template = "function(){#{template}}"
-
- # If an object `hardcode` is provided, insert the stringified value
- # of each variable directly in the function body. This is a less flexible but
- # faster alternative to the standard method of using `with` (see below).
- hardcoded_locals = ''
-
- if options.hardcode
- for k, v of options.hardcode
- if typeof v is 'function'
- # Make sure these functions have access to `data` as `@/this`.
- hardcoded_locals += "var #{k} = function(){return (#{v}).apply(data, arguments);};"
- else hardcoded_locals += "var #{k} = #{JSON.stringify v};"
-
- # Add a function for each tag this template references. We don't want to have
- # all hundred-odd tags wasting space in the compiled function.
- tag_functions = ''
- tags_used = []
-
- for t in coffeekup.tags
- if template.indexOf(t) > -1 or hardcoded_locals.indexOf(t) > -1
- tags_used.push t
-
- tag_functions += "var #{tags_used.join ','};"
- for t in tags_used
- tag_functions += "#{t} = function(){return __ck.tag('#{t}', arguments);};"
-
- # Main function assembly.
- code = tag_functions + hardcoded_locals + skeleton
-
- code += "__ck.doctypes = #{JSON.stringify coffeekup.doctypes};"
- code += "__ck.coffeescript_helpers = #{JSON.stringify coffeescript_helpers};"
- code += "__ck.self_closing = #{JSON.stringify coffeekup.self_closing};"
-
- # If `locals` is set, wrap the template inside a `with` block. This is the
- # most flexible but slower approach to specifying local variables.
- code += 'with(data.locals){' if options.locals
- code += "(#{template}).call(data);"
- code += '}' if options.locals
- code += "return __ck.buffer.join('');"
-
- new Function('data', code)
-
-cache = {}
-
-# Template in, HTML out. Accepts functions or strings as does `coffeekup.compile`.
-#
-# Accepts an option `cache`, by default `false`. If set to `false` templates will
-# be recompiled each time.
-#
-# `options` is just a convenience parameter to pass options separately from the
-# data, but the two will be merged and passed down to the compiler (which uses
-# `locals` and `hardcode`), and the template (which understands `locals`, `format`
-# and `autoescape`).
-coffeekup.render = (template, data = {}, options = {}) ->
- data[k] = v for k, v of options
- data.cache ?= off
-
- if data.cache and cache[template]? then tpl = cache[template]
- else if data.cache then tpl = cache[template] = coffeekup.compile(template, data)
- else tpl = coffeekup.compile(template, data)
- tpl(data)
-
-unless window?
- coffeekup.adapters =
- # Legacy adapters for when CoffeeKup expected data in the `context` attribute.
- simple: coffeekup.render
- meryl: coffeekup.render
-
- express:
- TemplateError: class extends Error
- constructor: (@message) ->
- Error.call this, @message
- Error.captureStackTrace this, arguments.callee
- name: 'TemplateError'
-
- compile: (template, data) ->
- # Allows `partial 'foo'` instead of `text @partial 'foo'`.
- data.hardcode ?= {}
- data.hardcode.partial = ->
- text @partial.apply @, arguments
-
- TemplateError = @TemplateError
- try tpl = coffeekup.compile(template, data)
- catch e then throw new TemplateError "Error compiling #{data.filename}: #{e.message}"
-
- return ->
- try tpl arguments...
- catch e then throw new TemplateError "Error rendering #{data.filename}: #{e.message}"
diff --git a/vendor/handlebars.js b/vendor/handlebars.js
deleted file mode 100644
index 3ae51089c..000000000
--- a/vendor/handlebars.js
+++ /dev/null
@@ -1,1494 +0,0 @@
-// lib/handlebars/parser.js
-/* Jison generated parser */
-var handlebars = (function(){
-var parser = {trace: function trace() { },
-yy: {},
-symbols_: {"error":2,"root":3,"program":4,"EOF":5,"statements":6,"simpleInverse":7,"statement":8,"openInverse":9,"closeBlock":10,"openBlock":11,"mustache":12,"partial":13,"CONTENT":14,"COMMENT":15,"OPEN_BLOCK":16,"inMustache":17,"CLOSE":18,"OPEN_INVERSE":19,"OPEN_ENDBLOCK":20,"path":21,"OPEN":22,"OPEN_UNESCAPED":23,"OPEN_PARTIAL":24,"params":25,"hash":26,"param":27,"STRING":28,"INTEGER":29,"BOOLEAN":30,"hashSegments":31,"hashSegment":32,"ID":33,"EQUALS":34,"pathSegments":35,"SEP":36,"$accept":0,"$end":1},
-terminals_: {2:"error",5:"EOF",14:"CONTENT",15:"COMMENT",16:"OPEN_BLOCK",18:"CLOSE",19:"OPEN_INVERSE",20:"OPEN_ENDBLOCK",22:"OPEN",23:"OPEN_UNESCAPED",24:"OPEN_PARTIAL",28:"STRING",29:"INTEGER",30:"BOOLEAN",33:"ID",34:"EQUALS",36:"SEP"},
-productions_: [0,[3,2],[4,3],[4,1],[4,0],[6,1],[6,2],[8,3],[8,3],[8,1],[8,1],[8,1],[8,1],[11,3],[9,3],[10,3],[12,3],[12,3],[13,3],[13,4],[7,2],[17,3],[17,2],[17,2],[17,1],[25,2],[25,1],[27,1],[27,1],[27,1],[27,1],[26,1],[31,2],[31,1],[32,3],[32,3],[32,3],[32,3],[21,1],[35,3],[35,1]],
-performAction: function anonymous(yytext,yyleng,yylineno,yy,yystate,$$,_$) {
-
-var $0 = $$.length - 1;
-switch (yystate) {
-case 1: return $$[$0-1]
-break;
-case 2: this.$ = new yy.ProgramNode($$[$0-2], $$[$0])
-break;
-case 3: this.$ = new yy.ProgramNode($$[$0])
-break;
-case 4: this.$ = new yy.ProgramNode([])
-break;
-case 5: this.$ = [$$[$0]]
-break;
-case 6: $$[$0-1].push($$[$0]); this.$ = $$[$0-1]
-break;
-case 7: this.$ = new yy.InverseNode($$[$0-2], $$[$0-1], $$[$0])
-break;
-case 8: this.$ = new yy.BlockNode($$[$0-2], $$[$0-1], $$[$0])
-break;
-case 9: this.$ = $$[$0]
-break;
-case 10: this.$ = $$[$0]
-break;
-case 11: this.$ = new yy.ContentNode($$[$0])
-break;
-case 12: this.$ = new yy.CommentNode($$[$0])
-break;
-case 13: this.$ = new yy.MustacheNode($$[$0-1][0], $$[$0-1][1])
-break;
-case 14: this.$ = new yy.MustacheNode($$[$0-1][0], $$[$0-1][1])
-break;
-case 15: this.$ = $$[$0-1]
-break;
-case 16: this.$ = new yy.MustacheNode($$[$0-1][0], $$[$0-1][1])
-break;
-case 17: this.$ = new yy.MustacheNode($$[$0-1][0], $$[$0-1][1], true)
-break;
-case 18: this.$ = new yy.PartialNode($$[$0-1])
-break;
-case 19: this.$ = new yy.PartialNode($$[$0-2], $$[$0-1])
-break;
-case 20:
-break;
-case 21: this.$ = [[$$[$0-2]].concat($$[$0-1]), $$[$0]]
-break;
-case 22: this.$ = [[$$[$0-1]].concat($$[$0]), null]
-break;
-case 23: this.$ = [[$$[$0-1]], $$[$0]]
-break;
-case 24: this.$ = [[$$[$0]], null]
-break;
-case 25: $$[$0-1].push($$[$0]); this.$ = $$[$0-1];
-break;
-case 26: this.$ = [$$[$0]]
-break;
-case 27: this.$ = $$[$0]
-break;
-case 28: this.$ = new yy.StringNode($$[$0])
-break;
-case 29: this.$ = new yy.IntegerNode($$[$0])
-break;
-case 30: this.$ = new yy.BooleanNode($$[$0])
-break;
-case 31: this.$ = new yy.HashNode($$[$0])
-break;
-case 32: $$[$0-1].push($$[$0]); this.$ = $$[$0-1]
-break;
-case 33: this.$ = [$$[$0]]
-break;
-case 34: this.$ = [$$[$0-2], $$[$0]]
-break;
-case 35: this.$ = [$$[$0-2], new yy.StringNode($$[$0])]
-break;
-case 36: this.$ = [$$[$0-2], new yy.IntegerNode($$[$0])]
-break;
-case 37: this.$ = [$$[$0-2], new yy.BooleanNode($$[$0])]
-break;
-case 38: this.$ = new yy.IdNode($$[$0])
-break;
-case 39: $$[$0-2].push($$[$0]); this.$ = $$[$0-2];
-break;
-case 40: this.$ = [$$[$0]]
-break;
-}
-},
-table: [{3:1,4:2,5:[2,4],6:3,8:4,9:5,11:6,12:7,13:8,14:[1,9],15:[1,10],16:[1,12],19:[1,11],22:[1,13],23:[1,14],24:[1,15]},{1:[3]},{5:[1,16]},{5:[2,3],7:17,8:18,9:5,11:6,12:7,13:8,14:[1,9],15:[1,10],16:[1,12],19:[1,19],20:[2,3],22:[1,13],23:[1,14],24:[1,15]},{5:[2,5],14:[2,5],15:[2,5],16:[2,5],19:[2,5],20:[2,5],22:[2,5],23:[2,5],24:[2,5]},{4:20,6:3,8:4,9:5,11:6,12:7,13:8,14:[1,9],15:[1,10],16:[1,12],19:[1,11],20:[2,4],22:[1,13],23:[1,14],24:[1,15]},{4:21,6:3,8:4,9:5,11:6,12:7,13:8,14:[1,9],15:[1,10],16:[1,12],19:[1,11],20:[2,4],22:[1,13],23:[1,14],24:[1,15]},{5:[2,9],14:[2,9],15:[2,9],16:[2,9],19:[2,9],20:[2,9],22:[2,9],23:[2,9],24:[2,9]},{5:[2,10],14:[2,10],15:[2,10],16:[2,10],19:[2,10],20:[2,10],22:[2,10],23:[2,10],24:[2,10]},{5:[2,11],14:[2,11],15:[2,11],16:[2,11],19:[2,11],20:[2,11],22:[2,11],23:[2,11],24:[2,11]},{5:[2,12],14:[2,12],15:[2,12],16:[2,12],19:[2,12],20:[2,12],22:[2,12],23:[2,12],24:[2,12]},{17:22,21:23,33:[1,25],35:24},{17:26,21:23,33:[1,25],35:24},{17:27,21:23,33:[1,25],35:24},{17:28,21:23,33:[1,25],35:24},{21:29,33:[1,25],35:24},{1:[2,1]},{6:30,8:4,9:5,11:6,12:7,13:8,14:[1,9],15:[1,10],16:[1,12],19:[1,11],22:[1,13],23:[1,14],24:[1,15]},{5:[2,6],14:[2,6],15:[2,6],16:[2,6],19:[2,6],20:[2,6],22:[2,6],23:[2,6],24:[2,6]},{17:22,18:[1,31],21:23,33:[1,25],35:24},{10:32,20:[1,33]},{10:34,20:[1,33]},{18:[1,35]},{18:[2,24],21:40,25:36,26:37,27:38,28:[1,41],29:[1,42],30:[1,43],31:39,32:44,33:[1,45],35:24},{18:[2,38],28:[2,38],29:[2,38],30:[2,38],33:[2,38],36:[1,46]},{18:[2,40],28:[2,40],29:[2,40],30:[2,40],33:[2,40],36:[2,40]},{18:[1,47]},{18:[1,48]},{18:[1,49]},{18:[1,50],21:51,33:[1,25],35:24},{5:[2,2],8:18,9:5,11:6,12:7,13:8,14:[1,9],15:[1,10],16:[1,12],19:[1,11],20:[2,2],22:[1,13],23:[1,14],24:[1,15]},{14:[2,20],15:[2,20],16:[2,20],19:[2,20],22:[2,20],23:[2,20],24:[2,20]},{5:[2,7],14:[2,7],15:[2,7],16:[2,7],19:[2,7],20:[2,7],22:[2,7],23:[2,7],24:[2,7]},{21:52,33:[1,25],35:24},{5:[2,8],14:[2,8],15:[2,8],16:[2,8],19:[2,8],20:[2,8],22:[2,8],23:[2,8],24:[2,8]},{14:[2,14],15:[2,14],16:[2,14],19:[2,14],20:[2,14],22:[2,14],23:[2,14],24:[2,14]},{18:[2,22],21:40,26:53,27:54,28:[1,41],29:[1,42],30:[1,43],31:39,32:44,33:[1,45],35:24},{18:[2,23]},{18:[2,26],28:[2,26],29:[2,26],30:[2,26],33:[2,26]},{18:[2,31],32:55,33:[1,56]},{18:[2,27],28:[2,27],29:[2,27],30:[2,27],33:[2,27]},{18:[2,28],28:[2,28],29:[2,28],30:[2,28],33:[2,28]},{18:[2,29],28:[2,29],29:[2,29],30:[2,29],33:[2,29]},{18:[2,30],28:[2,30],29:[2,30],30:[2,30],33:[2,30]},{18:[2,33],33:[2,33]},{18:[2,40],28:[2,40],29:[2,40],30:[2,40],33:[2,40],34:[1,57],36:[2,40]},{33:[1,58]},{14:[2,13],15:[2,13],16:[2,13],19:[2,13],20:[2,13],22:[2,13],23:[2,13],24:[2,13]},{5:[2,16],14:[2,16],15:[2,16],16:[2,16],19:[2,16],20:[2,16],22:[2,16],23:[2,16],24:[2,16]},{5:[2,17],14:[2,17],15:[2,17],16:[2,17],19:[2,17],20:[2,17],22:[2,17],23:[2,17],24:[2,17]},{5:[2,18],14:[2,18],15:[2,18],16:[2,18],19:[2,18],20:[2,18],22:[2,18],23:[2,18],24:[2,18]},{18:[1,59]},{18:[1,60]},{18:[2,21]},{18:[2,25],28:[2,25],29:[2,25],30:[2,25],33:[2,25]},{18:[2,32],33:[2,32]},{34:[1,57]},{21:61,28:[1,62],29:[1,63],30:[1,64],33:[1,25],35:24},{18:[2,39],28:[2,39],29:[2,39],30:[2,39],33:[2,39],36:[2,39]},{5:[2,19],14:[2,19],15:[2,19],16:[2,19],19:[2,19],20:[2,19],22:[2,19],23:[2,19],24:[2,19]},{5:[2,15],14:[2,15],15:[2,15],16:[2,15],19:[2,15],20:[2,15],22:[2,15],23:[2,15],24:[2,15]},{18:[2,34],33:[2,34]},{18:[2,35],33:[2,35]},{18:[2,36],33:[2,36]},{18:[2,37],33:[2,37]}],
-defaultActions: {16:[2,1],37:[2,23],53:[2,21]},
-parseError: function parseError(str, hash) {
- throw new Error(str);
-},
-parse: function parse(input) {
- var self = this,
- stack = [0],
- vstack = [null], // semantic value stack
- lstack = [], // location stack
- table = this.table,
- yytext = '',
- yylineno = 0,
- yyleng = 0,
- recovering = 0,
- TERROR = 2,
- EOF = 1;
-
- //this.reductionCount = this.shiftCount = 0;
-
- this.lexer.setInput(input);
- this.lexer.yy = this.yy;
- this.yy.lexer = this.lexer;
- if (typeof this.lexer.yylloc == 'undefined')
- this.lexer.yylloc = {};
- var yyloc = this.lexer.yylloc;
- lstack.push(yyloc);
-
- if (typeof this.yy.parseError === 'function')
- this.parseError = this.yy.parseError;
-
- function popStack (n) {
- stack.length = stack.length - 2*n;
- vstack.length = vstack.length - n;
- lstack.length = lstack.length - n;
- }
-
- function lex() {
- var token;
- token = self.lexer.lex() || 1; // $end = 1
- // if token isn't its numeric value, convert
- if (typeof token !== 'number') {
- token = self.symbols_[token] || token;
- }
- return token;
- };
-
- var symbol, preErrorSymbol, state, action, a, r, yyval={},p,len,newState, expected;
- while (true) {
- // retreive state number from top of stack
- state = stack[stack.length-1];
-
- // use default actions if available
- if (this.defaultActions[state]) {
- action = this.defaultActions[state];
- } else {
- if (symbol == null)
- symbol = lex();
- // read action for current state and first input
- action = table[state] && table[state][symbol];
- }
-
- // handle parse error
- if (typeof action === 'undefined' || !action.length || !action[0]) {
-
- if (!recovering) {
- // Report error
- expected = [];
- for (p in table[state]) if (this.terminals_[p] && p > 2) {
- expected.push("'"+this.terminals_[p]+"'");
- }
- var errStr = '';
- if (this.lexer.showPosition) {
- errStr = 'Parse error on line '+(yylineno+1)+":\n"+this.lexer.showPosition()+'\nExpecting '+expected.join(', ');
- } else {
- errStr = 'Parse error on line '+(yylineno+1)+": Unexpected " +
- (symbol == 1 /*EOF*/ ? "end of input" :
- ("'"+(this.terminals_[symbol] || symbol)+"'"));
- }
- this.parseError(errStr,
- {text: this.lexer.match, token: this.terminals_[symbol] || symbol, line: this.lexer.yylineno, loc: yyloc, expected: expected});
- }
-
- // just recovered from another error
- if (recovering == 3) {
- if (symbol == EOF) {
- throw new Error(errStr || 'Parsing halted.');
- }
-
- // discard current lookahead and grab another
- yyleng = this.lexer.yyleng;
- yytext = this.lexer.yytext;
- yylineno = this.lexer.yylineno;
- yyloc = this.lexer.yylloc;
- symbol = lex();
- }
-
- // try to recover from error
- while (1) {
- // check for error recovery rule in this state
- if ((TERROR.toString()) in table[state]) {
- break;
- }
- if (state == 0) {
- throw new Error(errStr || 'Parsing halted.');
- }
- popStack(1);
- state = stack[stack.length-1];
- }
-
- preErrorSymbol = symbol; // save the lookahead token
- symbol = TERROR; // insert generic error symbol as new lookahead
- state = stack[stack.length-1];
- action = table[state] && table[state][TERROR];
- recovering = 3; // allow 3 real symbols to be shifted before reporting a new error
- }
-
- // this shouldn't happen, unless resolve defaults are off
- if (action[0] instanceof Array && action.length > 1) {
- throw new Error('Parse Error: multiple actions possible at state: '+state+', token: '+symbol);
- }
-
- switch (action[0]) {
-
- case 1: // shift
- //this.shiftCount++;
-
- stack.push(symbol);
- vstack.push(this.lexer.yytext);
- lstack.push(this.lexer.yylloc);
- stack.push(action[1]); // push state
- symbol = null;
- if (!preErrorSymbol) { // normal execution/no error
- yyleng = this.lexer.yyleng;
- yytext = this.lexer.yytext;
- yylineno = this.lexer.yylineno;
- yyloc = this.lexer.yylloc;
- if (recovering > 0)
- recovering--;
- } else { // error just occurred, resume old lookahead f/ before error
- symbol = preErrorSymbol;
- preErrorSymbol = null;
- }
- break;
-
- case 2: // reduce
- //this.reductionCount++;
-
- len = this.productions_[action[1]][1];
-
- // perform semantic action
- yyval.$ = vstack[vstack.length-len]; // default to $$ = $1
- // default location, uses first token for firsts, last for lasts
- yyval._$ = {
- first_line: lstack[lstack.length-(len||1)].first_line,
- last_line: lstack[lstack.length-1].last_line,
- first_column: lstack[lstack.length-(len||1)].first_column,
- last_column: lstack[lstack.length-1].last_column
- };
- r = this.performAction.call(yyval, yytext, yyleng, yylineno, this.yy, action[1], vstack, lstack);
-
- if (typeof r !== 'undefined') {
- return r;
- }
-
- // pop off stack
- if (len) {
- stack = stack.slice(0,-1*len*2);
- vstack = vstack.slice(0, -1*len);
- lstack = lstack.slice(0, -1*len);
- }
-
- stack.push(this.productions_[action[1]][0]); // push nonterminal (reduce)
- vstack.push(yyval.$);
- lstack.push(yyval._$);
- // goto new state = table[STATE][NONTERMINAL]
- newState = table[stack[stack.length-2]][stack[stack.length-1]];
- stack.push(newState);
- break;
-
- case 3: // accept
- return true;
- }
-
- }
-
- return true;
-}};/* Jison generated lexer */
-var lexer = (function(){var lexer = ({EOF:1,
-parseError:function parseError(str, hash) {
- if (this.yy.parseError) {
- this.yy.parseError(str, hash);
- } else {
- throw new Error(str);
- }
- },
-setInput:function (input) {
- this._input = input;
- this._more = this._less = this.done = false;
- this.yylineno = this.yyleng = 0;
- this.yytext = this.matched = this.match = '';
- this.conditionStack = ['INITIAL'];
- this.yylloc = {first_line:1,first_column:0,last_line:1,last_column:0};
- return this;
- },
-input:function () {
- var ch = this._input[0];
- this.yytext+=ch;
- this.yyleng++;
- this.match+=ch;
- this.matched+=ch;
- var lines = ch.match(/\n/);
- if (lines) this.yylineno++;
- this._input = this._input.slice(1);
- return ch;
- },
-unput:function (ch) {
- this._input = ch + this._input;
- return this;
- },
-more:function () {
- this._more = true;
- return this;
- },
-pastInput:function () {
- var past = this.matched.substr(0, this.matched.length - this.match.length);
- return (past.length > 20 ? '...':'') + past.substr(-20).replace(/\n/g, "");
- },
-upcomingInput:function () {
- var next = this.match;
- if (next.length < 20) {
- next += this._input.substr(0, 20-next.length);
- }
- return (next.substr(0,20)+(next.length > 20 ? '...':'')).replace(/\n/g, "");
- },
-showPosition:function () {
- var pre = this.pastInput();
- var c = new Array(pre.length + 1).join("-");
- return pre + this.upcomingInput() + "\n" + c+"^";
- },
-next:function () {
- if (this.done) {
- return this.EOF;
- }
- if (!this._input) this.done = true;
-
- var token,
- match,
- col,
- lines;
- if (!this._more) {
- this.yytext = '';
- this.match = '';
- }
- var rules = this._currentRules();
- for (var i=0;i < rules.length; i++) {
- match = this._input.match(this.rules[rules[i]]);
- if (match) {
- lines = match[0].match(/\n.*/g);
- if (lines) this.yylineno += lines.length;
- this.yylloc = {first_line: this.yylloc.last_line,
- last_line: this.yylineno+1,
- first_column: this.yylloc.last_column,
- last_column: lines ? lines[lines.length-1].length-1 : this.yylloc.last_column + match[0].length}
- this.yytext += match[0];
- this.match += match[0];
- this.matches = match;
- this.yyleng = this.yytext.length;
- this._more = false;
- this._input = this._input.slice(match[0].length);
- this.matched += match[0];
- token = this.performAction.call(this, this.yy, this, rules[i],this.conditionStack[this.conditionStack.length-1]);
- if (token) return token;
- else return;
- }
- }
- if (this._input === "") {
- return this.EOF;
- } else {
- this.parseError('Lexical error on line '+(this.yylineno+1)+'. Unrecognized text.\n'+this.showPosition(),
- {text: "", token: null, line: this.yylineno});
- }
- },
-lex:function lex() {
- var r = this.next();
- if (typeof r !== 'undefined') {
- return r;
- } else {
- return this.lex();
- }
- },
-begin:function begin(condition) {
- this.conditionStack.push(condition);
- },
-popState:function popState() {
- return this.conditionStack.pop();
- },
-_currentRules:function _currentRules() {
- return this.conditions[this.conditionStack[this.conditionStack.length-1]].rules;
- }});
-lexer.performAction = function anonymous(yy,yy_,$avoiding_name_collisions,YY_START) {
-
-var YYSTATE=YY_START
-switch($avoiding_name_collisions) {
-case 0: this.begin("mu"); if (yy_.yytext) return 14;
-break;
-case 1: return 14;
-break;
-case 2: return 24;
-break;
-case 3: return 16;
-break;
-case 4: return 20;
-break;
-case 5: return 19;
-break;
-case 6: return 19;
-break;
-case 7: return 23;
-break;
-case 8: return 23;
-break;
-case 9: yy_.yytext = yy_.yytext.substr(3,yy_.yyleng-5); this.begin("INITIAL"); return 15;
-break;
-case 10: return 22;
-break;
-case 11: return 34;
-break;
-case 12: return 33;
-break;
-case 13: return 33;
-break;
-case 14: return 36;
-break;
-case 15: /*ignore whitespace*/
-break;
-case 16: this.begin("INITIAL"); return 18;
-break;
-case 17: this.begin("INITIAL"); return 18;
-break;
-case 18: yy_.yytext = yy_.yytext.substr(1,yy_.yyleng-2).replace(/\\"/g,'"'); return 28;
-break;
-case 19: return 30;
-break;
-case 20: return 30;
-break;
-case 21: return 29;
-break;
-case 22: return 33;
-break;
-case 23: return 'INVALID';
-break;
-case 24: return 5;
-break;
-}
-};
-lexer.rules = [/^[^\x00]*?(?=(\{\{))/,/^[^\x00]+/,/^\{\{>/,/^\{\{#/,/^\{\{\//,/^\{\{\^/,/^\{\{\s*else\b/,/^\{\{\{/,/^\{\{&/,/^\{\{![\s\S]*?\}\}/,/^\{\{/,/^=/,/^\.(?=[} ])/,/^\.\./,/^[/.]/,/^\s+/,/^\}\}\}/,/^\}\}/,/^"(\\["]|[^"])*"/,/^true(?=[}\s])/,/^false(?=[}\s])/,/^[0-9]+(?=[}\s])/,/^[a-zA-Z0-9_$-]+(?=[=}\s/.])/,/^./,/^$/];
-lexer.conditions = {"mu":{"rules":[2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24],"inclusive":false},"INITIAL":{"rules":[0,1,24],"inclusive":true}};return lexer;})()
-parser.lexer = lexer;
-return parser;
-})();
-// if (typeof require !== 'undefined' && typeof exports !== 'undefined') {
-// exports.parser = handlebars;
-// exports.parse = function () { return handlebars.parse.apply(handlebars, arguments); }
-// exports.main = function commonjsMain(args) {
-// if (!args[1])
-// throw new Error('Usage: '+args[0]+' FILE');
-// if (typeof process !== 'undefined') {
-// var source = require('fs').readFileSync(require('path').join(process.cwd(), args[1]), "utf8");
-// } else {
-// var cwd = require("file").path(require("file").cwd());
-// var source = cwd.join(args[1]).read({charset: "utf-8"});
-// }
-// return exports.parser.parse(source);
-// }
-// if (typeof module !== 'undefined' && require.main === module) {
-// exports.main(typeof process !== 'undefined' ? process.argv.slice(1) : require("system").args);
-// }
-// };
-// ;
-// lib/handlebars/base.js
-var Handlebars = {};
-
-Handlebars.VERSION = "1.0.beta.2";
-
-Handlebars.Parser = handlebars;
-
-Handlebars.parse = function(string) {
- Handlebars.Parser.yy = Handlebars.AST;
- return Handlebars.Parser.parse(string);
-};
-
-Handlebars.print = function(ast) {
- return new Handlebars.PrintVisitor().accept(ast);
-};
-
-Handlebars.helpers = {};
-Handlebars.partials = {};
-
-Handlebars.registerHelper = function(name, fn, inverse) {
- if(inverse) { fn.not = inverse; }
- this.helpers[name] = fn;
-};
-
-Handlebars.registerPartial = function(name, str) {
- this.partials[name] = str;
-};
-
-Handlebars.registerHelper('helperMissing', function(arg) {
- if(arguments.length === 2) {
- return undefined;
- } else {
- throw new Error("Could not find property '" + arg + "'");
- }
-});
-
-Handlebars.registerHelper('blockHelperMissing', function(context, fn, inverse) {
- inverse = inverse || function() {};
-
- var ret = "";
- var type = Object.prototype.toString.call(context);
-
- if(type === "[object Function]") {
- context = context();
- }
-
- if(context === true) {
- return fn(this);
- } else if(context === false || context == null) {
- return inverse(this);
- } else if(type === "[object Array]") {
- if(context.length > 0) {
- for(var i=0, j=context.length; i 0) {
- for(var i=0, j=context.length; i": ">",
- '"': """,
- "'": "'",
- "`": "`"
- };
-
- var badChars = /&(?!\w+;)|[<>"'`]/g;
- var possible = /[&<>"'`]/;
-
- var escapeChar = function(chr) {
- return escape[chr] || "&"
- };
-
- Handlebars.Utils = {
- escapeExpression: function(string) {
- // don't escape SafeStrings, since they're already safe
- if (string instanceof Handlebars.SafeString) {
- return string.toString();
- } else if (string == null || string === false) {
- return "";
- }
-
- if(!possible.test(string)) { return string; }
- return string.replace(badChars, escapeChar);
- },
-
- isEmpty: function(value) {
- if (typeof value === "undefined") {
- return true;
- } else if (value === null) {
- return true;
- } else if (value === false) {
- return true;
- } else if(Object.prototype.toString.call(value) === "[object Array]" && value.length === 0) {
- return true;
- } else {
- return false;
- }
- }
- };
-})();;
-// lib/handlebars/compiler.js
-Handlebars.Compiler = function() {};
-Handlebars.JavaScriptCompiler = function() {};
-
-(function(Compiler, JavaScriptCompiler) {
- Compiler.OPCODE_MAP = {
- appendContent: 1,
- getContext: 2,
- lookupWithHelpers: 3,
- lookup: 4,
- append: 5,
- invokeMustache: 6,
- appendEscaped: 7,
- pushString: 8,
- truthyOrFallback: 9,
- functionOrFallback: 10,
- invokeProgram: 11,
- invokePartial: 12,
- push: 13,
- invokeInverse: 14,
- assignToHash: 15,
- pushStringParam: 16
- };
-
- Compiler.MULTI_PARAM_OPCODES = {
- appendContent: 1,
- getContext: 1,
- lookupWithHelpers: 1,
- lookup: 1,
- invokeMustache: 2,
- pushString: 1,
- truthyOrFallback: 1,
- functionOrFallback: 1,
- invokeProgram: 2,
- invokePartial: 1,
- push: 1,
- invokeInverse: 1,
- assignToHash: 1,
- pushStringParam: 1
- };
-
- Compiler.DISASSEMBLE_MAP = {};
-
- for(var prop in Compiler.OPCODE_MAP) {
- var value = Compiler.OPCODE_MAP[prop];
- Compiler.DISASSEMBLE_MAP[value] = prop;
- }
-
- Compiler.multiParamSize = function(code) {
- return Compiler.MULTI_PARAM_OPCODES[Compiler.DISASSEMBLE_MAP[code]];
- };
-
- Compiler.prototype = {
- compiler: Compiler,
-
- disassemble: function() {
- var opcodes = this.opcodes, opcode, nextCode;
- var out = [], str, name, value;
-
- for(var i=0, l=opcodes.length; i 0) {
- this.source[0] = this.source[0] + ", " + locals.join(", ");
- }
-
- this.source[0] = this.source[0] + ";";
-
- this.source.push("return buffer;");
-
- var params = ["Handlebars", "context", "helpers", "partials"];
-
- if(this.options.data) { params.push("data"); }
-
- for(var i=0, l=this.environment.depths.list.length; i this.stackVars.length) { this.stackVars.push("stack" + this.stackSlot); }
- return "stack" + this.stackSlot;
- },
-
- popStack: function() {
- return "stack" + this.stackSlot--;
- },
-
- topStack: function() {
- return "stack" + this.stackSlot;
- },
-
- quotedString: function(str) {
- return '"' + str
- .replace(/\\/g, '\\\\')
- .replace(/"/g, '\\"')
- .replace(/\n/g, '\\n')
- .replace(/\r/g, '\\r') + '"';
- }
- };
-
- var reservedWords = ("break case catch continue default delete do else finally " +
- "for function if in instanceof new return switch this throw " +
- "try typeof var void while with null true false").split(" ");
-
- var compilerWords = JavaScriptCompiler.RESERVED_WORDS = {};
-
- for(var i=0, l=reservedWords.length; i