NetBSD/gnu/usr.bin/groff/troff/token.h
1993-03-21 09:45:37 +00:00

219 lines
4.8 KiB
C++

// -*- C++ -*-
/* Copyright (C) 1989, 1990 Free Software Foundation, Inc.
Written by James Clark (jjc@jclark.uucp)
This file is part of groff.
groff 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 1, or (at your option) any later
version.
groff 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 groff; see the file LICENSE. If not, write to the Free Software
Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
struct charinfo;
struct node;
struct vunits;
// See ARM p251.
static void process_input_stack();
class token {
symbol nm;
node *nd;
unsigned char c;
int val;
units dim;
enum token_type {
TOKEN_BACKSPACE,
TOKEN_BEGIN_TRAP,
TOKEN_CHAR, // a normal printing character
TOKEN_CHAR_HEIGHT, // \H
TOKEN_CHAR_SLANT, // \S
TOKEN_DUMMY,
TOKEN_EMPTY, // this is the initial value
TOKEN_END_TRAP,
TOKEN_ESCAPE, // \e
TOKEN_FONT_NAME, // \f followed by a name
TOKEN_FONT_POSITION, // \f followed by a digit
TOKEN_HYPHEN_INDICATOR,
TOKEN_INTERRUPT, // \c
TOKEN_ITALIC_CORRECTION, // \/
TOKEN_LEADER, // ^A
TOKEN_LEFT_BRACE,
TOKEN_MARK_INPUT, // \k -- `nm' is the name of the register
TOKEN_NEWLINE, // newline
TOKEN_NODE,
TOKEN_NUMBERED_CHAR,
TOKEN_PAGE_EJECTOR,
TOKEN_REQUEST,
TOKEN_RIGHT_BRACE,
TOKEN_SIZE, // \s
TOKEN_SPACE, // ` ' -- ordinary space
TOKEN_SPECIAL, // a special character -- \' \` \- \(xx
TOKEN_SPREAD, // \p -- break and spread output line
TOKEN_TAB, // tab
TOKEN_TRANSPARENT, // \!
TOKEN_EOF // end of file
} type;
public:
token();
~token();
token(const token &);
void operator=(const token &);
void next();
void process();
void skip();
int eof();
int nspaces(); // 1 if space, 2 if double space, 0 otherwise
int space(); // is it a space or double space?
int white_space(); // is the current token space or tab?
int newline(); // is the current token a newline?
int tab(); // is the current token a tab?
int leader();
int backspace();
int delimiter(int warn = 0); // is it suitable for use as a delimiter?
symbol special();
int dummy();
int transparent();
int left_brace();
int right_brace();
int page_ejector();
int operator==(const token &); // need this for delimiters, and for conditions
int operator!=(const token &); // ditto
unsigned char ch();
charinfo *get_char(int required = 0);
int add_to_node_list(node **);
int changes_env();
int is_size();
int title();
void make_space();
void make_newline();
const char *description();
friend void process_input_stack();
};
extern token tok; // the current token
extern symbol get_name(int required = 0);
extern symbol get_long_name(int required = 0);
extern charinfo *get_optional_char();
extern void skip_line();
extern void handle_initial_title();
struct hunits;
extern void read_title_parts(node **part, hunits *part_width);
extern int get_number(units *result, unsigned char si);
extern int get_integer(int *result);
extern int get_number(units *result, unsigned char si, units prev_value);
extern int get_integer(int *result, int prev_value);
void interpolate_number_reg(symbol, int);
const char *asciify(int c);
inline int token::newline()
{
return type == TOKEN_NEWLINE;
}
inline int token::space()
{
return type == TOKEN_SPACE;
}
inline int token::nspaces()
{
if (type == TOKEN_SPACE)
return 1;
else
return 0;
}
inline int token::white_space()
{
return type == TOKEN_SPACE || type == TOKEN_TAB;
}
inline int token::transparent()
{
return type == TOKEN_TRANSPARENT;
}
inline int token::page_ejector()
{
return type == TOKEN_PAGE_EJECTOR;
}
inline unsigned char token::ch()
{
return type == TOKEN_CHAR ? c : 0;
}
inline int token::eof()
{
return type == TOKEN_EOF;
}
inline symbol token::special()
{
return type == TOKEN_SPECIAL ? nm : symbol();
}
inline int token::dummy()
{
return type == TOKEN_DUMMY;
}
inline int token::is_size()
{
return type == TOKEN_SIZE;
}
inline int token::left_brace()
{
return type == TOKEN_LEFT_BRACE;
}
inline int token::right_brace()
{
return type == TOKEN_RIGHT_BRACE;
}
inline int token::changes_env()
{
return (type == TOKEN_CHAR_HEIGHT
|| type == TOKEN_CHAR_SLANT
|| type == TOKEN_FONT_NAME
|| type == TOKEN_FONT_POSITION
|| type == TOKEN_SIZE);
}
inline int token::tab()
{
return type == TOKEN_TAB;
}
inline int token::leader()
{
return type == TOKEN_LEADER;
}
inline int token::backspace()
{
return type == TOKEN_BACKSPACE;
}
int has_arg();