Provided by: manpages-posix_2.16-1_all bug

NAME

       getconf - get configuration values

SYNOPSIS

       getconf [ -v specification ] system_var

       getconf [ -v specification ] path_var pathname

DESCRIPTION

       In  the  first  synopsis  form,  the  getconf utility shall write to the standard output the value of the
       variable specified by the system_var operand.

       In the second synopsis form, the getconf utility shall write to the standard  output  the  value  of  the
       variable specified by the path_var operand for the path specified by the pathname operand.

       The  value  of  each  configuration  variable  shall  be determined as if it were obtained by calling the
       function from which it is defined to be available by this volume of IEEE Std 1003.1-2001 or by the System
       Interfaces volume of IEEE Std 1003.1-2001 (see the OPERANDS section). The value shall reflect  conditions
       in the current operating environment.

OPTIONS

       The  getconf  utility shall conform to the Base Definitions volume of IEEE Std 1003.1-2001, Section 12.2,
       Utility Syntax Guidelines.

       The following option shall be supported:

       -v  specification

              Indicate a  specific  specification  and  version  for  which  configuration  variables  shall  be
              determined.  If  this option is not specified, the values returned correspond to an implementation
              default conforming compilation environment.

       If the command:

              getconf _POSIX_V6_ILP32_OFF32

       does not write "-1\n" or "undefined\n" to standard output, then commands of the form:

              getconf -v POSIX_V6_ILP32_OFF32 ...

       determine values for  configuration  variables  corresponding  to  the  POSIX_V6_ILP32_OFF32  compilation
       environment specified in c99 , the EXTENDED DESCRIPTION.

       If the command:

              getconf _POSIX_V6_ILP32_OFFBIG

       does not write "-1\n" or "undefined\n" to standard output, then commands of the form:

              getconf -v POSIX_V6_ILP32_OFFBIG ...

       determine  values  for  configuration  variables  corresponding  to the POSIX_V6_ILP32_OFFBIG compilation
       environment specified in c99 , the EXTENDED DESCRIPTION.

       If the command:

              getconf _POSIX_V6_LP64_OFF64

       does not write "-1\n" or "undefined\n" to standard output, then commands of the form:

              getconf -v POSIX_V6_LP64_OFF64 ...

       determine values  for  configuration  variables  corresponding  to  the  POSIX_V6_LP64_OFF64  compilation
       environment specified in c99 , the EXTENDED DESCRIPTION.

       If the command:

              getconf _POSIX_V6_LPBIG_OFFBIG

       does not write "-1\n" or "undefined\n" to standard output, then commands of the form:

              getconf -v POSIX_V6_LPBIG_OFFBIG ...

       determine  values  for  configuration  variables  corresponding  to the POSIX_V6_LPBIG_OFFBIG compilation
       environment specified in c99 , the EXTENDED DESCRIPTION.

OPERANDS

       The following operands shall be supported:

       path_var
              A name of a configuration variable. All of the variables in the Variable column of  the  table  in
              the  DESCRIPTION  of  the  fpathconf()  function  defined  in  the  System  Interfaces  volume  of
              IEEE Std 1003.1-2001, without the enclosing braces, shall be supported.   The  implementation  may
              add other local variables.

       pathname
              A pathname for which the variable specified by path_var is to be determined.

       system_var
              A name of a configuration variable. All of the following variables shall be supported:

               * The  names  in the Variable column of the table in the DESCRIPTION of the sysconf() function in
                 the System Interfaces volume of IEEE Std 1003.1-2001, except for the entries  corresponding  to
                 _SC_CLK_TCK, _SC_GETGR_R_SIZE_MAX, and _SC_GETPW_R_SIZE_MAX, without the enclosing braces.

              For compatibility with earlier versions, the following variable names shall also be supported:

                     POSIX2_C_BIND
                     POSIX2_C_DEV
                     POSIX2_CHAR_TERM
                     POSIX2_FORT_DEV
                     POSIX2_FORT_RUN
                     POSIX2_LOCALEDEF
                     POSIX2_SW_DEV
                     POSIX2_UPE
                     POSIX2_VERSION

              and  shall  be  equivalent  to the same name prefixed with an underscore.  This requirement may be
              removed in a future version.

               * The names of the symbolic constants used as the name argument of the confstr() function in  the
                 System Interfaces volume of IEEE Std 1003.1-2001, without the _CS_ prefix.

               * The  names of the symbolic constants listed under the headings ``Maximum Values'' and ``Minimum
                 Values'' in the description of  the  <limits.h>  header  in  the  Base  Definitions  volume  of
                 IEEE Std 1003.1-2001, without the enclosing braces.

              For compatibility with earlier versions, the following variable names shall also be supported:

                     POSIX2_BC_BASE_MAX
                     POSIX2_BC_DIM_MAX
                     POSIX2_BC_SCALE_MAX
                     POSIX2_BC_STRING_MAX
                     POSIX2_COLL_WEIGHTS_MAX
                     POSIX2_EXPR_NEST_MAX
                     POSIX2_LINE_MAX
                     POSIX2_RE_DUP_MAX

              and  shall  be  equivalent  to the same name prefixed with an underscore.  This requirement may be
              removed in a future version.

       The implementation may add other local values.

