delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/1999/01/15/01:14:40

From: tangent AT cyberport DOT com (Warren Young)
Subject: Re: argc/argv
15 Jan 1999 01:14:40 -0800 :
Message-ID: <4.1.19990114113241.00a7d040.cygnus.gnu-win32@mail.cyberport.com>
References: <B0000013577 AT mail DOT tcc DOT com DOT cn>
Mime-Version: 1.0
To: gnu-win32 AT cygnus DOT com

At 05:24 PM 1/14/99 +0800, you wrote:
>Hi! Evidently gcc treats argc/argv quite differently from
>Turbo C when * appears in any argvs. It always tries to
>replace this argv with as many as possible matching files.

[snip]

>i know nothing about any standard or coding conventions
>about this, but could any of you tell me which is more
>standard or conventional?

Actually, it's not gcc setting up argv that way, but the C startup code
that ships with Cygwin's C library (libc).  This libc is trying to be
Unix-like in the absence of a Unix shell.  On a true Unix-like operating
system, the shell (sh, csh, bash, etc.) expands wildcards before running
the program.  But since you can't count on this under Win32, libc
apparently takes over this task.

It's curious, though, that when you run your test program under Cygwin's
bash like this:

	$ test "t*"

the t* isn't expanded.  This is normally the Right Thing, since double
quotes tells the shell not to expand wildcards, but the wildcarded argument
should be expanded by libc as it is when you run it from cmd.exe.  I
suspect that bash passes the quotes to the program literally, so that the C
startup routines will see them and not to expand the wildcard.

As for which behavior is "correct", the Cygwin behavior is correct if
you're trying to create a Unix-like environment, which they are.  Plus,
since wildcard conventions are substantially the same under Unix and DOS
(Unix is more or less a simple superset), it doesn't hurt compatibility to
do this.

Incidentally, you can make Turbo C-compiled programs expand their arguments
by linking in a special object file that comes with the compiler.  I can't
remember what it's called, but you can find info about it by searching the
techinfo archive at www.inprise.com.  Of course, it only expands the
DOS-standard * and ? wildcards (not the full regular expression suite
offered by Unix shells) but that's usually enough.  When it's not, run your
TC-compiled program under Cygwin's bash, which will do a full expansion for
you.

Good luck,

-
For help on using this list (especially unsubscribing), send a message to
"gnu-win32-request AT cygnus DOT com" with one line of text: "help".

- Raw text -


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