Skip to content
← Back to rules

unicorn/switch-case-break-position Style

🚧 An auto-fix is planned for this rule, but not implemented at this time.

What it does

Enforce consistent break/return/continue/throw position in case clauses.

Why is this bad?

Enforce that terminating statements (break, return, continue, throw) appear inside the block statement of a case clause, not after it. This can happen when refactoring — for example, removing an if wrapper but leaving the break outside the braces.

Examples

Examples of incorrect code for this rule:

js
switch (foo) {
  case 1:
    {
      doStuff();
    }
    break;
}

Examples of correct code for this rule:

js
switch (foo) {
  case 1: {
    doStuff();
    break;
  }
}

How to use

To enable this rule using the config file or in the CLI, you can use:

json
{
  "rules": {
    "unicorn/switch-case-break-position": "error"
  }
}
ts
import { defineConfig } from "oxlint";

export default defineConfig({
  rules: {
    "unicorn/switch-case-break-position": "error",
  },
});
bash
oxlint --deny unicorn/switch-case-break-position

Version

This rule was added in v1.59.0.

References