Base project
This commit is contained in:
@@ -0,0 +1,7 @@
|
||||
namespace FileTime.Core.Behaviors
|
||||
{
|
||||
public interface IOnContainerEnter
|
||||
{
|
||||
Task OnEnter();
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,9 @@
|
||||
namespace FileTime.Core.Enums
|
||||
{
|
||||
public enum AbsolutePathType
|
||||
{
|
||||
Unknown,
|
||||
Container,
|
||||
Element
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,9 @@
|
||||
namespace FileTime.Core.Enums
|
||||
{
|
||||
public enum SupportsDelete
|
||||
{
|
||||
False,
|
||||
True,
|
||||
HardDeleteOnly,
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,13 @@
|
||||
<Project Sdk="Microsoft.NET.Sdk">
|
||||
|
||||
<PropertyGroup>
|
||||
<TargetFramework>net6.0</TargetFramework>
|
||||
<ImplicitUsings>enable</ImplicitUsings>
|
||||
<Nullable>enable</Nullable>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<PackageReference Include="System.Reactive" Version="5.0.0" />
|
||||
</ItemGroup>
|
||||
|
||||
</Project>
|
||||
4
src/Core/FileTime.Core.Abstraction/Models/FullName.cs
Normal file
4
src/Core/FileTime.Core.Abstraction/Models/FullName.cs
Normal file
@@ -0,0 +1,4 @@
|
||||
namespace FileTime.Core.Models
|
||||
{
|
||||
public record FullName(string Path);
|
||||
}
|
||||
13
src/Core/FileTime.Core.Abstraction/Models/IAbsolutePath.cs
Normal file
13
src/Core/FileTime.Core.Abstraction/Models/IAbsolutePath.cs
Normal file
@@ -0,0 +1,13 @@
|
||||
using FileTime.Core.Enums;
|
||||
using FileTime.Core.Services;
|
||||
|
||||
namespace FileTime.Core.Models
|
||||
{
|
||||
public interface IAbsolutePath
|
||||
{
|
||||
IContentProvider ContentProvider { get; }
|
||||
IContentProvider? VirtualContentProvider { get; }
|
||||
FullName Path { get; }
|
||||
AbsolutePathType Type { get; }
|
||||
}
|
||||
}
|
||||
7
src/Core/FileTime.Core.Abstraction/Models/IContainer.cs
Normal file
7
src/Core/FileTime.Core.Abstraction/Models/IContainer.cs
Normal file
@@ -0,0 +1,7 @@
|
||||
namespace FileTime.Core.Models
|
||||
{
|
||||
public interface IContainer : IItem
|
||||
{
|
||||
IReadOnlyList<IAbsolutePath> Items { get; }
|
||||
}
|
||||
}
|
||||
7
src/Core/FileTime.Core.Abstraction/Models/IElement.cs
Normal file
7
src/Core/FileTime.Core.Abstraction/Models/IElement.cs
Normal file
@@ -0,0 +1,7 @@
|
||||
namespace FileTime.Core.Models
|
||||
{
|
||||
public interface IElement : IItem
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,7 @@
|
||||
namespace FileTime.Core.Models
|
||||
{
|
||||
public interface IFileElement : IElement
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
18
src/Core/FileTime.Core.Abstraction/Models/IItem.cs
Normal file
18
src/Core/FileTime.Core.Abstraction/Models/IItem.cs
Normal file
@@ -0,0 +1,18 @@
|
||||
using FileTime.Core.Enums;
|
||||
using FileTime.Core.Services;
|
||||
|
||||
namespace FileTime.Core.Models
|
||||
{
|
||||
public interface IItem
|
||||
{
|
||||
string Name { get; }
|
||||
string DisplayName { get; }
|
||||
FullName? FullName { get; }
|
||||
NativePath? NativePath { get; }
|
||||
bool IsHidden { get; }
|
||||
bool IsExists { get; }
|
||||
SupportsDelete CanDelete { get; }
|
||||
bool CanRename { get; }
|
||||
IContentProvider Provider { get; }
|
||||
}
|
||||
}
|
||||
4
src/Core/FileTime.Core.Abstraction/Models/NativePath.cs
Normal file
4
src/Core/FileTime.Core.Abstraction/Models/NativePath.cs
Normal file
@@ -0,0 +1,4 @@
|
||||
namespace FileTime.Core.Models
|
||||
{
|
||||
public record NativePath(string Path);
|
||||
}
|
||||
@@ -0,0 +1,12 @@
|
||||
using FileTime.Core.Behaviors;
|
||||
using FileTime.Core.Models;
|
||||
|
||||
namespace FileTime.Core.Services
|
||||
{
|
||||
public interface IContentProvider : IContainer, IOnContainerEnter
|
||||
{
|
||||
Task<IItem> GetItemByFullNameAsync(FullName fullName);
|
||||
Task<IItem> GetItemByNativePathAsync(NativePath nativePath);
|
||||
Task<List<IAbsolutePath>> GetItemsByContainerAsync(FullName fullName);
|
||||
}
|
||||
}
|
||||
7
src/Core/FileTime.Core.Abstraction/Services/ITab.cs
Normal file
7
src/Core/FileTime.Core.Abstraction/Services/ITab.cs
Normal file
@@ -0,0 +1,7 @@
|
||||
namespace FileTime.Core.Services
|
||||
{
|
||||
public interface ITab
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
22
src/Core/FileTime.Core.Models/AbsolutePath.cs
Normal file
22
src/Core/FileTime.Core.Models/AbsolutePath.cs
Normal file
@@ -0,0 +1,22 @@
|
||||
using FileTime.Core.Enums;
|
||||
using FileTime.Core.Services;
|
||||
|
||||
namespace FileTime.Core.Models
|
||||
{
|
||||
public class AbsolutePath : IAbsolutePath
|
||||
{
|
||||
public IContentProvider ContentProvider { get; }
|
||||
public IContentProvider? VirtualContentProvider { get; }
|
||||
|
||||
public FullName Path { get; }
|
||||
public AbsolutePathType Type { get; }
|
||||
|
||||
public AbsolutePath(IContentProvider contentProvider, FullName path, AbsolutePathType type, IContentProvider? virtualContentProvider = null)
|
||||
{
|
||||
ContentProvider = contentProvider;
|
||||
Path = path;
|
||||
VirtualContentProvider = virtualContentProvider;
|
||||
Type = type;
|
||||
}
|
||||
}
|
||||
}
|
||||
8
src/Core/FileTime.Core.Models/Constants.cs
Normal file
8
src/Core/FileTime.Core.Models/Constants.cs
Normal file
@@ -0,0 +1,8 @@
|
||||
namespace FileTime.Core.Models
|
||||
{
|
||||
public static class Constants
|
||||
{
|
||||
public const char SeparatorChar = '/';
|
||||
public const string ContentProviderProtocol = "ctp://";
|
||||
}
|
||||
}
|
||||
17
src/Core/FileTime.Core.Models/Container.cs
Normal file
17
src/Core/FileTime.Core.Models/Container.cs
Normal file
@@ -0,0 +1,17 @@
|
||||
using FileTime.Core.Enums;
|
||||
using FileTime.Core.Services;
|
||||
|
||||
namespace FileTime.Core.Models
|
||||
{
|
||||
public record Container
|
||||
(string Name,
|
||||
string DisplayName,
|
||||
FullName FullName,
|
||||
NativePath NativePath,
|
||||
bool IsHidden,
|
||||
bool IsExists,
|
||||
SupportsDelete CanDelete,
|
||||
bool CanRename,
|
||||
IContentProvider Provider,
|
||||
IReadOnlyList<IAbsolutePath> Items) : IContainer;
|
||||
}
|
||||
16
src/Core/FileTime.Core.Models/Element.cs
Normal file
16
src/Core/FileTime.Core.Models/Element.cs
Normal file
@@ -0,0 +1,16 @@
|
||||
using FileTime.Core.Enums;
|
||||
using FileTime.Core.Services;
|
||||
|
||||
namespace FileTime.Core.Models
|
||||
{
|
||||
public record Element
|
||||
(string Name,
|
||||
string DisplayName,
|
||||
FullName FullName,
|
||||
NativePath NativePath,
|
||||
bool IsHidden,
|
||||
bool IsExists,
|
||||
SupportsDelete CanDelete,
|
||||
bool CanRename,
|
||||
IContentProvider Provider) : IElement;
|
||||
}
|
||||
13
src/Core/FileTime.Core.Models/FileTime.Core.Models.csproj
Normal file
13
src/Core/FileTime.Core.Models/FileTime.Core.Models.csproj
Normal file
@@ -0,0 +1,13 @@
|
||||
<Project Sdk="Microsoft.NET.Sdk">
|
||||
|
||||
<PropertyGroup>
|
||||
<TargetFramework>net6.0</TargetFramework>
|
||||
<ImplicitUsings>enable</ImplicitUsings>
|
||||
<Nullable>enable</Nullable>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="..\FileTime.Core.Abstraction\FileTime.Core.Abstraction.csproj" />
|
||||
</ItemGroup>
|
||||
|
||||
</Project>
|
||||
41
src/Core/FileTime.Core.Services/ContentProviderBase.cs
Normal file
41
src/Core/FileTime.Core.Services/ContentProviderBase.cs
Normal file
@@ -0,0 +1,41 @@
|
||||
using FileTime.Core.Enums;
|
||||
using FileTime.Core.Models;
|
||||
|
||||
namespace FileTime.Core.Services
|
||||
{
|
||||
public abstract class ContentProviderBase : IContentProvider
|
||||
{
|
||||
protected List<IAbsolutePath> Items { get; set; } = new List<IAbsolutePath>();
|
||||
|
||||
IReadOnlyList<IAbsolutePath> IContainer.Items => Items;
|
||||
|
||||
public string Name { get; }
|
||||
|
||||
public string DisplayName { get; }
|
||||
|
||||
public FullName? FullName => null;
|
||||
|
||||
public NativePath? NativePath => null;
|
||||
|
||||
public bool IsHidden => false;
|
||||
|
||||
public bool IsExists => true;
|
||||
|
||||
public SupportsDelete CanDelete => SupportsDelete.False;
|
||||
|
||||
public bool CanRename => false;
|
||||
|
||||
public IContentProvider Provider => this;
|
||||
|
||||
protected ContentProviderBase(string name)
|
||||
{
|
||||
DisplayName = Name = name;
|
||||
}
|
||||
|
||||
public virtual Task OnEnter() => Task.CompletedTask;
|
||||
public virtual async Task<IItem> GetItemByFullNameAsync(FullName fullName) => await GetItemByNativePathAsync(GetNativePath(fullName));
|
||||
public abstract Task<IItem> GetItemByNativePathAsync(NativePath nativePath);
|
||||
public abstract Task<List<IAbsolutePath>> GetItemsByContainerAsync(FullName fullName);
|
||||
public abstract NativePath GetNativePath(FullName fullName);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,18 @@
|
||||
<Project Sdk="Microsoft.NET.Sdk">
|
||||
|
||||
<PropertyGroup>
|
||||
<TargetFramework>net6.0</TargetFramework>
|
||||
<ImplicitUsings>enable</ImplicitUsings>
|
||||
<Nullable>enable</Nullable>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<PackageReference Include="System.Reactive" Version="5.0.0" />
|
||||
</ItemGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="..\FileTime.Core.Abstraction\FileTime.Core.Abstraction.csproj" />
|
||||
<ProjectReference Include="..\FileTime.Core.Models\FileTime.Core.Models.csproj" />
|
||||
</ItemGroup>
|
||||
|
||||
</Project>
|
||||
7
src/Core/FileTime.Core.Services/Tab.cs
Normal file
7
src/Core/FileTime.Core.Services/Tab.cs
Normal file
@@ -0,0 +1,7 @@
|
||||
namespace FileTime.Core.Services
|
||||
{
|
||||
public class Tab : ITab
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user