Newsgroup: comp.compilers


Newsgroups: comp.compilers
Path: icdoc!ibmassc!yktnews!admin!newsgate.watson.ibm.com!uunet!decwrl!world!iecc!compilers-sender
From: Diomidis Spinellis <dds@doc.imperial.ac.uk>
Subject: Re: A lesson for compiler warning writers
Message-ID: <92-06-091@comp.compilers>
Keywords: C, lint
Sender: compilers-sender@iecc.cambridge.ma.us
Reply-To: Diomidis Spinellis <dds@doc.imperial.ac.uk>
Organization: Compilers Central
Date: Fri, 19 Jun 1992 14:49:47 GMT
Approved: compilers@iecc.cambridge.ma.us
Lines: 30
Content-Length: 1517
arnold@cc.gatech.edu (Arnold Robbins) writes:
>       file a.c:
>               double foo(long a) { return a * 2.0 ; }
>       file b.c
>               extern short foo(double a);
[...]
> Both files will compile just fine.  [...] But when you link the two 
> objects together, the output will be either garbage or a core dump.  
> lint will catch this, the C compiler won't.

There are methods to catch this at link time, with existing linker
technology..  See pp. 122-127 Margaret A. Ellis and Bjarne Stroustrup, 
The Annotated C++ Reference Manual, Addison-Wesley, 1990 and Diomidis 
Spinellis, Type-safe Linkage for Variables and Functions SIGPLAN 
Notices 26(8):74-79, August 1991.

Diomidis
--
Diomidis Spinellis    Internet: <dds@doc.ic.ac.uk>    UUCP: ...!ukc!icdoc!dds
Department of Computing, Imperial College, London SW7
[Good point.  In about 1975, when Dartmouth College wrote their first linker
to go with the PL/I compiler (the other compilers were so fast that it wasn't
worth saving object code, much less linking) and they had a type matching
hack:  The compiler annotated each external definition and reference with
a string of type data, and the linker complained if the type strings weren't
the same.  Simple, fast, and effective.  I presume the C++ approach is
similar, albeit with the type info encoded in the symbol name. -John]
-- 
Send compilers articles to compilers@iecc.cambridge.ma.us or
{ima | spdcc | world}!iecc!compilers.  Meta-mail to compilers-request.



Newsgroup comp.compilers contents
Newsgroup list
Diomidis Spinellis home page

Creative Commons License Unless otherwise expressly stated, all original material on this page created by Diomidis Spinellis is licensed under a Creative Commons Attribution-Share Alike 3.0 Greece License.