Re: GCC Behaves Differently for Different User?

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, 2011-12-06 at 13:56 -0800, Ian Lance Taylor wrote:
> John Graham <johngavingraham@xxxxxxxxxxxxxx> writes:
> 
> > However, I think I've found the cause of the problem, even if I have
> > no idea why it would cause this - when the new user runs "export", no
> > PATH shows up. If I run "echo $PATH" it shows up as I'd expect, and
> > when I do "export PATH" suddenly gcc can #include <stddef.h> just
> > fine. There must be some subtlety I'm not aware of... I don't suppose
> > you could shed any light on what's going on here?
> 
> No, you've got me there.  I have no idea what is going on.  I would be
> interested to hear if you figure out why PATH matters.

The gcc front-end has processing to look through $PATH to find itself.
If it comes up with the wrong pathname then you get VERY odd results.  I
don't know if this is the problem here or not, but it seems plausible if
you don't have PATH exported (the shell would find gcc and invoke it,
but gcc won't have PATH set).

In our environment we've been bit by this as well, in a slightly
different way because there's a bug in this algorithm: it doesn't ignore
_directories_ named "gcc" (or whatever) that are on your $PATH; it only
checks for the execute bit.  When the shell looks up <program> in $PATH
it ignores directories named <program>.

So for example if you "mkdir $HOME/bin/gcc" and you have $HOME/bin on
your PATH before /usr/bin (where gcc lives) then gcc gets very confused.
I haven't checked more recent versions of gcc to see if this behavior
persists though; maybe it's fixed.



[Index of Archives]     [Linux C Programming]     [Linux Kernel]     [eCos]     [Fedora Development]     [Fedora Announce]     [Autoconf]     [The DWARVES Debugging Tools]     [Yosemite Campsites]     [Yosemite News]     [Linux GCC]

  Powered by Linux