delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2006/04/23/07:13:16

X-Spam-Check-By: sourceware.org
From: "Dave Korn" <dave DOT korn AT artimi DOT com>
To: <cygwin AT cygwin DOT com>
Subject: RE: regarding a problem that you know how to fix
Date: Sun, 23 Apr 2006 12:12:58 +0100
Message-ID: <036601c666c6$e0ca7440$a501a8c0@CAM.ARTIMI.COM>
MIME-Version: 1.0
X-Mailer: Microsoft Office Outlook 11
In-Reply-To: <02f201c6661f$d88aeb40$a501a8c0@CAM.ARTIMI.COM>
Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm
List-Unsubscribe: <mailto:cygwin-unsubscribe-archive-cygwin=delorie DOT com AT cygwin DOT 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

On 22 April 2006 16:17, Dave Korn wrote:

> On 22 April 2006 15:40, Robert J. Cristel wrote:

>> mingw-install-20060210
>> is experiencing a problem
>> "tar: ssl/man/man1/md2.1.lnk: Cannot
>> utime: Permission denied"
>> with win98 that you solved a while back
>> http://www.cygwin.com/ml/cygwin/2002-05/msg00901.html
>> 
>> We would like to apply the same medicine
>> that you found.  What would you suggest?

  I need to clarify the exact problem here, I could have been more accurate
first time round.  Sorry.

>   Ah, it seems mingw doesn't provide it's own utime implementation but
> relies on the one in msvcrt, which is documented to return:-
> 
> " EACCES
> Path specifies directory or read-only file "
> 
> which is a problem; tar expects utime to behave in a POSIX compliant way,
> and to be able to set the timestamp if the relevant unix perms exist.

  Sorry, I was too vague here.  In fact, the condition is 

http://www.opengroup.org/onlinepubs/009695399/functions/utime.html

" The effective user ID of the process shall match the owner of the file, or
the process has write permission to the file or has appropriate privileges, to
use utime() in this manner. "

  So, saying "the relevant unix perms" was wrong, because the "relevant" unix
perm is write permission, and this is a read-only file in all cases.  The
/actual/ difference between POSIX utime and MSVCRT utime is that first
condition: if you own a file, you can utime it, regardless of the write perms,
and that's the extra condition that MSVCRT doesn't implement but would need
to.

>   I
> don't use mingw so I'm not sure, but wouldn't running tar under MSYS
> provide it with the sort of POSIX-alike environment it needs?  Otherwise
> perhaps it's possible to re-implement utime as a wrapper in the mingw
> runtime library? 

  Or as another option, you could patch the mingw version of tar to
temporarily chmod+w the file when it needs to utime it, then restore the
original perms.


    cheers,
      DaveK
-- 
Can't think of a witty .sigline today....


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