Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

warning: assignment discards qualifiers from pointer target type

Tags:

c

I wrote the following code:

void buildArrays(char *pLastLetter[],int length[], int size, const char str[]) {      int i;     int strIndex = 0;     int letterCounter = 0;      for (i=0; i<size; i++) {          while ( (str[strIndex] != SEPERATOR) || (str[strIndex] != '\0') ) {             letterCounter++;             strIndex++;         }         pLastLetter[i] = &str[strIndex-1];         length[i] = letterCounter;         letterCounter = 0;         strIndex++;     } } 

and I'm getting the above warning on pLastLetter[i] = &str[strIndex-1];

pLastLetter is a pointers array that points to a char in str[].

Anyone knows why I'm getting it and how to fix it?

like image 478
Asher Saban Avatar asked Aug 13 '10 18:08

Asher Saban


1 Answers

Well, as you said yourself, pLastLetter is an array of char * pointers, while str is an array of const char. The &str[strIndex-1] expression has type const char*. You are not allowed to assign a const char* value to a char * pointer. That would violate the rules of const-correctness. In fact, what you are doing is an error in C. C compilers traditionally report it as a mere "warning" to avoid breaking some old legacy code.

As for "how to fix it"... It depends on what you are trying to do. Either make pLastLetter an array of const char* or remove the const from str.

like image 61
AnT Avatar answered Sep 23 '22 15:09

AnT