Skip to content

Commit

Permalink
feat: lookup project tsconfig
Browse files Browse the repository at this point in the history
This looks up the default tsconfig.json file for the current project when used from the CLI, to avoid possible compliation errors. Fixes #2062
  • Loading branch information
slhck committed Sep 9, 2024
1 parent 46f638e commit bcf6160
Show file tree
Hide file tree
Showing 4 changed files with 37 additions and 1 deletion.
2 changes: 2 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,8 @@ Note that different platforms (e.g. Windows) may use different path separators s

Also note that you need to quote paths with `*` as otherwise the shell will expand the paths and therefore only pass the first path to the generator.

By default, the command-line generator will use the `tsconfig.json` file in the current working directory, or the first parent directory that contains a `tsconfig.json` file up to the root of the filesystem. If you want to use a different `tsconfig.json` file, you can use the `--tsconfig` option. In particular, if you need to use different compilation options for types, you may want to create a separate `tsconfig.json` file for the schema generation only.

### Options

```
Expand Down
22 changes: 22 additions & 0 deletions src/Utils/findTsConfig.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
import fs from "fs";
import path from "path";

/**
* Find the tsconfig.json file in the current working directory or any parent directory.
* This is the behavior from tsc: https://www.typescriptlang.org/docs/handbook/tsconfig-json.html
*
* @param directory - The directory to start searching from. Defaults to the current working directory.
* @param filename - The filename of the tsconfig.json file. Defaults to "tsconfig.json".
* @returns The path to the tsconfig.json file or undefined if no such file was found.
*/
export function findTsConfig(directory: string = process.cwd(), filename = "tsconfig.json"): string | undefined {
const tsConfigPath = path.join(directory, filename);
if (fs.existsSync(tsConfigPath)) {
return tsConfigPath;
}
const parentDir = path.dirname(directory);

Check warning on line 17 in src/Utils/findTsConfig.ts

View check run for this annotation

Codecov / codecov/patch

src/Utils/findTsConfig.ts#L17

Added line #L17 was not covered by tests
if (parentDir === directory) {
return undefined;

Check warning on line 19 in src/Utils/findTsConfig.ts

View check run for this annotation

Codecov / codecov/patch

src/Utils/findTsConfig.ts#L19

Added line #L19 was not covered by tests
}
return findTsConfig(parentDir, filename);

Check warning on line 21 in src/Utils/findTsConfig.ts

View check run for this annotation

Codecov / codecov/patch

src/Utils/findTsConfig.ts#L21

Added line #L21 was not covered by tests
}
11 changes: 11 additions & 0 deletions test/unit/findTsConfig.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import path from "path";
import { findTsConfig } from "../../src/Utils/findTsConfig.js";

describe("findTsConfig", () => {
it("returns the path to the tsconfig.json file", () => {
const TS_CONFIG_FILE = path.resolve(__dirname, "../../tsconfig.json");
const foundTsConfig = findTsConfig();
expect(foundTsConfig).toBeDefined();
expect(path.resolve(foundTsConfig as string)).toEqual(TS_CONFIG_FILE);
});
});
3 changes: 2 additions & 1 deletion ts-json-schema-generator.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import stableStringify from "safe-stable-stringify";
import { createGenerator } from "./factory/generator.js";
import type { Config } from "./src/Config.js";
import { BaseError } from "./src/Error/BaseError.js";
import { findTsConfig } from "./src/Utils/findTsConfig.js";

import pkg from "./package.json";

Expand Down Expand Up @@ -56,7 +57,7 @@ const args = new Command()
const config: Config = {
minify: args.minify,
path: args.path,
tsconfig: args.tsconfig,
tsconfig: args.tsconfig ?? findTsConfig(),
type: args.type,
schemaId: args.id,
expose: args.expose,
Expand Down

0 comments on commit bcf6160

Please sign in to comment.