1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
/* $Id$ */
/*
* Copyright (c) 2008 Kristaps Dzonsons <kristaps@kth.se>
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the
* above copyright notice and this permission notice appear in all
* copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
* WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
* AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
* DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
* PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
* TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
* PERFORMANCE OF THIS SOFTWARE.
*/
#ifndef MMAIN_H
#define MMAIN_H
/*
* This is a convenience library for utilities implementing mdoc(3)
* accepting a similar set of command-line patterns. mmain handles
* error reporting (to the terminal), command-line parsing, preparing
* and reading the input file, and enacting the parse itself.
*/
#include "mdoc.h"
__BEGIN_DECLS
struct mmain;
struct mmain *mmain_alloc(void);
__dead void mmain_exit(struct mmain *, int);
int mmain_getopt(struct mmain *, int, char *[],
const char *, const char *,
const char *, void *,
int (*)(void *, int, char *));
struct mdoc *mmain_mdoc(struct mmain *, const char *);
void mmain_reset(struct mmain *);
void mmain_free(struct mmain *);
void mmain_prepare(struct mmain *, const char *);
struct mdoc *mmain_process(struct mmain *);
__END_DECLS
#endif /*!MMAIN_H*/
|