ember-legacy-class-transform
Version:
The default blueprint for ember-cli addons.
289 lines (249 loc) • 28.8 kB
JavaScript
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
import { CompiledDynamicTemplate } from './compiled/blocks';
import { Ops } from '@glimmer/wire-format';
import { Register, debugSlice } from './opcodes';
import { ATTRS_BLOCK, compileStatement } from './syntax/functions';
import * as ClientSide from './syntax/client-side';
import { expr } from './syntax/functions';
import OpcodeBuilderDSL from './compiled/opcodes/builder';
export function compileLayout(compilable, env) {
var builder = new ComponentLayoutBuilder(env);
compilable.compile(builder);
return builder.compile();
}
var ComponentLayoutBuilder = function () {
function ComponentLayoutBuilder(env) {
_classCallCheck(this, ComponentLayoutBuilder);
this.env = env;
}
ComponentLayoutBuilder.prototype.wrapLayout = function wrapLayout(layout) {
this.inner = new WrappedBuilder(this.env, layout);
};
ComponentLayoutBuilder.prototype.fromLayout = function fromLayout(componentName, layout) {
this.inner = new UnwrappedBuilder(this.env, componentName, layout);
};
ComponentLayoutBuilder.prototype.compile = function compile() {
return this.inner.compile();
};
_createClass(ComponentLayoutBuilder, [{
key: 'tag',
get: function () {
return this.inner.tag;
}
}, {
key: 'attrs',
get: function () {
return this.inner.attrs;
}
}]);
return ComponentLayoutBuilder;
}();
var WrappedBuilder = function () {
function WrappedBuilder(env, layout) {
_classCallCheck(this, WrappedBuilder);
this.env = env;
this.layout = layout;
this.tag = new ComponentTagBuilder();
this.attrs = new ComponentAttrsBuilder();
}
WrappedBuilder.prototype.compile = function compile() {
//========DYNAMIC
// PutValue(TagExpr)
// Test
// JumpUnless(BODY)
// OpenDynamicPrimitiveElement
// DidCreateElement
// ...attr statements...
// FlushElement
// BODY: Noop
// ...body statements...
// PutValue(TagExpr)
// Test
// JumpUnless(END)
// CloseElement
// END: Noop
// DidRenderLayout
// Exit
//
//========STATIC
// OpenPrimitiveElementOpcode
// DidCreateElement
// ...attr statements...
// FlushElement
// ...body statements...
// CloseElement
// DidRenderLayout
// Exit
var env = this.env,
layout = this.layout;
var meta = { templateMeta: layout.meta, symbols: layout.symbols, asPartial: false };
var dynamicTag = this.tag.getDynamic();
var staticTag = this.tag.getStatic();
var b = builder(env, meta);
b.startLabels();
if (dynamicTag) {
b.fetch(Register.s1);
expr(dynamicTag, b);
b.dup();
b.load(Register.s1);
b.test('simple');
b.jumpUnless('BODY');
b.fetch(Register.s1);
b.pushComponentOperations();
b.openDynamicElement();
} else if (staticTag) {
b.pushComponentOperations();
b.openElementWithOperations(staticTag);
}
if (dynamicTag || staticTag) {
b.didCreateElement(Register.s0);
var attrs = this.attrs.buffer;
for (var i = 0; i < attrs.length; i++) {
compileStatement(attrs[i], b);
}
b.flushElement();
}
b.label('BODY');
b.invokeStatic(layout.asBlock());
if (dynamicTag) {
b.fetch(Register.s1);
b.test('simple');
b.jumpUnless('END');
b.closeElement();
} else if (staticTag) {
b.closeElement();
}
b.label('END');
b.didRenderLayout(Register.s0);
if (dynamicTag) {
b.load(Register.s1);
}
b.stopLabels();
var start = b.start;
var end = b.finalize();
if (false) {
debugSlice(env, env.program.heap.getaddr(start), env.program.heap.getaddr(end));
}
return new CompiledDynamicTemplate(start, {
meta: meta,
hasEval: layout.hasEval,
symbols: layout.symbols.concat([ATTRS_BLOCK])
});
};
return WrappedBuilder;
}();
var UnwrappedBuilder = function () {
function UnwrappedBuilder(env, componentName, layout) {
_classCallCheck(this, UnwrappedBuilder);
this.env = env;
this.componentName = componentName;
this.layout = layout;
this.attrs = new ComponentAttrsBuilder();
}
UnwrappedBuilder.prototype.compile = function compile() {
var env = this.env,
layout = this.layout;
return layout.asLayout(this.componentName, this.attrs.buffer).compileDynamic(env);
};
_createClass(UnwrappedBuilder, [{
key: 'tag',
get: function () {
throw new Error('BUG: Cannot call `tag` on an UnwrappedBuilder');
}
}]);
return UnwrappedBuilder;
}();
var ComponentTagBuilder = function () {
function ComponentTagBuilder() {
_classCallCheck(this, ComponentTagBuilder);
this.isDynamic = null;
this.isStatic = null;
this.staticTagName = null;
this.dynamicTagName = null;
}
ComponentTagBuilder.prototype.getDynamic = function getDynamic() {
if (this.isDynamic) {
return this.dynamicTagName;
}
};
ComponentTagBuilder.prototype.getStatic = function getStatic() {
if (this.isStatic) {
return this.staticTagName;
}
};
ComponentTagBuilder.prototype.static = function _static(tagName) {
this.isStatic = true;
this.staticTagName = tagName;
};
ComponentTagBuilder.prototype.dynamic = function dynamic(tagName) {
this.isDynamic = true;
this.dynamicTagName = [Ops.ClientSideExpression, ClientSide.Ops.FunctionExpression, tagName];
};
return ComponentTagBuilder;
}();
var ComponentAttrsBuilder = function () {
function ComponentAttrsBuilder() {
_classCallCheck(this, ComponentAttrsBuilder);
this.buffer = [];
}
ComponentAttrsBuilder.prototype.static = function _static(name, value) {
this.buffer.push([Ops.StaticAttr, name, value, null]);
};
ComponentAttrsBuilder.prototype.dynamic = function dynamic(name, value) {
this.buffer.push([Ops.DynamicAttr, name, [Ops.ClientSideExpression, ClientSide.Ops.FunctionExpression, value], null]);
};
return ComponentAttrsBuilder;
}();
export var ComponentBuilder = function () {
function ComponentBuilder(builder) {
_classCallCheck(this, ComponentBuilder);
this.builder = builder;
this.env = builder.env;
}
ComponentBuilder.prototype.static = function _static(definition, args) {
var params = args[0],
hash = args[1],
_default = args[2],
inverse = args[3];
var builder = this.builder;
builder.pushComponentManager(definition);
builder.invokeComponent(null, params, hash, _default, inverse);
};
ComponentBuilder.prototype.dynamic = function dynamic(definitionArgs, getDefinition, args) {
var params = args[0],
hash = args[1],
block = args[2],
inverse = args[3];
var builder = this.builder;
if (!definitionArgs || definitionArgs.length === 0) {
throw new Error("Dynamic syntax without an argument");
}
var meta = this.builder.meta.templateMeta;
function helper(vm, a) {
return getDefinition(vm, a, meta);
}
builder.startLabels();
builder.pushFrame();
builder.returnTo('END');
builder.compileArgs(definitionArgs[0], definitionArgs[1], true);
builder.helper(helper);
builder.dup();
builder.test('simple');
builder.enter(2);
builder.jumpUnless('ELSE');
builder.pushDynamicComponentManager();
builder.invokeComponent(null, params, hash, block, inverse);
builder.label('ELSE');
builder.exit();
builder.return();
builder.label('END');
builder.popFrame();
builder.stopLabels();
};
return ComponentBuilder;
}();
export function builder(env, meta) {
return new OpcodeBuilderDSL(env, meta);
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["lib/compiler.js"],"names":["CompiledDynamicTemplate","Ops","Register","debugSlice","ATTRS_BLOCK","compileStatement","ClientSide","expr","OpcodeBuilderDSL","compileLayout","compilable","env","builder","ComponentLayoutBuilder","compile","wrapLayout","layout","inner","WrappedBuilder","fromLayout","componentName","UnwrappedBuilder","tag","attrs","ComponentTagBuilder","ComponentAttrsBuilder","meta","templateMeta","symbols","asPartial","dynamicTag","getDynamic","staticTag","getStatic","b","startLabels","fetch","s1","dup","load","test","jumpUnless","pushComponentOperations","openDynamicElement","openElementWithOperations","didCreateElement","s0","buffer","i","length","flushElement","label","invokeStatic","asBlock","closeElement","didRenderLayout","stopLabels","start","end","finalize","program","heap","getaddr","hasEval","concat","asLayout","compileDynamic","Error","isDynamic","isStatic","staticTagName","dynamicTagName","static","tagName","dynamic","ClientSideExpression","FunctionExpression","name","value","push","StaticAttr","DynamicAttr","ComponentBuilder","definition","args","params","hash","_default","inverse","pushComponentManager","invokeComponent","definitionArgs","getDefinition","block","helper","vm","a","pushFrame","returnTo","compileArgs","enter","pushDynamicComponentManager","exit","return","popFrame"],"mappings":";;;;AAAA,SAASA,uBAAT,QAAwC,mBAAxC;AACA,SAASC,GAAT,QAAoB,sBAApB;AACA,SAASC,QAAT,EAAmBC,UAAnB,QAAqC,WAArC;AACA,SAASC,WAAT,EAAsBC,gBAAtB,QAA8C,oBAA9C;AACA,OAAO,KAAKC,UAAZ,MAA4B,sBAA5B;AACA,SAASC,IAAT,QAAqB,oBAArB;AACA,OAAOC,gBAAP,MAA6B,4BAA7B;;AAEA,OAAO,SAASC,aAAT,CAAuBC,UAAvB,EAAmCC,GAAnC,EAAwC;AAC3C,QAAIC,UAAU,IAAIC,sBAAJ,CAA2BF,GAA3B,CAAd;AACAD,eAAWI,OAAX,CAAmBF,OAAnB;AACA,WAAOA,QAAQE,OAAR,EAAP;AACH;;IACKD,sB;AACF,oCAAYF,GAAZ,EAAiB;AAAA;;AACb,aAAKA,GAAL,GAAWA,GAAX;AACH;;qCACDI,U,uBAAWC,M,EAAQ;AACf,aAAKC,KAAL,GAAa,IAAIC,cAAJ,CAAmB,KAAKP,GAAxB,EAA6BK,MAA7B,CAAb;AACH,K;;qCACDG,U,uBAAWC,a,EAAeJ,M,EAAQ;AAC9B,aAAKC,KAAL,GAAa,IAAII,gBAAJ,CAAqB,KAAKV,GAA1B,EAA+BS,aAA/B,EAA8CJ,MAA9C,CAAb;AACH,K;;qCACDF,O,sBAAU;AACN,eAAO,KAAKG,KAAL,CAAWH,OAAX,EAAP;AACH,K;;;;yBACS;AACN,mBAAO,KAAKG,KAAL,CAAWK,GAAlB;AACH;;;yBACW;AACR,mBAAO,KAAKL,KAAL,CAAWM,KAAlB;AACH;;;;;;IAECL,c;AACF,4BAAYP,GAAZ,EAAiBK,MAAjB,EAAyB;AAAA;;AACrB,aAAKL,GAAL,GAAWA,GAAX;AACA,aAAKK,MAAL,GAAcA,MAAd;AACA,aAAKM,GAAL,GAAW,IAAIE,mBAAJ,EAAX;AACA,aAAKD,KAAL,GAAa,IAAIE,qBAAJ,EAAb;AACH;;6BACDX,O,sBAAU;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA3BM,YA4BAH,GA5BA,GA4BgB,IA5BhB,CA4BAA,GA5BA;AAAA,YA4BKK,MA5BL,GA4BgB,IA5BhB,CA4BKA,MA5BL;;AA6BN,YAAIU,OAAO,EAAEC,cAAcX,OAAOU,IAAvB,EAA6BE,SAASZ,OAAOY,OAA7C,EAAsDC,WAAW,KAAjE,EAAX;AACA,YAAIC,aAAa,KAAKR,GAAL,CAASS,UAAT,EAAjB;AACA,YAAIC,YAAY,KAAKV,GAAL,CAASW,SAAT,EAAhB;AACA,YAAIC,IAAItB,QAAQD,GAAR,EAAae,IAAb,CAAR;AACAQ,UAAEC,WAAF;AACA,YAAIL,UAAJ,EAAgB;AACZI,cAAEE,KAAF,CAAQlC,SAASmC,EAAjB;AACA9B,iBAAKuB,UAAL,EAAiBI,CAAjB;AACAA,cAAEI,GAAF;AACAJ,cAAEK,IAAF,CAAOrC,SAASmC,EAAhB;AACAH,cAAEM,IAAF,CAAO,QAAP;AACAN,cAAEO,UAAF,CAAa,MAAb;AACAP,cAAEE,KAAF,CAAQlC,SAASmC,EAAjB;AACAH,cAAEQ,uBAAF;AACAR,cAAES,kBAAF;AACH,SAVD,MAUO,IAAIX,SAAJ,EAAe;AAClBE,cAAEQ,uBAAF;AACAR,cAAEU,yBAAF,CAA4BZ,SAA5B;AACH;AACD,YAAIF,cAAcE,SAAlB,EAA6B;AACzBE,cAAEW,gBAAF,CAAmB3C,SAAS4C,EAA5B;AACA,gBAAIvB,QAAQ,KAAKA,KAAL,CAAWwB,MAAvB;AACA,iBAAK,IAAIC,IAAI,CAAb,EAAgBA,IAAIzB,MAAM0B,MAA1B,EAAkCD,GAAlC,EAAuC;AACnC3C,iCAAiBkB,MAAMyB,CAAN,CAAjB,EAA2Bd,CAA3B;AACH;AACDA,cAAEgB,YAAF;AACH;AACDhB,UAAEiB,KAAF,CAAQ,MAAR;AACAjB,UAAEkB,YAAF,CAAepC,OAAOqC,OAAP,EAAf;AACA,YAAIvB,UAAJ,EAAgB;AACZI,cAAEE,KAAF,CAAQlC,SAASmC,EAAjB;AACAH,cAAEM,IAAF,CAAO,QAAP;AACAN,cAAEO,UAAF,CAAa,KAAb;AACAP,cAAEoB,YAAF;AACH,SALD,MAKO,IAAItB,SAAJ,EAAe;AAClBE,cAAEoB,YAAF;AACH;AACDpB,UAAEiB,KAAF,CAAQ,KAAR;AACAjB,UAAEqB,eAAF,CAAkBrD,SAAS4C,EAA3B;AACA,YAAIhB,UAAJ,EAAgB;AACZI,cAAEK,IAAF,CAAOrC,SAASmC,EAAhB;AACH;AACDH,UAAEsB,UAAF;AACA,YAAIC,QAAQvB,EAAEuB,KAAd;AACA,YAAIC,MAAMxB,EAAEyB,QAAF,EAAV;AACA,YAAI,KAAJ,EAAW;AACPxD,uBAAWQ,GAAX,EAAgBA,IAAIiD,OAAJ,CAAYC,IAAZ,CAAiBC,OAAjB,CAAyBL,KAAzB,CAAhB,EAAiD9C,IAAIiD,OAAJ,CAAYC,IAAZ,CAAiBC,OAAjB,CAAyBJ,GAAzB,CAAjD;AACH;AACD,eAAO,IAAI1D,uBAAJ,CAA4ByD,KAA5B,EAAmC;AACtC/B,sBADsC;AAEtCqC,qBAAS/C,OAAO+C,OAFsB;AAGtCnC,qBAASZ,OAAOY,OAAP,CAAeoC,MAAf,CAAsB,CAAC5D,WAAD,CAAtB;AAH6B,SAAnC,CAAP;AAKH,K;;;;;IAECiB,gB;AACF,8BAAYV,GAAZ,EAAiBS,aAAjB,EAAgCJ,MAAhC,EAAwC;AAAA;;AACpC,aAAKL,GAAL,GAAWA,GAAX;AACA,aAAKS,aAAL,GAAqBA,aAArB;AACA,aAAKJ,MAAL,GAAcA,MAAd;AACA,aAAKO,KAAL,GAAa,IAAIE,qBAAJ,EAAb;AACH;;+BAIDX,O,sBAAU;AAAA,YACAH,GADA,GACgB,IADhB,CACAA,GADA;AAAA,YACKK,MADL,GACgB,IADhB,CACKA,MADL;;AAEN,eAAOA,OAAOiD,QAAP,CAAgB,KAAK7C,aAArB,EAAoC,KAAKG,KAAL,CAAWwB,MAA/C,EAAuDmB,cAAvD,CAAsEvD,GAAtE,CAAP;AACH,K;;;;yBANS;AACN,kBAAM,IAAIwD,KAAJ,CAAU,+CAAV,CAAN;AACH;;;;;;IAMC3C,mB;AACF,mCAAc;AAAA;;AACV,aAAK4C,SAAL,GAAiB,IAAjB;AACA,aAAKC,QAAL,GAAgB,IAAhB;AACA,aAAKC,aAAL,GAAqB,IAArB;AACA,aAAKC,cAAL,GAAsB,IAAtB;AACH;;kCACDxC,U,yBAAa;AACT,YAAI,KAAKqC,SAAT,EAAoB;AAChB,mBAAO,KAAKG,cAAZ;AACH;AACJ,K;;kCACDtC,S,wBAAY;AACR,YAAI,KAAKoC,QAAT,EAAmB;AACf,mBAAO,KAAKC,aAAZ;AACH;AACJ,K;;kCACDE,M,oBAAOC,O,EAAS;AACZ,aAAKJ,QAAL,GAAgB,IAAhB;AACA,aAAKC,aAAL,GAAqBG,OAArB;AACH,K;;kCACDC,O,oBAAQD,O,EAAS;AACb,aAAKL,SAAL,GAAiB,IAAjB;AACA,aAAKG,cAAL,GAAsB,CAACtE,IAAI0E,oBAAL,EAA2BrE,WAAWL,GAAX,CAAe2E,kBAA1C,EAA8DH,OAA9D,CAAtB;AACH,K;;;;;IAEChD,qB;AACF,qCAAc;AAAA;;AACV,aAAKsB,MAAL,GAAc,EAAd;AACH;;oCACDyB,M,oBAAOK,I,EAAMC,K,EAAO;AAChB,aAAK/B,MAAL,CAAYgC,IAAZ,CAAiB,CAAC9E,IAAI+E,UAAL,EAAiBH,IAAjB,EAAuBC,KAAvB,EAA8B,IAA9B,CAAjB;AACH,K;;oCACDJ,O,oBAAQG,I,EAAMC,K,EAAO;AACjB,aAAK/B,MAAL,CAAYgC,IAAZ,CAAiB,CAAC9E,IAAIgF,WAAL,EAAkBJ,IAAlB,EAAwB,CAAC5E,IAAI0E,oBAAL,EAA2BrE,WAAWL,GAAX,CAAe2E,kBAA1C,EAA8DE,KAA9D,CAAxB,EAA8F,IAA9F,CAAjB;AACH,K;;;;;AAEL,WAAaI,gBAAb;AACI,8BAAYtE,OAAZ,EAAqB;AAAA;;AACjB,aAAKA,OAAL,GAAeA,OAAf;AACA,aAAKD,GAAL,GAAWC,QAAQD,GAAnB;AACH;;AAJL,+BAKI6D,MALJ,oBAKWW,UALX,EAKuBC,IALvB,EAK6B;AAAA,YAChBC,MADgB,GACmBD,IADnB;AAAA,YACRE,IADQ,GACmBF,IADnB;AAAA,YACFG,QADE,GACmBH,IADnB;AAAA,YACQI,OADR,GACmBJ,IADnB;AAAA,YAEfxE,OAFe,GAEH,IAFG,CAEfA,OAFe;;AAGrBA,gBAAQ6E,oBAAR,CAA6BN,UAA7B;AACAvE,gBAAQ8E,eAAR,CAAwB,IAAxB,EAA8BL,MAA9B,EAAsCC,IAAtC,EAA4CC,QAA5C,EAAsDC,OAAtD;AACH,KAVL;;AAAA,+BAWId,OAXJ,oBAWYiB,cAXZ,EAW4BC,aAX5B,EAW2CR,IAX3C,EAWiD;AAAA,YACpCC,MADoC,GACJD,IADI;AAAA,YAC5BE,IAD4B,GACJF,IADI;AAAA,YACtBS,KADsB,GACJT,IADI;AAAA,YACfI,OADe,GACJJ,IADI;AAAA,YAEnCxE,OAFmC,GAEvB,IAFuB,CAEnCA,OAFmC;;AAGzC,YAAI,CAAC+E,cAAD,IAAmBA,eAAe1C,MAAf,KAA0B,CAAjD,EAAoD;AAChD,kBAAM,IAAIkB,KAAJ,CAAU,oCAAV,CAAN;AACH;AACD,YAAIzC,OAAO,KAAKd,OAAL,CAAac,IAAb,CAAkBC,YAA7B;AACA,iBAASmE,MAAT,CAAgBC,EAAhB,EAAoBC,CAApB,EAAuB;AACnB,mBAAOJ,cAAcG,EAAd,EAAkBC,CAAlB,EAAqBtE,IAArB,CAAP;AACH;AACDd,gBAAQuB,WAAR;AACAvB,gBAAQqF,SAAR;AACArF,gBAAQsF,QAAR,CAAiB,KAAjB;AACAtF,gBAAQuF,WAAR,CAAoBR,eAAe,CAAf,CAApB,EAAuCA,eAAe,CAAf,CAAvC,EAA0D,IAA1D;AACA/E,gBAAQkF,MAAR,CAAeA,MAAf;AACAlF,gBAAQ0B,GAAR;AACA1B,gBAAQ4B,IAAR,CAAa,QAAb;AACA5B,gBAAQwF,KAAR,CAAc,CAAd;AACAxF,gBAAQ6B,UAAR,CAAmB,MAAnB;AACA7B,gBAAQyF,2BAAR;AACAzF,gBAAQ8E,eAAR,CAAwB,IAAxB,EAA8BL,MAA9B,EAAsCC,IAAtC,EAA4CO,KAA5C,EAAmDL,OAAnD;AACA5E,gBAAQuC,KAAR,CAAc,MAAd;AACAvC,gBAAQ0F,IAAR;AACA1F,gBAAQ2F,MAAR;AACA3F,gBAAQuC,KAAR,CAAc,KAAd;AACAvC,gBAAQ4F,QAAR;AACA5F,gBAAQ4C,UAAR;AACH,KAtCL;;AAAA;AAAA;AAwCA,OAAO,SAAS5C,OAAT,CAAiBD,GAAjB,EAAsBe,IAAtB,EAA4B;AAC/B,WAAO,IAAIlB,gBAAJ,CAAqBG,GAArB,EAA0Be,IAA1B,CAAP;AACH","file":"lib/compiler.js","sourcesContent":["import { CompiledDynamicTemplate } from './compiled/blocks';\nimport { Ops } from '@glimmer/wire-format';\nimport { Register, debugSlice } from './opcodes';\nimport { ATTRS_BLOCK, compileStatement } from './syntax/functions';\nimport * as ClientSide from './syntax/client-side';\nimport { expr } from './syntax/functions';\nimport OpcodeBuilderDSL from './compiled/opcodes/builder';\n\nexport function compileLayout(compilable, env) {\n    let builder = new ComponentLayoutBuilder(env);\n    compilable.compile(builder);\n    return builder.compile();\n}\nclass ComponentLayoutBuilder {\n    constructor(env) {\n        this.env = env;\n    }\n    wrapLayout(layout) {\n        this.inner = new WrappedBuilder(this.env, layout);\n    }\n    fromLayout(componentName, layout) {\n        this.inner = new UnwrappedBuilder(this.env, componentName, layout);\n    }\n    compile() {\n        return this.inner.compile();\n    }\n    get tag() {\n        return this.inner.tag;\n    }\n    get attrs() {\n        return this.inner.attrs;\n    }\n}\nclass WrappedBuilder {\n    constructor(env, layout) {\n        this.env = env;\n        this.layout = layout;\n        this.tag = new ComponentTagBuilder();\n        this.attrs = new ComponentAttrsBuilder();\n    }\n    compile() {\n        //========DYNAMIC\n        //        PutValue(TagExpr)\n        //        Test\n        //        JumpUnless(BODY)\n        //        OpenDynamicPrimitiveElement\n        //        DidCreateElement\n        //        ...attr statements...\n        //        FlushElement\n        // BODY:  Noop\n        //        ...body statements...\n        //        PutValue(TagExpr)\n        //        Test\n        //        JumpUnless(END)\n        //        CloseElement\n        // END:   Noop\n        //        DidRenderLayout\n        //        Exit\n        //\n        //========STATIC\n        //        OpenPrimitiveElementOpcode\n        //        DidCreateElement\n        //        ...attr statements...\n        //        FlushElement\n        //        ...body statements...\n        //        CloseElement\n        //        DidRenderLayout\n        //        Exit\n        let { env, layout } = this;\n        let meta = { templateMeta: layout.meta, symbols: layout.symbols, asPartial: false };\n        let dynamicTag = this.tag.getDynamic();\n        let staticTag = this.tag.getStatic();\n        let b = builder(env, meta);\n        b.startLabels();\n        if (dynamicTag) {\n            b.fetch(Register.s1);\n            expr(dynamicTag, b);\n            b.dup();\n            b.load(Register.s1);\n            b.test('simple');\n            b.jumpUnless('BODY');\n            b.fetch(Register.s1);\n            b.pushComponentOperations();\n            b.openDynamicElement();\n        } else if (staticTag) {\n            b.pushComponentOperations();\n            b.openElementWithOperations(staticTag);\n        }\n        if (dynamicTag || staticTag) {\n            b.didCreateElement(Register.s0);\n            let attrs = this.attrs.buffer;\n            for (let i = 0; i < attrs.length; i++) {\n                compileStatement(attrs[i], b);\n            }\n            b.flushElement();\n        }\n        b.label('BODY');\n        b.invokeStatic(layout.asBlock());\n        if (dynamicTag) {\n            b.fetch(Register.s1);\n            b.test('simple');\n            b.jumpUnless('END');\n            b.closeElement();\n        } else if (staticTag) {\n            b.closeElement();\n        }\n        b.label('END');\n        b.didRenderLayout(Register.s0);\n        if (dynamicTag) {\n            b.load(Register.s1);\n        }\n        b.stopLabels();\n        let start = b.start;\n        let end = b.finalize();\n        if (false) {\n            debugSlice(env, env.program.heap.getaddr(start), env.program.heap.getaddr(end));\n        }\n        return new CompiledDynamicTemplate(start, {\n            meta,\n            hasEval: layout.hasEval,\n            symbols: layout.symbols.concat([ATTRS_BLOCK])\n        });\n    }\n}\nclass UnwrappedBuilder {\n    constructor(env, componentName, layout) {\n        this.env = env;\n        this.componentName = componentName;\n        this.layout = layout;\n        this.attrs = new ComponentAttrsBuilder();\n    }\n    get tag() {\n        throw new Error('BUG: Cannot call `tag` on an UnwrappedBuilder');\n    }\n    compile() {\n        let { env, layout } = this;\n        return layout.asLayout(this.componentName, this.attrs.buffer).compileDynamic(env);\n    }\n}\nclass ComponentTagBuilder {\n    constructor() {\n        this.isDynamic = null;\n        this.isStatic = null;\n        this.staticTagName = null;\n        this.dynamicTagName = null;\n    }\n    getDynamic() {\n        if (this.isDynamic) {\n            return this.dynamicTagName;\n        }\n    }\n    getStatic() {\n        if (this.isStatic) {\n            return this.staticTagName;\n        }\n    }\n    static(tagName) {\n        this.isStatic = true;\n        this.staticTagName = tagName;\n    }\n    dynamic(tagName) {\n        this.isDynamic = true;\n        this.dynamicTagName = [Ops.ClientSideExpression, ClientSide.Ops.FunctionExpression, tagName];\n    }\n}\nclass ComponentAttrsBuilder {\n    constructor() {\n        this.buffer = [];\n    }\n    static(name, value) {\n        this.buffer.push([Ops.StaticAttr, name, value, null]);\n    }\n    dynamic(name, value) {\n        this.buffer.push([Ops.DynamicAttr, name, [Ops.ClientSideExpression, ClientSide.Ops.FunctionExpression, value], null]);\n    }\n}\nexport class ComponentBuilder {\n    constructor(builder) {\n        this.builder = builder;\n        this.env = builder.env;\n    }\n    static(definition, args) {\n        let [params, hash, _default, inverse] = args;\n        let { builder } = this;\n        builder.pushComponentManager(definition);\n        builder.invokeComponent(null, params, hash, _default, inverse);\n    }\n    dynamic(definitionArgs, getDefinition, args) {\n        let [params, hash, block, inverse] = args;\n        let { builder } = this;\n        if (!definitionArgs || definitionArgs.length === 0) {\n            throw new Error(\"Dynamic syntax without an argument\");\n        }\n        let meta = this.builder.meta.templateMeta;\n        function helper(vm, a) {\n            return getDefinition(vm, a, meta);\n        }\n        builder.startLabels();\n        builder.pushFrame();\n        builder.returnTo('END');\n        builder.compileArgs(definitionArgs[0], definitionArgs[1], true);\n        builder.helper(helper);\n        builder.dup();\n        builder.test('simple');\n        builder.enter(2);\n        builder.jumpUnless('ELSE');\n        builder.pushDynamicComponentManager();\n        builder.invokeComponent(null, params, hash, block, inverse);\n        builder.label('ELSE');\n        builder.exit();\n        builder.return();\n        builder.label('END');\n        builder.popFrame();\n        builder.stopLabels();\n    }\n}\nexport function builder(env, meta) {\n    return new OpcodeBuilderDSL(env, meta);\n}"]}