Files
valgrind/include/pub_tool_clientstate.h
Mark Wielaard 3392155359 Upgrade to GNU General Public License version 3
- Update COPYING and VEX/LICENSE.GPL to version 3.
- Update README, NEWS, docs/manual license and contributing text.
- Update file headers to say either version 3 of the License,
  or (at your option) any later version.
- Leave tests and perf file headers as is, unless the code is derived
  from Valgrind/VEX.
- Leave valgrind.h, cachegrind.h, callgrind.h, drd.h, helgrind.h,
  memcheck.h and dhat.h Hybrid-BSD licensed.
2025-10-18 00:55:07 +02:00

73 lines
2.6 KiB
C

/*--------------------------------------------------------------------*/
/*--- Misc client state info pub_tool_clientstate.h ---*/
/*--------------------------------------------------------------------*/
/*
This file is part of Valgrind, a dynamic binary instrumentation
framework.
Copyright (C) 2000-2017 Julian Seward
jseward@acm.org
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 3 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, see <http://www.gnu.org/licenses/>.
The GNU General Public License is contained in the file COPYING.
*/
#ifndef __PUB_TOOL_CLIENTSTATE_H
#define __PUB_TOOL_CLIENTSTATE_H
#include "pub_tool_basics.h" // VG_ macro
#include "pub_tool_xarray.h" // XArray
/* Note, this header requires pub_{core,tool}_xarray.h to be
included ahead of it. */
// Command line pieces, after they have been extracted from argv in
// m_main.main(). These are all NULL-terminated vectors.
/* Args for the client. */
extern XArray* /* of HChar* */ VG_(args_for_client);
/* Args for V. This is the concatenation of the following:
- contents of ~/.valgrindrc
- contents of $VALGRIND_OPTS
- contents of ./.valgrindrc
- args from the command line
in the stated order.
Only the last of these is passed onwards to child Valgrinds at
client sys_execve, since the children will re-acquire the first 3
categories for themselves. Therefore we also record the number of
these no-pass-at-execve arguments -- that is what
VG_(args_for_valgrind_noexecpass) is. */
extern XArray* /* of HChar* */ VG_(args_for_valgrind);
/* Number of leading args in VG_(args_for_valgrind) not to pass on at
exec time. */
extern Int VG_(args_for_valgrind_noexecpass);
/* The name of the client executable, as specified on the command
line. */
extern HChar* VG_(args_the_exename);
extern const HChar* VG_(resolved_exename);
#endif // __PUB_TOOL_CLIENTSTATE_H
/*--------------------------------------------------------------------*/
/*--- end ---*/
/*--------------------------------------------------------------------*/