From 5f42e3a08161e6201b650911efc72d3aa24152c1 Mon Sep 17 00:00:00 2001 From: 0x5BFA <62196528+0x5bfa@users.noreply.github.com> Date: Sun, 9 Jul 2023 14:13:50 +0900 Subject: [PATCH 01/12] Move storage stuff into Utils.Storage --- src/Files.App/Utils/{ => Global}/NetworkDrivesAPI.cs | 0 src/Files.App/Utils/{ => Global}/QuickAccessManager.cs | 0 src/Files.App/Utils/{ => Global}/WSLDistroManager.cs | 0 src/Files.App/Utils/{ => Global}/WallpaperHelpers.cs | 0 src/Files.App/Utils/{ => Global}/WindowsStorageDeviceWatcher.cs | 0 .../Storage/Cache/IStorageCacheController.cs} | 0 .../Storage/Cache/StorageCacheController.cs} | 0 .../Storage/Collection}/BlockingListEnumerator.cs | 0 .../Storage/Collection}/BulkConcurrentObservableCollection.cs | 0 .../Storage/Collection}/GroupedCollection.cs | 0 .../Storage/Collection}/GroupingHelper.cs | 0 .../Storage/Collection}/SortingHelper.cs | 0 .../Enumerators}/UniversalStorageEnumerator.cs | 0 .../Enumerators}/Win32StorageEnumerator.cs | 0 .../{Helpers/Storage => Utils/Storage/Helpers}/DeviceManager.cs | 0 .../{Helpers/Storage => Utils/Storage/Helpers}/DriveHelpers.cs | 0 .../Storage => Utils/Storage/Helpers}/ErrorCodeConverter.cs | 0 .../Storage => Utils/Storage/Helpers}/FileOperationsHelpers.cs | 0 .../Storage => Utils/Storage/Helpers}/FilePropertiesHelpers.cs | 0 .../Storage => Utils/Storage/Helpers}/FileSecurityHelpers.cs | 0 .../Storage => Utils/Storage/Helpers}/FileThumbnailHelper.cs | 0 .../{StorageFileHelpers => Storage/Helpers}/FilesystemResult.cs | 0 .../{StorageFileHelpers => Storage/Helpers}/FilesystemTasks.cs | 0 .../{Helpers/Storage => Utils/Storage/Helpers}/FolderHelpers.cs | 0 src/Files.App/Utils/{ => Storage/Helpers}/FtpHelpers.cs | 0 .../Helpers}/IStorageItemWithPath.cs | 0 .../Helpers}/StorageFileExtensions.cs | 0 .../Helpers}/StorageFileWithPath.cs | 0 .../Helpers}/StorageFolderWithPath.cs | 0 .../{Helpers/Storage => Utils/Storage/Helpers}/StorageHelpers.cs | 0 .../Storage => Utils/Storage/Helpers}/StorageItemIconHelpers.cs | 0 .../Storage => Utils/Storage/Helpers}/StorageSenseHelper.cs | 0 .../Utils/{StorageHistory => Storage/History}/IStorageHistory.cs | 0 .../History}/IStorageHistoryOperations.cs | 0 .../Utils/{StorageHistory => Storage/History}/StorageHistory.cs | 0 .../Helpers => Storage/History}/StorageHistoryHelpers.cs | 0 .../History}/StorageHistoryOperations.cs | 0 .../{StorageHistory => Storage/History}/StorageHistoryWrapper.cs | 0 .../Operations}/FileSystemProgress.cs | 0 .../Helpers => Storage/Operations}/FilesystemHelpers.cs | 0 .../Operations}/FilesystemOperations.cs | 0 .../Helpers => Storage/Operations}/IFilesystemHelpers.cs | 0 .../Operations}/IFilesystemOperations.cs | 0 .../Operations}/ShellFilesystemOperations.cs | 0 src/Files.App/Utils/{ => Storage}/Search/FolderSearch.cs | 0 src/Files.App/Utils/{ => Storage}/Security/AccessControlEntry.cs | 0 .../Utils/{ => Storage}/Security/AccessControlEntryFlags.cs | 0 .../Utils/{ => Storage}/Security/AccessControlEntryType.cs | 0 src/Files.App/Utils/{ => Storage}/Security/AccessControlList.cs | 0 src/Files.App/Utils/{ => Storage}/Security/AccessMaskFlags.cs | 0 src/Files.App/Utils/{ => Storage}/Security/AccessMaskItem.cs | 0 src/Files.App/Utils/{ => Storage}/Security/Principal.cs | 0 src/Files.App/Utils/{ => Storage}/Security/PrincipalType.cs | 0 .../StorageBaseItems}/BaseBasicProperties.cs | 0 .../StorageBaseItems}/BaseBasicStorageItemExtraProperties.cs | 0 .../{BaseStorage => Storage/StorageBaseItems}/BaseStorageFile.cs | 0 .../StorageBaseItems}/BaseStorageFolder.cs | 0 .../StorageBaseItems}/BaseStorageItemExtraProperties.cs | 0 .../{BaseStorage => Storage/StorageBaseItems}/IBaseStorageFile.cs | 0 .../StorageBaseItems}/IBaseStorageFolder.cs | 0 .../StorageBaseItems}/ICreateFileWithStream.cs | 0 .../Utils/{ => Storage}/StorageItems/BaseQueryResults.cs | 0 src/Files.App/Utils/{ => Storage}/StorageItems/FtpStorageFile.cs | 0 .../Utils/{ => Storage}/StorageItems/FtpStorageFolder.cs | 0 .../Utils/{ => Storage}/StorageItems/NativeStorageFile.cs | 0 .../Utils/{ => Storage}/StorageItems/ShellStorageFile.cs | 0 .../Utils/{ => Storage}/StorageItems/ShellStorageFolder.cs | 0 .../Utils/{ => Storage}/StorageItems/StreamWithContentType.cs | 0 .../Utils/{ => Storage}/StorageItems/SystemStorageFile.cs | 0 .../Utils/{ => Storage}/StorageItems/SystemStorageFolder.cs | 0 .../Utils/{ => Storage}/StorageItems/VirtualStorageFile.cs | 0 .../Utils/{ => Storage}/StorageItems/VirtualStorageFolder.cs | 0 .../Utils/{ => Storage}/StorageItems/VirtualStorageItem.cs | 0 src/Files.App/Utils/{ => Storage}/StorageItems/ZipStorageFile.cs | 0 .../Utils/{ => Storage}/StorageItems/ZipStorageFolder.cs | 0 75 files changed, 0 insertions(+), 0 deletions(-) rename src/Files.App/Utils/{ => Global}/NetworkDrivesAPI.cs (100%) rename src/Files.App/Utils/{ => Global}/QuickAccessManager.cs (100%) rename src/Files.App/Utils/{ => Global}/WSLDistroManager.cs (100%) rename src/Files.App/Utils/{ => Global}/WallpaperHelpers.cs (100%) rename src/Files.App/Utils/{ => Global}/WindowsStorageDeviceWatcher.cs (100%) rename src/Files.App/{Helpers/StorageCache/IFileListCache.cs => Utils/Storage/Cache/IStorageCacheController.cs} (100%) rename src/Files.App/{Helpers/StorageCache/FileListCacheController.cs => Utils/Storage/Cache/StorageCacheController.cs} (100%) rename src/Files.App/{Helpers/StorageItemCollection => Utils/Storage/Collection}/BlockingListEnumerator.cs (100%) rename src/Files.App/{Helpers/StorageItemCollection => Utils/Storage/Collection}/BulkConcurrentObservableCollection.cs (100%) rename src/Files.App/{Helpers/StorageItemCollection => Utils/Storage/Collection}/GroupedCollection.cs (100%) rename src/Files.App/{Helpers/StorageItemCollection => Utils/Storage/Collection}/GroupingHelper.cs (100%) rename src/Files.App/{Helpers/StorageItemCollection => Utils/Storage/Collection}/SortingHelper.cs (100%) rename src/Files.App/Utils/{StorageEnumerators => Storage/Enumerators}/UniversalStorageEnumerator.cs (100%) rename src/Files.App/Utils/{StorageEnumerators => Storage/Enumerators}/Win32StorageEnumerator.cs (100%) rename src/Files.App/{Helpers/Storage => Utils/Storage/Helpers}/DeviceManager.cs (100%) rename src/Files.App/{Helpers/Storage => Utils/Storage/Helpers}/DriveHelpers.cs (100%) rename src/Files.App/{Helpers/Storage => Utils/Storage/Helpers}/ErrorCodeConverter.cs (100%) rename src/Files.App/{Helpers/Storage => Utils/Storage/Helpers}/FileOperationsHelpers.cs (100%) rename src/Files.App/{Helpers/Storage => Utils/Storage/Helpers}/FilePropertiesHelpers.cs (100%) rename src/Files.App/{Helpers/Storage => Utils/Storage/Helpers}/FileSecurityHelpers.cs (100%) rename src/Files.App/{Helpers/Storage => Utils/Storage/Helpers}/FileThumbnailHelper.cs (100%) rename src/Files.App/Utils/{StorageFileHelpers => Storage/Helpers}/FilesystemResult.cs (100%) rename src/Files.App/Utils/{StorageFileHelpers => Storage/Helpers}/FilesystemTasks.cs (100%) rename src/Files.App/{Helpers/Storage => Utils/Storage/Helpers}/FolderHelpers.cs (100%) rename src/Files.App/Utils/{ => Storage/Helpers}/FtpHelpers.cs (100%) rename src/Files.App/Utils/{StorageFileHelpers => Storage/Helpers}/IStorageItemWithPath.cs (100%) rename src/Files.App/Utils/{StorageFileHelpers => Storage/Helpers}/StorageFileExtensions.cs (100%) rename src/Files.App/Utils/{StorageFileHelpers => Storage/Helpers}/StorageFileWithPath.cs (100%) rename src/Files.App/Utils/{StorageFileHelpers => Storage/Helpers}/StorageFolderWithPath.cs (100%) rename src/Files.App/{Helpers/Storage => Utils/Storage/Helpers}/StorageHelpers.cs (100%) rename src/Files.App/{Helpers/Storage => Utils/Storage/Helpers}/StorageItemIconHelpers.cs (100%) rename src/Files.App/{Helpers/Storage => Utils/Storage/Helpers}/StorageSenseHelper.cs (100%) rename src/Files.App/Utils/{StorageHistory => Storage/History}/IStorageHistory.cs (100%) rename src/Files.App/Utils/{StorageHistory => Storage/History}/IStorageHistoryOperations.cs (100%) rename src/Files.App/Utils/{StorageHistory => Storage/History}/StorageHistory.cs (100%) rename src/Files.App/Utils/{StorageHistory/Helpers => Storage/History}/StorageHistoryHelpers.cs (100%) rename src/Files.App/Utils/{StorageHistory => Storage/History}/StorageHistoryOperations.cs (100%) rename src/Files.App/Utils/{StorageHistory => Storage/History}/StorageHistoryWrapper.cs (100%) rename src/Files.App/Utils/{FilesystemOperations => Storage/Operations}/FileSystemProgress.cs (100%) rename src/Files.App/Utils/{FilesystemOperations/Helpers => Storage/Operations}/FilesystemHelpers.cs (100%) rename src/Files.App/Utils/{FilesystemOperations => Storage/Operations}/FilesystemOperations.cs (100%) rename src/Files.App/Utils/{FilesystemOperations/Helpers => Storage/Operations}/IFilesystemHelpers.cs (100%) rename src/Files.App/Utils/{FilesystemOperations => Storage/Operations}/IFilesystemOperations.cs (100%) rename src/Files.App/Utils/{FilesystemOperations => Storage/Operations}/ShellFilesystemOperations.cs (100%) rename src/Files.App/Utils/{ => Storage}/Search/FolderSearch.cs (100%) rename src/Files.App/Utils/{ => Storage}/Security/AccessControlEntry.cs (100%) rename src/Files.App/Utils/{ => Storage}/Security/AccessControlEntryFlags.cs (100%) rename src/Files.App/Utils/{ => Storage}/Security/AccessControlEntryType.cs (100%) rename src/Files.App/Utils/{ => Storage}/Security/AccessControlList.cs (100%) rename src/Files.App/Utils/{ => Storage}/Security/AccessMaskFlags.cs (100%) rename src/Files.App/Utils/{ => Storage}/Security/AccessMaskItem.cs (100%) rename src/Files.App/Utils/{ => Storage}/Security/Principal.cs (100%) rename src/Files.App/Utils/{ => Storage}/Security/PrincipalType.cs (100%) rename src/Files.App/Utils/{BaseStorage => Storage/StorageBaseItems}/BaseBasicProperties.cs (100%) rename src/Files.App/Utils/{BaseStorage => Storage/StorageBaseItems}/BaseBasicStorageItemExtraProperties.cs (100%) rename src/Files.App/Utils/{BaseStorage => Storage/StorageBaseItems}/BaseStorageFile.cs (100%) rename src/Files.App/Utils/{BaseStorage => Storage/StorageBaseItems}/BaseStorageFolder.cs (100%) rename src/Files.App/Utils/{BaseStorage => Storage/StorageBaseItems}/BaseStorageItemExtraProperties.cs (100%) rename src/Files.App/Utils/{BaseStorage => Storage/StorageBaseItems}/IBaseStorageFile.cs (100%) rename src/Files.App/Utils/{BaseStorage => Storage/StorageBaseItems}/IBaseStorageFolder.cs (100%) rename src/Files.App/Utils/{BaseStorage => Storage/StorageBaseItems}/ICreateFileWithStream.cs (100%) rename src/Files.App/Utils/{ => Storage}/StorageItems/BaseQueryResults.cs (100%) rename src/Files.App/Utils/{ => Storage}/StorageItems/FtpStorageFile.cs (100%) rename src/Files.App/Utils/{ => Storage}/StorageItems/FtpStorageFolder.cs (100%) rename src/Files.App/Utils/{ => Storage}/StorageItems/NativeStorageFile.cs (100%) rename src/Files.App/Utils/{ => Storage}/StorageItems/ShellStorageFile.cs (100%) rename src/Files.App/Utils/{ => Storage}/StorageItems/ShellStorageFolder.cs (100%) rename src/Files.App/Utils/{ => Storage}/StorageItems/StreamWithContentType.cs (100%) rename src/Files.App/Utils/{ => Storage}/StorageItems/SystemStorageFile.cs (100%) rename src/Files.App/Utils/{ => Storage}/StorageItems/SystemStorageFolder.cs (100%) rename src/Files.App/Utils/{ => Storage}/StorageItems/VirtualStorageFile.cs (100%) rename src/Files.App/Utils/{ => Storage}/StorageItems/VirtualStorageFolder.cs (100%) rename src/Files.App/Utils/{ => Storage}/StorageItems/VirtualStorageItem.cs (100%) rename src/Files.App/Utils/{ => Storage}/StorageItems/ZipStorageFile.cs (100%) rename src/Files.App/Utils/{ => Storage}/StorageItems/ZipStorageFolder.cs (100%) diff --git a/src/Files.App/Utils/NetworkDrivesAPI.cs b/src/Files.App/Utils/Global/NetworkDrivesAPI.cs similarity index 100% rename from src/Files.App/Utils/NetworkDrivesAPI.cs rename to src/Files.App/Utils/Global/NetworkDrivesAPI.cs diff --git a/src/Files.App/Utils/QuickAccessManager.cs b/src/Files.App/Utils/Global/QuickAccessManager.cs similarity index 100% rename from src/Files.App/Utils/QuickAccessManager.cs rename to src/Files.App/Utils/Global/QuickAccessManager.cs diff --git a/src/Files.App/Utils/WSLDistroManager.cs b/src/Files.App/Utils/Global/WSLDistroManager.cs similarity index 100% rename from src/Files.App/Utils/WSLDistroManager.cs rename to src/Files.App/Utils/Global/WSLDistroManager.cs diff --git a/src/Files.App/Utils/WallpaperHelpers.cs b/src/Files.App/Utils/Global/WallpaperHelpers.cs similarity index 100% rename from src/Files.App/Utils/WallpaperHelpers.cs rename to src/Files.App/Utils/Global/WallpaperHelpers.cs diff --git a/src/Files.App/Utils/WindowsStorageDeviceWatcher.cs b/src/Files.App/Utils/Global/WindowsStorageDeviceWatcher.cs similarity index 100% rename from src/Files.App/Utils/WindowsStorageDeviceWatcher.cs rename to src/Files.App/Utils/Global/WindowsStorageDeviceWatcher.cs diff --git a/src/Files.App/Helpers/StorageCache/IFileListCache.cs b/src/Files.App/Utils/Storage/Cache/IStorageCacheController.cs similarity index 100% rename from src/Files.App/Helpers/StorageCache/IFileListCache.cs rename to src/Files.App/Utils/Storage/Cache/IStorageCacheController.cs diff --git a/src/Files.App/Helpers/StorageCache/FileListCacheController.cs b/src/Files.App/Utils/Storage/Cache/StorageCacheController.cs similarity index 100% rename from src/Files.App/Helpers/StorageCache/FileListCacheController.cs rename to src/Files.App/Utils/Storage/Cache/StorageCacheController.cs diff --git a/src/Files.App/Helpers/StorageItemCollection/BlockingListEnumerator.cs b/src/Files.App/Utils/Storage/Collection/BlockingListEnumerator.cs similarity index 100% rename from src/Files.App/Helpers/StorageItemCollection/BlockingListEnumerator.cs rename to src/Files.App/Utils/Storage/Collection/BlockingListEnumerator.cs diff --git a/src/Files.App/Helpers/StorageItemCollection/BulkConcurrentObservableCollection.cs b/src/Files.App/Utils/Storage/Collection/BulkConcurrentObservableCollection.cs similarity index 100% rename from src/Files.App/Helpers/StorageItemCollection/BulkConcurrentObservableCollection.cs rename to src/Files.App/Utils/Storage/Collection/BulkConcurrentObservableCollection.cs diff --git a/src/Files.App/Helpers/StorageItemCollection/GroupedCollection.cs b/src/Files.App/Utils/Storage/Collection/GroupedCollection.cs similarity index 100% rename from src/Files.App/Helpers/StorageItemCollection/GroupedCollection.cs rename to src/Files.App/Utils/Storage/Collection/GroupedCollection.cs diff --git a/src/Files.App/Helpers/StorageItemCollection/GroupingHelper.cs b/src/Files.App/Utils/Storage/Collection/GroupingHelper.cs similarity index 100% rename from src/Files.App/Helpers/StorageItemCollection/GroupingHelper.cs rename to src/Files.App/Utils/Storage/Collection/GroupingHelper.cs diff --git a/src/Files.App/Helpers/StorageItemCollection/SortingHelper.cs b/src/Files.App/Utils/Storage/Collection/SortingHelper.cs similarity index 100% rename from src/Files.App/Helpers/StorageItemCollection/SortingHelper.cs rename to src/Files.App/Utils/Storage/Collection/SortingHelper.cs diff --git a/src/Files.App/Utils/StorageEnumerators/UniversalStorageEnumerator.cs b/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs similarity index 100% rename from src/Files.App/Utils/StorageEnumerators/UniversalStorageEnumerator.cs rename to src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs diff --git a/src/Files.App/Utils/StorageEnumerators/Win32StorageEnumerator.cs b/src/Files.App/Utils/Storage/Enumerators/Win32StorageEnumerator.cs similarity index 100% rename from src/Files.App/Utils/StorageEnumerators/Win32StorageEnumerator.cs rename to src/Files.App/Utils/Storage/Enumerators/Win32StorageEnumerator.cs diff --git a/src/Files.App/Helpers/Storage/DeviceManager.cs b/src/Files.App/Utils/Storage/Helpers/DeviceManager.cs similarity index 100% rename from src/Files.App/Helpers/Storage/DeviceManager.cs rename to src/Files.App/Utils/Storage/Helpers/DeviceManager.cs diff --git a/src/Files.App/Helpers/Storage/DriveHelpers.cs b/src/Files.App/Utils/Storage/Helpers/DriveHelpers.cs similarity index 100% rename from src/Files.App/Helpers/Storage/DriveHelpers.cs rename to src/Files.App/Utils/Storage/Helpers/DriveHelpers.cs diff --git a/src/Files.App/Helpers/Storage/ErrorCodeConverter.cs b/src/Files.App/Utils/Storage/Helpers/ErrorCodeConverter.cs similarity index 100% rename from src/Files.App/Helpers/Storage/ErrorCodeConverter.cs rename to src/Files.App/Utils/Storage/Helpers/ErrorCodeConverter.cs diff --git a/src/Files.App/Helpers/Storage/FileOperationsHelpers.cs b/src/Files.App/Utils/Storage/Helpers/FileOperationsHelpers.cs similarity index 100% rename from src/Files.App/Helpers/Storage/FileOperationsHelpers.cs rename to src/Files.App/Utils/Storage/Helpers/FileOperationsHelpers.cs diff --git a/src/Files.App/Helpers/Storage/FilePropertiesHelpers.cs b/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs similarity index 100% rename from src/Files.App/Helpers/Storage/FilePropertiesHelpers.cs rename to src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs diff --git a/src/Files.App/Helpers/Storage/FileSecurityHelpers.cs b/src/Files.App/Utils/Storage/Helpers/FileSecurityHelpers.cs similarity index 100% rename from src/Files.App/Helpers/Storage/FileSecurityHelpers.cs rename to src/Files.App/Utils/Storage/Helpers/FileSecurityHelpers.cs diff --git a/src/Files.App/Helpers/Storage/FileThumbnailHelper.cs b/src/Files.App/Utils/Storage/Helpers/FileThumbnailHelper.cs similarity index 100% rename from src/Files.App/Helpers/Storage/FileThumbnailHelper.cs rename to src/Files.App/Utils/Storage/Helpers/FileThumbnailHelper.cs diff --git a/src/Files.App/Utils/StorageFileHelpers/FilesystemResult.cs b/src/Files.App/Utils/Storage/Helpers/FilesystemResult.cs similarity index 100% rename from src/Files.App/Utils/StorageFileHelpers/FilesystemResult.cs rename to src/Files.App/Utils/Storage/Helpers/FilesystemResult.cs diff --git a/src/Files.App/Utils/StorageFileHelpers/FilesystemTasks.cs b/src/Files.App/Utils/Storage/Helpers/FilesystemTasks.cs similarity index 100% rename from src/Files.App/Utils/StorageFileHelpers/FilesystemTasks.cs rename to src/Files.App/Utils/Storage/Helpers/FilesystemTasks.cs diff --git a/src/Files.App/Helpers/Storage/FolderHelpers.cs b/src/Files.App/Utils/Storage/Helpers/FolderHelpers.cs similarity index 100% rename from src/Files.App/Helpers/Storage/FolderHelpers.cs rename to src/Files.App/Utils/Storage/Helpers/FolderHelpers.cs diff --git a/src/Files.App/Utils/FtpHelpers.cs b/src/Files.App/Utils/Storage/Helpers/FtpHelpers.cs similarity index 100% rename from src/Files.App/Utils/FtpHelpers.cs rename to src/Files.App/Utils/Storage/Helpers/FtpHelpers.cs diff --git a/src/Files.App/Utils/StorageFileHelpers/IStorageItemWithPath.cs b/src/Files.App/Utils/Storage/Helpers/IStorageItemWithPath.cs similarity index 100% rename from src/Files.App/Utils/StorageFileHelpers/IStorageItemWithPath.cs rename to src/Files.App/Utils/Storage/Helpers/IStorageItemWithPath.cs diff --git a/src/Files.App/Utils/StorageFileHelpers/StorageFileExtensions.cs b/src/Files.App/Utils/Storage/Helpers/StorageFileExtensions.cs similarity index 100% rename from src/Files.App/Utils/StorageFileHelpers/StorageFileExtensions.cs rename to src/Files.App/Utils/Storage/Helpers/StorageFileExtensions.cs diff --git a/src/Files.App/Utils/StorageFileHelpers/StorageFileWithPath.cs b/src/Files.App/Utils/Storage/Helpers/StorageFileWithPath.cs similarity index 100% rename from src/Files.App/Utils/StorageFileHelpers/StorageFileWithPath.cs rename to src/Files.App/Utils/Storage/Helpers/StorageFileWithPath.cs diff --git a/src/Files.App/Utils/StorageFileHelpers/StorageFolderWithPath.cs b/src/Files.App/Utils/Storage/Helpers/StorageFolderWithPath.cs similarity index 100% rename from src/Files.App/Utils/StorageFileHelpers/StorageFolderWithPath.cs rename to src/Files.App/Utils/Storage/Helpers/StorageFolderWithPath.cs diff --git a/src/Files.App/Helpers/Storage/StorageHelpers.cs b/src/Files.App/Utils/Storage/Helpers/StorageHelpers.cs similarity index 100% rename from src/Files.App/Helpers/Storage/StorageHelpers.cs rename to src/Files.App/Utils/Storage/Helpers/StorageHelpers.cs diff --git a/src/Files.App/Helpers/Storage/StorageItemIconHelpers.cs b/src/Files.App/Utils/Storage/Helpers/StorageItemIconHelpers.cs similarity index 100% rename from src/Files.App/Helpers/Storage/StorageItemIconHelpers.cs rename to src/Files.App/Utils/Storage/Helpers/StorageItemIconHelpers.cs diff --git a/src/Files.App/Helpers/Storage/StorageSenseHelper.cs b/src/Files.App/Utils/Storage/Helpers/StorageSenseHelper.cs similarity index 100% rename from src/Files.App/Helpers/Storage/StorageSenseHelper.cs rename to src/Files.App/Utils/Storage/Helpers/StorageSenseHelper.cs diff --git a/src/Files.App/Utils/StorageHistory/IStorageHistory.cs b/src/Files.App/Utils/Storage/History/IStorageHistory.cs similarity index 100% rename from src/Files.App/Utils/StorageHistory/IStorageHistory.cs rename to src/Files.App/Utils/Storage/History/IStorageHistory.cs diff --git a/src/Files.App/Utils/StorageHistory/IStorageHistoryOperations.cs b/src/Files.App/Utils/Storage/History/IStorageHistoryOperations.cs similarity index 100% rename from src/Files.App/Utils/StorageHistory/IStorageHistoryOperations.cs rename to src/Files.App/Utils/Storage/History/IStorageHistoryOperations.cs diff --git a/src/Files.App/Utils/StorageHistory/StorageHistory.cs b/src/Files.App/Utils/Storage/History/StorageHistory.cs similarity index 100% rename from src/Files.App/Utils/StorageHistory/StorageHistory.cs rename to src/Files.App/Utils/Storage/History/StorageHistory.cs diff --git a/src/Files.App/Utils/StorageHistory/Helpers/StorageHistoryHelpers.cs b/src/Files.App/Utils/Storage/History/StorageHistoryHelpers.cs similarity index 100% rename from src/Files.App/Utils/StorageHistory/Helpers/StorageHistoryHelpers.cs rename to src/Files.App/Utils/Storage/History/StorageHistoryHelpers.cs diff --git a/src/Files.App/Utils/StorageHistory/StorageHistoryOperations.cs b/src/Files.App/Utils/Storage/History/StorageHistoryOperations.cs similarity index 100% rename from src/Files.App/Utils/StorageHistory/StorageHistoryOperations.cs rename to src/Files.App/Utils/Storage/History/StorageHistoryOperations.cs diff --git a/src/Files.App/Utils/StorageHistory/StorageHistoryWrapper.cs b/src/Files.App/Utils/Storage/History/StorageHistoryWrapper.cs similarity index 100% rename from src/Files.App/Utils/StorageHistory/StorageHistoryWrapper.cs rename to src/Files.App/Utils/Storage/History/StorageHistoryWrapper.cs diff --git a/src/Files.App/Utils/FilesystemOperations/FileSystemProgress.cs b/src/Files.App/Utils/Storage/Operations/FileSystemProgress.cs similarity index 100% rename from src/Files.App/Utils/FilesystemOperations/FileSystemProgress.cs rename to src/Files.App/Utils/Storage/Operations/FileSystemProgress.cs diff --git a/src/Files.App/Utils/FilesystemOperations/Helpers/FilesystemHelpers.cs b/src/Files.App/Utils/Storage/Operations/FilesystemHelpers.cs similarity index 100% rename from src/Files.App/Utils/FilesystemOperations/Helpers/FilesystemHelpers.cs rename to src/Files.App/Utils/Storage/Operations/FilesystemHelpers.cs diff --git a/src/Files.App/Utils/FilesystemOperations/FilesystemOperations.cs b/src/Files.App/Utils/Storage/Operations/FilesystemOperations.cs similarity index 100% rename from src/Files.App/Utils/FilesystemOperations/FilesystemOperations.cs rename to src/Files.App/Utils/Storage/Operations/FilesystemOperations.cs diff --git a/src/Files.App/Utils/FilesystemOperations/Helpers/IFilesystemHelpers.cs b/src/Files.App/Utils/Storage/Operations/IFilesystemHelpers.cs similarity index 100% rename from src/Files.App/Utils/FilesystemOperations/Helpers/IFilesystemHelpers.cs rename to src/Files.App/Utils/Storage/Operations/IFilesystemHelpers.cs diff --git a/src/Files.App/Utils/FilesystemOperations/IFilesystemOperations.cs b/src/Files.App/Utils/Storage/Operations/IFilesystemOperations.cs similarity index 100% rename from src/Files.App/Utils/FilesystemOperations/IFilesystemOperations.cs rename to src/Files.App/Utils/Storage/Operations/IFilesystemOperations.cs diff --git a/src/Files.App/Utils/FilesystemOperations/ShellFilesystemOperations.cs b/src/Files.App/Utils/Storage/Operations/ShellFilesystemOperations.cs similarity index 100% rename from src/Files.App/Utils/FilesystemOperations/ShellFilesystemOperations.cs rename to src/Files.App/Utils/Storage/Operations/ShellFilesystemOperations.cs diff --git a/src/Files.App/Utils/Search/FolderSearch.cs b/src/Files.App/Utils/Storage/Search/FolderSearch.cs similarity index 100% rename from src/Files.App/Utils/Search/FolderSearch.cs rename to src/Files.App/Utils/Storage/Search/FolderSearch.cs diff --git a/src/Files.App/Utils/Security/AccessControlEntry.cs b/src/Files.App/Utils/Storage/Security/AccessControlEntry.cs similarity index 100% rename from src/Files.App/Utils/Security/AccessControlEntry.cs rename to src/Files.App/Utils/Storage/Security/AccessControlEntry.cs diff --git a/src/Files.App/Utils/Security/AccessControlEntryFlags.cs b/src/Files.App/Utils/Storage/Security/AccessControlEntryFlags.cs similarity index 100% rename from src/Files.App/Utils/Security/AccessControlEntryFlags.cs rename to src/Files.App/Utils/Storage/Security/AccessControlEntryFlags.cs diff --git a/src/Files.App/Utils/Security/AccessControlEntryType.cs b/src/Files.App/Utils/Storage/Security/AccessControlEntryType.cs similarity index 100% rename from src/Files.App/Utils/Security/AccessControlEntryType.cs rename to src/Files.App/Utils/Storage/Security/AccessControlEntryType.cs diff --git a/src/Files.App/Utils/Security/AccessControlList.cs b/src/Files.App/Utils/Storage/Security/AccessControlList.cs similarity index 100% rename from src/Files.App/Utils/Security/AccessControlList.cs rename to src/Files.App/Utils/Storage/Security/AccessControlList.cs diff --git a/src/Files.App/Utils/Security/AccessMaskFlags.cs b/src/Files.App/Utils/Storage/Security/AccessMaskFlags.cs similarity index 100% rename from src/Files.App/Utils/Security/AccessMaskFlags.cs rename to src/Files.App/Utils/Storage/Security/AccessMaskFlags.cs diff --git a/src/Files.App/Utils/Security/AccessMaskItem.cs b/src/Files.App/Utils/Storage/Security/AccessMaskItem.cs similarity index 100% rename from src/Files.App/Utils/Security/AccessMaskItem.cs rename to src/Files.App/Utils/Storage/Security/AccessMaskItem.cs diff --git a/src/Files.App/Utils/Security/Principal.cs b/src/Files.App/Utils/Storage/Security/Principal.cs similarity index 100% rename from src/Files.App/Utils/Security/Principal.cs rename to src/Files.App/Utils/Storage/Security/Principal.cs diff --git a/src/Files.App/Utils/Security/PrincipalType.cs b/src/Files.App/Utils/Storage/Security/PrincipalType.cs similarity index 100% rename from src/Files.App/Utils/Security/PrincipalType.cs rename to src/Files.App/Utils/Storage/Security/PrincipalType.cs diff --git a/src/Files.App/Utils/BaseStorage/BaseBasicProperties.cs b/src/Files.App/Utils/Storage/StorageBaseItems/BaseBasicProperties.cs similarity index 100% rename from src/Files.App/Utils/BaseStorage/BaseBasicProperties.cs rename to src/Files.App/Utils/Storage/StorageBaseItems/BaseBasicProperties.cs diff --git a/src/Files.App/Utils/BaseStorage/BaseBasicStorageItemExtraProperties.cs b/src/Files.App/Utils/Storage/StorageBaseItems/BaseBasicStorageItemExtraProperties.cs similarity index 100% rename from src/Files.App/Utils/BaseStorage/BaseBasicStorageItemExtraProperties.cs rename to src/Files.App/Utils/Storage/StorageBaseItems/BaseBasicStorageItemExtraProperties.cs diff --git a/src/Files.App/Utils/BaseStorage/BaseStorageFile.cs b/src/Files.App/Utils/Storage/StorageBaseItems/BaseStorageFile.cs similarity index 100% rename from src/Files.App/Utils/BaseStorage/BaseStorageFile.cs rename to src/Files.App/Utils/Storage/StorageBaseItems/BaseStorageFile.cs diff --git a/src/Files.App/Utils/BaseStorage/BaseStorageFolder.cs b/src/Files.App/Utils/Storage/StorageBaseItems/BaseStorageFolder.cs similarity index 100% rename from src/Files.App/Utils/BaseStorage/BaseStorageFolder.cs rename to src/Files.App/Utils/Storage/StorageBaseItems/BaseStorageFolder.cs diff --git a/src/Files.App/Utils/BaseStorage/BaseStorageItemExtraProperties.cs b/src/Files.App/Utils/Storage/StorageBaseItems/BaseStorageItemExtraProperties.cs similarity index 100% rename from src/Files.App/Utils/BaseStorage/BaseStorageItemExtraProperties.cs rename to src/Files.App/Utils/Storage/StorageBaseItems/BaseStorageItemExtraProperties.cs diff --git a/src/Files.App/Utils/BaseStorage/IBaseStorageFile.cs b/src/Files.App/Utils/Storage/StorageBaseItems/IBaseStorageFile.cs similarity index 100% rename from src/Files.App/Utils/BaseStorage/IBaseStorageFile.cs rename to src/Files.App/Utils/Storage/StorageBaseItems/IBaseStorageFile.cs diff --git a/src/Files.App/Utils/BaseStorage/IBaseStorageFolder.cs b/src/Files.App/Utils/Storage/StorageBaseItems/IBaseStorageFolder.cs similarity index 100% rename from src/Files.App/Utils/BaseStorage/IBaseStorageFolder.cs rename to src/Files.App/Utils/Storage/StorageBaseItems/IBaseStorageFolder.cs diff --git a/src/Files.App/Utils/BaseStorage/ICreateFileWithStream.cs b/src/Files.App/Utils/Storage/StorageBaseItems/ICreateFileWithStream.cs similarity index 100% rename from src/Files.App/Utils/BaseStorage/ICreateFileWithStream.cs rename to src/Files.App/Utils/Storage/StorageBaseItems/ICreateFileWithStream.cs diff --git a/src/Files.App/Utils/StorageItems/BaseQueryResults.cs b/src/Files.App/Utils/Storage/StorageItems/BaseQueryResults.cs similarity index 100% rename from src/Files.App/Utils/StorageItems/BaseQueryResults.cs rename to src/Files.App/Utils/Storage/StorageItems/BaseQueryResults.cs diff --git a/src/Files.App/Utils/StorageItems/FtpStorageFile.cs b/src/Files.App/Utils/Storage/StorageItems/FtpStorageFile.cs similarity index 100% rename from src/Files.App/Utils/StorageItems/FtpStorageFile.cs rename to src/Files.App/Utils/Storage/StorageItems/FtpStorageFile.cs diff --git a/src/Files.App/Utils/StorageItems/FtpStorageFolder.cs b/src/Files.App/Utils/Storage/StorageItems/FtpStorageFolder.cs similarity index 100% rename from src/Files.App/Utils/StorageItems/FtpStorageFolder.cs rename to src/Files.App/Utils/Storage/StorageItems/FtpStorageFolder.cs diff --git a/src/Files.App/Utils/StorageItems/NativeStorageFile.cs b/src/Files.App/Utils/Storage/StorageItems/NativeStorageFile.cs similarity index 100% rename from src/Files.App/Utils/StorageItems/NativeStorageFile.cs rename to src/Files.App/Utils/Storage/StorageItems/NativeStorageFile.cs diff --git a/src/Files.App/Utils/StorageItems/ShellStorageFile.cs b/src/Files.App/Utils/Storage/StorageItems/ShellStorageFile.cs similarity index 100% rename from src/Files.App/Utils/StorageItems/ShellStorageFile.cs rename to src/Files.App/Utils/Storage/StorageItems/ShellStorageFile.cs diff --git a/src/Files.App/Utils/StorageItems/ShellStorageFolder.cs b/src/Files.App/Utils/Storage/StorageItems/ShellStorageFolder.cs similarity index 100% rename from src/Files.App/Utils/StorageItems/ShellStorageFolder.cs rename to src/Files.App/Utils/Storage/StorageItems/ShellStorageFolder.cs diff --git a/src/Files.App/Utils/StorageItems/StreamWithContentType.cs b/src/Files.App/Utils/Storage/StorageItems/StreamWithContentType.cs similarity index 100% rename from src/Files.App/Utils/StorageItems/StreamWithContentType.cs rename to src/Files.App/Utils/Storage/StorageItems/StreamWithContentType.cs diff --git a/src/Files.App/Utils/StorageItems/SystemStorageFile.cs b/src/Files.App/Utils/Storage/StorageItems/SystemStorageFile.cs similarity index 100% rename from src/Files.App/Utils/StorageItems/SystemStorageFile.cs rename to src/Files.App/Utils/Storage/StorageItems/SystemStorageFile.cs diff --git a/src/Files.App/Utils/StorageItems/SystemStorageFolder.cs b/src/Files.App/Utils/Storage/StorageItems/SystemStorageFolder.cs similarity index 100% rename from src/Files.App/Utils/StorageItems/SystemStorageFolder.cs rename to src/Files.App/Utils/Storage/StorageItems/SystemStorageFolder.cs diff --git a/src/Files.App/Utils/StorageItems/VirtualStorageFile.cs b/src/Files.App/Utils/Storage/StorageItems/VirtualStorageFile.cs similarity index 100% rename from src/Files.App/Utils/StorageItems/VirtualStorageFile.cs rename to src/Files.App/Utils/Storage/StorageItems/VirtualStorageFile.cs diff --git a/src/Files.App/Utils/StorageItems/VirtualStorageFolder.cs b/src/Files.App/Utils/Storage/StorageItems/VirtualStorageFolder.cs similarity index 100% rename from src/Files.App/Utils/StorageItems/VirtualStorageFolder.cs rename to src/Files.App/Utils/Storage/StorageItems/VirtualStorageFolder.cs diff --git a/src/Files.App/Utils/StorageItems/VirtualStorageItem.cs b/src/Files.App/Utils/Storage/StorageItems/VirtualStorageItem.cs similarity index 100% rename from src/Files.App/Utils/StorageItems/VirtualStorageItem.cs rename to src/Files.App/Utils/Storage/StorageItems/VirtualStorageItem.cs diff --git a/src/Files.App/Utils/StorageItems/ZipStorageFile.cs b/src/Files.App/Utils/Storage/StorageItems/ZipStorageFile.cs similarity index 100% rename from src/Files.App/Utils/StorageItems/ZipStorageFile.cs rename to src/Files.App/Utils/Storage/StorageItems/ZipStorageFile.cs diff --git a/src/Files.App/Utils/StorageItems/ZipStorageFolder.cs b/src/Files.App/Utils/Storage/StorageItems/ZipStorageFolder.cs similarity index 100% rename from src/Files.App/Utils/StorageItems/ZipStorageFolder.cs rename to src/Files.App/Utils/Storage/StorageItems/ZipStorageFolder.cs From 2a81bb206ab66ff3afc3853b061dd71407a5d5ea Mon Sep 17 00:00:00 2001 From: 0x5BFA <62196528+0x5bfa@users.noreply.github.com> Date: Sun, 9 Jul 2023 14:46:58 +0900 Subject: [PATCH 02/12] Adjust namespaces --- src/Files.App/App.xaml.cs | 1 - .../SecurityAdvancedAccessControlItemFactory.cs | 1 - src/Files.App/Data/Items/ListedItem.cs | 1 - src/Files.App/Data/Models/ItemViewModel.cs | 6 +----- src/Files.App/Extensions/ShellNewEntryExtensions.cs | 1 - src/Files.App/GlobalUsings.cs | 6 +----- src/Files.App/Helpers/BitmapHelper.cs | 1 - .../Helpers/Navigation/NavigationHelpers.cs | 1 - src/Files.App/Helpers/ShareItemHelpers.cs | 1 - src/Files.App/Helpers/UI/UIFilesystemHelpers.cs | 1 - .../BaseLayoutCommandImplementationModel.cs | 1 - src/Files.App/Services/QuickAccessService.cs | 1 - src/Files.App/UserControls/SidebarControl.xaml.cs | 1 - .../UserControls/Widgets/RecentFilesWidget.xaml.cs | 2 -- src/Files.App/Utils/Archives/ArchiveHelpers.cs | 1 - src/Files.App/Utils/Archives/ZipHelpers.cs | 1 - src/Files.App/Utils/FileTags/FileTagsHelper.cs | 1 - src/Files.App/Utils/Git/GitHelpers.cs | 1 - src/Files.App/Utils/RecentItem/RecentItem.cs | 1 - .../Utils/Storage/Cache/IStorageCacheController.cs | 4 ++-- .../Utils/Storage/Cache/StorageCacheController.cs | 12 ++++++------ .../Storage/Collection/BlockingListEnumerator.cs | 2 +- .../Collection/BulkConcurrentObservableCollection.cs | 2 +- .../Utils/Storage/Collection/GroupedCollection.cs | 2 +- .../Utils/Storage/Collection/GroupingHelper.cs | 2 +- .../Utils/Storage/Collection/SortingHelper.cs | 2 +- .../Enumerators/UniversalStorageEnumerator.cs | 4 ++-- .../Storage/Enumerators/Win32StorageEnumerator.cs | 4 ++-- src/Files.App/Utils/Storage/Helpers/DeviceManager.cs | 2 +- src/Files.App/Utils/Storage/Helpers/DriveHelpers.cs | 2 +- .../Utils/Storage/Helpers/ErrorCodeConverter.cs | 2 +- .../Utils/Storage/Helpers/FileOperationsHelpers.cs | 3 +-- .../Utils/Storage/Helpers/FilePropertiesHelpers.cs | 2 +- .../Utils/Storage/Helpers/FileSecurityHelpers.cs | 3 +-- .../Utils/Storage/Helpers/FileThumbnailHelper.cs | 2 +- .../Utils/Storage/Helpers/FilesystemResult.cs | 2 +- .../Utils/Storage/Helpers/FilesystemTasks.cs | 2 +- src/Files.App/Utils/Storage/Helpers/FolderHelpers.cs | 3 +-- src/Files.App/Utils/Storage/Helpers/FtpHelpers.cs | 2 +- .../Utils/Storage/Helpers/IStorageItemWithPath.cs | 2 +- .../Utils/Storage/Helpers/StorageFileExtensions.cs | 4 ++-- .../Utils/Storage/Helpers/StorageFileWithPath.cs | 2 +- .../Utils/Storage/Helpers/StorageFolderWithPath.cs | 2 +- .../Utils/Storage/Helpers/StorageHelpers.cs | 1 - .../Utils/Storage/Helpers/StorageItemIconHelpers.cs | 2 +- .../Utils/Storage/Helpers/StorageSenseHelper.cs | 2 +- .../Utils/Storage/History/IStorageHistory.cs | 2 +- .../Storage/History/IStorageHistoryOperations.cs | 2 +- .../Utils/Storage/History/StorageHistory.cs | 2 +- .../Utils/Storage/History/StorageHistoryHelpers.cs | 2 +- .../Storage/History/StorageHistoryOperations.cs | 2 +- .../Utils/Storage/History/StorageHistoryWrapper.cs | 2 +- .../Utils/Storage/Operations/FileSystemProgress.cs | 2 +- .../Utils/Storage/Operations/FilesystemHelpers.cs | 4 +--- .../Utils/Storage/Operations/FilesystemOperations.cs | 6 +++--- .../Utils/Storage/Operations/IFilesystemHelpers.cs | 3 +-- .../Storage/Operations/IFilesystemOperations.cs | 4 ++-- .../Storage/Operations/ShellFilesystemOperations.cs | 6 +++--- src/Files.App/Utils/Storage/Search/FolderSearch.cs | 4 ++-- .../Utils/Storage/Security/AccessControlEntry.cs | 2 +- .../Storage/Security/AccessControlEntryFlags.cs | 2 +- .../Utils/Storage/Security/AccessControlEntryType.cs | 2 +- .../Utils/Storage/Security/AccessControlList.cs | 2 +- .../Utils/Storage/Security/AccessMaskFlags.cs | 2 +- .../Utils/Storage/Security/AccessMaskItem.cs | 2 +- src/Files.App/Utils/Storage/Security/Principal.cs | 2 +- .../Utils/Storage/Security/PrincipalType.cs | 2 +- .../Storage/StorageBaseItems/BaseBasicProperties.cs | 2 +- .../BaseBasicStorageItemExtraProperties.cs | 2 +- .../Storage/StorageBaseItems/BaseStorageFile.cs | 2 +- .../Storage/StorageBaseItems/BaseStorageFolder.cs | 2 +- .../BaseStorageItemExtraProperties.cs | 2 +- .../Storage/StorageBaseItems/IBaseStorageFile.cs | 2 +- .../Storage/StorageBaseItems/IBaseStorageFolder.cs | 2 +- .../StorageBaseItems/ICreateFileWithStream.cs | 2 +- .../Utils/Storage/StorageItems/BaseQueryResults.cs | 2 +- .../Utils/Storage/StorageItems/FtpStorageFile.cs | 2 +- .../Utils/Storage/StorageItems/FtpStorageFolder.cs | 2 +- .../Utils/Storage/StorageItems/NativeStorageFile.cs | 2 +- .../Utils/Storage/StorageItems/ShellStorageFile.cs | 2 +- .../Utils/Storage/StorageItems/ShellStorageFolder.cs | 2 +- .../Storage/StorageItems/StreamWithContentType.cs | 2 +- .../Utils/Storage/StorageItems/SystemStorageFile.cs | 2 +- .../Storage/StorageItems/SystemStorageFolder.cs | 2 +- .../Utils/Storage/StorageItems/VirtualStorageFile.cs | 2 +- .../Storage/StorageItems/VirtualStorageFolder.cs | 2 +- .../Utils/Storage/StorageItems/VirtualStorageItem.cs | 2 +- .../Utils/Storage/StorageItems/ZipStorageFile.cs | 2 +- .../Utils/Storage/StorageItems/ZipStorageFolder.cs | 2 +- src/Files.App/ViewModels/MainPageViewModel.cs | 1 - .../ViewModels/Previews/BasePreviewModel.cs | 1 - .../ViewModels/Previews/FolderPreviewViewModel.cs | 1 - .../Properties/Items/CombinedFileProperties.cs | 1 - .../ViewModels/Properties/Items/DriveProperties.cs | 1 - .../ViewModels/Properties/Items/FileProperties.cs | 1 - .../ViewModels/Properties/Items/FileProperty.cs | 1 - .../ViewModels/Properties/Items/FolderProperties.cs | 1 - .../ViewModels/Properties/Items/LibraryProperties.cs | 1 - .../Properties/SecurityAdvancedViewModel.cs | 1 - .../ViewModels/Properties/SecurityViewModel.cs | 1 - .../ViewModels/Settings/AdvancedViewModel.cs | 1 - .../ViewModels/UserControls/ToolbarViewModel.cs | 1 - src/Files.App/Views/LayoutModes/BaseLayout.cs | 2 +- .../Views/Properties/SecurityAdvancedPage.xaml | 2 +- src/Files.App/Views/Properties/SecurityPage.xaml | 2 +- src/Files.App/Views/Shells/BaseShellPage.cs | 2 -- src/Files.App/Views/Shells/IShellPage.cs | 1 - 107 files changed, 89 insertions(+), 138 deletions(-) diff --git a/src/Files.App/App.xaml.cs b/src/Files.App/App.xaml.cs index 2fe19b26128d..19d1a479b6e6 100644 --- a/src/Files.App/App.xaml.cs +++ b/src/Files.App/App.xaml.cs @@ -11,7 +11,6 @@ using Files.App.Extensions; using Files.App.Utils; using Files.App.Utils.Cloud; -using Files.App.Utils.FilesystemHistory; using Files.App.Helpers; using Files.App.Services; using Files.App.Services.DateTimeFormatter; diff --git a/src/Files.App/Data/Factories/SecurityAdvancedAccessControlItemFactory.cs b/src/Files.App/Data/Factories/SecurityAdvancedAccessControlItemFactory.cs index fd6c21a9db8a..51a969765aaa 100644 --- a/src/Files.App/Data/Factories/SecurityAdvancedAccessControlItemFactory.cs +++ b/src/Files.App/Data/Factories/SecurityAdvancedAccessControlItemFactory.cs @@ -2,7 +2,6 @@ // Licensed under the MIT License. See the LICENSE. using Files.App.Extensions; -using Files.App.Utils.Security; using System.Collections.Generic; using System.Collections.ObjectModel; diff --git a/src/Files.App/Data/Items/ListedItem.cs b/src/Files.App/Data/Items/ListedItem.cs index 865b15859126..e0753da72d06 100644 --- a/src/Files.App/Data/Items/ListedItem.cs +++ b/src/Files.App/Data/Items/ListedItem.cs @@ -2,7 +2,6 @@ // Licensed under the MIT License. See the LICENSE. using Files.App.Utils.Cloud; -using Files.App.Utils.StorageItems; using Files.App.ViewModels.Properties; using Files.Core.Helpers; using Files.Core.ViewModels.FileTags; diff --git a/src/Files.App/Data/Models/ItemViewModel.cs b/src/Files.App/Data/Models/ItemViewModel.cs index cc7d4951a1f1..899408092d93 100644 --- a/src/Files.App/Data/Models/ItemViewModel.cs +++ b/src/Files.App/Data/Models/ItemViewModel.cs @@ -2,10 +2,6 @@ // Licensed under the MIT License. See the LICENSE. using Files.App.Utils.Cloud; -using Files.App.Utils.Search; -using Files.App.Utils.StorageEnumerators; -using Files.App.Utils.StorageItems; -using Files.App.Helpers.StorageCache; using Files.App.Utils.Shell; using Files.App.Storage.FtpStorage; using Files.App.ViewModels.Previews; @@ -47,7 +43,7 @@ public sealed class ItemViewModel : ObservableObject, IDisposable private readonly AsyncManualResetEvent gitChangedEvent; private readonly DispatcherQueue dispatcherQueue; private readonly JsonElement defaultJson = JsonSerializer.SerializeToElement("{}"); - private readonly IFileListCache fileListCache = FileListCacheController.GetInstance(); + private readonly IStorageCacheController fileListCache = StorageCacheController.GetInstance(); private readonly string folderTypeTextLocalized = "Folder".GetLocalizedResource(); private Task? aProcessQueueAction; diff --git a/src/Files.App/Extensions/ShellNewEntryExtensions.cs b/src/Files.App/Extensions/ShellNewEntryExtensions.cs index f5cb1a81815c..65e6973f6002 100644 --- a/src/Files.App/Extensions/ShellNewEntryExtensions.cs +++ b/src/Files.App/Extensions/ShellNewEntryExtensions.cs @@ -2,7 +2,6 @@ // Licensed under the MIT License. See the LICENSE. using Files.App.Utils; -using Files.App.Utils.StorageItems; using Files.App.Helpers; using Files.App.Utils.Shell; using Files.Shared; diff --git a/src/Files.App/GlobalUsings.cs b/src/Files.App/GlobalUsings.cs index ab32ad652b3a..52b05898f040 100644 --- a/src/Files.App/GlobalUsings.cs +++ b/src/Files.App/GlobalUsings.cs @@ -27,18 +27,14 @@ global using global::Files.App.Utils; global using global::Files.App.Utils.Archives; global using global::Files.App.Utils.Cloud; -global using global::Files.App.Utils.FilesystemHistory; global using global::Files.App.Utils.FileTags; global using global::Files.App.Utils.Git; global using global::Files.App.Utils.Library; global using global::Files.App.Utils.RecentItem; global using global::Files.App.Utils.RecycleBin; -global using global::Files.App.Utils.Search; -global using global::Files.App.Utils.Security; global using global::Files.App.Utils.Serialization; global using global::Files.App.Utils.Shell; -global using global::Files.App.Utils.StorageEnumerators; -global using global::Files.App.Utils.StorageItems; +global using global::Files.App.Utils.Storage; global using global::Files.App.Data.EventArguments; global using global::Files.App.Data.Factories; global using global::Files.App.Data.Items; diff --git a/src/Files.App/Helpers/BitmapHelper.cs b/src/Files.App/Helpers/BitmapHelper.cs index fd9f082e7213..7d8791721366 100644 --- a/src/Files.App/Helpers/BitmapHelper.cs +++ b/src/Files.App/Helpers/BitmapHelper.cs @@ -1,7 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.StorageItems; using Microsoft.UI.Xaml.Media.Imaging; using System.IO; using Windows.Graphics.Imaging; diff --git a/src/Files.App/Helpers/Navigation/NavigationHelpers.cs b/src/Files.App/Helpers/Navigation/NavigationHelpers.cs index 170f74e7d4ad..53215e7785ac 100644 --- a/src/Files.App/Helpers/Navigation/NavigationHelpers.cs +++ b/src/Files.App/Helpers/Navigation/NavigationHelpers.cs @@ -4,7 +4,6 @@ using CommunityToolkit.Mvvm.DependencyInjection; using Files.App.Extensions; using Files.App.Utils; -using Files.App.Utils.StorageItems; using Files.App.Utils.Shell; using Files.App.ViewModels; using Files.App.Views; diff --git a/src/Files.App/Helpers/ShareItemHelpers.cs b/src/Files.App/Helpers/ShareItemHelpers.cs index 165913cd14ad..9dc2c0e41b04 100644 --- a/src/Files.App/Helpers/ShareItemHelpers.cs +++ b/src/Files.App/Helpers/ShareItemHelpers.cs @@ -3,7 +3,6 @@ using Files.App.Extensions; using Files.App.Utils; -using Files.App.Utils.StorageItems; using System; using System.Collections.Generic; using System.Linq; diff --git a/src/Files.App/Helpers/UI/UIFilesystemHelpers.cs b/src/Files.App/Helpers/UI/UIFilesystemHelpers.cs index ac9ebee3d3b1..38f697e3d05a 100644 --- a/src/Files.App/Helpers/UI/UIFilesystemHelpers.cs +++ b/src/Files.App/Helpers/UI/UIFilesystemHelpers.cs @@ -2,7 +2,6 @@ // Licensed under the MIT License. See the LICENSE. using Files.App.Dialogs; -using Files.App.Utils.StorageItems; using Files.App.ViewModels.Dialogs; using Microsoft.Extensions.Logging; using System.Collections.Concurrent; diff --git a/src/Files.App/Interacts/BaseLayoutCommandImplementationModel.cs b/src/Files.App/Interacts/BaseLayoutCommandImplementationModel.cs index e254b866f6ce..1e6917f22a11 100644 --- a/src/Files.App/Interacts/BaseLayoutCommandImplementationModel.cs +++ b/src/Files.App/Interacts/BaseLayoutCommandImplementationModel.cs @@ -3,7 +3,6 @@ #nullable disable warnings -using Files.App.Utils.StorageItems; using Microsoft.UI.Xaml; using Microsoft.UI.Xaml.Input; using System.IO; diff --git a/src/Files.App/Services/QuickAccessService.cs b/src/Files.App/Services/QuickAccessService.cs index 228a5999efde..735c846961d5 100644 --- a/src/Files.App/Services/QuickAccessService.cs +++ b/src/Files.App/Services/QuickAccessService.cs @@ -1,7 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.StorageItems; using Files.App.Utils.Shell; using Files.App.UserControls.Widgets; diff --git a/src/Files.App/UserControls/SidebarControl.xaml.cs b/src/Files.App/UserControls/SidebarControl.xaml.cs index 181c134504d2..b7fe94373648 100644 --- a/src/Files.App/UserControls/SidebarControl.xaml.cs +++ b/src/Files.App/UserControls/SidebarControl.xaml.cs @@ -8,7 +8,6 @@ using Files.App.Data.Items; using Files.App.Data.Models; using Files.App.Extensions; -using Files.App.Utils.StorageItems; using Files.App.Helpers.ContextFlyouts; using Files.App.Services; using Files.App.Utils.Shell; diff --git a/src/Files.App/UserControls/Widgets/RecentFilesWidget.xaml.cs b/src/Files.App/UserControls/Widgets/RecentFilesWidget.xaml.cs index 42eed10764c3..4c8ad84c5302 100644 --- a/src/Files.App/UserControls/Widgets/RecentFilesWidget.xaml.cs +++ b/src/Files.App/UserControls/Widgets/RecentFilesWidget.xaml.cs @@ -5,8 +5,6 @@ using CommunityToolkit.WinUI; using Files.App.Extensions; using Files.App.Utils; -using Files.App.Utils.StorageEnumerators; -using Files.App.Utils.StorageItems; using Files.App.Helpers; using Files.App.Helpers.ContextFlyouts; using Files.App.ViewModels; diff --git a/src/Files.App/Utils/Archives/ArchiveHelpers.cs b/src/Files.App/Utils/Archives/ArchiveHelpers.cs index c61d282ffb68..1a3fb3e8e457 100644 --- a/src/Files.App/Utils/Archives/ArchiveHelpers.cs +++ b/src/Files.App/Utils/Archives/ArchiveHelpers.cs @@ -3,7 +3,6 @@ using Files.App.Dialogs; using Files.App.Utils.Archives; -using Files.App.Utils.StorageItems; using Files.App.ViewModels.Dialogs; using Microsoft.UI.Xaml.Controls; using System.IO; diff --git a/src/Files.App/Utils/Archives/ZipHelpers.cs b/src/Files.App/Utils/Archives/ZipHelpers.cs index 94340bafe5a0..4211b9f829d9 100644 --- a/src/Files.App/Utils/Archives/ZipHelpers.cs +++ b/src/Files.App/Utils/Archives/ZipHelpers.cs @@ -1,7 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.StorageItems; using Microsoft.Extensions.Logging; using SevenZip; using System.IO; diff --git a/src/Files.App/Utils/FileTags/FileTagsHelper.cs b/src/Files.App/Utils/FileTags/FileTagsHelper.cs index 5162d470a462..b3dbcb342324 100644 --- a/src/Files.App/Utils/FileTags/FileTagsHelper.cs +++ b/src/Files.App/Utils/FileTags/FileTagsHelper.cs @@ -2,7 +2,6 @@ // Licensed under the MIT License. See the LICENSE. using Common; -using Files.App.Utils.StorageItems; using Files.App.Helpers; using Files.App.Utils.Shell; using Files.Shared.Extensions; diff --git a/src/Files.App/Utils/Git/GitHelpers.cs b/src/Files.App/Utils/Git/GitHelpers.cs index 2a446bcda42e..085f3c9f1c89 100644 --- a/src/Files.App/Utils/Git/GitHelpers.cs +++ b/src/Files.App/Utils/Git/GitHelpers.cs @@ -2,7 +2,6 @@ // Licensed under the MIT License. See the LICENSE. using Files.App.Dialogs; -using Files.App.Utils.StorageItems; using Files.App.ViewModels.Dialogs; using LibGit2Sharp; using Microsoft.AppCenter.Analytics; diff --git a/src/Files.App/Utils/RecentItem/RecentItem.cs b/src/Files.App/Utils/RecentItem/RecentItem.cs index 8500ee8a8cea..6d1445ae85c3 100644 --- a/src/Files.App/Utils/RecentItem/RecentItem.cs +++ b/src/Files.App/Utils/RecentItem/RecentItem.cs @@ -1,7 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.StorageItems; using Files.App.UserControls.Widgets; using Microsoft.UI.Xaml.Media.Imaging; using Windows.Storage; diff --git a/src/Files.App/Utils/Storage/Cache/IStorageCacheController.cs b/src/Files.App/Utils/Storage/Cache/IStorageCacheController.cs index af02cc3c84a7..af9bc2f82177 100644 --- a/src/Files.App/Utils/Storage/Cache/IStorageCacheController.cs +++ b/src/Files.App/Utils/Storage/Cache/IStorageCacheController.cs @@ -4,9 +4,9 @@ using System.Threading; using System.Threading.Tasks; -namespace Files.App.Helpers.StorageCache +namespace Files.App.Utils.Storage { - internal interface IFileListCache + internal interface IStorageCacheController { public ValueTask ReadFileDisplayNameFromCache(string path, CancellationToken cancellationToken); diff --git a/src/Files.App/Utils/Storage/Cache/StorageCacheController.cs b/src/Files.App/Utils/Storage/Cache/StorageCacheController.cs index 3a2ff4c1852d..b0758756357a 100644 --- a/src/Files.App/Utils/Storage/Cache/StorageCacheController.cs +++ b/src/Files.App/Utils/Storage/Cache/StorageCacheController.cs @@ -5,18 +5,18 @@ using System.Threading; using System.Threading.Tasks; -namespace Files.App.Helpers.StorageCache +namespace Files.App.Utils.Storage { - internal class FileListCacheController : IFileListCache + internal class StorageCacheController : IStorageCacheController { - private static FileListCacheController instance; + private static StorageCacheController instance; - public static FileListCacheController GetInstance() + public static StorageCacheController GetInstance() { - return instance ??= new FileListCacheController(); + return instance ??= new StorageCacheController(); } - private FileListCacheController() + private StorageCacheController() { } diff --git a/src/Files.App/Utils/Storage/Collection/BlockingListEnumerator.cs b/src/Files.App/Utils/Storage/Collection/BlockingListEnumerator.cs index ee24dda92b2c..ea76eefc5e45 100644 --- a/src/Files.App/Utils/Storage/Collection/BlockingListEnumerator.cs +++ b/src/Files.App/Utils/Storage/Collection/BlockingListEnumerator.cs @@ -4,7 +4,7 @@ using System.Collections; using System.Collections.Generic; -namespace Files.App.Helpers +namespace Files.App.Utils.Storage { public class BlockingListEnumerator : IEnumerator { diff --git a/src/Files.App/Utils/Storage/Collection/BulkConcurrentObservableCollection.cs b/src/Files.App/Utils/Storage/Collection/BulkConcurrentObservableCollection.cs index 1f507e50fd4a..dca96f0e796a 100644 --- a/src/Files.App/Utils/Storage/Collection/BulkConcurrentObservableCollection.cs +++ b/src/Files.App/Utils/Storage/Collection/BulkConcurrentObservableCollection.cs @@ -11,7 +11,7 @@ using System.Linq; using System.Threading; -namespace Files.App.Helpers +namespace Files.App.Utils.Storage { [DebuggerTypeProxy(typeof(CollectionDebugView<>))] [DebuggerDisplay("Count = {Count}")] diff --git a/src/Files.App/Utils/Storage/Collection/GroupedCollection.cs b/src/Files.App/Utils/Storage/Collection/GroupedCollection.cs index 234386a0c539..81a7dd87719c 100644 --- a/src/Files.App/Utils/Storage/Collection/GroupedCollection.cs +++ b/src/Files.App/Utils/Storage/Collection/GroupedCollection.cs @@ -9,7 +9,7 @@ using System.ComponentModel; using System.Runtime.CompilerServices; -namespace Files.App.Helpers +namespace Files.App.Utils.Storage { public class GroupedCollection : BulkConcurrentObservableCollection, IGroupedCollectionHeader { diff --git a/src/Files.App/Utils/Storage/Collection/GroupingHelper.cs b/src/Files.App/Utils/Storage/Collection/GroupingHelper.cs index aa4f17b8b247..a445ecd420b4 100644 --- a/src/Files.App/Utils/Storage/Collection/GroupingHelper.cs +++ b/src/Files.App/Utils/Storage/Collection/GroupingHelper.cs @@ -4,7 +4,7 @@ using Files.Shared.Services.DateTimeFormatter; using Windows.Storage; -namespace Files.App.Helpers +namespace Files.App.Utils.Storage { public static class GroupingHelper { diff --git a/src/Files.App/Utils/Storage/Collection/SortingHelper.cs b/src/Files.App/Utils/Storage/Collection/SortingHelper.cs index 8c87ad0196b8..86a10691d107 100644 --- a/src/Files.App/Utils/Storage/Collection/SortingHelper.cs +++ b/src/Files.App/Utils/Storage/Collection/SortingHelper.cs @@ -8,7 +8,7 @@ using System.Linq; using Windows.Storage; -namespace Files.App.Helpers +namespace Files.App.Utils.Storage { public static class SortingHelper { diff --git a/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs b/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs index 7a07d6edd08e..19c183498788 100644 --- a/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs +++ b/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs @@ -3,7 +3,7 @@ using CommunityToolkit.Mvvm.DependencyInjection; using Files.App.Extensions; -using Files.App.Utils.StorageItems; +using Files.App.Utils.Storage; using Files.App.Helpers; using Files.Core.Helpers; using Files.Core.Services.Settings; @@ -16,7 +16,7 @@ using System.Threading.Tasks; using Windows.Storage; -namespace Files.App.Utils.StorageEnumerators +namespace Files.App.Utils.Storage { public static class UniversalStorageEnumerator { diff --git a/src/Files.App/Utils/Storage/Enumerators/Win32StorageEnumerator.cs b/src/Files.App/Utils/Storage/Enumerators/Win32StorageEnumerator.cs index a2229ea73d79..c1e005fa583e 100644 --- a/src/Files.App/Utils/Storage/Enumerators/Win32StorageEnumerator.cs +++ b/src/Files.App/Utils/Storage/Enumerators/Win32StorageEnumerator.cs @@ -1,7 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.StorageItems; +using Files.App.Utils.Storage; using Files.App.Helpers.StorageCache; using Files.Core.Extensions; using Files.Core.Helpers; @@ -13,7 +13,7 @@ using static Files.Core.Helpers.NativeFindStorageItemHelper; using FileAttributes = System.IO.FileAttributes; -namespace Files.App.Utils.StorageEnumerators +namespace Files.App.Utils.Storage { public static class Win32StorageEnumerator { diff --git a/src/Files.App/Utils/Storage/Helpers/DeviceManager.cs b/src/Files.App/Utils/Storage/Helpers/DeviceManager.cs index 36137d032263..94187b92b34c 100644 --- a/src/Files.App/Utils/Storage/Helpers/DeviceManager.cs +++ b/src/Files.App/Utils/Storage/Helpers/DeviceManager.cs @@ -5,7 +5,7 @@ using Microsoft.Management.Infrastructure; using System; -namespace Files.App +namespace Files.App.Utils.Storage { public sealed class DeviceManager { diff --git a/src/Files.App/Utils/Storage/Helpers/DriveHelpers.cs b/src/Files.App/Utils/Storage/Helpers/DriveHelpers.cs index 0b2580cb8f34..957d5df9c19e 100644 --- a/src/Files.App/Utils/Storage/Helpers/DriveHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/DriveHelpers.cs @@ -17,7 +17,7 @@ using Windows.Storage; using Windows.Storage.FileProperties; -namespace Files.App.Helpers +namespace Files.App.Utils.Storage { public static class DriveHelpers { diff --git a/src/Files.App/Utils/Storage/Helpers/ErrorCodeConverter.cs b/src/Files.App/Utils/Storage/Helpers/ErrorCodeConverter.cs index 207e14cdf9da..6a1aa9283389 100644 --- a/src/Files.App/Utils/Storage/Helpers/ErrorCodeConverter.cs +++ b/src/Files.App/Utils/Storage/Helpers/ErrorCodeConverter.cs @@ -3,7 +3,7 @@ using Files.Shared.Enums; -namespace Files.App.Helpers +namespace Files.App.Utils.Storage { public static class ErrorCodeConverter { diff --git a/src/Files.App/Utils/Storage/Helpers/FileOperationsHelpers.cs b/src/Files.App/Utils/Storage/Helpers/FileOperationsHelpers.cs index b1e18d4fd15e..216b4cbe27c3 100644 --- a/src/Files.App/Utils/Storage/Helpers/FileOperationsHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/FileOperationsHelpers.cs @@ -1,7 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.Security; using Files.App.Utils.Shell; using Files.Core.Helpers; using Microsoft.Extensions.Logging; @@ -15,7 +14,7 @@ using Vanara.Windows.Shell; using Windows.ApplicationModel.DataTransfer; -namespace Files.App.Helpers +namespace Files.App.Utils.Storage { public class FileOperationsHelpers { diff --git a/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs b/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs index 98c5ace67217..b124a433656b 100644 --- a/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs @@ -13,7 +13,7 @@ using Windows.ApplicationModel; using Windows.Graphics; -namespace Files.App.Helpers +namespace Files.App.Utils.Storage { /// /// Represents a helper class that helps users open and handle item properties window diff --git a/src/Files.App/Utils/Storage/Helpers/FileSecurityHelpers.cs b/src/Files.App/Utils/Storage/Helpers/FileSecurityHelpers.cs index bd22042aeb3c..31848befaec9 100644 --- a/src/Files.App/Utils/Storage/Helpers/FileSecurityHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/FileSecurityHelpers.cs @@ -1,13 +1,12 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.Security; using Files.App.Utils.Shell; using Vanara.PInvoke; using static Vanara.PInvoke.AdvApi32; using SystemSecurity = System.Security.AccessControl; -namespace Files.App.Helpers +namespace Files.App.Utils.Storage { /// /// Represents a helper for file security information. diff --git a/src/Files.App/Utils/Storage/Helpers/FileThumbnailHelper.cs b/src/Files.App/Utils/Storage/Helpers/FileThumbnailHelper.cs index 2999e5b74291..770be8d72339 100644 --- a/src/Files.App/Utils/Storage/Helpers/FileThumbnailHelper.cs +++ b/src/Files.App/Utils/Storage/Helpers/FileThumbnailHelper.cs @@ -10,7 +10,7 @@ using Windows.Storage; using Windows.Storage.FileProperties; -namespace Files.App.Helpers +namespace Files.App.Utils.Storage { public static class FileThumbnailHelper { diff --git a/src/Files.App/Utils/Storage/Helpers/FilesystemResult.cs b/src/Files.App/Utils/Storage/Helpers/FilesystemResult.cs index 12a3d2282bf9..5d96cd7ec0a2 100644 --- a/src/Files.App/Utils/Storage/Helpers/FilesystemResult.cs +++ b/src/Files.App/Utils/Storage/Helpers/FilesystemResult.cs @@ -3,7 +3,7 @@ using Files.Shared.Enums; -namespace Files.App.Utils +namespace Files.App.Utils.Storage { public class FilesystemResult { diff --git a/src/Files.App/Utils/Storage/Helpers/FilesystemTasks.cs b/src/Files.App/Utils/Storage/Helpers/FilesystemTasks.cs index 08569214b679..af9ee64cd6e4 100644 --- a/src/Files.App/Utils/Storage/Helpers/FilesystemTasks.cs +++ b/src/Files.App/Utils/Storage/Helpers/FilesystemTasks.cs @@ -6,7 +6,7 @@ using System.Runtime.InteropServices; using Windows.Storage; -namespace Files.App.Utils +namespace Files.App.Utils.Storage { public static class FilesystemTasks { diff --git a/src/Files.App/Utils/Storage/Helpers/FolderHelpers.cs b/src/Files.App/Utils/Storage/Helpers/FolderHelpers.cs index 9aa7c153aee0..b982543cda5e 100644 --- a/src/Files.App/Utils/Storage/Helpers/FolderHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/FolderHelpers.cs @@ -1,14 +1,13 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.StorageItems; using System; using System.Collections.Generic; using System.IO; using System.Threading.Tasks; using static Files.Core.Helpers.NativeFindStorageItemHelper; -namespace Files.App.Utils +namespace Files.App.Utils.Storage { public static class FolderHelpers { diff --git a/src/Files.App/Utils/Storage/Helpers/FtpHelpers.cs b/src/Files.App/Utils/Storage/Helpers/FtpHelpers.cs index 8a78f9172f26..233664962c88 100644 --- a/src/Files.App/Utils/Storage/Helpers/FtpHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/FtpHelpers.cs @@ -5,7 +5,7 @@ using System; using System.Threading.Tasks; -namespace Files.App.Helpers +namespace Files.App.Utils.Storage { public static class FtpHelpers { diff --git a/src/Files.App/Utils/Storage/Helpers/IStorageItemWithPath.cs b/src/Files.App/Utils/Storage/Helpers/IStorageItemWithPath.cs index e5a5844353ab..91387674077d 100644 --- a/src/Files.App/Utils/Storage/Helpers/IStorageItemWithPath.cs +++ b/src/Files.App/Utils/Storage/Helpers/IStorageItemWithPath.cs @@ -3,7 +3,7 @@ using Windows.Storage; -namespace Files.App.Utils +namespace Files.App.Utils.Storage { public interface IStorageItemWithPath { diff --git a/src/Files.App/Utils/Storage/Helpers/StorageFileExtensions.cs b/src/Files.App/Utils/Storage/Helpers/StorageFileExtensions.cs index d4eb79966f58..81f5ed92ae03 100644 --- a/src/Files.App/Utils/Storage/Helpers/StorageFileExtensions.cs +++ b/src/Files.App/Utils/Storage/Helpers/StorageFileExtensions.cs @@ -5,7 +5,7 @@ using Files.App.Contexts; using Files.App.Data.Items; using Files.App.Extensions; -using Files.App.Utils.StorageItems; +using Files.App.Utils.Storage; using Files.App.Helpers; using Files.App.ViewModels; using Files.App.Views; @@ -20,7 +20,7 @@ using Windows.Storage; using Windows.Storage.Search; -namespace Files.App.Utils +namespace Files.App.Utils.Storage { public static class StorageFileExtensions { diff --git a/src/Files.App/Utils/Storage/Helpers/StorageFileWithPath.cs b/src/Files.App/Utils/Storage/Helpers/StorageFileWithPath.cs index d2c890db91f9..15f833902e73 100644 --- a/src/Files.App/Utils/Storage/Helpers/StorageFileWithPath.cs +++ b/src/Files.App/Utils/Storage/Helpers/StorageFileWithPath.cs @@ -1,7 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.StorageItems; +using Files.App.Utils.Storage; using Windows.Storage; using IO = System.IO; diff --git a/src/Files.App/Utils/Storage/Helpers/StorageFolderWithPath.cs b/src/Files.App/Utils/Storage/Helpers/StorageFolderWithPath.cs index 1581be353787..7e8179c2c356 100644 --- a/src/Files.App/Utils/Storage/Helpers/StorageFolderWithPath.cs +++ b/src/Files.App/Utils/Storage/Helpers/StorageFolderWithPath.cs @@ -1,7 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.StorageItems; +using Files.App.Utils.Storage; using Windows.Storage; using IO = System.IO; diff --git a/src/Files.App/Utils/Storage/Helpers/StorageHelpers.cs b/src/Files.App/Utils/Storage/Helpers/StorageHelpers.cs index 8f4bb369e70a..fc123c4c0826 100644 --- a/src/Files.App/Utils/Storage/Helpers/StorageHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/StorageHelpers.cs @@ -2,7 +2,6 @@ // Licensed under the MIT License. See the LICENSE. using Files.App.Utils; -using Files.App.Utils.StorageItems; using Files.Core.Helpers; using Files.Shared.Enums; using System; diff --git a/src/Files.App/Utils/Storage/Helpers/StorageItemIconHelpers.cs b/src/Files.App/Utils/Storage/Helpers/StorageItemIconHelpers.cs index 512c4149edce..0b909fcfeaef 100644 --- a/src/Files.App/Utils/Storage/Helpers/StorageItemIconHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/StorageItemIconHelpers.cs @@ -7,7 +7,7 @@ using Windows.Storage; using Windows.Storage.FileProperties; -namespace Files.App.Helpers +namespace Files.App.Utils.Storage { public static class StorageItemIconHelpers { diff --git a/src/Files.App/Utils/Storage/Helpers/StorageSenseHelper.cs b/src/Files.App/Utils/Storage/Helpers/StorageSenseHelper.cs index e8a99fb60f14..20412439b957 100644 --- a/src/Files.App/Utils/Storage/Helpers/StorageSenseHelper.cs +++ b/src/Files.App/Utils/Storage/Helpers/StorageSenseHelper.cs @@ -7,7 +7,7 @@ using Windows.Foundation.Metadata; using Windows.System; -namespace Files.App.Helpers +namespace Files.App.Utils.Storage { internal class StorageSenseHelper { diff --git a/src/Files.App/Utils/Storage/History/IStorageHistory.cs b/src/Files.App/Utils/Storage/History/IStorageHistory.cs index 62a8f060a51f..b18d5d1b1bbd 100644 --- a/src/Files.App/Utils/Storage/History/IStorageHistory.cs +++ b/src/Files.App/Utils/Storage/History/IStorageHistory.cs @@ -4,7 +4,7 @@ using Files.Shared.Enums; using System.Collections.Generic; -namespace Files.App.Utils.FilesystemHistory +namespace Files.App.Utils.Storage { public interface IStorageHistory { diff --git a/src/Files.App/Utils/Storage/History/IStorageHistoryOperations.cs b/src/Files.App/Utils/Storage/History/IStorageHistoryOperations.cs index 1ff10af46077..146df766633f 100644 --- a/src/Files.App/Utils/Storage/History/IStorageHistoryOperations.cs +++ b/src/Files.App/Utils/Storage/History/IStorageHistoryOperations.cs @@ -5,7 +5,7 @@ using System; using System.Threading.Tasks; -namespace Files.App.Utils.FilesystemHistory +namespace Files.App.Utils.Storage { public interface IStorageHistoryOperations : IDisposable { diff --git a/src/Files.App/Utils/Storage/History/StorageHistory.cs b/src/Files.App/Utils/Storage/History/StorageHistory.cs index a0a353479292..f478597a41a1 100644 --- a/src/Files.App/Utils/Storage/History/StorageHistory.cs +++ b/src/Files.App/Utils/Storage/History/StorageHistory.cs @@ -5,7 +5,7 @@ using Files.Shared.Extensions; using System.Collections.Generic; -namespace Files.App.Utils.FilesystemHistory +namespace Files.App.Utils.Storage { public class StorageHistory : IStorageHistory { diff --git a/src/Files.App/Utils/Storage/History/StorageHistoryHelpers.cs b/src/Files.App/Utils/Storage/History/StorageHistoryHelpers.cs index 6ba280270a85..2fab31b515a6 100644 --- a/src/Files.App/Utils/Storage/History/StorageHistoryHelpers.cs +++ b/src/Files.App/Utils/Storage/History/StorageHistoryHelpers.cs @@ -6,7 +6,7 @@ using System.Threading; using System.Threading.Tasks; -namespace Files.App.Utils.FilesystemHistory +namespace Files.App.Utils.Storage { public class StorageHistoryHelpers : IDisposable { diff --git a/src/Files.App/Utils/Storage/History/StorageHistoryOperations.cs b/src/Files.App/Utils/Storage/History/StorageHistoryOperations.cs index 168e97d7aac3..4627809b34da 100644 --- a/src/Files.App/Utils/Storage/History/StorageHistoryOperations.cs +++ b/src/Files.App/Utils/Storage/History/StorageHistoryOperations.cs @@ -13,7 +13,7 @@ using System.Threading.Tasks; using Windows.Storage; -namespace Files.App.Utils.FilesystemHistory +namespace Files.App.Utils.Storage { public class StorageHistoryOperations : IStorageHistoryOperations { diff --git a/src/Files.App/Utils/Storage/History/StorageHistoryWrapper.cs b/src/Files.App/Utils/Storage/History/StorageHistoryWrapper.cs index 113f17e3ae6b..42fb4ea13f54 100644 --- a/src/Files.App/Utils/Storage/History/StorageHistoryWrapper.cs +++ b/src/Files.App/Utils/Storage/History/StorageHistoryWrapper.cs @@ -4,7 +4,7 @@ using System; using System.Collections.Generic; -namespace Files.App.Utils.FilesystemHistory +namespace Files.App.Utils.Storage { public class StorageHistoryWrapper : IDisposable { diff --git a/src/Files.App/Utils/Storage/Operations/FileSystemProgress.cs b/src/Files.App/Utils/Storage/Operations/FileSystemProgress.cs index 62293539e21e..7909fe3145c1 100644 --- a/src/Files.App/Utils/Storage/Operations/FileSystemProgress.cs +++ b/src/Files.App/Utils/Storage/Operations/FileSystemProgress.cs @@ -1,7 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -namespace Files.App.Utils +namespace Files.App.Utils.Storage { /// /// Represents a model for file system operation progress. diff --git a/src/Files.App/Utils/Storage/Operations/FilesystemHelpers.cs b/src/Files.App/Utils/Storage/Operations/FilesystemHelpers.cs index 27ab99ae6e05..4108c3d69c6d 100644 --- a/src/Files.App/Utils/Storage/Operations/FilesystemHelpers.cs +++ b/src/Files.App/Utils/Storage/Operations/FilesystemHelpers.cs @@ -1,8 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.FilesystemHistory; -using Files.App.Utils.StorageItems; using Files.Core.Services; using Files.Core.ViewModels.Dialogs.FileSystemDialog; using Files.Core.Storage; @@ -19,7 +17,7 @@ using Windows.Storage.Streams; using FileAttributes = System.IO.FileAttributes; -namespace Files.App.Utils +namespace Files.App.Utils.Storage { public sealed class FilesystemHelpers : IFilesystemHelpers { diff --git a/src/Files.App/Utils/Storage/Operations/FilesystemOperations.cs b/src/Files.App/Utils/Storage/Operations/FilesystemOperations.cs index e81e2d6c19cf..ca788e593be4 100644 --- a/src/Files.App/Utils/Storage/Operations/FilesystemOperations.cs +++ b/src/Files.App/Utils/Storage/Operations/FilesystemOperations.cs @@ -1,14 +1,14 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.FilesystemHistory; -using Files.App.Utils.StorageItems; +using Files.App.Utils.Storage; +using Files.App.Utils.Storage; using Files.Core.Helpers; using Microsoft.UI.Xaml.Controls; using System.IO; using Windows.Storage; -namespace Files.App.Utils +namespace Files.App.Utils.Storage { /// /// Provides group of file system operation for given page instance. diff --git a/src/Files.App/Utils/Storage/Operations/IFilesystemHelpers.cs b/src/Files.App/Utils/Storage/Operations/IFilesystemHelpers.cs index 86d634eca70d..72680dd0e486 100644 --- a/src/Files.App/Utils/Storage/Operations/IFilesystemHelpers.cs +++ b/src/Files.App/Utils/Storage/Operations/IFilesystemHelpers.cs @@ -1,7 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.FilesystemHistory; using Files.Shared.Enums; using System; using System.Collections.Generic; @@ -9,7 +8,7 @@ using Windows.ApplicationModel.DataTransfer; using Windows.Storage; -namespace Files.App.Utils +namespace Files.App.Utils.Storage { public interface IFilesystemHelpers : IDisposable { diff --git a/src/Files.App/Utils/Storage/Operations/IFilesystemOperations.cs b/src/Files.App/Utils/Storage/Operations/IFilesystemOperations.cs index 209a11816bca..a9314866d0f7 100644 --- a/src/Files.App/Utils/Storage/Operations/IFilesystemOperations.cs +++ b/src/Files.App/Utils/Storage/Operations/IFilesystemOperations.cs @@ -1,10 +1,10 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.FilesystemHistory; +using Files.App.Utils.Storage; using Windows.Storage; -namespace Files.App.Utils +namespace Files.App.Utils.Storage { /// /// Represents an interface for file system operations. diff --git a/src/Files.App/Utils/Storage/Operations/ShellFilesystemOperations.cs b/src/Files.App/Utils/Storage/Operations/ShellFilesystemOperations.cs index 32c48535f509..7e5f28a62839 100644 --- a/src/Files.App/Utils/Storage/Operations/ShellFilesystemOperations.cs +++ b/src/Files.App/Utils/Storage/Operations/ShellFilesystemOperations.cs @@ -1,15 +1,15 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.FilesystemHistory; -using Files.App.Utils.StorageItems; +using Files.App.Utils.Storage; +using Files.App.Utils.Storage; using Files.App.Utils.Shell; using Files.Core.Services; using Files.Core.ViewModels.Dialogs.FileSystemDialog; using System.IO; using Windows.Storage; -namespace Files.App.Utils +namespace Files.App.Utils.Storage { /// /// Provides group of shell file system operation for given page instance. diff --git a/src/Files.App/Utils/Storage/Search/FolderSearch.cs b/src/Files.App/Utils/Storage/Search/FolderSearch.cs index 08b50413bc34..0c94f5e9fb47 100644 --- a/src/Files.App/Utils/Storage/Search/FolderSearch.cs +++ b/src/Files.App/Utils/Storage/Search/FolderSearch.cs @@ -5,7 +5,7 @@ using CommunityToolkit.WinUI; using Files.App.Data.Items; using Files.App.Extensions; -using Files.App.Utils.StorageItems; +using Files.App.Utils.Storage; using Files.App.Helpers; using Files.App.ViewModels; using Files.Core.Services.Settings; @@ -25,7 +25,7 @@ using FileAttributes = System.IO.FileAttributes; using WIN32_FIND_DATA = Files.Core.Helpers.NativeFindStorageItemHelper.WIN32_FIND_DATA; -namespace Files.App.Utils.Search +namespace Files.App.Utils.Storage { public class FolderSearch { diff --git a/src/Files.App/Utils/Storage/Security/AccessControlEntry.cs b/src/Files.App/Utils/Storage/Security/AccessControlEntry.cs index 20b6f8cd1b29..2ddc65425927 100644 --- a/src/Files.App/Utils/Storage/Security/AccessControlEntry.cs +++ b/src/Files.App/Utils/Storage/Security/AccessControlEntry.cs @@ -10,7 +10,7 @@ using System.Collections.ObjectModel; using System.Linq; -namespace Files.App.Utils.Security +namespace Files.App.Utils.Storage { /// /// Represents an access control entry (ACE). diff --git a/src/Files.App/Utils/Storage/Security/AccessControlEntryFlags.cs b/src/Files.App/Utils/Storage/Security/AccessControlEntryFlags.cs index 97f27257be6c..6663beb01116 100644 --- a/src/Files.App/Utils/Storage/Security/AccessControlEntryFlags.cs +++ b/src/Files.App/Utils/Storage/Security/AccessControlEntryFlags.cs @@ -1,7 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -namespace Files.App.Utils.Security +namespace Files.App.Utils.Storage { /// /// Represents inheritance flags of an ACE diff --git a/src/Files.App/Utils/Storage/Security/AccessControlEntryType.cs b/src/Files.App/Utils/Storage/Security/AccessControlEntryType.cs index 52166b26ec68..5808242154cf 100644 --- a/src/Files.App/Utils/Storage/Security/AccessControlEntryType.cs +++ b/src/Files.App/Utils/Storage/Security/AccessControlEntryType.cs @@ -1,7 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -namespace Files.App.Utils.Security +namespace Files.App.Utils.Storage { /// /// Represents ACE type. diff --git a/src/Files.App/Utils/Storage/Security/AccessControlList.cs b/src/Files.App/Utils/Storage/Security/AccessControlList.cs index 37ed5f912b8a..8f3acb76d0d8 100644 --- a/src/Files.App/Utils/Storage/Security/AccessControlList.cs +++ b/src/Files.App/Utils/Storage/Security/AccessControlList.cs @@ -1,7 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -namespace Files.App.Utils.Security +namespace Files.App.Utils.Storage { /// /// Represents an access control list (ACL). diff --git a/src/Files.App/Utils/Storage/Security/AccessMaskFlags.cs b/src/Files.App/Utils/Storage/Security/AccessMaskFlags.cs index 1b2753fea4cb..995674d5feb5 100644 --- a/src/Files.App/Utils/Storage/Security/AccessMaskFlags.cs +++ b/src/Files.App/Utils/Storage/Security/AccessMaskFlags.cs @@ -3,7 +3,7 @@ using System; -namespace Files.App.Utils.Security +namespace Files.App.Utils.Storage { /// /// Represents access mask flags of an ACE. diff --git a/src/Files.App/Utils/Storage/Security/AccessMaskItem.cs b/src/Files.App/Utils/Storage/Security/AccessMaskItem.cs index 7351875a39d1..e98c01f90a5f 100644 --- a/src/Files.App/Utils/Storage/Security/AccessMaskItem.cs +++ b/src/Files.App/Utils/Storage/Security/AccessMaskItem.cs @@ -4,7 +4,7 @@ using CommunityToolkit.Mvvm.ComponentModel; using System.ComponentModel; -namespace Files.App.Utils.Security +namespace Files.App.Utils.Storage { /// /// Represents an access mask details, such as its name and changeability. diff --git a/src/Files.App/Utils/Storage/Security/Principal.cs b/src/Files.App/Utils/Storage/Security/Principal.cs index 5139d41ec25b..9efd117413dc 100644 --- a/src/Files.App/Utils/Storage/Security/Principal.cs +++ b/src/Files.App/Utils/Storage/Security/Principal.cs @@ -5,7 +5,7 @@ using Vanara.PInvoke; using static Vanara.PInvoke.AdvApi32; -namespace Files.App.Utils.Security +namespace Files.App.Utils.Storage { /// /// Represents a principal of an ACE or an owner of an ACL. diff --git a/src/Files.App/Utils/Storage/Security/PrincipalType.cs b/src/Files.App/Utils/Storage/Security/PrincipalType.cs index 3b9718f90b7f..c594aadd3551 100644 --- a/src/Files.App/Utils/Storage/Security/PrincipalType.cs +++ b/src/Files.App/Utils/Storage/Security/PrincipalType.cs @@ -1,7 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -namespace Files.App.Utils.Security +namespace Files.App.Utils.Storage { /// /// Represents an ACL owner or an ACE principal type diff --git a/src/Files.App/Utils/Storage/StorageBaseItems/BaseBasicProperties.cs b/src/Files.App/Utils/Storage/StorageBaseItems/BaseBasicProperties.cs index b0e2f7f6097e..b1e880ecee83 100644 --- a/src/Files.App/Utils/Storage/StorageBaseItems/BaseBasicProperties.cs +++ b/src/Files.App/Utils/Storage/StorageBaseItems/BaseBasicProperties.cs @@ -1,7 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public class BaseBasicProperties : BaseStorageItemExtraProperties { diff --git a/src/Files.App/Utils/Storage/StorageBaseItems/BaseBasicStorageItemExtraProperties.cs b/src/Files.App/Utils/Storage/StorageBaseItems/BaseBasicStorageItemExtraProperties.cs index bd446839ee02..18ab84748730 100644 --- a/src/Files.App/Utils/Storage/StorageBaseItems/BaseBasicStorageItemExtraProperties.cs +++ b/src/Files.App/Utils/Storage/StorageBaseItems/BaseBasicStorageItemExtraProperties.cs @@ -5,7 +5,7 @@ using Windows.Foundation; using Windows.Storage; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public class BaseBasicStorageItemExtraProperties : BaseStorageItemExtraProperties { diff --git a/src/Files.App/Utils/Storage/StorageBaseItems/BaseStorageFile.cs b/src/Files.App/Utils/Storage/StorageBaseItems/BaseStorageFile.cs index cb503901a9eb..4cfdd3159b7f 100644 --- a/src/Files.App/Utils/Storage/StorageBaseItems/BaseStorageFile.cs +++ b/src/Files.App/Utils/Storage/StorageBaseItems/BaseStorageFile.cs @@ -9,7 +9,7 @@ using Windows.Storage.FileProperties; using Windows.Storage.Streams; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public abstract class BaseStorageFile : IBaseStorageFile { diff --git a/src/Files.App/Utils/Storage/StorageBaseItems/BaseStorageFolder.cs b/src/Files.App/Utils/Storage/StorageBaseItems/BaseStorageFolder.cs index fe4731fea22a..9d602a655262 100644 --- a/src/Files.App/Utils/Storage/StorageBaseItems/BaseStorageFolder.cs +++ b/src/Files.App/Utils/Storage/StorageBaseItems/BaseStorageFolder.cs @@ -7,7 +7,7 @@ using Windows.Storage.FileProperties; using Windows.Storage.Search; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public abstract class BaseStorageFolder : IBaseStorageFolder { diff --git a/src/Files.App/Utils/Storage/StorageBaseItems/BaseStorageItemExtraProperties.cs b/src/Files.App/Utils/Storage/StorageBaseItems/BaseStorageItemExtraProperties.cs index bc90b5a4bc71..1c6e8c7a737f 100644 --- a/src/Files.App/Utils/Storage/StorageBaseItems/BaseStorageItemExtraProperties.cs +++ b/src/Files.App/Utils/Storage/StorageBaseItems/BaseStorageItemExtraProperties.cs @@ -6,7 +6,7 @@ using Windows.Foundation.Metadata; using Windows.Storage.FileProperties; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public class BaseStorageItemExtraProperties : IStorageItemExtraProperties { diff --git a/src/Files.App/Utils/Storage/StorageBaseItems/IBaseStorageFile.cs b/src/Files.App/Utils/Storage/StorageBaseItems/IBaseStorageFile.cs index e3f4008c471e..66af49d24212 100644 --- a/src/Files.App/Utils/Storage/StorageBaseItems/IBaseStorageFile.cs +++ b/src/Files.App/Utils/Storage/StorageBaseItems/IBaseStorageFile.cs @@ -5,7 +5,7 @@ using Windows.Storage; using Windows.Storage.FileProperties; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public interface IBaseStorageFile : IStorageItem2, IStorageFile, IStorageFile2, IStorageItemProperties2, IStorageItemPropertiesWithProvider, IStorageFilePropertiesWithAvailability { diff --git a/src/Files.App/Utils/Storage/StorageBaseItems/IBaseStorageFolder.cs b/src/Files.App/Utils/Storage/StorageBaseItems/IBaseStorageFolder.cs index ef782bf8dfff..e85ef38357de 100644 --- a/src/Files.App/Utils/Storage/StorageBaseItems/IBaseStorageFolder.cs +++ b/src/Files.App/Utils/Storage/StorageBaseItems/IBaseStorageFolder.cs @@ -7,7 +7,7 @@ using Windows.Storage.FileProperties; using Windows.Storage.Search; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public interface IBaseStorageFolder : IStorageItem2, IStorageFolder, IStorageFolder2, IStorageItemProperties2, IStorageItemPropertiesWithProvider, IStorageFolderQueryOperations { diff --git a/src/Files.App/Utils/Storage/StorageBaseItems/ICreateFileWithStream.cs b/src/Files.App/Utils/Storage/StorageBaseItems/ICreateFileWithStream.cs index 2919002eb074..71b036cb5b68 100644 --- a/src/Files.App/Utils/Storage/StorageBaseItems/ICreateFileWithStream.cs +++ b/src/Files.App/Utils/Storage/StorageBaseItems/ICreateFileWithStream.cs @@ -5,7 +5,7 @@ using Windows.Foundation; using Windows.Storage; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public interface ICreateFileWithStream { diff --git a/src/Files.App/Utils/Storage/StorageItems/BaseQueryResults.cs b/src/Files.App/Utils/Storage/StorageItems/BaseQueryResults.cs index ff812c8910f0..9cf247ad1628 100644 --- a/src/Files.App/Utils/Storage/StorageItems/BaseQueryResults.cs +++ b/src/Files.App/Utils/Storage/StorageItems/BaseQueryResults.cs @@ -10,7 +10,7 @@ using Windows.Storage; using Windows.Storage.Search; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public class BaseStorageItemQueryResult { diff --git a/src/Files.App/Utils/Storage/StorageItems/FtpStorageFile.cs b/src/Files.App/Utils/Storage/StorageItems/FtpStorageFile.cs index 4fc041e8f841..953d66f7470f 100644 --- a/src/Files.App/Utils/Storage/StorageItems/FtpStorageFile.cs +++ b/src/Files.App/Utils/Storage/StorageItems/FtpStorageFile.cs @@ -11,7 +11,7 @@ using Windows.Storage.Streams; using IO = System.IO; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public sealed class FtpStorageFile : BaseStorageFile { diff --git a/src/Files.App/Utils/Storage/StorageItems/FtpStorageFolder.cs b/src/Files.App/Utils/Storage/StorageItems/FtpStorageFolder.cs index 74dbf03e3d13..ba7bc6bcdb20 100644 --- a/src/Files.App/Utils/Storage/StorageItems/FtpStorageFolder.cs +++ b/src/Files.App/Utils/Storage/StorageItems/FtpStorageFolder.cs @@ -11,7 +11,7 @@ using Windows.Storage.FileProperties; using Windows.Storage.Search; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public sealed class FtpStorageFolder : BaseStorageFolder { diff --git a/src/Files.App/Utils/Storage/StorageItems/NativeStorageFile.cs b/src/Files.App/Utils/Storage/StorageItems/NativeStorageFile.cs index 431dbed2e16a..4ab25a73136e 100644 --- a/src/Files.App/Utils/Storage/StorageItems/NativeStorageFile.cs +++ b/src/Files.App/Utils/Storage/StorageItems/NativeStorageFile.cs @@ -16,7 +16,7 @@ using Windows.Storage.Streams; using IO = System.IO; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { /// /// Shortcuts and alternate data stream. diff --git a/src/Files.App/Utils/Storage/StorageItems/ShellStorageFile.cs b/src/Files.App/Utils/Storage/StorageItems/ShellStorageFile.cs index 41312bdd5763..a5173fa6446a 100644 --- a/src/Files.App/Utils/Storage/StorageItems/ShellStorageFile.cs +++ b/src/Files.App/Utils/Storage/StorageItems/ShellStorageFile.cs @@ -12,7 +12,7 @@ using Windows.Storage.Streams; using IO = System.IO; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public class ShortcutStorageFile : ShellStorageFile, IShortcutStorageItem { diff --git a/src/Files.App/Utils/Storage/StorageItems/ShellStorageFolder.cs b/src/Files.App/Utils/Storage/StorageItems/ShellStorageFolder.cs index cfd7d59c9163..ebe561da839d 100644 --- a/src/Files.App/Utils/Storage/StorageItems/ShellStorageFolder.cs +++ b/src/Files.App/Utils/Storage/StorageItems/ShellStorageFolder.cs @@ -13,7 +13,7 @@ using Windows.Storage.FileProperties; using Windows.Storage.Search; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public class ShortcutStorageFolder : ShellStorageFolder, IShortcutStorageItem { diff --git a/src/Files.App/Utils/Storage/StorageItems/StreamWithContentType.cs b/src/Files.App/Utils/Storage/StorageItems/StreamWithContentType.cs index 56c12189fe45..8cb1ad5c575c 100644 --- a/src/Files.App/Utils/Storage/StorageItems/StreamWithContentType.cs +++ b/src/Files.App/Utils/Storage/StorageItems/StreamWithContentType.cs @@ -8,7 +8,7 @@ using Windows.Foundation; using Windows.Storage.Streams; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public class InputStreamWithDisposeCallback : IInputStream { diff --git a/src/Files.App/Utils/Storage/StorageItems/SystemStorageFile.cs b/src/Files.App/Utils/Storage/StorageItems/SystemStorageFile.cs index bd5902ff0741..f17ff828916b 100644 --- a/src/Files.App/Utils/Storage/StorageItems/SystemStorageFile.cs +++ b/src/Files.App/Utils/Storage/StorageItems/SystemStorageFile.cs @@ -14,7 +14,7 @@ using Windows.Storage.Streams; using IO = System.IO; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public sealed class SystemStorageFile : BaseStorageFile { diff --git a/src/Files.App/Utils/Storage/StorageItems/SystemStorageFolder.cs b/src/Files.App/Utils/Storage/StorageItems/SystemStorageFolder.cs index 8b4ad1cd73a0..1432a8a09c00 100644 --- a/src/Files.App/Utils/Storage/StorageItems/SystemStorageFolder.cs +++ b/src/Files.App/Utils/Storage/StorageItems/SystemStorageFolder.cs @@ -12,7 +12,7 @@ using Windows.Storage.FileProperties; using Windows.Storage.Search; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public sealed class SystemStorageFolder : BaseStorageFolder { diff --git a/src/Files.App/Utils/Storage/StorageItems/VirtualStorageFile.cs b/src/Files.App/Utils/Storage/StorageItems/VirtualStorageFile.cs index f3b9ee3ebc1d..7c938f5e6c54 100644 --- a/src/Files.App/Utils/Storage/StorageItems/VirtualStorageFile.cs +++ b/src/Files.App/Utils/Storage/StorageItems/VirtualStorageFile.cs @@ -9,7 +9,7 @@ using Windows.Storage.Streams; using IO = System.IO; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public class VirtualStorageFile : BaseStorageFile { diff --git a/src/Files.App/Utils/Storage/StorageItems/VirtualStorageFolder.cs b/src/Files.App/Utils/Storage/StorageItems/VirtualStorageFolder.cs index 6eef2a81eaa8..47e890f50ae8 100644 --- a/src/Files.App/Utils/Storage/StorageItems/VirtualStorageFolder.cs +++ b/src/Files.App/Utils/Storage/StorageItems/VirtualStorageFolder.cs @@ -7,7 +7,7 @@ using Windows.Storage.FileProperties; using Windows.Storage.Search; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public class VirtualStorageFolder : BaseStorageFolder { diff --git a/src/Files.App/Utils/Storage/StorageItems/VirtualStorageItem.cs b/src/Files.App/Utils/Storage/StorageItems/VirtualStorageItem.cs index a132a4db9995..b41ddfe004d8 100644 --- a/src/Files.App/Utils/Storage/StorageItems/VirtualStorageItem.cs +++ b/src/Files.App/Utils/Storage/StorageItems/VirtualStorageItem.cs @@ -11,7 +11,7 @@ using Windows.Storage.FileProperties; using static Files.Core.Helpers.NativeFindStorageItemHelper; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { /// /// Implements IStorageItem, allowing us to get an instance of IStorageItem for a ListedItem diff --git a/src/Files.App/Utils/Storage/StorageItems/ZipStorageFile.cs b/src/Files.App/Utils/Storage/StorageItems/ZipStorageFile.cs index 6fd9699a20d9..b0b204036f2e 100644 --- a/src/Files.App/Utils/Storage/StorageItems/ZipStorageFile.cs +++ b/src/Files.App/Utils/Storage/StorageItems/ZipStorageFile.cs @@ -17,7 +17,7 @@ using Windows.Storage.Streams; using IO = System.IO; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public sealed class ZipStorageFile : BaseStorageFile { diff --git a/src/Files.App/Utils/Storage/StorageItems/ZipStorageFolder.cs b/src/Files.App/Utils/Storage/StorageItems/ZipStorageFolder.cs index 0a44e79861b9..046754c280fc 100644 --- a/src/Files.App/Utils/Storage/StorageItems/ZipStorageFolder.cs +++ b/src/Files.App/Utils/Storage/StorageItems/ZipStorageFolder.cs @@ -20,7 +20,7 @@ using Windows.Storage.Search; using IO = System.IO; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public sealed class ZipStorageFolder : BaseStorageFolder, ICreateFileWithStream { diff --git a/src/Files.App/ViewModels/MainPageViewModel.cs b/src/Files.App/ViewModels/MainPageViewModel.cs index 12b1dfed9ee4..415b1a73f906 100644 --- a/src/Files.App/ViewModels/MainPageViewModel.cs +++ b/src/Files.App/ViewModels/MainPageViewModel.cs @@ -1,7 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.StorageItems; using Files.App.UserControls.MultitaskingControl; using Microsoft.UI.Xaml.Controls; using Microsoft.UI.Xaml.Input; diff --git a/src/Files.App/ViewModels/Previews/BasePreviewModel.cs b/src/Files.App/ViewModels/Previews/BasePreviewModel.cs index bc804e38dc72..1cebfecb6b6b 100644 --- a/src/Files.App/ViewModels/Previews/BasePreviewModel.cs +++ b/src/Files.App/ViewModels/Previews/BasePreviewModel.cs @@ -1,7 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.StorageItems; using Files.App.ViewModels.Properties; using Microsoft.UI.Xaml; using Microsoft.UI.Xaml.Media.Imaging; diff --git a/src/Files.App/ViewModels/Previews/FolderPreviewViewModel.cs b/src/Files.App/ViewModels/Previews/FolderPreviewViewModel.cs index 1973a4dc825e..e1aef3bcb292 100644 --- a/src/Files.App/ViewModels/Previews/FolderPreviewViewModel.cs +++ b/src/Files.App/ViewModels/Previews/FolderPreviewViewModel.cs @@ -1,7 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.StorageItems; using Files.App.ViewModels.Properties; using Files.Shared.Services.DateTimeFormatter; using Microsoft.UI.Xaml.Media.Imaging; diff --git a/src/Files.App/ViewModels/Properties/Items/CombinedFileProperties.cs b/src/Files.App/ViewModels/Properties/Items/CombinedFileProperties.cs index d1372a888096..874d24c60d01 100644 --- a/src/Files.App/ViewModels/Properties/Items/CombinedFileProperties.cs +++ b/src/Files.App/ViewModels/Properties/Items/CombinedFileProperties.cs @@ -1,7 +1,6 @@ // Copyright(c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.StorageItems; using Microsoft.UI.Dispatching; namespace Files.App.ViewModels.Properties diff --git a/src/Files.App/ViewModels/Properties/Items/DriveProperties.cs b/src/Files.App/ViewModels/Properties/Items/DriveProperties.cs index 0596781ecc21..aaa5a5e40cef 100644 --- a/src/Files.App/ViewModels/Properties/Items/DriveProperties.cs +++ b/src/Files.App/ViewModels/Properties/Items/DriveProperties.cs @@ -1,7 +1,6 @@ using Files.App.Data.Items; using Files.App.Extensions; using Files.App.Utils; -using Files.App.Utils.StorageItems; using Files.App.Helpers; using Microsoft.Extensions.Logging; using System; diff --git a/src/Files.App/ViewModels/Properties/Items/FileProperties.cs b/src/Files.App/ViewModels/Properties/Items/FileProperties.cs index 82a70bfe14ca..75eba8907097 100644 --- a/src/Files.App/ViewModels/Properties/Items/FileProperties.cs +++ b/src/Files.App/ViewModels/Properties/Items/FileProperties.cs @@ -1,7 +1,6 @@ // Copyright(c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.StorageItems; using Files.Core.Helpers; using Microsoft.UI.Dispatching; using System.IO; diff --git a/src/Files.App/ViewModels/Properties/Items/FileProperty.cs b/src/Files.App/ViewModels/Properties/Items/FileProperty.cs index 0436d3f860a5..70bd644e23e4 100644 --- a/src/Files.App/ViewModels/Properties/Items/FileProperty.cs +++ b/src/Files.App/ViewModels/Properties/Items/FileProperty.cs @@ -2,7 +2,6 @@ // Licensed under the MIT License. See the LICENSE. using Files.App.Converters; -using Files.App.Utils.StorageItems; using Microsoft.UI.Xaml; using Microsoft.UI.Xaml.Data; using System.Text.Json; diff --git a/src/Files.App/ViewModels/Properties/Items/FolderProperties.cs b/src/Files.App/ViewModels/Properties/Items/FolderProperties.cs index 30850ae8dddf..9af9b5c877e1 100644 --- a/src/Files.App/ViewModels/Properties/Items/FolderProperties.cs +++ b/src/Files.App/ViewModels/Properties/Items/FolderProperties.cs @@ -2,7 +2,6 @@ // Licensed under the MIT License. See the LICENSE. using ByteSizeLib; -using Files.App.Utils.StorageItems; using Files.App.Utils.Shell; using Microsoft.Extensions.Logging; using Microsoft.UI.Dispatching; diff --git a/src/Files.App/ViewModels/Properties/Items/LibraryProperties.cs b/src/Files.App/ViewModels/Properties/Items/LibraryProperties.cs index f2beb7c33368..1d9d6eb8a793 100644 --- a/src/Files.App/ViewModels/Properties/Items/LibraryProperties.cs +++ b/src/Files.App/ViewModels/Properties/Items/LibraryProperties.cs @@ -1,7 +1,6 @@ using CommunityToolkit.Mvvm.DependencyInjection; using Files.App.Extensions; using Files.App.Utils; -using Files.App.Utils.StorageItems; using Files.App.Helpers; using Files.Shared.Services.DateTimeFormatter; using Microsoft.Extensions.Logging; diff --git a/src/Files.App/ViewModels/Properties/SecurityAdvancedViewModel.cs b/src/Files.App/ViewModels/Properties/SecurityAdvancedViewModel.cs index 3ef475538864..edd42b7bda4a 100644 --- a/src/Files.App/ViewModels/Properties/SecurityAdvancedViewModel.cs +++ b/src/Files.App/ViewModels/Properties/SecurityAdvancedViewModel.cs @@ -1,7 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.Security; using Microsoft.UI.Xaml; using Vanara.PInvoke; using Windows.Storage; diff --git a/src/Files.App/ViewModels/Properties/SecurityViewModel.cs b/src/Files.App/ViewModels/Properties/SecurityViewModel.cs index 54bfdc3891ff..7da9e5ec45e9 100644 --- a/src/Files.App/ViewModels/Properties/SecurityViewModel.cs +++ b/src/Files.App/ViewModels/Properties/SecurityViewModel.cs @@ -2,7 +2,6 @@ // Licensed under the MIT License. See the LICENSE. using CommunityToolkit.WinUI; -using Files.App.Utils.Security; using Microsoft.UI.Xaml; using Vanara.PInvoke; using Windows.Storage; diff --git a/src/Files.App/ViewModels/Settings/AdvancedViewModel.cs b/src/Files.App/ViewModels/Settings/AdvancedViewModel.cs index 10da12107cfa..254a02be8d7a 100644 --- a/src/Files.App/ViewModels/Settings/AdvancedViewModel.cs +++ b/src/Files.App/ViewModels/Settings/AdvancedViewModel.cs @@ -1,7 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.StorageItems; using Files.App.Utils.Shell; using Microsoft.Extensions.Logging; using Microsoft.Win32; diff --git a/src/Files.App/ViewModels/UserControls/ToolbarViewModel.cs b/src/Files.App/ViewModels/UserControls/ToolbarViewModel.cs index 30f5688b7b95..ef58e76ec684 100644 --- a/src/Files.App/ViewModels/UserControls/ToolbarViewModel.cs +++ b/src/Files.App/ViewModels/UserControls/ToolbarViewModel.cs @@ -4,7 +4,6 @@ using CommunityToolkit.WinUI.UI; using Files.App.Commands; using Files.App.Contexts; -using Files.App.Utils.StorageItems; using Files.App.Utils.Shell; using Files.Core.Helpers; using Files.Core.Services; diff --git a/src/Files.App/Views/LayoutModes/BaseLayout.cs b/src/Files.App/Views/LayoutModes/BaseLayout.cs index 178bac58fe8b..b4c4c17e834f 100644 --- a/src/Files.App/Views/LayoutModes/BaseLayout.cs +++ b/src/Files.App/Views/LayoutModes/BaseLayout.cs @@ -445,7 +445,7 @@ protected override async void OnNavigatedTo(NavigationEventArgs eventArgs) { var displayName = App.LibraryManager.TryGetLibrary(navigationArguments.SearchPathParam, out var lib) ? lib.Text : navigationArguments.SearchPathParam; ParentShellPageInstance.UpdatePathUIToWorkingDirectory(null, string.Format("SearchPagePathBoxOverrideText".GetLocalizedResource(), navigationArguments.SearchQuery, displayName)); - var searchInstance = new Utils.Search.FolderSearch + var searchInstance = new Utils.Storage.FolderSearch { Query = navigationArguments.SearchQuery, Folder = navigationArguments.SearchPathParam, diff --git a/src/Files.App/Views/Properties/SecurityAdvancedPage.xaml b/src/Files.App/Views/Properties/SecurityAdvancedPage.xaml index 63925c420348..7333b9ce76ab 100644 --- a/src/Files.App/Views/Properties/SecurityAdvancedPage.xaml +++ b/src/Files.App/Views/Properties/SecurityAdvancedPage.xaml @@ -8,7 +8,7 @@ xmlns:helpers="using:Files.App.Helpers" xmlns:i="using:Microsoft.Xaml.Interactivity" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" - xmlns:security="using:Files.App.Utils.Security" + xmlns:security="using:Files.App.Utils.Storage" xmlns:toolkit="using:CommunityToolkit.WinUI.UI.Controls" xmlns:uc="using:Files.App.UserControls" xmlns:vm="using:Files.App.ViewModels.Properties" diff --git a/src/Files.App/Views/Properties/SecurityPage.xaml b/src/Files.App/Views/Properties/SecurityPage.xaml index 26b0e8074b18..f48efc9e1562 100644 --- a/src/Files.App/Views/Properties/SecurityPage.xaml +++ b/src/Files.App/Views/Properties/SecurityPage.xaml @@ -6,7 +6,7 @@ xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:helpers="using:Files.App.Helpers" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" - xmlns:security="using:Files.App.Utils.Security" + xmlns:security="using:Files.App.Utils.Storage" xmlns:vm="using:Files.App.ViewModels.Properties" xmlns:wctconverters="using:CommunityToolkit.WinUI.UI.Converters" DataContext="{x:Bind SecurityViewModel, Mode=OneWay}" diff --git a/src/Files.App/Views/Shells/BaseShellPage.cs b/src/Files.App/Views/Shells/BaseShellPage.cs index dc37947b3cb6..8e98f784755c 100644 --- a/src/Files.App/Views/Shells/BaseShellPage.cs +++ b/src/Files.App/Views/Shells/BaseShellPage.cs @@ -2,8 +2,6 @@ // Licensed under the MIT License. See the LICENSE. using Files.App.Commands; -using Files.App.Utils.FilesystemHistory; -using Files.App.Utils.Search; using Files.App.UserControls.MultitaskingControl; using Files.Core.Services; using Microsoft.UI.Input; diff --git a/src/Files.App/Views/Shells/IShellPage.cs b/src/Files.App/Views/Shells/IShellPage.cs index 58fda4445e74..2cb6f695aece 100644 --- a/src/Files.App/Views/Shells/IShellPage.cs +++ b/src/Files.App/Views/Shells/IShellPage.cs @@ -1,7 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.FilesystemHistory; using Files.App.UserControls.MultitaskingControl; namespace Files.App.Views.Shells From a3bc82e7212c1bd30238e2092bef35af4e5e5dbe Mon Sep 17 00:00:00 2001 From: 0x5BFA <62196528+0x5bfa@users.noreply.github.com> Date: Sun, 9 Jul 2023 16:15:02 +0900 Subject: [PATCH 03/12] Remove unnecessary using directives --- .../BaseLayoutCommandImplementationModel.cs | 6 ++--- .../UserControls/SidebarControl.xaml.cs | 4 ++-- .../Utils/Cloud/CloudDrivesDetector.cs | 2 +- .../Utils/Global/WallpaperHelpers.cs | 2 +- .../Storage/Cache/IStorageCacheController.cs | 5 +--- .../Storage/Cache/StorageCacheController.cs | 14 +++++------ .../Collection/BlockingListEnumerator.cs | 22 ++++++++---------- .../BulkConcurrentObservableCollection.cs | 8 ------- .../Storage/Collection/GroupedCollection.cs | 5 ---- .../Utils/Storage/Collection/SortingHelper.cs | 5 ---- .../Enumerators/UniversalStorageEnumerator.cs | 22 +++++------------- .../Enumerators/Win32StorageEnumerator.cs | 22 ++++++++---------- .../Utils/Storage/Helpers/DeviceManager.cs | 2 -- .../Utils/Storage/Helpers/DriveHelpers.cs | 9 -------- .../Storage/Helpers/ErrorCodeConverter.cs | 2 -- .../Storage/Helpers/FileOperationsHelpers.cs | 2 -- .../Storage/Helpers/FilePropertiesHelpers.cs | 1 - .../Storage/Helpers/FileSecurityHelpers.cs | 1 - .../Storage/Helpers/FileThumbnailHelper.cs | 6 ----- .../Utils/Storage/Helpers/FilesystemResult.cs | 2 -- .../Utils/Storage/Helpers/FolderHelpers.cs | 3 --- .../Utils/Storage/Helpers/FtpHelpers.cs | 2 -- .../Storage/Helpers/StorageFileExtensions.cs | 13 ----------- .../Storage/Helpers/StorageFileWithPath.cs | 1 - .../Storage/Helpers/StorageFolderWithPath.cs | 1 - .../Utils/Storage/Helpers/StorageHelpers.cs | 6 ----- .../Storage/Helpers/StorageItemIconHelpers.cs | 3 --- .../Storage/Helpers/StorageSenseHelper.cs | 3 --- .../Utils/Storage/History/IStorageHistory.cs | 3 --- .../History/IStorageHistoryOperations.cs | 4 ---- .../Utils/Storage/History/StorageHistory.cs | 4 ---- .../Storage/History/StorageHistoryHelpers.cs | 5 ---- .../History/StorageHistoryOperations.cs | 9 -------- .../Storage/History/StorageHistoryWrapper.cs | 3 --- .../Storage/Operations/FilesystemHelpers.cs | 2 -- .../Operations/FilesystemOperations.cs | 3 --- .../Storage/Operations/IFilesystemHelpers.cs | 4 ---- .../Operations/IFilesystemOperations.cs | 1 - .../Operations/ShellFilesystemOperations.cs | 5 ---- .../Utils/Storage/Search/FolderSearch.cs | 15 ------------ .../Storage/Security/AccessControlEntry.cs | 9 -------- .../Utils/Storage/Security/AccessMaskFlags.cs | 2 -- .../Utils/Storage/Security/AccessMaskItem.cs | 3 --- .../Storage/StorageItems/BaseQueryResults.cs | 3 --- .../Storage/StorageItems/NativeStorageFile.cs | 6 ----- .../Storage/StorageItems/ShellStorageFile.cs | 4 ---- .../StorageItems/ShellStorageFolder.cs | 6 ----- .../Storage/StorageItems/SystemStorageFile.cs | 4 ---- .../StorageItems/SystemStorageFolder.cs | 4 ---- .../StorageItems/VirtualStorageItem.cs | 3 --- .../Storage/StorageItems/ZipStorageFile.cs | 7 ------ .../Storage/StorageItems/ZipStorageFolder.cs | 8 ------- .../Views/LayoutModes/ColumnViewBase.xaml | 23 ++++++++++--------- .../LayoutModes/DetailsLayoutBrowser.xaml | 23 ++++++++++--------- .../Views/LayoutModes/GridViewBrowser.xaml | 23 ++++++++++--------- 55 files changed, 74 insertions(+), 286 deletions(-) diff --git a/src/Files.App/Interacts/BaseLayoutCommandImplementationModel.cs b/src/Files.App/Interacts/BaseLayoutCommandImplementationModel.cs index 1e6917f22a11..56c1b398948a 100644 --- a/src/Files.App/Interacts/BaseLayoutCommandImplementationModel.cs +++ b/src/Files.App/Interacts/BaseLayoutCommandImplementationModel.cs @@ -139,11 +139,11 @@ public virtual async Task DragOver(DragEventArgs e) itemManipulationModel.ClearSelection(); - if (Utils.FilesystemHelpers.HasDraggedStorageItems(e.DataView)) + if (FilesystemHelpers.HasDraggedStorageItems(e.DataView)) { e.Handled = true; - var draggedItems = await Utils.FilesystemHelpers.GetDraggedStorageItems(e.DataView); + var draggedItems = await FilesystemHelpers.GetDraggedStorageItems(e.DataView); var pwd = associatedInstance.FilesystemViewModel.WorkingDirectory.TrimPath(); var folderName = (Path.IsPathRooted(pwd) && Path.GetPathRoot(pwd) == pwd) ? Path.GetPathRoot(pwd) : Path.GetFileName(pwd); @@ -208,7 +208,7 @@ public virtual async Task Drop(DragEventArgs e) { var deferral = e.GetDeferral(); - if (Utils.FilesystemHelpers.HasDraggedStorageItems(e.DataView)) + if (FilesystemHelpers.HasDraggedStorageItems(e.DataView)) { await associatedInstance.FilesystemHelpers.PerformOperationTypeAsync(e.AcceptedOperation, e.DataView, associatedInstance.FilesystemViewModel.WorkingDirectory, false, true); e.Handled = true; diff --git a/src/Files.App/UserControls/SidebarControl.xaml.cs b/src/Files.App/UserControls/SidebarControl.xaml.cs index b7fe94373648..a7fd6a14def8 100644 --- a/src/Files.App/UserControls/SidebarControl.xaml.cs +++ b/src/Files.App/UserControls/SidebarControl.xaml.cs @@ -786,7 +786,7 @@ private async void NavigationViewFileTagItem_DragOver(object sender, DragEventAr var deferral = e.GetDeferral(); e.Handled = true; - var storageItems = await Utils.FilesystemHelpers.GetDraggedStorageItems(e.DataView); + var storageItems = await FilesystemHelpers.GetDraggedStorageItems(e.DataView); if (!storageItems.Any()) { @@ -819,7 +819,7 @@ private async void NavigationViewFileTag_Drop(object sender, DragEventArgs e) var deferral = e.GetDeferral(); - var storageItems = await Utils.FilesystemHelpers.GetDraggedStorageItems(e.DataView); + var storageItems = await FilesystemHelpers.GetDraggedStorageItems(e.DataView); foreach (var item in storageItems.Where(x => !string.IsNullOrEmpty(x.Path))) { var listedItem = new ListedItem(null) diff --git a/src/Files.App/Utils/Cloud/CloudDrivesDetector.cs b/src/Files.App/Utils/Cloud/CloudDrivesDetector.cs index 96ada7be1ee2..e1a08dd974fe 100644 --- a/src/Files.App/Utils/Cloud/CloudDrivesDetector.cs +++ b/src/Files.App/Utils/Cloud/CloudDrivesDetector.cs @@ -12,7 +12,7 @@ using System.Runtime.Versioning; using System.Threading.Tasks; -namespace Files.App.Helpers +namespace Files.App.Utils.Cloud { [SupportedOSPlatform("Windows10.0.10240")] public class CloudDrivesDetector diff --git a/src/Files.App/Utils/Global/WallpaperHelpers.cs b/src/Files.App/Utils/Global/WallpaperHelpers.cs index 147999040ac5..034bd0985b23 100644 --- a/src/Files.App/Utils/Global/WallpaperHelpers.cs +++ b/src/Files.App/Utils/Global/WallpaperHelpers.cs @@ -9,7 +9,7 @@ using Windows.Storage; using Windows.System.UserProfile; -namespace Files.App.Helpers +namespace Files.App.Utils { public static class WallpaperHelpers { diff --git a/src/Files.App/Utils/Storage/Cache/IStorageCacheController.cs b/src/Files.App/Utils/Storage/Cache/IStorageCacheController.cs index af9bc2f82177..b258a54a0c5f 100644 --- a/src/Files.App/Utils/Storage/Cache/IStorageCacheController.cs +++ b/src/Files.App/Utils/Storage/Cache/IStorageCacheController.cs @@ -1,9 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using System.Threading; -using System.Threading.Tasks; - namespace Files.App.Utils.Storage { internal interface IStorageCacheController @@ -12,4 +9,4 @@ internal interface IStorageCacheController public ValueTask SaveFileDisplayNameToCache(string path, string displayName); } -} \ No newline at end of file +} diff --git a/src/Files.App/Utils/Storage/Cache/StorageCacheController.cs b/src/Files.App/Utils/Storage/Cache/StorageCacheController.cs index b0758756357a..045d32add4cb 100644 --- a/src/Files.App/Utils/Storage/Cache/StorageCacheController.cs +++ b/src/Files.App/Utils/Storage/Cache/StorageCacheController.cs @@ -2,8 +2,6 @@ // Licensed under the MIT License. See the LICENSE. using System.Collections.Concurrent; -using System.Threading; -using System.Threading.Tasks; namespace Files.App.Utils.Storage { @@ -11,16 +9,16 @@ internal class StorageCacheController : IStorageCacheController { private static StorageCacheController instance; - public static StorageCacheController GetInstance() - { - return instance ??= new StorageCacheController(); - } + private readonly ConcurrentDictionary fileNamesCache = new(); private StorageCacheController() { } - private readonly ConcurrentDictionary fileNamesCache = new(); + public static StorageCacheController GetInstance() + { + return instance ??= new StorageCacheController(); + } public ValueTask ReadFileDisplayNameFromCache(string path, CancellationToken cancellationToken) { @@ -38,4 +36,4 @@ public ValueTask SaveFileDisplayNameToCache(string path, string displayName) return ValueTask.CompletedTask; } } -} \ No newline at end of file +} diff --git a/src/Files.App/Utils/Storage/Collection/BlockingListEnumerator.cs b/src/Files.App/Utils/Storage/Collection/BlockingListEnumerator.cs index ea76eefc5e45..739f73ea4bea 100644 --- a/src/Files.App/Utils/Storage/Collection/BlockingListEnumerator.cs +++ b/src/Files.App/Utils/Storage/Collection/BlockingListEnumerator.cs @@ -1,9 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using System.Collections; -using System.Collections.Generic; - namespace Files.App.Utils.Storage { public class BlockingListEnumerator : IEnumerator @@ -13,25 +10,24 @@ public class BlockingListEnumerator : IEnumerator private T m_Current; private int m_Pos; - public BlockingListEnumerator(IList inner, object @lock) - { - m_Inner = inner; - m_Lock = @lock; - m_Pos = -1; - } - public T Current { get { lock (m_Lock) - { return m_Current; - } } } - object IEnumerator.Current => Current; + object IEnumerator.Current + => Current; + + public BlockingListEnumerator(IList inner, object @lock) + { + m_Inner = inner; + m_Lock = @lock; + m_Pos = -1; + } public void Dispose() { diff --git a/src/Files.App/Utils/Storage/Collection/BulkConcurrentObservableCollection.cs b/src/Files.App/Utils/Storage/Collection/BulkConcurrentObservableCollection.cs index dca96f0e796a..d655ffaa864a 100644 --- a/src/Files.App/Utils/Storage/Collection/BulkConcurrentObservableCollection.cs +++ b/src/Files.App/Utils/Storage/Collection/BulkConcurrentObservableCollection.cs @@ -1,15 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.Shared.Extensions; -using System; -using System.Collections; -using System.Collections.Generic; using System.Collections.Specialized; -using System.ComponentModel; -using System.Diagnostics; -using System.Linq; -using System.Threading; namespace Files.App.Utils.Storage { diff --git a/src/Files.App/Utils/Storage/Collection/GroupedCollection.cs b/src/Files.App/Utils/Storage/Collection/GroupedCollection.cs index 81a7dd87719c..7a38bd845ae3 100644 --- a/src/Files.App/Utils/Storage/Collection/GroupedCollection.cs +++ b/src/Files.App/Utils/Storage/Collection/GroupedCollection.cs @@ -1,12 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using CommunityToolkit.Mvvm.ComponentModel; -using Files.App.Extensions; using Microsoft.UI.Xaml.Media; -using System; -using System.Collections.Generic; -using System.ComponentModel; using System.Runtime.CompilerServices; namespace Files.App.Utils.Storage diff --git a/src/Files.App/Utils/Storage/Collection/SortingHelper.cs b/src/Files.App/Utils/Storage/Collection/SortingHelper.cs index 86a10691d107..446e16084549 100644 --- a/src/Files.App/Utils/Storage/Collection/SortingHelper.cs +++ b/src/Files.App/Utils/Storage/Collection/SortingHelper.cs @@ -1,11 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils; -using Files.Shared.Enums; -using System; -using System.Collections.Generic; -using System.Linq; using Windows.Storage; namespace Files.App.Utils.Storage diff --git a/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs b/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs index 19c183498788..4f0262ebe4ff 100644 --- a/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs +++ b/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs @@ -1,19 +1,8 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using CommunityToolkit.Mvvm.DependencyInjection; -using Files.App.Extensions; -using Files.App.Utils.Storage; -using Files.App.Helpers; -using Files.Core.Helpers; -using Files.Core.Services.Settings; using Microsoft.UI.Xaml.Media.Imaging; -using System; -using System.Collections.Generic; using System.IO; -using System.Linq; -using System.Threading; -using System.Threading.Tasks; using Windows.Storage; namespace Files.App.Utils.Storage @@ -26,8 +15,7 @@ public static async Task> ListEntries( CancellationToken cancellationToken, int countLimit, Func, Task> intermediateAction, - Dictionary defaultIconPairs = null - ) + Dictionary defaultIconPairs = null) { var sampler = new IntervalSampler(500); var tempList = new List(); @@ -161,7 +149,10 @@ ex is UnauthorizedAccessException return tempList; } - public static async Task AddFolderAsync(BaseStorageFolder folder, StorageFolderWithPath currentStorageFolder, CancellationToken cancellationToken) + public static async Task AddFolderAsync( + BaseStorageFolder folder, + StorageFolderWithPath currentStorageFolder, + CancellationToken cancellationToken) { var basicProperties = await folder.GetBasicPropertiesAsync(); if (!cancellationToken.IsCancellationRequested) @@ -233,8 +224,7 @@ public static async Task AddFolderAsync(BaseStorageFolder folder, St public static async Task AddFileAsync( BaseStorageFile file, StorageFolderWithPath currentStorageFolder, - CancellationToken cancellationToken - ) + CancellationToken cancellationToken) { var basicProperties = await file.GetBasicPropertiesAsync(); // Display name does not include extension diff --git a/src/Files.App/Utils/Storage/Enumerators/Win32StorageEnumerator.cs b/src/Files.App/Utils/Storage/Enumerators/Win32StorageEnumerator.cs index c1e005fa583e..d3e08bd67df4 100644 --- a/src/Files.App/Utils/Storage/Enumerators/Win32StorageEnumerator.cs +++ b/src/Files.App/Utils/Storage/Enumerators/Win32StorageEnumerator.cs @@ -1,10 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.Storage; -using Files.App.Helpers.StorageCache; -using Files.Core.Extensions; -using Files.Core.Helpers; using Files.Core.Services.SizeProvider; using Microsoft.UI.Xaml.Media.Imaging; using System.IO; @@ -20,12 +16,12 @@ public static class Win32StorageEnumerator private static readonly ISizeProvider folderSizeProvider = Ioc.Default.GetService(); private static readonly string folderTypeTextLocalized = "Folder".GetLocalizedResource(); - private static readonly IFileListCache fileListCache = FileListCacheController.GetInstance(); + private static readonly IStorageCacheController fileListCache = StorageCacheController.GetInstance(); public static async Task> ListEntries( string path, IntPtr hFile, - Core.Helpers.NativeFindStorageItemHelper.WIN32_FIND_DATA findData, + NativeFindStorageItemHelper.WIN32_FIND_DATA findData, CancellationToken cancellationToken, int countLimit, Func, Task> intermediateAction, @@ -165,7 +161,7 @@ public static ListedItem GetAlternateStream((string Name, long Size) ads, Listed } public static async Task GetFolder( - Core.Helpers.NativeFindStorageItemHelper.WIN32_FIND_DATA findData, + NativeFindStorageItemHelper.WIN32_FIND_DATA findData, string pathRoot, bool isGitRepo, CancellationToken cancellationToken @@ -178,10 +174,10 @@ CancellationToken cancellationToken DateTime itemCreatedDate; try { - FileTimeToSystemTime(ref findData.ftLastWriteTime, out Core.Helpers.NativeFindStorageItemHelper.SYSTEMTIME systemModifiedTimeOutput); + FileTimeToSystemTime(ref findData.ftLastWriteTime, out NativeFindStorageItemHelper.SYSTEMTIME systemModifiedTimeOutput); itemModifiedDate = systemModifiedTimeOutput.ToDateTime(); - FileTimeToSystemTime(ref findData.ftCreationTime, out Core.Helpers.NativeFindStorageItemHelper.SYSTEMTIME systemCreatedTimeOutput); + FileTimeToSystemTime(ref findData.ftCreationTime, out NativeFindStorageItemHelper.SYSTEMTIME systemCreatedTimeOutput); itemCreatedDate = systemCreatedTimeOutput.ToDateTime(); } catch (ArgumentException) @@ -242,7 +238,7 @@ CancellationToken cancellationToken } public static async Task GetFile( - Core.Helpers.NativeFindStorageItemHelper.WIN32_FIND_DATA findData, + NativeFindStorageItemHelper.WIN32_FIND_DATA findData, string pathRoot, bool isGitRepo, CancellationToken cancellationToken @@ -254,13 +250,13 @@ CancellationToken cancellationToken DateTime itemModifiedDate, itemCreatedDate, itemLastAccessDate; try { - FileTimeToSystemTime(ref findData.ftLastWriteTime, out Core.Helpers.NativeFindStorageItemHelper.SYSTEMTIME systemModifiedDateOutput); + FileTimeToSystemTime(ref findData.ftLastWriteTime, out NativeFindStorageItemHelper.SYSTEMTIME systemModifiedDateOutput); itemModifiedDate = systemModifiedDateOutput.ToDateTime(); - FileTimeToSystemTime(ref findData.ftCreationTime, out Core.Helpers.NativeFindStorageItemHelper.SYSTEMTIME systemCreatedDateOutput); + FileTimeToSystemTime(ref findData.ftCreationTime, out NativeFindStorageItemHelper.SYSTEMTIME systemCreatedDateOutput); itemCreatedDate = systemCreatedDateOutput.ToDateTime(); - FileTimeToSystemTime(ref findData.ftLastAccessTime, out Core.Helpers.NativeFindStorageItemHelper.SYSTEMTIME systemLastAccessOutput); + FileTimeToSystemTime(ref findData.ftLastAccessTime, out NativeFindStorageItemHelper.SYSTEMTIME systemLastAccessOutput); itemLastAccessDate = systemLastAccessOutput.ToDateTime(); } catch (ArgumentException) diff --git a/src/Files.App/Utils/Storage/Helpers/DeviceManager.cs b/src/Files.App/Utils/Storage/Helpers/DeviceManager.cs index 94187b92b34c..989e5071e1d4 100644 --- a/src/Files.App/Utils/Storage/Helpers/DeviceManager.cs +++ b/src/Files.App/Utils/Storage/Helpers/DeviceManager.cs @@ -1,9 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.Shared; using Microsoft.Management.Infrastructure; -using System; namespace Files.App.Utils.Storage { diff --git a/src/Files.App/Utils/Storage/Helpers/DriveHelpers.cs b/src/Files.App/Utils/Storage/Helpers/DriveHelpers.cs index 957d5df9c19e..9704af48696f 100644 --- a/src/Files.App/Utils/Storage/Helpers/DriveHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/DriveHelpers.cs @@ -1,17 +1,8 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using CommunityToolkit.Mvvm.DependencyInjection; -using Files.App.Data.Items; -using Files.App.Extensions; -using Files.App.Utils; -using Files.App.Interacts; -using Files.App.ViewModels; using Microsoft.Management.Infrastructure; -using System; using System.IO; -using System.Linq; -using System.Threading.Tasks; using Windows.Devices.Enumeration; using Windows.Devices.Portable; using Windows.Storage; diff --git a/src/Files.App/Utils/Storage/Helpers/ErrorCodeConverter.cs b/src/Files.App/Utils/Storage/Helpers/ErrorCodeConverter.cs index 6a1aa9283389..fe1fac30be12 100644 --- a/src/Files.App/Utils/Storage/Helpers/ErrorCodeConverter.cs +++ b/src/Files.App/Utils/Storage/Helpers/ErrorCodeConverter.cs @@ -1,8 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.Shared.Enums; - namespace Files.App.Utils.Storage { public static class ErrorCodeConverter diff --git a/src/Files.App/Utils/Storage/Helpers/FileOperationsHelpers.cs b/src/Files.App/Utils/Storage/Helpers/FileOperationsHelpers.cs index 216b4cbe27c3..5d183315bbf1 100644 --- a/src/Files.App/Utils/Storage/Helpers/FileOperationsHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/FileOperationsHelpers.cs @@ -1,8 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.Shell; -using Files.Core.Helpers; using Microsoft.Extensions.Logging; using Microsoft.Win32; using System.Collections.Concurrent; diff --git a/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs b/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs index b124a433656b..54dbcaf0e6cb 100644 --- a/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs @@ -5,7 +5,6 @@ using Microsoft.UI.Windowing; using Microsoft.UI.Xaml; using Microsoft.UI.Xaml.Controls; -using Microsoft.UI.Xaml.Media; using Microsoft.UI.Xaml.Media.Animation; using Microsoft.Windows.ApplicationModel.Resources; using System.Collections.Concurrent; diff --git a/src/Files.App/Utils/Storage/Helpers/FileSecurityHelpers.cs b/src/Files.App/Utils/Storage/Helpers/FileSecurityHelpers.cs index 31848befaec9..ea76ec4e2823 100644 --- a/src/Files.App/Utils/Storage/Helpers/FileSecurityHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/FileSecurityHelpers.cs @@ -1,7 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.Shell; using Vanara.PInvoke; using static Vanara.PInvoke.AdvApi32; using SystemSecurity = System.Security.AccessControl; diff --git a/src/Files.App/Utils/Storage/Helpers/FileThumbnailHelper.cs b/src/Files.App/Utils/Storage/Helpers/FileThumbnailHelper.cs index 770be8d72339..aa674e2a1241 100644 --- a/src/Files.App/Utils/Storage/Helpers/FileThumbnailHelper.cs +++ b/src/Files.App/Utils/Storage/Helpers/FileThumbnailHelper.cs @@ -1,12 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Extensions; -using Files.App.Utils; -using Files.App.Utils.Shell; -using Files.Core.Helpers; -using System; -using System.Threading.Tasks; using Windows.Storage; using Windows.Storage.FileProperties; diff --git a/src/Files.App/Utils/Storage/Helpers/FilesystemResult.cs b/src/Files.App/Utils/Storage/Helpers/FilesystemResult.cs index 5d96cd7ec0a2..70950a775652 100644 --- a/src/Files.App/Utils/Storage/Helpers/FilesystemResult.cs +++ b/src/Files.App/Utils/Storage/Helpers/FilesystemResult.cs @@ -1,8 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.Shared.Enums; - namespace Files.App.Utils.Storage { public class FilesystemResult diff --git a/src/Files.App/Utils/Storage/Helpers/FolderHelpers.cs b/src/Files.App/Utils/Storage/Helpers/FolderHelpers.cs index b982543cda5e..602620409652 100644 --- a/src/Files.App/Utils/Storage/Helpers/FolderHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/FolderHelpers.cs @@ -1,10 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using System; -using System.Collections.Generic; using System.IO; -using System.Threading.Tasks; using static Files.Core.Helpers.NativeFindStorageItemHelper; namespace Files.App.Utils.Storage diff --git a/src/Files.App/Utils/Storage/Helpers/FtpHelpers.cs b/src/Files.App/Utils/Storage/Helpers/FtpHelpers.cs index 233664962c88..6267f6494d66 100644 --- a/src/Files.App/Utils/Storage/Helpers/FtpHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/FtpHelpers.cs @@ -2,8 +2,6 @@ // Licensed under the MIT License. See the LICENSE. using FluentFTP; -using System; -using System.Threading.Tasks; namespace Files.App.Utils.Storage { diff --git a/src/Files.App/Utils/Storage/Helpers/StorageFileExtensions.cs b/src/Files.App/Utils/Storage/Helpers/StorageFileExtensions.cs index 81f5ed92ae03..cbc4c3c7508b 100644 --- a/src/Files.App/Utils/Storage/Helpers/StorageFileExtensions.cs +++ b/src/Files.App/Utils/Storage/Helpers/StorageFileExtensions.cs @@ -1,22 +1,9 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using CommunityToolkit.Mvvm.DependencyInjection; -using Files.App.Contexts; -using Files.App.Data.Items; -using Files.App.Extensions; -using Files.App.Utils.Storage; -using Files.App.Helpers; -using Files.App.ViewModels; -using Files.App.Views; -using Files.Shared.Extensions; -using System; -using System.Collections.Generic; using System.Collections.Immutable; using System.IO; -using System.Linq; using System.Text; -using System.Threading.Tasks; using Windows.Storage; using Windows.Storage.Search; diff --git a/src/Files.App/Utils/Storage/Helpers/StorageFileWithPath.cs b/src/Files.App/Utils/Storage/Helpers/StorageFileWithPath.cs index 15f833902e73..78450819cb2c 100644 --- a/src/Files.App/Utils/Storage/Helpers/StorageFileWithPath.cs +++ b/src/Files.App/Utils/Storage/Helpers/StorageFileWithPath.cs @@ -1,7 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.Storage; using Windows.Storage; using IO = System.IO; diff --git a/src/Files.App/Utils/Storage/Helpers/StorageFolderWithPath.cs b/src/Files.App/Utils/Storage/Helpers/StorageFolderWithPath.cs index 7e8179c2c356..378092eefa77 100644 --- a/src/Files.App/Utils/Storage/Helpers/StorageFolderWithPath.cs +++ b/src/Files.App/Utils/Storage/Helpers/StorageFolderWithPath.cs @@ -1,7 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.Storage; using Windows.Storage; using IO = System.IO; diff --git a/src/Files.App/Utils/Storage/Helpers/StorageHelpers.cs b/src/Files.App/Utils/Storage/Helpers/StorageHelpers.cs index fc123c4c0826..c30df0db7654 100644 --- a/src/Files.App/Utils/Storage/Helpers/StorageHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/StorageHelpers.cs @@ -1,13 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils; -using Files.Core.Helpers; -using Files.Shared.Enums; -using System; -using System.Diagnostics; using System.Runtime.InteropServices; -using System.Threading.Tasks; using Windows.Storage; using Windows.Storage.FileProperties; diff --git a/src/Files.App/Utils/Storage/Helpers/StorageItemIconHelpers.cs b/src/Files.App/Utils/Storage/Helpers/StorageItemIconHelpers.cs index 0b909fcfeaef..c8af4c4a6e3d 100644 --- a/src/Files.App/Utils/Storage/Helpers/StorageItemIconHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/StorageItemIconHelpers.cs @@ -1,9 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.Shared.Enums; -using System; -using System.Threading.Tasks; using Windows.Storage; using Windows.Storage.FileProperties; diff --git a/src/Files.App/Utils/Storage/Helpers/StorageSenseHelper.cs b/src/Files.App/Utils/Storage/Helpers/StorageSenseHelper.cs index 20412439b957..1ce1ef16291c 100644 --- a/src/Files.App/Utils/Storage/Helpers/StorageSenseHelper.cs +++ b/src/Files.App/Utils/Storage/Helpers/StorageSenseHelper.cs @@ -1,9 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.Shell; -using System; -using System.Threading.Tasks; using Windows.Foundation.Metadata; using Windows.System; diff --git a/src/Files.App/Utils/Storage/History/IStorageHistory.cs b/src/Files.App/Utils/Storage/History/IStorageHistory.cs index b18d5d1b1bbd..c0dce998bfe0 100644 --- a/src/Files.App/Utils/Storage/History/IStorageHistory.cs +++ b/src/Files.App/Utils/Storage/History/IStorageHistory.cs @@ -1,9 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.Shared.Enums; -using System.Collections.Generic; - namespace Files.App.Utils.Storage { public interface IStorageHistory diff --git a/src/Files.App/Utils/Storage/History/IStorageHistoryOperations.cs b/src/Files.App/Utils/Storage/History/IStorageHistoryOperations.cs index 146df766633f..4309156df56d 100644 --- a/src/Files.App/Utils/Storage/History/IStorageHistoryOperations.cs +++ b/src/Files.App/Utils/Storage/History/IStorageHistoryOperations.cs @@ -1,10 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.Shared.Enums; -using System; -using System.Threading.Tasks; - namespace Files.App.Utils.Storage { public interface IStorageHistoryOperations : IDisposable diff --git a/src/Files.App/Utils/Storage/History/StorageHistory.cs b/src/Files.App/Utils/Storage/History/StorageHistory.cs index f478597a41a1..9a3e45db8abd 100644 --- a/src/Files.App/Utils/Storage/History/StorageHistory.cs +++ b/src/Files.App/Utils/Storage/History/StorageHistory.cs @@ -1,10 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.Shared.Enums; -using Files.Shared.Extensions; -using System.Collections.Generic; - namespace Files.App.Utils.Storage { public class StorageHistory : IStorageHistory diff --git a/src/Files.App/Utils/Storage/History/StorageHistoryHelpers.cs b/src/Files.App/Utils/Storage/History/StorageHistoryHelpers.cs index 2fab31b515a6..251696c8c289 100644 --- a/src/Files.App/Utils/Storage/History/StorageHistoryHelpers.cs +++ b/src/Files.App/Utils/Storage/History/StorageHistoryHelpers.cs @@ -1,11 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.Shared.Enums; -using System; -using System.Threading; -using System.Threading.Tasks; - namespace Files.App.Utils.Storage { public class StorageHistoryHelpers : IDisposable diff --git a/src/Files.App/Utils/Storage/History/StorageHistoryOperations.cs b/src/Files.App/Utils/Storage/History/StorageHistoryOperations.cs index 4627809b34da..a3d2a66882e7 100644 --- a/src/Files.App/Utils/Storage/History/StorageHistoryOperations.cs +++ b/src/Files.App/Utils/Storage/History/StorageHistoryOperations.cs @@ -1,16 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Helpers; -using Files.Shared.Enums; -using Files.Shared.Extensions; -using System; -using System.Collections.Generic; -using System.Diagnostics; using System.IO; -using System.Linq; -using System.Threading; -using System.Threading.Tasks; using Windows.Storage; namespace Files.App.Utils.Storage diff --git a/src/Files.App/Utils/Storage/History/StorageHistoryWrapper.cs b/src/Files.App/Utils/Storage/History/StorageHistoryWrapper.cs index 42fb4ea13f54..4ef992a6bfb1 100644 --- a/src/Files.App/Utils/Storage/History/StorageHistoryWrapper.cs +++ b/src/Files.App/Utils/Storage/History/StorageHistoryWrapper.cs @@ -1,9 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using System; -using System.Collections.Generic; - namespace Files.App.Utils.Storage { public class StorageHistoryWrapper : IDisposable diff --git a/src/Files.App/Utils/Storage/Operations/FilesystemHelpers.cs b/src/Files.App/Utils/Storage/Operations/FilesystemHelpers.cs index 4108c3d69c6d..43e7c3818240 100644 --- a/src/Files.App/Utils/Storage/Operations/FilesystemHelpers.cs +++ b/src/Files.App/Utils/Storage/Operations/FilesystemHelpers.cs @@ -1,8 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.Core.Services; -using Files.Core.ViewModels.Dialogs.FileSystemDialog; using Files.Core.Storage; using Files.Shared.Services; using Microsoft.Extensions.Logging; diff --git a/src/Files.App/Utils/Storage/Operations/FilesystemOperations.cs b/src/Files.App/Utils/Storage/Operations/FilesystemOperations.cs index ca788e593be4..12b26f6a62d1 100644 --- a/src/Files.App/Utils/Storage/Operations/FilesystemOperations.cs +++ b/src/Files.App/Utils/Storage/Operations/FilesystemOperations.cs @@ -1,9 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.Storage; -using Files.App.Utils.Storage; -using Files.Core.Helpers; using Microsoft.UI.Xaml.Controls; using System.IO; using Windows.Storage; diff --git a/src/Files.App/Utils/Storage/Operations/IFilesystemHelpers.cs b/src/Files.App/Utils/Storage/Operations/IFilesystemHelpers.cs index 72680dd0e486..083e323b4c2f 100644 --- a/src/Files.App/Utils/Storage/Operations/IFilesystemHelpers.cs +++ b/src/Files.App/Utils/Storage/Operations/IFilesystemHelpers.cs @@ -1,10 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.Shared.Enums; -using System; -using System.Collections.Generic; -using System.Threading.Tasks; using Windows.ApplicationModel.DataTransfer; using Windows.Storage; diff --git a/src/Files.App/Utils/Storage/Operations/IFilesystemOperations.cs b/src/Files.App/Utils/Storage/Operations/IFilesystemOperations.cs index a9314866d0f7..299b4e8d3c68 100644 --- a/src/Files.App/Utils/Storage/Operations/IFilesystemOperations.cs +++ b/src/Files.App/Utils/Storage/Operations/IFilesystemOperations.cs @@ -1,7 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.Storage; using Windows.Storage; namespace Files.App.Utils.Storage diff --git a/src/Files.App/Utils/Storage/Operations/ShellFilesystemOperations.cs b/src/Files.App/Utils/Storage/Operations/ShellFilesystemOperations.cs index 7e5f28a62839..58a2560447ca 100644 --- a/src/Files.App/Utils/Storage/Operations/ShellFilesystemOperations.cs +++ b/src/Files.App/Utils/Storage/Operations/ShellFilesystemOperations.cs @@ -1,11 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.Storage; -using Files.App.Utils.Storage; -using Files.App.Utils.Shell; -using Files.Core.Services; -using Files.Core.ViewModels.Dialogs.FileSystemDialog; using System.IO; using Windows.Storage; diff --git a/src/Files.App/Utils/Storage/Search/FolderSearch.cs b/src/Files.App/Utils/Storage/Search/FolderSearch.cs index 0c94f5e9fb47..fe8b0cf21492 100644 --- a/src/Files.App/Utils/Storage/Search/FolderSearch.cs +++ b/src/Files.App/Utils/Storage/Search/FolderSearch.cs @@ -1,23 +1,8 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using CommunityToolkit.Mvvm.DependencyInjection; -using CommunityToolkit.WinUI; -using Files.App.Data.Items; -using Files.App.Extensions; -using Files.App.Utils.Storage; -using Files.App.Helpers; -using Files.App.ViewModels; -using Files.Core.Services.Settings; -using Files.Shared.Extensions; using Microsoft.Extensions.Logging; -using System; -using System.Collections.Generic; -using System.Collections.ObjectModel; using System.IO; -using System.Linq; -using System.Threading; -using System.Threading.Tasks; using Windows.Storage; using Windows.Storage.FileProperties; using Windows.Storage.Search; diff --git a/src/Files.App/Utils/Storage/Security/AccessControlEntry.cs b/src/Files.App/Utils/Storage/Security/AccessControlEntry.cs index 2ddc65425927..4e2c389f32ba 100644 --- a/src/Files.App/Utils/Storage/Security/AccessControlEntry.cs +++ b/src/Files.App/Utils/Storage/Security/AccessControlEntry.cs @@ -1,15 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using CommunityToolkit.Mvvm.ComponentModel; -using CommunityToolkit.Mvvm.Input; -using Files.App.Data.Factories; -using Files.App.Extensions; -using System; -using System.Collections.Generic; -using System.Collections.ObjectModel; -using System.Linq; - namespace Files.App.Utils.Storage { /// diff --git a/src/Files.App/Utils/Storage/Security/AccessMaskFlags.cs b/src/Files.App/Utils/Storage/Security/AccessMaskFlags.cs index 995674d5feb5..915c2ea730ab 100644 --- a/src/Files.App/Utils/Storage/Security/AccessMaskFlags.cs +++ b/src/Files.App/Utils/Storage/Security/AccessMaskFlags.cs @@ -1,8 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using System; - namespace Files.App.Utils.Storage { /// diff --git a/src/Files.App/Utils/Storage/Security/AccessMaskItem.cs b/src/Files.App/Utils/Storage/Security/AccessMaskItem.cs index e98c01f90a5f..624fc320a8da 100644 --- a/src/Files.App/Utils/Storage/Security/AccessMaskItem.cs +++ b/src/Files.App/Utils/Storage/Security/AccessMaskItem.cs @@ -1,9 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using CommunityToolkit.Mvvm.ComponentModel; -using System.ComponentModel; - namespace Files.App.Utils.Storage { /// diff --git a/src/Files.App/Utils/Storage/StorageItems/BaseQueryResults.cs b/src/Files.App/Utils/Storage/StorageItems/BaseQueryResults.cs index 9cf247ad1628..832ab5a00870 100644 --- a/src/Files.App/Utils/Storage/StorageItems/BaseQueryResults.cs +++ b/src/Files.App/Utils/Storage/StorageItems/BaseQueryResults.cs @@ -1,9 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using System; -using System.Collections.Generic; -using System.Linq; using System.Runtime.InteropServices.WindowsRuntime; using System.Text.RegularExpressions; using Windows.Foundation; diff --git a/src/Files.App/Utils/Storage/StorageItems/NativeStorageFile.cs b/src/Files.App/Utils/Storage/StorageItems/NativeStorageFile.cs index 4ab25a73136e..df396fef8352 100644 --- a/src/Files.App/Utils/Storage/StorageItems/NativeStorageFile.cs +++ b/src/Files.App/Utils/Storage/StorageItems/NativeStorageFile.cs @@ -1,15 +1,9 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Extensions; -using Files.App.Helpers; -using Files.Core.Helpers; -using System; -using System.ComponentModel; using System.IO; using System.Runtime.InteropServices; using System.Runtime.InteropServices.WindowsRuntime; -using System.Threading.Tasks; using Windows.Foundation; using Windows.Storage; using Windows.Storage.FileProperties; diff --git a/src/Files.App/Utils/Storage/StorageItems/ShellStorageFile.cs b/src/Files.App/Utils/Storage/StorageItems/ShellStorageFile.cs index a5173fa6446a..64a40a6303a0 100644 --- a/src/Files.App/Utils/Storage/StorageItems/ShellStorageFile.cs +++ b/src/Files.App/Utils/Storage/StorageItems/ShellStorageFile.cs @@ -1,11 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.Shell; -using Files.Shared; -using System; using System.Runtime.InteropServices.WindowsRuntime; -using System.Threading.Tasks; using Windows.Foundation; using Windows.Storage; using Windows.Storage.FileProperties; diff --git a/src/Files.App/Utils/Storage/StorageItems/ShellStorageFolder.cs b/src/Files.App/Utils/Storage/StorageItems/ShellStorageFolder.cs index ebe561da839d..e576ce096b0b 100644 --- a/src/Files.App/Utils/Storage/StorageItems/ShellStorageFolder.cs +++ b/src/Files.App/Utils/Storage/StorageItems/ShellStorageFolder.cs @@ -1,13 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.Shell; -using Files.Shared; -using System; -using System.Collections.Generic; -using System.Linq; using System.Runtime.InteropServices.WindowsRuntime; -using System.Threading.Tasks; using Windows.Foundation; using Windows.Storage; using Windows.Storage.FileProperties; diff --git a/src/Files.App/Utils/Storage/StorageItems/SystemStorageFile.cs b/src/Files.App/Utils/Storage/StorageItems/SystemStorageFile.cs index f17ff828916b..45ff4c34ae61 100644 --- a/src/Files.App/Utils/Storage/StorageItems/SystemStorageFile.cs +++ b/src/Files.App/Utils/Storage/StorageItems/SystemStorageFile.cs @@ -1,12 +1,8 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Helpers; -using System; -using System.Collections.Generic; using System.IO; using System.Runtime.InteropServices.WindowsRuntime; -using System.Threading.Tasks; using Windows.Foundation; using Windows.Foundation.Metadata; using Windows.Storage; diff --git a/src/Files.App/Utils/Storage/StorageItems/SystemStorageFolder.cs b/src/Files.App/Utils/Storage/StorageItems/SystemStorageFolder.cs index 1432a8a09c00..ecbb79d15ad0 100644 --- a/src/Files.App/Utils/Storage/StorageItems/SystemStorageFolder.cs +++ b/src/Files.App/Utils/Storage/StorageItems/SystemStorageFolder.cs @@ -1,11 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using System; -using System.Collections.Generic; -using System.Linq; using System.Runtime.InteropServices.WindowsRuntime; -using System.Threading.Tasks; using Windows.Foundation; using Windows.Foundation.Metadata; using Windows.Storage; diff --git a/src/Files.App/Utils/Storage/StorageItems/VirtualStorageItem.cs b/src/Files.App/Utils/Storage/StorageItems/VirtualStorageItem.cs index b41ddfe004d8..81b3a1eabeff 100644 --- a/src/Files.App/Utils/Storage/StorageItems/VirtualStorageItem.cs +++ b/src/Files.App/Utils/Storage/StorageItems/VirtualStorageItem.cs @@ -1,11 +1,8 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Helpers; -using System; using System.IO; using System.Runtime.InteropServices.WindowsRuntime; -using System.Threading.Tasks; using Windows.Foundation; using Windows.Storage; using Windows.Storage.FileProperties; diff --git a/src/Files.App/Utils/Storage/StorageItems/ZipStorageFile.cs b/src/Files.App/Utils/Storage/StorageItems/ZipStorageFile.cs index b0b204036f2e..a9ff753b1aa5 100644 --- a/src/Files.App/Utils/Storage/StorageItems/ZipStorageFile.cs +++ b/src/Files.App/Utils/Storage/StorageItems/ZipStorageFile.cs @@ -1,16 +1,9 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Extensions; -using Files.App.Helpers; -using Files.Core.Helpers; using SevenZip; -using System; -using System.Collections.Generic; using System.IO; -using System.Linq; using System.Runtime.InteropServices.WindowsRuntime; -using System.Threading.Tasks; using Windows.Foundation; using Windows.Storage; using Windows.Storage.FileProperties; diff --git a/src/Files.App/Utils/Storage/StorageItems/ZipStorageFolder.cs b/src/Files.App/Utils/Storage/StorageItems/ZipStorageFolder.cs index 046754c280fc..4fff02231881 100644 --- a/src/Files.App/Utils/Storage/StorageItems/ZipStorageFolder.cs +++ b/src/Files.App/Utils/Storage/StorageItems/ZipStorageFolder.cs @@ -1,18 +1,10 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Extensions; -using Files.App.Helpers; -using Files.Core.Helpers; -using Files.Shared.Extensions; using SevenZip; -using System; using System.Collections.Concurrent; -using System.Collections.Generic; using System.IO; -using System.Linq; using System.Runtime.InteropServices.WindowsRuntime; -using System.Threading.Tasks; using Windows.ApplicationModel; using Windows.Foundation; using Windows.Storage; diff --git a/src/Files.App/Views/LayoutModes/ColumnViewBase.xaml b/src/Files.App/Views/LayoutModes/ColumnViewBase.xaml index 70362d645ed4..381edbca787d 100644 --- a/src/Files.App/Views/LayoutModes/ColumnViewBase.xaml +++ b/src/Files.App/Views/LayoutModes/ColumnViewBase.xaml @@ -10,6 +10,7 @@ xmlns:helpers="using:Files.App.Helpers" xmlns:local="using:Files.App.Views.LayoutModes" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" + xmlns:storage="using:Files.App.Utils.Storage" xmlns:uc="using:Files.App.UserControls" xmlns:wct="using:CommunityToolkit.WinUI.UI" xmlns:wctconverters="using:CommunityToolkit.WinUI.UI.Converters" @@ -340,7 +341,7 @@ - + - + @@ -435,7 +436,7 @@ VerticalAlignment="Center" FontSize="16" Style="{StaticResource SubtitleTextBlockStyle}" - Text="{x:Bind ((helpers:IGroupedCollectionHeader)Group).Model.Text, Mode=OneWay}" /> + Text="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.Text, Mode=OneWay}" /> + Text="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.CountText, Mode=OneWay}" + Visibility="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.ShowCountTextBelow, Mode=OneWay, Converter={StaticResource NegatedBoolToVisibilityConverter}}" /> + Text="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.Subtext, Mode=OneWay}" + Visibility="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.ShowCountTextBelow, Mode=OneWay, Converter={StaticResource BoolToVisibilityConverter}}" /> + Text="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.CountText, Mode=OneWay}" + Visibility="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.ShowCountTextBelow, Mode=OneWay, Converter={StaticResource BoolToVisibilityConverter}}" /> diff --git a/src/Files.App/Views/LayoutModes/DetailsLayoutBrowser.xaml b/src/Files.App/Views/LayoutModes/DetailsLayoutBrowser.xaml index a2ffa1034336..4bb43b79ebc9 100644 --- a/src/Files.App/Views/LayoutModes/DetailsLayoutBrowser.xaml +++ b/src/Files.App/Views/LayoutModes/DetailsLayoutBrowser.xaml @@ -13,6 +13,7 @@ xmlns:icore="using:Microsoft.Xaml.Interactions.Core" xmlns:local="using:Files.App.Views.LayoutModes" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" + xmlns:storage="using:Files.App.Utils.Storage" xmlns:toolkit="using:CommunityToolkit.WinUI.UI.Controls" xmlns:uc="using:Files.App.UserControls" xmlns:wct="using:CommunityToolkit.WinUI.UI" @@ -1369,7 +1370,7 @@ - + - + + Text="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.Text, Mode=OneWay}" /> + Text="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.CountText, Mode=OneWay}" + Visibility="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.ShowCountTextBelow, Mode=OneWay, Converter={StaticResource NegatedBoolToVisibilityConverter}}" /> + Text="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.Subtext, Mode=OneWay}" + Visibility="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.ShowCountTextBelow, Mode=OneWay, Converter={StaticResource BoolToVisibilityConverter}}" /> + Text="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.CountText, Mode=OneWay}" + Visibility="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.ShowCountTextBelow, Mode=OneWay, Converter={StaticResource BoolToVisibilityConverter}}" /> diff --git a/src/Files.App/Views/LayoutModes/GridViewBrowser.xaml b/src/Files.App/Views/LayoutModes/GridViewBrowser.xaml index ea93181ae7ad..67ba0be33a5c 100644 --- a/src/Files.App/Views/LayoutModes/GridViewBrowser.xaml +++ b/src/Files.App/Views/LayoutModes/GridViewBrowser.xaml @@ -12,6 +12,7 @@ xmlns:icore="using:Microsoft.Xaml.Interactions.Core" xmlns:local="using:Files.App.Views.LayoutModes" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" + xmlns:storage="using:Files.App.Utils.Storage" xmlns:toolkit="using:CommunityToolkit.WinUI.UI.Controls" xmlns:tui="using:CommunityToolkit.WinUI.UI" xmlns:uc="using:Files.App.UserControls" @@ -604,7 +605,7 @@ - + @@ -718,7 +719,7 @@ Height="24" HorizontalAlignment="Center" VerticalAlignment="Center" - Source="{x:Bind ((helpers:IGroupedCollectionHeader)Group).Model.ImageSource, Mode=OneWay}" + Source="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.ImageSource, Mode=OneWay}" Stretch="Uniform" /> + Glyph="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.Icon, Mode=OneWay}" /> + Text="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.Text, Mode=OneWay}" /> + Text="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.CountText, Mode=OneWay}" + Visibility="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.ShowCountTextBelow, Mode=OneWay, Converter={StaticResource NegatedBoolToVisibilityConverter}}" /> + Text="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.Subtext, Mode=OneWay}" + Visibility="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.ShowCountTextBelow, Mode=OneWay, Converter={StaticResource BoolToVisibilityConverter}}" /> + Text="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.CountText, Mode=OneWay}" + Visibility="{x:Bind ((storage:IGroupedCollectionHeader)Group).Model.ShowCountTextBelow, Mode=OneWay, Converter={StaticResource BoolToVisibilityConverter}}" /> From 0e858f3a5f20b8f1b5190619a224f56301931dba Mon Sep 17 00:00:00 2001 From: 0x5BFA <62196528+0x5bfa@users.noreply.github.com> Date: Wed, 12 Jul 2023 23:17:15 +0900 Subject: [PATCH 04/12] Added missing file --- .../IPasswordProtectedItem.cs | 44 +++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 src/Files.App/Utils/Storage/StorageBaseItems/IPasswordProtectedItem.cs diff --git a/src/Files.App/Utils/Storage/StorageBaseItems/IPasswordProtectedItem.cs b/src/Files.App/Utils/Storage/StorageBaseItems/IPasswordProtectedItem.cs new file mode 100644 index 000000000000..a2a1df16ad5e --- /dev/null +++ b/src/Files.App/Utils/Storage/StorageBaseItems/IPasswordProtectedItem.cs @@ -0,0 +1,44 @@ +using FluentFTP; +using SevenZip; +using System; +using Windows.Storage; + +namespace Files.App.Utils.StorageItems +{ + public interface IPasswordProtectedItem + { + StorageCredential Credentials { get; set; } + + Func> PasswordRequestedCallback { get; set; } + + async Task RetryWithCredentials(Func> func, Exception exception) + { + var handled = exception is SevenZipOpenFailedException szofex && szofex.Result is OperationResult.WrongPassword || + exception is ExtractionFailedException efex && efex.Result is OperationResult.WrongPassword || + exception is FtpAuthenticationException; + if (!handled || PasswordRequestedCallback is null) + throw exception; + + Credentials = await PasswordRequestedCallback(this); + return await func(); + } + + async Task RetryWithCredentials(Func func, Exception exception) + { + var handled = exception is SevenZipOpenFailedException szofex && szofex.Result is OperationResult.WrongPassword || + exception is ExtractionFailedException efex && efex.Result is OperationResult.WrongPassword || + exception is FtpAuthenticationException; + if (!handled || PasswordRequestedCallback is null) + throw exception; + + Credentials = await PasswordRequestedCallback(this); + await func(); + } + + void CopyFrom(IPasswordProtectedItem parent) + { + Credentials = parent.Credentials; + PasswordRequestedCallback = parent.PasswordRequestedCallback; + } + } +} From 4ac4cb622610f7c27500534d2b29bbf1099a18ce Mon Sep 17 00:00:00 2001 From: 0x5BFA <62196528+0x5bfa@users.noreply.github.com> Date: Wed, 12 Jul 2023 23:18:17 +0900 Subject: [PATCH 05/12] Fixed namespace --- .../Utils/Storage/StorageBaseItems/IPasswordProtectedItem.cs | 2 +- .../Utils/Storage/StorageBaseItems/StorageCredential.cs | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Files.App/Utils/Storage/StorageBaseItems/IPasswordProtectedItem.cs b/src/Files.App/Utils/Storage/StorageBaseItems/IPasswordProtectedItem.cs index a2a1df16ad5e..6d45e1e9c365 100644 --- a/src/Files.App/Utils/Storage/StorageBaseItems/IPasswordProtectedItem.cs +++ b/src/Files.App/Utils/Storage/StorageBaseItems/IPasswordProtectedItem.cs @@ -3,7 +3,7 @@ using System; using Windows.Storage; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { public interface IPasswordProtectedItem { diff --git a/src/Files.App/Utils/Storage/StorageBaseItems/StorageCredential.cs b/src/Files.App/Utils/Storage/StorageBaseItems/StorageCredential.cs index 15a3897ca42f..b7b79f27ff9b 100644 --- a/src/Files.App/Utils/Storage/StorageBaseItems/StorageCredential.cs +++ b/src/Files.App/Utils/Storage/StorageBaseItems/StorageCredential.cs @@ -1,7 +1,7 @@ using System.Runtime.InteropServices; using System.Security; -namespace Files.App.Utils.StorageItems +namespace Files.App.Utils.Storage { // Code from System.Net.NetworkCredential public class StorageCredential From 2b076a29384948c8c387d28ec69a65a24243c9cd Mon Sep 17 00:00:00 2001 From: 0x5BFA <62196528+0x5bfa@users.noreply.github.com> Date: Wed, 12 Jul 2023 23:38:39 +0900 Subject: [PATCH 06/12] Fixed missing using directives --- src/Files.App/Helpers/UI/UIFilesystemHelpers.cs | 1 + .../Utils/Storage/Enumerators/UniversalStorageEnumerator.cs | 1 + 2 files changed, 2 insertions(+) diff --git a/src/Files.App/Helpers/UI/UIFilesystemHelpers.cs b/src/Files.App/Helpers/UI/UIFilesystemHelpers.cs index 2bd0a74b2097..cdb08903d2ce 100644 --- a/src/Files.App/Helpers/UI/UIFilesystemHelpers.cs +++ b/src/Files.App/Helpers/UI/UIFilesystemHelpers.cs @@ -2,6 +2,7 @@ // Licensed under the MIT License. See the LICENSE. using Files.App.Dialogs; +using Files.App.Storage.FtpStorage; using Files.App.ViewModels.Dialogs; using Microsoft.Extensions.Logging; using System.Collections.Concurrent; diff --git a/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs b/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs index 4b07684226cd..4c6ffee786a4 100644 --- a/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs +++ b/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs @@ -1,6 +1,7 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. +using Microsoft.Extensions.Logging; using Microsoft.UI.Xaml.Media.Imaging; using System.IO; using Windows.Storage; From ba3419c799945f47cf9864302de504f602af3258 Mon Sep 17 00:00:00 2001 From: 0x5BFA <62196528+0x5bfa@users.noreply.github.com> Date: Wed, 12 Jul 2023 23:50:40 +0900 Subject: [PATCH 07/12] Refactored latest commits in main branch --- .../Collection/BlockingListEnumerator.cs | 3 + .../Storage/Collection/GroupedCollection.cs | 119 +----------------- .../Collection/GroupedHeaderViewModel.cs | 111 ++++++++++++++++ .../Storage/Collection/GroupingHelper.cs | 5 - .../Storage/Collection/IGroupableItem.cs | 10 ++ .../Collection/IGroupedCollectionHeader.cs | 16 +++ .../Utils/Storage/Collection/SortingHelper.cs | 2 +- .../Enumerators/UniversalStorageEnumerator.cs | 40 +++--- .../Enumerators/Win32StorageEnumerator.cs | 38 +++--- .../IPasswordProtectedItem.cs | 9 +- .../StorageBaseItems/StorageCredential.cs | 30 ++--- 11 files changed, 206 insertions(+), 177 deletions(-) create mode 100644 src/Files.App/Utils/Storage/Collection/GroupedHeaderViewModel.cs create mode 100644 src/Files.App/Utils/Storage/Collection/IGroupableItem.cs create mode 100644 src/Files.App/Utils/Storage/Collection/IGroupedCollectionHeader.cs diff --git a/src/Files.App/Utils/Storage/Collection/BlockingListEnumerator.cs b/src/Files.App/Utils/Storage/Collection/BlockingListEnumerator.cs index 739f73ea4bea..df02d4095a6c 100644 --- a/src/Files.App/Utils/Storage/Collection/BlockingListEnumerator.cs +++ b/src/Files.App/Utils/Storage/Collection/BlockingListEnumerator.cs @@ -6,8 +6,11 @@ namespace Files.App.Utils.Storage public class BlockingListEnumerator : IEnumerator { private readonly IList m_Inner; + private readonly object m_Lock; + private T m_Current; + private int m_Pos; public T Current diff --git a/src/Files.App/Utils/Storage/Collection/GroupedCollection.cs b/src/Files.App/Utils/Storage/Collection/GroupedCollection.cs index 7a38bd845ae3..9c20d3736278 100644 --- a/src/Files.App/Utils/Storage/Collection/GroupedCollection.cs +++ b/src/Files.App/Utils/Storage/Collection/GroupedCollection.cs @@ -1,9 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Microsoft.UI.Xaml.Media; -using System.Runtime.CompilerServices; - namespace Files.App.Utils.Storage { public class GroupedCollection : BulkConcurrentObservableCollection, IGroupedCollectionHeader @@ -77,118 +74,4 @@ public override void EndBulkOperation() Model.ResumePropertyChangedNotifications(); } } - - /// - /// This interface is used to allow using x:Bind for the group header template. - ///
- /// This is needed because x:Bind does not work with generic types, however it does work with interfaces. - /// that are implemented by generic types. - ///
- public interface IGroupedCollectionHeader - { - public GroupedHeaderViewModel Model { get; set; } - } - - public class GroupedHeaderViewModel : ObservableObject - { - public string Key { get; set; } - public bool Initialized { get; set; } - public int SortIndexOverride { get; set; } - - private string text; - - public string Text - { - get => text ?? ""; // Text is bound to AutomationProperties.Name and can't be null - set => SetPropertyWithUpdateDelay(ref text, value); - } - - private string subtext; - - public string Subtext - { - get => subtext; - set => SetPropertyWithUpdateDelay(ref subtext, value); - } - - private string countText; - - public string CountText - { - get => countText; - set => SetPropertyWithUpdateDelay(ref countText, value); - } - - private bool showCountTextBelow; - - public bool ShowCountTextBelow - { - get => showCountTextBelow; - set => SetProperty(ref showCountTextBelow, value); - } - - private ImageSource imageSource; - - public ImageSource ImageSource - { - get => imageSource; - set => SetPropertyWithUpdateDelay(ref imageSource, value); - } - - private string icon; - - public string Icon - { - get => icon; - set => SetPropertyWithUpdateDelay(ref icon, value); - } - - private void SetPropertyWithUpdateDelay(ref T field, T newVal, [CallerMemberName] string propName = null) - { - if (propName is null) - { - return; - } - var name = propName.StartsWith("get_", StringComparison.OrdinalIgnoreCase) - ? propName.Substring(4) - : propName; - - if (!deferPropChangedNotifs) - { - SetProperty(ref field, newVal, name); - } - else - { - field = newVal; - if (!changedPropQueue.Contains(name)) - { - changedPropQueue.Add(name); - } - } - } - - public void PausePropertyChangedNotifications() - { - deferPropChangedNotifs = true; - } - - public void ResumePropertyChangedNotifications(bool triggerUpdates = true) - { - if (deferPropChangedNotifs == false) - { - return; - } - deferPropChangedNotifs = false; - if (triggerUpdates) - { - changedPropQueue.ForEach(prop => OnPropertyChanged(prop)); - changedPropQueue.Clear(); - } - } - - private List changedPropQueue = new List(); - - // This is true by default to make it easier to initialize groups from a different thread - private bool deferPropChangedNotifs = true; - } -} \ No newline at end of file +} diff --git a/src/Files.App/Utils/Storage/Collection/GroupedHeaderViewModel.cs b/src/Files.App/Utils/Storage/Collection/GroupedHeaderViewModel.cs new file mode 100644 index 000000000000..0145d5484368 --- /dev/null +++ b/src/Files.App/Utils/Storage/Collection/GroupedHeaderViewModel.cs @@ -0,0 +1,111 @@ +// Copyright (c) 2023 Files Community +// Licensed under the MIT License. See the LICENSE. + +using Microsoft.UI.Xaml.Media; +using System.Runtime.CompilerServices; + +namespace Files.App.Utils.Storage +{ + public class GroupedHeaderViewModel : ObservableObject + { + public string Key { get; set; } + public bool Initialized { get; set; } + public int SortIndexOverride { get; set; } + + private string text; + + public string Text + { + get => text ?? ""; // Text is bound to AutomationProperties.Name and can't be null + set => SetPropertyWithUpdateDelay(ref text, value); + } + + private string subtext; + + public string Subtext + { + get => subtext; + set => SetPropertyWithUpdateDelay(ref subtext, value); + } + + private string countText; + + public string CountText + { + get => countText; + set => SetPropertyWithUpdateDelay(ref countText, value); + } + + private bool showCountTextBelow; + + public bool ShowCountTextBelow + { + get => showCountTextBelow; + set => SetProperty(ref showCountTextBelow, value); + } + + private ImageSource imageSource; + + public ImageSource ImageSource + { + get => imageSource; + set => SetPropertyWithUpdateDelay(ref imageSource, value); + } + + private string icon; + + public string Icon + { + get => icon; + set => SetPropertyWithUpdateDelay(ref icon, value); + } + + private void SetPropertyWithUpdateDelay(ref T field, T newVal, [CallerMemberName] string propName = null) + { + if (propName is null) + { + return; + } + var name = propName.StartsWith("get_", StringComparison.OrdinalIgnoreCase) + ? propName.Substring(4) + : propName; + + if (!deferPropChangedNotifs) + { + SetProperty(ref field, newVal, name); + } + else + { + field = newVal; + if (!changedPropQueue.Contains(name)) + { + changedPropQueue.Add(name); + } + } + } + + public void PausePropertyChangedNotifications() + { + deferPropChangedNotifs = true; + } + + public void ResumePropertyChangedNotifications(bool triggerUpdates = true) + { + if (deferPropChangedNotifs == false) + { + return; + } + deferPropChangedNotifs = false; + if (triggerUpdates) + { + changedPropQueue.ForEach(prop => OnPropertyChanged(prop)); + changedPropQueue.Clear(); + } + } + + private List changedPropQueue = new List(); + + // This is true by default to make it easier to initialize groups from a different thread + private bool deferPropChangedNotifs = true; + } +} diff --git a/src/Files.App/Utils/Storage/Collection/GroupingHelper.cs b/src/Files.App/Utils/Storage/Collection/GroupingHelper.cs index a445ecd420b4..5a6447622cd9 100644 --- a/src/Files.App/Utils/Storage/Collection/GroupingHelper.cs +++ b/src/Files.App/Utils/Storage/Collection/GroupingHelper.cs @@ -167,9 +167,4 @@ public static string GetGroupSizeKey(long size) (16000, "ItemSizeText_Small".GetLocalizedResource(), "16 KiB".ConvertSizeAbbreviation()), }; } - - public interface IGroupableItem - { - public string Key { get; set; } - } } diff --git a/src/Files.App/Utils/Storage/Collection/IGroupableItem.cs b/src/Files.App/Utils/Storage/Collection/IGroupableItem.cs new file mode 100644 index 000000000000..bd3cba2618d6 --- /dev/null +++ b/src/Files.App/Utils/Storage/Collection/IGroupableItem.cs @@ -0,0 +1,10 @@ +// Copyright (c) 2023 Files Community +// Licensed under the MIT License. See the LICENSE. + +namespace Files.App.Utils.Storage +{ + public interface IGroupableItem + { + public string Key { get; set; } + } +} diff --git a/src/Files.App/Utils/Storage/Collection/IGroupedCollectionHeader.cs b/src/Files.App/Utils/Storage/Collection/IGroupedCollectionHeader.cs new file mode 100644 index 000000000000..fe35173d0642 --- /dev/null +++ b/src/Files.App/Utils/Storage/Collection/IGroupedCollectionHeader.cs @@ -0,0 +1,16 @@ +// Copyright (c) 2023 Files Community +// Licensed under the MIT License. See the LICENSE. + +namespace Files.App.Utils.Storage +{ + /// + /// Represents an interface that is used to allow using x:Bind for the group header template. + ///
+ /// This is needed because x:Bind does not work with generic types, however it does work with interfaces. + /// that are implemented by generic types. + ///
+ public interface IGroupedCollectionHeader + { + public GroupedHeaderViewModel Model { get; set; } + } +} diff --git a/src/Files.App/Utils/Storage/Collection/SortingHelper.cs b/src/Files.App/Utils/Storage/Collection/SortingHelper.cs index 446e16084549..680cc482c386 100644 --- a/src/Files.App/Utils/Storage/Collection/SortingHelper.cs +++ b/src/Files.App/Utils/Storage/Collection/SortingHelper.cs @@ -92,4 +92,4 @@ static bool FolderThenFileAsync(ListedItem listedItem) return ordered; } } -} \ No newline at end of file +} diff --git a/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs b/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs index 4c6ffee786a4..89d8926a3c86 100644 --- a/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs +++ b/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs @@ -28,6 +28,7 @@ public static async Task> ListEntries( while (true) { IReadOnlyList items; + uint maxItemsToRetrieve = 300; if (intermediateAction is null) @@ -40,6 +41,7 @@ public static async Task> ListEntries( maxItemsToRetrieve = 32; firstRound = false; } + try { items = await rootFolder.GetItemsAsync(count, maxItemsToRetrieve); @@ -53,9 +55,9 @@ public static async Task> ListEntries( break; } catch (Exception ex) when ( - ex is UnauthorizedAccessException - || ex is FileNotFoundException - || (uint)ex.HResult == 0x80070490) // ERROR_NOT_FOUND + ex is UnauthorizedAccessException || + ex is FileNotFoundException || + (uint)ex.HResult == 0x80070490) // ERROR_NOT_FOUND { // If some unexpected exception is thrown - enumerate this folder file by file - just to be sure items = await EnumerateFileByFile(rootFolder, count, maxItemsToRetrieve); @@ -63,8 +65,10 @@ ex is UnauthorizedAccessException catch (Exception ex) { App.Logger.LogWarning(ex, "Error enumerating directory contents."); + break; } + foreach (var item in items) { var startWithDot = item.Name.StartsWith('.'); @@ -76,9 +80,8 @@ ex is UnauthorizedAccessException if (folder is not null) { if (defaultIconPairs?.ContainsKey(string.Empty) ?? false) - { folder.SetDefaultIcon(defaultIconPairs[string.Empty]); - } + tempList.Add(folder); } } @@ -93,60 +96,59 @@ ex is UnauthorizedAccessException { var lowercaseExtension = fileEntry.FileExtension.ToLowerInvariant(); if (defaultIconPairs.ContainsKey(lowercaseExtension)) - { fileEntry.SetDefaultIcon(defaultIconPairs[lowercaseExtension]); - } } } + tempList.Add(fileEntry); } } } + if (cancellationToken.IsCancellationRequested) - { break; - } } + count += maxItemsToRetrieve; if (countLimit > -1 && count >= countLimit) - { break; - } if (intermediateAction is not null && (items.Count == maxItemsToRetrieve || sampler.CheckNow())) { await intermediateAction(tempList); + // clear the temporary list every time we do an intermediate action tempList.Clear(); } } + return tempList; } private static async Task> EnumerateFileByFile(BaseStorageFolder rootFolder, uint startFrom, uint itemsToIterate) { var tempList = new List(); + for (var i = startFrom; i < startFrom + itemsToIterate; i++) { IStorageItem item; try { var results = await rootFolder.GetItemsAsync(i, 1); + item = results?.FirstOrDefault(); if (item is null) - { break; - } } catch (NotImplementedException) { break; } catch (Exception ex) when ( - ex is UnauthorizedAccessException - || ex is FileNotFoundException - || (uint)ex.HResult == 0x80070490) // ERROR_NOT_FOUND + ex is UnauthorizedAccessException || + ex is FileNotFoundException || + (uint)ex.HResult == 0x80070490) // ERROR_NOT_FOUND { continue; } @@ -155,8 +157,10 @@ ex is UnauthorizedAccessException App.Logger.LogWarning(ex, "Error enumerating directory contents."); break; } + tempList.Add(item); } + return tempList; } @@ -229,6 +233,7 @@ public static async Task AddFolderAsync( }; } } + return null; } @@ -250,9 +255,7 @@ public static async Task AddFileAsync( var itemThumbnailImgVis = false; if (cancellationToken.IsCancellationRequested) - { return null; - } // TODO: is this needed to be handled here? if (App.LibraryManager.TryGetLibrary(file.Path, out LibraryLocationItem library)) @@ -333,6 +336,7 @@ public static async Task AddFileAsync( }; } } + return null; } } diff --git a/src/Files.App/Utils/Storage/Enumerators/Win32StorageEnumerator.cs b/src/Files.App/Utils/Storage/Enumerators/Win32StorageEnumerator.cs index d3e08bd67df4..90ba15afc233 100644 --- a/src/Files.App/Utils/Storage/Enumerators/Win32StorageEnumerator.cs +++ b/src/Files.App/Utils/Storage/Enumerators/Win32StorageEnumerator.cs @@ -16,6 +16,7 @@ public static class Win32StorageEnumerator private static readonly ISizeProvider folderSizeProvider = Ioc.Default.GetService(); private static readonly string folderTypeTextLocalized = "Folder".GetLocalizedResource(); + private static readonly IStorageCacheController fileListCache = StorageCacheController.GetInstance(); public static async Task> ListEntries( @@ -43,9 +44,9 @@ public static async Task> ListEntries( var isHidden = ((FileAttributes)findData.dwFileAttributes & FileAttributes.Hidden) == FileAttributes.Hidden; var startWithDot = findData.cFileName.StartsWith('.'); if ((!isHidden || - (userSettingsService.FoldersSettingsService.ShowHiddenItems && - (!isSystem || userSettingsService.FoldersSettingsService.ShowProtectedSystemFiles))) && - (!startWithDot || userSettingsService.FoldersSettingsService.ShowDotFiles)) + (userSettingsService.FoldersSettingsService.ShowHiddenItems && + (!isSystem || userSettingsService.FoldersSettingsService.ShowProtectedSystemFiles))) && + (!startWithDot || userSettingsService.FoldersSettingsService.ShowDotFiles)) { if (((FileAttributes)findData.dwFileAttributes & FileAttributes.Directory) != FileAttributes.Directory) { @@ -63,6 +64,7 @@ public static async Task> ListEntries( } } } + tempList.Add(file); ++count; @@ -84,13 +86,12 @@ public static async Task> ListEntries( // Set folder icon (found by empty extension string) folder.SetDefaultIcon(defaultIconPairs[string.Empty]); } + tempList.Add(folder); ++count; if (userSettingsService.FoldersSettingsService.AreAlternateStreamsVisible) - { tempList.AddRange(EnumAdsForPath(folder.ItemPath, folder)); - } if (CalculateFolderSizes) { @@ -99,46 +100,48 @@ public static async Task> ListEntries( folder.FileSizeBytes = (long)size; folder.FileSize = size.ToSizeString(); } + _ = folderSizeProvider.UpdateAsync(folder.ItemPath, cancellationToken); } } } } } + if (cancellationToken.IsCancellationRequested || count == countLimit) - { break; - } if (intermediateAction is not null && (count == 32 || sampler.CheckNow())) { await intermediateAction(tempList); + // clear the temporary list every time we do an intermediate action tempList.Clear(); } } while (FindNextFile(hFile, out findData)); FindClose(hFile); + return tempList; } private static IEnumerable EnumAdsForPath(string itemPath, ListedItem main) { foreach (var ads in NativeFileOperationsHelper.GetAlternateStreams(itemPath)) - { yield return GetAlternateStream(ads, main); - } } public static ListedItem GetAlternateStream((string Name, long Size) ads, ListedItem main) { string itemType = "File".GetLocalizedResource(); string itemFileExtension = null; + if (ads.Name.Contains('.')) { itemFileExtension = Path.GetExtension(ads.Name); itemType = itemFileExtension.Trim('.') + " " + itemType; } + string adsName = ads.Name.Substring(1, ads.Name.Length - 7); // Remove ":" and ":$DATA" return new AlternateStreamItem() @@ -172,6 +175,7 @@ CancellationToken cancellationToken DateTime itemModifiedDate; DateTime itemCreatedDate; + try { FileTimeToSystemTime(ref findData.ftLastWriteTime, out NativeFindStorageItemHelper.SYSTEMTIME systemModifiedTimeOutput); @@ -185,19 +189,18 @@ CancellationToken cancellationToken // Invalid date means invalid findData, do not add to list return null; } + var itemPath = Path.Combine(pathRoot, findData.cFileName); + string itemName = await fileListCache.ReadFileDisplayNameFromCache(itemPath, cancellationToken); if (string.IsNullOrEmpty(itemName)) - { itemName = findData.cFileName; - } + bool isHidden = (((FileAttributes)findData.dwFileAttributes & FileAttributes.Hidden) == FileAttributes.Hidden); double opacity = 1; if (isHidden) - { opacity = Constants.UI.DimItemOpacity; - } if (isGitRepo) { @@ -248,6 +251,7 @@ CancellationToken cancellationToken var itemName = findData.cFileName; DateTime itemModifiedDate, itemCreatedDate, itemLastAccessDate; + try { FileTimeToSystemTime(ref findData.ftLastWriteTime, out NativeFindStorageItemHelper.SYSTEMTIME systemModifiedDateOutput); @@ -280,9 +284,7 @@ CancellationToken cancellationToken bool itemEmptyImgVis = true; if (cancellationToken.IsCancellationRequested) - { return null; - } bool isHidden = ((FileAttributes)findData.dwFileAttributes & FileAttributes.Hidden) == FileAttributes.Hidden; double opacity = isHidden ? Constants.UI.DimItemOpacity : 1; @@ -294,6 +296,7 @@ CancellationToken cancellationToken if (isSymlink) { var targetPath = NativeFileOperationsHelper.ParseSymLink(itemPath); + return new ShortcutItem(null) { PrimaryItemAttribute = StorageItemTypes.File, @@ -318,11 +321,11 @@ CancellationToken cancellationToken else if (FileExtensionHelpers.IsShortcutOrUrlFile(findData.cFileName)) { var isUrl = FileExtensionHelpers.IsWebLinkFile(findData.cFileName); + var shInfo = await FileOperationsHelpers.ParseLinkAsync(itemPath); if (shInfo is null) - { return null; - } + return new ShortcutItem(null) { PrimaryItemAttribute = shInfo.IsFolder ? StorageItemTypes.Folder : StorageItemTypes.File, @@ -419,6 +422,7 @@ CancellationToken cancellationToken }; } } + return null; } } diff --git a/src/Files.App/Utils/Storage/StorageBaseItems/IPasswordProtectedItem.cs b/src/Files.App/Utils/Storage/StorageBaseItems/IPasswordProtectedItem.cs index 6d45e1e9c365..51aab465e67d 100644 --- a/src/Files.App/Utils/Storage/StorageBaseItems/IPasswordProtectedItem.cs +++ b/src/Files.App/Utils/Storage/StorageBaseItems/IPasswordProtectedItem.cs @@ -1,4 +1,7 @@ -using FluentFTP; +// Copyright (c) 2023 Files Community +// Licensed under the MIT License. See the LICENSE. + +using FluentFTP; using SevenZip; using System; using Windows.Storage; @@ -16,10 +19,12 @@ async Task RetryWithCredentials(Func> func, Exception exc var handled = exception is SevenZipOpenFailedException szofex && szofex.Result is OperationResult.WrongPassword || exception is ExtractionFailedException efex && efex.Result is OperationResult.WrongPassword || exception is FtpAuthenticationException; + if (!handled || PasswordRequestedCallback is null) throw exception; Credentials = await PasswordRequestedCallback(this); + return await func(); } @@ -28,10 +33,12 @@ async Task RetryWithCredentials(Func func, Exception exception) var handled = exception is SevenZipOpenFailedException szofex && szofex.Result is OperationResult.WrongPassword || exception is ExtractionFailedException efex && efex.Result is OperationResult.WrongPassword || exception is FtpAuthenticationException; + if (!handled || PasswordRequestedCallback is null) throw exception; Credentials = await PasswordRequestedCallback(this); + await func(); } diff --git a/src/Files.App/Utils/Storage/StorageBaseItems/StorageCredential.cs b/src/Files.App/Utils/Storage/StorageBaseItems/StorageCredential.cs index b7b79f27ff9b..fcdf9ecb1da9 100644 --- a/src/Files.App/Utils/Storage/StorageBaseItems/StorageCredential.cs +++ b/src/Files.App/Utils/Storage/StorageBaseItems/StorageCredential.cs @@ -1,4 +1,7 @@ -using System.Runtime.InteropServices; +// Copyright (c) 2023 Files Community +// Licensed under the MIT License. See the LICENSE. + +using System.Runtime.InteropServices; using System.Security; namespace Files.App.Utils.Storage @@ -7,29 +10,28 @@ namespace Files.App.Utils.Storage public class StorageCredential { private string _userName = string.Empty; - private object? _password; - public string UserName { - get { return _userName; } - set { _userName = value ?? string.Empty; } + get => _userName; + set => _userName = value ?? string.Empty; } + private object? _password; public string Password { get { SecureString? sstr = _password as SecureString; if (sstr != null) - { return MarshalToString(sstr); - } + return (string?)_password ?? string.Empty; } set { SecureString? old = _password as SecureString; _password = value; + old?.Dispose(); } } @@ -40,9 +42,8 @@ public SecureString SecurePassword { string? str = _password as string; if (str != null) - { return MarshalToSecureString(str); - } + SecureString? sstr = _password as SecureString; return sstr != null ? sstr.Copy() : new SecureString(); } @@ -50,6 +51,7 @@ public SecureString SecurePassword { SecureString? old = _password as SecureString; _password = value?.Copy(); + old?.Dispose(); } } @@ -74,12 +76,11 @@ public StorageCredential(string? userName, SecureString? password) private static string MarshalToString(SecureString sstr) { if (sstr == null || sstr.Length == 0) - { return string.Empty; - } IntPtr ptr = IntPtr.Zero; string result = string.Empty; + try { ptr = Marshal.SecureStringToGlobalAllocUnicode(sstr); @@ -88,24 +89,19 @@ private static string MarshalToString(SecureString sstr) finally { if (ptr != IntPtr.Zero) - { Marshal.ZeroFreeGlobalAllocUnicode(ptr); - } } + return result; } private unsafe SecureString MarshalToSecureString(string str) { if (string.IsNullOrEmpty(str)) - { return new SecureString(); - } fixed (char* ptr = str) - { return new SecureString(ptr, str.Length); - } } } } From 0d01e60807bf79e0dd301a383cfc255151537c73 Mon Sep 17 00:00:00 2001 From: 0x5BFA <62196528+0x5bfa@users.noreply.github.com> Date: Thu, 13 Jul 2023 04:53:21 +0000 Subject: [PATCH 08/12] Remove App.Sdk --- .../DirectStorage/IDirectCopy.cs | 18 ------------------ .../DirectStorage/IDirectMove.cs | 18 ------------------ .../NestedStorage/INestedFile.cs | 9 --------- .../NestedStorage/INestedFolder.cs | 9 --------- .../NestedStorage/INestedStorable.cs | 16 ---------------- 5 files changed, 70 deletions(-) delete mode 100644 src/Files.Sdk.Storage/DirectStorage/IDirectCopy.cs delete mode 100644 src/Files.Sdk.Storage/DirectStorage/IDirectMove.cs delete mode 100644 src/Files.Sdk.Storage/NestedStorage/INestedFile.cs delete mode 100644 src/Files.Sdk.Storage/NestedStorage/INestedFolder.cs delete mode 100644 src/Files.Sdk.Storage/NestedStorage/INestedStorable.cs diff --git a/src/Files.Sdk.Storage/DirectStorage/IDirectCopy.cs b/src/Files.Sdk.Storage/DirectStorage/IDirectCopy.cs deleted file mode 100644 index ba86c6f34764..000000000000 --- a/src/Files.Sdk.Storage/DirectStorage/IDirectCopy.cs +++ /dev/null @@ -1,18 +0,0 @@ -using Files.Sdk.Storage.ModifiableStorage; -using Files.Sdk.Storage.NestedStorage; -using System.Threading; -using System.Threading.Tasks; - -namespace Files.Sdk.Storage.DirectStorage -{ - /// - /// Provides direct copy operation of storage objects. - /// - public interface IDirectCopy : IModifiableFolder - { - /// - /// Creates a copy of the provided storable item in this folder. - /// - Task CreateCopyOfAsync(INestedStorable itemToCopy, bool overwrite = default, CancellationToken cancellationToken = default); - } -} diff --git a/src/Files.Sdk.Storage/DirectStorage/IDirectMove.cs b/src/Files.Sdk.Storage/DirectStorage/IDirectMove.cs deleted file mode 100644 index 7a21edcc9b30..000000000000 --- a/src/Files.Sdk.Storage/DirectStorage/IDirectMove.cs +++ /dev/null @@ -1,18 +0,0 @@ -using Files.Sdk.Storage.ModifiableStorage; -using Files.Sdk.Storage.NestedStorage; -using System.Threading; -using System.Threading.Tasks; - -namespace Files.Sdk.Storage.DirectStorage -{ - /// - /// Provides direct move operation of storage objects. - /// - public interface IDirectMove : IModifiableFolder - { - /// - /// Moves a storable item out of the provided folder, and into this folder. Returns the new item that resides in this folder. - /// - Task MoveFromAsync(INestedStorable itemToMove, IModifiableFolder source, bool overwrite = default, CancellationToken cancellationToken = default); - } -} diff --git a/src/Files.Sdk.Storage/NestedStorage/INestedFile.cs b/src/Files.Sdk.Storage/NestedStorage/INestedFile.cs deleted file mode 100644 index b1a262ffcdb4..000000000000 --- a/src/Files.Sdk.Storage/NestedStorage/INestedFile.cs +++ /dev/null @@ -1,9 +0,0 @@ -namespace Files.Sdk.Storage.NestedStorage -{ - /// - /// Represents a file that resides within a traversable folder structure. - /// - public interface INestedFile : IFile, INestedStorable - { - } -} diff --git a/src/Files.Sdk.Storage/NestedStorage/INestedFolder.cs b/src/Files.Sdk.Storage/NestedStorage/INestedFolder.cs deleted file mode 100644 index d73c723adb37..000000000000 --- a/src/Files.Sdk.Storage/NestedStorage/INestedFolder.cs +++ /dev/null @@ -1,9 +0,0 @@ -namespace Files.Sdk.Storage.NestedStorage -{ - /// - /// Represents a folder that resides within a traversable folder structure. - /// - public interface INestedFolder : IFolder, INestedStorable - { - } -} diff --git a/src/Files.Sdk.Storage/NestedStorage/INestedStorable.cs b/src/Files.Sdk.Storage/NestedStorage/INestedStorable.cs deleted file mode 100644 index 3463db7d4bd6..000000000000 --- a/src/Files.Sdk.Storage/NestedStorage/INestedStorable.cs +++ /dev/null @@ -1,16 +0,0 @@ -using System.Threading; -using System.Threading.Tasks; - -namespace Files.Sdk.Storage.NestedStorage -{ - /// - /// Represents a storable resource that resides within a traversable folder structure. - /// - public interface INestedStorable : IStorable - { - /// - /// Gets the containing folder for this item, if any. - /// - Task GetParentAsync(CancellationToken cancellationToken = default); - } -} From aa5c0b74098555bb6cbdc5b613d50bdd1e89203d Mon Sep 17 00:00:00 2001 From: 0x5BFA <62196528+0x5bfa@users.noreply.github.com> Date: Thu, 13 Jul 2023 05:03:19 +0000 Subject: [PATCH 09/12] Update Files.Core.Storage.csproj --- src/Files.Core.Storage/Files.Core.Storage.csproj | 5 ----- 1 file changed, 5 deletions(-) diff --git a/src/Files.Core.Storage/Files.Core.Storage.csproj b/src/Files.Core.Storage/Files.Core.Storage.csproj index 224fd2108c99..2f251f813488 100644 --- a/src/Files.Core.Storage/Files.Core.Storage.csproj +++ b/src/Files.Core.Storage/Files.Core.Storage.csproj @@ -10,9 +10,4 @@ win10-x86;win10-x64;win10-arm64 - - - - - From 6dad720ec5e374f021ca0f4ff3881b184fb887b9 Mon Sep 17 00:00:00 2001 From: 0x5BFA <62196528+0x5bfa@users.noreply.github.com> Date: Thu, 13 Jul 2023 21:25:00 +0900 Subject: [PATCH 10/12] Fix build errors --- .../BaseLayoutCommandImplementationModel.cs | 222 ------------------ .../LayoutModes/BaseLayoutViewModel.cs | 1 - 2 files changed, 223 deletions(-) delete mode 100644 src/Files.App/Interacts/BaseLayoutCommandImplementationModel.cs diff --git a/src/Files.App/Interacts/BaseLayoutCommandImplementationModel.cs b/src/Files.App/Interacts/BaseLayoutCommandImplementationModel.cs deleted file mode 100644 index 1e96f21841f1..000000000000 --- a/src/Files.App/Interacts/BaseLayoutCommandImplementationModel.cs +++ /dev/null @@ -1,222 +0,0 @@ -// Copyright (c) 2023 Files Community -// Licensed under the MIT License. See the LICENSE. - -#nullable disable warnings - -using Microsoft.UI.Xaml; -using Microsoft.UI.Xaml.Input; -using System.IO; -using Windows.ApplicationModel.DataTransfer; -using Windows.ApplicationModel.DataTransfer.DragDrop; -using Windows.Storage; -using Windows.System; -using static Files.App.Constants.Browser.GridViewBrowser; - -namespace Files.App.Interacts -{ - /// - /// This class provides default implementation for BaseLayout commands. - /// This class can be also inherited from and functions overridden to provide custom functionality - /// - public class BaseLayoutCommandImplementationModel : IBaseLayoutCommandImplementationModel - { - #region Singleton - - private IBaseLayout SlimContentPage => associatedInstance?.SlimContentPage; - - #endregion Singleton - - #region Private Members - - private readonly IShellPage associatedInstance; - - private readonly ItemManipulationModel itemManipulationModel; - private readonly MainPageViewModel mainPageViewModel = Ioc.Default.GetRequiredService(); - - - #endregion Private Members - - #region Constructor - - public BaseLayoutCommandImplementationModel(IShellPage associatedInstance, ItemManipulationModel itemManipulationModel) - { - this.associatedInstance = associatedInstance; - this.itemManipulationModel = itemManipulationModel; - } - - #endregion Constructor - - #region IDisposable - - public void Dispose() - { - //associatedInstance = null; - } - - #endregion IDisposable - - #region Command Implementation - - public virtual async Task OpenDirectoryInNewTab(RoutedEventArgs e) - { - foreach (ListedItem listedItem in SlimContentPage.SelectedItems) - { - await MainWindow.Instance.DispatcherQueue.EnqueueOrInvokeAsync(async () => - { - await mainPageViewModel.AddNewTabByPathAsync(typeof(PaneHolderPage), (listedItem as ShortcutItem)?.TargetPath ?? listedItem.ItemPath); - }, - Microsoft.UI.Dispatching.DispatcherQueuePriority.Low); - } - } - - public virtual void OpenDirectoryInNewPane(RoutedEventArgs e) - { - NavigationHelpers.OpenInSecondaryPane(associatedInstance, SlimContentPage.SelectedItems.FirstOrDefault()); - } - - public virtual async Task OpenInNewWindowItem(RoutedEventArgs e) - { - List items = SlimContentPage.SelectedItems; - - foreach (ListedItem listedItem in items) - { - var selectedItemPath = (listedItem as ShortcutItem)?.TargetPath ?? listedItem.ItemPath; - var folderUri = new Uri($"files-uwp:?folder={@selectedItemPath}"); - await Launcher.LaunchUriAsync(folderUri); - } - } - - public virtual void CreateNewFile(ShellNewEntry f) - { - UIFilesystemHelpers.CreateFileFromDialogResultType(AddItemDialogItemType.File, f, associatedInstance); - } - - public virtual async Task ItemPointerPressed(PointerRoutedEventArgs e) - { - if (e.GetCurrentPoint(null).Properties.IsMiddleButtonPressed) - { - // If a folder item was clicked, disable middle mouse click to scroll to cancel the mouse scrolling state and re-enable it - if (e.OriginalSource is FrameworkElement { DataContext: ListedItem Item } && Item.PrimaryItemAttribute == StorageItemTypes.Folder) - { - SlimContentPage.IsMiddleClickToScrollEnabled = false; - SlimContentPage.IsMiddleClickToScrollEnabled = true; - - if (Item.IsShortcut) - await NavigationHelpers.OpenPathInNewTab(((e.OriginalSource as FrameworkElement)?.DataContext as ShortcutItem)?.TargetPath ?? Item.ItemPath); - else - await NavigationHelpers.OpenPathInNewTab(Item.ItemPath); - } - } - } - - public virtual void PointerWheelChanged(PointerRoutedEventArgs e) - { - if (e.KeyModifiers is VirtualKeyModifiers.Control) - { - if (associatedInstance.IsCurrentInstance) - { - int delta = e.GetCurrentPoint(null).Properties.MouseWheelDelta; - if (delta < 0) // Mouse wheel down - associatedInstance.InstanceViewModel.FolderSettings.GridViewSize -= GridViewIncrement; - else if (delta > 0) // Mouse wheel up - associatedInstance.InstanceViewModel.FolderSettings.GridViewSize += GridViewIncrement; - } - - e.Handled = true; - } - } - - public virtual async Task DragOver(DragEventArgs e) - { - var deferral = e.GetDeferral(); - - if (associatedInstance.InstanceViewModel.IsPageTypeSearchResults) - { - e.AcceptedOperation = DataPackageOperation.None; - deferral.Complete(); - return; - } - - itemManipulationModel.ClearSelection(); - - if (FilesystemHelpers.HasDraggedStorageItems(e.DataView)) - { - e.Handled = true; - - var draggedItems = await FilesystemHelpers.GetDraggedStorageItems(e.DataView); - - var pwd = associatedInstance.FilesystemViewModel.WorkingDirectory.TrimPath(); - var folderName = (Path.IsPathRooted(pwd) && Path.GetPathRoot(pwd) == pwd) ? Path.GetPathRoot(pwd) : Path.GetFileName(pwd); - - // As long as one file doesn't already belong to this folder - if (associatedInstance.InstanceViewModel.IsPageTypeSearchResults || (draggedItems.Any() && draggedItems.AreItemsAlreadyInFolder(associatedInstance.FilesystemViewModel.WorkingDirectory))) - { - e.AcceptedOperation = DataPackageOperation.None; - } - else if (!draggedItems.Any()) - { - e.AcceptedOperation = DataPackageOperation.None; - } - else - { - e.DragUIOverride.IsCaptionVisible = true; - if (pwd.StartsWith(Constants.UserEnvironmentPaths.RecycleBinPath, StringComparison.Ordinal)) - { - e.DragUIOverride.Caption = string.Format("MoveToFolderCaptionText".GetLocalizedResource(), folderName); - e.AcceptedOperation = DataPackageOperation.Move; - } - else if (e.Modifiers.HasFlag(DragDropModifiers.Alt) || e.Modifiers.HasFlag(DragDropModifiers.Control | DragDropModifiers.Shift)) - { - e.DragUIOverride.Caption = string.Format("LinkToFolderCaptionText".GetLocalizedResource(), folderName); - e.AcceptedOperation = DataPackageOperation.Link; - } - else if (e.Modifiers.HasFlag(DragDropModifiers.Control)) - { - e.DragUIOverride.Caption = string.Format("CopyToFolderCaptionText".GetLocalizedResource(), folderName); - e.AcceptedOperation = DataPackageOperation.Copy; - } - else if (e.Modifiers.HasFlag(DragDropModifiers.Shift)) - { - e.DragUIOverride.Caption = string.Format("MoveToFolderCaptionText".GetLocalizedResource(), folderName); - e.AcceptedOperation = DataPackageOperation.Move; - } - else if (draggedItems.Any(x => - x.Item is ZipStorageFile || - x.Item is ZipStorageFolder) || - ZipStorageFolder.IsZipPath(pwd)) - { - e.DragUIOverride.Caption = string.Format("CopyToFolderCaptionText".GetLocalizedResource(), folderName); - e.AcceptedOperation = DataPackageOperation.Copy; - } - else if (draggedItems.AreItemsInSameDrive(associatedInstance.FilesystemViewModel.WorkingDirectory)) - { - e.DragUIOverride.Caption = string.Format("MoveToFolderCaptionText".GetLocalizedResource(), folderName); - e.AcceptedOperation = DataPackageOperation.Move; - } - else - { - e.DragUIOverride.Caption = string.Format("CopyToFolderCaptionText".GetLocalizedResource(), folderName); - e.AcceptedOperation = DataPackageOperation.Copy; - } - } - } - - deferral.Complete(); - } - - public virtual async Task Drop(DragEventArgs e) - { - var deferral = e.GetDeferral(); - - if (FilesystemHelpers.HasDraggedStorageItems(e.DataView)) - { - await associatedInstance.FilesystemHelpers.PerformOperationTypeAsync(e.AcceptedOperation, e.DataView, associatedInstance.FilesystemViewModel.WorkingDirectory, false, true); - e.Handled = true; - } - - deferral.Complete(); - } - - #endregion Command Implementation - } -} diff --git a/src/Files.App/ViewModels/LayoutModes/BaseLayoutViewModel.cs b/src/Files.App/ViewModels/LayoutModes/BaseLayoutViewModel.cs index 33736b6aceaa..b839e0d7b411 100644 --- a/src/Files.App/ViewModels/LayoutModes/BaseLayoutViewModel.cs +++ b/src/Files.App/ViewModels/LayoutModes/BaseLayoutViewModel.cs @@ -1,7 +1,6 @@ // Copyright (c) 2023 Files Community // Licensed under the MIT License. See the LICENSE. -using Files.App.Utils.StorageItems; using Microsoft.UI.Xaml; using Microsoft.UI.Xaml.Input; using System.IO; From 9df580e1f5244e25059e7bc2553629f0f618c25c Mon Sep 17 00:00:00 2001 From: 0x5BFA <62196528+0x5bfa@users.noreply.github.com> Date: Wed, 19 Jul 2023 04:52:06 +0000 Subject: [PATCH 11/12] Requested changes --- .../Utils/Storage/Collection/GroupedCollection.cs | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/src/Files.App/Utils/Storage/Collection/GroupedCollection.cs b/src/Files.App/Utils/Storage/Collection/GroupedCollection.cs index 9c20d3736278..5d0fbc17b01a 100644 --- a/src/Files.App/Utils/Storage/Collection/GroupedCollection.cs +++ b/src/Files.App/Utils/Storage/Collection/GroupedCollection.cs @@ -41,36 +41,39 @@ private void GroupedCollection_PropertyChanged(object sender, PropertyChangedEve { if (e.PropertyName == nameof(Count)) { - Model.CountText = string.Format(Count > 1 ? "GroupItemsCount_Plural".GetLocalizedResource() : "GroupItemsCount_Singular".GetLocalizedResource(), Count); + Model.CountText = string.Format( + Count > 1 + ? "GroupItemsCount_Plural".GetLocalizedResource() + : "GroupItemsCount_Singular".GetLocalizedResource(), + Count); } } public void InitializeExtendedGroupHeaderInfoAsync() { if (GetExtendedGroupHeaderInfo is null) - { return; - } Model.ResumePropertyChangedNotifications(false); GetExtendedGroupHeaderInfo.Invoke(this); Model.Initialized = true; + if (isBulkOperationStarted) - { Model.PausePropertyChangedNotifications(); - } } public override void BeginBulkOperation() { base.BeginBulkOperation(); + Model.PausePropertyChangedNotifications(); } public override void EndBulkOperation() { base.EndBulkOperation(); + Model.ResumePropertyChangedNotifications(); } } From 67ae5f6519f1b22fffc82e47d827f2a2ae95a944 Mon Sep 17 00:00:00 2001 From: 0x5BFA <62196528+0x5bfa@users.noreply.github.com> Date: Wed, 19 Jul 2023 04:54:01 +0000 Subject: [PATCH 12/12] Fixed build errors --- .../Storage/Enumerators/UniversalStorageEnumerator.cs | 9 +-------- 1 file changed, 1 insertion(+), 8 deletions(-) diff --git a/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs b/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs index d237a647dc05..38eb5ed0a56c 100644 --- a/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs +++ b/src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs @@ -80,9 +80,7 @@ ex is FileNotFoundException || if (folder is not null) { if (defaultIconPairs?.ContainsKey(string.Empty) ?? false) - { folder.FileImage = defaultIconPairs[string.Empty]; - } tempList.Add(folder); } @@ -97,14 +95,9 @@ ex is FileNotFoundException || if (!string.IsNullOrEmpty(fileEntry.FileExtension)) { var lowercaseExtension = fileEntry.FileExtension.ToLowerInvariant(); + if (defaultIconPairs.ContainsKey(lowercaseExtension)) -<<<<<<< HEAD:src/Files.App/Utils/Storage/Enumerators/UniversalStorageEnumerator.cs - fileEntry.SetDefaultIcon(defaultIconPairs[lowercaseExtension]); -======= - { fileEntry.FileImage = defaultIconPairs[lowercaseExtension]; - } ->>>>>>> upstream/main:src/Files.App/Utils/StorageEnumerators/UniversalStorageEnumerator.cs } }