Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Why am i getting this warning in "if (fd=fopen(fileName,"r") == NULL)"?

FILE *fd;
if (fd=fopen(fileName,"r") == NULL)
{   
    printf("File failed to open");
    exit(1);
}

This is a code snippet. When I compile it with gcc, i get the following warning:-

warning: assignment makes pointer from integer without a cast

When I put fd=fopen(argv[2],"r") within brackets, the problem gets solved..

I am not able to understand where am i converting integer to pointer when the brackets are not put.

like image 487
Abhijeet Rastogi Avatar asked Jan 22 '10 14:01

Abhijeet Rastogi


3 Answers

Due to operator precedence rules the condition is interpreted as fd=(fopen(fileName,"r") == NULL). The result of == is integer, fd is a pointer, thus the error message.

Consider the "extended" version of your code:

FILE *fd;
int ok;
fd = fopen(fileName, "r");
ok = fd == NULL;
// ...

Would you expect the last line to be interpreted as (ok = fd) == NULL, or ok = (fd == NULL)?

like image 186
David Schmitt Avatar answered Nov 15 '22 04:11

David Schmitt


The precedence of the equality operator is higher than the assignment operator. Just change your code to:

FILE *fd;
if ((fd=fopen(fileName,"r")) == NULL)
{   
    printf("File failed to open");
    exit(1);
}
like image 42
Khaled Alshaya Avatar answered Nov 15 '22 06:11

Khaled Alshaya


== has higher precedence than =, so it compares the result of fopen() to NULL, then assigns that to fd.

like image 20
Ignacio Vazquez-Abrams Avatar answered Nov 15 '22 06:11

Ignacio Vazquez-Abrams