/*
* This file is part of ltrace.
* Copyright (C) 2012,2013 Petr Machata, Red Hat Inc.
* Copyright (C) 2009,2010 Joe Damato
* Copyright (C) 1998,2002,2008 Juan Cespedes
* Copyright (C) 2006 Ian Wienand
* Copyright (C) 2006 Steve Fink
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA
*/
#ifndef _OPTIONS_H_
#define _OPTIONS_H_
#include <stdio.h>
#include <sys/types.h>
#include <sys/time.h>
#include "forward.h"
#include "vect.h"
struct options_t {
int align; /* -a: default alignment column for results */
char * user; /* -u: username to run command as */
int syscalls; /* -S: display system calls */
int demangle; /* -C: demangle low-level names into user-level names */
int indent; /* -n: indent trace output according to program flow */
FILE *output; /* output to a specific file */
int summary; /* count time, calls, and report a summary on program exit */
int debug; /* debug */
size_t arraylen; /* default maximum # of array elements printed */
size_t strlen; /* default maximum # of bytes printed in strings */
int follow; /* trace child processes */
int no_signals; /* don't print signals */
#if defined(HAVE_UNWINDER)
int bt_depth; /* how may levels of stack frames to show */
#endif /* defined(HAVE_UNWINDER) */
struct filter *plt_filter;
struct filter *static_filter;
/* A filter matching library names of libraries, whose
* exported symbols we wish to trace. */
struct filter *export_filter;
int hide_caller; /* Whether caller library should be hidden. */
};
extern struct options_t options;
extern int opt_i; /* instruction pointer */
extern int opt_r; /* print relative timestamp */
extern int opt_t; /* print absolute timestamp */
extern int opt_T; /* show the time spent inside each call */
struct opt_p_t {
pid_t pid;
struct opt_p_t *next;
};
extern struct opt_p_t *opt_p; /* attach to process with a given pid */
enum opt_F_kind {
OPT_F_UNKNOWN = 0,
OPT_F_BROKEN,
OPT_F_FILE,
OPT_F_DIR,
};
struct opt_F_t {
char *pathname;
int own_pathname : 1;
enum opt_F_kind kind : 2;
};
/* If entry->kind is OPT_F_UNKNOWN, figure out whether it should be
* OPT_F_FILE or OPT_F_DIR, cache the result, and return it. Return
* OPT_F_BROKEN on failure. Error message will have been printed in
* that case. */
enum opt_F_kind opt_F_get_kind(struct opt_F_t *entry);
/* Destroy and release any memory associated with ENTRY (but don't
* free ENTRY itself). */
void opt_F_destroy(struct opt_F_t *entry);
/* PATHS contains colon-separated list of values, akin to enviroment
* variables PATH, PYTHONPATH, and others. No escaping is possible.
* The list is split and added to VEC, which shall be a vector
* initialized like VECT_INIT(VEC, struct opt_F_t); Returns 0 on
* success or a negative value on failure. */
int parse_colon_separated_list(const char *paths, struct vect *vec);
/* Vector of struct opt_F_t. */
extern struct vect opt_F;
extern char **process_options(int argc, char **argv);
#endif /* _OPTIONS_H_ */