/*
 * Copyright (c) 2002, The Tendra Project <http://www.ten15.org/>
 * 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 unmodified, 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.
 *
 * 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.
 *
 *
 *    		 Crown Copyright (c) 1997, 1998
 *
 *    This TenDRA(r) Computer Program is subject to Copyright
 *    owned by the United Kingdom Secretary of State for Defence
 *    acting through the Defence Evaluation and Research Agency
 *    (DERA).  It is made available to Recipients with a
 *    royalty-free licence for its use, reproduction, transfer
 *    to other parties and amendment for any purpose not excluding
 *    product development provided that any such use et cetera
 *    shall be deemed to be acceptance of the following conditions:-
 *
 *        (1) Its Recipients shall ensure that this Notice is
 *        reproduced upon any copies or amended versions of it;
 *
 *        (2) Any amended version of it shall be clearly marked to
 *        show both the nature of and the organisation responsible
 *        for the relevant amendment or amendments;
 *
 *        (3) Its onward transfer from a recipient to another
 *        party shall be deemed to be that party's acceptance of
 *        these conditions;
 *
 *        (4) DERA gives no warranty or assurance as to its
 *        quality or suitability for any purpose and DERA accepts
 *        no liability whatsoever in relation to any use to which
 *        it may be put.
 *
 * $TenDRA: tendra/src/producers/common/parse/parse.h,v 1.6 2005/10/16 07:47:46 stefanf Exp $
 */


#ifndef PARSE_INCLUDED
#define PARSE_INCLUDED


/*
 *    TYPE REPRESENTING A PARSER STATE
 *
 *    This type is used to represent the information to be saved before the
 *    separate compilation of any saved preprocessing tokens and restored
 *    afterwards.
 */

typedef struct pstate_tag {
	LOCATION loc;
	OPTIONS *opts;
	int flag [10];
	DECL_SPEC dspec [2];
	NAMESPACE nspace [2];
	STACK (NAMESPACE) nstack [3];
} PARSE_STATE;


/*
 *    TOKEN EXPANSION STATES
 *
 *    These values are used as arguments to expand_token to indicate the
 *    current parsing state.
 */

#define EXPAND_NORMAL			0
#define EXPAND_AHEAD			1
#define EXPAND_RESCAN			2
#define EXPAND_TEMPLATE			3
#define EXPAND_IDENTIFIER		4
#define EXPAND_COLON_COLON		5
#define EXPAND_CHECK_COLON		6
#define EXPAND_DESTRUCTOR		7
#define EXPAND_STRING			8
#define EXPAND_PRAGMA			9


/*
 *    TOKEN PARSER DECLARATIONS
 *
 *    The routines in this module are concerned with reading the next lexical
 *    token from the input file.  They include expand_token which is the top
 *    level lexical analysis and preprocessing routine.
 */

extern void init_parser(PPTOKEN *);
extern int expand_token(int);
extern int expand_preproc(int);
extern void rescan_template(NAMESPACE);
extern PPTOKEN *patch_tokens(int);
extern PPTOKEN *restore_parser(void);
extern PPTOKEN *read_loc_tokens(PPTOKEN *);
extern void snip_tokens(PPTOKEN *, PPTOKEN *);
extern void save_state(PARSE_STATE *, int);
extern void restore_state(PARSE_STATE *);
extern int crt_state_depth;


/*
 *    CURRENT TOKEN INFORMATION
 *
 *    These variables are used to store information about the current lexical
 *    token as read by expand_token.  crt_lex_token gives the current token
 *    number, with any additional information being stored in crt_token.
 *    last_lex_token gives the previous value of crt_lex_token.  Finally
 *    saved_lex_token is used as a temporary store in exception handling.
 */

extern PPTOKEN *crt_token;
extern NAMESPACE crt_lookup;
extern int crt_lex_token;
extern int saved_lex_token;
extern int last_lex_token;
extern int have_syntax_error;


/*
 *    PARSER MACROS
 *
 *    These macros are used by the SID parser to access the output of the
 *    lexical analysis and preprocessing routines.  CURRENT_TERMINAL gives
 *    the value of the current lexical token.  ADVANCE_LEXER reads the next
 *    lexical token.  RESCAN_LEXER rescans the current token.  SAVE_LEXER
 *    and RESTORE_LEXER are used in exception handling.
 */

#define CURRENT_TERMINAL	crt_lex_token
#define RESTORE_LEXER		crt_lex_token = saved_lex_token;
#define next_token()		expand_token (EXPAND_AHEAD)
#define RESCAN_LEXER		crt_lex_token = expand_token (EXPAND_RESCAN)

#define ADVANCE_LEXER\
	{\
	last_lex_token = crt_lex_token;\
	crt_lex_token = expand_token (EXPAND_NORMAL);\
	}


#define SAVE_LEXER(T)\
	{\
	saved_lex_token = crt_lex_token;\
	crt_lex_token = (T);\
	}


#endif


syntax highlighted by Code2HTML, v. 0.9.1