1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143
|
/* A Bison parser, made by GNU Bison 3.7.5. */
/* Bison interface for Yacc-like parsers in C
Copyright (C) 1984, 1989-1990, 2000-2015, 2018-2021 Free Software Foundation,
Inc.
This program 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 3 of the License, or
(at your option) any later version.
This program 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.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>. */
/* As a special exception, you may create a larger work that contains
part or all of the Bison parser skeleton and distribute that work
under terms of your choice, so long as that work isn't itself a
parser generator using the skeleton or a modified version thereof
as a parser skeleton. Alternatively, if you modify or redistribute
the parser skeleton itself, you may (at your option) remove this
special exception, which will cause the skeleton and the resulting
Bison output files to be licensed under the GNU General Public
License without this special exception.
This special exception was added by the Free Software Foundation in
version 2.2 of Bison. */
/* DO NOT RELY ON FEATURES THAT ARE NOT DOCUMENTED in the manual,
especially those whose name start with YY_ or yy_. They are
private implementation details that can be changed or removed. */
#ifndef YY_OCTAVE_TEX_LIBINTERP_COREFCN_OCT_TEX_PARSER_H_INCLUDED
# define YY_OCTAVE_TEX_LIBINTERP_COREFCN_OCT_TEX_PARSER_H_INCLUDED
/* Debug traces. */
#ifndef OCTAVE_TEX_DEBUG
# if defined YYDEBUG
#if YYDEBUG
# define OCTAVE_TEX_DEBUG 1
# else
# define OCTAVE_TEX_DEBUG 0
# endif
# else /* ! defined YYDEBUG */
# define OCTAVE_TEX_DEBUG 0
# endif /* ! defined YYDEBUG */
#endif /* ! defined OCTAVE_TEX_DEBUG */
#if OCTAVE_TEX_DEBUG
extern int octave_tex_debug;
#endif
/* "%code requires" blocks. */
#line 62 "../libinterp/corefcn/oct-tex-parser.yy"
#include <string>
#line 60 "libinterp/corefcn/oct-tex-parser.h"
/* Token kinds. */
#ifndef OCTAVE_TEX_TOKENTYPE
# define OCTAVE_TEX_TOKENTYPE
enum octave_tex_tokentype
{
OCTAVE_TEX_EMPTY = -2,
OCTAVE_TEX_EOF = 0, /* "end of file" */
OCTAVE_TEX_error = 256, /* error */
OCTAVE_TEX_UNDEF = 257, /* "invalid token" */
BF = 258, /* BF */
IT = 259, /* IT */
SL = 260, /* SL */
RM = 261, /* RM */
FONTNAME = 262, /* FONTNAME */
FONTSIZE = 263, /* FONTSIZE */
COLOR = 264, /* COLOR */
COLOR_RGB = 265, /* COLOR_RGB */
START = 266, /* START */
END = 267, /* END */
SUPER = 268, /* SUPER */
SUB = 269, /* SUB */
CH = 270, /* CH */
NUM = 271, /* NUM */
SYM = 272, /* SYM */
SCRIPT = 273, /* SCRIPT */
STR = 274 /* STR */
};
typedef enum octave_tex_tokentype octave_tex_token_kind_t;
#endif
/* Token kinds. */
#define OCTAVE_TEX_EMPTY -2
#define OCTAVE_TEX_EOF 0
#define OCTAVE_TEX_error 256
#define OCTAVE_TEX_UNDEF 257
#define BF 258
#define IT 259
#define SL 260
#define RM 261
#define FONTNAME 262
#define FONTSIZE 263
#define COLOR 264
#define COLOR_RGB 265
#define START 266
#define END 267
#define SUPER 268
#define SUB 269
#define CH 270
#define NUM 271
#define SYM 272
#define SCRIPT 273
#define STR 274
/* Value type. */
#if ! defined OCTAVE_TEX_STYPE && ! defined OCTAVE_TEX_STYPE_IS_DECLARED
union OCTAVE_TEX_STYPE
{
#line 65 "../libinterp/corefcn/oct-tex-parser.yy"
// Leaf symbols produced by the scanner.
char ch;
double num;
int sym;
// Used for string buffering.
std::string *str;
// Objects produced by the parser.
octave::text_element *e_base;
octave::text_element_list *e_list;
#line 132 "libinterp/corefcn/oct-tex-parser.h"
};
typedef union OCTAVE_TEX_STYPE OCTAVE_TEX_STYPE;
# define OCTAVE_TEX_STYPE_IS_TRIVIAL 1
# define OCTAVE_TEX_STYPE_IS_DECLARED 1
#endif
int octave_tex_parse (octave::text_parser_tex& parser);
#endif /* !YY_OCTAVE_TEX_LIBINTERP_COREFCN_OCT_TEX_PARSER_H_INCLUDED */
|