]>
git.cameronkatri.com Git - mandoc.git/blob - mandoc.c
1 /* $Id: mandoc.c,v 1.27 2010/07/25 19:05:59 joerg Exp $ */
3 * Copyright (c) 2008, 2009, 2010 Kristaps Dzonsons <kristaps@bsd.lv>
5 * Permission to use, copy, modify, and distribute this software for any
6 * purpose with or without fee is hereby granted, provided that the above
7 * copyright notice and this permission notice appear in all copies.
9 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
21 #include <sys/types.h>
31 #include "libmandoc.h"
33 static int a2time(time_t *, const char *, const char *);
37 mandoc_special(char *p
)
97 if ('+' == *p
|| '-' == *p
)
100 i
= ('s' != *(p
- 1));
121 if (ASCII_HYPH
== *p
)
123 if ('+' == *p
|| '-' == *p
) {
179 for ( ; *p
&& term
!= *p
; p
++)
180 if (ASCII_HYPH
== *p
)
182 return(*p
? (int)(p
- sv
) : 0);
185 for (i
= 0; *p
&& i
< len
; i
++, p
++)
186 if (ASCII_HYPH
== *p
)
188 return(i
== len
? (int)(p
- sv
) : 0);
193 mandoc_calloc(size_t num
, size_t size
)
197 ptr
= calloc(num
, size
);
208 mandoc_malloc(size_t size
)
223 mandoc_realloc(void *ptr
, size_t size
)
226 ptr
= realloc(ptr
, size
);
237 mandoc_strdup(const char *ptr
)
252 a2time(time_t *t
, const char *fmt
, const char *p
)
257 memset(&tm
, 0, sizeof(struct tm
));
259 pp
= strptime(p
, fmt
, &tm
);
260 if (NULL
!= pp
&& '\0' == *pp
) {
270 * Convert from a manual date string (see mdoc(7) and man(7)) into a
271 * date according to the stipulated date type.
274 mandoc_a2time(int flags
, const char *p
)
278 if (MTIME_MDOCDATE
& flags
) {
279 if (0 == strcmp(p
, "$" "Mdocdate$"))
281 if (a2time(&t
, "$" "Mdocdate: %b %d %Y $", p
))
285 if (MTIME_CANONICAL
& flags
|| MTIME_REDUCED
& flags
)
286 if (a2time(&t
, "%b %d, %Y", p
))
289 if (MTIME_ISO_8601
& flags
)
290 if (a2time(&t
, "%Y-%m-%d", p
))
293 if (MTIME_REDUCED
& flags
) {
294 if (a2time(&t
, "%d, %Y", p
))
296 if (a2time(&t
, "%Y", p
))
305 mandoc_eos(const char *p
, size_t sz
, int enclosed
)
314 * End-of-sentence recognition must include situations where
315 * some symbols, such as `)', allow prior EOS punctuation to
320 for (q
= p
+ (int)sz
- 1; q
>= p
; q
--) {
340 return(found
&& (!enclosed
|| isalnum((unsigned char)*q
)));
344 return(found
&& !enclosed
);
349 mandoc_hyph(const char *start
, const char *c
)
353 * Choose whether to break at a hyphenated character. We only
354 * do this if it's free-standing within a word.
357 /* Skip first/last character of buffer. */
358 if (c
== start
|| '\0' == *(c
+ 1))
360 /* Skip first/last character of word. */
361 if ('\t' == *(c
+ 1) || '\t' == *(c
- 1))
363 if (' ' == *(c
+ 1) || ' ' == *(c
- 1))
365 /* Skip double invocations. */
366 if ('-' == *(c
+ 1) || '-' == *(c
- 1))
369 if ('\\' == *(c
- 1))