diff options
author | bde <bde@FreeBSD.org> | 1995-04-07 11:43:40 +0000 |
---|---|---|
committer | bde <bde@FreeBSD.org> | 1995-04-07 11:43:40 +0000 |
commit | d60c039cdc1a7c5a23d38be0c4062ee46545edba (patch) | |
tree | c3eaa2b1303f3ab13ab32f66421ae7742ee7a83b /lib | |
parent | 9a3aa41f7b77a451350cdbcda0c65c5ed8af5300 (diff) | |
download | FreeBSD-src-d60c039cdc1a7c5a23d38be0c4062ee46545edba.zip FreeBSD-src-d60c039cdc1a7c5a23d38be0c4062ee46545edba.tar.gz |
Reviewed by: ache and wollman (long ago)
Fix numerous ANSI conformance bugs and other nits.
ctype.h:
o There were no prototypes behind the macros (conformance bug).
o isascii() didn't have enough parentheses (plain bug).
o tolower() and toupper were always static inline (conformance
bug? You could undef them and take their address, but this
gave different addresses in different modules. You couldn't
undef them and declare them (correctly) again). <stdio.h>'s
treatment of putc() shows one way to handle this problem,
but it only works because the putc() macro is allowed to
reevaluate its args. I used a hack controlled by
_EXTERNALIZE_CTYPE_INLINES_ to get <ctype.h> to generate the
code (the previous hack involving _ANSI_LIBRARY_ goes away).
This has the advantage that the core of the functions is only
written down once and the disadvantage that another layer of
functions is required. The extra layer goes away if inline
functions are used, leaving only the problem of understanding
why there are functions named toupper(), __toupper and
___toupper() as well as a macro named toupper.
o Nothing seems to define _USE_CTYPE_LIBRARY_. Eliminate it
o Let the user set _USE_CTYPE_INLINE_ and _DONT_USE_CTYPE_INLINE_
for full control over inlining.
o The args for the inline functions didn't have enough
underscores (conformance bug).
o The formatting and ordering was inconsistent (style bug).
o TODO: fix conformance bugs brought by including <runetype.h>.
Diffstat (limited to 'lib')
0 files changed, 0 insertions, 0 deletions