|
|
1.1 ! root 1: This is Info file gcc.info, produced by Makeinfo-1.54 from the input ! 2: file gcc.texi. ! 3: ! 4: This file documents the use and the internals of the GNU compiler. ! 5: ! 6: Published by the Free Software Foundation 675 Massachusetts Avenue ! 7: Cambridge, MA 02139 USA ! 8: ! 9: Copyright (C) 1988, 1989, 1992, 1993 Free Software Foundation, Inc. ! 10: ! 11: Permission is granted to make and distribute verbatim copies of this ! 12: manual provided the copyright notice and this permission notice are ! 13: preserved on all copies. ! 14: ! 15: Permission is granted to copy and distribute modified versions of ! 16: this manual under the conditions for verbatim copying, provided also ! 17: that the sections entitled "GNU General Public License" and "Protect ! 18: Your Freedom--Fight `Look And Feel'" are included exactly as in the ! 19: original, and provided that the entire resulting derived work is ! 20: distributed under the terms of a permission notice identical to this ! 21: one. ! 22: ! 23: Permission is granted to copy and distribute translations of this ! 24: manual into another language, under the above conditions for modified ! 25: versions, except that the sections entitled "GNU General Public ! 26: License" and "Protect Your Freedom--Fight `Look And Feel'", and this ! 27: permission notice, may be included in translations approved by the Free ! 28: Software Foundation instead of in the original English. ! 29: ! 30: ! 31: File: gcc.info, Node: Incompatibilities, Next: Fixed Headers, Prev: External Bugs, Up: Trouble ! 32: ! 33: Incompatibilities of GNU CC ! 34: =========================== ! 35: ! 36: There are several noteworthy incompatibilities between GNU C and most ! 37: existing (non-ANSI) versions of C. The `-traditional' option ! 38: eliminates many of these incompatibilities, *but not all*, by telling ! 39: GNU C to behave like the other C compilers. ! 40: ! 41: * GNU CC normally makes string constants read-only. If several ! 42: identical-looking string constants are used, GNU CC stores only one ! 43: copy of the string. ! 44: ! 45: One consequence is that you cannot call `mktemp' with a string ! 46: constant argument. The function `mktemp' always alters the string ! 47: its argument points to. ! 48: ! 49: Another consequence is that `sscanf' does not work on some systems ! 50: when passed a string constant as its format control string or ! 51: input. This is because `sscanf' incorrectly tries to write into ! 52: the string constant. Likewise `fscanf' and `scanf'. ! 53: ! 54: The best solution to these problems is to change the program to use ! 55: `char'-array variables with initialization strings for these ! 56: purposes instead of string constants. But if this is not possible, ! 57: you can use the `-fwritable-strings' flag, which directs GNU CC to ! 58: handle string constants the same way most C compilers do. ! 59: `-traditional' also has this effect, among others. ! 60: ! 61: * `-2147483648' is positive. ! 62: ! 63: This is because 2147483648 cannot fit in the type `int', so ! 64: (following the ANSI C rules) its data type is `unsigned long int'. ! 65: Negating this value yields 2147483648 again. ! 66: ! 67: * GNU CC does not substitute macro arguments when they appear inside ! 68: of string constants. For example, the following macro in GNU CC ! 69: ! 70: #define foo(a) "a" ! 71: ! 72: will produce output `"a"' regardless of what the argument A is. ! 73: ! 74: The `-traditional' option directs GNU CC to handle such cases ! 75: (among others) in the old-fashioned (non-ANSI) fashion. ! 76: ! 77: * When you use `setjmp' and `longjmp', the only automatic variables ! 78: guaranteed to remain valid are those declared `volatile'. This is ! 79: a consequence of automatic register allocation. Consider this ! 80: function: ! 81: ! 82: jmp_buf j; ! 83: ! 84: foo () ! 85: { ! 86: int a, b; ! 87: ! 88: a = fun1 (); ! 89: if (setjmp (j)) ! 90: return a; ! 91: ! 92: a = fun2 (); ! 93: /* `longjmp (j)' may occur in `fun3'. */ ! 94: return a + fun3 (); ! 95: } ! 96: ! 97: Here `a' may or may not be restored to its first value when the ! 98: `longjmp' occurs. If `a' is allocated in a register, then its ! 99: first value is restored; otherwise, it keeps the last value stored ! 100: in it. ! 101: ! 102: If you use the `-W' option with the `-O' option, you will get a ! 103: warning when GNU CC thinks such a problem might be possible. ! 104: ! 105: The `-traditional' option directs GNU C to put variables in the ! 106: stack by default, rather than in registers, in functions that call ! 107: `setjmp'. This results in the behavior found in traditional C ! 108: compilers. ! 109: ! 110: * Programs that use preprocessor directives in the middle of macro ! 111: arguments do not work with GNU CC. For example, a program like ! 112: this will not work: ! 113: ! 114: foobar ( ! 115: #define luser ! 116: hack) ! 117: ! 118: ANSI C does not permit such a construct. It would make sense to ! 119: support it when `-traditional' is used, but it is too much work to ! 120: implement. ! 121: ! 122: * Declarations of external variables and functions within a block ! 123: apply only to the block containing the declaration. In other ! 124: words, they have the same scope as any other declaration in the ! 125: same place. ! 126: ! 127: In some other C compilers, a `extern' declaration affects all the ! 128: rest of the file even if it happens within a block. ! 129: ! 130: The `-traditional' option directs GNU C to treat all `extern' ! 131: declarations as global, like traditional compilers. ! 132: ! 133: * In traditional C, you can combine `long', etc., with a typedef ! 134: name, as shown here: ! 135: ! 136: typedef int foo; ! 137: typedef long foo bar; ! 138: ! 139: In ANSI C, this is not allowed: `long' and other type modifiers ! 140: require an explicit `int'. Because this criterion is expressed by ! 141: Bison grammar rules rather than C code, the `-traditional' flag ! 142: cannot alter it. ! 143: ! 144: * PCC allows typedef names to be used as function parameters. The ! 145: difficulty described immediately above applies here too. ! 146: ! 147: * PCC allows whitespace in the middle of compound assignment ! 148: operators such as `+='. GNU CC, following the ANSI standard, does ! 149: not allow this. The difficulty described immediately above ! 150: applies here too. ! 151: ! 152: * GNU CC complains about unterminated character constants inside of ! 153: preprocessor conditionals that fail. Some programs have English ! 154: comments enclosed in conditionals that are guaranteed to fail; if ! 155: these comments contain apostrophes, GNU CC will probably report an ! 156: error. For example, this code would produce an error: ! 157: ! 158: #if 0 ! 159: You can't expect this to work. ! 160: #endif ! 161: ! 162: The best solution to such a problem is to put the text into an ! 163: actual C comment delimited by `/*...*/'. However, `-traditional' ! 164: suppresses these error messages. ! 165: ! 166: * Many user programs contain the declaration `long time ();'. In the ! 167: past, the system header files on many systems did not actually ! 168: declare `time', so it did not matter what type your program ! 169: declared it to return. But in systems with ANSI C headers, `time' ! 170: is declared to return `time_t', and if that is not the same as ! 171: `long', then `long time ();' is erroneous. ! 172: ! 173: The solution is to change your program to use `time_t' as the ! 174: return type of `time'. ! 175: ! 176: * When compiling functions that return `float', PCC converts it to a ! 177: double. GNU CC actually returns a `float'. If you are concerned ! 178: with PCC compatibility, you should declare your functions to return ! 179: `double'; you might as well say what you mean. ! 180: ! 181: * When compiling functions that return structures or unions, GNU CC ! 182: output code normally uses a method different from that used on most ! 183: versions of Unix. As a result, code compiled with GNU CC cannot ! 184: call a structure-returning function compiled with PCC, and vice ! 185: versa. ! 186: ! 187: The method used by GNU CC is as follows: a structure or union ! 188: which is 1, 2, 4 or 8 bytes long is returned like a scalar. A ! 189: structure or union with any other size is stored into an address ! 190: supplied by the caller (usually in a special, fixed register, but ! 191: on some machines it is passed on the stack). The ! 192: machine-description macros `STRUCT_VALUE' and ! 193: `STRUCT_INCOMING_VALUE' tell GNU CC where to pass this address. ! 194: ! 195: By contrast, PCC on most target machines returns structures and ! 196: unions of any size by copying the data into an area of static ! 197: storage, and then returning the address of that storage as if it ! 198: were a pointer value. The caller must copy the data from that ! 199: memory area to the place where the value is wanted. GNU CC does ! 200: not use this method because it is slower and nonreentrant. ! 201: ! 202: On some newer machines, PCC uses a reentrant convention for all ! 203: structure and union returning. GNU CC on most of these machines ! 204: uses a compatible convention when returning structures and unions ! 205: in memory, but still returns small structures and unions in ! 206: registers. ! 207: ! 208: You can tell GNU CC to use a compatible convention for all ! 209: structure and union returning with the option ! 210: `-fpcc-struct-return'. ! 211: ! 212: * GNU C complains about program fragments such as `0x74ae-0x4000' ! 213: which appear to be two hexadecimal constants separated by the minus ! 214: operator. Actually, this string is a single "preprocessing token". ! 215: Each such token must correspond to one token in C. Since this ! 216: does not, GNU C prints an error message. Although it may appear ! 217: obvious that what is meant is an operator and two values, the ANSI ! 218: C standard specifically requires that this be treated as erroneous. ! 219: ! 220: A "preprocessing token" is a "preprocessing number" if it begins ! 221: with a digit and is followed by letters, underscores, digits, ! 222: periods and `e+', `e-', `E+', or `E-' character sequences. ! 223: ! 224: To make the above program fragment valid, place whitespace in ! 225: front of the minus sign. This whitespace will end the ! 226: preprocessing number. ! 227: ! 228: ! 229: File: gcc.info, Node: Fixed Headers, Next: Disappointments, Prev: Incompatibilities, Up: Trouble ! 230: ! 231: Fixed Header Files ! 232: ================== ! 233: ! 234: GNU CC needs to install corrected versions of some system header ! 235: files. This is because most target systems have some header files that ! 236: won't work with GNU CC unless they are changed. Some have bugs, some ! 237: are incompatible with ANSI C, and some depend on special features of ! 238: other compilers. ! 239: ! 240: Installing GNU CC automatically creates and installs the fixed header ! 241: files, by running a program called `fixincludes' (or for certain ! 242: targets an alternative such as `fixinc.svr4'). Normally, you don't ! 243: need to pay attention to this. But there are cases where it doesn't do ! 244: the right thing automatically. ! 245: ! 246: * If you update the system's header files, such as by installing a ! 247: new system version, the fixed header files of GNU CC are not ! 248: automatically updated. The easiest way to update them is to ! 249: reinstall GNU CC. (If you want to be clever, look in the makefile ! 250: and you can find a shortcut.) ! 251: ! 252: * On some systems, in particular SunOS 4, header file directories ! 253: contain machine-specific symbolic links in certain places. This ! 254: makes it possible to share most of the header files among hosts ! 255: running the same version of SunOS 4 on different machine models. ! 256: ! 257: The programs that fix the header files do not understand this ! 258: special way of using symbolic links; therefore, the directory of ! 259: fixed header files is good only for the machine model used to ! 260: build it. ! 261: ! 262: In SunOS 4, only programs that look inside the kernel will notice ! 263: the difference between machine models. Therefore, for most ! 264: purposes, you need not be concerned about this. ! 265: ! 266: It is possible to make separate sets of fixed header files for the ! 267: different machine models, and arrange a structure of symbolic ! 268: links so as to use the proper set, but you'll have to do this by ! 269: hand. ! 270: ! 271: ! 272: File: gcc.info, Node: Disappointments, Next: C++ Misunderstandings, Prev: Fixed Headers, Up: Trouble ! 273: ! 274: Disappointments and Misunderstandings ! 275: ===================================== ! 276: ! 277: These problems are perhaps regrettable, but we don't know any ! 278: practical way around them. ! 279: ! 280: * Certain local variables aren't recognized by debuggers when you ! 281: compile with optimization. ! 282: ! 283: This occurs because sometimes GNU CC optimizes the variable out of ! 284: existence. There is no way to tell the debugger how to compute the ! 285: value such a variable "would have had", and it is not clear that ! 286: would be desirable anyway. So GNU CC simply does not mention the ! 287: eliminated variable when it writes debugging information. ! 288: ! 289: You have to expect a certain amount of disagreement between the ! 290: executable and your source code, when you use optimization. ! 291: ! 292: * Users often think it is a bug when GNU CC reports an error for code ! 293: like this: ! 294: ! 295: int foo (struct mumble *); ! 296: ! 297: struct mumble { ... }; ! 298: ! 299: int foo (struct mumble *x) ! 300: { ... } ! 301: ! 302: This code really is erroneous, because the scope of `struct ! 303: mumble' in the prototype is limited to the argument list ! 304: containing it. It does not refer to the `struct mumble' defined ! 305: with file scope immediately below--they are two unrelated types ! 306: with similar names in different scopes. ! 307: ! 308: But in the definition of `foo', the file-scope type is used ! 309: because that is available to be inherited. Thus, the definition ! 310: and the prototype do not match, and you get an error. ! 311: ! 312: This behavior may seem silly, but it's what the ANSI standard ! 313: specifies. It is easy enough for you to make your code work by ! 314: moving the definition of `struct mumble' above the prototype. ! 315: It's not worth being incompatible with ANSI C just to avoid an ! 316: error for the example shown above. ! 317: ! 318: * Accesses to bitfields even in volatile objects works by accessing ! 319: larger objects, such as a byte or a word. You cannot rely on what ! 320: size of object is accessed in order to read or write the bitfield; ! 321: it may even vary for a given bitfield according to the precise ! 322: usage. ! 323: ! 324: If you care about controlling the amount of memory that is ! 325: accessed, use volatile but do not use bitfields. ! 326: ! 327: * GNU CC comes with shell scripts to fix certain known problems in ! 328: system header files. They install corrected copies of various ! 329: header files in a special directory where only GNU CC will ! 330: normally look for them. The scripts adapt to various systems by ! 331: searching all the system header files for the problem cases that ! 332: we know about. ! 333: ! 334: If new system header files are installed, nothing automatically ! 335: arranges to update the corrected header files. You will have to ! 336: reinstall GNU CC to fix the new header files. More specifically, ! 337: go to the build directory and delete the files `stmp-fixinc' and ! 338: `stmp-headers', and the subdirectory `include'; then do `make ! 339: install' again. ! 340: ! 341: * On 68000 systems, you can get paradoxical results if you test the ! 342: precise values of floating point numbers. For example, you can ! 343: find that a floating point value which is not a NaN is not equal ! 344: to itself. This results from the fact that the the floating point ! 345: registers hold a few more bits of precision than fit in a `double' ! 346: in memory. Compiled code moves values between memory and floating ! 347: point registers at its convenience, and moving them into memory ! 348: truncates them. ! 349: ! 350: You can partially avoid this problem by using the `-ffloat-store' ! 351: option (*note Optimize Options::.). ! 352: ! 353: * On the MIPS, variable argument functions using `varargs.h' cannot ! 354: have a floating point value for the first argument. The reason ! 355: for this is that in the absence of a prototype in scope, if the ! 356: first argument is a floating point, it is passed in a floating ! 357: point register, rather than an integer register. ! 358: ! 359: If the code is rewritten to use the ANSI standard `stdarg.h' ! 360: method of variable arguments, and the prototype is in scope at the ! 361: time of the call, everything will work fine. ! 362: ! 363: ! 364: File: gcc.info, Node: C++ Misunderstandings, Next: Protoize Caveats, Prev: Disappointments, Up: Trouble ! 365: ! 366: Common Misunderstandings with GNU C++ ! 367: ===================================== ! 368: ! 369: C++ is a complex language and an evolving one, and its standard ! 370: definition (the ANSI C++ draft standard) is also evolving. As a result, ! 371: your C++ compiler may occasionally surprise you, even when its behavior ! 372: is correct. This section discusses some areas that frequently give ! 373: rise to questions of this sort. ! 374: ! 375: * Menu: ! 376: ! 377: * Static Definitions:: Static member declarations are not definitions ! 378: * Temporaries:: Temporaries may vanish before you expect ! 379: ! 380: ! 381: File: gcc.info, Node: Static Definitions, Next: Temporaries, Up: C++ Misunderstandings ! 382: ! 383: Declare *and* Define Static Members ! 384: ----------------------------------- ! 385: ! 386: When a class has static data members, it is not enough to *declare* ! 387: the static member; you must also *define* it. For example: ! 388: ! 389: class Foo ! 390: { ! 391: ... ! 392: void method(); ! 393: static int bar; ! 394: }; ! 395: ! 396: This declaration only establishes that the class `Foo' has an `int' ! 397: named `Foo::bar', and a member function named `Foo::method'. But you ! 398: still need to define *both* `method' and `bar' elsewhere. According to ! 399: the draft ANSI standard, you must supply an initializer in one (and ! 400: only one) source file, such as: ! 401: ! 402: int Foo::bar = 0; ! 403: ! 404: Other C++ compilers may not correctly implement the standard ! 405: behavior. As a result, when you switch to `g++' from one of these ! 406: compilers, you may discover that a program that appeared to work ! 407: correctly in fact does not conform to the standard: `g++' reports as ! 408: undefined symbols any static data members that lack definitions. ! 409: ! 410: ! 411: File: gcc.info, Node: Temporaries, Prev: Static Definitions, Up: C++ Misunderstandings ! 412: ! 413: Temporaries May Vanish Before You Expect ! 414: ---------------------------------------- ! 415: ! 416: It is dangerous to use pointers or references to *portions* of a ! 417: temporary object. The compiler may very well delete the object before ! 418: you expect it to, leaving a pointer to garbage. The most common place ! 419: where this problem crops up is in classes like the libg++ `String' ! 420: class, that define a conversion function to type `char *' or `const ! 421: char *'. However, any class that returns a pointer to some internal ! 422: structure is potentially subject to this problem. ! 423: ! 424: For example, a program may use a function `strfunc' that returns ! 425: `String' objects, and another function `charfunc' that operates on ! 426: pointers to `char': ! 427: ! 428: String strfunc (); ! 429: void charfunc (const char *); ! 430: ! 431: In this situation, it may seem natural to write ! 432: `charfunc (strfunc ());' based on the knowledge that class `String' has ! 433: an explicit conversion to `char' pointers. However, what really ! 434: happens is akin to `charfunc (strfunc ().convert ());', where the ! 435: `convert' method is a function to do the same data conversion normally ! 436: performed by a cast. Since the last use of the temporary `String' ! 437: object is the call to the conversion function, the compiler may delete ! 438: that object before actually calling `charfunc'. The compiler has no ! 439: way of knowing that deleting the `String' object will invalidate the ! 440: pointer. The pointer then points to garbage, so that by the time ! 441: `charfunc' is called, it gets an invalid argument. ! 442: ! 443: Code like this may run successfully under some other compilers, ! 444: especially those that delete temporaries relatively late. However, the ! 445: GNU C++ behavior is also standard-conformant, so if your program depends ! 446: on late destruction of temporaries it is not portable. ! 447: ! 448: If you think this is surprising, you should be aware that the ANSI ! 449: C++ committee continues to debate the lifetime-of-temporaries problem. ! 450: ! 451: For now, at least, the safe way to write such code is to give the ! 452: temporary a name, which forces it to remain until the end of the scope ! 453: of the name. For example: ! 454: ! 455: String& tmp = strfunc (); ! 456: charfunc (tmp); ! 457: ! 458: ! 459: File: gcc.info, Node: Protoize Caveats, Next: Non-bugs, Prev: C++ Misunderstandings, Up: Trouble ! 460: ! 461: Caveats of using `protoize' ! 462: =========================== ! 463: ! 464: The conversion programs `protoize' and `unprotoize' can sometimes ! 465: change a source file in a way that won't work unless you rearrange it. ! 466: ! 467: * `protoize' can insert references to a type name or type tag before ! 468: the definition, or in a file where they are not defined. ! 469: ! 470: If this happens, compiler error messages should show you where the ! 471: new references are, so fixing the file by hand is straightforward. ! 472: ! 473: * There are some C constructs which `protoize' cannot figure out. ! 474: For example, it can't determine argument types for declaring a ! 475: pointer-to-function variable; this you must do by hand. `protoize' ! 476: inserts a comment containing `???' each time it finds such a ! 477: variable; so you can find all such variables by searching for this ! 478: string. ANSI C does not require declaring the argument types of ! 479: pointer-to-function types. ! 480: ! 481: * Using `unprotoize' can easily introduce bugs. If the program ! 482: relied on prototypes to bring about conversion of arguments, these ! 483: conversions will not take place in the program without prototypes. ! 484: One case in which you can be sure `unprotoize' is safe is when you ! 485: are removing prototypes that were made with `protoize'; if the ! 486: program worked before without any prototypes, it will work again ! 487: without them. ! 488: ! 489: You can find all the places where this problem might occur by ! 490: compiling the program with the `-Wconversion' option. It prints a ! 491: warning whenever an argument is converted. ! 492: ! 493: * Both conversion programs can be confused if there are macro calls ! 494: in and around the text to be converted. In other words, the ! 495: standard syntax for a declaration or definition must not result ! 496: from expanding a macro. This problem is inherent in the design of ! 497: C and cannot be fixed. If only a few functions have confusing ! 498: macro calls, you can easily convert them manually. ! 499: ! 500: * `protoize' cannot get the argument types for a function whose ! 501: definition was not actually compiled due to preprocessor ! 502: conditionals. When this happens, `protoize' changes nothing in ! 503: regard to such a function. `protoize' tries to detect such ! 504: instances and warn about them. ! 505: ! 506: You can generally work around this problem by using `protoize' step ! 507: by step, each time specifying a different set of `-D' options for ! 508: compilation, until all of the functions have been converted. ! 509: There is no automatic way to verify that you have got them all, ! 510: however. ! 511: ! 512: * Confusion may result if there is an occasion to convert a function ! 513: declaration or definition in a region of source code where there ! 514: is more than one formal parameter list present. Thus, attempts to ! 515: convert code containing multiple (conditionally compiled) versions ! 516: of a single function header (in the same vicinity) may not produce ! 517: the desired (or expected) results. ! 518: ! 519: If you plan on converting source files which contain such code, it ! 520: is recommended that you first make sure that each conditionally ! 521: compiled region of source code which contains an alternative ! 522: function header also contains at least one additional follower ! 523: token (past the final right parenthesis of the function header). ! 524: This should circumvent the problem. ! 525: ! 526: * `unprotoize' can become confused when trying to convert a function ! 527: definition or declaration which contains a declaration for a ! 528: pointer-to-function formal argument which has the same name as the ! 529: function being defined or declared. We recommand you avoid such ! 530: choices of formal parameter names. ! 531: ! 532: * You might also want to correct some of the indentation by hand and ! 533: break long lines. (The conversion programs don't write lines ! 534: longer than eighty characters in any case.) ! 535: ! 536: ! 537: File: gcc.info, Node: Non-bugs, Next: Warnings and Errors, Prev: Protoize Caveats, Up: Trouble ! 538: ! 539: Certain Changes We Don't Want to Make ! 540: ===================================== ! 541: ! 542: This section lists changes that people frequently request, but which ! 543: we do not make because we think GNU CC is better without them. ! 544: ! 545: * Checking the number and type of arguments to a function which has ! 546: an old-fashioned definition and no prototype. ! 547: ! 548: Such a feature would work only occasionally--only for calls that ! 549: appear in the same file as the called function, following the ! 550: definition. The only way to check all calls reliably is to add a ! 551: prototype for the function. But adding a prototype eliminates the ! 552: motivation for this feature. So the feature is not worthwhile. ! 553: ! 554: * Warning about using an expression whose type is signed as a shift ! 555: count. ! 556: ! 557: Shift count operands are probably signed more often than unsigned. ! 558: Warning about this would cause far more annoyance than good. ! 559: ! 560: * Warning about assigning a signed value to an unsigned variable. ! 561: ! 562: Such assignments must be very common; warning about them would ! 563: cause more annoyance than good. ! 564: ! 565: * Warning about unreachable code. ! 566: ! 567: It's very common to have unreachable code in machine-generated ! 568: programs. For example, this happens normally in some files of GNU ! 569: C itself. ! 570: ! 571: * Warning when a non-void function value is ignored. ! 572: ! 573: Coming as I do from a Lisp background, I balk at the idea that ! 574: there is something dangerous about discarding a value. There are ! 575: functions that return values which some callers may find useful; ! 576: it makes no sense to clutter the program with a cast to `void' ! 577: whenever the value isn't useful. ! 578: ! 579: * Assuming (for optimization) that the address of an external symbol ! 580: is never zero. ! 581: ! 582: This assumption is false on certain systems when `#pragma weak' is ! 583: used. ! 584: ! 585: * Making `-fshort-enums' the default. ! 586: ! 587: This would cause storage layout to be incompatible with most other ! 588: C compilers. And it doesn't seem very important, given that you ! 589: can get the same result in other ways. The case where it matters ! 590: most is when the enumeration-valued object is inside a structure, ! 591: and in that case you can specify a field width explicitly. ! 592: ! 593: * Making bitfields unsigned by default on particular machines where ! 594: "the ABI standard" says to do so. ! 595: ! 596: The ANSI C standard leaves it up to the implementation whether a ! 597: bitfield declared plain `int' is signed or not. This in effect ! 598: creates two alternative dialects of C. ! 599: ! 600: The GNU C compiler supports both dialects; you can specify the ! 601: signed dialect with `-fsigned-bitfields' and the unsigned dialect ! 602: with `-funsigned-bitfields'. However, this leaves open the ! 603: question of which dialect to use by default. ! 604: ! 605: Currently, the preferred dialect makes plain bitfields signed, ! 606: because this is simplest. Since `int' is the same as `signed int' ! 607: in every other context, it is cleanest for them to be the same in ! 608: bitfields as well. ! 609: ! 610: Some computer manufacturers have published Application Binary ! 611: Interface standards which specify that plain bitfields should be ! 612: unsigned. It is a mistake, however, to say anything about this ! 613: issue in an ABI. This is because the handling of plain bitfields ! 614: distinguishes two dialects of C. Both dialects are meaningful on ! 615: every type of machine. Whether a particular object file was ! 616: compiled using signed bitfields or unsigned is of no concern to ! 617: other object files, even if they access the same bitfields in the ! 618: same data structures. ! 619: ! 620: A given program is written in one or the other of these two ! 621: dialects. The program stands a chance to work on most any machine ! 622: if it is compiled with the proper dialect. It is unlikely to work ! 623: at all if compiled with the wrong dialect. ! 624: ! 625: Many users appreciate the GNU C compiler because it provides an ! 626: environment that is uniform across machines. These users would be ! 627: inconvenienced if the compiler treated plain bitfields differently ! 628: on certain machines. ! 629: ! 630: Occasionally users write programs intended only for a particular ! 631: machine type. On these occasions, the users would benefit if the ! 632: GNU C compiler were to support by default the same dialect as the ! 633: other compilers on that machine. But such applications are rare. ! 634: And users writing a program to run on more than one type of ! 635: machine cannot possibly benefit from this kind of compatibility. ! 636: ! 637: This is why GNU CC does and will treat plain bitfields in the same ! 638: fashion on all types of machines (by default). ! 639: ! 640: There are some arguments for making bitfields unsigned by default ! 641: on all machines. If, for example, this becomes a universal de ! 642: facto standard, it would make sense for GNU CC to go along with ! 643: it. This is something to be considered in the future. ! 644: ! 645: (Of course, users strongly concerned about portability should ! 646: indicate explicitly in each bitfield whether it is signed or not. ! 647: In this way, they write programs which have the same meaning in ! 648: both C dialects.) ! 649: ! 650: * Undefining `__STDC__' when `-ansi' is not used. ! 651: ! 652: Currently, GNU CC defines `__STDC__' as long as you don't use ! 653: `-traditional'. This provides good results in practice. ! 654: ! 655: Programmers normally use conditionals on `__STDC__' to ask whether ! 656: it is safe to use certain features of ANSI C, such as function ! 657: prototypes or ANSI token concatenation. Since plain `gcc' supports ! 658: all the features of ANSI C, the correct answer to these questions ! 659: is "yes". ! 660: ! 661: Some users try to use `__STDC__' to check for the availability of ! 662: certain library facilities. This is actually incorrect usage in ! 663: an ANSI C program, because the ANSI C standard says that a ! 664: conforming freestanding implementation should define `__STDC__' ! 665: even though it does not have the library facilities. `gcc -ansi ! 666: -pedantic' is a conforming freestanding implementation, and it is ! 667: therefore required to define `__STDC__', even though it does not ! 668: come with an ANSI C library. ! 669: ! 670: Sometimes people say that defining `__STDC__' in a compiler that ! 671: does not completely conform to the ANSI C standard somehow ! 672: violates the standard. This is illogical. The standard is a ! 673: standard for compilers that claim to support ANSI C, such as `gcc ! 674: -ansi'--not for other compilers such as plain `gcc'. Whatever the ! 675: ANSI C standard says is relevant to the design of plain `gcc' ! 676: without `-ansi' only for pragmatic reasons, not as a requirement. ! 677: ! 678: * Undefining `__STDC__' in C++. ! 679: ! 680: Programs written to compile with C++-to-C translators get the ! 681: value of `__STDC__' that goes with the C compiler that is ! 682: subsequently used. These programs must test `__STDC__' to ! 683: determine what kind of C preprocessor that compiler uses: whether ! 684: they should concatenate tokens in the ANSI C fashion or in the ! 685: traditional fashion. ! 686: ! 687: These programs work properly with GNU C++ if `__STDC__' is defined. ! 688: They would not work otherwise. ! 689: ! 690: In addition, many header files are written to provide prototypes ! 691: in ANSI C but not in traditional C. Many of these header files ! 692: can work without change in C++ provided `__STDC__' is defined. If ! 693: `__STDC__' is not defined, they will all fail, and will all need ! 694: to be changed to test explicitly for C++ as well. ! 695: ! 696: * Deleting "empty" loops. ! 697: ! 698: GNU CC does not delete "empty" loops because the most likely reason ! 699: you would put one in a program is to have a delay. Deleting them ! 700: will not make real programs run any faster, so it would be ! 701: pointless. ! 702: ! 703: It would be different if optimization of a nonempty loop could ! 704: produce an empty one. But this generally can't happen. ! 705: ! 706: * Making side effects happen in the same order as in some other ! 707: compiler. ! 708: ! 709: It is never safe to depend on the order of evaluation of side ! 710: effects. For example, a function call like this may very well ! 711: behave differently from one compiler to another: ! 712: ! 713: void func (int, int); ! 714: ! 715: int i = 2; ! 716: func (i++, i++); ! 717: ! 718: There is no guarantee (in either the C or the C++ standard language ! 719: definitions) that the increments will be evaluated in any ! 720: particular order. Either increment might happen first. `func' ! 721: might get the arguments `3, 4', or it might get `4, 3', or even ! 722: `3, 3'. ! 723: ! 724: * Using the "canonical" form of the target configuration name as the ! 725: directory for installation. ! 726: ! 727: This would be an improvement in some respects, but it would also ! 728: cause problems. For one thing, users might expect to use in the ! 729: `-b' option the same name specified at installation; if ! 730: installation used the canonical form, that would not work. What's ! 731: more, the canonical name might be too long for certain file ! 732: systems. ! 733: ! 734: We suggest you make a link to the installation directory under the ! 735: canonical name, if you want to use that name in the `-b' option. ! 736: ! 737: ! 738: File: gcc.info, Node: Warnings and Errors, Prev: Non-bugs, Up: Trouble ! 739: ! 740: Warning Messages and Error Messages ! 741: =================================== ! 742: ! 743: The GNU compiler can produce two kinds of diagnostics: errors and ! 744: warnings. Each kind has a different purpose: ! 745: ! 746: *Errors* report problems that make it impossible to compile your ! 747: program. GNU CC reports errors with the source file name and line ! 748: number where the problem is apparent. ! 749: ! 750: *Warnings* report other unusual conditions in your code that *may* ! 751: indicate a problem, although compilation can (and does) proceed. ! 752: Warning messages also report the source file name and line number, ! 753: but include the text `warning:' to distinguish them from error ! 754: messages. ! 755: ! 756: Warnings may indicate danger points where you should check to make ! 757: sure that your program really does what you intend; or the use of ! 758: obsolete features; or the use of nonstandard features of GNU C or C++. ! 759: Many warnings are issued only if you ask for them, with one of the `-W' ! 760: options (for instance, `-Wall' requests a variety of useful warnings). ! 761: ! 762: GNU CC always tries to compile your program if possible; it never ! 763: gratuituously rejects a program whose meaning is clear merely because ! 764: (for instance) it fails to conform to a standard. In some cases, ! 765: however, the C and C++ standards specify that certain extensions are ! 766: forbidden, and a diagnostic *must* be issued by a conforming compiler. ! 767: The `-pedantic' option tells GNU CC to issue warnings in such cases; ! 768: `-pedantic-errors' says to make them errors instead. This does not ! 769: mean that *all* non-ANSI constructs get warnings or errors. ! 770: ! 771: *Note Options to Request or Suppress Warnings: Warning Options, for ! 772: more detail on these and related command-line options. ! 773: ! 774: ! 775: File: gcc.info, Node: Bugs, Next: Service, Prev: Trouble, Up: Top ! 776: ! 777: Reporting Bugs ! 778: ************** ! 779: ! 780: Your bug reports play an essential role in making GNU CC reliable. ! 781: ! 782: When you encounter a problem, the first thing to do is to see if it ! 783: is already known. *Note Trouble::. If it isn't known, then you should ! 784: report the problem. ! 785: ! 786: Reporting a bug may help you by bringing a solution to your problem, ! 787: or it may not. (If it does not, look in the service directory; see ! 788: *Note Service::.) In any case, the principal function of a bug report ! 789: is to help the entire community by making the next version of GNU CC ! 790: work better. Bug reports are your contribution to the maintenance of ! 791: GNU CC. ! 792: ! 793: Since the maintainers are very overloaded, we cannot respond to every ! 794: bug report. However, if the bug has not been fixed, we are likely to ! 795: send you a patch and ask you to tell us whether it works. ! 796: ! 797: In order for a bug report to serve its purpose, you must include the ! 798: information that makes for fixing the bug. ! 799: ! 800: * Menu: ! 801: ! 802: * Criteria: Bug Criteria. Have you really found a bug? ! 803: * Where: Bug Lists. Where to send your bug report. ! 804: * Reporting: Bug Reporting. How to report a bug effectively. ! 805: * Patches: Sending Patches. How to send a patch for GNU CC. ! 806: * Known: Trouble. Known problems. ! 807: * Help: Service. Where to ask for help. ! 808: ! 809: ! 810: File: gcc.info, Node: Bug Criteria, Next: Bug Lists, Up: Bugs ! 811: ! 812: Have You Found a Bug? ! 813: ===================== ! 814: ! 815: If you are not sure whether you have found a bug, here are some ! 816: guidelines: ! 817: ! 818: * If the compiler gets a fatal signal, for any input whatever, that ! 819: is a compiler bug. Reliable compilers never crash. ! 820: ! 821: * If the compiler produces invalid assembly code, for any input ! 822: whatever (except an `asm' statement), that is a compiler bug, ! 823: unless the compiler reports errors (not just warnings) which would ! 824: ordinarily prevent the assembler from being run. ! 825: ! 826: * If the compiler produces valid assembly code that does not ! 827: correctly execute the input source code, that is a compiler bug. ! 828: ! 829: However, you must double-check to make sure, because you may have ! 830: run into an incompatibility between GNU C and traditional C (*note ! 831: Incompatibilities::.). These incompatibilities might be considered ! 832: bugs, but they are inescapable consequences of valuable features. ! 833: ! 834: Or you may have a program whose behavior is undefined, which ! 835: happened by chance to give the desired results with another C or ! 836: C++ compiler. ! 837: ! 838: For example, in many nonoptimizing compilers, you can write `x;' ! 839: at the end of a function instead of `return x;', with the same ! 840: results. But the value of the function is undefined if `return' ! 841: is omitted; it is not a bug when GNU CC produces different results. ! 842: ! 843: Problems often result from expressions with two increment ! 844: operators, as in `f (*p++, *p++)'. Your previous compiler might ! 845: have interpreted that expression the way you intended; GNU CC might ! 846: interpret it another way. Neither compiler is wrong. The bug is ! 847: in your code. ! 848: ! 849: After you have localized the error to a single source line, it ! 850: should be easy to check for these things. If your program is ! 851: correct and well defined, you have found a compiler bug. ! 852: ! 853: * If the compiler produces an error message for valid input, that is ! 854: a compiler bug. ! 855: ! 856: * If the compiler does not produce an error message for invalid ! 857: input, that is a compiler bug. However, you should note that your ! 858: idea of "invalid input" might be my idea of "an extension" or ! 859: "support for traditional practice". ! 860: ! 861: * If you are an experienced user of C or C++ compilers, your ! 862: suggestions for improvement of GNU CC or GNU C++ are welcome in ! 863: any case. ! 864: ! 865: ! 866: File: gcc.info, Node: Bug Lists, Next: Bug Reporting, Prev: Bug Criteria, Up: Bugs ! 867: ! 868: Where to Report Bugs ! 869: ==================== ! 870: ! 871: Send bug reports for GNU C to one of these addresses: ! 872: ! 873: [email protected] ! 874: {ucbvax|mit-eddie|uunet}!prep.ai.mit.edu!bug-gcc ! 875: ! 876: Send bug reports for GNU C++ to one of these addresses: ! 877: ! 878: [email protected] ! 879: {ucbvax|mit-eddie|uunet}!prep.ai.mit.edu!bug-g++ ! 880: ! 881: If your bug involves the C++ class library libg++, send mail to ! 882: `[email protected]'. If you're not sure, you can send the ! 883: bug report to both lists. ! 884: ! 885: *Do not send bug reports to the mailing list `help-gcc', or to the ! 886: newsgroup `gnu.gcc.help'.* Most users of GNU CC do not want to receive ! 887: bug reports. Those that do, have asked to be on `bug-gcc' and/or ! 888: `bug-g++'. ! 889: ! 890: The mailing lists `bug-gcc' and `bug-g++' both have newsgroups which ! 891: serve as repeaters: `gnu.gcc.bug' and `gnu.g++.bug'. Each mailing list ! 892: and its newsgroup carry exactly the same messages. ! 893: ! 894: Often people think of posting bug reports to the newsgroup instead of ! 895: mailing them. This appears to work, but it has one problem which can be ! 896: crucial: a newsgroup posting does not contain a mail path back to the ! 897: sender. Thus, if maintainers need more information, they may be unable ! 898: to reach you. For this reason, you should always send bug reports by ! 899: mail to the proper mailing list. ! 900: ! 901: As a last resort, send bug reports on paper to: ! 902: ! 903: GNU Compiler Bugs ! 904: Free Software Foundation ! 905: 675 Mass Ave ! 906: Cambridge, MA 02139 ! 907:
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.