X-Recipient: archive-cygwin AT delorie DOT com X-Spam-Check-By: sourceware.org Date: Tue, 8 Jan 2008 15:19:17 +0100 From: Corinna Vinschen To: cygwin AT cygwin DOT com Subject: Re: Trouble with cygwin git Message-ID: <20080108141917.GA29568@calimero.vinschen.de> Reply-To: cygwin AT cygwin DOT com Mail-Followup-To: cygwin AT cygwin DOT com References: <376007 DOT 24556 DOT qm AT web45909 DOT mail DOT sp1 DOT yahoo DOT com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.16 (2007-06-09) Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm Precedence: bulk List-Id: List-Unsubscribe: List-Subscribe: List-Archive: List-Post: List-Help: , Sender: cygwin-owner AT cygwin DOT com Mail-Followup-To: cygwin AT cygwin DOT com Delivered-To: mailing list cygwin AT cygwin DOT com On Jan 2 19:35, MP wrote: > I dug into this, and found that the failure happens here: > > res = fh->link (newpath); > > in the link() function of file src/winsup/cygwin/syscalls.cc. res is -1, and > errno == EEXIST at this point. > > In the call above, newpath is: > /cygdrive/c/git/git/.git/objects/pack/pack- > d629a7029e3a941884c4bea2b33cc27e32f55779.pack > > Digging further, this line fails: > > if (CreateHardLinkA (newpc, pc, NULL)) > goto success; > > in function fhandler_disk_file::link(), fhandler_disk_file.cc. CreateHardLinkA > () returns 0, and GetLastError() returns 183 (ERROR_ALREADY_EXISTS: Cannot > create a file when that file already exists). > > In the CreateHardLinkA() call above, newpc.get_win32() yields: > c:\git\git\.git\objects\pack\pack-d629a7029e3a941884c4bea2b33cc27e32f55779.pack > > pc.get_win32() yields: > c:\git\git\.git\objects\tmp_pack_btsO9s > > I know that the destination file (newpc) does not exist; so I am perplexed why > CreateHardLinkA() is failing. In the CreateHardLink() documentation on MSDN, > I see this comment: > > "if you open a file that does not allow sharing, another application cannot > share the file by creating a new hard link to the file" > > However, I see that all calls to CreateFile() in XP Cygwin happen with: > > FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE > > Any ideas why CreateHardLinkA() could still be failing? Could you create a simple, self-contained testcase in plain C, which allows to reproduce the problem? Corinna -- Corinna Vinschen Please, send mails regarding Cygwin to Cygwin Project Co-Leader cygwin AT cygwin DOT com Red Hat -- Unsubscribe info: http://cygwin.com/ml/#unsubscribe-simple Problem reports: http://cygwin.com/problems.html Documentation: http://cygwin.com/docs.html FAQ: http://cygwin.com/faq/