2000-01-17 10:39:58 +00:00
|
|
|
|
/* toc.c -- table of contents handling.
|
2005-05-23 10:46:22 +00:00
|
|
|
|
$Id: toc.c,v 1.6 2004/04/11 17:56:47 karl Exp $
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
Copyright (C) 1999, 2000, 2001, 2002, 2003 Free Software 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.
|
|
|
|
|
|
2003-05-02 00:48:41 +00:00
|
|
|
|
Originally written by Karl Heinz Marbaise <kama@hippo.fido.de>. */
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
#include "system.h"
|
|
|
|
|
#include "makeinfo.h"
|
|
|
|
|
#include "cmds.h"
|
|
|
|
|
#include "files.h"
|
|
|
|
|
#include "macro.h"
|
|
|
|
|
#include "node.h"
|
2002-03-25 13:08:32 +00:00
|
|
|
|
#include "html.h"
|
2000-01-17 10:39:58 +00:00
|
|
|
|
#include "lang.h"
|
|
|
|
|
#include "makeinfo.h"
|
|
|
|
|
#include "sectioning.h"
|
|
|
|
|
#include "toc.h"
|
2005-05-23 10:46:22 +00:00
|
|
|
|
#include "xml.h"
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
/* array of toc entries */
|
|
|
|
|
static TOC_ENTRY_ELT **toc_entry_alist = NULL;
|
|
|
|
|
|
|
|
|
|
/* toc_counter start from 0 ... n for every @chapter, @section ... */
|
|
|
|
|
static int toc_counter = 0;
|
|
|
|
|
|
|
|
|
|
/* Routine to add an entry to the table of contents */
|
|
|
|
|
int
|
2005-05-23 10:46:22 +00:00
|
|
|
|
toc_add_entry (char *tocname, int level, char *node_name, char *anchor)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
char *tocname_and_node, *expanded_node, *d;
|
|
|
|
|
char *s = NULL;
|
2002-03-25 13:08:32 +00:00
|
|
|
|
char *filename = NULL;
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
if (!node_name)
|
|
|
|
|
node_name = "";
|
|
|
|
|
|
|
|
|
|
/* I assume that xrealloc behaves like xmalloc if toc_entry_alist is
|
|
|
|
|
NULL */
|
|
|
|
|
toc_entry_alist = xrealloc (toc_entry_alist,
|
|
|
|
|
(toc_counter + 1) * sizeof (TOC_ENTRY_ELT *));
|
|
|
|
|
|
|
|
|
|
toc_entry_alist[toc_counter] = xmalloc (sizeof (TOC_ENTRY_ELT));
|
|
|
|
|
|
|
|
|
|
if (html)
|
|
|
|
|
{
|
2002-07-22 16:52:57 +00:00
|
|
|
|
/* We need to insert the expanded node name into the toc, so
|
|
|
|
|
that when we eventually output the toc, its <a ref= link will
|
|
|
|
|
point to the <a name= tag created by cm_node in the navigation
|
2002-03-25 13:08:32 +00:00
|
|
|
|
bar. We cannot expand the containing_node member, for the
|
|
|
|
|
reasons explained in the WARNING below. We also cannot wait
|
2002-07-22 16:52:57 +00:00
|
|
|
|
with the node name expansion until the toc is actually output,
|
2002-03-25 13:08:32 +00:00
|
|
|
|
since by that time the macro definitions may have been changed.
|
|
|
|
|
So instead we store in the tocname member the expanded node
|
2002-07-22 16:52:57 +00:00
|
|
|
|
name and the toc name concatenated together (with the necessary
|
|
|
|
|
html markup), since that's how they are output. */
|
2000-01-17 10:39:58 +00:00
|
|
|
|
if (!anchor)
|
2002-03-25 13:08:32 +00:00
|
|
|
|
s = expanded_node = expand_node_name (node_name);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
else
|
2002-03-25 13:08:32 +00:00
|
|
|
|
expanded_node = anchor;
|
|
|
|
|
if (splitting)
|
|
|
|
|
{
|
|
|
|
|
if (!anchor)
|
|
|
|
|
filename = nodename_to_filename (expanded_node);
|
|
|
|
|
else
|
|
|
|
|
filename = filename_part (current_output_filename);
|
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
/* Sigh... Need to HTML-escape the expanded node name like
|
2002-03-25 13:08:32 +00:00
|
|
|
|
add_anchor_name does, except that we are not writing this to
|
|
|
|
|
the output, so can't use add_anchor_name... */
|
2000-01-17 10:39:58 +00:00
|
|
|
|
/* The factor 5 in the next allocation is because the maximum
|
2002-03-25 13:08:32 +00:00
|
|
|
|
expansion of HTML-escaping is for the & character, which is
|
|
|
|
|
output as "&". 2 is for "> that separates node from tocname. */
|
2000-01-17 10:39:58 +00:00
|
|
|
|
d = tocname_and_node = (char *)xmalloc (2 + 5 * strlen (expanded_node)
|
2002-03-25 13:08:32 +00:00
|
|
|
|
+ strlen (tocname) + 1);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
if (!anchor)
|
2002-03-25 13:08:32 +00:00
|
|
|
|
{
|
|
|
|
|
for (; *s; s++)
|
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (cr_or_whitespace (*s))
|
|
|
|
|
*d++ = '-';
|
2002-03-25 13:08:32 +00:00
|
|
|
|
else if (! URL_SAFE_CHAR (*s))
|
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
sprintf (d, "_00%x", (unsigned char) *s);
|
2002-03-25 13:08:32 +00:00
|
|
|
|
/* do this manually since sprintf returns char * on
|
|
|
|
|
SunOS 4 and other old systems. */
|
|
|
|
|
while (*d)
|
|
|
|
|
d++;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
*d++ = *s;
|
|
|
|
|
}
|
|
|
|
|
strcpy (d, "\">");
|
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
else
|
2002-03-25 13:08:32 +00:00
|
|
|
|
/* Section outside any node, they provided explicit anchor. */
|
|
|
|
|
strcpy (d, anchor);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
strcat (d, tocname);
|
|
|
|
|
free (tocname); /* it was malloc'ed by substring() */
|
|
|
|
|
free (expanded_node);
|
|
|
|
|
toc_entry_alist[toc_counter]->name = tocname_and_node;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
toc_entry_alist[toc_counter]->name = tocname;
|
|
|
|
|
/* WARNING! The node name saved in containing_node member must
|
|
|
|
|
be the node name with _only_ macros expanded (the macros in
|
|
|
|
|
the node name are expanded by cm_node when it grabs the name
|
|
|
|
|
from the @node directive). Non-macros, like @value, @@ and
|
|
|
|
|
other @-commands must NOT be expanded in containing_node,
|
|
|
|
|
because toc_find_section_of_node looks up the node name where
|
|
|
|
|
they are also unexpanded. You *have* been warned! */
|
|
|
|
|
toc_entry_alist[toc_counter]->containing_node = xstrdup (node_name);
|
|
|
|
|
toc_entry_alist[toc_counter]->level = level;
|
|
|
|
|
toc_entry_alist[toc_counter]->number = toc_counter;
|
2002-03-25 13:08:32 +00:00
|
|
|
|
toc_entry_alist[toc_counter]->html_file = filename;
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
/* have to be done at least */
|
|
|
|
|
return toc_counter++;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Return the name of a chapter/section/subsection etc. that
|
|
|
|
|
corresponds to the node NODE. If the node isn't found,
|
|
|
|
|
return NULL.
|
|
|
|
|
|
|
|
|
|
WARNING! This function relies on NODE being unexpanded
|
|
|
|
|
except for macros (i.e., @value, @@, and other non-macros
|
|
|
|
|
should NOT be expanded), because the containing_node member
|
|
|
|
|
stores unexpanded node names.
|
|
|
|
|
|
|
|
|
|
Note that this function returns the first section whose
|
|
|
|
|
containing node is NODE. Thus, they will lose if they use
|
|
|
|
|
more than a single chapter structioning command in a node,
|
|
|
|
|
or if they have a node without any structuring commands. */
|
|
|
|
|
char *
|
2005-05-23 10:46:22 +00:00
|
|
|
|
toc_find_section_of_node (char *node)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
int i;
|
|
|
|
|
|
|
|
|
|
if (!node)
|
|
|
|
|
node = "";
|
|
|
|
|
for (i = 0; i < toc_counter; i++)
|
|
|
|
|
if (STREQ (node, toc_entry_alist[i]->containing_node))
|
|
|
|
|
return toc_entry_alist[i]->name;
|
|
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* free up memory used by toc entries */
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
toc_free (void)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
int i;
|
|
|
|
|
|
|
|
|
|
if (toc_counter)
|
|
|
|
|
{
|
|
|
|
|
for (i = 0; i < toc_counter; i++)
|
|
|
|
|
{
|
|
|
|
|
free (toc_entry_alist[i]->name);
|
|
|
|
|
free (toc_entry_alist[i]->containing_node);
|
|
|
|
|
free (toc_entry_alist[i]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
free (toc_entry_alist);
|
|
|
|
|
toc_entry_alist = NULL; /* to be sure ;-) */
|
|
|
|
|
toc_counter = 0; /* to be absolutley sure ;-) */
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2002-03-25 13:08:32 +00:00
|
|
|
|
/* Print table of contents in HTML. */
|
|
|
|
|
|
2000-01-17 10:39:58 +00:00
|
|
|
|
static void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
contents_update_html (void)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
int i;
|
|
|
|
|
int k;
|
|
|
|
|
int last_level;
|
|
|
|
|
|
|
|
|
|
/* does exist any toc? */
|
|
|
|
|
if (!toc_counter)
|
|
|
|
|
/* no, so return to sender ;-) */
|
|
|
|
|
return;
|
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
add_html_block_elt_args ("\n<div class=\"contents\">\n<h2>%s</h2>\n<ul>\n", _("Table of Contents"));
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
last_level = toc_entry_alist[0]->level;
|
2002-03-25 13:08:32 +00:00
|
|
|
|
|
2000-01-17 10:39:58 +00:00
|
|
|
|
for (i = 0; i < toc_counter; i++)
|
|
|
|
|
{
|
|
|
|
|
if (toc_entry_alist[i]->level > last_level)
|
|
|
|
|
{
|
|
|
|
|
/* unusual, but it is possible
|
|
|
|
|
@chapter ...
|
|
|
|
|
@subsubsection ... ? */
|
|
|
|
|
for (k = 0; k < (toc_entry_alist[i]->level-last_level); k++)
|
2005-05-23 10:46:22 +00:00
|
|
|
|
add_html_block_elt ("<ul>\n");
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
else if (toc_entry_alist[i]->level < last_level)
|
|
|
|
|
{
|
|
|
|
|
/* @subsubsection ...
|
|
|
|
|
@chapter ... this IS usual.*/
|
|
|
|
|
for (k = 0; k < (last_level-toc_entry_alist[i]->level); k++)
|
2005-05-23 10:46:22 +00:00
|
|
|
|
add_word ("</li></ul>\n");
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
2002-03-25 13:08:32 +00:00
|
|
|
|
/* No double entries in TOC. */
|
|
|
|
|
if (!(i && strcmp (toc_entry_alist[i]->name,
|
|
|
|
|
toc_entry_alist[i-1]->name) == 0))
|
|
|
|
|
{
|
|
|
|
|
/* each toc entry is a list item. */
|
2005-05-23 10:46:22 +00:00
|
|
|
|
add_word ("<li>");
|
2002-03-25 13:08:32 +00:00
|
|
|
|
|
2003-05-02 00:48:41 +00:00
|
|
|
|
/* Insert link -- to an external file if splitting, or
|
|
|
|
|
within the current document if not splitting. */
|
2005-05-23 10:46:22 +00:00
|
|
|
|
add_word ("<a ");
|
2002-03-25 13:08:32 +00:00
|
|
|
|
/* For chapters (only), insert an anchor that the short contents
|
|
|
|
|
will link to. */
|
|
|
|
|
if (toc_entry_alist[i]->level == 0)
|
|
|
|
|
{
|
|
|
|
|
char *p = toc_entry_alist[i]->name;
|
|
|
|
|
|
|
|
|
|
/* toc_entry_alist[i]->name has the form `foo">bar',
|
|
|
|
|
that is, it includes both the node name and anchor
|
|
|
|
|
text. We need to find where `foo', the node name,
|
|
|
|
|
ends, and use that in toc_FOO. */
|
|
|
|
|
while (*p && *p != '"')
|
|
|
|
|
p++;
|
2005-05-23 10:46:22 +00:00
|
|
|
|
add_word_args ("name=\"toc_%.*s\" ",
|
2002-03-25 13:08:32 +00:00
|
|
|
|
p - toc_entry_alist[i]->name, toc_entry_alist[i]->name);
|
|
|
|
|
}
|
2005-05-23 10:46:22 +00:00
|
|
|
|
add_word_args ("href=\"%s#%s</a>\n",
|
2002-03-25 13:08:32 +00:00
|
|
|
|
splitting ? toc_entry_alist[i]->html_file : "",
|
|
|
|
|
toc_entry_alist[i]->name);
|
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
last_level = toc_entry_alist[i]->level;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Go back to start level. */
|
|
|
|
|
if (toc_entry_alist[0]->level < last_level)
|
|
|
|
|
for (k = 0; k < (last_level-toc_entry_alist[0]->level); k++)
|
2005-05-23 10:46:22 +00:00
|
|
|
|
add_word ("</li></ul>\n");
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
add_word ("</li></ul>\n</div>\n\n");
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* print table of contents in ASCII (--no-headers)
|
|
|
|
|
May be we should create a new command line switch --ascii ? */
|
|
|
|
|
static void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
contents_update_info (void)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
int i;
|
|
|
|
|
int k;
|
|
|
|
|
|
|
|
|
|
if (!toc_counter)
|
|
|
|
|
return;
|
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
insert_string ((char *) _("Table of Contents"));
|
|
|
|
|
insert ('\n');
|
|
|
|
|
for (i = 0; i < strlen (_("Table of Contents")); i++)
|
|
|
|
|
insert ('*');
|
|
|
|
|
insert_string ("\n\n");
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
for (i = 0; i < toc_counter; i++)
|
|
|
|
|
{
|
|
|
|
|
if (toc_entry_alist[i]->level == 0)
|
2005-05-23 10:46:22 +00:00
|
|
|
|
add_char ('\n');
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
/* indention with two spaces per level, should this
|
|
|
|
|
changed? */
|
|
|
|
|
for (k = 0; k < toc_entry_alist[i]->level; k++)
|
2005-05-23 10:46:22 +00:00
|
|
|
|
insert_string (" ");
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
insert_string (toc_entry_alist[i]->name);
|
|
|
|
|
insert ('\n');
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
2005-05-23 10:46:22 +00:00
|
|
|
|
insert_string ("\n\n");
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* shortcontents in HTML; Should this produce a standalone file? */
|
|
|
|
|
static void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
shortcontents_update_html (char *contents_filename)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
int i;
|
2005-05-23 10:46:22 +00:00
|
|
|
|
char *toc_file = NULL;
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
/* does exist any toc? */
|
|
|
|
|
if (!toc_counter)
|
|
|
|
|
return;
|
2002-03-25 13:08:32 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
add_html_block_elt_args ("\n<div class=\"shortcontents\">\n<h2>%s</h2>\n<ul>\n", _("Short Contents"));
|
2002-03-25 13:08:32 +00:00
|
|
|
|
|
|
|
|
|
if (contents_filename)
|
|
|
|
|
toc_file = filename_part (contents_filename);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
for (i = 0; i < toc_counter; i++)
|
|
|
|
|
{
|
2002-03-25 13:08:32 +00:00
|
|
|
|
char *name = toc_entry_alist[i]->name;
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2002-03-25 13:08:32 +00:00
|
|
|
|
if (toc_entry_alist[i]->level == 0)
|
|
|
|
|
{
|
|
|
|
|
if (contents_filename)
|
2005-05-23 10:46:22 +00:00
|
|
|
|
add_word_args ("<li><a href=\"%s#toc_%s</a></li>\n",
|
2002-03-25 13:08:32 +00:00
|
|
|
|
splitting ? toc_file : "", name);
|
|
|
|
|
else
|
2005-05-23 10:46:22 +00:00
|
|
|
|
add_word_args ("<a href=\"%s#%s</a>\n",
|
2002-03-25 13:08:32 +00:00
|
|
|
|
splitting ? toc_entry_alist[i]->html_file : "", name);
|
|
|
|
|
}
|
|
|
|
|
}
|
2005-05-23 10:46:22 +00:00
|
|
|
|
add_word ("</ul>\n</div>\n\n");
|
2002-03-25 13:08:32 +00:00
|
|
|
|
if (contents_filename)
|
|
|
|
|
free (toc_file);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
2002-03-25 13:08:32 +00:00
|
|
|
|
/* short contents in ASCII (--no-headers). */
|
2000-01-17 10:39:58 +00:00
|
|
|
|
static void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
shortcontents_update_info (void)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
|
|
|
|
int i;
|
|
|
|
|
|
|
|
|
|
if (!toc_counter)
|
|
|
|
|
return;
|
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
insert_string ((char *) _("Short Contents"));
|
|
|
|
|
insert ('\n');
|
|
|
|
|
for (i = 0; i < strlen (_("Short Contents")); i++)
|
|
|
|
|
insert ('*');
|
|
|
|
|
insert_string ("\n\n");
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
|
|
|
|
for (i = 0; i < toc_counter; i++)
|
|
|
|
|
{
|
2002-03-25 13:08:32 +00:00
|
|
|
|
if (toc_entry_alist[i]->level == 0)
|
2005-05-23 10:46:22 +00:00
|
|
|
|
{
|
|
|
|
|
insert_string (toc_entry_alist[i]->name);
|
|
|
|
|
insert ('\n');
|
|
|
|
|
}
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
2005-05-23 10:46:22 +00:00
|
|
|
|
insert_string ("\n\n");
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2005-05-23 10:46:22 +00:00
|
|
|
|
cm_contents (int arg)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
/* the file where we found the @contents directive */
|
|
|
|
|
static char *contents_filename;
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
/* No need to mess with delayed stuff for XML and Docbook. */
|
|
|
|
|
if (xml)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (arg == START)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
int elt = STREQ (command, "contents") ? CONTENTS : SHORTCONTENTS;
|
|
|
|
|
xml_insert_element (elt, START);
|
|
|
|
|
xml_insert_element (elt, END);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2005-05-23 10:46:22 +00:00
|
|
|
|
else if (!handling_delayed_writes)
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
register_delayed_write (STREQ (command, "contents")
|
|
|
|
|
? "@contents" : "@shortcontents");
|
2000-01-17 10:39:58 +00:00
|
|
|
|
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (html && STREQ (command, "contents"))
|
2000-01-17 10:39:58 +00:00
|
|
|
|
{
|
2005-05-23 10:46:22 +00:00
|
|
|
|
if (contents_filename)
|
|
|
|
|
free (contents_filename);
|
|
|
|
|
contents_filename = xstrdup (current_output_filename);
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2005-05-23 10:46:22 +00:00
|
|
|
|
else if (html)
|
|
|
|
|
STREQ (command, "contents")
|
|
|
|
|
? contents_update_html () : shortcontents_update_html (contents_filename);
|
|
|
|
|
else if (no_headers)
|
|
|
|
|
STREQ (command, "contents")
|
|
|
|
|
? contents_update_info () : shortcontents_update_info ();
|
2000-01-17 10:39:58 +00:00
|
|
|
|
}
|