2002-04-19 17:26:21 +00:00
|
|
|
/* $OpenBSD: extern.h,v 1.29 2002/02/16 21:27:48 millert Exp $ */
|
|
|
|
/* $NetBSD: extern.h,v 1.3 1996/01/13 23:25:24 pk Exp $ */
|
|
|
|
|
1994-05-27 12:33:43 +00:00
|
|
|
/*-
|
|
|
|
* Copyright (c) 1991, 1993
|
|
|
|
* The Regents of the University of California. All rights reserved.
|
|
|
|
*
|
|
|
|
* This code is derived from software contributed to Berkeley by
|
|
|
|
* Ozan Yigit at York University.
|
|
|
|
*
|
|
|
|
* 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 the University of
|
|
|
|
* California, Berkeley and its contributors.
|
|
|
|
* 4. Neither the name of the University nor the names of its contributors
|
|
|
|
* may be used to endorse or promote products derived from this software
|
|
|
|
* without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 REGENTS OR CONTRIBUTORS 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.
|
|
|
|
*
|
|
|
|
* @(#)extern.h 8.1 (Berkeley) 6/6/93
|
2001-04-16 18:36:35 +00:00
|
|
|
* $FreeBSD$
|
1994-05-27 12:33:43 +00:00
|
|
|
*/
|
|
|
|
|
2002-04-19 17:26:21 +00:00
|
|
|
/* eval.c */
|
|
|
|
extern void eval(const char *[], int, int);
|
|
|
|
extern void dodefine(const char *, const char *);
|
|
|
|
extern unsigned long expansion_id;
|
|
|
|
|
|
|
|
/* expr.c */
|
|
|
|
extern int expr(const char *);
|
|
|
|
|
|
|
|
/* gnum4.c */
|
|
|
|
extern void addtoincludepath(const char *);
|
|
|
|
extern struct input_file *fopen_trypath(struct input_file *, const char *);
|
|
|
|
extern void doindir(const char *[], int);
|
|
|
|
extern void dobuiltin(const char *[], int);
|
|
|
|
extern void dopatsubst(const char *[], int);
|
|
|
|
extern void doregexp(const char *[], int);
|
|
|
|
|
|
|
|
extern void doprintlineno(struct input_file *);
|
|
|
|
extern void doprintfilename(struct input_file *);
|
|
|
|
|
|
|
|
extern void doesyscmd(const char *);
|
|
|
|
|
|
|
|
|
|
|
|
/* look.c */
|
|
|
|
extern ndptr addent(const char *);
|
|
|
|
extern unsigned hash(const char *);
|
|
|
|
extern ndptr lookup(const char *);
|
|
|
|
extern void remhash(const char *, int);
|
|
|
|
|
|
|
|
/* main.c */
|
|
|
|
extern void outputstr(const char *);
|
|
|
|
extern int builtin_type(const char *);
|
Crank WARNS.
Cast sizeof() to (int), as it's being compared against an int, not a size_t.
If i is changed to a size_t, it means the logic must be slightly changed later
in the flow, where --i is checked to be >= 0. I am not sure I want to make a
logic change to account for clearing up a warning, when an aesthetic one will
keep from modifying the logic.
Other harmless casts, that I think I've made in the right directions.
Make gpbc() an inline function, rather than an obfuscated macro, make its
scratch space local, rather than global. The previous macro used a dirty
hack (logical AND in place of a conditional) which would lead GCC to throw
a fit (rightly so) as the logical check, as well as the incrementation of
a variable, were not used for anything.
const'ify a few places where gcc3 yells. xstrdup() some global consts in
places where we xstrdup() when not using consts, but tried to assign them
to non-consts before.
Don't use execv(2) if we don't have the kind of arguments it wants.
Reviewed by: asmodai obrien tjr
Submitted by: tjr (a gcc3 build log)
2002-04-20 01:49:10 +00:00
|
|
|
extern const char *builtin_realname(int);
|
2002-04-19 17:26:21 +00:00
|
|
|
extern void emitline(void);
|
|
|
|
|
|
|
|
/* misc.c */
|
|
|
|
extern void chrsave(int);
|
|
|
|
extern char *compute_prevep(void);
|
|
|
|
extern void getdiv(int);
|
|
|
|
extern ptrdiff_t indx(const char *, const char *);
|
|
|
|
extern void initspaces(void);
|
|
|
|
extern void killdiv(void);
|
|
|
|
extern void onintr(int);
|
|
|
|
extern void pbnum(int);
|
|
|
|
extern void pbunsigned(unsigned long);
|
|
|
|
extern void pbstr(const char *);
|
|
|
|
extern void putback(int);
|
|
|
|
extern void *xalloc(size_t);
|
|
|
|
extern char *xstrdup(const char *);
|
|
|
|
extern void usage(void);
|
|
|
|
extern void resizedivs(int);
|
|
|
|
extern size_t buffer_mark(void);
|
|
|
|
extern void dump_buffer(FILE *, size_t);
|
|
|
|
|
|
|
|
extern int obtain_char(struct input_file *);
|
|
|
|
extern void set_input(struct input_file *, FILE *, const char *);
|
|
|
|
extern void release_input(struct input_file *);
|
|
|
|
|
|
|
|
/* speeded-up versions of chrsave/putback */
|
|
|
|
#define PUTBACK(c) \
|
|
|
|
do { \
|
|
|
|
if (bp >= endpbb) \
|
|
|
|
enlarge_bufspace(); \
|
|
|
|
*bp++ = (c); \
|
|
|
|
} while(0)
|
|
|
|
|
|
|
|
#define CHRSAVE(c) \
|
|
|
|
do { \
|
|
|
|
if (ep >= endest) \
|
|
|
|
enlarge_strspace(); \
|
|
|
|
*ep++ = (c); \
|
|
|
|
} while(0)
|
|
|
|
|
|
|
|
/* and corresponding exposure for local symbols */
|
|
|
|
extern void enlarge_bufspace(void);
|
|
|
|
extern void enlarge_strspace(void);
|
|
|
|
extern char *endpbb;
|
|
|
|
extern char *endest;
|
|
|
|
|
|
|
|
/* trace.c */
|
|
|
|
extern void mark_traced(const char *, int);
|
|
|
|
extern int is_traced(const char *);
|
|
|
|
extern void trace_file(const char *);
|
|
|
|
extern ssize_t trace(const char **, int, struct input_file *);
|
|
|
|
extern void finish_trace(size_t);
|
|
|
|
extern int traced_macros;
|
|
|
|
extern void set_trace_flags(const char *);
|
|
|
|
extern FILE *traceout;
|
1994-05-27 12:33:43 +00:00
|
|
|
|
|
|
|
extern ndptr hashtab[]; /* hash table for macros etc. */
|
2002-04-19 17:26:21 +00:00
|
|
|
extern stae *mstack; /* stack of m4 machine */
|
|
|
|
extern char *sstack; /* shadow stack, for string space extension */
|
1994-05-27 12:33:43 +00:00
|
|
|
extern FILE *active; /* active output file pointer */
|
2002-04-19 17:26:21 +00:00
|
|
|
extern struct input_file infile[];/* input file stack (0=stdin) */
|
|
|
|
extern char *inname[]; /* names of these input files */
|
|
|
|
extern int inlineno[]; /* current number in each input file */
|
|
|
|
extern FILE **outfile; /* diversion array(0=bitbucket) */
|
|
|
|
extern int maxout; /* maximum number of diversions */
|
1994-05-27 12:33:43 +00:00
|
|
|
extern int fp; /* m4 call frame pointer */
|
|
|
|
extern int ilevel; /* input file stack pointer */
|
|
|
|
extern int oindex; /* diversion index. */
|
|
|
|
extern int sp; /* current m4 stack pointer */
|
2002-04-19 17:26:21 +00:00
|
|
|
extern char *bp; /* first available character */
|
|
|
|
extern char *buf; /* push-back buffer */
|
|
|
|
extern char *bufbase; /* buffer base for this ilevel */
|
|
|
|
extern char *bbase[]; /* buffer base per ilevel */
|
|
|
|
extern char ecommt[MAXCCHARS+1];/* end character for comment */
|
1994-05-27 12:33:43 +00:00
|
|
|
extern char *ep; /* first free char in strspace */
|
2002-04-19 17:26:21 +00:00
|
|
|
extern char lquote[MAXCCHARS+1];/* left quote character (`) */
|
Crank WARNS.
Cast sizeof() to (int), as it's being compared against an int, not a size_t.
If i is changed to a size_t, it means the logic must be slightly changed later
in the flow, where --i is checked to be >= 0. I am not sure I want to make a
logic change to account for clearing up a warning, when an aesthetic one will
keep from modifying the logic.
Other harmless casts, that I think I've made in the right directions.
Make gpbc() an inline function, rather than an obfuscated macro, make its
scratch space local, rather than global. The previous macro used a dirty
hack (logical AND in place of a conditional) which would lead GCC to throw
a fit (rightly so) as the logical check, as well as the incrementation of
a variable, were not used for anything.
const'ify a few places where gcc3 yells. xstrdup() some global consts in
places where we xstrdup() when not using consts, but tried to assign them
to non-consts before.
Don't use execv(2) if we don't have the kind of arguments it wants.
Reviewed by: asmodai obrien tjr
Submitted by: tjr (a gcc3 build log)
2002-04-20 01:49:10 +00:00
|
|
|
extern const char *m4wraps; /* m4wrap string default. */
|
|
|
|
extern const char *null; /* as it says.. just a null. */
|
2002-04-19 17:26:21 +00:00
|
|
|
extern char rquote[MAXCCHARS+1];/* right quote character (') */
|
|
|
|
extern char scommt[MAXCCHARS+1];/* start character for comment */
|
2002-04-17 17:26:32 +00:00
|
|
|
extern int synccpp; /* Line synchronisation for C preprocessor */
|
2002-04-19 17:26:21 +00:00
|
|
|
|
|
|
|
extern int mimic_gnu; /* behaves like gnu-m4 */
|
Crank WARNS.
Cast sizeof() to (int), as it's being compared against an int, not a size_t.
If i is changed to a size_t, it means the logic must be slightly changed later
in the flow, where --i is checked to be >= 0. I am not sure I want to make a
logic change to account for clearing up a warning, when an aesthetic one will
keep from modifying the logic.
Other harmless casts, that I think I've made in the right directions.
Make gpbc() an inline function, rather than an obfuscated macro, make its
scratch space local, rather than global. The previous macro used a dirty
hack (logical AND in place of a conditional) which would lead GCC to throw
a fit (rightly so) as the logical check, as well as the incrementation of
a variable, were not used for anything.
const'ify a few places where gcc3 yells. xstrdup() some global consts in
places where we xstrdup() when not using consts, but tried to assign them
to non-consts before.
Don't use execv(2) if we don't have the kind of arguments it wants.
Reviewed by: asmodai obrien tjr
Submitted by: tjr (a gcc3 build log)
2002-04-20 01:49:10 +00:00
|
|
|
|
|
|
|
/* get a possibly pushed-back-character, increment lineno if need be */
|
|
|
|
static __inline int gpbc(void)
|
|
|
|
{
|
|
|
|
int chscratch; /* Scratch space. */
|
|
|
|
|
|
|
|
if (bp > bufbase) {
|
|
|
|
if (*--bp)
|
2002-04-20 02:04:58 +00:00
|
|
|
return ((unsigned char)*bp);
|
Crank WARNS.
Cast sizeof() to (int), as it's being compared against an int, not a size_t.
If i is changed to a size_t, it means the logic must be slightly changed later
in the flow, where --i is checked to be >= 0. I am not sure I want to make a
logic change to account for clearing up a warning, when an aesthetic one will
keep from modifying the logic.
Other harmless casts, that I think I've made in the right directions.
Make gpbc() an inline function, rather than an obfuscated macro, make its
scratch space local, rather than global. The previous macro used a dirty
hack (logical AND in place of a conditional) which would lead GCC to throw
a fit (rightly so) as the logical check, as well as the incrementation of
a variable, were not used for anything.
const'ify a few places where gcc3 yells. xstrdup() some global consts in
places where we xstrdup() when not using consts, but tried to assign them
to non-consts before.
Don't use execv(2) if we don't have the kind of arguments it wants.
Reviewed by: asmodai obrien tjr
Submitted by: tjr (a gcc3 build log)
2002-04-20 01:49:10 +00:00
|
|
|
else
|
|
|
|
return (EOF);
|
|
|
|
}
|
|
|
|
chscratch = obtain_char(infile+ilevel);
|
|
|
|
if (chscratch == '\n')
|
|
|
|
++inlineno[ilevel];
|
|
|
|
return (chscratch);
|
|
|
|
}
|