Blame glib/gscanner.h

Packit ae235b
/* GLIB - Library of useful routines for C programming
Packit ae235b
 * Copyright (C) 1995-1997  Peter Mattis, Spencer Kimball and Josh MacDonald
Packit ae235b
 *
Packit ae235b
 * This library is free software; you can redistribute it and/or
Packit ae235b
 * modify it under the terms of the GNU Lesser General Public
Packit ae235b
 * License as published by the Free Software Foundation; either
Packit ae235b
 * version 2.1 of the License, or (at your option) any later version.
Packit ae235b
 *
Packit ae235b
 * This library is distributed in the hope that it will be useful,
Packit ae235b
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit ae235b
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.	 See the GNU
Packit ae235b
 * Lesser General Public License for more details.
Packit ae235b
 *
Packit ae235b
 * You should have received a copy of the GNU Lesser General Public
Packit ae235b
 * License along with this library; if not, see <http://www.gnu.org/licenses/>.
Packit ae235b
 */
Packit ae235b
Packit ae235b
/*
Packit ae235b
 * Modified by the GLib Team and others 1997-2000.  See the AUTHORS
Packit ae235b
 * file for a list of people on the GLib Team.  See the ChangeLog
Packit ae235b
 * files for a list of changes.  These files are distributed with
Packit ae235b
 * GLib at ftp://ftp.gtk.org/pub/gtk/.
Packit ae235b
 */
Packit ae235b
Packit ae235b
#ifndef __G_SCANNER_H__
Packit ae235b
#define __G_SCANNER_H__
Packit ae235b
Packit ae235b
#if !defined (__GLIB_H_INSIDE__) && !defined (GLIB_COMPILATION)
Packit ae235b
#error "Only <glib.h> can be included directly."
Packit ae235b
#endif
Packit ae235b
Packit ae235b
#include <glib/gdataset.h>
Packit ae235b
#include <glib/ghash.h>
Packit ae235b
Packit ae235b
G_BEGIN_DECLS
Packit ae235b
Packit ae235b
typedef struct _GScanner	GScanner;
Packit ae235b
typedef struct _GScannerConfig	GScannerConfig;
Packit ae235b
typedef union  _GTokenValue     GTokenValue;
Packit ae235b
Packit ae235b
typedef void		(*GScannerMsgFunc)	(GScanner      *scanner,
Packit ae235b
						 gchar	       *message,
Packit ae235b
						 gboolean	error);
Packit ae235b
Packit ae235b
/* GScanner: Flexible lexical scanner for general purpose.
Packit ae235b
 */
Packit ae235b
Packit ae235b
/* Character sets */
Packit ae235b
#define G_CSET_A_2_Z	"ABCDEFGHIJKLMNOPQRSTUVWXYZ"
Packit ae235b
#define G_CSET_a_2_z	"abcdefghijklmnopqrstuvwxyz"
Packit ae235b
#define G_CSET_DIGITS	"0123456789"
Packit ae235b
#define G_CSET_LATINC	"\300\301\302\303\304\305\306"\
Packit ae235b
			"\307\310\311\312\313\314\315\316\317\320"\
Packit ae235b
			"\321\322\323\324\325\326"\
Packit ae235b
			"\330\331\332\333\334\335\336"
Packit ae235b
#define G_CSET_LATINS	"\337\340\341\342\343\344\345\346"\
Packit ae235b
			"\347\350\351\352\353\354\355\356\357\360"\
Packit ae235b
			"\361\362\363\364\365\366"\
Packit ae235b
			"\370\371\372\373\374\375\376\377"
