2 Commits

Author SHA1 Message Date
52fecbb436 ci
All checks were successful
CI / build-test (push) Successful in 30s
Release / pack-and-publish (release) Successful in 38s
2025-11-27 10:49:10 +03:00
363c078321 Доработано формирование аргументов
All checks were successful
CI / build-test (push) Successful in 29s
Release / pack-and-publish (release) Successful in 35s
2025-11-27 10:41:57 +03:00
4 changed files with 34 additions and 9 deletions

View File

@@ -25,6 +25,13 @@ jobs:
TAG="${GITHUB_REF_NAME#v}"
echo "PACKAGE_VERSION=$TAG" >> $GITHUB_OUTPUT
- name: Replace ProjectReference with PackageReference
run: |
sed -i "s#<ProjectReference Include=\"..\/ArgumentsToolkit.Core\/ArgumentsToolkit.Core.csproj\" />#<PackageReference Include=\"ArgumentsToolkit.Core\" Version=\"${{ steps.version.outputs.PACKAGE_VERSION }}\" />#" ArgumentsToolkit.Help/ArgumentsToolkit.Help.csproj
sed -i "s#<ProjectReference Include=\"..\/ArgumentsToolkit.Core\/ArgumentsToolkit.Core.csproj\" />#<PackageReference Include=\"ArgumentsToolkit.Core\" Version=\"${{ steps.version.outputs.PACKAGE_VERSION }}\" />#" ArgumentsToolkit.Validation/ArgumentsToolkit.Validation.csproj
sed -i "s#<ProjectReference Include=\"..\/ArgumentsToolkit.Core\/ArgumentsToolkit.Core.csproj\" />#<PackageReference Include=\"ArgumentsToolkit.Core\" Version=\"${{ steps.version.outputs.PACKAGE_VERSION }}\" />#" ArgumentsToolkit/ArgumentsToolkit.csproj
sed -i "s#<ProjectReference Include=\"..\/ArgumentsToolkit.Help\/ArgumentsToolkit.Help.csproj\" />#<PackageReference Include=\"ArgumentsToolkit.Help\" Version=\"${{ steps.version.outputs.PACKAGE_VERSION }}\" />#" ArgumentsToolkit/ArgumentsToolkit.csproj
sed -i "s#<ProjectReference Include=\"..\/ArgumentsToolkit.Validation\/ArgumentsToolkit.Validation.csproj\" />#<PackageReference Include=\"ArgumentsToolkit.Validation\" Version=\"${{ steps.version.outputs.PACKAGE_VERSION }}\" />#" ArgumentsToolkit/ArgumentsToolkit.csproj
- name: Build and Pack projects
run: |
@@ -39,10 +46,10 @@ jobs:
done
env:
PROJECTS: |
ArgumentsToolkit
ArgumentsToolkit.Core
ArgumentsToolkit.Help
ArgumentsToolkit.Validation
ArgumentsToolkit
- name: Upload package artifacts

View File

@@ -136,10 +136,16 @@ public static class ArgumentsParser
return result;
}
public static string ToArguments<T>(T options)
/// <summary>
/// Формирование строки аргументов
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="options"></param>
/// <returns></returns>
public static string ToArguments<T>(T options, bool useShortName = false)
{
var props = typeof(T).GetProperties();
var parts = new List<string>();
var parts = new List<KeyValuePair<string, string>>();
foreach (var prop in props)
{
@@ -151,17 +157,22 @@ public static class ArgumentsParser
string prefix = "--" + opt.Name;
if (useShortName && !string.IsNullOrWhiteSpace(opt.ShortName))
{
prefix = "-" + opt.ShortName;
}
if (prop.PropertyType == typeof(bool))
{
if ((bool)value)
parts.Add(prefix);
parts.Add(new(prefix, ""));
}
else if (prop.PropertyType.IsGenericType &&
prop.PropertyType.GetGenericTypeDefinition() == typeof(List<>))
{
var list = (System.Collections.IList)value;
if (list.Count > 0)
parts.Add($"{prefix} {string.Join(",", list.Cast<object>())}");
parts.Add(new(prefix, string.Join(",", list.Cast<object>())));
}
else if (prop.PropertyType.IsGenericType &&
prop.PropertyType.GetGenericTypeDefinition() == typeof(Dictionary<,>))
@@ -171,15 +182,15 @@ public static class ArgumentsParser
foreach (var k in dict.Keys)
items.Add($"{k}={dict[k]}");
if (items.Count > 0)
parts.Add($"{prefix} {string.Join(",", items)}");
parts.Add(new(prefix, string.Join(",", items)));
}
else
{
parts.Add($"{prefix} {value}");
parts.Add(new(prefix, $"{value}"));
}
}
return string.Join(" ", parts);
return string.Join(" ", parts.Select(kvp => kvp.Key + " \"" + kvp.Value + "\""));
}
private static bool TryParse(Type targetType, string input, IOptionConverter? converterAttr, out object? value)

View File

@@ -40,10 +40,14 @@ internal class Program
Console.WriteLine($"Environment: {result.Value.Environment}");
Console.WriteLine($"DryRun: {result.Value.DryRun}");
Console.WriteLine($"Mode: {result.Value.Mode}");
Console.WriteLine($"Path: {result.Value.Path}");
Console.WriteLine($"Config.Author: {result.Value.Config.Author}");
Console.WriteLine($"Config.Timeout: {result.Value.Config.Timeout}");
Console.ResetColor();
Console.WriteLine("Строка аргументов:");
Console.WriteLine(ArgumentsParser.ToArguments(result.Value!, true));
return 0;
}
@@ -63,6 +67,9 @@ public class DeployOptions
[AllowedValues("dev", "staging", "prod")]
public string Environment { get; set; } = "dev";
[Option("path", null, "Среда деплоя")]
public string? Path { get; set; }
[Option("dry-run", "d", "Пробный запуск без изменений")]
public bool DryRun { get; set; }

View File

@@ -2,7 +2,7 @@
"profiles": {
"Demo": {
"commandName": "Project",
"commandLineArgs": "--server myhost --port 8080 --env staging --mode Incremental --config \"{\\\"Author\\\":\\\"FrigaT\\\",\\\"Timeout\\\":60}"
"commandLineArgs": "--server \"myhost\" --port 8080 --path \"C:\\Job\\Projects\\FrigaT\\ReleaseUpdater\\Updater.Test\\bin\\Debug\\net8.0\" --env staging --mode Incremental --config \"{\\\"Author\\\":\\\"FrigaT\\\",\\\"Timeout\\\":60} "
},
"Demo (Error)": {
"commandName": "Project",