ember-legacy-class-transform
Version:
The default blueprint for ember-cli addons.
322 lines (271 loc) • 28.8 kB
JavaScript
"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}"]}