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:from:to:subject:date:message-id:references | |
:in-reply-to:content-type:content-transfer-encoding | |
:mime-version; q=dns; s=default; b=vLC/pMwZqf7T7Skp50I4Jis12dU/r | |
iIAPKWe9pFpxOp789Vhjomr9cGnkKcI+hBeC8YlNUycgvFgB9x4140alC1J0Gp5Q | |
8XffssgUGVbKJxZda5Wc8evsa2lqumKHkqKhXuJDXNp1wfeCFWeFqdps2pU7Ijyu | |
Fv/5prxP7lBkgc= | |
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:from:to:subject:date:message-id:references | |
:in-reply-to:content-type:content-transfer-encoding | |
:mime-version; s=default; bh=YmkMSTY3XHt7CHnym4scZEAiZlE=; b=F/v | |
XaO0kKa5TzI/DVtjuJw+ywj3NtClfATbUDHuJLGXLN/ST8IZPqhBxiampfkO0Ilt | |
uNyDCiMNXR8v5S3oudHkVORnv6s3VdMSwhdgIdIPaKpfF870mHnU5QYhuUiW7n9b | |
W5Zii0dW8wQoymvz3suO2ZJAewF7JZxAENFP0bTg= | |
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=-0.1 required=5.0 tests=AWL,BAYES_05,MIME_BASE64_BLANKS,RCVD_IN_DNSWL_LOW,SPF_HELO_PASS,SPF_PASS autolearn=ham version=3.3.2 spammy=hzazic2, HZA-ZIC2, hza-zic2, HZAZIC2 |
X-HELO: | cluster-j.mailcontrol.com |
From: | "Lemke, Michael ST/HZA-ZIC2" <lemkemch AT schaeffler DOT com> |
To: | "wbparsons AT cshore DOT com" <wbparsons AT cshore DOT com>, |
"cygwin AT cygwin DOT com" <cygwin AT cygwin DOT com> | |
Subject: | RE: [SOLVED] Re: tcsh path conversion messed up? |
Date: | Wed, 8 Nov 2017 11:54:08 +0000 |
Message-ID: | <7523194fd3504a6a8345dd4268ee998e@DE013666.schaeffler.com> |
References: | <oto9is$k56$1 AT blaine DOT gmane DOT org> <otqlbj$91n$1 AT blaine DOT gmane DOT org> <otqlvg$bcf$1 AT blaine DOT gmane DOT org> <d9ac360f-c14d-5bd9-b2f5-54dceefd4449 AT SystematicSw DOT ab DOT ca> <8ef62c62e13846dd80c1ba65397b8a67 AT DE013666 DOT schaeffler DOT com> <ottaro$v2$1 AT blaine DOT gmane DOT org> |
In-Reply-To: | <ottaro$v2$1@blaine.gmane.org> |
x-ms-exchange-transport-fromentityheader: | Hosted |
MIME-Version: | 1.0 |
X-IsSubscribed: | yes |
X-MIME-Autoconverted: | from base64 to 8bit by delorie.com id vA8BsVtM013351 |
On November 07, 2017 11:08 PM Will Parsons wrote: >Lemke, Michael ST/HZA-ZIC2 wrote: >> On Tuesday, November 07, 2017 7:12 AM Brian Inglis wrote: >>>On 2017-11-06 14:59, Will Parsons wrote: >>>> Will Parsons wrote: >>>>> I asked about what I thought was a shell scripting problem: >>>>> PATH=/usr/local/bin:/usr/bin:/bin:/usr/sbin:/c/Windows/system32:/c/Windows:/c/Windows/system32/wbem:/c/ProgramData/Oracle/Java/javapath:/c/Program:Files/Common:Files/Microsoft:Shared/Windows:Live:/c/Program:Files:(x86)/Common:Files/Microsoft:Shared/Windows:Live:/c/Program:Files/Dell/DW:WLAN:Card:/c/Program:Files:(x86)/Intel/iCLS:Client:/c/Program:Files/Intel/iCLS:Client:/c/Windows/System32/WindowsPowerShell/v1.0:/c/Program:Files/WIDCOMM/Bluetooth:Software:/c/Program:Files/WIDCOMM/Bluetooth:Software/syswow64:/c/Program:Files:(x86)/Windows:Live/Shared:/c/Program:Files:(x86)/Bazaar:/c/Program:Files:(x86)/QuickTime/QTSystem:/c/cygwin/home/william/bin:/c/ezwinports/bin:/c/Program:Files:(x86)/PuTTY:/usr/lib/lapack >>>>> >>>>> This doesn't look right, and would explain the strange shell output I >>>>> reported. (The value of PATH under bash looks normal.) Did the installation >>>>> of tcsh somehow get corrupted? I don't remember a particularly recent update >>>>> to tcsh. >> >> How are you setting path? Do you have anything in your .cshrc/.login file? Most >> likely, you are doing it wrong. >> >>>> Another bit of info - I just noticed that the value of the (t)csh shell >>>> variable 'path' is: >>> >>>In csh, "PATH" is a standard Unix environment variable whose value is a colon >>>separated directory list, and "path" is a shell wordlist kept synchonized with >>>"PATH". >>>To list the wordlist entries with embedded spaces in csh, quote the variable >>>name with the :q modifier in a foreach loop wordlist, and you get the desired >>>result as easily as in your sh script [trimmed and ...s redacted]: >>> >>>.......% foreach p ( $path:q ) >>>foreach? echo $p >>>foreach? end >> >> And that is also key for setting path: >> >> set path = ( ... $path:q ) >> >> I had this bug ($path instead of $path:q) for 20 years in my init files. > >Bingo! I had this line in my ~/.cshrc: > > set path = ( /usr/local/bin /usr/bin /bin /usr/sbin $path ) > >Changing $path to $path.q solved the problem. For the record, it is $path:q not $path.q > >(I am still somewhat puzzled, though - the original PATH that I quoted in my >original query did have spaces, so what changed?) Nothing. csh treats PATH differently. I am not sure about all the details and how/if PATH and path are synchronized but in csh you define the path with "path", which is an array. "PATH" is only a string that gets parsed into individual elements by using : as the separator. Not so "path". You set its elements as set path = ( path1 path2 ... ) where the space is the separator. So how to add an element with a space? You add quotes: set path = ( "/cygdrive/c/program files" /usr/bin ) But that won't work in a simple replacement. In set path = ( /usr/local/bin $path ) $path expands into the space separated words producing what you saw. Think of it like you typed it yourself (note that path does not contain any quotes). So you'd think to do this: set path = ( /usr/local/bin "$path" ) Won't work either. It creates 2 entries with the last one being everything in path as a single entry. So you need to quote it differently or write a loop. Use the :q modifier to make $path expand as array elements. This is what :q is for. In Unix you most likely don't notice the difference as Unix directories usually have no spaces. But it is exactly the same. > >At any rate, the problem seems to be solved, so thank you very much. You might even find that more windows commands are now available (e.g. java), which got installed into Program Files and added to PATH. -- 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 |