]> diplodocus.org Git - nmh/blob - sbr/fmt_new.c
Another pass at cleaning up (some of) the manpages.
[nmh] / sbr / fmt_new.c
1
2 /*
3 * fmt_new.c -- read format file/string and normalize
4 *
5 * This code is Copyright (c) 2002, by the authors of nmh. See the
6 * COPYRIGHT file in the root directory of the nmh distribution for
7 * complete copyright information.
8 */
9
10 #include <h/mh.h>
11 #include <h/utils.h>
12
13 #define QUOTE '\\'
14
15 static char *formats = 0;
16
17 /*
18 * static prototypes
19 */
20 static void normalize (char *);
21
22
23 /*
24 * Get new format string
25 */
26
27 char *
28 new_fs (char *form, char *format, char *default_fs)
29 {
30 struct stat st;
31 register FILE *fp;
32
33 if (formats)
34 free (formats);
35
36 if (form) {
37 if ((fp = fopen (etcpath (form), "r")) == NULL)
38 adios (form, "unable to open format file");
39
40 if (fstat (fileno (fp), &st) == -1)
41 adios (form, "unable to stat format file");
42
43 formats = mh_xmalloc ((size_t) st.st_size + 1);
44
45 if (read (fileno(fp), formats, (int) st.st_size) != st.st_size)
46 adios (form, "error reading format file");
47
48 formats[st.st_size] = '\0';
49
50 fclose (fp);
51 } else {
52 formats = getcpy (format ? format : default_fs);
53 }
54
55 normalize (formats); /* expand escapes */
56
57 return formats;
58 }
59
60
61 void
62 free_fs (){
63 free (formats);
64 formats = 0;
65 }
66
67
68 /*
69 * Expand escapes in format strings
70 */
71
72 static void
73 normalize (char *cp)
74 {
75 char *dp;
76
77 for (dp = cp; *cp; cp++) {
78 if (*cp != QUOTE) {
79 *dp++ = *cp;
80 } else {
81 switch (*++cp) {
82 case 'b':
83 *dp++ = '\b';
84 break;
85
86 case 'f':
87 *dp++ = '\f';
88 break;
89
90 case 'n':
91 *dp++ = '\n';
92 break;
93
94 case 'r':
95 *dp++ = '\r';
96 break;
97
98 case 't':
99 *dp++ = '\t';
100 break;
101
102 case '\n':
103 break;
104
105 case 0:
106 cp--; /* fall */
107 default:
108 *dp++ = *cp;
109 break;
110 }
111 }
112 }
113 *dp = '\0';
114 }