2017-06-05 06:33:47 +02:00
|
|
|
.\" libbsd man page
|
|
|
|
.\"
|
2024-01-08 23:39:19 +01:00
|
|
|
.\" Copyright © 2017-2024 Guillem Jover <guillem@hadrons.org>
|
2017-06-05 06:33:47 +02:00
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\" 3. The name of the author may not be used to endorse or promote products
|
|
|
|
.\" derived from this software without specific prior written permission.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
|
|
|
|
.\" INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
|
|
|
|
.\" AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
|
|
|
.\" THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
|
|
|
.\" EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
|
|
|
.\" PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
|
|
|
|
.\" OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
|
|
|
.\" WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
|
|
|
|
.\" OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
|
|
|
.\" ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
.\"
|
2024-01-08 23:39:19 +01:00
|
|
|
.Dd January 8, 2024
|
2022-08-03 02:21:16 +02:00
|
|
|
.Dt libbsd 7
|
2017-06-05 06:33:47 +02:00
|
|
|
.Os
|
|
|
|
.Sh NAME
|
|
|
|
.Nm libbsd
|
|
|
|
.Nd utility functions from BSD systems
|
|
|
|
.Sh DESCRIPTION
|
|
|
|
The
|
|
|
|
.Nm libbsd
|
2019-03-10 10:03:12 +00:00
|
|
|
library provides a set of compatibility macros and functions commonly found
|
2017-06-05 06:33:47 +02:00
|
|
|
on BSD-based systems.
|
|
|
|
Its purpose is to make those available on non-BSD based systems to ease
|
|
|
|
portability.
|
|
|
|
.Pp
|
|
|
|
The library can be used in an overlay mode, which is the preferred way, so
|
|
|
|
that the code is portable and requires no modification to the original BSD
|
|
|
|
code.
|
|
|
|
This can be done easily with the
|
2022-10-05 01:35:08 +02:00
|
|
|
.Xr pkgconf 1
|
2017-06-05 06:33:47 +02:00
|
|
|
library named
|
|
|
|
.Pa libbsd-overlay .
|
|
|
|
Or by adding the system-specific include directory with the
|
|
|
|
.Pa bsd/
|
|
|
|
suffix to the list of system include paths.
|
|
|
|
With
|
|
|
|
.Nm gcc
|
|
|
|
this could be
|
|
|
|
.Ar -isystem ${includedir}/bsd .
|
|
|
|
In addition the
|
|
|
|
.Dv LIBBSD_OVERLAY
|
|
|
|
pre-processor variable needs to be defined.
|
|
|
|
The includes in this case should be the usual system ones, such as
|
|
|
|
.In unistd.h .
|
|
|
|
.Pp
|
|
|
|
The other way to use the library is to use the namespaced headers,
|
2022-10-06 03:59:33 +02:00
|
|
|
which is a discouraged way, being less portable as it makes using
|
2017-06-05 06:33:47 +02:00
|
|
|
.Nm libbsd
|
|
|
|
mandatory and it will not work on BSD-based systems, and requires
|
|
|
|
modifying original BSD code.
|
|
|
|
This can be done with the
|
2022-10-05 01:35:08 +02:00
|
|
|
.Xr pkgconf 1
|
2017-06-05 06:33:47 +02:00
|
|
|
library named
|
|
|
|
.Pa libbsd .
|
|
|
|
The includes in this case should be namespaced with
|
|
|
|
.Pa bsd/ ,
|
|
|
|
such as
|
|
|
|
.In bsd/unistd.h .
|
|
|
|
.Pp
|
|
|
|
The package also provides a
|
2021-02-18 23:38:30 +01:00
|
|
|
.Nm libbsd-ctor
|
2017-06-05 06:33:47 +02:00
|
|
|
static library that can be used to inject automatic constructors into a
|
|
|
|
program so that the
|
2024-01-08 23:40:31 +01:00
|
|
|
.Xr setproctitle_init 3bsd
|
2017-06-05 06:33:47 +02:00
|
|
|
function gets invoked automatically at startup time.
|
|
|
|
This can be done with the
|
2022-10-05 01:35:08 +02:00
|
|
|
.Xr pkgconf 1
|
2017-06-05 06:33:47 +02:00
|
|
|
library named
|
|
|
|
.Pa libbsd-ctor .
|
|
|
|
.Sh HEADERS
|
|
|
|
The following are the headers provided by
|
|
|
|
.Nm libbsd ,
|
|
|
|
that extend the standard system headers.
|
|
|
|
They can work in normal or overlay modes, for the former they need to
|
|
|
|
be prefixed with
|
|
|
|
.Pa bsd/ .
|
|
|
|
.Pp
|
|
|
|
.Bl -tag -width 4m -compact
|
|
|
|
.It In bitstring.h
|
|
|
|
.It In err.h
|
|
|
|
.It In getopt.h
|
2021-02-07 10:56:51 +01:00
|
|
|
.It In grp.h
|
2018-05-21 00:20:49 +02:00
|
|
|
.It In inttypes.h
|
2017-06-05 06:33:47 +02:00
|
|
|
.It In libutil.h
|
|
|
|
.It In md5.h
|
|
|
|
.It In netinet/ip_icmp.h
|
|
|
|
.It In nlist.h
|
2021-02-07 10:56:51 +01:00
|
|
|
.It In pwd.h
|
2017-06-05 06:33:47 +02:00
|
|
|
.It In readpassphrase.h
|
|
|
|
.It In stdio.h
|
|
|
|
.It In stdlib.h
|
|
|
|
.It In string.h
|
|
|
|
.It In stringlist.h
|
|
|
|
.It In sys/bitstring.h
|
|
|
|
.It In sys/cdefs.h
|
|
|
|
.It In sys/endian.h
|
2021-02-07 10:56:51 +01:00
|
|
|
.It In sys/param.h
|
2017-06-05 06:33:47 +02:00
|
|
|
.It In sys/poll.h
|
|
|
|
.It In sys/queue.h
|
2017-06-05 05:43:26 +02:00
|
|
|
.It In sys/time.h
|
2017-06-05 06:33:47 +02:00
|
|
|
.It In sys/tree.h
|
|
|
|
.It In timeconv.h
|
|
|
|
.It In unistd.h
|
|
|
|
.It In vis.h
|
|
|
|
.It In wchar.h
|
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
The following is a
|
|
|
|
.Pa libbsd
|
|
|
|
specific convenience header, that includes some of the extended headers.
|
|
|
|
It only works in non-overlay mode.
|
|
|
|
.Pp
|
|
|
|
.Bl -tag -width 4m -compact
|
|
|
|
.It In bsd/bsd.h
|
|
|
|
.El
|
2023-10-10 01:53:32 +02:00
|
|
|
.Sh VARIANTS
|
2021-02-07 10:56:51 +01:00
|
|
|
Some functions have different prototypes depending on the BSD where they
|
|
|
|
originated from, and these various implementations provided are selectable
|
|
|
|
at build-time.
|
|
|
|
.Pp
|
|
|
|
This is the list of functions that provide multiple implementations:
|
2022-04-04 11:49:52 +02:00
|
|
|
.Pp
|
|
|
|
.Bl -tag -width 4m -compact
|
2024-01-08 23:40:31 +01:00
|
|
|
.It Xr strnvis 3bsd
|
|
|
|
.It Xr strnunvis 3bsd
|
2021-02-07 10:56:51 +01:00
|
|
|
.Nx
|
|
|
|
added
|
2024-01-08 23:40:31 +01:00
|
|
|
.Xr strnvis 3bsd
|
2021-02-07 10:56:51 +01:00
|
|
|
and
|
2024-01-08 23:40:31 +01:00
|
|
|
.Xr strnunvis 3bsd
|
2021-02-07 10:56:51 +01:00
|
|
|
but unfortunately made it incompatible with the existing one in
|
|
|
|
.Ox
|
|
|
|
and Freedesktop's libbsd (the former having existed for over ten years).
|
|
|
|
Despite this incompatibility being reported during development (see
|
|
|
|
http://gnats.netbsd.org/44977) they still shipped it.
|
|
|
|
Even more unfortunately
|
|
|
|
.Fx
|
2024-01-08 23:37:43 +01:00
|
|
|
and later macOS picked up this incompatible implementation.
|
2021-02-07 10:56:51 +01:00
|
|
|
.Pp
|
|
|
|
Provide both implementations and default for now to the historical one to
|
|
|
|
avoid breakage, but we will switch to the
|
|
|
|
.Nx
|
|
|
|
one in a later release, which is internally consistent with the other
|
2024-01-08 23:40:31 +01:00
|
|
|
.Xr vis 3bsd
|
2021-02-07 10:56:51 +01:00
|
|
|
functions and is now more widespread.
|
|
|
|
Define
|
|
|
|
.Dv LIBBSD_NETBSD_VIS
|
|
|
|
to switch to the
|
2021-10-07 23:08:42 +02:00
|
|
|
.Nx
|
|
|
|
one now.
|
2021-02-07 10:56:51 +01:00
|
|
|
Define
|
|
|
|
.Dv LIBBSD_OPENBSD_VIS
|
|
|
|
to keep using the
|
|
|
|
.Ox
|
|
|
|
one.
|
|
|
|
.El
|
2017-06-05 06:33:47 +02:00
|
|
|
.Sh DEPRECATED
|
|
|
|
Some functions have been deprecated, they will emit warnings at compile time
|
|
|
|
and possibly while being linked at run-time.
|
|
|
|
This might be due to the functions not being portable at all to other
|
|
|
|
systems, making the package not buildable there; not portable in a correct
|
|
|
|
or non-buggy way; or because there are better more portable replacements now.
|
|
|
|
.Pp
|
|
|
|
This is the list of currently deprecated macros and functions:
|
|
|
|
.Bl -tag -width 4m
|
2024-01-08 23:40:31 +01:00
|
|
|
.It Xr fgetln 3bsd
|
2017-06-05 06:33:47 +02:00
|
|
|
Unportable, requires assistance from the stdio layer.
|
|
|
|
An implementation has to choose between leaking buffers or being reentrant
|
|
|
|
for a limited amount of streams (this implementation chose the latter with
|
|
|
|
a limit of 32).
|
|
|
|
Use
|
2023-10-10 01:52:37 +02:00
|
|
|
.Xr getline 3
|
2017-06-05 06:33:47 +02:00
|
|
|
instead, which is available in many systems and required by
|
|
|
|
.St -p1003.1-2008 .
|
2024-01-08 23:40:31 +01:00
|
|
|
.It Xr fgetwln 3bsd
|
2018-05-21 03:15:59 +02:00
|
|
|
Unportable, requires assistance from the stdio layer.
|
|
|
|
An implementation has to choose between leaking buffers or being reentrant
|
|
|
|
for a limited amount of streams (this implementation chose the latter with
|
|
|
|
a limit of 32).
|
|
|
|
Use
|
2023-10-10 01:52:37 +02:00
|
|
|
.Xr fgetwc 3
|
2018-05-21 03:15:59 +02:00
|
|
|
instead, which is available in many systems and required by
|
|
|
|
.St -isoC-99
|
|
|
|
and
|
|
|
|
.St -p1003.1-2001 .
|
2024-01-08 23:40:31 +01:00
|
|
|
.It Xr funopen 3bsd
|
2017-06-05 06:33:47 +02:00
|
|
|
Unportable, requires assistance from the stdio layer or some hook framework.
|
2024-01-08 23:57:45 +01:00
|
|
|
On glibc- and musl-based systems the
|
2023-10-10 01:52:37 +02:00
|
|
|
.Xr fopencookie 3
|
2017-06-05 06:33:47 +02:00
|
|
|
function can be used.
|
|
|
|
Otherwise the code needs to be prepared for neither of these functions being
|
|
|
|
available.
|
|
|
|
.El
|
2017-09-02 19:55:50 +02:00
|
|
|
.Sh SUPERSEDED
|
|
|
|
Some functions have been superseded by implementations in other system
|
|
|
|
libraries, and might disappear on the next SONAME bump, assuming those
|
|
|
|
other implementation have widespread deployment, or the implementations
|
|
|
|
are present in all major
|
|
|
|
.Nm libc
|
|
|
|
for example.
|
2017-06-05 06:33:47 +02:00
|
|
|
.Pp
|
2017-09-02 19:55:50 +02:00
|
|
|
.Bl -tag -width 4m -compact
|
2024-01-08 23:40:31 +01:00
|
|
|
.It Xr MD5Init 3
|
|
|
|
.It Xr MD5Update 3
|
|
|
|
.It Xr MD5Pad 3
|
|
|
|
.It Xr MD5Final 3
|
|
|
|
.It Xr MD5Transform 3
|
|
|
|
.It Xr MD5End 3
|
|
|
|
.It Xr MD5File 3
|
|
|
|
.It Xr MD5FileChunk 3
|
|
|
|
.It Xr MD5Data 3
|
2021-02-07 00:09:30 +01:00
|
|
|
The set of MD5 digest functions are now proxies for the implementations
|
|
|
|
provided by the
|
2017-06-05 06:33:47 +02:00
|
|
|
.Nm libmd
|
2021-02-07 00:09:30 +01:00
|
|
|
companion library, so it is advised to switch to use that directly instead.
|
2024-01-08 23:40:31 +01:00
|
|
|
.It Xr explicit_bzero 3bsd
|
2017-09-02 19:55:50 +02:00
|
|
|
This function is provided by
|
|
|
|
.Nm glibc
|
2022-03-30 22:56:43 +02:00
|
|
|
2.25, and
|
|
|
|
.Nm musl
|
|
|
|
1.1.20.
|
2024-01-08 23:40:31 +01:00
|
|
|
.It Xr reallocarray 3bsd
|
2017-09-02 19:55:50 +02:00
|
|
|
This function is provided by
|
|
|
|
.Nm glibc
|
2022-03-30 22:56:43 +02:00
|
|
|
2.26, and
|
|
|
|
.Nm musl
|
|
|
|
1.2.2.
|
2024-01-08 23:39:19 +01:00
|
|
|
.It Xr closefrom 3bsd
|
|
|
|
This function is provided by
|
|
|
|
.Nm glibc
|
|
|
|
2.34.
|
2024-01-08 23:40:31 +01:00
|
|
|
.It Xr arc4random 3bsd
|
|
|
|
.It Xr arc4random_buf 3bsd
|
|
|
|
.It Xr arc4random_uniform 3bsd
|
2022-08-03 01:23:09 +02:00
|
|
|
These functions are provided by
|
|
|
|
.Nm glibc
|
|
|
|
2.36.
|
|
|
|
Note that it does not provide the
|
2024-01-08 23:40:31 +01:00
|
|
|
.Xr arc4random_stir 3bsd
|
2022-08-03 01:23:09 +02:00
|
|
|
and
|
2024-01-08 23:40:31 +01:00
|
|
|
.Xr arc4random_addrandom 3bsd
|
2022-08-03 01:23:09 +02:00
|
|
|
functions.
|
2024-01-08 23:39:19 +01:00
|
|
|
.It Xr strlcpy 3bsd
|
|
|
|
.It Xr strlcat 3bsd
|
|
|
|
These functions are provided by
|
|
|
|
.Nm glibc
|
|
|
|
2.38, and
|
|
|
|
.Nm musl
|
|
|
|
0.5.0.
|
2017-09-02 19:55:50 +02:00
|
|
|
.El
|
2017-06-05 06:33:47 +02:00
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr arc4random 3bsd ,
|
|
|
|
.Xr bitstring 3bsd ,
|
|
|
|
.Xr byteorder 3bsd ,
|
|
|
|
.Xr closefrom 3bsd ,
|
|
|
|
.Xr errc 3bsd ,
|
|
|
|
.Xr expand_number 3bsd ,
|
|
|
|
.Xr explicit_bzero 3bsd ,
|
|
|
|
.Xr fgetln 3bsd ,
|
|
|
|
.Xr fgetwln 3bsd ,
|
|
|
|
.Xr flopen 3bsd ,
|
|
|
|
.Xr fmtcheck 3bsd ,
|
|
|
|
.Xr fparseln 3bsd ,
|
|
|
|
.Xr fpurge 3bsd ,
|
|
|
|
.Xr funopen 3bsd ,
|
|
|
|
.Xr getbsize 3bsd ,
|
|
|
|
.Xr getpeereid 3bsd ,
|
|
|
|
.Xr getprogname 3bsd ,
|
|
|
|
.Xr heapsort 3bsd ,
|
|
|
|
.Xr humanize_number 3bsd ,
|
|
|
|
.Xr md5 3bsd ,
|
|
|
|
.Xr nlist 3bsd ,
|
|
|
|
.Xr pidfile 3bsd ,
|
2021-02-07 10:56:51 +01:00
|
|
|
.Xr pwcache 3bsd ,
|
2017-06-05 06:33:47 +02:00
|
|
|
.Xr queue 3bsd ,
|
|
|
|
.Xr radixsort 3bsd ,
|
|
|
|
.Xr readpassphrase 3bsd ,
|
|
|
|
.Xr reallocarray 3bsd ,
|
|
|
|
.Xr reallocf 3bsd ,
|
|
|
|
.Xr setmode 3bsd ,
|
|
|
|
.Xr setproctitle 3bsd ,
|
|
|
|
.Xr stringlist 3bsd ,
|
|
|
|
.Xr strlcpy 3bsd ,
|
|
|
|
.Xr strmode 3bsd ,
|
|
|
|
.Xr strnstr 3bsd ,
|
2018-05-21 00:20:49 +02:00
|
|
|
.Xr strtoi 3bsd ,
|
2017-06-05 06:33:47 +02:00
|
|
|
.Xr strtonum 3bsd ,
|
2018-05-21 00:20:49 +02:00
|
|
|
.Xr strtou 3bsd ,
|
2017-06-05 05:43:26 +02:00
|
|
|
.Xr timeradd 3bsd ,
|
|
|
|
.Xr timeval 3bsd ,
|
2017-06-05 06:33:47 +02:00
|
|
|
.Xr tree 3bsd ,
|
|
|
|
.Xr unvis 3bsd ,
|
|
|
|
.Xr vis 3bsd ,
|
|
|
|
.Xr wcslcpy 3bsd .
|
|
|
|
.Sh HISTORY
|
|
|
|
The
|
|
|
|
.Nm libbsd
|
|
|
|
project started in the Debian GNU/kFreeBSD port as a way to ease porting
|
|
|
|
code from FreeBSD to the GNU-based system.
|
|
|
|
Pretty early on it was generalized and a project created on FreeDesktop.org
|
|
|
|
for other distributions and projects to use.
|
|
|
|
.Pp
|
|
|
|
It is now distributed as part of most non-BSD distributions.
|