input.h 1.61 KB
Newer Older
1 2
/* Declarations for variables relating to reading the source file.
   Used by parsers, lexical analyzers, and error message routines.
3
   Copyright (C) 1993, 1997, 1998, 2000 Free Software Foundation, Inc.
4

5
This file is part of GCC.
6

7 8 9 10
GCC is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License as published by the Free
Software Foundation; either version 2, or (at your option) any later
version.
11

12 13 14 15
GCC is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
for more details.
16 17

You should have received a copy of the GNU General Public License
18 19 20
along with GCC; see the file COPYING.  If not, write to the Free
Software Foundation, 59 Temple Place - Suite 330, Boston, MA
02111-1307, USA.  */
21

Richard Stallman committed
22
/* Source file current line is coming from.  */
Zack Weinberg committed
23
extern const char *input_filename;
Richard Stallman committed
24 25

/* Top-level source file.  */
Zack Weinberg committed
26
extern const char *main_input_filename;
Richard Stallman committed
27 28 29 30 31 32 33 34 35

/* Line number in current source file.  */
extern int lineno;

/* Stream for reading from input file.  */
extern FILE *finput;

struct file_stack
  {
Zack Weinberg committed
36
    const char *name;
Richard Stallman committed
37 38
    struct file_stack *next;
    int line;
Jeff Law committed
39
    int indent_level;
Richard Stallman committed
40 41 42 43 44 45 46 47
  };

/* Stack of currently pending input files.
   The line member is not accurate for the innermost file on the stack.  */
extern struct file_stack *input_file_stack;

/* Incremented on each change to input_file_stack.  */
extern int input_file_stack_tick;
48

Zack Weinberg committed
49
extern void push_srcloc PARAMS ((const char *name, int line));
50
extern void pop_srcloc PARAMS ((void));