aboutsummaryrefslogtreecommitdiff
path: root/gprof/source.h
blob: ebdbb3b91b22709a85b6973633f761ed6353b11e (plain)
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
50
51
52
53
54
55
#ifndef source_h
#define source_h

#include <stdio.h>
#include "gprof.h"
#include "search_list.h"

typedef struct source_file
  {
    struct source_file *next;
    const char *name;		/* name of source file */
    int ncalls;			/* # of "calls" to this file */
    int num_lines;		/* # of lines in file */
    int nalloced;		/* number of lines allocated */
    void **line;		/* usage-dependent per-line data */
  }
Source_File;

/*
 * Options:
 */
extern bool create_annotation_files;	/* create annotated output files? */

/*
 * List of directories to search for source files:
 */
extern Search_List src_search_list;

/*
 * Chain of source-file descriptors:
 */
extern Source_File *first_src_file;

/*
 * Returns pointer to source file descriptor for PATH/FILENAME.
 */
extern Source_File *source_file_lookup_path PARAMS ((const char *path));
extern Source_File *source_file_lookup_name PARAMS ((const char *filename));

/*
 * Read source file SF output annotated source.  The annotation is at
 * MAX_WIDTH characters wide and for each source-line an annotation is
 * obtained by invoking function ANNOTE.  ARG is an argument passed to
 * ANNOTE that is left uninterpreted by annotate_source().
 *
 * Returns a pointer to the output file (which maybe stdout) such
 * that summary statistics can be printed.  If the returned file
 * is not stdout, it should be closed when done with it.
 */
extern FILE *annotate_source PARAMS ((Source_File * sf, int max_width,
				      void (*annote) (char *b, int w, int l,
						      void *arg),
				      void *arg));

#endif /* source_h */