i have the following code:
public static void Serialize()
{
List<string> dirs = FileHelper.GetFilesRecursive(fileDirectoryPath);
List<string> dirFiles = new List<string>();
foreach (string p in dirs)
{
string path = p;
string lastAccessTime = File.GetLastAccessTime(path).ToString();
bool DirFile = File.Exists(path);
FileInfo fInf = new FileInfo(path);
long lengthInk = fInf.Length / 1024;
DateTime lastWriteTime = File.GetLastWriteTime(p);
dirFiles.Add(p + "|" + lastAccessTime.ToString() + "|" + DirFile.ToString() + "|" + lastWriteTime.ToString() + "|" + lengthInk.ToString() + " kb");
}
I keep hitting a PathTooLongException error with the following line:
string lastAccessTime = File.GetLastAccessTime(path).ToString();
The application drills into a drive and finds all files/folders w/in the drive. I cannot change this path but since it is above 260 characters...how to work around this?
Something like the
.LastAccessTime
property of Delimon.Win32.IO.FileInfo, might do the trick.Delimon is a library on Microsoft TechNet for overcoming the long filenames problem, it's called Delimon.Win32.IO Library (V4.0) and it has its own versions of key classes from System.IO
For example, you would replace:
with
which will let you handle long files and folders.
From the website:
.NET doesn't support Unicode file paths, so the only option I know of in this case is using P/Invoke (unless, of course, you can change the path) to call Win32 API functions that do support them. You can look here for instructions on how to use Unicode file path to break the 260 characters barrier.
As Microsoft says here, there is a Windows limitation on 260 characters.
You can try to avoid this with a symbolic link (not sure...).
The
GetLastAccessTime()
call, with a full path can exceed the internal limit (which is OS-version specific, but typically 260 characters) on the maximum length for a fully qualified file path.One way to avoid this, is to use
Directory.SetCurrentDirectory()
to change the current system directory and then callGetLastAccessTime()
with only a relative path. Just make sure you change your current directory back to what you started from to avoid unexpected issues.