-
-
Notifications
You must be signed in to change notification settings - Fork 157
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
extraction fails for long path names #58
Comments
This error is coming directly from the low-level CAB APIs which is a native C lib calling Win32 and not .NET - so it isn't .NET causing these errors. That code is all checked in at https://github.com/activescott/libmspack4n if you want to investigate and provide a fix that works with the longer file names using whatever Win32 APIs work (while still validating file paths). As long as the code is clean and tests pass I'll be more than happy to accept PRs there. |
Thank you. I did some experiments with libmspack4n in order to move the handling of long paths there, as you suggested, and it almost works: while the call to Half-finished patch attached to show what I mean; it's the first time I use either C# or Visual Studio, so please show some mercy. I could try finishing the patch with win32 calls for setting the file attributes and time-stamps if you agree that it is the correct solution. |
@mattiase Thanks! I have no concerns on the approach. As long as tests pass, I'll pull it. |
Good, I shall have a patch finished by tomorrow. Right now the tests don't work outside your timezone; something needs to be done about that. The timestamps in .CAB files lack any timezone information and are treated as local times when files are extracted. However, the metadata reference files for the tests contain dates with specified timezones, making them absolute points in time. As a result, these tests always fail when I run them here. The simplest fix is to remove the timezone information from all .csv files under TestFiles/ExpectedOutput: just delete the "-08:00" or "-07:00" suffix of each time stamp (usually two per line). The test will then treat these timestamps as local times, and the test succeeds no matter where on Earth they are run. I could send you a patch for this if you like, but it's just a simple mechanical change, and the generation code should be updated accordingly as well so that they will be generated without the timezone part next time. |
thanks. love the idea of removing timezone suffix from generation code and test files! |
The pull requests are there, one for libmspack4n and one for lessmsi. |
Thanks for the PRs! I'll get to these as soon as I can. Probably this weekend. Thanks again!
|
@mattiase thanks again for the PRs. Can you point me to a msi that actually exhibits this problem so that I can double-check it before creating a release? |
You can use any MSI that you have, as long as you unpack it into a directory long enough so that the combined length of the base directory and at least one of the files in the MSI exceeds 260 characters. For instance, the longest file name inside Try, for instance, the directory |
Doh, guess I should have thought that through, but thanks for the specific example. I gave this a shot and even with the libmspack4n updates, still encounter a problem. Seems that GetTargetDirectory in Wixtracts (LessMsi.Core) is trying to use System.IO to identify the target directory and it ran into problems. I'm working on fixes for that, but before I continue, I want to make sure that I'm not missing anything. Don't you encounter the same thing? I'm using what is currently in master. P.S. I found it kind of funny that almost nothing works with those paths. Even cmd.exe, total commander, and more all had weird failures. Good thing I have cygwin and bash installed which work fine with the long windows paths 😜 |
It does work for me in the extract-all-to-directory form, Yes, those "extended" paths aren't recognised much even by Microsoft's own tools, but often they are the only way out. I mostly use cygwin too. |
It is true that if the combined length of the destination root directory and the longest directory of any file being extracted exceeds 260 characters, then extraction still fails (in I have no immediate plan to do this right now. Is it holding up a release for you? |
@mattiase sorry for my delay on this. Thanks for confirming that I'm not missing anything. I have a local branch here where I'm working on this. I'm swamped right now with a combination of work and personal activities, but I hope to get back to this and wrap it up over the next week or two. |
@mattiase could you please try the branch at https://github.com/activescott/lessmsi/tree/tested_support_for_long_paths and see if it works for you and your needs. I tried to add support throughout. If you run into something not working I'd love to have a test added. |
That branch ( However, even in this branch, I wasn't able to extract |
Okay the branch at https://github.com/activescott/lessmsi/tree/tested_support_for_long_paths contains a longer output path which revealed more issues throughout the code and this latest commit now has a fix for them. @mattiase I will be grateful if you can give that code a quick build and test to make sure it's all working for you now. |
Thank you! It seems to work as far as I have tested it, but I haven't tried it on UNC paths, and I wonder if the conversion to extended path form is done correctly. Unless I'm mistaken, the long form of |
I tried extracting to an UNC path, and it does not work at all (even for short paths) because of the reason described in my previous comment. |
Thanks for the feedback. Its on my list |
Only thing left is:
|
I believe this has been resolved back with recent versions of LessIO. I'm not sure if any window application -including windows explorer- supports long paths as well as LessMSI now :) Let me know if I'm missing something and I'll fix it. |
Thank you – unfortunately I'm no longer in a position to verify its functioning in this respect, but I'll take your word for it. |
Extraction (
lessmsi x
) fails if the combined length of the destination directory and a file in the MSI exceeds the usual 260 character limit:(The path names in the example above has been edited; pretend they are much longer.)
Despite using a relative path name for the extraction directory (
destdir\
), it is being converted to an absolute file name when the file is extracted. Permitting relative destination path names all the way might shorten them somewhat, but would do nothing about long paths in the archive file.Using the Windows 'long' file name syntax,
\\?\c:\somedir\destdir\
, would solve the problem but does not work in lessmsi at all. Apparently, the .NET system libs don't like that syntax very much, although it works well on the Win32 API level. There are apparently some replacement libs that remedy this.The text was updated successfully, but these errors were encountered: