New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

jsii

Package Overview
Dependencies
Maintainers
4
Versions
1762
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

jsii - npm Package Compare versions

Comparing version 0.7.8 to 0.7.9

bin/jsii-fix-peers.d.ts

20

CHANGELOG.md

@@ -6,2 +6,22 @@ # Change Log

<a name="0.7.9"></a>
## [0.7.9](https://github.com/awslabs/jsii/compare/v0.7.8...v0.7.9) (2018-11-12)
### Bug Fixes
* **docs:** improve docs rendering ([#303](https://github.com/awslabs/jsii/issues/303)) ([094a215](https://github.com/awslabs/jsii/commit/094a215)), closes [#301](https://github.com/awslabs/jsii/issues/301) [#298](https://github.com/awslabs/jsii/issues/298) [#302](https://github.com/awslabs/jsii/issues/302) [#300](https://github.com/awslabs/jsii/issues/300) [#299](https://github.com/awslabs/jsii/issues/299)
* **jsii:** do not mark "any" or "unknown" as optional (unless "?") ([#295](https://github.com/awslabs/jsii/issues/295)) ([cdf5a53](https://github.com/awslabs/jsii/commit/cdf5a53)), closes [#284](https://github.com/awslabs/jsii/issues/284)
* **runtime/dotnet:** Correct a number of type mappings ([#291](https://github.com/awslabs/jsii/issues/291)) ([0d59dab](https://github.com/awslabs/jsii/commit/0d59dab)), closes [#290](https://github.com/awslabs/jsii/issues/290) [awslabs/aws-cdk#1027](https://github.com/awslabs/aws-cdk/issues/1027)
* accept variadic arguments after optional arguments ([#307](https://github.com/awslabs/jsii/issues/307)) ([c1af1d6](https://github.com/awslabs/jsii/commit/c1af1d6))
* remove overly strict checks on peer versions ([#306](https://github.com/awslabs/jsii/issues/306)) ([7b89d01](https://github.com/awslabs/jsii/commit/7b89d01))
### Features
* **jsii:** enforce peer dependencies ([#294](https://github.com/awslabs/jsii/issues/294)) ([1753910](https://github.com/awslabs/jsii/commit/1753910)), closes [awslabs/aws-cdk#979](https://github.com/awslabs/aws-cdk/issues/979)
<a name="0.7.8"></a>

@@ -8,0 +28,0 @@ ## [0.7.8](https://github.com/awslabs/jsii/compare/v0.7.7...v0.7.8) (2018-10-23)

9

lib/assembler.d.ts

@@ -10,2 +10,3 @@ import ts = require('typescript');

readonly program: ts.Program;
readonly stdlib: string;
private _diagnostics;

@@ -17,4 +18,5 @@ private _deferred;

* @param program the TypeScript program to be assembled from
* @param stdlib the directory where the TypeScript stdlib is rooted
*/
constructor(projectInfo: ProjectInfo, program: ts.Program);
constructor(projectInfo: ProjectInfo, program: ts.Program, stdlib: string);
private readonly _typeChecker;

@@ -97,2 +99,7 @@ /**

private allProperties;
/**
* Verifies that if a method has an optional parameter, all consecutive
* parameters are optionals as well.
*/
private _verifyConsecutiveOptionals;
}

@@ -99,0 +106,0 @@ /**

16

lib/compiler.js

@@ -61,5 +61,8 @@ "use strict";

const host = ts.createCompilerHost(COMPILER_OPTIONS);
if (!host.getDefaultLibLocation) {
throw new Error('No default library location was found on the TypeScript compiler host!');
}
host.getCurrentDirectory = () => this.options.projectInfo.projectRoot;
const prog = ts.createProgram(files.concat(_pathOfLibraries(host)), COMPILER_OPTIONS, host);
return await this._consumeProgram(prog);
return await this._consumeProgram(prog, host.getDefaultLibLocation());
}

@@ -70,5 +73,8 @@ async _startWatch() {

const host = ts.createWatchCompilerHost(await this._writeTypeScriptConfig(), Object.assign({}, COMPILER_OPTIONS, { noEmitOnError: false }), Object.assign({}, ts.sys, { getCurrentDirectory() { return projectRoot; } }));
if (!host.getDefaultLibLocation) {
throw new Error('No default library location was found on the TypeScript compiler host!');
}
const orig = host.afterProgramCreate;
host.afterProgramCreate = async (builderProgram) => {
await this._consumeProgram(builderProgram.getProgram());
await this._consumeProgram(builderProgram.getProgram(), host.getDefaultLibLocation());
if (orig) {

@@ -82,3 +88,3 @@ orig.call(host, builderProgram);

}
async _consumeProgram(program) {
async _consumeProgram(program, stdlib) {
const emit = program.emit();

@@ -89,3 +95,3 @@ if (emit.emitSkipped) {

}
const assembler = new assembler_1.Assembler(this.options.projectInfo, program);
const assembler = new assembler_1.Assembler(this.options.projectInfo, program, stdlib);
const assmEmit = await assembler.emit();

@@ -166,2 +172,2 @@ if (assmEmit.emitSkipped) {

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"compiler.js","sourceRoot":"","sources":["compiler.ts"],"names":[],"mappings":"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","sourcesContent":["import Case = require('case');\nimport colors = require('colors/safe');\nimport fs = require('fs-extra');\nimport log4js = require('log4js');\nimport path = require('path');\nimport ts = require('typescript');\nimport { Assembler } from './assembler';\nimport { EmitResult, Emitter } from './emitter';\nimport { ProjectInfo } from './project-info';\nimport utils = require('./utils');\n\nconst COMPILER_OPTIONS: ts.CompilerOptions = {\n    alwaysStrict: true,\n    charset: 'utf8',\n    declaration: true,\n    experimentalDecorators: true,\n    inlineSourceMap: true,\n    inlineSources: true,\n    lib: ['lib.es2016.d.ts', 'lib.es2017.object.d.ts', 'lib.es2017.string.d.ts'],\n    module: ts.ModuleKind.CommonJS,\n    noEmitOnError: true,\n    noFallthroughCasesInSwitch: true,\n    noImplicitAny: true,\n    noImplicitReturns: true,\n    noImplicitThis: true,\n    noUnusedLocals: true,\n    noUnusedParameters: true,\n    resolveJsonModule: true,\n    strict: true,\n    strictNullChecks: true,\n    strictPropertyInitialization: false,\n    target: ts.ScriptTarget.ES2018\n};\n\nconst LOG = log4js.getLogger('jsii/compiler');\nexport const DIAGNOSTICS = 'diagnostics';\n\nexport interface CompilerOptions {\n    /** The information about the project to be built */\n    projectInfo: ProjectInfo;\n    /** Whether the compiler should watch for changes or just compile once */\n    watch: boolean;\n}\n\nexport class Compiler implements Emitter {\n    public constructor(private readonly options: CompilerOptions) {}\n\n    /**\n     * Compiles the configured program.\n     *\n     * @param files can be specified to override the standard source code location logic. Useful for example when testing \"negatives\".\n     */\n    public async emit(...files: string[]): Promise<EmitResult | never> {\n        if (this.options.watch) {\n            if (files.length > 0) {\n                throw new Error(`Files cannot be specified in watch mode!`);\n            }\n            return await this._startWatch();\n        } else {\n            if (files.length === 0) {\n                files = await _findSourceFiles(this.options.projectInfo.projectRoot);\n            }\n            return await this._buildOnce(files);\n        }\n    }\n\n    private async _buildOnce(files: string[]): Promise<EmitResult> {\n        await this._writeTypeScriptConfig();\n        const host = ts.createCompilerHost(COMPILER_OPTIONS);\n        host.getCurrentDirectory = () => this.options.projectInfo.projectRoot;\n        const prog = ts.createProgram(\n            files.concat(_pathOfLibraries(host)),\n            COMPILER_OPTIONS,\n            host\n        );\n        return await this._consumeProgram(prog);\n    }\n\n    private async _startWatch(): Promise<never> {\n        return new Promise<never>(async () => {\n            const projectRoot = this.options.projectInfo.projectRoot;\n            const host = ts.createWatchCompilerHost(\n                await this._writeTypeScriptConfig(),\n                { ...COMPILER_OPTIONS, noEmitOnError: false },\n                { ...ts.sys, getCurrentDirectory() { return projectRoot; } }\n            );\n            const orig = host.afterProgramCreate;\n            host.afterProgramCreate = async builderProgram => {\n                await this._consumeProgram(builderProgram.getProgram());\n                if (orig) { orig.call(host, builderProgram); }\n            };\n            ts.createWatchProgram(host);\n            // Previous call never returns\n        });\n    }\n\n    private async _consumeProgram(program: ts.Program): Promise<EmitResult> {\n        const emit = program.emit();\n        if (emit.emitSkipped) {\n            LOG.error('Compilation errors prevented the JSII assembly from being created');\n            return emit;\n        }\n        const assembler = new Assembler(this.options.projectInfo, program);\n        const assmEmit = await assembler.emit();\n        if (assmEmit.emitSkipped) {\n            LOG.error('Type model errors prevented the JSII assembly from being created');\n        }\n        return {\n            emitSkipped: assmEmit.emitSkipped,\n            diagnostics: [...emit.diagnostics, ...assmEmit.diagnostics]\n        };\n    }\n\n    /**\n     * Creates a `tsconfig.json` file to improve the IDE experience.\n     *\n     * @return the fully qualified path to the ``tsconfig.json`` file\n     */\n    private async _writeTypeScriptConfig(): Promise<string> {\n        const commentKey = '_generated_by_jsii_';\n        const commentValue = 'Generated by jsii - safe to delete, and ideally should be in .gitignore';\n        const configPath = path.join(this.options.projectInfo.projectRoot, 'tsconfig.json');\n        if (await fs.pathExists(configPath)) {\n            const currentConfig = await fs.readJson(configPath);\n            if (!(commentKey in currentConfig)) {\n                // tslint:disable-next-line:max-line-length\n                throw new Error(`A '${configPath}' file that was not generated by jsii is in ${this.options.projectInfo.projectRoot}. Aborting instead of overwriting.`);\n            }\n        }\n        // tslint:disable-next-line:no-console\n        LOG.debug(`Creating or updating ${colors.blue(configPath)}`);\n        await fs.writeJson(configPath, {\n            compilerOptions: {\n                ...COMPILER_OPTIONS,\n                // Need to stip the `lib.` prefix and `.d.ts` suffix\n                lib: COMPILER_OPTIONS.lib && COMPILER_OPTIONS.lib.map(name => name.slice(4, name.length - 5)),\n                // Those int-enums, we need to output the names instead\n                module: COMPILER_OPTIONS.module && ts.ModuleKind[COMPILER_OPTIONS.module],\n                target: COMPILER_OPTIONS.target && ts.ScriptTarget[COMPILER_OPTIONS.target],\n                jsx: COMPILER_OPTIONS.jsx && Case.snake(ts.JsxEmit[COMPILER_OPTIONS.jsx]),\n            },\n            [commentKey]: commentValue\n        }, {  replacer: utils.filterEmpty, spaces: 4 });\n        return configPath;\n    }\n}\n\nfunction _pathOfLibraries(host: ts.CompilerHost | ts.WatchCompilerHost<any>): string[] {\n    if (!COMPILER_OPTIONS.lib || COMPILER_OPTIONS.lib.length === 0) { return []; }\n    const lib = host.getDefaultLibLocation && host.getDefaultLibLocation();\n    if (!lib) {\n        throw new Error(`Compiler host doesn't have a default library directory available for ${COMPILER_OPTIONS.lib.join(', ')}`);\n    }\n    return COMPILER_OPTIONS.lib.map(name => path.join(lib, name));\n}\n\nconst SOURCE_DIRS = new Set(['bin', 'lib', 'test']);\nasync function _findSourceFiles(dir: string, isRoot = true): Promise<string[]> {\n    const result = new Array<string>();\n    for (const name of await fs.readdir(dir)) {\n        const file = path.join(dir, name);\n        if ((await fs.stat(file)).isDirectory()) {\n            // Only consider white-listed source-dirs when in the root.\n            if (!isRoot || SOURCE_DIRS.has(name)) {\n                result.push(...await _findSourceFiles(file, false));\n            }\n            continue;\n        }\n        if (!isRoot && name === 'tsconfig.json') {\n            // Part of a different typescript project!\n            return [];\n        }\n        if (!(name.endsWith('.ts') || name.endsWith('.tsx'))) { continue; }\n        if (name.endsWith('.d.ts') || name.endsWith('.d.tsx')) { continue; }\n        result.push(file);\n    }\n    return result;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"compiler.js","sourceRoot":"","sources":["compiler.ts"],"names":[],"mappings":"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","sourcesContent":["import Case = require('case');\nimport colors = require('colors/safe');\nimport fs = require('fs-extra');\nimport log4js = require('log4js');\nimport path = require('path');\nimport ts = require('typescript');\nimport { Assembler } from './assembler';\nimport { EmitResult, Emitter } from './emitter';\nimport { ProjectInfo } from './project-info';\nimport utils = require('./utils');\n\nconst COMPILER_OPTIONS: ts.CompilerOptions = {\n    alwaysStrict: true,\n    charset: 'utf8',\n    declaration: true,\n    experimentalDecorators: true,\n    inlineSourceMap: true,\n    inlineSources: true,\n    lib: ['lib.es2016.d.ts', 'lib.es2017.object.d.ts', 'lib.es2017.string.d.ts'],\n    module: ts.ModuleKind.CommonJS,\n    noEmitOnError: true,\n    noFallthroughCasesInSwitch: true,\n    noImplicitAny: true,\n    noImplicitReturns: true,\n    noImplicitThis: true,\n    noUnusedLocals: true,\n    noUnusedParameters: true,\n    resolveJsonModule: true,\n    strict: true,\n    strictNullChecks: true,\n    strictPropertyInitialization: false,\n    target: ts.ScriptTarget.ES2018\n};\n\nconst LOG = log4js.getLogger('jsii/compiler');\nexport const DIAGNOSTICS = 'diagnostics';\n\nexport interface CompilerOptions {\n    /** The information about the project to be built */\n    projectInfo: ProjectInfo;\n    /** Whether the compiler should watch for changes or just compile once */\n    watch: boolean;\n}\n\nexport class Compiler implements Emitter {\n    public constructor(private readonly options: CompilerOptions) {}\n\n    /**\n     * Compiles the configured program.\n     *\n     * @param files can be specified to override the standard source code location logic. Useful for example when testing \"negatives\".\n     */\n    public async emit(...files: string[]): Promise<EmitResult | never> {\n        if (this.options.watch) {\n            if (files.length > 0) {\n                throw new Error(`Files cannot be specified in watch mode!`);\n            }\n            return await this._startWatch();\n        } else {\n            if (files.length === 0) {\n                files = await _findSourceFiles(this.options.projectInfo.projectRoot);\n            }\n            return await this._buildOnce(files);\n        }\n    }\n\n    private async _buildOnce(files: string[]): Promise<EmitResult> {\n        await this._writeTypeScriptConfig();\n        const host = ts.createCompilerHost(COMPILER_OPTIONS);\n        if (!host.getDefaultLibLocation) {\n            throw new Error('No default library location was found on the TypeScript compiler host!');\n        }\n        host.getCurrentDirectory = () => this.options.projectInfo.projectRoot;\n        const prog = ts.createProgram(\n            files.concat(_pathOfLibraries(host)),\n            COMPILER_OPTIONS,\n            host\n        );\n        return await this._consumeProgram(prog, host.getDefaultLibLocation());\n    }\n\n    private async _startWatch(): Promise<never> {\n        return new Promise<never>(async () => {\n            const projectRoot = this.options.projectInfo.projectRoot;\n            const host = ts.createWatchCompilerHost(\n                await this._writeTypeScriptConfig(),\n                { ...COMPILER_OPTIONS, noEmitOnError: false },\n                { ...ts.sys, getCurrentDirectory() { return projectRoot; } }\n            );\n            if (!host.getDefaultLibLocation) {\n                throw new Error('No default library location was found on the TypeScript compiler host!');\n            }\n            const orig = host.afterProgramCreate;\n            host.afterProgramCreate = async builderProgram => {\n                await this._consumeProgram(builderProgram.getProgram(), host.getDefaultLibLocation!());\n                if (orig) { orig.call(host, builderProgram); }\n            };\n            ts.createWatchProgram(host);\n            // Previous call never returns\n        });\n    }\n\n    private async _consumeProgram(program: ts.Program, stdlib: string): Promise<EmitResult> {\n        const emit = program.emit();\n        if (emit.emitSkipped) {\n            LOG.error('Compilation errors prevented the JSII assembly from being created');\n            return emit;\n        }\n        const assembler = new Assembler(this.options.projectInfo, program, stdlib);\n        const assmEmit = await assembler.emit();\n        if (assmEmit.emitSkipped) {\n            LOG.error('Type model errors prevented the JSII assembly from being created');\n        }\n        return {\n            emitSkipped: assmEmit.emitSkipped,\n            diagnostics: [...emit.diagnostics, ...assmEmit.diagnostics]\n        };\n    }\n\n    /**\n     * Creates a `tsconfig.json` file to improve the IDE experience.\n     *\n     * @return the fully qualified path to the ``tsconfig.json`` file\n     */\n    private async _writeTypeScriptConfig(): Promise<string> {\n        const commentKey = '_generated_by_jsii_';\n        const commentValue = 'Generated by jsii - safe to delete, and ideally should be in .gitignore';\n        const configPath = path.join(this.options.projectInfo.projectRoot, 'tsconfig.json');\n        if (await fs.pathExists(configPath)) {\n            const currentConfig = await fs.readJson(configPath);\n            if (!(commentKey in currentConfig)) {\n                // tslint:disable-next-line:max-line-length\n                throw new Error(`A '${configPath}' file that was not generated by jsii is in ${this.options.projectInfo.projectRoot}. Aborting instead of overwriting.`);\n            }\n        }\n        // tslint:disable-next-line:no-console\n        LOG.debug(`Creating or updating ${colors.blue(configPath)}`);\n        await fs.writeJson(configPath, {\n            compilerOptions: {\n                ...COMPILER_OPTIONS,\n                // Need to stip the `lib.` prefix and `.d.ts` suffix\n                lib: COMPILER_OPTIONS.lib && COMPILER_OPTIONS.lib.map(name => name.slice(4, name.length - 5)),\n                // Those int-enums, we need to output the names instead\n                module: COMPILER_OPTIONS.module && ts.ModuleKind[COMPILER_OPTIONS.module],\n                target: COMPILER_OPTIONS.target && ts.ScriptTarget[COMPILER_OPTIONS.target],\n                jsx: COMPILER_OPTIONS.jsx && Case.snake(ts.JsxEmit[COMPILER_OPTIONS.jsx]),\n            },\n            [commentKey]: commentValue\n        }, {  replacer: utils.filterEmpty, spaces: 4 });\n        return configPath;\n    }\n}\n\nfunction _pathOfLibraries(host: ts.CompilerHost | ts.WatchCompilerHost<any>): string[] {\n    if (!COMPILER_OPTIONS.lib || COMPILER_OPTIONS.lib.length === 0) { return []; }\n    const lib = host.getDefaultLibLocation && host.getDefaultLibLocation();\n    if (!lib) {\n        throw new Error(`Compiler host doesn't have a default library directory available for ${COMPILER_OPTIONS.lib.join(', ')}`);\n    }\n    return COMPILER_OPTIONS.lib.map(name => path.join(lib, name));\n}\n\nconst SOURCE_DIRS = new Set(['bin', 'lib', 'test']);\nasync function _findSourceFiles(dir: string, isRoot = true): Promise<string[]> {\n    const result = new Array<string>();\n    for (const name of await fs.readdir(dir)) {\n        const file = path.join(dir, name);\n        if ((await fs.stat(file)).isDirectory()) {\n            // Only consider white-listed source-dirs when in the root.\n            if (!isRoot || SOURCE_DIRS.has(name)) {\n                result.push(...await _findSourceFiles(file, false));\n            }\n            continue;\n        }\n        if (!isRoot && name === 'tsconfig.json') {\n            // Part of a different typescript project!\n            return [];\n        }\n        if (!(name.endsWith('.ts') || name.endsWith('.tsx'))) { continue; }\n        if (name.endsWith('.d.ts') || name.endsWith('.d.tsx')) { continue; }\n        result.push(file);\n    }\n    return result;\n}\n"]}

@@ -15,2 +15,3 @@ import spec = require('jsii-spec');

readonly dependencies: ReadonlyArray<spec.Assembly>;
readonly peerDependencies: ReadonlyArray<spec.Assembly>;
readonly transitiveDependencies: ReadonlyArray<spec.Assembly>;

@@ -17,0 +18,0 @@ readonly bundleDependencies: {

@@ -20,5 +20,11 @@ "use strict";

}
if (pkg.peerDependencies && name in pkg.peerDependencies) {
throw new Error(`The "package.json" has "${name}" in "bundleDependencies", and also in "peerDependencies"`);
}
bundleDependencies[name] = version;
});
const [dependencies, transitiveDependencies] = await _loadDependencies(pkg.dependencies, projectRoot, new Set(Object.keys(bundleDependencies)));
const transitiveAssemblies = {};
const dependencies = await _loadDependencies(pkg.dependencies, projectRoot, transitiveAssemblies, new Set(Object.keys(bundleDependencies)));
const peerDependencies = await _loadDependencies(pkg.peerDependencies, projectRoot, transitiveAssemblies);
const transitiveDependencies = Object.keys(transitiveAssemblies).map(name => transitiveAssemblies[name]);
return {

@@ -37,2 +43,3 @@ projectRoot,

dependencies,
peerDependencies,
transitiveDependencies,

@@ -58,8 +65,7 @@ bundleDependencies,

}
async function _loadDependencies(dependencies, searchPath, bundled = new Set()) {
async function _loadDependencies(dependencies, searchPath, transitiveAssemblies, bundled = new Set()) {
if (!dependencies) {
return [[], []];
return [];
}
const assemblies = new Array();
const transitiveAssemblies = new Array();
for (const name of Object.keys(dependencies)) {

@@ -82,15 +88,9 @@ if (bundled.has(name)) {

assemblies.push(assm);
transitiveAssemblies.push(assm);
transitiveAssemblies[assm.name] = assm;
const pkgDir = path.dirname(pkg);
if (assm.dependencies) {
const [depAssemblies, depTransitiveAssemblies,] = await _loadDependencies(assm.dependencies, pkgDir);
for (const depAssembly of depAssemblies.concat(depTransitiveAssemblies)) {
if (transitiveAssemblies.find(a => a.name === depAssembly.name) != null) {
continue;
}
transitiveAssemblies.push(depAssembly);
}
await _loadDependencies(assm.dependencies, pkgDir, transitiveAssemblies);
}
}
return [assemblies, transitiveAssemblies];
return assemblies;
}

@@ -130,2 +130,2 @@ function _required(value, message) {

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"project-info.js","sourceRoot":"","sources":["project-info.ts"],"names":[],"mappings":"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","sourcesContent":["import fs = require('fs-extra');\nimport spec = require('jsii-spec');\nimport log4js = require('log4js');\nimport path = require('path');\nimport semver = require('semver');\n\n// tslint:disable:no-var-requires Modules without TypeScript definitions\nconst spdx: Set<string> = require('spdx-license-list/simple');\n// tslint:enable:no-var-requires\n\nconst LOG = log4js.getLogger('jsii/package-info');\n\nexport interface ProjectInfo {\n    readonly projectRoot: string;\n\n    readonly name: string;\n    readonly version: string;\n    readonly author: spec.Person;\n    readonly license: string;\n    readonly repository: {\n        readonly type: string;\n        readonly url: string;\n    };\n\n    readonly main: string;\n    readonly types: string;\n\n    readonly dependencies: ReadonlyArray<spec.Assembly>;\n    readonly transitiveDependencies: ReadonlyArray<spec.Assembly>;\n    readonly bundleDependencies: { readonly [name: string]: string };\n    readonly targets: spec.AssemblyTargets;\n    readonly description?: string;\n    readonly homepage?: string;\n    readonly contributors?: ReadonlyArray<spec.Person>;\n}\n\nexport async function loadProjectInfo(projectRoot: string): Promise<ProjectInfo> {\n    const pkg = require(path.join(projectRoot, 'package.json'));\n\n    const bundleDependencies: { [name: string]: string } = {};\n    (pkg.bundleDependencies || pkg.bundledDependencies || []).forEach((name: string) => {\n        const version = pkg.dependencies && pkg.dependencies[name];\n        if (!version) {\n            throw new Error(`The \"package.json\" has \"${name}\" in \"bundleDependencies\", but it is not declared in \"dependencies\"`);\n        }\n        bundleDependencies[name] = version;\n    });\n\n    const [dependencies, transitiveDependencies] =\n            await _loadDependencies(pkg.dependencies, projectRoot, new Set<string>(Object.keys(bundleDependencies)));\n\n    return {\n        projectRoot,\n\n        name: _required(pkg.name, 'The \"package.json\" file must specify the \"name\" attribute'),\n        version: _required(pkg.version, 'The \"package.json\" file must specify the \"version\" attribute'),\n        author: _toPerson(_required(pkg.author, 'The \"package.json\" file must specify the \"author\" attribute'), 'author'),\n        repository: {\n            url: _required(pkg.repository.url, 'The \"package.json\" file must specify the \"repository.url\" attribute'),\n            type: pkg.repository.type || _guessRepositoryType(pkg.repository.url)\n        },\n        license: _validateLicense(pkg.license),\n\n        main: _required(pkg.main, 'The \"package.json\" file must specify the \"main\" attribute'),\n        types: _required(pkg.types, 'The \"package.json\" file must specify the \"types\" attribute'),\n\n        dependencies,\n        transitiveDependencies,\n        bundleDependencies,\n        targets: {\n            ..._required(pkg.jsii, 'The \"package.json\" file must specify the \"jsii\" attribute').targets,\n            js: { npm: pkg.name }\n        },\n\n        description: pkg.description,\n        homepage: pkg.homepage,\n        contributors: pkg.contributors\n            && (pkg.contributors as any[]).map((contrib, index) => _toPerson(contrib, `contributors[${index}]`, 'contributor'))\n    };\n}\n\nfunction _guessRepositoryType(url: string): string {\n    if (url.endsWith('.git')) { return 'git'; }\n    const parts = url.match(/^([^:]+):\\/\\//);\n    if (parts && parts[1] !== 'http' && parts[1] !== 'https') {\n        return parts[1];\n    }\n    throw new Error(`The \"package.json\" file must specify the \"repository.type\" attribute (could not guess from ${url})`);\n}\n\nasync function _loadDependencies(dependencies: { [name: string]: string | spec.PackageVersion } | undefined,\n                                 searchPath: string,\n                                 bundled: Set<string> = new Set()): Promise<[spec.Assembly[], spec.Assembly[]]> {\n    if (!dependencies) { return [[], []]; }\n    const assemblies = new Array<spec.Assembly>();\n    const transitiveAssemblies = new Array<spec.Assembly>();\n    for (const name of Object.keys(dependencies)) {\n        if (bundled.has(name)) { continue; }\n        const dep = dependencies[name];\n        const versionString = typeof dep === 'string' ? dep : dep.version;\n        const version = new semver.Range(versionString);\n        if (!version) {\n            throw new Error(`Invalid semver expression for ${name}: ${versionString}`);\n        }\n        const pkg = _tryResolve(path.join(name, '.jsii'), searchPath);\n        LOG.debug(`Resolved dependency ${name} to ${pkg}`);\n        const assm = spec.validateAssembly(await fs.readJson(pkg));\n        if (!version.intersects(new semver.Range(assm.version))) {\n            throw new Error(`Declared dependency on version ${versionString} of ${name}, but version ${assm.version} was found`);\n        }\n        assemblies.push(assm);\n        transitiveAssemblies.push(assm);\n        const pkgDir = path.dirname(pkg);\n        if (assm.dependencies) {\n            const [depAssemblies, depTransitiveAssemblies, ] = await _loadDependencies(assm.dependencies, pkgDir);\n            for (const depAssembly of depAssemblies.concat(depTransitiveAssemblies)) {\n                if (transitiveAssemblies.find(a => a.name === depAssembly.name) != null) { continue; }\n                transitiveAssemblies.push(depAssembly);\n            }\n        }\n    }\n    return [assemblies, transitiveAssemblies];\n}\n\nfunction _required<T>(value: T, message: string): T {\n    if (value == null) {\n        throw new Error(message);\n    }\n    return value;\n}\n\nfunction _toPerson(value: any, field: string, defaultRole: string = field): spec.Person {\n    return {\n        name: _required(value.name, `The \"package.json\" file must specify the \"${field}.name\" attribute`),\n        roles: value.roles ? [...new Set(value.roles as string[])] : [defaultRole],\n        email: value.email,\n        url: value.url,\n        organization: value.organization ? value.organization : undefined\n    };\n}\n\nfunction _tryResolve(mod: string, searchPath: string): string {\n    try {\n        const paths = [ searchPath, path.join(searchPath, 'node_modules') ];\n        return require.resolve(mod, { paths });\n    } catch (e) {\n        throw new Error(`Unable to locate module: ${mod}`);\n    }\n}\n\nfunction _validateLicense(id: string): string {\n    if (id === 'UNLICENSED') { return id; }\n    if (!spdx.has(id)) {\n        throw new Error(`Invalid license identifier \"${id}\", see valid license identifiers at https://spdx.org/licenses/`);\n    }\n    return id;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"project-info.js","sourceRoot":"","sources":["project-info.ts"],"names":[],"mappings":"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","sourcesContent":["import fs = require('fs-extra');\nimport spec = require('jsii-spec');\nimport log4js = require('log4js');\nimport path = require('path');\nimport semver = require('semver');\n\n// tslint:disable:no-var-requires Modules without TypeScript definitions\nconst spdx: Set<string> = require('spdx-license-list/simple');\n// tslint:enable:no-var-requires\n\nconst LOG = log4js.getLogger('jsii/package-info');\n\nexport interface ProjectInfo {\n    readonly projectRoot: string;\n\n    readonly name: string;\n    readonly version: string;\n    readonly author: spec.Person;\n    readonly license: string;\n    readonly repository: {\n        readonly type: string;\n        readonly url: string;\n    };\n\n    readonly main: string;\n    readonly types: string;\n\n    readonly dependencies: ReadonlyArray<spec.Assembly>;\n    readonly peerDependencies: ReadonlyArray<spec.Assembly>;\n    readonly transitiveDependencies: ReadonlyArray<spec.Assembly>;\n    readonly bundleDependencies: { readonly [name: string]: string };\n    readonly targets: spec.AssemblyTargets;\n    readonly description?: string;\n    readonly homepage?: string;\n    readonly contributors?: ReadonlyArray<spec.Person>;\n}\n\nexport async function loadProjectInfo(projectRoot: string): Promise<ProjectInfo> {\n    const pkg = require(path.join(projectRoot, 'package.json'));\n\n    const bundleDependencies: { [name: string]: string } = {};\n    (pkg.bundleDependencies || pkg.bundledDependencies || []).forEach((name: string) => {\n        const version = pkg.dependencies && pkg.dependencies[name];\n        if (!version) {\n            throw new Error(`The \"package.json\" has \"${name}\" in \"bundleDependencies\", but it is not declared in \"dependencies\"`);\n        }\n\n        if (pkg.peerDependencies && name in pkg.peerDependencies) {\n            throw new Error(`The \"package.json\" has \"${name}\" in \"bundleDependencies\", and also in \"peerDependencies\"`);\n        }\n\n        bundleDependencies[name] = version;\n    });\n\n    const transitiveAssemblies: { [name: string]: spec.Assembly } = {};\n    const dependencies =\n        await _loadDependencies(pkg.dependencies, projectRoot, transitiveAssemblies, new Set<string>(Object.keys(bundleDependencies)));\n    const peerDependencies =\n        await _loadDependencies(pkg.peerDependencies, projectRoot, transitiveAssemblies);\n\n    const transitiveDependencies = Object.keys(transitiveAssemblies).map(name => transitiveAssemblies[name]);\n\n    return {\n        projectRoot,\n\n        name: _required(pkg.name, 'The \"package.json\" file must specify the \"name\" attribute'),\n        version: _required(pkg.version, 'The \"package.json\" file must specify the \"version\" attribute'),\n        author: _toPerson(_required(pkg.author, 'The \"package.json\" file must specify the \"author\" attribute'), 'author'),\n        repository: {\n            url: _required(pkg.repository.url, 'The \"package.json\" file must specify the \"repository.url\" attribute'),\n            type: pkg.repository.type || _guessRepositoryType(pkg.repository.url)\n        },\n        license: _validateLicense(pkg.license),\n\n        main: _required(pkg.main, 'The \"package.json\" file must specify the \"main\" attribute'),\n        types: _required(pkg.types, 'The \"package.json\" file must specify the \"types\" attribute'),\n\n        dependencies,\n        peerDependencies,\n        transitiveDependencies,\n        bundleDependencies,\n        targets: {\n            ..._required(pkg.jsii, 'The \"package.json\" file must specify the \"jsii\" attribute').targets,\n            js: { npm: pkg.name }\n        },\n\n        description: pkg.description,\n        homepage: pkg.homepage,\n        contributors: pkg.contributors\n            && (pkg.contributors as any[]).map((contrib, index) => _toPerson(contrib, `contributors[${index}]`, 'contributor'))\n    };\n}\n\nfunction _guessRepositoryType(url: string): string {\n    if (url.endsWith('.git')) { return 'git'; }\n    const parts = url.match(/^([^:]+):\\/\\//);\n    if (parts && parts[1] !== 'http' && parts[1] !== 'https') {\n        return parts[1];\n    }\n    throw new Error(`The \"package.json\" file must specify the \"repository.type\" attribute (could not guess from ${url})`);\n}\n\nasync function _loadDependencies(dependencies: { [name: string]: string | spec.PackageVersion } | undefined,\n                                 searchPath: string,\n                                 transitiveAssemblies: { [name: string]: spec.Assembly },\n                                 bundled = new Set<string>()): Promise<spec.Assembly[]> {\n    if (!dependencies) { return []; }\n    const assemblies = new Array<spec.Assembly>();\n    for (const name of Object.keys(dependencies)) {\n        if (bundled.has(name)) { continue; }\n        const dep = dependencies[name];\n        const versionString = typeof dep === 'string' ? dep : dep.version;\n        const version = new semver.Range(versionString);\n        if (!version) {\n            throw new Error(`Invalid semver expression for ${name}: ${versionString}`);\n        }\n        const pkg = _tryResolve(path.join(name, '.jsii'), searchPath);\n        LOG.debug(`Resolved dependency ${name} to ${pkg}`);\n        const assm = spec.validateAssembly(await fs.readJson(pkg));\n        if (!version.intersects(new semver.Range(assm.version))) {\n            throw new Error(`Declared dependency on version ${versionString} of ${name}, but version ${assm.version} was found`);\n        }\n        assemblies.push(assm);\n        transitiveAssemblies[assm.name] = assm;\n        const pkgDir = path.dirname(pkg);\n        if (assm.dependencies) {\n            await _loadDependencies(assm.dependencies, pkgDir, transitiveAssemblies);\n        }\n    }\n    return assemblies;\n}\n\nfunction _required<T>(value: T, message: string): T {\n    if (value == null) {\n        throw new Error(message);\n    }\n    return value;\n}\n\nfunction _toPerson(value: any, field: string, defaultRole: string = field): spec.Person {\n    return {\n        name: _required(value.name, `The \"package.json\" file must specify the \"${field}.name\" attribute`),\n        roles: value.roles ? [...new Set(value.roles as string[])] : [defaultRole],\n        email: value.email,\n        url: value.url,\n        organization: value.organization ? value.organization : undefined\n    };\n}\n\nfunction _tryResolve(mod: string, searchPath: string): string {\n    try {\n        const paths = [ searchPath, path.join(searchPath, 'node_modules') ];\n        return require.resolve(mod, { paths });\n    } catch (e) {\n        throw new Error(`Unable to locate module: ${mod}`);\n    }\n}\n\nfunction _validateLicense(id: string): string {\n    if (id === 'UNLICENSED') { return id; }\n    if (!spdx.has(id)) {\n        throw new Error(`Invalid license identifier \"${id}\", see valid license identifiers at https://spdx.org/licenses/`);\n    }\n    return id;\n}\n"]}
"use strict";
// Generated at 2018-10-23T15:42:11Z by generate.sh
// Generated at 2018-11-12T11:25:46Z by generate.sh
Object.defineProperty(exports, "__esModule", { value: true });
/** The qualified version number for this JSII compiler. */
// tslint:disable-next-line:no-var-requires
exports.VERSION = `${require('../package.json').version.replace(/\+[0-9a-f]+$/, '')} (build 100f5ad)`;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLG1EQUFtRDs7QUFFbkQsMkRBQTJEO0FBQzNELDJDQUEyQztBQUM5QixRQUFBLE9BQU8sR0FBRyxHQUFHLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsY0FBYyxFQUFFLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIEdlbmVyYXRlZCBhdCAyMDE4LTEwLTIzVDE1OjQyOjExWiBieSBnZW5lcmF0ZS5zaFxuXG4vKiogVGhlIHF1YWxpZmllZCB2ZXJzaW9uIG51bWJlciBmb3IgdGhpcyBKU0lJIGNvbXBpbGVyLiAqL1xuLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOm5vLXZhci1yZXF1aXJlc1xuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBgJHtyZXF1aXJlKCcuLi9wYWNrYWdlLmpzb24nKS52ZXJzaW9uLnJlcGxhY2UoL1xcK1swLTlhLWZdKyQvLCAnJyl9IChidWlsZCAxMDBmNWFkKWA7XG4iXX0=
exports.VERSION = `${require('../package.json').version.replace(/\+[0-9a-f]+$/, '')} (build 588d29d)`;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLG1EQUFtRDs7QUFFbkQsMkRBQTJEO0FBQzNELDJDQUEyQztBQUM5QixRQUFBLE9BQU8sR0FBRyxHQUFHLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsY0FBYyxFQUFFLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIEdlbmVyYXRlZCBhdCAyMDE4LTExLTEyVDExOjI1OjQ2WiBieSBnZW5lcmF0ZS5zaFxuXG4vKiogVGhlIHF1YWxpZmllZCB2ZXJzaW9uIG51bWJlciBmb3IgdGhpcyBKU0lJIGNvbXBpbGVyLiAqL1xuLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOm5vLXZhci1yZXF1aXJlc1xuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBgJHtyZXF1aXJlKCcuLi9wYWNrYWdlLmpzb24nKS52ZXJzaW9uLnJlcGxhY2UoL1xcK1swLTlhLWZdKyQvLCAnJyl9IChidWlsZCA1ODhkMjlkKWA7XG4iXX0=
{
"name": "jsii",
"version": "0.7.8",
"version": "0.7.9",
"description": "TypeScript compiler for jsii",

@@ -12,3 +12,4 @@ "license": "Apache-2.0",

"bin": {
"jsii": "bin/jsii"
"jsii": "bin/jsii",
"jsii-fix-peers": "bin/jsii-fix-peers"
},

@@ -27,8 +28,8 @@ "scripts": {

"@types/log4js": "^2.3.5",
"@types/node": "^8.10.24",
"@types/node": "^8.10.37",
"@types/nodeunit": "^0.0.30",
"@types/semver": "^5.5.0",
"@types/yargs": "^11.1.1",
"@types/yargs": "^11.1.2",
"clone": "^2.1.2",
"jsii-build-tools": "^0.7.8",
"jsii-build-tools": "^0.7.9",
"nodeunit": "^0.11.3",

@@ -42,9 +43,9 @@ "nyc": "^12.0.2"

"fs-extra": "^7.0.0",
"jsii-spec": "^0.7.8",
"log4js": "^3.0.4",
"semver": "^5.5.0",
"jsii-spec": "^0.7.9",
"log4js": "^3.0.6",
"semver": "^5.6.0",
"sort-json": "^2.0.0",
"spdx-license-list": "^4.1.0",
"typescript": "^3.1.1",
"yargs": "^12.0.1"
"typescript": "^3.1.6",
"yargs": "^12.0.2"
},

@@ -51,0 +52,0 @@ "nyc": {

@@ -63,2 +63,3 @@ "use strict";

dependencies: [],
peerDependencies: [],
transitiveDependencies: [],

@@ -70,2 +71,2 @@ bundleDependencies: {},

module.exports = nodeunit.testCase({ 'jsii rejections': testCases });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.negatives.js","sourceRoot":"","sources":["test.negatives.ts"],"names":[],"mappings":"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","sourcesContent":["import fs = require('fs-extra');\nimport nodeunit = require('nodeunit');\nimport path = require('path');\nimport ts = require('typescript');\nimport { Compiler } from '../lib/compiler';\nimport { ProjectInfo } from '../lib/project-info';\n\nconst SOURCE_DIR = path.join(__dirname, 'negatives');\n\nconst testCases: { [name: string]: (test: nodeunit.Test) => void } = {};\n\nfor (const source of fs.readdirSync(SOURCE_DIR)) {\n    if (!source.startsWith('neg.') || !source.endsWith('.ts') || source.endsWith('.d.ts')) { continue; }\n    const filePath = path.join(SOURCE_DIR, source);\n    testCases[source.replace(/neg\\.(.+)\\.ts/, '$1')] = async (test: nodeunit.Test) => {\n        const expectations = await _getExpectedErrorMessage(filePath);\n        test.ok(expectations.length > 0, `Expected error messages should be specified using ${MATCH_ERROR_MARKER}`);\n        const compiler = new Compiler({ projectInfo: _makeProjectInfo(source), watch: false });\n        const emitResult = await compiler.emit(path.join(SOURCE_DIR, source));\n        test.equal(emitResult.emitSkipped, true, `emitSkipped should be true`);\n        const errors = emitResult.diagnostics.filter(diag => diag.category === ts.DiagnosticCategory.Error);\n        for (const expectation of expectations) {\n            test.notEqual(errors.find(e => _messageText(e).indexOf(expectation) !== -1),\n                          null,\n                          `No error contained: ${expectation}. Errors: \\n${errors.map((e, i) => `[${i}] ${e.messageText}`).join('\\n')}`);\n        }\n\n        // Cleaning up...\n        for (const file of await fs.readdir(SOURCE_DIR)) {\n            if (file.startsWith('neg.') && (file.endsWith('.d.ts') || file.endsWith('.js'))) {\n                await fs.remove(path.join(SOURCE_DIR, file));\n            }\n            await fs.remove(path.join(SOURCE_DIR, '.jsii'));\n            await fs.remove(path.join(SOURCE_DIR, 'tsconfig.json'));\n        }\n\n        test.done();\n    };\n}\n\nexport = nodeunit.testCase({ 'jsii rejections': testCases });\n\nconst MATCH_ERROR_MARKER = '///!MATCH_ERROR:';\nasync function _getExpectedErrorMessage(file: string): Promise<string[]> {\n    const data = await fs.readFile(file, { encoding: 'utf8' });\n    const lines = data.split('\\n');\n    const matches = lines.filter(line => line.startsWith(MATCH_ERROR_MARKER))\n                         .map(line => line.substr(MATCH_ERROR_MARKER.length).trim());\n    return matches;\n}\n\nfunction _messageText(diagnostic: ts.Diagnostic | ts.DiagnosticMessageChain): string {\n    if (typeof diagnostic.messageText === 'string') {\n        return diagnostic.messageText;\n    }\n    if (diagnostic.messageText.next) {\n        return diagnostic.messageText.messageText + '|' + _messageText(diagnostic.messageText.next);\n    }\n    return diagnostic.messageText.messageText;\n}\n\nfunction _makeProjectInfo(types: string): ProjectInfo {\n    return {\n        projectRoot: SOURCE_DIR,\n        types,\n        main: types.replace(/(?:\\.d)?\\.ts(x?)/, '.js$1'),\n        name: 'jsii', // That's what package.json would tell if we look up...\n        version: '0.0.1',\n        license: 'Apache-2.0',\n        author: { name: 'John Doe', roles: ['author'] },\n        repository: { type: 'git', url: 'https://github.com/awslabs/jsii.git' },\n        dependencies: [],\n        transitiveDependencies: [],\n        bundleDependencies: {},\n        targets: {}\n    };\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.negatives.js","sourceRoot":"","sources":["test.negatives.ts"],"names":[],"mappings":"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","sourcesContent":["import fs = require('fs-extra');\nimport nodeunit = require('nodeunit');\nimport path = require('path');\nimport ts = require('typescript');\nimport { Compiler } from '../lib/compiler';\nimport { ProjectInfo } from '../lib/project-info';\n\nconst SOURCE_DIR = path.join(__dirname, 'negatives');\n\nconst testCases: { [name: string]: (test: nodeunit.Test) => void } = {};\n\nfor (const source of fs.readdirSync(SOURCE_DIR)) {\n    if (!source.startsWith('neg.') || !source.endsWith('.ts') || source.endsWith('.d.ts')) { continue; }\n    const filePath = path.join(SOURCE_DIR, source);\n    testCases[source.replace(/neg\\.(.+)\\.ts/, '$1')] = async (test: nodeunit.Test) => {\n        const expectations = await _getExpectedErrorMessage(filePath);\n        test.ok(expectations.length > 0, `Expected error messages should be specified using ${MATCH_ERROR_MARKER}`);\n        const compiler = new Compiler({ projectInfo: _makeProjectInfo(source), watch: false });\n        const emitResult = await compiler.emit(path.join(SOURCE_DIR, source));\n        test.equal(emitResult.emitSkipped, true, `emitSkipped should be true`);\n        const errors = emitResult.diagnostics.filter(diag => diag.category === ts.DiagnosticCategory.Error);\n        for (const expectation of expectations) {\n            test.notEqual(errors.find(e => _messageText(e).indexOf(expectation) !== -1),\n                          null,\n                          `No error contained: ${expectation}. Errors: \\n${errors.map((e, i) => `[${i}] ${e.messageText}`).join('\\n')}`);\n        }\n\n        // Cleaning up...\n        for (const file of await fs.readdir(SOURCE_DIR)) {\n            if (file.startsWith('neg.') && (file.endsWith('.d.ts') || file.endsWith('.js'))) {\n                await fs.remove(path.join(SOURCE_DIR, file));\n            }\n            await fs.remove(path.join(SOURCE_DIR, '.jsii'));\n            await fs.remove(path.join(SOURCE_DIR, 'tsconfig.json'));\n        }\n\n        test.done();\n    };\n}\n\nexport = nodeunit.testCase({ 'jsii rejections': testCases });\n\nconst MATCH_ERROR_MARKER = '///!MATCH_ERROR:';\nasync function _getExpectedErrorMessage(file: string): Promise<string[]> {\n    const data = await fs.readFile(file, { encoding: 'utf8' });\n    const lines = data.split('\\n');\n    const matches = lines.filter(line => line.startsWith(MATCH_ERROR_MARKER))\n                         .map(line => line.substr(MATCH_ERROR_MARKER.length).trim());\n    return matches;\n}\n\nfunction _messageText(diagnostic: ts.Diagnostic | ts.DiagnosticMessageChain): string {\n    if (typeof diagnostic.messageText === 'string') {\n        return diagnostic.messageText;\n    }\n    if (diagnostic.messageText.next) {\n        return diagnostic.messageText.messageText + '|' + _messageText(diagnostic.messageText.next);\n    }\n    return diagnostic.messageText.messageText;\n}\n\nfunction _makeProjectInfo(types: string): ProjectInfo {\n    return {\n        projectRoot: SOURCE_DIR,\n        types,\n        main: types.replace(/(?:\\.d)?\\.ts(x?)/, '.js$1'),\n        name: 'jsii', // That's what package.json would tell if we look up...\n        version: '0.0.1',\n        license: 'Apache-2.0',\n        author: { name: 'John Doe', roles: ['author'] },\n        repository: { type: 'git', url: 'https://github.com/awslabs/jsii.git' },\n        dependencies: [],\n        peerDependencies: [],\n        transitiveDependencies: [],\n        bundleDependencies: {},\n        targets: {}\n    };\n}\n"]}

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc