Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

@ts-ignore for the block scope and imports #19573

Open
zpdDG4gta8XKpMCd opened this issue Oct 30, 2017 · 206 comments
Open

@ts-ignore for the block scope and imports #19573

zpdDG4gta8XKpMCd opened this issue Oct 30, 2017 · 206 comments
Labels
Awaiting More Feedback This means we'd like to hear from more people who would be helped by this feature Suggestion An idea for TypeScript VS Code Tracked There is a VS Code equivalent to this issue

Comments

@zpdDG4gta8XKpMCd
Copy link

zpdDG4gta8XKpMCd commented Oct 30, 2017

currently @ts-ignore only mutes the errors from the line immediately below it

would be great to have the same for

  1. the whole next block
  2. also for all imports

use case:

refactoring: commenting out a piece of code to see what would break without it, yet avoiding to deal with the errors in the file where commented code is which can be many

@zpdDG4gta8XKpMCd zpdDG4gta8XKpMCd changed the title @ts-ignore for the block scope @ts-ignore for the block scope and imports Oct 30, 2017
@mhegazy mhegazy added Suggestion An idea for TypeScript Awaiting More Feedback This means we'd like to hear from more people who would be helped by this feature labels Oct 30, 2017
@mjbvz mjbvz added the VS Code Tracked There is a VS Code equivalent to this issue label Feb 2, 2018
@bluelovers
Copy link
Contributor

need this lol

@jeahyoun
Copy link

Current use case for this feature is a unit test that deals with whitespace. We have the "no-trailing-whitespace" rule turned on in our codebase for good reason, but not being able to overpower it on a block level means that we can't easily test for trailing whitespace and carriage returns using an ES6 template string.

@DrSensor
Copy link

one of my use case to use custom bundling a.k.a partial import in mathjs

// tslint:disable:no-var-requires
import core from 'mathjs/core'

// @ts-ignore
import mathUnit from 'mathjs/lib/type/unit'
// @ts-ignore
import mathExpression from 'mathjs/lib/expression/function'
// @ts-ignore
import mathArithmatic from 'mathjs/lib/function/arithmetic'


const math = core.create()
// math.import(require('mathjs/lib/type/unit'))
// math.import(require('mathjs/lib/expression/function')) // compile, eval
// math.import(require('mathjs/lib/function/arithmetic')) // basic arithmetic like divide, exponent, etc

math.import(mathUnit)
math.import(mathExpression) // compile, eval
math.import(mathArithmatic) // basic arithmetic like divide, exponent, etc

export const unit = math.unit
export const createUnit = math.createUnit
export const compile = math.compile

@ptallett
Copy link

ptallett commented Jul 1, 2018

I'd like to ignore errors for a whole file. I have inherited some ES6 JS code I'd like to transpile to ES5 but have to use Babel at the moment. Would be nice to just rename the file to .ts and transpile with TS.

@DanielRosenwasser
Copy link
Member

@ptallett you can just compile .js files using allowJs and including it in the compilation. By default, we don't issue errors on .js files unless the file has a // @ts-check comment at the top, or you turn on checkJs.

@ExoMemphiz
Copy link

ExoMemphiz commented Aug 9, 2018

I would still love this functionality, I am sitting in a test file, it has the extension .ts, so I can import and easily see what parameters go where, and compiling it to a directory beside the src files is brilliant for my use case.

Most of my lines are now red, as I purposefully try to exclude some parameters, or give a different type to the function, than it originally takes, and expect an error thrown, as I check for it in runtime as well.

It would be lovely to not have a bunch of red lines everywhere. :)

Is there any update on it, or has anyone found some good way of doing this?

@anodynos
Copy link

anodynos commented Oct 10, 2018

Using lodash & especially lodash/fp with TypeScript is so painful, and even with latest versions of lodash & @types/lodash you can end up with very cryptic error messages.

If we can have a @ts-ignore-block that ignores errors for the following block, it would be great for use cases like this where you know what you're doing :-)

@jnwu
Copy link

jnwu commented Oct 10, 2018

I am working with legacy code with numerous global scoped variables, and writing @ts-ignore on every line is become tedious, any updates on this?

@dwilhel1
Copy link

dwilhel1 commented Oct 23, 2018

Also seeking an update on this request. Thanks!

@code-elf
Copy link

code-elf commented Nov 2, 2018