Packit ae235b
Packit ae235b
/* Error types */
Packit ae235b
typedef enum
Packit ae235b
{
Packit ae235b
  G_ERR_UNKNOWN,
Packit ae235b
  G_ERR_UNEXP_EOF,
Packit ae235b
  G_ERR_UNEXP_EOF_IN_STRING,
Packit ae235b
  G_ERR_UNEXP_EOF_IN_COMMENT,
Packit ae235b
  G_ERR_NON_DIGIT_IN_CONST,
Packit ae235b
  G_ERR_DIGIT_RADIX,
Packit ae235b
  G_ERR_FLOAT_RADIX,
Packit ae235b
  G_ERR_FLOAT_MALFORMED
Packit ae235b
} GErrorType;
Packit ae235b
Packit ae235b
/* Token types */
Packit ae235b
typedef enum
Packit ae235b
{
Packit ae235b
  G_TOKEN_EOF			=   0,
Packit ae235b
  
Packit ae235b
  G_TOKEN_LEFT_PAREN		= '(',
Packit ae235b
  G_TOKEN_RIGHT_PAREN		= ')',
Packit ae235b
  G_TOKEN_LEFT_CURLY		= '{',
Packit ae235b
  G_TOKEN_RIGHT_CURLY		= '}',
Packit ae235b
  G_TOKEN_LEFT_BRACE		= '[',
Packit ae235b
  G_TOKEN_RIGHT_BRACE		= ']',
Packit ae235b
  G_TOKEN_EQUAL_SIGN		= '=',
Packit ae235b
  G_TOKEN_COMMA			= ',',
Packit ae235b
  
Packit ae235b
  G_TOKEN_NONE			= 256,
Packit ae235b
  
Packit ae235b
  G_TOKEN_ERROR,
Packit ae235b
  
Packit ae235b
  G_TOKEN_CHAR,
Packit ae235b
  G_TOKEN_BINARY,
Packit ae235b
  G_TOKEN_OCTAL,
Packit ae235b
  G_TOKEN_INT,
Packit ae235b
  G_TOKEN_HEX,
Packit ae235b
  G_TOKEN_FLOAT,
Packit ae235b
  G_TOKEN_STRING,
Packit ae235b
  
Packit ae235b
  G_TOKEN_SYMBOL,
Packit ae235b
  G_TOKEN_IDENTIFIER,
Packit ae235b
  G_TOKEN_IDENTIFIER_NULL,
Packit ae235b
  
Packit ae235b
  G_TOKEN_COMMENT_SINGLE,
Packit ae235b
  G_TOKEN_COMMENT_MULTI,
Packit ae235b
Packit ae235b
  /*< private >*/
Packit ae235b
  G_TOKEN_LAST
Packit ae235b
} GTokenType;
Packit ae235b
Packit ae235b
union	_GTokenValue
Packit ae235b
{
Packit ae235b
  gpointer	v_symbol;
Packit ae235b
  gchar		*v_identifier;
Packit ae235b
  gulong	v_binary;
Packit ae235b
  gulong	v_octal;
Packit ae235b
  gulong	v_int;
Packit ae235b
  guint64       v_int64;
Packit ae235b
  gdouble	v_float;
Packit ae235b
  gulong	v_hex;
Packit ae235b
  gchar		*v_string;
Packit ae235b
  gchar		*v_comment;
Packit ae235b
  guchar	v_char;
Packit ae235b
  guint		v_error;
Packit ae235b
};
Packit ae235b
Packit ae235b
struct	_GScannerConfig
Packit ae235b
{
Packit ae235b
  /* Character sets
Packit ae235b
   */
Packit ae235b
  gchar		*cset_skip_characters;		/* default: " \t\n" */
Packit ae235b
  gchar		*cset_identifier_first;
Packit ae235b
  gchar		*cset_identifier_nth;
Packit ae235b
  gchar		*cpair_comment_single;		/* default: "#\n" */
Packit ae235b
  
Packit ae235b
  /* Should symbol lookup work case sensitive?
Packit ae235b
   */
Packit ae235b
  guint		case_sensitive : 1;
Packit ae235b
  
Packit ae235b
  /* Boolean values to be adjusted "on the fly"
Packit ae235b
   * to configure scanning behaviour.
Packit ae235b
   */
Packit ae235b
  guint		skip_comment_multi : 1;		/* C like comment */
Packit ae235b
  guint		skip_comment_single : 1;	/* single line comment */
Packit ae235b
  guint		scan_comment_multi : 1;		/* scan multi line comments? */
Packit ae235b
  guint		scan_identifier : 1;
Packit ae235b
  guint		scan_identifier_1char : 1;
Packit ae235b
  guint		scan_identifier_NULL : 1;
Packit ae235b
  guint		scan_symbols : 1;
Packit ae235b
  guint		scan_binary : 1;
Packit ae235b
  guint		scan_octal : 1;
Packit ae235b
  guint		scan_float : 1;
Packit ae235b
  guint		scan_hex : 1;			/* '0x0ff0' */
Packit ae235b
  guint		scan_hex_dollar : 1;		/* '$0ff0' */
Packit ae235b
  guint		scan_string_sq : 1;		/* string: 'anything' */
Packit ae235b
  guint		scan_string_dq : 1;		/* string: "\\-escapes!\n" */
Packit ae235b
  guint		numbers_2_int : 1;		/* bin, octal, hex => int */
Packit ae235b
  guint		int_2_float : 1;		/* int => G_TOKEN_FLOAT? */
Packit ae235b
  guint		identifier_2_string : 1;
Packit ae235b
  guint		char_2_token : 1;		/* return G_TOKEN_CHAR? */
Packit ae235b
  guint		symbol_2_token : 1;
Packit ae235b
  guint		scope_0_fallback : 1;		/* try scope 0 on lookups? */
Packit ae235b
  guint		store_int64 : 1; 		/* use value.v_int64 rather than v_int */
Packit ae235b
Packit ae235b
  /*< private >*/
Packit ae235b
  guint		padding_dummy;
Packit ae235b
};
Packit ae235b
Packit ae235b
struct	_GScanner
Packit ae235b
{
Packit ae235b
  /* unused fields */
Packit ae235b
  gpointer		user_data;
Packit ae235b
  guint			max_parse_errors;
Packit ae235b
  
Packit ae235b
  /* g_scanner_error() increments this field */
Packit ae235b
  guint			parse_errors;
Packit ae235b
  
Packit ae235b
  /* name of input stream, featured by the default message handler */
Packit ae235b
  const gchar		*input_name;
Packit ae235b
  
Packit ae235b
  /* quarked data */
Packit ae235b
  GData			*qdata;
Packit ae235b
  
Packit ae235b
  /* link into the scanner configuration */
Packit ae235b
  GScannerConfig	*config;
Packit ae235b
  
Packit ae235b
  /* fields filled in after g_scanner_get_next_token() */
Packit ae235b
  GTokenType		token;
Packit ae235b
  GTokenValue		value;
Packit ae235b
  guint			line;
Packit ae235b
  guint			position;
Packit ae235b
  
Packit ae235b
  /* fields filled in after g_scanner_peek_next_token() */
Packit ae235b
  GTokenType		next_token;
Packit ae235b
  GTokenValue		next_value;
Packit ae235b
  guint			next_line;
Packit ae235b
  guint			next_position;
Packit ae235b
Packit ae235b
  /*< private >*/
Packit ae235b
  /* to be considered private */
Packit ae235b
  GHashTable		*symbol_table;
Packit ae235b
  gint			input_fd;
Packit ae235b
  const gchar		*text;
Packit ae235b
  const gchar		*text_end;
Packit ae235b
  gchar			*buffer;
Packit ae235b
  guint			scope_id;
Packit ae235b
Packit ae235b
  /*< public >*/
Packit ae235b
  /* handler function for _warn and _error */
Packit ae235b
  GScannerMsgFunc	msg_handler;
Packit ae235b
};
Packit ae235b
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
GScanner*	g_scanner_new			(const GScannerConfig *config_templ);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
void		g_scanner_destroy		(GScanner	*scanner);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
void		g_scanner_input_file		(GScanner	*scanner,
Packit ae235b
						 gint		input_fd);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
