Skip to content

Commit

Permalink
Merge branch 'master' into production
Browse files Browse the repository at this point in the history
  • Loading branch information
LiuDanK committed Jan 9, 2023
2 parents e51bdc6 + 497c42d commit fdb8c6b
Show file tree
Hide file tree
Showing 5 changed files with 58 additions and 36 deletions.
14 changes: 14 additions & 0 deletions SageTools.Console/Extension.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
using System.Linq;
using SageTools.Extension;

namespace SageTools.Console;

public static class Extension
{
public static string GetArgValue(this string[] args, string argKey)
{
if (args.IsNullOrEmpty() || argKey.IsNullOrWhiteSpace()) return default;
argKey = '-' + argKey.TrimStart('-').TrimEnd('=') + '=';
return args.Where(x => x.Contains(argKey)).Select(x => x.Replace(argKey, "")).FirstOrDefault();
}
}
37 changes: 20 additions & 17 deletions SageTools.Console/Program.cs
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
using System;
using System.IO;
using SageTools.Extension;
using System.Linq;
using System.Xml;
using SageTools.Extension;

namespace SageTools.Console
{
internal class Program
{
static void Main(string[] args)
private static void Main(string[] args)
{
var help = args.Any(x => x.Contains("-h"));
if (help)
Expand All @@ -17,42 +17,45 @@ static void Main(string[] args)
Environment.Exit(0);
}
System.Console.WriteLine("处理xml文件");
var source = args.Where(x => x.Contains("-source=")).Select(x => x.Replace("-source=", "")).FirstOrDefault();
var step = args.Where(x => x.Contains("-step=")).Select(x => x.Replace("-step=", "")).FirstOrDefault();
var version = args.Where(x => x.Contains("-version=")).Select(x => x.Replace("-version=", "")).FirstOrDefault();
if (source.IsNullOrEmpty())
{
System.Console.WriteLine("执行错误:必须指定 -source");
Environment.Exit(-1);
}
var source = args.GetArgValue("source");
var step = args.GetArgValue("step");
var version = args.GetArgValue("version");

var path = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, source);
if (!File.Exists(path))
{
System.Console.WriteLine($"执行错误:【{path}】文件不存在");
Environment.Exit(-1);
}
var xmlDoc = new XmlDocument(); //新建XML文件
xmlDoc.Load(path); //加载XML文件
var xmlDoc = new XmlDocument();
xmlDoc.Load(path);
var versionNode = xmlDoc.DocumentElement?.SelectSingleNode("PropertyGroup")?.SelectSingleNode("Version");
if (versionNode == null)
if (versionNode.IsNull())
{
System.Console.WriteLine("执行错误:项目没有配置版本号");
Environment.Exit(-1);
}
if (version.IsNullOrEmpty())
{
version = versionNode.InnerText;
var lastNum = version.Substring(version.LastIndexOf(".", StringComparison.Ordinal) + 1);
version = versionNode!.InnerText;
var lastNum = version[(version.LastIndexOf(".", StringComparison.Ordinal) + 1)..];
var newNum = lastNum.ToInt32() + step;
var newVersion = version.Substring(0, version.LastIndexOf(".", StringComparison.Ordinal) + 1) + newNum;
var newVersion = version[..(version.LastIndexOf(".", StringComparison.Ordinal) + 1)] + newNum;
versionNode.InnerText = newVersion;
System.Console.WriteLine($"当前版本{version},末尾版本号{lastNum},新版本号{newVersion}");
}
else
{
System.Console.WriteLine($"直接指定新版本号为 {version}");
versionNode.InnerText = version;
versionNode!.InnerText = version;
}

var copyright = xmlDoc.DocumentElement?.SelectSingleNode("PropertyGroup")?.SelectSingleNode("Copyright");
if (copyright.IsNotNull())
{
copyright!.InnerText = $"Copyright © LiuDanK 2021-{DateTime.Now.Year}";
}

xmlDoc.Save(path);
System.Console.WriteLine("处理完毕!");
}
Expand Down
7 changes: 7 additions & 0 deletions SageTools.Console/Properties/launchSettings.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
{
"profiles": {
"SageTools.Console": {
"commandName": "Project"
}
}
}
6 changes: 2 additions & 4 deletions SageTools/SageTools.csproj
Original file line number Diff line number Diff line change
@@ -1,13 +1,11 @@
<Project Sdk="Microsoft.NET.Sdk">

