tags:

views:

326

answers:

6

This code does not compile for me on gcc version 4.3.2 (Debian 4.3.2-1.1)

main(){
  int unix;
}

I've checked the C keywords list and "unix" is not one of them. Why am I getting the following error?

unix.c:2: error: expected identifier or ‘(’ before numeric constant

Anybody?

+2  A: 

I'm gona take a wild stab at this and guess that gcc effectively #defined unix as 1 on UNIX systems.

try

main(){ 
  printf("%d", unix); 
} 

and see what you get.

James Curran
Ha! You're right: http://codepad.org/ML9VEsOa Stupid gcc.
Steve M
@Steve: see pmg's answer to see why `gcc` in non-standard mode tends to define this macro.
Jens Gustedt
+2  A: 

To answer your question, no unix is not a reserved word in C.

However, the symbol unix is most likely defined by the preprocessor either because you include a header file or because the compiler defines it.

Martin Liversage
It's gcc that does it.
Steve M
It should be noted that it's **broken** and nonconformant behavior for gcc to do this.
R..
+9  A: 

Run your code through the preprocessor to find out what the compiler is actually seeing:

gcc -E unix.c

Then see if your variable unix is preserved or converted by the preprocessor.

lacqui
+14  A: 

unix is not a identifier reserved by the Standard.

If you compile with -std=c89 or -std=c99 the gcc compiler will accept the program as you expected.

From gcc manual ( http://gcc.gnu.org/onlinedocs/cpp/System_002dspecific-Predefined-Macros.html ), the emphasis is mine.

... However, historically system-specific macros have had names with no special prefix; for instance, it is common to find unix defined on Unix systems. For all such macros, GCC provides a parallel macro with two underscores added at the beginning and the end. If unix is defined, __unix__ will be defined too. There will never be more than two underscores; the parallel of _mips is __mips__.

pmg
+8  A: 

unix is one of the defines the preprocessor uses in gcc to get a list of defs use

gcc -dM -E  -x c /dev/null

(-dM tells gcc to debugdump the defs -E tells it to stop after prepreocessing and -x c /dev/null tells him to pretend /dev/null is a c file)

Nikolaus Gradwohl
+2  A: 

It is not a keyword.

It is a predefined macro to identify the type of system. On Unix and Unix like systems it is defined to be 1.

To disable this use the -ansi option:

In C mode, this is equivalent to -std=c89. In C++ mode, it is equivalent to -std=c++98. This turns off certain features of GCC that are incompatible with ISO C90 (when compiling C code), or of standard C++ (when compiling C++ code), such as the "asm" and "typeof" keywords, and predefined macros such as "unix" and "vax" that identify the type of system you are using. It also enables the undesirable and rarely used ISO trigraph feature. For the C compiler, it disables recognition of C++ style // comments as well as the "inline" keyword.

codaddict