delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2005/08/10/15:40:42

Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm
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
Date: Wed, 10 Aug 2005 15:40:24 -0400
From: Christopher Faylor <cgf-no-personal-reply-please AT cygwin DOT com>
To: cygwin AT cygwin DOT com
Subject: Re: Programatically finding value of "cygdrive" prefix
Message-ID: <20050810194024.GC6294@trixie.casa.cgf.cx>
Reply-To: cygwin AT cygwin DOT com
References: <42FA4604 DOT 8000507 AT tlinx DOT org> <20050810183616 DOT GA5892 AT trixie DOT casa DOT cgf DOT cx> <20050810184119 DOT GA6155 AT trixie DOT casa DOT cgf DOT cx> <42FA4EC2 DOT 3000504 AT alltel DOT net>
Mime-Version: 1.0
In-Reply-To: <42FA4EC2.3000504@alltel.net>
User-Agent: Mutt/1.5.8i

On Wed, Aug 10, 2005 at 02:00:18PM -0500, Ken Dibble wrote:
>Christopher Faylor wrote:
>
>>On Wed, Aug 10, 2005 at 02:36:16PM -0400, Christopher Faylor wrote:
>> 
>>
>>>On Wed, Aug 10, 2005 at 11:23:00AM -0700, Linda W wrote:
>>>   
>>>
>>>>Is there a way to find out in a bash script the cygdrive prefix?
>>>>I thought something simple like
>>>> mount -p|tail -1|cut -f1
>>>>but that incorrectly assumed the fields were tab delimited.
>>>>Since there can be spaces in the cygdrive prefix, I can't
>>>>use space a delimiter, example:
>>>># mount -p
>>>>Prefix              Type         Flags
>>>>/cyg drive posix path  system       binmode
>>>>----
>>>>     
>>>>
>>>There may be a simpler way to do it, but this seems to work:
>>>
>>>mount -p | sed -n '2s/\([^ ]\)  *[^ ][^ ]*  *[^ ][^ ]*$/\1/p'
>>>   
>>>
>>
>>This is shorter:
>>
>>mount -p | sed -nr '2s/([^ ]) +\S+ +\S+$/\1/p'
>>
>Or you can do it the long, slow wasteful way, which us dullards are required
>to use, so we can figure out why it broke yet again.
>
>#!/bin/bash
>let c=0;
># get the number of fields
>for i in `mount -p | tail -1`; do let c=$c+1; done
>
># if number of fields is greater than 3 because mount point has a space, 
>add them
>CUT_FIELDS="--fields=1"
>let i=3;
>while [ $i -lt $c ]
>do
>CUT_FIELDS=$CUT_FIELDS,$i
>let i=$i+1
>done
>
># get the fields
>mount -p | tail -1 | /usr/bin/cut --delimiter=" " $CUT_FIELDS

Personally, if something breaks, I'd rather look at one line than
eighteen.  I can't imagine why anyone would find the above an acceptable
solution when it's possible to do it all with one line.  And, the above
doesn't handle imbedded spaces.

Btw, a further simplification:

mount -p | sed -nr '2s/(\S) +\S+ +\S+$/\1/p'

cgf

--
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/

- Raw text -


  webmaster     delorie software   privacy  
  Copyright © 2019   by DJ Delorie     Updated Jul 2019