mirror of
https://github.com/ezolenko/rollup-plugin-typescript2.git
synced 2025-12-08 19:06:16 +00:00
- basically, general format is:
```ts
import x from "external-dep"
import y from "./internal-dep"
```
- so external deps, new line, then internal/local deps
- with some further sorting within there, like trying to keep Node
built-ins (e.g. `path`) at the top half of externals, then core deps
like `typescript`, then any other external deps
- and similar for internal deps -- core internals at the top half of
internals, then any other internal deps
- just to keep things consistent between files -- makes the top
easier to read through when it's similar between files
- also makes it easier for contributors to understand where to put
imports, as there's a sorting already there
- this is how I generally sort my imports and how I wrote most of the
unit test suite's imports as well
- there is automation for this that we should probably add once TSLint
is replaced here; some previous art:
- https://github.com/trivago/prettier-plugin-sort-imports
- https://github.com/lydell/eslint-plugin-simple-import-sort/
- Older:
- https://github.com/renke/import-sort/tree/master/packages/import-sort-style-module
- https://github.com/mcdougal/js-isort
- inspired by Python's `isort` ofc
25 lines
476 B
TypeScript
25 lines
476 B
TypeScript
import * as path from "path";
|
|
import * as tsTypes from "typescript";
|
|
|
|
import { tsModule } from "./tsproxy";
|
|
|
|
export class FormatHost implements tsTypes.FormatDiagnosticsHost
|
|
{
|
|
public getCurrentDirectory(): string
|
|
{
|
|
return tsModule.sys.getCurrentDirectory();
|
|
}
|
|
|
|
public getCanonicalFileName(fileName: string): string
|
|
{
|
|
return path.normalize(fileName);
|
|
}
|
|
|
|
public getNewLine(): string
|
|
{
|
|
return tsModule.sys.newLine;
|
|
}
|
|
}
|
|
|
|
export const formatHost = new FormatHost();
|