54 lines
1.8 KiB
C

/* cmds.h -- declarations for cmds.c.
$Id: cmds.h,v 1.3 2002/11/04 22:15:19 karl Exp $
Copyright (C) 1998, 1999, 2002 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 2, 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, write to the Free Software Foundation, Inc.,
59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
#ifndef CMDS_H
#define CMDS_H
/* The three arguments a command can get are a flag saying whether it is
before argument parsing (START) or after (END), the starting position
of the arguments, and the ending position. */
typedef void COMMAND_FUNCTION (); /* So we can say COMMAND_FUNCTION *foo; */
/* Each command has an associated function. When the command is
encountered in the text, the associated function is called with START
as the argument. If the function expects arguments in braces, it
remembers itself on the stack. When the corresponding close brace is
encountered, the function is called with END as the argument. */
#define START 0
#define END 1
/* Does the command expect braces? */
#define NO_BRACE_ARGS 0
#define BRACE_ARGS 1
#define MAYBE_BRACE_ARGS 2
typedef struct
{
char *name;
COMMAND_FUNCTION *proc;
int argument_in_braces;
} COMMAND;
extern COMMAND command_table[];
/* Nonzero if we have seen an @titlepage command. */
extern int titlepage_cmd_present;
#endif /* !CMDS_H */