Option |
Default |
-cache-dir |
<purifyhome>/cache |
Sets the global directory where Purify caches the instrumented versions of object files and libraries. |
-always-use-cache-dir |
no |
Forces all Purify'd libraries and object files to be written to the global cache directory, even if the originals reside in writable directories. |
-forbidden-directories |
system dependent |
Use this option to specify a colon-separated list of directories into which Purify cannot write files, even if the directories listed are writable. All the subdirectories of forbidden directories are also forbidden. The default values are: Solaris
(32 bit): /lib:/opt:/usr/lib:/usr/ccs/lib: Solaris
(64 bit): /lib/sparcv9:/usr/lib/sparcv9: HP-UX: /lib:/usr/lib:/usr/local:/opt:/usr/ccs IRIX (32 bit): /lib:/lib32:/usr/lib:/usr/lib32:/usr/local IRIX (64 bit): /lib:/lib64:/usr/lib:/usr/lib64:/usr/local |
-auto-mount-prefix |
/tmp_mnt |
Specifies the directory prefix used by the file system auto-mounter, usually /tmp_mnt, to mount remote file systems in NFS environments. Use this option to strip the prefix, if present, in order to improve the readability of source filenames in Purify reports. Note: If your automounter alters the prefix, instead
of adding a prefix, use: -auto-mount-prefix=/tmp_mnt/home:/homes
If this option is not set correctly, Purify might be unable to access files on auto-mounted filesystems. The automounter might not recognize their names. |
-demangle-program |
not set |
Specifies the filter you want Purify to use for demangling the names of variables and functions. For example: -demangle-program=/usr/bin/c++filt The filter c++filt is the name of the demangle program for Sun and GNU compilers. Use this option if Purify's internal demangling of names is insufficient. |
-force-rebuild |
not set |
Forces your entire program to be reinstrumented
(irrespective of whether object files and libraries have been updated
since they were last instrumented). |
-linker |
system dependent |
Specifies the name of the linker that Purify should invoke to produce the executable. Use this option only if you need to bypass the default linker. The default linkers are: Solaris: /usr/ccs/bin/ld
Purify does not support this option on IRIX. |
-g++ |
no |
Purify sets this option automatically if you call the g++ compiler. Purify knows that the g++ compiler is being used and invokes special processing to avoid spurious ABR errors with the delete operator. It also sets the default demangling mode so that g++ mangled function names are properly resolved. |
-collector |
not set |
Specifies the name of the collect program to be used to sequence and collect static constructors in C++ code. You may have to set this option to the name of the collect program used by the g++ compiler. To find the name of the collect program used by the g++ compiler, use: % g++ -v myprogram.c For example, if the collect program is: /opt/gcc/2.6.3/lib/gcc-lib/hppa1.1-hp-hpux8.07/2.6.3/ld use the command: % purify -g++=yes -collector=/opt/gcc/2.6.3/lib/gcc-lib/hppa1.1-hp-hpux8.07/2.6.3/ld g++ myprogram.c Notes:
|
-help |
|
Prints a short help message about how to use the command line options. |
-ignore-runtime-environment |
no |
Builds into an executable all the run-time options specified on the link line along with any run-time options specified in the PURIFYOPTIONS and PUREOPTIONS environment variables. When the Purify'd program is run, Purify ignores the current option values set in environment variables, and instead uses the built-in values. Use the -ignore-runtime-environment option when:
The -ignore-runtime-environment option also builds in suppressions. If you do not explicitly specify the -add-suppression-files option, Purify uses the default suppression files .purify and .purify.<platform>. When a program has been built with -ignore-runtime-environment,
you can display, but not change, the run-time options in the Purify Viewer.
You can also display the options using command Use the -ignore-runtime-environment option at build time only. Purify ignores this option if you specify it at run time. |
-lib-path-length |
not set |
Specifies a minimum length for all library path names embedded inside your instrumented program or instrumented shared libraries. Purify extends the path names to the specified length by prepending a series of slashes (/), which has no effect on the meaning. For example, the following command: % purify -lib-path-length=50 cc -g myprog.c \ would cause the library to be registered in
the resulting a.out
file as something like: This option is intended to allow another team to work with your instrumented programs, even though they place the shared libraries in directories structured differently from yours. When the other team runs your instrumented program, they must use the option -replace-path to substitute the path that their environment requires. Use this option to make sure that the path length is sufficiently long to accommodate the longest absolute library path name that is likely to occur on the other team's system. The value assigned must be less than or equal to 700. 300 is ordinarily a safe choice. This option automatically calls the -force-rebuild option to rebuild all components of your program. This
option is supported only on HP-UX. |
-print-home-dir |
|
Prints the name of the directory where Purify is installed, then exits. For example, you can use this option to build the compiler command when including the purify.h file from the installation directory: $CC -c $CFLAGS -I`purify -print-home-dir` myprogram.c If you use this option to prefix internal product libraries such as libinternal, you must qualify the library path with the appropriate library sub-directory. For example: `purify -printhomedir`/lib32/solaris2_threads.so `purify -printhomedir`/lib64/solaris2_threads.so
|
-program-name |
argv[0] |
Specifies the full pathname of the Purify'd program if argv[0] contains an undesirable or incorrect value. For example, when your program is invoked by an exec call whose path differs from the argument that it passes as argv[0] to your program. In such cases, Purify cannot find the program file and therefore cannot interpret addresses as function names. You might need to use this option if you find little or no symbolic information in the messages from your Purify'd program. |
-test-license |
|
Verifies that you are licensed for the correct feature version of Purify. |
-usage |
|
Prints a short help message about how to use the command line options. |
-version |
|
Purify prints its version string to stdout and then exits. For example, you can identify which version of Purify is in use while running a test suite by incorporating these lines in your test harness scripts: #!/bin/sh
|
-ignore-objdebug |
no |
If set to yes, instructs Purify to pass the flags +noobjdebug and +nocopyobjdebug to the linker. This excludes the extra +objdebug debug information from the instrumented files. This option is supported only on HP-UX 11.X.
|
-ignore-objdebug-shlib |
NULL |
Use this option when you are using the HP-UX +objdebug compiler option to specify a colon-separated list of libraries for which you do not want +objdebug debug information. Note that Purify does instrument these libraries, but does not copy the extra debug information into the instrumented versions. This option is supported only on HP-UX 11.X.
|