From 119223b4d0c423624a1d57ea7e52dfd7b3323f01 Mon Sep 17 00:00:00 2001 From: gmickus Date: Wed, 30 Oct 2024 13:33:18 +0200 Subject: [PATCH 1/3] Update Using Formatter --- src/v2/formatters/using/UsingFormatter.ts | 65 +++++++++++++++++------ 1 file changed, 48 insertions(+), 17 deletions(-) diff --git a/src/v2/formatters/using/UsingFormatter.ts b/src/v2/formatters/using/UsingFormatter.ts index 256de6d..b31a1c9 100644 --- a/src/v2/formatters/using/UsingFormatter.ts +++ b/src/v2/formatters/using/UsingFormatter.ts @@ -8,6 +8,7 @@ import { IConfigurationManager } from "../../../utils/IConfigurationManager"; import { FormatterHelper } from "../../formatterFramework/FormatterHelper"; import { UsingSettings } from "./UsingSettings"; import { SyntaxNodeType } from "../../../model/SyntaxNodeType"; +import { Options } from "vscode-extension-tester"; @RegisterFormatter export class UsingFormatter extends AFormatter implements IFormatter { @@ -15,13 +16,15 @@ export class UsingFormatter extends AFormatter implements IFormatter { private readonly settings: UsingSettings; private usingStatementsFound: number = 0; + private alignOptionalStatements: number = 0; public constructor(configurationManager: IConfigurationManager) { super(configurationManager); this.settings = new UsingSettings(configurationManager); } - private usingStatements: string[] = []; + private usingStatements: UsingStatement[] = []; + private textUsingStatements: string[] = []; match(node: Readonly): boolean { if (node.type === SyntaxNodeType.UsingStatement) { @@ -36,13 +39,16 @@ export class UsingFormatter extends AFormatter implements IFormatter { this.usingStatementsFound++; if (this.usingStatementsFound === 1) { this.collectAllUsingStatements(node, fullText); - this.usingStatements.sort(); + this.textUsingStatements = this.usingStatements.map( + (usingStatement) => this.usingStatementToString(usingStatement) + ); + this.textUsingStatements.sort(); } const text = FormatterHelper.getCurrentText(node, fullText); if (this.usingStatementsFound > this.usingStatements.length) { return undefined; } - const newText = this.usingStatements[this.usingStatementsFound - 1]; + const newText = this.textUsingStatements[this.usingStatementsFound - 1]; return this.getCodeEdit(node, text, newText, fullText); } @@ -67,36 +73,61 @@ export class UsingFormatter extends AFormatter implements IFormatter { fullText ); keyword = this.settings.casing() - ? keyword.toUpperCase() - : keyword.toLowerCase(); + ? keyword.trim().toUpperCase() + : keyword.trim().toLowerCase(); const identifier = FormatterHelper.getCurrentText( identifierChild, fullText - ); + ).trim(); let optionalDefinitions = ""; + this.alignOptionalStatements = Math.max( + this.alignOptionalStatements, + keyword.length + identifier.length + ); if (node.childCount > 2) { for (let i = 2; i < node.childCount; ++i) { const currentChild = node.child(i); if (currentChild === null) { continue; } - optionalDefinitions += FormatterHelper.getCurrentText( - currentChild, - fullText - ); + optionalDefinitions += + FormatterHelper.getCurrentText( + currentChild, + fullText + ).trim() + " "; } optionalDefinitions = this.settings.casing() - ? optionalDefinitions.toUpperCase() - : optionalDefinitions.toLowerCase(); + ? optionalDefinitions.trim().toUpperCase() + : optionalDefinitions.trim().toLowerCase(); } - this.usingStatements.push( - keyword - .concat(identifier) - .concat(optionalDefinitions) - .concat(".") + this.usingStatements.push({ + identifier: keyword + " " + identifier, + optionalDefinitions, + }); + } + } + + private usingStatementToString(statement: UsingStatement): string { + if (statement.optionalDefinitions === "") { + return statement.identifier + "."; + } else { + return ( + statement.identifier + + " ".repeat( + this.alignOptionalStatements - + statement.identifier.length + + 1 + ) + + statement.optionalDefinitions + + "." ); } } } + +type UsingStatement = { + identifier: string; + optionalDefinitions: string; +}; From 6f47c21f2faafe1014b8ecb9d1644ff699b128ad Mon Sep 17 00:00:00 2001 From: gmickus Date: Wed, 30 Oct 2024 13:43:52 +0200 Subject: [PATCH 2/3] Add tests --- .../using/6optional-statements/input.p | 12 ++++++++++++ .../using/6optional-statements/target.p | 12 ++++++++++++ .../using/6optional-statements2/input.p | 11 +++++++++++ .../using/6optional-statements2/target.p | 11 +++++++++++ .../using/6optional-statements3/input.p | 11 +++++++++++ .../using/6optional-statements3/target.p | 16 ++++++++++++++++ src/v2/formatters/using/UsingFormatter.ts | 11 ++++++----- 7 files changed, 79 insertions(+), 5 deletions(-) create mode 100644 resources/functionalTests/using/6optional-statements/input.p create mode 100644 resources/functionalTests/using/6optional-statements/target.p create mode 100644 resources/functionalTests/using/6optional-statements2/input.p create mode 100644 resources/functionalTests/using/6optional-statements2/target.p create mode 100644 resources/functionalTests/using/6optional-statements3/input.p create mode 100644 resources/functionalTests/using/6optional-statements3/target.p diff --git a/resources/functionalTests/using/6optional-statements/input.p b/resources/functionalTests/using/6optional-statements/input.p new file mode 100644 index 0000000..ddd113c --- /dev/null +++ b/resources/functionalTests/using/6optional-statements/input.p @@ -0,0 +1,12 @@ +/* formatterSettingsOverride */ +/* { "AblFormatter.usingFormatting": true, + "abl.completion.upperCase": false}*/ + +using Common.* from propath. +using Exceptions.* from propath. +using Framework.* from propath. +using Framework.Ccs.* from propath. +using Framework.Enum.* from propath. +using Framework.Exceptions.* from propath. +using Util.* from propath. +using Lang.* from propath. \ No newline at end of file diff --git a/resources/functionalTests/using/6optional-statements/target.p b/resources/functionalTests/using/6optional-statements/target.p new file mode 100644 index 0000000..1296bfe --- /dev/null +++ b/resources/functionalTests/using/6optional-statements/target.p @@ -0,0 +1,12 @@ +/* formatterSettingsOverride */ +/* { "AblFormatter.usingFormatting": true, + "abl.completion.upperCase": false}*/ + +using Common.* from propath. +using Exceptions.* from propath. +using Framework.* from propath. +using Framework.Ccs.* from propath. +using Framework.Enum.* from propath. +using Framework.Exceptions.* from propath. +using Lang.* from propath. +using Util.* from propath. \ No newline at end of file diff --git a/resources/functionalTests/using/6optional-statements2/input.p b/resources/functionalTests/using/6optional-statements2/input.p new file mode 100644 index 0000000..d1b8ecf --- /dev/null +++ b/resources/functionalTests/using/6optional-statements2/input.p @@ -0,0 +1,11 @@ +/* formatterSettingsOverride */ +/* { "AblFormatter.usingFormatting": true, + "abl.completion.upperCase": false}*/ + +using Alpha.Beta.* from propath. +using Gamma.Delta.* from propath. +using Epsilon.Zeta.* from propath. +using Theta.Iota.* from assembly. +using Kappa.Lambda.* from propath. +using Mu.Nu.* from propath. +using Xi.Omicron.* from assembly. diff --git a/resources/functionalTests/using/6optional-statements2/target.p b/resources/functionalTests/using/6optional-statements2/target.p new file mode 100644 index 0000000..b805b16 --- /dev/null +++ b/resources/functionalTests/using/6optional-statements2/target.p @@ -0,0 +1,11 @@ +/* formatterSettingsOverride */ +/* { "AblFormatter.usingFormatting": true, + "abl.completion.upperCase": false}*/ + +using Alpha.Beta.* from propath. +using Epsilon.Zeta.* from propath. +using Gamma.Delta.* from propath. +using Kappa.Lambda.* from propath. +using Mu.Nu.* from propath. +using Theta.Iota.* from assembly. +using Xi.Omicron.* from assembly. diff --git a/resources/functionalTests/using/6optional-statements3/input.p b/resources/functionalTests/using/6optional-statements3/input.p new file mode 100644 index 0000000..d1b8ecf --- /dev/null +++ b/resources/functionalTests/using/6optional-statements3/input.p @@ -0,0 +1,11 @@ +/* formatterSettingsOverride */ +/* { "AblFormatter.usingFormatting": true, + "abl.completion.upperCase": false}*/ + +using Alpha.Beta.* from propath. +using Gamma.Delta.* from propath. +using Epsilon.Zeta.* from propath. +using Theta.Iota.* from assembly. +using Kappa.Lambda.* from propath. +using Mu.Nu.* from propath. +using Xi.Omicron.* from assembly. diff --git a/resources/functionalTests/using/6optional-statements3/target.p b/resources/functionalTests/using/6optional-statements3/target.p new file mode 100644 index 0000000..743de56 --- /dev/null +++ b/resources/functionalTests/using/6optional-statements3/target.p @@ -0,0 +1,16 @@ +/* formatterSettingsOverride */ +/* { "AblFormatter.usingFormatting": true, + "abl.completion.upperCase": false}*/ + +using Alpha.*. +using Alpha.Beta.* from propath. +using Beta.Gamma.*. +using Chi.Psi.Omega.* from propath. +using Delta.Epsilon.Zeta.Eta.* from propath. +using Epsilon.Zeta.* from assembly. +using Eta.Theta.* from propath. +using Gamma.Delta.* from propath. +using Kappa.Lambda.Mu.Nu.* from propath. +using Sigma.Tau.Upsilon.Phi.* from propath. +using Theta.Iota.* from propath. +using Xi.Omicron.Pi.Rho.* from propath. diff --git a/src/v2/formatters/using/UsingFormatter.ts b/src/v2/formatters/using/UsingFormatter.ts index b31a1c9..095ddc2 100644 --- a/src/v2/formatters/using/UsingFormatter.ts +++ b/src/v2/formatters/using/UsingFormatter.ts @@ -8,7 +8,6 @@ import { IConfigurationManager } from "../../../utils/IConfigurationManager"; import { FormatterHelper } from "../../formatterFramework/FormatterHelper"; import { UsingSettings } from "./UsingSettings"; import { SyntaxNodeType } from "../../../model/SyntaxNodeType"; -import { Options } from "vscode-extension-tester"; @RegisterFormatter export class UsingFormatter extends AFormatter implements IFormatter { @@ -83,7 +82,11 @@ export class UsingFormatter extends AFormatter implements IFormatter { let optionalDefinitions = ""; this.alignOptionalStatements = Math.max( this.alignOptionalStatements, - keyword.length + identifier.length + /* The format is this: + USING IDENTIFIER OPTIONAL_DEFINITIONS. + therefore we add +1 for the spaces between different parts. + */ + keyword.length + 1 + identifier.length + 1 ); if (node.childCount > 2) { for (let i = 2; i < node.childCount; ++i) { @@ -116,9 +119,7 @@ export class UsingFormatter extends AFormatter implements IFormatter { return ( statement.identifier + " ".repeat( - this.alignOptionalStatements - - statement.identifier.length + - 1 + this.alignOptionalStatements - statement.identifier.length ) + statement.optionalDefinitions + "." From 3bfa91aa0cc7586036c76c4e4995c925d3291131 Mon Sep 17 00:00:00 2001 From: gmickus Date: Wed, 30 Oct 2024 13:47:09 +0200 Subject: [PATCH 3/3] Update test --- .../using/6optional-statements3/input.p | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/resources/functionalTests/using/6optional-statements3/input.p b/resources/functionalTests/using/6optional-statements3/input.p index d1b8ecf..5aac9f8 100644 --- a/resources/functionalTests/using/6optional-statements3/input.p +++ b/resources/functionalTests/using/6optional-statements3/input.p @@ -2,10 +2,15 @@ /* { "AblFormatter.usingFormatting": true, "abl.completion.upperCase": false}*/ -using Alpha.Beta.* from propath. -using Gamma.Delta.* from propath. -using Epsilon.Zeta.* from propath. -using Theta.Iota.* from assembly. -using Kappa.Lambda.* from propath. -using Mu.Nu.* from propath. -using Xi.Omicron.* from assembly. +using Alpha.*. +using Alpha.Beta.* from propath. +using Beta.Gamma.*. +using Chi.Psi.Omega.* from propath. +using Delta.Epsilon.Zeta.Eta.* from propath. +using Epsilon.Zeta.* from assembly. +using Eta.Theta.* from propath. +using Gamma.Delta.* from propath. +using Kappa.Lambda.Mu.Nu.* from propath. +using Sigma.Tau.Upsilon.Phi.* from propath. +using Theta.Iota.* from propath. +using Xi.Omicron.Pi.Rho.* from propath.