xref: /illumos-gate/usr/src/tools/ctf/stabs/common/ctfstabs.h (revision 7a6d80f1660abd4755c68cbd094d4a914681d26e)
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License, Version 1.0 only
6  * (the "License").  You may not use this file except in compliance
7  * with the License.
8  *
9  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10  * or http://www.opensolaris.org/os/licensing.
11  * See the License for the specific language governing permissions
12  * and limitations under the License.
13  *
14  * When distributing Covered Code, include this CDDL HEADER in each
15  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16  * If applicable, add the following below this CDDL HEADER, with the
17  * fields enclosed by brackets "[]" replaced with your own identifying
18  * information: Portions Copyright [yyyy] [name of copyright owner]
19  *
20  * CDDL HEADER END
21  */
22 /*
23  * Copyright 2003 Sun Microsystems, Inc.  All rights reserved.
24  * Use is subject to license terms.
25  */
26 
27 #ifndef _CTFSTABS_H
28 #define	_CTFSTABS_H
29 
30 #include <stdio.h>
31 
32 #ifdef __cplusplus
33 extern "C" {
34 #endif
35 
36 #include "ctf_headers.h"
37 
38 /*
39  * The file-reading portion of ctfstabs communicates with the type-specific
40  * backends (genassym and forth) via the proc_ops_t, one of which is supplied
41  * by each backend.
42  */
43 typedef struct proc_ops {
44 	/*
45 	 * Called prior to reading the input template.  A return of -1 signals
46 	 * an error, and will halt processing.
47 	 */
48 	int (*po_init)(char *);
49 
50 	/*
51 	 * Called for each line in the input file.  If an error is returned,
52 	 * also signalled by a return of -1, input lines will be skipped, and
53 	 * this method will not be called, until a blank line is encountered.
54 	 */
55 	int (*po_line)(char *);
56 
57 	/*
58 	 * Called after all input lines have been processed.
59 	 */
60 	int (*po_fini)(void);
61 } proc_ops_t;
62 
63 extern proc_ops_t ga_ops;
64 extern proc_ops_t fth_ops;
65 
66 extern FILE *out;		/* the output file */
67 extern ctf_file_t *ctf;		/* the input object file */
68 
69 extern int parse_warn(char *, ...);
70 extern ctf_id_t find_type(char *);
71 
72 #ifdef __cplusplus
73 }
74 #endif
75 
76 #endif /* _CTFSTABS_H */
77