> ## Documentation Index
> Fetch the complete documentation index at: https://docs.fallow.tools/llms.txt
> Use this file to discover all available pages before exploring further.

# Known limitations

> Known limitations of fallow's syntactic analysis, including dynamic imports, runtime patterns, and framework-specific edge cases with workarounds.

Fallow is a syntactic analyzer: no TypeScript compiler, no type resolution. The trade-off is speed; the cost is that type-conditional dead code is not detectable.

<Info>
  The limitations below apply to specific patterns. Standard TypeScript projects with `isolatedModules: true` are unaffected by most of them.
</Info>

<Accordion title="Syntactic analysis only (no TypeScript type information)">
  Fallow parses source code as syntax trees using Oxc and uses `oxc_semantic` for scope-aware binding analysis. It does **not** invoke the TypeScript compiler or resolve type information. This trade-off is what makes fallow fast.

  **Impact:** Type-only imports (`import type { Foo }`) are handled correctly. Value imports used only as type annotations (e.g., `import { Foo }` followed by `const x: Foo`) are also tracked correctly via `oxc_semantic` reference counting. Conditional type exports or dead code behind generic interfaces would require actual type resolution to detect.

  **Workaround:** Set `isolatedModules: true` in `tsconfig.json`. esbuild, swc, and Vite already require this, so most modern projects have it. With `isolatedModules`, every import is either explicitly `import type` or a real value import, removing ambiguity.

  ```jsonc tsconfig.json theme={null}
  {
    "compilerOptions": {
      "isolatedModules": true
    }
  }
  ```
</Accordion>

<Accordion title="Svelte export let prop ambiguity">
  In Svelte components, `export let` declarations serve double duty: they define component props **and** regular exports. Fallow can't distinguish between props (used by consumers via the template) and utility exports that may genuinely be unused.

  **Impact:** Some unused exports in `.svelte` files may not be reported.

  **Workaround:** No configuration workaround exists. Review Svelte component exports manually. Extract utility functions into separate `.ts` files where fallow can track them accurately.

  <Tip>
    This limitation is about `export let` prop detection only. Fallow **does** track template-visible imports since v2.15.0: component tags, directives (`use:tooltip`, `v-focus-trap`), expressions, `$store` subscriptions in Svelte, and `v-on`/`v-bind` object syntax in Vue are all correctly credited as used. See [File types](/analysis/file-types) for details.
  </Tip>
</Accordion>

<Accordion title="CSS/SCSS regex-based parsing">
  CSS and SCSS files are parsed with lightweight regex extraction rather than a full CSS parser. This covers the most common patterns but not the entire CSS specification.

  **What's tracked:**

  * `@import` and `@use` statements
  * `@forward` rules
  * `@apply` and `@tailwind` directives (as Tailwind dependency usage)
  * `@plugin` directives (Tailwind v4 plugin sources, package or relative)

  **What's not tracked:**

  * `composes:` (CSS Modules composition)
  * `:global()` and `:local()` pseudo-selectors
  * Complex selector-based dependencies

  **Workaround:** If fallow reports false positives for CSS files that use `composes:` or `:global()`, suppress them with `ignorePatterns` or inline comments.

  ```jsonc .fallowrc.json theme={null}
  {
    "ignorePatterns": ["**/legacy-styles/**/*.css"]
  }
  ```
</Accordion>

<Accordion title="NestJS and dependency injection class members">
  Fallow tracks class member usage syntactically by looking for direct references in source code. In NestJS and other DI frameworks, abstract class methods may be invoked at runtime through the DI container without appearing as direct references.

  **Impact:** Abstract class methods and properties consumed via dependency injection may be reported as unused.

  **Workaround:** Disable `unused-class-members` for DI-heavy projects:

  <CodeGroup>
    ```jsonc .fallowrc.json theme={null}
    {
      "rules": {
        "unused-class-members": "off"
      }
    }
    ```

    ```toml fallow.toml theme={null}
    [rules]
    unused-class-members = "off"
    ```
  </CodeGroup>
</Accordion>

<Accordion title="Library consumer types (noisy but correct)">
  If your package exports types for external consumers (e.g., `ButtonProps`, `Config`), fallow correctly reports them as unused within your project, because they are. No internal file imports them.

  **Impact:** Correct findings that are noisy for library authors.

  **Workaround:** Use `ignoreExports` to mark public API files:

  ```jsonc .fallowrc.json theme={null}
  {
    "ignoreExports": [
      { "file": "src/index.ts", "exports": ["*"] },
      { "file": "src/types.ts", "exports": ["*"] }
    ]
  }
  ```
</Accordion>

<Accordion title="Config parsing ceiling">
  Fallow's built-in plugins parse config files (e.g., `vite.config.ts`, `jest.config.js`) using Oxc's AST parser. This handles static objects, arrays, and `defineConfig()` wrappers, but it can't evaluate arbitrary JavaScript.

  **What's handled:**

  * Static object literals and arrays
  * `defineConfig()` / `module.exports` wrappers
  * String concatenation in simple cases

  **What's not handled:**

  * Computed property keys
  * Conditional expressions (`process.env.NODE_ENV === 'production' ? ... : ...`)
  * Nested factory functions
  * Dynamic `require()` with variables

  **Workaround:** Add undetected entry points manually in your fallow config:

  ```jsonc .fallowrc.json theme={null}
  {
    "entry": ["src/dynamic-entry.ts", "scripts/*.ts"]
  }
  ```
</Accordion>

<Accordion title="React Native native modules">
  React Native auto-linked native packages (installed via `npx pod-install` or auto-linking) aren't detected as used by fallow. These packages may not have any explicit `import` in JavaScript code.

  **Impact:** Auto-linked packages like `react-native-screens` or `react-native-gesture-handler` may be reported as unused dependencies.

  **Workaround:** Add auto-linked packages to `ignoreDependencies`:

  ```jsonc .fallowrc.json theme={null}
  {
    "ignoreDependencies": [
      "react-native-screens",
      "react-native-gesture-handler",
      "react-native-safe-area-context"
    ]
  }
  ```
</Accordion>

<Accordion title="LSP column offsets are byte-based">
  The fallow LSP server reports column positions as byte offsets rather than character offsets. For ASCII-only source files this makes no difference. For files with multi-byte characters (emoji, CJK, accented characters), the column number may be off by a few positions.

  **Impact:** Diagnostic squiggles in VS Code may be slightly misaligned on lines containing non-ASCII characters.

  **Workaround:** This is a cosmetic issue only. The line number and file path are always correct, so navigation still works. A fix is planned for a future release.
</Accordion>

## See also

<CardGroup cols={3}>
  <Card title="Inline suppression" icon="comment-slash" href="/configuration/suppression">
    Suppress individual false positives directly in source code.
  </Card>

  <Card title="Configuration" icon="gear" href="/configuration/overview">
    Full config file reference for ignorePatterns, ignoreExports, and rules.
  </Card>

  <Card title="Agent integration" icon="robot" href="/integrations/mcp">
    How agents handle false positives via config and suppression.
  </Card>
</CardGroup>
