* man2hlp.c (handle_tp_ip): Implement .IP and .TP macroses

(without arguments).
(handle_command): Call handle_tp_ip().
(main): Handle label and body of .TP paragraph.
This commit is contained in:
Andrew V. Samoilov 2002-10-17 15:12:34 +00:00
parent 2f4a67be36
commit 1070df9609
2 changed files with 56 additions and 12 deletions

View File

@ -1,3 +1,10 @@
2002-10-17 Andrew V. Samoilov <sav@bcs.zp.ua>
* man2hlp.c (handle_tp_ip): Implement .IP and .TP macroses
(without arguments).
(handle_command): Call handle_tp_ip().
(main): Handle label and body of .TP paragraph.
2002-10-17 Pavel Roskin <proski@gnu.org> 2002-10-17 Pavel Roskin <proski@gnu.org>
* view.c (view_ok_to_quit): Use the same dialog as the editor. * view.c (view_ok_to_quit): Use the same dialog as the editor.

View File

@ -45,6 +45,10 @@ static FILE *f_out; /* Output file */
static const char *c_in; /* Current input filename */ static const char *c_in; /* Current input filename */
static int indentation; /* Indentation level, n spaces */
static int tp_flag; /* Flag: .TP paragraph
1 = this line is .TP label,
2 = first line of label description. */
static char *topics = NULL; static char *topics = NULL;
struct node { struct node {
@ -226,7 +230,7 @@ print_string (char *buffer)
continue; continue;
} }
backslash_flag = 0; backslash_flag = 0;
fprintf (f_out, "%c", c); fputc (c, f_out);
} }
} else { } else {
/* Split into words */ /* Split into words */
@ -241,8 +245,11 @@ print_string (char *buffer)
newline (); newline ();
/* Words are separated by spaces */ /* Words are separated by spaces */
if (col > 0) { if (col > 0) {
fprintf (f_out, " "); fputc (' ', f_out);
col++; col++;
} else if (indentation) {
while (col++ < indentation)
fputc (' ', f_out);
} }
/* Attempt to handle backslash quoting */ /* Attempt to handle backslash quoting */
while (*(buffer)) { while (*(buffer)) {
@ -252,7 +259,7 @@ print_string (char *buffer)
continue; continue;
} }
backslash_flag = 0; backslash_flag = 0;
fprintf (f_out, "%c", c); fputc (c, f_out);
} }
/* Increase column */ /* Increase column */
col += len; col += len;
@ -438,6 +445,22 @@ handle_alt_font (char *buffer)
return 1; return 1;
} }
/* Handle .IP and .TP commands. is_tp is 1 for .TP, 0 for .IP */
/* buffer is not used now */
static void
handle_tp_ip (char *buffer, int is_tp)
{
if (col > 0)
newline ();
newline ();
if (is_tp) {
tp_flag = 1;
indentation = 0;
}
else
indentation = 8;
}
/* Handle all the roff dot commands. See man groff_man for details */ /* Handle all the roff dot commands. See man groff_man for details */
static void static void
handle_command (char *buffer) handle_command (char *buffer)
@ -448,6 +471,7 @@ handle_command (char *buffer)
strtok (buffer, " \t"); strtok (buffer, " \t");
if (strcmp (buffer, ".SH") == 0) { if (strcmp (buffer, ".SH") == 0) {
indentation = 0;
handle_node (buffer, 1); handle_node (buffer, 1);
} else if (strcmp (buffer, ".\\\"NODE") == 0) { } else if (strcmp (buffer, ".\\\"NODE") == 0) {
handle_node (buffer, 0); handle_node (buffer, 0);
@ -460,6 +484,7 @@ handle_command (char *buffer)
link_flag = 2; link_flag = 2;
} else if ((strcmp (buffer, ".PP") == 0) || (strcmp (buffer, ".P") == 0) } else if ((strcmp (buffer, ".PP") == 0) || (strcmp (buffer, ".P") == 0)
|| (strcmp (buffer, ".LP") == 0)) { || (strcmp (buffer, ".LP") == 0)) {
indentation = 0;
/* End of paragraph */ /* End of paragraph */
if (col > 0) if (col > 0)
newline (); newline ();
@ -504,12 +529,10 @@ handle_command (char *buffer)
*w++ = CHAR_FONT_NORMAL; *w++ = CHAR_FONT_NORMAL;
*w = 0; *w = 0;
print_string (buffer); print_string (buffer);
} else if ((strcmp (buffer, ".TP") == 0) } else if (strcmp (buffer, ".TP") == 0) {
|| (strcmp (buffer, ".IP") == 0)) { handle_tp_ip (buffer, 1);
/* TODO: Implement these indented paragraphs */ } else if (strcmp (buffer, ".IP") == 0) {
if (col > 0) handle_tp_ip (buffer, 0);
newline ();
newline ();
} else if (strcmp (buffer, ".\\\"TOPICS") == 0) { } else if (strcmp (buffer, ".\\\"TOPICS") == 0) {
if (out_row > 1) { if (out_row > 1) {
print_error print_error
@ -675,16 +698,30 @@ main (int argc, char **argv)
print_string (input_line); print_string (input_line);
newline (); newline ();
} }
} else if (link_flag) } else if (link_flag) {
/* The line is a link */ /* The line is a link */
handle_link (input_line); handle_link (input_line);
else if (buffer[0] == '.') } else if (buffer[0] == '.') {
/* The line is a roff command */ /* The line is a roff command */
handle_command (input_line); handle_command (input_line);
else { } else {
/* A normal line, just output it */ /* A normal line, just output it */
print_string (input_line); print_string (input_line);
} }
/* .TP label processed as usual line */
if (tp_flag) {
if (tp_flag == 1) {
tp_flag = 2;
} else {
tp_flag = 0;
indentation = 8;
if (col >= indentation)
newline ();
else
while (++col < indentation)
fputc (' ', f_out);
}
}
} }
newline (); newline ();