/* * 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_ */