Add Lesson 7 Task 1
This commit is contained in:
parent
c5edc42ba0
commit
f5cf47f213
15 changed files with 320 additions and 0 deletions
39
Lesson_7/Task_1/Classes/CopyDirectory.cs
Normal file
39
Lesson_7/Task_1/Classes/CopyDirectory.cs
Normal file
|
@ -0,0 +1,39 @@
|
|||
namespace Lesson5.Classes;
|
||||
|
||||
using Lesson5.Interfaces;
|
||||
|
||||
public class CopyDirectory : ICopyDirectory
|
||||
{
|
||||
public static void Copy(string sourceDir, string destinationDir, bool recursive)
|
||||
{
|
||||
// Get information about the source directory
|
||||
var dir = new DirectoryInfo(sourceDir);
|
||||
|
||||
// Check if the source directory exists
|
||||
if (!dir.Exists)
|
||||
throw new DirectoryNotFoundException($"Source directory not found: {dir.FullName}");
|
||||
|
||||
// Cache directories before we start copying
|
||||
DirectoryInfo[] dirs = dir.GetDirectories();
|
||||
|
||||
// Create the destination directory
|
||||
Directory.CreateDirectory(destinationDir);
|
||||
|
||||
// Get the files in the source directory and copy to the destination directory
|
||||
foreach (FileInfo file in dir.GetFiles())
|
||||
{
|
||||
string targetFilePath = Path.Combine(destinationDir, file.Name);
|
||||
file.CopyTo(targetFilePath);
|
||||
}
|
||||
|
||||
// If recursive and copying subdirectories, recursively call this method
|
||||
if (recursive)
|
||||
{
|
||||
foreach (DirectoryInfo subDir in dirs)
|
||||
{
|
||||
string newDestinationDir = Path.Combine(destinationDir, subDir.Name);
|
||||
Copy(subDir.FullName, newDestinationDir, true);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
56
Lesson_7/Task_1/Classes/Operations.cs
Normal file
56
Lesson_7/Task_1/Classes/Operations.cs
Normal file
|
@ -0,0 +1,56 @@
|
|||
namespace Lesson5.Classes;
|
||||
|
||||
using Lesson5.Interfaces;
|
||||
|
||||
public class Operations : IOperations
|
||||
{
|
||||
|
||||
public static void GetFileInfo(string path)
|
||||
{
|
||||
var info = new FileInfo(path);
|
||||
|
||||
Console.WriteLine($"Name: {info.Name}");
|
||||
Console.WriteLine($"Creation time: {info.CreationTime}");
|
||||
Console.WriteLine($"Length: {info.Length}");
|
||||
}
|
||||
|
||||
public static async Task CopyAsync(string source, string destination, bool keepSource=true)
|
||||
{
|
||||
try
|
||||
{
|
||||
destination = Validation.Check(source, destination);
|
||||
}
|
||||
catch (PathConflictException)
|
||||
{
|
||||
Console.WriteLine("Conflict.");
|
||||
return;
|
||||
}
|
||||
|
||||
bool exists = await Task.Run(() => Directory.Exists(source) || File.Exists(source));
|
||||
|
||||
if (exists)
|
||||
if (keepSource)
|
||||
{
|
||||
if (Directory.Exists(source))
|
||||
await Task.Run(() => CopyDirectory.Copy(source, destination, true));
|
||||
else if (File.Exists(source))
|
||||
await Task.Run(() => File.Copy(source, destination));
|
||||
}
|
||||
else
|
||||
{
|
||||
await Task.Run(() => Directory.Move(source, destination));
|
||||
}
|
||||
else
|
||||
Console.WriteLine("Not found.");
|
||||
}
|
||||
|
||||
public static async Task DeleteAsync(string path)
|
||||
{
|
||||
if (Directory.Exists(path))
|
||||
await Task.Run(() => Directory.Delete(path, true));
|
||||
else if (File.Exists(path))
|
||||
await Task.Run(() => File.Delete(path));
|
||||
else
|
||||
Console.WriteLine("Not found.");
|
||||
}
|
||||
}
|
19
Lesson_7/Task_1/Classes/PathConflictException.cs
Normal file
19
Lesson_7/Task_1/Classes/PathConflictException.cs
Normal file
|
@ -0,0 +1,19 @@
|
|||
namespace Lesson5.Classes;
|
||||
|
||||
[Serializable]
|
||||
public class PathConflictException : Exception
|
||||
{
|
||||
public PathConflictException ()
|
||||
{
|
||||
}
|
||||
|
||||
public PathConflictException (string message)
|
||||
: base(message)
|
||||
{
|
||||
}
|
||||
|
||||
public PathConflictException (string message, Exception innerException)
|
||||
: base(message, innerException)
|
||||
{
|
||||
}
|
||||
}
|
17
Lesson_7/Task_1/Classes/ReadFile.cs
Normal file
17
Lesson_7/Task_1/Classes/ReadFile.cs
Normal file
|
@ -0,0 +1,17 @@
|
|||
namespace Lesson5.Classes;
|
||||
|
||||
using Lesson5.Interfaces;
|
||||
|
||||
public class ReadFile : IReadFile
|
||||
{
|
||||
public static async Task ReadByPathAsync(string path)
|
||||
{
|
||||
if (File.Exists(path))
|
||||
{
|
||||
var data = await File.ReadAllTextAsync(path);
|
||||
Console.WriteLine(data);
|
||||
}
|
||||
else
|
||||
Console.WriteLine("No such file exists.");
|
||||
}
|
||||
}
|
17
Lesson_7/Task_1/Classes/UserInput.cs
Normal file
17
Lesson_7/Task_1/Classes/UserInput.cs
Normal file
|
@ -0,0 +1,17 @@
|
|||
namespace Lesson5.Classes;
|
||||
|
||||
using Lesson5.Interfaces;
|
||||
|
||||
public class UserInput : IUserInput
|
||||
{
|
||||
public static string AskStringInput(string prompt)
|
||||
{
|
||||
while (true)
|
||||
{
|
||||
Console.Write(prompt);
|
||||
string? input = Console.ReadLine();
|
||||
if (!string.IsNullOrEmpty(input))
|
||||
return input;
|
||||
}
|
||||
}
|
||||
}
|
20
Lesson_7/Task_1/Classes/Validation.cs
Normal file
20
Lesson_7/Task_1/Classes/Validation.cs
Normal file
|
@ -0,0 +1,20 @@
|
|||
namespace Lesson5.Classes;
|
||||
|
||||
using Lesson5.Interfaces;
|
||||
|
||||
public class Validation : IValidation
|
||||
{
|
||||
public static string Check(string source, string destination)
|
||||
{
|
||||
if (File.Exists(destination))
|
||||
throw new PathConflictException();
|
||||
|
||||
if (Directory.Exists(destination))
|
||||
destination = Path.Combine(destination, Path.GetFileName(source));
|
||||
|
||||
if (File.Exists(destination) || Directory.Exists(destination))
|
||||
throw new PathConflictException();
|
||||
|
||||
return destination;
|
||||
}
|
||||
}
|
43
Lesson_7/Task_1/Classes/WorkWithFileSystem.cs
Normal file
43
Lesson_7/Task_1/Classes/WorkWithFileSystem.cs
Normal file
|
@ -0,0 +1,43 @@
|
|||
namespace Lesson5.Classes;
|
||||
|
||||
using Lesson5.Interfaces;
|
||||
|
||||
public class WorkWithFileSystem : IWorkWithFileSystem
|
||||
{
|
||||
public static async Task GetDirectoryFilesAsync(string path)
|
||||
{
|
||||
var current = new DirectoryInfo(path);
|
||||
var dirs = await Task.Run(() => Directory.GetDirectories(current.FullName));
|
||||
var files = await Task.Run(() => Directory.GetFiles(current.FullName));
|
||||
|
||||
foreach (var dir in dirs)
|
||||
{
|
||||
Console.WriteLine(dir.Split('\\').Last() + "/");
|
||||
}
|
||||
foreach (var file in files)
|
||||
{
|
||||
Console.WriteLine(file.Split('\\').Last());
|
||||
}
|
||||
}
|
||||
|
||||
public static string Cd(string name, string current)
|
||||
{
|
||||
if (name == "..")
|
||||
{
|
||||
var info = new DirectoryInfo(current);
|
||||
|
||||
var parent = info.Parent;
|
||||
|
||||
return parent is not null ? parent.FullName : current;
|
||||
}
|
||||
|
||||
var dir = Path.Combine(current, name);
|
||||
|
||||
if (Directory.Exists(dir))
|
||||
{
|
||||
return dir;
|
||||
}
|
||||
|
||||
return current;
|
||||
}
|
||||
}
|
6
Lesson_7/Task_1/Interfaces/ICopyDirectory.cs
Normal file
6
Lesson_7/Task_1/Interfaces/ICopyDirectory.cs
Normal file
|
@ -0,0 +1,6 @@
|
|||
namespace Lesson5.Interfaces;
|
||||
|
||||
public interface ICopyDirectory
|
||||
{
|
||||
static void Copy(string sourceDir, string destinationDir, bool recursive) => throw new NotImplementedException();
|
||||
}
|
8
Lesson_7/Task_1/Interfaces/IOperations.cs
Normal file
8
Lesson_7/Task_1/Interfaces/IOperations.cs
Normal file
|
@ -0,0 +1,8 @@
|
|||
namespace Lesson5.Interfaces;
|
||||
|
||||
public interface IOperations
|
||||
{
|
||||
static void GetFileInfo(string path) => throw new NotImplementedException();
|
||||
static Task CopyAsync(string source, string destination, bool keepSource=true) => throw new NotImplementedException();
|
||||
static Task DeleteAsync(string path) => throw new NotImplementedException();
|
||||
}
|
6
Lesson_7/Task_1/Interfaces/IReadFile.cs
Normal file
6
Lesson_7/Task_1/Interfaces/IReadFile.cs
Normal file
|
@ -0,0 +1,6 @@
|
|||
namespace Lesson5.Interfaces;
|
||||
|
||||
public interface IReadFile
|
||||
{
|
||||
static Task ReadByPathAsync(string path) => throw new NotImplementedException();
|
||||
}
|
6
Lesson_7/Task_1/Interfaces/IUserInput.cs
Normal file
6
Lesson_7/Task_1/Interfaces/IUserInput.cs
Normal file
|
@ -0,0 +1,6 @@
|
|||
namespace Lesson5.Interfaces;
|
||||
|
||||
public interface IUserInput
|
||||
{
|
||||
static string AskStringInput(string prompt) => throw new NotImplementedException();
|
||||
}
|
6
Lesson_7/Task_1/Interfaces/IValidation.cs
Normal file
6
Lesson_7/Task_1/Interfaces/IValidation.cs
Normal file
|
@ -0,0 +1,6 @@
|
|||
namespace Lesson5.Interfaces;
|
||||
|
||||
public interface IValidation
|
||||
{
|
||||
static string Check(string source, string destination) => throw new NotImplementedException();
|
||||
}
|
7
Lesson_7/Task_1/Interfaces/IWorkWithFileSystem.cs
Normal file
7
Lesson_7/Task_1/Interfaces/IWorkWithFileSystem.cs
Normal file
|
@ -0,0 +1,7 @@
|
|||
namespace Lesson5.Interfaces;
|
||||
|
||||
public interface IWorkWithFileSystem
|
||||
{
|
||||
static Task GetDirectoryFilesAsync(string path) => throw new NotImplementedException();
|
||||
static void Cd(string name, string current) => throw new NotImplementedException();
|
||||
}
|
60
Lesson_7/Task_1/Program.cs
Normal file
60
Lesson_7/Task_1/Program.cs
Normal file
|
@ -0,0 +1,60 @@
|
|||
/*
|
||||
* Lesson 5 Task 1: a file manager
|
||||
* Author: Stanislav Mykhailenko, parts of code used from DanyilMykytenko's repository
|
||||
* License: Unlicense
|
||||
*/
|
||||
|
||||
using Lesson5.Classes;
|
||||
using Lesson5.Interfaces;
|
||||
|
||||
var dir = Directory.GetCurrentDirectory();
|
||||
string? command;
|
||||
|
||||
while (true)
|
||||
{
|
||||
Console.WriteLine(@"cd - change directory
|
||||
dir - show current directory contents
|
||||
open - read data
|
||||
mv - move data
|
||||
rm - remove data
|
||||
cp - copy data
|
||||
info - get data info
|
||||
");
|
||||
|
||||
Console.Write("{0}> ", dir);
|
||||
|
||||
command = Console.ReadLine();
|
||||
|
||||
switch (command)
|
||||
{
|
||||
case "cd":
|
||||
dir = WorkWithFileSystem.Cd(UserInput.AskStringInput("Enter the directory name: "), dir);
|
||||
break;
|
||||
case "dir":
|
||||
await WorkWithFileSystem.GetDirectoryFilesAsync(dir);
|
||||
break;
|
||||
case "open":
|
||||
await ReadFile.ReadByPathAsync(UserInput.AskStringInput("Enter the file name: "));
|
||||
break;
|
||||
case "mv":
|
||||
string moveSource = Path.Combine(dir, UserInput.AskStringInput("Enter the source: "));
|
||||
string moveDestination = Path.Combine(dir, UserInput.AskStringInput("Enter the destination: "));
|
||||
await Operations.CopyAsync(moveSource, moveDestination, false);
|
||||
break;
|
||||
case "rm":
|
||||
string path = Path.Combine(dir, UserInput.AskStringInput("Enter the file or directory to delete: "));
|
||||
await Operations.DeleteAsync(path);
|
||||
break;
|
||||
case "cp":
|
||||
string copySource = Path.Combine(dir, UserInput.AskStringInput("Enter the source: "));
|
||||
string copyDestination = Path.Combine(dir, UserInput.AskStringInput("Enter the destination: "));
|
||||
await Operations.CopyAsync(copySource, copyDestination);
|
||||
break;
|
||||
case "info":
|
||||
Operations.GetFileInfo(UserInput.AskStringInput("Enter the file name: "));
|
||||
break;
|
||||
default:
|
||||
Console.WriteLine("Unknown command");
|
||||
break;
|
||||
}
|
||||
}
|
10
Lesson_7/Task_1/Task_1.csproj
Normal file
10
Lesson_7/Task_1/Task_1.csproj
Normal file
|
@ -0,0 +1,10 @@
|
|||
<Project Sdk="Microsoft.NET.Sdk">
|
||||
|
||||
<PropertyGroup>
|
||||
<OutputType>Exe</OutputType>
|
||||
<TargetFramework>net7.0</TargetFramework>
|
||||
<ImplicitUsings>enable</ImplicitUsings>
|
||||
<Nullable>enable</Nullable>
|
||||
</PropertyGroup>
|
||||
|
||||
</Project>
|
Reference in a new issue