void		g_scanner_sync_file_offset	(GScanner	*scanner);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
void		g_scanner_input_text		(GScanner	*scanner,
Packit ae235b
						 const	gchar	*text,
Packit ae235b
						 guint		text_len);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
GTokenType	g_scanner_get_next_token	(GScanner	*scanner);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
GTokenType	g_scanner_peek_next_token	(GScanner	*scanner);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
GTokenType	g_scanner_cur_token		(GScanner	*scanner);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
GTokenValue	g_scanner_cur_value		(GScanner	*scanner);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
guint		g_scanner_cur_line		(GScanner	*scanner);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
guint		g_scanner_cur_position		(GScanner	*scanner);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
gboolean	g_scanner_eof			(GScanner	*scanner);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
guint		g_scanner_set_scope		(GScanner	*scanner,
Packit ae235b
						 guint		 scope_id);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
void		g_scanner_scope_add_symbol	(GScanner	*scanner,
Packit ae235b
						 guint		 scope_id,
Packit ae235b
						 const gchar	*symbol,
Packit ae235b
						 gpointer	value);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
void		g_scanner_scope_remove_symbol	(GScanner	*scanner,
Packit ae235b
						 guint		 scope_id,
Packit ae235b
						 const gchar	*symbol);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
gpointer	g_scanner_scope_lookup_symbol	(GScanner	*scanner,
Packit ae235b
						 guint		 scope_id,
Packit ae235b
						 const gchar	*symbol);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
