Chessar.LongPaths 1.0.0-rc005

This is a prerelease version of Chessar.LongPaths.
There is a newer version of this package available.
See the version list below for details.
dotnet add package Chessar.LongPaths --version 1.0.0-rc005                
NuGet\Install-Package Chessar.LongPaths -Version 1.0.0-rc005                
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="Chessar.LongPaths" Version="1.0.0-rc005" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Chessar.LongPaths --version 1.0.0-rc005                
#r "nuget: Chessar.LongPaths, 1.0.0-rc005"                
#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 Chessar.LongPaths as a Cake Addin
#addin nuget:?package=Chessar.LongPaths&version=1.0.0-rc005&prerelease

// Install Chessar.LongPaths as a Cake Tool
#tool nuget:?package=Chessar.LongPaths&version=1.0.0-rc005&prerelease                

Chessar.LongPaths is a .NET library that allows you to enable long path support for the main System.IO classes:

FileStream, File, FileInfo, Directory, DirectoryInfo, ... (and others).

The library is based on replacing the internal NormalizePath and GetFullPathInternal functions from the static Path class. The replacement is done using JMP hooks (thanks to @wledfor2), in which the long path prefix \\?\ or \\?\UNC\ is added. Adding a prefix is done by calling the internal function Path.AddLongPathPrefix. Note also that the addition of such prefixes depends on the UseLegacyPathHandling and BlockLongPaths settings, which must necessarily be false (in the AppContextSwitchOverrides element).

In this case, your code does not need to directly add such prefixes to the paths.

Supported Platforms:

How to use

  1. Add the Chessar.LongPaths NuGet package to the project.
  2. In the file app.config (or web.config), in the section runtime, add:
<configuration>
...
  <runtime>
    <AppContextSwitchOverrides value="Switch.System.IO.UseLegacyPathHandling=false;Switch.System.IO.BlockLongPaths=false" />
  </runtime>
...
  1. In the code (when you start the application or at the beginning of Main) add code:
...
using static Chessar.Hooks;
...

    PatchLongPaths();

  1. Usage
...
var fileInfo = new FileInfo(path);
var fullName = fileInfo.FullName; // with long path prefix
...
  1. At the end of the application:
    RemoveLongPathsPatch();

See also Examples.

Notes

For the following list of ctors/methods, you must directly specify the prefix of long paths (because they are not supported by this library, see Unit Tests):

for example:

...
using static Chessar.Hooks;
...
    var ds = new DirectorySecurity(path.AddLongPathPrefix(), acs);

or use DirectoryInfo instead Directory (exclude MoveTo method) and FileInfo instead File.

Note that, next methods does not work for long paths, even if a prefix is added:

TODO

  1. Speed up MethodInfo.Invoke in the class Hooks, using, for example, DynamicMethod.CreateDelegate.
  2. Add long path support in ctors/methods from Notes.
  3. Add more unit tests.
  4. Make hooks more thread safe.

License

MIT - See LICENSE

Product Compatible and additional computed target framework versions.
.NET Framework net462 is compatible.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

This package has 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.1.8 1,634 10/25/2018
1.1.7 807 10/2/2018
1.1.7-rc003 610 10/2/2018
1.1.6 782 9/24/2018
1.1.5 760 9/23/2018
1.1.4 804 9/21/2018
1.1.3 781 9/20/2018
1.1.2 836 9/16/2018
1.1.1 802 9/12/2018
1.1.0 806 9/10/2018
1.0.9 860 9/4/2018
1.0.8 822 8/26/2018
1.0.7 869 7/30/2018
1.0.6 818 7/25/2018
1.0.5 836 7/19/2018
1.0.4 914 7/18/2018
1.0.3 932 7/18/2018
1.0.2 927 7/18/2018
1.0.1 956 7/12/2018
1.0.0 931 7/12/2018
1.0.0-rc005 694 7/5/2018
1.0.0-rc004 761 6/20/2018
1.0.0-rc003 754 6/18/2018

Pre-release. Final RC.