@angular/compiler-cli
Advanced tools
+2
-2
| { | ||
| "name": "@angular/compiler-cli", | ||
| "version": "6.0.0-rc.1", | ||
| "version": "6.0.0-rc.2", | ||
| "description": "Angular - the compiler CLI for Node.js", | ||
@@ -19,3 +19,3 @@ "main": "index.js", | ||
| "typescript": ">=2.7.2 <2.8", | ||
| "@angular/compiler": "6.0.0-rc.1" | ||
| "@angular/compiler": "6.0.0-rc.2" | ||
| }, | ||
@@ -22,0 +22,0 @@ "engines" : { |
| /// <amd-module name="@angular/compiler-cli/src/metadata/bundle_index_host" /> | ||
| import * as ts from 'typescript'; | ||
| import { CompilerOptions } from '../transformers/api'; | ||
| export declare function createBundleIndexHost<H extends ts.CompilerHost>(ngOptions: CompilerOptions, rootFiles: ReadonlyArray<string>, host: H): { | ||
| import { MetadataCache } from '../transformers/metadata_cache'; | ||
| export declare function createBundleIndexHost<H extends ts.CompilerHost>(ngOptions: CompilerOptions, rootFiles: ReadonlyArray<string>, host: H, getMetadataCache: () => MetadataCache): { | ||
| host: H; | ||
@@ -6,0 +7,0 @@ indexName?: string; |
@@ -28,4 +28,2 @@ /** | ||
| var normalSyntheticIndexName = path.normalize(syntheticIndex.name); | ||
| var indexContent = syntheticIndex.content; | ||
| var indexMetadata = syntheticIndex.metadata; | ||
| var newHost = Object.create(delegate); | ||
@@ -36,3 +34,3 @@ newHost.fileExists = function (fileName) { | ||
| newHost.readFile = function (fileName) { | ||
| return path.normalize(fileName) == normalSyntheticIndexName ? indexContent : | ||
| return path.normalize(fileName) == normalSyntheticIndexName ? syntheticIndex.content : | ||
| delegate.readFile(fileName); | ||
@@ -43,3 +41,3 @@ }; | ||
| if (path.normalize(fileName) == normalSyntheticIndexName) { | ||
| var sf = ts.createSourceFile(fileName, indexContent, languageVersion, true); | ||
| var sf = ts.createSourceFile(fileName, syntheticIndex.content, languageVersion, true); | ||
| if (delegate.fileNameToModuleName) { | ||
@@ -59,2 +57,3 @@ sf.moduleName = delegate.fileNameToModuleName(fileName); | ||
| var metadataName = fileName.replace(DTS, '.metadata.json'); | ||
| var indexMetadata = syntheticIndex.getMetadata(); | ||
| delegate.writeFile(metadataName, indexMetadata, writeByteOrderMark, onError, []); | ||
@@ -65,3 +64,3 @@ } | ||
| } | ||
| function createBundleIndexHost(ngOptions, rootFiles, host) { | ||
| function createBundleIndexHost(ngOptions, rootFiles, host, getMetadataCache) { | ||
| var files = rootFiles.filter(function (f) { return !DTS.test(f); }); | ||
@@ -106,9 +105,27 @@ var indexFile; | ||
| var indexModule = indexFile.replace(/\.ts$/, ''); | ||
| var bundler = new bundler_1.MetadataBundler(indexModule, ngOptions.flatModuleId, new bundler_1.CompilerHostAdapter(host), ngOptions.flatModulePrivateSymbolPrefix); | ||
| var metadataBundle = bundler.getMetadataBundle(); | ||
| var metadata = JSON.stringify(metadataBundle.metadata); | ||
| // The operation of producing a metadata bundle happens twice - once during setup and once during | ||
| // the emit phase. The first time, the bundle is produced without a metadata cache, to compute the | ||
| // contents of the flat module index. The bundle produced during emit does use the metadata cache | ||
| // with associated transforms, so the metadata will have lowered expressions, resource inlining, | ||
| // etc. | ||
| var getMetadataBundle = function (cache) { | ||
| var bundler = new bundler_1.MetadataBundler(indexModule, ngOptions.flatModuleId, new bundler_1.CompilerHostAdapter(host, cache), ngOptions.flatModulePrivateSymbolPrefix); | ||
| return bundler.getMetadataBundle(); | ||
| }; | ||
| // First, produce the bundle with no MetadataCache. | ||
| var metadataBundle = getMetadataBundle(/* MetadataCache */ null); | ||
| var name = path.join(path.dirname(indexModule), ngOptions.flatModuleOutFile.replace(JS_EXT, '.ts')); | ||
| var libraryIndex = "./" + path.basename(indexModule); | ||
| var content = index_writer_1.privateEntriesToIndex(libraryIndex, metadataBundle.privates); | ||
| host = createSyntheticIndexHost(host, { name: name, content: content, metadata: metadata }); | ||
| host = createSyntheticIndexHost(host, { | ||
| name: name, | ||
| content: content, | ||
| getMetadata: function () { | ||
| // The second metadata bundle production happens on-demand, and uses the getMetadataCache | ||
| // closure to retrieve an up-to-date MetadataCache which is configured with whatever metadata | ||
| // transforms were used to produce the JS output. | ||
| var metadataBundle = getMetadataBundle(getMetadataCache()); | ||
| return JSON.stringify(metadataBundle.metadata); | ||
| } | ||
| }); | ||
| return { host: host, indexName: name }; | ||
@@ -119,2 +136,2 @@ var e_1, _a; | ||
| }); | ||
| //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundle_index_host.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/metadata/bundle_index_host.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 * as fs from 'fs';\nimport * as path from 'path';\nimport * as ts from 'typescript';\n\nimport {CompilerOptions} from '../transformers/api';\n\nimport {CompilerHostAdapter, MetadataBundler} from './bundler';\nimport {privateEntriesToIndex} from './index_writer';\n\nconst DTS = /\\.d\\.ts$/;\nconst JS_EXT = /(\\.js|)$/;\n\nfunction createSyntheticIndexHost<H extends ts.CompilerHost>(\n    delegate: H, syntheticIndex: {name: string, content: string, metadata: string}): H {\n  const normalSyntheticIndexName = path.normalize(syntheticIndex.name);\n  const indexContent = syntheticIndex.content;\n  const indexMetadata = syntheticIndex.metadata;\n\n  const newHost = Object.create(delegate);\n  newHost.fileExists = (fileName: string): boolean => {\n    return path.normalize(fileName) == normalSyntheticIndexName || delegate.fileExists(fileName);\n  };\n\n  newHost.readFile = (fileName: string) => {\n    return path.normalize(fileName) == normalSyntheticIndexName ? indexContent :\n                                                                  delegate.readFile(fileName);\n  };\n\n  newHost.getSourceFile =\n      (fileName: string, languageVersion: ts.ScriptTarget, onError?: (message: string) => void) => {\n        if (path.normalize(fileName) == normalSyntheticIndexName) {\n          const sf = ts.createSourceFile(fileName, indexContent, languageVersion, true);\n          if ((delegate as any).fileNameToModuleName) {\n            sf.moduleName = (delegate as any).fileNameToModuleName(fileName);\n          }\n          return sf;\n        }\n        return delegate.getSourceFile(fileName, languageVersion, onError);\n      };\n\n  newHost.writeFile =\n      (fileName: string, data: string, writeByteOrderMark: boolean,\n       onError: ((message: string) => void) | undefined,\n       sourceFiles: Readonly<ts.SourceFile>[]) => {\n        delegate.writeFile(fileName, data, writeByteOrderMark, onError, sourceFiles);\n        if (fileName.match(DTS) && sourceFiles && sourceFiles.length == 1 &&\n            path.normalize(sourceFiles[0].fileName) === normalSyntheticIndexName) {\n          // If we are writing the synthetic index, write the metadata along side.\n          const metadataName = fileName.replace(DTS, '.metadata.json');\n          delegate.writeFile(metadataName, indexMetadata, writeByteOrderMark, onError, []);\n        }\n      };\n  return newHost;\n}\n\nexport function createBundleIndexHost<H extends ts.CompilerHost>(\n    ngOptions: CompilerOptions, rootFiles: ReadonlyArray<string>,\n    host: H): {host: H, indexName?: string, errors?: ts.Diagnostic[]} {\n  const files = rootFiles.filter(f => !DTS.test(f));\n  let indexFile: string|undefined;\n  if (files.length === 1) {\n    indexFile = files[0];\n  } else {\n    for (const f of files) {\n      // Assume the shortest file path called index.ts is the entry point\n      if (f.endsWith(path.sep + 'index.ts')) {\n        if (!indexFile || indexFile.length > f.length) {\n          indexFile = f;\n        }\n      }\n    }\n  }\n  if (!indexFile) {\n    return {\n      host,\n      errors: [{\n        file: null as any as ts.SourceFile,\n        start: null as any as number,\n        length: null as any as number,\n        messageText:\n            'Angular compiler option \"flatModuleIndex\" requires one and only one .ts file in the \"files\" field.',\n        category: ts.DiagnosticCategory.Error,\n        code: 0\n      }]\n    };\n  }\n\n  const indexModule = indexFile.replace(/\\.ts$/, '');\n  const bundler = new MetadataBundler(\n      indexModule, ngOptions.flatModuleId, new CompilerHostAdapter(host),\n      ngOptions.flatModulePrivateSymbolPrefix);\n  const metadataBundle = bundler.getMetadataBundle();\n  const metadata = JSON.stringify(metadataBundle.metadata);\n  const name =\n      path.join(path.dirname(indexModule), ngOptions.flatModuleOutFile !.replace(JS_EXT, '.ts'));\n  const libraryIndex = `./${path.basename(indexModule)}`;\n  const content = privateEntriesToIndex(libraryIndex, metadataBundle.privates);\n  host = createSyntheticIndexHost(host, {name, content, metadata});\n  return {host, indexName: name};\n}\n"]} | ||
| //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundle_index_host.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/metadata/bundle_index_host.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 * as fs from 'fs';\nimport * as path from 'path';\nimport * as ts from 'typescript';\n\nimport {CompilerOptions} from '../transformers/api';\nimport {MetadataCache} from '../transformers/metadata_cache';\n\nimport {CompilerHostAdapter, MetadataBundler} from './bundler';\nimport {privateEntriesToIndex} from './index_writer';\n\nconst DTS = /\\.d\\.ts$/;\nconst JS_EXT = /(\\.js|)$/;\n\nfunction createSyntheticIndexHost<H extends ts.CompilerHost>(\n    delegate: H, syntheticIndex: {name: string, content: string, getMetadata: () => string}): H {\n  const normalSyntheticIndexName = path.normalize(syntheticIndex.name);\n\n  const newHost = Object.create(delegate);\n  newHost.fileExists = (fileName: string): boolean => {\n    return path.normalize(fileName) == normalSyntheticIndexName || delegate.fileExists(fileName);\n  };\n\n  newHost.readFile = (fileName: string) => {\n    return path.normalize(fileName) == normalSyntheticIndexName ? syntheticIndex.content :\n                                                                  delegate.readFile(fileName);\n  };\n\n  newHost.getSourceFile =\n      (fileName: string, languageVersion: ts.ScriptTarget, onError?: (message: string) => void) => {\n        if (path.normalize(fileName) == normalSyntheticIndexName) {\n          const sf = ts.createSourceFile(fileName, syntheticIndex.content, languageVersion, true);\n          if ((delegate as any).fileNameToModuleName) {\n            sf.moduleName = (delegate as any).fileNameToModuleName(fileName);\n          }\n          return sf;\n        }\n        return delegate.getSourceFile(fileName, languageVersion, onError);\n      };\n\n  newHost.writeFile =\n      (fileName: string, data: string, writeByteOrderMark: boolean,\n       onError: ((message: string) => void) | undefined,\n       sourceFiles: Readonly<ts.SourceFile>[]) => {\n        delegate.writeFile(fileName, data, writeByteOrderMark, onError, sourceFiles);\n        if (fileName.match(DTS) && sourceFiles && sourceFiles.length == 1 &&\n            path.normalize(sourceFiles[0].fileName) === normalSyntheticIndexName) {\n          // If we are writing the synthetic index, write the metadata along side.\n          const metadataName = fileName.replace(DTS, '.metadata.json');\n          const indexMetadata = syntheticIndex.getMetadata();\n          delegate.writeFile(metadataName, indexMetadata, writeByteOrderMark, onError, []);\n        }\n      };\n  return newHost;\n}\n\nexport function createBundleIndexHost<H extends ts.CompilerHost>(\n    ngOptions: CompilerOptions, rootFiles: ReadonlyArray<string>, host: H,\n    getMetadataCache: () =>\n        MetadataCache): {host: H, indexName?: string, errors?: ts.Diagnostic[]} {\n  const files = rootFiles.filter(f => !DTS.test(f));\n  let indexFile: string|undefined;\n  if (files.length === 1) {\n    indexFile = files[0];\n  } else {\n    for (const f of files) {\n      // Assume the shortest file path called index.ts is the entry point\n      if (f.endsWith(path.sep + 'index.ts')) {\n        if (!indexFile || indexFile.length > f.length) {\n          indexFile = f;\n        }\n      }\n    }\n  }\n  if (!indexFile) {\n    return {\n      host,\n      errors: [{\n        file: null as any as ts.SourceFile,\n        start: null as any as number,\n        length: null as any as number,\n        messageText:\n            'Angular compiler option \"flatModuleIndex\" requires one and only one .ts file in the \"files\" field.',\n        category: ts.DiagnosticCategory.Error,\n        code: 0\n      }]\n    };\n  }\n\n  const indexModule = indexFile.replace(/\\.ts$/, '');\n\n  // The operation of producing a metadata bundle happens twice - once during setup and once during\n  // the emit phase. The first time, the bundle is produced without a metadata cache, to compute the\n  // contents of the flat module index. The bundle produced during emit does use the metadata cache\n  // with associated transforms, so the metadata will have lowered expressions, resource inlining,\n  // etc.\n  const getMetadataBundle = (cache: MetadataCache | null) => {\n    const bundler = new MetadataBundler(\n        indexModule, ngOptions.flatModuleId, new CompilerHostAdapter(host, cache),\n        ngOptions.flatModulePrivateSymbolPrefix);\n    return bundler.getMetadataBundle();\n  };\n\n  // First, produce the bundle with no MetadataCache.\n  const metadataBundle = getMetadataBundle(/* MetadataCache */ null);\n  const name =\n      path.join(path.dirname(indexModule), ngOptions.flatModuleOutFile !.replace(JS_EXT, '.ts'));\n  const libraryIndex = `./${path.basename(indexModule)}`;\n  const content = privateEntriesToIndex(libraryIndex, metadataBundle.privates);\n\n  host = createSyntheticIndexHost(host, {\n    name,\n    content,\n    getMetadata: () => {\n      // The second metadata bundle production happens on-demand, and uses the getMetadataCache\n      // closure to retrieve an up-to-date MetadataCache which is configured with whatever metadata\n      // transforms were used to produce the JS output.\n      const metadataBundle = getMetadataBundle(getMetadataCache());\n      return JSON.stringify(metadataBundle.metadata);\n    }\n  });\n  return {host, indexName: name};\n}\n"]} |
| /// <amd-module name="@angular/compiler-cli/src/metadata/bundler" /> | ||
| import * as ts from 'typescript'; | ||
| import { MetadataEntry, ModuleMetadata } from '../metadata/schema'; | ||
| import { MetadataCache } from '../transformers/metadata_cache'; | ||
| export interface BundleEntries { | ||
@@ -60,5 +61,6 @@ [name: string]: MetadataEntry; | ||
| private host; | ||
| private cache; | ||
| private collector; | ||
| constructor(host: ts.CompilerHost); | ||
| constructor(host: ts.CompilerHost, cache: MetadataCache | null); | ||
| getMetadataFor(fileName: string): ModuleMetadata | undefined; | ||
| } |
+1
-1
@@ -28,4 +28,4 @@ /** | ||
| */ | ||
| exports.VERSION = new compiler_1.Version('6.0.0-rc.1'); | ||
| exports.VERSION = new compiler_1.Version('6.0.0-rc.2'); | ||
| }); | ||
| //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbXBpbGVyLWNsaS9zcmMvdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7Ozs7Ozs7Ozs7OztJQUVIOzs7O09BSUc7SUFFSCxvREFBMEM7SUFDMUM7O09BRUc7SUFDVSxRQUFBLE9BQU8sR0FBRyxJQUFJLGtCQUFPLENBQUMsbUJBQW1CLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuLyoqXG4gKiBAbW9kdWxlXG4gKiBAZGVzY3JpcHRpb25cbiAqIEVudHJ5IHBvaW50IGZvciBhbGwgcHVibGljIEFQSXMgb2YgdGhlIGNvbW1vbiBwYWNrYWdlLlxuICovXG5cbmltcG9ydCB7VmVyc2lvbn0gZnJvbSAnQGFuZ3VsYXIvY29tcGlsZXInO1xuLyoqXG4gKiBAc3RhYmxlXG4gKi9cbmV4cG9ydCBjb25zdCBWRVJTSU9OID0gbmV3IFZlcnNpb24oJzAuMC4wLVBMQUNFSE9MREVSJyk7XG4iXX0= |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
Debug access
Supply chain riskUses debug, reflection and dynamic code execution features.
Found 1 instance in 1 package
Dynamic require
Supply chain riskDynamic require can indicate the package is performing dangerous or unsafe dynamic code execution.
Found 1 instance in 1 package
Filesystem access
Supply chain riskAccesses the file system, and could potentially read sensitive data.
Found 1 instance in 1 package
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
URL strings
Supply chain riskPackage contains fragments of external URLs or IP addresses, which the package may be accessing at runtime.
Found 1 instance in 1 package
Debug access
Supply chain riskUses debug, reflection and dynamic code execution features.
Found 1 instance in 1 package
Dynamic require
Supply chain riskDynamic require can indicate the package is performing dangerous or unsafe dynamic code execution.
Found 1 instance in 1 package
Filesystem access
Supply chain riskAccesses the file system, and could potentially read sensitive data.
Found 1 instance in 1 package
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
URL strings
Supply chain riskPackage contains fragments of external URLs or IP addresses, which the package may be accessing at runtime.
Found 1 instance in 1 package
1462287
0.32%10825
0.3%