summaryrefslogtreecommitdiff
path: root/gcc/README.Portability
diff options
context:
space:
mode:
authorMichael Meissner <meissner@redhat.com>2000-07-15 04:18:47 +0000
committerMichael Meissner <meissner@gcc.gnu.org>2000-07-15 04:18:47 +0000
commitae0e50e87b2a7cf575ff2477ae9db3d9229642ef (patch)
tree6466798fe934097e747d92267fe4bdf6a10a1852 /gcc/README.Portability
parent7de515541f1d2325ef08839db0dd99a3b0e612a3 (diff)
downloadgcc-ae0e50e87b2a7cf575ff2477ae9db3d9229642ef.tar.gz
update portability guide
From-SVN: r35041
Diffstat (limited to 'gcc/README.Portability')
-rw-r--r--gcc/README.Portability13
1 files changed, 8 insertions, 5 deletions
diff --git a/gcc/README.Portability b/gcc/README.Portability
index a7331512d28..d6c8aecaa5d 100644
--- a/gcc/README.Portability
+++ b/gcc/README.Portability
@@ -155,6 +155,9 @@ ansidecl.h for the definitions of the above macros and more.
#define PARAMS(paramlist) () /* K+R C. */
#define VPARAMS(args) (va_alist) va_dcl
+One aspect of using K+R style function declarations, is you cannot have
+arguments whose types are char, short, or float, since without prototypes (ie,
+K+R rules), these types are promoted to int, int, and double respectively.
Calling functions through pointers to functions
-----------------------------------------------
@@ -230,10 +233,6 @@ int is done as an unsigned comparison in K+R (since unsigned char
promotes to unsigned) while it is signed in ISO (since all of the
values in unsigned char fit in an int, it promotes to int).
-** Not having any argument whose type is a short type (char, short,
-float of any flavor) and subject to promotion. **
-
-
Trigraphs
---------
@@ -245,7 +244,11 @@ them.
Suffixes on Integer Constants
-----------------------------
-**Using a 'u' suffix on integer constants.**
+K+R C did not accept a 'u' suffix on integer constants. If you want to declare
+a constant to be be unsigned, you must use an explicit cast.
+
+You should never use a 'l' suffix on integer constants ('L' is fine), since it
+can easily be confused with the number '1'.
Common Coding Pitfalls