mirror of
https://github.com/microsoft/PowerToys.git
synced 2025-06-07 09:28:03 +08:00
ReSharper: remove redundant code
This commit is contained in:
parent
ae42c4df16
commit
0daa3a8f57
@ -59,11 +59,11 @@ namespace Wox.Plugin.CMD
|
|||||||
!results.Any(p => o.Equals(p.Title, StringComparison.OrdinalIgnoreCase)) &&
|
!results.Any(p => o.Equals(p.Title, StringComparison.OrdinalIgnoreCase)) &&
|
||||||
!results.Any(p => o.Equals(p.Title, StringComparison.OrdinalIgnoreCase))).ToList();
|
!results.Any(p => o.Equals(p.Title, StringComparison.OrdinalIgnoreCase))).ToList();
|
||||||
autocomplete.Sort();
|
autocomplete.Sort();
|
||||||
results.AddRange(autocomplete.ConvertAll(m => new Result()
|
results.AddRange(autocomplete.ConvertAll(m => new Result
|
||||||
{
|
{
|
||||||
Title = m,
|
Title = m,
|
||||||
IcoPath = "Images/cmd.png",
|
IcoPath = "Images/cmd.png",
|
||||||
Action = (c) =>
|
Action = c =>
|
||||||
{
|
{
|
||||||
ExecuteCMD(m);
|
ExecuteCMD(m);
|
||||||
return true;
|
return true;
|
||||||
@ -96,7 +96,7 @@ namespace Wox.Plugin.CMD
|
|||||||
Title = m.Key,
|
Title = m.Key,
|
||||||
SubTitle = string.Format(context.API.GetTranslation("wox_plugin_cmd_cmd_has_been_executed_times"), m.Value),
|
SubTitle = string.Format(context.API.GetTranslation("wox_plugin_cmd_cmd_has_been_executed_times"), m.Value),
|
||||||
IcoPath = "Images/cmd.png",
|
IcoPath = "Images/cmd.png",
|
||||||
Action = (c) =>
|
Action = c =>
|
||||||
{
|
{
|
||||||
ExecuteCMD(m.Key);
|
ExecuteCMD(m.Key);
|
||||||
return true;
|
return true;
|
||||||
@ -115,7 +115,7 @@ namespace Wox.Plugin.CMD
|
|||||||
Score = 5000,
|
Score = 5000,
|
||||||
SubTitle = context.API.GetTranslation("wox_plugin_cmd_execute_through_shell"),
|
SubTitle = context.API.GetTranslation("wox_plugin_cmd_execute_through_shell"),
|
||||||
IcoPath = "Images/cmd.png",
|
IcoPath = "Images/cmd.png",
|
||||||
Action = (c) =>
|
Action = c =>
|
||||||
{
|
{
|
||||||
ExecuteCMD(cmd);
|
ExecuteCMD(cmd);
|
||||||
return true;
|
return true;
|
||||||
@ -133,7 +133,7 @@ namespace Wox.Plugin.CMD
|
|||||||
Title = m.Key,
|
Title = m.Key,
|
||||||
SubTitle = string.Format(context.API.GetTranslation("wox_plugin_cmd_cmd_has_been_executed_times"), m.Value),
|
SubTitle = string.Format(context.API.GetTranslation("wox_plugin_cmd_cmd_has_been_executed_times"), m.Value),
|
||||||
IcoPath = "Images/cmd.png",
|
IcoPath = "Images/cmd.png",
|
||||||
Action = (c) =>
|
Action = c =>
|
||||||
{
|
{
|
||||||
ExecuteCMD(m.Key);
|
ExecuteCMD(m.Key);
|
||||||
return true;
|
return true;
|
||||||
@ -219,9 +219,9 @@ namespace Wox.Plugin.CMD
|
|||||||
|
|
||||||
public List<Result> LoadContextMenus(Result selectedResult)
|
public List<Result> LoadContextMenus(Result selectedResult)
|
||||||
{
|
{
|
||||||
return new List<Result>()
|
return new List<Result>
|
||||||
{
|
{
|
||||||
new Result()
|
new Result
|
||||||
{
|
{
|
||||||
Title = context.API.GetTranslation("wox_plugin_cmd_run_as_administrator"),
|
Title = context.API.GetTranslation("wox_plugin_cmd_run_as_administrator"),
|
||||||
Action = c =>
|
Action = c =>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
|
using System.Runtime.InteropServices;
|
||||||
using System.Text.RegularExpressions;
|
using System.Text.RegularExpressions;
|
||||||
using System.Windows;
|
using System.Windows;
|
||||||
using YAMP;
|
using YAMP;
|
||||||
@ -18,7 +19,7 @@ namespace Wox.Plugin.Caculator
|
|||||||
@"[ei]|[0-9]|[\+\-\*\/\^\., ""]|[\(\)\|\!\[\]]" +
|
@"[ei]|[0-9]|[\+\-\*\/\^\., ""]|[\(\)\|\!\[\]]" +
|
||||||
@")+$", RegexOptions.Compiled);
|
@")+$", RegexOptions.Compiled);
|
||||||
private static Regex regBrackets = new Regex(@"[\(\)\[\]]", RegexOptions.Compiled);
|
private static Regex regBrackets = new Regex(@"[\(\)\[\]]", RegexOptions.Compiled);
|
||||||
private static ParseContext yampContext = null;
|
private static ParseContext yampContext;
|
||||||
private PluginInitContext context { get; set; }
|
private PluginInitContext context { get; set; }
|
||||||
|
|
||||||
static Calculator()
|
static Calculator()
|
||||||
@ -39,19 +40,21 @@ namespace Wox.Plugin.Caculator
|
|||||||
var result = yampContext.Run(query.Search);
|
var result = yampContext.Run(query.Search);
|
||||||
if (result.Output != null && !string.IsNullOrEmpty(result.Result))
|
if (result.Output != null && !string.IsNullOrEmpty(result.Result))
|
||||||
{
|
{
|
||||||
return new List<Result>() { new Result() {
|
return new List<Result>
|
||||||
|
{ new Result
|
||||||
|
{
|
||||||
Title = result.Result,
|
Title = result.Result,
|
||||||
IcoPath = "Images/calculator.png",
|
IcoPath = "Images/calculator.png",
|
||||||
Score = 300,
|
Score = 300,
|
||||||
SubTitle = "Copy this number to the clipboard",
|
SubTitle = "Copy this number to the clipboard",
|
||||||
Action = (c) =>
|
Action = c =>
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
Clipboard.SetText(result.Result);
|
Clipboard.SetText(result.Result);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
catch (System.Runtime.InteropServices.ExternalException e)
|
catch (ExternalException e)
|
||||||
{
|
{
|
||||||
MessageBox.Show("Copy failed, please try later");
|
MessageBox.Show("Copy failed, please try later");
|
||||||
return false;
|
return false;
|
||||||
|
@ -47,7 +47,7 @@ namespace Wox.Plugin.ControlPanel
|
|||||||
var fuzzyMather = FuzzyMatcher.Create(myQuery);
|
var fuzzyMather = FuzzyMatcher.Create(myQuery);
|
||||||
if (MatchProgram(item, fuzzyMather))
|
if (MatchProgram(item, fuzzyMather))
|
||||||
{
|
{
|
||||||
results.Add(new Result()
|
results.Add(new Result
|
||||||
{
|
{
|
||||||
Title = item.LocalizedString,
|
Title = item.LocalizedString,
|
||||||
SubTitle = item.InfoTip,
|
SubTitle = item.InfoTip,
|
||||||
|
@ -123,7 +123,7 @@ namespace Wox.Plugin.ControlPanel
|
|||||||
|
|
||||||
if (currentKey.GetValue("LocalizedString") != null)
|
if (currentKey.GetValue("LocalizedString") != null)
|
||||||
{
|
{
|
||||||
localizedStringRaw = currentKey.GetValue("LocalizedString").ToString().Split(new string[] { ",-" }, StringSplitOptions.None);
|
localizedStringRaw = currentKey.GetValue("LocalizedString").ToString().Split(new[] { ",-" }, StringSplitOptions.None);
|
||||||
|
|
||||||
if (localizedStringRaw.Length > 1)
|
if (localizedStringRaw.Length > 1)
|
||||||
{
|
{
|
||||||
@ -184,7 +184,7 @@ namespace Wox.Plugin.ControlPanel
|
|||||||
|
|
||||||
if (currentKey.GetValue("InfoTip") != null)
|
if (currentKey.GetValue("InfoTip") != null)
|
||||||
{
|
{
|
||||||
infoTipRaw = currentKey.GetValue("InfoTip").ToString().Split(new string[] { ",-" }, StringSplitOptions.None);
|
infoTipRaw = currentKey.GetValue("InfoTip").ToString().Split(new[] { ",-" }, StringSplitOptions.None);
|
||||||
|
|
||||||
if (infoTipRaw.Length == 2)
|
if (infoTipRaw.Length == 2)
|
||||||
{
|
{
|
||||||
@ -229,7 +229,7 @@ namespace Wox.Plugin.ControlPanel
|
|||||||
{
|
{
|
||||||
if (currentKey.OpenSubKey("DefaultIcon").GetValue(null) != null)
|
if (currentKey.OpenSubKey("DefaultIcon").GetValue(null) != null)
|
||||||
{
|
{
|
||||||
iconString = new List<string>(currentKey.OpenSubKey("DefaultIcon").GetValue(null).ToString().Split(new char[] { ',' }, 2));
|
iconString = new List<string>(currentKey.OpenSubKey("DefaultIcon").GetValue(null).ToString().Split(new[] { ',' }, 2));
|
||||||
if (iconString[0][0] == '@')
|
if (iconString[0][0] == '@')
|
||||||
{
|
{
|
||||||
iconString[0] = iconString[0].Substring(1);
|
iconString[0] = iconString[0].Substring(1);
|
||||||
@ -247,7 +247,7 @@ namespace Wox.Plugin.ControlPanel
|
|||||||
if (iconPtr == IntPtr.Zero)
|
if (iconPtr == IntPtr.Zero)
|
||||||
{
|
{
|
||||||
defaultIconPtr = IntPtr.Zero;
|
defaultIconPtr = IntPtr.Zero;
|
||||||
EnumResourceNamesWithID(dataFilePointer, GROUP_ICON, new EnumResNameDelegate(EnumRes), IntPtr.Zero); //Iterate through resources.
|
EnumResourceNamesWithID(dataFilePointer, GROUP_ICON, EnumRes, IntPtr.Zero); //Iterate through resources.
|
||||||
|
|
||||||
iconPtr = LoadImage(dataFilePointer, defaultIconPtr, 1, iconSize, iconSize, 0);
|
iconPtr = LoadImage(dataFilePointer, defaultIconPtr, 1, iconSize, iconSize, 0);
|
||||||
}
|
}
|
||||||
@ -312,16 +312,16 @@ namespace Wox.Plugin.ControlPanel
|
|||||||
|
|
||||||
private static uint GET_RESOURCE_ID(IntPtr value)
|
private static uint GET_RESOURCE_ID(IntPtr value)
|
||||||
{
|
{
|
||||||
if (IS_INTRESOURCE(value) == true)
|
if (IS_INTRESOURCE(value))
|
||||||
return (uint)value;
|
return (uint)value;
|
||||||
throw new System.NotSupportedException("value is not an ID!");
|
throw new NotSupportedException("value is not an ID!");
|
||||||
}
|
}
|
||||||
|
|
||||||
private static string GET_RESOURCE_NAME(IntPtr value)
|
private static string GET_RESOURCE_NAME(IntPtr value)
|
||||||
{
|
{
|
||||||
if (IS_INTRESOURCE(value) == true)
|
if (IS_INTRESOURCE(value))
|
||||||
return value.ToString();
|
return value.ToString();
|
||||||
return Marshal.PtrToStringUni((IntPtr)value);
|
return Marshal.PtrToStringUni(value);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static bool EnumRes(IntPtr hModule, IntPtr lpszType, IntPtr lpszName, IntPtr lParam)
|
private static bool EnumRes(IntPtr hModule, IntPtr lpszType, IntPtr lpszName, IntPtr lParam)
|
||||||
|
@ -233,7 +233,7 @@ namespace Wox.Plugin.Everything.Everything
|
|||||||
{
|
{
|
||||||
Everything_GetResultFullPathName(idx, buffer, bufferSize);
|
Everything_GetResultFullPathName(idx, buffer, bufferSize);
|
||||||
|
|
||||||
var result = new SearchResult() { FullPath = buffer.ToString() };
|
var result = new SearchResult { FullPath = buffer.ToString() };
|
||||||
if (Everything_IsFolderResult(idx))
|
if (Everything_IsFolderResult(idx))
|
||||||
result.Type = ResultType.Folder;
|
result.Type = ResultType.Folder;
|
||||||
else if (Everything_IsFileResult(idx))
|
else if (Everything_IsFileResult(idx))
|
||||||
|
@ -4,7 +4,9 @@ using System.Diagnostics;
|
|||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
|
using System.Runtime.InteropServices;
|
||||||
using System.ServiceProcess;
|
using System.ServiceProcess;
|
||||||
|
using System.Windows;
|
||||||
using Wox.Plugin.Everything.Everything;
|
using Wox.Plugin.Everything.Everything;
|
||||||
|
|
||||||
namespace Wox.Plugin.Everything
|
namespace Wox.Plugin.Everything
|
||||||
@ -13,8 +15,8 @@ namespace Wox.Plugin.Everything
|
|||||||
{
|
{
|
||||||
PluginInitContext context;
|
PluginInitContext context;
|
||||||
EverythingAPI api = new EverythingAPI();
|
EverythingAPI api = new EverythingAPI();
|
||||||
private static List<string> imageExts = new List<string>() { ".png", ".jpg", ".jpeg", ".gif", ".bmp", ".tiff", ".ico" };
|
private static List<string> imageExts = new List<string> { ".png", ".jpg", ".jpeg", ".gif", ".bmp", ".tiff", ".ico" };
|
||||||
private static List<string> executableExts = new List<string>() { ".exe" };
|
private static List<string> executableExts = new List<string> { ".exe" };
|
||||||
|
|
||||||
public List<Result> Query(Query query)
|
public List<Result> Query(Query query)
|
||||||
{
|
{
|
||||||
@ -34,7 +36,7 @@ namespace Wox.Plugin.Everything
|
|||||||
r.Title = "Uninstall Everything";
|
r.Title = "Uninstall Everything";
|
||||||
r.SubTitle = "You need to uninstall everything service if you can not move/delete wox folder";
|
r.SubTitle = "You need to uninstall everything service if you can not move/delete wox folder";
|
||||||
r.IcoPath = "Images\\find.png";
|
r.IcoPath = "Images\\find.png";
|
||||||
r.Action = (c) =>
|
r.Action = c =>
|
||||||
{
|
{
|
||||||
UnInstallEverything();
|
UnInstallEverything();
|
||||||
return true;
|
return true;
|
||||||
@ -53,7 +55,7 @@ namespace Wox.Plugin.Everything
|
|||||||
r.Title = Path.GetFileName(path);
|
r.Title = Path.GetFileName(path);
|
||||||
r.SubTitle = path;
|
r.SubTitle = path;
|
||||||
r.IcoPath = GetIconPath(s);
|
r.IcoPath = GetIconPath(s);
|
||||||
r.Action = (c) =>
|
r.Action = c =>
|
||||||
{
|
{
|
||||||
context.API.HideApp();
|
context.API.HideApp();
|
||||||
Process.Start(new ProcessStartInfo
|
Process.Start(new ProcessStartInfo
|
||||||
@ -70,7 +72,7 @@ namespace Wox.Plugin.Everything
|
|||||||
catch (IPCErrorException)
|
catch (IPCErrorException)
|
||||||
{
|
{
|
||||||
StartEverything();
|
StartEverything();
|
||||||
results.Add(new Result()
|
results.Add(new Result
|
||||||
{
|
{
|
||||||
Title = context.API.GetTranslation("wox_plugin_everything_is_not_running"),
|
Title = context.API.GetTranslation("wox_plugin_everything_is_not_running"),
|
||||||
IcoPath = "Images\\warning.png"
|
IcoPath = "Images\\warning.png"
|
||||||
@ -78,13 +80,13 @@ namespace Wox.Plugin.Everything
|
|||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
results.Add(new Result()
|
results.Add(new Result
|
||||||
{
|
{
|
||||||
Title = context.API.GetTranslation("wox_plugin_everything_query_error"),
|
Title = context.API.GetTranslation("wox_plugin_everything_query_error"),
|
||||||
SubTitle = e.Message,
|
SubTitle = e.Message,
|
||||||
Action = _ =>
|
Action = _ =>
|
||||||
{
|
{
|
||||||
System.Windows.Clipboard.SetText(e.Message + "\r\n" + e.StackTrace);
|
Clipboard.SetText(e.Message + "\r\n" + e.StackTrace);
|
||||||
context.API.ShowMsg(context.API.GetTranslation("wox_plugin_everything_copied"), null, string.Empty);
|
context.API.ShowMsg(context.API.GetTranslation("wox_plugin_everything_copied"), null, string.Empty);
|
||||||
return false;
|
return false;
|
||||||
},
|
},
|
||||||
@ -120,13 +122,13 @@ namespace Wox.Plugin.Everything
|
|||||||
return "Images\\file.png";
|
return "Images\\file.png";
|
||||||
}
|
}
|
||||||
|
|
||||||
[System.Runtime.InteropServices.DllImport("kernel32.dll")]
|
[DllImport("kernel32.dll")]
|
||||||
private static extern int LoadLibrary(string name);
|
private static extern int LoadLibrary(string name);
|
||||||
|
|
||||||
private List<ContextMenu> GetDefaultContextMenu()
|
private List<ContextMenu> GetDefaultContextMenu()
|
||||||
{
|
{
|
||||||
List<ContextMenu> defaultContextMenus = new List<ContextMenu>();
|
List<ContextMenu> defaultContextMenus = new List<ContextMenu>();
|
||||||
ContextMenu openFolderContextMenu = new ContextMenu()
|
ContextMenu openFolderContextMenu = new ContextMenu
|
||||||
{
|
{
|
||||||
Name = context.API.GetTranslation("wox_plugin_everything_open_containing_folder"),
|
Name = context.API.GetTranslation("wox_plugin_everything_open_containing_folder"),
|
||||||
Command = "explorer.exe",
|
Command = "explorer.exe",
|
||||||
@ -282,7 +284,7 @@ namespace Wox.Plugin.Everything
|
|||||||
foreach (ContextMenu contextMenu in availableContextMenus)
|
foreach (ContextMenu contextMenu in availableContextMenus)
|
||||||
{
|
{
|
||||||
var menu = contextMenu;
|
var menu = contextMenu;
|
||||||
contextMenus.Add(new Result()
|
contextMenus.Add(new Result
|
||||||
{
|
{
|
||||||
Title = contextMenu.Name,
|
Title = contextMenu.Name,
|
||||||
Action = _ =>
|
Action = _ =>
|
||||||
|
@ -12,7 +12,7 @@ namespace Wox.Plugin.Folder
|
|||||||
|
|
||||||
public string Nickname
|
public string Nickname
|
||||||
{
|
{
|
||||||
get { return Path.Split(new char[] { System.IO.Path.DirectorySeparatorChar }, StringSplitOptions.None).Last(); }
|
get { return Path.Split(new[] { System.IO.Path.DirectorySeparatorChar }, StringSplitOptions.None).Last(); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -51,7 +51,7 @@ namespace Wox.Plugin.Folder
|
|||||||
{
|
{
|
||||||
List<Result> contextMenus = new List<Result>();
|
List<Result> contextMenus = new List<Result>();
|
||||||
string folderPath = ((FolderLink) targetResult.ContextData).Path;
|
string folderPath = ((FolderLink) targetResult.ContextData).Path;
|
||||||
contextMenus.Add(new Result()
|
contextMenus.Add(new Result
|
||||||
{
|
{
|
||||||
Title = "Copy to this folder",
|
Title = "Copy to this folder",
|
||||||
IcoPath = "Images/copy.png",
|
IcoPath = "Images/copy.png",
|
||||||
|
@ -1,7 +1,11 @@
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.IO;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Windows;
|
using System.Windows;
|
||||||
using System.Windows.Forms;
|
using System.Windows.Forms;
|
||||||
|
using DataFormats = System.Windows.DataFormats;
|
||||||
|
using DragDropEffects = System.Windows.DragDropEffects;
|
||||||
|
using DragEventArgs = System.Windows.DragEventArgs;
|
||||||
using MessageBox = System.Windows.MessageBox;
|
using MessageBox = System.Windows.MessageBox;
|
||||||
using UserControl = System.Windows.Controls.UserControl;
|
using UserControl = System.Windows.Controls.UserControl;
|
||||||
|
|
||||||
@ -66,10 +70,10 @@ namespace Wox.Plugin.Folder
|
|||||||
|
|
||||||
private void btnAdd_Click(object sender, RoutedEventArgs e)
|
private void btnAdd_Click(object sender, RoutedEventArgs e)
|
||||||
{
|
{
|
||||||
var folderBrowserDialog = new System.Windows.Forms.FolderBrowserDialog();
|
var folderBrowserDialog = new FolderBrowserDialog();
|
||||||
if (folderBrowserDialog.ShowDialog() == System.Windows.Forms.DialogResult.OK)
|
if (folderBrowserDialog.ShowDialog() == DialogResult.OK)
|
||||||
{
|
{
|
||||||
var newFolder = new FolderLink()
|
var newFolder = new FolderLink
|
||||||
{
|
{
|
||||||
Path = folderBrowserDialog.SelectedPath
|
Path = folderBrowserDialog.SelectedPath
|
||||||
};
|
};
|
||||||
@ -86,9 +90,9 @@ namespace Wox.Plugin.Folder
|
|||||||
lbxFolders.Items.Refresh();
|
lbxFolders.Items.Refresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void lbxFolders_Drop(object sender, System.Windows.DragEventArgs e)
|
private void lbxFolders_Drop(object sender, DragEventArgs e)
|
||||||
{
|
{
|
||||||
string[] files = (string[])e.Data.GetData(System.Windows.DataFormats.FileDrop);
|
string[] files = (string[])e.Data.GetData(DataFormats.FileDrop);
|
||||||
|
|
||||||
if (files != null && files.Count() > 0)
|
if (files != null && files.Count() > 0)
|
||||||
{
|
{
|
||||||
@ -99,9 +103,9 @@ namespace Wox.Plugin.Folder
|
|||||||
|
|
||||||
foreach (string s in files)
|
foreach (string s in files)
|
||||||
{
|
{
|
||||||
if (System.IO.Directory.Exists(s) == true)
|
if (Directory.Exists(s))
|
||||||
{
|
{
|
||||||
var newFolder = new FolderLink()
|
var newFolder = new FolderLink
|
||||||
{
|
{
|
||||||
Path = s
|
Path = s
|
||||||
};
|
};
|
||||||
@ -115,15 +119,15 @@ namespace Wox.Plugin.Folder
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void lbxFolders_DragEnter(object sender, System.Windows.DragEventArgs e)
|
private void lbxFolders_DragEnter(object sender, DragEventArgs e)
|
||||||
{
|
{
|
||||||
if (e.Data.GetDataPresent(System.Windows.DataFormats.FileDrop))
|
if (e.Data.GetDataPresent(DataFormats.FileDrop))
|
||||||
{
|
{
|
||||||
e.Effects = System.Windows.DragDropEffects.Link;
|
e.Effects = DragDropEffects.Link;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
e.Effects = System.Windows.DragDropEffects.None;
|
e.Effects = DragDropEffects.None;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -25,11 +25,11 @@ namespace Wox.Plugin.PluginIndicator
|
|||||||
SubTitle = $"Activate {metadata.Name} plugin",
|
SubTitle = $"Activate {metadata.Name} plugin",
|
||||||
Score = 100,
|
Score = 100,
|
||||||
IcoPath = metadata.FullIcoPath,
|
IcoPath = metadata.FullIcoPath,
|
||||||
Action = (c) =>
|
Action = c =>
|
||||||
{
|
{
|
||||||
context.API.ChangeQuery($"{keyword}{Plugin.Query.TermSeperater}");
|
context.API.ChangeQuery($"{keyword}{Plugin.Query.TermSeperater}");
|
||||||
return false;
|
return false;
|
||||||
},
|
}
|
||||||
};
|
};
|
||||||
return results.ToList();
|
return results.ToList();
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
using System.Windows;
|
using System.Windows;
|
||||||
|
using System.Windows.Forms;
|
||||||
|
|
||||||
namespace Wox.Plugin.Program
|
namespace Wox.Plugin.Program
|
||||||
{
|
{
|
||||||
@ -16,51 +17,51 @@ namespace Wox.Plugin.Program
|
|||||||
|
|
||||||
public AddProgramSource(ProgramSource edit) : this()
|
public AddProgramSource(ProgramSource edit) : this()
|
||||||
{
|
{
|
||||||
this._editing = edit;
|
_editing = edit;
|
||||||
this.Directory.Text = this._editing.Location;
|
Directory.Text = _editing.Location;
|
||||||
this.MaxDepth.Text = this._editing.MaxDepth.ToString();
|
MaxDepth.Text = _editing.MaxDepth.ToString();
|
||||||
this.Suffixes.Text = this._editing.Suffixes;
|
Suffixes.Text = _editing.Suffixes;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void BrowseButton_Click(object sender, RoutedEventArgs e)
|
private void BrowseButton_Click(object sender, RoutedEventArgs e)
|
||||||
{
|
{
|
||||||
var dialog = new System.Windows.Forms.FolderBrowserDialog();
|
var dialog = new FolderBrowserDialog();
|
||||||
System.Windows.Forms.DialogResult result = dialog.ShowDialog();
|
DialogResult result = dialog.ShowDialog();
|
||||||
if (result == System.Windows.Forms.DialogResult.OK)
|
if (result == System.Windows.Forms.DialogResult.OK)
|
||||||
{
|
{
|
||||||
this.Directory.Text = dialog.SelectedPath;
|
Directory.Text = dialog.SelectedPath;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void ButtonAdd_OnClick(object sender, RoutedEventArgs e)
|
private void ButtonAdd_OnClick(object sender, RoutedEventArgs e)
|
||||||
{
|
{
|
||||||
int max;
|
int max;
|
||||||
if(!int.TryParse(this.MaxDepth.Text, out max))
|
if(!int.TryParse(MaxDepth.Text, out max))
|
||||||
{
|
{
|
||||||
max = -1;
|
max = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(this._editing == null)
|
if(_editing == null)
|
||||||
{
|
{
|
||||||
ProgramStorage.Instance.ProgramSources.Add(new ProgramSource()
|
ProgramStorage.Instance.ProgramSources.Add(new ProgramSource
|
||||||
{
|
{
|
||||||
Location = this.Directory.Text,
|
Location = Directory.Text,
|
||||||
MaxDepth = max,
|
MaxDepth = max,
|
||||||
Suffixes = this.Suffixes.Text,
|
Suffixes = Suffixes.Text,
|
||||||
Type = "FileSystemProgramSource",
|
Type = "FileSystemProgramSource",
|
||||||
Enabled = true
|
Enabled = true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
this._editing.Location = this.Directory.Text;
|
_editing.Location = Directory.Text;
|
||||||
this._editing.MaxDepth = max;
|
_editing.MaxDepth = max;
|
||||||
this._editing.Suffixes = this.Suffixes.Text;
|
_editing.Suffixes = Suffixes.Text;
|
||||||
}
|
}
|
||||||
|
|
||||||
ProgramStorage.Instance.Save();
|
ProgramStorage.Instance.Save();
|
||||||
this.DialogResult = true;
|
DialogResult = true;
|
||||||
this.Close();
|
Close();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -7,7 +7,7 @@ namespace Wox.Plugin.Program
|
|||||||
{
|
{
|
||||||
internal class FileChangeWatcher
|
internal class FileChangeWatcher
|
||||||
{
|
{
|
||||||
private static bool isIndexing = false;
|
private static bool isIndexing;
|
||||||
private static List<string> watchedPath = new List<string>();
|
private static List<string> watchedPath = new List<string>();
|
||||||
|
|
||||||
public static void AddWatch(string path, bool includingSubDirectory = true)
|
public static void AddWatch(string path, bool includingSubDirectory = true)
|
||||||
|
@ -23,7 +23,7 @@ namespace Wox.Plugin.Program
|
|||||||
|
|
||||||
protected Program CreateEntry(string file)
|
protected Program CreateEntry(string file)
|
||||||
{
|
{
|
||||||
var p = new Program()
|
var p = new Program
|
||||||
{
|
{
|
||||||
Title = Path.GetFileNameWithoutExtension(file),
|
Title = Path.GetFileNameWithoutExtension(file),
|
||||||
IcoPath = file,
|
IcoPath = file,
|
||||||
|
@ -1,4 +1,6 @@
|
|||||||
using System;
|
using System;
|
||||||
|
using System.Text.RegularExpressions;
|
||||||
|
using System.Threading;
|
||||||
using Wox.Infrastructure;
|
using Wox.Infrastructure;
|
||||||
|
|
||||||
namespace Wox.Plugin.Program
|
namespace Wox.Plugin.Program
|
||||||
@ -6,7 +8,7 @@ namespace Wox.Plugin.Program
|
|||||||
[Serializable]
|
[Serializable]
|
||||||
public class Program
|
public class Program
|
||||||
{
|
{
|
||||||
private static readonly global::System.Text.RegularExpressions.Regex AbbrRegexp = new global::System.Text.RegularExpressions.Regex("[^A-Z0-9]", global::System.Text.RegularExpressions.RegexOptions.Compiled);
|
private static readonly Regex AbbrRegexp = new Regex("[^A-Z0-9]", RegexOptions.Compiled);
|
||||||
private string m_Title;
|
private string m_Title;
|
||||||
public string Title
|
public string Title
|
||||||
{
|
{
|
||||||
@ -19,7 +21,7 @@ namespace Wox.Plugin.Program
|
|||||||
m_Title = value;
|
m_Title = value;
|
||||||
string pinyin = m_Title.Unidecode();
|
string pinyin = m_Title.Unidecode();
|
||||||
PinyinTitle = pinyin;
|
PinyinTitle = pinyin;
|
||||||
AbbrTitle = AbbrRegexp.Replace(global::System.Threading.Thread.CurrentThread.CurrentCulture.TextInfo.ToTitleCase(pinyin), "");
|
AbbrTitle = AbbrRegexp.Replace(Thread.CurrentThread.CurrentCulture.TextInfo.ToTitleCase(pinyin), "");
|
||||||
if (AbbrTitle.Length < 2) AbbrTitle = null;
|
if (AbbrTitle.Length < 2) AbbrTitle = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
using System;
|
using System.IO;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Windows;
|
using System.Windows;
|
||||||
using System.Windows.Controls;
|
using System.Windows.Controls;
|
||||||
@ -31,9 +31,9 @@ namespace Wox.Plugin.Program
|
|||||||
programSourceView.Items.Refresh();
|
programSourceView.Items.Refresh();
|
||||||
ThreadPool.QueueUserWorkItem(t =>
|
ThreadPool.QueueUserWorkItem(t =>
|
||||||
{
|
{
|
||||||
Dispatcher.Invoke(new Action(() => { indexingPanel.Visibility = Visibility.Visible; }));
|
Dispatcher.Invoke(() => { indexingPanel.Visibility = Visibility.Visible; });
|
||||||
Programs.IndexPrograms();
|
Programs.IndexPrograms();
|
||||||
Dispatcher.Invoke(new Action(() => { indexingPanel.Visibility = Visibility.Hidden; }));
|
Dispatcher.Invoke(() => { indexingPanel.Visibility = Visibility.Hidden; });
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -42,7 +42,7 @@ namespace Wox.Plugin.Program
|
|||||||
var add = new AddProgramSource();
|
var add = new AddProgramSource();
|
||||||
if(add.ShowDialog() ?? false)
|
if(add.ShowDialog() ?? false)
|
||||||
{
|
{
|
||||||
this.ReIndexing();
|
ReIndexing();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -75,7 +75,7 @@ namespace Wox.Plugin.Program
|
|||||||
var add = new AddProgramSource(selectedProgramSource);
|
var add = new AddProgramSource(selectedProgramSource);
|
||||||
if (add.ShowDialog() ?? false)
|
if (add.ShowDialog() ?? false)
|
||||||
{
|
{
|
||||||
this.ReIndexing();
|
ReIndexing();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -116,9 +116,9 @@ namespace Wox.Plugin.Program
|
|||||||
{
|
{
|
||||||
foreach (string s in files)
|
foreach (string s in files)
|
||||||
{
|
{
|
||||||
if (System.IO.Directory.Exists(s) == true)
|
if (Directory.Exists(s))
|
||||||
{
|
{
|
||||||
ProgramStorage.Instance.ProgramSources.Add(new ProgramSource()
|
ProgramStorage.Instance.ProgramSources.Add(new ProgramSource
|
||||||
{
|
{
|
||||||
Location = s,
|
Location = s,
|
||||||
Type = "FileSystemProgramSource",
|
Type = "FileSystemProgramSource",
|
||||||
|
@ -16,7 +16,7 @@ namespace Wox.Plugin.Program
|
|||||||
|
|
||||||
public override string ToString()
|
public override string ToString()
|
||||||
{
|
{
|
||||||
return (this.Type ?? "") + ":" + this.Location ?? "";
|
return (Type ?? "") + ":" + Location ?? "";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,11 +1,14 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.ComponentModel;
|
||||||
|
using System.IO;
|
||||||
|
using Microsoft.Win32;
|
||||||
using Wox.Infrastructure.Logger;
|
using Wox.Infrastructure.Logger;
|
||||||
|
|
||||||
namespace Wox.Plugin.Program.ProgramSources
|
namespace Wox.Plugin.Program.ProgramSources
|
||||||
{
|
{
|
||||||
[Serializable]
|
[Serializable]
|
||||||
[System.ComponentModel.Browsable(false)]
|
[Browsable(false)]
|
||||||
public class AppPathsProgramSource : AbstractProgramSource
|
public class AppPathsProgramSource : AbstractProgramSource
|
||||||
{
|
{
|
||||||
public AppPathsProgramSource()
|
public AppPathsProgramSource()
|
||||||
@ -28,7 +31,7 @@ namespace Wox.Plugin.Program.ProgramSources
|
|||||||
|
|
||||||
private void ReadAppPaths(string rootpath, List<Program> list)
|
private void ReadAppPaths(string rootpath, List<Program> list)
|
||||||
{
|
{
|
||||||
using (var root = Microsoft.Win32.Registry.LocalMachine.OpenSubKey(rootpath))
|
using (var root = Registry.LocalMachine.OpenSubKey(rootpath))
|
||||||
{
|
{
|
||||||
if (root == null) return;
|
if (root == null) return;
|
||||||
foreach (var item in root.GetSubKeyNames())
|
foreach (var item in root.GetSubKeyNames())
|
||||||
@ -49,7 +52,7 @@ namespace Wox.Plugin.Program.ProgramSources
|
|||||||
path = path.Substring(begin + 1, path.Length - 2);
|
path = path.Substring(begin + 1, path.Length - 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!System.IO.File.Exists(path)) continue;
|
if (!File.Exists(path)) continue;
|
||||||
var entry = CreateEntry(path);
|
var entry = CreateEntry(path);
|
||||||
entry.ExecuteName = item;
|
entry.ExecuteName = item;
|
||||||
list.Add(entry);
|
list.Add(entry);
|
||||||
|
@ -1,11 +1,12 @@
|
|||||||
using System;
|
using System;
|
||||||
|
using System.ComponentModel;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
|
|
||||||
namespace Wox.Plugin.Program.ProgramSources
|
namespace Wox.Plugin.Program.ProgramSources
|
||||||
{
|
{
|
||||||
[Serializable]
|
[Serializable]
|
||||||
[global::System.ComponentModel.Browsable(false)]
|
[Browsable(false)]
|
||||||
public class CommonStartMenuProgramSource : FileSystemProgramSource
|
public class CommonStartMenuProgramSource : FileSystemProgramSource
|
||||||
{
|
{
|
||||||
[DllImport("shell32.dll")]
|
[DllImport("shell32.dll")]
|
||||||
@ -28,7 +29,7 @@ namespace Wox.Plugin.Program.ProgramSources
|
|||||||
public CommonStartMenuProgramSource(ProgramSource source)
|
public CommonStartMenuProgramSource(ProgramSource source)
|
||||||
: this()
|
: this()
|
||||||
{
|
{
|
||||||
this.BonusPoints = source.BonusPoints;
|
BonusPoints = source.BonusPoints;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override string ToString()
|
public override string ToString()
|
||||||
|
@ -27,7 +27,7 @@ namespace Wox.Plugin.Program.ProgramSources
|
|||||||
public FileSystemProgramSource(ProgramSource source)
|
public FileSystemProgramSource(ProgramSource source)
|
||||||
: this(source.Location, source.MaxDepth, source.Suffixes)
|
: this(source.Location, source.MaxDepth, source.Suffixes)
|
||||||
{
|
{
|
||||||
this.BonusPoints = source.BonusPoints;
|
BonusPoints = source.BonusPoints;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override List<Program> LoadPrograms()
|
public override List<Program> LoadPrograms()
|
||||||
@ -78,7 +78,7 @@ namespace Wox.Plugin.Program.ProgramSources
|
|||||||
|
|
||||||
public override string ToString()
|
public override string ToString()
|
||||||
{
|
{
|
||||||
return typeof(FileSystemProgramSource).Name + ":" + this.baseDirectory;
|
return typeof(FileSystemProgramSource).Name + ":" + baseDirectory;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,9 +1,10 @@
|
|||||||
using System;
|
using System;
|
||||||
|
using System.ComponentModel;
|
||||||
|
|
||||||
namespace Wox.Plugin.Program.ProgramSources
|
namespace Wox.Plugin.Program.ProgramSources
|
||||||
{
|
{
|
||||||
[Serializable]
|
[Serializable]
|
||||||
[global::System.ComponentModel.Browsable(false)]
|
[Browsable(false)]
|
||||||
public class UserStartMenuProgramSource : FileSystemProgramSource
|
public class UserStartMenuProgramSource : FileSystemProgramSource
|
||||||
{
|
{
|
||||||
public UserStartMenuProgramSource()
|
public UserStartMenuProgramSource()
|
||||||
@ -14,7 +15,7 @@ namespace Wox.Plugin.Program.ProgramSources
|
|||||||
public UserStartMenuProgramSource(ProgramSource source)
|
public UserStartMenuProgramSource(ProgramSource source)
|
||||||
: this()
|
: this()
|
||||||
{
|
{
|
||||||
this.BonusPoints = source.BonusPoints;
|
BonusPoints = source.BonusPoints;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override string ToString()
|
public override string ToString()
|
||||||
|
@ -5,6 +5,7 @@ using System.IO;
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
using System.Windows;
|
using System.Windows;
|
||||||
|
using System.Windows.Controls;
|
||||||
using Wox.Infrastructure;
|
using Wox.Infrastructure;
|
||||||
using Wox.Infrastructure.Logger;
|
using Wox.Infrastructure.Logger;
|
||||||
using Wox.Plugin.Program.ProgramSources;
|
using Wox.Plugin.Program.ProgramSources;
|
||||||
@ -17,11 +18,12 @@ namespace Wox.Plugin.Program
|
|||||||
private static object lockObject = new object();
|
private static object lockObject = new object();
|
||||||
private static List<Program> programs = new List<Program>();
|
private static List<Program> programs = new List<Program>();
|
||||||
private static List<IProgramSource> sources = new List<IProgramSource>();
|
private static List<IProgramSource> sources = new List<IProgramSource>();
|
||||||
private static Dictionary<string, Type> SourceTypes = new Dictionary<string, Type>() {
|
private static Dictionary<string, Type> SourceTypes = new Dictionary<string, Type>
|
||||||
|
{
|
||||||
{"FileSystemProgramSource", typeof(FileSystemProgramSource)},
|
{"FileSystemProgramSource", typeof(FileSystemProgramSource)},
|
||||||
{"CommonStartMenuProgramSource", typeof(CommonStartMenuProgramSource)},
|
{"CommonStartMenuProgramSource", typeof(CommonStartMenuProgramSource)},
|
||||||
{"UserStartMenuProgramSource", typeof(UserStartMenuProgramSource)},
|
{"UserStartMenuProgramSource", typeof(UserStartMenuProgramSource)},
|
||||||
{"AppPathsProgramSource", typeof(AppPathsProgramSource)},
|
{"AppPathsProgramSource", typeof(AppPathsProgramSource)}
|
||||||
};
|
};
|
||||||
private PluginInitContext context;
|
private PluginInitContext context;
|
||||||
|
|
||||||
@ -32,14 +34,14 @@ namespace Wox.Plugin.Program
|
|||||||
var results = programs.Where(p => MatchProgram(p, fuzzyMather)).
|
var results = programs.Where(p => MatchProgram(p, fuzzyMather)).
|
||||||
Select(ScoreFilter).
|
Select(ScoreFilter).
|
||||||
OrderByDescending(p => p.Score)
|
OrderByDescending(p => p.Score)
|
||||||
.Select(c => new Result()
|
.Select(c => new Result
|
||||||
{
|
{
|
||||||
Title = c.Title,
|
Title = c.Title,
|
||||||
SubTitle = c.ExecutePath,
|
SubTitle = c.ExecutePath,
|
||||||
IcoPath = c.IcoPath,
|
IcoPath = c.IcoPath,
|
||||||
Score = c.Score,
|
Score = c.Score,
|
||||||
ContextData = c,
|
ContextData = c,
|
||||||
Action = (e) =>
|
Action = e =>
|
||||||
{
|
{
|
||||||
context.API.HideApp();
|
context.API.HideApp();
|
||||||
Process.Start(c.ExecutePath);
|
Process.Start(c.ExecutePath);
|
||||||
@ -128,19 +130,19 @@ namespace Wox.Plugin.Program
|
|||||||
private static List<ProgramSource> LoadDeaultProgramSources()
|
private static List<ProgramSource> LoadDeaultProgramSources()
|
||||||
{
|
{
|
||||||
var list = new List<ProgramSource>();
|
var list = new List<ProgramSource>();
|
||||||
list.Add(new ProgramSource()
|
list.Add(new ProgramSource
|
||||||
{
|
{
|
||||||
BonusPoints = 0,
|
BonusPoints = 0,
|
||||||
Enabled = ProgramStorage.Instance.EnableStartMenuSource,
|
Enabled = ProgramStorage.Instance.EnableStartMenuSource,
|
||||||
Type = "CommonStartMenuProgramSource"
|
Type = "CommonStartMenuProgramSource"
|
||||||
});
|
});
|
||||||
list.Add(new ProgramSource()
|
list.Add(new ProgramSource
|
||||||
{
|
{
|
||||||
BonusPoints = 0,
|
BonusPoints = 0,
|
||||||
Enabled = ProgramStorage.Instance.EnableStartMenuSource,
|
Enabled = ProgramStorage.Instance.EnableStartMenuSource,
|
||||||
Type = "UserStartMenuProgramSource"
|
Type = "UserStartMenuProgramSource"
|
||||||
});
|
});
|
||||||
list.Add(new ProgramSource()
|
list.Add(new ProgramSource
|
||||||
{
|
{
|
||||||
BonusPoints = -10,
|
BonusPoints = -10,
|
||||||
Enabled = ProgramStorage.Instance.EnableRegistrySource,
|
Enabled = ProgramStorage.Instance.EnableRegistrySource,
|
||||||
@ -166,7 +168,7 @@ namespace Wox.Plugin.Program
|
|||||||
|
|
||||||
#region ISettingProvider Members
|
#region ISettingProvider Members
|
||||||
|
|
||||||
public System.Windows.Controls.Control CreateSettingPanel()
|
public Control CreateSettingPanel()
|
||||||
{
|
{
|
||||||
return new ProgramSetting(context);
|
return new ProgramSetting(context);
|
||||||
}
|
}
|
||||||
@ -190,9 +192,9 @@ namespace Wox.Plugin.Program
|
|||||||
public List<Result> LoadContextMenus(Result selectedResult)
|
public List<Result> LoadContextMenus(Result selectedResult)
|
||||||
{
|
{
|
||||||
Program p = selectedResult.ContextData as Program;
|
Program p = selectedResult.ContextData as Program;
|
||||||
List<Result> contextMenus = new List<Result>()
|
List<Result> contextMenus = new List<Result>
|
||||||
{
|
{
|
||||||
new Result()
|
new Result
|
||||||
{
|
{
|
||||||
Title = context.API.GetTranslation("wox_plugin_program_run_as_administrator"),
|
Title = context.API.GetTranslation("wox_plugin_program_run_as_administrator"),
|
||||||
Action = _ =>
|
Action = _ =>
|
||||||
@ -207,7 +209,7 @@ namespace Wox.Plugin.Program
|
|||||||
},
|
},
|
||||||
IcoPath = "Images/cmd.png"
|
IcoPath = "Images/cmd.png"
|
||||||
},
|
},
|
||||||
new Result()
|
new Result
|
||||||
{
|
{
|
||||||
Title = context.API.GetTranslation("wox_plugin_program_open_containing_folder"),
|
Title = context.API.GetTranslation("wox_plugin_program_open_containing_folder"),
|
||||||
Action = _ =>
|
Action = _ =>
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
using System;
|
using System;
|
||||||
|
using System.Globalization;
|
||||||
using System.Windows.Data;
|
using System.Windows.Data;
|
||||||
using System.Windows.Markup;
|
using System.Windows.Markup;
|
||||||
|
|
||||||
@ -6,13 +7,13 @@ namespace Wox.Plugin.Program
|
|||||||
{
|
{
|
||||||
public class StringEmptyConverter : MarkupExtension, IValueConverter
|
public class StringEmptyConverter : MarkupExtension, IValueConverter
|
||||||
{
|
{
|
||||||
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
|
public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
|
||||||
{
|
{
|
||||||
return string.IsNullOrEmpty((string)value) ? parameter : value;
|
return string.IsNullOrEmpty((string)value) ? parameter : value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public object ConvertBack(
|
public object ConvertBack(
|
||||||
object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
|
object value, Type targetType, object parameter, CultureInfo culture)
|
||||||
{
|
{
|
||||||
throw new NotSupportedException();
|
throw new NotSupportedException();
|
||||||
}
|
}
|
||||||
|
@ -76,14 +76,14 @@ namespace Wox.Plugin.Sys
|
|||||||
|
|
||||||
private void LoadCommands()
|
private void LoadCommands()
|
||||||
{
|
{
|
||||||
availableResults.AddRange(new Result[]
|
availableResults.AddRange(new[]
|
||||||
{
|
{
|
||||||
new Result
|
new Result
|
||||||
{
|
{
|
||||||
Title = "Shutdown",
|
Title = "Shutdown",
|
||||||
SubTitle = context.API.GetTranslation("wox_plugin_sys_shutdown_computer"),
|
SubTitle = context.API.GetTranslation("wox_plugin_sys_shutdown_computer"),
|
||||||
IcoPath = "Images\\exit.png",
|
IcoPath = "Images\\exit.png",
|
||||||
Action = (c) =>
|
Action = c =>
|
||||||
{
|
{
|
||||||
var reuslt = MessageBox.Show("Are you sure you want to shut the computer down?",
|
var reuslt = MessageBox.Show("Are you sure you want to shut the computer down?",
|
||||||
"Shutdown Computer?", MessageBoxButton.YesNo, MessageBoxImage.Warning);
|
"Shutdown Computer?", MessageBoxButton.YesNo, MessageBoxImage.Warning);
|
||||||
@ -99,7 +99,7 @@ namespace Wox.Plugin.Sys
|
|||||||
Title = "Restart",
|
Title = "Restart",
|
||||||
SubTitle = context.API.GetTranslation("wox_plugin_sys_restart_computer"),
|
SubTitle = context.API.GetTranslation("wox_plugin_sys_restart_computer"),
|
||||||
IcoPath = "Images\\restartcomp.png",
|
IcoPath = "Images\\restartcomp.png",
|
||||||
Action = (c) =>
|
Action = c =>
|
||||||
{
|
{
|
||||||
var result = MessageBox.Show("Are you sure you want to restart the computer?",
|
var result = MessageBox.Show("Are you sure you want to restart the computer?",
|
||||||
"Restart Computer?", MessageBoxButton.YesNo, MessageBoxImage.Warning);
|
"Restart Computer?", MessageBoxButton.YesNo, MessageBoxImage.Warning);
|
||||||
@ -115,14 +115,14 @@ namespace Wox.Plugin.Sys
|
|||||||
Title = "Log off",
|
Title = "Log off",
|
||||||
SubTitle = context.API.GetTranslation("wox_plugin_sys_log_off"),
|
SubTitle = context.API.GetTranslation("wox_plugin_sys_log_off"),
|
||||||
IcoPath = "Images\\logoff.png",
|
IcoPath = "Images\\logoff.png",
|
||||||
Action = (c) => ExitWindowsEx(EWX_LOGOFF, 0)
|
Action = c => ExitWindowsEx(EWX_LOGOFF, 0)
|
||||||
},
|
},
|
||||||
new Result
|
new Result
|
||||||
{
|
{
|
||||||
Title = "Lock",
|
Title = "Lock",
|
||||||
SubTitle = context.API.GetTranslation("wox_plugin_sys_lock"),
|
SubTitle = context.API.GetTranslation("wox_plugin_sys_lock"),
|
||||||
IcoPath = "Images\\lock.png",
|
IcoPath = "Images\\lock.png",
|
||||||
Action = (c) =>
|
Action = c =>
|
||||||
{
|
{
|
||||||
LockWorkStation();
|
LockWorkStation();
|
||||||
return true;
|
return true;
|
||||||
@ -133,14 +133,14 @@ namespace Wox.Plugin.Sys
|
|||||||
Title = "Sleep",
|
Title = "Sleep",
|
||||||
SubTitle = context.API.GetTranslation("wox_plugin_sys_sleep"),
|
SubTitle = context.API.GetTranslation("wox_plugin_sys_sleep"),
|
||||||
IcoPath = "Images\\sleep.png",
|
IcoPath = "Images\\sleep.png",
|
||||||
Action = (c) => FormsApplication.SetSuspendState(PowerState.Suspend, false, false)
|
Action = c => FormsApplication.SetSuspendState(PowerState.Suspend, false, false)
|
||||||
},
|
},
|
||||||
new Result
|
new Result
|
||||||
{
|
{
|
||||||
Title = "Empty Recycle Bin",
|
Title = "Empty Recycle Bin",
|
||||||
SubTitle = context.API.GetTranslation("wox_plugin_sys_emptyrecyclebin"),
|
SubTitle = context.API.GetTranslation("wox_plugin_sys_emptyrecyclebin"),
|
||||||
IcoPath = "Images\\recyclebin.png",
|
IcoPath = "Images\\recyclebin.png",
|
||||||
Action = (c) =>
|
Action = c =>
|
||||||
{
|
{
|
||||||
// http://www.pinvoke.net/default.aspx/shell32/SHEmptyRecycleBin.html
|
// http://www.pinvoke.net/default.aspx/shell32/SHEmptyRecycleBin.html
|
||||||
// 0 for nothing
|
// 0 for nothing
|
||||||
@ -160,7 +160,7 @@ namespace Wox.Plugin.Sys
|
|||||||
Title = "Exit",
|
Title = "Exit",
|
||||||
SubTitle = context.API.GetTranslation("wox_plugin_sys_exit"),
|
SubTitle = context.API.GetTranslation("wox_plugin_sys_exit"),
|
||||||
IcoPath = "Images\\app.png",
|
IcoPath = "Images\\app.png",
|
||||||
Action = (c) =>
|
Action = c =>
|
||||||
{
|
{
|
||||||
context.API.CloseApp();
|
context.API.CloseApp();
|
||||||
return true;
|
return true;
|
||||||
@ -171,7 +171,7 @@ namespace Wox.Plugin.Sys
|
|||||||
Title = "Restart Wox",
|
Title = "Restart Wox",
|
||||||
SubTitle = context.API.GetTranslation("wox_plugin_sys_restart"),
|
SubTitle = context.API.GetTranslation("wox_plugin_sys_restart"),
|
||||||
IcoPath = "Images\\restart.png",
|
IcoPath = "Images\\restart.png",
|
||||||
Action = (c) =>
|
Action = c =>
|
||||||
{
|
{
|
||||||
context.API.RestarApp();
|
context.API.RestarApp();
|
||||||
return false;
|
return false;
|
||||||
@ -182,7 +182,7 @@ namespace Wox.Plugin.Sys
|
|||||||
Title = "Settings",
|
Title = "Settings",
|
||||||
SubTitle = context.API.GetTranslation("wox_plugin_sys_setting"),
|
SubTitle = context.API.GetTranslation("wox_plugin_sys_setting"),
|
||||||
IcoPath = "Images\\app.png",
|
IcoPath = "Images\\app.png",
|
||||||
Action = (c) =>
|
Action = c =>
|
||||||
{
|
{
|
||||||
context.API.OpenSettingDialog();
|
context.API.OpenSettingDialog();
|
||||||
return true;
|
return true;
|
||||||
|
@ -11,7 +11,7 @@ namespace Wox.Plugin.Sys
|
|||||||
|
|
||||||
foreach (var Result in Results)
|
foreach (var Result in Results)
|
||||||
{
|
{
|
||||||
this.lbxCommands.Items.Add(Result);
|
lbxCommands.Items.Add(Result);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -110,7 +110,7 @@ namespace Wox.Plugin.WebSearch
|
|||||||
MessageBox.Show(exception.Message);
|
MessageBox.Show(exception.Message);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
WebSearchStorage.Instance.WebSearches.Add(new WebSearch()
|
WebSearchStorage.Instance.WebSearches.Add(new WebSearch
|
||||||
{
|
{
|
||||||
ActionKeyword = newActionKeyword,
|
ActionKeyword = newActionKeyword,
|
||||||
Enabled = cbEnable.IsChecked ?? false,
|
Enabled = cbEnable.IsChecked ?? false,
|
||||||
|
@ -29,10 +29,10 @@ namespace Wox.Plugin.WebSearch
|
|||||||
? Visibility.Visible
|
? Visibility.Visible
|
||||||
: Visibility.Collapsed;
|
: Visibility.Collapsed;
|
||||||
|
|
||||||
List<ComboBoxItem> items = new List<ComboBoxItem>()
|
List<ComboBoxItem> items = new List<ComboBoxItem>
|
||||||
{
|
{
|
||||||
new ComboBoxItem() {Content = "Google"},
|
new ComboBoxItem {Content = "Google"},
|
||||||
new ComboBoxItem() {Content = "Baidu"},
|
new ComboBoxItem {Content = "Baidu"}
|
||||||
};
|
};
|
||||||
ComboBoxItem selected = items.FirstOrDefault(o => o.Content.ToString() == WebSearchStorage.Instance.WebSearchSuggestionSource);
|
ComboBoxItem selected = items.FirstOrDefault(o => o.Content.ToString() == WebSearchStorage.Instance.WebSearchSuggestionSource);
|
||||||
if (selected == null)
|
if (selected == null)
|
||||||
|
@ -29,7 +29,7 @@ namespace Wox.Core.Plugin
|
|||||||
|
|
||||||
foreach (Type type in types)
|
foreach (Type type in types)
|
||||||
{
|
{
|
||||||
PluginPair pair = new PluginPair()
|
PluginPair pair = new PluginPair
|
||||||
{
|
{
|
||||||
Plugin = Activator.CreateInstance(type) as IPlugin,
|
Plugin = Activator.CreateInstance(type) as IPlugin,
|
||||||
Metadata = metadata
|
Metadata = metadata
|
||||||
@ -38,7 +38,7 @@ namespace Wox.Core.Plugin
|
|||||||
plugins.Add(pair);
|
plugins.Add(pair);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (System.Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
Log.Error(new WoxPluginException(metadata.Name, $"Couldn't load plugin", e));
|
Log.Error(new WoxPluginException(metadata.Name, $"Couldn't load plugin", e));
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
using System.Collections.Generic;
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
@ -41,7 +42,7 @@ namespace Wox.Core.Plugin
|
|||||||
foreach (JsonRPCResult result in queryResponseModel.Result)
|
foreach (JsonRPCResult result in queryResponseModel.Result)
|
||||||
{
|
{
|
||||||
JsonRPCResult result1 = result;
|
JsonRPCResult result1 = result;
|
||||||
result.Action = (c) =>
|
result.Action = c =>
|
||||||
{
|
{
|
||||||
if (result1.JsonRPCAction == null) return false;
|
if (result1.JsonRPCAction == null) return false;
|
||||||
|
|
||||||
@ -72,7 +73,7 @@ namespace Wox.Core.Plugin
|
|||||||
}
|
}
|
||||||
return results;
|
return results;
|
||||||
}
|
}
|
||||||
catch (System.Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
Log.Error(e);
|
Log.Error(e);
|
||||||
}
|
}
|
||||||
@ -89,7 +90,7 @@ namespace Wox.Core.Plugin
|
|||||||
{
|
{
|
||||||
methodInfo.Invoke(PluginManager.API, parameters);
|
methodInfo.Invoke(PluginManager.API, parameters);
|
||||||
}
|
}
|
||||||
catch (System.Exception)
|
catch (Exception)
|
||||||
{
|
{
|
||||||
#if (DEBUG)
|
#if (DEBUG)
|
||||||
{
|
{
|
||||||
@ -150,7 +151,7 @@ namespace Wox.Core.Plugin
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch(System.Exception e)
|
catch(Exception e)
|
||||||
{
|
{
|
||||||
throw new WoxJsonRPCException(e.Message);
|
throw new WoxJsonRPCException(e.Message);
|
||||||
}
|
}
|
||||||
|
@ -11,7 +11,7 @@ namespace Wox.Core.Plugin
|
|||||||
T jsonRPCPlugin = new T();
|
T jsonRPCPlugin = new T();
|
||||||
List<PluginMetadata> jsonRPCPluginMetadatas = pluginMetadatas.Where(o => o.Language.ToUpper() == jsonRPCPlugin.SupportedLanguage.ToUpper()).ToList();
|
List<PluginMetadata> jsonRPCPluginMetadatas = pluginMetadatas.Where(o => o.Language.ToUpper() == jsonRPCPlugin.SupportedLanguage.ToUpper()).ToList();
|
||||||
|
|
||||||
return jsonRPCPluginMetadatas.Select(metadata => new PluginPair()
|
return jsonRPCPluginMetadatas.Select(metadata => new PluginPair
|
||||||
{
|
{
|
||||||
Plugin = new T(), //every JsonRPC plugin should has its own plugin instance
|
Plugin = new T(), //every JsonRPC plugin should has its own plugin instance
|
||||||
Metadata = metadata
|
Metadata = metadata
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
using System.Collections.Generic;
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using Newtonsoft.Json;
|
using Newtonsoft.Json;
|
||||||
@ -45,7 +46,7 @@ namespace Wox.Core.Plugin
|
|||||||
Directory.Delete(directory, true);
|
Directory.Delete(directory, true);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
catch (System.Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
Log.Fatal(e);
|
Log.Fatal(e);
|
||||||
}
|
}
|
||||||
@ -77,7 +78,7 @@ namespace Wox.Core.Plugin
|
|||||||
// for plugin still use old ActionKeyword
|
// for plugin still use old ActionKeyword
|
||||||
metadata.ActionKeyword = metadata.ActionKeywords?[0];
|
metadata.ActionKeyword = metadata.ActionKeywords?[0];
|
||||||
}
|
}
|
||||||
catch (System.Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
string msg = $"Parse plugin config {configPath} failed: json format is not valid";
|
string msg = $"Parse plugin config {configPath} failed: json format is not valid";
|
||||||
Log.Error(new WoxException(msg));
|
Log.Error(new WoxException(msg));
|
||||||
|
@ -107,12 +107,12 @@ namespace Wox.Core.Plugin
|
|||||||
metadata = JsonConvert.DeserializeObject<PluginMetadata>(File.ReadAllText(configPath));
|
metadata = JsonConvert.DeserializeObject<PluginMetadata>(File.ReadAllText(configPath));
|
||||||
metadata.PluginDirectory = pluginDirectory;
|
metadata.PluginDirectory = pluginDirectory;
|
||||||
}
|
}
|
||||||
catch (System.Exception)
|
catch (Exception)
|
||||||
{
|
{
|
||||||
string error = $"Parse plugin config {configPath} failed: json format is not valid";
|
string error = $"Parse plugin config {configPath} failed: json format is not valid";
|
||||||
#if (DEBUG)
|
#if (DEBUG)
|
||||||
{
|
{
|
||||||
throw new System.Exception(error);
|
throw new Exception(error);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
return null;
|
return null;
|
||||||
@ -124,7 +124,7 @@ namespace Wox.Core.Plugin
|
|||||||
string error = $"Parse plugin config {configPath} failed: invalid language {metadata.Language}";
|
string error = $"Parse plugin config {configPath} failed: invalid language {metadata.Language}";
|
||||||
#if (DEBUG)
|
#if (DEBUG)
|
||||||
{
|
{
|
||||||
throw new System.Exception(error);
|
throw new Exception(error);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
return null;
|
return null;
|
||||||
@ -134,7 +134,7 @@ namespace Wox.Core.Plugin
|
|||||||
string error = $"Parse plugin config {configPath} failed: ExecuteFile {metadata.ExecuteFilePath} didn't exist";
|
string error = $"Parse plugin config {configPath} failed: ExecuteFile {metadata.ExecuteFilePath} didn't exist";
|
||||||
#if (DEBUG)
|
#if (DEBUG)
|
||||||
{
|
{
|
||||||
throw new System.Exception(error);
|
throw new Exception(error);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
return null;
|
return null;
|
||||||
|
@ -41,8 +41,8 @@ namespace Wox.Core.Plugin
|
|||||||
|
|
||||||
protected override string ExecuteQuery(Query query)
|
protected override string ExecuteQuery(Query query)
|
||||||
{
|
{
|
||||||
JsonRPCServerRequestModel request = new JsonRPCServerRequestModel()
|
JsonRPCServerRequestModel request = new JsonRPCServerRequestModel
|
||||||
{
|
{
|
||||||
Method = "query",
|
Method = "query",
|
||||||
Parameters = new object[] { query.GetAllRemainingParameter() },
|
Parameters = new object[] { query.GetAllRemainingParameter() },
|
||||||
HttpProxy = HttpProxy.Instance
|
HttpProxy = HttpProxy.Instance
|
||||||
|
@ -35,7 +35,7 @@ namespace Wox.Core.Theme
|
|||||||
{
|
{
|
||||||
Directory.CreateDirectory(pluginDirectory);
|
Directory.CreateDirectory(pluginDirectory);
|
||||||
}
|
}
|
||||||
catch (System.Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
Log.Error(e);
|
Log.Error(e);
|
||||||
}
|
}
|
||||||
@ -51,7 +51,7 @@ namespace Wox.Core.Theme
|
|||||||
themePath = GetThemePath("Dark");
|
themePath = GetThemePath("Dark");
|
||||||
if (string.IsNullOrEmpty(themePath))
|
if (string.IsNullOrEmpty(themePath))
|
||||||
{
|
{
|
||||||
throw new System.Exception("Change theme failed");
|
throw new Exception("Change theme failed");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -94,8 +94,8 @@ namespace Wox.Core.Theme
|
|||||||
Setter fontWeight = new Setter(TextBlock.FontWeightProperty, FontHelper.GetFontWeightFromInvariantStringOrNormal(UserSettingStorage.Instance.ResultItemFontWeight));
|
Setter fontWeight = new Setter(TextBlock.FontWeightProperty, FontHelper.GetFontWeightFromInvariantStringOrNormal(UserSettingStorage.Instance.ResultItemFontWeight));
|
||||||
Setter fontStretch = new Setter(TextBlock.FontStretchProperty, FontHelper.GetFontStretchFromInvariantStringOrNormal(UserSettingStorage.Instance.ResultItemFontStretch));
|
Setter fontStretch = new Setter(TextBlock.FontStretchProperty, FontHelper.GetFontStretchFromInvariantStringOrNormal(UserSettingStorage.Instance.ResultItemFontStretch));
|
||||||
|
|
||||||
Setter[] setters = new Setter[] { fontFamily, fontStyle, fontWeight, fontStretch };
|
Setter[] setters = { fontFamily, fontStyle, fontWeight, fontStretch };
|
||||||
Array.ForEach(new Style[] { resultItemStyle, resultSubItemStyle, resultItemSelectedStyle, resultSubItemSelectedStyle }, o => Array.ForEach(setters, p => o.Setters.Add(p)));
|
Array.ForEach(new[] { resultItemStyle, resultSubItemStyle, resultItemSelectedStyle, resultSubItemSelectedStyle }, o => Array.ForEach(setters, p => o.Setters.Add(p)));
|
||||||
}
|
}
|
||||||
return dict;
|
return dict;
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,7 @@ namespace Wox.Core.Updater
|
|||||||
public int MINOR { get; set; }
|
public int MINOR { get; set; }
|
||||||
public int PATCH { get; set; }
|
public int PATCH { get; set; }
|
||||||
|
|
||||||
public SemanticVersion(System.Version version)
|
public SemanticVersion(Version version)
|
||||||
{
|
{
|
||||||
MAJOR = version.Major;
|
MAJOR = version.Major;
|
||||||
MINOR = version.Minor;
|
MINOR = version.Minor;
|
||||||
|
@ -92,7 +92,7 @@ namespace Wox.Core.Updater
|
|||||||
StartUpdate();
|
StartUpdate();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (System.Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
Log.Error(e);
|
Log.Error(e);
|
||||||
}
|
}
|
||||||
@ -112,7 +112,7 @@ namespace Wox.Core.Updater
|
|||||||
{
|
{
|
||||||
((UpdateProcessAsyncResult)asyncResult).EndInvoke();
|
((UpdateProcessAsyncResult)asyncResult).EndInvoke();
|
||||||
}
|
}
|
||||||
catch (System.Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
Log.Error(e);
|
Log.Error(e);
|
||||||
updManager.CleanUp();
|
updManager.CleanUp();
|
||||||
@ -148,7 +148,7 @@ namespace Wox.Core.Updater
|
|||||||
{
|
{
|
||||||
UpdateManager.Instance.ApplyUpdates(true, UserSettingStorage.Instance.EnableUpdateLog, false);
|
UpdateManager.Instance.ApplyUpdates(true, UserSettingStorage.Instance.EnableUpdateLog, false);
|
||||||
}
|
}
|
||||||
catch (System.Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
string updateError = InternationalizationManager.Instance.GetTranslation("update_wox_update_error");
|
string updateError = InternationalizationManager.Instance.GetTranslation("update_wox_update_error");
|
||||||
Log.Error(e);
|
Log.Error(e);
|
||||||
|
@ -15,30 +15,30 @@ namespace Wox.Core.Updater
|
|||||||
|
|
||||||
public WoxUpdateSource(string feedUrl,IWebProxy proxy)
|
public WoxUpdateSource(string feedUrl,IWebProxy proxy)
|
||||||
{
|
{
|
||||||
this.FeedUrl = feedUrl;
|
FeedUrl = feedUrl;
|
||||||
this.Proxy = proxy;
|
Proxy = proxy;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void TryResolvingHost()
|
private void TryResolvingHost()
|
||||||
{
|
{
|
||||||
Uri uri = new Uri(this.FeedUrl);
|
Uri uri = new Uri(FeedUrl);
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
Dns.GetHostEntry(uri.Host);
|
Dns.GetHostEntry(uri.Host);
|
||||||
}
|
}
|
||||||
catch (System.Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
throw new WebException(string.Format("Failed to resolve {0}. Check your connectivity.", (object)uri.Host), WebExceptionStatus.ConnectFailure);
|
throw new WebException(string.Format("Failed to resolve {0}. Check your connectivity.", uri.Host), WebExceptionStatus.ConnectFailure);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public string GetUpdatesFeed()
|
public string GetUpdatesFeed()
|
||||||
{
|
{
|
||||||
this.TryResolvingHost();
|
TryResolvingHost();
|
||||||
string str = string.Empty;
|
string str = string.Empty;
|
||||||
WebRequest webRequest = WebRequest.Create(this.FeedUrl);
|
WebRequest webRequest = WebRequest.Create(FeedUrl);
|
||||||
webRequest.Method = "GET";
|
webRequest.Method = "GET";
|
||||||
webRequest.Proxy = this.Proxy;
|
webRequest.Proxy = Proxy;
|
||||||
using (WebResponse response = webRequest.GetResponse())
|
using (WebResponse response = webRequest.GetResponse())
|
||||||
{
|
{
|
||||||
Stream responseStream = response.GetResponseStream();
|
Stream responseStream = response.GetResponseStream();
|
||||||
@ -56,7 +56,7 @@ namespace Wox.Core.Updater
|
|||||||
if (!string.IsNullOrEmpty(baseUrl) && !baseUrl.EndsWith("/"))
|
if (!string.IsNullOrEmpty(baseUrl) && !baseUrl.EndsWith("/"))
|
||||||
baseUrl += "/";
|
baseUrl += "/";
|
||||||
FileDownloader fileDownloader = !Uri.IsWellFormedUriString(url, UriKind.Absolute) ? (!Uri.IsWellFormedUriString(baseUrl, UriKind.Absolute) ? (string.IsNullOrEmpty(baseUrl) ? new FileDownloader(url) : new FileDownloader(new Uri(new Uri(baseUrl), url))) : new FileDownloader(new Uri(new Uri(baseUrl, UriKind.Absolute), url))) : new FileDownloader(url);
|
FileDownloader fileDownloader = !Uri.IsWellFormedUriString(url, UriKind.Absolute) ? (!Uri.IsWellFormedUriString(baseUrl, UriKind.Absolute) ? (string.IsNullOrEmpty(baseUrl) ? new FileDownloader(url) : new FileDownloader(new Uri(new Uri(baseUrl), url))) : new FileDownloader(new Uri(new Uri(baseUrl, UriKind.Absolute), url))) : new FileDownloader(url);
|
||||||
fileDownloader.Proxy = this.Proxy;
|
fileDownloader.Proxy = Proxy;
|
||||||
if (string.IsNullOrEmpty(tempLocation) || !Directory.Exists(Path.GetDirectoryName(tempLocation)))
|
if (string.IsNullOrEmpty(tempLocation) || !Directory.Exists(Path.GetDirectoryName(tempLocation)))
|
||||||
tempLocation = Path.GetTempFileName();
|
tempLocation = Path.GetTempFileName();
|
||||||
return fileDownloader.DownloadToFile(tempLocation, onProgress);
|
return fileDownloader.DownloadToFile(tempLocation, onProgress);
|
||||||
|
@ -172,7 +172,7 @@ namespace Wox.Core.UserSettings
|
|||||||
var customizedPluginConfig = CustomizedPluginConfigs.FirstOrDefault(o => o.ID == metadata.ID);
|
var customizedPluginConfig = CustomizedPluginConfigs.FirstOrDefault(o => o.ID == metadata.ID);
|
||||||
if (customizedPluginConfig == null)
|
if (customizedPluginConfig == null)
|
||||||
{
|
{
|
||||||
CustomizedPluginConfigs.Add(new CustomizedPluginConfig()
|
CustomizedPluginConfigs.Add(new CustomizedPluginConfig
|
||||||
{
|
{
|
||||||
Disabled = false,
|
Disabled = false,
|
||||||
ID = metadata.ID,
|
ID = metadata.ID,
|
||||||
|
@ -18,7 +18,7 @@ namespace Wox.Core.i18n
|
|||||||
Chinese,
|
Chinese,
|
||||||
Chinese_TW,
|
Chinese_TW,
|
||||||
Russian,
|
Russian,
|
||||||
French,
|
French
|
||||||
};
|
};
|
||||||
return languages;
|
return languages;
|
||||||
}
|
}
|
||||||
|
@ -30,7 +30,7 @@ namespace Wox.Core.i18n
|
|||||||
{
|
{
|
||||||
Directory.CreateDirectory(DefaultDirectory);
|
Directory.CreateDirectory(DefaultDirectory);
|
||||||
}
|
}
|
||||||
catch (System.Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
Log.Error(e);
|
Log.Error(e);
|
||||||
}
|
}
|
||||||
@ -64,7 +64,7 @@ namespace Wox.Core.i18n
|
|||||||
path = GetLanguagePath(AvailableLanguages.English);
|
path = GetLanguagePath(AvailableLanguages.English);
|
||||||
if (string.IsNullOrEmpty(path))
|
if (string.IsNullOrEmpty(path))
|
||||||
{
|
{
|
||||||
throw new System.Exception("Change Language failed");
|
throw new Exception("Change Language failed");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -115,7 +115,7 @@ namespace Wox.Core.i18n
|
|||||||
pluginPair.Metadata.Name = pluginI18n.GetTranslatedPluginTitle();
|
pluginPair.Metadata.Name = pluginI18n.GetTranslatedPluginTitle();
|
||||||
pluginPair.Metadata.Description = pluginI18n.GetTranslatedPluginDescription();
|
pluginPair.Metadata.Description = pluginI18n.GetTranslatedPluginDescription();
|
||||||
}
|
}
|
||||||
catch (System.Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
var woxPluginException = new WoxPluginException(pluginPair.Metadata.Name, "Update Plugin metadata translation failed:", e);
|
var woxPluginException = new WoxPluginException(pluginPair.Metadata.Name, "Update Plugin metadata translation failed:", e);
|
||||||
Log.Error(woxPluginException);
|
Log.Error(woxPluginException);
|
||||||
|
@ -47,10 +47,10 @@ namespace Wox.CrashReporter
|
|||||||
.SetUserDescription(reproduceSteps)
|
.SetUserDescription(reproduceSteps)
|
||||||
.Submit();
|
.Submit();
|
||||||
ExceptionlessClient.Current.ProcessQueue();
|
ExceptionlessClient.Current.ProcessQueue();
|
||||||
Dispatcher.Invoke(new Action(() =>
|
Dispatcher.Invoke(() =>
|
||||||
{
|
{
|
||||||
Close();
|
Close();
|
||||||
}));
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -28,7 +28,7 @@ namespace Wox.Infrastructure
|
|||||||
|
|
||||||
public MatchResult Evaluate(string str)
|
public MatchResult Evaluate(string str)
|
||||||
{
|
{
|
||||||
if (string.IsNullOrEmpty(str) || string.IsNullOrEmpty(query)) return new MatchResult() { Success = false };
|
if (string.IsNullOrEmpty(str) || string.IsNullOrEmpty(query)) return new MatchResult { Success = false };
|
||||||
|
|
||||||
var len = str.Length;
|
var len = str.Length;
|
||||||
var compareString = opt.IgnoreCase ? str.ToLower() : str;
|
var compareString = opt.IgnoreCase ? str.ToLower() : str;
|
||||||
@ -67,7 +67,7 @@ namespace Wox.Infrastructure
|
|||||||
// return rendered string if we have a match for every char
|
// return rendered string if we have a match for every char
|
||||||
if (patternIdx == pattern.Length)
|
if (patternIdx == pattern.Length)
|
||||||
{
|
{
|
||||||
return new MatchResult()
|
return new MatchResult
|
||||||
{
|
{
|
||||||
Success = true,
|
Success = true,
|
||||||
Value = sb.ToString(),
|
Value = sb.ToString(),
|
||||||
@ -75,7 +75,7 @@ namespace Wox.Infrastructure
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
return new MatchResult() { Success = false };
|
return new MatchResult { Success = false };
|
||||||
}
|
}
|
||||||
|
|
||||||
private int CalScore(string str, int firstIndex, int matchLen)
|
private int CalScore(string str, int firstIndex, int matchLen)
|
||||||
@ -107,9 +107,9 @@ namespace Wox.Infrastructure
|
|||||||
{
|
{
|
||||||
public MatchOption()
|
public MatchOption()
|
||||||
{
|
{
|
||||||
this.Prefix = "";
|
Prefix = "";
|
||||||
this.Suffix = "";
|
Suffix = "";
|
||||||
this.IgnoreCase = true;
|
IgnoreCase = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -131,7 +131,7 @@ namespace Wox.Infrastructure.Hotkey
|
|||||||
if (CharKey != Key.None)
|
if (CharKey != Key.None)
|
||||||
{
|
{
|
||||||
text += specialSymbolDictionary.ContainsKey(CharKey)
|
text += specialSymbolDictionary.ContainsKey(CharKey)
|
||||||
? specialSymbolDictionary[CharKey].ToString()
|
? specialSymbolDictionary[CharKey]
|
||||||
: CharKey.ToString();
|
: CharKey.ToString();
|
||||||
}
|
}
|
||||||
else if (!string.IsNullOrEmpty(text))
|
else if (!string.IsNullOrEmpty(text))
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
namespace Wox.Infrastructure.Hotkey
|
namespace Wox.Infrastructure.Hotkey
|
||||||
{
|
{
|
||||||
public enum KeyEvent:int
|
public enum KeyEvent
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Key down
|
/// Key down
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Net;
|
using System.Net;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
|
using Wox.Infrastructure.Logger;
|
||||||
using Wox.Plugin;
|
using Wox.Plugin;
|
||||||
|
|
||||||
namespace Wox.Infrastructure.Http
|
namespace Wox.Infrastructure.Http
|
||||||
@ -56,7 +57,7 @@ namespace Wox.Infrastructure.Http
|
|||||||
}
|
}
|
||||||
catch (System.Exception e)
|
catch (System.Exception e)
|
||||||
{
|
{
|
||||||
Logger.Log.Error(e);
|
Log.Error(e);
|
||||||
return string.Empty;
|
return string.Empty;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -109,7 +110,7 @@ namespace Wox.Infrastructure.Http
|
|||||||
}
|
}
|
||||||
catch (System.Exception e)
|
catch (System.Exception e)
|
||||||
{
|
{
|
||||||
Logger.Log.Error(e);
|
Log.Error(e);
|
||||||
return string.Empty;
|
return string.Empty;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
using NLog;
|
using NLog;
|
||||||
using Wox.Infrastructure.Exception;
|
|
||||||
|
|
||||||
namespace Wox.Infrastructure.Logger
|
namespace Wox.Infrastructure.Logger
|
||||||
{
|
{
|
||||||
|
@ -69,7 +69,7 @@ namespace Wox.Infrastructure.Storage
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private System.Reflection.Assembly CurrentDomain_AssemblyResolve(object sender, ResolveEventArgs args)
|
private Assembly CurrentDomain_AssemblyResolve(object sender, ResolveEventArgs args)
|
||||||
{
|
{
|
||||||
Assembly ayResult = null;
|
Assembly ayResult = null;
|
||||||
string sShortAssemblyName = args.Name.Split(',')[0];
|
string sShortAssemblyName = args.Name.Split(',')[0];
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using Wox.Infrastructure;
|
using Wox.Infrastructure;
|
||||||
|
using Wox.Plugin;
|
||||||
|
|
||||||
namespace Wox.Test
|
namespace Wox.Test
|
||||||
{
|
{
|
||||||
@ -11,20 +12,20 @@ namespace Wox.Test
|
|||||||
[Test]
|
[Test]
|
||||||
public void MatchTest()
|
public void MatchTest()
|
||||||
{
|
{
|
||||||
var sources = new List<string>()
|
var sources = new List<string>
|
||||||
{
|
{
|
||||||
"file open in browser-test",
|
"file open in browser-test",
|
||||||
"Install Package",
|
"Install Package",
|
||||||
"add new bsd",
|
"add new bsd",
|
||||||
"Inste",
|
"Inste",
|
||||||
"aac",
|
"aac"
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
var results = new List<Wox.Plugin.Result>();
|
var results = new List<Result>();
|
||||||
foreach (var str in sources)
|
foreach (var str in sources)
|
||||||
{
|
{
|
||||||
results.Add(new Plugin.Result()
|
results.Add(new Result
|
||||||
{
|
{
|
||||||
Title = str,
|
Title = str,
|
||||||
Score = FuzzyMatcher.Create("inst").Evaluate(str).Score
|
Score = FuzzyMatcher.Create("inst").Evaluate(str).Score
|
||||||
|
@ -36,7 +36,7 @@ namespace Wox.UpdateFeedGenerator
|
|||||||
if (string.IsNullOrEmpty(config.OutputDirectory))
|
if (string.IsNullOrEmpty(config.OutputDirectory))
|
||||||
{
|
{
|
||||||
config.OutputDirectory = @"Update";
|
config.OutputDirectory = @"Update";
|
||||||
ConfigStorage.Instance.Save();
|
Instance.Save();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
|
using NAppUpdate.Framework.Utils;
|
||||||
|
|
||||||
namespace Wox.UpdateFeedGenerator
|
namespace Wox.UpdateFeedGenerator
|
||||||
{
|
{
|
||||||
@ -31,7 +32,7 @@ namespace Wox.UpdateFeedGenerator
|
|||||||
myFileInfo = new FileInfo(fileName);
|
myFileInfo = new FileInfo(fileName);
|
||||||
myFileVersion = FileVersionInfo.GetVersionInfo(fileName).FileVersion;
|
myFileVersion = FileVersionInfo.GetVersionInfo(fileName).FileVersion;
|
||||||
if (myFileVersion != null) myFileVersion = myFileVersion.Replace(", ", ".");
|
if (myFileVersion != null) myFileVersion = myFileVersion.Replace(", ", ".");
|
||||||
myHash = NAppUpdate.Framework.Utils.FileChecksum.GetSHA256Checksum(fileName);
|
myHash = FileChecksum.GetSHA256Checksum(fileName);
|
||||||
RelativeName = fileName.Substring(rootDirectoryLength + 1);
|
RelativeName = fileName.Substring(rootDirectoryLength + 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -162,9 +162,9 @@ namespace Wox.UpdateFeedGenerator
|
|||||||
if (fileTypesToMatch.IndexOfAny(new[] { ':', '<', '>', '/', '\\' }) >= 0) throw new ArgumentException("invalid cahracters in wildcard pattern", "fileTypesToMatch");
|
if (fileTypesToMatch.IndexOfAny(new[] { ':', '<', '>', '/', '\\' }) >= 0) throw new ArgumentException("invalid cahracters in wildcard pattern", "fileTypesToMatch");
|
||||||
|
|
||||||
m_includeSubDirs = includeSubDirs;
|
m_includeSubDirs = includeSubDirs;
|
||||||
m_paths = pathsToSearch.Split(new[] { ';', ',' });
|
m_paths = pathsToSearch.Split(';', ',');
|
||||||
|
|
||||||
string[] specs = fileTypesToMatch.Split(new[] { ';', ',' });
|
string[] specs = fileTypesToMatch.Split(';', ',');
|
||||||
m_fileSpecs = new List<Regex>(specs.Length);
|
m_fileSpecs = new List<Regex>(specs.Length);
|
||||||
foreach (string spec in specs) {
|
foreach (string spec in specs) {
|
||||||
// trim whitespace off file spec and convert Win32 wildcards to regular expressions
|
// trim whitespace off file spec and convert Win32 wildcards to regular expressions
|
||||||
|
@ -19,7 +19,6 @@ namespace Wox
|
|||||||
{
|
{
|
||||||
MessageBox.Show(InternationalizationManager.Instance.GetTranslation("cannotFindSpecifiedPlugin"));
|
MessageBox.Show(InternationalizationManager.Instance.GetTranslation("cannotFindSpecifiedPlugin"));
|
||||||
Close();
|
Close();
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -8,8 +8,6 @@ namespace Wox.Converters
|
|||||||
{
|
{
|
||||||
public class StringNullOrEmptyToVisibilityConverter : ConvertorBase<StringNullOrEmptyToVisibilityConverter>
|
public class StringNullOrEmptyToVisibilityConverter : ConvertorBase<StringNullOrEmptyToVisibilityConverter>
|
||||||
{
|
{
|
||||||
public StringNullOrEmptyToVisibilityConverter() { }
|
|
||||||
|
|
||||||
public override object Convert(object value, Type targetType, object parameter, CultureInfo culture)
|
public override object Convert(object value, Type targetType, object parameter, CultureInfo culture)
|
||||||
{
|
{
|
||||||
return string.IsNullOrEmpty(value as string) ? Visibility.Collapsed : Visibility.Visible;
|
return string.IsNullOrEmpty(value as string) ? Visibility.Collapsed : Visibility.Visible;
|
||||||
|
@ -38,7 +38,7 @@ namespace Wox
|
|||||||
UserSettingStorage.Instance.CustomPluginHotkeys = new List<CustomPluginHotkey>();
|
UserSettingStorage.Instance.CustomPluginHotkeys = new List<CustomPluginHotkey>();
|
||||||
}
|
}
|
||||||
|
|
||||||
var pluginHotkey = new CustomPluginHotkey()
|
var pluginHotkey = new CustomPluginHotkey
|
||||||
{
|
{
|
||||||
Hotkey = ctlHotkey.CurrentHotkey.ToString(),
|
Hotkey = ctlHotkey.CurrentHotkey.ToString(),
|
||||||
ActionKeyword = tbAction.Text
|
ActionKeyword = tbAction.Text
|
||||||
|
@ -25,7 +25,7 @@ namespace Wox.Helper
|
|||||||
{
|
{
|
||||||
if (!DropShadow(window))
|
if (!DropShadow(window))
|
||||||
{
|
{
|
||||||
window.SourceInitialized += new EventHandler(window_SourceInitialized);
|
window.SourceInitialized += window_SourceInitialized;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -35,7 +35,7 @@ namespace Wox.Helper
|
|||||||
|
|
||||||
DropShadow(window);
|
DropShadow(window);
|
||||||
|
|
||||||
window.SourceInitialized -= new EventHandler(window_SourceInitialized);
|
window.SourceInitialized -= window_SourceInitialized;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -16,14 +16,14 @@ namespace Wox.Helper
|
|||||||
public static void UnhandledExceptionHandle(object sender, UnhandledExceptionEventArgs e)
|
public static void UnhandledExceptionHandle(object sender, UnhandledExceptionEventArgs e)
|
||||||
{
|
{
|
||||||
//handle non-ui thread exceptions
|
//handle non-ui thread exceptions
|
||||||
App.Window.Dispatcher.Invoke(new Action(() =>
|
App.Window.Dispatcher.Invoke(() =>
|
||||||
{
|
{
|
||||||
Report((Exception)e.ExceptionObject);
|
Report((Exception)e.ExceptionObject);
|
||||||
if (!(e.ExceptionObject is WoxException))
|
if (!(e.ExceptionObject is WoxException))
|
||||||
{
|
{
|
||||||
Environment.Exit(0);
|
Environment.Exit(0);
|
||||||
}
|
}
|
||||||
}));
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void DispatcherUnhandledException(object sender, DispatcherUnhandledExceptionEventArgs e)
|
public static void DispatcherUnhandledException(object sender, DispatcherUnhandledExceptionEventArgs e)
|
||||||
|
@ -9,6 +9,7 @@ using System.Runtime.Remoting.Channels;
|
|||||||
using System.Runtime.Remoting.Channels.Ipc;
|
using System.Runtime.Remoting.Channels.Ipc;
|
||||||
using System.Runtime.Serialization.Formatters;
|
using System.Runtime.Serialization.Formatters;
|
||||||
using System.Security;
|
using System.Security;
|
||||||
|
using System.Text;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Windows;
|
using System.Windows;
|
||||||
using System.Windows.Threading;
|
using System.Windows.Threading;
|
||||||
@ -131,7 +132,7 @@ namespace Wox.Helper
|
|||||||
// This is the hard-coded message value used by WinForms for Shell_NotifyIcon.
|
// This is the hard-coded message value used by WinForms for Shell_NotifyIcon.
|
||||||
// It's relatively safe to reuse.
|
// It's relatively safe to reuse.
|
||||||
TRAYMOUSEMESSAGE = 0x800, //WM_USER + 1024
|
TRAYMOUSEMESSAGE = 0x800, //WM_USER + 1024
|
||||||
APP = 0x8000,
|
APP = 0x8000
|
||||||
}
|
}
|
||||||
|
|
||||||
[SuppressUnmanagedCodeSecurity]
|
[SuppressUnmanagedCodeSecurity]
|
||||||
@ -342,7 +343,7 @@ namespace Wox.Helper
|
|||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
using (TextReader reader = new StreamReader(cmdLinePath, System.Text.Encoding.Unicode))
|
using (TextReader reader = new StreamReader(cmdLinePath, Encoding.Unicode))
|
||||||
{
|
{
|
||||||
args = NativeMethods.CommandLineToArgvW(reader.ReadToEnd());
|
args = NativeMethods.CommandLineToArgvW(reader.ReadToEnd());
|
||||||
}
|
}
|
||||||
@ -465,7 +466,7 @@ namespace Wox.Helper
|
|||||||
{
|
{
|
||||||
// Do an asynchronous call to ActivateFirstInstance function
|
// Do an asynchronous call to ActivateFirstInstance function
|
||||||
Application.Current.Dispatcher.BeginInvoke(
|
Application.Current.Dispatcher.BeginInvoke(
|
||||||
DispatcherPriority.Normal, new DispatcherOperationCallback(SingleInstance<TApplication>.ActivateFirstInstanceCallback), args);
|
DispatcherPriority.Normal, new DispatcherOperationCallback(ActivateFirstInstanceCallback), args);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -35,7 +35,7 @@ namespace Wox.Helper
|
|||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var parts = result.ToString().Trim().Split(new char[] {' '}, 3).Select(byte.Parse).ToList();
|
var parts = result.ToString().Trim().Split(new[] {' '}, 3).Select(byte.Parse).ToList();
|
||||||
return Color.FromRgb(parts[0], parts[1], parts[2]);
|
return Color.FromRgb(parts[0], parts[1], parts[2]);
|
||||||
}
|
}
|
||||||
catch
|
catch
|
||||||
|
@ -10,7 +10,7 @@ namespace Wox.ImageLoader
|
|||||||
[Serializable]
|
[Serializable]
|
||||||
public class ImageCacheStroage : BinaryStorage<ImageCacheStroage>
|
public class ImageCacheStroage : BinaryStorage<ImageCacheStroage>
|
||||||
{
|
{
|
||||||
private int counter = 0;
|
private int counter;
|
||||||
private const int maxCached = 200;
|
private const int maxCached = 200;
|
||||||
public Dictionary<string, int> TopUsedImages = new Dictionary<string, int>();
|
public Dictionary<string, int> TopUsedImages = new Dictionary<string, int>();
|
||||||
|
|
||||||
|
@ -4,6 +4,7 @@ using System.Drawing;
|
|||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
using System.Windows;
|
using System.Windows;
|
||||||
|
using System.Windows.Interop;
|
||||||
using System.Windows.Media;
|
using System.Windows.Media;
|
||||||
using System.Windows.Media.Imaging;
|
using System.Windows.Media.Imaging;
|
||||||
using Wox.Infrastructure;
|
using Wox.Infrastructure;
|
||||||
@ -43,7 +44,7 @@ namespace Wox.ImageLoader
|
|||||||
Icon icon = GetFileIcon(fileName) ?? Icon.ExtractAssociatedIcon(fileName);
|
Icon icon = GetFileIcon(fileName) ?? Icon.ExtractAssociatedIcon(fileName);
|
||||||
if (icon != null)
|
if (icon != null)
|
||||||
{
|
{
|
||||||
return System.Windows.Interop.Imaging.CreateBitmapSourceFromHIcon(icon.Handle,
|
return Imaging.CreateBitmapSourceFromHIcon(icon.Handle,
|
||||||
new Int32Rect(0, 0, icon.Width, icon.Height), BitmapSizeOptions.FromEmptyOptions());
|
new Int32Rect(0, 0, icon.Width, icon.Height), BitmapSizeOptions.FromEmptyOptions());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -206,7 +207,7 @@ namespace Wox.ImageLoader
|
|||||||
public string szDisplayName;
|
public string szDisplayName;
|
||||||
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = NAMESIZE)]
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = NAMESIZE)]
|
||||||
public string szTypeName;
|
public string szTypeName;
|
||||||
};
|
}
|
||||||
|
|
||||||
private const uint SHGFI_ICON = 0x000000100; // get icon
|
private const uint SHGFI_ICON = 0x000000100; // get icon
|
||||||
private const uint SHGFI_DISPLAYNAME = 0x000000200; // get display name
|
private const uint SHGFI_DISPLAYNAME = 0x000000200; // get display name
|
||||||
|
@ -10,6 +10,7 @@ using System.Threading;
|
|||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using System.Windows;
|
using System.Windows;
|
||||||
using System.Windows.Controls;
|
using System.Windows.Controls;
|
||||||
|
using System.Windows.Forms;
|
||||||
using System.Windows.Input;
|
using System.Windows.Input;
|
||||||
using System.Windows.Media.Animation;
|
using System.Windows.Media.Animation;
|
||||||
using NHotkey;
|
using NHotkey;
|
||||||
@ -24,11 +25,16 @@ using Wox.Infrastructure;
|
|||||||
using Wox.Infrastructure.Hotkey;
|
using Wox.Infrastructure.Hotkey;
|
||||||
using Wox.Plugin;
|
using Wox.Plugin;
|
||||||
using Wox.Storage;
|
using Wox.Storage;
|
||||||
|
using Application = System.Windows.Application;
|
||||||
using ContextMenu = System.Windows.Forms.ContextMenu;
|
using ContextMenu = System.Windows.Forms.ContextMenu;
|
||||||
using NotifyIcon = System.Windows.Forms.NotifyIcon;
|
using DataFormats = System.Windows.DataFormats;
|
||||||
using Screen = System.Windows.Forms.Screen;
|
using DragEventArgs = System.Windows.DragEventArgs;
|
||||||
|
using IDataObject = System.Windows.IDataObject;
|
||||||
|
using KeyEventArgs = System.Windows.Input.KeyEventArgs;
|
||||||
using MenuItem = System.Windows.Forms.MenuItem;
|
using MenuItem = System.Windows.Forms.MenuItem;
|
||||||
|
using MessageBox = System.Windows.MessageBox;
|
||||||
using Stopwatch = Wox.Infrastructure.Stopwatch;
|
using Stopwatch = Wox.Infrastructure.Stopwatch;
|
||||||
|
using ToolTip = System.Windows.Controls.ToolTip;
|
||||||
|
|
||||||
namespace Wox
|
namespace Wox
|
||||||
{
|
{
|
||||||
@ -43,7 +49,7 @@ namespace Wox
|
|||||||
private Query _lastQuery = new Query();
|
private Query _lastQuery = new Query();
|
||||||
private ToolTip toolTip = new ToolTip();
|
private ToolTip toolTip = new ToolTip();
|
||||||
|
|
||||||
private bool _ignoreTextChange = false;
|
private bool _ignoreTextChange;
|
||||||
private List<Result> CurrentContextMenus = new List<Result>();
|
private List<Result> CurrentContextMenus = new List<Result>();
|
||||||
private string textBeforeEnterContextMenuMode;
|
private string textBeforeEnterContextMenuMode;
|
||||||
|
|
||||||
@ -53,7 +59,7 @@ namespace Wox
|
|||||||
|
|
||||||
public void ChangeQuery(string query, bool requery = false)
|
public void ChangeQuery(string query, bool requery = false)
|
||||||
{
|
{
|
||||||
Dispatcher.Invoke(new Action(() =>
|
Dispatcher.Invoke(() =>
|
||||||
{
|
{
|
||||||
tbQuery.Text = query;
|
tbQuery.Text = query;
|
||||||
tbQuery.CaretIndex = tbQuery.Text.Length;
|
tbQuery.CaretIndex = tbQuery.Text.Length;
|
||||||
@ -61,12 +67,12 @@ namespace Wox
|
|||||||
{
|
{
|
||||||
TbQuery_OnTextChanged(null, null);
|
TbQuery_OnTextChanged(null, null);
|
||||||
}
|
}
|
||||||
}));
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public void ChangeQueryText(string query, bool selectAll = false)
|
public void ChangeQueryText(string query, bool selectAll = false)
|
||||||
{
|
{
|
||||||
Dispatcher.Invoke(new Action(() =>
|
Dispatcher.Invoke(() =>
|
||||||
{
|
{
|
||||||
_ignoreTextChange = true;
|
_ignoreTextChange = true;
|
||||||
tbQuery.Text = query;
|
tbQuery.Text = query;
|
||||||
@ -75,7 +81,7 @@ namespace Wox
|
|||||||
{
|
{
|
||||||
tbQuery.SelectAll();
|
tbQuery.SelectAll();
|
||||||
}
|
}
|
||||||
}));
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public void CloseApp()
|
public void CloseApp()
|
||||||
@ -96,50 +102,50 @@ namespace Wox
|
|||||||
|
|
||||||
public void HideApp()
|
public void HideApp()
|
||||||
{
|
{
|
||||||
Dispatcher.Invoke(new Action(HideWox));
|
Dispatcher.Invoke(HideWox);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void ShowApp()
|
public void ShowApp()
|
||||||
{
|
{
|
||||||
Dispatcher.Invoke(new Action(() => ShowWox()));
|
Dispatcher.Invoke(() => ShowWox());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void ShowMsg(string title, string subTitle, string iconPath)
|
public void ShowMsg(string title, string subTitle, string iconPath)
|
||||||
{
|
{
|
||||||
Dispatcher.Invoke(new Action(() =>
|
Dispatcher.Invoke(() =>
|
||||||
{
|
{
|
||||||
var m = new Msg { Owner = GetWindow(this) };
|
var m = new Msg { Owner = GetWindow(this) };
|
||||||
m.Show(title, subTitle, iconPath);
|
m.Show(title, subTitle, iconPath);
|
||||||
}));
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public void OpenSettingDialog(string tabName = "general")
|
public void OpenSettingDialog(string tabName = "general")
|
||||||
{
|
{
|
||||||
Dispatcher.Invoke(new Action(() =>
|
Dispatcher.Invoke(() =>
|
||||||
{
|
{
|
||||||
SettingWindow sw = SingletonWindowOpener.Open<SettingWindow>(this);
|
SettingWindow sw = SingletonWindowOpener.Open<SettingWindow>(this);
|
||||||
sw.SwitchTo(tabName);
|
sw.SwitchTo(tabName);
|
||||||
}));
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public void StartLoadingBar()
|
public void StartLoadingBar()
|
||||||
{
|
{
|
||||||
Dispatcher.Invoke(new Action(StartProgress));
|
Dispatcher.Invoke(StartProgress);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void StopLoadingBar()
|
public void StopLoadingBar()
|
||||||
{
|
{
|
||||||
Dispatcher.Invoke(new Action(StopProgress));
|
Dispatcher.Invoke(StopProgress);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void InstallPlugin(string path)
|
public void InstallPlugin(string path)
|
||||||
{
|
{
|
||||||
Dispatcher.Invoke(new Action(() => PluginManager.InstallPlugin(path)));
|
Dispatcher.Invoke(() => PluginManager.InstallPlugin(path));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void ReloadPlugins()
|
public void ReloadPlugins()
|
||||||
{
|
{
|
||||||
Dispatcher.Invoke(new Action(() => PluginManager.Init(this)));
|
Dispatcher.Invoke(() => PluginManager.Init(this));
|
||||||
}
|
}
|
||||||
|
|
||||||
public string GetTranslation(string key)
|
public string GetTranslation(string key)
|
||||||
@ -241,7 +247,7 @@ namespace Wox
|
|||||||
UserSettingStorage.Instance.WindowLeft = Left;
|
UserSettingStorage.Instance.WindowLeft = Left;
|
||||||
UserSettingStorage.Instance.WindowTop = Top;
|
UserSettingStorage.Instance.WindowTop = Top;
|
||||||
UserSettingStorage.Instance.Save();
|
UserSettingStorage.Instance.Save();
|
||||||
this.HideWox();
|
HideWox();
|
||||||
e.Cancel = true;
|
e.Cancel = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -293,10 +299,10 @@ namespace Wox
|
|||||||
|
|
||||||
private void OnPrepareUpdateReady(object sender, EventArgs e)
|
private void OnPrepareUpdateReady(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
Dispatcher.Invoke(new Action(() =>
|
Dispatcher.Invoke(() =>
|
||||||
{
|
{
|
||||||
new WoxUpdate().ShowDialog();
|
new WoxUpdate().ShowDialog();
|
||||||
}));
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public void SetHotkey(string hotkeyStr, EventHandler<HotkeyEventArgs> action)
|
public void SetHotkey(string hotkeyStr, EventHandler<HotkeyEventArgs> action)
|
||||||
@ -664,7 +670,7 @@ namespace Wox
|
|||||||
case Key.Back:
|
case Key.Back:
|
||||||
if (BackKeyDownEvent != null)
|
if (BackKeyDownEvent != null)
|
||||||
{
|
{
|
||||||
BackKeyDownEvent(new WoxKeyDownEventArgs()
|
BackKeyDownEvent(new WoxKeyDownEventArgs
|
||||||
{
|
{
|
||||||
Query = tbQuery.Text,
|
Query = tbQuery.Text,
|
||||||
keyEventArgs = e
|
keyEventArgs = e
|
||||||
@ -736,9 +742,10 @@ namespace Wox
|
|||||||
var executeQueryHistoryTitle = GetTranslation("executeQuery");
|
var executeQueryHistoryTitle = GetTranslation("executeQuery");
|
||||||
var lastExecuteTime = GetTranslation("lastExecuteTime");
|
var lastExecuteTime = GetTranslation("lastExecuteTime");
|
||||||
pnlResult.RemoveResultsExcept(historyMetadata);
|
pnlResult.RemoveResultsExcept(historyMetadata);
|
||||||
UpdateResultViewInternal(new List<Result>()
|
UpdateResultViewInternal(new List<Result>
|
||||||
{
|
{
|
||||||
new Result(){
|
new Result
|
||||||
|
{
|
||||||
Title = string.Format(executeQueryHistoryTitle,history.Query),
|
Title = string.Format(executeQueryHistoryTitle,history.Query),
|
||||||
SubTitle = string.Format(lastExecuteTime,history.ExecutedDateTime),
|
SubTitle = string.Format(lastExecuteTime,history.ExecutedDateTime),
|
||||||
IcoPath = "Images\\history.png",
|
IcoPath = "Images\\history.png",
|
||||||
@ -815,7 +822,7 @@ namespace Wox
|
|||||||
{
|
{
|
||||||
if (result.Action != null)
|
if (result.Action != null)
|
||||||
{
|
{
|
||||||
bool hideWindow = result.Action(new ActionContext()
|
bool hideWindow = result.Action(new ActionContext
|
||||||
{
|
{
|
||||||
SpecialKeyState = GlobalHotkey.Instance.CheckModifiers()
|
SpecialKeyState = GlobalHotkey.Instance.CheckModifiers()
|
||||||
});
|
});
|
||||||
@ -832,7 +839,7 @@ namespace Wox
|
|||||||
private void UpdateResultView(List<Result> list, PluginMetadata metadata, Query originQuery)
|
private void UpdateResultView(List<Result> list, PluginMetadata metadata, Query originQuery)
|
||||||
{
|
{
|
||||||
_queryHasReturn = true;
|
_queryHasReturn = true;
|
||||||
progressBar.Dispatcher.Invoke(new Action(StopProgress));
|
progressBar.Dispatcher.Invoke(StopProgress);
|
||||||
|
|
||||||
list.ForEach(o =>
|
list.ForEach(o =>
|
||||||
{
|
{
|
||||||
@ -846,11 +853,11 @@ namespace Wox
|
|||||||
|
|
||||||
private void UpdateResultViewInternal(List<Result> list, PluginMetadata metadata)
|
private void UpdateResultViewInternal(List<Result> list, PluginMetadata metadata)
|
||||||
{
|
{
|
||||||
Dispatcher.Invoke(new Action(() =>
|
Dispatcher.Invoke(() =>
|
||||||
{
|
{
|
||||||
Stopwatch.Normal($"UI update cost for {metadata.Name}",
|
Stopwatch.Normal($"UI update cost for {metadata.Name}",
|
||||||
() => { pnlResult.AddResults(list, metadata.ID); });
|
() => { pnlResult.AddResults(list, metadata.ID); });
|
||||||
}));
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private Result GetTopMostContextMenu(Result result)
|
private Result GetTopMostContextMenu(Result result)
|
||||||
|
@ -12,7 +12,7 @@ namespace Wox
|
|||||||
public partial class Msg : Window
|
public partial class Msg : Window
|
||||||
{
|
{
|
||||||
Storyboard fadeOutStoryboard = new Storyboard();
|
Storyboard fadeOutStoryboard = new Storyboard();
|
||||||
private bool closing = false;
|
private bool closing;
|
||||||
|
|
||||||
public Msg()
|
public Msg()
|
||||||
{
|
{
|
||||||
@ -21,13 +21,13 @@ namespace Wox
|
|||||||
var dipWorkingArea = WindowIntelopHelper.TransformPixelsToDIP(this,
|
var dipWorkingArea = WindowIntelopHelper.TransformPixelsToDIP(this,
|
||||||
screen.WorkingArea.Width,
|
screen.WorkingArea.Width,
|
||||||
screen.WorkingArea.Height);
|
screen.WorkingArea.Height);
|
||||||
Left = dipWorkingArea.X - this.Width;
|
Left = dipWorkingArea.X - Width;
|
||||||
Top = dipWorkingArea.Y;
|
Top = dipWorkingArea.Y;
|
||||||
showAnimation.From = dipWorkingArea.Y;
|
showAnimation.From = dipWorkingArea.Y;
|
||||||
showAnimation.To = dipWorkingArea.Y - Height;
|
showAnimation.To = dipWorkingArea.Y - Height;
|
||||||
|
|
||||||
// Create the fade out storyboard
|
// Create the fade out storyboard
|
||||||
fadeOutStoryboard.Completed += new EventHandler(fadeOutStoryboard_Completed);
|
fadeOutStoryboard.Completed += fadeOutStoryboard_Completed;
|
||||||
DoubleAnimation fadeOutAnimation = new DoubleAnimation(dipWorkingArea.Y - Height, dipWorkingArea.Y, new Duration(TimeSpan.FromSeconds(0.3)))
|
DoubleAnimation fadeOutAnimation = new DoubleAnimation(dipWorkingArea.Y - Height, dipWorkingArea.Y, new Duration(TimeSpan.FromSeconds(0.3)))
|
||||||
{
|
{
|
||||||
AccelerationRatio = 0.2
|
AccelerationRatio = 0.2
|
||||||
|
@ -1,9 +1,10 @@
|
|||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
using System.Windows;
|
using System.Windows;
|
||||||
|
using Exceptionless.Configuration;
|
||||||
|
|
||||||
[assembly: AssemblyTitle("Wox")]
|
[assembly: AssemblyTitle("Wox")]
|
||||||
[assembly: ThemeInfo(
|
[assembly: ThemeInfo(
|
||||||
ResourceDictionaryLocation.None,
|
ResourceDictionaryLocation.None,
|
||||||
ResourceDictionaryLocation.SourceAssembly
|
ResourceDictionaryLocation.SourceAssembly
|
||||||
)]
|
)]
|
||||||
[assembly: Exceptionless.Configuration.Exceptionless("e0b256fbe9384498ba89aae2a6b7f8ab")]
|
[assembly: Exceptionless("e0b256fbe9384498ba89aae2a6b7f8ab")]
|
@ -17,7 +17,6 @@ using Wox.Core.Theme;
|
|||||||
using Wox.Core.Updater;
|
using Wox.Core.Updater;
|
||||||
using Wox.Core.UserSettings;
|
using Wox.Core.UserSettings;
|
||||||
using Wox.Helper;
|
using Wox.Helper;
|
||||||
using Wox.Infrastructure.Exception;
|
|
||||||
using Wox.Plugin;
|
using Wox.Plugin;
|
||||||
using Application = System.Windows.Forms.Application;
|
using Application = System.Windows.Forms.Application;
|
||||||
using Stopwatch = Wox.Infrastructure.Stopwatch;
|
using Stopwatch = Wox.Infrastructure.Stopwatch;
|
||||||
@ -27,13 +26,13 @@ namespace Wox
|
|||||||
public partial class SettingWindow : Window
|
public partial class SettingWindow : Window
|
||||||
{
|
{
|
||||||
public readonly MainWindow MainWindow;
|
public readonly MainWindow MainWindow;
|
||||||
bool settingsLoaded = false;
|
bool settingsLoaded;
|
||||||
private Dictionary<ISettingProvider, Control> featureControls = new Dictionary<ISettingProvider, Control>();
|
private Dictionary<ISettingProvider, Control> featureControls = new Dictionary<ISettingProvider, Control>();
|
||||||
private bool themeTabLoaded = false;
|
private bool themeTabLoaded;
|
||||||
|
|
||||||
public SettingWindow(MainWindow mainWindow)
|
public SettingWindow(MainWindow mainWindow)
|
||||||
{
|
{
|
||||||
this.MainWindow = mainWindow;
|
MainWindow = mainWindow;
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
Loaded += Setting_Loaded;
|
Loaded += Setting_Loaded;
|
||||||
}
|
}
|
||||||
@ -248,7 +247,7 @@ namespace Wox
|
|||||||
|
|
||||||
#region Hotkey
|
#region Hotkey
|
||||||
|
|
||||||
void ctlHotkey_OnHotkeyChanged(object sender, System.EventArgs e)
|
void ctlHotkey_OnHotkeyChanged(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
if (ctlHotkey.CurrentHotkeyAvailable)
|
if (ctlHotkey.CurrentHotkeyAvailable)
|
||||||
{
|
{
|
||||||
@ -362,50 +361,50 @@ namespace Wox
|
|||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
resultPanelPreview.AddResults(new List<Result>()
|
resultPanelPreview.AddResults(new List<Result>
|
||||||
{
|
{
|
||||||
new Result()
|
new Result
|
||||||
{
|
{
|
||||||
Title = "Wox is an effective launcher for windows",
|
Title = "Wox is an effective launcher for windows",
|
||||||
SubTitle = "Wox provide bundles of features let you access infomations quickly.",
|
SubTitle = "Wox provide bundles of features let you access infomations quickly.",
|
||||||
IcoPath = "Images/app.png",
|
IcoPath = "Images/app.png",
|
||||||
PluginDirectory = Path.GetDirectoryName(System.Windows.Forms.Application.ExecutablePath)
|
PluginDirectory = Path.GetDirectoryName(Application.ExecutablePath)
|
||||||
},
|
},
|
||||||
new Result()
|
new Result
|
||||||
{
|
{
|
||||||
Title = "Search applications",
|
Title = "Search applications",
|
||||||
SubTitle = "Search applications, files (via everything plugin) and browser bookmarks",
|
SubTitle = "Search applications, files (via everything plugin) and browser bookmarks",
|
||||||
IcoPath = "Images/app.png",
|
IcoPath = "Images/app.png",
|
||||||
PluginDirectory = Path.GetDirectoryName(System.Windows.Forms.Application.ExecutablePath)
|
PluginDirectory = Path.GetDirectoryName(Application.ExecutablePath)
|
||||||
},
|
},
|
||||||
new Result()
|
new Result
|
||||||
{
|
{
|
||||||
Title = "Search web contents with shortcuts",
|
Title = "Search web contents with shortcuts",
|
||||||
SubTitle = "e.g. search google with g keyword or youtube keyword)",
|
SubTitle = "e.g. search google with g keyword or youtube keyword)",
|
||||||
IcoPath = "Images/app.png",
|
IcoPath = "Images/app.png",
|
||||||
PluginDirectory = Path.GetDirectoryName(Application.ExecutablePath)
|
PluginDirectory = Path.GetDirectoryName(Application.ExecutablePath)
|
||||||
},
|
},
|
||||||
new Result()
|
new Result
|
||||||
{
|
{
|
||||||
Title = "clipboard history ",
|
Title = "clipboard history ",
|
||||||
IcoPath = "Images/app.png",
|
IcoPath = "Images/app.png",
|
||||||
PluginDirectory = Path.GetDirectoryName(Application.ExecutablePath)
|
PluginDirectory = Path.GetDirectoryName(Application.ExecutablePath)
|
||||||
},
|
},
|
||||||
new Result()
|
new Result
|
||||||
{
|
{
|
||||||
Title = "Themes support",
|
Title = "Themes support",
|
||||||
SubTitle = "get more themes from http://www.getwox.com/theme",
|
SubTitle = "get more themes from http://www.getwox.com/theme",
|
||||||
IcoPath = "Images/app.png",
|
IcoPath = "Images/app.png",
|
||||||
PluginDirectory = Path.GetDirectoryName(Application.ExecutablePath)
|
PluginDirectory = Path.GetDirectoryName(Application.ExecutablePath)
|
||||||
},
|
},
|
||||||
new Result()
|
new Result
|
||||||
{
|
{
|
||||||
Title = "Plugins support",
|
Title = "Plugins support",
|
||||||
SubTitle = "get more plugins from http://www.getwox.com/plugin",
|
SubTitle = "get more plugins from http://www.getwox.com/plugin",
|
||||||
IcoPath = "Images/app.png",
|
IcoPath = "Images/app.png",
|
||||||
PluginDirectory = Path.GetDirectoryName(Application.ExecutablePath)
|
PluginDirectory = Path.GetDirectoryName(Application.ExecutablePath)
|
||||||
},
|
},
|
||||||
new Result()
|
new Result
|
||||||
{
|
{
|
||||||
Title = "Wox is an open-source software",
|
Title = "Wox is an open-source software",
|
||||||
SubTitle = "Wox benefits from the open-source community a lot",
|
SubTitle = "Wox benefits from the open-source community a lot",
|
||||||
@ -416,7 +415,7 @@ namespace Wox
|
|||||||
|
|
||||||
foreach (string theme in ThemeManager.Theme.LoadAvailableThemes())
|
foreach (string theme in ThemeManager.Theme.LoadAvailableThemes())
|
||||||
{
|
{
|
||||||
string themeName = System.IO.Path.GetFileNameWithoutExtension(theme);
|
string themeName = Path.GetFileNameWithoutExtension(theme);
|
||||||
themeComboBox.Items.Add(themeName);
|
themeComboBox.Items.Add(themeName);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -453,7 +452,7 @@ namespace Wox
|
|||||||
if (!settingsLoaded) return;
|
if (!settingsLoaded) return;
|
||||||
string queryBoxFontName = cbQueryBoxFont.SelectedItem.ToString();
|
string queryBoxFontName = cbQueryBoxFont.SelectedItem.ToString();
|
||||||
UserSettingStorage.Instance.QueryBoxFont = queryBoxFontName;
|
UserSettingStorage.Instance.QueryBoxFont = queryBoxFontName;
|
||||||
this.cbQueryBoxFontFaces.SelectedItem = ((FontFamily)cbQueryBoxFont.SelectedItem).ChooseRegularFamilyTypeface();
|
cbQueryBoxFontFaces.SelectedItem = ((FontFamily)cbQueryBoxFont.SelectedItem).ChooseRegularFamilyTypeface();
|
||||||
UserSettingStorage.Instance.Save();
|
UserSettingStorage.Instance.Save();
|
||||||
ThemeManager.Theme.ChangeTheme(UserSettingStorage.Instance.Theme);
|
ThemeManager.Theme.ChangeTheme(UserSettingStorage.Instance.Theme);
|
||||||
}
|
}
|
||||||
@ -466,8 +465,6 @@ namespace Wox
|
|||||||
{
|
{
|
||||||
if (cbQueryBoxFontFaces.Items.Count > 0)
|
if (cbQueryBoxFontFaces.Items.Count > 0)
|
||||||
cbQueryBoxFontFaces.SelectedIndex = 0;
|
cbQueryBoxFontFaces.SelectedIndex = 0;
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -484,7 +481,7 @@ namespace Wox
|
|||||||
if (!settingsLoaded) return;
|
if (!settingsLoaded) return;
|
||||||
string resultItemFont = cbResultItemFont.SelectedItem.ToString();
|
string resultItemFont = cbResultItemFont.SelectedItem.ToString();
|
||||||
UserSettingStorage.Instance.ResultItemFont = resultItemFont;
|
UserSettingStorage.Instance.ResultItemFont = resultItemFont;
|
||||||
this.cbResultItemFontFaces.SelectedItem = ((FontFamily)cbResultItemFont.SelectedItem).ChooseRegularFamilyTypeface();
|
cbResultItemFontFaces.SelectedItem = ((FontFamily)cbResultItemFont.SelectedItem).ChooseRegularFamilyTypeface();
|
||||||
UserSettingStorage.Instance.Save();
|
UserSettingStorage.Instance.Save();
|
||||||
ThemeManager.Theme.ChangeTheme(UserSettingStorage.Instance.Theme);
|
ThemeManager.Theme.ChangeTheme(UserSettingStorage.Instance.Theme);
|
||||||
}
|
}
|
||||||
@ -596,7 +593,7 @@ namespace Wox
|
|||||||
if (customizedPluginConfig == null)
|
if (customizedPluginConfig == null)
|
||||||
{
|
{
|
||||||
// todo when this part will be invoked
|
// todo when this part will be invoked
|
||||||
UserSettingStorage.Instance.CustomizedPluginConfigs.Add(new CustomizedPluginConfig()
|
UserSettingStorage.Instance.CustomizedPluginConfigs.Add(new CustomizedPluginConfig
|
||||||
{
|
{
|
||||||
Disabled = cbDisabled.IsChecked ?? true,
|
Disabled = cbDisabled.IsChecked ?? true,
|
||||||
ID = id,
|
ID = id,
|
||||||
@ -800,7 +797,7 @@ namespace Wox
|
|||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
private void Window_PreviewKeyDown(object sender, System.Windows.Input.KeyEventArgs e)
|
private void Window_PreviewKeyDown(object sender, KeyEventArgs e)
|
||||||
{
|
{
|
||||||
// Hide window with ESC, but make sure it is not pressed as a hotkey
|
// Hide window with ESC, but make sure it is not pressed as a hotkey
|
||||||
if (e.Key == Key.Escape && !ctlHotkey.IsFocused)
|
if (e.Key == Key.Escape && !ctlHotkey.IsFocused)
|
||||||
|
@ -15,7 +15,7 @@ namespace Wox.Storage
|
|||||||
private List<HistoryItem> History = new List<HistoryItem>();
|
private List<HistoryItem> History = new List<HistoryItem>();
|
||||||
|
|
||||||
private int MaxHistory = 300;
|
private int MaxHistory = 300;
|
||||||
private int cursor = 0;
|
private int cursor;
|
||||||
|
|
||||||
public static PluginMetadata MetaData { get; } = new PluginMetadata
|
public static PluginMetadata MetaData { get; } = new PluginMetadata
|
||||||
{ ID = "Query history", Name = "Query history" };
|
{ ID = "Query history", Name = "Query history" };
|
||||||
@ -61,7 +61,7 @@ namespace Wox.Storage
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
History.Add(new HistoryItem()
|
History.Add(new HistoryItem
|
||||||
{
|
{
|
||||||
Query = query,
|
Query = query,
|
||||||
ExecutedDateTime = DateTime.Now
|
ExecutedDateTime = DateTime.Now
|
||||||
|
@ -3,6 +3,7 @@ using System.IO;
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
using Wox.Infrastructure.Storage;
|
using Wox.Infrastructure.Storage;
|
||||||
|
using Wox.Plugin;
|
||||||
|
|
||||||
namespace Wox.Storage
|
namespace Wox.Storage
|
||||||
{
|
{
|
||||||
@ -20,7 +21,7 @@ namespace Wox.Storage
|
|||||||
get { return "TopMostRecords"; }
|
get { return "TopMostRecords"; }
|
||||||
}
|
}
|
||||||
|
|
||||||
internal bool IsTopMost(Plugin.Result result)
|
internal bool IsTopMost(Result result)
|
||||||
{
|
{
|
||||||
return records.Any(o => o.Value.Title == result.Title
|
return records.Any(o => o.Value.Title == result.Title
|
||||||
&& o.Value.SubTitle == result.SubTitle
|
&& o.Value.SubTitle == result.SubTitle
|
||||||
@ -28,7 +29,7 @@ namespace Wox.Storage
|
|||||||
&& o.Key == result.OriginQuery.RawQuery);
|
&& o.Key == result.OriginQuery.RawQuery);
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void Remove(Plugin.Result result)
|
internal void Remove(Result result)
|
||||||
{
|
{
|
||||||
if (records.ContainsKey(result.OriginQuery.RawQuery))
|
if (records.ContainsKey(result.OriginQuery.RawQuery))
|
||||||
{
|
{
|
||||||
@ -37,7 +38,7 @@ namespace Wox.Storage
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void AddOrUpdate(Plugin.Result result)
|
internal void AddOrUpdate(Result result)
|
||||||
{
|
{
|
||||||
if (records.ContainsKey(result.OriginQuery.RawQuery))
|
if (records.ContainsKey(result.OriginQuery.RawQuery))
|
||||||
{
|
{
|
||||||
@ -47,11 +48,11 @@ namespace Wox.Storage
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
records.Add(result.OriginQuery.RawQuery, new TopMostRecord()
|
records.Add(result.OriginQuery.RawQuery, new TopMostRecord
|
||||||
{
|
{
|
||||||
PluginID = result.PluginID,
|
PluginID = result.PluginID,
|
||||||
Title = result.Title,
|
Title = result.Title,
|
||||||
SubTitle = result.SubTitle,
|
SubTitle = result.SubTitle
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user