importsort-d

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

commit 22cb3fb18f9cdf3a77a98a09ffae06661c0f22ab
parent 38dada38189e29ded7fa8b301a26b026aa68aed9
Author: Friedel Schoen <[email protected]>
Date:   Sat, 22 Oct 2022 23:54:40 +0200

adding --merge

Diffstat:
MREADME.md | 1+
Massets/help.txt | 4+++-
Msrc/main.d | 2++
Msrc/sort.d | 29++++++++++++++++++++++++-----
4 files changed, 30 insertions(+), 6 deletions(-)

diff --git a/README.md b/README.md @@ -58,6 +58,7 @@ $ importsort-d [-h] [-v] [-r] [-i] [-o <out>] [-k] [-a] [-r] <input...> - [ ] 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 `;`) +- [ ] merge imports - [ ] stripping unused imports (maybe) ## Changelog diff --git a/assets/help.txt b/assets/help.txt @@ -10,7 +10,8 @@ Options: -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 ........ writes to the input - -o, --output <path> . writes to `path` instead of stdout + -o, --output <path> . writes to `path` instead of stdout +\ No newline at end of file diff --git a/src/main.d b/src/main.d @@ -84,6 +84,8 @@ void main(string[] args) { config.byAttribute = true; } else if (arg == "--binding" || arg == "-b") { config.byBinding = true; + } else if (arg == "--merge" || arg == "-m") { + config.merge = true; } else if (arg == "--inline" || arg == "-i") { inline = true; } else if (arg == "--recursive" || arg == "-r") { diff --git a/src/sort.d b/src/sort.d @@ -1,6 +1,6 @@ module importsort.sort; -import std.algorithm : findSplit, sort; +import std.algorithm : findSplit, remove, sort; import std.array : split; import std.file : DirEntry, rename; import std.functional : unaryFun; @@ -15,10 +15,10 @@ enum PATTERN = ctRegex!`^(\s*)(?:(public|static)\s+)?import\s+(?:(\w+)\s*=\s*)?( struct SortConfig { bool keepLine = false; - bool byAttribute = false; bool byBinding = false; bool verbose = false; + bool merge = false; } struct Identifier { @@ -60,9 +60,26 @@ void writeImports(File outfile, SortConfig config, Import[] matches) { if (!matches) return; + if (config.merge) { + for (int i = 0; i < matches.length; i++) { + for (int j = i + 1; j < matches.length; j++) { + if (matches[i].name.original == matches[j].name.original + && matches[i].name.binding == matches[j].name.binding) { + + matches[i].line = null; + matches[i].idents ~= matches[j].idents; + matches = matches.remove(j); + j--; + } + } + } + } + matches.sort!((a, b) => a.sortBy < b.sortBy); + bool first; + foreach (m; matches) { - if (config.keepLine) { + if (config.keepLine && m.line.length > 0) { outfile.write(m.line); } else { outfile.write(m.begin); @@ -75,8 +92,10 @@ void writeImports(File outfile, SortConfig config, Import[] matches) { } else { outfile.write("import " ~ m.name.original); } - foreach (i, ident; m.idents) { - auto begin = i == 0 ? " : " : ", "; + first = true; + foreach (ident; m.idents) { + auto begin = first ? " : " : ", "; + first = false; if (ident.hasBinding) { // hasBinding outfile.writef("%s%s = %s", begin, ident.binding, ident.original); } else {