Skip to content

Commit

Permalink
[wildfly-extras#675] Process the CLI messages using Picocli formattin…
Browse files Browse the repository at this point in the history
…g to enable colours and styles
  • Loading branch information
spyrkob committed May 21, 2024
1 parent 7006311 commit 93885f6
Show file tree
Hide file tree
Showing 7 changed files with 51 additions and 28 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@
import org.wildfly.prospero.api.Console;
import org.wildfly.prospero.api.ProvisioningProgressEvent;
import org.wildfly.prospero.api.ArtifactChange;
import picocli.CommandLine;

import static org.jboss.galleon.Constants.TRACK_CONFIGS;
import static org.jboss.galleon.Constants.TRACK_LAYOUT_BUILD;
Expand Down Expand Up @@ -153,22 +154,22 @@ public void progressUpdate(ProvisioningProgressEvent update) {

public void updatesFound(List<ArtifactChange> artifactUpdates) {
if (artifactUpdates.isEmpty()) {
getStdOut().println(CliMessages.MESSAGES.noUpdatesFound());
println(CliMessages.MESSAGES.noUpdatesFound());
} else {
getStdOut().println(CliMessages.MESSAGES.updatesFound());
println(CliMessages.MESSAGES.updatesFound());
for (ArtifactChange artifactUpdate : artifactUpdates) {
final Optional<String> newVersion = artifactUpdate.getNewVersion();
final Optional<String> oldVersion = artifactUpdate.getOldVersion();
final String artifactName = artifactUpdate.getArtifactName();
final String channelName = artifactUpdate.getChannelName().map(name -> "[" + name + "]")
.orElse("");

getStdOut().printf(" %s%-50s %-20s ==> %-20s %-20s%n", artifactUpdate.isDowngrade()?"[*]":"", artifactName, oldVersion.orElse("[]"),
printf(" %s%-50s %-20s ==> %-20s %-20s%n", artifactUpdate.isDowngrade()?"[*]":"", artifactName, oldVersion.orElse("[]"),
newVersion.orElse("[]"), channelName);
}

if (artifactUpdates.stream().anyMatch(ArtifactChange::isDowngrade)) {
getStdOut().printf(CliMessages.MESSAGES.possibleDowngrade());
printf(CliMessages.MESSAGES.possibleDowngrade());
}
}
}
Expand Down Expand Up @@ -246,7 +247,21 @@ public void error(String message, String... args) {

@Override
public void println(String text) {
getStdOut().println(text);
if (text == null) {
getStdOut().println();
} else {
final CommandLine.Help.Ansi.Text formatted = CommandLine.Help.Ansi.AUTO.new Text(text);
getStdOut().println(formatted.toString());
}
}

public void printf(String text, String... args) {
if (text == null) {
getStdOut().println();
} else {
final String formatted = String.format(text, (String[]) args);
getStdOut().print(CommandLine.Help.Ansi.AUTO.new Text(formatted));
}
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -25,17 +25,19 @@
public class DiffPrinter {

private final String initialTab;
private final CliConsole console;

public DiffPrinter(String initialTab) {
public DiffPrinter(CliConsole console, String initialTab) {
this.initialTab = initialTab;
this.console = console;
}

public void print(Diff diff) {
print(diff, initialTab, false);
}

private void print(Diff diff, String tab, boolean nested) {
System.out.print(tab);
console.printf(tab);


if (diff.getChildren().isEmpty()) {
Expand All @@ -53,13 +55,13 @@ private void print(Diff diff, String tab, boolean nested) {
}
}

private static void print(Diff diff, boolean nested, String text, String... args) {
private void print(Diff diff, boolean nested, String text, String... args) {
if (!nested) {
text = String.format("[%s] ", getStatus(diff)) + String.format(text, (String[]) args);
} else {
text = String.format(text, (String[]) args);
}
System.out.print(text);
console.printf(text);
}

private static String getStatus(Diff diff) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -24,26 +24,32 @@

public class LicensePrinter {

private final CliConsole console;

public LicensePrinter(CliConsole console) {
this.console = console;
}

public void print(List<License> pendingLicenses) {
if (!pendingLicenses.isEmpty()) {
boolean first = true;
for (License pendingLicense : pendingLicenses) {
if (!first) {
System.out.println();
console.println("");
}
first = false;

System.out.println("===============");
System.out.println(pendingLicense.getTitle());
System.out.println("===============");
console.println("===============");
console.println(pendingLicense.getTitle());
console.println("===============");
final String text = pendingLicense.getText();
final String[] lines = text.split("\n");
for (String line : lines) {
System.out.println(" " + WordUtils.wrap(line, 118, System.lineSeparator() + " ", true));
console.println(" " + WordUtils.wrap(line, 118, System.lineSeparator() + " ", true));
}
System.out.println("===============");
console.println("===============");
}
System.out.println();
console.println("");
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,7 @@ public Integer call() throws Exception {

if (!pendingLicenses.isEmpty()) {
console.println(System.lineSeparator() + CliMessages.MESSAGES.featurePackRequiresLicense(fpl) + System.lineSeparator());
new LicensePrinter().print(pendingLicenses);
new LicensePrinter(console).print(pendingLicenses);

if (acceptAgreements) {
console.println(CliMessages.MESSAGES.agreementSkipped(CliConstants.ACCEPT_AGREEMENTS) + System.lineSeparator());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@ public Integer call() throws Exception {
if (changes.isEmpty()) {
console.println(CliMessages.MESSAGES.noChangesFound());
} else {
final DiffPrinter diffPrinter = new DiffPrinter(" ");
final DiffPrinter diffPrinter = new DiffPrinter(console, " ");
boolean needsLineBreak = false;
if (!changes.getArtifactChanges().isEmpty()) {
console.println(CliMessages.MESSAGES.diffUpdates()+ ":");
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -199,11 +199,11 @@ public Integer call() throws Exception {
final List<License> pendingLicenses = provisioningAction.getPendingLicenses(provisioningConfig,
effectiveChannels);
if (!pendingLicenses.isEmpty()) {
new LicensePrinter().print(pendingLicenses);
System.out.println();
new LicensePrinter(console).print(pendingLicenses);
console.println("");
if (acceptAgreements) {
System.out.println(CliMessages.MESSAGES.agreementSkipped(CliConstants.ACCEPT_AGREEMENTS));
System.out.println();
console.println(CliMessages.MESSAGES.agreementSkipped(CliConstants.ACCEPT_AGREEMENTS));
console.println("");
} else {
if (!console.confirm(CliMessages.MESSAGES.acceptAgreements(), "", CliMessages.MESSAGES.installationCancelled())) {
return ReturnCodes.PROCESSING_ERROR;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -60,13 +60,13 @@ public Integer call() throws Exception {

final List<License> pendingLicenses = provisioningAction.getPendingLicenses(provisioningConfig, channels);
if (!pendingLicenses.isEmpty()) {
System.out.println();
System.out.println(CliMessages.MESSAGES.listAgreementsHeader());
System.out.println();
new LicensePrinter().print(pendingLicenses);
console.println("");
console.println(CliMessages.MESSAGES.listAgreementsHeader());
console.println("");
new LicensePrinter(console).print(pendingLicenses);
} else {
System.out.println();
System.out.println(CliMessages.MESSAGES.noAgreementsNeeded());
console.println("");
console.println(CliMessages.MESSAGES.noAgreementsNeeded());
}
return ReturnCodes.SUCCESS;
} finally {
Expand Down

0 comments on commit 93885f6

Please sign in to comment.