---
title: Oxc (oxlint and oxfmt)
description: Learn how to use oxlint and oxfmt in your Turborepo projects.
product: turborepo
type: integration
summary: Configure oxlint and oxfmt as root tasks for fast linting and formatting in your monorepo.
prerequisites:
  - /docs/crafting-your-repository/configuring-tasks
related:
  - /docs/guides/tools/biome
  - /docs/guides/tools/eslint
---

# Oxc (oxlint and oxfmt)

<CopyPrompt
  title="Set up Oxc tools in a Turborepo"
  prompt={
  "Set up oxlint and oxfmt in this Turborepo.\n1) Install the tools\n2) Create scripts\n3) Set up turbo.json tasks\n\nWalk me through each step."
}
/>

[Oxc](https://oxc.rs/) is a collection of high-performance JavaScript and TypeScript tools written in Rust, including [oxlint](https://oxc.rs/docs/guide/usage/linter) (a fast linter) and [oxfmt](https://oxc.rs/docs/guide/usage/formatter) (a fast formatter).

<CreateTurboCallout />

Using Oxc tools with Turborepo [#using-oxc-tools-with-turborepo]

Similar to [Biome](/docs/guides/tools/biome), oxlint and oxfmt are **extraordinarily fast** tools. For this reason, we recommend using [Root Tasks](/docs/crafting-your-repository/configuring-tasks#registering-root-tasks) rather than creating separate scripts in each of your packages.

<Callout type="info" title="Caching behavior">
  Using oxlint or oxfmt at the root of the project will result in cache misses
  for all tasks when you upgrade versions or change configuration. If you prefer
  the tradeoff of higher cache hit ratios in these situations over less
  configuration, you can still run these tools in separate scripts like the
  other recommendations in our guides.
</Callout>

Setting up oxlint [#setting-up-oxlint]

Install oxlint [#install-oxlint]

First, install oxlint in your repository:

<PackageManagerTabs>
  <Tab value="pnpm">
    ```bash title="Terminal"
    pnpm add --save-dev oxlint
    ```
  </Tab>

  <Tab value="yarn">
    ```bash title="Terminal"
    yarn add --dev oxlint
    ```
  </Tab>

  <Tab value="npm">
    ```bash title="Terminal"
    npm install --save-dev oxlint
    ```
  </Tab>

  <Tab value="bun">
    ```bash title="Terminal"
    bun add --dev oxlint
    ```
  </Tab>
</PackageManagerTabs>

Create scripts [#create-scripts]

Add scripts to the root `package.json` of your repository:

```json title="./package.json"
{
  "scripts": {
    "lint": "oxlint .",
    "lint:fix": "oxlint --fix ."
  }
}
```

Create root tasks [#create-root-tasks]

Register the scripts to Turborepo as [Root Tasks](/docs/crafting-your-repository/configuring-tasks#registering-root-tasks):

```json title="./turbo.json"
{
  "tasks": {
    "//#lint": {},
    "//#lint:fix": {
      "cache": false
    }
  }
}
```

You can now run `turbo run lint` to lint your entire repository.

Setting up oxfmt [#setting-up-oxfmt]

oxfmt is a fast code formatter for JavaScript and TypeScript, designed to be a drop-in replacement for Prettier.

<Callout type="warn" title="oxfmt is experimental">
  oxfmt is currently in alpha and may not have full feature parity with
  Prettier. Check the [oxfmt
  documentation](https://oxc.rs/docs/guide/usage/formatter) for the latest
  status and supported options.
</Callout>

Install oxfmt [#install-oxfmt]

Install oxfmt as a dev dependency:

<PackageManagerTabs>
  <Tab value="pnpm">
    ```bash title="Terminal"
    pnpm add --save-dev oxfmt
    ```
  </Tab>

  <Tab value="yarn">
    ```bash title="Terminal"
    yarn add --dev oxfmt
    ```
  </Tab>

  <Tab value="npm">
    ```bash title="Terminal"
    npm install --save-dev oxfmt
    ```
  </Tab>

  <Tab value="bun">
    ```bash title="Terminal"
    bun add --dev oxfmt
    ```
  </Tab>
</PackageManagerTabs>

Create scripts [#create-scripts-1]

Add formatting scripts to the root `package.json`:

```json title="./package.json"
{
  "scripts": {
    "format": "oxfmt --check",
    "format:fix": "oxfmt ."
  }
}
```

Create root tasks [#create-root-tasks-1]

Register the scripts to Turborepo:

```json title="./turbo.json"
{
  "tasks": {
    "//#format": {},
    "//#format:fix": {
      "cache": false
    }
  }
}
```

You can now run `turbo run format` to check formatting and `turbo run format:fix` to format your code.

Using oxlint and oxfmt together [#using-oxlint-and-oxfmt-together]

For repositories using both tools, you can orchestrate them with a unified quality task:

```json title="./package.json"
{
  "scripts": {
    "lint": "oxlint .",
    "lint:fix": "oxlint --fix .",
    "format": "oxfmt --check",
    "format:fix": "oxfmt ."
  }
}
```

```json title="./turbo.json"
{
  "tasks": {
    "//#quality": {
      "dependsOn": ["//#lint", "//#format"]
    },
    "//#quality:fix": {
      "dependsOn": ["//#lint:fix", "//#format:fix"]
    },
    "//#lint": {},
    "//#lint:fix": {
      "cache": false
    },
    "//#format": {},
    "//#format:fix": {
      "cache": false
    }
  }
}
```

With this configuration:

* Run `turbo run quality` to check both linting and formatting
* Run `turbo run quality:fix` to fix both linting and formatting issues

---

[View full sitemap](/sitemap.md)