mirror of
https://github.com/Hofknecht/SystemTrayMenu.git
synced 2024-07-05 22:40:41 +12:00
Remove RowData dependency from FolderOptions
This commit is contained in:
parent
46bd18eb7e
commit
2e1cc20593
|
@ -1110,12 +1110,14 @@ namespace SystemTrayMenu.Business
|
|||
}
|
||||
|
||||
RowData rowDataRenamed = new(isFolder, rowData.IsAdditionalItem, false, 0, path);
|
||||
if (FolderOptions.IsHidden(rowDataRenamed))
|
||||
FolderOptions.ReadHiddenAttributes(rowDataRenamed.Path, out bool hasHiddenFlag, out bool isDirectoryToHide);
|
||||
if (isDirectoryToHide)
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
IconReader.RemoveIconFromCache(rowData.Path);
|
||||
rowDataRenamed.HiddenEntry = hasHiddenFlag;
|
||||
rowDataRenamed.ReadIcon(true);
|
||||
rowDatas.Add(rowDataRenamed);
|
||||
}
|
||||
|
@ -1188,11 +1190,13 @@ namespace SystemTrayMenu.Business
|
|||
bool isFolder = (attr & FileAttributes.Directory) == FileAttributes.Directory;
|
||||
bool isAddionalItem = Path.GetDirectoryName(e.FullPath) != Config.Path;
|
||||
RowData rowData = new(isFolder, isAddionalItem, false, 0, e.FullPath);
|
||||
if (FolderOptions.IsHidden(rowData))
|
||||
FolderOptions.ReadHiddenAttributes(rowData.Path, out bool hasHiddenFlag, out bool isDirectoryToHide);
|
||||
if (isDirectoryToHide)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
rowData.HiddenEntry = hasHiddenFlag;
|
||||
rowData.ReadIcon(true);
|
||||
|
||||
List<RowData> rowDatas = new()
|
||||
|
|
|
@ -18,14 +18,6 @@ namespace SystemTrayMenu.DataClasses
|
|||
{
|
||||
private static DateTime contextMenuClosed;
|
||||
|
||||
/// <summary>
|
||||
/// Initializes a new instance of the <see cref="RowData"/> class.
|
||||
/// empty dummy.
|
||||
/// </summary>
|
||||
internal RowData()
|
||||
{
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Initializes a new instance of the <see cref="RowData"/> class.
|
||||
/// (Related replace "\x00" see #171.)
|
||||
|
|
|
@ -125,12 +125,18 @@ namespace SystemTrayMenu.Helpers
|
|||
return;
|
||||
}
|
||||
|
||||
if (!menuData.IsNetworkRoot && FolderOptions.IsHidden(rowData))
|
||||
if (!menuData.IsNetworkRoot)
|
||||
{
|
||||
FolderOptions.ReadHiddenAttributes(rowData.Path, out bool hasHiddenFlag, out bool isDirectoryToHide);
|
||||
if (isDirectoryToHide)
|
||||
{
|
||||
rowDatasToRemove.Add(rowData);
|
||||
continue;
|
||||
}
|
||||
|
||||
rowData.HiddenEntry = hasHiddenFlag;
|
||||
}
|
||||
|
||||
rowData.ReadIcon(true);
|
||||
}
|
||||
|
||||
|
|
|
@ -9,7 +9,6 @@ namespace SystemTrayMenu.Utilities
|
|||
using System.Reflection;
|
||||
using System.Runtime.InteropServices;
|
||||
using Shell32;
|
||||
using SystemTrayMenu.DataClasses;
|
||||
|
||||
internal static class FolderOptions
|
||||
{
|
||||
|
@ -54,40 +53,39 @@ namespace SystemTrayMenu.Utilities
|
|||
}
|
||||
}
|
||||
|
||||
internal static bool IsHidden(RowData rowData)
|
||||
internal static void ReadHiddenAttributes(string? path, out bool hasHiddenFlag, out bool isDirectoryToHide)
|
||||
{
|
||||
bool isDirectoryToHide = false;
|
||||
if (rowData.Path == null || rowData.Path.Length >= 260)
|
||||
isDirectoryToHide = false;
|
||||
hasHiddenFlag = false;
|
||||
if (path == null || path.Length >= 260)
|
||||
{
|
||||
Log.Info($"path too long (>=260):'{rowData.Path}'");
|
||||
return isDirectoryToHide;
|
||||
Log.Info($"path too long (>=260):'{path}'");
|
||||
return;
|
||||
}
|
||||
|
||||
try
|
||||
{
|
||||
FileAttributes attributes = File.GetAttributes(rowData.Path);
|
||||
rowData.HiddenEntry = attributes.HasFlag(FileAttributes.Hidden);
|
||||
bool systemEntry = attributes.HasFlag(
|
||||
FileAttributes attributes = File.GetAttributes(path);
|
||||
hasHiddenFlag = attributes.HasFlag(FileAttributes.Hidden);
|
||||
bool hasSystemFlag = attributes.HasFlag(
|
||||
FileAttributes.Hidden | FileAttributes.System);
|
||||
if (Properties.Settings.Default.SystemSettingsShowHiddenFiles)
|
||||
{
|
||||
if ((hideHiddenEntries && rowData.HiddenEntry) ||
|
||||
(hideSystemEntries && systemEntry))
|
||||
if ((hideHiddenEntries && hasHiddenFlag) ||
|
||||
(hideSystemEntries && hasSystemFlag))
|
||||
{
|
||||
isDirectoryToHide = true;
|
||||
}
|
||||
}
|
||||
else if (rowData.HiddenEntry && Properties.Settings.Default.NeverShowHiddenFiles)
|
||||
else if (hasHiddenFlag && Properties.Settings.Default.NeverShowHiddenFiles)
|
||||
{
|
||||
isDirectoryToHide = true;
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
Log.Warn($"path:'{rowData.Path}'", ex);
|
||||
}
|
||||
|
||||
return isDirectoryToHide;
|
||||
Log.Warn($"path:'{path}'", ex);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue