version 1.11, 2018/12/04 02:53:51 |
version 1.17, 2018/12/31 08:38:21 |
|
|
#include <sys/types.h> |
#include <sys/types.h> |
|
|
#include <assert.h> |
#include <assert.h> |
#include <stddef.h> |
#include <stdio.h> |
#include <string.h> |
#include <string.h> |
|
|
#include "mandoc.h" |
#include "mandoc.h" |
|
|
typedef void (*roff_valid_fp)(ROFF_VALID_ARGS); |
typedef void (*roff_valid_fp)(ROFF_VALID_ARGS); |
|
|
static void roff_valid_br(ROFF_VALID_ARGS); |
static void roff_valid_br(ROFF_VALID_ARGS); |
|
static void roff_valid_fi(ROFF_VALID_ARGS); |
static void roff_valid_ft(ROFF_VALID_ARGS); |
static void roff_valid_ft(ROFF_VALID_ARGS); |
|
static void roff_valid_nf(ROFF_VALID_ARGS); |
static void roff_valid_sp(ROFF_VALID_ARGS); |
static void roff_valid_sp(ROFF_VALID_ARGS); |
|
|
static const roff_valid_fp roff_valids[ROFF_MAX] = { |
static const roff_valid_fp roff_valids[ROFF_MAX] = { |
roff_valid_br, /* br */ |
roff_valid_br, /* br */ |
NULL, /* ce */ |
NULL, /* ce */ |
|
roff_valid_fi, /* fi */ |
roff_valid_ft, /* ft */ |
roff_valid_ft, /* ft */ |
NULL, /* ll */ |
NULL, /* ll */ |
NULL, /* mc */ |
NULL, /* mc */ |
|
roff_valid_nf, /* nf */ |
NULL, /* po */ |
NULL, /* po */ |
NULL, /* rj */ |
NULL, /* rj */ |
roff_valid_sp, /* sp */ |
roff_valid_sp, /* sp */ |
Line 63 roff_valid_br(ROFF_VALID_ARGS) |
|
Line 67 roff_valid_br(ROFF_VALID_ARGS) |
|
{ |
{ |
struct roff_node *np; |
struct roff_node *np; |
|
|
if (n->child != NULL) |
if (n->next != NULL && n->next->type == ROFFT_TEXT && |
mandoc_vmsg(MANDOCERR_ARG_SKIP, man->parse, |
*n->next->string == ' ') { |
n->line, n->pos, "br %s", n->child->string); |
mandoc_msg(MANDOCERR_PAR_SKIP, n->line, n->pos, |
|
"br before text line with leading blank"); |
|
roff_node_delete(man, n); |
|
return; |
|
} |
|
|
if ((np = n->prev) == NULL) |
if ((np = n->prev) == NULL) |
return; |
return; |
Line 74 roff_valid_br(ROFF_VALID_ARGS) |
|
Line 82 roff_valid_br(ROFF_VALID_ARGS) |
|
case ROFF_br: |
case ROFF_br: |
case ROFF_sp: |
case ROFF_sp: |
case MDOC_Pp: |
case MDOC_Pp: |
mandoc_vmsg(MANDOCERR_PAR_SKIP, man->parse, |
mandoc_msg(MANDOCERR_PAR_SKIP, |
n->line, n->pos, "br after %s", roff_name[np->tok]); |
n->line, n->pos, "br after %s", roff_name[np->tok]); |
roff_node_delete(man, n); |
roff_node_delete(man, n); |
break; |
break; |
Line 84 roff_valid_br(ROFF_VALID_ARGS) |
|
Line 92 roff_valid_br(ROFF_VALID_ARGS) |
|
} |
} |
|
|
static void |
static void |
|
roff_valid_fi(ROFF_VALID_ARGS) |
|
{ |
|
if ((n->flags & NODE_NOFILL) == 0) |
|
mandoc_msg(MANDOCERR_FI_SKIP, n->line, n->pos, "fi"); |
|
} |
|
|
|
static void |
roff_valid_ft(ROFF_VALID_ARGS) |
roff_valid_ft(ROFF_VALID_ARGS) |
{ |
{ |
const char *cp; |
const char *cp; |
Line 96 roff_valid_ft(ROFF_VALID_ARGS) |
|
Line 111 roff_valid_ft(ROFF_VALID_ARGS) |
|
} |
} |
|
|
cp = n->child->string; |
cp = n->child->string; |
switch (*cp) { |
if (mandoc_font(cp, (int)strlen(cp)) != ESCAPE_ERROR) |
case '1': |
return; |
case '2': |
mandoc_msg(MANDOCERR_FT_BAD, n->line, n->pos, "ft %s", cp); |
case '3': |
|
case '4': |
|
case 'I': |
|
case 'P': |
|
case 'R': |
|
if (cp[1] == '\0') |
|
return; |
|
break; |
|
case 'B': |
|
if (cp[1] == '\0' || (cp[1] == 'I' && cp[2] == '\0')) |
|
return; |
|
break; |
|
case 'C': |
|
if (cp[1] != '\0' && cp[2] == '\0' && |
|
strchr("BIRW", cp[1]) != NULL) |
|
return; |
|
break; |
|
default: |
|
break; |
|
} |
|
|
|
mandoc_vmsg(MANDOCERR_FT_BAD, man->parse, |
|
n->line, n->pos, "ft %s", cp); |
|
roff_node_delete(man, n); |
roff_node_delete(man, n); |
} |
} |
|
|
static void |
static void |
|
roff_valid_nf(ROFF_VALID_ARGS) |
|
{ |
|
if (man->flags & ROFF_NOFILL) |
|
mandoc_msg(MANDOCERR_NF_SKIP, n->line, n->pos, "nf"); |
|
} |
|
|
|
static void |
roff_valid_sp(ROFF_VALID_ARGS) |
roff_valid_sp(ROFF_VALID_ARGS) |
{ |
{ |
struct roff_node *np; |
struct roff_node *np; |
|
|
if (n->child != NULL && n->child->next != NULL) |
|
mandoc_vmsg(MANDOCERR_ARG_EXCESS, man->parse, |
|
n->child->next->line, n->child->next->pos, |
|
"sp ... %s", n->child->next->string); |
|
|
|
if ((np = n->prev) == NULL) |
if ((np = n->prev) == NULL) |
return; |
return; |
|
|
switch (np->tok) { |
switch (np->tok) { |
case ROFF_br: |
case ROFF_br: |
mandoc_msg(MANDOCERR_PAR_SKIP, man->parse, |
mandoc_msg(MANDOCERR_PAR_SKIP, |
np->line, np->pos, "br before sp"); |
np->line, np->pos, "br before sp"); |
roff_node_delete(man, np); |
roff_node_delete(man, np); |
break; |
break; |
case MDOC_Pp: |
case MDOC_Pp: |
mandoc_msg(MANDOCERR_PAR_SKIP, man->parse, |
mandoc_msg(MANDOCERR_PAR_SKIP, |
n->line, n->pos, "sp after Pp"); |
n->line, n->pos, "sp after Pp"); |
roff_node_delete(man, n); |
roff_node_delete(man, n); |
break; |
break; |