This would also be very important for what I'm doing (namely type-checking generated Vue template render functions, which would require disabling specific inspections for a block of code.)
Along with this issue, #19139 would be very important, because especially when applying to large parts of code, you'll only want to disable specific inspections.

@pungggi
Copy link

pungggi commented Dec 1, 2018

with suppressing the hole file this could be added to Editors like vs code to save in workspace settings or such.

@mszczepanczyk
Copy link

Also need this. I'm auto-generating a whole ts file with types for my GraphQL schema using graphql-code-generator and there's an extraneous import triggering noUnusedLocals.

@marianturchyn
Copy link

marianturchyn commented Dec 17, 2018

/* tslint:disable */

code

/* tslint:enable */

@Blanen
Copy link

Blanen commented Dec 17, 2018

// @ts-ignore-start
// @ts-ignore-end

Can be combined with: #19139

// @ts-ignore-start Property_0_does_not_exist_on_type_1
// @ts-ignore-end (possible include the error type again so you can turn be more specific of where you want to ignore some errors

@marianturchyn this isn't tslint.

@lonix1
Copy link

lonix1 commented Jan 25, 2019

Sometimes while I'm moving stuff around and refactoring, I want to temporarily ignore the whole file (i.e. not compile it), without fiddling with the CLI options.

The quickest/easiest is a flag at the top of the file:

// @ts-ignore-file

@mgol
Copy link

mgol commented Jan 25, 2019

@lonix1 You use case is covered by:

// @ts-ignore-start
// @ts-ignore-end

You don't have to use the // @ts-ignore-end part. Many lint tools work that way.

@lonix1
Copy link

lonix1 commented Jan 25, 2019

@mgol I don't want to derail this thread... but I tried your suggestion - thanks! - and it didn't work for me. I put the lines together at the top of the file, and also tried one at the top and the other at the bottom.
Can anyone else get it to work?

@mgol
Copy link

mgol commented Jan 25, 2019

@lonix1 I meant that @Blanen's proposal would also work for you, we don't need TypeScript to implement both // @ts-ignore-start + // @ts-ignore-end and // @ts-ignore-file, implementing // @ts-ignore-start + // @ts-ignore-end would be enough. This is not implemented, that's why this issue is still open.

@matthiasg
Copy link

@DanielRosenwasser this would only work when the ts files get stored in another folder during build. when the project is setup to place js files next to the ts files it wont. Also will js files be 'compiled' e.g. transform to es5 ? When transporting legacy code this would really be helpful.

@fgcui1204
Copy link

Need this feature.

@haggholm
Copy link

Use case:

TypeORM expects us to create DB entity classes that have columns that may or may not be nullable. Many columns (hence) are not nullable…and hence should be treated, except in the class definition, as if the properties are unconditionally of certain defined types. However, Typescript requires us to define every column as being strongly typed. Hence, we end up with a great many entities like:

@Entity('investigation')
export class InvestigationEntity {
	@PrimaryGeneratedColumn('uuid')
	// @ts-ignore TS2564
	public investigationId: string;

	@Column({ type: 'uuid' })
	// @ts-ignore TS2564
	public userId: string;

	@Column({ type: 'jsonb' })
	// @ts-ignore TS2564
	public metadata: IEncryptedJSONContainer;
}

Every column is required and (hence) certain to contain a value, but due to the way TypeORM works, every property must be defined in such a way that it lacks an initializer. It would be extremely convenient to be able to suppress this particular, ORM-derived/specific issue, for an entire class (hence/or file).

@RyanCavanaugh
Copy link
Member

@haggholm any reason to prefer ts-ignore over public metadata!: IEncryptedJSONContainer ?

@haggholm
Copy link

@RyanCavanaugh Ignorance! I had missed that feature in the documentation. Sorry; please ignore.

@spacecowgoesmoo
Copy link

spacecowgoesmoo commented Nov 17, 2023

I solved my issue with a refactor but it still seems bad to not have this as an option. There's 6 years of other people with use cases posted in here at this point.

@akarola-IDG
Copy link

why still not added?

@dwilhel1
Copy link

why still not added?

Today is the Thanksgiving holiday in the USA where Microsoft is headquartered 🦃

@yolpsoftware
Copy link

why still not added?

Today is the Thanksgiving holiday in the USA where Microsoft is headquartered 🦃

Right. They can do it tomorrow then.

@HolgerJeromin
Copy link
Contributor

why still not added?

