=================================================================== RCS file: /cvs/docbook2mdoc/macro.c,v retrieving revision 1.10 retrieving revision 1.12 diff -u -p -r1.10 -r1.12 --- docbook2mdoc/macro.c 2019/04/12 08:48:16 1.10 +++ docbook2mdoc/macro.c 2019/04/14 12:59:15 1.12 @@ -1,4 +1,4 @@ -/* $Id: macro.c,v 1.10 2019/04/12 08:48:16 schwarze Exp $ */ +/* $Id: macro.c,v 1.12 2019/04/14 12:59:15 schwarze Exp $ */ /* * Copyright (c) 2019 Ingo Schwarze * @@ -112,13 +112,16 @@ macro_addarg(struct format *f, const char *arg, int fl /* Escape us if we look like a macro. */ - if ((flags & ARG_QUOTED) == 0 && + if ((flags & (ARG_QUOTED | ARG_UPPER)) == 0 && (cp == arg || isspace((unsigned char)cp[-1])) && isupper((unsigned char)cp[0]) && islower((unsigned char)cp[1]) && (cp[2] == '\0' || cp[2] == ' ' || - (islower((unsigned char)cp[2]) && - (cp[3] == '\0' || cp[3] == ' ')))) + ((cp[3] == '\0' || cp[3] == ' ') && + (strncmp(cp, "Brq", 3) == 0 || + strncmp(cp, "Bro", 3) == 0 || + strncmp(cp, "Brc", 3) == 0 || + strncmp(cp, "Bsx", 3) == 0)))) fputs("\\&", stdout); if (*cp == '"') @@ -216,8 +219,6 @@ print_text(struct format *f, const char *word, int fla { switch (f->linestate) { case LINE_NEW: - if (*word == '.' || *word == '\'') - fputs("\\&", stdout); break; case LINE_TEXT: if (flags & ARG_SPACE) @@ -227,6 +228,8 @@ print_text(struct format *f, const char *word, int fla macro_close(f); break; } + if (f->linestate == LINE_NEW && (*word == '.' || *word == '\'')) + fputs("\\&", stdout); while (*word != '\0') { putchar(*word); if (*word++ == '\\')