Move and update documentation
[lttv.git] / lttv / lttv / sync / graph_functions.h
CommitLineData
467066ee 1/* This file is part of the Linux Trace Toolkit viewer
277e5b53 2 * Copyright (C) 2009, 2010 Benjamin Poirier <benjamin.poirier@polymtl.ca>
467066ee 3 *
277e5b53
BP
4 * This program is free software: you can redistribute it and/or modify it
5 * under the terms of the GNU Lesser General Public License as published by
6 * the Free Software Foundation, either version 2.1 of the License, or (at
7 * your option) any later version.
467066ee 8 *
277e5b53
BP
9 * This program is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
12 * License for more details.
467066ee 13 *
277e5b53
BP
14 * You should have received a copy of the GNU Lesser General Public License
15 * along with this program. If not, see <http://www.gnu.org/licenses/>.
467066ee
BP
16 */
17
18#ifndef GRAPH_FUNCTIONS_H
19#define GRAPH_FUNCTIONS_H
20
21struct _SyncState;
22
66eaf2eb
BP
23typedef void (GraphVariableFunction)(struct _SyncState* const syncState, const
24 unsigned int i);
467066ee
BP
25typedef void (GraphFunction)(struct _SyncState* const syncState, const
26 unsigned int i, const unsigned int j);
27
28typedef struct
29{
eb8e0e6f
BP
30 /*
31 * These functions are called at the beginning of the gnuplot script and
32 * may writes variables that can be reused in the plot or options lines
33 */
66eaf2eb 34 GraphVariableFunction* writeVariables;
eb8e0e6f
BP
35
36 /*
37 * All "Back" functions are called, then all "Fore" functions. They add
38 * graphs to a gnuplot "plot" command. All "Options" functions are called.
39 * They can set options via the gnuplot "set" command. Finaly, a replot is
40 * performed. This is done so that options may be set using dynamic
41 * gnuplot variables like GPVAL_X_MIN
42 */
43 /*
44 * These next three functions ("writeTraceTrace...") are for graphs where
45 * both axes are in the scale of timestamps.
46 */
c6356aa7
BP
47 GraphFunction* writeTraceTraceForePlots;
48 GraphFunction* writeTraceTraceBackPlots;
467066ee 49 GraphFunction* writeTraceTraceOptions;
eb8e0e6f
BP
50
51 /*
52 * These next three functions ("writeTraceTime...") are for graphs where
53 * the abscissa are in the scale of timestamps and the ordinate in the
54 * scale of seconds.
55 */
c6356aa7
BP
56 GraphFunction* writeTraceTimeForePlots;
57 GraphFunction* writeTraceTimeBackPlots;
467066ee
BP
58 GraphFunction* writeTraceTimeOptions;
59} GraphFunctions;
60
61
1d597550
BP
62FILE* createGraphsDir(const char* const graphsDir);
63char* changeToGraphsDir(const char* const graphsDir);
467066ee
BP
64void writeGraphsScript(struct _SyncState* const syncState);
65
66#endif
This page took 0.025856 seconds and 4 git commands to generate.