Skip to content

Alias Binding incorrectly propagates through properties on ephemeral import #43891

@ericdrobinson

Description

@ericdrobinson

Bug Report

This is related to the [closed] issue #41628. We have some code that requires JSON (with "resolveJsonModule": true set in our tsconfig.json) and immediately accesses a string field (package version) on the returned JSON object, assigning it to a var/let variable. This produces the following error:

Cannot assign to 'version' because it is not a variable. ts(2539)

🔎 Search Terms

require json cannot assign let alias

🕗 Version & Regression Information

  • This changed between versions 4.0 and 4.1

⏯ Playground Link

Playground link with relevant code

💻 Code

let version = require('./package.json').version;
version += "-debug";

🙁 Actual behavior

TypeScript reports the following error:

Cannot assign to 'version' because it is not a variable.

🙂 Expected behavior

We expect no error in this case. The version property on the object returned by the require function should not be considered an alias, but a simple string.

One workaround is, of course, to use the //ts-ignore hammer. Another is to do something like the following:

const pkg = require('./package.json');
let version = pkg.version;
version += "-debug";

Metadata

Metadata

Assignees

No one assigned

    Labels

    BugA bug in TypeScriptDomain: BinderGenerally crashes in, or caused by, the binder not doing something rightHelp WantedYou can do this

    Type

    No type

    Projects

    No projects

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions