From 0471452ed966cea17c6914d99c020df230b81137 Mon Sep 17 00:00:00 2001
From: fengjiayi <12821976+ning_xi@user.noreply.gitee.com>
Date: Wed, 18 Dec 2024 00:05:42 +0800
Subject: [PATCH] =?UTF-8?q?=E9=87=8D=E6=96=B0=E8=AE=BE=E8=AE=A1=E4=BA=86@g?=
=?UTF-8?q?et=20=E8=A1=A8=E8=BE=BE=E5=BC=8F=EF=BC=8C=E4=BF=AE=E6=94=B9?=
=?UTF-8?q?=E4=BA=86=20Workbench=E5=90=8E=E5=8F=B0=E9=95=BF=E6=97=B6?=
=?UTF-8?q?=E9=97=B4=E8=BF=90=E8=A1=8C=E6=97=B6=EF=BC=8C=E9=87=8D=E6=96=B0?=
=?UTF-8?q?=E5=88=87=E6=8D=A2=E5=88=B0=E5=89=8D=E5=8F=B0=E4=BC=9A=E4=BA=A7?=
=?UTF-8?q?=E7=94=9F=E5=8F=82=E6=95=B0=E8=BF=9E=E6=8E=A5=E7=BA=BF=E9=94=99?=
=?UTF-8?q?=E8=AF=AF=E6=98=BE=E7=A4=BA=E7=9A=84=E9=97=AE=E9=A2=98?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
Library/Extension/SereinExtension.cs | 107 +++++++-
Library/FlowNode/NodeModelBaseFunc.cs | 18 +-
Library/SereinBaseFunction.cs | 6 +
Library/Utils/ConvertHelper.cs | 11 +
.../Resolver/BoolConditionResolver.cs | 2 +-
.../SereinExpression/SereinConditionParser.cs | 154 +-----------
.../SereinExpressionExtension.cs | 57 +++++
.../SerinExpressionEvaluator.cs | 234 +++++++-----------
NodeFlow/FlowStarter.cs | 19 ++
NodeFlow/Model/SingleConditionNode.cs | 8 +-
WorkBench/App.xaml.cs | 43 +++-
WorkBench/MainWindow.xaml.cs | 3 +-
Workbench/Node/INodeJunction.cs | 10 +
.../Node/Junction/ConnectionLineShape.cs | 2 +
.../Node/Junction/JunctionControlBase.cs | 2 +-
Workbench/Node/View/ConnectionControl.cs | 16 +-
16 files changed, 386 insertions(+), 306 deletions(-)
create mode 100644 Library/Utils/SereinExpression/SereinExpressionExtension.cs
diff --git a/Library/Extension/SereinExtension.cs b/Library/Extension/SereinExtension.cs
index 84e1c95..83fd8df 100644
--- a/Library/Extension/SereinExtension.cs
+++ b/Library/Extension/SereinExtension.cs
@@ -1,5 +1,7 @@
-using System;
+using Serein.Library.Utils;
+using System;
using System.Collections.Generic;
+using System.Data.SqlTypes;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
@@ -11,6 +13,109 @@ namespace Serein.Library
///
public static partial class SereinExtension
{
+ ///
+ /// 字面量转为对应类型
+ ///
+ ///
+ ///
+ public static Type ToTypeOfString(this string valueStr)
+ {
+ if (valueStr.IndexOf('.') != -1)
+ {
+ // 通过指定的类型名称获取类型
+ return Type.GetType(valueStr);
+ }
+
+
+ if (valueStr.Equals("bool", StringComparison.OrdinalIgnoreCase))
+ {
+ return typeof(bool);
+ }
+ #region 整数型
+ else if (valueStr.Equals("sbyte", StringComparison.OrdinalIgnoreCase)
+ || valueStr.Equals(nameof(SByte), StringComparison.OrdinalIgnoreCase))
+ {
+ return typeof(SByte);
+ }
+ else if (valueStr.Equals("short", StringComparison.OrdinalIgnoreCase)
+ || valueStr.Equals(nameof(Int16), StringComparison.OrdinalIgnoreCase))
+ {
+ return typeof(Int16);
+ }
+ else if (valueStr.Equals("int", StringComparison.OrdinalIgnoreCase)
+ || valueStr.Equals(nameof(Int32), StringComparison.OrdinalIgnoreCase))
+ {
+ return typeof(Int32);
+ }
+ else if (valueStr.Equals("long", StringComparison.OrdinalIgnoreCase)
+ || valueStr.Equals(nameof(Int64), StringComparison.OrdinalIgnoreCase))
+ {
+ return typeof(Int64);
+ }
+
+ else if (valueStr.Equals("byte", StringComparison.OrdinalIgnoreCase)
+ || valueStr.Equals(nameof(Byte), StringComparison.OrdinalIgnoreCase))
+ {
+ return typeof(Byte);
+ }
+ else if (valueStr.Equals("ushort", StringComparison.OrdinalIgnoreCase)
+ || valueStr.Equals(nameof(UInt16), StringComparison.OrdinalIgnoreCase))
+ {
+ return typeof(UInt16);
+ }
+ else if (valueStr.Equals("uint", StringComparison.OrdinalIgnoreCase)
+ || valueStr.Equals(nameof(UInt32), StringComparison.OrdinalIgnoreCase))
+ {
+ return typeof(UInt32);
+ }
+ else if (valueStr.Equals("ulong", StringComparison.OrdinalIgnoreCase)
+ || valueStr.Equals(nameof(UInt64), StringComparison.OrdinalIgnoreCase))
+ {
+ return typeof(UInt64);
+ }
+ #endregion
+
+ #region 浮点型
+ else if (valueStr.Equals("float", StringComparison.OrdinalIgnoreCase)
+ || valueStr.Equals(nameof(Single), StringComparison.OrdinalIgnoreCase))
+ {
+ return typeof(Single);
+ }
+ else if (valueStr.Equals("double", StringComparison.OrdinalIgnoreCase)
+ || valueStr.Equals(nameof(Double), StringComparison.OrdinalIgnoreCase))
+ {
+ return typeof(Double);
+ }
+ #endregion
+
+ #region 小数型
+
+ else if (valueStr.Equals("decimal", StringComparison.OrdinalIgnoreCase)
+ || valueStr.Equals(nameof(Decimal), StringComparison.OrdinalIgnoreCase))
+ {
+ return typeof(Decimal);
+ }
+ #endregion
+
+ #region 其他常见的类型
+ else if (valueStr.Equals(nameof(DateTime), StringComparison.OrdinalIgnoreCase))
+ {
+ return typeof(DateTime);
+ }
+
+ else if (valueStr.Equals(nameof(String), StringComparison.OrdinalIgnoreCase))
+ {
+ return typeof(String);
+ }
+ #endregion
+
+ else
+ {
+ throw new ArgumentException($"无法解析的字面量类型[{valueStr}]");
+ }
+ }
+
+
///
/// 判断连接类型
///
diff --git a/Library/FlowNode/NodeModelBaseFunc.cs b/Library/FlowNode/NodeModelBaseFunc.cs
index d8077a4..1a74be1 100644
--- a/Library/FlowNode/NodeModelBaseFunc.cs
+++ b/Library/FlowNode/NodeModelBaseFunc.cs
@@ -357,6 +357,10 @@ namespace Serein.Library
/// 节点传回数据对象
public virtual async Task