123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125 |
- using System;
- using System.IO;
- using MediaBrowser.Controller.IO;
- using MediaBrowser.Model.Entities;
- namespace MediaBrowser.Controller.Library
- {
- /// <summary>
- /// This is an EventArgs object used when resolving a Path into a BaseItem
- /// </summary>
- public class ItemResolveEventArgs : PreBeginResolveEventArgs
- {
- public WIN32_FIND_DATA[] FileSystemChildren { get; set; }
- public WIN32_FIND_DATA? GetFileSystemEntry(string path)
- {
- for (int i = 0; i < FileSystemChildren.Length; i++)
- {
- WIN32_FIND_DATA entry = FileSystemChildren[i];
- if (entry.Path.Equals(path, StringComparison.OrdinalIgnoreCase))
- {
- return entry;
- }
- }
-
- return null;
- }
- public bool ContainsFile(string name)
- {
- for (int i = 0; i < FileSystemChildren.Length; i++)
- {
- if (System.IO.Path.GetFileName(FileSystemChildren[i].Path).Equals(name, StringComparison.OrdinalIgnoreCase))
- {
- return true;
- }
- }
- return false;
- }
- public bool ContainsFolder(string name)
- {
- for (int i = 0; i < FileSystemChildren.Length; i++)
- {
- if (System.IO.Path.GetFileName(FileSystemChildren[i].Path).Equals(name, StringComparison.OrdinalIgnoreCase))
- {
- return true;
- }
- }
- return false;
- }
- }
- /// <summary>
- /// This is an EventArgs object used before we begin resolving a Path into a BaseItem
- /// File system children have not been collected yet, but consuming events will
- /// have a chance to cancel resolution based on the Path, Parent and FileAttributes
- /// </summary>
- public class PreBeginResolveEventArgs : EventArgs
- {
- public Folder Parent { get; set; }
- public bool Cancel { get; set; }
- public WIN32_FIND_DATA FileInfo { get; set; }
- public string Path { get; set; }
- public bool IsDirectory
- {
- get
- {
- return FileInfo.dwFileAttributes.HasFlag(FileAttributes.Directory);
- }
- }
- public VirtualFolder VirtualFolder
- {
- get
- {
- if (Parent != null)
- {
- return Parent.VirtualFolder;
- }
- return null;
- }
- }
- public string VirtualFolderCollectionType
- {
- get
- {
- VirtualFolder vf = VirtualFolder;
- if (vf == null)
- {
- return null;
- }
- return vf.CollectionType;
- }
- }
- public bool IsHidden
- {
- get
- {
- return FileInfo.IsHidden;
- }
- }
- public bool IsSystemFile
- {
- get
- {
- return FileInfo.IsSystemFile;
- }
- }
- }
- }
|