Probably because it would be no good feature in most cases:
#19573 (comment)

@AltairTF
Copy link

Why not close this and admit it will never be added?

@RyanCavanaugh
Copy link
Member

Why not close this and admit it will never be added?

People don't like it when we do that either!

@thetayloredman
Copy link

Again.. just apply ts-ignore to the following AST element. Almost every other ignore works that way (e.g. Prettier) and this solves the issue. I'm shocked TS doesn't do this.

@thetayloredman
Copy link

thetayloredman commented Jan 4, 2024 via email

@WhyINeedToFillUsername
Copy link

I can't see the Ryan's comment here (only in email), I am replying to this:

// @ts-ignore the constraint violation error is wrong
function foo(a: IsViolatingConstraint<T>) {
  return a.widht; // <-- oops, no typechecking now
}
  • is there a problem to limit the ignore to specific issue only? I agree that blanket ts-ignore is not desired, but ignoring a specific issue would be very helpful.

@HolgerJeromin
Copy link
Contributor

is there a problem to limit the ignore to specific issue only? I agree that blanket ts-ignore is not desired, but ignoring a specific issue would be very helpful.

Which would be #19139

@nurbek-mirai
Copy link

Bump.

@DeepDoge
Copy link

This would be really useful for JS with JSDoc, since in JSDoc we can't do things like as never, to force a type, when we know better than the typing system.

@weswigham
Copy link
Member

This would be really useful for JS with JSDoc, since in JSDoc we can't do things like as never, to force a type, when we know better than the typing system.

func(/** @type {*} */(expression_with_wrong_type));

@ION606
Copy link

ION606 commented May 27, 2024

wait did this ever get implemented? #19573 (comment) (I assume not but I choose to have hope)

@cscheffauer
Copy link

+1

@pm0u
Copy link

pm0u commented Jul 25, 2024

refactoring js -> ts, would love to have this feature so I could partially refactor a file while ignoring the ts errors in the rest so as to not overwhelm reviewers with an 800 line change summary. Its all tested and working, so I don't need TS to tell me anything about the unconverted js remaining in the file. I just want to break up a refactor and have each step pass CI checks.

@SharperImage
Copy link

Bruh please.

@angrybacon
Copy link

Pretty sure all the relevant people have unsubscribed by now with the constant and unnecessary noise so I suppose I'll do that as well

I just want to break up a refactor and have each step pass CI checks.

@pm0u Not really what you asked for but have you considered JSDoc as a first step? And if when approaching 100% coverage you still want actual TypeScript, codemod(s) to migrate the syntax

@pm0u
Copy link

pm0u commented Aug 5, 2024

@angrybacon interesting, I did not know about these (looking at ts-migrate) since we already have pretty solid JSDoc coverage on these files (to please the rest of the TS codebase) I think the JSDoc plugin would work. Not sure if this would exactly solve our problem, since it would still result in a lot of code for a human to review, but perhaps could help since there would be an outside tool involved. Thanks!

@anaibol
Copy link

anaibol commented Sep 24, 2024

+1

@Remzi1993
Copy link

Is this still not possible? I don't understand why populair functionality not gets implemented, it's not like corporations also need this.

@HolgerJeromin
Copy link
Contributor

#19573 (comment)
still applies...

@sigubrat
Copy link

sigubrat commented Oct 10, 2024

I'll replace my previous satirical comment made mostly out of spite to a more serious reason:

I need to do a crap-ton of type conversions due to how values are handled in form components utilizing TS and a legacy backend that needs to store yes/no, checkboxes and select fields as numbers. Doing these conversions are a bit wonky one way, but don't trigger any errors, while they do while converting them back again. The code works just fine, but TS can't possibly know that so it shows an error. I can choose to either ignore these errors, completely disable all errors in the file (scary for obvious reasons) or line-by-line tell TS to chill the fuck out.

Why not just give us the option to disable errors over multiple lines? We can already do it but it's ugly, so it changes nothing but quality-of-life for those that want to use it.
To those that don't need it or feel like it creates risk? Just...don't use it?

@angrybacon
Copy link

To anyone with the right permissions, please lock this thread. I wish everyone could flag comments that are out of place so that the thread becomes readable again but GH only provides such a feature for contributors of the repository AFAICT. I feel like the participants here have provided enough 1. workarounds 2. history 3. limitations that this conversation can be locked and serve as a 👍-counter rather than unwarranted noise in (y)our inboxes.

