From 0fb0f17319ecf71d66b96a6acfd07f754be9443e Mon Sep 17 00:00:00 2001
From: dengjunjie <dengjunjie@hnkhzn.com>
Date: 星期四, 24 十月 2024 13:44:38 +0800
Subject: [PATCH] WCS添加穿梭车信息表,修改任务信息表
---
项目代码/WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/RuntimeExtension.cs | 89 ++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 89 insertions(+), 0 deletions(-)
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/RuntimeExtension.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/RuntimeExtension.cs"
new file mode 100644
index 0000000..702db9b
--- /dev/null
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/RuntimeExtension.cs"
@@ -0,0 +1,89 @@
+锘�
+using Microsoft.Extensions.DependencyModel;
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Reflection;
+using System.Runtime.Loader;
+using System.Text;
+using System.Threading.Tasks;
+
+namespace WIDESEA_Core.Helper
+{
+ public static class RuntimeExtension
+ {
+ /// <summary>
+ /// 鑾峰彇椤圭洰绋嬪簭闆嗭紝鎺掗櫎鎵�鏈夌殑绯荤粺绋嬪簭闆�(Microsoft.***銆丼ystem.***绛�)銆丯uget涓嬭浇鍖�
+ /// </summary>
+ /// <returns></returns>
+ public static IList<Assembly> GetAllAssemblies()
+ {
+ var list = new List<Assembly>();
+ var deps = DependencyContext.Default;
+ //鍙姞杞介」鐩腑鐨勭▼搴忛泦
+ var libs = deps.CompileLibraries.Where(lib => !lib.Serviceable && lib.Type == "project"); //鎺掗櫎鎵�鏈夌殑绯荤粺绋嬪簭闆嗐�丯uget涓嬭浇鍖�
+ foreach (var lib in libs)
+ {
+ try
+ {
+ var assembly = AssemblyLoadContext.Default.LoadFromAssemblyName(new AssemblyName(lib.Name));
+ list.Add(assembly);
+ }
+ catch (Exception e)
+ {
+ //Log.Debug(e, "GetAllAssemblies Exception:{ex}", e.Message);
+ }
+ }
+
+ return list;
+ }
+
+ public static Assembly GetAssembly(string assemblyName)
+ {
+ return GetAllAssemblies().FirstOrDefault(assembly => assembly.FullName.Contains(assemblyName));
+ }
+
+ public static IList<Type> GetAllTypes()
+ {
+ var list = new List<Type>();
+ foreach (var assembly in GetAllAssemblies())
+ {
+ var typeInfos = assembly.DefinedTypes;
+ foreach (var typeInfo in typeInfos)
+ {
+ list.Add(typeInfo.AsType());
+ }
+ }
+
+ return list;
+ }
+
+ public static IList<Type> GetTypesByAssembly(string assemblyName)
+ {
+ var list = new List<Type>();
+ var assembly = AssemblyLoadContext.Default.LoadFromAssemblyName(new AssemblyName(assemblyName));
+ var typeInfos = assembly.DefinedTypes;
+ foreach (var typeInfo in typeInfos)
+ {
+ list.Add(typeInfo.AsType());
+ }
+
+ return list;
+ }
+
+ public static Type GetImplementType(string typeName, Type baseInterfaceType)
+ {
+ return GetAllTypes().FirstOrDefault(t =>
+ {
+ if (t.Name == typeName &&
+ t.GetTypeInfo().GetInterfaces().Any(b => b.Name == baseInterfaceType.Name))
+ {
+ var typeInfo = t.GetTypeInfo();
+ return typeInfo.IsClass && !typeInfo.IsAbstract && !typeInfo.IsGenericType;
+ }
+
+ return false;
+ });
+ }
+ }
+}
--
Gitblit v1.9.3