Mailing-List: contact cygwin-help AT sourceware DOT cygnus DOT com; run by ezmlm List-Subscribe: List-Archive: List-Post: List-Help: , Sender: cygwin-owner AT sources DOT redhat DOT com Delivered-To: mailing list cygwin AT sources DOT redhat DOT com Message-Id: <4.3.1.2.20010124140328.02259dd0@pop.ma.ultranet.com> X-Sender: lhall AT pop DOT ma DOT ultranet DOT com X-Mailer: QUALCOMM Windows Eudora Version 4.3.1 Date: Wed, 24 Jan 2001 14:12:54 -0500 To: cygwin AT sources DOT redhat DOT com From: "Larry Hall (RFK Partners, Inc)" Subject: Re: 1.1.7:mount and ls problem Cc: ehud AT unix DOT simonwiesel DOT co DOT il, lowella AT serv DOT net, cygwin AT sources DOT redhat DOT com In-Reply-To: <3A6F2317.686CD2BD@yahoo.com> References: <4 DOT 3 DOT 1 DOT 2 DOT 20010124100612 DOT 021e0c10 AT pop DOT ma DOT ultranet DOT com> <4 DOT 3 DOT 1 DOT 2 DOT 20010123202852 DOT 022d7ce8 AT pop DOT ma DOT ultranet DOT com> <4 DOT 3 DOT 1 DOT 2 DOT 20010124100612 DOT 021e0c10 AT pop DOT ma DOT ultranet DOT com> <4 DOT 3 DOT 1 DOT 2 DOT 20010124121519 DOT 0228be88 AT pop DOT ma DOT ultranet DOT com> Mime-Version: 1.0 Content-Type: text/plain; charset="us-ascii" At 01:46 PM 1/24/2001, Earnie Boyd wrote: >"Larry Hall (RFK Partners, Inc)" wrote: > > > > At 11:56 AM 1/24/2001, Ehud Karni wrote: > > > > cd / > > > > mkdir e > > > > mount e: /e > > > > All is well -- e shows up in both an ls ( as e) and mount (as e: /e). > > > > > > > > mount f: /f > > > > I get the error: > > > > mount: warning - /f does not exist > > > > but mount shows > > > > f: f/ . . . > > > > and ls doesn't show f. > > > > > > > > If I do mkdir f, I get: > > > > mkdir: cannot make directory `f': File exists > > > > > >On UNIX systems, you can NOT mount on non-existing directory. > > > > > >I think Cygwin can adopt this behavior and refuse to mount when the > > >directory is missing. There are 2 ways to accomplish this: > > > 1. Create the directory (silently or with a message). > > > 2. Produce an error and do not mount. > > >The 2nd approach has the possible problem for mounts that was done > > >previously (saved in the registry) - the mount directory may be erased > > >by a non Cygwin program. In that case I will produce an error message > > >every time the DLL try to use this mount, and ignore it (but not > > >delete it from the registry). > > > > This may be an issue. The simple approach for handling this here would > > be do 1, although one could always see what UNIX/Linux does in these cases > > too. As I recall, UNIX/Linux simply displays an error if the directory to > > mount to is removed. I see no real problem with supporting this approach > > either. > > > >There is no way that I know of to prevent the user from removing the >directory even if mounted. The user could still use the Windows File >Explorer or a cmd/command window to remove the directory. To make it >more difficult I suppose that the mount point directory could be marked >with the system attribute when mounted and remove the system attribute >when unmounted. However, this still wouldn't prevent it's removal. >What I would suggest for this is that if the physical mount point >directory is removed Cygwin recognizes this and removes the mount entry. My point was the reverse. On UNIX/Linux, its possible to unmount a directory, delete the directory, and then attempt to remount it. It will error. Still, your point is a good one. There is an asymmetry on Windows since there is nothing that prevents the user from removing any mounted directory by other means (this you cannot do on UNIX/Linux). There may be a way to lock the directory to prevent this or do as you suggest (or some other scheme) but I certainly accept that the UNIX/Linux mount symantics in this respect don't come for free in Windows/Cygwin environments. Addressing this whole issue is a nice little project.:-) >What ever the solution is, the incorrect solution is to create the >supposed physical directory. Recently, I've been creating a /cygmnt >directory at the root of each of my drive letters. I then create mount >points under the /cygmnt. So if I want to have a mount point foo on >drive D: then I would mkdir D:/cygmnt/foo > mount -b D:/cygmnt/foo /foo >The reason I do this is for ease of recognition of what I have mounted >on what devices. Right. Automatic creation of the directory, IMO, is worse than the current behavior. I don't really like the idea although someone may be able to convince me of at least a specific case where it makes sense. > > > > >I don't know the reasons of the Cygwin developers for choosing the > > >current behavior but I'm sure they had something in mind if they > > >decided to deviate from standard UNIX practice. > > > > Yes, I'm sure there was a reason. It may have just been for "expediency". > > In any case, its not worth speculating unless someone plans to take up the > > task. > > > >IIRC, the decision for the warning was because it didn't use to warn or >error and it was desired not to make it any more difficult. I don't >remember if Geoff Noer had intentioned it remaining a warning. This >goes back to 1998 if anyone cares to search the archives. I doubt it!;-) Larry Hall lhall AT rfk DOT com RFK Partners, Inc. http://www.rfk.com 118 Washington Street (508) 893-9779 - RFK Office Holliston, MA 01746 (508) 893-9889 - FAX -- Want to unsubscribe from this list? Check out: http://cygwin.com/ml/#unsubscribe-simple