FreeBSD manual
download PDF document: getlocalbase.3.pdf
GETLOCALBASE(3) FreeBSD Library Functions Manual GETLOCALBASE(3)
NAME
getlocalbase - return the path to the local software directory
LIBRARY
System Utilities Library (libutil, -lutil)
SYNOPSIS
#include <libutil.h>
const char*
getlocalbase(void);
DESCRIPTION
The getlocalbase() function returns the path to the local software base
directory. Normally this is the /usr/local directory. First the
LOCALBASE environment variable is checked. If that does not exist then
the user.localbase sysctl is checked. If that also does not exist then
the value of the LOCALBASE_PATH compile-time variable is used. If that
is undefined then the system default, _PATH_LOCALBASE is used.
The contents of the string returned by the getlocalbase() function shall
not be modified.
IMPLEMENTATION NOTES
Calls to getlocalbase() will perform a setugid check on the running
binary before checking the environment.
The address returned by getlocalbase() will point into the executing
processes environment if it is the result of getenv(LOCALBASE), to a
static buffer if it is the result of sysctl(user.localbase), and to a
constant string if the compiled in default value is returned.
The same value will be returned on successive calls during the run-time
of the program, ignoring any changes to the environment variable or the
sysctl value that might have been made.
The getlocalbase() function can be compiled with a non-default value of
LOCALBASE_CTL_LEN. A value of 0 will disable fetching of the sysctl
value, a value less than MAXPATHLEN will put a limit on the maximum
string length supported for this sysctl value. If built with a non-
default value of LOCALBASE_CTL_LEN, a value of the user.localbase sysctl
variable longer than this value will make getlocalbase() return a valid
string that is not a valid path prefix in any filesystem.
RETURN VALUES
The getlocalbase() function returns a pointer to a string, whose length
may exceed MAXPATHLEN, if it has been obtained from the environment.
ENVIRONMENT
The getlocalbase() library function retrieves the LOCALBASE environment
variable.
ERRORS
The getlocalbase() function always succeeds and returns a valid pointer
to a string.
SEE ALSO
Stefan Esser <se@FreeBSD.org>.
FreeBSD 14.0-RELEASE-p11 July 11, 2023 FreeBSD 14.0-RELEASE-p11