8b3f9b1455
Since type_t is different between lint1.h and lint2.h include the appropriate file depending on the pass. Make the argument mismatch error print the type names of the types involved. Now that we have a tyname() function we can fix the rest of the pass2 warnings to be more explanatory, but not now.
189 lines
6.3 KiB
C
189 lines
6.3 KiB
C
/* $NetBSD: lint2.h,v 1.7 2005/04/07 16:28:40 christos Exp $ */
|
|
|
|
/*
|
|
* Copyright (c) 1996 Christopher G. Demetriou. All Rights Reserved.
|
|
* Copyright (c) 1994, 1995 Jochen Pohl
|
|
* All Rights Reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
* 3. All advertising materials mentioning features or use of this software
|
|
* must display the following acknowledgement:
|
|
* This product includes software developed by Jochen Pohl for
|
|
* The NetBSD Project.
|
|
* 4. The name of the author may not be used to endorse or promote products
|
|
* derived from this software without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*/
|
|
|
|
#include "lint.h"
|
|
|
|
/*
|
|
* Types are described by structures of type type_t.
|
|
*/
|
|
struct type {
|
|
tspec_t t_tspec; /* type specifier */
|
|
u_int t_const : 1; /* constant */
|
|
u_int t_volatile : 1; /* volatile */
|
|
u_int t_vararg : 1; /* function has variable number of arguments */
|
|
u_int t_isenum : 1; /* enum type */
|
|
u_int t_proto : 1; /* this is a prototype */
|
|
u_int t_istag : 1; /* tag with _t_tag valid */
|
|
u_int t_istynam : 1; /* tag with _t_tynam valid */
|
|
u_int t_isuniqpos : 1; /* tag with _t_uniqpos valid */
|
|
union {
|
|
int _t_dim; /* if the type is an ARRAY than this
|
|
is the dimension of the array. */
|
|
struct hte *_t_tag; /* hash table entry of tag if
|
|
t_isenum, STRUCT or UNION */
|
|
struct hte *_t_tynam; /* hash table entry of typename if
|
|
t_isenum, STRUCT or UNION */
|
|
struct {
|
|
int p_line;
|
|
short p_file;
|
|
int p_uniq;
|
|
} _t_uniqpos; /* unique position, for untagged
|
|
untyped STRUCTs, UNIONS, and ENUMs,
|
|
if t_isuniqpos */
|
|
struct type **_t_args; /* list of argument types if this
|
|
is a prototype */
|
|
} t_u;
|
|
struct type *t_subt; /* indirected type (array element, pointed to
|
|
type, type of return value) */
|
|
};
|
|
|
|
#define t_dim t_u._t_dim
|
|
#define t_tag t_u._t_tag
|
|
#define t_tynam t_u._t_tynam
|
|
#define t_uniqpos t_u._t_uniqpos
|
|
#define t_args t_u._t_args
|
|
|
|
/*
|
|
* argument information
|
|
*
|
|
* Such a structure is created for each argument of a function call
|
|
* which is an integer constant or a constant string.
|
|
*/
|
|
typedef struct arginf {
|
|
int a_num; /* # of argument (1..) */
|
|
u_int a_zero : 1; /* argument is 0 */
|
|
u_int a_pcon : 1; /* msb of argument is not set */
|
|
u_int a_ncon : 1; /* msb of argument is set */
|
|
u_int a_fmt : 1; /* a_fstrg points to format string */
|
|
char *a_fstrg; /* format string */
|
|
struct arginf *a_nxt; /* information for next const. argument */
|
|
} arginf_t;
|
|
|
|
/*
|
|
* Keeps information about position in source file.
|
|
*/
|
|
typedef struct {
|
|
u_short p_src; /* index of name of translation unit
|
|
(the name which was specified at the
|
|
command line) */
|
|
u_short p_line; /* line number in p_src */
|
|
u_short p_isrc; /* index of (included) file */
|
|
u_short p_iline; /* line number in p_iline */
|
|
} pos_t;
|
|
|
|
/*
|
|
* Used for definitions and declarations
|
|
*
|
|
* To save memory, variable sized structures are used. If
|
|
* all s_va, s_prfl and s_scfl are not set, the memory allocated
|
|
* for a symbol is only large enough to keep the first member of
|
|
* struct sym, s_s.
|
|
*/
|
|
typedef struct sym {
|
|
struct {
|
|
pos_t s_pos; /* pos of def./decl. */
|
|
#ifndef lint
|
|
u_int s_def : 3; /* DECL, TDEF or DEF */
|
|
#else
|
|
def_t s_def;
|
|
#endif
|
|
u_int s_rval : 1; /* function has return value */
|
|
u_int s_osdef : 1; /* old style function definition */
|
|
u_int s_static : 1; /* symbol is static */
|
|
u_int s_va : 1; /* check only first s_nva arguments */
|
|
u_int s_prfl : 1; /* printflike */
|
|
u_int s_scfl : 1; /* scanflike */
|
|
u_short s_type; /* type */
|
|
struct sym *s_nxt; /* next symbol with same name */
|
|
} s_s;
|
|
short s_nva;
|
|
short s_nprfl;
|
|
short s_nscfl;
|
|
} sym_t;
|
|
|
|
#define s_pos s_s.s_pos
|
|
#define s_rval s_s.s_rval
|
|
#define s_osdef s_s.s_osdef
|
|
#define s_static s_s.s_static
|
|
#define s_def s_s.s_def
|
|
#define s_va s_s.s_va
|
|
#define s_prfl s_s.s_prfl
|
|
#define s_scfl s_s.s_scfl
|
|
#define s_type s_s.s_type
|
|
#define s_nxt s_s.s_nxt
|
|
|
|
/*
|
|
* Used to store informations about function calls.
|
|
*/
|
|
typedef struct fcall {
|
|
pos_t f_pos; /* position of call */
|
|
u_int f_rused : 1; /* return value used */
|
|
u_int f_rdisc : 1; /* return value discarded (casted to void) */
|
|
u_short f_type; /* types of expected return value and args */
|
|
arginf_t *f_args; /* information about constant arguments */
|
|
struct fcall *f_nxt; /* next call of same function */
|
|
} fcall_t;
|
|
|
|
/*
|
|
* Used to store information about usage of symbols other
|
|
* than for function calls.
|
|
*/
|
|
typedef struct usym {
|
|
pos_t u_pos; /* position */
|
|
struct usym *u_nxt; /* next usage */
|
|
} usym_t;
|
|
|
|
/*
|
|
* hash table entry
|
|
*/
|
|
typedef struct hte {
|
|
const char *h_name; /* name */
|
|
u_int h_used : 1; /* symbol is used */
|
|
u_int h_def : 1; /* symbol is defined */
|
|
u_int h_static : 1; /* static symbol */
|
|
sym_t *h_syms; /* declarations and definitions */
|
|
sym_t **h_lsym; /* points to s_nxt of last decl./def. */
|
|
fcall_t *h_calls; /* function calls */
|
|
fcall_t **h_lcall; /* points to f_nxt of last call */
|
|
usym_t *h_usyms; /* usage info */
|
|
usym_t **h_lusym; /* points to u_nxt of last usage info */
|
|
struct hte *h_link; /* next hte with same hash function */
|
|
struct hte *h_hte; /* pointer to other htes (for renames */
|
|
} hte_t;
|
|
|
|
/* maps type indices into pointers to type structs */
|
|
#define TP(idx) (tlst[idx])
|
|
|
|
#include "externs2.h"
|