/ * !
handlebars v3 . 0.2
Copyright ( C ) 2011 - 2014 by Yehuda Katz
Permission is hereby granted , free of charge , to any person obtaining a copy
of this software and associated documentation files ( the "Software" ) , to deal
in the Software without restriction , including without limitation the rights
to use , copy , modify , merge , publish , distribute , sublicense , and / or sell
copies of the Software , and to permit persons to whom the Software is
furnished to do so , subject to the following conditions :
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software .
THE SOFTWARE IS PROVIDED "AS IS" , WITHOUT WARRANTY OF ANY KIND , EXPRESS OR
IMPLIED , INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY ,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT . IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM , DAMAGES OR OTHER
LIABILITY , WHETHER IN AN ACTION OF CONTRACT , TORT OR OTHERWISE , ARISING FROM ,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE .
@ license
* /
( function webpackUniversalModuleDefinition ( root , factory ) {
if ( typeof exports === 'object' && typeof module === 'object' )
module . exports = factory ( ) ;
else if ( typeof define === 'function' && define . amd )
define ( factory ) ;
else if ( typeof exports === 'object' )
exports [ "Handlebars" ] = factory ( ) ;
else
root [ "Handlebars" ] = factory ( ) ;
} ) ( this , function ( ) {
return /******/ ( function ( modules ) { // webpackBootstrap
/******/ // The module cache
/******/ var installedModules = { } ;
/******/ // The require function
/******/ function _ _webpack _require _ _ ( moduleId ) {
/******/ // Check if module is in cache
/******/ if ( installedModules [ moduleId ] )
/******/ return installedModules [ moduleId ] . exports ;
/******/ // Create a new module (and put it into the cache)
/******/ var module = installedModules [ moduleId ] = {
/******/ exports : { } ,
/******/ id : moduleId ,
/******/ loaded : false
/******/ } ;
/******/ // Execute the module function
/******/ modules [ moduleId ] . call ( module . exports , module , module . exports , _ _webpack _require _ _ ) ;
/******/ // Flag the module as loaded
/******/ module . loaded = true ;
/******/ // Return the exports of the module
/******/ return module . exports ;
/******/ }
/******/ // expose the modules object (__webpack_modules__)
/******/ _ _webpack _require _ _ . m = modules ;
/******/ // expose the module cache
/******/ _ _webpack _require _ _ . c = installedModules ;
/******/ // __webpack_public_path__
/******/ _ _webpack _require _ _ . p = "" ;
/******/ // Load entry module and return exports
/******/ return _ _webpack _require _ _ ( 0 ) ;
/******/ } )
/************************************************************************/
/******/ ( [
/* 0 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
/* WEBPACK VAR INJECTION */ ( function ( global ) { 'use strict' ;
var _interopRequireWildcard = _ _webpack _require _ _ ( 7 ) [ 'default' ] ;
exports . _ _esModule = true ;
var _Handlebars = _ _webpack _require _ _ ( 1 ) ;
var _Handlebars2 = _interopRequireWildcard ( _Handlebars ) ;
// Compiler imports
var _AST = _ _webpack _require _ _ ( 2 ) ;
var _AST2 = _interopRequireWildcard ( _AST ) ;
var _Parser$parse = _ _webpack _require _ _ ( 3 ) ;
var _Compiler$compile$precompile = _ _webpack _require _ _ ( 4 ) ;
var _JavaScriptCompiler = _ _webpack _require _ _ ( 5 ) ;
var _JavaScriptCompiler2 = _interopRequireWildcard ( _JavaScriptCompiler ) ;
var _Visitor = _ _webpack _require _ _ ( 6 ) ;
var _Visitor2 = _interopRequireWildcard ( _Visitor ) ;
var _create = _Handlebars2 [ 'default' ] . create ;
function create ( ) {
var hb = _create ( ) ;
hb . compile = function ( input , options ) {
return _Compiler$compile$precompile . compile ( input , options , hb ) ;
} ;
hb . precompile = function ( input , options ) {
return _Compiler$compile$precompile . precompile ( input , options , hb ) ;
} ;
hb . AST = _AST2 [ 'default' ] ;
hb . Compiler = _Compiler$compile$precompile . Compiler ;
hb . JavaScriptCompiler = _JavaScriptCompiler2 [ 'default' ] ;
hb . Parser = _Parser$parse . parser ;
hb . parse = _Parser$parse . parse ;
return hb ;
}
var inst = create ( ) ;
inst . create = create ;
inst . Visitor = _Visitor2 [ 'default' ] ;
/*jshint -W040 */
/* istanbul ignore next */
var $Handlebars = global . Handlebars ;
/* istanbul ignore next */
inst . noConflict = function ( ) {
if ( global . Handlebars === inst ) {
global . Handlebars = $Handlebars ;
}
} ;
inst [ 'default' ] = inst ;
exports [ 'default' ] = inst ;
module . exports = exports [ 'default' ] ;
/* WEBPACK VAR INJECTION */ } . call ( exports , ( function ( ) { return this ; } ( ) ) ) )
/***/ } ,
/* 1 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
/* WEBPACK VAR INJECTION */ ( function ( global ) { 'use strict' ;
var _interopRequireWildcard = _ _webpack _require _ _ ( 7 ) [ 'default' ] ;
exports . _ _esModule = true ;
/*global window */
var _import = _ _webpack _require _ _ ( 8 ) ;
var base = _interopRequireWildcard ( _import ) ;
// Each of these augment the Handlebars object. No need to setup here.
// (This is done to easily share code between commonjs and browse envs)
var _SafeString = _ _webpack _require _ _ ( 9 ) ;
var _SafeString2 = _interopRequireWildcard ( _SafeString ) ;
var _Exception = _ _webpack _require _ _ ( 10 ) ;
var _Exception2 = _interopRequireWildcard ( _Exception ) ;
var _import2 = _ _webpack _require _ _ ( 11 ) ;
var Utils = _interopRequireWildcard ( _import2 ) ;
var _import3 = _ _webpack _require _ _ ( 12 ) ;
var runtime = _interopRequireWildcard ( _import3 ) ;
// For compatibility and usage outside of module systems, make the Handlebars object a namespace
function create ( ) {
var hb = new base . HandlebarsEnvironment ( ) ;
Utils . extend ( hb , base ) ;
hb . SafeString = _SafeString2 [ 'default' ] ;
hb . Exception = _Exception2 [ 'default' ] ;
hb . Utils = Utils ;
hb . escapeExpression = Utils . escapeExpression ;
hb . VM = runtime ;
hb . template = function ( spec ) {
return runtime . template ( spec , hb ) ;
} ;
return hb ;
}
var Handlebars = create ( ) ;
Handlebars . create = create ;
/*jshint -W040 */
/* istanbul ignore next */
var root = typeof global !== 'undefined' ? global : window ,
$Handlebars = root . Handlebars ;
/* istanbul ignore next */
Handlebars . noConflict = function ( ) {
if ( root . Handlebars === Handlebars ) {
root . Handlebars = $Handlebars ;
}
} ;
Handlebars [ 'default' ] = Handlebars ;
exports [ 'default' ] = Handlebars ;
module . exports = exports [ 'default' ] ;
/* WEBPACK VAR INJECTION */ } . call ( exports , ( function ( ) { return this ; } ( ) ) ) )
/***/ } ,
/* 2 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
exports . _ _esModule = true ;
var AST = {
Program : function Program ( statements , blockParams , strip , locInfo ) {
this . loc = locInfo ;
this . type = 'Program' ;
this . body = statements ;
this . blockParams = blockParams ;
this . strip = strip ;
} ,
MustacheStatement : function MustacheStatement ( path , params , hash , escaped , strip , locInfo ) {
this . loc = locInfo ;
this . type = 'MustacheStatement' ;
this . path = path ;
this . params = params || [ ] ;
this . hash = hash ;
this . escaped = escaped ;
this . strip = strip ;
} ,
BlockStatement : function BlockStatement ( path , params , hash , program , inverse , openStrip , inverseStrip , closeStrip , locInfo ) {
this . loc = locInfo ;
this . type = 'BlockStatement' ;
this . path = path ;
this . params = params || [ ] ;
this . hash = hash ;
this . program = program ;
this . inverse = inverse ;
this . openStrip = openStrip ;
this . inverseStrip = inverseStrip ;
this . closeStrip = closeStrip ;
} ,
PartialStatement : function PartialStatement ( name , params , hash , strip , locInfo ) {
this . loc = locInfo ;
this . type = 'PartialStatement' ;
this . name = name ;
this . params = params || [ ] ;
this . hash = hash ;
this . indent = '' ;
this . strip = strip ;
} ,
ContentStatement : function ContentStatement ( string , locInfo ) {
this . loc = locInfo ;
this . type = 'ContentStatement' ;
this . original = this . value = string ;
} ,
CommentStatement : function CommentStatement ( comment , strip , locInfo ) {
this . loc = locInfo ;
this . type = 'CommentStatement' ;
this . value = comment ;
this . strip = strip ;
} ,
SubExpression : function SubExpression ( path , params , hash , locInfo ) {
this . loc = locInfo ;
this . type = 'SubExpression' ;
this . path = path ;
this . params = params || [ ] ;
this . hash = hash ;
} ,
PathExpression : function PathExpression ( data , depth , parts , original , locInfo ) {
this . loc = locInfo ;
this . type = 'PathExpression' ;
this . data = data ;
this . original = original ;
this . parts = parts ;
this . depth = depth ;
} ,
StringLiteral : function StringLiteral ( string , locInfo ) {
this . loc = locInfo ;
this . type = 'StringLiteral' ;
this . original = this . value = string ;
} ,
NumberLiteral : function NumberLiteral ( number , locInfo ) {
this . loc = locInfo ;
this . type = 'NumberLiteral' ;
this . original = this . value = Number ( number ) ;
} ,
BooleanLiteral : function BooleanLiteral ( bool , locInfo ) {
this . loc = locInfo ;
this . type = 'BooleanLiteral' ;
this . original = this . value = bool === 'true' ;
} ,
UndefinedLiteral : function UndefinedLiteral ( locInfo ) {
this . loc = locInfo ;
this . type = 'UndefinedLiteral' ;
this . original = this . value = undefined ;
} ,
NullLiteral : function NullLiteral ( locInfo ) {
this . loc = locInfo ;
this . type = 'NullLiteral' ;
this . original = this . value = null ;
} ,
Hash : function Hash ( pairs , locInfo ) {
this . loc = locInfo ;
this . type = 'Hash' ;
this . pairs = pairs ;
} ,
HashPair : function HashPair ( key , value , locInfo ) {
this . loc = locInfo ;
this . type = 'HashPair' ;
this . key = key ;
this . value = value ;
} ,
// Public API used to evaluate derived attributes regarding AST nodes
helpers : {
// a mustache is definitely a helper if:
// * it is an eligible helper, and
// * it has at least one parameter or hash segment
helperExpression : function helperExpression ( node ) {
return ! ! ( node . type === 'SubExpression' || node . params . length || node . hash ) ;
} ,
scopedId : function scopedId ( path ) {
return /^\.|this\b/ . test ( path . original ) ;
} ,
// an ID is simple if it only has one part, and that part is not
// `..` or `this`.
simpleId : function simpleId ( path ) {
return path . parts . length === 1 && ! AST . helpers . scopedId ( path ) && ! path . depth ;
}
}
} ;
// Must be exported as an object rather than the root of the module as the jison lexer
// must modify the object to operate properly.
exports [ 'default' ] = AST ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 3 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireWildcard = _ _webpack _require _ _ ( 7 ) [ 'default' ] ;
exports . _ _esModule = true ;
exports . parse = parse ;
var _parser = _ _webpack _require _ _ ( 13 ) ;
var _parser2 = _interopRequireWildcard ( _parser ) ;
var _AST = _ _webpack _require _ _ ( 2 ) ;
var _AST2 = _interopRequireWildcard ( _AST ) ;
var _WhitespaceControl = _ _webpack _require _ _ ( 14 ) ;
var _WhitespaceControl2 = _interopRequireWildcard ( _WhitespaceControl ) ;
var _import = _ _webpack _require _ _ ( 15 ) ;
var Helpers = _interopRequireWildcard ( _import ) ;
var _extend = _ _webpack _require _ _ ( 11 ) ;
exports . parser = _parser2 [ 'default' ] ;
var yy = { } ;
_extend . extend ( yy , Helpers , _AST2 [ 'default' ] ) ;
function parse ( input , options ) {
// Just return if an already-compiled AST was passed in.
if ( input . type === 'Program' ) {
return input ;
}
_parser2 [ 'default' ] . yy = yy ;
// Altering the shared object here, but this is ok as parser is a sync operation
yy . locInfo = function ( locInfo ) {
return new yy . SourceLocation ( options && options . srcName , locInfo ) ;
} ;
var strip = new _WhitespaceControl2 [ 'default' ] ( ) ;
return strip . accept ( _parser2 [ 'default' ] . parse ( input ) ) ;
}
/***/ } ,
/* 4 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireWildcard = _ _webpack _require _ _ ( 7 ) [ 'default' ] ;
exports . _ _esModule = true ;
exports . Compiler = Compiler ;
exports . precompile = precompile ;
exports . compile = compile ;
var _Exception = _ _webpack _require _ _ ( 10 ) ;
var _Exception2 = _interopRequireWildcard ( _Exception ) ;
var _isArray$indexOf = _ _webpack _require _ _ ( 11 ) ;
var _AST = _ _webpack _require _ _ ( 2 ) ;
var _AST2 = _interopRequireWildcard ( _AST ) ;
var slice = [ ] . slice ;
function Compiler ( ) { }
// the foundHelper register will disambiguate helper lookup from finding a
// function in a context. This is necessary for mustache compatibility, which
// requires that context functions in blocks are evaluated by blockHelperMissing,
// and then proceed as if the resulting value was provided to blockHelperMissing.
Compiler . prototype = {
compiler : Compiler ,
equals : function equals ( other ) {
var len = this . opcodes . length ;
if ( other . opcodes . length !== len ) {
return false ;
}
for ( var i = 0 ; i < len ; i ++ ) {
var opcode = this . opcodes [ i ] ,
otherOpcode = other . opcodes [ i ] ;
if ( opcode . opcode !== otherOpcode . opcode || ! argEquals ( opcode . args , otherOpcode . args ) ) {
return false ;
}
}
// We know that length is the same between the two arrays because they are directly tied
// to the opcode behavior above.
len = this . children . length ;
for ( var i = 0 ; i < len ; i ++ ) {
if ( ! this . children [ i ] . equals ( other . children [ i ] ) ) {
return false ;
}
}
return true ;
} ,
guid : 0 ,
compile : function compile ( program , options ) {
this . sourceNode = [ ] ;
this . opcodes = [ ] ;
this . children = [ ] ;
this . options = options ;
this . stringParams = options . stringParams ;
this . trackIds = options . trackIds ;
options . blockParams = options . blockParams || [ ] ;
// These changes will propagate to the other compiler components
var knownHelpers = options . knownHelpers ;
options . knownHelpers = {
helperMissing : true ,
blockHelperMissing : true ,
each : true ,
'if' : true ,
unless : true ,
'with' : true ,
log : true ,
lookup : true
} ;
if ( knownHelpers ) {
for ( var _name in knownHelpers ) {
if ( _name in knownHelpers ) {
options . knownHelpers [ _name ] = knownHelpers [ _name ] ;
}
}
}
return this . accept ( program ) ;
} ,
compileProgram : function compileProgram ( program ) {
var childCompiler = new this . compiler ( ) ,
// eslint-disable-line new-cap
result = childCompiler . compile ( program , this . options ) ,
guid = this . guid ++ ;
this . usePartial = this . usePartial || result . usePartial ;
this . children [ guid ] = result ;
this . useDepths = this . useDepths || result . useDepths ;
return guid ;
} ,
accept : function accept ( node ) {
this . sourceNode . unshift ( node ) ;
var ret = this [ node . type ] ( node ) ;
this . sourceNode . shift ( ) ;
return ret ;
} ,
Program : function Program ( program ) {
this . options . blockParams . unshift ( program . blockParams ) ;
var body = program . body ,
bodyLength = body . length ;
for ( var i = 0 ; i < bodyLength ; i ++ ) {
this . accept ( body [ i ] ) ;
}
this . options . blockParams . shift ( ) ;
this . isSimple = bodyLength === 1 ;
this . blockParams = program . blockParams ? program . blockParams . length : 0 ;
return this ;
} ,
BlockStatement : function BlockStatement ( block ) {
transformLiteralToPath ( block ) ;
var program = block . program ,
inverse = block . inverse ;
program = program && this . compileProgram ( program ) ;
inverse = inverse && this . compileProgram ( inverse ) ;
var type = this . classifySexpr ( block ) ;
if ( type === 'helper' ) {
this . helperSexpr ( block , program , inverse ) ;
} else if ( type === 'simple' ) {
this . simpleSexpr ( block ) ;
// now that the simple mustache is resolved, we need to
// evaluate it by executing `blockHelperMissing`
this . opcode ( 'pushProgram' , program ) ;
this . opcode ( 'pushProgram' , inverse ) ;
this . opcode ( 'emptyHash' ) ;
this . opcode ( 'blockValue' , block . path . original ) ;
} else {
this . ambiguousSexpr ( block , program , inverse ) ;
// now that the simple mustache is resolved, we need to
// evaluate it by executing `blockHelperMissing`
this . opcode ( 'pushProgram' , program ) ;
this . opcode ( 'pushProgram' , inverse ) ;
this . opcode ( 'emptyHash' ) ;
this . opcode ( 'ambiguousBlockValue' ) ;
}
this . opcode ( 'append' ) ;
} ,
PartialStatement : function PartialStatement ( partial ) {
this . usePartial = true ;
var params = partial . params ;
if ( params . length > 1 ) {
throw new _Exception2 [ 'default' ] ( 'Unsupported number of partial arguments: ' + params . length , partial ) ;
} else if ( ! params . length ) {
params . push ( { type : 'PathExpression' , parts : [ ] , depth : 0 } ) ;
}
var partialName = partial . name . original ,
isDynamic = partial . name . type === 'SubExpression' ;
if ( isDynamic ) {
this . accept ( partial . name ) ;
}
this . setupFullMustacheParams ( partial , undefined , undefined , true ) ;
var indent = partial . indent || '' ;
if ( this . options . preventIndent && indent ) {
this . opcode ( 'appendContent' , indent ) ;
indent = '' ;
}
this . opcode ( 'invokePartial' , isDynamic , partialName , indent ) ;
this . opcode ( 'append' ) ;
} ,
MustacheStatement : function MustacheStatement ( mustache ) {
this . SubExpression ( mustache ) ; // eslint-disable-line new-cap
if ( mustache . escaped && ! this . options . noEscape ) {
this . opcode ( 'appendEscaped' ) ;
} else {
this . opcode ( 'append' ) ;
}
} ,
ContentStatement : function ContentStatement ( content ) {
if ( content . value ) {
this . opcode ( 'appendContent' , content . value ) ;
}
} ,
CommentStatement : function CommentStatement ( ) { } ,
SubExpression : function SubExpression ( sexpr ) {
transformLiteralToPath ( sexpr ) ;
var type = this . classifySexpr ( sexpr ) ;
if ( type === 'simple' ) {
this . simpleSexpr ( sexpr ) ;
} else if ( type === 'helper' ) {
this . helperSexpr ( sexpr ) ;
} else {
this . ambiguousSexpr ( sexpr ) ;
}
} ,
ambiguousSexpr : function ambiguousSexpr ( sexpr , program , inverse ) {
var path = sexpr . path ,
name = path . parts [ 0 ] ,
isBlock = program != null || inverse != null ;
this . opcode ( 'getContext' , path . depth ) ;
this . opcode ( 'pushProgram' , program ) ;
this . opcode ( 'pushProgram' , inverse ) ;
this . accept ( path ) ;
this . opcode ( 'invokeAmbiguous' , name , isBlock ) ;
} ,
simpleSexpr : function simpleSexpr ( sexpr ) {
this . accept ( sexpr . path ) ;
this . opcode ( 'resolvePossibleLambda' ) ;
} ,
helperSexpr : function helperSexpr ( sexpr , program , inverse ) {
var params = this . setupFullMustacheParams ( sexpr , program , inverse ) ,
path = sexpr . path ,
name = path . parts [ 0 ] ;
if ( this . options . knownHelpers [ name ] ) {
this . opcode ( 'invokeKnownHelper' , params . length , name ) ;
} else if ( this . options . knownHelpersOnly ) {
throw new _Exception2 [ 'default' ] ( 'You specified knownHelpersOnly, but used the unknown helper ' + name , sexpr ) ;
} else {
path . falsy = true ;
this . accept ( path ) ;
this . opcode ( 'invokeHelper' , params . length , path . original , _AST2 [ 'default' ] . helpers . simpleId ( path ) ) ;
}
} ,
PathExpression : function PathExpression ( path ) {
this . addDepth ( path . depth ) ;
this . opcode ( 'getContext' , path . depth ) ;
var name = path . parts [ 0 ] ,
scoped = _AST2 [ 'default' ] . helpers . scopedId ( path ) ,
blockParamId = ! path . depth && ! scoped && this . blockParamIndex ( name ) ;
if ( blockParamId ) {
this . opcode ( 'lookupBlockParam' , blockParamId , path . parts ) ;
} else if ( ! name ) {
// Context reference, i.e. `{{foo .}}` or `{{foo ..}}`
this . opcode ( 'pushContext' ) ;
} else if ( path . data ) {
this . options . data = true ;
this . opcode ( 'lookupData' , path . depth , path . parts ) ;
} else {
this . opcode ( 'lookupOnContext' , path . parts , path . falsy , scoped ) ;
}
} ,
StringLiteral : function StringLiteral ( string ) {
this . opcode ( 'pushString' , string . value ) ;
} ,
NumberLiteral : function NumberLiteral ( number ) {
this . opcode ( 'pushLiteral' , number . value ) ;
} ,
BooleanLiteral : function BooleanLiteral ( bool ) {
this . opcode ( 'pushLiteral' , bool . value ) ;
} ,
UndefinedLiteral : function UndefinedLiteral ( ) {
this . opcode ( 'pushLiteral' , 'undefined' ) ;
} ,
NullLiteral : function NullLiteral ( ) {
this . opcode ( 'pushLiteral' , 'null' ) ;
} ,
Hash : function Hash ( hash ) {
var pairs = hash . pairs ,
i = 0 ,
l = pairs . length ;
this . opcode ( 'pushHash' ) ;
for ( ; i < l ; i ++ ) {
this . pushParam ( pairs [ i ] . value ) ;
}
while ( i -- ) {
this . opcode ( 'assignToHash' , pairs [ i ] . key ) ;
}
this . opcode ( 'popHash' ) ;
} ,
// HELPERS
opcode : function opcode ( name ) {
this . opcodes . push ( { opcode : name , args : slice . call ( arguments , 1 ) , loc : this . sourceNode [ 0 ] . loc } ) ;
} ,
addDepth : function addDepth ( depth ) {
if ( ! depth ) {
return ;
}
this . useDepths = true ;
} ,
classifySexpr : function classifySexpr ( sexpr ) {
var isSimple = _AST2 [ 'default' ] . helpers . simpleId ( sexpr . path ) ;
var isBlockParam = isSimple && ! ! this . blockParamIndex ( sexpr . path . parts [ 0 ] ) ;
// a mustache is an eligible helper if:
// * its id is simple (a single part, not `this` or `..`)
var isHelper = ! isBlockParam && _AST2 [ 'default' ] . helpers . helperExpression ( sexpr ) ;
// if a mustache is an eligible helper but not a definite
// helper, it is ambiguous, and will be resolved in a later
// pass or at runtime.
var isEligible = ! isBlockParam && ( isHelper || isSimple ) ;
// if ambiguous, we can possibly resolve the ambiguity now
// An eligible helper is one that does not have a complex path, i.e. `this.foo`, `../foo` etc.
if ( isEligible && ! isHelper ) {
var _name2 = sexpr . path . parts [ 0 ] ,
options = this . options ;
if ( options . knownHelpers [ _name2 ] ) {
isHelper = true ;
} else if ( options . knownHelpersOnly ) {
isEligible = false ;
}
}
if ( isHelper ) {
return 'helper' ;
} else if ( isEligible ) {
return 'ambiguous' ;
} else {
return 'simple' ;
}
} ,
pushParams : function pushParams ( params ) {
for ( var i = 0 , l = params . length ; i < l ; i ++ ) {
this . pushParam ( params [ i ] ) ;
}
} ,
pushParam : function pushParam ( val ) {
var value = val . value != null ? val . value : val . original || '' ;
if ( this . stringParams ) {
if ( value . replace ) {
value = value . replace ( /^(\.?\.\/)*/g , '' ) . replace ( /\//g , '.' ) ;
}
if ( val . depth ) {
this . addDepth ( val . depth ) ;
}
this . opcode ( 'getContext' , val . depth || 0 ) ;
this . opcode ( 'pushStringParam' , value , val . type ) ;
if ( val . type === 'SubExpression' ) {
// SubExpressions get evaluated and passed in
// in string params mode.
this . accept ( val ) ;
}
} else {
if ( this . trackIds ) {
var blockParamIndex = undefined ;
if ( val . parts && ! _AST2 [ 'default' ] . helpers . scopedId ( val ) && ! val . depth ) {
blockParamIndex = this . blockParamIndex ( val . parts [ 0 ] ) ;
}
if ( blockParamIndex ) {
var blockParamChild = val . parts . slice ( 1 ) . join ( '.' ) ;
this . opcode ( 'pushId' , 'BlockParam' , blockParamIndex , blockParamChild ) ;
} else {
value = val . original || value ;
if ( value . replace ) {
value = value . replace ( /^\.\//g , '' ) . replace ( /^\.$/g , '' ) ;
}
this . opcode ( 'pushId' , val . type , value ) ;
}
}
this . accept ( val ) ;
}
} ,
setupFullMustacheParams : function setupFullMustacheParams ( sexpr , program , inverse , omitEmpty ) {
var params = sexpr . params ;
this . pushParams ( params ) ;
this . opcode ( 'pushProgram' , program ) ;
this . opcode ( 'pushProgram' , inverse ) ;
if ( sexpr . hash ) {
this . accept ( sexpr . hash ) ;
} else {
this . opcode ( 'emptyHash' , omitEmpty ) ;
}
return params ;
} ,
blockParamIndex : function blockParamIndex ( name ) {
for ( var depth = 0 , len = this . options . blockParams . length ; depth < len ; depth ++ ) {
var blockParams = this . options . blockParams [ depth ] ,
param = blockParams && _isArray$indexOf . indexOf ( blockParams , name ) ;
if ( blockParams && param >= 0 ) {
return [ depth , param ] ;
}
}
}
} ;
function precompile ( input , options , env ) {
if ( input == null || typeof input !== 'string' && input . type !== 'Program' ) {
throw new _Exception2 [ 'default' ] ( 'You must pass a string or Handlebars AST to Handlebars.precompile. You passed ' + input ) ;
}
options = options || { } ;
if ( ! ( 'data' in options ) ) {
options . data = true ;
}
if ( options . compat ) {
options . useDepths = true ;
}
var ast = env . parse ( input , options ) ,
environment = new env . Compiler ( ) . compile ( ast , options ) ;
return new env . JavaScriptCompiler ( ) . compile ( environment , options ) ;
}
function compile ( input , _x , env ) {
var options = arguments [ 1 ] === undefined ? { } : arguments [ 1 ] ;
if ( input == null || typeof input !== 'string' && input . type !== 'Program' ) {
throw new _Exception2 [ 'default' ] ( 'You must pass a string or Handlebars AST to Handlebars.compile. You passed ' + input ) ;
}
if ( ! ( 'data' in options ) ) {
options . data = true ;
}
if ( options . compat ) {
options . useDepths = true ;
}
var compiled = undefined ;
function compileInput ( ) {
var ast = env . parse ( input , options ) ,
environment = new env . Compiler ( ) . compile ( ast , options ) ,
templateSpec = new env . JavaScriptCompiler ( ) . compile ( environment , options , undefined , true ) ;
return env . template ( templateSpec ) ;
}
// Template is only compiled on first use and cached after that point.
function ret ( context , execOptions ) {
if ( ! compiled ) {
compiled = compileInput ( ) ;
}
return compiled . call ( this , context , execOptions ) ;
}
ret . _setup = function ( setupOptions ) {
if ( ! compiled ) {
compiled = compileInput ( ) ;
}
return compiled . _setup ( setupOptions ) ;
} ;
ret . _child = function ( i , data , blockParams , depths ) {
if ( ! compiled ) {
compiled = compileInput ( ) ;
}
return compiled . _child ( i , data , blockParams , depths ) ;
} ;
return ret ;
}
function argEquals ( a , b ) {
if ( a === b ) {
return true ;
}
if ( _isArray$indexOf . isArray ( a ) && _isArray$indexOf . isArray ( b ) && a . length === b . length ) {
for ( var i = 0 ; i < a . length ; i ++ ) {
if ( ! argEquals ( a [ i ] , b [ i ] ) ) {
return false ;
}
}
return true ;
}
}
function transformLiteralToPath ( sexpr ) {
if ( ! sexpr . path . parts ) {
var literal = sexpr . path ;
// Casting to string here to make false and 0 literal values play nicely with the rest
// of the system.
sexpr . path = new _AST2 [ 'default' ] . PathExpression ( false , 0 , [ literal . original + '' ] , literal . original + '' , literal . loc ) ;
}
}
/***/ } ,
/* 5 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireWildcard = _ _webpack _require _ _ ( 7 ) [ 'default' ] ;
exports . _ _esModule = true ;
var _COMPILER _REVISION$REVISION _CHANGES = _ _webpack _require _ _ ( 8 ) ;
var _Exception = _ _webpack _require _ _ ( 10 ) ;
var _Exception2 = _interopRequireWildcard ( _Exception ) ;
var _isArray = _ _webpack _require _ _ ( 11 ) ;
var _CodeGen = _ _webpack _require _ _ ( 16 ) ;
var _CodeGen2 = _interopRequireWildcard ( _CodeGen ) ;
function Literal ( value ) {
this . value = value ;
}
function JavaScriptCompiler ( ) { }
JavaScriptCompiler . prototype = {
// PUBLIC API: You can override these methods in a subclass to provide
// alternative compiled forms for name lookup and buffering semantics
nameLookup : function nameLookup ( parent , name /* , type*/ ) {
if ( JavaScriptCompiler . isValidJavaScriptVariableName ( name ) ) {
return [ parent , '.' , name ] ;
} else {
return [ parent , '[\'' , name , '\']' ] ;
}
} ,
depthedLookup : function depthedLookup ( name ) {
return [ this . aliasable ( 'this.lookup' ) , '(depths, "' , name , '")' ] ;
} ,
compilerInfo : function compilerInfo ( ) {
var revision = _COMPILER _REVISION$REVISION _CHANGES . COMPILER _REVISION ,
versions = _COMPILER _REVISION$REVISION _CHANGES . REVISION _CHANGES [ revision ] ;
return [ revision , versions ] ;
} ,
appendToBuffer : function appendToBuffer ( source , location , explicit ) {
// Force a source as this simplifies the merge logic.
if ( ! _isArray . isArray ( source ) ) {
source = [ source ] ;
}
source = this . source . wrap ( source , location ) ;
if ( this . environment . isSimple ) {
return [ 'return ' , source , ';' ] ;
} else if ( explicit ) {
// This is a case where the buffer operation occurs as a child of another
// construct, generally braces. We have to explicitly output these buffer
// operations to ensure that the emitted code goes in the correct location.
return [ 'buffer += ' , source , ';' ] ;
} else {
source . appendToBuffer = true ;
return source ;
}
} ,
initializeBuffer : function initializeBuffer ( ) {
return this . quotedString ( '' ) ;
} ,
// END PUBLIC API
compile : function compile ( environment , options , context , asObject ) {
this . environment = environment ;
this . options = options ;
this . stringParams = this . options . stringParams ;
this . trackIds = this . options . trackIds ;
this . precompile = ! asObject ;
this . name = this . environment . name ;
this . isChild = ! ! context ;
this . context = context || {
programs : [ ] ,
environments : [ ]
} ;
this . preamble ( ) ;
this . stackSlot = 0 ;
this . stackVars = [ ] ;
this . aliases = { } ;
this . registers = { list : [ ] } ;
this . hashes = [ ] ;
this . compileStack = [ ] ;
this . inlineStack = [ ] ;
this . blockParams = [ ] ;
this . compileChildren ( environment , options ) ;
this . useDepths = this . useDepths || environment . useDepths || this . options . compat ;
this . useBlockParams = this . useBlockParams || environment . useBlockParams ;
var opcodes = environment . opcodes ,
opcode = undefined ,
firstLoc = undefined ,
i = undefined ,
l = undefined ;
for ( i = 0 , l = opcodes . length ; i < l ; i ++ ) {
opcode = opcodes [ i ] ;
this . source . currentLocation = opcode . loc ;
firstLoc = firstLoc || opcode . loc ;
this [ opcode . opcode ] . apply ( this , opcode . args ) ;
}
// Flush any trailing content that might be pending.
this . source . currentLocation = firstLoc ;
this . pushSource ( '' ) ;
/* istanbul ignore next */
if ( this . stackSlot || this . inlineStack . length || this . compileStack . length ) {
throw new _Exception2 [ 'default' ] ( 'Compile completed with content left on stack' ) ;
}
var fn = this . createFunctionContext ( asObject ) ;
if ( ! this . isChild ) {
var ret = {
compiler : this . compilerInfo ( ) ,
main : fn
} ;
var programs = this . context . programs ;
for ( i = 0 , l = programs . length ; i < l ; i ++ ) {
if ( programs [ i ] ) {
ret [ i ] = programs [ i ] ;
}
}
if ( this . environment . usePartial ) {
ret . usePartial = true ;
}
if ( this . options . data ) {
ret . useData = true ;
}
if ( this . useDepths ) {
ret . useDepths = true ;
}
if ( this . useBlockParams ) {
ret . useBlockParams = true ;
}
if ( this . options . compat ) {
ret . compat = true ;
}
if ( ! asObject ) {
ret . compiler = JSON . stringify ( ret . compiler ) ;
this . source . currentLocation = { start : { line : 1 , column : 0 } } ;
ret = this . objectLiteral ( ret ) ;
if ( options . srcName ) {
ret = ret . toStringWithSourceMap ( { file : options . destName } ) ;
ret . map = ret . map && ret . map . toString ( ) ;
} else {
ret = ret . toString ( ) ;
}
} else {
ret . compilerOptions = this . options ;
}
return ret ;
} else {
return fn ;
}
} ,
preamble : function preamble ( ) {
// track the last context pushed into place to allow skipping the
// getContext opcode when it would be a noop
this . lastContext = 0 ;
this . source = new _CodeGen2 [ 'default' ] ( this . options . srcName ) ;
} ,
createFunctionContext : function createFunctionContext ( asObject ) {
var varDeclarations = '' ;
var locals = this . stackVars . concat ( this . registers . list ) ;
if ( locals . length > 0 ) {
varDeclarations += ', ' + locals . join ( ', ' ) ;
}
// Generate minimizer alias mappings
//
// When using true SourceNodes, this will update all references to the given alias
// as the source nodes are reused in situ. For the non-source node compilation mode,
// aliases will not be used, but this case is already being run on the client and
// we aren't concern about minimizing the template size.
var aliasCount = 0 ;
for ( var alias in this . aliases ) {
// eslint-disable-line guard-for-in
var node = this . aliases [ alias ] ;
if ( this . aliases . hasOwnProperty ( alias ) && node . children && node . referenceCount > 1 ) {
varDeclarations += ', alias' + ++ aliasCount + '=' + alias ;
node . children [ 0 ] = 'alias' + aliasCount ;
}
}
var params = [ 'depth0' , 'helpers' , 'partials' , 'data' ] ;
if ( this . useBlockParams || this . useDepths ) {
params . push ( 'blockParams' ) ;
}
if ( this . useDepths ) {
params . push ( 'depths' ) ;
}
// Perform a second pass over the output to merge content when possible
var source = this . mergeSource ( varDeclarations ) ;
if ( asObject ) {
params . push ( source ) ;
return Function . apply ( this , params ) ;
} else {
return this . source . wrap ( [ 'function(' , params . join ( ',' ) , ') {\n ' , source , '}' ] ) ;
}
} ,
mergeSource : function mergeSource ( varDeclarations ) {
var isSimple = this . environment . isSimple ,
appendOnly = ! this . forceBuffer ,
appendFirst = undefined ,
sourceSeen = undefined ,
bufferStart = undefined ,
bufferEnd = undefined ;
this . source . each ( function ( line ) {
if ( line . appendToBuffer ) {
if ( bufferStart ) {
line . prepend ( ' + ' ) ;
} else {
bufferStart = line ;
}
bufferEnd = line ;
} else {
if ( bufferStart ) {
if ( ! sourceSeen ) {
appendFirst = true ;
} else {
bufferStart . prepend ( 'buffer += ' ) ;
}
bufferEnd . add ( ';' ) ;
bufferStart = bufferEnd = undefined ;
}
sourceSeen = true ;
if ( ! isSimple ) {
appendOnly = false ;
}
}
} ) ;
if ( appendOnly ) {
if ( bufferStart ) {
bufferStart . prepend ( 'return ' ) ;
bufferEnd . add ( ';' ) ;
} else if ( ! sourceSeen ) {
this . source . push ( 'return "";' ) ;
}
} else {
varDeclarations += ', buffer = ' + ( appendFirst ? '' : this . initializeBuffer ( ) ) ;
if ( bufferStart ) {
bufferStart . prepend ( 'return buffer + ' ) ;
bufferEnd . add ( ';' ) ;
} else {
this . source . push ( 'return buffer;' ) ;
}
}
if ( varDeclarations ) {
this . source . prepend ( 'var ' + varDeclarations . substring ( 2 ) + ( appendFirst ? '' : ';\n' ) ) ;
}
return this . source . merge ( ) ;
} ,
// [blockValue]
//
// On stack, before: hash, inverse, program, value
// On stack, after: return value of blockHelperMissing
//
// The purpose of this opcode is to take a block of the form
// `{{#this.foo}}...{{/this.foo}}`, resolve the value of `foo`, and
// replace it on the stack with the result of properly
// invoking blockHelperMissing.
blockValue : function blockValue ( name ) {
var blockHelperMissing = this . aliasable ( 'helpers.blockHelperMissing' ) ,
params = [ this . contextName ( 0 ) ] ;
this . setupHelperArgs ( name , 0 , params ) ;
var blockName = this . popStack ( ) ;
params . splice ( 1 , 0 , blockName ) ;
this . push ( this . source . functionCall ( blockHelperMissing , 'call' , params ) ) ;
} ,
// [ambiguousBlockValue]
//
// On stack, before: hash, inverse, program, value
// Compiler value, before: lastHelper=value of last found helper, if any
// On stack, after, if no lastHelper: same as [blockValue]
// On stack, after, if lastHelper: value
ambiguousBlockValue : function ambiguousBlockValue ( ) {
// We're being a bit cheeky and reusing the options value from the prior exec
var blockHelperMissing = this . aliasable ( 'helpers.blockHelperMissing' ) ,
params = [ this . contextName ( 0 ) ] ;
this . setupHelperArgs ( '' , 0 , params , true ) ;
this . flushInline ( ) ;
var current = this . topStack ( ) ;
params . splice ( 1 , 0 , current ) ;
this . pushSource ( [ 'if (!' , this . lastHelper , ') { ' , current , ' = ' , this . source . functionCall ( blockHelperMissing , 'call' , params ) , '}' ] ) ;
} ,
// [appendContent]
//
// On stack, before: ...
// On stack, after: ...
//
// Appends the string value of `content` to the current buffer
appendContent : function appendContent ( content ) {
if ( this . pendingContent ) {
content = this . pendingContent + content ;
} else {
this . pendingLocation = this . source . currentLocation ;
}
this . pendingContent = content ;
} ,
// [append]
//
// On stack, before: value, ...
// On stack, after: ...
//
// Coerces `value` to a String and appends it to the current buffer.
//
// If `value` is truthy, or 0, it is coerced into a string and appended
// Otherwise, the empty string is appended
append : function append ( ) {
if ( this . isInline ( ) ) {
this . replaceStack ( function ( current ) {
return [ ' != null ? ' , current , ' : ""' ] ;
} ) ;
this . pushSource ( this . appendToBuffer ( this . popStack ( ) ) ) ;
} else {
var local = this . popStack ( ) ;
this . pushSource ( [ 'if (' , local , ' != null) { ' , this . appendToBuffer ( local , undefined , true ) , ' }' ] ) ;
if ( this . environment . isSimple ) {
this . pushSource ( [ 'else { ' , this . appendToBuffer ( '\'\'' , undefined , true ) , ' }' ] ) ;
}
}
} ,
// [appendEscaped]
//
// On stack, before: value, ...
// On stack, after: ...
//
// Escape `value` and append it to the buffer
appendEscaped : function appendEscaped ( ) {
this . pushSource ( this . appendToBuffer ( [ this . aliasable ( 'this.escapeExpression' ) , '(' , this . popStack ( ) , ')' ] ) ) ;
} ,
// [getContext]
//
// On stack, before: ...
// On stack, after: ...
// Compiler value, after: lastContext=depth
//
// Set the value of the `lastContext` compiler value to the depth
getContext : function getContext ( depth ) {
this . lastContext = depth ;
} ,
// [pushContext]
//
// On stack, before: ...
// On stack, after: currentContext, ...
//
// Pushes the value of the current context onto the stack.
pushContext : function pushContext ( ) {
this . pushStackLiteral ( this . contextName ( this . lastContext ) ) ;
} ,
// [lookupOnContext]
//
// On stack, before: ...
// On stack, after: currentContext[name], ...
//
// Looks up the value of `name` on the current context and pushes
// it onto the stack.
lookupOnContext : function lookupOnContext ( parts , falsy , scoped ) {
var i = 0 ;
if ( ! scoped && this . options . compat && ! this . lastContext ) {
// The depthed query is expected to handle the undefined logic for the root level that
// is implemented below, so we evaluate that directly in compat mode
this . push ( this . depthedLookup ( parts [ i ++ ] ) ) ;
} else {
this . pushContext ( ) ;
}
this . resolvePath ( 'context' , parts , i , falsy ) ;
} ,
// [lookupBlockParam]
//
// On stack, before: ...
// On stack, after: blockParam[name], ...
//
// Looks up the value of `parts` on the given block param and pushes
// it onto the stack.
lookupBlockParam : function lookupBlockParam ( blockParamId , parts ) {
this . useBlockParams = true ;
this . push ( [ 'blockParams[' , blockParamId [ 0 ] , '][' , blockParamId [ 1 ] , ']' ] ) ;
this . resolvePath ( 'context' , parts , 1 ) ;
} ,
// [lookupData]
//
// On stack, before: ...
// On stack, after: data, ...
//
// Push the data lookup operator
lookupData : function lookupData ( depth , parts ) {
/*jshint -W083 */
if ( ! depth ) {
this . pushStackLiteral ( 'data' ) ;
} else {
this . pushStackLiteral ( 'this.data(data, ' + depth + ')' ) ;
}
this . resolvePath ( 'data' , parts , 0 , true ) ;
} ,
resolvePath : function resolvePath ( type , parts , i , falsy ) {
var _this = this ;
/*jshint -W083 */
if ( this . options . strict || this . options . assumeObjects ) {
this . push ( strictLookup ( this . options . strict , this , parts , type ) ) ;
return ;
}
var len = parts . length ;
for ( ; i < len ; i ++ ) {
/*eslint-disable no-loop-func */
this . replaceStack ( function ( current ) {
var lookup = _this . nameLookup ( current , parts [ i ] , type ) ;
// We want to ensure that zero and false are handled properly if the context (falsy flag)
// needs to have the special handling for these values.
if ( ! falsy ) {
return [ ' != null ? ' , lookup , ' : ' , current ] ;
} else {
// Otherwise we can use generic falsy handling
return [ ' && ' , lookup ] ;
}
} ) ;
/*eslint-enable no-loop-func */
}
} ,
// [resolvePossibleLambda]
//
// On stack, before: value, ...
// On stack, after: resolved value, ...
//
// If the `value` is a lambda, replace it on the stack by
// the return value of the lambda
resolvePossibleLambda : function resolvePossibleLambda ( ) {
this . push ( [ this . aliasable ( 'this.lambda' ) , '(' , this . popStack ( ) , ', ' , this . contextName ( 0 ) , ')' ] ) ;
} ,
// [pushStringParam]
//
// On stack, before: ...
// On stack, after: string, currentContext, ...
//
// This opcode is designed for use in string mode, which
// provides the string value of a parameter along with its
// depth rather than resolving it immediately.
pushStringParam : function pushStringParam ( string , type ) {
this . pushContext ( ) ;
this . pushString ( type ) ;
// If it's a subexpression, the string result
// will be pushed after this opcode.
if ( type !== 'SubExpression' ) {
if ( typeof string === 'string' ) {
this . pushString ( string ) ;
} else {
this . pushStackLiteral ( string ) ;
}
}
} ,
emptyHash : function emptyHash ( omitEmpty ) {
if ( this . trackIds ) {
this . push ( '{}' ) ; // hashIds
}
if ( this . stringParams ) {
this . push ( '{}' ) ; // hashContexts
this . push ( '{}' ) ; // hashTypes
}
this . pushStackLiteral ( omitEmpty ? 'undefined' : '{}' ) ;
} ,
pushHash : function pushHash ( ) {
if ( this . hash ) {
this . hashes . push ( this . hash ) ;
}
this . hash = { values : [ ] , types : [ ] , contexts : [ ] , ids : [ ] } ;
} ,
popHash : function popHash ( ) {
var hash = this . hash ;
this . hash = this . hashes . pop ( ) ;
if ( this . trackIds ) {
this . push ( this . objectLiteral ( hash . ids ) ) ;
}
if ( this . stringParams ) {
this . push ( this . objectLiteral ( hash . contexts ) ) ;
this . push ( this . objectLiteral ( hash . types ) ) ;
}
this . push ( this . objectLiteral ( hash . values ) ) ;
} ,
// [pushString]
//
// On stack, before: ...
// On stack, after: quotedString(string), ...
//
// Push a quoted version of `string` onto the stack
pushString : function pushString ( string ) {
this . pushStackLiteral ( this . quotedString ( string ) ) ;
} ,
// [pushLiteral]
//
// On stack, before: ...
// On stack, after: value, ...
//
// Pushes a value onto the stack. This operation prevents
// the compiler from creating a temporary variable to hold
// it.
pushLiteral : function pushLiteral ( value ) {
this . pushStackLiteral ( value ) ;
} ,
// [pushProgram]
//
// On stack, before: ...
// On stack, after: program(guid), ...
//
// Push a program expression onto the stack. This takes
// a compile-time guid and converts it into a runtime-accessible
// expression.
pushProgram : function pushProgram ( guid ) {
if ( guid != null ) {
this . pushStackLiteral ( this . programExpression ( guid ) ) ;
} else {
this . pushStackLiteral ( null ) ;
}
} ,
// [invokeHelper]
//
// On stack, before: hash, inverse, program, params..., ...
// On stack, after: result of helper invocation
//
// Pops off the helper's parameters, invokes the helper,
// and pushes the helper's return value onto the stack.
//
// If the helper is not found, `helperMissing` is called.
invokeHelper : function invokeHelper ( paramSize , name , isSimple ) {
var nonHelper = this . popStack ( ) ,
helper = this . setupHelper ( paramSize , name ) ,
simple = isSimple ? [ helper . name , ' || ' ] : '' ;
var lookup = [ '(' ] . concat ( simple , nonHelper ) ;
if ( ! this . options . strict ) {
lookup . push ( ' || ' , this . aliasable ( 'helpers.helperMissing' ) ) ;
}
lookup . push ( ')' ) ;
this . push ( this . source . functionCall ( lookup , 'call' , helper . callParams ) ) ;
} ,
// [invokeKnownHelper]
//
// On stack, before: hash, inverse, program, params..., ...
// On stack, after: result of helper invocation
//
// This operation is used when the helper is known to exist,
// so a `helperMissing` fallback is not required.
invokeKnownHelper : function invokeKnownHelper ( paramSize , name ) {
var helper = this . setupHelper ( paramSize , name ) ;
this . push ( this . source . functionCall ( helper . name , 'call' , helper . callParams ) ) ;
} ,
// [invokeAmbiguous]
//
// On stack, before: hash, inverse, program, params..., ...
// On stack, after: result of disambiguation
//
// This operation is used when an expression like `{{foo}}`
// is provided, but we don't know at compile-time whether it
// is a helper or a path.
//
// This operation emits more code than the other options,
// and can be avoided by passing the `knownHelpers` and
// `knownHelpersOnly` flags at compile-time.
invokeAmbiguous : function invokeAmbiguous ( name , helperCall ) {
this . useRegister ( 'helper' ) ;
var nonHelper = this . popStack ( ) ;
this . emptyHash ( ) ;
var helper = this . setupHelper ( 0 , name , helperCall ) ;
var helperName = this . lastHelper = this . nameLookup ( 'helpers' , name , 'helper' ) ;
var lookup = [ '(' , '(helper = ' , helperName , ' || ' , nonHelper , ')' ] ;
if ( ! this . options . strict ) {
lookup [ 0 ] = '(helper = ' ;
lookup . push ( ' != null ? helper : ' , this . aliasable ( 'helpers.helperMissing' ) ) ;
}
this . push ( [ '(' , lookup , helper . paramsInit ? [ '),(' , helper . paramsInit ] : [ ] , '),' , '(typeof helper === ' , this . aliasable ( '"function"' ) , ' ? ' , this . source . functionCall ( 'helper' , 'call' , helper . callParams ) , ' : helper))' ] ) ;
} ,
// [invokePartial]
//
// On stack, before: context, ...
// On stack after: result of partial invocation
//
// This operation pops off a context, invokes a partial with that context,
// and pushes the result of the invocation back.
invokePartial : function invokePartial ( isDynamic , name , indent ) {
var params = [ ] ,
options = this . setupParams ( name , 1 , params , false ) ;
if ( isDynamic ) {
name = this . popStack ( ) ;
delete options . name ;
}
if ( indent ) {
options . indent = JSON . stringify ( indent ) ;
}
options . helpers = 'helpers' ;
options . partials = 'partials' ;
if ( ! isDynamic ) {
params . unshift ( this . nameLookup ( 'partials' , name , 'partial' ) ) ;
} else {
params . unshift ( name ) ;
}
if ( this . options . compat ) {
options . depths = 'depths' ;
}
options = this . objectLiteral ( options ) ;
params . push ( options ) ;
this . push ( this . source . functionCall ( 'this.invokePartial' , '' , params ) ) ;
} ,
// [assignToHash]
//
// On stack, before: value, ..., hash, ...
// On stack, after: ..., hash, ...
//
// Pops a value off the stack and assigns it to the current hash
assignToHash : function assignToHash ( key ) {
var value = this . popStack ( ) ,
context = undefined ,
type = undefined ,
id = undefined ;
if ( this . trackIds ) {
id = this . popStack ( ) ;
}
if ( this . stringParams ) {
type = this . popStack ( ) ;
context = this . popStack ( ) ;
}
var hash = this . hash ;
if ( context ) {
hash . contexts [ key ] = context ;
}
if ( type ) {
hash . types [ key ] = type ;
}
if ( id ) {
hash . ids [ key ] = id ;
}
hash . values [ key ] = value ;
} ,
pushId : function pushId ( type , name , child ) {
if ( type === 'BlockParam' ) {
this . pushStackLiteral ( 'blockParams[' + name [ 0 ] + '].path[' + name [ 1 ] + ']' + ( child ? ' + ' + JSON . stringify ( '.' + child ) : '' ) ) ;
} else if ( type === 'PathExpression' ) {
this . pushString ( name ) ;
} else if ( type === 'SubExpression' ) {
this . pushStackLiteral ( 'true' ) ;
} else {
this . pushStackLiteral ( 'null' ) ;
}
} ,
// HELPERS
compiler : JavaScriptCompiler ,
compileChildren : function compileChildren ( environment , options ) {
var children = environment . children ,
child = undefined ,
compiler = undefined ;
for ( var i = 0 , l = children . length ; i < l ; i ++ ) {
child = children [ i ] ;
compiler = new this . compiler ( ) ; // eslint-disable-line new-cap
var index = this . matchExistingProgram ( child ) ;
if ( index == null ) {
this . context . programs . push ( '' ) ; // Placeholder to prevent name conflicts for nested children
index = this . context . programs . length ;
child . index = index ;
child . name = 'program' + index ;
this . context . programs [ index ] = compiler . compile ( child , options , this . context , ! this . precompile ) ;
this . context . environments [ index ] = child ;
this . useDepths = this . useDepths || compiler . useDepths ;
this . useBlockParams = this . useBlockParams || compiler . useBlockParams ;
} else {
child . index = index ;
child . name = 'program' + index ;
this . useDepths = this . useDepths || child . useDepths ;
this . useBlockParams = this . useBlockParams || child . useBlockParams ;
}
}
} ,
matchExistingProgram : function matchExistingProgram ( child ) {
for ( var i = 0 , len = this . context . environments . length ; i < len ; i ++ ) {
var environment = this . context . environments [ i ] ;
if ( environment && environment . equals ( child ) ) {
return i ;
}
}
} ,
programExpression : function programExpression ( guid ) {
var child = this . environment . children [ guid ] ,
programParams = [ child . index , 'data' , child . blockParams ] ;
if ( this . useBlockParams || this . useDepths ) {
programParams . push ( 'blockParams' ) ;
}
if ( this . useDepths ) {
programParams . push ( 'depths' ) ;
}
return 'this.program(' + programParams . join ( ', ' ) + ')' ;
} ,
useRegister : function useRegister ( name ) {
if ( ! this . registers [ name ] ) {
this . registers [ name ] = true ;
this . registers . list . push ( name ) ;
}
} ,
push : function push ( expr ) {
if ( ! ( expr instanceof Literal ) ) {
expr = this . source . wrap ( expr ) ;
}
this . inlineStack . push ( expr ) ;
return expr ;
} ,
pushStackLiteral : function pushStackLiteral ( item ) {
this . push ( new Literal ( item ) ) ;
} ,
pushSource : function pushSource ( source ) {
if ( this . pendingContent ) {
this . source . push ( this . appendToBuffer ( this . source . quotedString ( this . pendingContent ) , this . pendingLocation ) ) ;
this . pendingContent = undefined ;
}
if ( source ) {
this . source . push ( source ) ;
}
} ,
replaceStack : function replaceStack ( callback ) {
var prefix = [ '(' ] ,
stack = undefined ,
createdStack = undefined ,
usedLiteral = undefined ;
/* istanbul ignore next */
if ( ! this . isInline ( ) ) {
throw new _Exception2 [ 'default' ] ( 'replaceStack on non-inline' ) ;
}
// We want to merge the inline statement into the replacement statement via ','
var top = this . popStack ( true ) ;
if ( top instanceof Literal ) {
// Literals do not need to be inlined
stack = [ top . value ] ;
prefix = [ '(' , stack ] ;
usedLiteral = true ;
} else {
// Get or create the current stack name for use by the inline
createdStack = true ;
var _name = this . incrStack ( ) ;
prefix = [ '((' , this . push ( _name ) , ' = ' , top , ')' ] ;
stack = this . topStack ( ) ;
}
var item = callback . call ( this , stack ) ;
if ( ! usedLiteral ) {
this . popStack ( ) ;
}
if ( createdStack ) {
this . stackSlot -- ;
}
this . push ( prefix . concat ( item , ')' ) ) ;
} ,
incrStack : function incrStack ( ) {
this . stackSlot ++ ;
if ( this . stackSlot > this . stackVars . length ) {
this . stackVars . push ( 'stack' + this . stackSlot ) ;
}
return this . topStackName ( ) ;
} ,
topStackName : function topStackName ( ) {
return 'stack' + this . stackSlot ;
} ,
flushInline : function flushInline ( ) {
var inlineStack = this . inlineStack ;
this . inlineStack = [ ] ;
for ( var i = 0 , len = inlineStack . length ; i < len ; i ++ ) {
var entry = inlineStack [ i ] ;
/* istanbul ignore if */
if ( entry instanceof Literal ) {
this . compileStack . push ( entry ) ;
} else {
var stack = this . incrStack ( ) ;
this . pushSource ( [ stack , ' = ' , entry , ';' ] ) ;
this . compileStack . push ( stack ) ;
}
}
} ,
isInline : function isInline ( ) {
return this . inlineStack . length ;
} ,
popStack : function popStack ( wrapped ) {
var inline = this . isInline ( ) ,
item = ( inline ? this . inlineStack : this . compileStack ) . pop ( ) ;
if ( ! wrapped && item instanceof Literal ) {
return item . value ;
} else {
if ( ! inline ) {
/* istanbul ignore next */
if ( ! this . stackSlot ) {
throw new _Exception2 [ 'default' ] ( 'Invalid stack pop' ) ;
}
this . stackSlot -- ;
}
return item ;
}
} ,
topStack : function topStack ( ) {
var stack = this . isInline ( ) ? this . inlineStack : this . compileStack ,
item = stack [ stack . length - 1 ] ;
/* istanbul ignore if */
if ( item instanceof Literal ) {
return item . value ;
} else {
return item ;
}
} ,
contextName : function contextName ( context ) {
if ( this . useDepths && context ) {
return 'depths[' + context + ']' ;
} else {
return 'depth' + context ;
}
} ,
quotedString : function quotedString ( str ) {
return this . source . quotedString ( str ) ;
} ,
objectLiteral : function objectLiteral ( obj ) {
return this . source . objectLiteral ( obj ) ;
} ,
aliasable : function aliasable ( name ) {
var ret = this . aliases [ name ] ;
if ( ret ) {
ret . referenceCount ++ ;
return ret ;
}
ret = this . aliases [ name ] = this . source . wrap ( name ) ;
ret . aliasable = true ;
ret . referenceCount = 1 ;
return ret ;
} ,
setupHelper : function setupHelper ( paramSize , name , blockHelper ) {
var params = [ ] ,
paramsInit = this . setupHelperArgs ( name , paramSize , params , blockHelper ) ;
var foundHelper = this . nameLookup ( 'helpers' , name , 'helper' ) ;
return {
params : params ,
paramsInit : paramsInit ,
name : foundHelper ,
callParams : [ this . contextName ( 0 ) ] . concat ( params )
} ;
} ,
setupParams : function setupParams ( helper , paramSize , params ) {
var options = { } ,
contexts = [ ] ,
types = [ ] ,
ids = [ ] ,
param = undefined ;
options . name = this . quotedString ( helper ) ;
options . hash = this . popStack ( ) ;
if ( this . trackIds ) {
options . hashIds = this . popStack ( ) ;
}
if ( this . stringParams ) {
options . hashTypes = this . popStack ( ) ;
options . hashContexts = this . popStack ( ) ;
}
var inverse = this . popStack ( ) ,
program = this . popStack ( ) ;
// Avoid setting fn and inverse if neither are set. This allows
// helpers to do a check for `if (options.fn)`
if ( program || inverse ) {
options . fn = program || 'this.noop' ;
options . inverse = inverse || 'this.noop' ;
}
// The parameters go on to the stack in order (making sure that they are evaluated in order)
// so we need to pop them off the stack in reverse order
var i = paramSize ;
while ( i -- ) {
param = this . popStack ( ) ;
params [ i ] = param ;
if ( this . trackIds ) {
ids [ i ] = this . popStack ( ) ;
}
if ( this . stringParams ) {
types [ i ] = this . popStack ( ) ;
contexts [ i ] = this . popStack ( ) ;
}
}
if ( this . trackIds ) {
options . ids = this . source . generateArray ( ids ) ;
}
if ( this . stringParams ) {
options . types = this . source . generateArray ( types ) ;
options . contexts = this . source . generateArray ( contexts ) ;
}
if ( this . options . data ) {
options . data = 'data' ;
}
if ( this . useBlockParams ) {
options . blockParams = 'blockParams' ;
}
return options ;
} ,
setupHelperArgs : function setupHelperArgs ( helper , paramSize , params , useRegister ) {
var options = this . setupParams ( helper , paramSize , params , true ) ;
options = this . objectLiteral ( options ) ;
if ( useRegister ) {
this . useRegister ( 'options' ) ;
params . push ( 'options' ) ;
return [ 'options=' , options ] ;
} else {
params . push ( options ) ;
return '' ;
}
}
} ;
( function ( ) {
var reservedWords = ( 'break else new var' + ' case finally return void' + ' catch for switch while' + ' continue function this with' + ' default if throw' + ' delete in try' + ' do instanceof typeof' + ' abstract enum int short' + ' boolean export interface static' + ' byte extends long super' + ' char final native synchronized' + ' class float package throws' + ' const goto private transient' + ' debugger implements protected volatile' + ' double import public let yield await' + ' null true false' ) . split ( ' ' ) ;
var compilerWords = JavaScriptCompiler . RESERVED _WORDS = { } ;
for ( var i = 0 , l = reservedWords . length ; i < l ; i ++ ) {
compilerWords [ reservedWords [ i ] ] = true ;
}
} ) ( ) ;
JavaScriptCompiler . isValidJavaScriptVariableName = function ( name ) {
return ! JavaScriptCompiler . RESERVED _WORDS [ name ] && /^[a-zA-Z_$][0-9a-zA-Z_$]*$/ . test ( name ) ;
} ;
function strictLookup ( requireTerminal , compiler , parts , type ) {
var stack = compiler . popStack ( ) ,
i = 0 ,
len = parts . length ;
if ( requireTerminal ) {
len -- ;
}
for ( ; i < len ; i ++ ) {
stack = compiler . nameLookup ( stack , parts [ i ] , type ) ;
}
if ( requireTerminal ) {
return [ compiler . aliasable ( 'this.strict' ) , '(' , stack , ', ' , compiler . quotedString ( parts [ i ] ) , ')' ] ;
} else {
return stack ;
}
}
exports [ 'default' ] = JavaScriptCompiler ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 6 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireWildcard = _ _webpack _require _ _ ( 7 ) [ 'default' ] ;
exports . _ _esModule = true ;
var _Exception = _ _webpack _require _ _ ( 10 ) ;
var _Exception2 = _interopRequireWildcard ( _Exception ) ;
var _AST = _ _webpack _require _ _ ( 2 ) ;
var _AST2 = _interopRequireWildcard ( _AST ) ;
function Visitor ( ) {
this . parents = [ ] ;
}
Visitor . prototype = {
constructor : Visitor ,
mutating : false ,
// Visits a given value. If mutating, will replace the value if necessary.
acceptKey : function acceptKey ( node , name ) {
var value = this . accept ( node [ name ] ) ;
if ( this . mutating ) {
// Hacky sanity check:
if ( value && ( ! value . type || ! _AST2 [ 'default' ] [ value . type ] ) ) {
throw new _Exception2 [ 'default' ] ( 'Unexpected node type "' + value . type + '" found when accepting ' + name + ' on ' + node . type ) ;
}
node [ name ] = value ;
}
} ,
// Performs an accept operation with added sanity check to ensure
// required keys are not removed.
acceptRequired : function acceptRequired ( node , name ) {
this . acceptKey ( node , name ) ;
if ( ! node [ name ] ) {
throw new _Exception2 [ 'default' ] ( node . type + ' requires ' + name ) ;
}
} ,
// Traverses a given array. If mutating, empty respnses will be removed
// for child elements.
acceptArray : function acceptArray ( array ) {
for ( var i = 0 , l = array . length ; i < l ; i ++ ) {
this . acceptKey ( array , i ) ;
if ( ! array [ i ] ) {
array . splice ( i , 1 ) ;
i -- ;
l -- ;
}
}
} ,
accept : function accept ( object ) {
if ( ! object ) {
return ;
}
if ( this . current ) {
this . parents . unshift ( this . current ) ;
}
this . current = object ;
var ret = this [ object . type ] ( object ) ;
this . current = this . parents . shift ( ) ;
if ( ! this . mutating || ret ) {
return ret ;
} else if ( ret !== false ) {
return object ;
}
} ,
Program : function Program ( program ) {
this . acceptArray ( program . body ) ;
} ,
MustacheStatement : function MustacheStatement ( mustache ) {
this . acceptRequired ( mustache , 'path' ) ;
this . acceptArray ( mustache . params ) ;
this . acceptKey ( mustache , 'hash' ) ;
} ,
BlockStatement : function BlockStatement ( block ) {
this . acceptRequired ( block , 'path' ) ;
this . acceptArray ( block . params ) ;
this . acceptKey ( block , 'hash' ) ;
this . acceptKey ( block , 'program' ) ;
this . acceptKey ( block , 'inverse' ) ;
} ,
PartialStatement : function PartialStatement ( partial ) {
this . acceptRequired ( partial , 'name' ) ;
this . acceptArray ( partial . params ) ;
this . acceptKey ( partial , 'hash' ) ;
} ,
ContentStatement : function ContentStatement ( ) { } ,
CommentStatement : function CommentStatement ( ) { } ,
SubExpression : function SubExpression ( sexpr ) {
this . acceptRequired ( sexpr , 'path' ) ;
this . acceptArray ( sexpr . params ) ;
this . acceptKey ( sexpr , 'hash' ) ;
} ,
PathExpression : function PathExpression ( ) { } ,
StringLiteral : function StringLiteral ( ) { } ,
NumberLiteral : function NumberLiteral ( ) { } ,
BooleanLiteral : function BooleanLiteral ( ) { } ,
UndefinedLiteral : function UndefinedLiteral ( ) { } ,
NullLiteral : function NullLiteral ( ) { } ,
Hash : function Hash ( hash ) {
this . acceptArray ( hash . pairs ) ;
} ,
HashPair : function HashPair ( pair ) {
this . acceptRequired ( pair , 'value' ) ;
}
} ;
exports [ 'default' ] = Visitor ;
module . exports = exports [ 'default' ] ;
/* content */ /* comment */ /* path */ /* string */ /* number */ /* bool */ /* literal */ /* literal */
/***/ } ,
/* 7 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
"use strict" ;
exports [ "default" ] = function ( obj ) {
return obj && obj . _ _esModule ? obj : {
"default" : obj
} ;
} ;
exports . _ _esModule = true ;
/***/ } ,
/* 8 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireWildcard = _ _webpack _require _ _ ( 7 ) [ 'default' ] ;
exports . _ _esModule = true ;
exports . HandlebarsEnvironment = HandlebarsEnvironment ;
exports . createFrame = createFrame ;
var _import = _ _webpack _require _ _ ( 11 ) ;
var Utils = _interopRequireWildcard ( _import ) ;
var _Exception = _ _webpack _require _ _ ( 10 ) ;
var _Exception2 = _interopRequireWildcard ( _Exception ) ;
var VERSION = '3.0.1' ;
exports . VERSION = VERSION ;
var COMPILER _REVISION = 6 ;
exports . COMPILER _REVISION = COMPILER _REVISION ;
var REVISION _CHANGES = {
1 : '<= 1.0.rc.2' , // 1.0.rc.2 is actually rev2 but doesn't report it
2 : '== 1.0.0-rc.3' ,
3 : '== 1.0.0-rc.4' ,
4 : '== 1.x.x' ,
5 : '== 2.0.0-alpha.x' ,
6 : '>= 2.0.0-beta.1'
} ;
exports . REVISION _CHANGES = REVISION _CHANGES ;
var isArray = Utils . isArray ,
isFunction = Utils . isFunction ,
toString = Utils . toString ,
objectType = '[object Object]' ;
function HandlebarsEnvironment ( helpers , partials ) {
this . helpers = helpers || { } ;
this . partials = partials || { } ;
registerDefaultHelpers ( this ) ;
}
HandlebarsEnvironment . prototype = {
constructor : HandlebarsEnvironment ,
logger : logger ,
log : log ,
registerHelper : function registerHelper ( name , fn ) {
if ( toString . call ( name ) === objectType ) {
if ( fn ) {
throw new _Exception2 [ 'default' ] ( 'Arg not supported with multiple helpers' ) ;
}
Utils . extend ( this . helpers , name ) ;
} else {
this . helpers [ name ] = fn ;
}
} ,
unregisterHelper : function unregisterHelper ( name ) {
delete this . helpers [ name ] ;
} ,
registerPartial : function registerPartial ( name , partial ) {
if ( toString . call ( name ) === objectType ) {
Utils . extend ( this . partials , name ) ;
} else {
if ( typeof partial === 'undefined' ) {
throw new _Exception2 [ 'default' ] ( 'Attempting to register a partial as undefined' ) ;
}
this . partials [ name ] = partial ;
}
} ,
unregisterPartial : function unregisterPartial ( name ) {
delete this . partials [ name ] ;
}
} ;
function registerDefaultHelpers ( instance ) {
instance . registerHelper ( 'helperMissing' , function ( ) {
if ( arguments . length === 1 ) {
// A missing field in a {{foo}} constuct.
return undefined ;
} else {
// Someone is actually trying to call something, blow up.
throw new _Exception2 [ 'default' ] ( 'Missing helper: "' + arguments [ arguments . length - 1 ] . name + '"' ) ;
}
} ) ;
instance . registerHelper ( 'blockHelperMissing' , function ( context , options ) {
var inverse = options . inverse ,
fn = options . fn ;
if ( context === true ) {
return fn ( this ) ;
} else if ( context === false || context == null ) {
return inverse ( this ) ;
} else if ( isArray ( context ) ) {
if ( context . length > 0 ) {
if ( options . ids ) {
options . ids = [ options . name ] ;
}
return instance . helpers . each ( context , options ) ;
} else {
return inverse ( this ) ;
}
} else {
if ( options . data && options . ids ) {
var data = createFrame ( options . data ) ;
data . contextPath = Utils . appendContextPath ( options . data . contextPath , options . name ) ;
options = { data : data } ;
}
return fn ( context , options ) ;
}
} ) ;
instance . registerHelper ( 'each' , function ( context , options ) {
if ( ! options ) {
throw new _Exception2 [ 'default' ] ( 'Must pass iterator to #each' ) ;
}
var fn = options . fn ,
inverse = options . inverse ,
i = 0 ,
ret = '' ,
data = undefined ,
contextPath = undefined ;
if ( options . data && options . ids ) {
contextPath = Utils . appendContextPath ( options . data . contextPath , options . ids [ 0 ] ) + '.' ;
}
if ( isFunction ( context ) ) {
context = context . call ( this ) ;
}
if ( options . data ) {
data = createFrame ( options . data ) ;
}
function execIteration ( field , index , last ) {
if ( data ) {
data . key = field ;
data . index = index ;
data . first = index === 0 ;
data . last = ! ! last ;
if ( contextPath ) {
data . contextPath = contextPath + field ;
}
}
ret = ret + fn ( context [ field ] , {
data : data ,
blockParams : Utils . blockParams ( [ context [ field ] , field ] , [ contextPath + field , null ] )
} ) ;
}
if ( context && typeof context === 'object' ) {
if ( isArray ( context ) ) {
for ( var j = context . length ; i < j ; i ++ ) {
execIteration ( i , i , i === context . length - 1 ) ;
}
} else {
var priorKey = undefined ;
for ( var key in context ) {
if ( context . hasOwnProperty ( key ) ) {
// We're running the iterations one step out of sync so we can detect
// the last iteration without have to scan the object twice and create
// an itermediate keys array.
if ( priorKey ) {
execIteration ( priorKey , i - 1 ) ;
}
priorKey = key ;
i ++ ;
}
}
if ( priorKey ) {
execIteration ( priorKey , i - 1 , true ) ;
}
}
}
if ( i === 0 ) {
ret = inverse ( this ) ;
}
return ret ;
} ) ;
instance . registerHelper ( 'if' , function ( conditional , options ) {
if ( isFunction ( conditional ) ) {
conditional = conditional . call ( this ) ;
}
// Default behavior is to render the positive path if the value is truthy and not empty.
// The `includeZero` option may be set to treat the condtional as purely not empty based on the
// behavior of isEmpty. Effectively this determines if 0 is handled by the positive path or negative.
if ( ! options . hash . includeZero && ! conditional || Utils . isEmpty ( conditional ) ) {
return options . inverse ( this ) ;
} else {
return options . fn ( this ) ;
}
} ) ;
instance . registerHelper ( 'unless' , function ( conditional , options ) {
return instance . helpers [ 'if' ] . call ( this , conditional , { fn : options . inverse , inverse : options . fn , hash : options . hash } ) ;
} ) ;
instance . registerHelper ( 'with' , function ( context , options ) {
if ( isFunction ( context ) ) {
context = context . call ( this ) ;
}
var fn = options . fn ;
if ( ! Utils . isEmpty ( context ) ) {
if ( options . data && options . ids ) {
var data = createFrame ( options . data ) ;
data . contextPath = Utils . appendContextPath ( options . data . contextPath , options . ids [ 0 ] ) ;
options = { data : data } ;
}
return fn ( context , options ) ;
} else {
return options . inverse ( this ) ;
}
} ) ;
instance . registerHelper ( 'log' , function ( message , options ) {
var level = options . data && options . data . level != null ? parseInt ( options . data . level , 10 ) : 1 ;
instance . log ( level , message ) ;
} ) ;
instance . registerHelper ( 'lookup' , function ( obj , field ) {
return obj && obj [ field ] ;
} ) ;
}
var logger = {
methodMap : { 0 : 'debug' , 1 : 'info' , 2 : 'warn' , 3 : 'error' } ,
// State enum
DEBUG : 0 ,
INFO : 1 ,
WARN : 2 ,
ERROR : 3 ,
level : 1 ,
// Can be overridden in the host environment
log : function log ( level , message ) {
if ( typeof console !== 'undefined' && logger . level <= level ) {
var method = logger . methodMap [ level ] ;
( console [ method ] || console . log ) . call ( console , message ) ; // eslint-disable-line no-console
}
}
} ;
exports . logger = logger ;
var log = logger . log ;
exports . log = log ;
function createFrame ( object ) {
var frame = Utils . extend ( { } , object ) ;
frame . _parent = object ;
return frame ;
}
/* [args, ]options */
/***/ } ,
/* 9 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
exports . _ _esModule = true ;
// Build out our basic SafeString type
function SafeString ( string ) {
this . string = string ;
}
SafeString . prototype . toString = SafeString . prototype . toHTML = function ( ) {
return '' + this . string ;
} ;
exports [ 'default' ] = SafeString ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 10 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
exports . _ _esModule = true ;
var errorProps = [ 'description' , 'fileName' , 'lineNumber' , 'message' , 'name' , 'number' , 'stack' ] ;
function Exception ( message , node ) {
var loc = node && node . loc ,
line = undefined ,
column = undefined ;
if ( loc ) {
line = loc . start . line ;
column = loc . start . column ;
message += ' - ' + line + ':' + column ;
}
var tmp = Error . prototype . constructor . call ( this , message ) ;
// Unfortunately errors are not enumerable in Chrome (at least), so `for prop in tmp` doesn't work.
for ( var idx = 0 ; idx < errorProps . length ; idx ++ ) {
this [ errorProps [ idx ] ] = tmp [ errorProps [ idx ] ] ;
}
if ( Error . captureStackTrace ) {
Error . captureStackTrace ( this , Exception ) ;
}
if ( loc ) {
this . lineNumber = line ;
this . column = column ;
}
}
Exception . prototype = new Error ( ) ;
exports [ 'default' ] = Exception ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 11 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
exports . _ _esModule = true ;
exports . extend = extend ;
// Older IE versions do not directly support indexOf so we must implement our own, sadly.
exports . indexOf = indexOf ;
exports . escapeExpression = escapeExpression ;
exports . isEmpty = isEmpty ;
exports . blockParams = blockParams ;
exports . appendContextPath = appendContextPath ;
/*jshint -W004 */
var escape = {
'&' : '&' ,
'<' : '<' ,
'>' : '>' ,
'"' : '"' ,
'\'' : ''' ,
'`' : '`'
} ;
var badChars = /[&<>"'`]/g ,
possible = /[&<>"'`]/ ;
function escapeChar ( chr ) {
return escape [ chr ] ;
}
function extend ( obj /* , ...source */ ) {
for ( var i = 1 ; i < arguments . length ; i ++ ) {
for ( var key in arguments [ i ] ) {
if ( Object . prototype . hasOwnProperty . call ( arguments [ i ] , key ) ) {
obj [ key ] = arguments [ i ] [ key ] ;
}
}
}
return obj ;
}
var toString = Object . prototype . toString ;
exports . toString = toString ;
// Sourced from lodash
// https://github.com/bestiejs/lodash/blob/master/LICENSE.txt
/*eslint-disable func-style, no-var */
var isFunction = function isFunction ( value ) {
return typeof value === 'function' ;
} ;
// fallback for older versions of Chrome and Safari
/* istanbul ignore next */
if ( isFunction ( /x/ ) ) {
exports . isFunction = isFunction = function ( value ) {
return typeof value === 'function' && toString . call ( value ) === '[object Function]' ;
} ;
}
var isFunction ;
exports . isFunction = isFunction ;
/*eslint-enable func-style, no-var */
/* istanbul ignore next */
var isArray = Array . isArray || function ( value ) {
return value && typeof value === 'object' ? toString . call ( value ) === '[object Array]' : false ;
} ; exports . isArray = isArray ;
function indexOf ( array , value ) {
for ( var i = 0 , len = array . length ; i < len ; i ++ ) {
if ( array [ i ] === value ) {
return i ;
}
}
return - 1 ;
}
function escapeExpression ( string ) {
if ( typeof string !== 'string' ) {
// don't escape SafeStrings, since they're already safe
if ( string && string . toHTML ) {
return string . toHTML ( ) ;
} else if ( string == null ) {
return '' ;
} else if ( ! string ) {
return string + '' ;
}
// Force a string conversion as this will be done by the append regardless and
// the regex test will do this transparently behind the scenes, causing issues if
// an object's to string has escaped characters in it.
string = '' + string ;
}
if ( ! possible . test ( string ) ) {
return string ;
}
return string . replace ( badChars , escapeChar ) ;
}
function isEmpty ( value ) {
if ( ! value && value !== 0 ) {
return true ;
} else if ( isArray ( value ) && value . length === 0 ) {
return true ;
} else {
return false ;
}
}
function blockParams ( params , ids ) {
params . path = ids ;
return params ;
}
function appendContextPath ( contextPath , id ) {
return ( contextPath ? contextPath + '.' : '' ) + id ;
}
/***/ } ,
/* 12 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireWildcard = _ _webpack _require _ _ ( 7 ) [ 'default' ] ;
exports . _ _esModule = true ;
exports . checkRevision = checkRevision ;
// TODO: Remove this line and break up compilePartial
exports . template = template ;
exports . wrapProgram = wrapProgram ;
exports . resolvePartial = resolvePartial ;
exports . invokePartial = invokePartial ;
exports . noop = noop ;
var _import = _ _webpack _require _ _ ( 11 ) ;
var Utils = _interopRequireWildcard ( _import ) ;
var _Exception = _ _webpack _require _ _ ( 10 ) ;
var _Exception2 = _interopRequireWildcard ( _Exception ) ;
var _COMPILER _REVISION$REVISION _CHANGES$createFrame = _ _webpack _require _ _ ( 8 ) ;
function checkRevision ( compilerInfo ) {
var compilerRevision = compilerInfo && compilerInfo [ 0 ] || 1 ,
currentRevision = _COMPILER _REVISION$REVISION _CHANGES$createFrame . COMPILER _REVISION ;
if ( compilerRevision !== currentRevision ) {
if ( compilerRevision < currentRevision ) {
var runtimeVersions = _COMPILER _REVISION$REVISION _CHANGES$createFrame . REVISION _CHANGES [ currentRevision ] ,
compilerVersions = _COMPILER _REVISION$REVISION _CHANGES$createFrame . REVISION _CHANGES [ compilerRevision ] ;
throw new _Exception2 [ 'default' ] ( 'Template was precompiled with an older version of Handlebars than the current runtime. ' + 'Please update your precompiler to a newer version (' + runtimeVersions + ') or downgrade your runtime to an older version (' + compilerVersions + ').' ) ;
} else {
// Use the embedded version info since the runtime doesn't know about this revision yet
throw new _Exception2 [ 'default' ] ( 'Template was precompiled with a newer version of Handlebars than the current runtime. ' + 'Please update your runtime to a newer version (' + compilerInfo [ 1 ] + ').' ) ;
}
}
}
function template ( templateSpec , env ) {
/* istanbul ignore next */
if ( ! env ) {
throw new _Exception2 [ 'default' ] ( 'No environment passed to template' ) ;
}
if ( ! templateSpec || ! templateSpec . main ) {
throw new _Exception2 [ 'default' ] ( 'Unknown template object: ' + typeof templateSpec ) ;
}
// Note: Using env.VM references rather than local var references throughout this section to allow
// for external users to override these as psuedo-supported APIs.
env . VM . checkRevision ( templateSpec . compiler ) ;
function invokePartialWrapper ( partial , context , options ) {
if ( options . hash ) {
context = Utils . extend ( { } , context , options . hash ) ;
}
partial = env . VM . resolvePartial . call ( this , partial , context , options ) ;
var result = env . VM . invokePartial . call ( this , partial , context , options ) ;
if ( result == null && env . compile ) {
options . partials [ options . name ] = env . compile ( partial , templateSpec . compilerOptions , env ) ;
result = options . partials [ options . name ] ( context , options ) ;
}
if ( result != null ) {
if ( options . indent ) {
var lines = result . split ( '\n' ) ;
for ( var i = 0 , l = lines . length ; i < l ; i ++ ) {
if ( ! lines [ i ] && i + 1 === l ) {
break ;
}
lines [ i ] = options . indent + lines [ i ] ;
}
result = lines . join ( '\n' ) ;
}
return result ;
} else {
throw new _Exception2 [ 'default' ] ( 'The partial ' + options . name + ' could not be compiled when running in runtime-only mode' ) ;
}
}
// Just add water
var container = {
strict : function strict ( obj , name ) {
if ( ! ( name in obj ) ) {
throw new _Exception2 [ 'default' ] ( '"' + name + '" not defined in ' + obj ) ;
}
return obj [ name ] ;
} ,
lookup : function lookup ( depths , name ) {
var len = depths . length ;
for ( var i = 0 ; i < len ; i ++ ) {
if ( depths [ i ] && depths [ i ] [ name ] != null ) {
return depths [ i ] [ name ] ;
}
}
} ,
lambda : function lambda ( current , context ) {
return typeof current === 'function' ? current . call ( context ) : current ;
} ,
escapeExpression : Utils . escapeExpression ,
invokePartial : invokePartialWrapper ,
fn : function fn ( i ) {
return templateSpec [ i ] ;
} ,
programs : [ ] ,
program : function program ( i , data , declaredBlockParams , blockParams , depths ) {
var programWrapper = this . programs [ i ] ,
fn = this . fn ( i ) ;
if ( data || depths || blockParams || declaredBlockParams ) {
programWrapper = wrapProgram ( this , i , fn , data , declaredBlockParams , blockParams , depths ) ;
} else if ( ! programWrapper ) {
programWrapper = this . programs [ i ] = wrapProgram ( this , i , fn ) ;
}
return programWrapper ;
} ,
data : function data ( value , depth ) {
while ( value && depth -- ) {
value = value . _parent ;
}
return value ;
} ,
merge : function merge ( param , common ) {
var obj = param || common ;
if ( param && common && param !== common ) {
obj = Utils . extend ( { } , common , param ) ;
}
return obj ;
} ,
noop : env . VM . noop ,
compilerInfo : templateSpec . compiler
} ;
function ret ( context ) {
var options = arguments [ 1 ] === undefined ? { } : arguments [ 1 ] ;
var data = options . data ;
ret . _setup ( options ) ;
if ( ! options . partial && templateSpec . useData ) {
data = initData ( context , data ) ;
}
var depths = undefined ,
blockParams = templateSpec . useBlockParams ? [ ] : undefined ;
if ( templateSpec . useDepths ) {
depths = options . depths ? [ context ] . concat ( options . depths ) : [ context ] ;
}
return templateSpec . main . call ( container , context , container . helpers , container . partials , data , blockParams , depths ) ;
}
ret . isTop = true ;
ret . _setup = function ( options ) {
if ( ! options . partial ) {
container . helpers = container . merge ( options . helpers , env . helpers ) ;
if ( templateSpec . usePartial ) {
container . partials = container . merge ( options . partials , env . partials ) ;
}
} else {
container . helpers = options . helpers ;
container . partials = options . partials ;
}
} ;
ret . _child = function ( i , data , blockParams , depths ) {
if ( templateSpec . useBlockParams && ! blockParams ) {
throw new _Exception2 [ 'default' ] ( 'must pass block params' ) ;
}
if ( templateSpec . useDepths && ! depths ) {
throw new _Exception2 [ 'default' ] ( 'must pass parent depths' ) ;
}
return wrapProgram ( container , i , templateSpec [ i ] , data , 0 , blockParams , depths ) ;
} ;
return ret ;
}
function wrapProgram ( container , i , fn , data , declaredBlockParams , blockParams , depths ) {
function prog ( context ) {
var options = arguments [ 1 ] === undefined ? { } : arguments [ 1 ] ;
return fn . call ( container , context , container . helpers , container . partials , options . data || data , blockParams && [ options . blockParams ] . concat ( blockParams ) , depths && [ context ] . concat ( depths ) ) ;
}
prog . program = i ;
prog . depth = depths ? depths . length : 0 ;
prog . blockParams = declaredBlockParams || 0 ;
return prog ;
}
function resolvePartial ( partial , context , options ) {
if ( ! partial ) {
partial = options . partials [ options . name ] ;
} else if ( ! partial . call && ! options . name ) {
// This is a dynamic partial that returned a string
options . name = partial ;
partial = options . partials [ partial ] ;
}
return partial ;
}
function invokePartial ( partial , context , options ) {
options . partial = true ;
if ( partial === undefined ) {
throw new _Exception2 [ 'default' ] ( 'The partial ' + options . name + ' could not be found' ) ;
} else if ( partial instanceof Function ) {
return partial ( context , options ) ;
}
}
function noop ( ) {
return '' ;
}
function initData ( context , data ) {
if ( ! data || ! ( 'root' in data ) ) {
data = data ? _COMPILER _REVISION$REVISION _CHANGES$createFrame . createFrame ( data ) : { } ;
data . root = context ;
}
return data ;
}
/***/ } ,
/* 13 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
"use strict" ;
exports . _ _esModule = true ;
/* jshint ignore:start */
/* istanbul ignore next */
/* Jison generated parser */
var handlebars = ( function ( ) {
var parser = { trace : function trace ( ) { } ,
yy : { } ,
symbols _ : { error : 2 , root : 3 , program : 4 , EOF : 5 , program _repetition0 : 6 , statement : 7 , mustache : 8 , block : 9 , rawBlock : 10 , partial : 11 , content : 12 , COMMENT : 13 , CONTENT : 14 , openRawBlock : 15 , END _RAW _BLOCK : 16 , OPEN _RAW _BLOCK : 17 , helperName : 18 , openRawBlock _repetition0 : 19 , openRawBlock _option0 : 20 , CLOSE _RAW _BLOCK : 21 , openBlock : 22 , block _option0 : 23 , closeBlock : 24 , openInverse : 25 , block _option1 : 26 , OPEN _BLOCK : 27 , openBlock _repetition0 : 28 , openBlock _option0 : 29 , openBlock _option1 : 30 , CLOSE : 31 , OPEN _INVERSE : 32 , openInverse _repetition0 : 33 , openInverse _option0 : 34 , openInverse _option1 : 35 , openInverseChain : 36 , OPEN _INVERSE _CHAIN : 37 , openInverseChain _repetition0 : 38 , openInverseChain _option0 : 39 , openInverseChain _option1 : 40 , inverseAndProgram : 41 , INVERSE : 42 , inverseChain : 43 , inverseChain _option0 : 44 , OPEN _ENDBLOCK : 45 , OPEN : 46 , mustache _repetition0 : 47 , mustache _option0 : 48 , OPEN _UNESCAPED : 49 , mustache _repetition1 : 50 , mustache _option1 : 51 , CLOSE _UNESCAPED : 52 , OPEN _PARTIAL : 53 , partialName : 54 , partial _repetition0 : 55 , partial _option0 : 56 , param : 57 , sexpr : 58 , OPEN _SEXPR : 59 , sexpr _repetition0 : 60 , sexpr _option0 : 61 , CLOSE _SEXPR : 62 , hash : 63 , hash _repetition _plus0 : 64 , hashSegment : 65 , ID : 66 , EQUALS : 67 , blockParams : 68 , OPEN _BLOCK _PARAMS : 69 , blockParams _repetition _plus0 : 70 , CLOSE _BLOCK _PARAMS : 71 , path : 72 , dataName : 73 , STRING : 74 , NUMBER : 75 , BOOLEAN : 76 , UNDEFINED : 77 , NULL : 78 , DATA : 79 , pathSegments : 80 , SEP : 81 , $accept : 0 , $end : 1 } ,
terminals _ : { 2 : "error" , 5 : "EOF" , 13 : "COMMENT" , 14 : "CONTENT" , 16 : "END_RAW_BLOCK" , 17 : "OPEN_RAW_BLOCK" , 21 : "CLOSE_RAW_BLOCK" , 27 : "OPEN_BLOCK" , 31 : "CLOSE" , 32 : "OPEN_INVERSE" , 37 : "OPEN_INVERSE_CHAIN" , 42 : "INVERSE" , 45 : "OPEN_ENDBLOCK" , 46 : "OPEN" , 49 : "OPEN_UNESCAPED" , 52 : "CLOSE_UNESCAPED" , 53 : "OPEN_PARTIAL" , 59 : "OPEN_SEXPR" , 62 : "CLOSE_SEXPR" , 66 : "ID" , 67 : "EQUALS" , 69 : "OPEN_BLOCK_PARAMS" , 71 : "CLOSE_BLOCK_PARAMS" , 74 : "STRING" , 75 : "NUMBER" , 76 : "BOOLEAN" , 77 : "UNDEFINED" , 78 : "NULL" , 79 : "DATA" , 81 : "SEP" } ,
productions _ : [ 0 , [ 3 , 2 ] , [ 4 , 1 ] , [ 7 , 1 ] , [ 7 , 1 ] , [ 7 , 1 ] , [ 7 , 1 ] , [ 7 , 1 ] , [ 7 , 1 ] , [ 12 , 1 ] , [ 10 , 3 ] , [ 15 , 5 ] , [ 9 , 4 ] , [ 9 , 4 ] , [ 22 , 6 ] , [ 25 , 6 ] , [ 36 , 6 ] , [ 41 , 2 ] , [ 43 , 3 ] , [ 43 , 1 ] , [ 24 , 3 ] , [ 8 , 5 ] , [ 8 , 5 ] , [ 11 , 5 ] , [ 57 , 1 ] , [ 57 , 1 ] , [ 58 , 5 ] , [ 63 , 1 ] , [ 65 , 3 ] , [ 68 , 3 ] , [ 18 , 1 ] , [ 18 , 1 ] , [ 18 , 1 ] , [ 18 , 1 ] , [ 18 , 1 ] , [ 18 , 1 ] , [ 18 , 1 ] , [ 54 , 1 ] , [ 54 , 1 ] , [ 73 , 2 ] , [ 72 , 1 ] , [ 80 , 3 ] , [ 80 , 1 ] , [ 6 , 0 ] , [ 6 , 2 ] , [ 19 , 0 ] , [ 19 , 2 ] , [ 20 , 0 ] , [ 20 , 1 ] , [ 23 , 0 ] , [ 23 , 1 ] , [ 26 , 0 ] , [ 26 , 1 ] , [ 28 , 0 ] , [ 28 , 2 ] , [ 29 , 0 ] , [ 29 , 1 ] , [ 30 , 0 ] , [ 30 , 1 ] , [ 33 , 0 ] , [ 33 , 2 ] , [ 34 , 0 ] , [ 34 , 1 ] , [ 35 , 0 ] , [ 35 , 1 ] , [ 38 , 0 ] , [ 38 , 2 ] , [ 39 , 0 ] , [ 39 , 1 ] , [ 40 , 0 ] , [ 40 , 1 ] , [ 44 , 0 ] , [ 44 , 1 ] , [ 47 , 0 ] , [ 47 , 2 ] , [ 48 , 0 ] , [ 48 , 1 ] , [ 50 , 0 ] , [ 50 , 2 ] , [ 51 , 0 ] , [ 51 , 1 ] , [ 55 , 0 ] , [ 55 , 2 ] , [ 56 , 0 ] , [ 56 , 1 ] , [ 60 , 0 ] , [ 60 , 2 ] , [ 61 , 0 ] , [ 61 , 1 ] , [ 64 , 1 ] , [ 64 , 2 ] , [ 70 , 1 ] , [ 70 , 2 ] ] ,
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 . Program ( $$ [ $0 ] , null , { } , yy . locInfo ( this . _$ ) ) ;
break ;
case 3 :
this . $ = $$ [ $0 ] ;
break ;
case 4 :
this . $ = $$ [ $0 ] ;
break ;
case 5 :
this . $ = $$ [ $0 ] ;
break ;
case 6 :
this . $ = $$ [ $0 ] ;
break ;
case 7 :
this . $ = $$ [ $0 ] ;
break ;
case 8 :
this . $ = new yy . CommentStatement ( yy . stripComment ( $$ [ $0 ] ) , yy . stripFlags ( $$ [ $0 ] , $$ [ $0 ] ) , yy . locInfo ( this . _$ ) ) ;
break ;
case 9 :
this . $ = new yy . ContentStatement ( $$ [ $0 ] , yy . locInfo ( this . _$ ) ) ;
break ;
case 10 :
this . $ = yy . prepareRawBlock ( $$ [ $0 - 2 ] , $$ [ $0 - 1 ] , $$ [ $0 ] , this . _$ ) ;
break ;
case 11 :
this . $ = { path : $$ [ $0 - 3 ] , params : $$ [ $0 - 2 ] , hash : $$ [ $0 - 1 ] } ;
break ;
case 12 :
this . $ = yy . prepareBlock ( $$ [ $0 - 3 ] , $$ [ $0 - 2 ] , $$ [ $0 - 1 ] , $$ [ $0 ] , false , this . _$ ) ;
break ;
case 13 :
this . $ = yy . prepareBlock ( $$ [ $0 - 3 ] , $$ [ $0 - 2 ] , $$ [ $0 - 1 ] , $$ [ $0 ] , true , this . _$ ) ;
break ;
case 14 :
this . $ = { path : $$ [ $0 - 4 ] , params : $$ [ $0 - 3 ] , hash : $$ [ $0 - 2 ] , blockParams : $$ [ $0 - 1 ] , strip : yy . stripFlags ( $$ [ $0 - 5 ] , $$ [ $0 ] ) } ;
break ;
case 15 :
this . $ = { path : $$ [ $0 - 4 ] , params : $$ [ $0 - 3 ] , hash : $$ [ $0 - 2 ] , blockParams : $$ [ $0 - 1 ] , strip : yy . stripFlags ( $$ [ $0 - 5 ] , $$ [ $0 ] ) } ;
break ;
case 16 :
this . $ = { path : $$ [ $0 - 4 ] , params : $$ [ $0 - 3 ] , hash : $$ [ $0 - 2 ] , blockParams : $$ [ $0 - 1 ] , strip : yy . stripFlags ( $$ [ $0 - 5 ] , $$ [ $0 ] ) } ;
break ;
case 17 :
this . $ = { strip : yy . stripFlags ( $$ [ $0 - 1 ] , $$ [ $0 - 1 ] ) , program : $$ [ $0 ] } ;
break ;
case 18 :
var inverse = yy . prepareBlock ( $$ [ $0 - 2 ] , $$ [ $0 - 1 ] , $$ [ $0 ] , $$ [ $0 ] , false , this . _$ ) ,
program = new yy . Program ( [ inverse ] , null , { } , yy . locInfo ( this . _$ ) ) ;
program . chained = true ;
this . $ = { strip : $$ [ $0 - 2 ] . strip , program : program , chain : true } ;
break ;
case 19 :
this . $ = $$ [ $0 ] ;
break ;
case 20 :
this . $ = { path : $$ [ $0 - 1 ] , strip : yy . stripFlags ( $$ [ $0 - 2 ] , $$ [ $0 ] ) } ;
break ;
case 21 :
this . $ = yy . prepareMustache ( $$ [ $0 - 3 ] , $$ [ $0 - 2 ] , $$ [ $0 - 1 ] , $$ [ $0 - 4 ] , yy . stripFlags ( $$ [ $0 - 4 ] , $$ [ $0 ] ) , this . _$ ) ;
break ;
case 22 :
this . $ = yy . prepareMustache ( $$ [ $0 - 3 ] , $$ [ $0 - 2 ] , $$ [ $0 - 1 ] , $$ [ $0 - 4 ] , yy . stripFlags ( $$ [ $0 - 4 ] , $$ [ $0 ] ) , this . _$ ) ;
break ;
case 23 :
this . $ = new yy . PartialStatement ( $$ [ $0 - 3 ] , $$ [ $0 - 2 ] , $$ [ $0 - 1 ] , yy . stripFlags ( $$ [ $0 - 4 ] , $$ [ $0 ] ) , yy . locInfo ( this . _$ ) ) ;
break ;
case 24 :
this . $ = $$ [ $0 ] ;
break ;
case 25 :
this . $ = $$ [ $0 ] ;
break ;
case 26 :
this . $ = new yy . SubExpression ( $$ [ $0 - 3 ] , $$ [ $0 - 2 ] , $$ [ $0 - 1 ] , yy . locInfo ( this . _$ ) ) ;
break ;
case 27 :
this . $ = new yy . Hash ( $$ [ $0 ] , yy . locInfo ( this . _$ ) ) ;
break ;
case 28 :
this . $ = new yy . HashPair ( yy . id ( $$ [ $0 - 2 ] ) , $$ [ $0 ] , yy . locInfo ( this . _$ ) ) ;
break ;
case 29 :
this . $ = yy . id ( $$ [ $0 - 1 ] ) ;
break ;
case 30 :
this . $ = $$ [ $0 ] ;
break ;
case 31 :
this . $ = $$ [ $0 ] ;
break ;
case 32 :
this . $ = new yy . StringLiteral ( $$ [ $0 ] , yy . locInfo ( this . _$ ) ) ;
break ;
case 33 :
this . $ = new yy . NumberLiteral ( $$ [ $0 ] , yy . locInfo ( this . _$ ) ) ;
break ;
case 34 :
this . $ = new yy . BooleanLiteral ( $$ [ $0 ] , yy . locInfo ( this . _$ ) ) ;
break ;
case 35 :
this . $ = new yy . UndefinedLiteral ( yy . locInfo ( this . _$ ) ) ;
break ;
case 36 :
this . $ = new yy . NullLiteral ( yy . locInfo ( this . _$ ) ) ;
break ;
case 37 :
this . $ = $$ [ $0 ] ;
break ;
case 38 :
this . $ = $$ [ $0 ] ;
break ;
case 39 :
this . $ = yy . preparePath ( true , $$ [ $0 ] , this . _$ ) ;
break ;
case 40 :
this . $ = yy . preparePath ( false , $$ [ $0 ] , this . _$ ) ;
break ;
case 41 :
$$ [ $0 - 2 ] . push ( { part : yy . id ( $$ [ $0 ] ) , original : $$ [ $0 ] , separator : $$ [ $0 - 1 ] } ) ; this . $ = $$ [ $0 - 2 ] ;
break ;
case 42 :
this . $ = [ { part : yy . id ( $$ [ $0 ] ) , original : $$ [ $0 ] } ] ;
break ;
case 43 :
this . $ = [ ] ;
break ;
case 44 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 45 :
this . $ = [ ] ;
break ;
case 46 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 53 :
this . $ = [ ] ;
break ;
case 54 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 59 :
this . $ = [ ] ;
break ;
case 60 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 65 :
this . $ = [ ] ;
break ;
case 66 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 73 :
this . $ = [ ] ;
break ;
case 74 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 77 :
this . $ = [ ] ;
break ;
case 78 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 81 :
this . $ = [ ] ;
break ;
case 82 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 85 :
this . $ = [ ] ;
break ;
case 86 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 89 :
this . $ = [ $$ [ $0 ] ] ;
break ;
case 90 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 91 :
this . $ = [ $$ [ $0 ] ] ;
break ;
case 92 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
}
} ,
table : [ { 3 : 1 , 4 : 2 , 5 : [ 2 , 43 ] , 6 : 3 , 13 : [ 2 , 43 ] , 14 : [ 2 , 43 ] , 17 : [ 2 , 43 ] , 27 : [ 2 , 43 ] , 32 : [ 2 , 43 ] , 46 : [ 2 , 43 ] , 49 : [ 2 , 43 ] , 53 : [ 2 , 43 ] } , { 1 : [ 3 ] } , { 5 : [ 1 , 4 ] } , { 5 : [ 2 , 2 ] , 7 : 5 , 8 : 6 , 9 : 7 , 10 : 8 , 11 : 9 , 12 : 10 , 13 : [ 1 , 11 ] , 14 : [ 1 , 18 ] , 15 : 16 , 17 : [ 1 , 21 ] , 22 : 14 , 25 : 15 , 27 : [ 1 , 19 ] , 32 : [ 1 , 20 ] , 37 : [ 2 , 2 ] , 42 : [ 2 , 2 ] , 45 : [ 2 , 2 ] , 46 : [ 1 , 12 ] , 49 : [ 1 , 13 ] , 53 : [ 1 , 17 ] } , { 1 : [ 2 , 1 ] } , { 5 : [ 2 , 44 ] , 13 : [ 2 , 44 ] , 14 : [ 2 , 44 ] , 17 : [ 2 , 44 ] , 27 : [ 2 , 44 ] , 32 : [ 2 , 44 ] , 37 : [ 2 , 44 ] , 42 : [ 2 , 44 ] , 45 : [ 2 , 44 ] , 46 : [ 2 , 44 ] , 49 : [ 2 , 44 ] , 53 : [ 2 , 44 ] } , { 5 : [ 2 , 3 ] , 13 : [ 2 , 3 ] , 14 : [ 2 , 3 ] , 17 : [ 2 , 3 ] , 27 : [ 2 , 3 ] , 32 : [ 2 , 3 ] , 37 : [ 2 , 3 ] , 42 : [ 2 , 3 ] , 45 : [ 2 , 3 ] , 46 : [ 2 , 3 ] , 49 : [ 2 , 3 ] , 53 : [ 2 , 3 ] } , { 5 : [ 2 , 4 ] , 13 : [ 2 , 4 ] , 14 : [ 2 , 4 ] , 17 : [ 2 , 4 ] , 27 : [ 2 , 4 ] , 32 : [ 2 , 4 ] , 37 : [ 2 , 4 ] , 42 : [ 2 , 4 ] , 45 : [ 2 , 4 ] , 46 : [ 2 , 4 ] , 49 : [ 2 , 4 ] , 53 : [ 2 , 4 ] } , { 5 : [ 2 , 5 ] , 13 : [ 2 , 5 ] , 14 : [ 2 , 5 ] , 17 : [ 2 , 5 ] , 27 : [ 2 , 5 ] , 32 : [ 2 , 5 ] , 37 : [ 2 , 5 ] , 42 : [ 2 , 5 ] , 45 : [ 2 , 5 ] , 46 : [ 2 , 5 ] , 49 : [ 2 , 5 ] , 53 : [ 2 , 5 ] } , { 5 : [ 2 , 6 ] , 13 : [ 2 , 6 ] , 14 : [ 2 , 6 ] , 17 : [ 2 , 6 ] , 27 : [ 2 , 6 ] , 32 : [ 2 , 6 ] , 37 : [ 2 , 6 ] , 42 : [ 2 , 6 ] , 45 : [ 2 , 6 ] , 46 : [ 2 , 6 ] , 49 : [ 2 , 6 ] , 53 : [ 2 , 6 ] } , { 5 : [ 2 , 7 ] , 13 : [ 2 , 7 ] , 14 : [ 2 , 7 ] , 17 : [ 2 , 7 ] , 27 : [ 2 , 7 ] , 32 : [ 2 , 7 ] , 37 : [ 2 , 7 ] , 42 : [ 2 , 7 ] , 45 : [ 2 , 7 ] , 46 : [ 2 , 7 ] , 49 : [ 2 , 7 ] , 53 : [ 2 , 7 ] } , { 5 : [ 2 , 8 ] , 13 : [ 2 , 8 ] , 14 : [ 2 , 8 ] , 17 : [ 2 , 8 ] , 27 : [ 2 , 8 ] , 32 : [ 2 , 8 ] , 37 : [ 2 , 8 ] , 42 : [ 2 , 8 ] , 45 : [ 2 , 8 ] , 46 : [ 2 , 8 ] , 49 : [ 2 , 8 ] , 53 : [ 2 , 8 ] } , { 18 : 22 , 66 : [ 1 , 32 ] , 72 : 23 , 73 : 24 , 74 : [ 1 , 25 ] , 75 : [ 1 , 26 ] , 76 : [ 1 , 27 ] , 77 : [ 1 , 28 ] , 78 : [ 1 , 29 ] , 79 : [ 1 , 31 ] , 80 : 30 } , { 18 : 33 , 66 : [ 1 , 32 ] , 72 : 23 , 73 : 24 , 74 : [ 1 , 25 ] , 75 : [ 1 , 26 ] , 76 : [ 1 , 27 ] , 77 : [ 1 , 28 ] , 78 : [ 1 , 29 ] , 79 : [ 1 , 31 ] , 80 : 30 } , { 4 : 34 , 6 : 3 , 13 : [ 2 , 43 ] , 14 : [ 2 , 43 ] , 17 : [ 2 , 43 ] , 27 : [ 2 , 43 ] , 32 : [ 2 , 43 ] , 37 : [ 2 , 43 ] , 42 : [ 2 , 43 ] , 45 : [ 2 , 43 ] , 46 : [ 2 , 43 ] , 49 : [ 2 , 43 ] , 53 : [ 2 , 43 ] } , { 4 : 35 , 6 : 3 , 13 : [ 2 , 43 ] , 14 : [ 2 , 43 ] , 17 : [ 2 , 43 ] , 27 : [ 2 , 43 ] , 32 : [ 2 , 43 ] , 42 : [ 2 , 43 ] , 45 : [ 2 , 43 ] , 46 : [ 2 , 43 ] , 49 : [ 2 , 43 ] , 53 : [ 2 , 43 ] } , { 12 : 36 , 14 : [ 1 , 18 ] } , { 18 : 38 , 54 : 37 , 58 : 39 , 59 : [ 1 , 40 ] , 66 : [ 1 , 32 ] , 72 : 23 , 73 : 24 , 74 : [ 1 , 25 ] , 75 : [ 1 , 26 ] , 76 : [ 1 , 27 ] , 77 : [ 1 , 28 ] , 78 : [ 1 , 29 ] , 79 : [ 1 , 31 ] , 80 : 30 } , { 5 : [ 2 , 9 ] , 13 : [ 2 , 9 ] , 14 : [ 2 , 9 ] , 16 : [ 2 , 9 ] , 17 : [ 2 , 9 ] , 27 : [ 2 , 9 ] , 32 : [ 2 , 9 ] , 37 : [ 2 , 9 ] , 42 : [ 2 , 9 ] , 45 : [ 2 , 9 ] , 46 : [ 2 , 9 ] , 49 : [ 2 , 9 ] , 53 : [ 2 , 9 ] } , { 18 : 41 , 66 : [ 1 , 32 ] , 72 : 23 , 73 : 24 , 74 : [ 1 , 25 ] , 75 : [ 1 , 26 ] , 76 : [ 1 , 27 ] , 77 : [ 1 , 28 ] , 78 : [ 1 , 29 ] , 79 : [ 1 , 31 ] , 80 : 30 } , { 18 : 42 , 66 : [ 1 , 32 ] , 72 : 23 , 73 : 24 , 74 : [ 1 , 25 ] , 75 : [ 1 , 26 ] , 76 : [ 1 , 27 ] , 77 : [ 1 , 28 ] , 78 : [ 1 , 29 ] , 79 : [ 1 , 31 ] , 80 : 30 } , { 18 : 43 , 66 : [ 1 , 32 ] , 72 : 23 , 73 : 24 , 74 : [ 1 , 25 ] , 75 : [ 1 , 26 ] , 76 : [ 1 , 27 ] , 77 : [ 1 , 28 ] , 78 : [ 1 , 29 ] , 79 : [ 1 , 31 ] , 80 : 30 } , { 31 : [ 2 , 73 ] , 47 : 44 , 59 : [ 2 , 73 ] , 66 : [ 2 , 73 ] , 74 : [ 2 , 73 ] , 75 : [ 2 , 73 ] , 76 : [ 2 , 73 ] , 77 : [ 2 , 73 ] , 78 : [ 2 , 73 ] , 79 : [ 2 , 73 ] } , { 21 : [ 2 , 30 ] , 31 : [ 2 , 30 ] , 52 : [ 2 , 30 ] , 59 : [ 2 , 30 ] , 62 : [ 2 , 30 ] , 66 : [ 2 , 30 ] , 69 : [ 2 , 30 ] , 74 : [ 2 , 30 ] , 75 : [ 2 , 30 ] , 76 : [ 2 , 30 ] , 77 : [ 2 , 30 ] , 78 : [ 2 , 30 ] , 79 : [ 2 , 30 ] } , { 21 : [ 2 , 31 ] , 31 : [ 2 , 31 ] , 52 : [ 2 , 31 ] , 59 : [ 2 , 31 ] , 62 : [ 2 , 31 ] , 66 : [ 2 , 31 ] , 69 : [ 2 , 31 ] , 74 : [ 2 , 31 ] , 75 : [ 2 , 31 ] , 76 : [ 2 , 31 ] , 77 : [ 2 , 31 ] , 78 : [ 2 , 31 ] , 79 : [ 2 , 31 ] } , { 21 : [ 2 , 32 ] , 31 : [ 2 , 32 ] , 52 : [ 2 , 32 ] , 59 : [ 2 , 32 ] , 62 : [ 2 , 32 ] , 66 : [ 2 , 32 ] , 69 : [ 2 , 32 ] , 74 : [ 2 , 32 ] , 75 : [ 2 , 32 ] , 76 : [ 2 , 32 ] , 77 : [ 2 , 32 ] , 78 : [ 2 , 32 ] , 79 : [ 2 , 32 ] } , { 21 : [ 2 , 33 ] , 31 : [ 2 , 33 ] , 52 : [ 2 , 33 ] , 59 : [ 2 , 33 ] , 62 : [ 2 , 33 ] , 66 : [ 2 , 33 ] , 69 : [ 2 , 33 ] , 74 : [ 2 , 33 ] , 75 : [ 2 , 33 ] , 76 : [ 2 , 33 ] , 77 : [ 2 , 33 ] , 78 : [ 2 , 33 ] , 79 : [ 2 , 33 ] } , { 21 : [ 2 , 34 ] , 31 : [ 2 , 34 ] , 52 : [ 2 , 34 ] , 59 : [ 2 , 34 ] , 62 : [ 2 , 34 ] , 66 : [ 2 , 34 ] , 69 : [ 2 , 34 ] , 74 : [ 2 , 34 ] , 75 : [ 2 , 34 ] , 76 : [ 2 , 34 ] , 77 : [ 2 , 34 ] , 78 : [ 2 , 34 ] , 79 : [ 2 , 34 ] } , { 21 : [ 2 , 35 ] , 31 : [ 2 , 35 ] , 52 : [ 2 , 35 ] , 59 : [ 2 , 35 ] , 62 : [ 2 , 35 ] , 66 : [ 2 , 35 ] , 69 : [ 2 , 35 ] , 74 : [ 2 , 35 ] , 75 : [ 2 , 35 ] , 76 : [ 2 , 35 ] , 77 : [ 2 , 35 ] , 78 : [ 2 , 35 ] , 79 : [ 2 , 35 ] } , { 21 : [ 2 , 36 ] , 31 : [ 2 , 36 ] , 52 : [ 2 , 36 ] , 59 : [ 2 , 36 ] , 62 : [ 2 , 36 ] , 66 : [ 2 , 36 ] , 69 : [ 2 , 36 ] , 74 : [ 2 , 36 ] , 75 : [ 2 , 36 ] , 76 : [ 2 , 36 ] , 77 : [ 2 , 36 ] , 78 : [ 2 , 36 ] , 79 : [ 2 , 36 ] } , { 21 : [ 2 , 40 ] , 3
defaultActions : { 4 : [ 2 , 1 ] , 49 : [ 2 , 50 ] , 51 : [ 2 , 19 ] , 55 : [ 2 , 52 ] , 64 : [ 2 , 76 ] , 73 : [ 2 , 80 ] , 78 : [ 2 , 17 ] , 82 : [ 2 , 84 ] , 92 : [ 2 , 48 ] , 99 : [ 2 , 18 ] , 100 : [ 2 , 72 ] , 105 : [ 2 , 88 ] , 107 : [ 2 , 58 ] , 110 : [ 2 , 64 ] , 111 : [ 2 , 11 ] , 123 : [ 2 , 70 ] , 124 : [ 2 , 29 ] } ,
parseError : function parseError ( str , hash ) {
throw new Error ( str ) ;
} ,
parse : function parse ( input ) {
var self = this ,
stack = [ 0 ] ,
vstack = [ null ] ,
lstack = [ ] ,
table = this . table ,
yytext = "" ,
yylineno = 0 ,
yyleng = 0 ,
recovering = 0 ,
TERROR = 2 ,
EOF = 1 ;
this . lexer . setInput ( input ) ;
this . lexer . yy = this . yy ;
this . yy . lexer = this . lexer ;
this . yy . parser = this ;
if ( typeof this . lexer . yylloc == "undefined" ) this . lexer . yylloc = { } ;
var yyloc = this . lexer . yylloc ;
lstack . push ( yyloc ) ;
var ranges = this . lexer . options && this . lexer . options . ranges ;
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 ;
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 ) {
state = stack [ stack . length - 1 ] ;
if ( this . defaultActions [ state ] ) {
action = this . defaultActions [ state ] ;
} else {
if ( symbol === null || typeof symbol == "undefined" ) {
symbol = lex ( ) ;
}
action = table [ state ] && table [ state ] [ symbol ] ;
}
if ( typeof action === "undefined" || ! action . length || ! action [ 0 ] ) {
var errStr = "" ;
if ( ! recovering ) {
expected = [ ] ;
for ( p in table [ state ] ) if ( this . terminals _ [ p ] && p > 2 ) {
expected . push ( "'" + this . terminals _ [ p ] + "'" ) ;
}
if ( this . lexer . showPosition ) {
errStr = "Parse error on line " + ( yylineno + 1 ) + ":\n" + this . lexer . showPosition ( ) + "\nExpecting " + expected . join ( ", " ) + ", got '" + ( this . terminals _ [ symbol ] || symbol ) + "'" ;
} else {
errStr = "Parse error on line " + ( yylineno + 1 ) + ": Unexpected " + ( symbol == 1 ? "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 } ) ;
}
}
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 :
stack . push ( symbol ) ;
vstack . push ( this . lexer . yytext ) ;
lstack . push ( this . lexer . yylloc ) ;
stack . push ( action [ 1 ] ) ;
symbol = null ;
if ( ! preErrorSymbol ) {
yyleng = this . lexer . yyleng ;
yytext = this . lexer . yytext ;
yylineno = this . lexer . yylineno ;
yyloc = this . lexer . yylloc ;
if ( recovering > 0 ) recovering -- ;
} else {
symbol = preErrorSymbol ;
preErrorSymbol = null ;
}
break ;
case 2 :
len = this . productions _ [ action [ 1 ] ] [ 1 ] ;
yyval . $ = vstack [ vstack . length - len ] ;
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 } ;
if ( ranges ) {
yyval . _$ . range = [ lstack [ lstack . length - ( len || 1 ) ] . range [ 0 ] , lstack [ lstack . length - 1 ] . range [ 1 ] ] ;
}
r = this . performAction . call ( yyval , yytext , yyleng , yylineno , this . yy , action [ 1 ] , vstack , lstack ) ;
if ( typeof r !== "undefined" ) {
return r ;
}
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 ] ) ;
vstack . push ( yyval . $ ) ;
lstack . push ( yyval . _$ ) ;
newState = table [ stack [ stack . length - 2 ] ] [ stack [ stack . length - 1 ] ] ;
stack . push ( newState ) ;
break ;
case 3 :
return true ;
}
}
return true ;
}
} ;
/* Jison generated lexer */
var lexer = ( function ( ) {
var lexer = { EOF : 1 ,
parseError : function parseError ( str , hash ) {
if ( this . yy . parser ) {
this . yy . parser . parseError ( str , hash ) ;
} else {
throw new Error ( str ) ;
}
} ,
setInput : function setInput ( 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 } ;
if ( this . options . ranges ) this . yylloc . range = [ 0 , 0 ] ;
this . offset = 0 ;
return this ;
} ,
input : function input ( ) {
var ch = this . _input [ 0 ] ;
this . yytext += ch ;
this . yyleng ++ ;
this . offset ++ ;
this . match += ch ;
this . matched += ch ;
var lines = ch . match ( /(?:\r\n?|\n).*/g ) ;
if ( lines ) {
this . yylineno ++ ;
this . yylloc . last _line ++ ;
} else {
this . yylloc . last _column ++ ;
}
if ( this . options . ranges ) this . yylloc . range [ 1 ] ++ ;
this . _input = this . _input . slice ( 1 ) ;
return ch ;
} ,
unput : function unput ( ch ) {
var len = ch . length ;
var lines = ch . split ( /(?:\r\n?|\n)/g ) ;
this . _input = ch + this . _input ;
this . yytext = this . yytext . substr ( 0 , this . yytext . length - len - 1 ) ;
//this.yyleng -= len;
this . offset -= len ;
var oldLines = this . match . split ( /(?:\r\n?|\n)/g ) ;
this . match = this . match . substr ( 0 , this . match . length - 1 ) ;
this . matched = this . matched . substr ( 0 , this . matched . length - 1 ) ;
if ( lines . length - 1 ) this . yylineno -= lines . length - 1 ;
var r = this . yylloc . range ;
this . yylloc = { first _line : this . yylloc . first _line ,
last _line : this . yylineno + 1 ,
first _column : this . yylloc . first _column ,
last _column : lines ? ( lines . length === oldLines . length ? this . yylloc . first _column : 0 ) + oldLines [ oldLines . length - lines . length ] . length - lines [ 0 ] . length : this . yylloc . first _column - len
} ;
if ( this . options . ranges ) {
this . yylloc . range = [ r [ 0 ] , r [ 0 ] + this . yyleng - len ] ;
}
return this ;
} ,
more : function more ( ) {
this . _more = true ;
return this ;
} ,
less : function less ( n ) {
this . unput ( this . match . slice ( n ) ) ;
} ,
pastInput : function pastInput ( ) {
var past = this . matched . substr ( 0 , this . matched . length - this . match . length ) ;
return ( past . length > 20 ? "..." : "" ) + past . substr ( - 20 ) . replace ( /\n/g , "" ) ;
} ,
upcomingInput : function upcomingInput ( ) {
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 showPosition ( ) {
var pre = this . pastInput ( ) ;
var c = new Array ( pre . length + 1 ) . join ( "-" ) ;
return pre + this . upcomingInput ( ) + "\n" + c + "^" ;
} ,
next : function next ( ) {
if ( this . done ) {
return this . EOF ;
}
if ( ! this . _input ) this . done = true ;
var token , match , tempMatch , index , col , lines ;
if ( ! this . _more ) {
this . yytext = "" ;
this . match = "" ;
}
var rules = this . _currentRules ( ) ;
for ( var i = 0 ; i < rules . length ; i ++ ) {
tempMatch = this . _input . match ( this . rules [ rules [ i ] ] ) ;
if ( tempMatch && ( ! match || tempMatch [ 0 ] . length > match [ 0 ] . length ) ) {
match = tempMatch ;
index = i ;
if ( ! this . options . flex ) break ;
}
}
if ( match ) {
lines = match [ 0 ] . match ( /(?:\r\n?|\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 - lines [ lines . length - 1 ] . match ( /\r?\n?/ ) [ 0 ] . length : this . yylloc . last _column + match [ 0 ] . length } ;
this . yytext += match [ 0 ] ;
this . match += match [ 0 ] ;
this . matches = match ;
this . yyleng = this . yytext . length ;
if ( this . options . ranges ) {
this . yylloc . range = [ this . offset , this . offset += this . yyleng ] ;
}
this . _more = false ;
this . _input = this . _input . slice ( match [ 0 ] . length ) ;
this . matched += match [ 0 ] ;
token = this . performAction . call ( this , this . yy , this , rules [ index ] , this . conditionStack [ this . conditionStack . length - 1 ] ) ;
if ( this . done && this . _input ) this . done = false ;
if ( token ) {
return token ;
} else {
return ;
}
}
if ( this . _input === "" ) {
return this . EOF ;
} else {
return 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 ;
} ,
topState : function topState ( ) {
return this . conditionStack [ this . conditionStack . length - 2 ] ;
} ,
pushState : function begin ( condition ) {
this . begin ( condition ) ;
} } ;
lexer . options = { } ;
lexer . performAction = function anonymous ( yy , yy _ , $avoiding _name _collisions , YY _START ) {
function strip ( start , end ) {
return yy _ . yytext = yy _ . yytext . substr ( start , yy _ . yyleng - end ) ;
}
var YYSTATE = YY _START ;
switch ( $avoiding _name _collisions ) {
case 0 :
if ( yy _ . yytext . slice ( - 2 ) === "\\\\" ) {
strip ( 0 , 1 ) ;
this . begin ( "mu" ) ;
} else if ( yy _ . yytext . slice ( - 1 ) === "\\" ) {
strip ( 0 , 1 ) ;
this . begin ( "emu" ) ;
} else {
this . begin ( "mu" ) ;
}
if ( yy _ . yytext ) {
return 14 ;
} break ;
case 1 :
return 14 ;
break ;
case 2 :
this . popState ( ) ;
return 14 ;
break ;
case 3 :
yy _ . yytext = yy _ . yytext . substr ( 5 , yy _ . yyleng - 9 ) ;
this . popState ( ) ;
return 16 ;
break ;
case 4 :
return 14 ;
break ;
case 5 :
this . popState ( ) ;
return 13 ;
break ;
case 6 :
return 59 ;
break ;
case 7 :
return 62 ;
break ;
case 8 :
return 17 ;
break ;
case 9 :
this . popState ( ) ;
this . begin ( "raw" ) ;
return 21 ;
break ;
case 10 :
return 53 ;
break ;
case 11 :
return 27 ;
break ;
case 12 :
return 45 ;
break ;
case 13 :
this . popState ( ) ; return 42 ;
break ;
case 14 :
this . popState ( ) ; return 42 ;
break ;
case 15 :
return 32 ;
break ;
case 16 :
return 37 ;
break ;
case 17 :
return 49 ;
break ;
case 18 :
return 46 ;
break ;
case 19 :
this . unput ( yy _ . yytext ) ;
this . popState ( ) ;
this . begin ( "com" ) ;
break ;
case 20 :
this . popState ( ) ;
return 13 ;
break ;
case 21 :
return 46 ;
break ;
case 22 :
return 67 ;
break ;
case 23 :
return 66 ;
break ;
case 24 :
return 66 ;
break ;
case 25 :
return 81 ;
break ;
case 26 :
// ignore whitespace
break ;
case 27 :
this . popState ( ) ; return 52 ;
break ;
case 28 :
this . popState ( ) ; return 31 ;
break ;
case 29 :
yy _ . yytext = strip ( 1 , 2 ) . replace ( /\\"/g , "\"" ) ; return 74 ;
break ;
case 30 :
yy _ . yytext = strip ( 1 , 2 ) . replace ( /\\'/g , "'" ) ; return 74 ;
break ;
case 31 :
return 79 ;
break ;
case 32 :
return 76 ;
break ;
case 33 :
return 76 ;
break ;
case 34 :
return 77 ;
break ;
case 35 :
return 78 ;
break ;
case 36 :
return 75 ;
break ;
case 37 :
return 69 ;
break ;
case 38 :
return 71 ;
break ;
case 39 :
return 66 ;
break ;
case 40 :
return 66 ;
break ;
case 41 :
return "INVALID" ;
break ;
case 42 :
return 5 ;
break ;
}
} ;
lexer . rules = [ /^(?:[^\x00]*?(?=(\{\{)))/ , /^(?:[^\x00]+)/ , /^(?:[^\x00]{2,}?(?=(\{\{|\\\{\{|\\\\\{\{|$)))/ , /^(?:\{\{\{\{\/[^\s!"#%-,\.\/;->@\[-\^`\{-~]+(?=[=}\s\/.])\}\}\}\})/ , /^(?:[^\x00]*?(?=(\{\{\{\{\/)))/ , /^(?:[\s\S]*?--(~)?\}\})/ , /^(?:\()/ , /^(?:\))/ , /^(?:\{\{\{\{)/ , /^(?:\}\}\}\})/ , /^(?:\{\{(~)?>)/ , /^(?:\{\{(~)?#)/ , /^(?:\{\{(~)?\/)/ , /^(?:\{\{(~)?\^\s*(~)?\}\})/ , /^(?:\{\{(~)?\s*else\s*(~)?\}\})/ , /^(?:\{\{(~)?\^)/ , /^(?:\{\{(~)?\s*else\b)/ , /^(?:\{\{(~)?\{)/ , /^(?:\{\{(~)?&)/ , /^(?:\{\{(~)?!--)/ , /^(?:\{\{(~)?![\s\S]*?\}\})/ , /^(?:\{\{(~)?)/ , /^(?:=)/ , /^(?:\.\.)/ , /^(?:\.(?=([=~}\s\/.)|])))/ , /^(?:[\/.])/ , /^(?:\s+)/ , /^(?:\}(~)?\}\})/ , /^(?:(~)?\}\})/ , /^(?:"(\\["]|[^"])*")/ , /^(?:'(\\[']|[^'])*')/ , /^(?:@)/ , /^(?:true(?=([~}\s)])))/ , /^(?:false(?=([~}\s)])))/ , /^(?:undefined(?=([~}\s)])))/ , /^(?:null(?=([~}\s)])))/ , /^(?:-?[0-9]+(?:\.[0-9]+)?(?=([~}\s)])))/ , /^(?:as\s+\|)/ , /^(?:\|)/ , /^(?:([^\s!"#%-,\.\/;->@\[-\^`\{-~]+(?=([=~}\s\/.)|]))))/ , /^(?:\[[^\]]*\])/ , /^(?:.)/ , /^(?:$)/ ] ;
lexer . conditions = { mu : { rules : [ 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 17 , 18 , 19 , 20 , 21 , 22 , 23 , 24 , 25 , 26 , 27 , 28 , 29 , 30 , 31 , 32 , 33 , 34 , 35 , 36 , 37 , 38 , 39 , 40 , 41 , 42 ] , inclusive : false } , emu : { rules : [ 2 ] , inclusive : false } , com : { rules : [ 5 ] , inclusive : false } , raw : { rules : [ 3 , 4 ] , inclusive : false } , INITIAL : { rules : [ 0 , 1 , 42 ] , inclusive : true } } ;
return lexer ;
} ) ( ) ;
parser . lexer = lexer ;
function Parser ( ) {
this . yy = { } ;
} Parser . prototype = parser ; parser . Parser = Parser ;
return new Parser ( ) ;
} ) ( ) ; exports [ "default" ] = handlebars ;
/* jshint ignore:end */
module . exports = exports [ "default" ] ;
/***/ } ,
/* 14 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireWildcard = _ _webpack _require _ _ ( 7 ) [ 'default' ] ;
exports . _ _esModule = true ;
var _Visitor = _ _webpack _require _ _ ( 6 ) ;
var _Visitor2 = _interopRequireWildcard ( _Visitor ) ;
function WhitespaceControl ( ) { }
WhitespaceControl . prototype = new _Visitor2 [ 'default' ] ( ) ;
WhitespaceControl . prototype . Program = function ( program ) {
var isRoot = ! this . isRootSeen ;
this . isRootSeen = true ;
var body = program . body ;
for ( var i = 0 , l = body . length ; i < l ; i ++ ) {
var current = body [ i ] ,
strip = this . accept ( current ) ;
if ( ! strip ) {
continue ;
}
var _isPrevWhitespace = isPrevWhitespace ( body , i , isRoot ) ,
_isNextWhitespace = isNextWhitespace ( body , i , isRoot ) ,
openStandalone = strip . openStandalone && _isPrevWhitespace ,
closeStandalone = strip . closeStandalone && _isNextWhitespace ,
inlineStandalone = strip . inlineStandalone && _isPrevWhitespace && _isNextWhitespace ;
if ( strip . close ) {
omitRight ( body , i , true ) ;
}
if ( strip . open ) {
omitLeft ( body , i , true ) ;
}
if ( inlineStandalone ) {
omitRight ( body , i ) ;
if ( omitLeft ( body , i ) ) {
// If we are on a standalone node, save the indent info for partials
if ( current . type === 'PartialStatement' ) {
// Pull out the whitespace from the final line
current . indent = /([ \t]+$)/ . exec ( body [ i - 1 ] . original ) [ 1 ] ;
}
}
}
if ( openStandalone ) {
omitRight ( ( current . program || current . inverse ) . body ) ;
// Strip out the previous content node if it's whitespace only
omitLeft ( body , i ) ;
}
if ( closeStandalone ) {
// Always strip the next node
omitRight ( body , i ) ;
omitLeft ( ( current . inverse || current . program ) . body ) ;
}
}
return program ;
} ;
WhitespaceControl . prototype . BlockStatement = function ( block ) {
this . accept ( block . program ) ;
this . accept ( block . inverse ) ;
// Find the inverse program that is involed with whitespace stripping.
var program = block . program || block . inverse ,
inverse = block . program && block . inverse ,
firstInverse = inverse ,
lastInverse = inverse ;
if ( inverse && inverse . chained ) {
firstInverse = inverse . body [ 0 ] . program ;
// Walk the inverse chain to find the last inverse that is actually in the chain.
while ( lastInverse . chained ) {
lastInverse = lastInverse . body [ lastInverse . body . length - 1 ] . program ;
}
}
var strip = {
open : block . openStrip . open ,
close : block . closeStrip . close ,
// Determine the standalone candiacy. Basically flag our content as being possibly standalone
// so our parent can determine if we actually are standalone
openStandalone : isNextWhitespace ( program . body ) ,
closeStandalone : isPrevWhitespace ( ( firstInverse || program ) . body )
} ;
if ( block . openStrip . close ) {
omitRight ( program . body , null , true ) ;
}
if ( inverse ) {
var inverseStrip = block . inverseStrip ;
if ( inverseStrip . open ) {
omitLeft ( program . body , null , true ) ;
}
if ( inverseStrip . close ) {
omitRight ( firstInverse . body , null , true ) ;
}
if ( block . closeStrip . open ) {
omitLeft ( lastInverse . body , null , true ) ;
}
// Find standalone else statments
if ( isPrevWhitespace ( program . body ) && isNextWhitespace ( firstInverse . body ) ) {
omitLeft ( program . body ) ;
omitRight ( firstInverse . body ) ;
}
} else if ( block . closeStrip . open ) {
omitLeft ( program . body , null , true ) ;
}
return strip ;
} ;
WhitespaceControl . prototype . MustacheStatement = function ( mustache ) {
return mustache . strip ;
} ;
WhitespaceControl . prototype . PartialStatement = WhitespaceControl . prototype . CommentStatement = function ( node ) {
/* istanbul ignore next */
var strip = node . strip || { } ;
return {
inlineStandalone : true ,
open : strip . open ,
close : strip . close
} ;
} ;
function isPrevWhitespace ( body , i , isRoot ) {
if ( i === undefined ) {
i = body . length ;
}
// Nodes that end with newlines are considered whitespace (but are special
// cased for strip operations)
var prev = body [ i - 1 ] ,
sibling = body [ i - 2 ] ;
if ( ! prev ) {
return isRoot ;
}
if ( prev . type === 'ContentStatement' ) {
return ( sibling || ! isRoot ? /\r?\n\s*?$/ : /(^|\r?\n)\s*?$/ ) . test ( prev . original ) ;
}
}
function isNextWhitespace ( body , i , isRoot ) {
if ( i === undefined ) {
i = - 1 ;
}
var next = body [ i + 1 ] ,
sibling = body [ i + 2 ] ;
if ( ! next ) {
return isRoot ;
}
if ( next . type === 'ContentStatement' ) {
return ( sibling || ! isRoot ? /^\s*?\r?\n/ : /^\s*?(\r?\n|$)/ ) . test ( next . original ) ;
}
}
// Marks the node to the right of the position as omitted.
// I.e. {{foo}}' ' will mark the ' ' node as omitted.
//
// If i is undefined, then the first child will be marked as such.
//
// If mulitple is truthy then all whitespace will be stripped out until non-whitespace
// content is met.
function omitRight ( body , i , multiple ) {
var current = body [ i == null ? 0 : i + 1 ] ;
if ( ! current || current . type !== 'ContentStatement' || ! multiple && current . rightStripped ) {
return ;
}
var original = current . value ;
current . value = current . value . replace ( multiple ? /^\s+/ : /^[ \t]*\r?\n?/ , '' ) ;
current . rightStripped = current . value !== original ;
}
// Marks the node to the left of the position as omitted.
// I.e. ' '{{foo}} will mark the ' ' node as omitted.
//
// If i is undefined then the last child will be marked as such.
//
// If mulitple is truthy then all whitespace will be stripped out until non-whitespace
// content is met.
function omitLeft ( body , i , multiple ) {
var current = body [ i == null ? body . length - 1 : i - 1 ] ;
if ( ! current || current . type !== 'ContentStatement' || ! multiple && current . leftStripped ) {
return ;
}
// We omit the last node if it's whitespace only and not preceeded by a non-content node.
var original = current . value ;
current . value = current . value . replace ( multiple ? /\s+$/ : /[ \t]+$/ , '' ) ;
current . leftStripped = current . value !== original ;
return current . leftStripped ;
}
exports [ 'default' ] = WhitespaceControl ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 15 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireWildcard = _ _webpack _require _ _ ( 7 ) [ 'default' ] ;
exports . _ _esModule = true ;
exports . SourceLocation = SourceLocation ;
exports . id = id ;
exports . stripFlags = stripFlags ;
exports . stripComment = stripComment ;
exports . preparePath = preparePath ;
exports . prepareMustache = prepareMustache ;
exports . prepareRawBlock = prepareRawBlock ;
exports . prepareBlock = prepareBlock ;
var _Exception = _ _webpack _require _ _ ( 10 ) ;
var _Exception2 = _interopRequireWildcard ( _Exception ) ;
function SourceLocation ( source , locInfo ) {
this . source = source ;
this . start = {
line : locInfo . first _line ,
column : locInfo . first _column
} ;
this . end = {
line : locInfo . last _line ,
column : locInfo . last _column
} ;
}
function id ( token ) {
if ( /^\[.*\]$/ . test ( token ) ) {
return token . substr ( 1 , token . length - 2 ) ;
} else {
return token ;
}
}
function stripFlags ( open , close ) {
return {
open : open . charAt ( 2 ) === '~' ,
close : close . charAt ( close . length - 3 ) === '~'
} ;
}
function stripComment ( comment ) {
return comment . replace ( /^\{\{~?\!-?-?/ , '' ) . replace ( /-?-?~?\}\}$/ , '' ) ;
}
function preparePath ( data , parts , locInfo ) {
/*jshint -W040 */
locInfo = this . locInfo ( locInfo ) ;
var original = data ? '@' : '' ,
dig = [ ] ,
depth = 0 ,
depthString = '' ;
for ( var i = 0 , l = parts . length ; i < l ; i ++ ) {
var part = parts [ i ] . part ,
// If we have [] syntax then we do not treat path references as operators,
// i.e. foo.[this] resolves to approximately context.foo['this']
isLiteral = parts [ i ] . original !== part ;
original += ( parts [ i ] . separator || '' ) + part ;
if ( ! isLiteral && ( part === '..' || part === '.' || part === 'this' ) ) {
if ( dig . length > 0 ) {
throw new _Exception2 [ 'default' ] ( 'Invalid path: ' + original , { loc : locInfo } ) ;
} else if ( part === '..' ) {
depth ++ ;
depthString += '../' ;
}
} else {
dig . push ( part ) ;
}
}
return new this . PathExpression ( data , depth , dig , original , locInfo ) ;
}
function prepareMustache ( path , params , hash , open , strip , locInfo ) {
/*jshint -W040 */
// Must use charAt to support IE pre-10
var escapeFlag = open . charAt ( 3 ) || open . charAt ( 2 ) ,
escaped = escapeFlag !== '{' && escapeFlag !== '&' ;
return new this . MustacheStatement ( path , params , hash , escaped , strip , this . locInfo ( locInfo ) ) ;
}
function prepareRawBlock ( openRawBlock , content , close , locInfo ) {
/*jshint -W040 */
if ( openRawBlock . path . original !== close ) {
var errorNode = { loc : openRawBlock . path . loc } ;
throw new _Exception2 [ 'default' ] ( openRawBlock . path . original + ' doesn\'t match ' + close , errorNode ) ;
}
locInfo = this . locInfo ( locInfo ) ;
var program = new this . Program ( [ content ] , null , { } , locInfo ) ;
return new this . BlockStatement ( openRawBlock . path , openRawBlock . params , openRawBlock . hash , program , undefined , { } , { } , { } , locInfo ) ;
}
function prepareBlock ( openBlock , program , inverseAndProgram , close , inverted , locInfo ) {
/*jshint -W040 */
// When we are chaining inverse calls, we will not have a close path
if ( close && close . path && openBlock . path . original !== close . path . original ) {
var errorNode = { loc : openBlock . path . loc } ;
throw new _Exception2 [ 'default' ] ( openBlock . path . original + ' doesn\'t match ' + close . path . original , errorNode ) ;
}
program . blockParams = openBlock . blockParams ;
var inverse = undefined ,
inverseStrip = undefined ;
if ( inverseAndProgram ) {
if ( inverseAndProgram . chain ) {
inverseAndProgram . program . body [ 0 ] . closeStrip = close . strip ;
}
inverseStrip = inverseAndProgram . strip ;
inverse = inverseAndProgram . program ;
}
if ( inverted ) {
inverted = inverse ;
inverse = program ;
program = inverted ;
}
return new this . BlockStatement ( openBlock . path , openBlock . params , openBlock . hash , program , inverse , openBlock . strip , inverseStrip , close && close . strip , this . locInfo ( locInfo ) ) ;
}
/***/ } ,
/* 16 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
exports . _ _esModule = true ;
/*global define */
var _isArray = _ _webpack _require _ _ ( 11 ) ;
var SourceNode = undefined ;
try {
/* istanbul ignore next */
if ( false ) {
// We don't support this in AMD environments. For these environments, we asusme that
// they are running on the browser and thus have no need for the source-map library.
var SourceMap = require ( 'source-map' ) ;
SourceNode = SourceMap . SourceNode ;
}
} catch ( err ) { }
/* istanbul ignore if: tested but not covered in istanbul due to dist build */
if ( ! SourceNode ) {
SourceNode = function ( line , column , srcFile , chunks ) {
this . src = '' ;
if ( chunks ) {
this . add ( chunks ) ;
}
} ;
/* istanbul ignore next */
SourceNode . prototype = {
add : function add ( chunks ) {
if ( _isArray . isArray ( chunks ) ) {
chunks = chunks . join ( '' ) ;
}
this . src += chunks ;
} ,
prepend : function prepend ( chunks ) {
if ( _isArray . isArray ( chunks ) ) {
chunks = chunks . join ( '' ) ;
}
this . src = chunks + this . src ;
} ,
toStringWithSourceMap : function toStringWithSourceMap ( ) {
return { code : this . toString ( ) } ;
} ,
toString : function toString ( ) {
return this . src ;
}
} ;
}
function castChunk ( chunk , codeGen , loc ) {
if ( _isArray . isArray ( chunk ) ) {
var ret = [ ] ;
for ( var i = 0 , len = chunk . length ; i < len ; i ++ ) {
ret . push ( codeGen . wrap ( chunk [ i ] , loc ) ) ;
}
return ret ;
} else if ( typeof chunk === 'boolean' || typeof chunk === 'number' ) {
// Handle primitives that the SourceNode will throw up on
return chunk + '' ;
}
return chunk ;
}
function CodeGen ( srcFile ) {
this . srcFile = srcFile ;
this . source = [ ] ;
}
CodeGen . prototype = {
prepend : function prepend ( source , loc ) {
this . source . unshift ( this . wrap ( source , loc ) ) ;
} ,
push : function push ( source , loc ) {
this . source . push ( this . wrap ( source , loc ) ) ;
} ,
merge : function merge ( ) {
var source = this . empty ( ) ;
this . each ( function ( line ) {
source . add ( [ ' ' , line , '\n' ] ) ;
} ) ;
return source ;
} ,
each : function each ( iter ) {
for ( var i = 0 , len = this . source . length ; i < len ; i ++ ) {
iter ( this . source [ i ] ) ;
}
} ,
empty : function empty ( ) {
var loc = arguments [ 0 ] === undefined ? this . currentLocation || { start : { } } : arguments [ 0 ] ;
return new SourceNode ( loc . start . line , loc . start . column , this . srcFile ) ;
} ,
wrap : function wrap ( chunk ) {
var loc = arguments [ 1 ] === undefined ? this . currentLocation || { start : { } } : arguments [ 1 ] ;
if ( chunk instanceof SourceNode ) {
return chunk ;
}
chunk = castChunk ( chunk , this , loc ) ;
return new SourceNode ( loc . start . line , loc . start . column , this . srcFile , chunk ) ;
} ,
functionCall : function functionCall ( fn , type , params ) {
params = this . generateList ( params ) ;
return this . wrap ( [ fn , type ? '.' + type + '(' : '(' , params , ')' ] ) ;
} ,
quotedString : function quotedString ( str ) {
return '"' + ( str + '' ) . replace ( /\\/g , '\\\\' ) . replace ( /"/g , '\\"' ) . replace ( /\n/g , '\\n' ) . replace ( /\r/g , '\\r' ) . replace ( /\u2028/g , '\\u2028' ) // Per Ecma-262 7.3 + 7.8.4
. replace ( /\u2029/g , '\\u2029' ) + '"' ;
} ,
objectLiteral : function objectLiteral ( obj ) {
var pairs = [ ] ;
for ( var key in obj ) {
if ( obj . hasOwnProperty ( key ) ) {
var value = castChunk ( obj [ key ] , this ) ;
if ( value !== 'undefined' ) {
pairs . push ( [ this . quotedString ( key ) , ':' , value ] ) ;
}
}
}
var ret = this . generateList ( pairs ) ;
ret . prepend ( '{' ) ;
ret . add ( '}' ) ;
return ret ;
} ,
generateList : function generateList ( entries , loc ) {
var ret = this . empty ( loc ) ;
for ( var i = 0 , len = entries . length ; i < len ; i ++ ) {
if ( i ) {
ret . add ( ',' ) ;
}
ret . add ( castChunk ( entries [ i ] , this , loc ) ) ;
}
return ret ;
} ,
generateArray : function generateArray ( entries , loc ) {
var ret = this . generateList ( entries , loc ) ;
ret . prepend ( '[' ) ;
ret . add ( ']' ) ;
return ret ;
}
} ;
exports [ 'default' ] = CodeGen ;
module . exports = exports [ 'default' ] ;
/* NOP */
/***/ }
/******/ ] )
} ) ;
;