STDIN

       Not used.

INPUT FILES

       None.

ENVIRONMENT VARIABLES

       The following environment variables shall affect the execution of getconf:

       LANG   Provide a default value for the internationalization variables that are unset or  null.  (See  the
              Base  Definitions  volume of IEEE Std 1003.1-2001, Section 8.2, Internationalization Variables for
              the  precedence  of  internationalization  variables  used  to  determine  the  values  of  locale
              categories.)

       LC_ALL If  set  to  a  non-empty  string value, override the values of all the other internationalization
              variables.

       LC_CTYPE
              Determine the locale for the interpretation of sequences of bytes of text data as characters  (for
              example, single-byte as opposed to multi-byte characters in arguments).

       LC_MESSAGES
              Determine  the locale that should be used to affect the format and contents of diagnostic messages
              written to standard error.

       NLSPATH
              Determine the location of message catalogs for the processing of LC_MESSAGES .

ASYNCHRONOUS EVENTS

       Default.

STDOUT

       If the specified variable is defined on the system and its value is described to be  available  from  the
       confstr()  function  defined  in the System Interfaces volume of IEEE Std 1003.1-2001, its value shall be
       written in the following format:

              "%s\n", <value>

       Otherwise, if the specified variable is defined on  the  system,  its  value  shall  be  written  in  the
       following format:

              "%d\n", <value>

       If  the  specified  variable  is  valid,  but  is  undefined on the system, getconf shall write using the
       following format:

              "undefined\n"

       If the variable name is invalid or an error occurs, nothing shall be written to standard output.

STDERR

       The standard error shall be used only for diagnostic messages.

OUTPUT FILES

       None.

EXTENDED DESCRIPTION

       None.

EXIT STATUS

       The following exit values shall be returned:

        0     The specified variable is valid and information about its current state was written successfully.

       >0     An error occurred.

CONSEQUENCES OF ERRORS

       Default.

       The following sections are informative.

APPLICATION USAGE

       None.

EXAMPLES

       The following example illustrates the value of {NGROUPS_MAX}:

              getconf NGROUPS_MAX

       The following example illustrates the value of {NAME_MAX} for a specific directory:

              getconf NAME_MAX /usr

       The following example shows how to deal more carefully with results that might be unspecified:

              if value=$(getconf PATH_MAX /usr); then
                  if [ "$value" = "undefined" ]; then
                      echo PATH_MAX in /usr is infinite.
                  else
                      echo PATH_MAX in /usr is $value.
                  fi
              else
                  echo Error in getconf.
              fi

       Note that:

              sysconf(_SC_POSIX_C_BIND);

       and:

              system("getconf POSIX2_C_BIND");

       in a C program could give different answers. The sysconf() call supplies a value that corresponds to  the
       conditions  when  the  program  was  either  compiled  or  executed, depending on the implementation; the
       system() call to getconf always supplies  a  value  corresponding  to  conditions  when  the  program  is
       executed.

RATIONALE

       The  original  need for this utility, and for the confstr() function, was to provide a way of finding the
       configuration-defined default value for the PATH environment variable. Since PATH can be modified by  the
       user  to include directories that could contain utilities replacing the standard utilities, shell scripts
       need a way to determine the system-supplied PATH environment variable value  that  contains  the  correct
       search  path  for  the  standard  utilities.  It  was  later suggested that access to the other variables
       described in this volume of IEEE Std 1003.1-2001 could also be useful to applications.

       This functionality of getconf would not be adequately subsumed by another command such as:

              grep var /etc/conf

       because such a strategy would provide correct values  for  neither  those  variables  that  can  vary  at
       runtime, nor those that can vary depending on the path.

       Early proposal versions of getconf specified exit status 1 when the specified variable was valid, but not
       defined  on  the  system. The output string "undefined" is now used to specify this case with exit code 0
       because so many things depend on an exit code of zero when an invoked utility is successful.

FUTURE DIRECTIONS

       None.

SEE ALSO

       c99 , the Base Definitions volume of IEEE Std 1003.1-2001, <limits.h>, the System  Interfaces  volume  of
       IEEE Std 1003.1-2001, confstr(), pathconf(), sysconf(), system()

COPYRIGHT

       Portions of this text are reprinted and reproduced in electronic form from IEEE Std 1003.1, 2003 Edition,
       Standard  for  Information Technology -- Portable Operating System Interface (POSIX), The Open Group Base
       Specifications Issue 6, Copyright (C) 2001-2003 by the Institute of Electrical and Electronics Engineers,
       Inc and The Open Group. In the event of any discrepancy between this version and the  original  IEEE  and
       The  Open  Group  Standard,  the  original  IEEE and The Open Group Standard is the referee document. The
       original Standard can be obtained online at http://www.opengroup.org/unix/online.html .

IEEE/The Open Group                                   2003                                            GETCONF(P)