This is the mail archive of the cygwin@sourceware.cygnus.com mailing list for the Cygwin project.
Index Nav: | [Date Index] [Subject Index] [Author Index] [Thread Index] | |
---|---|---|
Message Nav: | [Date Prev] [Date Next] | [Thread Prev] [Thread Next] |
I like your idea very much.
Sincerely,
Wei Ku
***************************************
Department of Physics and Astronomy
The University of Tennessee
1408 Circle Drive
Knoxville, Tennessee 37996-1200
weiku@utkux.utcc.utk.edu
---------------------------------------
Solid State Division
Oak Ridge National Laboratory
P.O.Box 2008
Oak Ridge, TN 37831-6032
Phone: (423) 574-5795
Fax: (423) 574-4143
weiku@solid.ssd.ornl.gov
***************************************
----
From: Michael Condict <condict@opengroup.org>
To: Sergey Okhapkin <sos@prospect.com.ru>
Cc: gnu-win32@cygnus.com; 'ap096@po.cwru.edu'; condict@opengroup.org
Date: Sunday, May 25, 1997 2:55 AM
Subject: Re: v18 vs v17 compile times....
In message <01BC669C.7C655BC0@gater.krystalbank.msk.ru">01BC669C.7C655BC0@gater.krystalbank.msk.ru>,
you write:
> > Somebody else already asked, but I did not see the answer to the
question, "Is
> > it (reasonably) easy to build without or turn off symbolic
links?"
>
> I've made some improvements in symlink checking and sent a patch to mr.
> Noer. My patch checks "system" file attribute symlinks must to
have. It
> doesn't affect non-cygwin programs any way - they knows nothing about
> symlinks.
Isn't the performance problem with symlinks inherent in the current
design? They are files without a suffix, therefore without an
identifiable Windows type. Therefore you have to look at the contents
of the file to see if it is a symlink. And checking the system
attribute is not a complete solution to the performance problem. It
just means that you don't have to check the contents of the file unless
it has the system attribute. But you still have to always perform an
extra operation to check the system attribute. And for the many non-
symlink files that have the system attribute, you still have to read
the file to see if it's a symlink.
I'd like to step back and point out that Windows 95 / NT 4 already *have*
symlinks. They are ".lnk" files for folders, data files and
Win32 programs,
and ".pif" files for 16-bit programs. They have all the power of
UNIX
symlinks in what information is stored in them, and more.
Now it's true that Windows makes very poor use of these symlinks,
allowing them to have meaning only if you double-click on them in an
Explorer window or feed them to the "Run" menu or the
"start" command.
You can't "cd" through them or print the contents of the file to
which
they point using the "type" command. But this is no reason that
Cygnus
Win32 can't endow them with the full power of UNIX symlinks. This
would
be a solution that does not require reading a symlink file.
It's also much better integrated with Windows. Wouldn't it be nice if
you could navigate through Cygnus Win32 symlinks using Explorer? When
you've made c:/bin be a symlink/shortcut to the Cygnus godawfully named
".../H-i386-cygwin32/bin" directory, wouldn't it be nice if you
could
type e.g. "/bin/bash" to the Start / Run window, and have it start
up
bash?
Here are some details of how such links could work:
1) Readdir, when returning the names of files in a directory,
should delete the suffix ".lnk" or ".pif", if
present.
2) In the open syscall, if an attempt to open a file fails with
a "not found" error, open should suffix ".lnk"
and try
again. If that fails, it should suffix ".pif" and
try
again. If either of these succeeds, open should then read
the shortcut file, find the path name of the target, and do a
Win32 open of the target file. This will slow down the
processing of sym links a bit (because a failed open has to
take place first), but allows non-symlink files to be
processed without any overhead added by the symlink code.
3) The other syscalls that take a pathname and are supposed to
follow symlinks (e.g. chdir, stat), should select the target
file or folder similarly to the algorithm used by open.
Comments?
Michael Condict m.condict@opengroup.org
The Open Group Research Inst. (617) 621-7349
11 Cambridge Center
Cambridge, MA 02142
-
For help on using this list (especially unsubscribing), send a message to
"gnu-win32-request@cygnus.com"
with one line of text: "help".
Index Nav: | [Date Index] [Subject Index] [Author Index] [Thread Index] | |
---|---|---|
Message Nav: | [Date Prev] [Date Next] | [Thread Prev] [Thread Next] |