/**
 * @license
 * Copyright Google Inc. All Rights Reserved.
 *
 * Use of this source code is governed by an MIT-style license that can be
 * found in the LICENSE file at https://angular.io/license
 */
(function (factory) {
    if (typeof module === "object" && typeof module.exports === "object") {
        var v = factory(require, exports);
        if (v !== undefined) module.exports = v;
    }
    else if (typeof define === "function" && define.amd) {
        define("@angular/compiler/src/render3/r3_pipe_compiler", ["require", "exports", "tslib", "@angular/compiler/src/compile_metadata", "@angular/compiler/src/output/output_ast", "@angular/compiler/src/util", "@angular/compiler/src/render3/r3_factory", "@angular/compiler/src/render3/r3_identifiers", "@angular/compiler/src/render3/util"], factory);
    }
})(function (require, exports) {
    "use strict";
    Object.defineProperty(exports, "__esModule", { value: true });
    var tslib_1 = require("tslib");
    var compile_metadata_1 = require("@angular/compiler/src/compile_metadata");
    var o = require("@angular/compiler/src/output/output_ast");
    var util_1 = require("@angular/compiler/src/util");
    var r3_factory_1 = require("@angular/compiler/src/render3/r3_factory");
    var r3_identifiers_1 = require("@angular/compiler/src/render3/r3_identifiers");
    var util_2 = require("@angular/compiler/src/render3/util");
    function compilePipeFromMetadata(metadata) {
        var definitionMapValues = [];
        // e.g. `name: 'myPipe'`
        definitionMapValues.push({ key: 'name', value: o.literal(metadata.pipeName), quoted: false });
        // e.g. `type: MyPipe`
        definitionMapValues.push({ key: 'type', value: metadata.type.value, quoted: false });
        // e.g. `pure: true`
        definitionMapValues.push({ key: 'pure', value: o.literal(metadata.pure), quoted: false });
        var expression = o.importExpr(r3_identifiers_1.Identifiers.definePipe).callFn([o.literalMap(definitionMapValues)]);
        var type = new o.ExpressionType(o.importExpr(r3_identifiers_1.Identifiers.PipeDefWithMeta, [
            util_2.typeWithParameters(metadata.type.type, metadata.typeArgumentCount),
            new o.ExpressionType(new o.LiteralExpr(metadata.pipeName)),
        ]));
        return { expression: expression, type: type };
    }
    exports.compilePipeFromMetadata = compilePipeFromMetadata;
    /**
     * Write a pipe definition to the output context.
     */
    function compilePipeFromRender2(outputCtx, pipe, reflector) {
        var name = compile_metadata_1.identifierName(pipe.type);
        if (!name) {
            return util_1.error("Cannot resolve the name of " + pipe.type);
        }
        var type = outputCtx.importExpr(pipe.type.reference);
        var metadata = {
            name: name,
            type: util_2.wrapReference(type),
            internalType: type,
            pipeName: pipe.name,
            typeArgumentCount: 0,
            deps: r3_factory_1.dependenciesFromGlobalMetadata(pipe.type, outputCtx, reflector),
            pure: pipe.pure,
        };
        var res = compilePipeFromMetadata(metadata);
        var factoryRes = r3_factory_1.compileFactoryFunction(tslib_1.__assign(tslib_1.__assign({}, metadata), { injectFn: r3_identifiers_1.Identifiers.directiveInject, target: r3_factory_1.R3FactoryTarget.Pipe }));
        var definitionField = outputCtx.constantPool.propertyNameOf(3 /* Pipe */);
        var ngFactoryDefStatement = new o.ClassStmt(
        /* name */ name, 
        /* parent */ null, 
        /* fields */
        [new o.ClassField(
            /* name */ 'ɵfac', 
            /* type */ o.INFERRED_TYPE, 
            /* modifiers */ [o.StmtModifier.Static], 
            /* initializer */ factoryRes.factory)], 
        /* getters */ [], 
        /* constructorMethod */ new o.ClassMethod(null, [], []), 
        /* methods */ []);
        var pipeDefStatement = new o.ClassStmt(
        /* name */ name, 
        /* parent */ null, 
        /* fields */ [new o.ClassField(
            /* name */ definitionField, 
            /* type */ o.INFERRED_TYPE, 
            /* modifiers */ [o.StmtModifier.Static], 
            /* initializer */ res.expression)], 
        /* getters */ [], 
        /* constructorMethod */ new o.ClassMethod(null, [], []), 
        /* methods */ []);
        outputCtx.statements.push(ngFactoryDefStatement, pipeDefStatement);
    }
    exports.compilePipeFromRender2 = compilePipeFromRender2;
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"r3_pipe_compiler.js","sourceRoot":"","sources":["../../../../../../../packages/compiler/src/render3/r3_pipe_compiler.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {CompilePipeMetadata, identifierName} from '../compile_metadata';\nimport {CompileReflector} from '../compile_reflector';\nimport {DefinitionKind} from '../constant_pool';\nimport * as o from '../output/output_ast';\nimport {OutputContext, error} from '../util';\n\nimport {R3DependencyMetadata, R3FactoryTarget, compileFactoryFunction, dependenciesFromGlobalMetadata} from './r3_factory';\nimport {Identifiers as R3} from './r3_identifiers';\nimport {R3Reference, typeWithParameters, wrapReference} from './util';\n\nexport interface R3PipeMetadata {\n  /**\n   * Name of the pipe type.\n   */\n  name: string;\n\n  /**\n   * An expression representing a reference to the pipe itself.\n   */\n  type: R3Reference;\n\n  /**\n   * An expression representing the pipe being compiled, intended for use within a class definition\n   * itself.\n   *\n   * This can differ from the outer `type` if the class is being compiled by ngcc and is inside an\n   * IIFE structure that uses a different name internally.\n   */\n  internalType: o.Expression;\n\n  /**\n   * Number of generic type parameters of the type itself.\n   */\n  typeArgumentCount: number;\n\n  /**\n   * Name of the pipe.\n   */\n  pipeName: string;\n\n  /**\n   * Dependencies of the pipe's constructor.\n   */\n  deps: R3DependencyMetadata[]|null;\n\n  /**\n   * Whether the pipe is marked as pure.\n   */\n  pure: boolean;\n}\n\nexport function compilePipeFromMetadata(metadata: R3PipeMetadata) {\n  const definitionMapValues: {key: string, quoted: boolean, value: o.Expression}[] = [];\n\n  // e.g. `name: 'myPipe'`\n  definitionMapValues.push({key: 'name', value: o.literal(metadata.pipeName), quoted: false});\n\n  // e.g. `type: MyPipe`\n  definitionMapValues.push({key: 'type', value: metadata.type.value, quoted: false});\n\n  // e.g. `pure: true`\n  definitionMapValues.push({key: 'pure', value: o.literal(metadata.pure), quoted: false});\n\n  const expression = o.importExpr(R3.definePipe).callFn([o.literalMap(definitionMapValues)]);\n  const type = new o.ExpressionType(o.importExpr(R3.PipeDefWithMeta, [\n    typeWithParameters(metadata.type.type, metadata.typeArgumentCount),\n    new o.ExpressionType(new o.LiteralExpr(metadata.pipeName)),\n  ]));\n\n  return {expression, type};\n}\n\n/**\n * Write a pipe definition to the output context.\n */\nexport function compilePipeFromRender2(\n    outputCtx: OutputContext, pipe: CompilePipeMetadata, reflector: CompileReflector) {\n  const name = identifierName(pipe.type);\n\n  if (!name) {\n    return error(`Cannot resolve the name of ${pipe.type}`);\n  }\n\n  const type = outputCtx.importExpr(pipe.type.reference);\n  const metadata: R3PipeMetadata = {\n    name,\n    type: wrapReference(type),\n    internalType: type,\n    pipeName: pipe.name,\n    typeArgumentCount: 0,\n    deps: dependenciesFromGlobalMetadata(pipe.type, outputCtx, reflector),\n    pure: pipe.pure,\n  };\n  const res = compilePipeFromMetadata(metadata);\n  const factoryRes = compileFactoryFunction(\n      {...metadata, injectFn: R3.directiveInject, target: R3FactoryTarget.Pipe});\n  const definitionField = outputCtx.constantPool.propertyNameOf(DefinitionKind.Pipe);\n  const ngFactoryDefStatement = new o.ClassStmt(\n      /* name */ name,\n      /* parent */ null,\n      /* fields */\n      [new o.ClassField(\n          /* name */ 'ɵfac',\n          /* type */ o.INFERRED_TYPE,\n          /* modifiers */[o.StmtModifier.Static],\n          /* initializer */ factoryRes.factory)],\n      /* getters */[],\n      /* constructorMethod */ new o.ClassMethod(null, [], []),\n      /* methods */[]);\n  const pipeDefStatement = new o.ClassStmt(\n      /* name */ name,\n      /* parent */ null,\n      /* fields */[new o.ClassField(\n          /* name */ definitionField,\n          /* type */ o.INFERRED_TYPE,\n          /* modifiers */[o.StmtModifier.Static],\n          /* initializer */ res.expression)],\n      /* getters */[],\n      /* constructorMethod */ new o.ClassMethod(null, [], []),\n      /* methods */[]);\n\n  outputCtx.statements.push(ngFactoryDefStatement, pipeDefStatement);\n}\n"]}