UNPKG

ember-legacy-class-transform

Version:
322 lines (271 loc) 28.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.ComponentBuilder = undefined; exports.compileLayout = compileLayout; exports.builder = builder; var _blocks = require("./compiled/blocks"); var _wireFormat = require("@glimmer/wire-format"); var _opcodes = require("./opcodes"); var _functions = require("./syntax/functions"); var _clientSide = require("./syntax/client-side"); var ClientSide = _interopRequireWildcard(_clientSide); var _builder = require("./compiled/opcodes/builder"); var _builder2 = _interopRequireDefault(_builder); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _interopRequireWildcard(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; } } 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"); } } 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(_opcodes.Register.s1); (0, _functions.expr)(dynamicTag, b); b.dup(); b.load(_opcodes.Register.s1); b.test('simple'); b.jumpUnless('BODY'); b.fetch(_opcodes.Register.s1); b.pushComponentOperations(); b.openDynamicElement(); } else if (staticTag) { b.pushComponentOperations(); b.openElementWithOperations(staticTag); } if (dynamicTag || staticTag) { b.didCreateElement(_opcodes.Register.s0); var attrs = this.attrs.buffer; for (var i = 0; i < attrs.length; i++) { (0, _functions.compileStatement)(attrs[i], b); } b.flushElement(); } b.label('BODY'); b.invokeStatic(layout.asBlock()); if (dynamicTag) { b.fetch(_opcodes.Register.s1); b.test('simple'); b.jumpUnless('END'); b.closeElement(); } else if (staticTag) { b.closeElement(); } b.label('END'); b.didRenderLayout(_opcodes.Register.s0); if (dynamicTag) { b.load(_opcodes.Register.s1); } b.stopLabels(); var start = b.start; var end = b.finalize(); if (false) { (0, _opcodes.debugSlice)(env, env.program.heap.getaddr(start), env.program.heap.getaddr(end)); } return new _blocks.CompiledDynamicTemplate(start, { meta: meta, hasEval: layout.hasEval, symbols: layout.symbols.concat([_functions.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 = [_wireFormat.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([_wireFormat.Ops.StaticAttr, name, value, null]); }; ComponentAttrsBuilder.prototype.dynamic = function dynamic(name, value) { this.buffer.push([_wireFormat.Ops.DynamicAttr, name, [_wireFormat.Ops.ClientSideExpression, ClientSide.Ops.FunctionExpression, value], null]); }; return ComponentAttrsBuilder; }(); var ComponentBuilder = exports.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; }(); function builder(env, meta) { return new _builder2.default(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":"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","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}"]}