PowerToys/WinAlfred/PluginLoader/BasePluginLoader.cs

132 lines
4.8 KiB
C#
Raw Normal View History

2013-12-20 19:38:10 +08:00
using System;
using System.Collections.Generic;
using System.IO;
2014-01-03 18:16:05 +08:00
using System.Linq;
using System.Reflection;
2014-01-12 21:02:39 +08:00
using System.Windows.Forms;
2013-12-20 19:38:10 +08:00
using WinAlfred.Helper;
using WinAlfred.Plugin;
2014-01-03 18:16:05 +08:00
using WinAlfred.Plugin.System;
2013-12-20 19:38:10 +08:00
namespace WinAlfred.PluginLoader
{
public abstract class BasePluginLoader
{
2014-01-12 21:02:39 +08:00
private static string PluginPath = AppDomain.CurrentDomain.BaseDirectory + "Plugins";
2013-12-20 19:38:10 +08:00
private static string PluginConfigName = "plugin.ini";
protected static List<PluginMetadata> pluginMetadatas = new List<PluginMetadata>();
public abstract List<PluginPair> LoadPlugin();
2013-12-20 19:38:10 +08:00
2014-01-12 18:15:30 +08:00
public static void ParsePluginsConfig()
2013-12-20 19:38:10 +08:00
{
2014-01-12 18:15:30 +08:00
pluginMetadatas.Clear();
2014-01-03 18:16:05 +08:00
ParseSystemPlugins();
ParseThirdPartyPlugins();
2013-12-20 19:38:10 +08:00
}
2014-01-03 18:16:05 +08:00
private static void ParseSystemPlugins()
{
2014-01-03 23:52:36 +08:00
PluginMetadata metadata = new PluginMetadata();
metadata.Name = "System Plugins";
metadata.Author = "System";
metadata.Description = "system plugins collection";
metadata.Language = AllowedLanguage.CSharp;
metadata.Version = "1.0";
metadata.PluginType = PluginType.System;
metadata.ActionKeyword = "*";
metadata.ExecuteFileName = "WinAlfred.Plugin.System.dll";
metadata.ExecuteFilePath = AppDomain.CurrentDomain.BaseDirectory + metadata.ExecuteFileName;
metadata.PluginDirecotry = AppDomain.CurrentDomain.BaseDirectory;
pluginMetadatas.Add(metadata);
2014-01-03 18:16:05 +08:00
}
private static void ParseThirdPartyPlugins()
{
if (!Directory.Exists(PluginPath))
Directory.CreateDirectory(PluginPath);
2013-12-20 19:38:10 +08:00
string[] directories = Directory.GetDirectories(PluginPath);
foreach (string directory in directories)
{
PluginMetadata metadata = GetMetadataFromIni(directory);
2013-12-20 19:38:10 +08:00
if (metadata != null) pluginMetadatas.Add(metadata);
}
}
private static PluginMetadata GetMetadataFromIni(string directory)
2013-12-20 19:38:10 +08:00
{
string iniPath = directory + "\\" + PluginConfigName;
2013-12-20 19:38:10 +08:00
if (!File.Exists(iniPath))
{
Log.Error(string.Format("parse plugin {0} failed: didn't find config file.", iniPath));
2013-12-20 19:38:10 +08:00
return null;
}
try
{
PluginMetadata metadata = new PluginMetadata();
IniParser ini = new IniParser(iniPath);
metadata.Name = ini.GetSetting("plugin", "Name");
metadata.Author = ini.GetSetting("plugin", "Author");
metadata.Description = ini.GetSetting("plugin", "Description");
metadata.Language = ini.GetSetting("plugin", "Language");
metadata.Version = ini.GetSetting("plugin", "Version");
2014-01-03 18:16:05 +08:00
metadata.PluginType = PluginType.ThirdParty;
metadata.ActionKeyword = ini.GetSetting("plugin", "ActionKeyword");
2014-01-12 21:02:39 +08:00
metadata.ExecuteFilePath = directory + "\\" + ini.GetSetting("plugin", "ExecuteFile");
metadata.PluginDirecotry = directory + "\\";
2013-12-23 23:53:38 +08:00
metadata.ExecuteFileName = ini.GetSetting("plugin", "ExecuteFile");
2013-12-20 19:38:10 +08:00
if (!AllowedLanguage.IsAllowed(metadata.Language))
{
2013-12-23 19:21:51 +08:00
string error = string.Format("Parse ini {0} failed: invalid language {1}", iniPath,
metadata.Language);
Log.Error(error);
#if (DEBUG)
{
throw new WinAlfredException(error);
}
#endif
return null;
}
2013-12-23 23:53:38 +08:00
if (!File.Exists(metadata.ExecuteFilePath))
{
2013-12-23 23:53:38 +08:00
string error = string.Format("Parse ini {0} failed: ExecuteFilePath didn't exist {1}", iniPath,
metadata.ExecuteFilePath);
2013-12-23 19:21:51 +08:00
Log.Error(error);
#if (DEBUG)
{
throw new WinAlfredException(error);
}
#endif
2013-12-20 19:38:10 +08:00
return null;
}
return metadata;
}
catch (Exception e)
{
Log.Error(string.Format("Parse ini {0} failed: {1}", iniPath, e.Message));
2013-12-23 19:21:51 +08:00
#if (DEBUG)
{
throw;
}
#endif
2013-12-20 19:38:10 +08:00
return null;
}
}
///// <summary>
///// Change python execute file name to unique file name using GUID
///// this is because if two pythong plugin use the same
///// </summary>
///// <param name="metadata"></param>
///// <returns></returns>
//private static PluginMetadata filterPythonMetadata(PluginMetadata metadata)
//{
2014-01-12 18:15:30 +08:00
//}
2013-12-20 19:38:10 +08:00
}
}