當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript TypeScriptEmitter.emitStatements方法代碼示例

本文整理匯總了TypeScript中@angular/compiler/src/output/ts_emitter.TypeScriptEmitter.emitStatements方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript TypeScriptEmitter.emitStatements方法的具體用法?TypeScript TypeScriptEmitter.emitStatements怎麽用?TypeScript TypeScriptEmitter.emitStatements使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在@angular/compiler/src/output/ts_emitter.TypeScriptEmitter的用法示例。


在下文中一共展示了TypeScriptEmitter.emitStatements方法的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: emitStmt

 function emitStmt(stmt: o.Statement | o.Statement[], exportedVars: string[] = null): string {
   if (!exportedVars) {
     exportedVars = [];
   }
   const stmts = Array.isArray(stmt) ? stmt : [stmt];
   return emitter.emitStatements(someModuleUrl, stmts, exportedVars);
 }
開發者ID:doxiaodong,項目名稱:angular,代碼行數:7,代碼來源:ts_emitter_spec.ts

示例2: emit

export function emit() {
  const emitter = new TypeScriptEmitter(new SimpleJsImportGenerator());
  const emittedCode = emitter.emitStatements(
      assetUrl('compiler', 'output/output_emitter_codegen_typed', 'test'), codegenStmts,
      codegenExportsVars);
  return emittedCode;
}
開發者ID:ScottSWu,項目名稱:angular,代碼行數:7,代碼來源:output_emitter_codegen_typed.ts

示例3: emitSourceMap

 function emitSourceMap(
     stmt: o.Statement | o.Statement[], exportedVars: string[] | null = null,
     preamble?: string): SourceMap {
   const stmts = Array.isArray(stmt) ? stmt : [stmt];
   const source = emitter.emitStatements(
       someSourceFilePath, someGenFilePath, stmts, exportedVars || [], preamble);
   return extractSourceMap(source) !;
 }
開發者ID:diestrin,項目名稱:angular,代碼行數:8,代碼來源:ts_emitter_node_only_spec.ts

示例4: emitStmt

 function emitStmt(
     stmt: o.Statement | o.Statement[], exportedVars: string[] = null,
     preamble?: string): string {
   const stmts = Array.isArray(stmt) ? stmt : [stmt];
   const source = emitter.emitStatements(
       someSourceFilePath, someGenFilePath, stmts, exportedVars || [], preamble);
   return stripSourceMapAndNewLine(source);
 }
開發者ID:JohnnyQQQQ,項目名稱:angular,代碼行數:8,代碼來源:ts_emitter_spec.ts

示例5: it

  it('should quote identifiers quoted in the source', () => {
    const sourceText = `
      import {Component} from '@angular/core';

      @Component({
        providers: [{ provide: 'SomeToken', useValue: {a: 1, 'b': 2, c: 3, 'd': 4}}]
      })
      export class MyComponent {}
    `;
    const source = ts.createSourceFile('test.ts', sourceText, ts.ScriptTarget.Latest);
    const collector = new MetadataCollector({quotedNames: true});
    const stubHost = new StubReflectorHost();
    const symbolCache = new StaticSymbolCache();
    const symbolResolver =
        new StaticSymbolResolver(stubHost, symbolCache, new MockSummaryResolver());
    const reflector = new StaticReflector(symbolResolver);

    // Get the metadata from the above source
    const metadata = collector.getMetadata(source);
    const componentMetadata = metadata.metadata['MyComponent'];

    // Get the first argument of the decorator call which is passed to @Component
    expect(isClassMetadata(componentMetadata)).toBeTruthy();
    if (!isClassMetadata(componentMetadata)) return;
    const decorators = componentMetadata.decorators;
    const firstDecorator = decorators[0];
    expect(isMetadataSymbolicCallExpression(firstDecorator)).toBeTruthy();
    if (!isMetadataSymbolicCallExpression(firstDecorator)) return;
    const firstArgument = firstDecorator.arguments[0];

    // Simplify this value using the StaticReflector
    const context = reflector.getStaticSymbol('none', 'none');
    const argumentValue = reflector.simplify(context, firstArgument);

    // Convert the value to an output AST
    const outputAst = convertValueToOutputAst(argumentValue);
    const statement = outputAst.toStmt();

    // Convert the value to text using the typescript emitter
    const emitter = new TypeScriptEmitter(new StubImportResolver());
    const text = emitter.emitStatements('module', [statement], []);

    // Expect the keys for 'b' and 'd' to be quoted but 'a' and 'c' not to be.
    expect(text).toContain('\'b\': 2');
    expect(text).toContain('\'d\': 4');
    expect(text).not.toContain('\'a\'');
    expect(text).not.toContain('\'c\'');
  });
開發者ID:DzmitryShylovich,項目名稱:angular,代碼行數:48,代碼來源:ts_emitter_node_only_spec.ts

示例6: emitStmt

 function emitStmt(stmt: o.Statement, exportedVars: string[] = null): string {
   if (isBlank(exportedVars)) {
     exportedVars = [];
   }
   return emitter.emitStatements(someModuleUrl, [stmt], exportedVars);
 }
開發者ID:WimpyKnight,項目名稱:angular,代碼行數:6,代碼來源:ts_emitter_spec.ts

示例7: emitSourceMap

 function emitSourceMap(
     stmt: o.Statement | o.Statement[], exportedVars: string[] = null): SourceMap {
   const stmts = Array.isArray(stmt) ? stmt : [stmt];
   const source = emitter.emitStatements(someModuleUrl, stmts, exportedVars || []);
   return extractSourceMap(source);
 }
開發者ID:manekinekko,項目名稱:angular,代碼行數:6,代碼來源:ts_emitter_node_only_spec.ts

示例8: emitStmt

 function emitStmt(stmt: o.Statement | o.Statement[], exportedVars: string[] = null): string {
   const stmts = Array.isArray(stmt) ? stmt : [stmt];
   const source = emitter.emitStatements(someModuleUrl, stmts, exportedVars || []);
   return stripSourceMapAndNewLine(source);
 }
開發者ID:acramatte,項目名稱:angular,代碼行數:5,代碼來源:ts_emitter_spec.ts


注:本文中的@angular/compiler/src/output/ts_emitter.TypeScriptEmitter.emitStatements方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。