void		g_scanner_scope_foreach_symbol	(GScanner	*scanner,
Packit ae235b
						 guint		 scope_id,
Packit ae235b
						 GHFunc		 func,
Packit ae235b
						 gpointer	 user_data);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
gpointer	g_scanner_lookup_symbol		(GScanner	*scanner,
Packit ae235b
						 const gchar	*symbol);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
void		g_scanner_unexp_token		(GScanner	*scanner,
Packit ae235b
						 GTokenType	expected_token,
Packit ae235b
						 const gchar	*identifier_spec,
Packit ae235b
						 const gchar	*symbol_spec,
Packit ae235b
						 const gchar	*symbol_name,
Packit ae235b
						 const gchar	*message,
Packit ae235b
						 gint		 is_error);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
void		g_scanner_error			(GScanner	*scanner,
Packit ae235b
						 const gchar	*format,
Packit ae235b
						 ...) G_GNUC_PRINTF (2,3);
Packit ae235b
GLIB_AVAILABLE_IN_ALL
Packit ae235b
void		g_scanner_warn			(GScanner	*scanner,
Packit ae235b
						 const gchar	*format,
Packit ae235b
						 ...) G_GNUC_PRINTF (2,3);
Packit ae235b
Packit ae235b
#ifndef G_DISABLE_DEPRECATED
Packit ae235b
Packit ae235b
/* keep downward source compatibility */
Packit ae235b
#define		g_scanner_add_symbol( scanner, symbol, value )	G_STMT_START { \
Packit ae235b
  g_scanner_scope_add_symbol ((scanner), 0, (symbol), (value)); \
Packit ae235b
} G_STMT_END
Packit ae235b
#define		g_scanner_remove_symbol( scanner, symbol )	G_STMT_START { \
Packit ae235b
  g_scanner_scope_remove_symbol ((scanner), 0, (symbol)); \
Packit ae235b
} G_STMT_END
Packit ae235b
#define		g_scanner_foreach_symbol( scanner, func, data )	G_STMT_START { \
Packit ae235b
  g_scanner_scope_foreach_symbol ((scanner), 0, (func), (data)); \
Packit ae235b
} G_STMT_END
Packit ae235b
Packit ae235b
/* The following two functions are deprecated and will be removed in
Packit ae235b
 * the next major release. They do no good. */
Packit ae235b
#define g_scanner_freeze_symbol_table(scanner) ((void)0)
Packit ae235b
#define g_scanner_thaw_symbol_table(scanner) ((void)0)
Packit ae235b
Packit ae235b
#endif /* G_DISABLE_DEPRECATED */
Packit ae235b
Packit ae235b
G_END_DECLS
Packit ae235b
Packit ae235b
#endif /* __G_SCANNER_H__ */