Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm 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 From: ericblake AT comcast DOT net (Eric Blake) To: cygwin AT cygwin DOT com Subject: Re: mkdir -p and network drives Date: Tue, 03 May 2005 13:48:41 +0000 Message-Id: <050320051348.18015.427781390000B85B0000465F22069997350A050E040D0C079D0A@comcast.net> X-Authenticated-Sender: ZXJpY2JsYWtlQGNvbWNhc3QubmV0 > O(n^2)? I see only O(n), regardless where the algorithm begins the search. > In any path of length n, you have a constant sum of n stat and mkdir calls, > AFAICS. I was using n to mean the number of components separated by /, not the string length of the path (see the source code coreutils/lib/makepath.c where the optimization discusses this same issue). Yes, there are only O(n) syscalls, but each syscall has to check the existance of O(n) components, and the leftmost component's existance is checked n times, for a total of O(n^2) component checks. By starting at the left, and changing directories as you go, the leftmost component's existance is checked only once (at least, on systems where relative paths do not have to be converted to an absolute path first). I concede that you are probably right that the optimization attempted by coreutils performs no faster on cygwin, since cygwin has to convert relative to absolute and check the existance of the leftmost component every time (whether it is cygwin1.dll or Windows doing the check each time). > If coreutils is trying to be POSIX compliant, it has to allow and evalute > correctly two leading slashes: The coreutils maintainers are well aware of that fact. I think this case is just an oversight; I'm not sure if coreutils ever worked, since looking at http://savannah.gnu.org/cgi-bin/viewcvs/coreutils/coreutils/lib/makepath.c shows that it has blindly chdir()'d to / ever since version 1.27 in July 1997, before coreutils even existed. -- Eric Blake -- 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/