mirror of
https://gitee.com/langsisi_admin/serein-flow
synced 2026-03-10 11:40:48 +08:00
忘记改啥了*1
This commit is contained in:
@@ -64,13 +64,20 @@ namespace Serein.Library
|
||||
[PropertyInfo]
|
||||
private string _methodAnotherName;
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// 参数描述
|
||||
/// </summary>
|
||||
[PropertyInfo]
|
||||
private ParameterDetails[] _parameterDetailss;
|
||||
|
||||
/// <summary>
|
||||
/// <para>描述该方法是否存在可选参数</para>
|
||||
/// <para>-1表示不存在</para>
|
||||
/// <para>0表示第一个参数是可选参数</para>
|
||||
/// </summary>
|
||||
[PropertyInfo]
|
||||
private int _isParamsArgIndex = -1;
|
||||
|
||||
/// <summary>
|
||||
/// 出参类型
|
||||
/// </summary>
|
||||
@@ -81,6 +88,83 @@ namespace Serein.Library
|
||||
|
||||
public partial class MethodDetails
|
||||
{
|
||||
|
||||
#region 新增可选参数
|
||||
/// <summary>
|
||||
/// 新增可选参数
|
||||
/// </summary>
|
||||
/// <param name="index"></param>
|
||||
public void AddParamsArg(int index = 0)
|
||||
{
|
||||
if (IsParamsArgIndex >= 0 // 方法是否包含可选参数
|
||||
&& index >= 0 // 如果包含,则判断从哪个参数赋值
|
||||
&& index >= IsParamsArgIndex // 需要判断是否为可选参数的部分
|
||||
&& index < ParameterDetailss.Length) // 防止下标越界
|
||||
{
|
||||
var newPd = ParameterDetailss[index].CloneOfModel(this.NodeModel); // 复制出属于本身节点的参数描述
|
||||
newPd.Index = ParameterDetailss.Length; // 更新索引
|
||||
newPd.IsParams = true;
|
||||
ParameterDetailss = AddToArray(ParameterDetailss, newPd); // 新增
|
||||
}
|
||||
}
|
||||
/// <summary>
|
||||
/// 移除可选参数
|
||||
/// </summary>
|
||||
/// <param name="index"></param>
|
||||
public void RemoveParamsArg(int index = 0)
|
||||
{
|
||||
if (IsParamsArgIndex >= 0 // 方法是否包含可选参数
|
||||
&& index >= 0 // 如果包含,则判断从哪个参数赋值
|
||||
&& index >= IsParamsArgIndex // 需要判断是否为可选参数的部分
|
||||
&& index < ParameterDetailss.Length) // 防止下标越界
|
||||
{
|
||||
//var newPd = ParameterDetailss[index].CloneOfModel(this.NodeModel); // 复制出属于本身节点的参数描述
|
||||
//newPd.Index = ParameterDetailss.Length; // 更新索引
|
||||
ParameterDetailss[index] = null; // 释放对象引用
|
||||
ParameterDetailss = RemoteToArray(ParameterDetailss, index); // 新增
|
||||
}
|
||||
}
|
||||
|
||||
public static T[] AddToArray<T>(T[] original, T newObject)
|
||||
{
|
||||
// 创建一个新数组,比原数组大1
|
||||
T[] newArray = new T[original.Length + 1];
|
||||
|
||||
// 复制原数组的元素
|
||||
for (int i = 0; i < original.Length; i++)
|
||||
{
|
||||
newArray[i] = original[i];
|
||||
}
|
||||
|
||||
// 将新对象放在最后一位
|
||||
newArray[newArray.Length - 1] = newObject;
|
||||
|
||||
return newArray;
|
||||
}
|
||||
public static T[] RemoteToArray<T>(T[] original, int index)
|
||||
{
|
||||
if(index == 0)
|
||||
{
|
||||
return new T[0];
|
||||
}
|
||||
// 创建一个新数组,比原数组小1
|
||||
T[] newArray = new T[original.Length - 1];
|
||||
|
||||
for (int i = 0; i < index; i++)
|
||||
{
|
||||
newArray[i] = original[i];
|
||||
}
|
||||
for (int i = index; i < newArray.Length; i++)
|
||||
{
|
||||
newArray[i] = original[i+1];
|
||||
}
|
||||
return newArray;
|
||||
}
|
||||
|
||||
|
||||
#endregion
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// 不包含方法信息的基础节点(后续可能要改为DLL引入基础节点)
|
||||
/// </summary>
|
||||
@@ -91,9 +175,8 @@ namespace Serein.Library
|
||||
/// <summary>
|
||||
/// 生成元数据
|
||||
/// </summary>
|
||||
/// <param name="env">节点运行的环境</param>
|
||||
/// <param name="nodeModel">标识属于哪个节点</param>
|
||||
public MethodDetails(IFlowEnvironment env, NodeModelBase nodeModel)
|
||||
public MethodDetails(NodeModelBase nodeModel)
|
||||
{
|
||||
NodeModel = nodeModel;
|
||||
}
|
||||
@@ -114,6 +197,7 @@ namespace Serein.Library
|
||||
MethodDynamicType = nodeType;
|
||||
ReturnType = Type.GetType(Info.ReturnTypeFullName);
|
||||
ParameterDetailss = Info.ParameterDetailsInfos.Select(pinfo => new ParameterDetails(pinfo)).ToArray();
|
||||
IsParamsArgIndex = Info.IsParamsArgIndex;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@@ -122,25 +206,25 @@ namespace Serein.Library
|
||||
/// <returns></returns>
|
||||
public MethodDetailsInfo ToInfo()
|
||||
{
|
||||
|
||||
|
||||
return new MethodDetailsInfo
|
||||
{
|
||||
MethodName = MethodName,
|
||||
MethodAnotherName = MethodAnotherName,
|
||||
NodeType = MethodDynamicType.ToString(),
|
||||
ParameterDetailsInfos = ParameterDetailss.Select(p => p.ToInfo()).ToArray(),
|
||||
ReturnTypeFullName = ReturnType.FullName,
|
||||
MethodName = this.MethodName,
|
||||
MethodAnotherName = this.MethodAnotherName,
|
||||
NodeType = this.MethodDynamicType.ToString(),
|
||||
ParameterDetailsInfos = this.ParameterDetailss.Select(p => p.ToInfo()).ToArray(),
|
||||
ReturnTypeFullName = this.ReturnType.FullName,
|
||||
IsParamsArgIndex = this.IsParamsArgIndex,
|
||||
};
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 从DLL拖动出来时拷贝属于节点的实例
|
||||
/// 从DLL拖动出来时,从元数据拷贝新的实例,作为属于节点独享的方法描述
|
||||
/// </summary>
|
||||
/// <returns></returns>
|
||||
public MethodDetails CloneOfNode(IFlowEnvironment env, NodeModelBase nodeModel)
|
||||
public MethodDetails CloneOfNode( NodeModelBase nodeModel)
|
||||
{
|
||||
var md = new MethodDetails(env, nodeModel) // 创建新节点时拷贝实例
|
||||
// this => 是元数据
|
||||
var md = new MethodDetails( nodeModel) // 创建新节点时拷贝实例
|
||||
{
|
||||
ActingInstance = this.ActingInstance,
|
||||
ActingInstanceType = this.ActingInstanceType,
|
||||
@@ -150,8 +234,9 @@ namespace Serein.Library
|
||||
MethodName = this.MethodName,
|
||||
MethodLockName = this.MethodLockName,
|
||||
IsProtectionParameter = this.IsProtectionParameter,
|
||||
IsParamsArgIndex= this.IsParamsArgIndex,
|
||||
};
|
||||
md.ParameterDetailss = this.ParameterDetailss?.Select(p => p?.CloneOfClone(env, nodeModel)).ToArray(); // 拷贝属于节点方法的新入参描述
|
||||
md.ParameterDetailss = this.ParameterDetailss?.Select(p => p?.CloneOfModel(nodeModel)).ToArray(); // 拷贝属于节点方法的新入参描述
|
||||
return md;
|
||||
}
|
||||
|
||||
@@ -163,71 +248,16 @@ namespace Serein.Library
|
||||
sb.AppendLine($"需要实例:{this.ActingInstanceType?.FullName}");
|
||||
sb.AppendLine($"");
|
||||
sb.AppendLine($"入参参数信息:");
|
||||
foreach (var arg in this.ParameterDetailss)
|
||||
for (int i = 0; i < ParameterDetailss.Length; i++)
|
||||
{
|
||||
sb.AppendLine($" {arg.ToString()}");
|
||||
ParameterDetails arg = this.ParameterDetailss[i];
|
||||
}
|
||||
sb.AppendLine($"");
|
||||
sb.AppendLine($"返回值信息:");
|
||||
sb.AppendLine($" {this.ReturnType.FullName}");
|
||||
sb.AppendLine($" {this.ReturnType?.FullName}");
|
||||
return sb.ToString();
|
||||
}
|
||||
|
||||
///// <summary>
|
||||
///// 每个节点有独自的MethodDetails实例
|
||||
///// </summary>
|
||||
//public partial class TmpMethodDetails
|
||||
//{
|
||||
// /// <summary>
|
||||
// /// 是否保护参数(目前仅视觉效果参数,不影响运行实现,后续将设置作用在运行逻辑中)
|
||||
// /// </summary>
|
||||
// public bool IsProtectionParameter { get; set; } = false;
|
||||
|
||||
// /// <summary>
|
||||
// /// 作用实例的类型(多个相同的节点将拥有相同的类型)
|
||||
// /// </summary>
|
||||
// public Type ActingInstanceType { get; set; }
|
||||
|
||||
// /// <summary>
|
||||
// /// 作用实例(多个相同的节点将会共享同一个实例)
|
||||
// /// </summary>
|
||||
// public object ActingInstance { get; set; }
|
||||
|
||||
// /// <summary>
|
||||
// /// 方法名称
|
||||
// /// </summary>
|
||||
// public string MethodName { get; set; }
|
||||
|
||||
// /// <summary>
|
||||
// /// 节点类型
|
||||
// /// </summary>
|
||||
// public NodeType MethodDynamicType { get; set; }
|
||||
|
||||
// /// <summary>
|
||||
// /// 锁名称(暂未实现)
|
||||
// /// </summary>
|
||||
// public string MethodLockName { get; set; }
|
||||
|
||||
|
||||
// /// <summary>
|
||||
// /// 方法说明
|
||||
// /// </summary>
|
||||
// public string MethodTips { get; set; }
|
||||
|
||||
|
||||
// /// <summary>
|
||||
// /// 参数描述
|
||||
// /// </summary>
|
||||
|
||||
// public ParameterDetails[] ParameterDetailss { get; set; }
|
||||
|
||||
// /// <summary>
|
||||
// /// 出参类型
|
||||
// /// </summary>
|
||||
|
||||
// public Type ReturnType { get; set; }
|
||||
//}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user