PowerToys/Wox.Plugin.SystemPlugins/Program/ProgramSources/FileSystemProgramSource.cs

76 lines
2.3 KiB
C#
Raw Normal View History

using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.IO;
2014-03-30 11:16:44 +08:00
using System.Linq;
2014-09-19 16:57:48 +08:00
using log4net.Repository.Hierarchy;
2014-03-23 16:17:41 +08:00
using Wox.Infrastructure.Storage.UserSettings;
2014-09-19 16:57:48 +08:00
using Log = Wox.Infrastructure.Logger.Log;
2014-03-30 11:16:44 +08:00
namespace Wox.Plugin.SystemPlugins.Program.ProgramSources
{
[Serializable]
public class FileSystemProgramSource : AbstractProgramSource
{
private string baseDirectory;
public FileSystemProgramSource(string baseDirectory)
{
this.baseDirectory = baseDirectory;
}
public FileSystemProgramSource(ProgramSource source):this(source.Location)
{
2014-03-19 20:16:20 +08:00
this.BonusPoints = source.BonusPoints;
}
public override List<Program> LoadPrograms()
{
List<Program> list = new List<Program>();
if (Directory.Exists(baseDirectory))
{
GetAppFromDirectory(baseDirectory, list);
FileChangeWatcher.AddWatch(baseDirectory);
}
return list;
}
private void GetAppFromDirectory(string path, List<Program> list)
{
try
{
foreach (string file in Directory.GetFiles(path))
{
if (UserSettingStorage.Instance.ProgramSuffixes.Split(';').Any(o => file.EndsWith("." + o)))
{
Program p = CreateEntry(file);
list.Add(p);
}
}
foreach (var subDirectory in Directory.GetDirectories(path))
{
GetAppFromDirectory(subDirectory, list);
}
}
catch (UnauthorizedAccessException e)
{
2014-09-19 16:57:48 +08:00
Log.Warn(string.Format("Can't access to directory {0}", path));
}
catch (DirectoryNotFoundException e)
{
2014-09-19 16:57:48 +08:00
Log.Warn(string.Format("Directory {0} doesn't exist", path));
}
catch (PathTooLongException e)
{
Log.Warn(string.Format("File path too long: {0}", e.Message));
}
}
2014-03-19 20:16:20 +08:00
public override string ToString()
{
return typeof(FileSystemProgramSource).Name + ":" + this.baseDirectory;
2014-03-19 20:16:20 +08:00
}
}
}