> and it's a bug that bash-4 is filtering them. Maybe, maybe not. That's open to interpretation. Here's how I see it.
> not allowing them to be used in > the shell is fine (echo ${vmlinux.lds}), but removing them from the > environment and thus not allowing other applications to leverage them is not. The shell is not like other applications that simply pass the environment through as uninterpreted strings. It applies semantic interpretation to the environment variables it inherits. Shells scan the initial environment exactly once: at startup, when creating variables. The environment passed to child processes is created from the set of exported shell variables. This implies to me that the environment passed to child processes consists only of valid shell variables. Certainly conforming applications should not create environment variables with invalid names. > POSIX explicitly states that applications shall tolerate the presence of > these > environment variables, and while that is open for interpretation (i.e. you've > interpreted this to mean automatic removal), i dont see any reason for bash > to > be culling these. Posix also says that "variables" are inherited from the environment. That word has a very specific meaning, as was reiterated during the $@ and set -u discussion. The same "variables" language is used when Posix talks about creating the environment for shell execution environments. The question is whether "tolerant" just means that the shell doesn't display a warning message about the assignment, as it does when you use an invalid variable name in an assignment statement, or exit with a variable assignment error, or dump core with a seg fault, as in many historical versions of sh. It may or may not also mean that the shell passes inherited invalid variable names to child processes. Historical versions of sh and ksh behave like bash-4.0. It seems, though, that there might be enough use for me to try and make it work. While I'm not wild about creating yet another class of variable, there might be a way to do it simply. Chet -- ``The lyf so short, the craft so long to lerne.'' - Chaucer Chet Ramey, ITS, CWRU c...@case.edu http://tiswww.tis.case.edu/~chet/