ChEJunkie.TempFolder 1.0.4

dotnet add package ChEJunkie.TempFolder --version 1.0.4                
NuGet\Install-Package ChEJunkie.TempFolder -Version 1.0.4                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="ChEJunkie.TempFolder" Version="1.0.4" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add ChEJunkie.TempFolder --version 1.0.4                
#r "nuget: ChEJunkie.TempFolder, 1.0.4"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install ChEJunkie.TempFolder as a Cake Addin
#addin nuget:?package=ChEJunkie.TempFolder&version=1.0.4

// Install ChEJunkie.TempFolder as a Cake Tool
#tool nuget:?package=ChEJunkie.TempFolder&version=1.0.4                

Temporary Folder

NuGet version (ChEJunkie.TempFolder)

Provides unique temporary folders that automatically delete after use (when the class is disposed). To ensure that the temporary folder is actually deleted on destroy, attributes are automatically cleared from contained files and subdirectories when necessary.

The default constructor places the temporary folder in the user temp directory under a folder with the name of the calling assembly. Use Root and FullName properties to view the automatic definitions. Since the temporary folder implements IDisposable it is easiest to implment with a using statement:

[TestMethod]
public void Create_And_Destroy_Success()
{
    TempFolder dir;
    using (dir = new TempFolder())
    {
        // Root = <user temp directory>//<calling assembly name>
        // FullName = <root>//<randomly generated name>
        Debug.WriteLine($"Root: {dir.Root}");
        Debug.WriteLine($"FullName: {dir.FullName}");
        Assert.IsTrue(dir.Exists);
    }
    Debug.WriteLine($"Removed? {!dir.Exists}");
    Assert.IsFalse(dir.Exists);
}

If you choose, you can explicitaly define the root and temporary folder name in the constructor overload.

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net6.0

    • No dependencies.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.4 538 9/30/2023
1.0.3 465 9/30/2023
1.0.2 513 9/30/2023
1.0.1 698 12/31/2022
1.0.0 702 12/31/2022

Update assembly name to match package ID. Embedd readme and MIT license in package.