2000-01-17 10:39:58 +00:00
|
|
|
|
/* cmds.c -- Texinfo commands.
|
2005-05-23 10:46:22 +00:00
|
|
|
|
$Id: cmds.c,v 1.55 2004/12/14 00:15:36 karl Exp $
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003, 2004 Free Software
|
2003-05-02 00:48:41 +00:00
|
|
|
|
Foundation, Inc.
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
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. */
|
|
|
|
|
|
|
|
|
|
#include "system.h"
|
|
|
|
|
#include "cmds.h"
|
|
|
|
|
#include "defun.h"
|
|
|
|
|
#include "files.h"
|
|
|
|
|
#include "footnote.h"
|
2003-05-02 00:48:41 +00:00
|
|
|
|
#include "html.h"
|
2000-01-17 10:39:58 +00:00
|
|
|
|
#include "insertion.h"
|
|
|
|
|
#include "lang.h"
|
|
|
|
|
#include "macro.h"
|
|
|
|
|
#include "makeinfo.h"
|
|
|
|
|
#include "node.h"
|
|
|
|
|
#include "sectioning.h"
|
|
|
|
|
#include "toc.h"
|
2002-03-25 13:08:32 +00:00
|
|
|
|
#include "xml.h"
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
#ifdef TM_IN_SYS_TIME
|
|
|
|
|
#include <sys/time.h>
|
|
|
|
|
#else
|
|
|
|
|
#include <time.h>
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
/* Options. */
|
2005-05-23 10:46:22 +00:00
|
|
|
|
static void cm_exampleindent (void),
|
|
|
|
|
cm_firstparagraphindent (void),
|
|
|
|
|
cm_paragraphindent (void),
|
|
|
|
|
cm_novalidate (void);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
/* Internals. */
|
2005-05-23 10:46:22 +00:00
|
|
|
|
static void cm_obsolete (int arg, int start, int end),
|
|
|
|
|
not_fixed_width (int arg);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
/* The dispatch table. */
|
|
|
|
|
COMMAND command_table[] = {
|
|
|
|
|
{ "\t", insert_space, NO_BRACE_ARGS },
|
|
|
|
|
{ "\n", insert_space, NO_BRACE_ARGS },
|
2002-03-25 13:08:32 +00:00
|
|
|
|
{ " ", insert_space, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "!", cm_punct, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "\"", cm_accent_umlaut, MAYBE_BRACE_ARGS },
|
|
|
|
|
{ "'", cm_accent_acute, MAYBE_BRACE_ARGS },
|
|
|
|
|
{ "*", cm_asterisk, NO_BRACE_ARGS },
|
|
|
|
|
{ ",", cm_accent_cedilla, MAYBE_BRACE_ARGS },
|
|
|
|
|
{ "-", cm_no_op, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ ".", cm_punct, NO_BRACE_ARGS },
|
2003-06-18 12:57:43 +00:00
|
|
|
|
{ "/", cm_no_op, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ ":", cm_colon, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "=", cm_accent, MAYBE_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "?", cm_punct, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "@", insert_self, NO_BRACE_ARGS },
|
2002-07-22 16:52:57 +00:00
|
|
|
|
{ "\\", insert_self, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "^", cm_accent_hat, MAYBE_BRACE_ARGS },
|
|
|
|
|
{ "`", cm_accent_grave, MAYBE_BRACE_ARGS },
|
|
|
|
|
{ "{", insert_self, NO_BRACE_ARGS },
|
|
|
|
|
{ "|", cm_no_op, NO_BRACE_ARGS },
|
|
|
|
|
{ "}", insert_self, NO_BRACE_ARGS },
|
|
|
|
|
{ "~", cm_accent_tilde, MAYBE_BRACE_ARGS },
|
|
|
|
|
{ "AA", cm_special_char, BRACE_ARGS },
|
|
|
|
|
{ "AE", cm_special_char, BRACE_ARGS },
|
|
|
|
|
{ "H", cm_accent, MAYBE_BRACE_ARGS },
|
|
|
|
|
{ "L", cm_special_char, BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "LaTeX", cm_LaTeX, BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "O", cm_special_char, BRACE_ARGS },
|
|
|
|
|
{ "OE", cm_special_char, BRACE_ARGS },
|
|
|
|
|
{ "TeX", cm_TeX, BRACE_ARGS },
|
|
|
|
|
{ "aa", cm_special_char, BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "abbr", cm_abbr, BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "acronym", cm_acronym, BRACE_ARGS },
|
|
|
|
|
{ "ae", cm_special_char, BRACE_ARGS },
|
2002-03-25 13:08:32 +00:00
|
|
|
|
{ "afivepaper", cm_ignore_line, NO_BRACE_ARGS },
|
|
|
|
|
{ "afourlatex", cm_ignore_line, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "afourpaper", cm_ignore_line, NO_BRACE_ARGS },
|
2002-03-25 13:08:32 +00:00
|
|
|
|
{ "afourwide", cm_ignore_line, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "alias", cm_alias, NO_BRACE_ARGS },
|
|
|
|
|
{ "anchor", cm_anchor, BRACE_ARGS },
|
|
|
|
|
{ "appendix", cm_appendix, NO_BRACE_ARGS },
|
|
|
|
|
{ "appendixsection", cm_appendixsec, NO_BRACE_ARGS },
|
|
|
|
|
{ "appendixsec", cm_appendixsec, NO_BRACE_ARGS },
|
|
|
|
|
{ "appendixsubsec", cm_appendixsubsec, NO_BRACE_ARGS },
|
|
|
|
|
{ "appendixsubsubsec", cm_appendixsubsubsec, NO_BRACE_ARGS },
|
|
|
|
|
{ "asis", cm_no_op, BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "author", cm_author, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "b", cm_b, BRACE_ARGS },
|
|
|
|
|
{ "bullet", cm_bullet, BRACE_ARGS },
|
|
|
|
|
{ "bye", cm_bye, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "c", cm_comment, NO_BRACE_ARGS },
|
|
|
|
|
{ "caption", cm_caption, BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "cartouche", cm_cartouche, NO_BRACE_ARGS },
|
|
|
|
|
{ "center", cm_center, NO_BRACE_ARGS },
|
|
|
|
|
{ "centerchap", cm_unnumbered, NO_BRACE_ARGS },
|
|
|
|
|
{ "chapheading", cm_chapheading, NO_BRACE_ARGS },
|
|
|
|
|
{ "chapter", cm_chapter, NO_BRACE_ARGS },
|
|
|
|
|
{ "cindex", cm_cindex, NO_BRACE_ARGS },
|
|
|
|
|
{ "cite", cm_cite, BRACE_ARGS },
|
|
|
|
|
{ "clear", cm_clear, NO_BRACE_ARGS },
|
|
|
|
|
{ "code", cm_code, BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "comma", cm_comma, BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "command", cm_code, BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "comment", cm_comment, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "contents", cm_contents, NO_BRACE_ARGS },
|
2002-07-22 16:52:57 +00:00
|
|
|
|
{ "copying", cm_copying, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "copyright", cm_copyright, BRACE_ARGS },
|
|
|
|
|
{ "ctrl", cm_obsolete, BRACE_ARGS },
|
|
|
|
|
{ "defcodeindex", cm_defcodeindex, NO_BRACE_ARGS },
|
|
|
|
|
{ "defcv", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defcvx", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "deffn", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "deffnx", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defindex", cm_defindex, NO_BRACE_ARGS },
|
|
|
|
|
{ "definfoenclose", cm_definfoenclose, NO_BRACE_ARGS },
|
|
|
|
|
{ "defivar", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defivarx", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defmac", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defmacx", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defmethod", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defmethodx", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defop", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defopt", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defoptx", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defopx", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defspec", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defspecx", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "deftp", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "deftpx", cm_defun, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "deftypecv", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "deftypecvx", cm_defun, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "deftypefn", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "deftypefnx", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "deftypefun", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "deftypefunx", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "deftypeivar", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "deftypeivarx", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "deftypemethod", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "deftypemethodx", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "deftypeop", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "deftypeopx", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "deftypevar", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "deftypevarx", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "deftypevr", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "deftypevrx", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defun", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defunx", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defvar", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defvarx", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defvr", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "defvrx", cm_defun, NO_BRACE_ARGS },
|
|
|
|
|
{ "detailmenu", cm_detailmenu, NO_BRACE_ARGS },
|
|
|
|
|
{ "dfn", cm_dfn, BRACE_ARGS },
|
|
|
|
|
{ "dircategory", cm_dircategory, NO_BRACE_ARGS },
|
|
|
|
|
{ "direntry", cm_direntry, NO_BRACE_ARGS },
|
|
|
|
|
{ "display", cm_display, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "dmn", cm_dmn, BRACE_ARGS },
|
|
|
|
|
{ "docbook", cm_docbook, NO_BRACE_ARGS },
|
2002-03-25 13:08:32 +00:00
|
|
|
|
{ "documentdescription", cm_documentdescription, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "documentencoding", cm_documentencoding, NO_BRACE_ARGS },
|
|
|
|
|
{ "documentlanguage", cm_documentlanguage, NO_BRACE_ARGS },
|
|
|
|
|
{ "dotaccent", cm_accent, MAYBE_BRACE_ARGS },
|
|
|
|
|
{ "dotless", cm_dotless, BRACE_ARGS },
|
|
|
|
|
{ "dots", cm_dots, BRACE_ARGS },
|
|
|
|
|
{ "email", cm_email, BRACE_ARGS },
|
|
|
|
|
{ "emph", cm_emph, BRACE_ARGS },
|
|
|
|
|
{ "end", cm_end, NO_BRACE_ARGS },
|
|
|
|
|
{ "enddots", cm_enddots, BRACE_ARGS },
|
|
|
|
|
{ "enumerate", cm_enumerate, NO_BRACE_ARGS },
|
|
|
|
|
{ "env", cm_code, BRACE_ARGS },
|
|
|
|
|
{ "equiv", cm_equiv, BRACE_ARGS },
|
|
|
|
|
{ "error", cm_error, BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "euro", cm_special_char, BRACE_ARGS },
|
2002-07-22 16:52:57 +00:00
|
|
|
|
{ "evenfooting", cm_ignore_line, NO_BRACE_ARGS },
|
|
|
|
|
{ "evenheading", cm_ignore_line, NO_BRACE_ARGS },
|
|
|
|
|
{ "everyfooting", cm_ignore_line, NO_BRACE_ARGS },
|
|
|
|
|
{ "everyheading", cm_ignore_line, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "example", cm_example, NO_BRACE_ARGS },
|
|
|
|
|
{ "exampleindent", cm_exampleindent, NO_BRACE_ARGS },
|
|
|
|
|
{ "exclamdown", cm_special_char, BRACE_ARGS },
|
|
|
|
|
{ "exdent", cm_exdent, NO_BRACE_ARGS },
|
|
|
|
|
{ "expansion", cm_expansion, BRACE_ARGS },
|
|
|
|
|
{ "file", cm_code, BRACE_ARGS },
|
|
|
|
|
{ "finalout", cm_no_op, NO_BRACE_ARGS },
|
|
|
|
|
{ "findex", cm_findex, NO_BRACE_ARGS },
|
2003-06-18 12:57:43 +00:00
|
|
|
|
{ "firstparagraphindent", cm_firstparagraphindent, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "float", cm_float, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "flushleft", cm_flushleft, NO_BRACE_ARGS },
|
|
|
|
|
{ "flushright", cm_flushright, NO_BRACE_ARGS },
|
|
|
|
|
{ "footnote", cm_footnote, NO_BRACE_ARGS}, /* self-arg eater */
|
|
|
|
|
{ "footnotestyle", cm_footnotestyle, NO_BRACE_ARGS },
|
|
|
|
|
{ "format", cm_format, NO_BRACE_ARGS },
|
|
|
|
|
{ "ftable", cm_ftable, NO_BRACE_ARGS },
|
|
|
|
|
{ "group", cm_group, NO_BRACE_ARGS },
|
|
|
|
|
{ "heading", cm_heading, NO_BRACE_ARGS },
|
|
|
|
|
{ "headings", cm_ignore_line, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "headitem", cm_headitem, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "html", cm_html, NO_BRACE_ARGS },
|
|
|
|
|
{ "hyphenation", cm_ignore_arg, BRACE_ARGS },
|
|
|
|
|
{ "i", cm_i, BRACE_ARGS },
|
|
|
|
|
{ "ifclear", cm_ifclear, NO_BRACE_ARGS },
|
|
|
|
|
{ "ifeq", cm_ifeq, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "ifdocbook", cm_ifdocbook, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "ifhtml", cm_ifhtml, NO_BRACE_ARGS },
|
|
|
|
|
{ "ifinfo", cm_ifinfo, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "ifnotdocbook", cm_ifnotdocbook, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "ifnothtml", cm_ifnothtml, NO_BRACE_ARGS },
|
|
|
|
|
{ "ifnotinfo", cm_ifnotinfo, NO_BRACE_ARGS },
|
2002-07-22 16:52:57 +00:00
|
|
|
|
{ "ifnotplaintext", cm_ifnotplaintext, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "ifnottex", cm_ifnottex, NO_BRACE_ARGS },
|
2003-05-02 00:48:41 +00:00
|
|
|
|
{ "ifnotxml", cm_ifnotxml, NO_BRACE_ARGS },
|
2002-07-22 16:52:57 +00:00
|
|
|
|
{ "ifplaintext", cm_ifplaintext, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "ifset", cm_ifset, NO_BRACE_ARGS },
|
|
|
|
|
{ "iftex", cm_iftex, NO_BRACE_ARGS },
|
2003-05-02 00:48:41 +00:00
|
|
|
|
{ "ifxml", cm_ifxml, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "ignore", command_name_condition, NO_BRACE_ARGS },
|
|
|
|
|
{ "image", cm_image, BRACE_ARGS },
|
|
|
|
|
{ "include", cm_include, NO_BRACE_ARGS },
|
2003-06-18 12:57:43 +00:00
|
|
|
|
{ "indent", cm_indent, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "indicateurl", cm_indicate_url, BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "inforef", cm_inforef, BRACE_ARGS },
|
2002-07-22 16:52:57 +00:00
|
|
|
|
{ "insertcopying", cm_insert_copying, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "item", cm_item, NO_BRACE_ARGS },
|
|
|
|
|
{ "itemize", cm_itemize, NO_BRACE_ARGS },
|
|
|
|
|
{ "itemx", cm_itemx, NO_BRACE_ARGS },
|
|
|
|
|
{ "kbd", cm_kbd, BRACE_ARGS },
|
|
|
|
|
{ "kbdinputstyle", cm_ignore_line, NO_BRACE_ARGS },
|
|
|
|
|
{ "key", cm_key, BRACE_ARGS },
|
|
|
|
|
{ "kindex", cm_kindex, NO_BRACE_ARGS },
|
|
|
|
|
{ "l", cm_special_char, BRACE_ARGS },
|
|
|
|
|
{ "lisp", cm_lisp, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "listoffloats", cm_listoffloats, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "lowersections", cm_lowersections, NO_BRACE_ARGS },
|
|
|
|
|
{ "macro", cm_macro, NO_BRACE_ARGS },
|
|
|
|
|
{ "majorheading", cm_majorheading, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "math", cm_math, BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "menu", cm_menu, NO_BRACE_ARGS },
|
|
|
|
|
{ "minus", cm_minus, BRACE_ARGS },
|
|
|
|
|
{ "multitable", cm_multitable, NO_BRACE_ARGS },
|
|
|
|
|
{ "need", cm_ignore_line, NO_BRACE_ARGS },
|
|
|
|
|
{ "node", cm_node, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "noindent", cm_noindent_cmd, NO_BRACE_ARGS },
|
2003-06-18 12:57:43 +00:00
|
|
|
|
{ "novalidate", cm_novalidate, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "nwnode", cm_node, NO_BRACE_ARGS },
|
|
|
|
|
{ "o", cm_special_char, BRACE_ARGS },
|
2002-07-22 16:52:57 +00:00
|
|
|
|
{ "oddfooting", cm_ignore_line, NO_BRACE_ARGS },
|
|
|
|
|
{ "oddheading", cm_ignore_line, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "oe", cm_special_char, BRACE_ARGS },
|
|
|
|
|
{ "option", cm_code, BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "ordf", cm_special_char, BRACE_ARGS },
|
|
|
|
|
{ "ordm", cm_special_char, BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "page", cm_no_op, NO_BRACE_ARGS },
|
|
|
|
|
{ "pagesizes", cm_ignore_line, NO_BRACE_ARGS },
|
|
|
|
|
{ "paragraphindent", cm_paragraphindent, NO_BRACE_ARGS },
|
|
|
|
|
{ "pindex", cm_pindex, NO_BRACE_ARGS },
|
|
|
|
|
{ "point", cm_point, BRACE_ARGS },
|
|
|
|
|
{ "pounds", cm_special_char, BRACE_ARGS },
|
|
|
|
|
{ "print", cm_print, BRACE_ARGS },
|
|
|
|
|
{ "printindex", cm_printindex, NO_BRACE_ARGS },
|
|
|
|
|
{ "pxref", cm_pxref, BRACE_ARGS },
|
|
|
|
|
{ "questiondown", cm_special_char, BRACE_ARGS },
|
|
|
|
|
{ "quotation", cm_quotation, NO_BRACE_ARGS },
|
|
|
|
|
{ "r", cm_r, BRACE_ARGS },
|
|
|
|
|
{ "raisesections", cm_raisesections, NO_BRACE_ARGS },
|
|
|
|
|
{ "ref", cm_ref, BRACE_ARGS },
|
|
|
|
|
{ "refill", cm_no_op, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "registeredsymbol", cm_registeredsymbol, BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "result", cm_result, BRACE_ARGS },
|
|
|
|
|
{ "ringaccent", cm_accent, MAYBE_BRACE_ARGS },
|
|
|
|
|
{ "rmacro", cm_rmacro, NO_BRACE_ARGS },
|
|
|
|
|
{ "samp", cm_code, BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "sansserif", cm_sansserif, BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "sc", cm_sc, BRACE_ARGS },
|
|
|
|
|
{ "section", cm_section, NO_BRACE_ARGS },
|
|
|
|
|
{ "set", cm_set, NO_BRACE_ARGS },
|
|
|
|
|
{ "setchapternewpage", cm_ignore_line, NO_BRACE_ARGS },
|
|
|
|
|
{ "setchapterstyle", cm_obsolete, NO_BRACE_ARGS },
|
|
|
|
|
{ "setcontentsaftertitlepage", cm_no_op, NO_BRACE_ARGS },
|
|
|
|
|
{ "setfilename", cm_setfilename, NO_BRACE_ARGS },
|
|
|
|
|
{ "setshortcontentsaftertitlepage", cm_no_op, NO_BRACE_ARGS },
|
|
|
|
|
{ "settitle", cm_settitle, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "shortcaption", cm_caption, BRACE_ARGS },
|
|
|
|
|
{ "shortcontents", cm_contents, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "shorttitlepage", cm_ignore_line, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "slanted", cm_slanted, BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "smallbook", cm_ignore_line, NO_BRACE_ARGS },
|
|
|
|
|
{ "smalldisplay", cm_smalldisplay, NO_BRACE_ARGS },
|
|
|
|
|
{ "smallexample", cm_smallexample, NO_BRACE_ARGS },
|
|
|
|
|
{ "smallformat", cm_smallformat, NO_BRACE_ARGS },
|
|
|
|
|
{ "smalllisp", cm_smalllisp, NO_BRACE_ARGS },
|
|
|
|
|
{ "sp", cm_sp, NO_BRACE_ARGS },
|
|
|
|
|
{ "ss", cm_special_char, BRACE_ARGS },
|
|
|
|
|
{ "strong", cm_strong, BRACE_ARGS },
|
|
|
|
|
{ "subheading", cm_subheading, NO_BRACE_ARGS },
|
|
|
|
|
{ "subsection", cm_subsection, NO_BRACE_ARGS },
|
|
|
|
|
{ "subsubheading", cm_subsubheading, NO_BRACE_ARGS },
|
|
|
|
|
{ "subsubsection", cm_subsubsection, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "subtitle", cm_titlepage_cmds, NO_BRACE_ARGS },
|
|
|
|
|
{ "summarycontents", cm_contents, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "syncodeindex", cm_synindex, NO_BRACE_ARGS },
|
|
|
|
|
{ "synindex", cm_synindex, NO_BRACE_ARGS },
|
|
|
|
|
{ "t", cm_tt, BRACE_ARGS },
|
|
|
|
|
{ "tab", cm_tab, NO_BRACE_ARGS },
|
|
|
|
|
{ "table", cm_table, NO_BRACE_ARGS },
|
|
|
|
|
{ "tex", cm_tex, NO_BRACE_ARGS },
|
2003-05-02 00:48:41 +00:00
|
|
|
|
{ "tie", cm_tie, BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "tieaccent", cm_accent, MAYBE_BRACE_ARGS },
|
|
|
|
|
{ "tindex", cm_tindex, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "title", cm_titlepage_cmds, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "titlefont", cm_titlefont, BRACE_ARGS },
|
2003-05-02 00:48:41 +00:00
|
|
|
|
{ "titlepage", cm_titlepage, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "today", cm_today, BRACE_ARGS },
|
|
|
|
|
{ "top", cm_top, NO_BRACE_ARGS },
|
|
|
|
|
{ "u", cm_accent, MAYBE_BRACE_ARGS },
|
|
|
|
|
{ "ubaraccent", cm_accent, MAYBE_BRACE_ARGS },
|
|
|
|
|
{ "udotaccent", cm_accent, MAYBE_BRACE_ARGS },
|
|
|
|
|
{ "unmacro", cm_unmacro, NO_BRACE_ARGS },
|
|
|
|
|
{ "unnumbered", cm_unnumbered, NO_BRACE_ARGS },
|
|
|
|
|
{ "unnumberedsec", cm_unnumberedsec, NO_BRACE_ARGS },
|
|
|
|
|
{ "unnumberedsubsec", cm_unnumberedsubsec, NO_BRACE_ARGS },
|
|
|
|
|
{ "unnumberedsubsubsec", cm_unnumberedsubsubsec, NO_BRACE_ARGS },
|
|
|
|
|
{ "uref", cm_uref, BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "url", cm_uref, BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "v", cm_accent, MAYBE_BRACE_ARGS },
|
|
|
|
|
{ "value", cm_value, BRACE_ARGS },
|
|
|
|
|
{ "var", cm_var, BRACE_ARGS },
|
2002-03-25 13:08:32 +00:00
|
|
|
|
{ "verb", cm_verb, NO_BRACE_ARGS },
|
|
|
|
|
{ "verbatim", cm_verbatim, NO_BRACE_ARGS },
|
|
|
|
|
{ "verbatiminclude", cm_verbatiminclude, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "vindex", cm_vindex, NO_BRACE_ARGS },
|
|
|
|
|
{ "vtable", cm_vtable, NO_BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "vskip", cm_ignore_line, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "w", cm_w, BRACE_ARGS },
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ "xml", cm_xml, NO_BRACE_ARGS },
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ "xref", cm_xref, BRACE_ARGS },
|
|
|
|
|
|
|
|
|
|
/* Deprecated commands. These used to be for italics. */
|
|
|
|
|
{ "iappendix", cm_ideprecated, NO_BRACE_ARGS },
|
|
|
|
|
{ "iappendixsec", cm_ideprecated, NO_BRACE_ARGS },
|
|
|
|
|
{ "iappendixsection", cm_ideprecated, NO_BRACE_ARGS },
|
|
|
|
|
{ "iappendixsubsec", cm_ideprecated, NO_BRACE_ARGS },
|
|
|
|
|
{ "iappendixsubsubsec", cm_ideprecated, NO_BRACE_ARGS },
|
|
|
|
|
{ "ichapter", cm_ideprecated, NO_BRACE_ARGS },
|
|
|
|
|
{ "isection", cm_ideprecated, NO_BRACE_ARGS },
|
|
|
|
|
{ "isubsection", cm_ideprecated, NO_BRACE_ARGS },
|
|
|
|
|
{ "isubsubsection", cm_ideprecated, NO_BRACE_ARGS },
|
|
|
|
|
{ "iunnumbered", cm_ideprecated, NO_BRACE_ARGS },
|
|
|
|
|
{ "iunnumberedsec", cm_ideprecated, NO_BRACE_ARGS },
|
|
|
|
|
{ "iunnumberedsubsec", cm_ideprecated, NO_BRACE_ARGS },
|
|
|
|
|
{ "iunnumberedsubsubsec", cm_ideprecated, NO_BRACE_ARGS },
|
|
|
|
|
|
|
|
|
|
/* Now @include does what this was used to. */
|
|
|
|
|
{ "infoinclude", cm_obsolete, NO_BRACE_ARGS },
|
|
|
|
|
{ "titlespec", cm_obsolete, NO_BRACE_ARGS },
|
|
|
|
|
|
|
|
|
|
{ NULL, NULL, NO_BRACE_ARGS }
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/* The bulk of the Texinfo commands. */
|
|
|
|
|
|
|
|
|
|
/* Commands which insert their own names. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
insert_self (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == START)
|
|
|
|
|
add_word (command);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
insert_space (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == START)
|
2002-03-25 13:08:32 +00:00
|
|
|
|
{
|
|
|
|
|
if (xml && !docbook)
|
2003-05-02 00:48:41 +00:00
|
|
|
|
xml_insert_entity ("space");
|
2002-03-25 13:08:32 +00:00
|
|
|
|
else
|
2003-05-02 00:48:41 +00:00
|
|
|
|
add_char (' ');
|
2002-03-25 13:08:32 +00:00
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
/* Insert a comma. Useful when a literal , would break our parsing of
|
|
|
|
|
multiple arguments. */
|
|
|
|
|
void
|
|
|
|
|
cm_comma (int arg)
|
|
|
|
|
{
|
|
|
|
|
if (arg == START)
|
|
|
|
|
add_char (',');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2000-01-17 10:39:58 +00:00
|
|
|
|
/* Force a line break in the output. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_asterisk (void)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (html)
|
|
|
|
|
add_word ("<br>");
|
2002-03-25 13:08:32 +00:00
|
|
|
|
else if (xml && !docbook)
|
|
|
|
|
xml_insert_entity ("linebreak");
|
|
|
|
|
else if (docbook)
|
|
|
|
|
xml_asterisk ();
|
2000-01-17 10:39:58 +00:00
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
close_single_paragraph ();
|
|
|
|
|
cm_noindent ();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Insert ellipsis. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_dots (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == START)
|
2002-03-25 13:08:32 +00:00
|
|
|
|
{
|
|
|
|
|
if (xml && !docbook)
|
2003-05-02 00:48:41 +00:00
|
|
|
|
xml_insert_entity ("dots");
|
2002-03-25 13:08:32 +00:00
|
|
|
|
else if (docbook)
|
2003-05-02 00:48:41 +00:00
|
|
|
|
xml_insert_entity ("hellip");
|
2002-03-25 13:08:32 +00:00
|
|
|
|
else
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (html && !in_fixed_width_font)
|
|
|
|
|
insert_string ("<small class=\"dots\">...</small>");
|
|
|
|
|
else
|
|
|
|
|
add_word ("...");
|
2002-03-25 13:08:32 +00:00
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Insert ellipsis for sentence end. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_enddots (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == START)
|
2002-03-25 13:08:32 +00:00
|
|
|
|
{
|
|
|
|
|
if (xml && !docbook)
|
|
|
|
|
xml_insert_entity ("enddots");
|
|
|
|
|
else if (docbook)
|
|
|
|
|
{
|
|
|
|
|
xml_insert_entity ("hellip");
|
|
|
|
|
add_char ('.');
|
|
|
|
|
}
|
|
|
|
|
else
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (html && !in_fixed_width_font)
|
|
|
|
|
insert_string ("<small class=\"enddots\">....</small>");
|
|
|
|
|
else
|
|
|
|
|
add_word ("....");
|
2002-03-25 13:08:32 +00:00
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_bullet (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == START)
|
|
|
|
|
{
|
|
|
|
|
if (html)
|
2005-05-23 10:46:22 +00:00
|
|
|
|
add_word ("•");
|
2002-03-25 13:08:32 +00:00
|
|
|
|
else if (xml && !docbook)
|
|
|
|
|
xml_insert_entity ("bullet");
|
|
|
|
|
else if (docbook)
|
|
|
|
|
xml_insert_entity ("bull");
|
2000-01-17 10:39:58 +00:00
|
|
|
|
else
|
|
|
|
|
add_char ('*');
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_minus (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == START)
|
2002-03-25 13:08:32 +00:00
|
|
|
|
{
|
|
|
|
|
if (xml)
|
|
|
|
|
xml_insert_entity ("minus");
|
2005-05-23 10:46:22 +00:00
|
|
|
|
else if (html)
|
|
|
|
|
add_word ("−");
|
2002-03-25 13:08:32 +00:00
|
|
|
|
else
|
|
|
|
|
add_char ('-');
|
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
/* Formatting a dimension unit. */
|
|
|
|
|
void
|
|
|
|
|
cm_dmn (int arg)
|
|
|
|
|
{
|
|
|
|
|
if (html)
|
|
|
|
|
insert_html_tag_with_attribute (arg, "span", "class=\"dmn\"");
|
|
|
|
|
else if (docbook)
|
|
|
|
|
/* No units in docbook yet. */
|
|
|
|
|
;
|
|
|
|
|
else if (xml)
|
|
|
|
|
xml_insert_element (DIMENSION, arg);
|
|
|
|
|
}
|
|
|
|
|
|
2000-01-17 10:39:58 +00:00
|
|
|
|
/* Insert "TeX". */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_TeX (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
static int last_position;
|
|
|
|
|
|
2000-01-17 10:39:58 +00:00
|
|
|
|
if (arg == START)
|
2002-03-25 13:08:32 +00:00
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (xml)
|
2002-03-25 13:08:32 +00:00
|
|
|
|
xml_insert_entity ("tex");
|
|
|
|
|
else
|
|
|
|
|
add_word ("TeX");
|
2005-05-23 10:46:22 +00:00
|
|
|
|
|
|
|
|
|
last_position = output_paragraph_offset;
|
|
|
|
|
}
|
|
|
|
|
else if (last_position != output_paragraph_offset)
|
|
|
|
|
{
|
|
|
|
|
warning (_("arguments to @%s ignored"), command);
|
|
|
|
|
output_paragraph_offset = last_position;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Insert "LaTeX". */
|
|
|
|
|
void
|
|
|
|
|
cm_LaTeX (int arg)
|
|
|
|
|
{
|
|
|
|
|
static int last_position;
|
|
|
|
|
|
|
|
|
|
if (arg == START)
|
|
|
|
|
{
|
|
|
|
|
if (xml)
|
|
|
|
|
xml_insert_entity ("latex");
|
|
|
|
|
else
|
|
|
|
|
add_word ("LaTeX");
|
|
|
|
|
|
|
|
|
|
last_position = output_paragraph_offset;
|
|
|
|
|
}
|
|
|
|
|
else if (last_position != output_paragraph_offset)
|
|
|
|
|
{
|
|
|
|
|
warning (_("arguments to @%s ignored"), command);
|
|
|
|
|
output_paragraph_offset = last_position;
|
2002-03-25 13:08:32 +00:00
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Copyright symbol. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_copyright (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == START)
|
2002-03-25 13:08:32 +00:00
|
|
|
|
{
|
2000-01-17 10:39:58 +00:00
|
|
|
|
if (html)
|
|
|
|
|
add_word ("©");
|
2002-03-25 13:08:32 +00:00
|
|
|
|
else if (xml && !docbook)
|
|
|
|
|
xml_insert_entity ("copyright");
|
|
|
|
|
else if (docbook)
|
|
|
|
|
xml_insert_entity ("copy");
|
2000-01-17 10:39:58 +00:00
|
|
|
|
else
|
|
|
|
|
add_word ("(C)");
|
2002-03-25 13:08:32 +00:00
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
/* Registered symbol. */
|
|
|
|
|
void
|
|
|
|
|
cm_registeredsymbol (int arg)
|
|
|
|
|
{
|
|
|
|
|
if (arg == START)
|
|
|
|
|
{
|
|
|
|
|
if (html)
|
|
|
|
|
add_word ("®");
|
|
|
|
|
else if (docbook)
|
|
|
|
|
xml_insert_entity ("reg");
|
|
|
|
|
else if (xml && !docbook)
|
|
|
|
|
xml_insert_entity ("registered");
|
|
|
|
|
else
|
|
|
|
|
add_word ("(R)");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2000-01-17 10:39:58 +00:00
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_today (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
static char *months[12] =
|
|
|
|
|
{ N_("January"), N_("February"), N_("March"), N_("April"), N_("May"),
|
|
|
|
|
N_("June"), N_("July"), N_("August"), N_("September"), N_("October"),
|
|
|
|
|
N_("November"), N_("December") };
|
|
|
|
|
if (arg == START)
|
|
|
|
|
{
|
|
|
|
|
time_t timer = time (0);
|
|
|
|
|
struct tm *ts = localtime (&timer);
|
|
|
|
|
add_word_args ("%d %s %d", ts->tm_mday, _(months[ts->tm_mon]),
|
|
|
|
|
ts->tm_year + 1900);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_comment (void)
|
|
|
|
|
{
|
|
|
|
|
/* For HTML, do not output comments before HTML header is written,
|
|
|
|
|
otherwise comments before @settitle cause an empty <title> in the
|
|
|
|
|
header. */
|
|
|
|
|
if ((html && html_output_head_p) || xml)
|
|
|
|
|
{
|
|
|
|
|
char *line;
|
|
|
|
|
get_rest_of_line (0, &line);
|
|
|
|
|
|
|
|
|
|
if (strlen (line) > 0)
|
|
|
|
|
{
|
|
|
|
|
int save_inhibit_indentation = inhibit_paragraph_indentation;
|
|
|
|
|
int save_paragraph_is_open = paragraph_is_open;
|
|
|
|
|
int save_escape_html = escape_html;
|
|
|
|
|
int save_xml_no_para = xml_no_para;
|
|
|
|
|
int i;
|
|
|
|
|
|
|
|
|
|
inhibit_paragraph_indentation = 1;
|
|
|
|
|
escape_html = 0;
|
|
|
|
|
xml_no_para = 1;
|
|
|
|
|
|
|
|
|
|
/* @c and @comment can appear between @item and @itemx,
|
|
|
|
|
@deffn and @deffnx. */
|
|
|
|
|
xml_dont_touch_items_defs++;
|
|
|
|
|
|
|
|
|
|
/* Use insert for HTML, and XML when indentation is enabled.
|
|
|
|
|
For Docbook, use add_char. */
|
|
|
|
|
if (xml && xml_indentation_increment > 0
|
|
|
|
|
&& output_paragraph[output_paragraph_offset-1] != '\n')
|
|
|
|
|
insert ('\n');
|
|
|
|
|
|
|
|
|
|
/* Crunch double hyphens in comments. */
|
|
|
|
|
add_html_block_elt ("<!-- ");
|
|
|
|
|
for (i = 0; i < strlen (line); i++)
|
|
|
|
|
if (line[i] != '-' || (i && line[i-1] != '-'))
|
|
|
|
|
add_char (line[i]);
|
|
|
|
|
add_word (" -->");
|
|
|
|
|
|
|
|
|
|
if (html)
|
|
|
|
|
add_char ('\n');
|
|
|
|
|
|
|
|
|
|
inhibit_paragraph_indentation = save_inhibit_indentation;
|
|
|
|
|
paragraph_is_open = save_paragraph_is_open;
|
|
|
|
|
escape_html = save_escape_html;
|
|
|
|
|
xml_no_para = save_xml_no_para;
|
|
|
|
|
xml_dont_touch_items_defs--;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
free (line);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
cm_ignore_line ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* We keep acronyms with two arguments around, to be able to refer to them
|
|
|
|
|
later with only one argument. */
|
|
|
|
|
static ACRONYM_DESC *acronyms_stack = NULL;
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
cm_acronym_or_abbr (int arg, int is_abbr)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
char *aa, *description;
|
|
|
|
|
unsigned len;
|
|
|
|
|
|
|
|
|
|
/* We do everything at START. */
|
|
|
|
|
if (arg == END)
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
get_until_in_braces (",", &aa);
|
|
|
|
|
if (input_text[input_text_offset] == ',')
|
|
|
|
|
input_text_offset++;
|
|
|
|
|
get_until_in_braces ("}", &description);
|
|
|
|
|
|
|
|
|
|
canon_white (aa);
|
|
|
|
|
canon_white (description);
|
|
|
|
|
|
|
|
|
|
/* If not enclosed in braces, strip after comma to be compatible
|
|
|
|
|
with texinfo.tex. */
|
|
|
|
|
if (description[0] != '{' && strchr (description, ',') != NULL)
|
|
|
|
|
{
|
|
|
|
|
int i = 0;
|
|
|
|
|
while (description[i] != ',')
|
|
|
|
|
i++;
|
|
|
|
|
/* For now, just terminate the string at comma. */
|
|
|
|
|
description[i] = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Get description out of braces. */
|
|
|
|
|
if (description[0] == '{')
|
|
|
|
|
description++;
|
|
|
|
|
|
|
|
|
|
len = strlen (description);
|
|
|
|
|
if (len && description[len-1] == '}')
|
|
|
|
|
description[len-1] = 0;
|
|
|
|
|
|
|
|
|
|
/* Save new description. */
|
|
|
|
|
if (strlen (description) > 0)
|
|
|
|
|
{
|
|
|
|
|
ACRONYM_DESC *new = xmalloc (sizeof (ACRONYM_DESC));
|
|
|
|
|
|
|
|
|
|
new->acronym = xstrdup (aa);
|
|
|
|
|
new->description = xstrdup (description);
|
|
|
|
|
new->next = acronyms_stack;
|
|
|
|
|
acronyms_stack = new;
|
|
|
|
|
}
|
|
|
|
|
|
2000-01-17 10:39:58 +00:00
|
|
|
|
if (html)
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{
|
|
|
|
|
add_word (is_abbr ? "<abbr" : "<acronym");
|
|
|
|
|
|
|
|
|
|
if (strlen (description) > 0)
|
|
|
|
|
add_word_args (" title=\"%s\"", text_expansion (description));
|
|
|
|
|
else if (acronyms_stack)
|
|
|
|
|
{
|
|
|
|
|
/* No second argument, get from previous. Search order is from
|
|
|
|
|
last to first defined, so we get the most recent version of
|
|
|
|
|
the description. */
|
|
|
|
|
ACRONYM_DESC *temp = acronyms_stack;
|
|
|
|
|
|
|
|
|
|
while (temp)
|
|
|
|
|
{
|
|
|
|
|
if (STREQ (aa, temp->acronym)
|
|
|
|
|
&& strlen (temp->description) > 0)
|
|
|
|
|
{
|
|
|
|
|
add_word_args (" title=\"%s\"",
|
|
|
|
|
text_expansion (temp->description));
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
temp = temp->next;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
add_char ('>');
|
|
|
|
|
execute_string ("%s", aa);
|
|
|
|
|
add_word (is_abbr ? "</abbr>" : "</acronym>");
|
|
|
|
|
}
|
|
|
|
|
else if (docbook)
|
|
|
|
|
{
|
|
|
|
|
xml_insert_element (is_abbr ? ABBREV : ACRONYM, START);
|
|
|
|
|
execute_string ("%s", aa);
|
|
|
|
|
xml_insert_element (is_abbr ? ABBREV : ACRONYM, END);
|
|
|
|
|
}
|
2002-03-25 13:08:32 +00:00
|
|
|
|
else if (xml)
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{
|
|
|
|
|
xml_insert_element (is_abbr ? ABBREV : ACRONYM, START);
|
|
|
|
|
|
|
|
|
|
xml_insert_element (is_abbr ? ABBREVWORD : ACRONYMWORD, START);
|
|
|
|
|
execute_string ("%s", aa);
|
|
|
|
|
xml_insert_element (is_abbr ? ABBREVWORD : ACRONYMWORD, END);
|
|
|
|
|
|
|
|
|
|
if (strlen (description) > 0)
|
|
|
|
|
{
|
|
|
|
|
xml_insert_element (is_abbr ? ABBREVDESC : ACRONYMDESC, START);
|
|
|
|
|
execute_string ("%s", description);
|
|
|
|
|
xml_insert_element (is_abbr ? ABBREVDESC : ACRONYMDESC, END);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
xml_insert_element (is_abbr ? ABBREV : ACRONYM, END);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
execute_string ("%s", aa);
|
|
|
|
|
|
|
|
|
|
/* Put description into parenthesis after the acronym for all outputs
|
|
|
|
|
except XML. */
|
|
|
|
|
if (strlen (description) > 0 && (!xml || docbook))
|
|
|
|
|
add_word_args (" (%s)", description);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_acronym (int arg)
|
|
|
|
|
{
|
|
|
|
|
cm_acronym_or_abbr (arg, 0);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
cm_abbr (int arg)
|
|
|
|
|
{
|
|
|
|
|
cm_acronym_or_abbr (arg, 1);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
cm_tt (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
/* @t{} is a no-op in Info. */
|
|
|
|
|
if (html)
|
|
|
|
|
insert_html_tag (arg, "tt");
|
2002-03-25 13:08:32 +00:00
|
|
|
|
else if (xml)
|
|
|
|
|
xml_insert_element (TT, arg);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_code (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (arg == START)
|
|
|
|
|
in_fixed_width_font++;
|
|
|
|
|
|
2002-03-25 13:08:32 +00:00
|
|
|
|
if (xml)
|
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (STREQ (command, "command"))
|
|
|
|
|
xml_insert_element (COMMAND_TAG, arg);
|
|
|
|
|
else if (STREQ (command, "env"))
|
|
|
|
|
xml_insert_element (ENV, arg);
|
|
|
|
|
else if (STREQ (command, "file"))
|
|
|
|
|
xml_insert_element (FILE_TAG, arg);
|
|
|
|
|
else if (STREQ (command, "option"))
|
|
|
|
|
xml_insert_element (OPTION, arg);
|
|
|
|
|
else if (STREQ (command, "samp"))
|
2003-05-02 00:48:41 +00:00
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (docbook && arg == START)
|
|
|
|
|
{
|
|
|
|
|
/* Even though @samp is in_fixed_width_font, it
|
|
|
|
|
should always start a paragraph. Unfortunately,
|
|
|
|
|
in_fixed_width_font inhibits that. */
|
|
|
|
|
xml_start_para ();
|
|
|
|
|
xml_insert_entity ("lsquo");
|
|
|
|
|
}
|
|
|
|
|
xml_insert_element (SAMP, arg);
|
|
|
|
|
if (docbook && arg == END)
|
|
|
|
|
xml_insert_entity ("rsquo");
|
2003-05-02 00:48:41 +00:00
|
|
|
|
}
|
2005-05-23 10:46:22 +00:00
|
|
|
|
else
|
|
|
|
|
xml_insert_element (CODE, arg);
|
|
|
|
|
}
|
|
|
|
|
else if (html)
|
|
|
|
|
{
|
|
|
|
|
if (STREQ (command, "code"))
|
2000-01-17 10:39:58 +00:00
|
|
|
|
insert_html_tag (arg, "code");
|
2003-05-02 00:48:41 +00:00
|
|
|
|
else
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{ /* Use <samp> tag in general to get typewriter. */
|
|
|
|
|
if (arg == START)
|
|
|
|
|
{ /* If @samp specifically, add quotes a la TeX output. */
|
|
|
|
|
if (STREQ (command, "samp")) add_char ('`');
|
|
|
|
|
add_word ("<samp>");
|
|
|
|
|
}
|
|
|
|
|
insert_html_tag_with_attribute (arg, "span", "class=\"%s\"",command);
|
|
|
|
|
if (arg == END)
|
|
|
|
|
{
|
|
|
|
|
add_word ("</samp>");
|
|
|
|
|
if (STREQ (command, "samp")) add_char ('\'');
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
extern int printing_index;
|
|
|
|
|
|
|
|
|
|
if (!printing_index)
|
2003-05-02 00:48:41 +00:00
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (arg == START)
|
|
|
|
|
add_char ('`');
|
|
|
|
|
else
|
2003-05-02 00:48:41 +00:00
|
|
|
|
add_meta_char ('\'');
|
|
|
|
|
}
|
2002-03-25 13:08:32 +00:00
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_kbd (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2002-03-25 13:08:32 +00:00
|
|
|
|
if (xml)
|
|
|
|
|
xml_insert_element (KBD, arg);
|
|
|
|
|
else if (html)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{ /* Seems like we should increment in_fixed_width_font for Info
|
|
|
|
|
format too, but then the quote-omitting special case gets
|
|
|
|
|
confused. Punt. */
|
|
|
|
|
if (arg == START)
|
|
|
|
|
in_fixed_width_font++;
|
|
|
|
|
insert_html_tag (arg, "kbd");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{ /* People use @kbd in an example to get the "user input" font.
|
|
|
|
|
We don't want quotes in that case. */
|
|
|
|
|
if (!in_fixed_width_font)
|
|
|
|
|
cm_code (arg);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
/* Just show a url (http://example.org/..., for example), don't link to it. */
|
2000-01-17 10:39:58 +00:00
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_indicate_url (int arg, int start, int end)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2002-03-25 13:08:32 +00:00
|
|
|
|
if (xml)
|
|
|
|
|
xml_insert_element (URL, arg);
|
|
|
|
|
else if (html)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == START)
|
2003-05-02 00:48:41 +00:00
|
|
|
|
add_word ("<");
|
|
|
|
|
insert_html_tag (arg, "code");
|
|
|
|
|
if (arg != START)
|
|
|
|
|
add_word (">");
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
if (arg == START)
|
|
|
|
|
add_word ("<");
|
|
|
|
|
else
|
|
|
|
|
add_word (">");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_key (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2002-03-25 13:08:32 +00:00
|
|
|
|
if (xml)
|
|
|
|
|
xml_insert_element (KEY, arg);
|
|
|
|
|
else if (html)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
add_word (arg == START ? "<" : ">");
|
|
|
|
|
else
|
|
|
|
|
add_char (arg == START ? '<' : '>');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Handle a command that switches to a non-fixed-width font. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
not_fixed_width (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == START)
|
|
|
|
|
in_fixed_width_font = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* @var in makeinfo just uppercases the text. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_var (int arg, int start_pos, int end_pos)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2002-03-25 13:08:32 +00:00
|
|
|
|
if (xml)
|
|
|
|
|
xml_insert_element (VAR, arg);
|
|
|
|
|
else
|
|
|
|
|
{
|
2000-01-17 10:39:58 +00:00
|
|
|
|
not_fixed_width (arg);
|
|
|
|
|
|
|
|
|
|
if (html)
|
|
|
|
|
insert_html_tag (arg, "var");
|
|
|
|
|
else if (arg == END)
|
|
|
|
|
{
|
|
|
|
|
while (start_pos < end_pos)
|
|
|
|
|
{
|
|
|
|
|
unsigned char c = output_paragraph[start_pos];
|
|
|
|
|
if (strchr ("[](),", c))
|
|
|
|
|
warning (_("unlikely character %c in @var"), c);
|
|
|
|
|
output_paragraph[start_pos] = coerce_to_upper (c);
|
|
|
|
|
start_pos++;
|
|
|
|
|
}
|
|
|
|
|
}
|
2002-03-25 13:08:32 +00:00
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_sc (int arg, int start_pos, int end_pos)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2002-03-25 13:08:32 +00:00
|
|
|
|
if (xml)
|
|
|
|
|
xml_insert_element (SC, arg);
|
|
|
|
|
else
|
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
not_fixed_width (arg);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (arg == START)
|
|
|
|
|
{
|
|
|
|
|
if (html)
|
|
|
|
|
insert_html_tag_with_attribute (arg, "span", "class=\"sc\"");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
int all_upper;
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (html)
|
|
|
|
|
start_pos += sizeof ("<span class=\"sc\">") - 1; /* skip <span> */
|
|
|
|
|
|
|
|
|
|
/* Avoid the warning below if there's no text inside @sc{}, or
|
|
|
|
|
when processing menus under --no-headers. */
|
|
|
|
|
all_upper = start_pos < end_pos;
|
|
|
|
|
|
|
|
|
|
while (start_pos < end_pos)
|
|
|
|
|
{
|
|
|
|
|
unsigned char c = output_paragraph[start_pos];
|
|
|
|
|
if (!isupper (c))
|
|
|
|
|
all_upper = 0;
|
|
|
|
|
if (!html)
|
|
|
|
|
output_paragraph[start_pos] = coerce_to_upper (c);
|
|
|
|
|
start_pos++;
|
|
|
|
|
}
|
|
|
|
|
if (all_upper)
|
|
|
|
|
warning (_("@sc argument all uppercase, thus no effect"));
|
2002-03-25 13:08:32 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (html)
|
|
|
|
|
insert_html_tag (arg, "span");
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
2002-03-25 13:08:32 +00:00
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_dfn (int arg, int position)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2002-03-25 13:08:32 +00:00
|
|
|
|
if (xml)
|
|
|
|
|
xml_insert_element (DFN, arg);
|
|
|
|
|
else
|
|
|
|
|
{
|
2000-01-17 10:39:58 +00:00
|
|
|
|
if (html)
|
|
|
|
|
insert_html_tag (arg, "dfn");
|
|
|
|
|
else if (arg == START)
|
|
|
|
|
add_char ('"');
|
|
|
|
|
else
|
|
|
|
|
add_meta_char ('"');
|
2002-03-25 13:08:32 +00:00
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_emph (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2002-03-25 13:08:32 +00:00
|
|
|
|
if (xml)
|
|
|
|
|
xml_insert_element (EMPH, arg);
|
|
|
|
|
else if (html)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
insert_html_tag (arg, "em");
|
|
|
|
|
else
|
|
|
|
|
add_char ('_');
|
|
|
|
|
}
|
|
|
|
|
|
2002-03-25 13:08:32 +00:00
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_verb (int arg)
|
2002-03-25 13:08:32 +00:00
|
|
|
|
{
|
|
|
|
|
int character;
|
2005-05-23 10:46:22 +00:00
|
|
|
|
int delimiter = 0; /* avoid warning */
|
2002-03-25 13:08:32 +00:00
|
|
|
|
int seen_end = 0;
|
|
|
|
|
|
|
|
|
|
in_fixed_width_font++;
|
|
|
|
|
/* are these necessary ? */
|
|
|
|
|
last_char_was_newline = 0;
|
|
|
|
|
|
|
|
|
|
if (html)
|
2003-05-02 00:48:41 +00:00
|
|
|
|
add_word ("<tt>");
|
2002-03-25 13:08:32 +00:00
|
|
|
|
|
|
|
|
|
if (input_text_offset < input_text_length)
|
|
|
|
|
{
|
|
|
|
|
character = curchar ();
|
|
|
|
|
if (character == '{')
|
|
|
|
|
input_text_offset++;
|
|
|
|
|
else
|
|
|
|
|
line_error (_("`{' expected, but saw `%c'"), character);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (input_text_offset < input_text_length)
|
|
|
|
|
{
|
|
|
|
|
delimiter = curchar ();
|
|
|
|
|
input_text_offset++;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
while (input_text_offset < input_text_length)
|
|
|
|
|
{
|
|
|
|
|
character = curchar ();
|
|
|
|
|
|
|
|
|
|
if (character == '\n')
|
2003-05-02 00:48:41 +00:00
|
|
|
|
{
|
|
|
|
|
line_number++;
|
|
|
|
|
if (html)
|
|
|
|
|
add_word ("<br>\n");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
else if (html && character == '<')
|
|
|
|
|
add_word ("<");
|
|
|
|
|
|
|
|
|
|
else if (html && character == '&')
|
|
|
|
|
add_word ("&");
|
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
else if (character == delimiter && input_text[input_text_offset+1] == '}')
|
2003-05-02 00:48:41 +00:00
|
|
|
|
{ /* Assume no newlines in END_VERBATIM. */
|
2002-03-25 13:08:32 +00:00
|
|
|
|
seen_end = 1;
|
|
|
|
|
input_text_offset++;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
2003-05-02 00:48:41 +00:00
|
|
|
|
else
|
|
|
|
|
add_char (character);
|
|
|
|
|
|
2002-03-25 13:08:32 +00:00
|
|
|
|
input_text_offset++;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!seen_end)
|
|
|
|
|
warning (_("end of file inside verb block"));
|
|
|
|
|
|
|
|
|
|
if (input_text_offset < input_text_length)
|
|
|
|
|
{
|
|
|
|
|
character = curchar ();
|
|
|
|
|
if (character == '}')
|
|
|
|
|
input_text_offset++;
|
|
|
|
|
else
|
|
|
|
|
line_error (_("`}' expected, but saw `%c'"), character);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (html)
|
2003-05-02 00:48:41 +00:00
|
|
|
|
add_word ("</tt>");
|
|
|
|
|
|
|
|
|
|
in_fixed_width_font--;
|
2002-03-25 13:08:32 +00:00
|
|
|
|
}
|
|
|
|
|
|
2003-05-02 00:48:41 +00:00
|
|
|
|
|
2000-01-17 10:39:58 +00:00
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_strong (int arg, int start_pos, int end_pos)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (docbook && arg == START)
|
|
|
|
|
xml_insert_element_with_attribute (B, arg, "role=\"bold\"");
|
|
|
|
|
else if (xml)
|
2002-03-25 13:08:32 +00:00
|
|
|
|
xml_insert_element (STRONG, arg);
|
|
|
|
|
else if (html)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
insert_html_tag (arg, "strong");
|
|
|
|
|
else
|
|
|
|
|
add_char ('*');
|
2005-05-23 10:46:22 +00:00
|
|
|
|
|
|
|
|
|
if (!xml && !html && !docbook && !no_headers
|
|
|
|
|
&& arg == END
|
|
|
|
|
&& end_pos - start_pos >= 6
|
|
|
|
|
&& (STRNCASEEQ ((char *) output_paragraph + start_pos, "*Note:", 6)
|
|
|
|
|
|| STRNCASEEQ ((char *) output_paragraph + start_pos, "*Note ", 6)))
|
|
|
|
|
{
|
|
|
|
|
/* Translators: "Note:" is literal here and should not be
|
|
|
|
|
translated. @strong{Nota}, say, does not cause the problem. */
|
|
|
|
|
warning (_("@strong{Note...} produces a spurious cross-reference in Info; reword to avoid that"));
|
|
|
|
|
/* Adjust the output to avoid writing the bad xref. */
|
|
|
|
|
output_paragraph[start_pos + 5] = '_';
|
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_cite (int arg, int position)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2002-03-25 13:08:32 +00:00
|
|
|
|
if (xml)
|
|
|
|
|
xml_insert_element (CITE, arg);
|
|
|
|
|
else if (html)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
insert_html_tag (arg, "cite");
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (arg == START)
|
|
|
|
|
add_char ('`');
|
|
|
|
|
else
|
|
|
|
|
add_char ('\'');
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* No highlighting, but argument switches fonts. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_not_fixed_width (int arg, int start, int end)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2002-03-25 13:08:32 +00:00
|
|
|
|
if (xml)
|
|
|
|
|
xml_insert_element (NOTFIXEDWIDTH, arg);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
not_fixed_width (arg);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_i (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
/* Make use of <lineannotation> of Docbook, if we are
|
|
|
|
|
inside an @example or similar. */
|
|
|
|
|
extern int printing_index;
|
|
|
|
|
if (docbook && !filling_enabled && !printing_index)
|
|
|
|
|
xml_insert_element (LINEANNOTATION, arg);
|
|
|
|
|
else if (xml)
|
2002-03-25 13:08:32 +00:00
|
|
|
|
xml_insert_element (I, arg);
|
|
|
|
|
else if (html)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
insert_html_tag (arg, "i");
|
|
|
|
|
else
|
|
|
|
|
not_fixed_width (arg);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_slanted (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
/* Make use of <lineannotation> of Docbook, if we are
|
|
|
|
|
inside an @example or similar. */
|
|
|
|
|
extern int printing_index;
|
|
|
|
|
if (docbook && !filling_enabled && !printing_index)
|
|
|
|
|
xml_insert_element (LINEANNOTATION, arg);
|
|
|
|
|
else if (xml)
|
|
|
|
|
xml_insert_element (SLANTED, arg);
|
|
|
|
|
else if (html)
|
|
|
|
|
insert_html_tag (arg, "i");
|
|
|
|
|
else
|
|
|
|
|
not_fixed_width (arg);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
cm_b (int arg)
|
|
|
|
|
{
|
|
|
|
|
/* See cm_i comments. */
|
|
|
|
|
extern int printing_index;
|
|
|
|
|
if (docbook && !filling_enabled && !printing_index)
|
|
|
|
|
xml_insert_element (LINEANNOTATION, arg);
|
|
|
|
|
else if (docbook && arg == START)
|
|
|
|
|
xml_insert_element_with_attribute (B, arg, "role=\"bold\"");
|
|
|
|
|
else if (xml)
|
2002-03-25 13:08:32 +00:00
|
|
|
|
xml_insert_element (B, arg);
|
|
|
|
|
else if (html)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
insert_html_tag (arg, "b");
|
|
|
|
|
else
|
|
|
|
|
not_fixed_width (arg);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_r (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
/* See cm_i comments. */
|
|
|
|
|
extern int printing_index;
|
|
|
|
|
if (docbook && !filling_enabled && !printing_index)
|
|
|
|
|
xml_insert_element (LINEANNOTATION, arg);
|
|
|
|
|
else if (xml)
|
2002-03-25 13:08:32 +00:00
|
|
|
|
xml_insert_element (R, arg);
|
2005-05-23 10:46:22 +00:00
|
|
|
|
else if (html)
|
|
|
|
|
insert_html_tag_with_attribute (arg, "span", "class=\"roman\"");
|
2002-03-25 13:08:32 +00:00
|
|
|
|
else
|
2005-05-23 10:46:22 +00:00
|
|
|
|
not_fixed_width (arg);
|
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
void
|
|
|
|
|
cm_sansserif (int arg)
|
|
|
|
|
{
|
|
|
|
|
/* See cm_i comments. */
|
|
|
|
|
extern int printing_index;
|
|
|
|
|
if (docbook && !filling_enabled && !printing_index)
|
|
|
|
|
xml_insert_element (LINEANNOTATION, arg);
|
|
|
|
|
else if (xml)
|
|
|
|
|
xml_insert_element (SANSSERIF, arg);
|
|
|
|
|
else if (html)
|
|
|
|
|
insert_html_tag_with_attribute (arg, "span", "class=\"sansserif\"");
|
|
|
|
|
else
|
|
|
|
|
not_fixed_width (arg);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_titlefont (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2002-03-25 13:08:32 +00:00
|
|
|
|
if (xml)
|
|
|
|
|
xml_insert_element (TITLEFONT, arg);
|
|
|
|
|
else
|
2003-05-02 00:48:41 +00:00
|
|
|
|
{
|
|
|
|
|
not_fixed_width (arg);
|
|
|
|
|
if (html)
|
|
|
|
|
{
|
|
|
|
|
html_title_written = 1; /* suppress title from @settitle */
|
|
|
|
|
if (arg == START)
|
|
|
|
|
add_word ("<h1 class=\"titlefont\">");
|
|
|
|
|
else
|
|
|
|
|
add_word ("</h1>\n");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
/* Unfortunately, we cannot interpret @math{} contents like TeX does. We just
|
|
|
|
|
pass them through. */
|
2003-05-02 00:48:41 +00:00
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_math (int arg)
|
2003-05-02 00:48:41 +00:00
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (xml && !docbook)
|
|
|
|
|
xml_insert_element (MATH, arg);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Various commands are no-op's. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_no_op (void)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* For proofing single chapters, etc. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_novalidate (void)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
validating = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* Prevent the argument from being split across two lines. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_w (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == START)
|
|
|
|
|
non_splitting_words++;
|
|
|
|
|
else
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{
|
|
|
|
|
if (docbook || html || xml)
|
|
|
|
|
/* This is so @w{$}Log$ doesn't end up as <dollar>Log<dollar>
|
|
|
|
|
in the output. */
|
|
|
|
|
insert_string ("<!-- /@w -->");
|
|
|
|
|
|
|
|
|
|
non_splitting_words--;
|
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2003-05-02 00:48:41 +00:00
|
|
|
|
/* An unbreakable word space. Same as @w{ } for makeinfo, but different
|
|
|
|
|
for TeX (the space stretches and stretches, and does not inhibit
|
|
|
|
|
hyphenation). */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_tie (int arg)
|
2003-05-02 00:48:41 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == START)
|
|
|
|
|
{
|
|
|
|
|
cm_w (START);
|
|
|
|
|
add_char (' ');
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
cm_w (END);
|
|
|
|
|
}
|
|
|
|
|
|
2000-01-17 10:39:58 +00:00
|
|
|
|
/* Explain that this command is obsolete, thus the user shouldn't
|
|
|
|
|
do anything with it. */
|
|
|
|
|
static void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_obsolete (int arg, int start, int end)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == START)
|
|
|
|
|
warning (_("%c%s is obsolete"), COMMAND_PREFIX, command);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2003-06-18 12:57:43 +00:00
|
|
|
|
/* Inhibit the indentation of the next paragraph, but not of following
|
|
|
|
|
paragraphs. */
|
2000-01-17 10:39:58 +00:00
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_noindent (void)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (!inhibit_paragraph_indentation)
|
|
|
|
|
inhibit_paragraph_indentation = -1;
|
|
|
|
|
}
|
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
void
|
|
|
|
|
cm_noindent_cmd (void)
|
|
|
|
|
{
|
|
|
|
|
cm_noindent ();
|
|
|
|
|
xml_no_indent = 1;
|
|
|
|
|
skip_whitespace_and_newlines();
|
|
|
|
|
|
|
|
|
|
if (xml)
|
|
|
|
|
xml_start_para ();
|
|
|
|
|
else if (html && !paragraph_is_open)
|
|
|
|
|
add_html_block_elt ("<p class=\"noindent\">");
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
paragraph_is_open = 0;
|
|
|
|
|
start_paragraph ();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2003-06-18 12:57:43 +00:00
|
|
|
|
/* Force indentation of the next paragraph. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_indent (void)
|
2003-06-18 12:57:43 +00:00
|
|
|
|
{
|
|
|
|
|
inhibit_paragraph_indentation = 0;
|
2005-05-23 10:46:22 +00:00
|
|
|
|
xml_no_indent = 0;
|
|
|
|
|
skip_whitespace_and_newlines();
|
|
|
|
|
|
|
|
|
|
if (xml)
|
|
|
|
|
xml_start_para ();
|
|
|
|
|
else if (html && !paragraph_is_open)
|
|
|
|
|
add_html_block_elt ("<p class=\"indent\">");
|
|
|
|
|
else
|
|
|
|
|
start_paragraph ();
|
2003-06-18 12:57:43 +00:00
|
|
|
|
}
|
|
|
|
|
|
2000-01-17 10:39:58 +00:00
|
|
|
|
/* I don't know exactly what to do with this. Should I allow
|
|
|
|
|
someone to switch filenames in the middle of output? Since the
|
|
|
|
|
file could be partially written, this doesn't seem to make sense.
|
2003-06-18 12:57:43 +00:00
|
|
|
|
Another option: ignore it, since they don't really want to
|
2000-01-17 10:39:58 +00:00
|
|
|
|
switch files. Finally, complain, or at least warn. It doesn't
|
|
|
|
|
really matter, anyway, since this doesn't get executed. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_setfilename (void)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
char *filename;
|
|
|
|
|
get_rest_of_line (1, &filename);
|
|
|
|
|
/* warning ("`@%s %s' encountered and ignored", command, filename); */
|
2002-03-25 13:08:32 +00:00
|
|
|
|
if (xml)
|
|
|
|
|
add_word_args ("<setfilename>%s</setfilename>", filename);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
free (filename);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_settitle (void)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2002-03-25 13:08:32 +00:00
|
|
|
|
if (xml)
|
|
|
|
|
{
|
2002-07-22 16:52:57 +00:00
|
|
|
|
xml_begin_document (current_output_filename);
|
2002-03-25 13:08:32 +00:00
|
|
|
|
xml_insert_element (SETTITLE, START);
|
2003-05-02 00:48:41 +00:00
|
|
|
|
xml_in_book_title = 1;
|
2002-03-25 13:08:32 +00:00
|
|
|
|
get_rest_of_line (0, &title);
|
|
|
|
|
execute_string ("%s", title);
|
2003-05-02 00:48:41 +00:00
|
|
|
|
xml_in_book_title = 0;
|
2002-03-25 13:08:32 +00:00
|
|
|
|
xml_insert_element (SETTITLE, END);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
get_rest_of_line (0, &title);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
2002-03-25 13:08:32 +00:00
|
|
|
|
|
2000-01-17 10:39:58 +00:00
|
|
|
|
/* Ignore argument in braces. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_ignore_arg (int arg, int start_pos, int end_pos)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == END)
|
|
|
|
|
output_paragraph_offset = start_pos;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Ignore argument on rest of line. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_ignore_line (void)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
discard_until ("\n");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Insert the number of blank lines passed as argument. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_sp (void)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
int lines;
|
|
|
|
|
char *line;
|
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
/* Due to tricky stuff in execute_string(), @value{} can't be expanded.
|
|
|
|
|
So there is really no reason to enable expansion for @sp parameters. */
|
|
|
|
|
get_rest_of_line (0, &line);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
if (sscanf (line, "%d", &lines) != 1 || lines <= 0)
|
|
|
|
|
line_error (_("@sp requires a positive numeric argument, not `%s'"), line);
|
|
|
|
|
else
|
2002-03-25 13:08:32 +00:00
|
|
|
|
{
|
|
|
|
|
if (xml)
|
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
/* @sp can appear between @item and @itemx, @deffn and @deffnx. */
|
|
|
|
|
xml_dont_touch_items_defs++;
|
2002-03-25 13:08:32 +00:00
|
|
|
|
xml_insert_element_with_attribute (SP, START, "lines=\"%s\"", line);
|
|
|
|
|
/* insert_string (line);*/
|
|
|
|
|
xml_insert_element (SP, END);
|
2005-05-23 10:46:22 +00:00
|
|
|
|
xml_dont_touch_items_defs--;
|
2002-03-25 13:08:32 +00:00
|
|
|
|
}
|
|
|
|
|
else
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{
|
|
|
|
|
/* Must disable filling since otherwise multiple newlines is like
|
|
|
|
|
multiple spaces. Must close paragraph since that's what the
|
|
|
|
|
manual says and that's what TeX does. */
|
|
|
|
|
int save_filling_enabled = filling_enabled;
|
|
|
|
|
filling_enabled = 0;
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
/* close_paragraph generates an extra blank line. */
|
|
|
|
|
close_single_paragraph ();
|
2002-03-25 13:08:32 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (lines && html && !executing_string)
|
|
|
|
|
html_output_head ();
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (html)
|
|
|
|
|
add_html_block_elt ("<pre class=\"sp\">\n");
|
|
|
|
|
|
|
|
|
|
while (lines--)
|
|
|
|
|
add_char ('\n');
|
|
|
|
|
|
|
|
|
|
if (html)
|
|
|
|
|
add_html_block_elt ("</pre>\n");
|
|
|
|
|
|
|
|
|
|
filling_enabled = save_filling_enabled;
|
|
|
|
|
}
|
2002-03-25 13:08:32 +00:00
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
free (line);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* @dircategory LINE outputs INFO-DIR-SECTION LINE, unless --no-headers. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_dircategory (void)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
char *line;
|
|
|
|
|
|
2002-03-25 13:08:32 +00:00
|
|
|
|
if (html || docbook)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
cm_ignore_line ();
|
2002-03-25 13:08:32 +00:00
|
|
|
|
else if (xml)
|
|
|
|
|
{
|
|
|
|
|
xml_insert_element (DIRCATEGORY, START);
|
|
|
|
|
get_rest_of_line (1, &line);
|
|
|
|
|
insert_string (line);
|
|
|
|
|
free (line);
|
|
|
|
|
xml_insert_element (DIRCATEGORY, END);
|
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
get_rest_of_line (1, &line);
|
|
|
|
|
|
|
|
|
|
if (!no_headers && !html)
|
|
|
|
|
{
|
|
|
|
|
kill_self_indent (-1); /* make sure there's no indentation */
|
|
|
|
|
insert_string ("INFO-DIR-SECTION ");
|
|
|
|
|
insert_string (line);
|
|
|
|
|
insert ('\n');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
free (line);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Start a new line with just this text on it.
|
|
|
|
|
Then center the line of text.
|
2002-03-25 13:08:32 +00:00
|
|
|
|
*/
|
2000-01-17 10:39:58 +00:00
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_center (void)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2002-03-25 13:08:32 +00:00
|
|
|
|
if (xml)
|
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
char *line;
|
2002-03-25 13:08:32 +00:00
|
|
|
|
xml_insert_element (CENTER, START);
|
2005-05-23 10:46:22 +00:00
|
|
|
|
get_rest_of_line (0, &line);
|
|
|
|
|
execute_string ("%s", line);
|
2002-03-25 13:08:32 +00:00
|
|
|
|
free (line);
|
|
|
|
|
xml_insert_element (CENTER, END);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
int i, start, length;
|
|
|
|
|
char *line;
|
|
|
|
|
int save_indented_fill = indented_fill;
|
|
|
|
|
int save_filling_enabled = filling_enabled;
|
|
|
|
|
int fudge_factor = 1;
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
filling_enabled = indented_fill = 0;
|
|
|
|
|
cm_noindent ();
|
|
|
|
|
start = output_paragraph_offset;
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (html)
|
|
|
|
|
add_html_block_elt ("<div align=\"center\">");
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
inhibit_output_flushing ();
|
|
|
|
|
get_rest_of_line (0, &line);
|
|
|
|
|
execute_string ("%s", line);
|
|
|
|
|
free (line);
|
|
|
|
|
uninhibit_output_flushing ();
|
|
|
|
|
if (html)
|
|
|
|
|
add_html_block_elt ("</div>");
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
i = output_paragraph_offset - 1;
|
|
|
|
|
while (i > (start - 1) && output_paragraph[i] == '\n')
|
|
|
|
|
i--;
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
output_paragraph_offset = ++i;
|
|
|
|
|
length = output_paragraph_offset - start;
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (length < (fill_column - fudge_factor))
|
|
|
|
|
{
|
|
|
|
|
line = xmalloc (1 + length);
|
|
|
|
|
memcpy (line, (char *)(output_paragraph + start), length);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
i = (fill_column - fudge_factor - length) / 2;
|
|
|
|
|
output_paragraph_offset = start;
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
while (i--)
|
|
|
|
|
insert (' ');
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
for (i = 0; i < length; i++)
|
|
|
|
|
insert (line[i]);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
free (line);
|
|
|
|
|
}
|
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
insert ('\n');
|
|
|
|
|
filling_enabled = save_filling_enabled;
|
|
|
|
|
indented_fill = save_indented_fill;
|
|
|
|
|
close_single_paragraph ();
|
|
|
|
|
if (looking_at("\n"))
|
|
|
|
|
insert ('\n');
|
2002-03-25 13:08:32 +00:00
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Show what an expression returns. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_result (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == END)
|
|
|
|
|
add_word (html ? "=>" : "=>");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* What an expression expands to. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_expansion (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == END)
|
|
|
|
|
add_word (html ? "==>" : "==>");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Indicates two expressions are equivalent. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_equiv (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == END)
|
|
|
|
|
add_word ("==");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* What an expression may print. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_print (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == END)
|
|
|
|
|
add_word ("-|");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* An error signaled. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_error (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == END)
|
|
|
|
|
add_word (html ? "error-->" : "error-->");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* The location of point in an example of a buffer. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_point (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (arg == END)
|
|
|
|
|
add_word ("-!-");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* @exdent: Start a new line with just this text on it.
|
|
|
|
|
The text is outdented one level if possible. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_exdent (void)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
char *line;
|
|
|
|
|
int save_indent = current_indent;
|
|
|
|
|
int save_in_fixed_width_font = in_fixed_width_font;
|
|
|
|
|
|
2003-05-02 00:48:41 +00:00
|
|
|
|
/* Read argument. */
|
2000-01-17 10:39:58 +00:00
|
|
|
|
get_rest_of_line (0, &line);
|
|
|
|
|
|
|
|
|
|
/* Exdent the output. Actually this may be a no-op. */
|
|
|
|
|
if (current_indent)
|
|
|
|
|
current_indent -= default_indentation_increment;
|
|
|
|
|
|
|
|
|
|
/* @exdent arg is supposed to be in roman. */
|
|
|
|
|
in_fixed_width_font = 0;
|
|
|
|
|
|
|
|
|
|
/* The preceding newline already inserted the `current_indent'.
|
|
|
|
|
Remove one level's worth. */
|
|
|
|
|
kill_self_indent (default_indentation_increment);
|
|
|
|
|
|
|
|
|
|
if (html)
|
|
|
|
|
add_word ("<br>");
|
2005-05-23 10:46:22 +00:00
|
|
|
|
else if (docbook)
|
|
|
|
|
xml_insert_element (LINEANNOTATION, START);
|
|
|
|
|
else if (xml)
|
|
|
|
|
xml_insert_element (EXDENT, START);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
/* Can't close_single_paragraph, then we lose preceding blank lines. */
|
|
|
|
|
flush_output ();
|
|
|
|
|
execute_string ("%s", line);
|
|
|
|
|
free (line);
|
|
|
|
|
|
|
|
|
|
if (html)
|
|
|
|
|
add_word ("<br>");
|
2005-05-23 10:46:22 +00:00
|
|
|
|
else if (xml)
|
|
|
|
|
{
|
|
|
|
|
xml_insert_element (docbook ? LINEANNOTATION : EXDENT, END);
|
|
|
|
|
insert ('\n');
|
|
|
|
|
}
|
|
|
|
|
|
2000-01-17 10:39:58 +00:00
|
|
|
|
close_single_paragraph ();
|
|
|
|
|
|
|
|
|
|
current_indent = save_indent;
|
|
|
|
|
in_fixed_width_font = save_in_fixed_width_font;
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (!xml)
|
|
|
|
|
start_paragraph ();
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
2002-03-25 13:08:32 +00:00
|
|
|
|
/*
|
|
|
|
|
Read include-filename, process the include-file:
|
|
|
|
|
verbatim_include == 0: process through reader_loop
|
|
|
|
|
verbatim_include != 0: process through handle_verbatim_environment
|
|
|
|
|
*/
|
|
|
|
|
static void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
handle_include (int verbatim_include)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2003-05-02 00:48:41 +00:00
|
|
|
|
char *arg, *filename;
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
if (macro_expansion_output_stream && !executing_string)
|
|
|
|
|
me_append_before_this_command ();
|
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (!insertion_stack)
|
|
|
|
|
close_paragraph (); /* No blank lines etc. if not at outer level. */
|
|
|
|
|
|
2003-05-02 00:48:41 +00:00
|
|
|
|
get_rest_of_line (0, &arg);
|
|
|
|
|
/* We really only want to expand @value, but it's easier to just do
|
|
|
|
|
everything. TeX will only work with @value. */
|
|
|
|
|
filename = text_expansion (arg);
|
|
|
|
|
free (arg);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
if (macro_expansion_output_stream && !executing_string)
|
|
|
|
|
remember_itext (input_text, input_text_offset);
|
|
|
|
|
|
|
|
|
|
pushfile ();
|
|
|
|
|
|
|
|
|
|
/* In verbose mode we print info about including another file. */
|
|
|
|
|
if (verbose_mode)
|
|
|
|
|
{
|
|
|
|
|
int i = 0;
|
|
|
|
|
FSTACK *stack = filestack;
|
|
|
|
|
|
|
|
|
|
for (i = 0, stack = filestack; stack; stack = stack->next, i++);
|
|
|
|
|
|
|
|
|
|
i *= 2;
|
|
|
|
|
|
|
|
|
|
printf ("%*s", i, "");
|
2002-03-25 13:08:32 +00:00
|
|
|
|
printf ("%c%s `%s'\n", COMMAND_PREFIX, command, filename);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
fflush (stdout);
|
|
|
|
|
}
|
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (!find_and_load (filename, 1))
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
popfile ();
|
|
|
|
|
line_number--;
|
|
|
|
|
|
2002-03-25 13:08:32 +00:00
|
|
|
|
/* /wh/bar:5: @include/@verbatiminclude `foo': No such file or dir */
|
|
|
|
|
line_error ("%c%s `%s': %s", COMMAND_PREFIX, command, filename,
|
2000-01-17 10:39:58 +00:00
|
|
|
|
strerror (errno));
|
|
|
|
|
|
|
|
|
|
free (filename);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (macro_expansion_output_stream && !executing_string)
|
2002-03-25 13:08:32 +00:00
|
|
|
|
remember_itext (input_text, input_text_offset);
|
|
|
|
|
|
|
|
|
|
if (!verbatim_include)
|
|
|
|
|
reader_loop ();
|
|
|
|
|
else
|
|
|
|
|
handle_verbatim_environment (0);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
free (filename);
|
|
|
|
|
popfile ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2002-03-25 13:08:32 +00:00
|
|
|
|
/* Include file as if put in @verbatim environment */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_verbatiminclude (void)
|
2002-03-25 13:08:32 +00:00
|
|
|
|
{
|
|
|
|
|
handle_include (1);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* Remember this file, and move onto the next. */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_include (void)
|
2002-03-25 13:08:32 +00:00
|
|
|
|
{
|
|
|
|
|
handle_include (0);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2000-01-17 10:39:58 +00:00
|
|
|
|
/* @bye: Signals end of processing. Easy to make this happen. */
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_bye (void)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
discard_braces (); /* should not have any unclosed braces left */
|
|
|
|
|
input_text_offset = input_text_length;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* @paragraphindent */
|
|
|
|
|
|
|
|
|
|
static void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_paragraphindent (void)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
char *arg;
|
|
|
|
|
|
|
|
|
|
get_rest_of_line (1, &arg);
|
|
|
|
|
if (set_paragraph_indent (arg) != 0)
|
|
|
|
|
line_error (_("Bad argument to %c%s"), COMMAND_PREFIX, command);
|
|
|
|
|
|
|
|
|
|
free (arg);
|
|
|
|
|
}
|
|
|
|
|
|
2003-06-18 12:57:43 +00:00
|
|
|
|
|
2000-01-17 10:39:58 +00:00
|
|
|
|
/* @exampleindent: change indentation of example-like environments. */
|
|
|
|
|
static int
|
2005-05-23 10:46:22 +00:00
|
|
|
|
set_example_indentation_increment (char *string)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
if (strcmp (string, "asis") == 0 || strcmp (string, _("asis")) == 0)
|
|
|
|
|
;
|
|
|
|
|
else if (strcmp (string, "none") == 0 || strcmp (string, _("none")) == 0)
|
2005-05-23 10:46:22 +00:00
|
|
|
|
example_indentation_increment = 0;
|
|
|
|
|
else if (sscanf (string, "%d", &example_indentation_increment) != 1)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
return -1;
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_exampleindent (void)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
char *arg;
|
|
|
|
|
|
|
|
|
|
get_rest_of_line (1, &arg);
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (set_example_indentation_increment (arg) != 0)
|
|
|
|
|
line_error (_("Bad argument to @%s"), command);
|
|
|
|
|
|
|
|
|
|
if (input_text[input_text_offset] == '\n')
|
|
|
|
|
close_single_paragraph ();
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
free (arg);
|
|
|
|
|
}
|
2003-06-18 12:57:43 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* @firstparagraphindent: suppress indentation in first paragraphs after
|
|
|
|
|
headings. */
|
|
|
|
|
static int
|
2005-05-23 10:46:22 +00:00
|
|
|
|
set_firstparagraphindent (char *string)
|
2003-06-18 12:57:43 +00:00
|
|
|
|
{
|
|
|
|
|
if (STREQ (string, "insert") || STREQ (string, _("insert")))
|
|
|
|
|
do_first_par_indent = 1;
|
|
|
|
|
else if (STREQ (string, "none") || STREQ (string, _("none")))
|
|
|
|
|
do_first_par_indent = 0;
|
|
|
|
|
else
|
|
|
|
|
return -1;
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_firstparagraphindent (void)
|
2003-06-18 12:57:43 +00:00
|
|
|
|
{
|
|
|
|
|
char *arg;
|
|
|
|
|
|
|
|
|
|
get_rest_of_line (1, &arg);
|
|
|
|
|
if (set_firstparagraphindent (arg) != 0)
|
|
|
|
|
line_error (_("Bad argument to %c%s"), COMMAND_PREFIX, command);
|
|
|
|
|
|
|
|
|
|
free (arg);
|
|
|
|
|
}
|
2005-05-23 10:46:22 +00:00
|
|
|
|
|
|
|
|
|
/* For DocBook and XML, produce . for `.@:'. This gives the processing
|
|
|
|
|
software a fighting chance to treat it specially by not adding extra space.
|
|
|
|
|
|
|
|
|
|
Do this also for ?, !, and :. */
|
|
|
|
|
void
|
|
|
|
|
cm_colon (void)
|
|
|
|
|
{
|
|
|
|
|
if (xml)
|
|
|
|
|
{
|
|
|
|
|
if (strchr (".?!:", input_text[input_text_offset-3]) != NULL)
|
|
|
|
|
{
|
|
|
|
|
/* Erase literal character that's there, except `>', which is
|
|
|
|
|
part of the XML tag. */
|
|
|
|
|
if (output_paragraph[output_paragraph_offset-1] != '>')
|
|
|
|
|
output_paragraph_offset--;
|
|
|
|
|
|
|
|
|
|
switch (input_text[input_text_offset-3])
|
|
|
|
|
{
|
|
|
|
|
case '.':
|
|
|
|
|
xml_insert_entity ("period");
|
|
|
|
|
break;
|
|
|
|
|
case '?':
|
|
|
|
|
xml_insert_entity ("quest");
|
|
|
|
|
break;
|
|
|
|
|
case '!':
|
|
|
|
|
xml_insert_entity ("excl");
|
|
|
|
|
break;
|
|
|
|
|
case ':':
|
|
|
|
|
xml_insert_entity ("colon");
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Ending sentences explicitly. Currently, only outputs entities for XML
|
|
|
|
|
output, for other formats it calls insert_self. */
|
|
|
|
|
void
|
|
|
|
|
cm_punct (int arg)
|
|
|
|
|
{
|
|
|
|
|
if (xml && !docbook)
|
|
|
|
|
{
|
|
|
|
|
switch (input_text[input_text_offset-1])
|
|
|
|
|
{
|
|
|
|
|
case '.':
|
|
|
|
|
xml_insert_entity ("eosperiod");
|
|
|
|
|
break;
|
|
|
|
|
case '?':
|
|
|
|
|
xml_insert_entity ("eosquest");
|
|
|
|
|
break;
|
|
|
|
|
case '!':
|
|
|
|
|
xml_insert_entity ("eosexcl");
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
insert_self (arg);
|
|
|
|
|
}
|
|
|
|
|
}
|