While cloning a git repository from Linux to a Windows system, I am getting the following error in checkout the phase:
$ git clone gituser@serveraddr:
Try:
git config --system core.longpaths true
This will allow it to checkout the files even with longer filepaths. The issue with this would be when you try to delete it, as Windows will not allow to delete a path longer than it's allowed threshold. The workaround to that is to rename the folders in the local repository, so that the overall length of the path is lessened. For example, a path that is alpha/beta/gamma/universe.txt, can be limited to 1/2/3/universe.txt, so that it's length is under the windows filesize threshold.
Use Windows PowerShell. Worked for me.
Many Windows APIs are limited to 260 symbols for file path name. So git can't create files with names longer than 260 symbols. NTFS file system actually supports longer names (32k) but there is no easy way to allow long names for programs.
Workaround 1: move your project to a new location, closer to disk root. Advantage:
Disadvantage:
Workaround 2: create a Junction to your project folder from a folder that is closer to disk root and do git clone from the junction folder. You can do this with mklink
command or Link Shell Extension.
Advantage:
Disadvantage:
The only suggestion I saw, considering a similar issue, was:
Workaround: use http://www.cygwin.com/
Or at least check if a checkout in a git-bash session of msysgit works better.
Update May 2015 (2 years later):
Note: the latest 2.4.1 git-for-windows proposes:
core.longpaths::
Enable long path (> 260) support for builtin commands in Git for Windows.
This is disabled by default, as long paths are not supported by Windows Explorer, cmd.exe and the Git for Windows tool chain (msys, bash, tcl, perl...).
Only enable this if you know what you're doing and are prepared to live with a few quirks.
I experienced similar problems when checking out a project into a Windows directory that had a 67- (Windows) or 76- (cygwin) character base path - when added to the path-length of the checked out files, it exceeded Windows' path-length limit:
git checkout -f HEAD
error: unable to create file <194-character filepath> (No such file or directory)
fatal: cannot create directory at '<187-character directory path>': No such file
or directory
I solved the problem by checking out the git repository to c:\git, which, at 6 or 15 characters in length, kept the maximum path-length under the Windows limit.