make PatchUploader selector more friendly
This commit is contained in:
parent
92302eb3d9
commit
88135a2dc6
@ -95,8 +95,11 @@ namespace VersionFlow.Editors
|
||||
var uploaderTypes = builder.GetAllPatcherType();
|
||||
|
||||
var options = uploaderTypes.Select(t => $"{t.Namespace}.{t.Name}").ToList();
|
||||
|
||||
var selectIndex = options.IndexOf(builder.uploaderClassName);
|
||||
selectIndex = EditorGUILayout.Popup("选择上传器", selectIndex, options.ToArray());
|
||||
|
||||
|
||||
selectIndex = EditorGUILayout.Popup("选择上传器", selectIndex, options.Select(op=>PatchUploaderUtility.GetPatcherPrettyName(op)).ToArray());
|
||||
if (selectIndex != -1)
|
||||
{
|
||||
var selectClassName = options[selectIndex];
|
||||
@ -104,9 +107,13 @@ namespace VersionFlow.Editors
|
||||
}
|
||||
|
||||
var patchLoader = builder.GetPatchLoader();
|
||||
Editor.CreateEditor(patchLoader).OnInspectorGUI();
|
||||
string json = patchLoader.GetCfgJson();
|
||||
builder.uploaderCfgJson = json;
|
||||
if (patchLoader != null)
|
||||
{
|
||||
Editor.CreateEditor(patchLoader).OnInspectorGUI();
|
||||
string json = patchLoader.GetCfgJson();
|
||||
builder.uploaderCfgJson = json;
|
||||
}
|
||||
|
||||
if (GUI.changed)
|
||||
{
|
||||
EditorUtility.SetDirty(target);
|
||||
|
||||
@ -3,6 +3,7 @@ using AlibabaCloud.SDK.Cdn20180510.Models;
|
||||
using Aliyun.OSS;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.ComponentModel;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
@ -13,7 +14,8 @@ using static VersionFlow.Editors.ICDNPerformer;
|
||||
|
||||
namespace VersionFlow.Editors
|
||||
{
|
||||
public class Patchloader_AliOSS : PatchUploader<Patchloader_AliOSS.Config>, ICDNPerformer
|
||||
[Description("阿里云OSS")]
|
||||
public class PatchUpLoader_AliOSS : PatchUploader<PatchUpLoader_AliOSS.Config>, ICDNPerformer
|
||||
{
|
||||
private OssClient m_ossClient;
|
||||
private Client m_cdnClient;
|
||||
@ -1,5 +1,6 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.ComponentModel;
|
||||
using System.Reflection;
|
||||
using UnityEditor;
|
||||
using VersionFlow.Runtime;
|
||||
@ -10,13 +11,14 @@ namespace VersionFlow.Editors
|
||||
{
|
||||
static Dictionary<BuilderConfig, PatchUploader> s_patchInstance = new Dictionary<BuilderConfig, PatchUploader>();
|
||||
static Dictionary<string, Type> s_patchloaderTypesMapper;
|
||||
static Dictionary<Type, string> s_patcherPrettyNameMapper;
|
||||
|
||||
static void PreparePatcherTypes()
|
||||
{
|
||||
if (s_patchloaderTypesMapper != null) return;
|
||||
|
||||
s_patchloaderTypesMapper = new Dictionary<string, Type>();
|
||||
|
||||
s_patcherPrettyNameMapper = new Dictionary<Type, string>();
|
||||
foreach (var assembly in AppDomain.CurrentDomain.GetAssemblies())
|
||||
{
|
||||
if (assembly.IsDynamic) continue;
|
||||
@ -26,6 +28,14 @@ namespace VersionFlow.Editors
|
||||
if (!typeof(PatchUploader).IsAssignableFrom(type)) continue;
|
||||
|
||||
s_patchloaderTypesMapper[type.FullName] = type;
|
||||
if (type.GetCustomAttribute<DescriptionAttribute>() is DescriptionAttribute desAtt)
|
||||
{
|
||||
s_patcherPrettyNameMapper[type] = desAtt.Description;
|
||||
}
|
||||
else
|
||||
{
|
||||
s_patcherPrettyNameMapper[type] = $"{type.Namespace}.{type.Name}";
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -36,6 +46,21 @@ namespace VersionFlow.Editors
|
||||
|
||||
return s_patchloaderTypesMapper.Values;
|
||||
}
|
||||
public static Type GetPatcherType(string className)
|
||||
{
|
||||
s_patchloaderTypesMapper.TryGetValue(className, out var type);
|
||||
return type;
|
||||
}
|
||||
public static string GetPatcherPrettyName(string className)
|
||||
{
|
||||
s_patcherPrettyNameMapper.TryGetValue(GetPatcherType(className), out var prettyName);
|
||||
return prettyName;
|
||||
}
|
||||
public static string GetPatcherPrettyName(Type patcherType)
|
||||
{
|
||||
s_patcherPrettyNameMapper.TryGetValue(patcherType, out var prettyName);
|
||||
return prettyName;
|
||||
}
|
||||
|
||||
public static PatchUploader GetPatchLoader(this BuilderConfig builder)
|
||||
{
|
||||
|
||||
Loading…
Reference in New Issue
Block a user