importsort-d

Sort and format imports in DLang
Log | Files | Refs | README

commit f23ea2703f61fe9efb59bf092c71c3dfe15b29c9
parent a5280797420210554540cfa26a89b2098cede2ab
Author: Friedel Schoen <[email protected]>
Date:   Sun, 23 Oct 2022 16:08:07 +0200

adding a page

Diffstat:
Adocs/index.md | 91+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Msrc/sort.d | 5++++-
2 files changed, 95 insertions(+), 1 deletion(-)

diff --git a/docs/index.md b/docs/index.md @@ -0,0 +1,90 @@ +# Sort Imports for [D](https://dlang.org/) + +<img src="assets/importsort-d.png" alt="logo" width="256" /> + +`sortimport-d` can sort your dozens of `import`'s in a `.d` file (no matter where) + +## Installation + +## Prerequisite + +- [`dub`](https://dub.pm/) + +### Building from HEAD + +Get the repository with `git` and compile everything with `dub` +``` +$ git clone https://github.com/friedelschoen/importsort-d +$ cd importsort-d +$ dub build +``` + +If everything went fine, there should be a binary at `bin/importsort-d`. + +Copy this into a directory included in `$PATH` (`/usr/bin` for example) to make this command work globally. + +### Building with DUB + +``` +$ dub fetch importsort-d +$ dub run importsort-d -- --help +``` + +This won't install the command globally, you always have to run `dub run importsort-d <args>` + +## Usage + +``` +$ importsort-d [-h] [-v] [-r] [-i] [-o <out>] [-k] [-a] [-r] <input...> +``` +`input` may be omitted or set to `-` to read from STDIN + +| option | description | +| --------------------- | ---------------------------------------------- | +| `-h, --help` | prints a help message | +| `-v, --verbose` | prints useful debug messages | +| | | +| `-k, --keep` | keeps the line as-is instead of formatting | +| `-a, --attribute` | public and static imports first | +| `-b, --binding` | sorts by binding rather then the original | +| `-m, --merge` | merge imports which uses same file | +| | | +| `-r, --recursive` | recursively search in directories | +| `-i, --inline` | changes the input | +| `-o, --output <path>` | writes to `path` rather then writing to STDOUT | + +## TODO's + +- [x] recursive searching (`v0.2.0`) +- [x] merge imports (`v0.3.0`) +- [ ] watch-mode (struggling with save-timings - can clear files) + - you can add importsort-d into your onSave-hooks (e. g. [Run on Save](https://marketplace.visualstudio.com/items?itemName=emeraldwalk.RunOnSave) on VSCode) +- [ ] support multiple imports in one line (demilited by `;`) +- [ ] stripping unused imports (maybe) + +## Changelog + +### `v0.1.0` +- the very first version +- not a lot is implemented + +### `v0.2.0` +- added `--recursive` (see above) +- option `--keep` becomes disabling formatting +- option `--inline` doen't copy the original but creates a `*.new` and renames it afterwards +- option `--original` becomes `--binding` and sorts by original by default +- refactoring code + +### `v0.3.0` +- added `--merge` (see above) + +### `v0.3.1` +- added documentation for contributers (or people who wan't to see my code) + +## License + +This whole project is licensed under the beautiful terms of the `zlib-license`. + +Further information [here](LICENSE) + +> made with love and a lot of cat memes +\ No newline at end of file diff --git a/src/sort.d b/src/sort.d @@ -81,6 +81,9 @@ struct Import { /// spaces before the import (indentation) string begin; + /// the newline + string end; + /// the string to sort string sortBy() { if (byAttribute && (public_ || static_)) @@ -136,7 +139,7 @@ void writeImports(File outfile, SortConfig config, Import[] matches) { outfile.write(begin ~ ident.original); } } - outfile.writef(";%s", m.end); + outfile.writef(";", m.end); } } }