2013-12-03 02:15:31 +08:00
/ * !
2016-01-16 00:40:30 +08:00
handlebars v4 . 0.5
2013-06-07 05:50:49 +08:00
2016-01-16 00:40:30 +08:00
Copyright ( C ) 2011 - 2015 by Yehuda Katz
2013-06-07 05:50:49 +08:00
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 .
2013-12-03 02:15:31 +08:00
@ license
2013-06-07 05:50:49 +08:00
* /
2016-01-16 00:40:30 +08:00
( 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 _ _ ) {
'use strict' ;
var _interopRequireDefault = _ _webpack _require _ _ ( 1 ) [ 'default' ] ;
exports . _ _esModule = true ;
var _handlebarsRuntime = _ _webpack _require _ _ ( 2 ) ;
var _handlebarsRuntime2 = _interopRequireDefault ( _handlebarsRuntime ) ;
// Compiler imports
var _handlebarsCompilerAst = _ _webpack _require _ _ ( 21 ) ;
var _handlebarsCompilerAst2 = _interopRequireDefault ( _handlebarsCompilerAst ) ;
var _handlebarsCompilerBase = _ _webpack _require _ _ ( 22 ) ;
var _handlebarsCompilerCompiler = _ _webpack _require _ _ ( 27 ) ;
var _handlebarsCompilerJavascriptCompiler = _ _webpack _require _ _ ( 28 ) ;
var _handlebarsCompilerJavascriptCompiler2 = _interopRequireDefault ( _handlebarsCompilerJavascriptCompiler ) ;
var _handlebarsCompilerVisitor = _ _webpack _require _ _ ( 25 ) ;
var _handlebarsCompilerVisitor2 = _interopRequireDefault ( _handlebarsCompilerVisitor ) ;
var _handlebarsNoConflict = _ _webpack _require _ _ ( 20 ) ;
var _handlebarsNoConflict2 = _interopRequireDefault ( _handlebarsNoConflict ) ;
var _create = _handlebarsRuntime2 [ 'default' ] . create ;
function create ( ) {
var hb = _create ( ) ;
hb . compile = function ( input , options ) {
return _handlebarsCompilerCompiler . compile ( input , options , hb ) ;
} ;
hb . precompile = function ( input , options ) {
return _handlebarsCompilerCompiler . precompile ( input , options , hb ) ;
} ;
hb . AST = _handlebarsCompilerAst2 [ 'default' ] ;
hb . Compiler = _handlebarsCompilerCompiler . Compiler ;
hb . JavaScriptCompiler = _handlebarsCompilerJavascriptCompiler2 [ 'default' ] ;
hb . Parser = _handlebarsCompilerBase . parser ;
hb . parse = _handlebarsCompilerBase . parse ;
return hb ;
}
var inst = create ( ) ;
inst . create = create ;
_handlebarsNoConflict2 [ 'default' ] ( inst ) ;
inst . Visitor = _handlebarsCompilerVisitor2 [ 'default' ] ;
inst [ 'default' ] = inst ;
exports [ 'default' ] = inst ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 1 */
/***/ function ( module , exports ) {
"use strict" ;
exports [ "default" ] = function ( obj ) {
return obj && obj . _ _esModule ? obj : {
"default" : obj
} ;
} ;
exports . _ _esModule = true ;
/***/ } ,
/* 2 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireWildcard = _ _webpack _require _ _ ( 3 ) [ 'default' ] ;
var _interopRequireDefault = _ _webpack _require _ _ ( 1 ) [ 'default' ] ;
exports . _ _esModule = true ;
var _handlebarsBase = _ _webpack _require _ _ ( 4 ) ;
var base = _interopRequireWildcard ( _handlebarsBase ) ;
// 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 _handlebarsSafeString = _ _webpack _require _ _ ( 18 ) ;
var _handlebarsSafeString2 = _interopRequireDefault ( _handlebarsSafeString ) ;
var _handlebarsException = _ _webpack _require _ _ ( 6 ) ;
var _handlebarsException2 = _interopRequireDefault ( _handlebarsException ) ;
var _handlebarsUtils = _ _webpack _require _ _ ( 5 ) ;
var Utils = _interopRequireWildcard ( _handlebarsUtils ) ;
var _handlebarsRuntime = _ _webpack _require _ _ ( 19 ) ;
var runtime = _interopRequireWildcard ( _handlebarsRuntime ) ;
var _handlebarsNoConflict = _ _webpack _require _ _ ( 20 ) ;
var _handlebarsNoConflict2 = _interopRequireDefault ( _handlebarsNoConflict ) ;
// 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 = _handlebarsSafeString2 [ 'default' ] ;
hb . Exception = _handlebarsException2 [ 'default' ] ;
hb . Utils = Utils ;
hb . escapeExpression = Utils . escapeExpression ;
hb . VM = runtime ;
hb . template = function ( spec ) {
return runtime . template ( spec , hb ) ;
} ;
return hb ;
}
var inst = create ( ) ;
inst . create = create ;
_handlebarsNoConflict2 [ 'default' ] ( inst ) ;
inst [ 'default' ] = inst ;
exports [ 'default' ] = inst ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 3 */
/***/ function ( module , exports ) {
"use strict" ;
exports [ "default" ] = function ( obj ) {
if ( obj && obj . _ _esModule ) {
return obj ;
} else {
var newObj = { } ;
if ( obj != null ) {
for ( var key in obj ) {
if ( Object . prototype . hasOwnProperty . call ( obj , key ) ) newObj [ key ] = obj [ key ] ;
}
}
newObj [ "default" ] = obj ;
return newObj ;
}
} ;
exports . _ _esModule = true ;
/***/ } ,
/* 4 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireDefault = _ _webpack _require _ _ ( 1 ) [ 'default' ] ;
exports . _ _esModule = true ;
exports . HandlebarsEnvironment = HandlebarsEnvironment ;
var _utils = _ _webpack _require _ _ ( 5 ) ;
var _exception = _ _webpack _require _ _ ( 6 ) ;
var _exception2 = _interopRequireDefault ( _exception ) ;
var _helpers = _ _webpack _require _ _ ( 7 ) ;
var _decorators = _ _webpack _require _ _ ( 15 ) ;
var _logger = _ _webpack _require _ _ ( 17 ) ;
var _logger2 = _interopRequireDefault ( _logger ) ;
var VERSION = '4.0.5' ;
exports . VERSION = VERSION ;
var COMPILER _REVISION = 7 ;
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' ,
7 : '>= 4.0.0'
} ;
exports . REVISION _CHANGES = REVISION _CHANGES ;
var objectType = '[object Object]' ;
function HandlebarsEnvironment ( helpers , partials , decorators ) {
this . helpers = helpers || { } ;
this . partials = partials || { } ;
this . decorators = decorators || { } ;
_helpers . registerDefaultHelpers ( this ) ;
_decorators . registerDefaultDecorators ( this ) ;
}
HandlebarsEnvironment . prototype = {
constructor : HandlebarsEnvironment ,
logger : _logger2 [ 'default' ] ,
log : _logger2 [ 'default' ] . log ,
registerHelper : function registerHelper ( name , fn ) {
if ( _utils . 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 ( _utils . toString . call ( name ) === objectType ) {
_utils . extend ( this . partials , name ) ;
} else {
if ( typeof partial === 'undefined' ) {
throw new _exception2 [ 'default' ] ( 'Attempting to register a partial called "' + name + '" as undefined' ) ;
}
this . partials [ name ] = partial ;
}
} ,
unregisterPartial : function unregisterPartial ( name ) {
delete this . partials [ name ] ;
} ,
registerDecorator : function registerDecorator ( name , fn ) {
if ( _utils . toString . call ( name ) === objectType ) {
if ( fn ) {
throw new _exception2 [ 'default' ] ( 'Arg not supported with multiple decorators' ) ;
}
_utils . extend ( this . decorators , name ) ;
} else {
this . decorators [ name ] = fn ;
}
} ,
unregisterDecorator : function unregisterDecorator ( name ) {
delete this . decorators [ name ] ;
}
} ;
var log = _logger2 [ 'default' ] . log ;
exports . log = log ;
exports . createFrame = _utils . createFrame ;
exports . logger = _logger2 [ 'default' ] ;
/***/ } ,
/* 5 */
/***/ function ( module , exports ) {
'use strict' ;
exports . _ _esModule = true ;
exports . extend = extend ;
exports . indexOf = indexOf ;
exports . escapeExpression = escapeExpression ;
exports . isEmpty = isEmpty ;
exports . createFrame = createFrame ;
exports . blockParams = blockParams ;
exports . appendContextPath = appendContextPath ;
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 */
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]' ;
} ;
}
exports . isFunction = isFunction ;
/* eslint-enable func-style */
/* istanbul ignore next */
var isArray = Array . isArray || function ( value ) {
return value && typeof value === 'object' ? toString . call ( value ) === '[object Array]' : false ;
} ;
exports . isArray = isArray ;
// Older IE versions do not directly support indexOf so we must implement our own, sadly.
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 createFrame ( object ) {
var frame = extend ( { } , object ) ;
frame . _parent = object ;
return frame ;
}
function blockParams ( params , ids ) {
params . path = ids ;
return params ;
}
function appendContextPath ( contextPath , id ) {
return ( contextPath ? contextPath + '.' : '' ) + id ;
}
/***/ } ,
/* 6 */
/***/ function ( module , exports ) {
'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 ] ] ;
}
/* istanbul ignore else */
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' ] ;
/***/ } ,
/* 7 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireDefault = _ _webpack _require _ _ ( 1 ) [ 'default' ] ;
exports . _ _esModule = true ;
exports . registerDefaultHelpers = registerDefaultHelpers ;
var _helpersBlockHelperMissing = _ _webpack _require _ _ ( 8 ) ;
var _helpersBlockHelperMissing2 = _interopRequireDefault ( _helpersBlockHelperMissing ) ;
var _helpersEach = _ _webpack _require _ _ ( 9 ) ;
var _helpersEach2 = _interopRequireDefault ( _helpersEach ) ;
var _helpersHelperMissing = _ _webpack _require _ _ ( 10 ) ;
var _helpersHelperMissing2 = _interopRequireDefault ( _helpersHelperMissing ) ;
var _helpersIf = _ _webpack _require _ _ ( 11 ) ;
var _helpersIf2 = _interopRequireDefault ( _helpersIf ) ;
var _helpersLog = _ _webpack _require _ _ ( 12 ) ;
var _helpersLog2 = _interopRequireDefault ( _helpersLog ) ;
var _helpersLookup = _ _webpack _require _ _ ( 13 ) ;
var _helpersLookup2 = _interopRequireDefault ( _helpersLookup ) ;
var _helpersWith = _ _webpack _require _ _ ( 14 ) ;
var _helpersWith2 = _interopRequireDefault ( _helpersWith ) ;
function registerDefaultHelpers ( instance ) {
_helpersBlockHelperMissing2 [ 'default' ] ( instance ) ;
_helpersEach2 [ 'default' ] ( instance ) ;
_helpersHelperMissing2 [ 'default' ] ( instance ) ;
_helpersIf2 [ 'default' ] ( instance ) ;
_helpersLog2 [ 'default' ] ( instance ) ;
_helpersLookup2 [ 'default' ] ( instance ) ;
_helpersWith2 [ 'default' ] ( instance ) ;
}
/***/ } ,
/* 8 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
exports . _ _esModule = true ;
var _utils = _ _webpack _require _ _ ( 5 ) ;
exports [ 'default' ] = function ( instance ) {
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 ( _utils . 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 = _utils . createFrame ( options . data ) ;
data . contextPath = _utils . appendContextPath ( options . data . contextPath , options . name ) ;
options = { data : data } ;
}
return fn ( context , options ) ;
}
} ) ;
} ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 9 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireDefault = _ _webpack _require _ _ ( 1 ) [ 'default' ] ;
exports . _ _esModule = true ;
var _utils = _ _webpack _require _ _ ( 5 ) ;
var _exception = _ _webpack _require _ _ ( 6 ) ;
var _exception2 = _interopRequireDefault ( _exception ) ;
exports [ 'default' ] = function ( instance ) {
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 ( _utils . isFunction ( context ) ) {
context = context . call ( this ) ;
}
if ( options . data ) {
data = _utils . 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 ( _utils . isArray ( context ) ) {
for ( var j = context . length ; i < j ; i ++ ) {
if ( i in context ) {
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 !== undefined ) {
execIteration ( priorKey , i - 1 ) ;
}
priorKey = key ;
i ++ ;
}
}
if ( priorKey !== undefined ) {
execIteration ( priorKey , i - 1 , true ) ;
}
}
}
if ( i === 0 ) {
ret = inverse ( this ) ;
}
return ret ;
} ) ;
} ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 10 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireDefault = _ _webpack _require _ _ ( 1 ) [ 'default' ] ;
exports . _ _esModule = true ;
var _exception = _ _webpack _require _ _ ( 6 ) ;
var _exception2 = _interopRequireDefault ( _exception ) ;
exports [ 'default' ] = function ( instance ) {
instance . registerHelper ( 'helperMissing' , function ( ) /* [args, ]options */ {
if ( arguments . length === 1 ) {
// A missing field in a {{foo}} construct.
return undefined ;
} else {
// Someone is actually trying to call something, blow up.
throw new _exception2 [ 'default' ] ( 'Missing helper: "' + arguments [ arguments . length - 1 ] . name + '"' ) ;
}
} ) ;
} ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 11 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
exports . _ _esModule = true ;
var _utils = _ _webpack _require _ _ ( 5 ) ;
exports [ 'default' ] = function ( instance ) {
instance . registerHelper ( 'if' , function ( conditional , options ) {
if ( _utils . 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 } ) ;
} ) ;
} ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 12 */
/***/ function ( module , exports ) {
'use strict' ;
exports . _ _esModule = true ;
exports [ 'default' ] = function ( instance ) {
instance . registerHelper ( 'log' , function ( ) /* message, options */ {
var args = [ undefined ] ,
options = arguments [ arguments . length - 1 ] ;
for ( var i = 0 ; i < arguments . length - 1 ; i ++ ) {
args . push ( arguments [ i ] ) ;
}
var level = 1 ;
if ( options . hash . level != null ) {
level = options . hash . level ;
} else if ( options . data && options . data . level != null ) {
level = options . data . level ;
}
args [ 0 ] = level ;
instance . log . apply ( instance , args ) ;
} ) ;
} ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 13 */
/***/ function ( module , exports ) {
'use strict' ;
exports . _ _esModule = true ;
exports [ 'default' ] = function ( instance ) {
instance . registerHelper ( 'lookup' , function ( obj , field ) {
return obj && obj [ field ] ;
} ) ;
} ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 14 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
exports . _ _esModule = true ;
var _utils = _ _webpack _require _ _ ( 5 ) ;
exports [ 'default' ] = function ( instance ) {
instance . registerHelper ( 'with' , function ( context , options ) {
if ( _utils . isFunction ( context ) ) {
context = context . call ( this ) ;
}
var fn = options . fn ;
if ( ! _utils . isEmpty ( context ) ) {
var data = options . data ;
if ( options . data && options . ids ) {
data = _utils . createFrame ( options . data ) ;
data . contextPath = _utils . appendContextPath ( options . data . contextPath , options . ids [ 0 ] ) ;
}
return fn ( context , {
data : data ,
blockParams : _utils . blockParams ( [ context ] , [ data && data . contextPath ] )
} ) ;
} else {
return options . inverse ( this ) ;
}
} ) ;
} ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 15 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireDefault = _ _webpack _require _ _ ( 1 ) [ 'default' ] ;
exports . _ _esModule = true ;
exports . registerDefaultDecorators = registerDefaultDecorators ;
var _decoratorsInline = _ _webpack _require _ _ ( 16 ) ;
var _decoratorsInline2 = _interopRequireDefault ( _decoratorsInline ) ;
function registerDefaultDecorators ( instance ) {
_decoratorsInline2 [ 'default' ] ( instance ) ;
}
/***/ } ,
/* 16 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
exports . _ _esModule = true ;
var _utils = _ _webpack _require _ _ ( 5 ) ;
exports [ 'default' ] = function ( instance ) {
instance . registerDecorator ( 'inline' , function ( fn , props , container , options ) {
var ret = fn ;
if ( ! props . partials ) {
props . partials = { } ;
ret = function ( context , options ) {
// Create a new partials stack frame prior to exec.
var original = container . partials ;
container . partials = _utils . extend ( { } , original , props . partials ) ;
var ret = fn ( context , options ) ;
container . partials = original ;
return ret ;
} ;
}
props . partials [ options . args [ 0 ] ] = options . fn ;
return ret ;
} ) ;
} ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 17 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
exports . _ _esModule = true ;
var _utils = _ _webpack _require _ _ ( 5 ) ;
var logger = {
methodMap : [ 'debug' , 'info' , 'warn' , 'error' ] ,
level : 'info' ,
// Maps a given level value to the `methodMap` indexes above.
lookupLevel : function lookupLevel ( level ) {
if ( typeof level === 'string' ) {
var levelMap = _utils . indexOf ( logger . methodMap , level . toLowerCase ( ) ) ;
if ( levelMap >= 0 ) {
level = levelMap ;
} else {
level = parseInt ( level , 10 ) ;
}
}
return level ;
} ,
// Can be overridden in the host environment
log : function log ( level ) {
level = logger . lookupLevel ( level ) ;
if ( typeof console !== 'undefined' && logger . lookupLevel ( logger . level ) <= level ) {
var method = logger . methodMap [ level ] ;
if ( ! console [ method ] ) {
// eslint-disable-line no-console
method = 'log' ;
}
for ( var _len = arguments . length , message = Array ( _len > 1 ? _len - 1 : 0 ) , _key = 1 ; _key < _len ; _key ++ ) {
message [ _key - 1 ] = arguments [ _key ] ;
}
console [ method ] . apply ( console , message ) ; // eslint-disable-line no-console
}
}
} ;
exports [ 'default' ] = logger ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 18 */
/***/ function ( module , exports ) {
// Build out our basic SafeString type
'use strict' ;
exports . _ _esModule = true ;
function SafeString ( string ) {
this . string = string ;
}
SafeString . prototype . toString = SafeString . prototype . toHTML = function ( ) {
return '' + this . string ;
} ;
exports [ 'default' ] = SafeString ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 19 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireWildcard = _ _webpack _require _ _ ( 3 ) [ 'default' ] ;
var _interopRequireDefault = _ _webpack _require _ _ ( 1 ) [ 'default' ] ;
exports . _ _esModule = true ;
exports . checkRevision = checkRevision ;
exports . template = template ;
exports . wrapProgram = wrapProgram ;
exports . resolvePartial = resolvePartial ;
exports . invokePartial = invokePartial ;
exports . noop = noop ;
var _utils = _ _webpack _require _ _ ( 5 ) ;
var Utils = _interopRequireWildcard ( _utils ) ;
var _exception = _ _webpack _require _ _ ( 6 ) ;
var _exception2 = _interopRequireDefault ( _exception ) ;
var _base = _ _webpack _require _ _ ( 4 ) ;
function checkRevision ( compilerInfo ) {
var compilerRevision = compilerInfo && compilerInfo [ 0 ] || 1 ,
currentRevision = _base . COMPILER _REVISION ;
if ( compilerRevision !== currentRevision ) {
if ( compilerRevision < currentRevision ) {
var runtimeVersions = _base . REVISION _CHANGES [ currentRevision ] ,
compilerVersions = _base . 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 ) ;
}
templateSpec . main . decorator = templateSpec . main _d ;
// 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 ) ;
if ( options . ids ) {
options . ids [ 0 ] = true ;
}
}
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 ) {
var ret = templateSpec [ i ] ;
ret . decorator = templateSpec [ i + '_d' ] ;
return ret ;
} ,
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 . length <= 1 || 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 ) {
if ( options . depths ) {
depths = context !== options . depths [ 0 ] ? [ context ] . concat ( options . depths ) : options . depths ;
} else {
depths = [ context ] ;
}
}
function main ( context /*, options*/ ) {
return '' + templateSpec . main ( container , context , container . helpers , container . partials , data , blockParams , depths ) ;
}
main = executeDecorators ( templateSpec . main , main , container , options . depths || [ ] , data , blockParams ) ;
return main ( context , options ) ;
}
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 ) ;
}
if ( templateSpec . usePartial || templateSpec . useDecorators ) {
container . decorators = container . merge ( options . decorators , env . decorators ) ;
}
} else {
container . helpers = options . helpers ;
container . partials = options . partials ;
container . decorators = options . decorators ;
}
} ;
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 . length <= 1 || arguments [ 1 ] === undefined ? { } : arguments [ 1 ] ;
var currentDepths = depths ;
if ( depths && context !== depths [ 0 ] ) {
currentDepths = [ context ] . concat ( depths ) ;
}
return fn ( container , context , container . helpers , container . partials , options . data || data , blockParams && [ options . blockParams ] . concat ( blockParams ) , currentDepths ) ;
}
prog = executeDecorators ( fn , prog , container , depths , data , blockParams ) ;
prog . program = i ;
prog . depth = depths ? depths . length : 0 ;
prog . blockParams = declaredBlockParams || 0 ;
return prog ;
}
function resolvePartial ( partial , context , options ) {
if ( ! partial ) {
if ( options . name === '@partial-block' ) {
partial = options . data [ 'partial-block' ] ;
} else {
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 ( options . ids ) {
options . data . contextPath = options . ids [ 0 ] || options . data . contextPath ;
}
var partialBlock = undefined ;
if ( options . fn && options . fn !== noop ) {
options . data = _base . createFrame ( options . data ) ;
partialBlock = options . data [ 'partial-block' ] = options . fn ;
if ( partialBlock . partials ) {
options . partials = Utils . extend ( { } , options . partials , partialBlock . partials ) ;
}
}
if ( partial === undefined && partialBlock ) {
partial = partialBlock ;
}
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 ? _base . createFrame ( data ) : { } ;
data . root = context ;
}
return data ;
}
function executeDecorators ( fn , prog , container , depths , data , blockParams ) {
if ( fn . decorator ) {
var props = { } ;
prog = fn . decorator ( prog , props , container , depths && depths [ 0 ] , data , blockParams , depths ) ;
Utils . extend ( prog , props ) ;
}
return prog ;
}
/***/ } ,
/* 20 */
/***/ function ( module , exports ) {
/* WEBPACK VAR INJECTION */ ( function ( global ) { /* global window */
'use strict' ;
exports . _ _esModule = true ;
exports [ 'default' ] = function ( Handlebars ) {
/* 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 ;
}
return Handlebars ;
} ;
} ;
module . exports = exports [ 'default' ] ;
/* WEBPACK VAR INJECTION */ } . call ( exports , ( function ( ) { return this ; } ( ) ) ) )
/***/ } ,
/* 21 */
/***/ function ( module , exports ) {
'use strict' ;
exports . _ _esModule = true ;
var AST = {
// 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 . type === 'MustacheStatement' || node . type === 'BlockStatement' ) && ! ! ( node . params && 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' ] ;
/***/ } ,
/* 22 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireDefault = _ _webpack _require _ _ ( 1 ) [ 'default' ] ;
var _interopRequireWildcard = _ _webpack _require _ _ ( 3 ) [ 'default' ] ;
exports . _ _esModule = true ;
exports . parse = parse ;
var _parser = _ _webpack _require _ _ ( 23 ) ;
var _parser2 = _interopRequireDefault ( _parser ) ;
var _whitespaceControl = _ _webpack _require _ _ ( 24 ) ;
var _whitespaceControl2 = _interopRequireDefault ( _whitespaceControl ) ;
var _helpers = _ _webpack _require _ _ ( 26 ) ;
var Helpers = _interopRequireWildcard ( _helpers ) ;
var _utils = _ _webpack _require _ _ ( 5 ) ;
exports . parser = _parser2 [ 'default' ] ;
var yy = { } ;
_utils . extend ( yy , Helpers ) ;
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' ] ( options ) ;
return strip . accept ( _parser2 [ 'default' ] . parse ( input ) ) ;
}
/***/ } ,
/* 23 */
/***/ function ( module , exports ) {
/* istanbul ignore next */
/* Jison generated parser */
"use strict" ;
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 , "partialBlock" : 12 , "content" : 13 , "COMMENT" : 14 , "CONTENT" : 15 , "openRawBlock" : 16 , "rawBlock_repetition_plus0" : 17 , "END_RAW_BLOCK" : 18 , "OPEN_RAW_BLOCK" : 19 , "helperName" : 20 , "openRawBlock_repetition0" : 21 , "openRawBlock_option0" : 22 , "CLOSE_RAW_BLOCK" : 23 , "openBlock" : 24 , "block_option0" : 25 , "closeBlock" : 26 , "openInverse" : 27 , "block_option1" : 28 , "OPEN_BLOCK" : 29 , "openBlock_repetition0" : 30 , "openBlock_option0" : 31 , "openBlock_option1" : 32 , "CLOSE" : 33 , "OPEN_INVERSE" : 34 , "openInverse_repetition0" : 35 , "openInverse_option0" : 36 , "openInverse_option1" : 37 , "openInverseChain" : 38 , "OPEN_INVERSE_CHAIN" : 39 , "openInverseChain_repetition0" : 40 , "openInverseChain_option0" : 41 , "openInverseChain_option1" : 42 , "inverseAndProgram" : 43 , "INVERSE" : 44 , "inverseChain" : 45 , "inverseChain_option0" : 46 , "OPEN_ENDBLOCK" : 47 , "OPEN" : 48 , "mustache_repetition0" : 49 , "mustache_option0" : 50 , "OPEN_UNESCAPED" : 51 , "mustache_repetition1" : 52 , "mustache_option1" : 53 , "CLOSE_UNESCAPED" : 54 , "OPEN_PARTIAL" : 55 , "partialName" : 56 , "partial_repetition0" : 57 , "partial_option0" : 58 , "openPartialBlock" : 59 , "OPEN_PARTIAL_BLOCK" : 60 , "openPartialBlock_repetition0" : 61 , "openPartialBlock_option0" : 62 , "param" : 63 , "sexpr" : 64 , "OPEN_SEXPR" : 65 , "sexpr_repetition0" : 66 , "sexpr_option0" : 67 , "CLOSE_SEXPR" : 68 , "hash" : 69 , "hash_repetition_plus0" : 70 , "hashSegment" : 71 , "ID" : 72 , "EQUALS" : 73 , "blockParams" : 74 , "OPEN_BLOCK_PARAMS" : 75 , "blockParams_repetition_plus0" : 76 , "CLOSE_BLOCK_PARAMS" : 77 , "path" : 78 , "dataName" : 79 , "STRING" : 80 , "NUMBER" : 81 , "BOOLEAN" : 82 , "UNDEFINED" : 83 , "NULL" : 84 , "DATA" : 85 , "pathSegments" : 86 , "SEP" : 87 , "$accept" : 0 , "$end" : 1 } ,
terminals _ : { 2 : "error" , 5 : "EOF" , 14 : "COMMENT" , 15 : "CONTENT" , 18 : "END_RAW_BLOCK" , 19 : "OPEN_RAW_BLOCK" , 23 : "CLOSE_RAW_BLOCK" , 29 : "OPEN_BLOCK" , 33 : "CLOSE" , 34 : "OPEN_INVERSE" , 39 : "OPEN_INVERSE_CHAIN" , 44 : "INVERSE" , 47 : "OPEN_ENDBLOCK" , 48 : "OPEN" , 51 : "OPEN_UNESCAPED" , 54 : "CLOSE_UNESCAPED" , 55 : "OPEN_PARTIAL" , 60 : "OPEN_PARTIAL_BLOCK" , 65 : "OPEN_SEXPR" , 68 : "CLOSE_SEXPR" , 72 : "ID" , 73 : "EQUALS" , 75 : "OPEN_BLOCK_PARAMS" , 77 : "CLOSE_BLOCK_PARAMS" , 80 : "STRING" , 81 : "NUMBER" , 82 : "BOOLEAN" , 83 : "UNDEFINED" , 84 : "NULL" , 85 : "DATA" , 87 : "SEP" } ,
productions _ : [ 0 , [ 3 , 2 ] , [ 4 , 1 ] , [ 7 , 1 ] , [ 7 , 1 ] , [ 7 , 1 ] , [ 7 , 1 ] , [ 7 , 1 ] , [ 7 , 1 ] , [ 7 , 1 ] , [ 13 , 1 ] , [ 10 , 3 ] , [ 16 , 5 ] , [ 9 , 4 ] , [ 9 , 4 ] , [ 24 , 6 ] , [ 27 , 6 ] , [ 38 , 6 ] , [ 43 , 2 ] , [ 45 , 3 ] , [ 45 , 1 ] , [ 26 , 3 ] , [ 8 , 5 ] , [ 8 , 5 ] , [ 11 , 5 ] , [ 12 , 3 ] , [ 59 , 5 ] , [ 63 , 1 ] , [ 63 , 1 ] , [ 64 , 5 ] , [ 69 , 1 ] , [ 71 , 3 ] , [ 74 , 3 ] , [ 20 , 1 ] , [ 20 , 1 ] , [ 20 , 1 ] , [ 20 , 1 ] , [ 20 , 1 ] , [ 20 , 1 ] , [ 20 , 1 ] , [ 56 , 1 ] , [ 56 , 1 ] , [ 79 , 2 ] , [ 78 , 1 ] , [ 86 , 3 ] , [ 86 , 1 ] , [ 6 , 0 ] , [ 6 , 2 ] , [ 17 , 1 ] , [ 17 , 2 ] , [ 21 , 0 ] , [ 21 , 2 ] , [ 22 , 0 ] , [ 22 , 1 ] , [ 25 , 0 ] , [ 25 , 1 ] , [ 28 , 0 ] , [ 28 , 1 ] , [ 30 , 0 ] , [ 30 , 2 ] , [ 31 , 0 ] , [ 31 , 1 ] , [ 32 , 0 ] , [ 32 , 1 ] , [ 35 , 0 ] , [ 35 , 2 ] , [ 36 , 0 ] , [ 36 , 1 ] , [ 37 , 0 ] , [ 37 , 1 ] , [ 40 , 0 ] , [ 40 , 2 ] , [ 41 , 0 ] , [ 41 , 1 ] , [ 42 , 0 ] , [ 42 , 1 ] , [ 46 , 0 ] , [ 46 , 1 ] , [ 49 , 0 ] , [ 49 , 2 ] , [ 50 , 0 ] , [ 50 , 1 ] , [ 52 , 0 ] , [ 52 , 2 ] , [ 53 , 0 ] , [ 53 , 1 ] , [ 57 , 0 ] , [ 57 , 2 ] , [ 58 , 0 ] , [ 58 , 1 ] , [ 61 , 0 ] , [ 61 , 2 ] , [ 62 , 0 ] , [ 62 , 1 ] , [ 66 , 0 ] , [ 66 , 2 ] , [ 67 , 0 ] , [ 67 , 1 ] , [ 70 , 1 ] , [ 70 , 2 ] , [ 76 , 1 ] , [ 76 , 2 ] ] ,
performAction : function anonymous ( yytext , yyleng , yylineno , yy , yystate , $$ , _$
/**/ ) {
var $0 = $$ . length - 1 ;
switch ( yystate ) {
case 1 :
return $$ [ $0 - 1 ] ;
break ;
case 2 :
this . $ = yy . prepareProgram ( $$ [ $0 ] ) ;
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 . $ = $$ [ $0 ] ;
break ;
case 9 :
this . $ = {
type : 'CommentStatement' ,
value : yy . stripComment ( $$ [ $0 ] ) ,
strip : yy . stripFlags ( $$ [ $0 ] , $$ [ $0 ] ) ,
loc : yy . locInfo ( this . _$ )
} ;
break ;
case 10 :
this . $ = {
type : 'ContentStatement' ,
original : $$ [ $0 ] ,
value : $$ [ $0 ] ,
loc : yy . locInfo ( this . _$ )
} ;
break ;
case 11 :
this . $ = yy . prepareRawBlock ( $$ [ $0 - 2 ] , $$ [ $0 - 1 ] , $$ [ $0 ] , this . _$ ) ;
break ;
case 12 :
this . $ = { path : $$ [ $0 - 3 ] , params : $$ [ $0 - 2 ] , hash : $$ [ $0 - 1 ] } ;
break ;
case 13 :
this . $ = yy . prepareBlock ( $$ [ $0 - 3 ] , $$ [ $0 - 2 ] , $$ [ $0 - 1 ] , $$ [ $0 ] , false , this . _$ ) ;
break ;
case 14 :
this . $ = yy . prepareBlock ( $$ [ $0 - 3 ] , $$ [ $0 - 2 ] , $$ [ $0 - 1 ] , $$ [ $0 ] , true , this . _$ ) ;
break ;
case 15 :
this . $ = { open : $$ [ $0 - 5 ] , 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 . $ = { path : $$ [ $0 - 4 ] , params : $$ [ $0 - 3 ] , hash : $$ [ $0 - 2 ] , blockParams : $$ [ $0 - 1 ] , strip : yy . stripFlags ( $$ [ $0 - 5 ] , $$ [ $0 ] ) } ;
break ;
case 18 :
this . $ = { strip : yy . stripFlags ( $$ [ $0 - 1 ] , $$ [ $0 - 1 ] ) , program : $$ [ $0 ] } ;
break ;
case 19 :
var inverse = yy . prepareBlock ( $$ [ $0 - 2 ] , $$ [ $0 - 1 ] , $$ [ $0 ] , $$ [ $0 ] , false , this . _$ ) ,
program = yy . prepareProgram ( [ inverse ] , $$ [ $0 - 1 ] . loc ) ;
program . chained = true ;
this . $ = { strip : $$ [ $0 - 2 ] . strip , program : program , chain : true } ;
break ;
case 20 :
this . $ = $$ [ $0 ] ;
break ;
case 21 :
this . $ = { path : $$ [ $0 - 1 ] , strip : yy . stripFlags ( $$ [ $0 - 2 ] , $$ [ $0 ] ) } ;
break ;
case 22 :
this . $ = yy . prepareMustache ( $$ [ $0 - 3 ] , $$ [ $0 - 2 ] , $$ [ $0 - 1 ] , $$ [ $0 - 4 ] , yy . stripFlags ( $$ [ $0 - 4 ] , $$ [ $0 ] ) , this . _$ ) ;
break ;
case 23 :
this . $ = yy . prepareMustache ( $$ [ $0 - 3 ] , $$ [ $0 - 2 ] , $$ [ $0 - 1 ] , $$ [ $0 - 4 ] , yy . stripFlags ( $$ [ $0 - 4 ] , $$ [ $0 ] ) , this . _$ ) ;
break ;
case 24 :
this . $ = {
type : 'PartialStatement' ,
name : $$ [ $0 - 3 ] ,
params : $$ [ $0 - 2 ] ,
hash : $$ [ $0 - 1 ] ,
indent : '' ,
strip : yy . stripFlags ( $$ [ $0 - 4 ] , $$ [ $0 ] ) ,
loc : yy . locInfo ( this . _$ )
} ;
break ;
case 25 :
this . $ = yy . preparePartialBlock ( $$ [ $0 - 2 ] , $$ [ $0 - 1 ] , $$ [ $0 ] , this . _$ ) ;
break ;
case 26 :
this . $ = { path : $$ [ $0 - 3 ] , params : $$ [ $0 - 2 ] , hash : $$ [ $0 - 1 ] , strip : yy . stripFlags ( $$ [ $0 - 4 ] , $$ [ $0 ] ) } ;
break ;
case 27 :
this . $ = $$ [ $0 ] ;
break ;
case 28 :
this . $ = $$ [ $0 ] ;
break ;
case 29 :
this . $ = {
type : 'SubExpression' ,
path : $$ [ $0 - 3 ] ,
params : $$ [ $0 - 2 ] ,
hash : $$ [ $0 - 1 ] ,
loc : yy . locInfo ( this . _$ )
} ;
break ;
case 30 :
this . $ = { type : 'Hash' , pairs : $$ [ $0 ] , loc : yy . locInfo ( this . _$ ) } ;
break ;
case 31 :
this . $ = { type : 'HashPair' , key : yy . id ( $$ [ $0 - 2 ] ) , value : $$ [ $0 ] , loc : yy . locInfo ( this . _$ ) } ;
break ;
case 32 :
this . $ = yy . id ( $$ [ $0 - 1 ] ) ;
break ;
case 33 :
this . $ = $$ [ $0 ] ;
break ;
case 34 :
this . $ = $$ [ $0 ] ;
break ;
case 35 :
this . $ = { type : 'StringLiteral' , value : $$ [ $0 ] , original : $$ [ $0 ] , loc : yy . locInfo ( this . _$ ) } ;
break ;
case 36 :
this . $ = { type : 'NumberLiteral' , value : Number ( $$ [ $0 ] ) , original : Number ( $$ [ $0 ] ) , loc : yy . locInfo ( this . _$ ) } ;
break ;
case 37 :
this . $ = { type : 'BooleanLiteral' , value : $$ [ $0 ] === 'true' , original : $$ [ $0 ] === 'true' , loc : yy . locInfo ( this . _$ ) } ;
break ;
case 38 :
this . $ = { type : 'UndefinedLiteral' , original : undefined , value : undefined , loc : yy . locInfo ( this . _$ ) } ;
break ;
case 39 :
this . $ = { type : 'NullLiteral' , original : null , value : null , loc : yy . locInfo ( this . _$ ) } ;
break ;
case 40 :
this . $ = $$ [ $0 ] ;
break ;
case 41 :
this . $ = $$ [ $0 ] ;
break ;
case 42 :
this . $ = yy . preparePath ( true , $$ [ $0 ] , this . _$ ) ;
break ;
case 43 :
this . $ = yy . preparePath ( false , $$ [ $0 ] , this . _$ ) ;
break ;
case 44 :
$$ [ $0 - 2 ] . push ( { part : yy . id ( $$ [ $0 ] ) , original : $$ [ $0 ] , separator : $$ [ $0 - 1 ] } ) ; this . $ = $$ [ $0 - 2 ] ;
break ;
case 45 :
this . $ = [ { part : yy . id ( $$ [ $0 ] ) , original : $$ [ $0 ] } ] ;
break ;
case 46 :
this . $ = [ ] ;
break ;
case 47 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 48 :
this . $ = [ $$ [ $0 ] ] ;
break ;
case 49 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 50 :
this . $ = [ ] ;
break ;
case 51 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 58 :
this . $ = [ ] ;
break ;
case 59 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 64 :
this . $ = [ ] ;
break ;
case 65 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 70 :
this . $ = [ ] ;
break ;
case 71 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 78 :
this . $ = [ ] ;
break ;
case 79 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 82 :
this . $ = [ ] ;
break ;
case 83 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 86 :
this . $ = [ ] ;
break ;
case 87 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 90 :
this . $ = [ ] ;
break ;
case 91 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 94 :
this . $ = [ ] ;
break ;
case 95 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 98 :
this . $ = [ $$ [ $0 ] ] ;
break ;
case 99 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
case 100 :
this . $ = [ $$ [ $0 ] ] ;
break ;
case 101 :
$$ [ $0 - 1 ] . push ( $$ [ $0 ] ) ;
break ;
}
} ,
table : [ { 3 : 1 , 4 : 2 , 5 : [ 2 , 46 ] , 6 : 3 , 14 : [ 2 , 46 ] , 15 : [ 2 , 46 ] , 19 : [ 2 , 46 ] , 29 : [ 2 , 46 ] , 34 : [ 2 , 46 ] , 48 : [ 2 , 46 ] , 51 : [ 2 , 46 ] , 55 : [ 2 , 46 ] , 60 : [ 2 , 46 ] } , { 1 : [ 3 ] } , { 5 : [ 1 , 4 ] } , { 5 : [ 2 , 2 ] , 7 : 5 , 8 : 6 , 9 : 7 , 10 : 8 , 11 : 9 , 12 : 10 , 13 : 11 , 14 : [ 1 , 12 ] , 15 : [ 1 , 20 ] , 16 : 17 , 19 : [ 1 , 23 ] , 24 : 15 , 27 : 16 , 29 : [ 1 , 21 ] , 34 : [ 1 , 22 ] , 39 : [ 2 , 2 ] , 44 : [ 2 , 2 ] , 47 : [ 2 , 2 ] , 48 : [ 1 , 13 ] , 51 : [ 1 , 14 ] , 55 : [ 1 , 18 ] , 59 : 19 , 60 : [ 1 , 24 ] } , { 1 : [ 2 , 1 ] } , { 5 : [ 2 , 47 ] , 14 : [ 2 , 47 ] , 15 : [ 2 , 47 ] , 19 : [ 2 , 47 ] , 29 : [ 2 , 47 ] , 34 : [ 2 , 47 ] , 39 : [ 2 , 47 ] , 44 : [ 2 , 47 ] , 47 : [ 2 , 47 ] , 48 : [ 2 , 47 ] , 51 : [ 2 , 47 ] , 55 : [ 2 , 47 ] , 60 : [ 2 , 47 ] } , { 5 : [ 2 , 3 ] , 14 : [ 2 , 3 ] , 15 : [ 2 , 3 ] , 19 : [ 2 , 3 ] , 29 : [ 2 , 3 ] , 34 : [ 2 , 3 ] , 39 : [ 2 , 3 ] , 44 : [ 2 , 3 ] , 47 : [ 2 , 3 ] , 48 : [ 2 , 3 ] , 51 : [ 2 , 3 ] , 55 : [ 2 , 3 ] , 60 : [ 2 , 3 ] } , { 5 : [ 2 , 4 ] , 14 : [ 2 , 4 ] , 15 : [ 2 , 4 ] , 19 : [ 2 , 4 ] , 29 : [ 2 , 4 ] , 34 : [ 2 , 4 ] , 39 : [ 2 , 4 ] , 44 : [ 2 , 4 ] , 47 : [ 2 , 4 ] , 48 : [ 2 , 4 ] , 51 : [ 2 , 4 ] , 55 : [ 2 , 4 ] , 60 : [ 2 , 4 ] } , { 5 : [ 2 , 5 ] , 14 : [ 2 , 5 ] , 15 : [ 2 , 5 ] , 19 : [ 2 , 5 ] , 29 : [ 2 , 5 ] , 34 : [ 2 , 5 ] , 39 : [ 2 , 5 ] , 44 : [ 2 , 5 ] , 47 : [ 2 , 5 ] , 48 : [ 2 , 5 ] , 51 : [ 2 , 5 ] , 55 : [ 2 , 5 ] , 60 : [ 2 , 5 ] } , { 5 : [ 2 , 6 ] , 14 : [ 2 , 6 ] , 15 : [ 2 , 6 ] , 19 : [ 2 , 6 ] , 29 : [ 2 , 6 ] , 34 : [ 2 , 6 ] , 39 : [ 2 , 6 ] , 44 : [ 2 , 6 ] , 47 : [ 2 , 6 ] , 48 : [ 2 , 6 ] , 51 : [ 2 , 6 ] , 55 : [ 2 , 6 ] , 60 : [ 2 , 6 ] } , { 5 : [ 2 , 7 ] , 14 : [ 2 , 7 ] , 15 : [ 2 , 7 ] , 19 : [ 2 , 7 ] , 29 : [ 2 , 7 ] , 34 : [ 2 , 7 ] , 39 : [ 2 , 7 ] , 44 : [ 2 , 7 ] , 47 : [ 2 , 7 ] , 48 : [ 2 , 7 ] , 51 : [ 2 , 7 ] , 55 : [ 2 , 7 ] , 60 : [ 2 , 7 ] } , { 5 : [ 2 , 8 ] , 14 : [ 2 , 8 ] , 15 : [ 2 , 8 ] , 19 : [ 2 , 8 ] , 29 : [ 2 , 8 ] , 34 : [ 2 , 8 ] , 39 : [ 2 , 8 ] , 44 : [ 2 , 8 ] , 47 : [ 2 , 8 ] , 48 : [ 2 , 8 ] , 51 : [ 2 , 8 ] , 55 : [ 2 , 8 ] , 60 : [ 2 , 8 ] } , { 5 : [ 2 , 9 ] , 14 : [ 2 , 9 ] , 15 : [ 2 , 9 ] , 19 : [ 2 , 9 ] , 29 : [ 2 , 9 ] , 34 : [ 2 , 9 ] , 39 : [ 2 , 9 ] , 44 : [ 2 , 9 ] , 47 : [ 2 , 9 ] , 48 : [ 2 , 9 ] , 51 : [ 2 , 9 ] , 55 : [ 2 , 9 ] , 60 : [ 2 , 9 ] } , { 20 : 25 , 72 : [ 1 , 35 ] , 78 : 26 , 79 : 27 , 80 : [ 1 , 28 ] , 81 : [ 1 , 29 ] , 82 : [ 1 , 30 ] , 83 : [ 1 , 31 ] , 84 : [ 1 , 32 ] , 85 : [ 1 , 34 ] , 86 : 33 } , { 20 : 36 , 72 : [ 1 , 35 ] , 78 : 26 , 79 : 27 , 80 : [ 1 , 28 ] , 81 : [ 1 , 29 ] , 82 : [ 1 , 30 ] , 83 : [ 1 , 31 ] , 84 : [ 1 , 32 ] , 85 : [ 1 , 34 ] , 86 : 33 } , { 4 : 37 , 6 : 3 , 14 : [ 2 , 46 ] , 15 : [ 2 , 46 ] , 19 : [ 2 , 46 ] , 29 : [ 2 , 46 ] , 34 : [ 2 , 46 ] , 39 : [ 2 , 46 ] , 44 : [ 2 , 46 ] , 47 : [ 2 , 46 ] , 48 : [ 2 , 46 ] , 51 : [ 2 , 46 ] , 55 : [ 2 , 46 ] , 60 : [ 2 , 46 ] } , { 4 : 38 , 6 : 3 , 14 : [ 2 , 46 ] , 15 : [ 2 , 46 ] , 19 : [ 2 , 46 ] , 29 : [ 2 , 46 ] , 34 : [ 2 , 46 ] , 44 : [ 2 , 46 ] , 47 : [ 2 , 46 ] , 48 : [ 2 , 46 ] , 51 : [ 2 , 46 ] , 55 : [ 2 , 46 ] , 60 : [ 2 , 46 ] } , { 13 : 40 , 15 : [ 1 , 20 ] , 17 : 39 } , { 20 : 42 , 56 : 41 , 64 : 43 , 65 : [ 1 , 44 ] , 72 : [ 1 , 35 ] , 78 : 26 , 79 : 27 , 80 : [ 1 , 28 ] , 81 : [ 1 , 29 ] , 82 : [ 1 , 30 ] , 83 : [ 1 , 31 ] , 84 : [ 1 , 32 ] , 85 : [ 1 , 34 ] , 86 : 33 } , { 4 : 45 , 6 : 3 , 14 : [ 2 , 46 ] , 15 : [ 2 , 46 ] , 19 : [ 2 , 46 ] , 29 : [ 2 , 46 ] , 34 : [ 2 , 46 ] , 47 : [ 2 , 46 ] , 48 : [ 2 , 46 ] , 51 : [ 2 , 46 ] , 55 : [ 2 , 46 ] , 60 : [ 2 , 46 ] } , { 5 : [ 2 , 10 ] , 14 : [ 2 , 10 ] , 15 : [ 2 , 10 ] , 18 : [ 2 , 10 ] , 19 : [ 2 , 10 ] , 29 : [ 2 , 10 ] , 34 : [ 2 , 10 ] , 39 : [ 2 , 10 ] , 44 : [ 2 , 10 ] , 47 : [ 2 , 10 ] , 48 : [ 2 , 10 ] , 51 : [ 2 , 10 ] , 55 : [ 2 , 10 ] , 60 : [ 2 , 10 ] } , { 20 : 46 , 72 : [ 1 , 35 ] , 78 : 26 , 79 : 27 , 80 : [ 1 , 28 ] , 81 : [ 1 , 29 ] , 82 : [ 1 , 30 ] , 83 : [ 1 , 31 ] , 84 : [ 1 , 32 ] , 85 : [ 1 , 34 ] , 86 : 33 } , { 20 : 47 , 72 : [ 1 , 35 ] , 78 : 26 , 79 : 27 , 80 : [ 1 , 28 ] , 81 : [ 1 , 29 ] , 82 : [ 1 , 30 ] , 83 : [ 1 , 31 ] , 84 : [ 1 , 32 ] , 85 : [ 1 , 34 ] , 86 : 33 } , { 20 : 48 , 72 : [ 1 , 35 ] , 78 : 26 , 79 : 27 , 80 : [ 1 , 28 ] , 81 : [ 1 , 29 ] , 82 : [ 1 , 30 ] , 83 : [ 1 , 31 ] , 84 : [ 1 , 32 ] , 85 : [ 1 , 34 ] , 86 : 33 } , { 20 : 42 , 56 : 49 , 64 : 43 , 65 : [ 1 , 44 ] , 72 : [ 1 , 35 ] , 78 : 26 , 79 : 27 , 80 : [ 1 , 28 ] , 81 : [ 1 , 29 ] , 82 : [ 1 , 30 ] , 83 : [ 1 , 31 ] , 84 : [ 1 , 32 ] , 85 : [ 1 , 34 ] , 86 : 33 } , { 33 : [ 2 , 78 ] , 49 : 50 , 65 : [ 2 , 78 ] , 72 : [ 2 , 78 ] , 80 : [ 2 , 78 ] , 81 : [ 2 , 78 ] , 82 : [ 2 , 78 ] , 83 : [ 2 , 78 ] , 84 : [ 2 , 78 ] , 85 : [ 2 , 78 ] } , { 23 : [ 2 , 33 ] , 33 : [ 2 , 33 ] , 54 : [ 2 , 33 ] , 65 : [ 2 , 33 ] , 68 : [ 2 , 33 ] , 72 : [ 2 , 33 ] , 75 : [ 2 , 33 ] , 80 : [ 2 , 33 ] , 81 : [ 2 , 33 ] , 82 : [ 2 , 33 ] , 83 : [ 2 , 33 ] , 84 : [ 2 , 33 ] , 85 : [ 2 , 33 ] } , { 23 : [ 2 , 34 ] , 33 : [ 2 , 34 ] , 54 : [ 2 , 34 ] , 65 : [ 2 , 34 ] , 68 : [ 2 , 34 ] , 72 : [ 2 , 34 ] , 75 : [ 2 , 34 ] , 80 : [ 2 , 34 ] , 81 : [ 2 , 34 ] , 82 : [ 2 , 34 ] , 83 : [ 2 , 34 ] , 84 : [ 2 , 34 ] , 85 : [ 2 , 34 ] } , { 23 : [ 2 , 35 ] , 33 : [ 2 , 35 ] , 54 : [ 2 , 35 ] , 65 : [ 2 , 35 ] , 68 : [ 2 , 35 ] , 72 : [ 2 , 35 ] , 75 : [ 2 , 35 ] , 80 : [ 2 , 35 ] , 81 : [ 2 , 35 ] , 82 : [ 2 , 35 ] , 83 : [ 2 , 35 ] , 84 : [ 2 , 35 ] , 85 : [ 2 , 35 ] } , { 23 : [ 2 , 36 ] , 33 : [ 2 , 36 ] , 54 : [ 2 , 36 ] , 65 : [ 2 , 36 ] , 68 : [
defaultActions : { 4 : [ 2 , 1 ] , 55 : [ 2 , 55 ] , 57 : [ 2 , 20 ] , 61 : [ 2 , 57 ] , 74 : [ 2 , 81 ] , 83 : [ 2 , 85 ] , 87 : [ 2 , 18 ] , 91 : [ 2 , 89 ] , 102 : [ 2 , 53 ] , 105 : [ 2 , 93 ] , 111 : [ 2 , 19 ] , 112 : [ 2 , 77 ] , 117 : [ 2 , 97 ] , 120 : [ 2 , 63 ] , 123 : [ 2 , 69 ] , 124 : [ 2 , 12 ] , 136 : [ 2 , 75 ] , 137 : [ 2 , 32 ] } ,
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 15 ;
break ;
case 1 :
return 15 ;
break ;
case 2 :
this . popState ( ) ;
return 15 ;
break ;
case 3 :
this . begin ( 'raw' ) ; return 15 ;
break ;
case 4 :
this . popState ( ) ;
// Should be using `this.topState()` below, but it currently
// returns the second top instead of the first top. Opened an
// issue about it at https://github.com/zaach/jison/issues/291
if ( this . conditionStack [ this . conditionStack . length - 1 ] === 'raw' ) {
return 15 ;
} else {
yy _ . yytext = yy _ . yytext . substr ( 5 , yy _ . yyleng - 9 ) ;
return 'END_RAW_BLOCK' ;
}
break ;
case 5 :
return 15 ;
break ;
case 6 :
this . popState ( ) ;
return 14 ;
break ;
case 7 :
return 65 ;
break ;
case 8 :
return 68 ;
break ;
case 9 :
return 19 ;
break ;
case 10 :
this . popState ( ) ;
this . begin ( 'raw' ) ;
return 23 ;
break ;
case 11 :
return 55 ;
break ;
case 12 :
return 60 ;
break ;
case 13 :
return 29 ;
break ;
case 14 :
return 47 ;
break ;
case 15 :
this . popState ( ) ; return 44 ;
break ;
case 16 :
this . popState ( ) ; return 44 ;
break ;
case 17 :
return 34 ;
break ;
case 18 :
return 39 ;
break ;
case 19 :
return 51 ;
break ;
case 20 :
return 48 ;
break ;
case 21 :
this . unput ( yy _ . yytext ) ;
this . popState ( ) ;
this . begin ( 'com' ) ;
break ;
case 22 :
this . popState ( ) ;
return 14 ;
break ;
case 23 :
return 48 ;
break ;
case 24 :
return 73 ;
break ;
case 25 :
return 72 ;
break ;
case 26 :
return 72 ;
break ;
case 27 :
return 87 ;
break ;
case 28 :
// ignore whitespace
break ;
case 29 :
this . popState ( ) ; return 54 ;
break ;
case 30 :
this . popState ( ) ; return 33 ;
break ;
case 31 :
yy _ . yytext = strip ( 1 , 2 ) . replace ( /\\"/g , '"' ) ; return 80 ;
break ;
case 32 :
yy _ . yytext = strip ( 1 , 2 ) . replace ( /\\'/g , "'" ) ; return 80 ;
break ;
case 33 :
return 85 ;
break ;
case 34 :
return 82 ;
break ;
case 35 :
return 82 ;
break ;
case 36 :
return 83 ;
break ;
case 37 :
return 84 ;
break ;
case 38 :
return 81 ;
break ;
case 39 :
return 75 ;
break ;
case 40 :
return 77 ;
break ;
case 41 :
return 72 ;
break ;
case 42 :
yy _ . yytext = yy _ . yytext . replace ( /\\([\\\]])/g , '$1' ) ; return 72 ;
break ;
case 43 :
return 'INVALID' ;
break ;
case 44 :
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" : [ 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 , 43 , 44 ] , "inclusive" : false } , "emu" : { "rules" : [ 2 ] , "inclusive" : false } , "com" : { "rules" : [ 6 ] , "inclusive" : false } , "raw" : { "rules" : [ 3 , 4 , 5 ] , "inclusive" : false } , "INITIAL" : { "rules" : [ 0 , 1 , 44 ] , "inclusive" : true } } ;
return lexer ;
} ) ( ) ;
parser . lexer = lexer ;
function Parser ( ) {
this . yy = { } ;
} Parser . prototype = parser ; parser . Parser = Parser ;
return new Parser ( ) ;
} ) ( ) ; exports . _ _esModule = true ;
exports [ 'default' ] = handlebars ;
/***/ } ,
/* 24 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireDefault = _ _webpack _require _ _ ( 1 ) [ 'default' ] ;
exports . _ _esModule = true ;
var _visitor = _ _webpack _require _ _ ( 25 ) ;
var _visitor2 = _interopRequireDefault ( _visitor ) ;
function WhitespaceControl ( ) {
var options = arguments . length <= 0 || arguments [ 0 ] === undefined ? { } : arguments [ 0 ] ;
this . options = options ;
}
WhitespaceControl . prototype = new _visitor2 [ 'default' ] ( ) ;
WhitespaceControl . prototype . Program = function ( program ) {
var doStandalone = ! this . options . ignoreStandalone ;
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 ( doStandalone && 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 ( doStandalone && openStandalone ) {
omitRight ( ( current . program || current . inverse ) . body ) ;
// Strip out the previous content node if it's whitespace only
omitLeft ( body , i ) ;
}
if ( doStandalone && closeStandalone ) {
// Always strip the next node
omitRight ( body , i ) ;
omitLeft ( ( current . inverse || current . program ) . body ) ;
}
}
return program ;
} ;
WhitespaceControl . prototype . BlockStatement = WhitespaceControl . prototype . DecoratorBlock = WhitespaceControl . prototype . PartialBlockStatement = 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 ( ! this . options . ignoreStandalone && 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 . Decorator = 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' ] ;
/***/ } ,
/* 25 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireDefault = _ _webpack _require _ _ ( 1 ) [ 'default' ] ;
exports . _ _esModule = true ;
var _exception = _ _webpack _require _ _ ( 6 ) ;
var _exception2 = _interopRequireDefault ( _exception ) ;
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: This may have a few false positives for type for the helper
// methods but will generally do the right thing without a lot of overhead.
if ( value && ! Visitor . prototype [ 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 ;
}
/* istanbul ignore next: Sanity code */
if ( ! this [ object . type ] ) {
throw new _exception2 [ 'default' ] ( 'Unknown type: ' + object . type , object ) ;
}
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 : visitSubExpression ,
Decorator : visitSubExpression ,
BlockStatement : visitBlock ,
DecoratorBlock : visitBlock ,
PartialStatement : visitPartial ,
PartialBlockStatement : function PartialBlockStatement ( partial ) {
visitPartial . call ( this , partial ) ;
this . acceptKey ( partial , 'program' ) ;
} ,
ContentStatement : function ContentStatement ( ) /* content */ { } ,
CommentStatement : function CommentStatement ( ) /* comment */ { } ,
SubExpression : visitSubExpression ,
PathExpression : function PathExpression ( ) /* path */ { } ,
StringLiteral : function StringLiteral ( ) /* string */ { } ,
NumberLiteral : function NumberLiteral ( ) /* number */ { } ,
BooleanLiteral : function BooleanLiteral ( ) /* bool */ { } ,
UndefinedLiteral : function UndefinedLiteral ( ) /* literal */ { } ,
NullLiteral : function NullLiteral ( ) /* literal */ { } ,
Hash : function Hash ( hash ) {
this . acceptArray ( hash . pairs ) ;
} ,
HashPair : function HashPair ( pair ) {
this . acceptRequired ( pair , 'value' ) ;
}
} ;
function visitSubExpression ( mustache ) {
this . acceptRequired ( mustache , 'path' ) ;
this . acceptArray ( mustache . params ) ;
this . acceptKey ( mustache , 'hash' ) ;
}
function visitBlock ( block ) {
visitSubExpression . call ( this , block ) ;
this . acceptKey ( block , 'program' ) ;
this . acceptKey ( block , 'inverse' ) ;
}
function visitPartial ( partial ) {
this . acceptRequired ( partial , 'name' ) ;
this . acceptArray ( partial . params ) ;
this . acceptKey ( partial , 'hash' ) ;
}
exports [ 'default' ] = Visitor ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 26 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireDefault = _ _webpack _require _ _ ( 1 ) [ '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 ;
exports . prepareProgram = prepareProgram ;
exports . preparePartialBlock = preparePartialBlock ;
var _exception = _ _webpack _require _ _ ( 6 ) ;
var _exception2 = _interopRequireDefault ( _exception ) ;
function validateClose ( open , close ) {
close = close . path ? close . path . original : close ;
if ( open . path . original !== close ) {
var errorNode = { loc : open . path . loc } ;
throw new _exception2 [ 'default' ] ( open . path . original + " doesn't match " + close , errorNode ) ;
}
}
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 , loc ) {
loc = this . locInfo ( loc ) ;
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 : loc } ) ;
} else if ( part === '..' ) {
depth ++ ;
depthString += '../' ;
}
} else {
dig . push ( part ) ;
}
}
return {
type : 'PathExpression' ,
data : data ,
depth : depth ,
parts : dig ,
original : original ,
loc : loc
} ;
}
function prepareMustache ( path , params , hash , open , strip , locInfo ) {
// Must use charAt to support IE pre-10
var escapeFlag = open . charAt ( 3 ) || open . charAt ( 2 ) ,
escaped = escapeFlag !== '{' && escapeFlag !== '&' ;
var decorator = /\*/ . test ( open ) ;
return {
type : decorator ? 'Decorator' : 'MustacheStatement' ,
path : path ,
params : params ,
hash : hash ,
escaped : escaped ,
strip : strip ,
loc : this . locInfo ( locInfo )
} ;
}
function prepareRawBlock ( openRawBlock , contents , close , locInfo ) {
validateClose ( openRawBlock , close ) ;
locInfo = this . locInfo ( locInfo ) ;
var program = {
type : 'Program' ,
body : contents ,
strip : { } ,
loc : locInfo
} ;
return {
type : 'BlockStatement' ,
path : openRawBlock . path ,
params : openRawBlock . params ,
hash : openRawBlock . hash ,
program : program ,
openStrip : { } ,
inverseStrip : { } ,
closeStrip : { } ,
loc : locInfo
} ;
}
function prepareBlock ( openBlock , program , inverseAndProgram , close , inverted , locInfo ) {
if ( close && close . path ) {
validateClose ( openBlock , close ) ;
}
var decorator = /\*/ . test ( openBlock . open ) ;
program . blockParams = openBlock . blockParams ;
var inverse = undefined ,
inverseStrip = undefined ;
if ( inverseAndProgram ) {
if ( decorator ) {
throw new _exception2 [ 'default' ] ( 'Unexpected inverse block on decorator' , 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 {
type : decorator ? 'DecoratorBlock' : 'BlockStatement' ,
path : openBlock . path ,
params : openBlock . params ,
hash : openBlock . hash ,
program : program ,
inverse : inverse ,
openStrip : openBlock . strip ,
inverseStrip : inverseStrip ,
closeStrip : close && close . strip ,
loc : this . locInfo ( locInfo )
} ;
}
function prepareProgram ( statements , loc ) {
if ( ! loc && statements . length ) {
var firstLoc = statements [ 0 ] . loc ,
lastLoc = statements [ statements . length - 1 ] . loc ;
/* istanbul ignore else */
if ( firstLoc && lastLoc ) {
loc = {
source : firstLoc . source ,
start : {
line : firstLoc . start . line ,
column : firstLoc . start . column
} ,
end : {
line : lastLoc . end . line ,
column : lastLoc . end . column
}
} ;
}
}
return {
type : 'Program' ,
body : statements ,
strip : { } ,
loc : loc
} ;
}
function preparePartialBlock ( open , program , close , locInfo ) {
validateClose ( open , close ) ;
return {
type : 'PartialBlockStatement' ,
name : open . path ,
params : open . params ,
hash : open . hash ,
program : program ,
openStrip : open . strip ,
closeStrip : close && close . strip ,
loc : this . locInfo ( locInfo )
} ;
}
/***/ } ,
/* 27 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
/* eslint-disable new-cap */
'use strict' ;
var _interopRequireDefault = _ _webpack _require _ _ ( 1 ) [ 'default' ] ;
exports . _ _esModule = true ;
exports . Compiler = Compiler ;
exports . precompile = precompile ;
exports . compile = compile ;
var _exception = _ _webpack _require _ _ ( 6 ) ;
var _exception2 = _interopRequireDefault ( _exception ) ;
var _utils = _ _webpack _require _ _ ( 5 ) ;
var _ast = _ _webpack _require _ _ ( 21 ) ;
var _ast2 = _interopRequireDefault ( _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 ) {
/* istanbul ignore else */
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 ) {
/* istanbul ignore next: Sanity code */
if ( ! this [ node . type ] ) {
throw new _exception2 [ 'default' ] ( 'Unknown type: ' + node . type , 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' ) ;
} ,
DecoratorBlock : function DecoratorBlock ( decorator ) {
var program = decorator . program && this . compileProgram ( decorator . program ) ;
var params = this . setupFullMustacheParams ( decorator , program , undefined ) ,
path = decorator . path ;
this . useDecorators = true ;
this . opcode ( 'registerDecorator' , params . length , path . original ) ;
} ,
PartialStatement : function PartialStatement ( partial ) {
this . usePartial = true ;
var program = partial . program ;
if ( program ) {
program = this . compileProgram ( partial . program ) ;
}
var params = partial . params ;
if ( params . length > 1 ) {
throw new _exception2 [ 'default' ] ( 'Unsupported number of partial arguments: ' + params . length , partial ) ;
} else if ( ! params . length ) {
if ( this . options . explicitPartialContext ) {
this . opcode ( 'pushLiteral' , 'undefined' ) ;
} else {
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 , program , 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' ) ;
} ,
PartialBlockStatement : function PartialBlockStatement ( partialBlock ) {
this . PartialStatement ( partialBlock ) ;
} ,
MustacheStatement : function MustacheStatement ( mustache ) {
this . SubExpression ( mustache ) ;
if ( mustache . escaped && ! this . options . noEscape ) {
this . opcode ( 'appendEscaped' ) ;
} else {
this . opcode ( 'append' ) ;
}
} ,
Decorator : function Decorator ( decorator ) {
this . DecoratorBlock ( decorator ) ;
} ,
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 ) ;
path . strict = true ;
this . accept ( path ) ;
this . opcode ( 'invokeAmbiguous' , name , isBlock ) ;
} ,
simpleSexpr : function simpleSexpr ( sexpr ) {
var path = sexpr . path ;
path . strict = true ;
this . accept ( 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 . strict = true ;
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 , path . strict ) ;
} else {
this . opcode ( 'lookupOnContext' , path . parts , path . falsy , path . strict , 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 ( /^this(?:\.|$)/ , '' ) . replace ( /^\.\// , '' ) . replace ( /^\.$/ , '' ) ;
}
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 && _utils . 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 , options , env ) {
if ( options === undefined ) options = { } ;
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 ( _utils . isArray ( a ) && _utils . 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 = {
type : 'PathExpression' ,
data : false ,
depth : 0 ,
parts : [ literal . original + '' ] ,
original : literal . original + '' ,
loc : literal . loc
} ;
}
}
/***/ } ,
/* 28 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
'use strict' ;
var _interopRequireDefault = _ _webpack _require _ _ ( 1 ) [ 'default' ] ;
exports . _ _esModule = true ;
var _base = _ _webpack _require _ _ ( 4 ) ;
var _exception = _ _webpack _require _ _ ( 6 ) ;
var _exception2 = _interopRequireDefault ( _exception ) ;
var _utils = _ _webpack _require _ _ ( 5 ) ;
var _codeGen = _ _webpack _require _ _ ( 29 ) ;
var _codeGen2 = _interopRequireDefault ( _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 , '[' , JSON . stringify ( name ) , ']' ] ;
}
} ,
depthedLookup : function depthedLookup ( name ) {
return [ this . aliasable ( 'container.lookup' ) , '(depths, "' , name , '")' ] ;
} ,
compilerInfo : function compilerInfo ( ) {
var revision = _base . COMPILER _REVISION ,
versions = _base . REVISION _CHANGES [ revision ] ;
return [ revision , versions ] ;
} ,
appendToBuffer : function appendToBuffer ( source , location , explicit ) {
// Force a source as this simplifies the merge logic.
if ( ! _utils . 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 || {
decorators : [ ] ,
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 || environment . useDecorators || 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' ) ;
}
if ( ! this . decorators . isEmpty ( ) ) {
this . useDecorators = true ;
this . decorators . prepend ( 'var decorators = container.decorators;\n' ) ;
this . decorators . push ( 'return fn;' ) ;
if ( asObject ) {
this . decorators = Function . apply ( this , [ 'fn' , 'props' , 'container' , 'depth0' , 'data' , 'blockParams' , 'depths' , this . decorators . merge ( ) ] ) ;
} else {
this . decorators . prepend ( 'function(fn, props, container, depth0, data, blockParams, depths) {\n' ) ;
this . decorators . push ( '}\n' ) ;
this . decorators = this . decorators . merge ( ) ;
}
} else {
this . decorators = undefined ;
}
var fn = this . createFunctionContext ( asObject ) ;
if ( ! this . isChild ) {
var ret = {
compiler : this . compilerInfo ( ) ,
main : fn
} ;
if ( this . decorators ) {
ret . main _d = this . decorators ; // eslint-disable-line camelcase
ret . useDecorators = true ;
}
var _context = this . context ;
var programs = _context . programs ;
var decorators = _context . decorators ;
for ( i = 0 , l = programs . length ; i < l ; i ++ ) {
if ( programs [ i ] ) {
ret [ i ] = programs [ i ] ;
if ( decorators [ i ] ) {
ret [ i + '_d' ] = decorators [ i ] ;
ret . useDecorators = true ;
}
}
}
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 ) ;
this . decorators = 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 = [ 'container' , '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 ( 'container.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 , strict , 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 , strict ) ;
} ,
// [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 , strict ) {
if ( ! depth ) {
this . pushStackLiteral ( 'data' ) ;
} else {
this . pushStackLiteral ( 'container.data(data, ' + depth + ')' ) ;
}
this . resolvePath ( 'data' , parts , 0 , true , strict ) ;
} ,
resolvePath : function resolvePath ( type , parts , i , falsy , strict ) {
// istanbul ignore next
var _this = this ;
if ( this . options . strict || this . options . assumeObjects ) {
this . push ( strictLookup ( this . options . strict && 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 ( 'container.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 ) ;
}
} ,
// [registerDecorator]
//
// On stack, before: hash, program, params..., ...
// On stack, after: ...
//
// Pops off the decorator's parameters, invokes the decorator,
// and inserts the decorator into the decorators list.
registerDecorator : function registerDecorator ( paramSize , name ) {
var foundDecorator = this . nameLookup ( 'decorators' , name , 'decorator' ) ,
options = this . setupHelperArgs ( name , paramSize ) ;
this . decorators . push ( [ 'fn = ' , this . decorators . functionCall ( foundDecorator , '' , [ 'fn' , 'props' , 'container' , options ] ) , ' || fn;' ] ) ;
} ,
// [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 ) ;
if ( isDynamic ) {
name = this . popStack ( ) ;
delete options . name ;
}
if ( indent ) {
options . indent = JSON . stringify ( indent ) ;
}
options . helpers = 'helpers' ;
options . partials = 'partials' ;
options . decorators = 'container.decorators' ;
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 ( 'container.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 . decorators [ index ] = compiler . decorators ;
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 'container.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' ) ,
callContext = this . aliasable ( this . contextName ( 0 ) + ' != null ? ' + this . contextName ( 0 ) + ' : {}' ) ;
return {
params : params ,
paramsInit : paramsInit ,
name : foundHelper ,
callParams : [ callContext ] . concat ( params )
} ;
} ,
setupParams : function setupParams ( helper , paramSize , params ) {
var options = { } ,
contexts = [ ] ,
types = [ ] ,
ids = [ ] ,
objectArgs = ! params ,
param = undefined ;
if ( objectArgs ) {
params = [ ] ;
}
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 || 'container.noop' ;
options . inverse = inverse || 'container.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 ( objectArgs ) {
options . args = this . source . generateArray ( params ) ;
}
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 ) ;
options = this . objectLiteral ( options ) ;
if ( useRegister ) {
this . useRegister ( 'options' ) ;
params . push ( 'options' ) ;
return [ 'options=' , options ] ;
} else if ( params ) {
params . push ( options ) ;
return '' ;
} else {
return options ;
}
}
} ;
( 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 ( 'container.strict' ) , '(' , stack , ', ' , compiler . quotedString ( parts [ i ] ) , ')' ] ;
} else {
return stack ;
}
}
exports [ 'default' ] = JavaScriptCompiler ;
module . exports = exports [ 'default' ] ;
/***/ } ,
/* 29 */
/***/ function ( module , exports , _ _webpack _require _ _ ) {
/* global define */
'use strict' ;
exports . _ _esModule = true ;
var _utils = _ _webpack _require _ _ ( 5 ) ;
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 ) { }
/* NOP */
/* 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 ( _utils . isArray ( chunks ) ) {
chunks = chunks . join ( '' ) ;
}
this . src += chunks ;
} ,
prepend : function prepend ( chunks ) {
if ( _utils . 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 ( _utils . 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 = {
isEmpty : function isEmpty ( ) {
return ! this . source . length ;
} ,
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 = this . currentLocation || { start : { } } ;
return new SourceNode ( loc . start . line , loc . start . column , this . srcFile ) ;
} ,
wrap : function wrap ( chunk ) {
var loc = arguments . length <= 1 || 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 ) {
var ret = this . empty ( ) ;
for ( var i = 0 , len = entries . length ; i < len ; i ++ ) {
if ( i ) {
ret . add ( ',' ) ;
}
ret . add ( castChunk ( entries [ i ] , this ) ) ;
}
return ret ;
} ,
generateArray : function generateArray ( entries ) {
var ret = this . generateList ( entries ) ;
ret . prepend ( '[' ) ;
ret . add ( ']' ) ;
return ret ;
}
} ;
exports [ 'default' ] = CodeGen ;
module . exports = exports [ 'default' ] ;
/***/ }
/******/ ] )
} ) ;
2016-04-30 05:29:41 +08:00
;