Improve formating

This commit is contained in:
Peter Butzhammer
2024-04-28 20:47:20 +02:00
parent e358c03db0
commit cd70cc4714
2 changed files with 96 additions and 90 deletions

View File

@@ -4,4 +4,5 @@ public static class CustomStyles
{ {
public static Style Error { get; } = new Style(foreground: Color.Red); public static Style Error { get; } = new Style(foreground: Color.Red);
public static Style Note { get; } = new(foreground: Color.DarkSlateGray1); public static Style Note { get; } = new(foreground: Color.DarkSlateGray1);
public static Style? Hex { get; } = new(foreground: Color.Blue);
} }

View File

@@ -1,4 +1,5 @@
using System.ComponentModel; using System.Collections;
using System.ComponentModel;
using System.Reactive.Linq; using System.Reactive.Linq;
using System.Reactive.Threading.Tasks; using System.Reactive.Threading.Tasks;
using JetBrains.Annotations; using JetBrains.Annotations;
@@ -13,7 +14,7 @@ internal sealed class ReadPlcCommand : AsyncCommand<ReadPlcCommand.Settings>
{ {
public override async Task<int> ExecuteAsync(CommandContext context, Settings settings) public override async Task<int> ExecuteAsync(CommandContext context, Settings settings)
{ {
var token = (CancellationToken) (context.Data ?? CancellationToken.None); var token = (CancellationToken)(context.Data ?? CancellationToken.None);
try try
{ {
@@ -28,23 +29,27 @@ internal sealed class ReadPlcCommand : AsyncCommand<ReadPlcCommand.Settings>
private static IRenderable FormatCellData(VariableRecord record) private static IRenderable FormatCellData(VariableRecord record)
{ {
if (record.Value is IRenderable renderable) return record.Value switch
return renderable;
if (record.Value is Exception ex)
return new Text(ex.Message, CustomStyles.Error);
if (record.Value is byte[] byteArray)
{ {
var text = string.Join(" ", byteArray.Select(b => $"0x{b:X2}")); IRenderable renderable => renderable,
return new Text(text); Exception ex => new Text(ex.Message, CustomStyles.Error),
} byte[] byteArray => new Text(string.Join(" ", byteArray.Select(b => $"0x{b:X2}")), CustomStyles.Hex),
byte => FormatNo(),
short =>FormatNo(),
ushort =>FormatNo(),
int =>FormatNo(),
uint =>FormatNo(),
long =>FormatNo(),
ulong =>FormatNo(),
return new Text(record.Value.ToString() ?? ""); _ => new Text(record.Value.ToString() ?? "")
};
Markup FormatNo() => new($"[blue]0x{record.Value:X2}[/] {record.Value}");
} }
private static async Task RunProgram(Settings settings, CancellationToken token) private static async Task RunProgram(Settings settings, CancellationToken token)
{ {
AnsiConsole.MarkupLine($"Connecting to plc [green]{settings.PlcIp}[/], CPU [green]{settings.CpuMpiAddress}[/], rack [green]{settings.RackNumber}[/]. "); AnsiConsole.MarkupLine($"Connecting to plc [green]{settings.PlcIp}[/], CPU [green]{settings.CpuMpiAddress}[/], rack [green]{settings.RackNumber}[/]. ");
AnsiConsole.MarkupLine("[gray]Press Ctrl + C to cancel.[/]"); AnsiConsole.MarkupLine("[gray]Press Ctrl + C to cancel.[/]");
@@ -104,11 +109,11 @@ internal sealed class ReadPlcCommand : AsyncCommand<ReadPlcCommand.Settings>
await Task.Delay(100, token); await Task.Delay(100, token);
} }
}); });
} }
[NoReorder] [NoReorder]
public sealed class Settings : CommandSettings public sealed class Settings : CommandSettings
{ {
[Description("IP address of S7")] [Description("IP address of S7")]
[CommandArgument(0, "<IP address>")] [CommandArgument(0, "<IP address>")]
public required string PlcIp { get; init; } public required string PlcIp { get; init; }
@@ -137,5 +142,5 @@ internal sealed class ReadPlcCommand : AsyncCommand<ReadPlcCommand.Settings>
return ValidationResult.Success(); return ValidationResult.Success();
} }
} }
} }