delorie.com/archives/browse.cgi | search |
X-Recipient: | archive-cygwin AT delorie DOT com |
DomainKey-Signature: | a=rsa-sha1; c=nofws; d=sourceware.org; h=list-id |
:list-unsubscribe:list-subscribe:list-archive:list-post | |
:list-help:sender:message-id:date:from:mime-version:to:subject | |
:content-type:content-transfer-encoding; q=dns; s=default; b=wL+ | |
860Te+tUk5ZSVwIm1KG+53xzuvDJiUx6h1jrkSNkOuEha9V22rE/d4IGjyPILddV | |
JJcqIeqvHFWKm1fm15mmG/ue051FyZyCcBLuhnlDdlsKB8AjxoIEGjaR7ngH0uRn | |
L77N0CQrghz1lwjALvdCI40i4b2tgh1faZY3J1U0= | |
DKIM-Signature: | v=1; a=rsa-sha1; c=relaxed; d=sourceware.org; h=list-id |
:list-unsubscribe:list-subscribe:list-archive:list-post | |
:list-help:sender:message-id:date:from:mime-version:to:subject | |
:content-type:content-transfer-encoding; s=default; bh=6olfd1nGZ | |
+ozU7zuuLKKy+h8Ndw=; b=d/KQdipaug2L9U55C+Au5V5UiHyYYSWS3nhhJlZM+ | |
KJjLwzIIZ+tTVSnU7KSRJb/GWNJKs9Wy07CvYxP/KC3fQHW9NS+kJB0XhIkuRh83 | |
emoN7+TyTrcKJqGpgl4fL50lpbbpvGu1PitMkaeY4fQcLNSM2oto4Qe7TV8QTXBg | |
rg= | |
Mailing-List: | contact cygwin-help AT cygwin DOT com; run by ezmlm |
List-Id: | <cygwin.cygwin.com> |
List-Subscribe: | <mailto:cygwin-subscribe AT cygwin DOT com> |
List-Archive: | <http://sourceware.org/ml/cygwin/> |
List-Post: | <mailto:cygwin AT cygwin DOT com> |
List-Help: | <mailto:cygwin-help AT cygwin DOT com>, <http://sourceware.org/ml/#faqs> |
Sender: | cygwin-owner AT cygwin DOT com |
Mail-Followup-To: | cygwin AT cygwin DOT com |
Delivered-To: | mailing list cygwin AT cygwin DOT com |
Authentication-Results: | sourceware.org; auth=none |
X-Virus-Found: | No |
X-Spam-SWARE-Status: | No, score=1.3 required=5.0 tests=AWL,BAYES_00,BODY_8BITS,GARBLED_BODY,RP_MATCHES_RCVD,SPF_PASS autolearn=no version=3.3.2 |
X-HELO: | mx1.ptc.com |
Message-ID: | <542A219C.6070402@ptc.com> |
Date: | Mon, 29 Sep 2014 22:21:00 -0500 |
From: | Brian Ericson <bericson AT ptc DOT com> |
User-Agent: | Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Thunderbird/31.1.1 |
MIME-Version: | 1.0 |
To: | <cygwin AT cygwin DOT com> |
Subject: | Native symbolic links to non-existent targets (possible bug?) |
X-IsSubscribed: | yes |
Note-from-DJ: | This may be spam |
Cygwin appears to ignore "winsymlinks:native" when asked to create a symbolic link to a non-existent target, reverting to its "magic header" approach. This can be demonstrated via the following examples (using a Cygwin shell): echo hello > aaa ln -s aaa bbb notepad bbb ln -s xxx yyy notepad yyy "notepad bbb" will show "hello", but "notepad yyy" produces "㰡祳æ±æ¹© 㹫xxx ". "bbb" is a native symbolic link, "yyy" is not. (This can also be confirmed using "dir" (cmd.exe /c dir from within Cygwin) or looking for the curved arrow glyph in the folder explorer.) Note that this is in contrast to mklink (using a command prompt): echo hello > aaaa mklink bbbb aaaa notepad bbbb mklink yyyy xxxx notepad yyyy In this case, both mklink commands succeed; "notepad bbbb" works as expected, and "notepad yyyy" pops up an alert with "Cannot find the yyyy file. Do you want to create a new file?", which makes sense (it even writes to xxxx if you say "yes"). Also, mklink-created symbolic links to non-existent targets appear to work (just as they do on *nix) when the non-existent target is created: echo hello again > xxxx notepad yyyy The result is now "hello again". I initially stumbled upon this discrepancy in the following real-world example: git init foo cd foo touch .gitignore git add .gitignore git commit -m 'first commit' git checkout -b links mkdir -p a/b echo hello > a/file_in_a ln -s ../file_in_a a/b/link_to_file_in_a git add a git commit -m 'Added symbolic link' At this point, we have a valid, native symbolic link, which can be confirmed using notepad as before: notepad a/b/link_to_file_in_a We run into problems, however, when we do the following: git checkout master && git checkout links Git will create the symbolic link *before* it creates the target, and the result is a non-native file. "notepad a/b/link_to_file_in_a" now produces "㰡祳æ±æ¹©ã¹«ï»¿../file_in_a ". Shouldn't Cygwin honor "winsymlinks:native" even with the target does not exist? I'm using Cygwin 6.1. -- Problem reports: http://cygwin.com/problems.html FAQ: http://cygwin.com/faq/ Documentation: http://cygwin.com/docs.html Unsubscribe info: http://cygwin.com/ml/#unsubscribe-simple
webmaster | delorie software privacy |
Copyright © 2019 by DJ Delorie | Updated Jul 2019 |