@gondar00
Copy link

gondar00 commented Nov 5, 2024

+1

Krinkle added a commit to qunitjs/qtap that referenced this issue Jan 9, 2025
Workarounds for TypeScript shortcomings:

* `@typedef` can't be namespaced in JS files, thus mandating awkward
  constructs like `/** @import { Logger } from './qtap.js' */`.

* There is no way to apply a type to a `catch` clause in JS files.
  The workaround is to re-assign it to a local variable and type that
  like `catch (e) { /* @type {any} */ const err = e;`.

* There is no way to disable type checking for an entire block,
  function, or otherwise multiple lines, thus mandating lots of
  `// @ts-ignore` lines for the same problem, or to move the code
  out into a separate file where the entire file is ignored (as I
  ended up doing for client.js).

  Reported 8y ago, microsoft/TypeScript#19573.

* `@types/node` lacks Error.code or Error.stack definitinos,
  thus regularly requiring use of the above workarounds.
  Reported 3y ago, DefinitelyTyped/DefinitelyTyped#59692.

* The `noUnusedLocals` rule is broken, making a paradoxal claim.

  ```
  /** @import { Logger } from './qtap.js' */

  /**
    * @param {Logger} logger
    */
  ```
  The above makes sense, and passes, until noUnusedLocals is enabled.
  Then it fails:

  ```
  error TS6133: 'Logger' is declared but its value is never read.
  /** @import { Logger } from './qtap.js' */
  ```

  Removing the import, of course, causes a more severe error instead:
  ```
  error TS2304: Cannot find name 'Logger'.
  * @param {Logger} logger
  ```

  Reported 2y ago, closed as wontfix.
  microsoft/TypeScript#54042

* The `noUnusedParameters` errors on unused arguments before arguments
  that are required and used. It appears to be unconfigurable and thus
  serves no purpose. Leave disabled in favor of ESLint no-unused-vars.
Krinkle added a commit to qunitjs/qtap that referenced this issue Jan 11, 2025
Workarounds for TypeScript shortcomings:

* `@typedef` can't be namespaced in JS files, thus mandating awkward
  constructs like `/** @import { Logger } from './qtap.js' */`.

* There is no way to apply a type to a `catch` clause in JS files.
  The workaround is to re-assign it to a local variable and type that
  like `catch (e) { /* @type {any} */ const err = e;`.

* There is no way to disable type checking for an entire block,
  function, or otherwise multiple lines, thus mandating lots of
  `// @ts-ignore` lines for the same problem, or to move the code
  out into a separate file where the entire file is ignored (as I
  ended up doing for client.js).

  Reported 8y ago, microsoft/TypeScript#19573.

* `@types/node` lacks Error.code or Error.stack definitinos,
  thus regularly requiring use of the above workarounds.
  Reported 3y ago, DefinitelyTyped/DefinitelyTyped#59692.

* The `noUnusedLocals` rule is broken, making a paradoxal claim.

  ```
  /** @import { Logger } from './qtap.js' */

  /**
    * @param {Logger} logger
    */
  ```
  The above makes sense, and passes, until noUnusedLocals is enabled.
  Then it fails:

  ```
  error TS6133: 'Logger' is declared but its value is never read.
  /** @import { Logger } from './qtap.js' */
  ```

  Removing the import, of course, causes a more severe error instead:
  ```
  error TS2304: Cannot find name 'Logger'.
  * @param {Logger} logger
  ```

  Reported 2y ago, closed as wontfix.
  microsoft/TypeScript#54042

* The `noUnusedParameters` errors on unused arguments before arguments
  that are required and used. It appears to be unconfigurable and thus
  serves no purpose. Leave disabled in favor of ESLint no-unused-vars.

* The `noImplicitAny: false` setting, while ostensibly turning some
  checks off, makes array behaviour more strict, changing default
  from `any[]` to an awkward `never[]`.

  Reported 5y ago, https://stackoverflow.com/a/57563877/319266

  ```
  const seen = { plan: null, asserts: [] };

  p.on('assert', function (result) {
    //> error TS2345: Argument of type 'any' is not assignable to parameter of type 'never'.
    seen.asserts.push(result);
  })
  ```
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Awaiting More Feedback This means we'd like to hear from more people who would be helped by this feature Suggestion An idea for TypeScript VS Code Tracked There is a VS Code equivalent to this issue
Projects
None yet