<PropertyGroup>
<TargetFramework>netstandard2.1</TargetFramework>
<GeneratePackageOnBuild>true</GeneratePackageOnBuild>
<Authors>LiuDanK</Authors>
<Company>LiuDanK</Company>
<Description>常用工具类、拓展方法等封装,目前还在实现中</Description>
<Copyright>Copyright © LiuDanK 2021</Copyright>
<Version>1.0.0</Version>
<Version>1.8.6</Version>
</PropertyGroup>

</Project>
</Project>
30 changes: 15 additions & 15 deletions SageTools/Utils/ShortIdGen.cs → SageTools/Utils/ShortIdGenUtil.cs
Original file line number Diff line number Diff line change
Expand Up @@ -8,23 +8,23 @@ namespace SageTools.Utils
/// 短 ID 生成类
/// <para>代码参考自:https://github.com/MonkSoul/Furion </para>
/// </summary>
public static class ShortIdGen
public static class ShortIdGenUtil
{
/// <summary>
/// 短 ID 生成器期初数据
/// </summary>
private static Random _random = new Random();

private const string BIG = "ABCDEFGHIJKLMNPQRSTUVWXY";
private const string SMALL = "abcdefghjklmnopqrstuvwxyz";
private const string NUMBER = "0123456789";
private const string SPECIAL = "_-";
private static string _pool = $"{SMALL}{BIG}";
private const string Big = "ABCDEFGHIJKLMNPQRSTUVWXY";
private const string Small = "abcdefghjklmnopqrstuvwxyz";
private const string Number = "0123456789";
private const string Special = "_-";
private static string _pool = $"{Small}{Big}";

/// <summary>
/// 线程安全锁
/// </summary>
private static readonly object _threadLock = new object();
private static readonly object ThreadLock = new object();

/// <summary>
/// 生成目前比较主流的短 ID
Expand Down Expand Up @@ -61,27 +61,27 @@ public static string NextId(GenerationOptions options)
throw new ArgumentException(
$"The specified length of {options.Length} is less than the lower limit of {Constants.MINIMUM_AUTO_LENGTH} to avoid conflicts.");
}
var characterPool = _pool;
var characterPool = ShortIdGenUtil._pool;
var poolBuilder = new StringBuilder(characterPool);

// 是否包含数字
if (options.UseNumbers)
{
poolBuilder.Append(NUMBER);
poolBuilder.Append(Number);
}

// 是否包含特殊字符
if (options.UseSpecialCharacters)
{
poolBuilder.Append(SPECIAL);
poolBuilder.Append(Special);
}
var pool = poolBuilder.ToString();

// 生成拼接
var output = new char[options.Length];
for (var i = 0; i < options.Length; i++)
{
lock (_threadLock)
lock (ThreadLock)
{
var charIndex = _random.Next(0, pool.Length);
output[i] = pool[charIndex];
Expand Down Expand Up @@ -110,7 +110,7 @@ public static void SetCharacters(string characters)
throw new InvalidOperationException(
$"The replacement characters must be at least {Constants.MINIMUM_CHARACTER_SET_LENGTH} letters in length and without whitespace.");
}
lock (_threadLock)
lock (ThreadLock)
{
_pool = new string(charSet);
}
Expand All @@ -122,7 +122,7 @@ public static void SetCharacters(string characters)
/// <param name="seed"></param>
public static void SetSeed(int seed)
{
lock (_threadLock)
lock (ThreadLock)
{
_random = new Random(seed);
}
Expand All @@ -133,10 +133,10 @@ public static void SetSeed(int seed)
/// </summary>
public static void Reset()
{
lock (_threadLock)
lock (ThreadLock)
{
_random = new Random();
_pool = $"{SMALL}{BIG}";
_pool = $"{Small}{Big}";
}
}

Expand Down

0 comments on commit fdb8c6b

Please sign in to comment.